diff options
author | Aldy Hernandez <aldyh@redhat.com> | 2023-04-18 07:56:52 +0200 |
---|---|---|
committer | Aldy Hernandez <aldyh@redhat.com> | 2023-04-18 10:49:33 +0200 |
commit | 6e552ec218a04dac046066e2608202ba90d66f11 (patch) | |
tree | 507cc5dc793ec27e6655fcf0c1074e3ddacb2e95 | |
parent | 5baf2cccd0345a7ac3d4467343414f8b7ff1724b (diff) | |
download | gcc-6e552ec218a04dac046066e2608202ba90d66f11.zip gcc-6e552ec218a04dac046066e2608202ba90d66f11.tar.gz gcc-6e552ec218a04dac046066e2608202ba90d66f11.tar.bz2 |
Abstract out REAL_VALUE_TYPE streaming.
In upcoming patches I will contribute code to stream out frange's as
well as vrange's. This patch abstracts out the REAL_VALUE_TYPE
streaming into their own functions, so that they may be used elsewhere.
gcc/ChangeLog:
* data-streamer.cc (bp_pack_real_value): New.
(bp_unpack_real_value): New.
* data-streamer.h (bp_pack_real_value): New.
(bp_unpack_real_value): New.
* tree-streamer-in.cc (unpack_ts_real_cst_value_fields): Use
bp_unpack_real_value.
* tree-streamer-out.cc (pack_ts_real_cst_value_fields): Use
bp_pack_real_value.
-rw-r--r-- | gcc/data-streamer.cc | 33 | ||||
-rw-r--r-- | gcc/data-streamer.h | 2 | ||||
-rw-r--r-- | gcc/tree-streamer-in.cc | 14 | ||||
-rw-r--r-- | gcc/tree-streamer-out.cc | 14 |
4 files changed, 38 insertions, 25 deletions
diff --git a/gcc/data-streamer.cc b/gcc/data-streamer.cc index d4b663b..0b9c457 100644 --- a/gcc/data-streamer.cc +++ b/gcc/data-streamer.cc @@ -113,3 +113,36 @@ bp_unpack_var_len_int (struct bitpack_d *bp) } } } + +/* Pack REAL_VALUE_TYPE R into BP. */ + +void +bp_pack_real_value (struct bitpack_d *bp, const REAL_VALUE_TYPE *r) +{ + bp_pack_value (bp, r->cl, 2); + bp_pack_value (bp, r->decimal, 1); + bp_pack_value (bp, r->sign, 1); + bp_pack_value (bp, r->signalling, 1); + bp_pack_value (bp, r->canonical, 1); + bp_pack_value (bp, r->uexp, EXP_BITS); + for (unsigned i = 0; i < SIGSZ; i++) + bp_pack_value (bp, r->sig[i], HOST_BITS_PER_LONG); +} + +/* Unpack REAL_VALUE_TYPE R from BP. */ + +void +bp_unpack_real_value (struct bitpack_d *bp, REAL_VALUE_TYPE *r) +{ + /* Clear all bits of the real value type so that we can later do + bitwise comparisons to see if two values are the same. */ + memset (r, 0, sizeof (*r)); + r->cl = (unsigned) bp_unpack_value (bp, 2); + r->decimal = (unsigned) bp_unpack_value (bp, 1); + r->sign = (unsigned) bp_unpack_value (bp, 1); + r->signalling = (unsigned) bp_unpack_value (bp, 1); + r->canonical = (unsigned) bp_unpack_value (bp, 1); + r->uexp = (unsigned) bp_unpack_value (bp, EXP_BITS); + for (unsigned i = 0; i < SIGSZ; i++) + r->sig[i] = (unsigned long) bp_unpack_value (bp, HOST_BITS_PER_LONG); +} diff --git a/gcc/data-streamer.h b/gcc/data-streamer.h index d8c7e21..19c9d6e 100644 --- a/gcc/data-streamer.h +++ b/gcc/data-streamer.h @@ -46,6 +46,8 @@ struct bitpack_d /* In data-streamer.cc */ void bp_pack_var_len_unsigned (struct bitpack_d *, unsigned HOST_WIDE_INT); void bp_pack_var_len_int (struct bitpack_d *, HOST_WIDE_INT); +void bp_pack_real_value (struct bitpack_d *, const REAL_VALUE_TYPE *); +void bp_unpack_real_value (struct bitpack_d *, REAL_VALUE_TYPE *); unsigned HOST_WIDE_INT bp_unpack_var_len_unsigned (struct bitpack_d *); HOST_WIDE_INT bp_unpack_var_len_int (struct bitpack_d *); diff --git a/gcc/tree-streamer-in.cc b/gcc/tree-streamer-in.cc index d4dc30f..bf4bd5c 100644 --- a/gcc/tree-streamer-in.cc +++ b/gcc/tree-streamer-in.cc @@ -188,21 +188,9 @@ unpack_ts_int_cst_value_fields (struct bitpack_d *bp, tree expr) static void unpack_ts_real_cst_value_fields (struct bitpack_d *bp, tree expr) { - unsigned i; REAL_VALUE_TYPE r; - /* Clear all bits of the real value type so that we can later do - bitwise comparisons to see if two values are the same. */ - memset (&r, 0, sizeof r); - r.cl = (unsigned) bp_unpack_value (bp, 2); - r.decimal = (unsigned) bp_unpack_value (bp, 1); - r.sign = (unsigned) bp_unpack_value (bp, 1); - r.signalling = (unsigned) bp_unpack_value (bp, 1); - r.canonical = (unsigned) bp_unpack_value (bp, 1); - r.uexp = (unsigned) bp_unpack_value (bp, EXP_BITS); - for (i = 0; i < SIGSZ; i++) - r.sig[i] = (unsigned long) bp_unpack_value (bp, HOST_BITS_PER_LONG); - + bp_unpack_real_value (bp, &r); memcpy (TREE_REAL_CST_PTR (expr), &r, sizeof (REAL_VALUE_TYPE)); } diff --git a/gcc/tree-streamer-out.cc b/gcc/tree-streamer-out.cc index d107229..81e6fcb 100644 --- a/gcc/tree-streamer-out.cc +++ b/gcc/tree-streamer-out.cc @@ -166,18 +166,8 @@ pack_ts_int_cst_value_fields (struct bitpack_d *bp, tree expr) static void pack_ts_real_cst_value_fields (struct bitpack_d *bp, tree expr) { - unsigned i; - REAL_VALUE_TYPE r; - - r = TREE_REAL_CST (expr); - bp_pack_value (bp, r.cl, 2); - bp_pack_value (bp, r.decimal, 1); - bp_pack_value (bp, r.sign, 1); - bp_pack_value (bp, r.signalling, 1); - bp_pack_value (bp, r.canonical, 1); - bp_pack_value (bp, r.uexp, EXP_BITS); - for (i = 0; i < SIGSZ; i++) - bp_pack_value (bp, r.sig[i], HOST_BITS_PER_LONG); + REAL_VALUE_TYPE r = TREE_REAL_CST (expr); + bp_pack_real_value (bp, &r); } |