summaryrefslogtreecommitdiffstats
path: root/fpga/xilinx/programmer/dependencies/libxsvf/xsvftool-xpcu.src/Makefile
blob: ca0621d1b438605851cb96ef46ad35df2f15d8e4 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
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