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
|
|
|
|
|
2020-02-27 15:36:53 +11:00
|
|
|
|
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
|
|
|
class FlashBdev:
|
|
|
|
|
|
|
|
SEC_SIZE = 4096
|
2017-05-12 16:08:54 +03:00
|
|
|
RESERVED_SECS = 1
|
2017-01-04 23:47:09 +11:00
|
|
|
START_SEC = esp.flash_user_start() // SEC_SIZE + RESERVED_SECS
|
2020-02-27 15:36:53 +11:00
|
|
|
NUM_BLK = 0x6B - RESERVED_SECS
|
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
|
|
|
|
|
2019-11-07 18:43:37 +11:00
|
|
|
def readblocks(self, n, buf, off=0):
|
2020-02-27 15:36:53 +11:00
|
|
|
# print("readblocks(%s, %x(%d), %d)" % (n, id(buf), len(buf), off))
|
2019-11-07 18:43:37 +11:00
|
|
|
esp.flash_read((n + self.START_SEC) * self.SEC_SIZE + off, 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
|
|
|
|
2019-11-07 18:43:37 +11:00
|
|
|
def writeblocks(self, n, buf, off=None):
|
2020-02-27 15:36:53 +11:00
|
|
|
# print("writeblocks(%s, %x(%d), %d)" % (n, id(buf), len(buf), off))
|
|
|
|
# assert len(buf) <= self.SEC_SIZE, len(buf)
|
2019-11-07 18:43:37 +11:00
|
|
|
if off is None:
|
|
|
|
esp.flash_erase(n + self.START_SEC)
|
|
|
|
off = 0
|
|
|
|
esp.flash_write((n + self.START_SEC) * self.SEC_SIZE + off, 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
|
|
|
|
|
|
|
def ioctl(self, op, arg):
|
2020-02-27 15:36:53 +11:00
|
|
|
# print("ioctl(%d, %r)" % (op, arg))
|
2019-10-29 12:25:30 +11:00
|
|
|
if op == 4: # MP_BLOCKDEV_IOCTL_BLOCK_COUNT
|
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
|
|
|
return self.blocks
|
2019-10-29 12:25:30 +11:00
|
|
|
if op == 5: # MP_BLOCKDEV_IOCTL_BLOCK_SIZE
|
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
|
|
|
return self.SEC_SIZE
|
2019-11-07 18:43:37 +11:00
|
|
|
if op == 6: # MP_BLOCKDEV_IOCTL_BLOCK_ERASE
|
|
|
|
esp.flash_erase(arg + self.START_SEC)
|
|
|
|
return 0
|
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
|
|
|
|
2020-02-27 15:36:53 +11:00
|
|
|
|
2016-04-26 01:36:32 +03:00
|
|
|
size = esp.flash_size()
|
2020-02-27 15:36:53 +11:00
|
|
|
if size < 1024 * 1024:
|
2016-04-18 17:14:00 +03:00
|
|
|
bdev = None
|
|
|
|
else:
|
2016-08-06 15:21:49 +03:00
|
|
|
# 20K at the flash end is reserved for SDK params storage
|
|
|
|
bdev = FlashBdev((size - 20480) // FlashBdev.SEC_SIZE - FlashBdev.START_SEC)
|