mirror of
https://mirrors.bfsu.edu.cn/git/linux.git
synced 2024-11-28 14:44:10 +08:00
tools: ynl-gen: use enum names in op strmap more carefully
In preparation for supporting families which use different msg ids to and from the kernel - make sure the ids in op strmap are correct. The map is expected to be used mostly for notifications, don't generate a separate map for the "to kernel" direction. Signed-off-by: Jakub Kicinski <kuba@kernel.org>
This commit is contained in:
parent
8947e50373
commit
9858bfc271
@ -16,7 +16,6 @@
|
||||
|
||||
/* Enums */
|
||||
static const char * const fou_op_strmap[] = {
|
||||
[FOU_CMD_UNSPEC] = "unspec",
|
||||
[FOU_CMD_ADD] = "add",
|
||||
[FOU_CMD_DEL] = "del",
|
||||
[FOU_CMD_GET] = "get",
|
||||
|
@ -442,6 +442,10 @@ class SpecFamily(SpecElement):
|
||||
else:
|
||||
raise Exception("Can't parse directional ops")
|
||||
|
||||
if req_val == req_val_next:
|
||||
req_val = None
|
||||
if rsp_val == rsp_val_next:
|
||||
rsp_val = None
|
||||
op = self.new_operation(elem, req_val, rsp_val)
|
||||
req_val = req_val_next
|
||||
rsp_val = rsp_val_next
|
||||
|
@ -1220,7 +1220,11 @@ def put_op_name(family, cw):
|
||||
map_name = f'{family.name}_op_strmap'
|
||||
cw.block_start(line=f"static const char * const {map_name}[] =")
|
||||
for op_name, op in family.msgs.items():
|
||||
cw.p(f'[{op.enum_name}] = "{op_name}",')
|
||||
if op.rsp_value:
|
||||
if op.req_value == op.rsp_value:
|
||||
cw.p(f'[{op.enum_name}] = "{op_name}",')
|
||||
else:
|
||||
cw.p(f'[{op.rsp_value}] = "{op_name}",')
|
||||
cw.block_end(line=';')
|
||||
cw.nl()
|
||||
|
||||
|
Loading…
Reference in New Issue
Block a user