Custom Partition Tables // Resolve #58

This commit is contained in:
Ivan Kravets
2018-05-26 01:13:54 +03:00
parent 9080ace7ac
commit fd9ed71c4f
5 changed files with 95 additions and 45 deletions
+1 -1
View File
@@ -7,7 +7,7 @@
"flash_mode": "dio",
"ldscript": "esp32_out.ld",
"mcu": "esp32",
"partitions": "minimal",
"partitions": "minimal.csv",
"variant": "nina_w10"
},
"connectivity": [
+8 -9
View File
@@ -302,7 +302,7 @@ env.Append(
FLASH_EXTRA_IMAGES=[
("0x1000", join("$BUILD_DIR", "bootloader.bin")),
("0x8000", join("$BUILD_DIR", "partitions_table.bin"))
("0x8000", join("$BUILD_DIR", "partitions.bin"))
]
)
@@ -339,17 +339,16 @@ else:
# Generate partition table
#
# Export path to the partitions table
fwpartitions_dir = join(FRAMEWORK_DIR, "components", "partition_table")
partitions_csv = env.BoardConfig().get("build.partitions",
"partitions_singleapp.csv")
env.Replace(
PARTITION_TABLE_CSV=join(
FRAMEWORK_DIR, "components", "partition_table",
"%s.csv" % env.BoardConfig().get("build.partitions", "partitions_singleapp")
)
)
PARTITIONS_TABLE_CSV=join(fwpartitions_dir, partitions_csv) if isfile(
join(fwpartitions_dir, partitions_csv)) else partitions_csv)
partition_table = env.Command(
join("$BUILD_DIR", "partitions_table.bin"),
"$PARTITION_TABLE_CSV",
join("$BUILD_DIR", "partitions.bin"),
"$PARTITIONS_TABLE_CSV",
env.VerboseAction('"$PYTHONEXE" "%s" -q $SOURCE $TARGET' % join(
FRAMEWORK_DIR, "components", "partition_table", "gen_esp32part.py"),
"Generating partitions $TARGET"))
+1 -1
View File
@@ -54,7 +54,7 @@ env.AddMethod(VariantDirWrap)
env.Replace(
PLATFORMFW_DIR=env.PioPlatform().get_package_dir("framework-pumbaa"),
UPLOADERFLAGS=[], # Backward compatibility for obsolete build script
UPLOADERFLAGS=[] # Backward compatibility for obsolete build script
)
SConscript(
+11 -11
View File
@@ -51,18 +51,18 @@ env.AddMethod(LookupSources)
env.AddMethod(VariantDirWrap)
env.Replace(
PLATFORMFW_DIR=env.PioPlatform().get_package_dir("framework-simba")
)
env.Append(
UPLOADERFLAGS=[
"0x1000", join("$PLATFORMFW_DIR", "3pp", "esp32",
"bin", "bootloader.bin"),
"0x4000", join("$PLATFORMFW_DIR", "3pp", "esp32",
"bin", "partitions_singleapp.bin"),
"0x10000"
]
PLATFORMFW_DIR=env.PioPlatform().get_package_dir("framework-simba"),
UPLOADERFLAGS=[] # Backward compatibility for obsolete build script
)
SConscript(
[env.subst(join("$PLATFORMFW_DIR", "make", "platformio.sconscript"))])
env.Replace(
FLASH_EXTRA_IMAGES=[
("0x1000", join("$PLATFORMFW_DIR", "3pp", "esp32",
"bin", "bootloader.bin")),
("0x8000", join("$PLATFORMFW_DIR", "3pp", "esp32",
"bin", "partitions_singleapp.bin"))
]
)
+74 -23
View File
@@ -20,6 +20,10 @@ from SCons.Script import (COMMAND_LINE_TARGETS, AlwaysBuild, Builder, Default,
DefaultEnvironment)
#
# Helpers
#
def _get_board_f_flash(env):
frequency = env.subst("$BOARD_F_FLASH")
frequency = str(frequency).replace("L", "")
@@ -34,30 +38,73 @@ def _get_board_flash_mode(env):
return "dout"
return mode
def _parse_size(value):
if value.isdigit():
return int(value)
elif value.startswith("0x"):
return int(value, 16)
elif value[-1] in ("K", "M"):
base = 1024 if value[-1] == "K" else 1024 * 1024
return int(value[:-1]) * base
return value
def _parse_partitions(env):
partitions_csv = env.subst("$PARTITIONS_TABLE_CSV")
if not isfile(partitions_csv):
sys.stderr.write("Could not find the file %s with partitions "
"table.\n" % partitions_csv)
env.Exit(1)
result = []
with open(partitions_csv) as fp:
for line in fp.readlines():
line = line.strip()
if not line or line.startswith("#"):
continue
tokens = [t.strip() for t in line.split(",") if t.strip()]
if len(tokens) < 5:
continue
result.append({
"name": tokens[0],
"type": tokens[1],
"subtype": tokens[2],
"offset": tokens[3],
"size": tokens[4],
"flags": tokens[5] if len(tokens) > 5 else None
})
return result
def _update_max_upload_size(env):
if not env.get("PARTITIONS_TABLE_CSV"):
return
sizes = [
_parse_size(p['size']) for p in _parse_partitions(env)
if p['type'] in ("0", "app")
]
if sizes:
env.BoardConfig().update("upload.maximum_size", max(sizes))
#
# SPIFFS helpers
#
def fetch_spiffs_size(env):
path_to_patition_table = env.get("PARTITION_TABLE_CSV")
if not isfile(path_to_patition_table):
sys.stderr.write("Could not find the file %s with paritions table." %
path_to_patition_table)
env.Exit(1)
with open(path_to_patition_table) as fp:
for l in fp.readlines():
if l.startswith("spiffs"):
spiffs_config = [s.strip() for s in l.split(",")]
env["SPIFFS_START"] = spiffs_config[3]
env["SPIFFS_SIZE"] = spiffs_config[4]
env["SPIFFS_PAGE"] = "0x100"
env["SPIFFS_BLOCK"] = "0x1000"
return
sys.stderr.write("Could not find the spiffs section in the paritions "
"file %s" % path_to_patition_table)
env.Exit(1)
spiffs = None
for p in _parse_partitions(env):
if p['type'] == "data" and p['subtype'] == "spiffs":
spiffs = p
if not spiffs:
sys.stderr.write(
env.subst("Could not find the `spiffs` section in the partitions "
"table $PARTITIONS_TABLE_CSV\n"))
env["SPIFFS_START"] = _parse_size(spiffs['offset'])
env["SPIFFS_SIZE"] = _parse_size(spiffs['size'])
env["SPIFFS_PAGE"] = int("0x100", 16)
env["SPIFFS_BLOCK"] = int("0x1000", 16)
def __fetch_spiffs_size(target, source, env):
@@ -157,9 +204,9 @@ env.Append(
action=env.VerboseAction(" ".join([
'"$MKSPIFFSTOOL"',
"-c", "$SOURCES",
"-p", "${int(SPIFFS_PAGE, 16)}",
"-b", "${int(SPIFFS_BLOCK, 16)}",
"-s", "${int(SPIFFS_SIZE, 16)}",
"-p", "$SPIFFS_PAGE",
"-b", "$SPIFFS_BLOCK",
"-s", "$SPIFFS_SIZE",
"$TARGET"
]), "Building SPIFFS image from '$SOURCES' directory to $TARGET"),
emitter=__fetch_spiffs_size,
@@ -194,6 +241,10 @@ else:
AlwaysBuild(env.Alias("nobuild", target_firm))
target_buildprog = env.Alias("buildprog", target_firm, target_firm)
# update max upload size based on CSV file
if "upload" in COMMAND_LINE_TARGETS:
_update_max_upload_size(env)
#
# Target: Print binary size
#
@@ -263,7 +314,7 @@ if upload_protocol == "esptool":
"write_flash", "-z",
"--flash_mode", "$BOARD_FLASH_MODE",
"--flash_size", "detect",
"${int(SPIFFS_START, 16)}"
"$SPIFFS_START"
],
UPLOADCMD='"$PYTHONEXE" "$UPLOADER" $UPLOADERFLAGS $SOURCE',
)