[PATCH 01/73] tcg: Add TCGOp.type

Richard Henderson posted 73 patches 3 months ago
There is a newer version of this series
[PATCH 01/73] tcg: Add TCGOp.type
Posted by Richard Henderson 3 months ago
Steal 3 bits from nargs to add type without expanding
the size of the structure.  Move the build-time asserts
to the top of tcg.c, so that MAX_CALL_IARGS is in scope
without exporting that detail in the main tcg.h header.

So far, the type field is unused and memset initialized to 0.

Signed-off-by: Richard Henderson <richard.henderson@linaro.org>
---
 include/tcg/tcg.h | 6 ++----
 tcg/tcg.c         | 9 +++++++++
 2 files changed, 11 insertions(+), 4 deletions(-)

diff --git a/include/tcg/tcg.h b/include/tcg/tcg.h
index a77ed12b9d..f2ffb69c0c 100644
--- a/include/tcg/tcg.h
+++ b/include/tcg/tcg.h
@@ -417,7 +417,8 @@ typedef uint32_t TCGLifeData;
 
 struct TCGOp {
     TCGOpcode opc   : 8;
-    unsigned nargs  : 8;
+    TCGType type    : 3;
+    unsigned nargs  : 5;
 
     /* Parameters for this opcode.  See below.  */
     unsigned param1 : 8;
@@ -442,9 +443,6 @@ struct TCGOp {
 #define TCGOP_VECL(X)     (X)->param1
 #define TCGOP_VECE(X)     (X)->param2
 
-/* Make sure operands fit in the bitfields above.  */
-QEMU_BUILD_BUG_ON(NB_OPS > (1 << 8));
-
 static inline TCGRegSet output_pref(const TCGOp *op, unsigned i)
 {
     return i < ARRAY_SIZE(op->output_pref) ? op->output_pref[i] : 0;
diff --git a/tcg/tcg.c b/tcg/tcg.c
index 4578b185be..f8c4394e1d 100644
--- a/tcg/tcg.c
+++ b/tcg/tcg.c
@@ -60,6 +60,15 @@
 #include "user/guest-base.h"
 #endif
 
+/*
+ * Make sure operands fit in the TCGOp bitfields.
+ * For TCGOp.nargs, maximum physical arguments are constrained by
+ * MAX_CALL_IARGS * TCG_TYPE_I128 on 32-bit hosts, so 128 / 32.
+ */
+QEMU_BUILD_BUG_ON(NB_OPS > (1 << 8));
+QEMU_BUILD_BUG_ON(TCG_TYPE_COUNT > (1 << 3));
+QEMU_BUILD_BUG_ON(MAX_CALL_IARGS * (128 / 32) > (1 << 5));
+
 /* Forward declarations for functions declared in tcg-target.c.inc and
    used here. */
 static void tcg_target_init(TCGContext *s);
-- 
2.43.0