Hexagon (target/hexagon) Make generators object oriented - gen_op_regs
authorTaylor Simpson <ltaylorsimpson@gmail.com>
Sun, 10 Dec 2023 22:07:09 +0000 (15:07 -0700)
committerBrian Cain <bcain@quicinc.com>
Mon, 22 Jan 2024 06:02:18 +0000 (22:02 -0800)
Reviewed-by: Brian Cain <bcain@quicinc.com>
Signed-off-by: Taylor Simpson <ltaylorsimpson@gmail.com>
Message-Id: <20231210220712.491494-7-ltaylorsimpson@gmail.com>
Signed-off-by: Brian Cain <bcain@quicinc.com>
target/hexagon/gen_op_regs.py

index a8a7712129c40c8def63c73ecabd9f6a230d4038..7b7b33895ab80aa5488a8ac3bce5ec7d75144fdc 100755 (executable)
@@ -70,6 +70,7 @@ def strip_reg_prefix(x):
 def main():
     hex_common.read_semantics_file(sys.argv[1])
     hex_common.read_attribs_file(sys.argv[2])
+    hex_common.init_registers()
     tagregs = hex_common.get_tagregs(full=True)
     tagimms = hex_common.get_tagimms()
 
@@ -80,11 +81,12 @@ def main():
             wregs = []
             regids = ""
             for regtype, regid, _, numregs in regs:
-                if hex_common.is_read(regid):
+                reg = hex_common.get_register(tag, regtype, regid)
+                if reg.is_read():
                     if regid[0] not in regids:
                         regids += regid[0]
                     rregs.append(regtype + regid + numregs)
-                if hex_common.is_written(regid):
+                if reg.is_written():
                     wregs.append(regtype + regid + numregs)
                     if regid[0] not in regids:
                         regids += regid[0]