Added support for AM572x. Performance to be tuned and optimized.
[dense-linear-algebra-libraries/linalg.git] / src / ti / linalg / Makefile
2 .PHONY: clean ARMonly linalg cleanall install build prebuild
4 LINALG_BLIS_DIR     = blis
5 LINALG_CBLAS_DIR    = cblas
6 LINALG_TICBLAS_DIR  = ticblas
7 LINALG_BLASACC_DIR  = blasblisacc
8 LINALG_CLAPACK_DIR  = clapack
9 BLIS_VERSION = $(shell cat $(LINALG_BLIS_DIR)/version)
11 CBLAS_HEADERS  =$(LINALG_CBLAS_DIR)/include/cblas.h
12 CLAPACK_HEADERS =$(LINALG_CLAPACK_DIR)/INCLUDE/blaswrap.h  
13 CLAPACK_HEADERS+=$(LINALG_CLAPACK_DIR)/INCLUDE/clapack.h  
14 CLAPACK_HEADERS+=$(LINALG_CLAPACK_DIR)/INCLUDE/f2c.h  
16 ifneq (,$(findstring DSP,$(MAKECMDGOALS)))
18 ifeq ($(LIBOS),LIB_RTOS)
19 CBLAS_HEADERS +=$(LINALG_TICBLAS_DIR)/ticblas.h
20 endif
22 ifeq ($(TARGET),SOC_K2H)
23 NUM_ARM_CORES=4
24 NUM_DSP_CORES=8
25 else ifeq ($(TARGET),SOC_SHANNON)
26 NUM_DSP_CORES=8
27 else ifeq ($(TARGET),SOC_AM572x)
28 NUM_ARM_CORES=2
29 NUM_DSP_CORES=2
30 else
31 $(call error, ERROR - MEM_MODEL NOT DEFINED. Must specify one of: MEM_MODEL=Large, MEM_MODEL=Medium, MEM_MODEL=Small)
32 endif
34 endif
36 # MEM_MODEL needs to be defined for both build and clean
37 ifeq ($(MEM_MODEL),Large)
38 BLIS_CFG   = c66xLarge
39 else ifeq ($(MEM_MODEL),Medium)
40 BLIS_CFG   = c66xMedium
41 else ifeq ($(MEM_MODEL),Small)
42 BLIS_CFG   = c66xSmall
43 else
44 $(call error, ERROR - MEM_MODEL NOT DEFINED. Must specify one of: MEM_MODEL=Large, MEM_MODEL=Medium, MEM_MODEL=Small)
45 endif
47 # Build DSP code for DSP-only platforms and for ARM+DSP platforms. 
48 # All object binaries are added to a singl archive: lib/libcblas.ae66, which includes:
49 #    - CBLAS 
50 #    - BLIS for specified TARGET, MEM_MODEL, LIBOS (BIOS or OPENCL), NUM_DSP_CORES
51 #    - TICBLAS for specified TARGET, MEM_MODEL, LIBOS (BIOS or OPENCL)
52 DSPlibs:
53         cd $(LINALG_CBLAS_DIR); make arch=C66 alllib; \
54         cd ../$(LINALG_BLIS_DIR); ./configure -p install/$(BLIS_CFG) c66x; \
55         make -j8 MEM_MODEL=$(MEM_MODEL) TARGET=$(TARGET) LIBOS=$(LIBOS) NUM_DSP_CORES=$(NUM_DSP_CORES); make install; \
56         cd ../$(LINALG_TICBLAS_DIR)/src; make MEM_MODEL=$(MEM_MODEL) TARGET=$(TARGET) LIBOS=$(LIBOS); cd ../lib; \
57         echo "combining BLIS, CBLAS, and TICBLAS libraries into one: libcblas.ae66"; \
58         mkdir -p objs; cd objs; rm -f *; ar x ../../../blis/install/$(BLIS_CFG)/lib/libblis.ae66; mmv 'cblas*.o' 'blis_cblas#1.o'; \
59         ar -x ../../../cblas/lib/C66/libcblas.ae66; ar -x ../libticblas.ae66; chmod +rw *;cd ../../..; \
60         mkdir -p lib; cd lib; rm -f *; ar -cr libcblas.ae66 ../ticblas/lib/objs/*; cd ..; \
61         mkdir -p include; rm -f include/*; cp $(CBLAS_HEADERS) include
63 # Build ARM code for ARM+DSP platforms
64 ARMlibs:
65         cd $(LINALG_CBLAS_DIR); make arch=ARM alllib; \
66         cd ../$(LINALG_BLIS_DIR); ./configure -p install/arm cortex-a15; make -j8 NUM_ARM_CORES=$(NUM_ARM_CORES); make install; \
67         cd ../$(LINALG_CLAPACK_DIR); make f2clib; make cblaswrap; cd SRC; make -j8; cd ..
69 # Build host-callable libraries for ARM+DSP platforms. 
70 # BLAS has a single archive: libcblas_armplusdsp.a, which includes:
71 #    - CBLAS ARM code
72 #    - BLIS ARM code for specified NUM_ARM_CORES
73 #    - BLAS wrapper (accelerator) code
74 #    - DSP code built by DSPlibs
75 # LAPACK has 3 archives: 
76 #    - liblapack.a: CLAPACK ARM library
77 #    - libcblaswr.a: CBLAS wrapper library used by CLAPACK
78 #    - libf2c.a: F2C library used by CLAPACK
79 ARMplusDSP: DSPlibs ARMlibs
80         cd $(LINALG_BLASACC_DIR)/src; make MEM_MODEL=$(MEM_MODEL) TARGET=$(TARGET); cd ../..; \
81         cd lib; rm -f *; \
82         cp ../$(LINALG_BLASACC_DIR)/lib/libcblas_armplusdsp.a .; \
83         cp ../$(LINALG_BLIS_DIR)/install/arm/lib/libblis.a .; \
84         ar -x libblis.a; mmv "cblas_*.o" "blis_cblas_#1.o"; ar -x libcblas_armplusdsp.a; rm *.a; \
85         ar -cr libcblas_armplusdsp.a *.o; rm *.o; cd ..; \
86         cp $(LINALG_CLAPACK_DIR)/lapack_ARM.a ./lib/liblapack.a; \
87         cp $(LINALG_CLAPACK_DIR)/libcblaswr_ARM.a ./lib/libcblaswr.a; \
88         cp $(LINALG_CLAPACK_DIR)/F2CLIBS/libf2c_ARM.a ./lib/libf2c.a; \
89         cp $(CLAPACK_HEADERS) include
91 cleanDSPlibs:
92         rm -f lib/*
93         cd $(LINALG_CBLAS_DIR); make arch=C66 clean; \
94         cd ../$(LINALG_BLIS_DIR); ./configure -p install/$(BLIS_CFG) c66x; make -j8 clean; rm -r install/$(BLIS_CFG); \
95         cd ../$(LINALG_TICBLAS_DIR)/src; make clean; 
97 cleanARMlibs:
98         cd $(LINALG_CBLAS_DIR); make arch=ARM clean; \
99         cd ../$(LINALG_BLIS_DIR); ./configure -p install/arm cortex-a15; make clean; rm -r install/arm; \
100         cd ../$(LINALG_BLASACC_DIR); make clean; \
101         cd ../$(LINALG_BLIS_DIR)/testsuite; make clean; \
102         cd ../../$(LINALG_CLAPACK_DIR); make clean
104 BLIStest:
105         cd $(LINALG_BLIS_DIR); ./configure -p install/arm cortex-a15; \
106         cd testsuite; make lib=OpenCLCBLAS -j8 
108 BLIStestDSP:
109         cd $(LINALG_BLIS_DIR); ./configure -p install/$(BLIS_CFG) c66x; \
110         cd testsuite/dsponly; make MEM_MODEL=Small TARGET=SOC_C6678 LIBOS=LIB_RTOS 
112 BLAStest:
113         cd $(LINALG_CLAPACK_DIR)/BLAS/TESTING; make -f Makeblat1; make -f Makeblat2; make -f Makeblat3
115 CLAPACKtest:
116         cd $(LINALG_CLAPACK_DIR)/TESTING/MATGEN; make 
117         cd $(LINALG_CLAPACK_DIR)/TESTING/LIN; make
118         cd $(LINALG_CLAPACK_DIR)/TESTING/EIG; make
121 cleanARMplusDSP: cleanDSPlibs cleanARMlibs
123 docs: doxygen/doxycfg.txt doxygen/mainpage.dox
124         doxygen ./docs/doxygen/doxycfg.txt
126 installDSPlib:
127         install -m 755 -d ${DESTDIR}/include
128         install -m 755 -d ${DESTDIR}/lib
129         cp include/* ${DESTDIR}/include
130         cp ./lib/libcblas.ae66 ${DESTDIR}/lib
131         cp -r docs ${DESTDIR}
133 installARMplusDSPlib:
134         install -m 755 -d ${DESTDIR}/include
135         install -m 755 -d ${DESTDIR}/lib
136         cp include/* ${DESTDIR}/include
137         cp ./lib/libcblas_armplusdsp.a ${DESTDIR}/lib
138         cp ./lib/liblapack.a ${DESTDIR}/lib
139         cp ./lib/libcblaswr.a ${DESTDIR}/lib
140         cp ./lib/libf2c.a ${DESTDIR}/lib
141         cp -r docs ${DESTDIR}