#create:2018-10-12
#auther:zsl,wb

#Ķļ֪ʶ
#(1)ַ'\'ʾ
#(2)Ŀĵһָǰһtab4ո
#(3)$@  ʾĿļ
#   $^  ʾеļ
#   $<  ʾһļ
#   $?  ʾĿ껹Ҫµļб

#屾ļʹõıʵҪ޸ġ
#̨·
printf    := echo

#.Cļļ
SRC_C := ./srcc
#.Sļļ
SRC_S := ./srcs
#.oļĿ¼
D_OBJ := ./obj
#.dļĿ¼
D_MK  := ./dmk
#.Cļб
SRC_CList := $(wildcard ./srcc/*.c)
#.Sļб
SRC_SList := $(wildcard ./srcs/*.S)

#ļ(.ld)Ĵ洢·
LDS_SRCS := ../03_MCU/Linker_File/msp432p401r.lds
#ɵļ
finalGoal := ADCMSP432-20210410
#ͷļڵ·
include := -I"C:\Users\lenovo\Desktop\MSP-20210417\MSP-20210417\User-MSP432-20210417\ch10-ADC-CMP\ADC(MSP432)-20210410\.launches" -I"C:\Users\lenovo\Desktop\MSP-20210417\MSP-20210417\User-MSP432-20210417\ch10-ADC-CMP\ADC(MSP432)-20210410\01_Doc" -I"C:\Users\lenovo\Desktop\MSP-20210417\MSP-20210417\User-MSP432-20210417\ch10-ADC-CMP\ADC(MSP432)-20210410\02_CPU" -I"C:\Users\lenovo\Desktop\MSP-20210417\MSP-20210417\User-MSP432-20210417\ch10-ADC-CMP\ADC(MSP432)-20210410\03_MCU" -I"C:\Users\lenovo\Desktop\MSP-20210417\MSP-20210417\User-MSP432-20210417\ch10-ADC-CMP\ADC(MSP432)-20210410\04_GEC" -I"C:\Users\lenovo\Desktop\MSP-20210417\MSP-20210417\User-MSP432-20210417\ch10-ADC-CMP\ADC(MSP432)-20210410\05_UserBoard" -I"C:\Users\lenovo\Desktop\MSP-20210417\MSP-20210417\User-MSP432-20210417\ch10-ADC-CMP\ADC(MSP432)-20210410\06_SoftComponent" -I"C:\Users\lenovo\Desktop\MSP-20210417\MSP-20210417\User-MSP432-20210417\ch10-ADC-CMP\ADC(MSP432)-20210410\07_NosPrg" -I"C:\Users\lenovo\Desktop\MSP-20210417\MSP-20210417\User-MSP432-20210417\ch10-ADC-CMP\ADC(MSP432)-20210410\Debug" -I"C:\Users\lenovo\Desktop\MSP-20210417\MSP-20210417\User-MSP432-20210417\ch10-ADC-CMP\ADC(MSP432)-20210410\03_MCU\Linker_File" -I"C:\Users\lenovo\Desktop\MSP-20210417\MSP-20210417\User-MSP432-20210417\ch10-ADC-CMP\ADC(MSP432)-20210410\03_MCU\MCU_drivers" -I"C:\Users\lenovo\Desktop\MSP-20210417\MSP-20210417\User-MSP432-20210417\ch10-ADC-CMP\ADC(MSP432)-20210410\03_MCU\startup" -I"C:\Users\lenovo\Desktop\MSP-20210417\MSP-20210417\User-MSP432-20210417\ch10-ADC-CMP\ADC(MSP432)-20210410\Debug\obj" -I"C:\Users\lenovo\Desktop\MSP-20210417\MSP-20210417\User-MSP432-20210417\ch10-ADC-CMP\ADC(MSP432)-20210410\Debug\srcc" -I"C:\Users\lenovo\Desktop\MSP-20210417\MSP-20210417\User-MSP432-20210417\ch10-ADC-CMP\ADC(MSP432)-20210410\Debug\srcs"
#Ż𡣹O0O1O2OsOgĬʹOg
opt := Og
#.oļб
OBJ_C := $(addprefix $(D_OBJ)/,$(patsubst %.c,%.o,$(notdir $(SRC_CList))))
OBJ_C += $(addprefix $(D_OBJ)/,$(patsubst %.S,%.o,$(notdir $(SRC_SList))))
#.dļб
SRC_MK := $(addprefix $(D_OBJ)/, $(patsubst %.c,%.d,$(notdir $(SRC_CList))))
SRC_MK += $(addprefix $(D_OBJ)/, $(patsubst %.S,%.d,$(notdir $(SRC_SList))))

#ļ./Sourceе.cļΪ.oļ
$(D_OBJ)/%.o:$(SRC_C)/%.c
	@echo 'Building file: $<'
	@echo 'Invoking: GNU Compiler'
	arm-none-eabi-gcc -c -mcpu=cortex-m4 -march=armv7e-m -mthumb -mfloat-abi=hard -mfpu=fpv4-sp-d16 -D__MSP432P401R__ -DTARGET_IS_FALCON -Dgcc $(include)  -g -gdwarf-3 -gstrict-dwarf -Wall -Wa,-adhlns="$@.lst" -MMD -MP -MF"$(@:%.o=%.d)" -MT"$(@)" -o"$@" "$<"
	@echo 'Finished building: $<'
	@echo ' '

#ļ./Sourceе.SļΪ.oļ 
$(D_OBJ)/%.o:$(SRC_S)/%.S
	@echo 'Building file: $<'
	@echo 'Invoking: GNU Compiler'
	arm-none-eabi-gcc -c -mcpu=cortex-m4 -march=armv7e-m -mthumb -mfloat-abi=hard -mfpu=fpv4-sp-d16 -D__MSP432P401R__ -DTARGET_IS_FALCON -Dgcc $(include)  -g -gdwarf-3 -gstrict-dwarf -Wall -Wa,-adhlns="$@.lst" -MMD -MP -MF"$(@:%.o=%.d)" -MT"$(@)" -o"$@" "$<"
	@echo 'Finished building: $<'
	@echo ' '

# ļеĿꡣĿΪϣɵļСall͡cleanΪαĿ
all: $(finalGoal).lst $(finalGoal).hex

$(finalGoal).out: $(OBJ_C) $(LDS_SRCS)
	@echo 'Building target: $@'
	@echo 'Invoking: GNU Linker'
	arm-none-eabi-gcc -o "$(finalGoal).out" $(OBJ_C) -mcpu=cortex-m4 -T $(LDS_SRCS) \
--specs=nosys.specs -Wl,-Map="$(finalGoal).map" -Wl,--gc-sections -static --specs=nano.specs -mfpu=fpv4-sp-d16 \
-mfloat-abi=hard -mthumb -Wl,--start-group -lc -lm -Wl,--end-group
	@echo 'Finished building target: $@'
	@echo ' '

$(finalGoal).lst: $(finalGoal).out
	@echo 'Invoking: GNU Objcopy Utility'
	arm-none-eabi-objdump --source --all-headers --demangle --line-numbers --wide "$(finalGoal).out" > "$(finalGoal).lst"
	@echo 'Finished building: $@'
	@echo ' '

$(finalGoal).hex: $(finalGoal).out 
	@echo 'Invoking: GNU Objcopy Utility'
	arm-none-eabi-objcopy.exe -I ihex  "$<"  "$@"
	@echo 'Finished building: $@'
	@echo ' '

#ռαĿ
#ɾĿļļδ䶯򲻱룬߱ٶ
fastClean:
	rm -rf "$(finalGoal).out" "$(finalGoal).hex" "$(finalGoal).map"
	-@$(printf) 'make: fast clean has be done'
	-@$(printf) ' '
#ɾмļĿļȫ±	
clean:
	rm -rf  "$(finalGoal).out" "$(finalGoal).hex" "$(finalGoal).map" "$(finalGoal).lst" $(OBJ_C) $(SRC_MK)
	-@$(printf) 'make: clean has be done'
	
second-target:$(finalGoal).lst
	
#ָЩĿΪαĿ
.PHONY: all clean fastClean test


