Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in / Register
Toggle navigation
L
litex-boards
Project overview
Project overview
Details
Activity
Releases
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Issues
0
Issues
0
List
Boards
Labels
Milestones
Merge Requests
1
Merge Requests
1
Analytics
Analytics
Repository
Value Stream
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Commits
Issue Boards
Open sidebar
Kestrel Collaboration
Kestrel LiteX
litex-boards
Commits
47faaf20
Commit
47faaf20
authored
Mar 09, 2021
by
Florent Kermarrec
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
deca: Integrate Video Terminal (untested, resource issue).
parent
8fb80053
Changes
2
Hide whitespace changes
Inline
Side-by-side
Showing
2 changed files
with
30 additions
and
22 deletions
+30
-22
litex_boards/platforms/deca.py
litex_boards/platforms/deca.py
+14
-14
litex_boards/targets/deca.py
litex_boards/targets/deca.py
+16
-8
No files found.
litex_boards/platforms/deca.py
View file @
47faaf20
...
...
@@ -50,7 +50,7 @@ _io = [
(
"temp"
,
0
,
Subsignal
(
"cs_n"
,
Pins
(
"PIN_AB4"
)),
Subsignal
(
"sc"
,
Pins
(
"PIN_AA1"
)),
Subsignal
(
"sio"
,
Pins
(
"PIN_Y2"
)),
Subsignal
(
"sio"
,
Pins
(
"PIN_Y2"
)),
IOStandard
(
"3.3-V LVTTL"
)
),
...
...
@@ -199,14 +199,14 @@ _io = [
# HDMI
(
"hdmi"
,
0
,
Subsignal
(
"
tx_d_r"
,
Pins
(
"C18 D17 C17 C19 D14 B19 D13 A19 C14
"
)),
Subsignal
(
"
tx_d_
g"
,
Pins
(
"C14 A17 B16 C15 A14 A15 A12 A16"
)),
Subsignal
(
"
tx_d_
b"
,
Pins
(
"A13 C16 C12 B17 B12 B14 A18 C13"
)),
Subsignal
(
"
tx_clk"
,
Pins
(
"A20"
)),
Subsignal
(
"
tx_de"
,
Pins
(
"C9"
)),
Subsignal
(
"
tx_hs"
,
Pins
(
"B11"
)),
Subsignal
(
"
tx_vs"
,
Pins
(
"C11"
)),
Subsignal
(
"
tx_int"
,
Pins
(
"B10"
)),
Subsignal
(
"
r"
,
Pins
(
"C18 D17 C17 C19 D14 B19 D13 A19
"
)),
Subsignal
(
"g"
,
Pins
(
"C14 A17 B16 C15 A14 A15 A12 A16"
)),
Subsignal
(
"b"
,
Pins
(
"A13 C16 C12 B17 B12 B14 A18 C13"
)),
Subsignal
(
"
clk"
,
Pins
(
"A20"
)),
Subsignal
(
"
de"
,
Pins
(
"C9"
)),
Subsignal
(
"
hsync"
,
Pins
(
"B11"
)),
Subsignal
(
"
vsync"
,
Pins
(
"C11"
)),
Subsignal
(
"
int"
,
Pins
(
"B10"
)),
Misc
(
"FAST_OUTPUT_REGISTER ON"
),
IOStandard
(
"1.8 V"
)
),
...
...
@@ -252,14 +252,14 @@ _io = [
(
"gpio"
,
0
,
Pins
(
"P8:3 P8:4 P8:5 P8:6 P8:7 P8:8 P8:9 P8:10"
,
"P8:11 P8:12 P8:13 P8:14 P8:15 P8:16 P8:17 P8:18"
,
"P8:19 P8:20 P8:21 P8:22 P8:23 P8:24 P8:25 P8:26"
,
"P8:19 P8:20 P8:21 P8:22 P8:23 P8:24 P8:25 P8:26"
,
"P8:27 P8:28 P8:29 P8:30 P8:31 P8:32 P8:33 P8:34"
,
"P8:35 P8:36 P8:37 P8:38 P8:39 P8:40 P8:41 P8:42"
,
"P8:43 P8:44 P8:45 P8:46"
),
IOStandard
(
"3.3-V LVTTL"
)
),
(
"gpio"
,
1
,
Pins
(
"P9:11 P9:12 P9:13 P9:14 P9:15 P9:16 P9:17 P9:18"
,
"P9:19 P9:20 P9:21 P9:22 P9:23 P9:24 P9:25 P9:26"
,
"P9:19 P9:20 P9:21 P9:22 P9:23 P9:24 P9:25 P9:26"
,
"P9:27 P9:28 P9:29 P9:30 P9:31 P9:41 P9:42"
),
IOStandard
(
"3.3-V LVTTL"
)
),
...
...
@@ -269,8 +269,8 @@ _io = [
_connectors
=
[
# Beagle bone black headers (numbering 1-based, Pin 0 is dummy)
# 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 41 42 43 44 45 46
(
"P8"
,
"- - - W18 Y18 Y19 AA17 AA20 AA19 AB21 AB20 AB19 Y16 V16 AB18 V15 W17 AB17 AA16 AB16 W16 AB15 W15 Y14 AA15 AB14 AA14 AB13 AA13 AB12 AA12 AB11 AA11 AB10 Y13 Y11 W13 W12 W11 V12 V11 V13 V14 Y17 W14 U15 R13"
),
# 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 41 42 43 44 45 46
(
"P8"
,
"- - - W18 Y18 Y19 AA17 AA20 AA19 AB21 AB20 AB19 Y16 V16 AB18 V15 W17 AB17 AA16 AB16 W16 AB15 W15 Y14 AA15 AB14 AA14 AB13 AA13 AB12 AA12 AB11 AA11 AB10 Y13 Y11 W13 W12 W11 V12 V11 V13 V14 Y17 W14 U15 R13"
),
(
"P9"
,
"- - - - - - - - - U6 AA2 Y5 Y6 W6 W7 W8 V8 AB8 V7 R11 AB7 AB6 AA7 AA6 Y7 V10 U7 W9 W5 R9 W4 P9 - K4 - J4 H3 J8 J9 F5 F4 V17 W3 - - - -"
)
]
...
...
@@ -283,7 +283,7 @@ class Platform(AlteraPlatform):
def
__init__
(
self
):
AlteraPlatform
.
__init__
(
self
,
"10M50DAF484C6GES"
,
_io
,
_connectors
)
# disable config pin so bank8 can use 1.2V
# disable config pin so bank8 can use 1.2V
self
.
add_platform_command
(
"set_global_assignment -name AUTO_RESTART_CONFIGURATION ON"
)
self
.
add_platform_command
(
"set_global_assignment -name ENABLE_CONFIGURATION_PINS OFF"
)
self
.
add_platform_command
(
"set_global_assignment -name ENABLE_BOOT_SEL_PIN OFF"
)
...
...
litex_boards/targets/deca.py
View file @
47faaf20
...
...
@@ -21,6 +21,7 @@ from litex.soc.integration.soc import SoCRegion
from
litex.soc.integration.soc_core
import
*
from
litex.soc.integration.soc_sdram
import
*
from
litex.soc.integration.builder
import
*
from
litex.soc.cores.video
import
VideoDVIPHY
from
litex.soc.cores.led
import
LedChaser
# CRG ----------------------------------------------------------------------------------------------
...
...
@@ -29,7 +30,7 @@ class _CRG(Module):
def
__init__
(
self
,
platform
,
sys_clk_freq
):
self
.
rst
=
Signal
()
self
.
clock_domains
.
cd_sys
=
ClockDomain
()
self
.
clock_domains
.
cd_
sys_ps
=
ClockDomain
(
reset_less
=
True
)
self
.
clock_domains
.
cd_
hdmi
=
ClockDomain
(
)
# # #
...
...
@@ -40,13 +41,13 @@ class _CRG(Module):
self
.
submodules
.
pll
=
pll
=
Max10PLL
(
speedgrade
=
"-6"
)
self
.
comb
+=
pll
.
reset
.
eq
(
self
.
rst
)
pll
.
register_clkin
(
clk50
,
50e6
)
pll
.
create_clkout
(
self
.
cd_sys
,
sys_clk_freq
)
pll
.
create_clkout
(
self
.
cd_
sys_ps
,
sys_clk_freq
,
phase
=
90
)
pll
.
create_clkout
(
self
.
cd_sys
,
sys_clk_freq
)
pll
.
create_clkout
(
self
.
cd_
hdmi
,
40e6
)
# BaseSoC ------------------------------------------------------------------------------------------
class
BaseSoC
(
SoCCore
):
def
__init__
(
self
,
sys_clk_freq
=
int
(
50e6
),
with_v
ga
=
False
,
**
kwargs
):
def
__init__
(
self
,
sys_clk_freq
=
int
(
50e6
),
with_v
ideo_terminal
=
False
,
**
kwargs
):
platform
=
deca
.
Platform
()
# Defaults to UART over JTAG because no hardware uart is on the board
...
...
@@ -62,6 +63,11 @@ class BaseSoC(SoCCore):
# CRG --------------------------------------------------------------------------------------
self
.
submodules
.
crg
=
_CRG
(
platform
,
sys_clk_freq
)
# Video ------------------------------------------------------------------------------------
if
with_video_terminal
:
self
.
submodules
.
videophy
=
VideoDVIPHY
(
platform
.
request
(
"hdmi"
),
clock_domain
=
"hdmi"
)
self
.
add_video_terminal
(
phy
=
self
.
videophy
,
timings
=
"800x600@60Hz"
,
clock_domain
=
"hdmi"
)
# Leds -------------------------------------------------------------------------------------
self
.
submodules
.
leds
=
LedChaser
(
pads
=
platform
.
request_all
(
"user_led"
),
...
...
@@ -72,15 +78,17 @@ class BaseSoC(SoCCore):
def
main
():
parser
=
argparse
.
ArgumentParser
(
description
=
"LiteX SoC on DECA"
)
parser
.
add_argument
(
"--build"
,
action
=
"store_true"
,
help
=
"Build bitstream"
)
parser
.
add_argument
(
"--load"
,
action
=
"store_true"
,
help
=
"Load bitstream"
)
parser
.
add_argument
(
"--sys-clk-freq"
,
default
=
50e6
,
help
=
"System clock frequency (default: 50MHz)"
)
parser
.
add_argument
(
"--build"
,
action
=
"store_true"
,
help
=
"Build bitstream"
)
parser
.
add_argument
(
"--load"
,
action
=
"store_true"
,
help
=
"Load bitstream"
)
parser
.
add_argument
(
"--sys-clk-freq"
,
default
=
50e6
,
help
=
"System clock frequency (default: 50MHz)"
)
parser
.
add_argument
(
"--with-video-terminal"
,
action
=
"store_true"
,
help
=
"Enable Video Terminal (VGA)"
)
builder_args
(
parser
)
soc_sdram_args
(
parser
)
args
=
parser
.
parse_args
()
soc
=
BaseSoC
(
sys_clk_freq
=
int
(
float
(
args
.
sys_clk_freq
)),
sys_clk_freq
=
int
(
float
(
args
.
sys_clk_freq
)),
with_video_terminal
=
args
.
with_video_terminal
,
**
soc_sdram_argdict
(
args
)
)
builder
=
Builder
(
soc
,
**
builder_argdict
(
args
))
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment