From 5c4b9f1efd1c5d9853a3c508e2a103d0f5679173 Mon Sep 17 00:00:00 2001 From: Andrew Yourtchenko Date: Tue, 19 Mar 2019 14:52:29 +0100 Subject: vppapigen: allow for enum size other than u32 Change-Id: If20d2fbab9b854b7db276c81918fdff6abcb8385 Signed-off-by: Andrew Yourtchenko --- src/tools/vppapigen/vppapigen_c.py | 11 ++++++++++- 1 file changed, 10 insertions(+), 1 deletion(-) (limited to 'src/tools') diff --git a/src/tools/vppapigen/vppapigen_c.py b/src/tools/vppapigen/vppapigen_c.py index e189b024454..6c4ca356f3a 100644 --- a/src/tools/vppapigen/vppapigen_c.py +++ b/src/tools/vppapigen/vppapigen_c.py @@ -127,10 +127,19 @@ def typedefs(objs, aliases, filename): tname = o.__class__.__name__ output += duplicate_wrapper_head(o.name) if tname == 'Enum': - output += "typedef enum {\n" + if o.enumtype == 'u32': + output += "typedef enum {\n" + else: + output += "typedef enum __attribute__((__packed__)) {\n" + for b in o.block: output += " %s = %s,\n" % (b[0], b[1]) output += '} vl_api_%s_t;\n' % o.name + if o.enumtype != 'u32': + size1 = 'sizeof(vl_api_%s_t)' % o.name + size2 = 'sizeof(%s)' % o.enumtype + err_str = 'size of API enum %s is wrong' % o.name + output += 'STATIC_ASSERT(%s == %s, "%s");\n' % (size1, size2, err_str) else: if tname == 'Union': output += "typedef VL_API_PACKED(union _vl_api_%s {\n" % o.name -- cgit 1.2.3-korg