diff options
author | Timothy Pearson <kb9vqf@pearsoncomputing.net> | 2012-10-01 21:07:55 -0500 |
---|---|---|
committer | Timothy Pearson <kb9vqf@pearsoncomputing.net> | 2012-10-01 21:07:55 -0500 |
commit | d1b70f80180fe4b5ac6078e2be9678fc36d74c5c (patch) | |
tree | 2e46de7a644f89e36842247af6826ff00a0d3fa4 /fpga/xilinx/programmer/dependencies/libxsvf/xsvftool-xpcu.src/.svn/text-base/Makefile.svn-base | |
parent | ae161b4a6a978922747cf09e8c04479340825852 (diff) | |
download | ulab-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-base | 97 |
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 + |