summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorAndrew Leech <andrew.leech@planetinnovation.com.au>2018-12-03 07:44:42 +1100
committerDamien George <damien.p.george@gmail.com>2018-12-22 01:30:47 +1100
commitce0c58117913f805db99767b22ecb7255b8686a1 (patch)
treef58b1070aa4fe3c78cdff0a26a50e3d9d6aba921
parent5ed578e5b48730606536ded9a711223ae9a70262 (diff)
stm32/main: Add board config option to enable/disable mounting SD card.
The new option MICROPY_HW_SDCARD_MOUNT_AT_BOOT can now be defined to 0 in mpconfigboard.h to allow SD hardware to be enabled but not auto-mounted at boot. This feature is enabled by default to retain previous behaviour. Previously, if an SD card is enabled in hardware it is also used to boot from. While this can be disabled with a SKIPSD file on internal flash, this wont be available at first boot or if the internal flash gets corrupted.
-rw-r--r--ports/stm32/main.c4
-rw-r--r--ports/stm32/mpconfigboard_common.h5
2 files changed, 7 insertions, 2 deletions
diff --git a/ports/stm32/main.c b/ports/stm32/main.c
index 62cba5434..42bebf079 100644
--- a/ports/stm32/main.c
+++ b/ports/stm32/main.c
@@ -268,7 +268,7 @@ MP_NOINLINE STATIC bool init_flash_fs(uint reset_mode) {
}
#endif
-#if MICROPY_HW_HAS_SDCARD
+#if MICROPY_HW_SDCARD_MOUNT_AT_BOOT
STATIC bool init_sdcard_fs(void) {
bool first_part = true;
for (int part_num = 1; part_num <= 4; ++part_num) {
@@ -620,7 +620,7 @@ soft_reset:
#endif
bool mounted_sdcard = false;
- #if MICROPY_HW_HAS_SDCARD
+ #if MICROPY_HW_SDCARD_MOUNT_AT_BOOT
// if an SD card is present then mount it on /sd/
if (sdcard_is_present()) {
// if there is a file in the flash called "SKIPSD", then we don't mount the SD card
diff --git a/ports/stm32/mpconfigboard_common.h b/ports/stm32/mpconfigboard_common.h
index 2acdcc2f7..d4e7c2014 100644
--- a/ports/stm32/mpconfigboard_common.h
+++ b/ports/stm32/mpconfigboard_common.h
@@ -97,6 +97,11 @@
#define MICROPY_HW_HAS_SDCARD (0)
#endif
+// Whether to automatically mount (and boot from) the SD card if it's present
+#ifndef MICROPY_HW_SDCARD_MOUNT_AT_BOOT
+#define MICROPY_HW_SDCARD_MOUNT_AT_BOOT (MICROPY_HW_HAS_SDCARD)
+#endif
+
// Whether to enable the MMA7660 driver, exposed as pyb.Accel
#ifndef MICROPY_HW_HAS_MMA7660
#define MICROPY_HW_HAS_MMA7660 (0)