From 621f6facf0c684a87c856d24a7f66cafe8067c87 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Fin=20Maa=C3=9F?= Date: Wed, 29 May 2024 11:57:18 +0200 Subject: [PATCH] litex_json2dts_zephyr.py: add custon handler for spiflash MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit add custon handler for spiflash. Signed-off-by: Fin Maaß --- litex/tools/litex_json2dts_zephyr.py | 27 ++++++++++++++++++++++++++- 1 file changed, 26 insertions(+), 1 deletion(-) diff --git a/litex/tools/litex_json2dts_zephyr.py b/litex/tools/litex_json2dts_zephyr.py index 236a62e438..87ce9d867a 100755 --- a/litex/tools/litex_json2dts_zephyr.py +++ b/litex/tools/litex_json2dts_zephyr.py @@ -201,6 +201,31 @@ def spimaster_handler(name, parm, csr): return dtsi +def spiflash_handler(name, parm, csr): + registers = get_registers_of(name, csr) + if len(registers) == 0: + raise KeyError + + # Add memory mapped region for spiflash, the linker script in zephyr + # expects this region to be the second entry in the reg property. + try: + registers.insert(1, { + 'addr': csr['memories'][name]['base'], + 'size': csr['memories'][name]['size'], + 'name': 'spiflash_mmap', + }) + except KeyError as e: + print(' memory mapped', e, 'not found') + + dtsi = dts_reg(registers) + dtsi += dts_reg_names(registers) + + dtsi += indent("clock-frequency = <{}>;\n".format( + csr['constants'][name + '_phy_frequency'] + + return dtsi + + def peripheral_handler(name, parm, csr): registers = get_registers_of(name, csr) if len(registers) == 0: @@ -244,7 +269,7 @@ def peripheral_handler(name, parm, csr): 'alias': 'spi0', }, 'spiflash': { - 'handler': peripheral_handler, + 'handler': spiflash_handler, 'alias': 'spi1', }, 'sdcard_block2mem': {