Skip to content
Open
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
19 changes: 18 additions & 1 deletion proxyclient/m1n1/adt.py
Original file line number Diff line number Diff line change
Expand Up @@ -102,8 +102,8 @@
"unk2_0" / Int16ul,
"pd" / Int8ul,
"ps_cfg16" / Int8ul,
"group" / Int8ul,
"offset" / Int24ul,
"group" / Int8ul,
"unk2_2" / Int32ul,
"unk2_3" / Int16ul,
"id2" / Int16ul,
Expand Down Expand Up @@ -823,6 +823,7 @@ def create_node(self, name):

def pmgr_init(self):
self._pmgr_u8id = (self["/arm-io/pmgr"].devices[0].id1 != self["/arm-io/pmgr"].devices[1].id1)
self._pmgr_use_group_and_offset = not "ps-regs" in self["/arm-io/pmgr"]._properties

def pmgr_dev_get_id(self, dev):
if self._pmgr_u8id:
Expand All @@ -836,6 +837,22 @@ def pmgr_dev_get_parents(self, dev):
else:
return dev.parents_un.u16id.parents

def pmgr_dev_get_block(self, dev):
if self._pmgr_use_group_and_offset:
reg = self["/arm-io/pmgr"].ps_groups[dev.group].reg
else:
reg = self["/arm-io/pmgr"].ps_regs[dev.psreg].reg
return self["/arm-io/pmgr"].get_reg(reg)

def pmgr_dev_get_offset(self, dev):
if self._pmgr_use_group_and_offset:
return dev.offset
else:
return self["/arm-io/pmgr"].ps_regs[dev.psreg].offset + dev.psidx * 8

def pmgr_dev_get_addr(self, dev):
return self.pmgr_dev_get_block(dev)[0] + self.pmgr_dev_get_offset(dev)

def load_adt(data):
node = ADTNode(ADTNodeStruct.parse(data))
node.pmgr_init()
Expand Down
5 changes: 2 additions & 3 deletions proxyclient/tools/dump_pmgr.py
Original file line number Diff line number Diff line change
Expand Up @@ -52,8 +52,7 @@
s += f" perf_reg: {dev.perf_block}:{dev.perf_idx:#04x} unk3: {dev.unk3:3d} {dev.unk2_0:2d} {dev.ps_cfg16:2d} {dev.unk2_3:3d}"

if not dev.flags.no_ps:
ps = pmgr.ps_regs[dev.psreg]
addr = pmgr.get_reg(ps.reg)[0] + ps.offset + dev.psidx * 8
addr = dt.pmgr_dev_get_addr(dev)
val = p.read32(addr)
s += f" @ {addr:#x} = {val:#010x}"
else:
Expand Down Expand Up @@ -108,7 +107,7 @@

print()

if chip_id in (0x8960, 0x7000, 0x7001, 0x8000, 0x8001, 0x8003, 0x8010, 0x8012, 0x8015):
if dt["/chosen"].chip_id in (0x8960, 0x7000, 0x7001, 0x8000, 0x8001, 0x8003, 0x8010, 0x8012, 0x8015):
exit(0)

print("=== Boot clocks ===")
Expand Down
11 changes: 4 additions & 7 deletions proxyclient/tools/pmgr_adt2dt.py
Original file line number Diff line number Diff line change
Expand Up @@ -39,10 +39,9 @@ def die_label(s):
for i, dev in enumerate(pmgr.devices):
if dev.flags.no_ps:
continue
ps = pmgr.ps_regs[dev.psreg]
block = pmgr.get_reg(ps.reg)
block = dt.pmgr_dev_get_block(dev)
blocks.setdefault(block, []).append(dev)
offset = ps.offset + dev.psidx * 8
offset = dt.pmgr_dev_get_offset(dev)
maxaddr[block[0]] = max(maxaddr.get(block[0], 0), offset)

pmgr_compat = pmgr.compatible[0].split(",")[1]
Expand All @@ -65,13 +64,11 @@ def die_label(s):
for i, ((base, size), devices) in enumerate(sorted(blocks.items())):
print(f"&pmgr{i} {{")

for dev in sorted(devices, key=lambda d: pmgr.ps_regs[d.psreg].offset + dev.psidx * 8):
for dev in sorted(devices, key=dt.pmgr_dev_get_addr):
if dev.flags.no_ps:
continue

ps = pmgr.ps_regs[dev.psreg]
offset = ps.offset + dev.psidx * 8
addr = pmgr.get_reg(ps.reg)[0] + offset
addr = dt.pmgr_dev_get_addr(dev)
assert base <= addr <= (base + size)

print()
Expand Down
Loading