From mboxrd@z Thu Jan 1 00:00:00 1970 Return-Path: Received: from mx0b-001b2d01.pphosted.com (mx0b-001b2d01.pphosted.com [148.163.158.5]) by sourceware.org (Postfix) with ESMTPS id 951DA3858420 for ; Fri, 12 Apr 2024 14:47:45 +0000 (GMT) DMARC-Filter: OpenDMARC Filter v1.4.2 sourceware.org 951DA3858420 Authentication-Results: sourceware.org; dmarc=none (p=none dis=none) header.from=linux.ibm.com Authentication-Results: sourceware.org; spf=pass smtp.mailfrom=linux.ibm.com ARC-Filter: OpenARC Filter v1.0.0 sourceware.org 951DA3858420 Authentication-Results: server2.sourceware.org; arc=none smtp.remote-ip=148.163.158.5 ARC-Seal: i=1; a=rsa-sha256; d=sourceware.org; s=key; t=1712933268; cv=none; b=mVqI3o8VMZXuvQI12NVU3g53hjVB9HyCh1OJZ0fkOnWqxVtlCB1YLMtiADosJ9tqL+8W7269hZdSIXItpNPlHmFn2JcW9jjOOg0uZkmBGO5bNZXJCkoRA08+fwidOy1iYCwOkk6sVam9Osg3VVs/wAVmvL64nQ2z1xWy6DNbI3Y= ARC-Message-Signature: i=1; a=rsa-sha256; d=sourceware.org; s=key; t=1712933268; c=relaxed/simple; bh=yatUq0ki/+EG9dDV6DfNUECDF2Yiur08MA0jgi7LVsA=; h=DKIM-Signature:From:To:Subject:Date:Message-Id:MIME-Version; b=jADB5MMMNDCcp9jQcVgAY2lDh1H2LpAoQCxxsNTJ7fAM0EiZ2GYi7p4tAg5r10qw1wP06siXfGkDprNnrXnWqu4pnCJVo2avfOoTSgTSVZLBoxDWC7MWGfmFINn4tGyXYv/bKdH/iVyUzHYuky4ArNjgXQNCPNIc+FXJHl542Sg= ARC-Authentication-Results: i=1; server2.sourceware.org Received: from pps.filterd (m0353723.ppops.net [127.0.0.1]) by mx0a-001b2d01.pphosted.com (8.17.1.19/8.17.1.19) with ESMTP id 43CEgWDn001794; Fri, 12 Apr 2024 14:47:44 GMT DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=ibm.com; h=from : to : cc : subject : date : message-id : in-reply-to : references : mime-version : content-transfer-encoding; s=pp1; bh=mr9U5FKlHxdrtcMJVL8G8mJJY4/YkGVshkNC8nbztk4=; b=nydxSZFDJGKnOE6Wts4FT7gHIL49GmvMYnh6vbz9SUUScMqRpBEYSnC+xywhNtCTBYMA ycnGb/WVJyyqk/h7ZuUzdEG4GEUAAp0k8tIdt/1t2V6pBpHYp5BSrr2Ch0vvGRcmMnDA hCj6Q7Kb+2GmQWLNKhCsAp5ELhoA3TWWVr2hY88A+PQRgpVkzfTy+YHBCcLEeB0kosaG iBQJP6obFgi7PrAyWlJVzID2AqfgpiElDKTQt60yxhDyQHXNI2O0R1/AIsJePSEAIWov Y/NqL9NUzgUfz7/NPimsCKzVTA2/zuU9ttY5GvD0x3ru4eabGLiQUV2p+HYO4zDQB5lR ew== Received: from ppma21.wdc07v.mail.ibm.com (5b.69.3da9.ip4.static.sl-reverse.com [169.61.105.91]) by mx0a-001b2d01.pphosted.com (PPS) with ESMTPS id 3xf4pg8av6-1 (version=TLSv1.2 cipher=ECDHE-RSA-AES256-GCM-SHA384 bits=256 verify=NOT); Fri, 12 Apr 2024 14:47:43 +0000 Received: from pps.filterd (ppma21.wdc07v.mail.ibm.com [127.0.0.1]) by ppma21.wdc07v.mail.ibm.com (8.17.1.19/8.17.1.19) with ESMTP id 43CDwM9H022573; Fri, 12 Apr 2024 14:47:28 GMT Received: from smtprelay07.fra02v.mail.ibm.com ([9.218.2.229]) by ppma21.wdc07v.mail.ibm.com (PPS) with ESMTPS id 3xbhqpjdqu-1 (version=TLSv1.2 cipher=ECDHE-RSA-AES256-GCM-SHA384 bits=256 verify=NOT); Fri, 12 Apr 2024 14:47:28 +0000 Received: from smtpav02.fra02v.mail.ibm.com (smtpav02.fra02v.mail.ibm.com [10.20.54.101]) by smtprelay07.fra02v.mail.ibm.com (8.14.9/8.14.9/NCO v10.0) with ESMTP id 43CElMTZ53019028 (version=TLSv1/SSLv3 cipher=DHE-RSA-AES256-GCM-SHA384 bits=256 verify=OK); Fri, 12 Apr 2024 14:47:24 GMT Received: from smtpav02.fra02v.mail.ibm.com (unknown [127.0.0.1]) by IMSVA (Postfix) with ESMTP id AB4B42004E; Fri, 12 Apr 2024 14:47:22 +0000 (GMT) Received: from smtpav02.fra02v.mail.ibm.com (unknown [127.0.0.1]) by IMSVA (Postfix) with ESMTP id 8FC652004F; Fri, 12 Apr 2024 14:47:22 +0000 (GMT) Received: from tuxmaker.boeblingen.de.ibm.com (unknown [9.152.85.9]) by smtpav02.fra02v.mail.ibm.com (Postfix) with ESMTP; Fri, 12 Apr 2024 14:47:22 +0000 (GMT) From: Jens Remus To: binutils@sourceware.org, Indu Bhagat Cc: Jens Remus , Andreas Krebbel Subject: [PATCH v3 02/15] gas: Enhance arch-specific SFrame configuration descriptions Date: Fri, 12 Apr 2024 16:47:05 +0200 Message-Id: <20240412144718.4191286-3-jremus@linux.ibm.com> X-Mailer: git-send-email 2.40.1 In-Reply-To: <20240412144718.4191286-1-jremus@linux.ibm.com> References: <20240412144718.4191286-1-jremus@linux.ibm.com> MIME-Version: 1.0 Content-Transfer-Encoding: 8bit X-TM-AS-GCONF: 00 X-Proofpoint-GUID: jmX-MjV2iw1AxiSZGoIf9KJsy6VXuk2W X-Proofpoint-ORIG-GUID: jmX-MjV2iw1AxiSZGoIf9KJsy6VXuk2W X-Proofpoint-Virus-Version: vendor=baseguard engine=ICAP:2.0.272,Aquarius:18.0.1011,Hydra:6.0.619,FMLib:17.11.176.26 definitions=2024-04-12_11,2024-04-09_01,2023-05-22_02 X-Proofpoint-Spam-Details: rule=outbound_notspam policy=outbound score=0 mlxscore=0 bulkscore=0 adultscore=0 suspectscore=0 clxscore=1015 phishscore=0 mlxlogscore=999 impostorscore=0 spamscore=0 malwarescore=0 lowpriorityscore=0 priorityscore=1501 classifier=spam adjust=0 reason=mlx scancount=1 engine=8.12.0-2404010000 definitions=main-2404120107 X-Spam-Status: No, score=-12.3 required=5.0 tests=BAYES_00,DKIM_SIGNED,DKIM_VALID,DKIM_VALID_EF,GIT_PATCH_0,RCVD_IN_MSPIKE_H4,RCVD_IN_MSPIKE_WL,SPF_HELO_NONE,SPF_PASS,TXREP autolearn=ham autolearn_force=no version=3.4.6 X-Spam-Checker-Version: SpamAssassin 3.4.6 (2021-04-09) on server2.sourceware.org List-Id: Explicitly mention "SFrame" in the descriptions for the architecture- specific SFrame configuration macros, variables, and functions. Use the term "frame pointer" (FP) instead of "base pointer". This aligns with the terminology used in the SFrame specification. Additionally it helps not to confuse "base-pointer register" with the term "BASE_REG" used in the specification to denote either the SP or FP register. Specify what the SFRAME_CFA_*_REG register numbers are used for: - SP (stack pointer): CFA tracking - FP (frame pointer): CFA and FP tracking - RA (return address): RA tracking Align the descriptions for definitions in the source files to the declarations in the header files. gas/ * config/tc-aarch64.h: Enhance architecture-specific SFrame configuration descriptions. * config/tc-aarch64.c: Likewise. * config/tc-i386.h: Likewise. * config/tc-i386.c: Likewise. Signed-off-by: Jens Remus --- Notes (jremus): Changes v2 -> v3: - Add "SFrame" to architecture-specific SFrame macro, variable, and function descriptions as suggested by Indu. Do so for all and not only those previously touched. - Reword further SFrame macro, variable, and function descriptions to align with those previously touched. - Align description of definition in source with declaration in header. - Corrected formatting of ChangeLog in commit message. - Changed commit subject prefix from "sframe" to "gas". gas/config/tc-aarch64.c | 6 +++--- gas/config/tc-aarch64.h | 12 ++++++------ gas/config/tc-i386.c | 5 +++++ gas/config/tc-i386.h | 10 +++++----- 4 files changed, 19 insertions(+), 14 deletions(-) diff --git a/gas/config/tc-aarch64.c b/gas/config/tc-aarch64.c index 6ad4fae8b0ec..077cbd485979 100644 --- a/gas/config/tc-aarch64.c +++ b/gas/config/tc-aarch64.c @@ -8870,7 +8870,7 @@ aarch64_support_sframe_p (void) return (aarch64_abi == AARCH64_ABI_LP64); } -/* Specify if RA tracking is needed. */ +/* Whether SFrame return-address tracking is needed. */ bool aarch64_sframe_ra_tracking_p (void) @@ -8878,8 +8878,8 @@ aarch64_sframe_ra_tracking_p (void) return true; } -/* Specify the fixed offset to recover RA from CFA. - (useful only when RA tracking is not needed). */ +/* The fixed offset from CFA for SFrame to recover the return address. + (useful only when SFrame RA tracking is not needed). */ offsetT aarch64_sframe_cfa_ra_offset (void) diff --git a/gas/config/tc-aarch64.h b/gas/config/tc-aarch64.h index 1b8badad9fdc..63acbd46a379 100644 --- a/gas/config/tc-aarch64.h +++ b/gas/config/tc-aarch64.h @@ -267,24 +267,24 @@ extern void aarch64_after_parse_args (void); extern bool aarch64_support_sframe_p (void); #define support_sframe_p aarch64_support_sframe_p -/* The stack-pointer register number for SFrame stack trace info. */ +/* The stack-pointer DWARF register number for SFrame CFA tracking. */ extern unsigned int aarch64_sframe_cfa_sp_reg; #define SFRAME_CFA_SP_REG aarch64_sframe_cfa_sp_reg -/* The base-pointer register number for CFA stack trace info. */ +/* The frame-pointer DWARF register number for SFrame CFA and FP tracking. */ extern unsigned int aarch64_sframe_cfa_fp_reg; #define SFRAME_CFA_FP_REG aarch64_sframe_cfa_fp_reg -/* The return address register number for CFA stack trace info. */ +/* The return-address DWARF register number for SFrame RA tracking. */ extern unsigned int aarch64_sframe_cfa_ra_reg; #define SFRAME_CFA_RA_REG aarch64_sframe_cfa_ra_reg -/* Specify if RA tracking is needed. */ +/* Whether SFrame return-address tracking is needed. */ extern bool aarch64_sframe_ra_tracking_p (void); #define sframe_ra_tracking_p aarch64_sframe_ra_tracking_p -/* Specify the fixed offset to recover RA from CFA. - (useful only when RA tracking is not needed). */ +/* The fixed offset from CFA for SFrame to recover the return address. + (useful only when SFrame RA tracking is not needed). */ extern offsetT aarch64_sframe_cfa_ra_offset (void); #define sframe_cfa_ra_offset aarch64_sframe_cfa_ra_offset diff --git a/gas/config/tc-i386.c b/gas/config/tc-i386.c index cd20e0c9415e..08a8eb2aeb69 100644 --- a/gas/config/tc-i386.c +++ b/gas/config/tc-i386.c @@ -11181,6 +11181,7 @@ x86_cleanup (void) subseg_set (seg, subseg); } +/* Whether SFrame stack trace info is supported. */ bool x86_support_sframe_p (void) { @@ -11188,6 +11189,7 @@ x86_support_sframe_p (void) return (x86_elf_abi == X86_64_ABI); } +/* Whether SFrame return-address tracking is needed. */ bool x86_sframe_ra_tracking_p (void) { @@ -11197,6 +11199,8 @@ x86_sframe_ra_tracking_p (void) return false; } +/* The fixed offset from CFA for SFrame to recover the return address. + (useful only when SFrame RA tracking is not needed). */ offsetT x86_sframe_cfa_ra_offset (void) { @@ -11204,6 +11208,7 @@ x86_sframe_cfa_ra_offset (void) return (offsetT) -8; } +/* The abi/arch indentifier for SFrame. */ unsigned char x86_sframe_get_abi_arch (void) { diff --git a/gas/config/tc-i386.h b/gas/config/tc-i386.h index 7aae7a33dc14..e98362111698 100644 --- a/gas/config/tc-i386.h +++ b/gas/config/tc-i386.h @@ -441,20 +441,20 @@ extern bool x86_scfi_callee_saved_p (uint32_t dw2reg_num); extern bool x86_support_sframe_p (void); #define support_sframe_p x86_support_sframe_p -/* The stack-pointer register number for SFrame stack trace info. */ +/* The stack-pointer DWARF register number for SFrame CFA tracking. */ extern unsigned int x86_sframe_cfa_sp_reg; #define SFRAME_CFA_SP_REG x86_sframe_cfa_sp_reg -/* The frame-pointer register number for SFrame stack trace info. */ +/* The frame-pointer DWARF register number for SFrame CFA and FP tracking. */ extern unsigned int x86_sframe_cfa_fp_reg; #define SFRAME_CFA_FP_REG x86_sframe_cfa_fp_reg -/* Specify if RA tracking is needed. */ +/* Whether SFrame return-address tracking is needed. */ extern bool x86_sframe_ra_tracking_p (void); #define sframe_ra_tracking_p x86_sframe_ra_tracking_p -/* Specify the fixed offset to recover RA from CFA. - (useful only when RA tracking is not needed). */ +/* The fixed offset from CFA for SFrame to recover the return address. + (useful only when SFrame RA tracking is not needed). */ extern offsetT x86_sframe_cfa_ra_offset (void); #define sframe_cfa_ra_offset x86_sframe_cfa_ra_offset -- 2.40.1