ltl2k generates all variable definition in both ltl_start() and
ltl_possible_next_states(). However, these two functions may not use all
the variables, causing "unused variable" compiler warning.
Change the script to only generate used variables.
Signed-off-by: Nam Cao <namcao@linutronix.de>
---
tools/verification/rvgen/rvgen/ltl2k.py | 25 +++++++++++++++++++++----
1 file changed, 21 insertions(+), 4 deletions(-)
diff --git a/tools/verification/rvgen/rvgen/ltl2k.py b/tools/verification/rvgen/rvgen/ltl2k.py
index 59da351792ec..b075f98d50c4 100644
--- a/tools/verification/rvgen/rvgen/ltl2k.py
+++ b/tools/verification/rvgen/rvgen/ltl2k.py
@@ -106,20 +106,25 @@ class ltl2k(generator.Monitor):
])
return buf
- def _fill_atom_values(self):
+ def _fill_atom_values(self, required_values):
buf = []
for node in self.ltl:
- if node.op.is_temporal():
+ if str(node) not in required_values:
continue
if isinstance(node.op, ltl2ba.AndOp):
buf.append("\tbool %s = %s && %s;" % (node, node.op.left, node.op.right))
+ required_values |= {str(node.op.left), str(node.op.right)}
elif isinstance(node.op, ltl2ba.OrOp):
buf.append("\tbool %s = %s || %s;" % (node, node.op.left, node.op.right))
+ required_values |= {str(node.op.left), str(node.op.right)}
elif isinstance(node.op, ltl2ba.NotOp):
buf.append("\tbool %s = !%s;" % (node, node.op.child))
+ required_values.add(str(node.op.child))
for atom in self.atoms:
+ if atom.lower() not in required_values:
+ continue
buf.append("\tbool %s = test_bit(LTL_%s, mon->atoms);" % (atom.lower(), atom))
buf.reverse()
@@ -135,7 +140,13 @@ class ltl2k(generator.Monitor):
"ltl_possible_next_states(struct ltl_monitor *mon, unsigned int state, unsigned long *next)",
"{"
]
- buf.extend(self._fill_atom_values())
+
+ required_values = set()
+ for node in self.ba:
+ for o in sorted(node.outgoing):
+ required_values |= o.labels
+
+ buf.extend(self._fill_atom_values(required_values))
buf.extend([
"",
"\tswitch (state) {"
@@ -166,7 +177,13 @@ class ltl2k(generator.Monitor):
"static void ltl_start(struct task_struct *task, struct ltl_monitor *mon)",
"{"
]
- buf.extend(self._fill_atom_values())
+
+ required_values = set()
+ for node in self.ba:
+ if node.init:
+ required_values |= node.labels
+
+ buf.extend(self._fill_atom_values(required_values))
buf.append("")
for node in self.ba:
--
2.39.5
On Fri, 2025-07-18 at 16:58 +0200, Nam Cao wrote: > ltl2k generates all variable definition in both ltl_start() and > ltl_possible_next_states(). However, these two functions may not use > all > the variables, causing "unused variable" compiler warning. > > Change the script to only generate used variables. > > Signed-off-by: Nam Cao <namcao@linutronix.de> Tried both patches and they seem to work as intended. Reviewed-by: Gabriele Monaco <gmonaco@redhat.com> Thanks, Gabriele > --- > tools/verification/rvgen/rvgen/ltl2k.py | 25 +++++++++++++++++++++-- > -- > 1 file changed, 21 insertions(+), 4 deletions(-) > > diff --git a/tools/verification/rvgen/rvgen/ltl2k.py > b/tools/verification/rvgen/rvgen/ltl2k.py > index 59da351792ec..b075f98d50c4 100644 > --- a/tools/verification/rvgen/rvgen/ltl2k.py > +++ b/tools/verification/rvgen/rvgen/ltl2k.py > @@ -106,20 +106,25 @@ class ltl2k(generator.Monitor): > ]) > return buf > > - def _fill_atom_values(self): > + def _fill_atom_values(self, required_values): > buf = [] > for node in self.ltl: > - if node.op.is_temporal(): > + if str(node) not in required_values: > continue > > if isinstance(node.op, ltl2ba.AndOp): > buf.append("\tbool %s = %s && %s;" % (node, > node.op.left, node.op.right)) > + required_values |= {str(node.op.left), > str(node.op.right)} > elif isinstance(node.op, ltl2ba.OrOp): > buf.append("\tbool %s = %s || %s;" % (node, > node.op.left, node.op.right)) > + required_values |= {str(node.op.left), > str(node.op.right)} > elif isinstance(node.op, ltl2ba.NotOp): > buf.append("\tbool %s = !%s;" % (node, > node.op.child)) > + required_values.add(str(node.op.child)) > > for atom in self.atoms: > + if atom.lower() not in required_values: > + continue > buf.append("\tbool %s = test_bit(LTL_%s, mon->atoms);" % > (atom.lower(), atom)) > > buf.reverse() > @@ -135,7 +140,13 @@ class ltl2k(generator.Monitor): > "ltl_possible_next_states(struct ltl_monitor *mon, > unsigned int state, unsigned long *next)", > "{" > ] > - buf.extend(self._fill_atom_values()) > + > + required_values = set() > + for node in self.ba: > + for o in sorted(node.outgoing): > + required_values |= o.labels > + > + buf.extend(self._fill_atom_values(required_values)) > buf.extend([ > "", > "\tswitch (state) {" > @@ -166,7 +177,13 @@ class ltl2k(generator.Monitor): > "static void ltl_start(struct task_struct *task, struct > ltl_monitor *mon)", > "{" > ] > - buf.extend(self._fill_atom_values()) > + > + required_values = set() > + for node in self.ba: > + if node.init: > + required_values |= node.labels > + > + buf.extend(self._fill_atom_values(required_values)) > buf.append("") > > for node in self.ba:
© 2016 - 2025 Red Hat, Inc.