cc3200: Rework SD API. Increase heap to avoid malloc failures.

pull/1421/head
Daniel Campora 2015-08-11 16:06:43 +02:00
rodzic 34c290b678
commit 11d21081b4
11 zmienionych plików z 162 dodań i 111 usunięć

Wyświetl plik

@ -279,8 +279,6 @@ DSTATUS sd_disk_init (void) {
sd_disk_info.bStatus = 0; sd_disk_info.bStatus = 0;
} }
} }
// Set card rd/wr block len
MAP_SDHostBlockSizeSet(SDHOST_BASE, SD_SECTOR_SIZE);
} }
return sd_disk_info.bStatus; return sd_disk_info.bStatus;
@ -315,15 +313,6 @@ DSTATUS sd_disk_status (void) {
return sd_disk_info.bStatus; return sd_disk_info.bStatus;
} }
//*****************************************************************************
//
//! Returns wether the sd card is ready to be accessed or not
//
//*****************************************************************************
bool sd_disk_ready (void) {
return (!sd_disk_info.bStatus);
}
//***************************************************************************** //*****************************************************************************
// //
//! Reads sector(s) from the disk drive. //! Reads sector(s) from the disk drive.

Wyświetl plik

@ -22,7 +22,6 @@ extern DiskInfo_t sd_disk_info;
DSTATUS sd_disk_init (void); DSTATUS sd_disk_init (void);
void sd_disk_deinit (void); void sd_disk_deinit (void);
DSTATUS sd_disk_status (void); DSTATUS sd_disk_status (void);
bool sd_disk_ready (void);
DRESULT sd_disk_read (BYTE* pBuffer, DWORD ulSectorNumber, UINT bSectorCount); DRESULT sd_disk_read (BYTE* pBuffer, DWORD ulSectorNumber, UINT bSectorCount);
DRESULT sd_disk_write (const BYTE* pBuffer, DWORD ulSectorNumber, UINT bSectorCount); DRESULT sd_disk_write (const BYTE* pBuffer, DWORD ulSectorNumber, UINT bSectorCount);

Wyświetl plik

