cc3200: Enable long filename support in FatFS.
This has implications all over the place. I have to admit that you can instantly see that usability improves, but it costs 3K. At the same time I took the oportunity to rename the '/SFLASH' drive to '/flash' which improves compatibility with the pyboard.
This commit is contained in:
parent
d35ac956d1
commit
6e25d955f4
@ -83,7 +83,7 @@
|
|||||||
#define configUSE_TICK_HOOK 1
|
#define configUSE_TICK_HOOK 1
|
||||||
#define configCPU_CLOCK_HZ ( ( unsigned long ) 80000000 )
|
#define configCPU_CLOCK_HZ ( ( unsigned long ) 80000000 )
|
||||||
#define configTICK_RATE_HZ ( ( TickType_t ) 1000 )
|
#define configTICK_RATE_HZ ( ( TickType_t ) 1000 )
|
||||||
#define configMINIMAL_STACK_SIZE ( ( unsigned short ) 72 )
|
#define configMINIMAL_STACK_SIZE ( ( unsigned short ) 64 )
|
||||||
#define configTOTAL_HEAP_SIZE ( ( size_t ) ( 16384 ) )
|
#define configTOTAL_HEAP_SIZE ( ( size_t ) ( 16384 ) )
|
||||||
#define configMAX_TASK_NAME_LEN ( 8 )
|
#define configMAX_TASK_NAME_LEN ( 8 )
|
||||||
#define configUSE_TRACE_FACILITY 0
|
#define configUSE_TRACE_FACILITY 0
|
||||||
|
@ -139,8 +139,9 @@ APP_MAIN_SRC_C = \
|
|||||||
serverstask.c
|
serverstask.c
|
||||||
|
|
||||||
APP_LIB_SRC_C = $(addprefix lib/,\
|
APP_LIB_SRC_C = $(addprefix lib/,\
|
||||||
libc/string0.c \
|
|
||||||
fatfs/ff.c \
|
fatfs/ff.c \
|
||||||
|
fatfs/option/ccsbcs.c \
|
||||||
|
libc/string0.c \
|
||||||
mp-readline/readline.c \
|
mp-readline/readline.c \
|
||||||
)
|
)
|
||||||
|
|
||||||
@ -206,7 +207,7 @@ endif
|
|||||||
SHELL = bash
|
SHELL = bash
|
||||||
APP_SIGN = appsign.sh
|
APP_SIGN = appsign.sh
|
||||||
|
|
||||||
all: $(BUILD)/MCUIMG.BIN
|
all: $(BUILD)/mcuimg.bin
|
||||||
|
|
||||||
$(BUILD)/application.axf: $(OBJ) $(LINKER_SCRIPT)
|
$(BUILD)/application.axf: $(OBJ) $(LINKER_SCRIPT)
|
||||||
$(ECHO) "LINK $@"
|
$(ECHO) "LINK $@"
|
||||||
@ -217,7 +218,7 @@ $(BUILD)/application.bin: $(BUILD)/application.axf
|
|||||||
$(ECHO) "Create $@"
|
$(ECHO) "Create $@"
|
||||||
$(Q)$(OBJCOPY) -O binary $< $@
|
$(Q)$(OBJCOPY) -O binary $< $@
|
||||||
|
|
||||||
$(BUILD)/MCUIMG.BIN: $(BUILD)/application.bin
|
$(BUILD)/mcuimg.bin: $(BUILD)/application.bin
|
||||||
$(ECHO) "Create $@"
|
$(ECHO) "Create $@"
|
||||||
$(Q)$(SHELL) $(APP_SIGN) $(BOARD) $(BTYPE)
|
$(Q)$(SHELL) $(APP_SIGN) $(BOARD) $(BTYPE)
|
||||||
|
|
||||||
|
@ -16,13 +16,13 @@ BUILD=build/${BOARD}/${BTYPE}
|
|||||||
echo -n `md5sum --binary $BUILD/application.bin | awk '{ print $1 }'` > __md5hash.bin
|
echo -n `md5sum --binary $BUILD/application.bin | awk '{ print $1 }'` > __md5hash.bin
|
||||||
|
|
||||||
# Concatenate it with the application binary
|
# Concatenate it with the application binary
|
||||||
cat $BUILD/application.bin __md5hash.bin > $BUILD/MCUIMG.BIN
|
cat $BUILD/application.bin __md5hash.bin > $BUILD/mcuimg.bin
|
||||||
RET=$?
|
RET=$?
|
||||||
|
|
||||||
# Remove the tmp files
|
# Remove the tmp files
|
||||||
rm -f __md5hash.bin
|
rm -f __md5hash.bin
|
||||||
|
|
||||||
# Remove hte unsigned binary
|
# Remove the unsigned binary
|
||||||
rm -f $BUILD/application.bin
|
rm -f $BUILD/application.bin
|
||||||
|
|
||||||
exit $RET
|
exit $RET
|
||||||
|
@ -38,7 +38,6 @@ extern BYTE ff_CurrVol;
|
|||||||
#endif
|
#endif
|
||||||
|
|
||||||
STATIC bool check_path(const TCHAR **path, const char *mount_point_str, mp_uint_t mount_point_len) {
|
STATIC bool check_path(const TCHAR **path, const char *mount_point_str, mp_uint_t mount_point_len) {
|
||||||
stoupper ((char *)(*path));
|
|
||||||
if (strncmp(*path, mount_point_str, mount_point_len) == 0) {
|
if (strncmp(*path, mount_point_str, mount_point_len) == 0) {
|
||||||
if ((*path)[mount_point_len] == '/') {
|
if ((*path)[mount_point_len] == '/') {
|
||||||
*path += mount_point_len;
|
*path += mount_point_len;
|
||||||
@ -66,11 +65,11 @@ int ff_get_ldnumber (const TCHAR **path) {
|
|||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
|
|
||||||
if (check_path(path, "/SFLASH", 7)) {
|
if (check_path(path, "/flash", 6)) {
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
#if MICROPY_HW_HAS_SDCARD
|
#if MICROPY_HW_HAS_SDCARD
|
||||||
else if (check_path(path, "/SD", 3)) {
|
else if (check_path(path, "/sd", 3)) {
|
||||||
return 1;
|
return 1;
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
@ -84,13 +83,13 @@ void ff_get_volname(BYTE vol, TCHAR **dest) {
|
|||||||
if (vol == 0)
|
if (vol == 0)
|
||||||
#endif
|
#endif
|
||||||
{
|
{
|
||||||
memcpy(*dest, "/SFLASH", 7);
|
memcpy(*dest, "/flash", 6);
|
||||||
*dest += 7;
|
*dest += 7;
|
||||||
}
|
}
|
||||||
#if MICROPY_HW_HAS_SDCARD
|
#if MICROPY_HW_HAS_SDCARD
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
memcpy(*dest, "/SD", 3);
|
memcpy(*dest, "/sd", 3);
|
||||||
*dest += 3;
|
*dest += 3;
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
@ -3,8 +3,6 @@
|
|||||||
/* (C)ChaN, 2014 */
|
/* (C)ChaN, 2014 */
|
||||||
/*------------------------------------------------------------------------*/
|
/*------------------------------------------------------------------------*/
|
||||||
|
|
||||||
#include "py/mpconfig.h"
|
|
||||||
#include MICROPY_HAL_H
|
|
||||||
#include "ff.h"
|
#include "ff.h"
|
||||||
|
|
||||||
|
|
||||||
@ -134,7 +132,7 @@ void* ff_memalloc ( /* Returns pointer to the allocated memory block */
|
|||||||
UINT msize /* Number of bytes to allocate */
|
UINT msize /* Number of bytes to allocate */
|
||||||
)
|
)
|
||||||
{
|
{
|
||||||
return malloc(msize); /* Allocate a new memory block with POSIX API */
|
return pvPortMalloc(msize); /* Allocate a new memory block with POSIX API */
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
@ -146,7 +144,7 @@ void ff_memfree (
|
|||||||
void* mblock /* Pointer to the memory block to free */
|
void* mblock /* Pointer to the memory block to free */
|
||||||
)
|
)
|
||||||
{
|
{
|
||||||
free(mblock); /* Discard the memory block with POSIX API */
|
vPortFree(mblock); /* Discard the memory block with POSIX API */
|
||||||
}
|
}
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
@ -301,19 +301,21 @@ void ftp_run (void) {
|
|||||||
if (SOCKETFIFO_IsEmpty()) {
|
if (SOCKETFIFO_IsEmpty()) {
|
||||||
uint32_t readsize;
|
uint32_t readsize;
|
||||||
ftp_result_t result;
|
ftp_result_t result;
|
||||||
result = ftp_read_file ((char *)ftp_data.dBuffer, FTP_BUFFER_SIZE, &readsize);
|
|
||||||
if (readsize > 0 && result != E_FTP_RESULT_FAILED) {
|
|
||||||
ftp_send_data(readsize);
|
|
||||||
ftp_data.ctimeout = 0;
|
ftp_data.ctimeout = 0;
|
||||||
|
result = ftp_read_file ((char *)ftp_data.dBuffer, FTP_BUFFER_SIZE, &readsize);
|
||||||
|
if (result == E_FTP_RESULT_FAILED) {
|
||||||
|
ftp_send_reply(451, NULL);
|
||||||
|
ftp_data.state = E_FTP_STE_END_TRANSFER;
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
if (readsize > 0) {
|
||||||
|
ftp_send_data(readsize);
|
||||||
|
}
|
||||||
if (result == E_FTP_RESULT_OK) {
|
if (result == E_FTP_RESULT_OK) {
|
||||||
ftp_send_reply(226, NULL);
|
ftp_send_reply(226, NULL);
|
||||||
ftp_data.state = E_FTP_STE_END_TRANSFER;
|
ftp_data.state = E_FTP_STE_END_TRANSFER;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
else {
|
|
||||||
ftp_send_reply(451, NULL);
|
|
||||||
ftp_data.state = E_FTP_STE_END_TRANSFER;
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
case E_FTP_STE_CONTINUE_FILE_RX:
|
case E_FTP_STE_CONTINUE_FILE_RX:
|
||||||
@ -588,8 +590,12 @@ static void ftp_process_cmd (void) {
|
|||||||
char *bufptr = (char *)ftp_cmd_buffer;
|
char *bufptr = (char *)ftp_cmd_buffer;
|
||||||
ftp_result_t result;
|
ftp_result_t result;
|
||||||
uint32_t listsize;
|
uint32_t listsize;
|
||||||
FILINFO fno;
|
|
||||||
FRESULT fres;
|
FRESULT fres;
|
||||||
|
FILINFO fno;
|
||||||
|
#if _USE_LFN
|
||||||
|
fno.lfname = NULL;
|
||||||
|
fno.lfsize = 0;
|
||||||
|
#endif
|
||||||
|
|
||||||
ftp_data.closechild = false;
|
ftp_data.closechild = false;
|
||||||
// also use the reply buffer to receive new commands
|
// also use the reply buffer to receive new commands
|
||||||
@ -887,12 +893,20 @@ static int ftp_print_eplf_item (char *dest, uint32_t destsize, FILINFO *fno) {
|
|||||||
if (FTP_UNIX_SECONDS_180_DAYS < tseconds - fseconds) {
|
if (FTP_UNIX_SECONDS_180_DAYS < tseconds - fseconds) {
|
||||||
return snprintf(dest, destsize, "%srw-rw-r-- 1 root root %9u %s %2u %5u %s\r\n",
|
return snprintf(dest, destsize, "%srw-rw-r-- 1 root root %9u %s %2u %5u %s\r\n",
|
||||||
type, (_u32)fno->fsize, ftp_month[mindex].month, day,
|
type, (_u32)fno->fsize, ftp_month[mindex].month, day,
|
||||||
|
#if _USE_LFN
|
||||||
|
1980 + ((fno->fdate >> 9) & 0x7f), *fno->lfname ? fno->lfname : fno->fname);
|
||||||
|
#else
|
||||||
1980 + ((fno->fdate >> 9) & 0x7f), fno->fname);
|
1980 + ((fno->fdate >> 9) & 0x7f), fno->fname);
|
||||||
|
#endif
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
return snprintf(dest, destsize, "%srw-rw-r-- 1 root root %9u %s %2u %02u:%02u %s\r\n",
|
return snprintf(dest, destsize, "%srw-rw-r-- 1 root root %9u %s %2u %02u:%02u %s\r\n",
|
||||||
type, (_u32)fno->fsize, ftp_month[mindex].month, day,
|
type, (_u32)fno->fsize, ftp_month[mindex].month, day,
|
||||||
|
#if _USE_LFN
|
||||||
|
(fno->ftime >> 11) & 0x1f, (fno->ftime >> 5) & 0x3f, *fno->lfname ? fno->lfname : fno->fname);
|
||||||
|
#else
|
||||||
(fno->ftime >> 11) & 0x1f, (fno->ftime >> 5) & 0x3f, fno->fname);
|
(fno->ftime >> 11) & 0x1f, (fno->ftime >> 5) & 0x3f, fno->fname);
|
||||||
|
#endif
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -956,10 +970,10 @@ static ftp_result_t ftp_open_dir_for_listing (const char *path, char *list, uint
|
|||||||
uint next = 0;
|
uint next = 0;
|
||||||
// "hack" to list root directory
|
// "hack" to list root directory
|
||||||
if (path[0] == '/' && path[1] == '\0') {
|
if (path[0] == '/' && path[1] == '\0') {
|
||||||
next += ftp_print_eplf_drive((list + next), (maxlistsize - next), "SFLASH");
|
next += ftp_print_eplf_drive((list + next), (maxlistsize - next), "flash");
|
||||||
#if MICROPY_HW_HAS_SDCARD
|
#if MICROPY_HW_HAS_SDCARD
|
||||||
if (sd_disk_ready()) {
|
if (sd_disk_ready()) {
|
||||||
next += ftp_print_eplf_drive((list + next), (maxlistsize - next), "SD");
|
next += ftp_print_eplf_drive((list + next), (maxlistsize - next), "sd");
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
*listsize = next;
|
*listsize = next;
|
||||||
@ -979,11 +993,18 @@ static ftp_result_t ftp_list_dir (char *list, uint32_t maxlistsize, uint32_t *li
|
|||||||
uint next = 0;
|
uint next = 0;
|
||||||
uint count = 0;
|
uint count = 0;
|
||||||
FRESULT res;
|
FRESULT res;
|
||||||
FILINFO fno;
|
|
||||||
ftp_result_t result = E_FTP_RESULT_CONTINUE;
|
ftp_result_t result = E_FTP_RESULT_CONTINUE;
|
||||||
|
FILINFO fno;
|
||||||
|
#if _USE_LFN
|
||||||
|
fno.lfname = mem_Malloc(_MAX_LFN);
|
||||||
|
fno.lfsize = _MAX_LFN;
|
||||||
|
|
||||||
/* read up to 4 directory items */
|
// read up to 2 directory items
|
||||||
while (count++ < 4) {
|
while (count < 2) {
|
||||||
|
#else
|
||||||
|
// read up to 4 directory items
|
||||||
|
while (count < 4) {
|
||||||
|
#endif
|
||||||
res = f_readdir(&ftp_data.dp, &fno); /* Read a directory item */
|
res = f_readdir(&ftp_data.dp, &fno); /* Read a directory item */
|
||||||
if (res != FR_OK || fno.fname[0] == 0) {
|
if (res != FR_OK || fno.fname[0] == 0) {
|
||||||
result = E_FTP_RESULT_OK;
|
result = E_FTP_RESULT_OK;
|
||||||
@ -992,13 +1013,17 @@ static ftp_result_t ftp_list_dir (char *list, uint32_t maxlistsize, uint32_t *li
|
|||||||
if (fno.fname[0] == '.' && fno.fname[1] == 0) continue; /* Ignore . entry */
|
if (fno.fname[0] == '.' && fno.fname[1] == 0) continue; /* Ignore . entry */
|
||||||
if (fno.fname[0] == '.' && fno.fname[1] == '.' && fno.fname[2] == 0) continue; /* Ignore .. entry */
|
if (fno.fname[0] == '.' && fno.fname[1] == '.' && fno.fname[2] == 0) continue; /* Ignore .. entry */
|
||||||
|
|
||||||
// Add the entry to the list
|
// add the entry to the list
|
||||||
next += ftp_print_eplf_item((list + next), (maxlistsize - next), &fno);
|
next += ftp_print_eplf_item((list + next), (maxlistsize - next), &fno);
|
||||||
|
count++;
|
||||||
}
|
}
|
||||||
if (result == E_FTP_RESULT_OK) {
|
if (result == E_FTP_RESULT_OK) {
|
||||||
ftp_close_files();
|
ftp_close_files();
|
||||||
}
|
}
|
||||||
*listsize = next;
|
*listsize = next;
|
||||||
|
#if _USE_LFN
|
||||||
|
mem_Free(fno.lfname);
|
||||||
|
#endif
|
||||||
return result;
|
return result;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -14,9 +14,9 @@
|
|||||||
/******************************************************************************
|
/******************************************************************************
|
||||||
DEFINE PRIVATE CONSTANTS
|
DEFINE PRIVATE CONSTANTS
|
||||||
******************************************************************************/
|
******************************************************************************/
|
||||||
#define UPDATER_IMG_PATH "/SFLASH/SYS/MCUIMG.BIN"
|
#define UPDATER_IMG_PATH "/flash/sys/mcuimg.bin"
|
||||||
#define UPDATER_SRVPACK_PATH "/SFLASH/SYS/SRVPCK.UCF"
|
#define UPDATER_SRVPACK_PATH "/flash/sys/servicepack.ucf"
|
||||||
#define UPDATER_SIGN_PATH "/SFLASH/SYS/SRVPCK.SIG"
|
#define UPDATER_SIGN_PATH "/flash/sys/servicepack.sig"
|
||||||
|
|
||||||
/******************************************************************************
|
/******************************************************************************
|
||||||
DEFINE TYPES
|
DEFINE TYPES
|
||||||
@ -37,8 +37,6 @@ static updater_data_t updater_data;
|
|||||||
DEFINE PUBLIC FUNCTIONS
|
DEFINE PUBLIC FUNCTIONS
|
||||||
******************************************************************************/
|
******************************************************************************/
|
||||||
bool updater_check_path (void *path) {
|
bool updater_check_path (void *path) {
|
||||||
// conert the path supplied to upper case
|
|
||||||
stoupper (path);
|
|
||||||
if (!strcmp(UPDATER_IMG_PATH, path)) {
|
if (!strcmp(UPDATER_IMG_PATH, path)) {
|
||||||
updater_data.path = IMG_UPDATE;
|
updater_data.path = IMG_UPDATE;
|
||||||
updater_data.fsize = IMG_SIZE;
|
updater_data.fsize = IMG_SIZE;
|
||||||
|
@ -49,11 +49,11 @@
|
|||||||
/// The filesystem has `/` as the root directory, and the available physical
|
/// The filesystem has `/` as the root directory, and the available physical
|
||||||
/// drives are accessible from here. They are currently:
|
/// drives are accessible from here. They are currently:
|
||||||
///
|
///
|
||||||
/// /SFLASH -- the serial flash filesystem
|
/// /flash -- the serial flash filesystem
|
||||||
/// /SD -- the SD card (if it exists)
|
/// /sd -- the SD card (if it exists)
|
||||||
///
|
///
|
||||||
/// On boot up, the current directory is `/SFLASH` if no SD card is inserted,
|
/// On boot up, the current directory is `/flash` if no SD card is inserted,
|
||||||
/// otherwise it is `/SD`.
|
/// otherwise it is `/sd`.
|
||||||
|
|
||||||
/******************************************************************************
|
/******************************************************************************
|
||||||
DEFINE PRIVATE FUNCTIONS
|
DEFINE PRIVATE FUNCTIONS
|
||||||
@ -109,6 +109,7 @@ STATIC MP_DEFINE_CONST_FUN_OBJ_0(os_getcwd_obj, os_getcwd);
|
|||||||
STATIC mp_obj_t os_listdir(mp_uint_t n_args, const mp_obj_t *args) {
|
STATIC mp_obj_t os_listdir(mp_uint_t n_args, const mp_obj_t *args) {
|
||||||
bool is_str_type = true;
|
bool is_str_type = true;
|
||||||
const char *path;
|
const char *path;
|
||||||
|
|
||||||
if (n_args == 1) {
|
if (n_args == 1) {
|
||||||
if (mp_obj_get_type(args[0]) == &mp_type_bytes) {
|
if (mp_obj_get_type(args[0]) == &mp_type_bytes) {
|
||||||
is_str_type = false;
|
is_str_type = false;
|
||||||
@ -121,16 +122,21 @@ STATIC mp_obj_t os_listdir(mp_uint_t n_args, const mp_obj_t *args) {
|
|||||||
// "hack" to list root directory
|
// "hack" to list root directory
|
||||||
if (path[0] == '/' && path[1] == '\0') {
|
if (path[0] == '/' && path[1] == '\0') {
|
||||||
mp_obj_t dir_list = mp_obj_new_list(0, NULL);
|
mp_obj_t dir_list = mp_obj_new_list(0, NULL);
|
||||||
mp_obj_list_append(dir_list, MP_OBJ_NEW_QSTR(MP_QSTR_SFLASH));
|
mp_obj_list_append(dir_list, MP_OBJ_NEW_QSTR(MP_QSTR_flash));
|
||||||
if (sd_in_root()) {
|
if (sd_in_root()) {
|
||||||
mp_obj_list_append(dir_list, MP_OBJ_NEW_QSTR(MP_QSTR_SD));
|
mp_obj_list_append(dir_list, MP_OBJ_NEW_QSTR(MP_QSTR_sd));
|
||||||
}
|
}
|
||||||
return dir_list;
|
return dir_list;
|
||||||
}
|
}
|
||||||
|
|
||||||
FRESULT res;
|
FRESULT res;
|
||||||
FILINFO fno;
|
|
||||||
DIR dir;
|
DIR dir;
|
||||||
|
FILINFO fno;
|
||||||
|
#if _USE_LFN
|
||||||
|
char lfn_buf[_MAX_LFN + 1];
|
||||||
|
fno.lfname = lfn_buf;
|
||||||
|
fno.lfsize = sizeof(lfn_buf);
|
||||||
|
#endif
|
||||||
|
|
||||||
res = f_opendir(&dir, path); /* Open the directory */
|
res = f_opendir(&dir, path); /* Open the directory */
|
||||||
if (res != FR_OK) {
|
if (res != FR_OK) {
|
||||||
@ -145,7 +151,11 @@ STATIC mp_obj_t os_listdir(mp_uint_t n_args, const mp_obj_t *args) {
|
|||||||
if (fno.fname[0] == '.' && fno.fname[1] == 0) continue; /* Ignore . entry */
|
if (fno.fname[0] == '.' && fno.fname[1] == 0) continue; /* Ignore . entry */
|
||||||
if (fno.fname[0] == '.' && fno.fname[1] == '.' && fno.fname[2] == 0) continue; /* Ignore .. entry */
|
if (fno.fname[0] == '.' && fno.fname[1] == '.' && fno.fname[2] == 0) continue; /* Ignore .. entry */
|
||||||
|
|
||||||
|
#if _USE_LFN
|
||||||
|
char *fn = *fno.lfname ? fno.lfname : fno.fname;
|
||||||
|
#else
|
||||||
char *fn = fno.fname;
|
char *fn = fno.fname;
|
||||||
|
#endif
|
||||||
|
|
||||||
// make a string object for this entry
|
// make a string object for this entry
|
||||||
mp_obj_t entry_o;
|
mp_obj_t entry_o;
|
||||||
@ -215,14 +225,18 @@ STATIC bool path_equal(const char *path, const char *path_canonical) {
|
|||||||
/// Get the status of a file or directory.
|
/// Get the status of a file or directory.
|
||||||
STATIC mp_obj_t os_stat(mp_obj_t path_in) {
|
STATIC mp_obj_t os_stat(mp_obj_t path_in) {
|
||||||
const char *path = mp_obj_str_get_str(path_in);
|
const char *path = mp_obj_str_get_str(path_in);
|
||||||
stoupper((char *)path);
|
|
||||||
|
|
||||||
FILINFO fno;
|
|
||||||
FRESULT res;
|
FRESULT res;
|
||||||
if (path_equal(path, "/") || path_equal(path, "/SFLASH") || path_equal(path, "/SD")) {
|
FILINFO fno;
|
||||||
|
#if _USE_LFN
|
||||||
|
fno.lfname = NULL;
|
||||||
|
fno.lfsize = 0;
|
||||||
|
#endif
|
||||||
|
|
||||||
|
if (path_equal(path, "/") || path_equal(path, "/flash") || path_equal(path, "/sd")) {
|
||||||
// stat built-in directory
|
// stat built-in directory
|
||||||
if (path[1] == 'S' && !sd_in_root()) {
|
if (path[1] == 's' && !sd_in_root()) {
|
||||||
// no /SD directory
|
// no /sd directory
|
||||||
res = FR_NO_PATH;
|
res = FR_NO_PATH;
|
||||||
goto error;
|
goto error;
|
||||||
}
|
}
|
||||||
|
@ -148,13 +148,13 @@ STATIC mp_obj_t pybsd_enable (mp_obj_t self_in) {
|
|||||||
// do the init first
|
// do the init first
|
||||||
pybsd_init (self);
|
pybsd_init (self);
|
||||||
|
|
||||||
// try to mount the sd card on /SD
|
// try to mount the sd card on /sd
|
||||||
if (FR_OK != f_mount(self->fatfs, "/SD", 1)) {
|
if (FR_OK != f_mount(self->fatfs, "/sd", 1)) {
|
||||||
nlr_raise(mp_obj_new_exception_msg(&mp_type_OSError, mpexception_os_operation_failed));
|
nlr_raise(mp_obj_new_exception_msg(&mp_type_OSError, mpexception_os_operation_failed));
|
||||||
}
|
}
|
||||||
|
|
||||||
mp_obj_list_append(mp_sys_path, MP_OBJ_NEW_QSTR(MP_QSTR__slash_SD));
|
mp_obj_list_append(mp_sys_path, MP_OBJ_NEW_QSTR(MP_QSTR__slash_sd));
|
||||||
mp_obj_list_append(mp_sys_path, MP_OBJ_NEW_QSTR(MP_QSTR__slash_SD_slash_LIB));
|
mp_obj_list_append(mp_sys_path, MP_OBJ_NEW_QSTR(MP_QSTR__slash_sd_slash_lib));
|
||||||
|
|
||||||
// register it with the sleep module
|
// register it with the sleep module
|
||||||
pybsleep_add ((const mp_obj_t)&pybsd_obj, (WakeUpCB_t)pybsd_init);
|
pybsleep_add ((const mp_obj_t)&pybsd_obj, (WakeUpCB_t)pybsd_init);
|
||||||
@ -172,10 +172,10 @@ STATIC mp_obj_t pybsd_disable (mp_obj_t self_in) {
|
|||||||
if (self->enabled) {
|
if (self->enabled) {
|
||||||
self->enabled = false;
|
self->enabled = false;
|
||||||
// unmount the sd card
|
// unmount the sd card
|
||||||
f_mount (NULL, "/SD", 1);
|
f_mount (NULL, "/sd", 1);
|
||||||
// remove sd paths from mp_sys_path
|
// remove sd paths from mp_sys_path
|
||||||
mp_obj_list_remove(mp_sys_path, MP_OBJ_NEW_QSTR(MP_QSTR__slash_SD));
|
mp_obj_list_remove(mp_sys_path, MP_OBJ_NEW_QSTR(MP_QSTR__slash_sd));
|
||||||
mp_obj_list_remove(mp_sys_path, MP_OBJ_NEW_QSTR(MP_QSTR__slash_SD_slash_LIB));
|
mp_obj_list_remove(mp_sys_path, MP_OBJ_NEW_QSTR(MP_QSTR__slash_sd_slash_lib));
|
||||||
|
|
||||||
// disable the peripheral
|
// disable the peripheral
|
||||||
MAP_PRCMPeripheralClkDisable(PRCM_SDHOST, PRCM_RUN_MODE_CLK | PRCM_SLP_MODE_CLK);
|
MAP_PRCMPeripheralClkDisable(PRCM_SDHOST, PRCM_RUN_MODE_CLK | PRCM_SLP_MODE_CLK);
|
||||||
@ -186,8 +186,8 @@ STATIC mp_obj_t pybsd_disable (mp_obj_t self_in) {
|
|||||||
// unregister it with the sleep module
|
// unregister it with the sleep module
|
||||||
pybsleep_remove (self);
|
pybsleep_remove (self);
|
||||||
|
|
||||||
// change the drive in case it was /SD
|
// change the drive in case it was /sd
|
||||||
f_chdrive("/SFLASH");
|
f_chdrive("/flash");
|
||||||
}
|
}
|
||||||
return mp_const_none;
|
return mp_const_none;
|
||||||
}
|
}
|
||||||
|
@ -54,8 +54,8 @@
|
|||||||
2: Enable LFN with dynamic working buffer on the STACK.
|
2: Enable LFN with dynamic working buffer on the STACK.
|
||||||
3: Enable LFN with dynamic working buffer on the HEAP.
|
3: Enable LFN with dynamic working buffer on the HEAP.
|
||||||
*/
|
*/
|
||||||
#define MICROPY_ENABLE_LFN (0)
|
#define MICROPY_ENABLE_LFN (2)
|
||||||
#define MICROPY_LFN_CODE_PAGE (1)
|
#define MICROPY_LFN_CODE_PAGE (437) // 1=SFN/ANSI 437=LFN/U.S.(OEM)
|
||||||
#define MICROPY_STREAMS_NON_BLOCK (1)
|
#define MICROPY_STREAMS_NON_BLOCK (1)
|
||||||
#define MICROPY_MODULE_WEAK_LINKS (0)
|
#define MICROPY_MODULE_WEAK_LINKS (0)
|
||||||
#define MICROPY_CAN_OVERRIDE_BUILTINS (0)
|
#define MICROPY_CAN_OVERRIDE_BUILTINS (0)
|
||||||
|
@ -174,16 +174,16 @@ soft_reset:
|
|||||||
// initialize the serial flash file system
|
// initialize the serial flash file system
|
||||||
mptask_init_sflash_filesystem();
|
mptask_init_sflash_filesystem();
|
||||||
|
|
||||||
// append the SFLASH paths to the system path
|
// append the flash paths to the system path
|
||||||
mp_obj_list_append(mp_sys_path, MP_OBJ_NEW_QSTR(MP_QSTR__slash_SFLASH));
|
mp_obj_list_append(mp_sys_path, MP_OBJ_NEW_QSTR(MP_QSTR__slash_flash));
|
||||||
mp_obj_list_append(mp_sys_path, MP_OBJ_NEW_QSTR(MP_QSTR__slash_SFLASH_slash_LIB));
|
mp_obj_list_append(mp_sys_path, MP_OBJ_NEW_QSTR(MP_QSTR__slash_flash_slash_lib));
|
||||||
|
|
||||||
// reset config variables; they should be set by boot.py
|
// reset config variables; they should be set by boot.py
|
||||||
MP_STATE_PORT(pyb_config_main) = MP_OBJ_NULL;
|
MP_STATE_PORT(pyb_config_main) = MP_OBJ_NULL;
|
||||||
|
|
||||||
if (!safeboot) {
|
if (!safeboot) {
|
||||||
// run boot.py, if it exists
|
// run boot.py, if it exists
|
||||||
const char *boot_py = "BOOT.PY";
|
const char *boot_py = "boot.py";
|
||||||
res = f_stat(boot_py, NULL);
|
res = f_stat(boot_py, NULL);
|
||||||
if (res == FR_OK) {
|
if (res == FR_OK) {
|
||||||
int ret = pyexec_file(boot_py);
|
int ret = pyexec_file(boot_py);
|
||||||
@ -208,7 +208,7 @@ soft_reset:
|
|||||||
if (pyexec_mode_kind == PYEXEC_MODE_FRIENDLY_REPL) {
|
if (pyexec_mode_kind == PYEXEC_MODE_FRIENDLY_REPL) {
|
||||||
const char *main_py;
|
const char *main_py;
|
||||||
if (MP_STATE_PORT(pyb_config_main) == MP_OBJ_NULL) {
|
if (MP_STATE_PORT(pyb_config_main) == MP_OBJ_NULL) {
|
||||||
main_py = "MAIN.PY";
|
main_py = "main.py";
|
||||||
} else {
|
} else {
|
||||||
main_py = mp_obj_str_get_str(MP_STATE_PORT(pyb_config_main));
|
main_py = mp_obj_str_get_str(MP_STATE_PORT(pyb_config_main));
|
||||||
}
|
}
|
||||||
@ -290,38 +290,42 @@ STATIC void mptask_pre_init (void) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
STATIC void mptask_init_sflash_filesystem (void) {
|
STATIC void mptask_init_sflash_filesystem (void) {
|
||||||
|
FILINFO fno;
|
||||||
|
#if _USE_LFN
|
||||||
|
fno.lfname = NULL;
|
||||||
|
fno.lfsize = 0;
|
||||||
|
#endif
|
||||||
|
|
||||||
// Initialise the local flash filesystem.
|
// Initialise the local flash filesystem.
|
||||||
// Create it if needed, and mount in on /sflash.
|
// Create it if needed, and mount in on /flash.
|
||||||
// try to mount the flash
|
// try to mount the flash
|
||||||
FRESULT res = f_mount(sflash_fatfs, "/SFLASH", 1);
|
FRESULT res = f_mount(sflash_fatfs, "/flash", 1);
|
||||||
if (res == FR_NO_FILESYSTEM) {
|
if (res == FR_NO_FILESYSTEM) {
|
||||||
// no filesystem, so create a fresh one
|
// no filesystem, so create a fresh one
|
||||||
res = f_mkfs("/SFLASH", 1, 0);
|
res = f_mkfs("/flash", 1, 0);
|
||||||
if (res == FR_OK) {
|
if (res == FR_OK) {
|
||||||
// success creating fresh LFS
|
// success creating fresh LFS
|
||||||
} else {
|
} else {
|
||||||
__fatal_error("failed to create /SFLASH");
|
__fatal_error("failed to create /flash");
|
||||||
}
|
}
|
||||||
// create empty main.py
|
// create empty main.py
|
||||||
mptask_create_main_py();
|
mptask_create_main_py();
|
||||||
} else if (res == FR_OK) {
|
} else if (res == FR_OK) {
|
||||||
// mount sucessful
|
// mount sucessful
|
||||||
FILINFO fno;
|
if (FR_OK != f_stat("/flash/main.py", &fno)) {
|
||||||
if (FR_OK != f_stat("/SFLASH/MAIN.PY", &fno)) {
|
|
||||||
// create empty main.py
|
// create empty main.py
|
||||||
mptask_create_main_py();
|
mptask_create_main_py();
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
__fatal_error("failed to create /SFLASH");
|
__fatal_error("failed to create /flash");
|
||||||
}
|
}
|
||||||
|
|
||||||
// The current directory is used as the boot up directory.
|
// The current directory is used as the boot up directory.
|
||||||
// It is set to the internal flash filesystem by default.
|
// It is set to the internal flash filesystem by default.
|
||||||
f_chdrive("/SFLASH");
|
f_chdrive("/flash");
|
||||||
|
|
||||||
// Make sure we have a /flash/boot.py. Create it if needed.
|
// Make sure we have a /flash/boot.py. Create it if needed.
|
||||||
FILINFO fno;
|
res = f_stat("/flash/boot.py", &fno);
|
||||||
res = f_stat("/SFLASH/BOOT.PY", &fno);
|
|
||||||
if (res == FR_OK) {
|
if (res == FR_OK) {
|
||||||
if (fno.fattrib & AM_DIR) {
|
if (fno.fattrib & AM_DIR) {
|
||||||
// exists as a directory
|
// exists as a directory
|
||||||
@ -333,7 +337,7 @@ STATIC void mptask_init_sflash_filesystem (void) {
|
|||||||
} else {
|
} else {
|
||||||
// doesn't exist, create fresh file
|
// doesn't exist, create fresh file
|
||||||
FIL fp;
|
FIL fp;
|
||||||
f_open(&fp, "/SFLASH/BOOT.PY", FA_WRITE | FA_CREATE_ALWAYS);
|
f_open(&fp, "/flash/boot.py", FA_WRITE | FA_CREATE_ALWAYS);
|
||||||
UINT n;
|
UINT n;
|
||||||
f_write(&fp, fresh_boot_py, sizeof(fresh_boot_py) - 1 /* don't count null terminator */, &n);
|
f_write(&fp, fresh_boot_py, sizeof(fresh_boot_py) - 1 /* don't count null terminator */, &n);
|
||||||
// TODO check we could write n bytes
|
// TODO check we could write n bytes
|
||||||
@ -350,7 +354,7 @@ STATIC void mptask_enter_ap_mode (void) {
|
|||||||
STATIC void mptask_create_main_py (void) {
|
STATIC void mptask_create_main_py (void) {
|
||||||
// create empty main.py
|
// create empty main.py
|
||||||
FIL fp;
|
FIL fp;
|
||||||
f_open(&fp, "/SFLASH/MAIN.PY", FA_WRITE | FA_CREATE_ALWAYS);
|
f_open(&fp, "/flash/main.py", FA_WRITE | FA_CREATE_ALWAYS);
|
||||||
UINT n;
|
UINT n;
|
||||||
f_write(&fp, fresh_main_py, sizeof(fresh_main_py) - 1 /* don't count null terminator */, &n);
|
f_write(&fp, fresh_main_py, sizeof(fresh_main_py) - 1 /* don't count null terminator */, &n);
|
||||||
f_close(&fp);
|
f_close(&fp);
|
||||||
|
@ -1,3 +1,30 @@
|
|||||||
|
/*
|
||||||
|
* This file is part of the Micro Python project, http://micropython.org/
|
||||||
|
*
|
||||||
|
* The MIT License (MIT)
|
||||||
|
*
|
||||||
|
* Copyright (c) 2013, 2014 Damien P. George
|
||||||
|
* Copyright (c) 2015 Daniel Campora
|
||||||
|
*
|
||||||
|
* Permission is hereby granted, free of charge, to any person obtaining a copy
|
||||||
|
* of this software and associated documentation files (the "Software"), to deal
|
||||||
|
* in the Software without restriction, including without limitation the rights
|
||||||
|
* to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
|
||||||
|
* copies of the Software, and to permit persons to whom the Software is
|
||||||
|
* furnished to do so, subject to the following conditions:
|
||||||
|
*
|
||||||
|
* The above copyright notice and this permission notice shall be included in
|
||||||
|
* all copies or substantial portions of the Software.
|
||||||
|
*
|
||||||
|
* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
||||||
|
* IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
||||||
|
* FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
|
||||||
|
* AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
|
||||||
|
* LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
|
||||||
|
* OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
|
||||||
|
* THE SOFTWARE.
|
||||||
|
*/
|
||||||
|
|
||||||
// qstrs specific to this port
|
// qstrs specific to this port
|
||||||
Q(__name__)
|
Q(__name__)
|
||||||
Q(help)
|
Q(help)
|
||||||
@ -36,10 +63,12 @@ Q(mkdisk)
|
|||||||
Q(enable)
|
Q(enable)
|
||||||
Q(disable)
|
Q(disable)
|
||||||
// Entries for sys.path
|
// Entries for sys.path
|
||||||
Q(/SFLASH)
|
Q(/flash)
|
||||||
Q(/SFLASH/LIB)
|
Q(/flash/lib)
|
||||||
Q(/SD)
|
#if MICROPY_HW_HAS_SDCARD
|
||||||
Q(/SD/LIB)
|
Q(/sd)
|
||||||
|
Q(/sd/lib)
|
||||||
|
#endif
|
||||||
|
|
||||||
// for module weak links
|
// for module weak links
|
||||||
Q(re)
|
Q(re)
|
||||||
@ -50,8 +79,10 @@ Q(heapq)
|
|||||||
Q(uos)
|
Q(uos)
|
||||||
Q(os)
|
Q(os)
|
||||||
Q(/)
|
Q(/)
|
||||||
Q(SFLASH)
|
Q(flash)
|
||||||
Q(SD)
|
#if MICROPY_HW_HAS_SDCARD
|
||||||
|
Q(sd)
|
||||||
|
#endif
|
||||||
Q(chdir)
|
Q(chdir)
|
||||||
Q(getcwd)
|
Q(getcwd)
|
||||||
Q(listdir)
|
Q(listdir)
|
||||||
@ -144,10 +175,12 @@ Q(mem_write)
|
|||||||
Q(ADC)
|
Q(ADC)
|
||||||
Q(read)
|
Q(read)
|
||||||
|
|
||||||
|
#if MICROPY_HW_HAS_SDCARD
|
||||||
// for SD class
|
// for SD class
|
||||||
Q(SD)
|
Q(SD)
|
||||||
Q(enable)
|
Q(enable)
|
||||||
Q(disable)
|
Q(disable)
|
||||||
|
#endif
|
||||||
|
|
||||||
// for RTC class
|
// for RTC class
|
||||||
Q(RTC)
|
Q(RTC)
|
||||||
|
@ -31,7 +31,7 @@
|
|||||||
DEFINE CONSTANTS
|
DEFINE CONSTANTS
|
||||||
******************************************************************************/
|
******************************************************************************/
|
||||||
#define SERVERS_PRIORITY 2
|
#define SERVERS_PRIORITY 2
|
||||||
#define SERVERS_STACK_SIZE 944
|
#define SERVERS_STACK_SIZE 1072
|
||||||
|
|
||||||
#define SERVERS_SSID_LEN_MAX 16
|
#define SERVERS_SSID_LEN_MAX 16
|
||||||
#define SERVERS_KEY_LEN_MAX 16
|
#define SERVERS_KEY_LEN_MAX 16
|
||||||
|
Loading…
x
Reference in New Issue
Block a user