scripts: list_hardware: Add check for soc.yml runner validity
Adds checking that qualifiers listed in a soc.yml file are valid
for the socs and cpuclusters defined in that file
Signed-off-by: Jamie McCrae <jamie.mccrae@nordicsemi.no>
diff --git a/scripts/list_hardware.py b/scripts/list_hardware.py
index 2fa7c2a..d1f31a4 100755
--- a/scripts/list_hardware.py
+++ b/scripts/list_hardware.py
@@ -10,6 +10,7 @@
import sys
from typing import List
import yaml
+import re
SOC_SCHEMA_PATH = str(Path(__file__).parent / 'schemas' / 'soc-schema.yml')
@@ -40,6 +41,40 @@
except (yaml.YAMLError, pykwalify.errors.SchemaError) as e:
sys.exit(f'ERROR: Malformed yaml {soc_yaml.as_posix()}', e)
+ # Ensure that any runner configuration matches socs and cpuclusters declared in the same
+ # soc.yml file
+ if 'runners' in data and 'run_once' in data['runners']:
+ for grp in data['runners']['run_once']:
+ for item_data in data['runners']['run_once'][grp]:
+ for group in item_data['groups']:
+ for qualifiers in group['qualifiers']:
+ components = qualifiers.split('/')
+ soc = components.pop(0)
+ found_match = False
+
+ # Allow 'ns' as final qualifier until "virtual" CPUs are ported to soc.yml
+ # https://github.com/zephyrproject-rtos/zephyr/issues/70721
+ if len(components) > 0 and components[len(components)-1] == 'ns':
+ components.pop(len(components)-1)
+
+ for f in data.get('family', []):
+ for s in f.get('series', []):
+ for socs in s.get('socs', []):
+ if re.match(fr'^{soc}$', socs.get('name')) is not None:
+ if 'cpuclusters' in socs and len(components) > 0:
+ check_string = '/'.join(components)
+ for cpucluster in socs.get('cpuclusters', []):
+ if re.match(fr'^{check_string}$', cpucluster.get('name')) is not None:
+ found_match = True
+ break
+ elif 'cpuclusters' not in socs and len(components) == 0:
+ found_match = True
+ break
+
+
+ if found_match is False:
+ sys.exit(f'ERROR: SoC qualifier match unresolved: {qualifiers}')
+
for f in data.get('family', []):
family = Family(f['name'], folder, [], [])
for s in f.get('series', []):