mirror of
https://github.com/Ai-Thinker-Open/Ai-Thinker-Open_RTL8710BX_ALIOS_SDK.git
synced 2025-07-31 19:31:05 +00:00
rel_1.6.0 init
This commit is contained in:
commit
27b3e2883d
19359 changed files with 8093121 additions and 0 deletions
220
Living_SDK/kernel/modules/fs/fatfs/diskio.c
Normal file
220
Living_SDK/kernel/modules/fs/fatfs/diskio.c
Normal file
|
|
@ -0,0 +1,220 @@
|
|||
/*
|
||||
* Copyright (C) 2015-2017 Alibaba Group Holding Limited
|
||||
*/
|
||||
#include <string.h>
|
||||
#include "fatfs_diskio.h"
|
||||
#include "ff.h"
|
||||
|
||||
#ifdef CONFIG_AOS_FATFS_SUPPORT_MMC
|
||||
#include <hal/soc/sd.h>
|
||||
|
||||
static sd_dev_t sdmmc;
|
||||
static DSTATUS SDMMC_initialize()
|
||||
{
|
||||
DSTATUS stat = STA_NOINIT;
|
||||
|
||||
memset(&sdmmc, 0, sizeof(sd_dev_t));
|
||||
if (hal_sd_init(&sdmmc) == RES_OK) {
|
||||
stat &= ~STA_NOINIT;
|
||||
}
|
||||
|
||||
return stat;
|
||||
}
|
||||
|
||||
static DSTATUS SDMMC_status()
|
||||
{
|
||||
hal_sd_stat status;
|
||||
if (hal_sd_stat_get(&sdmmc, &status) == 0) {
|
||||
if (status == SD_STAT_TRANSFER)
|
||||
return 0;
|
||||
}
|
||||
|
||||
return STA_NOINIT;
|
||||
}
|
||||
|
||||
static DRESULT SDMMC_read(BYTE *buff, DWORD sector, UINT count)
|
||||
{
|
||||
DRESULT res = RES_OK;
|
||||
|
||||
if (hal_sd_blks_read(&sdmmc, buff, sector, count, AOS_WAIT_FOREVER) != 0) {
|
||||
res = RES_ERROR;
|
||||
}
|
||||
|
||||
return res;
|
||||
}
|
||||
|
||||
static DRESULT SDMMC_write(BYTE *buff, DWORD sector, UINT count)
|
||||
{
|
||||
DRESULT res = RES_OK;
|
||||
|
||||
if (hal_sd_blks_write(&sdmmc, buff, sector, count, AOS_WAIT_FOREVER) != 0) {
|
||||
res = RES_ERROR;
|
||||
}
|
||||
|
||||
return res;
|
||||
}
|
||||
|
||||
static DRESULT SDMMC_ioctl(BYTE cmd, void *buff)
|
||||
{
|
||||
DRESULT res = RES_ERROR;
|
||||
hal_sd_info_t info;
|
||||
|
||||
if (SDMMC_status() & STA_NOINIT) return RES_NOTRDY;
|
||||
|
||||
switch (cmd) {
|
||||
case CTRL_SYNC:
|
||||
res = RES_OK;
|
||||
break;
|
||||
|
||||
#if FF_USE_MKFS
|
||||
case GET_SECTOR_COUNT:
|
||||
if (hal_sd_info_get(&sdmmc, &info) == 0) {
|
||||
*(DWORD *)buff = info.blk_nums;
|
||||
res = RES_OK;
|
||||
}
|
||||
break;
|
||||
|
||||
case GET_BLOCK_SIZE:
|
||||
*(DWORD *)buff = 1;
|
||||
res = RES_OK;
|
||||
break;
|
||||
|
||||
case GET_FORMAT_OPTION:
|
||||
*(BYTE *)buff = FM_ANY;
|
||||
res = RES_OK;
|
||||
break;
|
||||
#endif
|
||||
|
||||
case GET_SECTOR_SIZE:
|
||||
if (hal_sd_info_get(&sdmmc, &info) == 0) {
|
||||
*(WORD *)buff = info.blk_size;
|
||||
res = RES_OK;
|
||||
}
|
||||
break;
|
||||
default:
|
||||
res = RES_PARERR;
|
||||
}
|
||||
|
||||
return res;
|
||||
}
|
||||
|
||||
#endif
|
||||
|
||||
DSTATUS ff_disk_status(BYTE pdrv)
|
||||
{
|
||||
switch (pdrv) {
|
||||
#ifdef CONFIG_AOS_FATFS_SUPPORT_MMC
|
||||
case DEV_MMC:
|
||||
return SDMMC_status();
|
||||
#endif
|
||||
|
||||
#ifdef CONFIG_AOS_FATFS_SUPPORT_USB
|
||||
case DEV_USB:
|
||||
retutn USB_disk_status();
|
||||
#endif
|
||||
|
||||
#ifdef CONFIG_AOS_FATFS_SUPPORT_RAM
|
||||
case DEV_RAM:
|
||||
return RAM_disk_status();
|
||||
#endif
|
||||
|
||||
default:
|
||||
break;
|
||||
}
|
||||
return STA_NOINIT;
|
||||
}
|
||||
|
||||
DSTATUS ff_disk_initialize(BYTE pdrv)
|
||||
{
|
||||
switch (pdrv) {
|
||||
#ifdef CONFIG_AOS_FATFS_SUPPORT_MMC
|
||||
case DEV_MMC:
|
||||
return SDMMC_initialize();
|
||||
#endif
|
||||
|
||||
#ifdef CONFIG_AOS_FATFS_SUPPORT_USB
|
||||
case DEV_USB:
|
||||
return USB_disk_initialize();
|
||||
#endif
|
||||
|
||||
#ifdef CONFIG_AOS_FATFS_SUPPORT_RAM
|
||||
case DEV_RAM:
|
||||
return RAM_disk_initialize();
|
||||
#endif
|
||||
default:
|
||||
break;
|
||||
}
|
||||
return STA_NOINIT;
|
||||
}
|
||||
|
||||
DRESULT ff_disk_read(BYTE pdrv, BYTE *buff, DWORD sector, UINT count)
|
||||
{
|
||||
switch (pdrv) {
|
||||
#ifdef CONFIG_AOS_FATFS_SUPPORT_MMC
|
||||
case DEV_MMC:
|
||||
return SDMMC_read(buff, sector, count);
|
||||
#endif
|
||||
|
||||
#ifdef CONFIG_AOS_FATFS_SUPPORT_USB
|
||||
case DEV_USB:
|
||||
return USB_disk_read(buff, sector, count);
|
||||
#endif
|
||||
|
||||
#ifdef CONFIG_AOS_FATFS_SUPPORT_RAM
|
||||
case DEV_RAM:
|
||||
return RAM_disk_read(buff, sector, count);
|
||||
#endif
|
||||
|
||||
default:
|
||||
break;
|
||||
}
|
||||
return RES_PARERR;
|
||||
}
|
||||
|
||||
DRESULT ff_disk_write(BYTE pdrv, const BYTE *buff, DWORD sector, UINT count)
|
||||
{
|
||||
switch (pdrv) {
|
||||
#ifdef CONFIG_AOS_FATFS_SUPPORT_MMC
|
||||
case DEV_MMC:
|
||||
return SDMMC_write((BYTE *)buff, sector, count);
|
||||
#endif
|
||||
|
||||
#ifdef CONFIG_AOS_FATFS_SUPPORT_USB
|
||||
case DEV_USB:
|
||||
return USB_disk_write(buff, sector, count);
|
||||
#endif
|
||||
|
||||
#ifdef CONFIG_AOS_FATFS_SUPPORT_RAM
|
||||
case DEV_RAM:
|
||||
return RAM_disk_write(buff, sector, count);
|
||||
#endif
|
||||
|
||||
default:
|
||||
break;
|
||||
}
|
||||
return RES_PARERR;
|
||||
}
|
||||
|
||||
DRESULT ff_disk_ioctl(BYTE pdrv, BYTE cmd, void *buff)
|
||||
{
|
||||
switch (pdrv) {
|
||||
#ifdef CONFIG_AOS_FATFS_SUPPORT_MMC
|
||||
case DEV_MMC:
|
||||
return SDMMC_ioctl(cmd, buff);
|
||||
#endif
|
||||
|
||||
#ifdef CONFIG_AOS_FATFS_SUPPORT_USB
|
||||
case DEV_USB:
|
||||
return USB_disk_ioctl(cmd, buff);
|
||||
#endif
|
||||
|
||||
#ifdef CONFIG_AOS_FATFS_SUPPORT_RAM
|
||||
case DEV_RAM:
|
||||
return RAM_disk_ioctl(cmd, buff);
|
||||
#endif
|
||||
|
||||
default:
|
||||
break;
|
||||
}
|
||||
return RES_PARERR;
|
||||
}
|
||||
597
Living_SDK/kernel/modules/fs/fatfs/fatfs.c
Normal file
597
Living_SDK/kernel/modules/fs/fatfs/fatfs.c
Normal file
|
|
@ -0,0 +1,597 @@
|
|||
/*
|
||||
* Copyright (C) 2015-2017 Alibaba Group Holding Limited
|
||||
*/
|
||||
#include <stdio.h>
|
||||
#include <string.h>
|
||||
#include <sys/fcntl.h>
|
||||
#include "fatfs.h"
|
||||
#include "fatfs_diskio.h"
|
||||
#include "ff.h"
|
||||
#include "vfs_inode.h"
|
||||
#include "vfs_register.h"
|
||||
|
||||
#if FF_USE_LFN == 0
|
||||
#define MAX_NAME_LEN 12
|
||||
#else
|
||||
#define MAX_NAME_LEN FF_MAX_LFN
|
||||
#endif
|
||||
|
||||
typedef struct _fsid_map_t
|
||||
{
|
||||
int index; /* Device index */
|
||||
const char *root; /* The mount point of the physical device */
|
||||
const char *id; /* The partition id of the device in fatfs */
|
||||
}fsid_map_t;
|
||||
|
||||
typedef struct _fat_dir_t
|
||||
{
|
||||
aos_dir_t dir;
|
||||
FF_DIR ffdir;
|
||||
FILINFO filinfo;
|
||||
aos_dirent_t cur_dirent;
|
||||
}fat_dir_t;
|
||||
|
||||
static fsid_map_t g_fsid[] = {
|
||||
{ DEV_MMC, MMC_MOUNTPOINT, MMC_PARTITION_ID },
|
||||
{ DEV_USB, USB_MOUNTPOINT, USB_PARTITION_ID },
|
||||
{ DEV_RAM, RAM_MOUNTPOINT, RAM_PARTITION_ID }
|
||||
};
|
||||
|
||||
static FATFS *g_fatfs[FF_VOLUMES] = {0};
|
||||
|
||||
#if FF_USE_LFN == 3 /* Dynamic memory allocation */
|
||||
|
||||
/*------------------------------------------------------------------------*/
|
||||
/* Allocate a memory block */
|
||||
/*------------------------------------------------------------------------*/
|
||||
|
||||
void* ff_memalloc ( /* Returns pointer to the allocated memory block (null on not enough core) */
|
||||
UINT msize /* Number of bytes to allocate */
|
||||
)
|
||||
{
|
||||
return (void *)aos_malloc(msize); /* Allocate a new memory block with POSIX API */
|
||||
}
|
||||
|
||||
|
||||
/*------------------------------------------------------------------------*/
|
||||
/* Free a memory block */
|
||||
/*------------------------------------------------------------------------*/
|
||||
|
||||
void ff_memfree (
|
||||
void* mblock /* Pointer to the memory block to free */
|
||||
)
|
||||
{
|
||||
aos_free(mblock); /* Free the memory block with POSIX API */
|
||||
}
|
||||
|
||||
#endif
|
||||
|
||||
|
||||
|
||||
#if FF_FS_REENTRANT /* Mutal exclusion */
|
||||
|
||||
/*------------------------------------------------------------------------*/
|
||||
/* Create a Synchronization Object */
|
||||
/*------------------------------------------------------------------------*/
|
||||
/* This function is called in f_mount() function to create a new
|
||||
/ synchronization object for the volume, such as semaphore and mutex.
|
||||
/ When a 0 is returned, the f_mount() function fails with FR_INT_ERR.
|
||||
*/
|
||||
|
||||
//const osMutexDef_t Mutex[FF_VOLUMES]; /* CMSIS-RTOS */
|
||||
|
||||
|
||||
int ff_cre_syncobj ( /* 1:Function succeeded, 0:Could not create the sync object */
|
||||
BYTE vol, /* Corresponding volume (logical drive number) */
|
||||
FF_SYNC_t *sobj /* Pointer to return the created sync object */
|
||||
)
|
||||
{
|
||||
int ret = aos_mutex_new(sobj);
|
||||
return (ret == FR_OK) ? 1 : 0;
|
||||
}
|
||||
|
||||
|
||||
/*------------------------------------------------------------------------*/
|
||||
/* Delete a Synchronization Object */
|
||||
/*------------------------------------------------------------------------*/
|
||||
/* This function is called in f_mount() function to delete a synchronization
|
||||
/ object that created with ff_cre_syncobj() function. When a 0 is returned,
|
||||
/ the f_mount() function fails with FR_INT_ERR.
|
||||
*/
|
||||
|
||||
int ff_del_syncobj ( /* 1:Function succeeded, 0:Could not delete due to an error */
|
||||
FF_SYNC_t sobj /* Sync object tied to the logical drive to be deleted */
|
||||
)
|
||||
{
|
||||
aos_mutex_free(&sobj);
|
||||
return 1;
|
||||
}
|
||||
|
||||
|
||||
/*------------------------------------------------------------------------*/
|
||||
/* Request Grant to Access the Volume */
|
||||
/*------------------------------------------------------------------------*/
|
||||
/* This function is called on entering file functions to lock the volume.
|
||||
/ When a 0 is returned, the file function fails with FR_TIMEOUT.
|
||||
*/
|
||||
|
||||
int ff_req_grant ( /* 1:Got a grant to access the volume, 0:Could not get a grant */
|
||||
FF_SYNC_t sobj /* Sync object to wait */
|
||||
)
|
||||
{
|
||||
int ret = aos_mutex_lock(&sobj, FF_FS_TIMEOUT);
|
||||
return (ret == FR_OK) ? 1 : 0;
|
||||
}
|
||||
|
||||
|
||||
/*------------------------------------------------------------------------*/
|
||||
/* Release Grant to Access the Volume */
|
||||
/*------------------------------------------------------------------------*/
|
||||
/* This function is called on leaving file functions to unlock the volume.
|
||||
*/
|
||||
|
||||
void ff_rel_grant (
|
||||
FF_SYNC_t sobj /* Sync object to be signaled */
|
||||
)
|
||||
{
|
||||
aos_mutex_unlock(&sobj);
|
||||
}
|
||||
|
||||
#endif
|
||||
|
||||
static int get_disk_index(int pdrv)
|
||||
{
|
||||
int index;
|
||||
for(index = 0; index < FF_VOLUMES; index++) {
|
||||
if (g_fsid[index].index == pdrv)
|
||||
return index;
|
||||
}
|
||||
|
||||
return -1;
|
||||
}
|
||||
|
||||
static char* translate_relative_path(const char *path)
|
||||
{
|
||||
int len, prefix_len;
|
||||
char *relpath, *p;
|
||||
BYTE pdrv;
|
||||
|
||||
if (!path)
|
||||
return NULL;
|
||||
|
||||
len = strlen(path);
|
||||
for (pdrv = 0; pdrv < FF_VOLUMES; pdrv++) {
|
||||
prefix_len = strlen(g_fsid[pdrv].root);
|
||||
if (strncmp(g_fsid[pdrv].root, path, prefix_len) == 0)
|
||||
break;
|
||||
}
|
||||
|
||||
if (pdrv == FF_VOLUMES)
|
||||
return NULL;
|
||||
|
||||
relpath = (char *)aos_malloc(len + 1);
|
||||
if (!relpath)
|
||||
return NULL;
|
||||
|
||||
memset(relpath, 0, len + 1);
|
||||
memcpy(relpath, g_fsid[pdrv].id, strlen(g_fsid[pdrv].id));
|
||||
|
||||
if (len > prefix_len) {
|
||||
p = (char *)(path + strlen(g_fsid[pdrv].root) + 1);
|
||||
memcpy(relpath + strlen(g_fsid[pdrv].id), p, len - prefix_len - 1);
|
||||
}
|
||||
|
||||
relpath[len] = '\0';
|
||||
|
||||
return relpath;
|
||||
}
|
||||
|
||||
static int fatfs_mode_conv(int m)
|
||||
{
|
||||
int res = 0;
|
||||
int acc_mode = m & O_ACCMODE;
|
||||
if (acc_mode == O_RDONLY) {
|
||||
res |= FA_READ;
|
||||
} else if (acc_mode == O_WRONLY) {
|
||||
res |= FA_WRITE;
|
||||
} else if (acc_mode == O_RDWR) {
|
||||
res |= FA_READ | FA_WRITE;
|
||||
}
|
||||
if ((m & O_CREAT) && (m & O_EXCL)) {
|
||||
res |= FA_CREATE_NEW;
|
||||
} else if ((m & O_CREAT) && (m & O_TRUNC)) {
|
||||
res |= FA_CREATE_ALWAYS;
|
||||
} else if (m & O_APPEND) {
|
||||
res |= FA_OPEN_ALWAYS;
|
||||
} else {
|
||||
res |= FA_OPEN_EXISTING;
|
||||
}
|
||||
return res;
|
||||
}
|
||||
|
||||
|
||||
static int fatfs_open(file_t *fp, const char *path, int flags)
|
||||
{
|
||||
int ret = -EPERM;
|
||||
FIL *f = NULL;
|
||||
char *relpath = NULL;
|
||||
|
||||
f = (FIL *)aos_malloc(sizeof(FIL));
|
||||
if (!f)
|
||||
return -ENOMEM;
|
||||
|
||||
relpath = translate_relative_path(path);
|
||||
if (!relpath) {
|
||||
aos_free(f);
|
||||
return -EINVAL;
|
||||
}
|
||||
|
||||
ret = f_open(f, relpath, fatfs_mode_conv(flags));
|
||||
if (ret == FR_OK) {
|
||||
fp->f_arg = (void *)f;
|
||||
aos_free(relpath);
|
||||
return ret;
|
||||
}
|
||||
|
||||
aos_free(relpath);
|
||||
aos_free(f);
|
||||
return ret;
|
||||
}
|
||||
|
||||
static int fatfs_close(file_t *fp)
|
||||
{
|
||||
int ret = -EPERM;
|
||||
FIL *f = (FIL *)(fp->f_arg);
|
||||
|
||||
if (f) {
|
||||
ret = f_close(f);
|
||||
if (ret == FR_OK) {
|
||||
aos_free(f);
|
||||
fp->f_arg = NULL;
|
||||
}
|
||||
}
|
||||
|
||||
return ret;
|
||||
}
|
||||
|
||||
static ssize_t fatfs_read(file_t *fp, char *buf, size_t len)
|
||||
{
|
||||
ssize_t nbytes;
|
||||
int ret = -EPERM;
|
||||
FIL *f = (FIL *)(fp->f_arg);
|
||||
|
||||
if (f) {
|
||||
if ((ret = f_read(f, (void *)buf, (UINT)len, (UINT *)&nbytes)) == FR_OK)
|
||||
return nbytes;
|
||||
}
|
||||
|
||||
return ret;
|
||||
}
|
||||
|
||||
static ssize_t fatfs_write(file_t *fp, const char *buf, size_t len)
|
||||
{
|
||||
ssize_t nbytes;
|
||||
int ret = -EPERM;
|
||||
FIL *f = (FIL *)(fp->f_arg);
|
||||
|
||||
if (f) {
|
||||
if ((ret = f_write(f, (void *)buf, (UINT)len, (UINT *)&nbytes)) == FR_OK)
|
||||
return nbytes;
|
||||
}
|
||||
|
||||
return ret;
|
||||
}
|
||||
|
||||
static off_t fatfs_lseek(file_t *fp, off_t off, int whence)
|
||||
{
|
||||
off_t new_pos = 0;
|
||||
int ret = -EPERM;
|
||||
FIL *f = (FIL *)(fp->f_arg);
|
||||
|
||||
if (f) {
|
||||
if (whence == SEEK_SET) {
|
||||
new_pos = off;
|
||||
} else if (whence == SEEK_CUR) {
|
||||
off_t cur_pos = f_tell(f);
|
||||
new_pos = cur_pos + off;
|
||||
} else if (whence == SEEK_END) {
|
||||
off_t size = f_size(f);
|
||||
new_pos = size + off;
|
||||
} else {
|
||||
return -EINVAL;
|
||||
}
|
||||
|
||||
if ((ret = f_lseek(f, new_pos)) != FR_OK) {
|
||||
return ret;
|
||||
}
|
||||
}
|
||||
|
||||
return new_pos;
|
||||
}
|
||||
|
||||
static int fatfs_sync(file_t *fp)
|
||||
{
|
||||
int ret = -EPERM;
|
||||
FIL *f = (FIL *)(fp->f_arg);
|
||||
|
||||
if (f) {
|
||||
ret = f_sync(f);
|
||||
}
|
||||
|
||||
return ret;
|
||||
}
|
||||
|
||||
static int fatfs_stat(file_t *fp, const char *path, struct stat *st)
|
||||
{
|
||||
char *relpath = NULL;
|
||||
FILINFO info;
|
||||
int ret;
|
||||
|
||||
relpath = translate_relative_path(path);
|
||||
if (!relpath)
|
||||
return -EINVAL;
|
||||
|
||||
if ((ret = f_stat(relpath, &info)) == FR_OK) {
|
||||
st->st_size = info.fsize;
|
||||
st->st_mode = S_IRWXU | S_IRWXG | S_IRWXO |
|
||||
((info.fattrib & AM_DIR) ? S_IFDIR : S_IFREG);
|
||||
}
|
||||
|
||||
aos_free(relpath);
|
||||
return ret;
|
||||
}
|
||||
|
||||
static int fatfs_unlink(file_t *fp, const char *path)
|
||||
{
|
||||
char *relpath = NULL;
|
||||
int ret;
|
||||
|
||||
relpath = translate_relative_path(path);
|
||||
if (!relpath)
|
||||
return -EINVAL;
|
||||
|
||||
ret = f_unlink(relpath);
|
||||
|
||||
aos_free(relpath);
|
||||
return ret;
|
||||
}
|
||||
|
||||
static int fatfs_rename(file_t *fp, const char *oldpath, const char *newpath)
|
||||
{
|
||||
int ret;
|
||||
char *oldname = NULL;
|
||||
char *newname = NULL;
|
||||
|
||||
oldname = translate_relative_path(oldpath);
|
||||
if (!oldname)
|
||||
return -EINVAL;
|
||||
|
||||
newname = translate_relative_path(newpath);
|
||||
if (!newname) {
|
||||
aos_free(oldname);
|
||||
return -EINVAL;
|
||||
}
|
||||
|
||||
ret = f_rename(oldname, newname);
|
||||
|
||||
aos_free(oldname);
|
||||
aos_free(newname);
|
||||
return ret;
|
||||
}
|
||||
|
||||
static aos_dir_t* fatfs_opendir(file_t *fp, const char *path)
|
||||
{
|
||||
fat_dir_t *dp = NULL;
|
||||
char *relpath = NULL;
|
||||
|
||||
relpath = translate_relative_path(path);
|
||||
if (!relpath)
|
||||
return NULL;
|
||||
|
||||
dp = (fat_dir_t *)aos_malloc(sizeof(fat_dir_t) + MAX_NAME_LEN + 1);
|
||||
if (!dp) {
|
||||
aos_free(relpath);
|
||||
return NULL;
|
||||
}
|
||||
|
||||
memset(dp, 0, sizeof(fat_dir_t) + MAX_NAME_LEN + 1);
|
||||
if (f_opendir(&dp->ffdir, relpath) == FR_OK) {
|
||||
aos_free(relpath);
|
||||
return (aos_dir_t *)dp;
|
||||
}
|
||||
|
||||
aos_free(relpath);
|
||||
aos_free(dp);
|
||||
return NULL;
|
||||
}
|
||||
|
||||
static aos_dirent_t* fatfs_readdir(file_t *fp, aos_dir_t *dir)
|
||||
{
|
||||
fat_dir_t *dp = (fat_dir_t *)dir;
|
||||
aos_dirent_t *out_dirent;
|
||||
|
||||
if (!dp)
|
||||
return NULL;
|
||||
|
||||
if (f_readdir(&dp->ffdir, &dp->filinfo) != FR_OK)
|
||||
return NULL;
|
||||
|
||||
if (dp->filinfo.fname[0] == 0)
|
||||
return NULL;
|
||||
|
||||
dp->cur_dirent.d_ino = 0;
|
||||
if (dp->filinfo.fattrib & AM_DIR) {
|
||||
dp->cur_dirent.d_type = AM_DIR;
|
||||
}
|
||||
|
||||
strncpy(dp->cur_dirent.d_name, dp->filinfo.fname, MAX_NAME_LEN);
|
||||
dp->cur_dirent.d_name[MAX_NAME_LEN] = '\0';
|
||||
|
||||
out_dirent = &dp->cur_dirent;
|
||||
return out_dirent;
|
||||
}
|
||||
|
||||
static int fatfs_closedir(file_t *fp, aos_dir_t *dir)
|
||||
{
|
||||
int ret = -EPERM;
|
||||
fat_dir_t *dp = (fat_dir_t *)dir;
|
||||
|
||||
if (!dp)
|
||||
return -EINVAL;
|
||||
|
||||
ret = f_closedir(&dp->ffdir);
|
||||
if (ret == FR_OK)
|
||||
aos_free(dp);
|
||||
|
||||
return ret;
|
||||
}
|
||||
|
||||
static int fatfs_mkdir(file_t *fp, const char *path)
|
||||
{
|
||||
int ret = -EPERM;
|
||||
char *relpath = NULL;
|
||||
|
||||
relpath = translate_relative_path(path);
|
||||
if (!relpath)
|
||||
return -EINVAL;
|
||||
|
||||
ret = f_mkdir(relpath);
|
||||
|
||||
aos_free(relpath);
|
||||
return ret;
|
||||
}
|
||||
|
||||
static const fs_ops_t fatfs_ops = {
|
||||
.open = &fatfs_open,
|
||||
.close = &fatfs_close,
|
||||
.read = &fatfs_read,
|
||||
.write = &fatfs_write,
|
||||
.lseek = &fatfs_lseek,
|
||||
.sync = &fatfs_sync,
|
||||
.stat = &fatfs_stat,
|
||||
.unlink = &fatfs_unlink,
|
||||
.rename = &fatfs_rename,
|
||||
.opendir = &fatfs_opendir,
|
||||
.readdir = &fatfs_readdir,
|
||||
.closedir = &fatfs_closedir,
|
||||
.mkdir = &fatfs_mkdir,
|
||||
.ioctl = NULL
|
||||
};
|
||||
|
||||
static int fatfs_dev_register(int pdrv)
|
||||
{
|
||||
int err, index;
|
||||
FATFS *fatfs = NULL;
|
||||
|
||||
index = get_disk_index(pdrv);
|
||||
if (index < 0)
|
||||
return -EINVAL;
|
||||
|
||||
if (g_fatfs[index] != NULL)
|
||||
return FR_OK;
|
||||
|
||||
fatfs = (FATFS *)aos_malloc(sizeof(FATFS));
|
||||
if (!fatfs)
|
||||
return -ENOMEM;
|
||||
|
||||
err = f_mount(fatfs, g_fsid[index].id, 1);
|
||||
|
||||
if (err == FR_OK) {
|
||||
g_fatfs[index] = fatfs;
|
||||
return aos_register_fs(g_fsid[index].root, &fatfs_ops, NULL);
|
||||
}
|
||||
|
||||
#if FF_USE_MKFS && !FF_FS_READONLY
|
||||
if (err == FR_NO_FILESYSTEM) {
|
||||
char *work = (char *)aos_malloc(FF_MAX_SS);
|
||||
if (!work) {
|
||||
err = -ENOMEM;
|
||||
goto error;
|
||||
}
|
||||
|
||||
BYTE opt = FM_ANY;
|
||||
disk_ioctl(g_fsid[index].index, GET_FORMAT_OPTION, &opt);
|
||||
|
||||
err = f_mkfs(g_fsid[index].id, opt, 0, work, FF_MAX_SS);
|
||||
aos_free(work);
|
||||
|
||||
if (err != FR_OK)
|
||||
goto error;
|
||||
|
||||
f_mount(NULL, g_fsid[index].id, 1);
|
||||
err = f_mount(fatfs, g_fsid[index].id, 1);
|
||||
|
||||
if (err == FR_OK) {
|
||||
g_fatfs[index] = fatfs;
|
||||
return aos_register_fs(g_fsid[index].root, &fatfs_ops, NULL);
|
||||
}
|
||||
}
|
||||
#endif
|
||||
error:
|
||||
aos_free(fatfs);
|
||||
return err;
|
||||
}
|
||||
|
||||
|
||||
static int fatfs_dev_unregister(int pdrv)
|
||||
{
|
||||
int err = FR_OK;
|
||||
int index;
|
||||
|
||||
index = get_disk_index(pdrv);
|
||||
if (index < 0)
|
||||
return -EINVAL;
|
||||
|
||||
err = aos_unregister_fs(g_fsid[index].root);
|
||||
if (err == FR_OK) {
|
||||
f_mount(NULL, g_fsid[index].id, 1);
|
||||
aos_free(g_fatfs[index]);
|
||||
g_fatfs[index] = NULL;
|
||||
}
|
||||
|
||||
return err;
|
||||
}
|
||||
|
||||
int fatfs_register(void)
|
||||
{
|
||||
int err = -EINVAL;
|
||||
|
||||
#ifdef CONFIG_AOS_FATFS_SUPPORT_MMC
|
||||
if ((err = fatfs_dev_register(DEV_MMC)) != FR_OK)
|
||||
return err;
|
||||
#endif
|
||||
|
||||
#ifdef CONFIG_AOS_FATFS_SUPPORT_USB
|
||||
if ((err = fatfs_dev_register(DEV_USB)) != FR_OK)
|
||||
return err;
|
||||
#endif
|
||||
|
||||
#ifdef CONFIG_AOS_FATFS_SUPPORT_RAM
|
||||
if ((err = fatfs_dev_register(DEV_RAM)) != FR_OK)
|
||||
return err;
|
||||
#endif
|
||||
|
||||
return err;
|
||||
}
|
||||
|
||||
int fatfs_unregister(void)
|
||||
{
|
||||
int err = -EINVAL;
|
||||
|
||||
#ifdef CONFIG_AOS_FATFS_SUPPORT_MMC
|
||||
if ((err = fatfs_dev_unregister(DEV_MMC)) != FR_OK)
|
||||
return err;
|
||||
#endif
|
||||
|
||||
#ifdef CONFIG_AOS_FATFS_SUPPORT_USB
|
||||
if ((err = fatfs_dev_unregister(DEV_USB)) != FR_OK)
|
||||
return err;
|
||||
#endif
|
||||
|
||||
#ifdef CONFIG_AOS_FATFS_SUPPORT_RAM
|
||||
if ((err = fatfs_dev_unregister(DEV_RAM)) != FR_OK)
|
||||
return err;
|
||||
#endif
|
||||
|
||||
return err;
|
||||
}
|
||||
18
Living_SDK/kernel/modules/fs/fatfs/fatfs.mk
Normal file
18
Living_SDK/kernel/modules/fs/fatfs/fatfs.mk
Normal file
|
|
@ -0,0 +1,18 @@
|
|||
NAME := fatfs
|
||||
|
||||
$(NAME)_TYPE := kernel
|
||||
|
||||
$(NAME)_SOURCES := fatfs.c
|
||||
$(NAME)_SOURCES += diskio.c
|
||||
$(NAME)_SOURCES += ff/ff.c
|
||||
$(NAME)_SOURCES += ff/ffunicode.c
|
||||
|
||||
#default gcc
|
||||
ifeq ($(COMPILER),)
|
||||
$(NAME)_CFLAGS += -Wall -Werror
|
||||
else ifeq ($(COMPILER),gcc)
|
||||
$(NAME)_CFLAGS += -Wall -Werror
|
||||
endif
|
||||
|
||||
GLOBAL_INCLUDES += include ff/include
|
||||
GLOBAL_DEFINES += AOS_FATFS
|
||||
6203
Living_SDK/kernel/modules/fs/fatfs/ff/ff.c
Normal file
6203
Living_SDK/kernel/modules/fs/fatfs/ff/ff.c
Normal file
File diff suppressed because it is too large
Load diff
5730
Living_SDK/kernel/modules/fs/fatfs/ff/ffunicode.c
Normal file
5730
Living_SDK/kernel/modules/fs/fatfs/ff/ffunicode.c
Normal file
File diff suppressed because it is too large
Load diff
87
Living_SDK/kernel/modules/fs/fatfs/ff/include/diskio.h
Normal file
87
Living_SDK/kernel/modules/fs/fatfs/ff/include/diskio.h
Normal file
|
|
@ -0,0 +1,87 @@
|
|||
/*-----------------------------------------------------------------------/
|
||||
/ Low level disk interface modlue include file (C)ChaN, 2014 /
|
||||
/-----------------------------------------------------------------------*/
|
||||
|
||||
#ifndef _DISKIO_DEFINED
|
||||
#define _DISKIO_DEFINED
|
||||
|
||||
#ifdef __cplusplus
|
||||
extern "C" {
|
||||
#endif
|
||||
|
||||
#include "integer.h"
|
||||
|
||||
|
||||
/* Status of Disk Functions */
|
||||
typedef BYTE DSTATUS;
|
||||
|
||||
/* Results of Disk Functions */
|
||||
typedef enum {
|
||||
RES_OK = 0, /* 0: Successful */
|
||||
RES_ERROR, /* 1: R/W Error */
|
||||
RES_WRPRT, /* 2: Write Protected */
|
||||
RES_NOTRDY, /* 3: Not Ready */
|
||||
RES_PARERR /* 4: Invalid Parameter */
|
||||
} DRESULT;
|
||||
|
||||
|
||||
/*---------------------------------------*/
|
||||
/* Prototypes for disk control functions */
|
||||
|
||||
/* Redefine names of disk IO functions to prevent name collisions */
|
||||
#define disk_initialize ff_disk_initialize
|
||||
#define disk_status ff_disk_status
|
||||
#define disk_read ff_disk_read
|
||||
#define disk_write ff_disk_write
|
||||
#define disk_ioctl ff_disk_ioctl
|
||||
|
||||
DSTATUS disk_initialize (BYTE pdrv);
|
||||
DSTATUS disk_status (BYTE pdrv);
|
||||
DRESULT disk_read (BYTE pdrv, BYTE* buff, DWORD sector, UINT count);
|
||||
DRESULT disk_write (BYTE pdrv, const BYTE* buff, DWORD sector, UINT count);
|
||||
DRESULT disk_ioctl (BYTE pdrv, BYTE cmd, void* buff);
|
||||
|
||||
|
||||
/* Disk Status Bits (DSTATUS) */
|
||||
|
||||
#define STA_NOINIT 0x01 /* Drive not initialized */
|
||||
#define STA_NODISK 0x02 /* No medium in the drive */
|
||||
#define STA_PROTECT 0x04 /* Write protected */
|
||||
|
||||
|
||||
/* Command code for disk_ioctrl fucntion */
|
||||
|
||||
/* Generic command (Used by FatFs) */
|
||||
#define CTRL_SYNC 0 /* Complete pending write process (needed at _FS_READONLY == 0) */
|
||||
#define GET_SECTOR_COUNT 1 /* Get media size (needed at _USE_MKFS == 1) */
|
||||
#define GET_SECTOR_SIZE 2 /* Get sector size (needed at _MAX_SS != _MIN_SS) */
|
||||
#define GET_BLOCK_SIZE 3 /* Get erase block size (needed at _USE_MKFS == 1) */
|
||||
#define CTRL_TRIM 4 /* Inform device that the data on the block of sectors is no longer used (needed at _USE_TRIM == 1) */
|
||||
#define GET_FORMAT_OPTION 9 /* Get media format option (need at _USE_MKFS == 1) */
|
||||
|
||||
/* Generic command (Not used by FatFs) */
|
||||
#define CTRL_POWER 5 /* Get/Set power status */
|
||||
#define CTRL_LOCK 6 /* Lock/Unlock media removal */
|
||||
#define CTRL_EJECT 7 /* Eject media */
|
||||
#define CTRL_FORMAT 8 /* Create physical format on the media */
|
||||
|
||||
/* MMC/SDC specific ioctl command */
|
||||
#define MMC_GET_TYPE 10 /* Get card type */
|
||||
#define MMC_GET_CSD 11 /* Get CSD */
|
||||
#define MMC_GET_CID 12 /* Get CID */
|
||||
#define MMC_GET_OCR 13 /* Get OCR */
|
||||
#define MMC_GET_SDSTAT 14 /* Get SD status */
|
||||
#define ISDIO_READ 55 /* Read data form SD iSDIO register */
|
||||
#define ISDIO_WRITE 56 /* Write data to SD iSDIO register */
|
||||
#define ISDIO_MRITE 57 /* Masked write data to SD iSDIO register */
|
||||
|
||||
/* ATA/CF specific ioctl command */
|
||||
#define ATA_GET_REV 20 /* Get F/W revision */
|
||||
#define ATA_GET_MODEL 21 /* Get model name */
|
||||
#define ATA_GET_SN 22 /* Get serial number */
|
||||
|
||||
#ifdef __cplusplus
|
||||
}
|
||||
#endif
|
||||
|
||||
#endif
|
||||
365
Living_SDK/kernel/modules/fs/fatfs/ff/include/ff.h
Normal file
365
Living_SDK/kernel/modules/fs/fatfs/ff/include/ff.h
Normal file
|
|
@ -0,0 +1,365 @@
|
|||
/*----------------------------------------------------------------------------/
|
||||
/ FatFs - Generic FAT Filesystem module R0.13 /
|
||||
/-----------------------------------------------------------------------------/
|
||||
/
|
||||
/ Copyright (C) 2017, ChaN, all right reserved.
|
||||
/
|
||||
/ FatFs module is an open source software. Redistribution and use of FatFs in
|
||||
/ source and binary forms, with or without modification, are permitted provided
|
||||
/ that the following condition is met:
|
||||
|
||||
/ 1. Redistributions of source code must retain the above copyright notice,
|
||||
/ this condition and the following disclaimer.
|
||||
/
|
||||
/ This software is provided by the copyright holder and contributors "AS IS"
|
||||
/ and any warranties related to this software are DISCLAIMED.
|
||||
/ The copyright owner or contributors be NOT LIABLE for any damages caused
|
||||
/ by use of this software.
|
||||
/
|
||||
/----------------------------------------------------------------------------*/
|
||||
|
||||
|
||||
#ifndef FF_DEFINED
|
||||
#define FF_DEFINED 87030 /* Revision ID */
|
||||
|
||||
#ifdef __cplusplus
|
||||
extern "C" {
|
||||
#endif
|
||||
|
||||
#include <errno.h> /* Standard errno definations */
|
||||
#include "integer.h" /* Basic integer types */
|
||||
#include "ffconf.h" /* FatFs configuration options */
|
||||
|
||||
#if FF_DEFINED != FFCONF_DEF
|
||||
#error Wrong configuration file (ffconf.h).
|
||||
#endif
|
||||
|
||||
|
||||
|
||||
/* Definitions of volume management */
|
||||
|
||||
#if FF_MULTI_PARTITION /* Multiple partition configuration */
|
||||
typedef struct {
|
||||
BYTE pd; /* Physical drive number */
|
||||
BYTE pt; /* Partition: 0:Auto detect, 1-4:Forced partition) */
|
||||
} PARTITION;
|
||||
extern PARTITION VolToPart[]; /* Volume - Partition resolution table */
|
||||
#endif
|
||||
|
||||
|
||||
|
||||
/* Type of path name strings on FatFs API */
|
||||
|
||||
#if FF_LFN_UNICODE && FF_USE_LFN /* Unicode (UTF-16) string */
|
||||
#ifndef _INC_TCHAR
|
||||
typedef WCHAR TCHAR;
|
||||
#define _T(x) L ## x
|
||||
#define _TEXT(x) L ## x
|
||||
#define _INC_TCHAR
|
||||
#endif
|
||||
#else /* ANSI/OEM string */
|
||||
#ifndef _INC_TCHAR
|
||||
typedef char TCHAR;
|
||||
#define _T(x) x
|
||||
#define _TEXT(x) x
|
||||
#define _INC_TCHAR
|
||||
#endif
|
||||
#endif
|
||||
|
||||
|
||||
|
||||
/* Type of file size variables */
|
||||
|
||||
#if FF_FS_EXFAT
|
||||
#if !FF_USE_LFN
|
||||
#error LFN must be enabled when enable exFAT
|
||||
#endif
|
||||
typedef QWORD FSIZE_t;
|
||||
#else
|
||||
typedef DWORD FSIZE_t;
|
||||
#endif
|
||||
|
||||
|
||||
|
||||
/* Filesystem object structure (FATFS) */
|
||||
|
||||
typedef struct {
|
||||
BYTE fs_type; /* Filesystem type (0:N/A) */
|
||||
BYTE pdrv; /* Physical drive number */
|
||||
BYTE n_fats; /* Number of FATs (1 or 2) */
|
||||
BYTE wflag; /* win[] flag (b0:dirty) */
|
||||
BYTE fsi_flag; /* FSINFO flags (b7:disabled, b0:dirty) */
|
||||
WORD id; /* Volume mount ID */
|
||||
WORD n_rootdir; /* Number of root directory entries (FAT12/16) */
|
||||
WORD csize; /* Cluster size [sectors] */
|
||||
#if FF_MAX_SS != FF_MIN_SS
|
||||
WORD ssize; /* Sector size (512, 1024, 2048 or 4096) */
|
||||
#endif
|
||||
#if FF_USE_LFN
|
||||
WCHAR* lfnbuf; /* LFN working buffer */
|
||||
#endif
|
||||
#if FF_FS_EXFAT
|
||||
BYTE* dirbuf; /* Directory entry block scratchpad buffer for exFAT */
|
||||
#endif
|
||||
#if FF_FS_REENTRANT
|
||||
FF_SYNC_t sobj; /* Identifier of sync object */
|
||||
#endif
|
||||
#if !FF_FS_READONLY
|
||||
DWORD last_clst; /* Last allocated cluster */
|
||||
DWORD free_clst; /* Number of free clusters */
|
||||
#endif
|
||||
#if FF_FS_RPATH
|
||||
DWORD cdir; /* Current directory start cluster (0:root) */
|
||||
#if FF_FS_EXFAT
|
||||
DWORD cdc_scl; /* Containing directory start cluster (invalid when cdir is 0) */
|
||||
DWORD cdc_size; /* b31-b8:Size of containing directory, b7-b0: Chain status */
|
||||
DWORD cdc_ofs; /* Offset in the containing directory (invalid when cdir is 0) */
|
||||
#endif
|
||||
#endif
|
||||
DWORD n_fatent; /* Number of FAT entries (number of clusters + 2) */
|
||||
DWORD fsize; /* Size of an FAT [sectors] */
|
||||
DWORD volbase; /* Volume base sector */
|
||||
DWORD fatbase; /* FAT base sector */
|
||||
DWORD dirbase; /* Root directory base sector/cluster */
|
||||
DWORD database; /* Data base sector */
|
||||
DWORD winsect; /* Current sector appearing in the win[] */
|
||||
BYTE win[FF_MAX_SS]; /* Disk access window for Directory, FAT (and file data at tiny cfg) */
|
||||
} FATFS;
|
||||
|
||||
|
||||
|
||||
/* Object ID and allocation information (FFOBJID) */
|
||||
|
||||
typedef struct {
|
||||
FATFS* fs; /* Pointer to the hosting volume of this object */
|
||||
WORD id; /* Hosting volume mount ID */
|
||||
BYTE attr; /* Object attribute */
|
||||
BYTE stat; /* Object chain status (b1-0: =0:not contiguous, =2:contiguous, =3:flagmented in this session, b2:sub-directory stretched) */
|
||||
DWORD sclust; /* Object data start cluster (0:no cluster or root directory) */
|
||||
FSIZE_t objsize; /* Object size (valid when sclust != 0) */
|
||||
#if FF_FS_EXFAT
|
||||
DWORD n_cont; /* Size of first fragment - 1 (valid when stat == 3) */
|
||||
DWORD n_frag; /* Size of last fragment needs to be written to FAT (valid when not zero) */
|
||||
DWORD c_scl; /* Containing directory start cluster (valid when sclust != 0) */
|
||||
DWORD c_size; /* b31-b8:Size of containing directory, b7-b0: Chain status (valid when c_scl != 0) */
|
||||
DWORD c_ofs; /* Offset in the containing directory (valid when file object and sclust != 0) */
|
||||
#endif
|
||||
#if FF_FS_LOCK
|
||||
UINT lockid; /* File lock ID origin from 1 (index of file semaphore table Files[]) */
|
||||
#endif
|
||||
} FFOBJID;
|
||||
|
||||
|
||||
|
||||
/* File object structure (FIL) */
|
||||
|
||||
typedef struct {
|
||||
FFOBJID obj; /* Object identifier (must be the 1st member to detect invalid object pointer) */
|
||||
BYTE flag; /* File status flags */
|
||||
BYTE err; /* Abort flag (error code) */
|
||||
FSIZE_t fptr; /* File read/write pointer (Zeroed on file open) */
|
||||
DWORD clust; /* Current cluster of fpter (invalid when fptr is 0) */
|
||||
DWORD sect; /* Sector number appearing in buf[] (0:invalid) */
|
||||
#if !FF_FS_READONLY
|
||||
DWORD dir_sect; /* Sector number containing the directory entry (not used at exFAT) */
|
||||
BYTE* dir_ptr; /* Pointer to the directory entry in the win[] (not used at exFAT) */
|
||||
#endif
|
||||
#if FF_USE_FASTSEEK
|
||||
DWORD* cltbl; /* Pointer to the cluster link map table (nulled on open, set by application) */
|
||||
#endif
|
||||
#if !FF_FS_TINY
|
||||
BYTE buf[FF_MAX_SS]; /* File private data read/write window */
|
||||
#endif
|
||||
} FIL;
|
||||
|
||||
|
||||
|
||||
/* Directory object structure (DIR) */
|
||||
|
||||
typedef struct {
|
||||
FFOBJID obj; /* Object identifier */
|
||||
DWORD dptr; /* Current read/write offset */
|
||||
DWORD clust; /* Current cluster */
|
||||
DWORD sect; /* Current sector (0:Read operation has terminated) */
|
||||
BYTE* dir; /* Pointer to the directory item in the win[] */
|
||||
BYTE fn[12]; /* SFN (in/out) {body[8],ext[3],status[1]} */
|
||||
#if FF_USE_LFN
|
||||
DWORD blk_ofs; /* Offset of current entry block being processed (0xFFFFFFFF:Invalid) */
|
||||
#endif
|
||||
#if FF_USE_FIND
|
||||
const TCHAR* pat; /* Pointer to the name matching pattern */
|
||||
#endif
|
||||
} FF_DIR;
|
||||
|
||||
|
||||
|
||||
/* File information structure (FILINFO) */
|
||||
|
||||
typedef struct {
|
||||
FSIZE_t fsize; /* File size */
|
||||
WORD fdate; /* Modified date */
|
||||
WORD ftime; /* Modified time */
|
||||
BYTE fattrib; /* File attribute */
|
||||
#if FF_USE_LFN
|
||||
TCHAR altname[13]; /* Altenative file name */
|
||||
TCHAR fname[FF_MAX_LFN + 1]; /* Primary file name */
|
||||
#else
|
||||
TCHAR fname[13]; /* File name */
|
||||
#endif
|
||||
} FILINFO;
|
||||
|
||||
|
||||
|
||||
/* File function return code (FRESULT) */
|
||||
|
||||
typedef enum {
|
||||
FR_OK = 0, /* (0) Succeeded */
|
||||
FR_DISK_ERR = -EIO, /* (1) A hard error occurred in the low level disk I/O layer */
|
||||
FR_INT_ERR = -EIO, /* (2) Assertion failed */
|
||||
FR_NOT_READY = -ENODEV, /* (3) The physical drive cannot work */
|
||||
FR_NO_FILE = -ENOENT, /* (4) Could not find the file */
|
||||
FR_NO_PATH = -ENOENT, /* (5) Could not find the path */
|
||||
FR_INVALID_NAME = -EINVAL, /* (6) The path name format is invalid */
|
||||
FR_DENIED = -EACCES, /* (7) Access denied due to prohibited access or directory full */
|
||||
FR_EXIST = -EEXIST, /* (8) Access denied due to prohibited access */
|
||||
FR_INVALID_OBJECT = -EBADF, /* (9) The file/directory object is invalid */
|
||||
FR_WRITE_PROTECTED = -EACCES, /* (10) The physical drive is write protected */
|
||||
FR_INVALID_DRIVE = -ENXIO, /* (11) The logical drive number is invalid */
|
||||
FR_NOT_ENABLED = -ENODEV, /* (12) The volume has no work area */
|
||||
FR_NO_FILESYSTEM = -ENODEV, /* (13) There is no valid FAT volume */
|
||||
FR_MKFS_ABORTED = -EINTR, /* (14) The f_mkfs() aborted due to any problem */
|
||||
FR_TIMEOUT = -ETIMEDOUT, /* (15) Could not get a grant to access the volume within defined period */
|
||||
FR_LOCKED = -EACCES, /* (16) The operation is rejected according to the file sharing policy */
|
||||
FR_NOT_ENOUGH_CORE = -ENOMEM, /* (17) LFN working buffer could not be allocated */
|
||||
FR_TOO_MANY_OPEN_FILES = -ENFILE, /* (18) Number of open files > FF_FS_LOCK */
|
||||
FR_INVALID_PARAMETER = -EINVAL /* (19) Given parameter is invalid */
|
||||
} FRESULT;
|
||||
|
||||
|
||||
|
||||
/*--------------------------------------------------------------*/
|
||||
/* FatFs module application interface */
|
||||
|
||||
FRESULT f_open (FIL* fp, const TCHAR* path, BYTE mode); /* Open or create a file */
|
||||
FRESULT f_close (FIL* fp); /* Close an open file object */
|
||||
FRESULT f_read (FIL* fp, void* buff, UINT btr, UINT* br); /* Read data from the file */
|
||||
FRESULT f_write (FIL* fp, const void* buff, UINT btw, UINT* bw); /* Write data to the file */
|
||||
FRESULT f_lseek (FIL* fp, FSIZE_t ofs); /* Move file pointer of the file object */
|
||||
FRESULT f_truncate (FIL* fp); /* Truncate the file */
|
||||
FRESULT f_sync (FIL* fp); /* Flush cached data of the writing file */
|
||||
FRESULT f_opendir (FF_DIR* dp, const TCHAR* path); /* Open a directory */
|
||||
FRESULT f_closedir (FF_DIR* dp); /* Close an open directory */
|
||||
FRESULT f_readdir (FF_DIR* dp, FILINFO* fno); /* Read a directory item */
|
||||
FRESULT f_findfirst (FF_DIR* dp, FILINFO* fno, const TCHAR* path, const TCHAR* pattern); /* Find first file */
|
||||
FRESULT f_findnext (FF_DIR* dp, FILINFO* fno); /* Find next file */
|
||||
FRESULT f_mkdir (const TCHAR* path); /* Create a sub directory */
|
||||
FRESULT f_unlink (const TCHAR* path); /* Delete an existing file or directory */
|
||||
FRESULT f_rename (const TCHAR* path_old, const TCHAR* path_new); /* Rename/Move a file or directory */
|
||||
FRESULT f_stat (const TCHAR* path, FILINFO* fno); /* Get file status */
|
||||
FRESULT f_chmod (const TCHAR* path, BYTE attr, BYTE mask); /* Change attribute of a file/dir */
|
||||
FRESULT f_utime (const TCHAR* path, const FILINFO* fno); /* Change timestamp of a file/dir */
|
||||
FRESULT f_chdir (const TCHAR* path); /* Change current directory */
|
||||
FRESULT f_chdrive (const TCHAR* path); /* Change current drive */
|
||||
FRESULT f_getcwd (TCHAR* buff, UINT len); /* Get current directory */
|
||||
FRESULT f_getfree (const TCHAR* path, DWORD* nclst, FATFS** fatfs); /* Get number of free clusters on the drive */
|
||||
FRESULT f_getlabel (const TCHAR* path, TCHAR* label, DWORD* vsn); /* Get volume label */
|
||||
FRESULT f_setlabel (const TCHAR* label); /* Set volume label */
|
||||
FRESULT f_forward (FIL* fp, UINT(*func)(const BYTE*,UINT), UINT btf, UINT* bf); /* Forward data to the stream */
|
||||
FRESULT f_expand (FIL* fp, FSIZE_t szf, BYTE opt); /* Allocate a contiguous block to the file */
|
||||
FRESULT f_mount (FATFS* fs, const TCHAR* path, BYTE opt); /* Mount/Unmount a logical drive */
|
||||
FRESULT f_mkfs (const TCHAR* path, BYTE opt, DWORD au, void* work, UINT len); /* Create a FAT volume */
|
||||
FRESULT f_fdisk (BYTE pdrv, const DWORD* szt, void* work); /* Divide a physical drive into some partitions */
|
||||
FRESULT f_setcp (WORD cp); /* Set current code page */
|
||||
int f_putc (TCHAR c, FIL* fp); /* Put a character to the file */
|
||||
int f_puts (const TCHAR* str, FIL* cp); /* Put a string to the file */
|
||||
int f_printf (FIL* fp, const TCHAR* str, ...); /* Put a formatted string to the file */
|
||||
TCHAR* f_gets (TCHAR* buff, int len, FIL* fp); /* Get a string from the file */
|
||||
|
||||
#define f_eof(fp) ((int)((fp)->fptr == (fp)->obj.objsize))
|
||||
#define f_error(fp) ((fp)->err)
|
||||
#define f_tell(fp) ((fp)->fptr)
|
||||
#define f_size(fp) ((fp)->obj.objsize)
|
||||
#define f_rewind(fp) f_lseek((fp), 0)
|
||||
#define f_rewinddir(dp) f_readdir((dp), 0)
|
||||
#define f_rmdir(path) f_unlink(path)
|
||||
#define f_unmount(path) f_mount(0, path, 0)
|
||||
|
||||
#ifndef EOF
|
||||
#define EOF (-1)
|
||||
#endif
|
||||
|
||||
|
||||
|
||||
|
||||
/*--------------------------------------------------------------*/
|
||||
/* Additional user defined functions */
|
||||
|
||||
/* RTC function */
|
||||
#if !FF_FS_READONLY && !FF_FS_NORTC
|
||||
DWORD get_fattime (void);
|
||||
#endif
|
||||
|
||||
/* LFN support functions */
|
||||
#if FF_USE_LFN /* Code conversion (defined in unicode.c) */
|
||||
WCHAR ff_oem2uni (WCHAR oem, WORD cp); /* OEM code to Unicode conversion */
|
||||
WCHAR ff_uni2oem (WCHAR uni, WORD cp); /* Unicode to OEM code conversion */
|
||||
WCHAR ff_wtoupper (WCHAR uni); /* Unicode upper-case conversion */
|
||||
#endif
|
||||
#if FF_USE_LFN == 3 /* Dynamic memory allocation */
|
||||
void* ff_memalloc (UINT msize); /* Allocate memory block */
|
||||
void ff_memfree (void* mblock); /* Free memory block */
|
||||
#endif
|
||||
|
||||
/* Sync functions */
|
||||
#if FF_FS_REENTRANT
|
||||
int ff_cre_syncobj (BYTE vol, FF_SYNC_t* sobj); /* Create a sync object */
|
||||
int ff_req_grant (FF_SYNC_t sobj); /* Lock sync object */
|
||||
void ff_rel_grant (FF_SYNC_t sobj); /* Unlock sync object */
|
||||
int ff_del_syncobj (FF_SYNC_t sobj); /* Delete a sync object */
|
||||
#endif
|
||||
|
||||
|
||||
|
||||
|
||||
/*--------------------------------------------------------------*/
|
||||
/* Flags and offset address */
|
||||
|
||||
|
||||
/* File access mode and open method flags (3rd argument of f_open) */
|
||||
#define FA_READ 0x01
|
||||
#define FA_WRITE 0x02
|
||||
#define FA_OPEN_EXISTING 0x00
|
||||
#define FA_CREATE_NEW 0x04
|
||||
#define FA_CREATE_ALWAYS 0x08
|
||||
#define FA_OPEN_ALWAYS 0x10
|
||||
#define FA_OPEN_APPEND 0x30
|
||||
|
||||
/* Fast seek controls (2nd argument of f_lseek) */
|
||||
#define CREATE_LINKMAP ((FSIZE_t)0 - 1)
|
||||
|
||||
/* Format options (2nd argument of f_mkfs) */
|
||||
#define FM_FAT 0x01
|
||||
#define FM_FAT32 0x02
|
||||
#define FM_EXFAT 0x04
|
||||
#define FM_ANY 0x07
|
||||
#define FM_SFD 0x08
|
||||
|
||||
/* Filesystem type (FATFS.fs_type) */
|
||||
#define FS_FAT12 1
|
||||
#define FS_FAT16 2
|
||||
#define FS_FAT32 3
|
||||
#define FS_EXFAT 4
|
||||
|
||||
/* File attribute bits for directory entry (FILINFO.fattrib) */
|
||||
#define AM_RDO 0x01 /* Read only */
|
||||
#define AM_HID 0x02 /* Hidden */
|
||||
#define AM_SYS 0x04 /* System */
|
||||
#define AM_DIR 0x10 /* Directory */
|
||||
#define AM_ARC 0x20 /* Archive */
|
||||
|
||||
|
||||
#ifdef __cplusplus
|
||||
}
|
||||
#endif
|
||||
|
||||
#endif /* FF_DEFINED */
|
||||
247
Living_SDK/kernel/modules/fs/fatfs/ff/include/ffconf.h
Normal file
247
Living_SDK/kernel/modules/fs/fatfs/ff/include/ffconf.h
Normal file
|
|
@ -0,0 +1,247 @@
|
|||
/*---------------------------------------------------------------------------/
|
||||
/ FatFs - Configuration file
|
||||
/---------------------------------------------------------------------------*/
|
||||
#include <aos/aos.h>
|
||||
|
||||
#define FFCONF_DEF 87030 /* Revision ID */
|
||||
|
||||
/*---------------------------------------------------------------------------/
|
||||
/ Function Configurations
|
||||
/---------------------------------------------------------------------------*/
|
||||
|
||||
#define FF_FS_READONLY 0
|
||||
/* This option switches read-only configuration. (0:Read/Write or 1:Read-only)
|
||||
/ Read-only configuration removes writing API functions, f_write(), f_sync(),
|
||||
/ f_unlink(), f_mkdir(), f_chmod(), f_rename(), f_truncate(), f_getfree()
|
||||
/ and optional writing functions as well. */
|
||||
|
||||
|
||||
#define FF_FS_MINIMIZE 0
|
||||
/* This option defines minimization level to remove some basic API functions.
|
||||
/
|
||||
/ 0: All basic functions are enabled.
|
||||
/ 1: f_stat(), f_getfree(), f_unlink(), f_mkdir(), f_truncate() and f_rename()
|
||||
/ are removed.
|
||||
/ 2: f_opendir(), f_readdir() and f_closedir() are removed in addition to 1.
|
||||
/ 3: f_lseek() function is removed in addition to 2. */
|
||||
|
||||
|
||||
#define FF_USE_STRFUNC 0
|
||||
/* This option switches string functions, f_gets(), f_putc(), f_puts() and f_printf().
|
||||
/
|
||||
/ 0: Disable string functions.
|
||||
/ 1: Enable without LF-CRLF conversion.
|
||||
/ 2: Enable with LF-CRLF conversion. */
|
||||
|
||||
|
||||
#define FF_USE_FIND 0
|
||||
/* This option switches filtered directory read functions, f_findfirst() and
|
||||
/ f_findnext(). (0:Disable, 1:Enable 2:Enable with matching altname[] too) */
|
||||
|
||||
|
||||
#define FF_USE_MKFS 1
|
||||
/* This option switches f_mkfs() function. (0:Disable or 1:Enable) */
|
||||
|
||||
|
||||
#define FF_USE_FASTSEEK 0
|
||||
/* This option switches fast seek function. (0:Disable or 1:Enable) */
|
||||
|
||||
|
||||
#define FF_USE_EXPAND 0
|
||||
/* This option switches f_expand function. (0:Disable or 1:Enable) */
|
||||
|
||||
|
||||
#define FF_USE_CHMOD 0
|
||||
/* This option switches attribute manipulation functions, f_chmod() and f_utime().
|
||||
/ (0:Disable or 1:Enable) Also FF_FS_READONLY needs to be 0 to enable this option. */
|
||||
|
||||
|
||||
#define FF_USE_LABEL 0
|
||||
/* This option switches volume label functions, f_getlabel() and f_setlabel().
|
||||
/ (0:Disable or 1:Enable) */
|
||||
|
||||
|
||||
#define FF_USE_FORWARD 0
|
||||
/* This option switches f_forward() function. (0:Disable or 1:Enable) */
|
||||
|
||||
|
||||
/*---------------------------------------------------------------------------/
|
||||
/ Locale and Namespace Configurations
|
||||
/---------------------------------------------------------------------------*/
|
||||
|
||||
#define FF_CODE_PAGE 437
|
||||
/* This option specifies the OEM code page to be used on the target system.
|
||||
/ Incorrect code page setting can cause a file open failure.
|
||||
/
|
||||
/ 437 - U.S.
|
||||
/ 936 - Simplified Chinese (DBCS)
|
||||
*/
|
||||
|
||||
|
||||
#define FF_USE_LFN 1
|
||||
#define FF_MAX_LFN 255
|
||||
/* The FF_USE_LFN switches the support for LFN (long file name).
|
||||
/
|
||||
/ 0: Disable LFN. FF_MAX_LFN has no effect.
|
||||
/ 1: Enable LFN with static working buffer on the BSS. Always NOT thread-safe.
|
||||
/ 2: Enable LFN with dynamic working buffer on the STACK.
|
||||
/ 3: Enable LFN with dynamic working buffer on the HEAP.
|
||||
/
|
||||
/ To enable the LFN, Unicode handling functions (option/unicode.c) must be added
|
||||
/ to the project. The working buffer occupies (FF_MAX_LFN + 1) * 2 bytes and
|
||||
/ additional 608 bytes at exFAT enabled. FF_MAX_LFN can be in range from 12 to 255.
|
||||
/ It should be set 255 to support full featured LFN operations.
|
||||
/ When use stack for the working buffer, take care on stack overflow. When use heap
|
||||
/ memory for the working buffer, memory management functions, ff_memalloc() and
|
||||
/ ff_memfree(), must be added to the project. */
|
||||
|
||||
|
||||
#define FF_LFN_UNICODE 0
|
||||
/* This option switches character encoding on the API, 0:ANSI/OEM or 1:UTF-16,
|
||||
/ when LFN is enabled. Also behavior of string I/O functions will be affected by
|
||||
/ this option. When LFN is not enabled, this option has no effect.
|
||||
*/
|
||||
|
||||
|
||||
#define FF_STRF_ENCODE 3
|
||||
/* When FF_LFN_UNICODE = 1 with LFN enabled, string I/O functions, f_gets(),
|
||||
/ f_putc(), f_puts and f_printf() convert the character encoding in it.
|
||||
/ This option selects assumption of character encoding ON THE FILE to be
|
||||
/ read/written via those functions.
|
||||
/
|
||||
/ 0: ANSI/OEM
|
||||
/ 1: UTF-16LE
|
||||
/ 2: UTF-16BE
|
||||
/ 3: UTF-8
|
||||
*/
|
||||
|
||||
|
||||
#define FF_FS_RPATH 0
|
||||
/* This option configures support for relative path.
|
||||
/
|
||||
/ 0: Disable relative path and remove related functions.
|
||||
/ 1: Enable relative path. f_chdir() and f_chdrive() are available.
|
||||
/ 2: f_getcwd() function is available in addition to 1.
|
||||
*/
|
||||
|
||||
|
||||
/*---------------------------------------------------------------------------/
|
||||
/ Drive/Volume Configurations
|
||||
/---------------------------------------------------------------------------*/
|
||||
|
||||
#define FF_VOLUMES 3
|
||||
/* Number of volumes (logical drives) to be used. (1-10) */
|
||||
|
||||
|
||||
#define FF_STR_VOLUME_ID 0
|
||||
#define FF_VOLUME_STRS "RAM","NAND","CF","SD","SD2","USB","USB2","USB3"
|
||||
/* FF_STR_VOLUME_ID switches string support for volume ID.
|
||||
/ When FF_STR_VOLUME_ID is set to 1, also pre-defined strings can be used as drive
|
||||
/ number in the path name. FF_VOLUME_STRS defines the drive ID strings for each
|
||||
/ logical drives. Number of items must be equal to FF_VOLUMES. Valid characters for
|
||||
/ the drive ID strings are: A-Z and 0-9. */
|
||||
|
||||
|
||||
#define FF_MULTI_PARTITION 0
|
||||
/* This option switches support for multiple volumes on the physical drive.
|
||||
/ By default (0), each logical drive number is bound to the same physical drive
|
||||
/ number and only an FAT volume found on the physical drive will be mounted.
|
||||
/ When this function is enabled (1), each logical drive number can be bound to
|
||||
/ arbitrary physical drive and partition listed in the VolToPart[]. Also f_fdisk()
|
||||
/ funciton will be available. */
|
||||
|
||||
|
||||
#define FF_MIN_SS 512
|
||||
#define FF_MAX_SS 512
|
||||
/* This set of options configures the range of sector size to be supported. (512,
|
||||
/ 1024, 2048 or 4096) Always set both 512 for most systems, generic memory card and
|
||||
/ harddisk. But a larger value may be required for on-board flash memory and some
|
||||
/ type of optical media. When FF_MAX_SS is larger than FF_MIN_SS, FatFs is configured
|
||||
/ for variable sector size mode and disk_ioctl() function needs to implement
|
||||
/ GET_SECTOR_SIZE command. */
|
||||
|
||||
|
||||
#define FF_USE_TRIM 0
|
||||
/* This option switches support for ATA-TRIM. (0:Disable or 1:Enable)
|
||||
/ To enable Trim function, also CTRL_TRIM command should be implemented to the
|
||||
/ disk_ioctl() function. */
|
||||
|
||||
|
||||
#define FF_FS_NOFSINFO 0
|
||||
/* If you need to know correct free space on the FAT32 volume, set bit 0 of this
|
||||
/ option, and f_getfree() function at first time after volume mount will force
|
||||
/ a full FAT scan. Bit 1 controls the use of last allocated cluster number.
|
||||
/
|
||||
/ bit0=0: Use free cluster count in the FSINFO if available.
|
||||
/ bit0=1: Do not trust free cluster count in the FSINFO.
|
||||
/ bit1=0: Use last allocated cluster number in the FSINFO if available.
|
||||
/ bit1=1: Do not trust last allocated cluster number in the FSINFO.
|
||||
*/
|
||||
|
||||
|
||||
|
||||
/*---------------------------------------------------------------------------/
|
||||
/ System Configurations
|
||||
/---------------------------------------------------------------------------*/
|
||||
|
||||
#define FF_FS_TINY 0
|
||||
/* This option switches tiny buffer configuration. (0:Normal or 1:Tiny)
|
||||
/ At the tiny configuration, size of file object (FIL) is shrinked FF_MAX_SS bytes.
|
||||
/ Instead of private sector buffer eliminated from the file object, common sector
|
||||
/ buffer in the filesystem object (FATFS) is used for the file data transfer. */
|
||||
|
||||
|
||||
#define FF_FS_EXFAT 0
|
||||
/* This option switches support for exFAT filesystem. (0:Disable or 1:Enable)
|
||||
/ When enable exFAT, also LFN needs to be enabled.
|
||||
/ Note that enabling exFAT discards ANSI C (C89) compatibility. */
|
||||
|
||||
|
||||
#define FF_FS_NORTC 1
|
||||
#define FF_NORTC_MON 5
|
||||
#define FF_NORTC_MDAY 1
|
||||
#define FF_NORTC_YEAR 2017
|
||||
/* The option FF_FS_NORTC switches timestamp functiton. If the system does not have
|
||||
/ any RTC function or valid timestamp is not needed, set FF_FS_NORTC = 1 to disable
|
||||
/ the timestamp function. All objects modified by FatFs will have a fixed timestamp
|
||||
/ defined by FF_NORTC_MON, FF_NORTC_MDAY and FF_NORTC_YEAR in local time.
|
||||
/ To enable timestamp function (FF_FS_NORTC = 0), get_fattime() function need to be
|
||||
/ added to the project to read current time form real-time clock. FF_NORTC_MON,
|
||||
/ FF_NORTC_MDAY and FF_NORTC_YEAR have no effect.
|
||||
/ These options have no effect at read-only configuration (FF_FS_READONLY = 1). */
|
||||
|
||||
|
||||
#define FF_FS_LOCK 0
|
||||
/* The option FF_FS_LOCK switches file lock function to control duplicated file open
|
||||
/ and illegal operation to open objects. This option must be 0 when FF_FS_READONLY
|
||||
/ is 1.
|
||||
/
|
||||
/ 0: Disable file lock function. To avoid volume corruption, application program
|
||||
/ should avoid illegal open, remove and rename to the open objects.
|
||||
/ >0: Enable file lock function. The value defines how many files/sub-directories
|
||||
/ can be opened simultaneously under file lock control. Note that the file
|
||||
/ lock control is independent of re-entrancy. */
|
||||
|
||||
|
||||
#define FF_FS_REENTRANT 0
|
||||
#define FF_FS_TIMEOUT 1000
|
||||
#define FF_SYNC_t aos_mutex_t
|
||||
/* The option FF_FS_REENTRANT switches the re-entrancy (thread safe) of the FatFs
|
||||
/ module itself. Note that regardless of this option, file access to different
|
||||
/ volume is always re-entrant and volume control functions, f_mount(), f_mkfs()
|
||||
/ and f_fdisk() function, are always not re-entrant. Only file/directory access
|
||||
/ to the same volume is under control of this function.
|
||||
/
|
||||
/ 0: Disable re-entrancy. FF_FS_TIMEOUT and FF_SYNC_t have no effect.
|
||||
/ 1: Enable re-entrancy. Also user provided synchronization handlers,
|
||||
/ ff_req_grant(), ff_rel_grant(), ff_del_syncobj() and ff_cre_syncobj()
|
||||
/ function, must be added to the project. Samples are available in
|
||||
/ option/syscall.c.
|
||||
/
|
||||
/ The FF_FS_TIMEOUT defines timeout period in unit of time tick.
|
||||
/ The FF_SYNC_t defines O/S dependent sync object type. e.g. HANDLE, ID, OS_EVENT*,
|
||||
/ SemaphoreHandle_t and etc. A header file for O/S definitions needs to be
|
||||
/ included somewhere in the scope of ff.h. */
|
||||
|
||||
|
||||
/*--- End of configuration options ---*/
|
||||
38
Living_SDK/kernel/modules/fs/fatfs/ff/include/integer.h
Normal file
38
Living_SDK/kernel/modules/fs/fatfs/ff/include/integer.h
Normal file
|
|
@ -0,0 +1,38 @@
|
|||
/*-------------------------------------------*/
|
||||
/* Integer type definitions for FatFs module */
|
||||
/*-------------------------------------------*/
|
||||
|
||||
#ifndef FF_INTEGER
|
||||
#define FF_INTEGER
|
||||
|
||||
#ifdef _WIN32 /* FatFs development platform */
|
||||
|
||||
#include <windows.h>
|
||||
#include <tchar.h>
|
||||
typedef unsigned __int64 QWORD;
|
||||
|
||||
|
||||
#else /* Embedded platform */
|
||||
|
||||
/* These types MUST be 16-bit or 32-bit */
|
||||
typedef int INT;
|
||||
typedef unsigned int UINT;
|
||||
|
||||
/* This type MUST be 8-bit */
|
||||
typedef unsigned char BYTE;
|
||||
|
||||
/* These types MUST be 16-bit */
|
||||
typedef short SHORT;
|
||||
typedef unsigned short WORD;
|
||||
typedef unsigned short WCHAR;
|
||||
|
||||
/* These types MUST be 32-bit */
|
||||
typedef long LONG;
|
||||
typedef unsigned long DWORD;
|
||||
|
||||
/* This type MUST be 64-bit (Remove this for ANSI C (C89) compatibility) */
|
||||
typedef unsigned long long QWORD;
|
||||
|
||||
#endif
|
||||
|
||||
#endif
|
||||
20
Living_SDK/kernel/modules/fs/fatfs/include/fatfs.h
Normal file
20
Living_SDK/kernel/modules/fs/fatfs/include/fatfs.h
Normal file
|
|
@ -0,0 +1,20 @@
|
|||
/*
|
||||
* Copyright (C) 2015-2017 Alibaba Group Holding Limited
|
||||
*/
|
||||
|
||||
#ifndef FS_FAT_H
|
||||
#define FS_FAT_H
|
||||
|
||||
#ifdef __cplusplus
|
||||
extern "C" {
|
||||
#endif
|
||||
|
||||
int fatfs_register(void);
|
||||
int fatfs_unregister(void);
|
||||
|
||||
#ifdef __cplusplus
|
||||
}
|
||||
#endif
|
||||
|
||||
|
||||
#endif
|
||||
34
Living_SDK/kernel/modules/fs/fatfs/include/fatfs_diskio.h
Normal file
34
Living_SDK/kernel/modules/fs/fatfs/include/fatfs_diskio.h
Normal file
|
|
@ -0,0 +1,34 @@
|
|||
/*
|
||||
* Copyright (C) 2015-2017 Alibaba Group Holding Limited
|
||||
*/
|
||||
|
||||
#ifndef FS_FAT_DISKIO_H
|
||||
#define FS_FAT_DISKIO_H
|
||||
|
||||
#ifdef __cplusplus
|
||||
extern "C" {
|
||||
#endif
|
||||
|
||||
#include "diskio.h"
|
||||
|
||||
/* Definitions of physical driver number of each drive */
|
||||
#define DEV_MMC 0 /* Map MMC/SD card to physical drive 0 */
|
||||
#define DEV_USB 1 /* Map USB to physical drive 1 */
|
||||
#define DEV_RAM 2 /* Map ramdisk to physical drive 0 */
|
||||
|
||||
#define MMC_MOUNTPOINT "/sdcard"
|
||||
#define MMC_PARTITION_ID "0:"
|
||||
|
||||
#define USB_MOUNTPOINT "/usb"
|
||||
#define USB_PARTITION_ID "1:"
|
||||
|
||||
#define RAM_MOUNTPOINT "/ramdisk"
|
||||
#define RAM_PARTITION_ID "2:"
|
||||
|
||||
|
||||
#ifdef __cplusplus
|
||||
}
|
||||
#endif
|
||||
|
||||
|
||||
#endif
|
||||
14
Living_SDK/kernel/modules/fs/fatfs/ucube.py
Normal file
14
Living_SDK/kernel/modules/fs/fatfs/ucube.py
Normal file
|
|
@ -0,0 +1,14 @@
|
|||
src = Split('''
|
||||
fatfs.c
|
||||
diskio.c
|
||||
ff/ff.c
|
||||
ff/ffunicode.c
|
||||
''')
|
||||
|
||||
component = aos_component('fatfs', src)
|
||||
component.add_cflags('-Wall')
|
||||
component.add_cflags('-Werror')
|
||||
|
||||
component.add_global_macros('AOS_FATFS')
|
||||
component.add_global_includes('include')
|
||||
component.add_global_includes('ff/include')
|
||||
71
Living_SDK/kernel/modules/fs/kv/include/kvmgr.h
Normal file
71
Living_SDK/kernel/modules/fs/kv/include/kvmgr.h
Normal file
|
|
@ -0,0 +1,71 @@
|
|||
/*
|
||||
* Copyright (C) 2015-2017 Alibaba Group Holding Limited
|
||||
*/
|
||||
|
||||
#ifndef _key_value_h_
|
||||
#define _key_value_h_
|
||||
|
||||
#if defined(__cplusplus) /* If this is a C++ compiler, use C linkage */
|
||||
extern "C"
|
||||
{
|
||||
#endif
|
||||
|
||||
/* The totally storage size for key-value store */
|
||||
#ifndef CONFIG_AOS_KV_BUFFER_SIZE
|
||||
#define KV_TOTAL_SIZE (8 * 1024)
|
||||
#else
|
||||
#define KV_TOTAL_SIZE CONFIG_AOS_KV_BUFFER_SIZE
|
||||
#endif
|
||||
|
||||
/* The physical parition for key-value store */
|
||||
#ifndef CONFIG_AOS_KV_PTN
|
||||
#define KV_PTN HAL_PARTITION_PARAMETER_2
|
||||
#else
|
||||
#define KV_PTN CONFIG_AOS_KV_PTN
|
||||
#endif
|
||||
|
||||
#ifdef CONFIG_AOS_KV_DEBUG
|
||||
#define KV_DBG_ENABLE 1
|
||||
#endif
|
||||
|
||||
#ifdef DEFAULT_LOG_LEVEL_DEBUG
|
||||
#define SUPPORT_KV_LIST_CMD
|
||||
#endif
|
||||
|
||||
typedef enum _kv_get_type_e
|
||||
{
|
||||
KV_GET_TYPE_STRING = 1,
|
||||
KV_GET_TYPE_BINARY,
|
||||
KV_GET_TYPE_INT,
|
||||
KV_GET_TYPE_FLOAT,
|
||||
KV_GET_TYPE_MAX
|
||||
}kv_get_type_e;
|
||||
|
||||
/**
|
||||
* @brief init the kv module.
|
||||
*
|
||||
* @param[in] none.
|
||||
*
|
||||
* @note: the default KV size is @HASH_TABLE_MAX_SIZE, the path to store
|
||||
* the kv file is @KVFILE_PATH.
|
||||
* @retval 0 on success, otherwise -1 will be returned
|
||||
*/
|
||||
int aos_kv_init(void);
|
||||
|
||||
/**
|
||||
* @brief deinit the kv module.
|
||||
*
|
||||
* @param[in] none.
|
||||
*
|
||||
* @note: all the KV in RAM will be released.
|
||||
* @retval none.
|
||||
*/
|
||||
void aos_kv_deinit(void);
|
||||
|
||||
#if defined(__cplusplus) /* If this is a C++ compiler, use C linkage */
|
||||
}
|
||||
#endif
|
||||
|
||||
#endif
|
||||
|
||||
|
||||
15
Living_SDK/kernel/modules/fs/kv/kv.mk
Normal file
15
Living_SDK/kernel/modules/fs/kv/kv.mk
Normal file
|
|
@ -0,0 +1,15 @@
|
|||
NAME := kv
|
||||
|
||||
$(NAME)_TYPE := kernel
|
||||
$(NAME)_SOURCES := kvmgr.c
|
||||
$(NAME)_COMPONENTS += log
|
||||
|
||||
#default gcc
|
||||
ifeq ($(COMPILER),)
|
||||
$(NAME)_CFLAGS += -Wall -Werror
|
||||
else ifeq ($(COMPILER),gcc)
|
||||
$(NAME)_CFLAGS += -Wall -Werror
|
||||
endif
|
||||
|
||||
GLOBAL_INCLUDES += include
|
||||
GLOBAL_DEFINES += AOS_KV
|
||||
1202
Living_SDK/kernel/modules/fs/kv/kvmgr.c
Executable file
1202
Living_SDK/kernel/modules/fs/kv/kvmgr.c
Executable file
File diff suppressed because it is too large
Load diff
11
Living_SDK/kernel/modules/fs/kv/ucube.py
Normal file
11
Living_SDK/kernel/modules/fs/kv/ucube.py
Normal file
|
|
@ -0,0 +1,11 @@
|
|||
src = Split('''
|
||||
kvmgr.c
|
||||
''')
|
||||
|
||||
component = aos_component('kv', src)
|
||||
|
||||
component.add_comp_deps('utility/log')
|
||||
|
||||
component.add_global_includes('include')
|
||||
|
||||
component.add_global_macros('AOS_KV')
|
||||
92
Living_SDK/kernel/modules/mm/tlsf/README.md
Normal file
92
Living_SDK/kernel/modules/mm/tlsf/README.md
Normal file
|
|
@ -0,0 +1,92 @@
|
|||
# tlsf
|
||||
Two-Level Segregated Fit memory allocator implementation.
|
||||
Written by Matthew Conte (matt@baisoku.org).
|
||||
Released under the BSD license.
|
||||
|
||||
Features
|
||||
--------
|
||||
* O(1) cost for malloc, free, realloc, memalign
|
||||
* Extremely low overhead per allocation (4 bytes)
|
||||
* Low overhead per TLSF management of pools (~3kB)
|
||||
* Low fragmentation
|
||||
* Compiles to only a few kB of code and data
|
||||
* Support for adding and removing memory pool regions on the fly
|
||||
|
||||
Caveats
|
||||
-------
|
||||
* Currently, assumes architecture can make 4-byte aligned accesses
|
||||
* Not designed to be thread safe; the user must provide this
|
||||
|
||||
Notes
|
||||
-----
|
||||
This code was based on the TLSF 1.4 spec and documentation found at:
|
||||
|
||||
http://www.gii.upv.es/tlsf/main/docs
|
||||
|
||||
It also leverages the TLSF 2.0 improvement to shrink the per-block overhead from 8 to 4 bytes.
|
||||
|
||||
History
|
||||
-------
|
||||
2016/04/10 - v3.1
|
||||
* Code moved to github
|
||||
* tlsfbits.h rolled into tlsf.c
|
||||
* License changed to BSD
|
||||
|
||||
2014/02/08 - v3.0
|
||||
* This version is based on improvements from 3DInteractive GmbH
|
||||
* Interface changed to allow more than one memory pool
|
||||
* Separated pool handling from control structure (adding, removing, debugging)
|
||||
* Control structure and pools can still be constructed in the same memory block
|
||||
* Memory blocks for control structure and pools are checked for alignment
|
||||
* Added functions to retrieve control structure size, alignment size, min and max block size, overhead of pool structure, and overhead of a single allocation
|
||||
* Minimal Pool size is tlsf_block_size_min() + tlsf_pool_overhead()
|
||||
* Pool must be empty when it is removed, in order to allow O(1) removal
|
||||
|
||||
2011/10/20 - v2.0
|
||||
* 64-bit support
|
||||
* More compiler intrinsics for ffs/fls
|
||||
* ffs/fls verification during TLSF creation in debug builds
|
||||
|
||||
2008/04/04 - v1.9
|
||||
* Add tlsf_heap_check, a heap integrity check
|
||||
* Support a predefined tlsf_assert macro
|
||||
* Fix realloc case where block should shrink; if adjacent block is in use, execution would go down the slow path
|
||||
|
||||
2007/02/08 - v1.8
|
||||
* Fix for unnecessary reallocation in tlsf_realloc
|
||||
|
||||
2007/02/03 - v1.7
|
||||
* tlsf_heap_walk takes a callback
|
||||
* tlsf_realloc now returns NULL on failure
|
||||
* tlsf_memalign optimization for 4-byte alignment
|
||||
* Usage of size_t where appropriate
|
||||
|
||||
2006/11/21 - v1.6
|
||||
* ffs/fls broken out into tlsfbits.h
|
||||
* tlsf_overhead queries per-pool overhead
|
||||
|
||||
2006/11/07 - v1.5
|
||||
* Smart realloc implementation
|
||||
* Smart memalign implementation
|
||||
|
||||
2006/10/11 - v1.4
|
||||
* Add some ffs/fls implementations
|
||||
* Minor code footprint reduction
|
||||
|
||||
2006/09/14 - v1.3
|
||||
* Profiling indicates heavy use of blocks of size 1-128, so implement small block handling
|
||||
* Reduce pool overhead by about 1kb
|
||||
* Reduce minimum block size from 32 to 12 bytes
|
||||
* Realloc bug fix
|
||||
|
||||
2006/09/09 - v1.2
|
||||
* Add tlsf_block_size
|
||||
* Static assertion mechanism for invariants
|
||||
* Minor bugfixes
|
||||
|
||||
2006/09/01 - v1.1
|
||||
* Add tlsf_realloc
|
||||
* Add tlsf_walk_heap
|
||||
|
||||
2006/08/25 - v1.0
|
||||
* First release
|
||||
1265
Living_SDK/kernel/modules/mm/tlsf/tlsf.c
Normal file
1265
Living_SDK/kernel/modules/mm/tlsf/tlsf.c
Normal file
File diff suppressed because it is too large
Load diff
90
Living_SDK/kernel/modules/mm/tlsf/tlsf.h
Normal file
90
Living_SDK/kernel/modules/mm/tlsf/tlsf.h
Normal file
|
|
@ -0,0 +1,90 @@
|
|||
#ifndef INCLUDED_tlsf
|
||||
#define INCLUDED_tlsf
|
||||
|
||||
/*
|
||||
** Two Level Segregated Fit memory allocator, version 3.1.
|
||||
** Written by Matthew Conte
|
||||
** http://tlsf.baisoku.org
|
||||
**
|
||||
** Based on the original documentation by Miguel Masmano:
|
||||
** http://www.gii.upv.es/tlsf/main/docs
|
||||
**
|
||||
** This implementation was written to the specification
|
||||
** of the document, therefore no GPL restrictions apply.
|
||||
**
|
||||
** Copyright (c) 2006-2016, Matthew Conte
|
||||
** All rights reserved.
|
||||
**
|
||||
** Redistribution and use in source and binary forms, with or without
|
||||
** modification, are permitted provided that the following conditions are met:
|
||||
** * Redistributions of source code must retain the above copyright
|
||||
** notice, this list of conditions and the following disclaimer.
|
||||
** * Redistributions in binary form must reproduce the above copyright
|
||||
** notice, this list of conditions and the following disclaimer in the
|
||||
** documentation and/or other materials provided with the distribution.
|
||||
** * Neither the name of the copyright holder nor the
|
||||
** names of its contributors may be used to endorse or promote products
|
||||
** derived from this software without specific prior written permission.
|
||||
**
|
||||
** THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND
|
||||
** ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
|
||||
** WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
|
||||
** DISCLAIMED. IN NO EVENT SHALL MATTHEW CONTE BE LIABLE FOR ANY
|
||||
** DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
|
||||
** (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
|
||||
** LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND
|
||||
** ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
|
||||
** (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
|
||||
** SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
||||
*/
|
||||
|
||||
#include <stddef.h>
|
||||
|
||||
#if defined(__cplusplus)
|
||||
extern "C" {
|
||||
#endif
|
||||
|
||||
/* tlsf_t: a TLSF structure. Can contain 1 to N pools. */
|
||||
/* pool_t: a block of memory that TLSF can manage. */
|
||||
typedef void* tlsf_t;
|
||||
typedef void* pool_t;
|
||||
|
||||
/* Create/destroy a memory pool. */
|
||||
tlsf_t tlsf_create(void* mem);
|
||||
tlsf_t tlsf_create_with_pool(void* mem, size_t bytes);
|
||||
void tlsf_destroy(tlsf_t tlsf);
|
||||
pool_t tlsf_get_pool(tlsf_t tlsf);
|
||||
|
||||
/* Add/remove memory pools. */
|
||||
pool_t tlsf_add_pool(tlsf_t tlsf, void* mem, size_t bytes);
|
||||
void tlsf_remove_pool(tlsf_t tlsf, pool_t pool);
|
||||
|
||||
/* malloc/memalign/realloc/free replacements. */
|
||||
void* tlsf_malloc(tlsf_t tlsf, size_t bytes);
|
||||
void* tlsf_memalign(tlsf_t tlsf, size_t align, size_t bytes);
|
||||
void* tlsf_realloc(tlsf_t tlsf, void* ptr, size_t size);
|
||||
void tlsf_free(tlsf_t tlsf, void* ptr);
|
||||
|
||||
/* Returns internal block size, not original request size */
|
||||
size_t tlsf_block_size(void* ptr);
|
||||
|
||||
/* Overheads/limits of internal structures. */
|
||||
size_t tlsf_size(void);
|
||||
size_t tlsf_align_size(void);
|
||||
size_t tlsf_block_size_min(void);
|
||||
size_t tlsf_block_size_max(void);
|
||||
size_t tlsf_pool_overhead(void);
|
||||
size_t tlsf_alloc_overhead(void);
|
||||
|
||||
/* Debugging. */
|
||||
typedef void (*tlsf_walker)(void* ptr, size_t size, int used, void* user);
|
||||
void tlsf_walk_pool(pool_t pool, tlsf_walker walker, void* user);
|
||||
/* Returns nonzero if any internal consistency check fails. */
|
||||
int tlsf_check(tlsf_t tlsf);
|
||||
int tlsf_check_pool(pool_t pool);
|
||||
|
||||
#if defined(__cplusplus)
|
||||
};
|
||||
#endif
|
||||
|
||||
#endif
|
||||
Loading…
Add table
Add a link
Reference in a new issue