aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorAndreas Schwab <schwab@suse.de>2023-06-13 14:49:38 +0200
committerAndreas Schwab <schwab@suse.de>2023-06-19 09:15:14 +0200
commit71a75b51a62b5cbc12c68b9c4d1dcae0f8a59263 (patch)
tree2141d27ede9c4dcc224d74deb0b27bd46b94c03f
parent39f02ae4ad8a59267d01eab69517af0f87d2e516 (diff)
downloadbinutils-71a75b51a62b5cbc12c68b9c4d1dcae0f8a59263.zip
binutils-71a75b51a62b5cbc12c68b9c4d1dcae0f8a59263.tar.gz
binutils-71a75b51a62b5cbc12c68b9c4d1dcae0f8a59263.tar.bz2
riscv: Use run-time endianess for floating point literals
gas/ PR binutils/30551 * config/tc-riscv.c (md_atof): Use target_big_endian instead of TARGET_BYTES_BIG_ENDIAN. * testsuite/gas/riscv/float-be.d: New file. * testsuite/gas/riscv/float-le.d: New file. * testsuite/gas/riscv/float.s: New file.
-rw-r--r--gas/config/tc-riscv.c2
-rw-r--r--gas/testsuite/gas/riscv/float-be.d8
-rw-r--r--gas/testsuite/gas/riscv/float-le.d8
-rw-r--r--gas/testsuite/gas/riscv/float.s3
4 files changed, 20 insertions, 1 deletions
diff --git a/gas/config/tc-riscv.c b/gas/config/tc-riscv.c
index 7684fa7..e915b82 100644
--- a/gas/config/tc-riscv.c
+++ b/gas/config/tc-riscv.c
@@ -3693,7 +3693,7 @@ md_assemble (char *str)
const char *
md_atof (int type, char *litP, int *sizeP)
{
- return ieee_md_atof (type, litP, sizeP, TARGET_BYTES_BIG_ENDIAN);
+ return ieee_md_atof (type, litP, sizeP, target_big_endian);
}
void
diff --git a/gas/testsuite/gas/riscv/float-be.d b/gas/testsuite/gas/riscv/float-be.d
new file mode 100644
index 0000000..ca6b236
--- /dev/null
+++ b/gas/testsuite/gas/riscv/float-be.d
@@ -0,0 +1,8 @@
+# source: float.s
+# objdump: -sj .data
+# as: -mbig-endian
+
+.*:[ ]+file format .*bigriscv
+
+Contents of section \.data:
+ 0000 3f8ccccd 40019999 9999999a.*
diff --git a/gas/testsuite/gas/riscv/float-le.d b/gas/testsuite/gas/riscv/float-le.d
new file mode 100644
index 0000000..306abf6
--- /dev/null
+++ b/gas/testsuite/gas/riscv/float-le.d
@@ -0,0 +1,8 @@
+# source: float.s
+# objdump: -sj .data
+# as: -mlittle-endian
+
+.*:[ ]+file format .*littleriscv
+
+Contents of section \.data:
+ 0000 cdcc8c3f 9a999999 99990140.*
diff --git a/gas/testsuite/gas/riscv/float.s b/gas/testsuite/gas/riscv/float.s
new file mode 100644
index 0000000..ddc0969
--- /dev/null
+++ b/gas/testsuite/gas/riscv/float.s
@@ -0,0 +1,3 @@
+ .data
+ .float 1.1
+ .double 2.2