mirror of
https://github.com/litex-hub/litex-boards.git
synced 2025-01-03 03:43:36 -05:00
commit
9119250276
2 changed files with 96 additions and 5 deletions
|
@ -13,11 +13,87 @@ from litex.build.altera.programmer import USBBlaster
|
|||
_io = [
|
||||
# Clk
|
||||
("clk50", 0, Pins("AF14"), IOStandard("3.3-V LVTTL")),
|
||||
("clk50", 1, Pins("AA16"), IOStandard("3.3-V LVTTL")),
|
||||
("clk50", 2, Pins("Y26"), IOStandard("3.3-V LVTTL")),
|
||||
("clk50", 3, Pins("K14"), IOStandard("3.3-V LVTTL")),
|
||||
|
||||
# Leds
|
||||
("user_led", 0, Pins("V16"), IOStandard("3.3-V LVTTL")),
|
||||
("user_led", 1, Pins("W16"), IOStandard("3.3-V LVTTL")),
|
||||
("user_led", 2, Pins("V17"), IOStandard("3.3-V LVTTL")),
|
||||
("user_led", 3, Pins("V18"), IOStandard("3.3-V LVTTL")),
|
||||
("user_led", 4, Pins("W17"), IOStandard("3.3-V LVTTL")),
|
||||
("user_led", 5, Pins("W19"), IOStandard("3.3-V LVTTL")),
|
||||
("user_led", 6, Pins("Y19"), IOStandard("3.3-V LVTTL")),
|
||||
("user_led", 7, Pins("W20"), IOStandard("3.3-V LVTTL")),
|
||||
("user_led", 8, Pins("W21"), IOStandard("3.3-V LVTTL")),
|
||||
("user_led", 9, Pins("Y21"), IOStandard("3.3-V LVTTL")),
|
||||
|
||||
# Seven Segment
|
||||
("seven_seg", 0, Pins("AE26 AE27 AE28 AG27 AF28 AG28 AH28"), IOStandard("3.3-V LVTTL")),
|
||||
("seven_seg", 1, Pins("AJ29 AH29 AH30 AG30 AF29 AF30 AD27"), IOStandard("3.3-V LVTTL")),
|
||||
("seven_seg", 2, Pins("AB23 AE29 AD29 AC28 AD30 AC29 AC30"), IOStandard("3.3-V LVTTL")),
|
||||
("seven_seg", 3, Pins("AD26 AC27 AD25 AC25 AB28 AB25 AB22"), IOStandard("3.3-V LVTTL")),
|
||||
("seven_seg", 4, Pins("AA24 Y23 Y24 W22 W24 V23 W25"), IOStandard("3.3-V LVTTL")),
|
||||
("seven_seg", 5, Pins("V25 AA28 Y27 AB27 AB26 AA26 AA2"), IOStandard("3.3-V LVTTL")),
|
||||
|
||||
# Button
|
||||
("key", 0, Pins("AA14"), IOStandard("3.3-V LVTTL")),
|
||||
("key", 1, Pins("AA15"), IOStandard("3.3-V LVTTL")),
|
||||
("key", 2, Pins("W15"), IOStandard("3.3-V LVTTL")),
|
||||
("key", 3, Pins("Y16"), IOStandard("3.3-V LVTTL")),
|
||||
|
||||
# Switches
|
||||
("user_sw", 0, Pins("AB12"), IOStandard("3.3-V LVTTL")),
|
||||
("user_sw", 1, Pins("AC12"), IOStandard("3.3-V LVTTL")),
|
||||
("user_sw", 2, Pins("AF9"), IOStandard("3.3-V LVTTL")),
|
||||
("user_sw", 3, Pins("AF10"), IOStandard("3.3-V LVTTL")),
|
||||
("user_sw", 4, Pins("AD11"), IOStandard("3.3-V LVTTL")),
|
||||
("user_sw", 5, Pins("AD12"), IOStandard("3.3-V LVTTL")),
|
||||
("user_sw", 6, Pins("AE11"), IOStandard("3.3-V LVTTL")),
|
||||
("user_sw", 7, Pins("AC9"), IOStandard("3.3-V LVTTL")),
|
||||
("user_sw", 8, Pins("AD10"), IOStandard("3.3-V LVTTL")),
|
||||
("user_sw", 9, Pins("AE12"), IOStandard("3.3-V LVTTL")),
|
||||
|
||||
# Serial
|
||||
("serial", 0,
|
||||
Subsignal("tx", Pins("AC18"), IOStandard("3.3-V LVTTL")), # JP1 GPIO[0]
|
||||
Subsignal("rx", Pins("Y17"), IOStandard("3.3-V LVTTL")) # JP1 GPIO[1]
|
||||
Subsignal("tx", Pins("JP1:1"), IOStandard("3.3-V LVTTL")),
|
||||
Subsignal("rx", Pins("JP1:2"), IOStandard("3.3-V LVTTL"))
|
||||
),
|
||||
|
||||
# I2C
|
||||
("i2c", 0,
|
||||
Subsignal("sclk", Pins("J12")),
|
||||
Subsignal("sdat", Pins("K12")),
|
||||
IOStandard("3.3-V LVTTL")
|
||||
),
|
||||
|
||||
# VGA
|
||||
("vga", 0,
|
||||
Subsignal("hsync_n", Pins("B11")),
|
||||
Subsignal("vsync_n", Pins("D11")),
|
||||
Subsignal("r", Pins("A13 C13 E13 B12 C12 D12 E12 F1")),
|
||||
Subsignal("g", Pins("J9 J10 H12 G10 G11 G12 F11 E11")),
|
||||
Subsignal("b", Pins("B13 G13 H13 F14 H14 F15 G15 J14 F10")),
|
||||
IOStandard("3.3-V LVTTL")
|
||||
),
|
||||
|
||||
# GPIOs
|
||||
("gpio_0", 0, Pins(
|
||||
"D3 C3 A2 A3 B3 B4 A4 B5",
|
||||
"A5 D5 B6 A6 B7 D6 A7 C6",
|
||||
"C8 E6 E7 D8 E8 F8 F9 E9",
|
||||
"C9 D9 E11 E10 C11 B11 A12 D11",
|
||||
"D12 B12"),
|
||||
IOStandard("3.3-V LVTTL")
|
||||
),
|
||||
("gpio_1", 0, Pins(
|
||||
"F13 T15 T14 T13 R13 T12 R12 T11",
|
||||
"T10 R11 P11 R10 N12 P9 N9 N11",
|
||||
"L16 K16 R16 L15 P15 P16 R14 N16",
|
||||
"N15 P14 L14 N14 M10 L13 J16 K15",
|
||||
"J13 J14"),
|
||||
IOStandard("3.3-V LVTTL")
|
||||
),
|
||||
|
||||
# SDR SDRAM
|
||||
|
@ -40,6 +116,14 @@ _io = [
|
|||
),
|
||||
]
|
||||
|
||||
# Connectors ---------------------------------------------------------------------------------------
|
||||
|
||||
_connectors = [
|
||||
# PIN 0 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40
|
||||
("JP1", "- AC18 Y17 AD17 Y18 AK16 AK18 AK19 AJ19 AJ17 AJ16 - - AH18 AH17 AG16 AE16 AF16 AG17 AA18 AA19 AE17 AC20 AH19 AJ20 AH20 AK21 AD19 AD20 - - AE18 AE19 AF20 AF21 AF19 AG21 AF18 AG20 AG18 AJ21"),
|
||||
("JP2", "- AB17 AA21 AB21 AC23 AD24 AE23 AE24 AF25 AF26 AG25 - - AG26 AH24 AH27 AJ27 AK29 AK28 AK27 AJ26 AK26 AH25 AJ25 AJ24 AK24 AG23 AK23 AH23 - - AK22 AJ22 AH22 AG22 AF24 AF23 AE22 AD21 AA20 AC22")
|
||||
]
|
||||
|
||||
# Platform -----------------------------------------------------------------------------------------
|
||||
|
||||
class Platform(AlteraPlatform):
|
||||
|
@ -47,10 +131,10 @@ class Platform(AlteraPlatform):
|
|||
default_clk_period = 1e9/50e6
|
||||
|
||||
def __init__(self):
|
||||
AlteraPlatform.__init__(self, "5CSEMA5F31C6", _io)
|
||||
AlteraPlatform.__init__(self, "5CSEMA5F31C6", _io, _connectors)
|
||||
|
||||
def create_programmer(self):
|
||||
return USBBlaster()
|
||||
return USBBlaster(cable_name="DE-SoC", device_id=2)
|
||||
|
||||
def do_finalize(self, fragment):
|
||||
AlteraPlatform.do_finalize(self, fragment)
|
||||
|
|
|
@ -19,6 +19,7 @@ from litex_boards.platforms import de1soc
|
|||
from litex.soc.cores.clock import CycloneVPLL
|
||||
from litex.soc.integration.soc_core import *
|
||||
from litex.soc.integration.builder import *
|
||||
from litex.soc.cores.led import LedChaser
|
||||
|
||||
from litedram.modules import IS42S16320
|
||||
from litedram.phy import GENSDRPHY
|
||||
|
@ -49,7 +50,7 @@ class _CRG(Module):
|
|||
# BaseSoC ------------------------------------------------------------------------------------------
|
||||
|
||||
class BaseSoC(SoCCore):
|
||||
def __init__(self, sys_clk_freq=int(50e6), **kwargs):
|
||||
def __init__(self, sys_clk_freq=int(50e6), with_led_chaser=True, **kwargs):
|
||||
platform = de1soc.Platform()
|
||||
|
||||
# SoCCore ----------------------------------------------------------------------------------
|
||||
|
@ -70,6 +71,12 @@ class BaseSoC(SoCCore):
|
|||
l2_cache_size = kwargs.get("l2_size", 8192)
|
||||
)
|
||||
|
||||
# Leds -------------------------------------------------------------------------------------
|
||||
if with_led_chaser:
|
||||
self.submodules.leds = LedChaser(
|
||||
pads = platform.request_all("user_led"),
|
||||
sys_clk_freq = sys_clk_freq)
|
||||
|
||||
# Build --------------------------------------------------------------------------------------------
|
||||
|
||||
def main():
|
||||
|
|
Loading…
Reference in a new issue