TI Openmpacc Makefile讲解

Data: 2017.12.29

Author: cjh

Theme: TI Openmpacc Makefile讲解

 

本章节主要是对Makefile进行讲解,有利于读者后期对代码的修改和编译

Makefile讲解

#包含make.inc
include ../make.inc

#target编译选项
OA_TC_OPTS 			= -O3
ifeq ($(VERBOSE),1)
#主机编译选项 -fopenmp为openmp编译选项
OA_HC_OPTS 			= -O3 -Wall -Wextra -fopenmp

#-v -k --hc --tc详见TI Openmp clacc编译器讲解
OA_SHELL_OPTS 		= -v -k --hc="$(OA_HC_OPTS)" --tc="$(OA_TC_OPTS)"
else
OA_HC_OPTS 			= -O3 -fopenmp
OA_SHELL_OPTS 		= --hc="$(OA_HC_OPTS)" --tc="$(OA_TC_OPTS)"
endif

#CPP编译选项,有需求可以在这里添加
CXX_OPTS 			= -O3

#最终编译执行程序名字
EXE     	= dsplib_fft
#主机端代码
HOST_CODE 	= dsplib_fft_main.cpp dsplib_fft_host.cpp
#target端代码
TARGET_CODE = dsplib_fft_target.c
#调用dsplib库,需要调用别的库按此方法添加,不可想传统方法-L/-llib进行添加库
DSPLIB 		= ./dsplib.ae66
#具体意思可参见Makefile学习总结
OBJS 		= $(patsubst %.cpp,%.o,$(HOST_CODE)) 

#目标文件编译
$(EXE): $(OBJS) 
	$(OA_SHELL) $(OA_SHELL_OPTS) $(OBJS) $(TARGET_CODE) $(DSPLIB) -o $@

#.c文件编译
%.o: %.c
	$(CC) $(CXX_OPTS) -c $<

#.cpp文件编译	
%.o: %.cpp
	$(CXX) $(CXX_OPTS) -c $<

clean:
	@rm -f $(EXE) $(OA_SHELL_TMP_FILES) *.log

make.inc讲解

#opencl编译器
CL                    = cl6x -mv6600 --abi=eabi 
#clacc编译器
OA_SHELL 	          = clacc 
CXX 		          = arm-linux-gnueabihf-g++  
CC  		          = arm-linux-gnueabihf-gcc  
#CXX 		          = g++  
#CC  		          = gcc  
OA_SHELL_TMP_FILES    = *.out __TI_CLACC_KERNEL.c *.cl *.asm *.dsp_h *.bc *.objc *.if *.map *.opt *.int.c *.o *.obj __s2s_predef.gcc_h


#下面的内容不是很重要,不用管
# temporary workaround for locale bug
LC_ALL?=C
export LC_ALL

UNAME_M :=$(shell uname -m)
ifneq (,$(findstring x86, $(UNAME_M)))
 ifeq ($(TARGET_ROOTDIR),)
 $(call error,ERROR - TARGET_ROOTDIR must be set for cross compiling)
 endif
endif

ifeq ($(TI_OCL_CGT_INSTALL),)
  TI_OCL_CGT_INSTALL = $(TARGET_ROOTDIR)/usr/share/ti/cgt-c6x
endif

需要通用模板或者编译过程有问题的可以提问交流。




  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
SPDK(Storage Performance Development Kit)是一个开源的高性能存储软件开发工具包,提供了一组用于开发高性能存储系统的API和工具。SPDK的Makefile文件是一个非常复杂的文件,以下是对SPDK的Makefile进行简要讲解: 1. 定义变量 Makefile首先会定义一系列变量,用于设置编译器、编译选项、目标文件、依赖库等等。例如: ``` CC = gcc CFLAGS += -g -O2 LIBS += -lpthread -lrt TARGET = spdk ``` 在上述代码中,CC变量定义了编译器为gcc,CFLAGS变量定义了编译选项为-g -O2,LIBS变量定义了依赖库为pthread和rt,TARGET变量定义了目标文件为spdk。 2. 定义规则 Makefile接下来会定义一系列规则,用于指定如何编译源代码、如何链接目标文件、如何清除编译生成的文件等等。例如: ``` $(TARGET): $(OBJS) $(CC) $(LDFLAGS) -o $@ $^ $(LIBS) %.o: %.c $(CC) $(CFLAGS) -c -o $@ $< ``` 在上述代码中,$(TARGET)规则指定了如何链接目标文件,依赖于$(OBJS)变量中定义的一组目标文件,使用$(LDFLAGS)变量中定义的链接选项和$(LIBS)变量中定义的依赖库进行链接。%.o规则指定了如何编译C源代码文件,使用$(CFLAGS)变量中定义的编译选项进行编译,并将生成的目标文件保存为.o文件。 3. 定义依赖 Makefile接下来会定义一系列依赖关系,用于指定哪些源代码文件依赖于哪些头文件、哪些目标文件依赖于哪些源代码文件等等。例如: ``` spdk.o: spdk.c spdk_internal.h spdk/env.h spdk/event.h spdk/queue.h spdk/thread.h ``` 在上述代码中,spdk.o目标文件依赖于spdk.c、spdk_internal.h、spdk/env.h、spdk/event.h、spdk/queue.h和spdk/thread.h等一组源代码文件和头文件。 4. 定义清理规则 Makefile最后会定义一系列清理规则,用于删除编译生成的文件。例如: ``` clean: rm -f $(TARGET) $(OBJS) ``` 在上述代码中,clean规则指定了如何删除$(TARGET)变量和$(OBJS)变量中定义的一组文件。 以上是SPDK的Makefile文件的基本结构和内容,由于SPDK是一个非常复杂的软件工具包,其Makefile文件很复杂,还包括了很多其他的规则和变量定义等。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值