| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270 |
- # DECLARATIONS
- # Directory where QEMU_STM32 ARM executable is located - used for running
- # program in emulator.
- QEMU_ARM_DIR ?=
- # OpenOCD interface file used for programming/debugging the micronctroller
- OPENOCD_INTERFACE ?= interface/olimex-arm-usb-tiny-h.cfg
- # Declare command line tools - assume these are in the path
- CC = arm-none-eabi-gcc
- LD = arm-none-eabi-ld
- AS = arm-none-eabi-as
- CP = arm-none-eabi-objcopy
- OD = arm-none-eabi-objdump
- # Declare command line flags
- CORE_CFLAGS = -I./ -I$(CORE_SRC) -I$(DEVICE_SRC) -I$(STD_PERIPH)/inc -Idemos/common -fno-common -O0 -g -mcpu=cortex-m3 -mthumb
- CFLAGS = $(CORE_CFLAGS) -c
- CFLAGS_LINK = -Wl,-Tdemos/main.ld -nostartfiles $(CORE_CFLAGS)
- ASFLAGS = -mcpu=cortex-m3 -mthumb -g
- LDFLAGS = -Tdemos/main.ld
- CPFLAGS = -Obinary
- ODFLAGS = -S
- # Declare library source paths
- SRC = $(realpath .)
- CORE_SRC = $(SRC)/libraries/CMSIS/CM3/CoreSupport
- DEVICE_SRC = $(SRC)/libraries/CMSIS/CM3/DeviceSupport/ST/STM32F10x
- STD_PERIPH = $(SRC)/libraries/STM32F10x_StdPeriph_Driver
- STD_PERIPH_SRC = $(STD_PERIPH)/src
- # List common and system library source files
- # (i.e. for accessing STM32/Cortex M3 hardware)
- COMMON_FILES = $(CORE_SRC)/core_cm3.c
- COMMON_FILES += $(DEVICE_SRC)/system_stm32f10x.c
- COMMON_FILES += $(DEVICE_SRC)/startup/gcc_ride7/startup_stm32f10x_md.s
- COMMON_FILES += demos/common/stm32_p103.c
- COMMON_FILES += demos/common/myprintk.c
- COMMON_FILES += $(STD_PERIPH_SRC)/stm32f10x_rcc.c
- COMMON_FILES += $(STD_PERIPH_SRC)/stm32f10x_gpio.c
- COMMON_FILES += $(STD_PERIPH_SRC)/stm32f10x_usart.c
- COMMON_FILES += $(STD_PERIPH_SRC)/stm32f10x_exti.c
- COMMON_FILES += $(STD_PERIPH_SRC)/stm32f10x_adc.c
- COMMON_FILES += $(STD_PERIPH_SRC)/stm32f10x_tim.c
- COMMON_FILES += $(STD_PERIPH_SRC)/stm32f10x_rtc.c
- COMMON_FILES += $(STD_PERIPH_SRC)/stm32f10x_dac.c
- COMMON_FILES += $(STD_PERIPH_SRC)/misc.c
- # List all demos
- DEMOS = printf_demo
- DEMOS += systick
- # List all demo folders
- DEMO_FOLDERS = $(addprefix demos/,$(DEMOS))
- # List FreeRTOS resources
- FREE_RTOS_SRC = $(SRC)/libraries/FreeRTOS
- FREE_RTOS_SRC_FILES = $(FREE_RTOS_SRC)/croutine.c $(FREE_RTOS_SRC)/list.c $(FREE_RTOS_SRC)/queue.c $(FREE_RTOS_SRC)/tasks.c $(FREE_RTOS_SRC)/croutine.c $(FREE_RTOS_SRC)/stream_buffer.c $(FREE_RTOS_SRC)/portable/GCC/ARM_CM3/port.c
- FREE_RTOS_INC = $(FREE_RTOS_SRC)/include/
- FREE_RTOS_PORT_INC = $(FREE_RTOS_SRC)/portable/GCC/ARM_CM3/
- # List path to demo build output files
- OUTPUT_FILES = $(addsuffix /main,$(DEMO_FOLDERS))
- ELF_FILES = $(addsuffix .elf,$(OUTPUT_FILES))
- LIST_FILES = $(addsuffix .list,$(OUTPUT_FILES))
- BIN_FILES = $(addsuffix .bin,$(OUTPUT_FILES))
- # Declare target names for each demo
- ALL_TARGETS = $(addsuffix _ALL,$(DEMOS))
- PROG_TARGETS = $(addsuffix _PROG,$(DEMOS))
- QEMU_RUN_TARGETS = $(addsuffix _QEMURUN,$(DEMOS))
- QEMU_RUN_PTY_TARGETS = $(addsuffix _QEMURUN_PTY,$(DEMOS))
- QEMU_RUN_TEL_TARGETS = $(addsuffix _QEMURUN_TEL,$(DEMOS))
- QEMU_DBG_TARGETS = $(addsuffix _QEMUDBG,$(DEMOS))
- QEMU_DBG_PTY_TARGETS = $(addsuffix _QEMUDBG_PTY,$(DEMOS))
- QEMU_DBG_TEL_TARGETS = $(addsuffix _QEMUDBG_TEL,$(DEMOS))
- # TARGETS - See README for descriptions of the targets
- # Generic targets
- .PHONY: clean $(ALL_TARGETS) $(PROG_TARGETS) openocd_dbg
- all: $(ALL_TARGETS)
- clean:
- find . -type f -name "*.o" -exec rm {} \;
- find . -type f -name "*.elf" -exec rm {} \;
- find . -type f -name "*.bin" -exec rm {} \;
- find . -type f -name "*.list" -exec rm {} \;
- # Compile targets (builds all output files)
- $(ALL_TARGETS): %_ALL : demos/%/main.elf demos/%/main.bin demos/%/main.list
- # Targets to program a microntroller using OpenOCD
- $(PROG_TARGETS): %_PROG : %_ALL
- -killall -q openocd
- openocd -f $(OPENOCD_INTERFACE) -f openocd/openocd_stm32_p103.cfg -c "program_flash demos/$*/main.bin"
- # Target to launch OpenOCD - by default, OpenOCD creates a GDB server at port 3333.
- DBG:
- -killall -q openocd
- openocd -f $(OPENOCD_INTERFACE) -f openocd/openocd_stm32_p103.cfg -c "init_stm32"
-
- # QEMU run targets
- $(QEMU_RUN_TARGETS): %_QEMURUN : %_ALL
- -killall -q qemu-system-arm
- $(QEMU_ARM_DIR)qemu-system-arm -M stm32-p103 -kernel demos/$*/main.bin
- $(QEMU_RUN_PTY_TARGETS): %_QEMURUN_PTY : %_ALL
- -killall -q qemu-system-arm
- $(QEMU_ARM_DIR)qemu-system-arm -M stm32-p103 -kernel demos/$*/main.bin -serial pty
-
- $(QEMU_RUN_TEL_TARGETS): %_QEMURUN_TEL : %_ALL
- -killall -q qemu-system-arm
- $(QEMU_ARM_DIR)qemu-system-arm -M stm32-p103 -kernel demos/$*/main.bin -serial tcp::7777,server
- # QEMU debug targets
- $(QEMU_DBG_TARGETS): %_QEMUDBG : %_ALL
- -killall -q qemu-system-arm
- $(QEMU_ARM_DIR)qemu-system-arm -M stm32-p103 -gdb tcp::3333 -S -kernel demos/$*/main.bin
- $(QEMU_DBG_PTY_TARGETS): %_QEMUDBG_PTY : %_ALL
- -killall -q qemu-system-arm
- $(QEMU_ARM_DIR)qemu-system-arm -M stm32-p103 -gdb tcp::3333 -S -kernel demos/$*/main.bin -serial pty
-
- $(QEMU_DBG_TEL_TARGETS): %_QEMUDBG_TEL : %_ALL
- -killall -q qemu-system-arm
- $(QEMU_ARM_DIR)qemu-system-arm -M stm32-p103 -gdb tcp::3333 -S -kernel demos/$*/main.bin -serial tcp::7777,server
-
- # Note: Use this command to run QEMU in low-level debug mode:
- # qemu-system-arm -cpu cortex-m3 -M stm32-p103 -nographic -singlestep -kernel main.bin -d in_asm,out_asm,exec,cpu,int,op,op_opt
- # Compile targets to build individual files
- $(LIST_FILES): %.list : %.elf
- $(OD) $(ODFLAGS) $< > $@
- $(BIN_FILES): %.bin : %.elf
- $(CP) $(CPFLAGS) $< $@
- # Targets to build individual demos
- demos/blink_flash/main.elf: demos/blink_flash/main.c
- demos/blink_flash/main.elf: $(STD_PERIPH_SRC)/stm32f10x_rcc.c
- demos/blink_flash/main.elf: $(STD_PERIPH_SRC)/stm32f10x_gpio.c
- demos/blink_flash/main.elf: $(COMMON_FILES)
- $(CC) $(CFLAGS_LINK) -Idemos/blink_flash/ -o $@ $^
- demos/blink_flash_asm/main.elf: demos/blink_flash_asm/main.o
- $(LD) $(LDFLAGS) -o $@ $<
- demos/blink_flash_asm/main.o: demos/blink_flash_asm/main.s
- $(AS) $(ASFLAGS) -o $@ $<
- demos/adc_single/main.elf: demos/adc_single/main.c
- demos/adc_single/main.elf: $(COMMON_FILES)
- $(CC) $(CFLAGS_LINK) -Idemos/adc_single/ -o $@ $^
- demos/button/main.elf: demos/button/main.c
- demos/button/main.elf: $(COMMON_FILES)
- $(CC) $(CFLAGS_LINK) -Idemos/button/ -o $@ $^
- demos/button_int/main.elf: demos/button_int/main.c
- demos/button_int/main.elf: $(COMMON_FILES)
- $(CC) $(CFLAGS_LINK) -Idemos/button_int/ -o $@ $^
- demos/button_int_infinite/main.elf: demos/button_int/main.c
- demos/button_int_infinite/main.elf: $(COMMON_FILES)
- $(CC) -DDO_NOT_CLEAR_IT_PENDING_FLAG $(CFLAGS_LINK) -Idemos/button_int/ -o $@ $^
- demos/c_mem_model/main.o: demos/c_mem_model/main.c
- $(CC) $(CFLAGS_LINK) -Idemos/c_mem_model/ -c -o $@ $^
- demos/c_mem_model/main.elf: demos/c_mem_model/main.o
- demos/c_mem_model/main.elf: $(COMMON_FILES)
- $(CC) $(CFLAGS_LINK) -Idemos/c_mem_model/ -o $@ $^
- demos/freertos_singlethread/main.elf: demos/freertos_singlethread/main.c
- demos/freertos_singlethread/main.elf: $(COMMON_FILES)
- demos/freertos_singlethread/main.elf: $(FREE_RTOS_SRC_FILES)
- demos/freertos_singlethread/main.elf: $(FREE_RTOS_SRC)/portable/MemMang/heap_1.c
- $(CC) $(CFLAGS_LINK) -Idemos/freertos_singlethread/ -I$(FREE_RTOS_INC) -I$(FREE_RTOS_PORT_INC) -o $@ $^
- demos/freertos_multithread/main.elf: demos/freertos_multithread/main.c
- demos/freertos_multithread/main.elf: $(COMMON_FILES)
- demos/freertos_multithread/main.elf: $(FREE_RTOS_SRC_FILES)
- demos/freertos_multithread/main.elf: $(FREE_RTOS_SRC)/portable/MemMang/heap_1.c
- $(CC) $(CFLAGS_LINK) -Idemos/freertos_multithread/ -I$(FREE_RTOS_INC) -I$(FREE_RTOS_PORT_INC) -o $@ $^
- demos/freertos_streambuffer/main.elf: demos/freertos_streambuffer/main.c
- demos/freertos_streambuffer/main.elf: $(COMMON_FILES)
- demos/freertos_streambuffer/main.elf: $(FREE_RTOS_SRC_FILES)
- demos/freertos_streambuffer/main.elf: $(FREE_RTOS_SRC)/portable/MemMang/heap_1.c
- $(CC) $(CFLAGS_LINK) -Idemos/freertos_streambuffer/ -I$(FREE_RTOS_INC) -I$(FREE_RTOS_PORT_INC) -o $@ $^
- demos/qemu_test/main.elf: demos/qemu_test/main.c
- demos/qemu_test/main.elf: $(COMMON_FILES)
- $(CC) $(CFLAGS_LINK) -Idemos/qemu_test/ -o $@ $^
- demos/software_int/main.elf: demos/software_int/main.c
- demos/software_int/main.elf: $(COMMON_FILES)
- $(CC) $(CFLAGS_LINK) -Idemos/software_int/ -o $@ $^
- demos/stkalign/main.elf: demos/stkalign/main.c
- demos/stkalign/main.elf: $(COMMON_FILES)
- $(CC) $(CFLAGS_LINK) -Idemos/stkalign/ -o $@ $^
- demos/systick/main.elf: demos/systick/main.c
- demos/systick/main.elf: $(COMMON_FILES)
- $(CC) $(CFLAGS_LINK) -Idemos/systick/ -o $@ $^
- demos/timer/main.elf: demos/timer/main.c
- demos/timer/main.elf: $(COMMON_FILES)
- $(CC) $(CFLAGS_LINK) -Idemos/timer/ -o $@ $^
- demos/uart_echo/main.elf: demos/uart_echo/main.c
- demos/uart_echo/main.elf: $(COMMON_FILES)
- $(CC) $(CFLAGS_LINK) -Idemos/uart_echo/ -o $@ $^
- demos/printf_demo/main.elf: demos/printf_demo/main.c
- demos/printf_demo/main.elf: $(COMMON_FILES)
- $(CC) $(CFLAGS_LINK) -Idemos/printf_demo/ -o $@ $^
- demos/uart_repeat_write/main.elf: demos/uart_repeat_write/main.c
- demos/uart_repeat_write/main.elf: $(COMMON_FILES)
- $(CC) $(CFLAGS_LINK) -Idemos/uart_repeat_write/ -o $@ $^
- demos/uart_echo_int/main.elf: demos/uart_echo_int/main.c
- demos/uart_echo_int/main.elf: $(COMMON_FILES)
- $(CC) $(CFLAGS_LINK) -Idemos/uart_echo_int/ -o $@ $^
- demos/uart_repeat_write_int/main.elf: demos/uart_repeat_write_int/main.c
- demos/uart_repeat_write_int/main.elf: $(COMMON_FILES)
- $(CC) $(CFLAGS_LINK) -Idemos/uart_repeat_write_int/ -o $@ $^
- demos/dac/main.elf: demos/dac/main.c
- demos/dac/main.elf: $(COMMON_FILES)
- $(CC) $(CFLAGS_LINK) -Idemos/dac/ -o $@ $^
- demos/rtc/main.elf: demos/rtc/main.c
- demos/rtc/main.elf: $(COMMON_FILES)
- $(CC) $(CFLAGS_LINK) -Idemos/rtc/ -o $@ $^
- demos/freertos_semaphore1/main.elf: demos/freertos_semaphore1/main.c
- demos/freertos_semaphore1/main.elf: $(COMMON_FILES)
- demos/freertos_semaphore1/main.elf: $(FREE_RTOS_SRC_FILES)
- demos/freertos_semaphore1/main.elf: $(FREE_RTOS_SRC)/portable/MemMang/heap_1.c
- $(CC) $(CFLAGS_LINK) -Idemos/freertos_semaphore1/ -I$(FREE_RTOS_INC) -I$(FREE_RTOS_PORT_INC) -o $@ $^
- demos/freertos_cycletask/main.elf: demos/freertos_cycletask/main.c
- demos/freertos_cycletask/main.elf: $(COMMON_FILES)
- demos/freertos_cycletask/main.elf: $(FREE_RTOS_SRC_FILES)
- demos/freertos_cycletask/main.elf: $(FREE_RTOS_SRC)/portable/MemMang/heap_1.c
- $(CC) $(CFLAGS_LINK) -Idemos/freertos_cycletask/ -I$(FREE_RTOS_INC) -I$(FREE_RTOS_PORT_INC) -o $@ $^
|