]> git.ipfire.org Git - thirdparty/binutils-gdb.git/commitdiff
RISC-V: Add .bfloat16 directive
authorKito Cheng <kito.cheng@sifive.com>
Mon, 20 Jan 2025 11:24:36 +0000 (19:24 +0800)
committerNelson Chu <nelson@rivosinc.com>
Tue, 11 Feb 2025 06:44:19 +0000 (14:44 +0800)
RISC-V already support bfloat16 instruciton like Zfbfmin, Zvfbfmin and
Zvfbfwma, so I think it's reasonable to add .bfloat16 directive to
support bfloat16 data type.

And the code logic mostly support by common code already.

gas/config/tc-riscv.c
gas/doc/c-riscv.texi
gas/testsuite/gas/riscv/bfloat16-be.d [new file with mode: 0644]
gas/testsuite/gas/riscv/bfloat16-le.d [new file with mode: 0644]
gas/testsuite/gas/riscv/bfloat16.s [new file with mode: 0644]

index eb0d681bb3ce434609a8623471a20ab508203543..ac1a10aa5e42df5b6c5e7d6c8bcd36e314ea06d1 100644 (file)
@@ -470,7 +470,7 @@ const char EXP_CHARS[] = "eE";
 
 /* Chars that mean this number is a floating point constant.
    As in 0f12.456 or 0d1.2345e12.  */
-const char FLT_CHARS[] = "rRsSfFdDxXpPhH";
+const char FLT_CHARS[] = "rRsSfFdDxXpPhHbB";
 
 /* Indicate ELF attributes are explicitly set.  */
 static bool explicit_attr = false;
@@ -5802,6 +5802,7 @@ static const pseudo_typeS riscv_pseudo_table[] =
   {"attribute", s_riscv_attribute, 0},
   {"variant_cc", s_variant_cc, 0},
   {"float16", float_cons, 'h'},
+  {"bfloat16", float_cons, 'b'},
 
   { NULL, NULL, 0 },
 };
index 10cb772b2ed9683920e06e5a874fe4ba99ba830a..314e28c7503936d292875f6fb4333330659c9220 100644 (file)
@@ -256,6 +256,16 @@ The @var{tag} is either an attribute number, or one of the following:
 @code{Tag_RISCV_unaligned_access}, @code{Tag_RISCV_priv_spec},
 @code{Tag_RISCV_priv_spec_minor}, @code{Tag_RISCV_priv_spec_revision}.
 
+@cindex @code{.bfloat16} directive, RISC-V
+@item .bfloat16 @var{value}
+Floating point constructors for the bfloat16 type, example usage:
+
+@smallexample
+       .bfloat16 12.0
+       .bfloat16 NaN
+       .bfloat16 0b:ffc1
+@end smallexample
+
 @end table
 
 @node RISC-V-Modifiers
diff --git a/gas/testsuite/gas/riscv/bfloat16-be.d b/gas/testsuite/gas/riscv/bfloat16-be.d
new file mode 100644 (file)
index 0000000..21408d0
--- /dev/null
@@ -0,0 +1,10 @@
+# source: bfloat16.s
+# objdump: -sj .data
+# as: -mbig-endian
+
+.*:[   ]+file format .*
+
+Contents of section \.data:
+ 0000 41403dfc 000042f7 8000c2f7 7fff7f80.*
+ 0010 ff807f7f ff7f0080 80800001 8001007f.*
+ 0020 807f3f80 bf804000 c000ffc1 ff81.*
diff --git a/gas/testsuite/gas/riscv/bfloat16-le.d b/gas/testsuite/gas/riscv/bfloat16-le.d
new file mode 100644 (file)
index 0000000..2043a9c
--- /dev/null
@@ -0,0 +1,10 @@
+# source: bfloat16.s
+# objdump: -sj .data
+# as: -mlittle-endian
+
+.*:[   ]+file format .*
+
+Contents of section \.data:
+ 0000 4041fc3d 0000f742 0080f7c2 ff7f807f.*
+ 0010 80ff7f7f 7fff8000 80800100 01807f00.*
+ 0020 7f80803f 80bf0040 00c0c1ff 81ff.*
diff --git a/gas/testsuite/gas/riscv/bfloat16.s b/gas/testsuite/gas/riscv/bfloat16.s
new file mode 100644 (file)
index 0000000..ed92856
--- /dev/null
@@ -0,0 +1,21 @@
+ .data
+       .bfloat16 12.0
+       .bfloat16 0.123
+       .bfloat16 +0.0
+       .bfloat16 123.4
+       .bfloat16 -0.0
+       .bfloat16 -123.4
+       .bfloat16 NaN
+       .bfloat16 Inf
+       .bfloat16 -Inf
+       .bfloat16 3.390e+38
+       .bfloat16 -3.390e+38
+       .bfloat16 1.175e-38
+       .bfloat16 -1.175e-38
+       .bfloat16 9.194e-41
+       .bfloat16 -9.194e-41
+       .bfloat16 1.167e-38
+       .bfloat16 -1.167e-38
+       .bfloat16 1.0, -1, 2.0, -2
+       .bfloat16 0b:ffc1
+       .bfloat16 0B:ff81