]> git.ipfire.org Git - thirdparty/binutils-gdb.git/commitdiff
gas: change meaning of ; in the BPF assembler
authorJose E. Marchesi <jose.marchesi@oracle.com>
Tue, 28 Nov 2023 10:58:58 +0000 (11:58 +0100)
committerJose E. Marchesi <jose.marchesi@oracle.com>
Tue, 28 Nov 2023 14:01:18 +0000 (15:01 +0100)
The BPF assembler in clang uses semi-colon (;) to separate statements,
not to be begin line comments.  This patch adapts the GNU assembler
accordingly.

Testsuite and documentation updated accordingly.

2023-11-28  Jose E. Marchesi  <jose.marchesi@oracle.com>

* config/tc-bpf.c: Semicolon does not start a comment, but
separates multiple commands on a single line.
* testsuite/gas/bpf/alu-pseudoc.s: Adapt test accordingly.
* testsuite/gas/bpf/spacing-pseudoc.s: Likewise.
* testsuite/gas/bpf/offset16-overflow.s: Likewise.
* testsuite/gas/bpf/jump-relax-jump.s: Likewise.
* testsuite/gas/bpf/jump-relax-ja.s: Likewise.
* testsuite/gas/bpf/imm32-overflow.s: Likewise.
* testsuite/gas/bpf/disp32-overflow.s: Likewise.
* testsuite/gas/bpf/disp16-overflow-relax.s: Likewise.
* testsuite/gas/bpf/disp16-overflow.s: Likewise.
* doc/c-bpf.texi (BPF Special Characters): Update.

12 files changed:
gas/ChangeLog
gas/config/tc-bpf.c
gas/doc/c-bpf.texi
gas/testsuite/gas/bpf/alu-pseudoc.s
gas/testsuite/gas/bpf/disp16-overflow-relax.s
gas/testsuite/gas/bpf/disp16-overflow.s
gas/testsuite/gas/bpf/disp32-overflow.s
gas/testsuite/gas/bpf/imm32-overflow.s
gas/testsuite/gas/bpf/jump-relax-ja.s
gas/testsuite/gas/bpf/jump-relax-jump.s
gas/testsuite/gas/bpf/offset16-overflow.s
gas/testsuite/gas/bpf/spacing-pseudoc.s

index 9414f7df67863dc1d2766c6cd5428b8be0e464dd..c5e781d275cdb4b0279be9fcb90fedf2508a7010 100644 (file)
@@ -1,3 +1,18 @@
+2023-11-28  Jose E. Marchesi  <jose.marchesi@oracle.com>
+
+       * config/tc-bpf.c: Semicolon does not start a comment, but
+       separates multiple commands on a single line.
+       * testsuite/gas/bpf/alu-pseudoc.s: Adapt test accordingly.
+       * testsuite/gas/bpf/spacing-pseudoc.s: Likewise.
+       * testsuite/gas/bpf/offset16-overflow.s: Likewise.
+       * testsuite/gas/bpf/jump-relax-jump.s: Likewise.
+       * testsuite/gas/bpf/jump-relax-ja.s: Likewise.
+       * testsuite/gas/bpf/imm32-overflow.s: Likewise.
+       * testsuite/gas/bpf/disp32-overflow.s: Likewise.
+       * testsuite/gas/bpf/disp16-overflow-relax.s: Likewise.
+       * testsuite/gas/bpf/disp16-overflow.s: Likewise.
+       * doc/c-bpf.texi (BPF Special Characters): Update.
+
 2023-11-23  YunQiang Su  <yunqiang.su@cipunited.com>
 
        * testsuite/gas/mips/elf-rel.s: Use addiu in place of addi.
index b6b1db4742719b15bd525bef8af7159a3b58cd60..00567545de82ed2bd88e278728039cd74a275c63 100644 (file)
@@ -56,9 +56,9 @@ struct bpf_insn
   expressionS *relaxed_exp;
 };
 
-const char comment_chars[]        = ";#";
+const char comment_chars[]        = "#";
 const char line_comment_chars[]   = "#";
-const char line_separator_chars[] = "`";
+const char line_separator_chars[] = ";`";
 const char EXP_CHARS[]            = "eE";
 const char FLT_CHARS[]            = "fFdD";
 
index 25ae231d19c4420d8e3b3cff8623cc20b68caf40..7ff07e9176423e73731555874bdfc61443d15c6b 100644 (file)
@@ -68,11 +68,18 @@ the host endianness is used.
 
 @cindex line comment character, BPF
 @cindex BPF line comment character
