aboutsummaryrefslogtreecommitdiffstats
path: root/host/lib/ic_reg_maps/gen_zbx_cpld_regs.py
diff options
context:
space:
mode:
Diffstat (limited to 'host/lib/ic_reg_maps/gen_zbx_cpld_regs.py')
-rwxr-xr-xhost/lib/ic_reg_maps/gen_zbx_cpld_regs.py25
1 files changed, 17 insertions, 8 deletions
diff --git a/host/lib/ic_reg_maps/gen_zbx_cpld_regs.py b/host/lib/ic_reg_maps/gen_zbx_cpld_regs.py
index fce051d53..5e5274930 100755
--- a/host/lib/ic_reg_maps/gen_zbx_cpld_regs.py
+++ b/host/lib/ic_reg_maps/gen_zbx_cpld_regs.py
@@ -399,19 +399,28 @@ void set_reg(uint16_t addr, uint32_t val)
}
}
+<%
+ ro_regs = set()
+ for reg in filter(lambda reg: reg.is_readonly(), filter(all_addr_filter, regs)):
+ for index in range(reg.get_array_len() if reg.is_array else 1):
+ ro_regs.add(reg.get_addr() + index * reg.get_addr_step_size())
+
+ rw_regs = set()
+ for reg in filter(lambda reg: not reg.is_readonly(), filter(all_addr_filter, regs)):
+ for index in range(reg.get_array_len() if reg.is_array else 1):
+ rw_regs.add(reg.get_addr() + index * reg.get_addr_step_size())
+%>
+
template<typename T> std::set<T> get_all_addrs(bool include_ro = false)
{
std::set<T> addrs;
- % for reg in filter(all_addr_filter, regs):
- % if reg.is_readonly():
if (include_ro) {
- % else:
- {
- % endif
- % for index in range(reg.get_array_len() if reg.is_array else 1):
- addrs.insert(${reg.get_addr() + index * reg.get_addr_step_size()});
- % endfor
+ % for reg in sorted(ro_regs):
+ addrs.insert(${reg});
+ % endfor
}
+ % for reg in sorted(rw_regs):
+ addrs.insert(${reg});
% endfor
return addrs;
}