1# Makefile to compile the helloworld app for esptool tests 2 3# Prefix for each cross compiler (can include a directory path) 4# These can be overridden via environment variables or on the make command line 5CROSS_8266 ?= xtensa-lx106-elf- 6CROSS_32 ?= xtensa-esp32-elf- 7CROSS_32S2 ?= xtensa-esp32s2-elf- 8CROSS_32S3 ?= xtensa-esp32s3-elf- 9CROSS_ESPRISCV32 ?= riscv32-esp-elf- 10 11# Pass V=1 to see the commands being executed by make 12ifneq ("$(V)","1") 13Q = @ 14endif 15 16APP = helloworld 17SRCS = main.c 18 19BUILD_DIR = build 20 21APP_ELF_8266 = $(BUILD_DIR)/$(APP)-esp8266.elf 22APP_ELF_32 = $(BUILD_DIR)/$(APP)-esp32.elf 23APP_ELF_32S2 = $(BUILD_DIR)/$(APP)-esp32s2.elf 24APP_ELF_32S3_BETA_2 = $(BUILD_DIR)/$(APP)-esp32s3beta2.elf 25APP_ELF_32S3 = $(BUILD_DIR)/$(APP)-esp32s3.elf 26APP_ELF_32C3 = $(BUILD_DIR)/$(APP)-esp32c3.elf 27APP_ELF_32C2 = $(BUILD_DIR)/$(APP)-esp32c2.elf 28APP_ELF_32C6 = $(BUILD_DIR)/$(APP)-esp32c6.elf 29APP_ELF_32C61 = $(BUILD_DIR)/$(APP)-esp32c61.elf 30APP_ELF_32H2 = $(BUILD_DIR)/$(APP)-esp32h2.elf 31APP_ELF_32P4 = $(BUILD_DIR)/$(APP)-esp32p4.elf 32APP_ELF_32C5 = $(BUILD_DIR)/$(APP)-esp32c5.elf 33 34.PHONY: all esp32 clean 35 36all: $(APP_ELF_8266) $(APP_ELF_32) $(APP_ELF_32S2) $(APP_ELF_32C3) $(APP_ELF_32S3) $(APP_ELF_32C2) $(APP_ELF_32C6) $(APP_ELF_32H2) $(APP_ELF_32P4) $(APP_ELF_32C5) 37 38esp32: $(APP_ELF_32) $(APP_ELF_32S2) $(APP_ELF_32C3) $(APP_ELF_32S3) $(APP_ELF_32C2) $(APP_ELF_32C6) $(APP_ELF_32C61) $(APP_ELF_32H2) $(APP_ELF_32P4) $(APP_ELF_32C5) 39 40$(BUILD_DIR): 41 $(Q) mkdir $@ 42 43CFLAGS = -std=c99 -Wall -Werror -Os \ 44 -mtext-section-literals -mlongcalls -nostdlib -fno-builtin -flto \ 45 -Wl,-static -g -ffunction-sections -Wl,--gc-sections -Iinclude -Lld 46CFLAGS_ESPRISCV32 = -std=c99 -Wall -Werror -Os \ 47 -march=rv32imc -msmall-data-limit=0 \ 48 -nostdlib -fno-builtin -flto \ 49 -Wl,-static -g -ffunction-sections -Wl,--gc-sections -Iinclude -Lld 50LDLIBS = -lgcc 51 52$(APP_ELF_8266): $(SRCS) $(SRCS_8266) $(BUILD_DIR) ld/app_8266.ld | Makefile 53 @echo " CC(8266) $^ -> $@" 54 $(Q) $(CROSS_8266)gcc $(CFLAGS) -DESP8266=1 -Tapp_8266.ld -Wl,-Map=$(@:.elf=.map) -o $@ $(filter %.c, $^) $(LDLIBS) 55 56$(APP_ELF_32): $(SRCS) $(BUILD_DIR) ld/app_32.ld | Makefile 57 @echo " CC(32) $^ -> $@" 58 $(Q) $(CROSS_32)gcc $(CFLAGS) -DESP32=1 -Tapp_32.ld -Wl,-Map=$(@:.elf=.map) -o $@ $(filter %.c, $^) $(LDLIBS) 59 60$(APP_ELF_32S2): $(SRCS) $(BUILD_DIR) ld/app_32s2.ld 61 @echo " CC(32S2) $^ -> $@" 62 $(Q) $(CROSS_32S2)gcc $(CFLAGS) -DESP32S2=1 -Tapp_32s2.ld -Wl,-Map=$(@:.elf=.map) -o $@ $(filter %.c, $^) $(LDLIBS) 63 64$(APP_ELF_32S3_BETA_2): $(SRCS) $(BUILD_DIR) ld/app_32s3_beta_2.ld 65 @echo " CC(32S3) $^ -> $@" 66 $(Q) $(CROSS_32S3)gcc $(CFLAGS) -DESP32S3=1 -Tapp_32s3.ld -Wl,-Map=$(@:.elf=.map) -o $@ $(filter %.c, $^) $(LDLIBS) 67 68$(APP_ELF_32S3): $(SRCS) $(BUILD_DIR) ld/app_32s3.ld 69 @echo " CC(32S3) $^ -> $@" 70 $(Q) $(CROSS_32S3)gcc $(CFLAGS) -DESP32S3=1 -Tapp_32s3.ld -Wl,-Map=$(@:.elf=.map) -o $@ $(filter %.c, $^) $(LDLIBS) 71 72$(APP_ELF_32C3): $(SRCS) $(BUILD_DIR) ld/app_32c3.ld 73 @echo " CC(32C3) $^ -> $@" 74 $(Q) $(CROSS_ESPRISCV32)gcc $(CFLAGS_ESPRISCV32) -DESP32C3=1 -Tapp_32c3.ld -Wl,-Map=$(@:.elf=.map) -o $@ $(filter %.c, $^) $(LDLIBS) 75 76$(APP_ELF_32C2): $(SRCS) $(BUILD_DIR) ld/app_32c2.ld 77 @echo " CC(32C2) $^ -> $@" 78 $(Q) $(CROSS_ESPRISCV32)gcc $(CFLAGS_ESPRISCV32) -DESP32C2=1 -Tapp_32c2.ld -Wl,-Map=$(@:.elf=.map) -o $@ $(filter %.c, $^) $(LDLIBS) 79 80$(APP_ELF_32C6): $(SRCS) $(BUILD_DIR) ld/app_32c6.ld 81 @echo " CC(32C6) $^ -> $@" 82 $(Q) $(CROSS_ESPRISCV32)gcc $(CFLAGS_ESPRISCV32) -DESP32C6=1 -Tapp_32c6.ld -Wl,-Map=$(@:.elf=.map) -o $@ $(filter %.c, $^) $(LDLIBS) 83 84$(APP_ELF_32C61): $(SRCS) $(BUILD_DIR) ld/app_32c61.ld 85 @echo " CC(32C61) $^ -> $@" 86 $(Q) $(CROSS_ESPRISCV32)gcc $(CFLAGS_ESPRISCV32) -DESP32C61=1 -Tapp_32c61.ld -Wl,-Map=$(@:.elf=.map) -o $@ $(filter %.c, $^) $(LDLIBS) 87 88$(APP_ELF_32H2): $(SRCS) $(BUILD_DIR) ld/app_32h2.ld 89 @echo " CC(32H2) $^ -> $@" 90 $(Q) $(CROSS_ESPRISCV32)gcc $(CFLAGS_ESPRISCV32) -DESP32H2=1 -Tapp_32h2.ld -Wl,-Map=$(@:.elf=.map) -o $@ $(filter %.c, $^) $(LDLIBS) 91 92$(APP_ELF_32P4): $(SRCS) $(BUILD_DIR) ld/app_32p4.ld 93 @echo " CC(32P4) $^ -> $@" 94 $(Q) $(CROSS_ESPRISCV32)gcc $(CFLAGS_ESPRISCV32) -DESP32P4=1 -Tapp_32p4.ld -Wl,-Map=$(@:.elf=.map) -o $@ $(filter %.c, $^) $(LDLIBS) 95 96$(APP_ELF_32C5): $(SRCS) $(BUILD_DIR) ld/app_32c5.ld 97 @echo " CC(32C5) $^ -> $@" 98 $(Q) $(CROSS_ESPRISCV32)gcc $(CFLAGS_ESPRISCV32) -DESP32C5=1 -Tapp_32c5.ld -Wl,-Map=$(@:.elf=.map) -o $@ $(filter %.c, $^) $(LDLIBS) 99 100clean: 101 $(Q) rm -rf $(BUILD_DIR) 102