首页 > 其他 > 详细

S32K的make过程

时间:2020-04-20 13:10:58      阅读:110      评论:0      收藏:0      [点我收藏+]

>>S32DS编译时的主make过程

 1 #<<<<<<<<<<主makefile重要流程>>>>>>>>>>
 2 #======1.定义first的依赖项为all
 3 first:all
 4 
 5 #======2.定义RM 用于clean操作时的删除当前目录下的所有文件
 6 RM := rm -rf
 7     #======3.包含sources.mk和surbdir.mk(工程子文件夹中所有用到.c的子makefile文件)
 8     -include sources.mk
 9     -include subdir.mk
10     -include APP/DEA/subdir.mk
11 
12 #======3.0 sources.mk主要用于:
13 #======3.0.1 定义所有全局变量并赋空值
14         TODISASSEMBLE_SRCS_QUOTED := 
15         OBJ_SRCS_OS_FORMAT := 
16 #======3.0.2 定义文件夹路径变量SUBDIRS
17         SUBDIRS := 18         APP/DEA 19         APP/SWVersion 20         
21 #======3.1 subdir.mk主要用于:
22 #======3.1.1 追加全局变量:C_SRCS_QUOTED C_SRCS C_DEPS_QUOTED OBJS_QUOTED C_DEPS OBJS_OS_FORMAT OBJS
23         C_SRCS_QUOTED += 24         "../APP/DEA/DeaCoding.c" 25         
26 #======3.1.2 定义各自.o的依赖项及生成.d文件
27         APP/DEA/DeaDiag.o: ../APP/DEA/DeaDiag.c
28           arm-none-eabi-gcc "@APP/DEA/DeaDiag.args" -MMD -MP -MF"$(@:%.o=%.d)" -MT"$(@)" -c -o "APP/DEA/DeaDiag.o" "$<"
29 
30 #====================================4.定义all的依赖项
31 # All Target
32 all: warning-messages explicit-dependencies app.elf secondary-outputs
33 # Tool invocations
34 app.elf: $(OBJS) E:/workspace/S32K/ioc/Projects/D532_MC/D532_MC_APP/Project_Settings/Linker_Files/S32K148_256_flash.ld $(USER_OBJS)
35     @echo Building target: $@
36     @echo Executing target #340 $@
37     @echo Invoking: Standard S32DS C Linker
38     arm-none-eabi-gcc -o "app.elf" "@app.args"  $(USER_OBJS_QUOTED) 
39     @echo Finished building target: $@
40     @echo  
41 
42 app.bin: $(EXECUTABLES)
43     @echo Executing target #341 $@
44     @echo Invoking: Standard S32DS Create Flash Image
45     arm-none-eabi-objcopy -O binary $(EXECUTABLES)  "app.bin"
46     @echo Finished building: $@
47     @echo  
48 
49 app.siz: $(EXECUTABLES)
50     @echo Executing target #342 $@
51     @echo Invoking: Standard S32DS Print Size
52     arm-none-eabi-size --format=berkeley $(EXECUTABLES)
53     @echo Finished building: $@
54     @echo  
55 
56 # Other Targets
57 clean:
58     -$(RM) $(SECONDARY_FLASH_QUOTED) ./*/*/*/*.d ./*/*/*/*/*/*/*.d ./*/*/*/*/*/*/*/*.d ./*/*/*/*/*.d ./*/*/*/*/*/*.d ./*/*.d ./*/*/*.d  ./*/*/*/*.o ./*/*/*/*/*/*/*.o ./*/*/*/*/*/*/*/*.o ./*/*/*/*/*.o ./*/*/*/*/*/*.o ./*/*/*.o ./*/*.o  $(SECONDARY_SIZE_QUOTED) $(EXECUTABLES_QUOTED)
59     -@echo  
60 
61 secondary-outputs: $(SECONDARY_FLASH) $(SECONDARY_SIZE)
62 
63 .PHONY: all clean dependents explicit-dependencies warning-messages
64 .SECONDARY:
65 
66 -include ../makefile.targets
67 
68 explicit-dependencies: 
69 
70 warning-messages: 

 

>>S32DS编译时的子make过程

 1 -include ../../makefile.local
 2 
 3 # Add inputs and outputs from these tool invocations to the build variables 
 4 #======3.1.1 追加全局变量:C_SRCS_QUOTED C_SRCS C_DEPS_QUOTED OBJS_QUOTED C_DEPS OBJS_OS_FORMAT OBJS
 5 C_SRCS_QUOTED +=  6 "../APP/Task_Com/CanApp.c"  7 
 8 C_SRCS +=  9 ../APP/Task_Com/CanApp.c 10 
11 C_DEPS_QUOTED += 12 "./APP/Task_Com/CanApp.d" 13 
14 OBJS_QUOTED += 15 "./APP/Task_Com/CanApp.o" 16 
17 C_DEPS += 18 ./APP/Task_Com/CanApp.d 19 
20 OBJS_OS_FORMAT += 21 ./APP/Task_Com/CanApp.o 22 
23 OBJS += 24 ./APP/Task_Com/CanApp.o 25 
26 #======3.1.2 定义各自.o的依赖项及生成.d文件
27 # Each subdirectory must supply rules for building sources it contributes
28 APP/Task_Com/CanApp.o: ../APP/Task_Com/CanApp.c | pre-build
29     @echo Building file: $<
30     @echo Executing target #50 $<
31     @echo Invoking: Standard S32DS C Compiler
32     arm-none-eabi-gcc "@APP/Task_Com/CanApp.args" -MMD -MP -MF"$(@:%.o=%.d)" -MT"$(@)" -c -o "APP/Task_Com/CanApp.o" "$<"
33     @echo Finished building: $<
34     @echo  

 

S32K的make过程

原文:https://www.cnblogs.com/tjy1805099/p/12736841.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!