mirror of
https://gitlab.freedesktop.org/monado/monado.git
synced 2025-01-21 06:01:43 +00:00
ipc: More script simplification.
This commit is contained in:
parent
0964a6dd07
commit
4efdb6762a
|
@ -39,6 +39,32 @@ class Arg:
|
||||||
self.isAggregate = True
|
self.isAggregate = True
|
||||||
|
|
||||||
|
|
||||||
|
def _write_common(f, start, args, indent):
|
||||||
|
"Write something like a declaration or call."
|
||||||
|
f.write("\n" + indent)
|
||||||
|
f.write(start)
|
||||||
|
# For parameter indenting
|
||||||
|
delim_pad = ",\n" + indent + (" " * len(start))
|
||||||
|
f.write(delim_pad.join(args))
|
||||||
|
f.write(")")
|
||||||
|
|
||||||
|
|
||||||
|
def write_decl(f, return_type, function_name, args, indent=""):
|
||||||
|
f.write("\n" + indent)
|
||||||
|
f.write(return_type)
|
||||||
|
_write_common(f,
|
||||||
|
"{}(".format(function_name),
|
||||||
|
args,
|
||||||
|
indent)
|
||||||
|
|
||||||
|
|
||||||
|
def write_invocation(f, return_val, function_name, args, indent=""):
|
||||||
|
_write_common(f,
|
||||||
|
"{} = {}(".format(return_val, function_name),
|
||||||
|
args,
|
||||||
|
indent)
|
||||||
|
|
||||||
|
|
||||||
class Call:
|
class Call:
|
||||||
|
|
||||||
def dump(self):
|
def dump(self):
|
||||||
|
@ -53,25 +79,14 @@ class Call:
|
||||||
arg.dump()
|
arg.dump()
|
||||||
|
|
||||||
def writeCallDecl(self, f):
|
def writeCallDecl(self, f):
|
||||||
f.write("\nipc_result_t\n")
|
|
||||||
start = "ipc_call_" + self.name + "("
|
|
||||||
delim_pad = ",\n" + (" " * len(start))
|
|
||||||
|
|
||||||
f.write(start)
|
|
||||||
args = ["struct ipc_connection *ipc_c"]
|
args = ["struct ipc_connection *ipc_c"]
|
||||||
args.extend(arg.getFuncArgumentIn() for arg in self.inArgs)
|
args.extend(arg.getFuncArgumentIn() for arg in self.inArgs)
|
||||||
args.extend(arg.getFuncArgumentOut() for arg in self.outArgs)
|
args.extend(arg.getFuncArgumentOut() for arg in self.outArgs)
|
||||||
if self.outFds:
|
if self.outFds:
|
||||||
args.extend(("int *fds", "size_t num_fds"))
|
args.extend(("int *fds", "size_t num_fds"))
|
||||||
f.write(delim_pad.join(args))
|
write_decl(f, 'ipc_result_t', 'ipc_call_' + self.name, args)
|
||||||
f.write(")")
|
|
||||||
|
|
||||||
def writeHandleDecl(self, f):
|
def writeHandleDecl(self, f):
|
||||||
f.write("\nipc_result_t\n")
|
|
||||||
start = "ipc_handle_" + self.name + "("
|
|
||||||
delim_pad = ",\n" + (" " * len(start))
|
|
||||||
|
|
||||||
f.write(start)
|
|
||||||
args = ["volatile struct ipc_client_state *cs"]
|
args = ["volatile struct ipc_client_state *cs"]
|
||||||
args.extend(arg.getFuncArgumentIn() for arg in self.inArgs)
|
args.extend(arg.getFuncArgumentIn() for arg in self.inArgs)
|
||||||
args.extend(arg.getFuncArgumentOut() for arg in self.outArgs)
|
args.extend(arg.getFuncArgumentOut() for arg in self.outArgs)
|
||||||
|
@ -80,8 +95,7 @@ class Call:
|
||||||
"size_t max_num_fds",
|
"size_t max_num_fds",
|
||||||
"int *out_fds",
|
"int *out_fds",
|
||||||
"size_t *out_num_fds"))
|
"size_t *out_num_fds"))
|
||||||
f.write(delim_pad.join(args))
|
write_decl(f, 'ipc_result_t', 'ipc_handle_' + self.name, args)
|
||||||
f.write(")")
|
|
||||||
|
|
||||||
def __init__(self, name, data):
|
def __init__(self, name, data):
|
||||||
|
|
||||||
|
@ -244,14 +258,13 @@ def doClientC(file, p):
|
||||||
else:
|
else:
|
||||||
f.write("\tstruct ipc_result_reply _reply = {0};\n")
|
f.write("\tstruct ipc_result_reply _reply = {0};\n")
|
||||||
|
|
||||||
f.write('''
|
func = 'ipc_client_send_and_get_reply'
|
||||||
\tipc_result_t ret = ipc_client_send_and_get_reply''')
|
args = ['ipc_c', '&_msg', 'sizeof(_msg)', '&_reply', 'sizeof(_reply)']
|
||||||
if call.outFds:
|
if call.outFds:
|
||||||
f.write('''_fds(
|
func += '_fds'
|
||||||
\t ipc_c, &_msg, sizeof(_msg), &_reply, sizeof(_reply), fds, num_fds);''')
|
args.extend(('fds', 'num_fds'))
|
||||||
else:
|
write_invocation(f, 'ipc_result_t ret', func, args, indent="\t")
|
||||||
f.write('''(
|
f.write(';')
|
||||||
\t ipc_c, &_msg, sizeof(_msg), &_reply, sizeof(_reply));''')
|
|
||||||
f.write('''
|
f.write('''
|
||||||
\tif (ret != IPC_SUCCESS) {
|
\tif (ret != IPC_SUCCESS) {
|
||||||
\t\treturn ret;
|
\t\treturn ret;
|
||||||
|
@ -320,9 +333,8 @@ ipc_dispatch(volatile struct ipc_client_state *cs, ipc_command_t *ipc_command)
|
||||||
f.write("\t\tint fds[MAX_FDS] = {0};\n")
|
f.write("\t\tint fds[MAX_FDS] = {0};\n")
|
||||||
f.write("\t\tsize_t num_fds = {0};\n")
|
f.write("\t\tsize_t num_fds = {0};\n")
|
||||||
f.write("\n")
|
f.write("\n")
|
||||||
start = "reply.result = ipc_handle_" + call.name + "("
|
|
||||||
delim_pad = ",\n\t\t" + " " * len(start)
|
# Write call to ipc_handle_CALLNAME
|
||||||
f.write("\t\t" + start)
|
|
||||||
args = ["cs"]
|
args = ["cs"]
|
||||||
for arg in call.inArgs:
|
for arg in call.inArgs:
|
||||||
args.append(("&msg->" + arg.name)
|
args.append(("&msg->" + arg.name)
|
||||||
|
@ -333,8 +345,8 @@ ipc_dispatch(volatile struct ipc_client_state *cs, ipc_command_t *ipc_command)
|
||||||
args.extend(("MAX_FDS",
|
args.extend(("MAX_FDS",
|
||||||
"fds",
|
"fds",
|
||||||
"&num_fds",))
|
"&num_fds",))
|
||||||
f.write(delim_pad.join(args))
|
write_invocation(f, 'reply.result', 'ipc_handle_' + call.name, args, indent="\t\t")
|
||||||
f.write(");\n")
|
f.write(";\n")
|
||||||
|
|
||||||
if call.outFds:
|
if call.outFds:
|
||||||
f.write(
|
f.write(
|
||||||
|
|
Loading…
Reference in a new issue