diff options
| author | Jakub Kicinski <[email protected]> | 2025-02-03 21:55:10 +0000 |
|---|---|---|
| committer | Paolo Abeni <[email protected]> | 2025-02-06 10:21:15 +0000 |
| commit | fa796178e5eb0078a9a6c36f60fd6494cfc3f81d (patch) | |
| tree | 01113ca57169c871c4d817e98c9cab1e85110ad0 /tools/net/ynl/pyynl/ynl_gen_c.py | |
| parent | tools: ynl-gen: don't output external constants (diff) | |
| download | kernel-fa796178e5eb0078a9a6c36f60fd6494cfc3f81d.tar.gz kernel-fa796178e5eb0078a9a6c36f60fd6494cfc3f81d.zip | |
tools: ynl-gen: support limits using definitions
Support using defines / constants in integer checks.
Carolina will need this for rate API extensions.
Reported-by: Carolina Jubran <[email protected]>
Link: https://lore.kernel.org/[email protected]
Signed-off-by: Jakub Kicinski <[email protected]>
Link: https://patch.msgid.link/[email protected]
Signed-off-by: Paolo Abeni <[email protected]>
Diffstat (limited to 'tools/net/ynl/pyynl/ynl_gen_c.py')
| -rwxr-xr-x | tools/net/ynl/pyynl/ynl_gen_c.py | 5 |
1 files changed, 4 insertions, 1 deletions
diff --git a/tools/net/ynl/pyynl/ynl_gen_c.py b/tools/net/ynl/pyynl/ynl_gen_c.py index aa08b8b1463d..b22082fd660e 100755 --- a/tools/net/ynl/pyynl/ynl_gen_c.py +++ b/tools/net/ynl/pyynl/ynl_gen_c.py @@ -100,7 +100,7 @@ class Type(SpecAttr): if isinstance(value, int): return value if value in self.family.consts: - raise Exception("Resolving family constants not implemented, yet") + return self.family.consts[value]["value"] return limit_to_number(value) def get_limit_str(self, limit, default=None, suffix=''): @@ -110,6 +110,9 @@ class Type(SpecAttr): if isinstance(value, int): return str(value) + suffix if value in self.family.consts: + const = self.family.consts[value] + if const.get('header'): + return c_upper(value) return c_upper(f"{self.family['name']}-{value}") return c_upper(value) |
