from mibuild.generic_platform import * from mibuild.crg import SimpleCRG from mibuild.xilinx.ise import XilinxISEPlatform _ios = [ ("clk0", 0, Pins("N9"), IOStandard("LVCMOS18")), ("fpga_reset", 0, Pins("T9"), IOStandard("LVCMOS18"), Drive("8")), ("fpga_initb", 0, Pins("T12"), IOStandard("LVCMOS18"), Drive("8")), ("weim", 0, Subsignal("cs4_dtack", Pins("R3"), IOStandard("LVCMOS18"), Drive("8")), Subsignal("cs5n", Pins("P10"), IOStandard("LVCMOS18")), Subsignal("eb0n", Pins("P9"), IOStandard("LVCMOS18")), Subsignal("oen", Pins("R9"), IOStandard("LVCMOS18")), Subsignal("data", Pins("T5 T6 P7 N8 P12 T13 R13 T14 P5 N6 T3 T11 T4 R5 M10 T10"), IOStandard("LVCMOS18"), Drive("8")), Subsignal("addr", Pins("N5 L7 M7 M8 L8 L9 L10 M11 P11 N11 N12 P13"), IOStandard("LVCMOS18")) ) ] _connectors = [ ("J2", "None", # no 0 pin "None", # 1 +3v3 "None", # 2 +3v3 "None", # 3 GND "None", # 4 GND "None", # 5 DP USB_OTG_PHY +3V3 "None", # 6 DM USB_OTG_PHY +3V3 "None", # 7 VBUS USB_OTG_ PHY +3V3 "None", # 8 PSW_N USB_OTG_PHY +3V3 "None", # 9 ID USB_OTG_PHY +3V3 "None", # 10 FAULT USB_OTG_PHY +3V3 "None", # 11 RXP Ethernet_PHY +3V3 "None", # 12 RXN Ethernet_PHY +3V3 "None", # 13 ETH_LINK Ethernet_PHY +2V8 "None", # 14 PC_VS2 PC +2V8 PF13 "None", # 15 PC_VS1 PC +2V8 PF14 "None", # 16 PC_PWRON PC +2V8 PF16 "None", # 17 PC_READY PC +2V8 PF17 "None", # 18 PWM0 PWM0 +2V8 PE5 "None", # 19 TOUT GPT +2V8 PC14 "None", # 20 GND POWER "None", # 21 VCC01 (IN) BANK1 SUPPLY VCCO1 "C16", # 22 IO_L24P_1 FPGA_BANK1 VCC01 "C15", # 23 IO_L24N_1 FPGA_BANK1 VCC01 "D16", # 24 IO_L22_P1 FPGA_BANK1 VCC01 "None", # 25 GND POWER "B14", # 26 IO_L02N_0 FPGA_BANK0 VCCO0 "B15", # 27 IO_L02P_0 FPGA_BANK0 "A13", # 28 IO_L04N_0 FPGA_BANK0 "A14", # 29 IO_L04P_0 FPGA_BANK0 VCCO0 "D11", # 30 IO_L03N_0 FPGA_BANK0 VCCO0 "C12", # 31 IO_L03P_0 FPGA_BANK0 VCCO0 "A10", # 32 IO_L08N_0 FPGA_BANK0 VCCO0 "B10", # 33 IO_L08P_0 FPGA_BANK0 VCCO0 "A9", # 34 IO_L10N_0 / GLCK7 FPGA_BANK0 VCCO0 "C9", # 35 IO_L10P_0 / GCLK6 FPGA_BANK0 VCCO0 "B8", # 36 IO_L12N_0 / GCLK11 FPGA_BANK0 VCCO0 "A8", # 37 IO_L12P_0 / GCLK10 FPGA_BANK0 VCCO0 "B6", # 38 IO_L15N_0 FPGA_BANK0 VCCO0 "A6", # 39 IO_L15P_0 FPGA_BANK0 VCCO0 "B4", # 40 IO_L18N_0 FPGA_BANK0 VCCO0 "A4", # 41 IO_L18P_0 FPGA_BANK0 VCCO0 "None", # 42 GND POWER "N3", # 43 IO_L24P_3 FPGA_BANK3 VCCO3 "R1", # 44 IO_L23P_3 FPGA_BANK3 VCCO3 "P1", # 45 IO_L22N_3 FPGA_BANK3 VCCO3 "N1", # 46 IO_L20N_3 FPGA_BANK3 VCCO3 "M1", # 47 IO_L20P_3 FPGA_BANK3 VCCO3 "H3", # 48 IO_L12P_3 FPGA_BANK3 VCCO3 "K1", # 49 IO_L15N_3 FPGA_BANK3 VCCO3 "J1", # 50 IO_L14N_3 FPGA_BANK3 VCCO3 "H1", # 51 IO_L11N_3 FPGA_BANK3 VCCO3 "G1", # 52 IO_L08N_3 FPGA_BANK3 VCCO3 "F1", # 53 IO_L08P_3 FPGA_BANK3 VCCO3 "E1", # 54 IO_L03N_3 FPGA_BANK3 VCCO3 "D1", # 55 IO_LO3P_3 FPGA_BANK3 VCCO3 "C1", # 56 IO_L01N_3 FPGA_BANK3 VCCO3 "None", # 57 GND POWER "None", # 58 TRSTN JTAG +2V8 "None", # 59 TDI JTAG +2V8 "None", # 60 TCK JTAG +2V8 "None", # 61 TDO JTAG +2V8 "None", # 62 TMS JTAG +2V8 "None", # 63 GND POWER "C2", # 64 IO_L01P_3 FPGA_BANK3 VCCO3 "D3", # 65 IO_L02N_3 FPGA_BANK3 VCCO3 "D4", # 66 IO_L02P_3 FPGA_BANK3 VCCO3 "F4", # 67 IP_LO4N_3 FPGA_BANK3 VCCO3 "G2", # 68 IO_L11P_3 FPGA_BANK3 VCCO3 "J2", # 69 IO_L14P_3 FPGA_BANK3 VCCO3 "K3", # 70 IO_L15P_3 FPGA_BANK3 VCCO3 "J3", # 71 IO_L12N_3 FPGA_BANK3 VCCO3 "N2", # 72 IO_L22P_3 FPGA_BANK3 VCCO3 "P2", # 73 IO_L23N_3 FPGA_BANK3 VCCO3 "M4", # 74 IO_L24N_3 FPGA_BANK3 VCCO3 "L6", # 75 IP_L25N_3 FPGA_BANK3 VCCO3 "None", # 76 VCCO3 (IN) BANK3 SUPPLY VCCO3 (3.3Vmax) "None", # 77 VCCO3 (IN) BANK3 SUPPLY VCCO3 (3.3Vmax) "A3", # 78 IO_L19P_0 FPGA_BANK0 VCCO0 "B3", # 79 IO_L19N_0 FPGA_BANK0 VCCO0 "A5", # 80 IO_L17P_0 FPGA_BANK0 VCCO0 "C5", # 81 IO_L17N_0 FPGA_BANK0 VCCO0 "D7", # 82 IO_L16P_0 FPGA_BANK0 VCCO0 "C6", # 83 IO_L16N_0 FPGA_BANK0 VCCO0 "C8", # 84 IO_L11P_0 / GCLK8 FPGA_BANK0 VCCO0 "D8", # 85 IO_L11N_0 / GCLK9 FPGA_BANK0 VCCO0 "C10", # 86 IO_L09P_0 / GCLK4 FPGA_BANK0 VCCO0 "D9", # 87 IO_L09N_0 / GCLK5 FPGA_BANK0 VCCO0 "C11", # 88 IO_L07P_0 FPGA_BANK0 VCCO0 "A11", # 89 IO_L07N_0 FPGA_BANK0 VCCO0 "D13", # 90 IO_L01P_0 FPGA_BANK0 VCCO0 "C13", # 91 IO_L01N_0 FPGA_BANK0 VCCO0 "None", # 92 VCCO0 (IN) BANK0 SUPPLY VCCO0 (3.3Vmax) "None", # 93 VCCO0 (IN) BANK0 SUPPLY VCCO0 (3.3Vmax) "None", # 94 GND POWER VCCO0 A13 "D15", # 95 IO_L22N_1 FPGA_BANK1 VCC01 "E13", # 96 IO_L23P_1 FPGA_BANK1 VCC01 "D14", # 97 IO_L23N_1 FPGA_BANK1 VCC01 "E14", # 98 IO_L20P_1 FPGA_BANK1 VCC01 "F13", # 99 IO_L20N_1 FPGA_BANK1 VCC01 "None", # 100 GND POWER (3.3Vmax) "None", # 101 USR_RESETN (open CONFIG Pos PC15 +2V8 drain with pullup) "None", # 102 TIN GPT +2V8 "None", # 103 EXTAL_26M CONFIG +2V5 "None", # 104 RX3 RS232_3 RS232 "None", # 105 TX3 RS232_3 RS232 "None", # 106 RX1 RS232_1 RS232 "None", # 107 TX1 RS232_1 RS232 "None", # 108 BOOT CONFIG +2V8 "None", # 109 TXN Ethernet_PHY +3V3 "None", # 110 TXP Ethernet_PHY +3V3 "None", # 111 ETH_ACTIVITY Ethernet_PHY +2V8 "None", # 112 USBH2_NXT USB_HOST2 +2V5 PA3 "None", # 113 USBH2_DIR USB_HOST2 +2V5 PA1 "None", # 114 USBH2_DATA7 USB_HOST2 +2V5 PA2 "None", # 115 USBH2_STP USB_HOST2 +2V5 PA4 "None") # 116 USBH2_CLK USB_HOST2 +2V5 PA0 ] class Platform(XilinxISEPlatform): def __init__(self): XilinxISEPlatform.__init__(self, "xc3s200a-ft256-4", _ios, lambda p: SimpleCRG(p, "clk0", None), _connectors) def do_finalize(self, fragment): try: self.add_period_constraint(self.lookup_request("clk0"), 10) except ConstraintError: pass