From mboxrd@z Thu Jan 1 00:00:00 1970 Return-Path: Received: from mx0b-00069f02.pphosted.com (mx0b-00069f02.pphosted.com [205.220.177.32]) by sourceware.org (Postfix) with ESMTPS id 965123852779 for ; Tue, 14 Jun 2022 20:44:50 +0000 (GMT) DMARC-Filter: OpenDMARC Filter v1.4.1 sourceware.org 965123852779 Received: from pps.filterd (m0246631.ppops.net [127.0.0.1]) by mx0b-00069f02.pphosted.com (8.17.1.5/8.17.1.5) with ESMTP id 25EKSiLZ027180 for ; Tue, 14 Jun 2022 20:44:50 GMT Received: from phxpaimrmta01.imrmtpd1.prodappphxaev1.oraclevcn.com (phxpaimrmta01.appoci.oracle.com [138.1.114.2]) by mx0b-00069f02.pphosted.com (PPS) with ESMTPS id 3gmhu2pyva-1 (version=TLSv1.2 cipher=ECDHE-RSA-AES256-GCM-SHA384 bits=256 verify=OK) for ; Tue, 14 Jun 2022 20:44:50 +0000 Received: from pps.filterd (phxpaimrmta01.imrmtpd1.prodappphxaev1.oraclevcn.com [127.0.0.1]) by phxpaimrmta01.imrmtpd1.prodappphxaev1.oraclevcn.com (8.16.1.2/8.16.1.2) with SMTP id 25EKa9Er030558 for ; Tue, 14 Jun 2022 20:44:49 GMT Received: from nam11-dm6-obe.outbound.protection.outlook.com (mail-dm6nam11lp2170.outbound.protection.outlook.com [104.47.57.170]) by phxpaimrmta01.imrmtpd1.prodappphxaev1.oraclevcn.com with ESMTP id 3gpqq0jvk6-1 (version=TLSv1.2 cipher=ECDHE-RSA-AES256-GCM-SHA384 bits=256 verify=OK) for ; Tue, 14 Jun 2022 20:44:49 +0000 ARC-Seal: i=1; a=rsa-sha256; s=arcselector9901; d=microsoft.com; cv=none; b=hHS/CfoHoFE2YTtH6M7hT1XMKfI6jskLPRZpLqsWwS0kIKUM+dHE6l9vfxD2/QGqHtrtnEiGSHmeClpKUCg0GqTWrXSs2ri8oN4k9spj0pyHKajmrkeK7sU01niGUalVH9Axp9+5mQ4P8a1iedyHZWcJVHBd5bvLnakO4dZYcfSRuNicOuNvTndJr4Fz0bvHW51fN1G1igG3yT6UyA9dmkDT+jYauPvW+LVgD5JyW5Z0VqcU+0KFCXhgZ+c5I+lwyw5POLr6qCXVhSFUrhxQ5RS20OhAV2d1cqqwyxmKqSmVRY+v57cPQ2zNJOkHTTkcMvdfS2/vWZ46KO0WWNTu8A== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=microsoft.com; s=arcselector9901; h=From:Date:Subject:Message-ID:Content-Type:MIME-Version:X-MS-Exchange-AntiSpam-MessageData-ChunkCount:X-MS-Exchange-AntiSpam-MessageData-0:X-MS-Exchange-AntiSpam-MessageData-1; bh=jbACBnd7kQLh+6DKYI26IIp3FQEdwzPv2GoNP6nx2e4=; b=Q7GJ30slN5kAwc1ZwnxmT4DI7SaYiyZ3/aPp3ejcTsXauLaW2knEISfw9oRUjZdE6HJsHSt8RWcj/t8A6r9NImIS7e5M0LHl+0qp+THfNr3g7plBvcPOJrW/jVqa+jgQ7FTMxHzPi6ws/MZEZWRrW1f56B+N6wUh16OlU62RcVWBhWA8sdqigYtkCiDgb1aX8UBtaGpw0VFw70WyTxo9S6NEmtJC9frDvmNQOclCzvQu/N/fotUrCHyAa6pY4re57vpX2AOoVuDC4c62myXw4he3bLHMM/dCWQ4XfCpiqld6ircTyDcmJTX101O3ZCgCt1LrXLfX/9f/XegZAVcv+A== ARC-Authentication-Results: i=1; mx.microsoft.com 1; spf=pass smtp.mailfrom=oracle.com; dmarc=pass action=none header.from=oracle.com; dkim=pass header.d=oracle.com; arc=none Received: from MWHPR1001MB2158.namprd10.prod.outlook.com (2603:10b6:301:2d::17) by MWHPR1001MB2398.namprd10.prod.outlook.com (2603:10b6:301:2f::37) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.20.5332.20; Tue, 14 Jun 2022 20:44:47 +0000 Received: from MWHPR1001MB2158.namprd10.prod.outlook.com ([fe80::8862:60b0:854d:7251]) by MWHPR1001MB2158.namprd10.prod.outlook.com ([fe80::8862:60b0:854d:7251%6]) with mapi id 15.20.5332.022; Tue, 14 Jun 2022 20:44:46 +0000 Subject: Re: [PATCH,RFC,V3 0/8] Definition and Implementation of CTF Frame format From: Indu Bhagat To: binutils@sourceware.org References: <20220614070652.1608873-1-indu.bhagat@oracle.com> Message-ID: Date: Tue, 14 Jun 2022 13:44:45 -0700 User-Agent: Mozilla/5.0 (X11; Linux x86_64; rv:78.0) Gecko/20100101 Thunderbird/78.6.1 In-Reply-To: <20220614070652.1608873-1-indu.bhagat@oracle.com> Content-Type: text/plain; charset=utf-8; format=flowed Content-Language: en-US Content-Transfer-Encoding: 8bit X-ClientProxiedBy: MW4P221CA0014.NAMP221.PROD.OUTLOOK.COM (2603:10b6:303:8b::19) To MWHPR1001MB2158.namprd10.prod.outlook.com (2603:10b6:301:2d::17) MIME-Version: 1.0 X-MS-PublicTrafficType: Email X-MS-Office365-Filtering-Correlation-Id: d45e537d-857e-4cb5-6aab-08da4e46b7ec X-MS-TrafficTypeDiagnostic: MWHPR1001MB2398:EE_ X-Microsoft-Antispam-PRVS: X-MS-Exchange-SenderADCheck: 1 X-MS-Exchange-AntiSpam-Relay: 0 X-Microsoft-Antispam: BCL:0; X-Microsoft-Antispam-Message-Info: lvAgOAwiMyilmHljJHT+XpkzDVRyoB3qUYY/aw1BBOcD9FAcTwjdL/Pjfn/E2M+NuZLbuBjXFy30mBDNemCDfX7PcpMz9KlCdYhOfRJgly9/327q4sG3ZeHHJmJLUqv7GnbqY6z45eAjcCNuA92v1Q09UzG0QGqRPKD44a1M2Wl06udNuOM00sFY++yGTueWU4G38UUS+T2UvAVN4bGrkVcmezq4x/Gluw/p1IvELgqb05eYvEkp8iIwDpLCmUiTprqOqXkSEij5BS2TUid5sTPHb+C6RkvTis2x4+GheXI4T4gxNB18ZvEAmr5e7yL7HS6Q7ehRd6OjdjxX2hjiKcFxuozOtt4gU9+/Vvw7XmyJleI9GBkKTfu+dVLH582Zq9nq/+XKA25oh6mg1dSpjbrQ+vWubD5xpxrtt0QsykovS1EHs9GyHAcleVHYcuWcIKJzCuvrjZV4EWmEkxy5Ukq+f4Q8gyobMZElp/2pBFtWtoGE3QasLWQbuE0B/dBVyZapa5Uru+w+2qrOCalBiA7DjKcAuS/fkLEUtGrh+8jYBlBeE3DUtXi0Z5PO5xxtZlfD6qey8bfrsPbGe58FM1A13SvNprtYQ/p8fzMWAW/fQgvh5rue5ip1lmfHQXXgynEElgguqgScgIiuYI5uide/s6HchWa4YOPcO16TQoIakLAFW0oIrgbEJJV7lyZI7hpe8UtSyqP9BkCwI5eQGgSLm+OudvTKTwzSIoVoxMQmfKbJ1X1WY/wxtIigqR2ct6AyhaeFpq1P4gIwxLFIQHuuK9MyxpFiYflONHJ2e2wBuP9aW6J7OuWFxS8FqEKCkn9tsE7tCfAFRv/O0mW1NxkZHwW9LyDamKPJgkfWutY= X-Forefront-Antispam-Report: CIP:255.255.255.255; CTRY:; LANG:en; SCL:1; SRV:; IPV:NLI; SFV:NSPM; H:MWHPR1001MB2158.namprd10.prod.outlook.com; PTR:; CAT:NONE; SFS:(13230016)(366004)(26005)(186003)(6506007)(53546011)(66556008)(2616005)(6512007)(38100700002)(31696002)(86362001)(83380400001)(6916009)(8936002)(508600001)(6486002)(44832011)(316002)(5660300002)(31686004)(36756003)(2906002)(66946007)(8676002)(66476007)(966005)(45980500001)(43740500002); DIR:OUT; SFP:1101; X-MS-Exchange-AntiSpam-MessageData-ChunkCount: 1 X-MS-Exchange-AntiSpam-MessageData-0: =?utf-8?B?OWRobHVUK204OTZ4bXpyRS9DMlBwYWtkQzY0MTVLYlpPMnhkS2J5ZFQwenA0?= =?utf-8?B?MldmdVZvdTk2MmRJdTRKTFJCQkFsQ1EzQVFoWFNzL3BKdmtEcTZoTFlBQ3p4?= =?utf-8?B?NEtJOXpTekVZZHJZUG1vK3lweU1pUnhxSVAyemswVGFVbkJPU2FXUCt3VW95?= =?utf-8?B?UDdwN3VBSGtGS282R1dMUmhnU2pENTROQkJMcDdhdko2TnU4d1lFekVCV1NR?= =?utf-8?B?VEtiVDBWR0F6ZEpjbytBbURvekI3MWZ0aEZqTTNydUZlSjdOQWozSWpqQjVy?= =?utf-8?B?Rm44YTlZRTZETVl5OWdIM0ZJNm1sTGRvZ0FQWklNVjZ4R3JDa1pXTEwva05Z?= =?utf-8?B?RFBXV1RUV2NrR0Z6UGViUi9yTFNxaXBFeUNtMTBnd2hzOThLR0lFNU1jZ1dr?= =?utf-8?B?NFJid3Z4eE4xSHdFbU1ZclJ1cmpOMmhSTFZ2OHZYaTlJRjc2Um1xS0psVERC?= =?utf-8?B?aUJwMzRKWjQzZjM4eVFCWGsxRUVUL2NMK2pROW5QNlBoTktubDBoOFp5U3Vk?= =?utf-8?B?SS9OQUlGcmJFZHB4MVh3bHNHRjk2T0pqQ041NzZSZkVaRFNsdDFOTG1ieVE4?= =?utf-8?B?b2VadzREVDhVcGlkK0tvRVNBNmVyYWI2S0kvZkorM3ovYzc3V2U0d0FGeEFG?= =?utf-8?B?c2pjSTRKckVnNVNxSWt2YjRWTEpZNDh2MjYwbWthWlpBUUlBeE5YNTJJei9j?= =?utf-8?B?RUFJQlVXT2dBWU0wWGdUdGc4bXc1M0RDVkRHVFhHb0RScXBJeTJiS3JKVVZB?= =?utf-8?B?UHlIYkxjR0MxT241eHUyZ0cwUVRJK2ovaE5DN0p0SzlyUFlaYjU1VDhCQmZs?= =?utf-8?B?T3QvSC80SHRBb056d242RjQwVFFvaHI4dC8yaGc3aGJpSkxFWFZJOEpNOXNM?= =?utf-8?B?akRzUWtuRTlKTldjWUtxVFBnYWgzR0ZPNk56ZUsyYjBzUkJZdkpBL3kwSVZw?= =?utf-8?B?WWNxTEE1OUpKZkFCckk4UFdWcUVZRFdWQlhSVmlVUHNjaVB4TDY1d0JGVmRm?= =?utf-8?B?STNXREs2WXhBRXlDZ2dFL1RxMVlaUTVMS2hBanJieWNaeXhsMDU5ZGJoT2FO?= =?utf-8?B?aWRueWIxMkdnNEl6V0gzU0tIanNpcURoeDVFelRnd2Fnc2M3TUZLZEdmVHda?= =?utf-8?B?dWNrRVNvUHdVeHkxb2prQnd0RWRhZDA2ZVhsWStPUnEySTVKMmxjZWpWUkZU?= =?utf-8?B?anJ1MXhweFZEWHRGSFM5MkF4RFkzTktLRloyWE5mY2U1dGkzaEs1SjhZcEx2?= =?utf-8?B?NHIxS0xsZW9LSzZjb0RFTTBGV05Vc3NjNDVvb0k1eUg0cVQvSGNVdEtzNERz?= =?utf-8?B?OTBSNnRmRDRzdGFDcEFnc2FmRHZjWHg5Zm1oWHFOdjVncm9ZMVd2Q3pzZjZ0?= =?utf-8?B?ZEI2NXBBaXFWWHllQnYrK2lLNjFzSXovbTM0RWFaTDdwd1RBVmtEZ0hlWElX?= =?utf-8?B?S08zL2w4bThmTFEvbEhKbHllaHUzUWg4bWhTa05yV0wzSFM0V2RBVXdZbm45?= =?utf-8?B?LzVtc21Oc2ZPN1J3RC9HZmk1b0NJS010Ly9IT2NPRGF0WkN6ZlJKMmp0cXR4?= =?utf-8?B?dEpiMGZLMUl5cFNyR0tKeXBIRkZLOWw4OXJIbkdHZXRKMU1NN0E3bVc4RVRy?= =?utf-8?B?L1BCcmlVbTJ5eHN3em5NdVlzbHJ0L1p1a0JCWTFKdWJicW1zS0tUWDZsMlFw?= =?utf-8?B?U0ZjK2diWUZsTy9VZitNRkxUZDRXZmgxT2R4VjdVVUgzc0hJRENhRGJGeHVB?= =?utf-8?B?U3VHRzZGUGVRY1lFN0tKVkJ2alpYSFZLdVpsMnV1ZWtwZEtzeHV0NXY0S1BL?= =?utf-8?B?SlZOaCttN2d0SEUrOURpNUllWkVLajRnYmFBVHVHekl3LzZsTXVja3Myek1a?= =?utf-8?B?ZmJpa3FNRkl2MVdEQ1lYUXdQc3cvaVhvMEtuU3dQdWNKZ0UzQm03T2o5QURP?= =?utf-8?B?Y1JCWlQrd0tzM01ZTkJ1cVBkazhlZkhVTFJVSjZub1Z1WTdOd0Rmb0dRSUlZ?= =?utf-8?B?aFNkV0xadkp5V3R3UEtkK1ZnSVdKamx2U3RYdUV6aU1QcXYyMi9VaXpwTEVi?= =?utf-8?B?RklpSEdqV1AvdU5rbDFQelVLOFgvQmgrUFJSUVRWS1hJc2poWGtKdEhoSHA2?= =?utf-8?B?M3lBemhyTEFwNG8yenk2MDJYTjE4YTVoWUt6VWZuUk5nVGRRa3JOQWc5NmpC?= =?utf-8?B?YzRnTTkyU1FmY3RBQ2JuRVduY25GNG1UeHhqTGdtZ1NUNkhDaExTTDlkeWxy?= =?utf-8?B?bUgxM1pVbXVCZ0ltQzZ4T2hCWmZLcVNER0Q1WDA5aWUwMFhBQm44eUpVRXdJ?= =?utf-8?B?ZmxoSmVCbHE1Q2NteFVqaFdMck00WVY4RE9heUZXbGVpZERxbU9yVENZNWlC?= =?utf-8?Q?M+U2jWEX6LzvXIi4=3D?= X-OriginatorOrg: oracle.com X-MS-Exchange-CrossTenant-Network-Message-Id: d45e537d-857e-4cb5-6aab-08da4e46b7ec X-MS-Exchange-CrossTenant-AuthSource: MWHPR1001MB2158.namprd10.prod.outlook.com X-MS-Exchange-CrossTenant-AuthAs: Internal X-MS-Exchange-CrossTenant-OriginalArrivalTime: 14 Jun 2022 20:44:46.8779 (UTC) X-MS-Exchange-CrossTenant-FromEntityHeader: Hosted X-MS-Exchange-CrossTenant-Id: 4e2c6054-71cb-48f1-bd6c-3a9705aca71b X-MS-Exchange-CrossTenant-MailboxType: HOSTED X-MS-Exchange-CrossTenant-UserPrincipalName: BmuRfY2umjffySt9xk7ajdSArFZtSZwKE73T6OOdxc5qdPlH2is9Nz7lND1GkLMUzMQFt7Bq7dOUjVfXSP+x/w== X-MS-Exchange-Transport-CrossTenantHeadersStamped: MWHPR1001MB2398 X-Proofpoint-Virus-Version: vendor=fsecure engine=2.50.10434:6.0.517, 18.0.874 definitions=2022-06-14_09:2022-06-13, 2022-06-14 signatures=0 X-Proofpoint-Spam-Details: rule=notspam policy=default score=0 malwarescore=0 mlxlogscore=999 bulkscore=0 spamscore=0 phishscore=0 adultscore=0 suspectscore=0 mlxscore=0 classifier=spam adjust=0 reason=mlx scancount=1 engine=8.12.0-2204290000 definitions=main-2206140074 X-Proofpoint-GUID: XLd7KyJ3eo_7vSzyiFQ47hXzlUwllgia X-Proofpoint-ORIG-GUID: XLd7KyJ3eo_7vSzyiFQ47hXzlUwllgia X-Spam-Status: No, score=-7.7 required=5.0 tests=BAYES_00, DKIM_SIGNED, DKIM_VALID, DKIM_VALID_AU, DKIM_VALID_EF, NICE_REPLY_A, RCVD_IN_DNSWL_LOW, RCVD_IN_MSPIKE_H2, SPF_HELO_NONE, SPF_NONE, TXREP, T_SCC_BODY_TEXT_LINE autolearn=ham autolearn_force=no version=3.4.6 X-Spam-Checker-Version: SpamAssassin 3.4.6 (2021-04-09) on server2.sourceware.org X-BeenThere: binutils@sourceware.org X-Mailman-Version: 2.1.29 Precedence: list List-Id: Binutils mailing list List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , X-List-Received-Date: Tue, 14 Jun 2022 20:44:52 -0000 On 6/14/22 12:06 AM, Indu Bhagat wrote: > Hello, > > This is version 3 of the previously sent RFC series. > > Initial (V1) posting contains necessary introductions: > https://sourceware.org/pipermail/binutils/2022-May/120731.html > V2 posting with some improvements: > https://sourceware.org/pipermail/binutils/2022-May/120899.html > In addition to the above, here are few little notes which can hopefully help with the review and feedback on the CTF Frame format. This is a quick high-level snapshot of what CTF Frame section looks like and how to try it out with this patch series. $ cat a.c static int cnt; int foo (int a) { return a++; } int bar (int b) { return foo (b * 5); } int main() { cnt++; return bar (cnt); } Pass --gctf-frame option to the assembler to emit a .ctf_frame section.  GAS uses the .cfi_* directives embedded by the compiler to generate the .ctf_frame section. The support for gas option --gctf-frame and readelf option --ctf-frame=.ctf_frame is provided in this patch series. $ gcc -c -Wa,--gctf-frame a.c Lets dump .eh_frame just for sake of understanding the whole picture. $ readelf --debug=frames-interp a.o 00000000 0000000000000014 00000000 CIE "zR" cf=1 df=-8 ra=16    LOC           CFA      ra 0000000000000000 rsp+8    c-8 00000018 000000000000001c 0000001c FDE cie=00000000 pc=0000000000000000..0000000000000012    LOC           CFA      rbp   ra 0000000000000000 rsp+8    u     c-8 0000000000000001 rsp+16   c-16  c-8 0000000000000004 rbp+16   c-16  c-8 0000000000000011 rsp+8    c-16  c-8 00000038 000000000000001c 0000003c FDE cie=00000000 pc=0000000000000012..0000000000000030    LOC           CFA      rbp   ra 0000000000000012 rsp+8    u     c-8 0000000000000013 rsp+16   c-16  c-8 0000000000000016 rbp+16   c-16  c-8 000000000000002f rsp+8    c-16  c-8 00000058 000000000000001c 0000005c FDE cie=00000000 pc=0000000000000030..0000000000000052    LOC           CFA      rbp   ra 0000000000000030 rsp+8    u     c-8 0000000000000031 rsp+16   c-16  c-8 0000000000000034 rbp+16   c-16  c-8 0000000000000051 rsp+8    c-16  c-8 $readelf --ctf-frame=.ctf_frame a.o output is as follows (with hand-marked annotations with @@ for illustration only @@) : ...     Version: CTF_FRAME_VERSION_1     Flags: NONE     Num FDEs: 3     Num FREs: 12   Function Index :     func idx [0]: pc = 0x0, size = 18 bytes     @@ FDE 1 @@     STARTPC           CFA       FP        RA     0000000000000000  sp+8      u         u         @@ FRE 1 @@     0000000000000001  sp+16     c-16      u         @@ FRE 2 @@     0000000000000004  fp+16     c-16      u         @@ FRE 3 @@     0000000000000011  sp+8      c-16      u         @@ FRE 4 @@     func idx [1]: pc = 0x0, size = 30 bytes         @@ FDE 1 @@     STARTPC           CFA       FP        RA     0000000000000000  sp+8      u         u         @@ FRE 5 @@     0000000000000001  sp+16     c-16      u         @@ FRE 6 @@     0000000000000004  fp+16     c-16      u         @@ FRE 7 @@     000000000000001d  sp+8      c-16      u         @@ FRE 8 @@     func idx [2]: pc = 0x0, size = 34 bytes         @@ FDE 1 @@     STARTPC           CFA       FP        RA     0000000000000000  sp+8      u         u         @@ FRE 9 @@     0000000000000001  sp+16     c-16      u         @@ FRE 10 @@     0000000000000004  fp+16     c-16      u         @@ FRE 11 @@     0000000000000021  sp+8      c-16      u         @@ FRE 12 @@ .ctf_frame section in an object is relocated at link-time as usual. $ readelf --relocs a.o ... Relocation section '.rela.ctf_frame' at offset 0x388 contains 3 entries:   Offset          Info           Type           Sym. Value    Sym. Name + Addend 00000000001b  000200000002 R_X86_64_PC32     0000000000000000 .text + 0 00000000002c  000200000002 R_X86_64_PC32     0000000000000000 .text + 12 00000000003d  000200000002 R_X86_64_PC32     0000000000000000 .text + 30 Notes: 1. .ctf_frame information is for tracking CFA, FP, RA only. Although not apparent in the dump of .eh_frame here, but .eh_frame tracks the applicable set of callee-saved registers as well per function. 2. FDE = Function Descriptor entry, one per function. FRE = Frame Row Entry. 3. An FRE is a self-sufficient entity that can be used to infer the unwind information for a group of contiguous PCs. 4. In the final linked artifact, the output .ctf_frame section has FDEs in sorted order of their start PC.  This helps in using binary search for looking up the FDE.  For each FDE, the FREs are sorted in order of the PC of instructions. The CTF Frame header file will also be a helpful resource for understanding the format. > The commit log of each patch in the current patch series specifies the changes > from the version V2 of the respective patch. Briefly, following are the main > changes in the current version V3 as compared to V2: > > 1. Testsuites for gas, ld, libctfframe. > 2. Some code cleanup, improvements and bugfixes. > > This is a work in progress. In the subsequent iterations of the series, I plan > to focus on the bloat caused by the CTF Frame unwind information for the plt* > entries on x86_64 and enhance the testsuite for CTF Frame. > > Important note: libctfframe/configure has NOT been included in the patch > series, as it causes the size of some patches to go beyond the allowed limit. > Please regenerate the libctfframe/configure after applying the series. > > Please comment and provide feedback, it will help shape the format. At this > time, I really need some inputs on: > > 1. What is a good place for an unwinder based on CTF Frame format ? Currently > to facilitate discussion, it is presented in a library of its own: > libctfbacktrace which, in turn, uses the libctfframe library for decoding the > .ctf_frame section for unwinding. We brainstormed a bit about the possible > candidates being libbacktace, libgcc or libunwind ? Are there any > recommendations ? > > Thanks, > > Indu Bhagat (6): > ctf-frame.h: Add CTF Frame format definition > gas: add new command line option --gctf-frame > gas: generate .ctf_frame > bfd: linker: merge .ctf_frame sections > readelf/objdump: support for CTF Frame section > gdb: sim: buildsystem changes to accommodate libctfframe > > Weimin Pan (2): > libctfframe: add the CTF Frame library > unwinder: generate backtrace using CTF Frame format