aboutsummaryrefslogtreecommitdiffstats
path: root/fpga/usrp3/top/n3xx/mb_pins.xdc
diff options
context:
space:
mode:
authorMartin Braun <martin.braun@ettus.com>2020-01-23 16:10:22 -0800
committerMartin Braun <martin.braun@ettus.com>2020-01-28 09:35:36 -0800
commitbafa9d95453387814ef25e6b6256ba8db2df612f (patch)
tree39ba24b5b67072d354775272e687796bb511848d /fpga/usrp3/top/n3xx/mb_pins.xdc
parent3075b981503002df3115d5f1d0b97d2619ba30f2 (diff)
downloaduhd-bafa9d95453387814ef25e6b6256ba8db2df612f.tar.gz
uhd-bafa9d95453387814ef25e6b6256ba8db2df612f.tar.bz2
uhd-bafa9d95453387814ef25e6b6256ba8db2df612f.zip
Merge FPGA repository back into UHD repository
The FPGA codebase was removed from the UHD repository in 2014 to reduce the size of the repository. However, over the last half-decade, the split between the repositories has proven more burdensome than it has been helpful. By merging the FPGA code back, it will be possible to create atomic commits that touch both FPGA and UHD codebases. Continuous integration testing is also simplified by merging the repositories, because it was previously difficult to automatically derive the correct UHD branch when testing a feature branch on the FPGA repository. This commit also updates the license files and paths therein. We are therefore merging the repositories again. Future development for FPGA code will happen in the same repository as the UHD host code and MPM code. == Original Codebase and Rebasing == The original FPGA repository will be hosted for the foreseeable future at its original local location: https://github.com/EttusResearch/fpga/ It can be used for bisecting, reference, and a more detailed history. The final commit from said repository to be merged here is 05003794e2da61cabf64dd278c45685a7abad7ec. This commit is tagged as v4.0.0.0-pre-uhd-merge. If you have changes in the FPGA repository that you want to rebase onto the UHD repository, simply run the following commands: - Create a directory to store patches (this should be an empty directory): mkdir ~/patches - Now make sure that your FPGA codebase is based on the same state as the code that was merged: cd src/fpga # Or wherever your FPGA code is stored git rebase v4.0.0.0-pre-uhd-merge Note: The rebase command may look slightly different depending on what exactly you're trying to rebase. - Create a patch set for your changes versus v4.0.0.0-pre-uhd-merge: git format-patch v4.0.0.0-pre-uhd-merge -o ~/patches Note: Make sure that only patches are stored in your output directory. It should otherwise be empty. Make sure that you picked the correct range of commits, and only commits you wanted to rebase were exported as patch files. - Go to the UHD repository and apply the patches: cd src/uhd # Or wherever your UHD repository is stored git am --directory fpga ~/patches/* rm -rf ~/patches # This is for cleanup == Contributors == The following people have contributed mainly to these files (this list is not complete): Co-authored-by: Alex Williams <alex.williams@ni.com> Co-authored-by: Andrej Rode <andrej.rode@ettus.com> Co-authored-by: Ashish Chaudhari <ashish@ettus.com> Co-authored-by: Ben Hilburn <ben.hilburn@ettus.com> Co-authored-by: Ciro Nishiguchi <ciro.nishiguchi@ni.com> Co-authored-by: Daniel Jepson <daniel.jepson@ni.com> Co-authored-by: Derek Kozel <derek.kozel@ettus.com> Co-authored-by: EJ Kreinar <ej@he360.com> Co-authored-by: Humberto Jimenez <humberto.jimenez@ni.com> Co-authored-by: Ian Buckley <ian.buckley@gmail.com> Co-authored-by: Jörg Hofrichter <joerg.hofrichter@ni.com> Co-authored-by: Jon Kiser <jon.kiser@ni.com> Co-authored-by: Josh Blum <josh@joshknows.com> Co-authored-by: Jonathon Pendlum <jonathan.pendlum@ettus.com> Co-authored-by: Martin Braun <martin.braun@ettus.com> Co-authored-by: Matt Ettus <matt@ettus.com> Co-authored-by: Michael West <michael.west@ettus.com> Co-authored-by: Moritz Fischer <moritz.fischer@ettus.com> Co-authored-by: Nick Foster <nick@ettus.com> Co-authored-by: Nicolas Cuervo <nicolas.cuervo@ettus.com> Co-authored-by: Paul Butler <paul.butler@ni.com> Co-authored-by: Paul David <paul.david@ettus.com> Co-authored-by: Ryan Marlow <ryan.marlow@ettus.com> Co-authored-by: Sugandha Gupta <sugandha.gupta@ettus.com> Co-authored-by: Sylvain Munaut <tnt@246tNt.com> Co-authored-by: Trung Tran <trung.tran@ettus.com> Co-authored-by: Vidush Vishwanath <vidush.vishwanath@ettus.com> Co-authored-by: Wade Fife <wade.fife@ettus.com>
Diffstat (limited to 'fpga/usrp3/top/n3xx/mb_pins.xdc')
-rw-r--r--fpga/usrp3/top/n3xx/mb_pins.xdc386
1 files changed, 386 insertions, 0 deletions
diff --git a/fpga/usrp3/top/n3xx/mb_pins.xdc b/fpga/usrp3/top/n3xx/mb_pins.xdc
new file mode 100644
index 000000000..6eecc42d5
--- /dev/null
+++ b/fpga/usrp3/top/n3xx/mb_pins.xdc
@@ -0,0 +1,386 @@
+#
+# Copyright 2017 Ettus Research, A National Instruments Company
+# SPDX-License-Identifier: LGPL-3.0
+#
+# Motherboard Pin Definitions for the N3xx Product Family.
+#
+
+## Bank 12: 3.3V Logic : ################################################################
+## Front-panel GPIO
+## FPGA test outputs
+#########################################################################################
+
+set_property PACKAGE_PIN AF25 [get_ports {FPGA_GPIO[0]}]
+set_property PACKAGE_PIN AE25 [get_ports {FPGA_GPIO[1]}]
+set_property PACKAGE_PIN AG26 [get_ports {FPGA_GPIO[2]}]
+set_property PACKAGE_PIN AG27 [get_ports {FPGA_GPIO[3]}]
+set_property PACKAGE_PIN AE26 [get_ports {FPGA_GPIO[4]}]
+set_property PACKAGE_PIN AB26 [get_ports {FPGA_GPIO[5]}]
+set_property PACKAGE_PIN AF27 [get_ports {FPGA_GPIO[6]}]
+set_property PACKAGE_PIN AA27 [get_ports {FPGA_GPIO[7]}]
+set_property PACKAGE_PIN AE27 [get_ports {FPGA_GPIO[8]}]
+set_property PACKAGE_PIN AC26 [get_ports {FPGA_GPIO[9]}]
+set_property PACKAGE_PIN AD25 [get_ports {FPGA_GPIO[10]}]
+set_property PACKAGE_PIN AD26 [get_ports {FPGA_GPIO[11]}]
+set_property IOSTANDARD LVCMOS33 [get_ports {FPGA_GPIO[*]}]
+set_property DRIVE 4 [get_ports {FPGA_GPIO[*]}]
+set_property SLEW SLOW [get_ports {FPGA_GPIO[*]}]
+
+# These pins should be commented out for release hardware.
+set_property PACKAGE_PIN Y30 [get_ports {FPGA_TEST[0]}]
+set_property PACKAGE_PIN AA30 [get_ports {FPGA_TEST[1]}]
+set_property IOSTANDARD LVCMOS33 [get_ports {FPGA_TEST[*]}]
+
+# set_property PACKAGE_PIN AH27 [get_ports {MGMT-GPIO0}]
+# set_property PACKAGE_PIN AH26 [get_ports {MGMT-GPIO1}]
+# set_property PACKAGE_PIN AC27 [get_ports {MGMT-JTAG-TCK}]
+# set_property PACKAGE_PIN AF29 [get_ports {MGMT-JTAG-TDI}]
+# set_property PACKAGE_PIN AG29 [get_ports {MGMT-JTAG-TDO}]
+# set_property PACKAGE_PIN AB27 [get_ports {MGMT-JTAG-TMS}]
+# set_property PACKAGE_PIN Y28 [get_ports {MGMT-SPI-LE}]
+# set_property PACKAGE_PIN AD28 [get_ports {MGMT-SPI-MISO}]
+# set_property PACKAGE_PIN AA28 [get_ports {MGMT-SPI-MOSI}]
+# set_property PACKAGE_PIN AE28 [get_ports {MGMT-SPI-RESET}]
+# set_property PACKAGE_PIN AC28 [get_ports {MGMT-SPI-SCLK}]
+# When implemented, the MGMT signals need DRIVE and SLEW attributes applied.
+
+# NPIO and QSFP located elsewhere
+
+
+## Bank 9, 2.5V Logic : #################################################################
+## All of these are inputs and all require internal termination to meet voltage
+## swing requirements at the pin. These ports and buffers should always be instantiated
+## to meet the internal termination requirement.
+#########################################################################################
+
+set_property PACKAGE_PIN AC18 [get_ports FPGA_REFCLK_P]
+set_property PACKAGE_PIN AC19 [get_ports FPGA_REFCLK_N]
+set_property IOSTANDARD LVDS_25 [get_ports FPGA_REFCLK_*]
+set_property DIFF_TERM TRUE [get_ports FPGA_REFCLK_*]
+
+set_property PACKAGE_PIN AD18 [get_ports NETCLK_REF_P]
+set_property PACKAGE_PIN AD19 [get_ports NETCLK_REF_N]
+set_property DIFF_TERM TRUE [get_ports NETCLK_REF_*]
+set_property IOSTANDARD LVDS_25 [get_ports NETCLK_REF_*]
+
+set_property PACKAGE_PIN AA18 [get_ports WB_20MHZ_P]
+set_property PACKAGE_PIN AA19 [get_ports WB_20MHZ_N]
+set_property DIFF_TERM TRUE [get_ports WB_20MHZ_*]
+set_property IOSTANDARD LVDS_25 [get_ports WB_20MHZ_*]
+
+
+## Bank 13, 3.3V : ######################################################################
+## PPS In/Out (including MGMT PPS, unused)
+## GPS PPS Raw/Disciplined
+## RJ45 signaling (unused)
+## Authentication IC
+## Resets
+## Rear-panel LEDs
+#########################################################################################
+
+set_property PACKAGE_PIN U24 [get_ports REF_1PPS_IN]
+set_property IOSTANDARD LVCMOS33 [get_ports REF_1PPS_IN]
+
+set_property PACKAGE_PIN V29 [get_ports REF_1PPS_OUT]
+set_property IOSTANDARD LVCMOS33 [get_ports REF_1PPS_OUT]
+set_property DRIVE 12 [get_ports REF_1PPS_OUT]
+set_property SLEW SLOW [get_ports REF_1PPS_OUT]
+set_property IOB TRUE [get_ports REF_1PPS_OUT]
+
+# set_property PACKAGE_PIN U29 [get_ports REF_1PPS_IN_MGMT]
+# set_property IOSTANDARD LVCMOS33 [get_ports REF_1PPS_IN_MGMT]
+
+set_property PACKAGE_PIN W30 [get_ports GPS_1PPS]
+set_property IOSTANDARD LVCMOS33 [get_ports GPS_1PPS]
+
+# set_property PACKAGE_PIN V28 [get_ports GPS_1PPS_RAW]
+# set_property IOSTANDARD LVCMOS33 [get_ports GPS_1PPS_RAW]
+
+set_property PACKAGE_PIN U26 [get_ports ENET0_CLK125]
+set_property IOSTANDARD LVCMOS33 [get_ports ENET0_CLK125]
+
+# set_property PACKAGE_PIN R25 [get_ports ENET0_PTP]
+# set_property IOSTANDARD LVCMOS33 [get_ports ENET0_PTP]
+
+# set_property PACKAGE_PIN R30 [get_ports ENET0_PTP_DIR]
+# set_property IOSTANDARD LVCMOS33 [get_ports ENET0_PTP_DIR]
+
+# set_property PACKAGE_PIN U30 [get_ports ATSHA204_SDA]
+# set_property IOSTANDARD LVCMOS33 [get_ports ATSHA204_SDA]
+
+set_property PACKAGE_PIN P26 [get_ports FPGA_PL_RESETN]
+set_property IOSTANDARD LVCMOS33 [get_ports FPGA_PL_RESETN]
+
+set_property PACKAGE_PIN U25 [get_ports PANEL_LED_GPS]
+set_property PACKAGE_PIN T25 [get_ports PANEL_LED_LINK]
+set_property PACKAGE_PIN W29 [get_ports PANEL_LED_PPS]
+set_property PACKAGE_PIN V24 [get_ports PANEL_LED_REF]
+set_property IOSTANDARD LVCMOS33 [get_ports PANEL_LED_*]
+set_property DRIVE 4 [get_ports PANEL_LED_*]
+set_property SLEW SLOW [get_ports PANEL_LED_*]
+
+# SFP+ Sideband and White Rabbit DAC Control located elsewhere
+
+
+## NanoPitch Interface : ################################################################
+## Bank 12, 3.3V
+#########################################################################################
+
+# set_property PACKAGE_PIN AD29 [get_ports {NPIO-GPIO0}]
+# set_property PACKAGE_PIN AC29 [get_ports {NPIO-GPIO1}]
+# set_property PACKAGE_PIN AE30 [get_ports {NPIO-GPIO2}]
+# set_property PACKAGE_PIN AD30 [get_ports {NPIO-GPIO3}]
+# set_property PACKAGE_PIN AH29 [get_ports {NPIO-GPIO4}]
+# set_property PACKAGE_PIN AH28 [get_ports {NPIO-GPIO5}]
+# set_property PACKAGE_PIN AF30 [get_ports {NPIO-GPIO6}]
+# set_property PACKAGE_PIN AG30 [get_ports {NPIO-GPIO7}]
+# When implemented, the QSFP signals need DRIVE and SLEW attributes applied.
+
+set_property PACKAGE_PIN AE8 [get_ports {NPIO_RX0_P}]
+set_property PACKAGE_PIN AE7 [get_ports {NPIO_RX0_N}]
+set_property PACKAGE_PIN AG8 [get_ports {NPIO_RX1_P}]
+set_property PACKAGE_PIN AG7 [get_ports {NPIO_RX1_N}]
+set_property PACKAGE_PIN AK2 [get_ports {NPIO_TX0_P}]
+set_property PACKAGE_PIN AK1 [get_ports {NPIO_TX0_N}]
+set_property PACKAGE_PIN AJ4 [get_ports {NPIO_TX1_P}]
+set_property PACKAGE_PIN AJ3 [get_ports {NPIO_TX1_N}]
+
+
+## QSFP : ###############################################################################
+## Bank 12, 3.3V
+#########################################################################################
+
+set_property PACKAGE_PIN AJ26 [get_ports {QSFP_I2C_SCL}]
+set_property IOSTANDARD LVCMOS33 [get_ports {QSFP_I2C_SCL}]
+set_property DRIVE 8 [get_ports {QSFP_I2C_SCL}]
+
+set_property PACKAGE_PIN AK26 [get_ports {QSFP_I2C_SDA}]
+set_property IOSTANDARD LVCMOS33 [get_ports {QSFP_I2C_SDA}]
+set_property DRIVE 8 [get_ports {QSFP_I2C_SDA}]
+
+set_property PACKAGE_PIN AK28 [get_ports {QSFP_INT_B}]
+set_property IOSTANDARD LVCMOS33 [get_ports {QSFP_INT_B}]
+
+set_property PACKAGE_PIN AK30 [get_ports {QSFP_LED}]
+set_property IOSTANDARD LVCMOS33 [get_ports {QSFP_LED}]
+
+set_property PACKAGE_PIN AJ29 [get_ports {QSFP_LPMODE}]
+set_property IOSTANDARD LVCMOS33 [get_ports {QSFP_LPMODE}]
+
+set_property PACKAGE_PIN AK27 [get_ports {QSFP_PRESENT_B}]
+set_property IOSTANDARD LVCMOS33 [get_ports {QSFP_PRESENT_B}]
+
+set_property PACKAGE_PIN AJ28 [get_ports {QSFP_MODSEL_B}]
+set_property IOSTANDARD LVCMOS33 [get_ports {QSFP_MODSEL_B}]
+
+set_property PACKAGE_PIN AJ30 [get_ports {QSFP_RESET_B}]
+set_property IOSTANDARD LVCMOS33 [get_ports {QSFP_RESET_B}]
+
+# When implemented, the QSFP signals need DRIVE and SLEW attributes applied.
+
+set_property PACKAGE_PIN AD5 [get_ports {QSFP_RX_N[0]}]
+set_property PACKAGE_PIN AD6 [get_ports {QSFP_RX_P[0]}]
+set_property PACKAGE_PIN AF5 [get_ports {QSFP_RX_N[1]}]
+set_property PACKAGE_PIN AF6 [get_ports {QSFP_RX_P[1]}]
+set_property PACKAGE_PIN AG3 [get_ports {QSFP_RX_N[2]}]
+set_property PACKAGE_PIN AG4 [get_ports {QSFP_RX_P[2]}]
+set_property PACKAGE_PIN AH5 [get_ports {QSFP_RX_N[3]}]
+set_property PACKAGE_PIN AH6 [get_ports {QSFP_RX_P[3]}]
+set_property PACKAGE_PIN AD1 [get_ports {QSFP_TX_N[0]}]
+set_property PACKAGE_PIN AD2 [get_ports {QSFP_TX_P[0]}]
+set_property PACKAGE_PIN AE3 [get_ports {QSFP_TX_N[1]}]
+set_property PACKAGE_PIN AE4 [get_ports {QSFP_TX_P[1]}]
+set_property PACKAGE_PIN AF1 [get_ports {QSFP_TX_N[2]}]
+set_property PACKAGE_PIN AF2 [get_ports {QSFP_TX_P[2]}]
+set_property PACKAGE_PIN AH1 [get_ports {QSFP_TX_N[3]}]
+set_property PACKAGE_PIN AH2 [get_ports {QSFP_TX_P[3]}]
+
+
+## White Rabbit : #######################################################################
+## Bank 13, 3.3V
+#########################################################################################
+
+set_property PACKAGE_PIN T29 [get_ports {WB_DAC_DIN}]
+set_property PACKAGE_PIN T28 [get_ports {WB_DAC_NCLR}]
+set_property PACKAGE_PIN T30 [get_ports {WB_DAC_NLDAC}]
+set_property PACKAGE_PIN N29 [get_ports {WB_DAC_NSYNC}]
+set_property PACKAGE_PIN P29 [get_ports {WB_DAC_SCLK}]
+set_property IOSTANDARD LVCMOS33 [get_ports {WB_DAC_*}]
+set_property DRIVE 4 [get_ports {WB_DAC_*}]
+set_property SLEW SLOW [get_ports {WB_DAC_*}]
+
+
+## SFP+ : ###############################################################################
+##
+#########################################################################################
+
+## Clocks, Bank 109 and 110
+
+# These need to have the internal buffer in the FPGA enabled at all times to avoid
+# damage to the part. Therefore declare them here in the top level pins file.
+set_property PACKAGE_PIN AA8 [get_ports {MGT156MHZ_CLK1_P}]
+set_property PACKAGE_PIN AA7 [get_ports {MGT156MHZ_CLK1_N}]
+
+set_property PACKAGE_PIN AF10 [get_ports {NETCLK_P}]
+set_property PACKAGE_PIN AF9 [get_ports {NETCLK_N}]
+
+# Swapping SFP_0 and SFP_1 pinout to match the label on the silkscreen.
+# These FPGA pins are reversed with respect to the schematic now.
+## MGTs, Bank 109
+
+set_property PACKAGE_PIN AJ7 [get_ports SFP_0_RX_N]
+set_property PACKAGE_PIN AJ8 [get_ports SFP_0_RX_P]
+set_property PACKAGE_PIN AK5 [get_ports SFP_0_TX_N]
+set_property PACKAGE_PIN AK6 [get_ports SFP_0_TX_P]
+
+set_property PACKAGE_PIN AH9 [get_ports SFP_1_RX_N]
+set_property PACKAGE_PIN AH10 [get_ports SFP_1_RX_P]
+set_property PACKAGE_PIN AK9 [get_ports SFP_1_TX_N]
+set_property PACKAGE_PIN AK10 [get_ports SFP_1_TX_P]
+
+## SFP+ 0, Sideband, Bank 13 3.3V
+
+set_property PACKAGE_PIN T27 [get_ports {SFP_0_I2C_NPRESENT}]
+set_property IOSTANDARD LVCMOS33 [get_ports {SFP_0_I2C_NPRESENT}]
+
+set_property PACKAGE_PIN N27 [get_ports SFP_0_LED_A]
+set_property PACKAGE_PIN N28 [get_ports SFP_0_LED_B]
+set_property IOSTANDARD LVCMOS33 [get_ports SFP_0_LED_*]
+set_property DRIVE 4 [get_ports SFP_0_LED_*]
+set_property SLEW SLOW [get_ports SFP_0_LED_*]
+
+set_property PACKAGE_PIN R27 [get_ports SFP_0_LOS]
+set_property IOSTANDARD LVCMOS33 [get_ports SFP_0_LOS]
+
+set_property PACKAGE_PIN R26 [get_ports SFP_0_RS0]
+set_property PACKAGE_PIN P28 [get_ports SFP_0_RS1]
+set_property IOSTANDARD LVCMOS33 [get_ports SFP_0_RS*]
+set_property DRIVE 4 [get_ports SFP_0_RS*]
+set_property SLEW SLOW [get_ports SFP_0_RS*]
+
+set_property PACKAGE_PIN U27 [get_ports SFP_0_TXDISABLE]
+set_property IOSTANDARD LVCMOS33 [get_ports SFP_0_TXDISABLE]
+set_property DRIVE 4 [get_ports SFP_0_TXDISABLE]
+set_property SLEW SLOW [get_ports SFP_0_TXDISABLE]
+
+set_property PACKAGE_PIN V26 [get_ports SFP_0_TXFAULT]
+set_property IOSTANDARD LVCMOS33 [get_ports SFP_0_TXFAULT]
+
+## SFP+ 1, Slow Speed, Bank 13 3.3V
+
+# set_property PACKAGE_PIN V23 [get_ports {SFP_1_I2C_NPRESENT}]
+# set_property IOSTANDARD LVCMOS33 [get_ports {SFP_1_I2C_NPRESENT}]
+
+set_property PACKAGE_PIN N26 [get_ports SFP_1_LED_A]
+set_property PACKAGE_PIN P30 [get_ports SFP_1_LED_B]
+set_property IOSTANDARD LVCMOS33 [get_ports SFP_1_LED_*]
+set_property DRIVE 4 [get_ports SFP_1_LED_*]
+set_property SLEW SLOW [get_ports SFP_1_LED_*]
+
+set_property PACKAGE_PIN R28 [get_ports SFP_1_LOS]
+set_property IOSTANDARD LVCMOS33 [get_ports SFP_1_LOS]
+
+set_property PACKAGE_PIN T24 [get_ports SFP_1_RS0]
+set_property PACKAGE_PIN P25 [get_ports SFP_1_RS1]
+set_property IOSTANDARD LVCMOS33 [get_ports SFP_1_RS*]
+set_property DRIVE 4 [get_ports SFP_1_RS*]
+set_property SLEW SLOW [get_ports SFP_1_RS*]
+
+set_property PACKAGE_PIN V27 [get_ports SFP_1_TXDISABLE]
+set_property IOSTANDARD LVCMOS33 [get_ports SFP_1_TXDISABLE]
+set_property DRIVE 4 [get_ports SFP_1_TXDISABLE]
+set_property SLEW SLOW [get_ports SFP_1_TXDISABLE]
+
+set_property PACKAGE_PIN W24 [get_ports SFP_1_TXFAULT]
+set_property IOSTANDARD LVCMOS33 [get_ports SFP_1_TXFAULT]
+
+
+## PL DDR : #############################################################################
+##
+#########################################################################################
+
+# This port must be always enabled due to a Xilinx bug in the silicon.
+# https://www.xilinx.com/support/answers/63950.html
+set_property PACKAGE_PIN A8 [get_ports FPGA_PUDC_B]
+set_property IOSTANDARD LVDCI_15 [get_ports FPGA_PUDC_B]
+
+set_property PACKAGE_PIN D8 [get_ports {ddr3_addr[0]}]
+set_property PACKAGE_PIN A7 [get_ports {ddr3_addr[1]}]
+set_property PACKAGE_PIN C7 [get_ports {ddr3_addr[2]}]
+set_property PACKAGE_PIN D9 [get_ports {ddr3_addr[3]}]
+set_property PACKAGE_PIN J9 [get_ports {ddr3_addr[4]}]
+set_property PACKAGE_PIN E8 [get_ports {ddr3_addr[5]}]
+set_property PACKAGE_PIN G7 [get_ports {ddr3_addr[6]}]
+set_property PACKAGE_PIN E7 [get_ports {ddr3_addr[7]}]
+set_property PACKAGE_PIN G11 [get_ports {ddr3_addr[8]}]
+set_property PACKAGE_PIN C6 [get_ports {ddr3_addr[9]}]
+set_property PACKAGE_PIN B6 [get_ports {ddr3_addr[10]}]
+set_property PACKAGE_PIN H7 [get_ports {ddr3_addr[11]}]
+set_property PACKAGE_PIN B7 [get_ports {ddr3_addr[12]}]
+set_property PACKAGE_PIN F7 [get_ports {ddr3_addr[13]}]
+set_property PACKAGE_PIN F8 [get_ports {ddr3_addr[14]}]
+set_property PACKAGE_PIN F9 [get_ports {ddr3_addr[15]}]
+
+set_property PACKAGE_PIN C9 [get_ports {ddr3_ba[0]}]
+set_property PACKAGE_PIN E10 [get_ports {ddr3_ba[1]}]
+set_property PACKAGE_PIN B9 [get_ports {ddr3_ba[2]}]
+
+set_property PACKAGE_PIN A10 [get_ports ddr3_cas_n]
+set_property PACKAGE_PIN E11 [get_ports {ddr3_cke[0]}]
+set_property PACKAGE_PIN H8 [get_ports {ddr3_ck_n[0]}]
+set_property PACKAGE_PIN J8 [get_ports {ddr3_ck_p[0]}]
+set_property PACKAGE_PIN D11 [get_ports {ddr3_cs_n[0]}]
+
+set_property PACKAGE_PIN B16 [get_ports {ddr3_dm[0]}]
+set_property PACKAGE_PIN B11 [get_ports {ddr3_dm[1]}]
+set_property PACKAGE_PIN H13 [get_ports {ddr3_dm[2]}]
+set_property PACKAGE_PIN G15 [get_ports {ddr3_dm[3]}]
+
+set_property PACKAGE_PIN B17 [get_ports {ddr3_dq[0]}]
+set_property PACKAGE_PIN A17 [get_ports {ddr3_dq[1]}]
+set_property PACKAGE_PIN D15 [get_ports {ddr3_dq[2]}]
+set_property PACKAGE_PIN D14 [get_ports {ddr3_dq[3]}]
+set_property PACKAGE_PIN C17 [get_ports {ddr3_dq[4]}]
+set_property PACKAGE_PIN E15 [get_ports {ddr3_dq[5]}]
+set_property PACKAGE_PIN C16 [get_ports {ddr3_dq[6]}]
+set_property PACKAGE_PIN D16 [get_ports {ddr3_dq[7]}]
+set_property PACKAGE_PIN A13 [get_ports {ddr3_dq[8]}]
+set_property PACKAGE_PIN A12 [get_ports {ddr3_dq[9]}]
+set_property PACKAGE_PIN C14 [get_ports {ddr3_dq[10]}]
+set_property PACKAGE_PIN B12 [get_ports {ddr3_dq[11]}]
+set_property PACKAGE_PIN B14 [get_ports {ddr3_dq[12]}]
+set_property PACKAGE_PIN C12 [get_ports {ddr3_dq[13]}]
+set_property PACKAGE_PIN A14 [get_ports {ddr3_dq[14]}]
+set_property PACKAGE_PIN C11 [get_ports {ddr3_dq[15]}]
+set_property PACKAGE_PIN J15 [get_ports {ddr3_dq[16]}]
+set_property PACKAGE_PIN L14 [get_ports {ddr3_dq[17]}]
+set_property PACKAGE_PIN L15 [get_ports {ddr3_dq[18]}]
+set_property PACKAGE_PIN J13 [get_ports {ddr3_dq[19]}]
+set_property PACKAGE_PIN J14 [get_ports {ddr3_dq[20]}]
+set_property PACKAGE_PIN K15 [get_ports {ddr3_dq[21]}]
+set_property PACKAGE_PIN J16 [get_ports {ddr3_dq[22]}]
+set_property PACKAGE_PIN H14 [get_ports {ddr3_dq[23]}]
+set_property PACKAGE_PIN F15 [get_ports {ddr3_dq[24]}]
+set_property PACKAGE_PIN G16 [get_ports {ddr3_dq[25]}]
+set_property PACKAGE_PIN F14 [get_ports {ddr3_dq[26]}]
+set_property PACKAGE_PIN E13 [get_ports {ddr3_dq[27]}]
+set_property PACKAGE_PIN G14 [get_ports {ddr3_dq[28]}]
+set_property PACKAGE_PIN D13 [get_ports {ddr3_dq[29]}]
+set_property PACKAGE_PIN F13 [get_ports {ddr3_dq[30]}]
+set_property PACKAGE_PIN E12 [get_ports {ddr3_dq[31]}]
+
+set_property PACKAGE_PIN F17 [get_ports {ddr3_dqs_p[0]}]
+set_property PACKAGE_PIN E17 [get_ports {ddr3_dqs_n[0]}]
+set_property PACKAGE_PIN B15 [get_ports {ddr3_dqs_p[1]}]
+set_property PACKAGE_PIN A15 [get_ports {ddr3_dqs_n[1]}]
+set_property PACKAGE_PIN L13 [get_ports {ddr3_dqs_p[2]}]
+set_property PACKAGE_PIN K13 [get_ports {ddr3_dqs_n[2]}]
+set_property PACKAGE_PIN F12 [get_ports {ddr3_dqs_n[3]}]
+set_property PACKAGE_PIN G12 [get_ports {ddr3_dqs_p[3]}]
+
+set_property PACKAGE_PIN D10 [get_ports {ddr3_odt[0]}]
+set_property PACKAGE_PIN B10 [get_ports ddr3_ras_n]
+set_property PACKAGE_PIN D6 [get_ports ddr3_reset_n]
+set_property PACKAGE_PIN G9 [get_ports sys_clk_n]
+set_property PACKAGE_PIN H9 [get_ports sys_clk_p]
+set_property PACKAGE_PIN A9 [get_ports ddr3_we_n]