aboutsummaryrefslogtreecommitdiff
path: root/gcc
diff options
context:
space:
mode:
authorMarc Poulhiès <dkm@kataplop.net>2024-02-19 22:52:29 +0100
committerArthur Cohen <arthur.cohen@embecosm.com>2024-08-01 12:47:18 +0200
commita58f7df1475c4e8bb744a79bfa36293ff7fb20bb (patch)
tree0ffd377babb781185145f12393dace684b53a241 /gcc
parent8319fa7847d90c87fe6a4e78b1079d13dbe05d62 (diff)
downloadgcc-a58f7df1475c4e8bb744a79bfa36293ff7fb20bb.zip
gcc-a58f7df1475c4e8bb744a79bfa36293ff7fb20bb.tar.gz
gcc-a58f7df1475c4e8bb744a79bfa36293ff7fb20bb.tar.bz2
gccrs: minor cleanup in langhook.type_for_mode
gcc/rust/ChangeLog: * rust-lang.cc (grs_langhook_type_for_mode): simplify code for xImode. Add missing long_double_type_node. Signed-off-by: Marc Poulhiès <dkm@kataplop.net>
Diffstat (limited to 'gcc')
-rw-r--r--gcc/rust/rust-lang.cc39
1 files changed, 15 insertions, 24 deletions
diff --git a/gcc/rust/rust-lang.cc b/gcc/rust/rust-lang.cc
index 4c2ef10..a1f5fe3 100644
--- a/gcc/rust/rust-lang.cc
+++ b/gcc/rust/rust-lang.cc
@@ -169,38 +169,29 @@ static tree
grs_langhook_type_for_mode (machine_mode mode, int unsignedp)
{
// TODO: change all this later to match rustc types
- if (mode == TYPE_MODE (float_type_node))
- return float_type_node;
-
- if (mode == TYPE_MODE (double_type_node))
- return double_type_node;
-
- if (mode == TYPE_MODE (intQI_type_node)) // quarter integer mode - single byte
- // treated as integer
+ if (mode == QImode)
return unsignedp ? unsigned_intQI_type_node : intQI_type_node;
- if (mode
- == TYPE_MODE (intHI_type_node)) // half integer mode - two-byte integer
+
+ if (mode == HImode)
return unsignedp ? unsigned_intHI_type_node : intHI_type_node;
- if (mode
- == TYPE_MODE (intSI_type_node)) // single integer mode - four-byte integer
+
+ if (mode == SImode)
return unsignedp ? unsigned_intSI_type_node : intSI_type_node;
- if (mode
- == TYPE_MODE (
- intDI_type_node)) // double integer mode - eight-byte integer
+
+ if (mode == DImode)
return unsignedp ? unsigned_intDI_type_node : intDI_type_node;
- if (mode
- == TYPE_MODE (intTI_type_node)) // tetra integer mode - 16-byte integer
+
+ if (mode == TYPE_MODE (intTI_type_node))
return unsignedp ? unsigned_intTI_type_node : intTI_type_node;
- if (mode == TYPE_MODE (integer_type_node))
- return unsignedp ? unsigned_type_node : integer_type_node;
+ if (mode == TYPE_MODE (float_type_node))
+ return float_type_node;
- if (mode == TYPE_MODE (long_integer_type_node))
- return unsignedp ? long_unsigned_type_node : long_integer_type_node;
+ if (mode == TYPE_MODE (double_type_node))
+ return double_type_node;
- if (mode == TYPE_MODE (long_long_integer_type_node))
- return unsignedp ? long_long_unsigned_type_node
- : long_long_integer_type_node;
+ if (mode == TYPE_MODE (long_double_type_node))
+ return long_double_type_node;
if (COMPLEX_MODE_P (mode))
{