mirror of
https://github.com/platformio/platformio-core.git
synced 2025-07-30 01:57:13 +02:00
Merge pull request #299 from valeros/develop
Update espressif platform // Resolve #296, #297
This commit is contained in:
@ -3,7 +3,7 @@
|
|||||||
"build": {
|
"build": {
|
||||||
"core": "esp8266",
|
"core": "esp8266",
|
||||||
"extra_flags": "-DARDUINO_ESP8266_ESP01 -DARDUINO_ARCH_ESP8266 -DESP8266",
|
"extra_flags": "-DARDUINO_ESP8266_ESP01 -DARDUINO_ARCH_ESP8266 -DESP8266",
|
||||||
"f_cpu": "80000000L",
|
"f_cpu": "40000000L",
|
||||||
"ldscript": "esp8266.flash.512k.ld",
|
"ldscript": "esp8266.flash.512k.ld",
|
||||||
"mcu": "esp8266",
|
"mcu": "esp8266",
|
||||||
"variant": "generic"
|
"variant": "generic"
|
||||||
|
@ -31,7 +31,7 @@ env.Replace(
|
|||||||
ASPPFLAGS=["-x", "assembler-with-cpp"],
|
ASPPFLAGS=["-x", "assembler-with-cpp"],
|
||||||
|
|
||||||
CFLAGS=[
|
CFLAGS=[
|
||||||
"-std=c99",
|
"-std=gnu99",
|
||||||
"-Wpointer-arith",
|
"-Wpointer-arith",
|
||||||
"-Wno-implicit-function-declaration",
|
"-Wno-implicit-function-declaration",
|
||||||
"-Wl,-EL",
|
"-Wl,-EL",
|
||||||
@ -76,9 +76,7 @@ env.Replace(
|
|||||||
"-cb", "$UPLOAD_SPEED",
|
"-cb", "$UPLOAD_SPEED",
|
||||||
"-cp", "$UPLOAD_PORT",
|
"-cp", "$UPLOAD_PORT",
|
||||||
"-ca", "0x00000",
|
"-ca", "0x00000",
|
||||||
"-cf", "${SOURCES[0]}",
|
"-cf", "$SOURCE"
|
||||||
"-ca", "0x40000" if "FRAMEWORK" not in env else "0x10000",
|
|
||||||
"-cf", "${SOURCES[1]}"
|
|
||||||
],
|
],
|
||||||
UPLOADCMD='$UPLOADER $UPLOADERFLAGS',
|
UPLOADCMD='$UPLOADER $UPLOADERFLAGS',
|
||||||
|
|
||||||
@ -86,23 +84,35 @@ env.Replace(
|
|||||||
PROGSUFFIX=".elf"
|
PROGSUFFIX=".elf"
|
||||||
)
|
)
|
||||||
|
|
||||||
|
if "FRAMEWORK" in env:
|
||||||
|
env.Append(
|
||||||
|
LINKFLAGS=[
|
||||||
|
"-Wl,-wrap,system_restart_local",
|
||||||
|
"-Wl,-wrap,register_chipv6_phy"
|
||||||
|
]
|
||||||
|
)
|
||||||
|
|
||||||
env.Append(
|
env.Append(
|
||||||
BUILDERS=dict(
|
BUILDERS=dict(
|
||||||
ElfToBin=Builder(
|
ElfToBin=Builder(
|
||||||
action=" ".join([
|
action=" ".join([
|
||||||
"$UPLOADER",
|
"$UPLOADER",
|
||||||
|
"-eo", join("$PLATFORMFW_DIR", "bootloaders",
|
||||||
|
"eboot", "eboot.elf"),
|
||||||
|
"-bo", "$TARGET",
|
||||||
|
"-bm", "dio",
|
||||||
|
"-bf", "${BOARD_OPTIONS['build']['f_cpu'][:2]}",
|
||||||
|
"-bz", str(int(env.get("BOARD_OPTIONS", {}).get(
|
||||||
|
"upload", {}).get("maximum_size") / 1024)) + "K",
|
||||||
|
"-bs", ".text",
|
||||||
|
"-bp", "4096",
|
||||||
|
"-ec",
|
||||||
"-eo", "$SOURCES",
|
"-eo", "$SOURCES",
|
||||||
"-bo", "${TARGETS[0]}",
|
"-bs", ".irom0.text",
|
||||||
"-bm", "qio",
|
|
||||||
"-bf", "40",
|
|
||||||
"-bz", "512K",
|
|
||||||
"-bs", ".text",
|
"-bs", ".text",
|
||||||
"-bs", ".data",
|
"-bs", ".data",
|
||||||
"-bs", ".rodata",
|
"-bs", ".rodata",
|
||||||
"-bc", "-ec",
|
"-bc", "-ec"
|
||||||
"-eo", "$SOURCES",
|
|
||||||
"-es", ".irom0.text", "${TARGETS[1]}",
|
|
||||||
"-ec", "-v"
|
|
||||||
]),
|
]),
|
||||||
suffix=".bin"
|
suffix=".bin"
|
||||||
)
|
)
|
||||||
@ -119,13 +129,43 @@ if "FRAMEWORK" not in env:
|
|||||||
join("$PIOPACKAGES_DIR", "sdk-esp8266", "include"),
|
join("$PIOPACKAGES_DIR", "sdk-esp8266", "include"),
|
||||||
"$PROJECTSRC_DIR"
|
"$PROJECTSRC_DIR"
|
||||||
],
|
],
|
||||||
LIBPATH=[join("$PIOPACKAGES_DIR", "sdk-esp8266", "lib")]
|
LIBPATH=[join("$PIOPACKAGES_DIR", "sdk-esp8266", "lib")],
|
||||||
|
BUILDERS=dict(
|
||||||
|
ElfToBin=Builder(
|
||||||
|
action=" ".join([
|
||||||
|
"$UPLOADER",
|
||||||
|
"-eo", "$SOURCES",
|
||||||
|
"-bo", "${TARGETS[0]}",
|
||||||
|
"-bm", "qio",
|
||||||
|
"-bf", "40",
|
||||||
|
"-bz", "512K",
|
||||||
|
"-bs", ".text",
|
||||||
|
"-bs", ".data",
|
||||||
|
"-bs", ".rodata",
|
||||||
|
"-bc", "-ec",
|
||||||
|
"-eo", "$SOURCES",
|
||||||
|
"-es", ".irom0.text", "${TARGETS[1]}",
|
||||||
|
"-ec", "-v"
|
||||||
|
]),
|
||||||
|
suffix=".bin"
|
||||||
|
)
|
||||||
|
)
|
||||||
)
|
)
|
||||||
env.Replace(
|
env.Replace(
|
||||||
LDSCRIPT_PATH=join(
|
LDSCRIPT_PATH=join(
|
||||||
"$PIOPACKAGES_DIR", "sdk-esp8266", "ld", "eagle.app.v6.ld"),
|
"$PIOPACKAGES_DIR", "sdk-esp8266", "ld", "eagle.app.v6.ld"),
|
||||||
LIBS=["c", "gcc", "phy", "pp", "net80211", "lwip", "wpa", "main",
|
LIBS=["c", "gcc", "phy", "pp", "net80211", "lwip", "wpa", "main",
|
||||||
"json", "upgrade", "smartconfig", "pwm", "at", "ssl"]
|
"json", "upgrade", "smartconfig", "pwm", "at", "ssl"],
|
||||||
|
UPLOADERFLAGS=[
|
||||||
|
"-vv",
|
||||||
|
"-cd", "ck",
|
||||||
|
"-cb", "$UPLOAD_SPEED",
|
||||||
|
"-cp", "$UPLOAD_PORT",
|
||||||
|
"-ca", "0x00000",
|
||||||
|
"-cf", "${SOURCES[0]}",
|
||||||
|
"-ca", "0x40000",
|
||||||
|
"-cf", "${SOURCES[1]}"
|
||||||
|
]
|
||||||
)
|
)
|
||||||
|
|
||||||
#
|
#
|
||||||
@ -139,17 +179,20 @@ target_elf = env.BuildProgram()
|
|||||||
#
|
#
|
||||||
|
|
||||||
if "uploadlazy" in COMMAND_LINE_TARGETS:
|
if "uploadlazy" in COMMAND_LINE_TARGETS:
|
||||||
target_firm = [
|
if "FRAMEWORK" not in env:
|
||||||
join("$BUILD_DIR", "firmware_00000.bin"),
|
target_firm = [
|
||||||
join("$BUILD_DIR", "firmware_%s.bin" %
|
join("$BUILD_DIR", "firmware_00000.bin"),
|
||||||
("40000" if "FRAMEWORK" not in env else "10000"))
|
join("$BUILD_DIR", "firmware_40000.bin")
|
||||||
]
|
]
|
||||||
|
else:
|
||||||
|
target_firm = join("$BUILD_DIR", "firmware.bin")
|
||||||
else:
|
else:
|
||||||
target_firm = env.ElfToBin(
|
if "FRAMEWORK" not in env:
|
||||||
[join("$BUILD_DIR", "firmware_00000"),
|
target_firm = env.ElfToBin(
|
||||||
join("$BUILD_DIR", "firmware_%s" %
|
[join("$BUILD_DIR", "firmware_00000"),
|
||||||
("40000" if "FRAMEWORK" not in env else "10000"))], target_elf)
|
join("$BUILD_DIR", "firmware_40000")], target_elf)
|
||||||
|
else:
|
||||||
|
target_firm = env.ElfToBin(join("$BUILD_DIR", "firmware"), target_elf)
|
||||||
|
|
||||||
#
|
#
|
||||||
# Target: Print binary size
|
# Target: Print binary size
|
||||||
|
@ -47,7 +47,7 @@ elif env.get("PLATFORM") == "espressif":
|
|||||||
CPPPATH=[join("$PLATFORMFW_DIR", "sdk", "include")],
|
CPPPATH=[join("$PLATFORMFW_DIR", "sdk", "include")],
|
||||||
LIBPATH=[join("$PLATFORMFW_DIR", "sdk", "lib")],
|
LIBPATH=[join("$PLATFORMFW_DIR", "sdk", "lib")],
|
||||||
LIBS=["smartconfig", "pp", "main", "wpa", "lwip",
|
LIBS=["smartconfig", "pp", "main", "wpa", "lwip",
|
||||||
"net80211", "phy", "hal", "gcc", "m"]
|
"net80211", "wps", "crypto", "phy", "hal", "gcc", "m"]
|
||||||
)
|
)
|
||||||
|
|
||||||
env.Replace(PLATFORMFW_DIR=PLATFORMFW_DIR)
|
env.Replace(PLATFORMFW_DIR=PLATFORMFW_DIR)
|
||||||
|
Reference in New Issue
Block a user