################################################################################# # Filename: ddrc_test01.xcf # Date:2014-05-20 # Author: Andrey Filippov # Description: DDR3 controller test with axi constraints # # Copyright (c) 2014 Elphel, Inc. # ddrc_test01.xcf is free software; you can redistribute it and/or modify # it under the terms of the GNU General Public License as published by # the Free Software Foundation, either version 3 of the License, or # (at your option) any later version. # # ddrc_test01.xcf is distributed in the hope that it will be useful, # but WITHOUT ANY WARRANTY; without even the implied warranty of # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the # GNU General Public License for more details. # # You should have received a copy of the GNU General Public License # along with this program. If not, see <http://www.gnu.org/licenses/> . ################################################################################# # output SDRST, // output SDRST, active low # set_property IOSTANDARD SSTL15 [get_ports {SDRST}] # set_property PACKAGE_PIN J4 [get_ports {SDRST}] NET "SDRST" LOC = "J4" | IOSTANDARD = "SSTL15" ; # output SDCLK, // DDR3 clock differential output, positive #set_property IOSTANDARD DIFF_SSTL15 [get_ports {SDCLK}] #set_property PACKAGE_PIN K3 [get_ports {SDCLK}] NET "SDCLK" LOC = "K3" | IOSTANDARD = "SSTL15" ; # output SDNCLK,// DDR3 clock differential output, negative #set_property IOSTANDARD DIFF_SSTL15 [get_ports {SDNCLK}] #set_property PACKAGE_PIN K2 [get_ports {SDNCLK}] NET "SDNCLK" LOC = "K2" | IOSTANDARD = "SSTL15" ; # output [ADDRESS_NUMBER-1:0] SDA, // output address ports (14:0) for 4Gb device #set_property IOSTANDARD SSTL15 [get_ports {SDA[0]}] #set_property PACKAGE_PIN N3 [get_ports {SDA[0]}] NET "SDA<0>" LOC = "N3" | IOSTANDARD = "SSTL15" ; #set_property IOSTANDARD SSTL15 [get_ports {SDA[1]}] #set_property PACKAGE_PIN H2 [get_ports {SDA[1]}] NET "SDA<1>" LOC = "H2" | IOSTANDARD = "SSTL15" ; #set_property IOSTANDARD SSTL15 [get_ports {SDA[2]}] #set_property PACKAGE_PIN M2 [get_ports {SDA[2]}] NET "SDA<2>" LOC = "M2" | IOSTANDARD = "SSTL15" ; #set_property IOSTANDARD SSTL15 [get_ports {SDA[3]}] #set_property PACKAGE_PIN P5 [get_ports {SDA[3]}] NET "SDA<3>" LOC = "P5" | IOSTANDARD = "SSTL15" ; #set_property IOSTANDARD SSTL15 [get_ports {SDA[4]}] #set_property PACKAGE_PIN H1 [get_ports {SDA[4]}] NET "SDA<4>" LOC = "H1" | IOSTANDARD = "SSTL15" ; #set_property IOSTANDARD SSTL15 [get_ports {SDA[5]}] #set_property PACKAGE_PIN M3 [get_ports {SDA[5]}] NET "SDA<5>" LOC = "M3" | IOSTANDARD = "SSTL15" ; #set_property IOSTANDARD SSTL15 [get_ports {SDA[6]}] #set_property PACKAGE_PIN J1 [get_ports {SDA[6]}] NET "SDA<6>" LOC = "J1" | IOSTANDARD = "SSTL15" ; #set_property IOSTANDARD SSTL15 [get_ports {SDA[7]}] #set_property PACKAGE_PIN P4 [get_ports {SDA[7]}] NET "SDA<7>" LOC = "P4" | IOSTANDARD = "SSTL15" ; #set_property IOSTANDARD SSTL15 [get_ports {SDA[8]}] #set_property PACKAGE_PIN K1 [get_ports {SDA[8]}] NET "SDA<8>" LOC = "K1" | IOSTANDARD = "SSTL15" ; #set_property IOSTANDARD SSTL15 [get_ports {SDA[9]}] #set_property PACKAGE_PIN P3 [get_ports {SDA[9]}] NET "SDA<9>" LOC = "P3" | IOSTANDARD = "SSTL15" ; #set_property IOSTANDARD SSTL15 [get_ports {SDA[10]}] #set_property PACKAGE_PIN F2 [get_ports {SDA[10]}] NET "SDA<10>" LOC = "F2" | IOSTANDARD = "SSTL15" ; #set_property IOSTANDARD SSTL15 [get_ports {SDA[11]}] #set_property PACKAGE_PIN H3 [get_ports {SDA[11]}] NET "SDA<11>" LOC = "H3" | IOSTANDARD = "SSTL15" ; #set_property IOSTANDARD SSTL15 [get_ports {SDA[12]}] #set_property PACKAGE_PIN G3 [get_ports {SDA[12]}] NET "SDA<12>" LOC = "G3" | IOSTANDARD = "SSTL15" ; #set_property IOSTANDARD SSTL15 [get_ports {SDA[13]}] #set_property PACKAGE_PIN N2 [get_ports {SDA[13]}] NET "SDA<13>" LOC = "N2" | IOSTANDARD = "SSTL15" ; #set_property IOSTANDARD SSTL15 [get_ports {SDA[14]}] #set_property PACKAGE_PIN J3 [get_ports {SDA[14]}] NET "SDA<14>" LOC = "J3" | IOSTANDARD = "SSTL15" ; # output [2:0] SDBA, // output bank address ports #set_property IOSTANDARD SSTL15 [get_ports {SDBA[0]}] #set_property PACKAGE_PIN N1 [get_ports {SDBA[0]}] NET "SDBA<0>" LOC = "N1" | IOSTANDARD = "SSTL15" ; #set_property IOSTANDARD SSTL15 [get_ports {SDBA[1]}] #set_property PACKAGE_PIN F1 [get_ports {SDBA[1]}] NET "SDBA<1>" LOC = "F1" | IOSTANDARD = "SSTL15" ; #set_property IOSTANDARD SSTL15 [get_ports {SDBA[2]}] #set_property PACKAGE_PIN P1 [get_ports {SDBA[2]}] NET "SDBA<2>" LOC = "P1" | IOSTANDARD = "SSTL15" ; # output SDWE, // output WE port #set_property IOSTANDARD SSTL15 [get_ports {SDWE}] #set_property PACKAGE_PIN G4 [get_ports {SDWE}] NET "SDWE" LOC = "G4" | IOSTANDARD = "SSTL15" ; # output SDRAS, // output RAS port #set_property IOSTANDARD SSTL15 [get_ports {SDRAS}] #set_property PACKAGE_PIN L2 [get_ports {SDRAS}] NET "SDRAS" LOC = "L2" | IOSTANDARD = "SSTL15" ; # output SDCAS, // output CAS port #set_property IOSTANDARD SSTL15 [get_ports {SDCAS}] #set_property PACKAGE_PIN L1 [get_ports {SDCAS}] NET "SDCAS" LOC = "L1" | IOSTANDARD = "SSTL15" ; # output SDCKE, // output Clock Enable port #set_property IOSTANDARD SSTL15 [get_ports {SDCKE}] #set_property PACKAGE_PIN E1 [get_ports {SDCKE}] NET "SDCKE" LOC = "E1" | IOSTANDARD = "SSTL15" ; # output SDODT, // output ODT port #set_property IOSTANDARD SSTL15 [get_ports {SDODT}] #set_property PACKAGE_PIN M7 [get_ports {SDODT}] NET "SDODT" LOC = "M7" | IOSTANDARD = "SSTL15" ; # inout [15:0] SDD, // DQ I/O pads #set_property IOSTANDARD SSTL15_T_DCI [get_ports {SDD[0]}] #set_property PACKAGE_PIN K6 [get_ports {SDD[0]}] NET "SDD<0>" LOC = "K6" | IOSTANDARD = "SSTL15_T_DCI" ; # inout [15:0] SDD, // DQ I/O pads #set_property IOSTANDARD SSTL15_T_DCI [get_ports {SDD[1]}] #set_property PACKAGE_PIN L4 [get_ports {SDD[1]}] NET "SDD<1>" LOC = "L4" | IOSTANDARD = "SSTL15_T_DCI" ; # inout [15:0] SDD, // DQ I/O pads #set_property IOSTANDARD SSTL15_T_DCI [get_ports {SDD[2]}] #set_property PACKAGE_PIN K7 [get_ports {SDD[2]}] NET "SDD<2>" LOC = "K7" | IOSTANDARD = "SSTL15_T_DCI" ; # inout [15:0] SDD, // DQ I/O pads #set_property IOSTANDARD SSTL15_T_DCI [get_ports {SDD[3]}] #set_property PACKAGE_PIN K4 [get_ports {SDD[3]}] NET "SDD<3>" LOC = "K4" | IOSTANDARD = "SSTL15_T_DCI" ; # inout [15:0] SDD, // DQ I/O pads #set_property IOSTANDARD SSTL15_T_DCI [get_ports {SDD[4]}] #set_property PACKAGE_PIN L6 [get_ports {SDD[4]}] NET "SDD<4>" LOC = "L6" | IOSTANDARD = "SSTL15_T_DCI" ; # inout [15:0] SDD, // DQ I/O pads #set_property IOSTANDARD SSTL15_T_DCI [get_ports {SDD[5]}] #set_property PACKAGE_PIN M4 [get_ports {SDD[5]}] NET "SDD<5>" LOC = "M4" | IOSTANDARD = "SSTL15_T_DCI" ; # inout [15:0] SDD, // DQ I/O pads #set_property IOSTANDARD SSTL15_T_DCI [get_ports {SDD[6]}] #set_property PACKAGE_PIN L7 [get_ports {SDD[6]}] NET "SDD<6>" LOC = "L7" | IOSTANDARD = "SSTL15_T_DCI" ; # inout [15:0] SDD, // DQ I/O pads #set_property IOSTANDARD SSTL15_T_DCI [get_ports {SDD[7]}] #set_property PACKAGE_PIN N5 [get_ports {SDD[7]}] NET "SDD<7>" LOC = "N5" | IOSTANDARD = "SSTL15_T_DCI" ; # inout [15:0] SDD, // DQ I/O pads #set_property IOSTANDARD SSTL15_T_DCI [get_ports {SDD[8]}] #set_property PACKAGE_PIN H5 [get_ports {SDD[8]}] NET "SDD<8>" LOC = "H5" | IOSTANDARD = "SSTL15_T_DCI" ; # inout [15:0] SDD, // DQ I/O pads #set_property IOSTANDARD SSTL15_T_DCI [get_ports {SDD[9]}] #set_property PACKAGE_PIN J6 [get_ports {SDD[9]}] NET "SDD<9>" LOC = "J6" | IOSTANDARD = "SSTL15_T_DCI" ; # inout [15:0] SDD, // DQ I/O pads #set_property IOSTANDARD SSTL15_T_DCI [get_ports {SDD[10]}] #set_property PACKAGE_PIN G5 [get_ports {SDD[10]}] NET "SDD<10>" LOC = "G5" | IOSTANDARD = "SSTL15_T_DCI" ; # inout [15:0] SDD, // DQ I/O pads #set_property IOSTANDARD SSTL15_T_DCI [get_ports {SDD[11]}] #set_property PACKAGE_PIN H6 [get_ports {SDD[11]}] NET "SDD<11>" LOC = "H6" | IOSTANDARD = "SSTL15_T_DCI" ; # inout [15:0] SDD, // DQ I/O pads #set_property IOSTANDARD SSTL15_T_DCI [get_ports {SDD[12]}] #set_property PACKAGE_PIN F5 [get_ports {SDD[12]}] NET "SDD<12>" LOC = "F5" | IOSTANDARD = "SSTL15_T_DCI" ; # inout [15:0] SDD, // DQ I/O pads #set_property IOSTANDARD SSTL15_T_DCI [get_ports {SDD[13]}] #set_property PACKAGE_PIN F7 [get_ports {SDD[13]}] NET "SDD<13>" LOC = "F7" | IOSTANDARD = "SSTL15_T_DCI" ; # inout [15:0] SDD, // DQ I/O pads #set_property IOSTANDARD SSTL15_T_DCI [get_ports {SDD[14]}] #set_property PACKAGE_PIN F4 [get_ports {SDD[14]}] NET "SDD<14>" LOC = "F4" | IOSTANDARD = "SSTL15_T_DCI" ; # inout [15:0] SDD, // DQ I/O pads #set_property IOSTANDARD SSTL15_T_DCI [get_ports {SDD[15]}] #set_property PACKAGE_PIN F6 [get_ports {SDD[15]}] NET "SDD<15>" LOC = "F6" | IOSTANDARD = "SSTL15_T_DCI" ; # inout DQSL, // LDQS I/O pad #set_property PACKAGE_PIN N7 [get_ports {DQSL}] #set_property SLEW FAST [get_ports {DQSL}] #set_property IOSTANDARD DIFF_SSTL15_T_DCI [get_ports {DQSL}] NET "DQSL" LOC = "N7" | IOSTANDARD = "DIFF_SSTL15_T_DCI"; # | SLEW = "FAST"; # inout NDQSL, // ~LDQS I/O pad #set_property PACKAGE_PIN N6 [get_ports {NDQSL}] #set_property SLEW FAST [get_ports {NDQSL}] #set_property IOSTANDARD DIFF_SSTL15_T_DCI [get_ports {NDQSL}] NET "NDQSL" LOC = "N6" | IOSTANDARD = "DIFF_SSTL15_T_DCI";# | SLEW = "FAST"; # inout DQSU, // UDQS I/O pad #set_property PACKAGE_PIN H7 [get_ports {DQSU}] #set_property SLEW FAST [get_ports {DQSU}] #set_property IOSTANDARD DIFF_SSTL15_T_DCI [get_ports {DQSU}] NET "DQSU" LOC = "H7" | IOSTANDARD = "DIFF_SSTL15_T_DCI";# | SLEW = "FAST"; # inout NDQSU, // ~UDQS I/O pad #set_property PACKAGE_PIN G7 [get_ports {NDQSU}] #set_property SLEW FAST [get_ports {NDQSU}] #set_property IOSTANDARD DIFF_SSTL15_T_DCI [get_ports {NDQSU}] NET "NDQSU" LOC = "G7" | IOSTANDARD = "DIFF_SSTL15_T_DCI";# | SLEW = "FAST"; # inout SDDML, // LDM I/O pad (actually only output) #set_property IOSTANDARD SSTL15_T_DCI [get_ports {SDDML}] #set_property IOSTANDARD SSTL15 [get_ports {SDDML}] #set_property PACKAGE_PIN L5 [get_ports {SDDML}] NET "SDDML" LOC = "L5" | IOSTANDARD = "SSTL15"; # inout SDDMU, // UDM I/O pad (actually only output) #set_property IOSTANDARD SSTL15_T_DCI [get_ports {SDDMU}] #set_property IOSTANDARD SSTL15 [get_ports {SDDMU}] #set_property PACKAGE_PIN J5 [get_ports {SDDMU}] NET "SDDMU" LOC = "J5" | IOSTANDARD = "SSTL15"; # Global constraints #set_property INTERNAL_VREF 0.750 [get_iobanks 34] CONFIG INTERNAL_VREF_BANK34=0.750; #set_property DCI_CASCADE 34 [get_iobanks 35] CONFIG DCI_CASCADE = "35 34"; #set_property INTERNAL_VREF 0.750 [get_iobanks 35] CONFIG INTERNAL_VREF_BANK35=0.750; #set_property CFGBVS GND [current_design] # No UCF? #set_property CONFIG_VOLTAGE 1.8 [current_design] # No UCF?