diff options
author | Flavio Cruz <flaviocruz@gmail.com> | 2023-05-16 23:04:18 -0400 |
---|---|---|
committer | Samuel Thibault <samuel.thibault@ens-lyon.org> | 2023-09-24 23:31:15 +0200 |
commit | b5a567954ce3b4d236b7a2375a6a00f3a4a853e8 (patch) | |
tree | 56cc650be6577b1590dbeb0854a33dc557825ee5 /utils.c | |
parent | d9a36da6d785844139d291b37f80fbe087b2b59e (diff) | |
download | mig-b5a567954ce3b4d236b7a2375a6a00f3a4a853e8.tar.gz mig-b5a567954ce3b4d236b7a2375a6a00f3a4a853e8.tar.bz2 mig-b5a567954ce3b4d236b7a2375a6a00f3a4a853e8.zip |
Update code generation to handle the new 64 bit ABI
Mostly, we don't set the fields that do not exist and avoid type
mismatching (like casting unsigned short to unsigned char for
msgt_name).
We also revamp type checking to compare mach_msg_type_t to uint64_t
instead of just uint32_t as we now use the whole structure.
Message-Id: <ZGREMgn19Zptc/Pf@jupiter.tail36e24.ts.net>
Diffstat (limited to 'utils.c')
-rw-r--r-- | utils.c | 27 |
1 files changed, 19 insertions, 8 deletions
@@ -78,7 +78,7 @@ WriteBogusDefines(FILE *file) fprintf(file, "#define BAD_TYPECHECK(type, check) mig_unlikely (({\\\n"); fprintf(file, - " union { mach_msg_type_t t; uint32_t w; } _t, _c;\\\n"); + " union { mach_msg_type_t t; uint%d_t w; } _t, _c;\\\n", desired_complex_alignof * 8); fprintf(file, " _t.t = *(type); _c.t = *(check);_t.w != _c.w; }))\n"); } @@ -358,11 +358,21 @@ static void WriteStaticLongDecl(FILE *file, const ipc_type_t *it, dealloc_t dealloc, bool inname, identifier_t name) { + const_string_t msgt_name = inname ? it->itInNameStr : it->itOutNameStr; fprintf(file, "\tconst mach_msg_type_long_t %s = {\n", name); fprintf(file, "\t\t.msgtl_header = {\n"); - fprintf(file, "\t\t\t.msgt_name =\t\t0,\n"); - fprintf(file, "\t\t\t.msgt_size =\t\t0,\n"); - fprintf(file, "\t\t\t.msgt_number =\t\t0,\n"); + if (IS_64BIT_ABI) { + /* For the 64 bit ABI we don't really have mach_msg_type_long_t + * so we fill mach_msg_type_long_t just like mach_msg_type_t. + */ + fprintf(file, "\t\t\t.msgt_name =\t\t(unsigned char) %s,\n", msgt_name); + fprintf(file, "\t\t\t.msgt_size =\t\t%d,\n", it->itSize); + fprintf(file, "\t\t\t.msgt_number =\t\t%d,\n", it->itNumber); + } else { + fprintf(file, "\t\t\t.msgt_name =\t\t0,\n"); + fprintf(file, "\t\t\t.msgt_size =\t\t0,\n"); + fprintf(file, "\t\t\t.msgt_number =\t\t0,\n"); + } fprintf(file, "\t\t\t.msgt_inline =\t\t%s,\n", strbool(it->itInLine)); fprintf(file, "\t\t\t.msgt_longform =\t\tTRUE,\n"); @@ -370,10 +380,11 @@ WriteStaticLongDecl(FILE *file, const ipc_type_t *it, strdealloc(dealloc)); fprintf(file, "\t\t\t.msgt_unused =\t\t0\n"); fprintf(file, "\t\t},\n"); - fprintf(file, "\t\t.msgtl_name =\t(unsigned short) %s,\n", - inname ? it->itInNameStr : it->itOutNameStr); - fprintf(file, "\t\t.msgtl_size =\t%d,\n", it->itSize); - fprintf(file, "\t\t.msgtl_number =\t%d,\n", it->itNumber); + if (!IS_64BIT_ABI) { + fprintf(file, "\t\t.msgtl_name =\t(unsigned short) %s,\n", msgt_name); + fprintf(file, "\t\t.msgtl_size =\t%d,\n", it->itSize); + fprintf(file, "\t\t.msgtl_number =\t%d,\n", it->itNumber); + } fprintf(file, "\t};\n"); } |