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 uos
|
|
|
|
import network
|
|
|
|
from flashbdev import bdev
|
|
|
|
|
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
|
|
|
def wifi():
|
|
|
|
import ubinascii
|
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
|
|
|
ap_if = network.WLAN(network.AP_IF)
|
2016-05-03 02:16:42 +03:00
|
|
|
essid = b"MicroPython-%s" % ubinascii.hexlify(ap_if.config("mac")[-3:])
|
2016-04-12 00:46:04 +03:00
|
|
|
ap_if.config(essid=essid, authmode=network.AUTH_WPA_WPA2_PSK, password=b"micropythoN")
|
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
|
|
|
|
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 check_bootsec():
|
|
|
|
buf = bytearray(bdev.SEC_SIZE)
|
|
|
|
bdev.readblocks(0, buf)
|
|
|
|
empty = True
|
|
|
|
for b in buf:
|
2020-02-27 15:36:53 +11:00
|
|
|
if b != 0xFF:
|
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
|
|
|
empty = False
|
|
|
|
break
|
|
|
|
if empty:
|
|
|
|
return True
|
|
|
|
fs_corrupted()
|
|
|
|
|
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
|
|
|
def fs_corrupted():
|
|
|
|
import time
|
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
|
|
|
while 1:
|
2020-02-27 15:36:53 +11:00
|
|
|
print(
|
|
|
|
"""\
|
2017-01-02 18:52:35 +03:00
|
|
|
The FAT filesystem starting at sector %d with size %d sectors appears to
|
|
|
|
be corrupted. If you had important data there, you may want to make a flash
|
|
|
|
snapshot to try to recover it. Otherwise, perform factory reprogramming
|
|
|
|
of MicroPython firmware (completely erase flash, followed by firmware
|
|
|
|
programming).
|
2020-02-27 15:36:53 +11:00
|
|
|
"""
|
|
|
|
% (bdev.START_SEC, bdev.blocks)
|
|
|
|
)
|
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
|
|
|
time.sleep(3)
|
2016-04-29 20:02:59 +03:00
|
|
|
|
2020-02-27 15:36:53 +11:00
|
|
|
|
2016-04-29 20:02:59 +03:00
|
|
|
def setup():
|
|
|
|
check_bootsec()
|
|
|
|
print("Performing initial setup")
|
|
|
|
wifi()
|
|
|
|
uos.VfsFat.mkfs(bdev)
|
2017-01-27 15:16:08 +11:00
|
|
|
vfs = uos.VfsFat(bdev)
|
2020-02-27 15:36:53 +11:00
|
|
|
uos.mount(vfs, "/")
|
2017-01-27 15:16:08 +11:00
|
|
|
with open("boot.py", "w") as f:
|
2020-02-27 15:36:53 +11:00
|
|
|
f.write(
|
|
|
|
"""\
|
2016-04-29 20:11:48 +03:00
|
|
|
# This file is executed on every boot (including wake-boot from deepsleep)
|
2016-08-06 15:27:38 +03:00
|
|
|
#import esp
|
|
|
|
#esp.osdebug(None)
|
2018-05-15 15:13:58 +10:00
|
|
|
import uos, machine
|
2019-01-10 00:53:38 +11:00
|
|
|
#uos.dupterm(None, 1) # disable REPL on UART(0)
|
2016-07-02 19:20:13 +03:00
|
|
|
import gc
|
2016-05-07 20:04:45 +03:00
|
|
|
#import webrepl
|
|
|
|
#webrepl.start()
|
2016-07-02 19:20:13 +03:00
|
|
|
gc.collect()
|
2020-02-27 15:36:53 +11:00
|
|
|
"""
|
|
|
|
)
|
2016-04-29 20:02:59 +03:00
|
|
|
return vfs
|