forked from pavel-demin/red-pitaya-notes
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Makefile
152 lines (121 loc) · 5.27 KB
/
Makefile
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
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
# 'make' builds everything
# 'make clean' deletes everything except source files and Makefile
#
# You need to set NAME, PART and PROC for your project.
# NAME is the base name for most of the generated files.
# solves problem with awk while building linux kernel
# solution taken from http://www.googoolia.com/wp/2015/04/21/awk-symbol-lookup-error-awk-undefined-symbol-mpfr_z_sub/
LD_LIBRARY_PATH =
NAME = led_blinker
PART = xc7z010clg400-1
PROC = ps7_cortexa9_0
CORES = axi_axis_reader_v1_0 axi_axis_writer_v1_0 axi_bram_reader_v1_0 \
axi_bram_writer_v1_0 axi_cfg_register_v1_0 axis_accumulator_v1_0 \
axis_alex_v1_0 axis_bram_reader_v1_0 axis_bram_writer_v1_0 \
axis_constant_v1_0 axis_counter_v1_0 axis_decimator_v1_0 \
axis_fifo_v1_0 axis_gpio_reader_v1_0 axis_histogram_v1_0 \
axis_interpolator_v1_0 axis_keyer_v1_0 axis_lfsr_v1_0 axis_oscilloscope_v1_0 \
axis_packetizer_v1_0 axis_phase_generator_v1_0 \
axis_pulse_height_analyzer_v1_0 axis_ram_writer_v1_0 \
axis_red_pitaya_adc_v1_0 axis_red_pitaya_dac_v1_0 axis_stepper_v1_0 \
axis_tagger_v1_0 axis_timer_v1_0 axis_trigger_v1_0 axi_sts_register_v1_0 \
axis_validator_v1_0 axis_variable_v1_0 axis_variant_v1_0 axis_zeroer_v1_0 \
dna_reader_v1_0 gpio_debouncer_v1_0 pulse_generator_v1_0
VIVADO = vivado -nolog -nojournal -mode batch
HSI = hsi -nolog -nojournal -mode batch
RM = rm -rf
UBOOT_TAG = xilinx-v2016.2
LINUX_TAG = xilinx-v2016.2
DTREE_TAG = xilinx-v2016.2
UBOOT_DIR = tmp/u-boot-xlnx-$(UBOOT_TAG)
LINUX_DIR = tmp/linux-xlnx-$(LINUX_TAG)
DTREE_DIR = tmp/device-tree-xlnx-$(DTREE_TAG)
UBOOT_TAR = tmp/u-boot-xlnx-$(UBOOT_TAG).tar.gz
LINUX_TAR = tmp/linux-xlnx-$(LINUX_TAG).tar.gz
DTREE_TAR = tmp/device-tree-xlnx-$(DTREE_TAG).tar.gz
UBOOT_URL = https://github.com/Xilinx/u-boot-xlnx/archive/$(UBOOT_TAG).tar.gz
LINUX_URL = https://github.com/Xilinx/linux-xlnx/archive/$(LINUX_TAG).tar.gz
DTREE_URL = https://github.com/Xilinx/device-tree-xlnx/archive/$(DTREE_TAG).tar.gz
LINUX_CFLAGS = "-O2 -march=armv7-a -mcpu=cortex-a9 -mtune=cortex-a9 -mfpu=neon -mfloat-abi=hard"
UBOOT_CFLAGS = "-O2 -march=armv7-a -mcpu=cortex-a9 -mtune=cortex-a9 -mfpu=neon -mfloat-abi=hard"
ARMHF_CFLAGS = "-O2 -march=armv7-a -mcpu=cortex-a9 -mtune=cortex-a9 -mfpu=neon -mfloat-abi=hard"
RTL_TAR = tmp/rtl8192cu.tgz
RTL_URL = https://googledrive.com/host/0B-t5klOOymMNfmJ0bFQzTVNXQ3RtWm5SQ2NGTE1hRUlTd3V2emdSNzN6d0pYamNILW83Wmc/rtl8192cu/rtl8192cu.tgz
.PRECIOUS: tmp/cores/% tmp/%.xpr tmp/%.hwdef tmp/%.bit tmp/%.fsbl/executable.elf tmp/%.tree/system.dts
all: boot.bin uImage devicetree.dtb fw_printenv
$(UBOOT_TAR):
mkdir -p $(@D)
curl -L $(UBOOT_URL) -o $@
$(LINUX_TAR):
mkdir -p $(@D)
curl -L $(LINUX_URL) -o $@
$(DTREE_TAR):
mkdir -p $(@D)
curl -L $(DTREE_URL) -o $@
$(RTL_TAR):
mkdir -p $(@D)
curl -L $(RTL_URL) -o $@
$(UBOOT_DIR): $(UBOOT_TAR)
mkdir -p $@
tar -zxf $< --strip-components=1 --directory=$@
patch -d tmp -p 0 < patches/u-boot-xlnx-$(UBOOT_TAG).patch
cp patches/zynq_red_pitaya_defconfig $@/configs
cp patches/zynq-red-pitaya.dts $@/arch/arm/dts
cp patches/zynq_red_pitaya.h $@/include/configs
cp patches/u-boot-lantiq.c $@/drivers/net/phy/lantiq.c
$(LINUX_DIR): $(LINUX_TAR) $(RTL_TAR)
mkdir -p $@
tar -zxf $< --strip-components=1 --directory=$@
tar -zxf $(RTL_TAR) --directory=$@/drivers/net/wireless/realtek
patch -d tmp -p 0 < patches/linux-xlnx-$(LINUX_TAG).patch
cp patches/linux-lantiq.c $@/drivers/net/phy/lantiq.c
$(DTREE_DIR): $(DTREE_TAR)
mkdir -p $@
tar -zxf $< --strip-components=1 --directory=$@
uImage: $(LINUX_DIR)
make -C $< mrproper
make -C $< ARCH=arm xilinx_zynq_defconfig
make -C $< ARCH=arm CFLAGS=$(LINUX_CFLAGS) \
-j $(shell nproc 2> /dev/null || echo 1) \
CROSS_COMPILE=arm-linux-gnueabihf- UIMAGE_LOADADDR=0x8000 uImage
cp $</arch/arm/boot/uImage $@
tmp/u-boot.elf: $(UBOOT_DIR)
mkdir -p $(@D)
make -C $< mrproper
make -C $< ARCH=arm zynq_red_pitaya_defconfig
make -C $< ARCH=arm CFLAGS=$(UBOOT_CFLAGS) \
CROSS_COMPILE=arm-linux-gnueabihf- all
cp $</u-boot $@
fw_printenv: $(UBOOT_DIR) tmp/u-boot.elf
make -C $< ARCH=arm CFLAGS=$(ARMHF_CFLAGS) \
CROSS_COMPILE=arm-linux-gnueabihf- env
cp $</tools/env/fw_printenv $@
boot.bin: tmp/$(NAME).fsbl/executable.elf tmp/$(NAME).bit tmp/u-boot.elf
echo "img:{[bootloader] $^}" > tmp/boot.bif
bootgen -image tmp/boot.bif -w -o i $@
devicetree.dtb: uImage tmp/$(NAME).tree/system.dts
$(LINUX_DIR)/scripts/dtc/dtc -I dts -O dtb -o devicetree.dtb \
-i tmp/$(NAME).tree tmp/$(NAME).tree/system.dts
tmp/cores/%: cores/%/core_config.tcl cores/%/*.v
mkdir -p $(@D)
$(VIVADO) -source scripts/core.tcl -tclargs $* $(PART)
tmp/%.xpr: projects/% $(addprefix tmp/cores/, $(CORES))
mkdir -p $(@D)
$(VIVADO) -source scripts/project.tcl -tclargs $* $(PART)
tmp/%.hwdef: tmp/%.xpr
mkdir -p $(@D)
$(VIVADO) -source scripts/hwdef.tcl -tclargs $*
tmp/%.bit: tmp/%.xpr
mkdir -p $(@D)
$(VIVADO) -source scripts/bitstream.tcl -tclargs $*
tmp/%.fsbl/executable.elf: tmp/%.hwdef
mkdir -p $(@D)
$(HSI) -source scripts/fsbl.tcl -tclargs $* $(PROC)
tmp/%.tree/system.dts: tmp/%.hwdef $(DTREE_DIR)
mkdir -p $(@D)
$(HSI) -source scripts/devicetree.tcl -tclargs $* $(PROC) $(DTREE_DIR)
patch $@ patches/devicetree.patch
clean:
$(RM) uImage fw_printenv boot.bin devicetree.dtb tmp
$(RM) .Xil usage_statistics_webtalk.html usage_statistics_webtalk.xml
$(RM) webtalk*.jou webtalk*.log