summaryrefslogtreecommitdiffstats
path: root/fpga/xilinx/programmer/dependencies/libxsvf/xsvftool-xpcu.src/.svn/text-base/Makefile.svn-base
diff options
context:
space:
mode:
authorTimothy Pearson <kb9vqf@pearsoncomputing.net>2012-10-01 21:07:55 -0500
committerTimothy Pearson <kb9vqf@pearsoncomputing.net>2012-10-01 21:07:55 -0500
commitd1b70f80180fe4b5ac6078e2be9678fc36d74c5c (patch)
tree2e46de7a644f89e36842247af6826ff00a0d3fa4 /fpga/xilinx/programmer/dependencies/libxsvf/xsvftool-xpcu.src/.svn/text-base/Makefile.svn-base
parentae161b4a6a978922747cf09e8c04479340825852 (diff)
downloadulab-d1b70f80180fe4b5ac6078e2be9678fc36d74c5c.tar.gz
ulab-d1b70f80180fe4b5ac6078e2be9678fc36d74c5c.zip
Add initial files for direct FPGA programming
Diffstat (limited to 'fpga/xilinx/programmer/dependencies/libxsvf/xsvftool-xpcu.src/.svn/text-base/Makefile.svn-base')
-rw-r--r--fpga/xilinx/programmer/dependencies/libxsvf/xsvftool-xpcu.src/.svn/text-base/Makefile.svn-base97
1 files changed, 97 insertions, 0 deletions
diff --git a/fpga/xilinx/programmer/dependencies/libxsvf/xsvftool-xpcu.src/.svn/text-base/Makefile.svn-base b/fpga/xilinx/programmer/dependencies/libxsvf/xsvftool-xpcu.src/.svn/text-base/Makefile.svn-base
new file mode 100644
index 0000000..ca0621d
--- /dev/null
+++ b/fpga/xilinx/programmer/dependencies/libxsvf/xsvftool-xpcu.src/.svn/text-base/Makefile.svn-base
@@ -0,0 +1,97 @@
+#
+# xsvftool-xpcu - An (X)SVF player for the Xilinx Platform Cable USB
+#
+# Copyright (C) 2011 RIEGL Research ForschungsGmbH
+# Copyright (C) 2011 Clifford Wolf <clifford@clifford.at>
+#
+# Permission to use, copy, modify, and/or distribute this software for any
+# purpose with or without fee is hereby granted, provided that the above
+# copyright notice and this permission notice appear in all copies.
+#
+# THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
+# WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
+# MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR
+# ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
+# WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN
+# ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
+# OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
+#
+
+USE_PREP_FIRMWARE = 1
+USE_PREP_HARDWARE = 1
+
+LIBXSVFDIR=..
+
+CC = gcc
+CFLAGS = -Wall -Wextra -Werror -Os -ggdb -I$(LIBXSVFDIR) -MD
+LDFLAGS = -L$(LIBXSVFDIR)
+LDLIBS = -lusb -lreadline -lxsvf
+
+SDCC = sdcc
+SDCFLAGS = -mmcs51 --xram-loc 0x2000
+
+all: xsvftool-xpcu
+
+xsvftool-xpcu: filedata.h hardware_cksum_c.inc $(LIBXSVFDIR)/libxsvf.a xsvftool-xpcu.o fx2usb-interface.o
+ $(CC) $(LDFLAGS) xsvftool-xpcu.o fx2usb-interface.o $(LDLIBS) -o $@
+
+hardware.svf erasecpld.svf: hardware.sh hardware.ucf hardware.v hardware_cksum_vl.inc
+ifeq ($(USE_PREP_HARDWARE),1)
+ cp prep_hardware.svf hardware.svf
+ cp prep_erasecpld.svf erasecpld.svf
+else
+ bash hardware.sh
+endif
+
+firmware.ihx: firmware.c
+ifeq ($(USE_PREP_FIRMWARE),1)
+ cp prep_firmware.ihx firmware.ihx
+else
+ cpp -MD -MF $(basename $<).d -MT $(basename $<).ihx -o /dev/null $<
+ $(SDCC) $(SDCFLAGS) $<
+endif
+
+firmware.ihx: gpifprog_fixed.c
+gpifprog_fixed.c: gpifprog.c
+ sed 's/ xdata / /g;' < $< > $@
+
+$(LIBXSVFDIR)/libxsvf.a:
+ $(MAKE) -C $(LIBXSVFDIR) libxsvf.a
+
+hardware_cksum_vl.inc hardware_cksum_c.inc: hardware.sh hardware.ucf hardware.v
+ echo "'h$$(cat $^ | md5sum | cut -c1-6 | tr a-z A-Z)" > hardware_cksum_vl.inc
+ echo "\"$$(cat $^ | md5sum | cut -c1-6 | tr a-z A-Z)\"" > hardware_cksum_c.inc
+
+filedata.h: hardware.svf erasecpld.svf firmware.ihx
+ { echo "unsigned char hardware_svf[] = { " && perl -pe 's/(.)/ord($$1).","/sge' hardware.svf && echo "};" && \
+ echo "unsigned char erasecpld_svf[] = { " && perl -pe 's/(.)/ord($$1).","/sge' erasecpld.svf && echo "};" && \
+ echo "unsigned char firmware_ihx[] = { " && perl -pe 's/(.)/ord($$1).","/sge' firmware.ihx && echo "};"; } | \
+ perl -pe 's/(.{70}.*?,)/$$1\n/g' > filedata.h_new
+ mv filedata.h_new filedata.h
+
+prep:
+ make clean
+ sed -i '/^USE_PREP_/ s/1/0/;' Makefile
+ make hardware.svf firmware.ihx
+ cp hardware.svf prep_hardware.svf
+ cp erasecpld.svf prep_erasecpld.svf
+ cp firmware.ihx prep_firmware.ihx
+ sed -i '/^USE_PREP_/ s/0/1/;' Makefile
+ make clean
+
+clean:
+ rm -f firmware.asm firmware.lnk firmware.lst firmware.map
+ rm -f firmware.mem firmware.rel firmware.rst firmware.sym
+ rm -f hardware.bld hardware_build.xml hardware.chk hardware.cmd
+ rm -f hardware.log hardware.lso hardware.mfd hardware.ngc hardware.ngd
+ rm -f hardware_ngdbuild.xrpt hardware.ngr hardware.pad hardware_pad.csv
+ rm -f hardware.pnx hardware.prj hardware.rpt hardware.svf hardware.syr
+ rm -f hardware.vm6 hardware.xml hardware.xst hardware_xst.xrpt
+ rm -f hardware.cxt hardware.gyd hardware.jed _impactbatch.log tmperr.err
+ rm -f hardware_cksum_vl.inc hardware_cksum_c.inc gpifprog_fixed.c
+ rm -rf hardware_html xilinx xlnx_auto_0_xdb _xmsgs
+ rm -f filedata.h firmware.ihx erasecpld.cmd erasecpld.svf
+ rm -f xsvftool-xpcu core *.o *.d
+
+-include *.d
+