@ -47,8 +47,7 @@
#include "ff.h" #include "ff.h"
#include "fifo.h" #include "fifo.h"
#include "socketfifo.h" #include "socketfifo.h"
#include "diskio.h" #include "pybsd.h"
#include "sd_diskio.h"
#include "updater.h" #include "updater.h"
#include "timeutils.h" #include "timeutils.h"
@ -193,7 +192,7 @@ static const ftp_month_t ftp_month[] = { { "Jan" }, { "Feb" }, { "Mar" }, { "Apr
{ "May" }, { "Jun" }, { "Jul" }, { "Ago" }, { "May" }, { "Jun" }, { "Jul" }, { "Ago" },
{ "Sep" }, { "Oct" }, { "Nov" }, { "Dec" } }; { "Sep" }, { "Oct" }, { "Nov" }, { "Dec" } };
static SocketFifoElement_t *ftp_fifoelements; static SocketFifoElement_t ftp_fifoelements[FTP_SOCKETFIFO_ELEMENTS_MAX];
static FIFO_t ftp_socketfifo; static FIFO_t ftp_socketfifo;
/****************************************************************************** /******************************************************************************
@ -233,7 +232,6 @@ void ftp_init (void) {
ASSERT ((ftp_path = mem_Malloc(FTP_MAX_PARAM_SIZE)) != NULL); ASSERT ((ftp_path = mem_Malloc(FTP_MAX_PARAM_SIZE)) != NULL);
ASSERT ((ftp_scratch_buffer = mem_Malloc(FTP_MAX_PARAM_SIZE)) != NULL); ASSERT ((ftp_scratch_buffer = mem_Malloc(FTP_MAX_PARAM_SIZE)) != NULL);
ASSERT ((ftp_cmd_buffer = mem_Malloc(FTP_MAX_PARAM_SIZE + FTP_CMD_SIZE_MAX)) != NULL); ASSERT ((ftp_cmd_buffer = mem_Malloc(FTP_MAX_PARAM_SIZE + FTP_CMD_SIZE_MAX)) != NULL);
ASSERT ((ftp_fifoelements = mem_Malloc(FTP_SOCKETFIFO_ELEMENTS_MAX * sizeof(SocketFifoElement_t))) != NULL);
SOCKETFIFO_Init (&ftp_socketfifo, (void *)ftp_fifoelements, FTP_SOCKETFIFO_ELEMENTS_MAX); SOCKETFIFO_Init (&ftp_socketfifo, (void *)ftp_fifoelements, FTP_SOCKETFIFO_ELEMENTS_MAX);
ftp_data.c_sd = -1; ftp_data.c_sd = -1;
ftp_data.d_sd = -1; ftp_data.d_sd = -1;
@ -987,7 +985,7 @@ static ftp_result_t ftp_open_dir_for_listing (const char *path, char *list, uint
if (path[0] == '/' && path[1] == '\0') { if (path[0] == '/' && path[1] == '\0') {
next += ftp_print_eplf_drive((list + next), (maxlistsize - next), "flash"); 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 (pybsd_is_mounted()) {
next += ftp_print_eplf_drive((list + next), (maxlistsize - next), "sd"); next += ftp_print_eplf_drive((list + next), (maxlistsize - next), "sd");
} }
#endif #endif

Wyświetl plik

@ -39,7 +39,7 @@
#include "sflash_diskio.h" #include "sflash_diskio.h"
#include "file.h" #include "file.h"
#include "random.h" #include "random.h"
#include "sd_diskio.h" #include "pybsd.h"
#include "mpexception.h" #include "mpexception.h"
#include "version.h" #include "version.h"
#include "timeutils.h" #include "timeutils.h"
@ -60,13 +60,6 @@
/****************************************************************************** /******************************************************************************
DEFINE PRIVATE FUNCTIONS DEFINE PRIVATE FUNCTIONS
******************************************************************************/ ******************************************************************************/
STATIC bool sd_in_root(void) {
#if MICROPY_HW_HAS_SDCARD
return sd_disk_ready();
#else
return false;
#endif
}
/******************************************************************************/ /******************************************************************************/
// Micro Python bindings // Micro Python bindings
@ -151,7 +144,7 @@ STATIC mp_obj_t os_listdir(mp_uint_t n_args, const mp_obj_t *args) {
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_flash)); mp_obj_list_append(dir_list, MP_OBJ_NEW_QSTR(MP_QSTR_flash));
#if MICROPY_HW_HAS_SDCARD #if MICROPY_HW_HAS_SDCARD
if (sd_in_root()) { if (pybsd_is_mounted()) {
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));
} }
#endif #endif
@ -280,7 +273,11 @@ STATIC mp_obj_t os_stat(mp_obj_t path_in) {
if (path_equal(path, "/") || path_equal(path, "/flash") || path_equal(path, "/sd")) { 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 MICROPY_HW_HAS_SDCARD
if (path[1] == 's' && !pybsd_is_mounted()) {
#else
if (path[1] == 's') {
#endif
// no /sd directory // no /sd directory
res = FR_NO_PATH; res = FR_NO_PATH;
goto error; goto error;
@ -353,11 +350,21 @@ STATIC mp_obj_t os_urandom(mp_obj_t num) {
STATIC MP_DEFINE_CONST_FUN_OBJ_1(os_urandom_obj, os_urandom); STATIC MP_DEFINE_CONST_FUN_OBJ_1(os_urandom_obj, os_urandom);
#endif #endif
/// \function mkfs('path') /// \function mkfs('drive')
/// Formats the selected drive, useful when the filesystem has been damaged beyond repair /// Formats the selected drive, useful when the filesystem has been damaged beyond repair.
/// Path must be either '/sd' or '/flash'
STATIC mp_obj_t os_mkfs(mp_obj_t path_o) { STATIC mp_obj_t os_mkfs(mp_obj_t path_o) {
const char *path = mp_obj_str_get_str(path_o); const char *path = mp_obj_str_get_str(path_o);
if (FR_OK != f_mkfs(path, 1, 0)) { uint8_t sfd;
if (!strcmp(path, "/flash")) {
sfd = 1;
} else if (!strcmp(path, "/sd")) {
sfd = 0;
} else {
nlr_raise(mp_obj_new_exception_msg(&mp_type_ValueError, mpexception_value_invalid_arguments));
}
if (FR_OK != f_mkfs(path, sfd, 0)) {
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));
} }
return mp_const_none; return mp_const_none;

Wyświetl plik

@ -58,19 +58,23 @@ typedef struct {
pin_obj_t *pin_clk; pin_obj_t *pin_clk;
bool pinsset; bool pinsset;
bool enabled; bool enabled;
bool mounted;
} pybsd_obj_t; } pybsd_obj_t;
/****************************************************************************** /******************************************************************************
DECLARE PRIVATE DATA DECLARE PRIVATE DATA
******************************************************************************/ ******************************************************************************/
STATIC pybsd_obj_t pybsd_obj; STATIC pybsd_obj_t pybsd_obj = {.pinsset = false, .enabled = false, .mounted = false};
/****************************************************************************** /******************************************************************************
DECLARE PRIVATE FUNCTIONS DECLARE PRIVATE FUNCTIONS
******************************************************************************/ ******************************************************************************/
STATIC void pybsd_hw_init (pybsd_obj_t *self);
STATIC mp_obj_t pybsd_make_new (mp_obj_t type_in, mp_uint_t n_args, mp_uint_t n_kw, const mp_obj_t *args); STATIC mp_obj_t pybsd_make_new (mp_obj_t type_in, mp_uint_t n_args, mp_uint_t n_kw, const mp_obj_t *args);
STATIC mp_obj_t pybsd_disable (mp_obj_t self_in); STATIC mp_obj_t pybsd_init (uint n_args, const mp_obj_t *args);
STATIC mp_obj_t pybsd_enable (mp_obj_t self_in); STATIC mp_obj_t pybsd_deinit (mp_obj_t self_in);
STATIC mp_obj_t pybsd_mount (mp_obj_t self_in);
STATIC mp_obj_t pybsd_unmount (mp_obj_t self_in);
/****************************************************************************** /******************************************************************************
DEFINE PUBLIC FUNCTIONS DEFINE PUBLIC FUNCTIONS
@ -81,15 +85,19 @@ void pybsd_init0 (void) {
ASSERT ((pybsd_obj.fatfs = mem_Malloc(sizeof(FATFS))) != NULL); ASSERT ((pybsd_obj.fatfs = mem_Malloc(sizeof(FATFS))) != NULL);
} }
void pybsd_deinit (void) { void pybsd_disable (void) {
pybsd_disable ((mp_obj_t)&pybsd_obj); pybsd_deinit ((mp_obj_t)&pybsd_obj);
}
bool pybsd_is_mounted (void) {
return pybsd_obj.mounted;
} }
/****************************************************************************** /******************************************************************************
DEFINE PRIVATE FUNCTIONS DEFINE PRIVATE FUNCTIONS
******************************************************************************/ ******************************************************************************/
/// Initalizes the sd card driver /// Initalizes the sd card hardware driver
STATIC void pybsd_init (pybsd_obj_t *self) { STATIC void pybsd_hw_init (pybsd_obj_t *self) {
// Configure the clock pin as output only // Configure the clock pin as output only
MAP_PinDirModeSet(self->pin_clk->pin_num, PIN_DIR_MODE_OUT); MAP_PinDirModeSet(self->pin_clk->pin_num, PIN_DIR_MODE_OUT);
// Enable SD peripheral clock // Enable SD peripheral clock
@ -100,6 +108,41 @@ STATIC void pybsd_init (pybsd_obj_t *self) {
MAP_SDHostInit(SDHOST_BASE); MAP_SDHostInit(SDHOST_BASE);
// Configure the card clock // Configure the card clock
MAP_SDHostSetExpClk(SDHOST_BASE, MAP_PRCMPeripheralClockGet(PRCM_SDHOST), PYBSD_FREQUENCY_HZ); MAP_SDHostSetExpClk(SDHOST_BASE, MAP_PRCMPeripheralClockGet(PRCM_SDHOST), PYBSD_FREQUENCY_HZ);
// Set card rd/wr block len
MAP_SDHostBlockSizeSet(SDHOST_BASE, SD_SECTOR_SIZE);
}
STATIC mp_obj_t pybsd_init_helper (pybsd_obj_t *self, uint n_args, const mp_obj_t *args) {
if (n_args > 0) {
if (mp_obj_get_type(args[0]) == &mp_type_tuple) {
mp_obj_t *items;
mp_obj_get_array_fixed_n(args[0], 6, &items);
// save the clock pin for later use
self->pin_clk = (pin_obj_t *)pin_find(items[2]);
// configure the data pin with pull-up enabled
pin_config ((pin_obj_t *)pin_find(items[0]), mp_obj_get_int(items[1]), 0, PIN_TYPE_STD_PU, PIN_STRENGTH_4MA);
// configure the clock pin
pin_config (self->pin_clk, mp_obj_get_int(items[3]), 0, PIN_TYPE_STD, PIN_STRENGTH_4MA);
// configure the command pin with pull-up enabled
pin_config ((pin_obj_t *)pin_find(items[4]), mp_obj_get_int(items[5]), 0, PIN_TYPE_STD_PU, PIN_STRENGTH_4MA);
self->pinsset = true;
} else {
nlr_raise(mp_obj_new_exception_msg(&mp_type_TypeError, mpexception_num_type_invalid_arguments));
}
}
if (!self->enabled) {
if (!self->pinsset) {
nlr_raise(mp_obj_new_exception_msg(&mp_type_OSError, mpexception_os_request_not_possible));
}
pybsd_hw_init (self);
// mark as enabled and register it with the sleep module
self->enabled = true;
pybsleep_add ((const mp_obj_t)self, (WakeUpCB_t)pybsd_hw_init);
}
return mp_const_none;
} }
/******************************************************************************/ /******************************************************************************/
@ -107,95 +150,98 @@ STATIC void pybsd_init (pybsd_obj_t *self) {
// //
/// \classmethod \constructor() /// \classmethod \constructor()
/// Configure the pins used for the sd card. /// Creates an SD card object.
/// May receive 0, or 6 arguments. /// Accepts a tuple of pins an alternate functions to configure the SD card interface.
/// When called with no arguments it returns the previoulsy created SD card object.
/// ///
/// Usage: /// Usage:
/// sd = pyb.SD() /// sd = pyb.SD()
//// /// Or:
/// sd = pyb.SD(d0_pin, d0_af, clk_pin, clk_af, cmd_pin, cmd_af) /// sd = pyb.SD((d0_pin, d0_af, clk_pin, clk_af, cmd_pin, cmd_af))
/// ///
STATIC mp_obj_t pybsd_make_new (mp_obj_t type_in, mp_uint_t n_args, mp_uint_t n_kw, const mp_obj_t *args) { STATIC mp_obj_t pybsd_make_new (mp_obj_t type_in, mp_uint_t n_args, mp_uint_t n_kw, const mp_obj_t *args) {
mp_arg_check_num(n_args, n_kw, 0, 6, false); mp_arg_check_num(n_args, n_kw, 0, 1, false);
mp_obj_t self = &pybsd_obj;
if (n_args == 6) {
// save the clock pin for later use
pybsd_obj.pin_clk = (pin_obj_t *)pin_find(args[2]);
// configure the data pin with pull-up enabled
pin_config ((pin_obj_t *)pin_find(args[0]), mp_obj_get_int(args[1]), 0, PIN_TYPE_STD_PU, PIN_STRENGTH_4MA);
// configure the clock pin
pin_config (pybsd_obj.pin_clk, mp_obj_get_int(args[3]), 0, PIN_TYPE_STD, PIN_STRENGTH_4MA);
// configure the command pin with pull-up enabled
pin_config ((pin_obj_t *)pin_find(args[4]), mp_obj_get_int(args[5]), 0, PIN_TYPE_STD_PU, PIN_STRENGTH_4MA);
pybsd_obj.pinsset = true;
pybsd_obj.base.type = &pyb_sd_type; pybsd_obj.base.type = &pyb_sd_type;
}
else if (!pybsd_obj.pinsset) {
nlr_raise(mp_obj_new_exception_msg(&mp_type_TypeError, mpexception_num_type_invalid_arguments));
}
return &pybsd_obj; if (n_args > 0) {
pybsd_init_helper (self, n_args, args);
}
return self;
} }
/// \method enable() /// \method init()
/// Enables the sd card and mounts the file system /// Enables the sd card
STATIC mp_obj_t pybsd_enable (mp_obj_t self_in) { STATIC mp_obj_t pybsd_init (uint n_args, const mp_obj_t *args) {
return pybsd_init_helper(args[0], n_args - 1, args + 1);
}
STATIC MP_DEFINE_CONST_FUN_OBJ_VAR_BETWEEN(pybsd_init_obj, 1, 2, pybsd_init);
/// \method deinit()
/// Disables the sd card
STATIC mp_obj_t pybsd_deinit (mp_obj_t self_in) {
pybsd_obj_t *self = self_in; pybsd_obj_t *self = self_in;
if (self->enabled) {
// unmounted in case not done yet
pybsd_unmount (self);
self->enabled = false;
// disable the peripheral
MAP_PRCMPeripheralClkDisable(PRCM_SDHOST, PRCM_RUN_MODE_CLK | PRCM_SLP_MODE_CLK);
// de-initialze the sd card at diskio level
sd_disk_deinit();
// unregister it with the sleep module
pybsleep_remove (self);
}
return mp_const_none;
}
STATIC MP_DEFINE_CONST_FUN_OBJ_1(pybsd_deinit_obj, pybsd_deinit);
/// \method mount()
/// Mount the sd card on /sd
STATIC mp_obj_t pybsd_mount (mp_obj_t self_in) {
pybsd_obj_t *self = self_in;
if (!self->mounted) {
if (!self->enabled) { if (!self->enabled) {
// do the init first nlr_raise(mp_obj_new_exception_msg(&mp_type_OSError, mpexception_os_request_not_possible));
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));
self->mounted = true;
// register it with the sleep module
pybsleep_add ((const mp_obj_t)&pybsd_obj, (WakeUpCB_t)pybsd_init);
self->enabled = true;
} }
return mp_const_none; return mp_const_none;
} }
STATIC MP_DEFINE_CONST_FUN_OBJ_1(pybsd_enable_obj, pybsd_enable); STATIC MP_DEFINE_CONST_FUN_OBJ_1(pybsd_mount_obj, pybsd_mount);
/// \method disable() /// \method unmount()
/// Disables the sd card and unmounts the file system /// Unmount the sd card
STATIC mp_obj_t pybsd_disable (mp_obj_t self_in) { STATIC mp_obj_t pybsd_unmount (mp_obj_t self_in) {
pybsd_obj_t *self = self_in; pybsd_obj_t *self = self_in;
if (self->enabled) { if (self->mounted) {
self->enabled = false; if (!self->enabled) {
nlr_raise(mp_obj_new_exception_msg(&mp_type_OSError, mpexception_os_request_not_possible));
}
// 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));
self->mounted = false;
// disable the peripheral
MAP_PRCMPeripheralClkDisable(PRCM_SDHOST, PRCM_RUN_MODE_CLK | PRCM_SLP_MODE_CLK);
// de-initialze de sd card at diskio level
sd_disk_deinit();
// unregister it with the sleep module
pybsleep_remove (self);
// change the drive in case it was /sd // change the drive in case it was /sd
f_chdrive("/flash"); f_chdrive("/flash");
} }
return mp_const_none; return mp_const_none;
} }
STATIC MP_DEFINE_CONST_FUN_OBJ_1(pybsd_disable_obj, pybsd_disable); STATIC MP_DEFINE_CONST_FUN_OBJ_1(pybsd_unmount_obj, pybsd_unmount);
STATIC const mp_map_elem_t pybsd_locals_dict_table[] = { STATIC const mp_map_elem_t pybsd_locals_dict_table[] = {
{ MP_OBJ_NEW_QSTR(MP_QSTR_enable), (mp_obj_t)&pybsd_enable_obj }, { MP_OBJ_NEW_QSTR(MP_QSTR_init), (mp_obj_t)&pybsd_init_obj },
{ MP_OBJ_NEW_QSTR(MP_QSTR_disable), (mp_obj_t)&pybsd_disable_obj }, { MP_OBJ_NEW_QSTR(MP_QSTR_deinit), (mp_obj_t)&pybsd_deinit_obj },
{ MP_OBJ_NEW_QSTR(MP_QSTR_mount), (mp_obj_t)&pybsd_mount_obj },
{ MP_OBJ_NEW_QSTR(MP_QSTR_unmount), (mp_obj_t)&pybsd_unmount_obj },
}; };
STATIC MP_DEFINE_CONST_DICT(pybsd_locals_dict, pybsd_locals_dict_table); STATIC MP_DEFINE_CONST_DICT(pybsd_locals_dict, pybsd_locals_dict_table);

Wyświetl plik

@ -30,7 +30,8 @@
extern const mp_obj_type_t pyb_sd_type; extern const mp_obj_type_t pyb_sd_type;
void pybsd_init0 (void); void pybsd_init0 (void);
void pybsd_deinit (void); void pybsd_disable (void);
bool pybsd_is_mounted (void);
#endif #endif
#endif // PYBSD_H_ #endif // PYBSD_H_

Wyświetl plik

@ -251,7 +251,7 @@ soft_reset_exit:
modusocket_close_all_user_sockets(); modusocket_close_all_user_sockets();
#if MICROPY_HW_HAS_SDCARD #if MICROPY_HW_HAS_SDCARD
pybsd_deinit(); pybsd_disable();
#endif #endif
// wait for pending transactions to complete // wait for pending transactions to complete
@ -284,7 +284,7 @@ STATIC void mptask_pre_init (void) {
// this one allocates memory for the updater semaphore // this one allocates memory for the updater semaphore
updater_pre_init(); updater_pre_init();
// this one allocates memory for the Socket semaphore // this one allocates memory for the socket semaphore
modusocket_pre_init(); modusocket_pre_init();
#if MICROPY_HW_HAS_SDCARD #if MICROPY_HW_HAS_SDCARD

Wyświetl plik

@ -188,8 +188,10 @@ Q(deinit)
#if MICROPY_HW_HAS_SDCARD #if MICROPY_HW_HAS_SDCARD
// for SD class // for SD class
Q(SD) Q(SD)
Q(enable) Q(init)
Q(disable) Q(deinit)
Q(mount)
Q(unmount)
#endif #endif
// for RTC class // for RTC class

Wyświetl plik

@ -31,7 +31,7 @@
DEFINE CONSTANTS DEFINE CONSTANTS
******************************************************************************/ ******************************************************************************/
#define SERVERS_PRIORITY 2 #define SERVERS_PRIORITY 2
#define SERVERS_STACK_SIZE 1072 #define SERVERS_STACK_SIZE 1024
#define SERVERS_SSID_LEN_MAX 16 #define SERVERS_SSID_LEN_MAX 16
#define SERVERS_KEY_LEN_MAX 16 #define SERVERS_KEY_LEN_MAX 16

Wyświetl plik

@ -15,25 +15,34 @@ Example usage::
# data, clk and cmd pins must be passed along with # data, clk and cmd pins must be passed along with
# their respective alternate functions # their respective alternate functions
sd = pyb.SD('GP15', 8, 'GP10', 6, 'GP11', 6) sd = pyb.SD(('GP15', 8, 'GP10', 6, 'GP11', 6))
sd.enable() # enable and mount the SD card sd.mount()
sd.disable() # disable and unmount it # do normal file operations
Constructors Constructors
------------ ------------
.. class:: pyb.SD(dat_pin, dat_pin_af, clk_pin, clk_pin_af, cmd_pin, cmd_pin_af) .. class:: pyb.SD([pins_tuple])
Create a SD card object. Data, clock and cmd pins must be passed along with Create a SD card object. In order to initalize the card, give it a 6-tuple
their respective alternate functions. ``(dat_pin, dat_af, clk_pin, clk_af, cmd_pin, cmd_af)`` with the data, clock
and cmd pins together their respective alternate functions.
Methods Methods
------- -------
.. method:: sd.enable() .. method:: sd.init([pins_tuple])
Enable the SD card and mount it on the file system. Accesible as ``/sd``. Enable the SD card.
.. method:: sd.disable() .. method:: sd.deinit()
Disable the SD card and remove it from the file system. Disable the SD card (also unmounts it to avoid file system crashes).
.. method:: sd.mount()
Mount the SD card on the file system. Accesible as ``/sd``.
.. method:: sd.unmount()
Unmount the SD card from the file system.

Wyświetl plik

@ -172,10 +172,10 @@ See :ref:`pyb.SD <pyb.SD>`. ::
from pyb import SD from pyb import SD
# SD card pins need special configuration so we pass 'em to the constructor # SD card pins need special configuration so we pass them to the constructor
# data pin, data af, clock pin, clock af, cmd pin, cmd af # data pin, data af, clock pin, clock af, cmd pin, cmd af
sd = pyb.SD('GP15', 8, 'GP10', 6, 'GP11', 6) sd = pyb.SD(('GP15', 8, 'GP10', 6, 'GP11', 6))
sd.enable() sd.mount()
WLAN (WiFi) WLAN (WiFi)
----------- -----------