cc3200: Unmount all user file systems after a soft reset.
This commit is contained in:
parent
65971f5160
commit
e4404fbef0
|
@ -62,6 +62,14 @@
|
||||||
STATIC uint32_t os_num_mounted_devices;
|
STATIC uint32_t os_num_mounted_devices;
|
||||||
STATIC os_term_dup_obj_t os_term_dup_obj;
|
STATIC os_term_dup_obj_t os_term_dup_obj;
|
||||||
|
|
||||||
|
/******************************************************************************
|
||||||
|
DECLARE PRIVATE FUNCTIONS
|
||||||
|
******************************************************************************/
|
||||||
|
STATIC void unmount (os_fs_mount_t *mount_obj);
|
||||||
|
STATIC bool path_equal(const char *path, const char *path_canonical);
|
||||||
|
STATIC void append_dir_item (mp_obj_t dirlist, const char *item, bool string);
|
||||||
|
STATIC void mount (mp_obj_t device, const char *path, uint pathlen, bool readonly);
|
||||||
|
|
||||||
/******************************************************************************
|
/******************************************************************************
|
||||||
DEFINE PUBLIC FUNCTIONS
|
DEFINE PUBLIC FUNCTIONS
|
||||||
******************************************************************************/
|
******************************************************************************/
|
||||||
|
@ -102,6 +110,13 @@ os_fs_mount_t *osmount_find_by_device (mp_obj_t device) {
|
||||||
return NULL;
|
return NULL;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void osmount_unmount_all (void) {
|
||||||
|
for (mp_uint_t i = 0; i < MP_STATE_PORT(mount_obj_list).len; i++) {
|
||||||
|
os_fs_mount_t *mount_obj = ((os_fs_mount_t *)(MP_STATE_PORT(mount_obj_list).items[i]));
|
||||||
|
unmount(mount_obj);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
/******************************************************************************
|
/******************************************************************************
|
||||||
DEFINE PRIVATE FUNCTIONS
|
DEFINE PRIVATE FUNCTIONS
|
||||||
******************************************************************************/
|
******************************************************************************/
|
||||||
|
@ -188,19 +203,11 @@ STATIC void mount (mp_obj_t device, const char *path, uint pathlen, bool readonl
|
||||||
os_num_mounted_devices++;
|
os_num_mounted_devices++;
|
||||||
}
|
}
|
||||||
|
|
||||||
STATIC void unmount (const char *path) {
|
STATIC void unmount (os_fs_mount_t *mount_obj) {
|
||||||
if (FR_OK != f_mount (NULL, path, 1)) {
|
// remove it from the list and then call FatFs
|
||||||
nlr_raise(mp_obj_new_exception_msg(&mp_type_OSError, mpexception_os_operation_failed));
|
f_mount (NULL, mount_obj->path, 1);
|
||||||
}
|
|
||||||
|
|
||||||
// remove from the list after the actual unmount
|
|
||||||
os_fs_mount_t *mount_obj;
|
|
||||||
if ((mount_obj = osmount_find_by_path(path))) {
|
|
||||||
mp_obj_list_remove(&MP_STATE_PORT(mount_obj_list), mount_obj);
|
mp_obj_list_remove(&MP_STATE_PORT(mount_obj_list), mount_obj);
|
||||||
os_num_mounted_devices--;
|
os_num_mounted_devices--;
|
||||||
} else {
|
|
||||||
nlr_raise(mp_obj_new_exception_msg(&mp_type_ValueError, mpexception_value_invalid_arguments));
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/******************************************************************************/
|
/******************************************************************************/
|
||||||
|
@ -487,7 +494,12 @@ STATIC mp_obj_t os_unmount(mp_obj_t path_o) {
|
||||||
}
|
}
|
||||||
|
|
||||||
// now unmount it
|
// now unmount it
|
||||||
unmount (path);
|
os_fs_mount_t *mount_obj;
|
||||||
|
if ((mount_obj = osmount_find_by_path(path))) {
|
||||||
|
unmount (mount_obj);
|
||||||
|
} else {
|
||||||
|
nlr_raise(mp_obj_new_exception_msg(&mp_type_ValueError, mpexception_value_invalid_arguments));
|
||||||
|
}
|
||||||
|
|
||||||
return mp_const_none;
|
return mp_const_none;
|
||||||
}
|
}
|
||||||
|
@ -495,6 +507,7 @@ STATIC MP_DEFINE_CONST_FUN_OBJ_1(os_unmount_obj, os_unmount);
|
||||||
|
|
||||||
STATIC mp_obj_t os_mkfs(mp_obj_t device) {
|
STATIC mp_obj_t os_mkfs(mp_obj_t device) {
|
||||||
const char *path = "/__mkfs__mnt__";
|
const char *path = "/__mkfs__mnt__";
|
||||||
|
os_fs_mount_t *mount_obj = NULL;
|
||||||
bool unmt = false;
|
bool unmt = false;
|
||||||
FRESULT res;
|
FRESULT res;
|
||||||
|
|
||||||
|
@ -505,29 +518,26 @@ STATIC mp_obj_t os_mkfs(mp_obj_t device) {
|
||||||
nlr_raise(mp_obj_new_exception_msg(&mp_type_OSError, mpexception_value_invalid_arguments));
|
nlr_raise(mp_obj_new_exception_msg(&mp_type_OSError, mpexception_value_invalid_arguments));
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
// mount it and unmount it briefly
|
// mount it briefly
|
||||||
unmt = true;
|
|
||||||
mount(device, path, strlen(path), false);
|
mount(device, path, strlen(path), false);
|
||||||
|
unmt = true;
|
||||||
}
|
}
|
||||||
|
|
||||||
byte sfd = 0;
|
byte sfd = 0;
|
||||||
if (!memcmp(path, "/flash", strlen("/flash"))) {
|
if (!memcmp(path, "/flash", strlen("/flash"))) {
|
||||||
sfd = 1;
|
sfd = 1;
|
||||||
} else {
|
} else if ((mount_obj = osmount_find_by_path(path))) {
|
||||||
os_fs_mount_t *mount_obj;
|
|
||||||
if ((mount_obj = osmount_find_by_path(path))) {
|
|
||||||
if (mount_obj->device != (mp_obj_t)&pybsd_obj &&
|
if (mount_obj->device != (mp_obj_t)&pybsd_obj &&
|
||||||
mp_obj_get_int(mp_call_method_n_kw(0, 0, mount_obj->count)) < 2048) {
|
mp_obj_get_int(mp_call_method_n_kw(0, 0, mount_obj->count)) < 2048) {
|
||||||
sfd = 1;
|
sfd = 1;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
|
||||||
|
|
||||||
// now format the device
|
// now format the device
|
||||||
res = f_mkfs(path, sfd, 0);
|
res = f_mkfs(path, sfd, 0);
|
||||||
|
|
||||||
if (unmt) {
|
if (unmt && mount_obj) {
|
||||||
unmount (path);
|
unmount (mount_obj);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (res != FR_OK) {
|
if (res != FR_OK) {
|
||||||
|
|
|
@ -57,5 +57,6 @@ typedef struct _os_term_dup_obj_t {
|
||||||
void moduos_init0 (void);
|
void moduos_init0 (void);
|
||||||
os_fs_mount_t *osmount_find_by_path (const char *path);
|
os_fs_mount_t *osmount_find_by_path (const char *path);
|
||||||
os_fs_mount_t *osmount_find_by_volume (uint8_t vol);
|
os_fs_mount_t *osmount_find_by_volume (uint8_t vol);
|
||||||
|
void osmount_unmount_all (void);
|
||||||
|
|
||||||
#endif // MODUOS_H_
|
#endif // MODUOS_H_
|
||||||
|
|
|
@ -235,6 +235,9 @@ soft_reset_exit:
|
||||||
// clean-up the user socket space
|
// clean-up the user socket space
|
||||||
modusocket_close_all_user_sockets();
|
modusocket_close_all_user_sockets();
|
||||||
|
|
||||||
|
// unmount all user file systems
|
||||||
|
osmount_unmount_all();
|
||||||
|
|
||||||
// wait for pending transactions to complete
|
// wait for pending transactions to complete
|
||||||
mp_hal_delay_ms(20);
|
mp_hal_delay_ms(20);
|
||||||
|
|
||||||
|
|
|
@ -124,6 +124,16 @@ try:
|
||||||
except:
|
except:
|
||||||
print('Exception')
|
print('Exception')
|
||||||
|
|
||||||
|
try:
|
||||||
|
os.unmount('/something')
|
||||||
|
except:
|
||||||
|
print('Exception')
|
||||||
|
|
||||||
|
try:
|
||||||
|
os.unmount('something')
|
||||||
|
except:
|
||||||
|
print('Exception')
|
||||||
|
|
||||||
try:
|
try:
|
||||||
os.mkfs('flash') # incorrect path format
|
os.mkfs('flash') # incorrect path format
|
||||||
except:
|
except:
|
||||||
|
|
|
@ -27,4 +27,6 @@ Exception
|
||||||
Exception
|
Exception
|
||||||
Exception
|
Exception
|
||||||
Exception
|
Exception
|
||||||
|
Exception
|
||||||
|
Exception
|
||||||
['flash', 'sd']
|
['flash', 'sd']
|
||||||
|
|
Loading…
Reference in New Issue