cc3200: Unmount all user file systems after a soft reset.

This commit is contained in:
danicampora 2015-11-16 20:37:58 +01:00
parent 65971f5160
commit e4404fbef0
5 changed files with 51 additions and 25 deletions

View File

@ -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);
} mp_obj_list_remove(&MP_STATE_PORT(mount_obj_list), mount_obj);
os_num_mounted_devices--;
// 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);
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->device != (mp_obj_t)&pybsd_obj &&
if ((mount_obj = osmount_find_by_path(path))) { mp_obj_get_int(mp_call_method_n_kw(0, 0, mount_obj->count)) < 2048) {
if (mount_obj->device != (mp_obj_t)&pybsd_obj && sfd = 1;
mp_obj_get_int(mp_call_method_n_kw(0, 0, mount_obj->count)) < 2048) {
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) {

View File

@ -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_

View File

@ -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);

View File

@ -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:

View File

@ -27,4 +27,6 @@ Exception
Exception Exception
Exception Exception
Exception Exception
Exception
Exception
['flash', 'sd'] ['flash', 'sd']