esp8266: Add Python modules for initial configuration.
Main entry point is _boot.py which checks whether FAT FS in flash mountable,
and if so, mounts it. Otherwise, it checks if flash is empty, and if so,
performs initial module setup: makes FAT FS, configures default AP name,
etc. As a last option, if flash is not empty, and could not be mounted,
it means filesystem corruption, and warning message with instructions is
printed in an infinite loop.
2016-04-12 00:37:04 +03:00
|
|
|
import esp
|
|
|
|
|
|
|
|
class FlashBdev:
|
|
|
|
|
|
|
|
SEC_SIZE = 4096
|
2016-04-18 01:23:04 +03:00
|
|
|
START_SEC = 0x89000 // SEC_SIZE
|
|
|
|
NUM_BLK = 0x73
|
esp8266: Add Python modules for initial configuration.
Main entry point is _boot.py which checks whether FAT FS in flash mountable,
and if so, mounts it. Otherwise, it checks if flash is empty, and if so,
performs initial module setup: makes FAT FS, configures default AP name,
etc. As a last option, if flash is not empty, and could not be mounted,
it means filesystem corruption, and warning message with instructions is
printed in an infinite loop.
2016-04-12 00:37:04 +03:00
|
|
|
|
|
|
|
def __init__(self, blocks=NUM_BLK):
|
|
|
|
self.blocks = blocks
|
|
|
|
|
|
|
|
def readblocks(self, n, buf):
|
2016-04-20 00:35:46 +03:00
|
|
|
#print("readblocks(%s, %x(%d))" % (n, id(buf), len(buf)))
|
esp8266: Add Python modules for initial configuration.
Main entry point is _boot.py which checks whether FAT FS in flash mountable,
and if so, mounts it. Otherwise, it checks if flash is empty, and if so,
performs initial module setup: makes FAT FS, configures default AP name,
etc. As a last option, if flash is not empty, and could not be mounted,
it means filesystem corruption, and warning message with instructions is
printed in an infinite loop.
2016-04-12 00:37:04 +03:00
|
|
|
esp.flash_read((n + self.START_SEC) * self.SEC_SIZE, buf)
|
|
|
|
|
|
|
|
def writeblocks(self, n, buf):
|
2016-04-20 00:35:46 +03:00
|
|
|
#print("writeblocks(%s, %x(%d))" % (n, id(buf), len(buf)))
|
|
|
|
#assert len(buf) <= self.SEC_SIZE, len(buf)
|
esp8266: Add Python modules for initial configuration.
Main entry point is _boot.py which checks whether FAT FS in flash mountable,
and if so, mounts it. Otherwise, it checks if flash is empty, and if so,
performs initial module setup: makes FAT FS, configures default AP name,
etc. As a last option, if flash is not empty, and could not be mounted,
it means filesystem corruption, and warning message with instructions is
printed in an infinite loop.
2016-04-12 00:37:04 +03:00
|
|
|
esp.flash_erase(n + self.START_SEC)
|
|
|
|
esp.flash_write((n + self.START_SEC) * self.SEC_SIZE, buf)
|
|
|
|
|
|
|
|
def ioctl(self, op, arg):
|
2016-04-20 00:35:46 +03:00
|
|
|
#print("ioctl(%d, %r)" % (op, arg))
|
esp8266: Add Python modules for initial configuration.
Main entry point is _boot.py which checks whether FAT FS in flash mountable,
and if so, mounts it. Otherwise, it checks if flash is empty, and if so,
performs initial module setup: makes FAT FS, configures default AP name,
etc. As a last option, if flash is not empty, and could not be mounted,
it means filesystem corruption, and warning message with instructions is
printed in an infinite loop.
2016-04-12 00:37:04 +03:00
|
|
|
if op == 4: # BP_IOCTL_SEC_COUNT
|
|
|
|
return self.blocks
|
|
|
|
if op == 5: # BP_IOCTL_SEC_SIZE
|
|
|
|
return self.SEC_SIZE
|
|
|
|
|
2016-04-20 13:48:33 +03:00
|
|
|
def set_bl_flash_size(real_size):
|
|
|
|
if real_size == 256*1024:
|
|
|
|
code = 1
|
|
|
|
elif real_size == 512*1024:
|
|
|
|
code = 0
|
|
|
|
elif real_size == 1024*1024:
|
|
|
|
code = 2
|
|
|
|
elif real_size == 2048*1024:
|
|
|
|
code = 3
|
|
|
|
elif real_size == 4096*1024:
|
|
|
|
code = 4
|
|
|
|
else:
|
|
|
|
code = 2
|
|
|
|
buf = bytearray(4096)
|
|
|
|
esp.flash_read(0, buf)
|
|
|
|
buf[3] = (buf[3] & 0xf) | (code << 4)
|
|
|
|
esp.flash_erase(0)
|
|
|
|
esp.flash_write(0, buf)
|
|
|
|
|
|
|
|
# If bootloader size ID doesn't correspond to real Flash size,
|
|
|
|
# fix bootloader value and reboot.
|
|
|
|
size = esp.flash_id() >> 16
|
|
|
|
# Check that it looks like realistic power of 2 for flash sizes
|
|
|
|
# commonly used with esp8266
|
|
|
|
if 22 >= size >= 18:
|
|
|
|
size = 1 << size
|
|
|
|
if size != esp.flash_size():
|
|
|
|
import machine
|
|
|
|
import time
|
|
|
|
print("Bootloader Flash size appear to have been set incorrectly, trying to fix")
|
|
|
|
set_bl_flash_size(size)
|
|
|
|
machine.reset()
|
|
|
|
while 1: time.sleep(1)
|
|
|
|
|
2016-04-26 01:36:32 +03:00
|
|
|
size = esp.flash_size()
|
|
|
|
if size < 1024*1024:
|
2016-04-18 17:14:00 +03:00
|
|
|
bdev = None
|
|
|
|
else:
|
2016-04-26 01:36:32 +03:00
|
|
|
# 16K at the flash end is reserved for SDK params storage
|
|
|
|
bdev = FlashBdev((size - 16384) // FlashBdev.SEC_SIZE - FlashBdev.START_SEC)
|