Update espressif platform // Resolve #296, #297

This commit is contained in:
Valeriy Koval
2015-10-02 16:11:00 +03:00
parent 12b29a760a
commit 4dcef89301
3 changed files with 69 additions and 26 deletions

View File

@ -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"

View File

@ -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

View File

@ -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)