forked from gpu-fftw/gpu_fftw
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Makefile
105 lines (85 loc) · 3.03 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
#####
# Cross compilation vars
####
MAKEFLAGS=-j4
RPIARCH=armv6l-unknown-linux-gnueabihf
RPIDIR=~/x-tools/$(RPIARCH)
RPISYSROOT=~/x-tools/$(RPIARCH)/$(RPIARCH)/sysroot
RPICXX=$(RPIDIR)/bin/$(RPIARCH)-g++
RPICC=$(RPIDIR)/bin/$(RPIARCH)-gcc
RPICXXFLAGS=-march=armv6 -mfloat-abi=hard -mfpu=vfp -O3 -ffast-math \
-pipe -mtune=arm1176jzf-s -fstack-protector --param=ssp-buffer-size=4
RPILDFLAGS=-Wl,-O1,--sort-common,--as-needed,-z,relro
#####
# Regular variables
#####
# See https://gcc.gnu.org/wiki/Visibility for the visibility flag
VISIBILITY= -fvisibility=hidden
CC = $(RPICC)
CXX = $(RPICXX)
CFLAGS += $(RPICXXFLAGS) -std=c99 -Wall -g $(VISIBILITY)
CXXFLAGS += $(RPICXXFLAGS) -std=c++11 -Wall -g $(VISIBILITY) -fvisibility-inlines-hidden
RELVER = 1
TARGETLIBS= libgpufftw.so libgpufftwf.so
TARGETEXES= gpu_fftw
SHARED_SRC= gpu_fftw_util.c \
hello_fft/mailbox.c \
hello_fft/mailbox.c \
hello_fft/gpu_fft.c \
hello_fft/gpu_fft_base.c \
hello_fft/gpu_fft_twiddles.c \
hello_fft/gpu_fft_shaders.c
MAIN_SRC =
#Skip cross-compiling if the x-tools directory is not present in $HOME
ifneq ($(shell test -d ~/x-tools && echo xcompile),xcompile)
CC=gcc
CXX=g++
endif
#TODO: security risk
#RPATH=-Wl,-rpath,'$$ORIGIN/.'
RPATH=
# $(1) - C prefix: fftwf for float and fftw for double
# $(2) - Fortran prefix: s for float and d for double
instantiate=sed -e 's/FPREFIX/$(2)/g' -e 's/PREFIX/$(1)/g' $(3) > $(4)
make_so=$(CC) $(CFLAGS) -shared -fpic -Wl,-soname,libgpu$(1).so -o $@ $^ -ldl -l$(2)
.PHONY: all vsn.h
all: $(TARGETLIBS) $(TARGETEXES)
########################################################
# Shared libs and main executable
########################################################
# Build C source files from the template
# fftw -> double precission
# fftwf -> single (float) precission
gpu_fftw.c: gpu_fftw.c.template
$(call instantiate,fftw,d,$<,$@)
gpu_fftwf.c: gpu_fftw.c.template
$(call instantiate,fftwf,s,$<,$@)
# double precision shared lib
libgpufftw.so.1: gpu_fftw.c $(SHARED_SRC)
$(call make_so,fftw,fftw3)
libgpufftw.so: libgpufftw.so.$(RELVER)
ln -sf $< $@
# single precision shared lib
libgpufftwf.so.1: gpu_fftwf.c $(SHARED_SRC)
$(call make_so,fftwf,fftw3f)
libgpufftwf.so: libgpufftwf.so.$(RELVER)
ln -sf $< $@
# main executable
vsn.h:
VSN="`git describe --always --tags --abbrev=1 | sed 's/^v//'`"; \
echo "#define GPU_FFTW_VSN \"$$VSN\"" > vsn.h
gpu_fftw: gpu_fftw_main.cpp vsn.h libgpufftw.so libgpufftwf.so
$(CXX) $(CXXFLAGS) $(RPATH) -o $@ $< $(MAIN_SRC) -L. -lfftw3f
########################################################
# Clean, update hello_fft from upstream
########################################################
fft_update:
cd hello_fft
svn checkout https://github.com/raspberrypi/firmware/trunk/opt/vc/src/hello_pi/hello_fft
clean:
rm -f gpu_fftw.c gpu_fftwf.c $(TARGETEXES) *~ **/*~
for i in $(TARGETLIBS); do \
rm -f $$i; \
done
test: gpu_fftw
LD_PRELOAD=./libgpufftwf.so LD_LIBRARY_PATH=. GPU_FFTW_DEBUG=7 valgrind --quiet --leak-check=full ./gpu_fftw