sipeed_tang_nano: Add SPI Flash, Enable CPU and use new external SPI Flash support from OpenFPGALoader.
./sipeed_tang_nano_4k.py --cpu-type=vexriscv --cpu-variant=lite --build --flash __ _ __ _ __ / / (_) /____ | |/_/ / /__/ / __/ -_)> < /____/_/\__/\__/_/|_| Build your hardware, easily! (c) Copyright 2012-2021 Enjoy-Digital (c) Copyright 2007-2015 M-Labs BIOS built on Sep 17 2021 15:54:08 BIOS CRC passed (6cc6de6d) Migen git sha1: a5bc262 LiteX git sha1: 46cd9c5a --=============== SoC ==================-- CPU: VexRiscv_Lite @ 27MHz BUS: WISHBONE 32-bit @ 4GiB CSR: 32-bit data ROM: 64KiB SRAM: 8KiB FLASH: 4096KiB --========== Initialization ============-- Initializing W25Q32 SPI Flash @0x80000000... SPI Flash clk configured to 13 MHz Memspeed at 0x80000000 (Sequential, 4.0KiB)... Read speed: 1.3MiB/s Memspeed at 0x80000000 (Random, 4.0KiB)... Read speed: 521.9KiB/s --============== Boot ==================-- Booting from serial... Press Q or ESC to abort boot completely. sL5DdSMmkekro Timeout No boot medium found --============= Console ================-- litex>
This commit is contained in:
parent
28571308bc
commit
376a836583
|
@ -28,6 +28,13 @@ _io = [
|
||||||
("user_btn", 0, Pins("14"), IOStandard("LVCMOS18")),
|
("user_btn", 0, Pins("14"), IOStandard("LVCMOS18")),
|
||||||
("user_btn", 1, Pins("15"), IOStandard("LVCMOS18")),
|
("user_btn", 1, Pins("15"), IOStandard("LVCMOS18")),
|
||||||
|
|
||||||
|
# Serial (FIXME: For tests, change or remove.)
|
||||||
|
("serial", 0,
|
||||||
|
Subsignal("rx", Pins("44")), # CAM_SCL
|
||||||
|
Subsignal("tx", Pins("46")), # CAM_SDA
|
||||||
|
IOStandard("LVCMOS33")
|
||||||
|
),
|
||||||
|
|
||||||
# SPIFlash
|
# SPIFlash
|
||||||
("spiflash", 0,
|
("spiflash", 0,
|
||||||
Subsignal("cs_n", Pins("2"), IOStandard("LVCMOS33")),
|
Subsignal("cs_n", Pins("2"), IOStandard("LVCMOS33")),
|
||||||
|
|
|
@ -13,11 +13,15 @@ from migen import *
|
||||||
from migen.genlib.resetsync import AsyncResetSynchronizer
|
from migen.genlib.resetsync import AsyncResetSynchronizer
|
||||||
|
|
||||||
from litex.soc.integration.soc_core import *
|
from litex.soc.integration.soc_core import *
|
||||||
|
from litex.soc.integration.soc import SoCRegion
|
||||||
from litex.soc.integration.builder import *
|
from litex.soc.integration.builder import *
|
||||||
from litex.soc.cores.led import LedChaser
|
from litex.soc.cores.led import LedChaser
|
||||||
|
|
||||||
from litex_boards.platforms import tang_nano_4k
|
from litex_boards.platforms import tang_nano_4k
|
||||||
|
|
||||||
|
kB = 1024
|
||||||
|
mB = 1024*kB
|
||||||
|
|
||||||
# CRG ----------------------------------------------------------------------------------------------
|
# CRG ----------------------------------------------------------------------------------------------
|
||||||
|
|
||||||
class _CRG(Module):
|
class _CRG(Module):
|
||||||
|
@ -36,13 +40,13 @@ class _CRG(Module):
|
||||||
# BaseSoC ------------------------------------------------------------------------------------------
|
# BaseSoC ------------------------------------------------------------------------------------------
|
||||||
|
|
||||||
class BaseSoC(SoCCore):
|
class BaseSoC(SoCCore):
|
||||||
|
mem_map = {**SoCCore.mem_map, **{"spiflash": 0x80000000}}
|
||||||
def __init__(self, sys_clk_freq=int(27e6), with_led_chaser=True, **kwargs):
|
def __init__(self, sys_clk_freq=int(27e6), with_led_chaser=True, **kwargs):
|
||||||
platform = tang_nano_4k.Platform()
|
platform = tang_nano_4k.Platform()
|
||||||
|
|
||||||
|
# Put BIOS in SPIFlash to save BlockRAMs.
|
||||||
# Disable CPU/UART for now.
|
kwargs["integrated_rom_size"] = 0
|
||||||
kwargs["cpu_type"] = None
|
kwargs["cpu_reset_address"] = self.mem_map["spiflash"] + 0
|
||||||
kwargs["with_uart"] = False
|
|
||||||
|
|
||||||
# SoCCore ----------------------------------------------------------------------------------
|
# SoCCore ----------------------------------------------------------------------------------
|
||||||
SoCCore.__init__(self, platform, sys_clk_freq,
|
SoCCore.__init__(self, platform, sys_clk_freq,
|
||||||
|
@ -53,6 +57,18 @@ class BaseSoC(SoCCore):
|
||||||
# CRG --------------------------------------------------------------------------------------
|
# CRG --------------------------------------------------------------------------------------
|
||||||
self.submodules.crg = _CRG(platform, sys_clk_freq)
|
self.submodules.crg = _CRG(platform, sys_clk_freq)
|
||||||
|
|
||||||
|
# SPI Flash --------------------------------------------------------------------------------
|
||||||
|
from litespi.modules import W25Q32
|
||||||
|
from litespi.opcodes import SpiNorFlashOpCodes as Codes
|
||||||
|
self.add_spi_flash(mode="1x", module=W25Q32(Codes.READ_1_1_1), with_master=False)
|
||||||
|
|
||||||
|
# Add ROM linker region --------------------------------------------------------------------
|
||||||
|
self.bus.add_region("rom", SoCRegion(
|
||||||
|
origin = self.mem_map["spiflash"] + 0,
|
||||||
|
size = 64*kB,
|
||||||
|
linker = True)
|
||||||
|
)
|
||||||
|
|
||||||
# Leds -------------------------------------------------------------------------------------
|
# Leds -------------------------------------------------------------------------------------
|
||||||
if with_led_chaser:
|
if with_led_chaser:
|
||||||
self.submodules.leds = LedChaser(
|
self.submodules.leds = LedChaser(
|
||||||
|
@ -86,6 +102,7 @@ def main():
|
||||||
if args.flash:
|
if args.flash:
|
||||||
prog = soc.platform.create_programmer()
|
prog = soc.platform.create_programmer()
|
||||||
prog.flash(0, os.path.join(builder.gateware_dir, "impl", "pnr", "project.fs"))
|
prog.flash(0, os.path.join(builder.gateware_dir, "impl", "pnr", "project.fs"))
|
||||||
|
prog.flash(0, "build/sipeed_tang_nano_4k/software/bios/bios.bin", external=True)
|
||||||
|
|
||||||
if __name__ == "__main__":
|
if __name__ == "__main__":
|
||||||
main()
|
main()
|
||||||
|
|
Loading…
Reference in New Issue