Download pre-built toolchains (#2545)
* Download pre-built toolchains * Updated to include the platform in the name of the pre-built toolchain * Download archive into cache/ * Update Travis configuration to use pre-built toolchain via make
This commit is contained in:
parent
2d958750b5
commit
8bb41fe93f
|
@ -8,6 +8,7 @@ server-ca.crt
|
||||||
luac.cross
|
luac.cross
|
||||||
uz_unzip
|
uz_unzip
|
||||||
uz_zip
|
uz_zip
|
||||||
|
tools/toolchains/
|
||||||
|
|
||||||
#ignore Eclipse project files
|
#ignore Eclipse project files
|
||||||
.cproject
|
.cproject
|
||||||
|
|
|
@ -7,9 +7,6 @@ addons:
|
||||||
cache:
|
cache:
|
||||||
- directories:
|
- directories:
|
||||||
- cache
|
- cache
|
||||||
install:
|
|
||||||
- tar -Jxvf tools/esp-open-sdk.tar.xz
|
|
||||||
- export PATH=$PATH:$PWD/esp-open-sdk/xtensa-lx106-elf/bin
|
|
||||||
script:
|
script:
|
||||||
- export BUILD_DATE=$(date +%Y%m%d)
|
- export BUILD_DATE=$(date +%Y%m%d)
|
||||||
- make EXTRA_CCFLAGS="-DBUILD_DATE='\"'$BUILD_DATE'\"'" all
|
- make EXTRA_CCFLAGS="-DBUILD_DATE='\"'$BUILD_DATE'\"'" all
|
||||||
|
|
32
Makefile
32
Makefile
|
@ -2,6 +2,8 @@
|
||||||
#
|
#
|
||||||
.NOTPARALLEL:
|
.NOTPARALLEL:
|
||||||
|
|
||||||
|
TOOLCHAIN_VERSION:=20181106.0
|
||||||
|
|
||||||
# SDK base version, as released by Espressif
|
# SDK base version, as released by Espressif
|
||||||
SDK_BASE_VER:=2.2.1
|
SDK_BASE_VER:=2.2.1
|
||||||
|
|
||||||
|
@ -47,7 +49,7 @@ ifeq ($(OS),Windows_NT)
|
||||||
OBJCOPY = xt-objcopy
|
OBJCOPY = xt-objcopy
|
||||||
#MAKE = xt-make
|
#MAKE = xt-make
|
||||||
CCFLAGS += --rename-section .text=.irom0.text --rename-section .literal=.irom0.literal
|
CCFLAGS += --rename-section .text=.irom0.text --rename-section .literal=.irom0.literal
|
||||||
else
|
else
|
||||||
# It is gcc, may be cygwin
|
# It is gcc, may be cygwin
|
||||||
# Can we use -fdata-sections?
|
# Can we use -fdata-sections?
|
||||||
CCFLAGS += -ffunction-sections -fno-jump-tables -fdata-sections
|
CCFLAGS += -ffunction-sections -fno-jump-tables -fdata-sections
|
||||||
|
@ -73,11 +75,13 @@ ifeq ($(OS),Windows_NT)
|
||||||
else
|
else
|
||||||
# We are under other system, may be Linux. Assume using gcc.
|
# We are under other system, may be Linux. Assume using gcc.
|
||||||
# Can we use -fdata-sections?
|
# Can we use -fdata-sections?
|
||||||
|
PLATFORM:=linux-x86_64
|
||||||
ifndef COMPORT
|
ifndef COMPORT
|
||||||
ESPPORT = /dev/ttyUSB0
|
ESPPORT = /dev/ttyUSB0
|
||||||
else
|
else
|
||||||
ESPPORT = $(COMPORT)
|
ESPPORT = $(COMPORT)
|
||||||
endif
|
endif
|
||||||
|
export PATH := $(PATH):$(TOP_DIR)/tools/toolchains/esp8266-$(PLATFORM)-$(TOOLCHAIN_VERSION)/bin/
|
||||||
CCFLAGS += -ffunction-sections -fno-jump-tables -fdata-sections
|
CCFLAGS += -ffunction-sections -fno-jump-tables -fdata-sections
|
||||||
AR = xtensa-lx106-elf-ar
|
AR = xtensa-lx106-elf-ar
|
||||||
CC = $(WRAPCC) xtensa-lx106-elf-gcc
|
CC = $(WRAPCC) xtensa-lx106-elf-gcc
|
||||||
|
@ -145,9 +149,9 @@ endif
|
||||||
endif
|
endif
|
||||||
|
|
||||||
#
|
#
|
||||||
# Note:
|
# Note:
|
||||||
# https://gcc.gnu.org/onlinedocs/gcc/Optimize-Options.html
|
# https://gcc.gnu.org/onlinedocs/gcc/Optimize-Options.html
|
||||||
# If you add global optimize options like "-O2" here
|
# If you add global optimize options like "-O2" here
|
||||||
# they will override "-Os" defined above.
|
# they will override "-Os" defined above.
|
||||||
# "-Os" should be used to reduce code size
|
# "-Os" should be used to reduce code size
|
||||||
#
|
#
|
||||||
|
@ -161,7 +165,7 @@ CCFLAGS += \
|
||||||
-nostdlib \
|
-nostdlib \
|
||||||
-mlongcalls \
|
-mlongcalls \
|
||||||
-mtext-section-literals
|
-mtext-section-literals
|
||||||
# -Wall
|
# -Wall
|
||||||
|
|
||||||
CFLAGS = $(CCFLAGS) $(DEFINES) $(EXTRA_CCFLAGS) $(STD_CFLAGS) $(INCLUDES)
|
CFLAGS = $(CCFLAGS) $(DEFINES) $(EXTRA_CCFLAGS) $(STD_CFLAGS) $(INCLUDES)
|
||||||
DFLAGS = $(CCFLAGS) $(DDEFINES) $(EXTRA_CCFLAGS) $(STD_CFLAGS) $(INCLUDES)
|
DFLAGS = $(CCFLAGS) $(DDEFINES) $(EXTRA_CCFLAGS) $(STD_CFLAGS) $(INCLUDES)
|
||||||
|
@ -191,7 +195,7 @@ DEP_LIBS_$(1) = $$(foreach lib,$$(filter %.a,$$(COMPONENTS_$(1))),$$(dir $$(lib)
|
||||||
DEP_OBJS_$(1) = $$(foreach obj,$$(filter %.o,$$(COMPONENTS_$(1))),$$(dir $$(obj))$$(OBJODIR)/$$(notdir $$(obj)))
|
DEP_OBJS_$(1) = $$(foreach obj,$$(filter %.o,$$(COMPONENTS_$(1))),$$(dir $$(obj))$$(OBJODIR)/$$(notdir $$(obj)))
|
||||||
$$(IMAGEODIR)/$(1).out: $$(OBJS) $$(DEP_OBJS_$(1)) $$(DEP_LIBS_$(1)) $$(DEPENDS_$(1))
|
$$(IMAGEODIR)/$(1).out: $$(OBJS) $$(DEP_OBJS_$(1)) $$(DEP_LIBS_$(1)) $$(DEPENDS_$(1))
|
||||||
@mkdir -p $$(IMAGEODIR)
|
@mkdir -p $$(IMAGEODIR)
|
||||||
$$(CC) $$(LDFLAGS) $$(if $$(LINKFLAGS_$(1)),$$(LINKFLAGS_$(1)),$$(LINKFLAGS_DEFAULT) $$(OBJS) $$(DEP_OBJS_$(1)) $$(DEP_LIBS_$(1))) -o $$@
|
$$(CC) $$(LDFLAGS) $$(if $$(LINKFLAGS_$(1)),$$(LINKFLAGS_$(1)),$$(LINKFLAGS_DEFAULT) $$(OBJS) $$(DEP_OBJS_$(1)) $$(DEP_LIBS_$(1))) -o $$@
|
||||||
endef
|
endef
|
||||||
|
|
||||||
$(BINODIR)/%.bin: $(IMAGEODIR)/%.out
|
$(BINODIR)/%.bin: $(IMAGEODIR)/%.out
|
||||||
|
@ -204,16 +208,32 @@ $(BINODIR)/%.bin: $(IMAGEODIR)/%.out
|
||||||
# Should be done in top-level makefile only
|
# Should be done in top-level makefile only
|
||||||
#
|
#
|
||||||
|
|
||||||
all: sdk_pruned pre_build .subdirs $(OBJS) $(OLIBS) $(OIMAGES) $(OBINS) $(SPECIAL_MKTARGETS)
|
all: toolchain sdk_pruned pre_build .subdirs $(OBJS) $(OLIBS) $(OIMAGES) $(OBINS) $(SPECIAL_MKTARGETS)
|
||||||
|
|
||||||
.PHONY: sdk_extracted
|
.PHONY: sdk_extracted
|
||||||
.PHONY: sdk_patched
|
.PHONY: sdk_patched
|
||||||
.PHONY: sdk_pruned
|
.PHONY: sdk_pruned
|
||||||
|
.PHONY: toolchain
|
||||||
|
|
||||||
sdk_extracted: $(TOP_DIR)/sdk/.extracted-$(SDK_BASE_VER)
|
sdk_extracted: $(TOP_DIR)/sdk/.extracted-$(SDK_BASE_VER)
|
||||||
sdk_patched: sdk_extracted $(TOP_DIR)/sdk/.patched-$(SDK_VER)
|
sdk_patched: sdk_extracted $(TOP_DIR)/sdk/.patched-$(SDK_VER)
|
||||||
sdk_pruned: $(SDK_DIR_DEPENDS) $(TOP_DIR)/sdk/.pruned-$(SDK_VER)
|
sdk_pruned: $(SDK_DIR_DEPENDS) $(TOP_DIR)/sdk/.pruned-$(SDK_VER)
|
||||||
|
|
||||||
|
ifeq ($(OS),Windows_NT)
|
||||||
|
toolchain:
|
||||||
|
else
|
||||||
|
toolchain: $(TOP_DIR)/tools/toolchains/esp8266-$(PLATFORM)-$(TOOLCHAIN_VERSION)/bin/xtensa-lx106-elf-gcc
|
||||||
|
|
||||||
|
$(TOP_DIR)/tools/toolchains/esp8266-$(PLATFORM)-$(TOOLCHAIN_VERSION)/bin/xtensa-lx106-elf-gcc: $(TOP_DIR)/cache/toolchain-esp8266-$(PLATFORM)-$(TOOLCHAIN_VERSION).tar.xz
|
||||||
|
mkdir -p $(TOP_DIR)/tools/toolchains/
|
||||||
|
tar -xJf $< -C $(TOP_DIR)/tools/toolchains/
|
||||||
|
touch $@
|
||||||
|
|
||||||
|
$(TOP_DIR)/cache/toolchain-esp8266-$(PLATFORM)-$(TOOLCHAIN_VERSION).tar.xz:
|
||||||
|
mkdir -p $(TOP_DIR)/cache
|
||||||
|
wget --tries=10 --timeout=15 --waitretry=30 --read-timeout=20 --retry-connrefused https://github.com/jmattsson/esp-toolchains/releases/download/$(PLATFORM)-$(TOOLCHAIN_VERSION)/toolchain-esp8266-$(PLATFORM)-$(TOOLCHAIN_VERSION).tar.xz -O $@ || { rm -f "$@"; exit 1; }
|
||||||
|
endif
|
||||||
|
|
||||||
$(TOP_DIR)/sdk/.extracted-$(SDK_BASE_VER): $(TOP_DIR)/cache/v$(SDK_FILE_VER).zip
|
$(TOP_DIR)/sdk/.extracted-$(SDK_BASE_VER): $(TOP_DIR)/cache/v$(SDK_FILE_VER).zip
|
||||||
mkdir -p "$(dir $@)"
|
mkdir -p "$(dir $@)"
|
||||||
(cd "$(dir $@)" && rm -fr esp_iot_sdk_v$(SDK_VER) ESP8266_NONOS_SDK-$(SDK_BASE_VER) && unzip $(TOP_DIR)/cache/v$(SDK_FILE_VER).zip ESP8266_NONOS_SDK-$(SDK_BASE_VER)/lib/* ESP8266_NONOS_SDK-$(SDK_BASE_VER)/ld/eagle.rom.addr.v6.ld ESP8266_NONOS_SDK-$(SDK_BASE_VER)/include/* ESP8266_NONOS_SDK-$(SDK_BASE_VER)/bin/esp_init_data_default_v05.bin)
|
(cd "$(dir $@)" && rm -fr esp_iot_sdk_v$(SDK_VER) ESP8266_NONOS_SDK-$(SDK_BASE_VER) && unzip $(TOP_DIR)/cache/v$(SDK_FILE_VER).zip ESP8266_NONOS_SDK-$(SDK_BASE_VER)/lib/* ESP8266_NONOS_SDK-$(SDK_BASE_VER)/ld/eagle.rom.addr.v6.ld ESP8266_NONOS_SDK-$(SDK_BASE_VER)/include/* ESP8266_NONOS_SDK-$(SDK_BASE_VER)/bin/esp_init_data_default_v05.bin)
|
||||||
|
|
Binary file not shown.
Loading…
Reference in New Issue