mirror of
https://github.com/enjoy-digital/litex.git
synced 2025-01-04 09:52:26 -05:00
CSR fields: generate convenience functions (#725)
Generate convenience methods to extract/replace bits in CSR fields, only generate replace if CSR register is writable.
This commit is contained in:
parent
cd80c87f1a
commit
8a82ddf6e1
1 changed files with 23 additions and 2 deletions
|
@ -223,8 +223,29 @@ def get_csr_header(regions, constants, csr_base=None, with_access_functions=True
|
||||||
origin += alignment//8*nr
|
origin += alignment//8*nr
|
||||||
if hasattr(csr, "fields"):
|
if hasattr(csr, "fields"):
|
||||||
for field in csr.fields.fields:
|
for field in csr.fields.fields:
|
||||||
r += "#define CSR_"+name.upper()+"_"+csr.name.upper()+"_"+field.name.upper()+"_OFFSET "+str(field.offset)+"\n"
|
offset = str(field.offset)
|
||||||
r += "#define CSR_"+name.upper()+"_"+csr.name.upper()+"_"+field.name.upper()+"_SIZE "+str(field.size)+"\n"
|
size = str(field.size)
|
||||||
|
r += "#define CSR_"+name.upper()+"_"+csr.name.upper()+"_"+field.name.upper()+"_OFFSET "+offset+"\n"
|
||||||
|
r += "#define CSR_"+name.upper()+"_"+csr.name.upper()+"_"+field.name.upper()+"_SIZE "+size+"\n"
|
||||||
|
if with_access_functions:
|
||||||
|
reg_name = name + "_" + csr.name.lower()
|
||||||
|
field_name = reg_name + "_" + field.name.lower()
|
||||||
|
r += "static inline uint32_t " + field_name + "_extract(uint32_t oldword) {\n"
|
||||||
|
r += "\tuint32_t mask = ((1 << " + size + ")-1);\n"
|
||||||
|
r += "\treturn ( (oldword >> " + offset + ") & mask );\n}\n"
|
||||||
|
r += "static inline uint32_t " + field_name + "_read(void) {\n"
|
||||||
|
r += "\tuint32_t word = " + reg_name + "_read();\n"
|
||||||
|
r += "\treturn " + field_name + "_extract(word);\n"
|
||||||
|
r += "}\n"
|
||||||
|
if (reg_name + "_write") in r:
|
||||||
|
r += "static inline uint32_t " + field_name + "_replace(uint32_t oldword, uint32_t plain_value) {\n"
|
||||||
|
r += "\tuint32_t mask = ((1 << " + size + ")-1);\n"
|
||||||
|
r += "\treturn (oldword & (~(mask << " + offset + "))) | (mask & plain_value)<< " + offset + " ;\n}\n"
|
||||||
|
r += "static inline void " + field_name + "_write(uint32_t plain_value) {\n"
|
||||||
|
r += "\tuint32_t oldword = " + reg_name + "_read();\n"
|
||||||
|
r += "\tuint32_t newword = " + field_name + "_replace(oldword, plain_value);\n"
|
||||||
|
r += "\t" + reg_name + "_write(newword);\n"
|
||||||
|
r += "}\n"
|
||||||
|
|
||||||
r += "\n#endif\n"
|
r += "\n#endif\n"
|
||||||
return r
|
return r
|
||||||
|
|
Loading…
Reference in a new issue