]> git.ipfire.org Git - thirdparty/gcc.git/commitdiff
LoongArch: Delete macro definition ASM_OUTPUT_ALIGN_WITH_NOP.
authorLulu Cheng <chenglulu@loongson.cn>
Fri, 15 Sep 2023 03:56:01 +0000 (11:56 +0800)
committerLulu Cheng <chenglulu@loongson.cn>
Tue, 17 Oct 2023 01:59:11 +0000 (09:59 +0800)
There are two reasons for removing this macro definition:
1. The default in the assembler is to use the nop instruction for filling.
2. For assembly directives: .align [abs-expr[, abs-expr[, abs-expr]]]
   The third expression it is the maximum number of bytes that should be
   skipped by this alignment directive.
   Therefore, it will affect the display of the specified alignment rules
   and affect the operating efficiency.

This modification relies on binutils commit 1fb3cdd87ec61715a5684925fb6d6a6cf53bb97c.
(Since the assembler will add nop based on the .align information when doing relax,
it will cause the conditional branch to go out of bounds during the assembly process.
This submission of binutils solves this problem.)

gcc/ChangeLog:

* config/loongarch/loongarch.h (ASM_OUTPUT_ALIGN_WITH_NOP):
Delete.

Co-authored-by: Chenghua Xu <xuchenghua@loongson.cn>
gcc/config/loongarch/loongarch.h

index 19a18fb5f1b47c8a687a32b58841713aaabc0753..da3ec2add9ad6d967a3803e67e376dc3d669c10b 100644 (file)
@@ -1058,11 +1058,6 @@ typedef struct {
 
 #define ASM_OUTPUT_ALIGN(STREAM, LOG) fprintf (STREAM, "\t.align\t%d\n", (LOG))
 
-/* "nop" instruction 54525952 (andi $r0,$r0,0) is
-   used for padding.  */
-#define ASM_OUTPUT_ALIGN_WITH_NOP(STREAM, LOG) \
-  fprintf (STREAM, "\t.align\t%d,54525952,4\n", (LOG))
-
 /* This is how to output an assembler line to advance the location
    counter by SIZE bytes.  */