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