boards/platform/ac701: add proper copyright, cleanup to be similar to others platforms

This commit is contained in:
Florent Kermarrec 2019-04-23 10:02:07 +02:00
parent 0122982e09
commit ea8dbff86e

View file

@ -1,7 +1,10 @@
from litex.build.generic_platform import * # This file is Copyright (c) 2019 Vamsi K Vytla <vamsi.vytla@gmail.com>
from litex.build.xilinx import XilinxPlatform, XC3SProg, VivadoProgrammer, iMPACT # License: BSD
from litex.build.xilinx.ise import XilinxISEToolchain
from litex.build.generic_platform import *
from litex.build.xilinx import XilinxPlatform, VivadoProgrammer
# IOs ----------------------------------------------------------------------------------------------
_io = [ _io = [
("user_led", 0, Pins("M26"), IOStandard("LVCMOS33")), ("user_led", 0, Pins("M26"), IOStandard("LVCMOS33")),
@ -26,7 +29,8 @@ _io = [
Subsignal("rts", Pins("W19")), Subsignal("rts", Pins("W19")),
Subsignal("tx", Pins("U19")), Subsignal("tx", Pins("U19")),
Subsignal("rx", Pins("T19")), Subsignal("rx", Pins("T19")),
IOStandard("LVCMOS18")), IOStandard("LVCMOS18")
),
("eth_clocks", 0, ("eth_clocks", 0,
Subsignal("tx", Pins("U22")), Subsignal("tx", Pins("U22")),
@ -85,6 +89,7 @@ _io = [
Subsignal("p", Pins("AA13")), Subsignal("p", Pins("AA13")),
Subsignal("n", Pins("AB13")) Subsignal("n", Pins("AB13"))
), ),
("sfp", 0, ("sfp", 0,
Subsignal("txp", Pins("AC10")), Subsignal("txp", Pins("AC10")),
Subsignal("txn", Pins("AD10")), Subsignal("txn", Pins("AD10")),
@ -95,130 +100,125 @@ _io = [
("sfp_mgt_clk_sel1", 0, Pins("C24"), IOStandard("LVCMOS25")), ("sfp_mgt_clk_sel1", 0, Pins("C24"), IOStandard("LVCMOS25")),
("sfp_tx_disable_n", 0, Pins("R18"), IOStandard("LVCMOS33")), ("sfp_tx_disable_n", 0, Pins("R18"), IOStandard("LVCMOS33")),
("sfp_rx_los", 0, Pins("R23"), IOStandard("LVCMOS33")), ("sfp_rx_los", 0, Pins("R23"), IOStandard("LVCMOS33")),
("XADC", 0,
Subsignal("GPIO0", Pins("H17")),
Subsignal("GPIO1", Pins("E22")),
Subsignal("GPIO2", Pins("K18")),
Subsignal("GPIO3", Pins("L19")),
Subsignal("VAUX0_N", Pins("J16")),
Subsignal("VAUX0_P", Pins("K15")),
Subsignal("VAUX8_N", Pins("J15")),
Subsignal("VAUX8_P", Pins("J14")),
IOStandard("LVCMOS25")),
] ]
# Connectors ---------------------------------------------------------------------------------------
_connectors = [ _connectors = [
('HPC', ("HPC", {
{'CLK0_M2C_N': 'C19', "CLK0_M2C_N": "C19",
'CLK0_M2C_P': 'D19', "CLK0_M2C_P": "D19",
'CLK1_M2C_N': 'H22', "CLK1_M2C_N": "H22",
'CLK1_M2C_P': 'H21', "CLK1_M2C_P": "H21",
'LA00_CC_N': 'C18', "LA00_CC_N": "C18",
'LA00_CC_P': 'D18', "LA00_CC_P": "D18",
'LA01_CC_N': 'E18', "LA01_CC_N": "E18",
'LA01_CC_P': 'E17', "LA01_CC_P": "E17",
'LA02_N': 'H15', "LA02_N": "H15",
'LA02_P': 'H14', "LA02_P": "H14",
'LA03_N': 'F17', "LA03_N": "F17",
'LA03_P': 'G17', "LA03_P": "G17",
'LA04_N': 'F19', "LA04_N": "F19",
'LA04_P': 'F18', "LA04_P": "F18",
'LA05_N': 'F15', "LA05_N": "F15",
'LA05_P': 'G15', "LA05_P": "G15",
'LA06_N': 'F20', "LA06_N": "F20",
'LA06_P': 'G19', "LA06_P": "G19",
'LA07_N': 'G16', "LA07_N": "G16",
'LA07_P': 'H16', "LA07_P": "H16",
'LA08_N': 'B17', "LA08_N": "B17",
'LA08_P': 'C17', "LA08_P": "C17",
'LA09_N': 'D16', "LA09_N": "D16",
'LA09_P': 'E16', "LA09_P": "E16",
'LA10_N': 'A18', "LA10_N": "A18",
'LA10_P': 'A17', "LA10_P": "A17",
'LA11_N': 'A19', "LA11_N": "A19",
'LA11_P': 'B19', "LA11_P": "B19",
'LA12_N': 'D20', "LA12_N": "D20",
'LA12_P': 'E20', "LA12_P": "E20",
'LA13_N': 'A20', "LA13_N": "A20",
'LA13_P': 'B20', "LA13_P": "B20",
'LA14_N': 'B21', "LA14_N": "B21",
'LA14_P': 'C21', "LA14_P": "C21",
'LA15_N': 'A22', "LA15_N": "A22",
'LA15_P': 'B22', "LA15_P": "B22",
'LA16_N': 'D21', "LA16_N": "D21",
'LA16_P': 'E21', "LA16_P": "E21",
'LA17_CC_N': 'J21', "LA17_CC_N": "J21",
'LA17_CC_P': 'K21', "LA17_CC_P": "K21",
'LA18_CC_N': 'G21', "LA18_CC_N": "G21",
'LA18_CC_P': 'G20', "LA18_CC_P": "G20",
'LA19_N': 'L14', "LA19_N": "L14",
'LA19_P': 'M14', "LA19_P": "M14",
'LA20_N': 'M17', "LA20_N": "M17",
'LA20_P': 'M16', "LA20_P": "M16",
'LA21_N': 'H19', "LA21_N": "H19",
'LA21_P': 'J19', "LA21_P": "J19",
'LA22_N': 'L18', "LA22_N": "L18",
'LA22_P': 'L17', "LA22_P": "L17",
'LA23_N': 'J20', "LA23_N": "J20",
'LA23_P': 'K20', "LA23_P": "K20",
'LA24_N': 'H18', "LA24_N": "H18",
'LA24_P': 'J18', "LA24_P": "J18",
'LA25_N': 'F22', "LA25_N": "F22",
'LA25_P': 'G22', "LA25_P": "G22",
'LA26_N': 'H24', "LA26_N": "H24",
'LA26_P': 'J24', "LA26_P": "J24",
'LA27_N': 'E23', "LA27_N": "E23",
'LA27_P': 'F23', "LA27_P": "F23",
'LA28_N': 'K23', "LA28_N": "K23",
'LA28_P': 'K22', "LA28_P": "K22",
'LA29_N': 'F24', "LA29_N": "F24",
'LA29_P': 'G24', "LA29_P": "G24",
'LA30_N': 'D25', "LA30_N": "D25",
'LA30_P': 'E25', "LA30_P": "E25",
'LA31_N': 'D26', "LA31_N": "D26",
'LA31_P': 'E26', "LA31_P": "E26",
'LA32_N': 'G26', "LA32_N": "G26",
'LA32_P': 'H26', "LA32_P": "H26",
'LA33_N': 'F25', "LA33_N": "F25",
'LA33_P': 'G25', "LA33_P": "G25",
'PRSNT_M2C_L': 'N16', "PRSNT_M2C_L": "N16",
'PWR_GOOD_FLASH_RST_B': 'P15'}) "PWR_GOOD_FLASH_RST_B": "P15"}
),
("XADC", {
"GPIO0": "H17",
"GPIO1": "E22",
"GPIO2": "K18",
"GPIO3": "L19",
"VAUX0_N": "J16",
"VAUX0_P": "K15",
"VAUX8_N": "J15",
"VAUX8_P": "J14",
}
),
] ]
# Platform -----------------------------------------------------------------------------------------
class Platform(XilinxPlatform): class Platform(XilinxPlatform):
default_clk_name = "clk156" default_clk_name = "clk156"
default_clk_period = 6.4 default_clk_period = 6.4
def __init__(self, toolchain="vivado", programmer="vivado"): def __init__(self):
XilinxPlatform.__init__(self, "xc7a200t-fbg676-2", _io, _connectors, XilinxPlatform.__init__(self, "xc7a200t-fbg676-2", _io, _connectors, toolchain="vivado")
toolchain=toolchain)
self.toolchain.bitstream_commands = ["set_property BITSTREAM.CONFIG.SPI_BUSWIDTH 4 [current_design]"] self.toolchain.bitstream_commands = ["set_property BITSTREAM.CONFIG.SPI_BUSWIDTH 4 [current_design]"]
self.toolchain.additional_commands = ["write_cfgmem -force -format bin -interface spix4 -size 16 -loadbit \"up 0x0 {build_name}.bit\" -file {build_name}.bin"] self.toolchain.additional_commands = ["write_cfgmem -force -format bin -interface spix4 -size 16 -loadbit \"up 0x0 {build_name}.bit\" -file {build_name}.bin"]
self.programmer = programmer
def create_programmer(self): def create_programmer(self):
if self.programmer == "xc3sprog": return VivadoProgrammer()
return XC3SProg("jtaghs1_fast")
elif self.programmer == "vivado":
return VivadoProgrammer()
elif self.programmer == "impact":
return iMPACT()
else:
raise ValueError("{} programmer is not supported".format(programmer))
def do_finalize(self, fragment): def do_finalize(self, fragment):
XilinxPlatform.do_finalize(self, fragment) XilinxPlatform.do_finalize(self, fragment)
try: try:
self.add_period_constraint(self.lookup_request("clk200").p, 5.0) self.add_period_constraint(self.lookup_request("clk200").p, 1e9/200e6)
except ConstraintError: except ConstraintError:
pass pass
try: try:
self.add_period_constraint(self.lookup_request("eth_clocks").rx, 8.0) self.add_period_constraint(self.lookup_request("eth_clocks").rx, 1e9/125e6)
except ConstraintError: except ConstraintError:
pass pass
try: try:
self.add_period_constraint(self.lookup_request("eth_clocks").tx, 8.0) self.add_period_constraint(self.lookup_request("eth_clocks").tx, 1e9/125e6)
except ConstraintError: except ConstraintError:
pass pass