Skip to content

Commit

Permalink
Merge pull request #631 from andelf/enhance/sipeed_tang_name_20k
Browse files Browse the repository at this point in the history
sipeed_tang_nano_20k: add SPI flash and HDMI support
  • Loading branch information
enjoy-digital authored Dec 17, 2024
2 parents 89d96a3 + 2d25408 commit a15fbb6
Show file tree
Hide file tree
Showing 2 changed files with 64 additions and 3 deletions.
17 changes: 17 additions & 0 deletions litex_boards/platforms/sipeed_tang_nano_20k.py
Original file line number Diff line number Diff line change
Expand Up @@ -48,6 +48,23 @@
IOStandard("LVCMOS33"),
),

# HDMI
("hdmi", 0,
Subsignal("clk_p", Pins("33")),
Subsignal("clk_n", Pins("34")),
Subsignal("data0_p", Pins("35")),
Subsignal("data0_n", Pins("36")),
Subsignal("data1_p", Pins("37")),
Subsignal("data1_n", Pins("38")),
Subsignal("data2_p", Pins("39")),
Subsignal("data2_n", Pins("40")),
Subsignal("hdp", Pins("26"), IOStandard("LVCMOS18")),
Subsignal("cec", Pins("25"), IOStandard("LVCMOS18")),
Subsignal("sda", Pins("53")),
Subsignal("scl", Pins("52")),
Misc("PULL_MODE=NONE"),
),

# Leds
("led_n", 0, Pins("15"), IOStandard("LVCMOS33")),
("led_n", 1, Pins("16"), IOStandard("LVCMOS33")),
Expand Down
50 changes: 47 additions & 3 deletions litex_boards/targets/sipeed_tang_nano_20k.py
Original file line number Diff line number Diff line change
Expand Up @@ -20,6 +20,7 @@
from litex.soc.integration.builder import *
from litex.soc.cores.gpio import GPIOIn
from litex.soc.cores.led import LedChaser, WS2812
from litex.soc.cores.video import VideoGowinHDMIPHY

from litedram.modules import M12L64322A # FIXME: use the real model number
from litedram.phy import GENSDRPHY
Expand All @@ -29,10 +30,13 @@
# CRG ----------------------------------------------------------------------------------------------

class _CRG(LiteXModule):
def __init__(self, platform, sys_clk_freq):
def __init__(self, platform, sys_clk_freq, with_hdmi=False):
self.rst = Signal()
self.cd_sys = ClockDomain()
self.cd_por = ClockDomain()
if with_hdmi:
self.cd_hdmi = ClockDomain()
self.cd_hdmi5x = ClockDomain()

# Clk
clk27 = platform.request("clk27")
Expand All @@ -50,24 +54,46 @@ def __init__(self, platform, sys_clk_freq):
pll.register_clkin(clk27, 27e6)
pll.create_clkout(self.cd_sys, sys_clk_freq)

# HDMI PLL
if with_hdmi:
self.video_pll = video_pll = GW2APLL(devicename=platform.devicename, device=platform.device)
video_pll.register_clkin(clk27, 27e6)
video_pll.create_clkout(self.cd_hdmi5x, 125e6, margin=1e-2)
self.specials += Instance("CLKDIV",
p_DIV_MODE = "5",
i_RESETN = 1, # Disable reset signal.
i_CALIB = 0, # No calibration.
i_HCLKIN = self.cd_hdmi5x.clk,
o_CLKOUT = self.cd_hdmi.clk
)

# BaseSoC ------------------------------------------------------------------------------------------

class BaseSoC(SoCCore):
def __init__(self, toolchain="gowin", sys_clk_freq=48e6,
with_led_chaser = True,
with_rgb_led = False,
with_buttons = True,
with_spi_flash = False,
with_video_terminal = False,
with_video_colorbars = False,
**kwargs):

platform = sipeed_tang_nano_20k.Platform(toolchain=toolchain)

with_hdmi = with_video_terminal or with_video_colorbars

# CRG --------------------------------------------------------------------------------------
self.crg = _CRG(platform, sys_clk_freq)
self.crg = _CRG(platform, sys_clk_freq, with_hdmi=with_hdmi)

# SoCCore ----------------------------------------------------------------------------------
SoCCore.__init__(self, platform, sys_clk_freq, ident="LiteX SoC on Tang Nano 20K", **kwargs)

# TODO: XTX SPI Flash
# SPI Flash: XT25F64B ----------------------------------------------------------------------
if with_spi_flash:
from litespi.modules import W25Q64 as SpiFlashModule # compatible with XT25F64B
from litespi.opcodes import SpiNorFlashOpCodes as Codes
self.add_spi_flash(mode="1x", module=SpiFlashModule(Codes.READ_1_1_1))

# SDR SDRAM --------------------------------------------------------------------------------
if not self.integrated_main_ram_size:
Expand All @@ -94,6 +120,15 @@ def __init__(self):
l2_cache_size = 128,
)

# Video ------------------------------------------------------------------------------------
if with_hdmi:
self.videophy = VideoGowinHDMIPHY(platform.request("hdmi"), clock_domain="hdmi")
if with_video_terminal:
# self.add_video_terminal(phy=self.videophy, timings="800x600@60Hz", clock_domain="hdmi")
self.add_video_terminal(phy=self.videophy, timings="640x480@60Hz", clock_domain="hdmi")
if with_video_colorbars:
self.add_video_colorbars(phy=self.videophy, timings="800x600@60Hz", clock_domain="hdmi")

# Leds -------------------------------------------------------------------------------------
if with_led_chaser:
self.leds = LedChaser(
Expand Down Expand Up @@ -125,14 +160,23 @@ def main():
parser = LiteXArgumentParser(platform=sipeed_tang_nano_20k.Platform, description="LiteX SoC on Tang Nano 20K.")
parser.add_target_argument("--flash", action="store_true", help="Flash Bitstream.")
parser.add_target_argument("--sys-clk-freq", default=48e6, type=float, help="System clock frequency.")
parser.add_target_argument("--with-spi-flash", action="store_true", help="Enable SPI Flash (MMAPed).")
parser.add_target_argument("--with-rbg-led", action="store_true", help="Enable WS2812 RGB Led.")
sdopts = parser.target_group.add_mutually_exclusive_group()
sdopts.add_argument("--with-spi-sdcard", action="store_true", help="Enable SPI-mode SDCard support.")
sdopts.add_argument("--with-sdcard", action="store_true", help="Enable SDCard support.")
viopts = parser.target_group.add_mutually_exclusive_group()
viopts.add_argument("--with-video-terminal", action="store_true", help="Enable Video Terminal (HDMI).")
viopts.add_argument("--with-video-colorbars", action="store_true", help="Enable Video Colorbars (HDMI).")
args = parser.parse_args()

soc = BaseSoC(
toolchain = args.toolchain,
sys_clk_freq = args.sys_clk_freq,
with_rgb_led = args.with_rbg_led,
with_spi_flash = args.with_spi_flash,
with_video_terminal = args.with_video_terminal,
with_video_colorbars = args.with_video_colorbars,
**parser.soc_argdict
)
if args.with_spi_sdcard:
Expand Down

0 comments on commit a15fbb6

Please sign in to comment.