-The presence of a @samp{;} or a @samp{#} on a line indicates the start
-of a comment that extends to the end of the current line.
+The presence of a @samp{#} on a line indicates the start of a comment
+that extends to the end of the current line.
+
+@cindex block comments, BPF
+@cindex BPF block comments
+The presence of the @samp{/*} sequence indicates the beginning of a
+block (multi-line) comment, whose contents span until the next
+@samp{*/} sequence.  It is not possible to nest block comments.
 
 @cindex statement separator, BPF
-Statements and assembly directives are separated by newlines.
+Statements and assembly directives are separated by newlines and
+@samp{;} characters.
 
 @node BPF Registers
 @section BPF Registers
index 3d60d4f7a770a1d8263cb7a1b3e9ee7ec07745f9..04d2b76e3f7a638bb866b444b846318ba772e1c2 100644 (file)
@@ -61,5 +61,5 @@
         r1 = bswap16 r1
         r2 = bswap32 r2
         r3 = bswap64 r3
-        ;; The following is to be interpreted as a mov, not lddw.
+        /* The following is to be interpreted as a mov, not lddw. */
         r2 = 666ll
index 05d505caaae6fb695ddadad2468718920b6202d7..7ac969a854a363d4d3c9c682679d36bd36eb90cc 100644 (file)
@@ -1,4 +1,4 @@
-        jeq %r1,%r2,2147483647  ; Overflows.
-        jlt %r3,%r4,2147483648  ; Overflows.
-        jge %r5,10,-2147483648  ; Overflows.
-        ja -2147483649          ; Overflows.
+        jeq %r1,%r2,2147483647  /* Overflows. */
+        jlt %r3,%r4,2147483648  /* Overflows. */
+        jge %r5,10,-2147483648  /* Overflows. */
+        ja -2147483649          /* Overflows. */
index 4a8fd9fcf1c4001028343fc3d59872f8d89888cc..c46590e4959ec24b211663a2ce2cec246f66e88f 100644 (file)
@@ -1,4 +1,4 @@
         ja 32767
-        jeq %r1,%r2,65536       ; Overflows
+        jeq %r1,%r2,65536       /* Overflows */
         jlt %r3,%r4,-32768
-        jge %r5,10,-32769       ; Overflows
+        jge %r5,10,-32769       /* Overflows */
index 11128a20dff2f5c5e0af22142d70cc54f0e77619..eb8b445588bcee402adecd518f64f2d2384f1de1 100644 (file)
@@ -1,4 +1,4 @@
         call -2147483648
-        call -2147483649        ; This overflows.
+        call -2147483649        /* This overflows.  */
         call 4294967295
-        call 4294967296         ; This overflows.
+        call 4294967296         /* This overflows.  */
index b2ab43d2e7a054d7159a664300b8c638986326ef..1aac58bd0ea98d26f3c632b7ba39c452d88271f2 100644 (file)
@@ -1,4 +1,4 @@
         add %r1, 2147483647
-        or %r2, 4294967296         ; This overflows.
+        or %r2, 4294967296         /* This overflows.  */
         xor %r3, 4294967295
-        sub %r4, 4294967296        ; This overflows.
+        sub %r4, 4294967296        /* This overflows.  */
index 1faf67909eb99f9a54f44c13795d6e0cd1d627af..f164176bbd56e5c4d9eba98dd4dfd243f6cbcf82 100644 (file)
@@ -1,16 +1,16 @@
-        ;; The following two instructions have constant targets that
-        ;; fix in the JA 16-bit signed displacement operand.  These
-        ;; are not relaxed.
+        /* The following two instructions have constant targets that
+           fix in the JA 16-bit signed displacement operand.  These
+           are not relaxed.  */
 1:      ja -32768
         ja 32767
-        ;; The following instruction refers to a defined symbol that
-        ;; is on reach, so it should not be relaxed.
+        /* The following instruction refers to a defined symbol that
+           is on reach, so it should not be relaxed.  */
         ja 1b
-        ;; The following instruction has an undefined symbol as a
-        ;; target.  It is not to be relaxed.
+        /* The following instruction has an undefined symbol as a
+           target.  It is not to be relaxed.  */
         ja undefined + 10
-        ;; The following instructions refer to a defined symbol that
-        ;; is not on reach.  They shall be relaxed to a JAL.
+        /* The following instructions refer to a defined symbol that
+           is not on reach.  They shall be relaxed to a JAL.  */
         ja tail
         tail = .text + 262160
         ja tail
index 3ee7c873320eab1f706698d446ab00c914379a47..5ea61109bcaa15360230c3315c28484e7c720e84 100644 (file)
@@ -1,12 +1,12 @@
-        ;; The following two instructions have constant targets that
-        ;; fix in the jump 16-bit signed displacement operand.
+        /* The following two instructions have constant targets that
+           fix in the jump 16-bit signed displacement operand.  */
 1:      jeq %r1, %r2, -32768
         jlt %r1, %r2, 32767
-        ;; The following instruction refers to a defined symbol that
-        ;; is on reach, so it should not be relaxed.
+        /* The following instruction refers to a defined symbol that
+           is on reach, so it should not be relaxed.  */
         jle %r1, %r2, 1b
-        ;; The following instructions refer to a defined symbol that
-        ;; is not on reach.  They shall be relaxed.
+        /* The following instructions refer to a defined symbol that
+           is not on reach.  They shall be relaxed.  */
         jeq %r1, %r2, tail
         tail = .text + 262160
         jgt %r1, %r2, tail
index ebd8e05c09e3ab4c82ce1970d9d15e3f69155dab..2bcb63baf8d46558d39680c82d3df37e70623d3c 100644 (file)
@@ -1,4 +1,4 @@
         ldxh %r2, [%r1 + 65535]
-        ldxw %r2, [%r1 + 65536]  ; This overflows
+        ldxw %r2, [%r1 + 65536]  /* This overflows.  */
         stxw [%r2 - 32768], %r1
-        stxdw [%r2 - 32769], %r1  ; This overflows
+        stxdw [%r2 - 32769], %r1  /* This overflows.  */
index 3c19d9a5073d0ff356fb465488adbe70761877e8..5aff93dcf337acc9226beb682b500a51dc59d2cf 100644 (file)
@@ -1,5 +1,5 @@
-        ;; This test checks that flexible spacing is supported in the
-        ;; pseudoc syntax.
+        /* This test checks that flexible spacing is supported in the
+           pseudoc syntax.  */
         r4 = 0xdeadbeefll
         r4 = 0xdeadbeef ll
         goto +1