From 6d990ba48023f1f786c7c5e46eb11de90cef321f Mon Sep 17 00:00:00 2001 From: Jakob Bornecrantz Date: Wed, 1 Nov 2023 23:45:47 +0000 Subject: [PATCH] ipc: Refactor proto generation a little bit --- src/xrt/ipc/shared/ipcproto/common.py | 41 ++++++++++++++++++++++++++- src/xrt/ipc/shared/proto.py | 38 +++++-------------------- 2 files changed, 47 insertions(+), 32 deletions(-) diff --git a/src/xrt/ipc/shared/ipcproto/common.py b/src/xrt/ipc/shared/ipcproto/common.py index 0b8288cfd..c55a477b3 100644 --- a/src/xrt/ipc/shared/ipcproto/common.py +++ b/src/xrt/ipc/shared/ipcproto/common.py @@ -1,5 +1,5 @@ #!/usr/bin/env python3 -# Copyright 2020, Collabora, Ltd. +# Copyright 2020-2023, Collabora, Ltd. # SPDX-License-Identifier: BSL-1.0 """Generate code from a JSON file describing the IPC protocol.""" @@ -64,6 +64,45 @@ def write_result_handler(f, result, cleanup="", indent=""): f.write("\n" + indent + "}\n") +def write_msg_struct(f, call, ident): + # Message struct + if call.needs_msg_struct: + f.write(ident + "struct ipc_" + call.name + "_msg _msg = {\n") + else: + f.write(ident + "struct ipc_command_msg _msg = {\n") + + f.write(ident + " .cmd = " + str(call.id) + ",\n") + for arg in call.in_args: + if arg.is_aggregate: + f.write(ident + " ." + arg.name + " = *" + arg.name + ",\n") + else: + f.write(ident + " ." + arg.name + " = " + arg.name + ",\n") + if call.in_handles: + f.write(ident + " ." + call.in_handles.count_arg_name + " = " + + call.in_handles.count_arg_name + ",\n") + f.write(ident + "};\n") + + +def write_reply_struct(f, call, ident): + # Reply struct + if call.out_args: + f.write(ident + "struct ipc_" + call.name + "_reply _reply;\n") + else: + f.write(ident + "struct ipc_result_reply _reply = {0};\n") + if call.in_handles: + f.write(ident + "struct ipc_result_reply _sync = {0};\n") + + +def write_msg_send(f, ret, indent): + # Prepare initial sending + func = 'ipc_send' + args = ['&ipc_c->imc', '&_msg', 'sizeof(_msg)'] + + f.write("\n" + indent + "// Send our request") + write_invocation(f, ret, func, args, indent=indent) + f.write(';') + + class Arg: """An IPC call argument.""" diff --git a/src/xrt/ipc/shared/proto.py b/src/xrt/ipc/shared/proto.py index 0be409fda..8189b3cc9 100755 --- a/src/xrt/ipc/shared/proto.py +++ b/src/xrt/ipc/shared/proto.py @@ -1,5 +1,5 @@ #!/usr/bin/env python3 -# Copyright 2020, Collabora, Ltd. +# Copyright 2020-2023, Collabora, Ltd. # SPDX-License-Identifier: BSL-1.0 """Generate code from a JSON file describing the IPC protocol.""" @@ -7,9 +7,10 @@ import argparse from ipcproto.common import (Proto, write_decl, write_invocation, write_result_handler, write_cpp_header_guard_start, - write_cpp_header_guard_end) + write_cpp_header_guard_end, write_msg_struct, + write_reply_struct, write_msg_send) -header = '''// Copyright 2020, Collabora, Ltd. +header = '''// Copyright 2020-2023, Collabora, Ltd. // SPDX-License-Identifier: BSL-1.0 /*! * @file @@ -113,29 +114,8 @@ def generate_client_c(file, p): f.write("\tIPC_TRACE(ipc_c, \"Calling " + call.name + "\");\n\n") - # Message struct - if call.needs_msg_struct: - f.write("\tstruct ipc_" + call.name + "_msg _msg = {\n") - else: - f.write("\tstruct ipc_command_msg _msg = {\n") - f.write("\t .cmd = " + str(call.id) + ",\n") - for arg in call.in_args: - if arg.is_aggregate: - f.write("\t ." + arg.name + " = *" + arg.name + ",\n") - else: - f.write("\t ." + arg.name + " = " + arg.name + ",\n") - if call.in_handles: - f.write("\t ." + call.in_handles.count_arg_name + - " = " + call.in_handles.count_arg_name + ",\n") - f.write("\t};\n") - - # Reply struct - if call.out_args: - f.write("\tstruct ipc_" + call.name + "_reply _reply;\n") - else: - f.write("\tstruct ipc_result_reply _reply = {0};\n") - if call.in_handles: - f.write("\tstruct ipc_result_reply _sync = {0};\n") + write_msg_struct(f, call, '\t') + write_reply_struct(f, call, '\t') f.write(""" \t// Other threads must not read/write the fd while we wait for reply @@ -144,11 +124,7 @@ def generate_client_c(file, p): cleanup = "os_mutex_unlock(&ipc_c->mutex);" # Prepare initial sending - func = 'ipc_send' - args = ['&ipc_c->imc', '&_msg', 'sizeof(_msg)'] - f.write("\n\t// Send our request") - write_invocation(f, 'xrt_result_t ret', func, args, indent="\t") - f.write(';') + write_msg_send(f, 'xrt_result_t ret', indent="\t") write_result_handler(f, 'ret', cleanup, indent="\t") if call.in_handles: