bpf: disasemble offsets of value 0 as "+0"
authorDavid Faust <david.faust@oracle.com>
Fri, 21 Jul 2023 18:41:43 +0000 (11:41 -0700)
committerDavid Faust <david.faust@oracle.com>
Fri, 21 Jul 2023 18:49:24 +0000 (11:49 -0700)
This tiny patch makes the BPF disassembler to emit, e.g.

  ldxdw %r1, [%r0+0]

instead of

  ldxdw %r1, [%r00]

when the offset is 0, to avoid confusion.

opcodes/

* bpf-dis.c (print_insn_bpf): Print offsets with value 0 as "+0".

gas/

* testsuite/gas/bpf/mem.s: Add tests with offset 0.
* testsuite/gas/bpf/mem-pseudoc.s: Likewise.
* testsuite/gas/bpf/mem.d: Update accordingly.
* testsuite/gas/bpf/mem-be.d: Likewise.
* testsuite/gas/bpf/mem-pseudoc.d: Likewise.
* testsuite/gas/bpf/mem-be-pseudoc.d: Likewise.

gas/testsuite/gas/bpf/mem-be-pseudoc.d
gas/testsuite/gas/bpf/mem-be.d
gas/testsuite/gas/bpf/mem-pseudoc.d
gas/testsuite/gas/bpf/mem-pseudoc.s
gas/testsuite/gas/bpf/mem.d
gas/testsuite/gas/bpf/mem.s
opcodes/bpf-dis.c

index 9a1ffc109844f7db3137c4d30471b487d961c03a..5dff35c225de9a246fa83e98c80d0d8d257b434e 100644 (file)
@@ -32,3 +32,5 @@ Disassembly of section .text:
   a8:  89 21 7e ef 00 00 00 00         r2=\*\(i16\*\)\(r1\+0x7eef\)
   b0:  91 21 7e ef 00 00 00 00         r2=\*\(i8\*\)\(r1\+0x7eef\)
   b8:  99 21 7e ef 00 00 00 00         r2=\*\(i64\*\)\(r1\+0x7eef\)
+  c0:  58 05 00 00 00 00 00 00         r0=\*\(u64\*\)skb\[r5\+0x0\]
+  c8:  61 21 00 00 00 00 00 00         r2=\*\(u32\*\)\(r1\+0x0\)
index 5746b6a948534edb5cde695ccc7c07d60988b186..cd7b35c60a393cd67bf72c04898cd0bb4de47ec4 100644 (file)
@@ -31,4 +31,6 @@ Disassembly of section .text:
   a0:  81 21 7e ef 00 00 00 00         ldxsw %r2,\[%r1\+0x7eef\]
   a8:  89 21 7e ef 00 00 00 00         ldxsh %r2,\[%r1\+0x7eef\]
   b0:  91 21 7e ef 00 00 00 00         ldxsb %r2,\[%r1\+0x7eef\]
-  b8:  99 21 7e ef 00 00 00 00         ldxsdw %r2,\[%r1\+0x7eef\]
\ No newline at end of file
+  b8:  99 21 7e ef 00 00 00 00         ldxsdw %r2,\[%r1\+0x7eef\]
+  c0:  79 21 00 00 00 00 00 00         ldxdw %r2,\[%r1\+0x0\]
+  c8:  40 03 00 00 00 00 00 00         ldindw %r3,0x0
index 8481048504d5f8643cbc32b0150833d72f137735..ca94cef51cf6223a79d082b4e1d98793a5fb295c 100644 (file)
@@ -32,3 +32,5 @@ Disassembly of section .text:
   a8:  89 12 ef 7e 00 00 00 00         r2=\*\(i16\*\)\(r1\+0x7eef\)
   b0:  91 12 ef 7e 00 00 00 00         r2=\*\(i8\*\)\(r1\+0x7eef\)
   b8:  99 12 ef 7e 00 00 00 00         r2=\*\(i64\*\)\(r1\+0x7eef\)
+  c0:  58 50 00 00 00 00 00 00         r0=\*\(u64\*\)skb\[r5\+0x0\]
+  c8:  61 12 00 00 00 00 00 00         r2=\*\(u32\*\)\(r1\+0x0\)
index 1ffa2e25926f6869361407d68af85f3e3614fefc..4a5e588b91afac36851d35e0308311ace80d6628 100644 (file)
@@ -25,3 +25,5 @@
         r2 = *(i16*)(r1+0x7eef)
         r2 = *(i8*)(r1+0x7eef)
         r2 = *(i64*)(r1+0x7eef)
+       r0 = *(u64 *)skb[r5 + 0]
+       r2 = *(u32 *)(r1 + 0)
index 8b7a488ae018858672fdf03a6d9d9abbe881cc88..9a1e7095df099b388f8fa38d280b9d6814d9f521 100644 (file)
@@ -31,4 +31,6 @@ Disassembly of section .text:
   a0:  81 12 ef 7e 00 00 00 00         ldxsw %r2,\[%r1\+0x7eef\]
   a8:  89 12 ef 7e 00 00 00 00         ldxsh %r2,\[%r1\+0x7eef\]
   b0:  91 12 ef 7e 00 00 00 00         ldxsb %r2,\[%r1\+0x7eef\]
-  b8:  99 12 ef 7e 00 00 00 00         ldxsdw %r2,\[%r1\+0x7eef\]
\ No newline at end of file
+  b8:  99 12 ef 7e 00 00 00 00         ldxsdw %r2,\[%r1\+0x7eef\]
+  c0:  79 12 00 00 00 00 00 00         ldxdw %r2,\[%r1\+0x0\]
+  c8:  40 30 00 00 00 00 00 00         ldindw %r3,0x0
index 6323cf1ede763cc325f04b50681de38c2beb0ca2..adeda473bb87bac46085559c4b501df4bf881c26 100644 (file)
@@ -26,3 +26,5 @@
         ldxsh %r2, [%r1+0x7eef]
         ldxsb %r2, [%r1+0x7eef]
         ldxsdw %r2, [%r1+0x7eef]
+       ldxdw %r2, [%r1+0]
+       ldindw %r3, 0
index a4dc3dc25230d77cb7049ad16751243d65deb67a..4fe0efc2f96f879945449fa26db20b3f8e59edf1 100644 (file)
@@ -215,7 +215,7 @@ print_insn_bpf (bfd_vma pc, disassemble_info *info)
                   if (p[1] == 'I')
                     (*info->fprintf_styled_func) (info->stream, dis_style_immediate,
                                                   "%s",
-                                                  asm_obase != 10 || imm32 > 0 ? "+" : "");
+                                                 asm_obase != 10 || imm32 >= 0 ? "+" : "");
                   (*info->fprintf_styled_func) (info->stream, dis_style_immediate,
                                                 asm_obase == 10 ? "%" PRIi32
                                                 : asm_obase == 8 ? "%" PRIo32
@@ -231,7 +231,7 @@ print_insn_bpf (bfd_vma pc, disassemble_info *info)
                   if (p[1] == 'o')
                     (*info->fprintf_styled_func) (info->stream, dis_style_immediate,
                                                   "%s",
-                                                  asm_obase != 10 || offset16 > 0 ? "+" : "");
+                                                 asm_obase != 10 || offset16 >= 0 ? "+" : "");
                   if (asm_obase == 16 || asm_obase == 8)
                     (*info->fprintf_styled_func) (info->stream, dis_style_immediate,
                                                   asm_obase == 8 ? "0%" PRIo16 : "0x%" PRIx16,