forked from gary/BCU
2
0
Fork 0
BCU/library/rl_flashfs/File_lib.c

844 lines
26 KiB
C
Raw Normal View History

2024-11-26 15:52:49 +08:00
/*----------------------------------------------------------------------------
* RL-ARM - FlashFS
*----------------------------------------------------------------------------
* Name: FILE_LIB.C
* Purpose: FlashFS System Configuration
* Rev.: V4.74
*----------------------------------------------------------------------------
* This code is part of the RealView Run-Time Library.
* Copyright (c) 2004-2013 KEIL - An ARM Company. All rights reserved.
*---------------------------------------------------------------------------*/
#include <absacc.h>
#pragma thumb
#pragma O3
/*----------------------------------------------------------------------------
* Library for File_Config.c
*---------------------------------------------------------------------------*/
#ifdef __MICROLIB
#error FlashFS does not work with MicroLIB
#endif
/* If MC1 drive not defined */
#ifndef MC1_EN
#define MC1_EN 0
#define MC1_DEF 0
#endif
/* If NAND1 drive not defined */
#ifndef NAND1_EN
#define NAND1_EN 0
#define NAND1_DEF 0
#endif
/* If USB1 drive not defined */
#ifndef USB1_EN
#define USB1_EN 0
#define USB1_DEF 0
#endif
/* Check number of enabled drives */
#define FS_NDRV (FL0_EN + \
SF0_EN + \
RAM0_EN + \
MC0_EN + MC1_EN + \
USB0_EN + USB1_EN + \
NAND0_EN + NAND1_EN)
#if (FS_NDRV == 0)
#error all drives disabled in configuration
#endif
/* Count number of enabled FAT drives */
#define FS_FAT_NDRV (MC0_EN + MC1_EN + USB0_EN + USB1_EN + NAND0_EN + NAND1_EN)
/* Check Default drive settings */
#define __DEF ((FL0_DEF & FL0_EN) + \
(SF0_DEF & SF0_EN) + \
(RAM0_DEF & RAM0_EN) + \
(MC0_DEF & MC0_EN) + (MC1_DEF & MC1_EN) + \
(USB0_DEF & USB0_EN) + (USB1_DEF & USB1_EN) + \
(NAND0_DEF & NAND0_EN) + (NAND1_DEF & NAND1_EN))
#if (__DEF == 0)
#error default drive not specified
#elif (__DEF > 1)
#error multiple default drives enabled
#endif
/* Check FS usage */
#define EFS_USE (FL0_EN + SF0_EN + RAM0_EN)
#define FAT_USE (MC0_EN + MC1_EN + USB0_EN + USB1_EN + NAND0_EN + NAND1_EN)
/* Check journal usage */
#define FSJ_USE (MC0_EN * MC0_FSJ + MC1_EN * MC1_FSJ + \
USB0_EN * USB0_FSJ + USB1_EN * USB1_FSJ + \
NAND0_EN * NAND0_FSJ + NAND1_EN * NAND1_FSJ)
/* Reserved sector count */
#define FAT_SECT_RSVD 64
/* Make sure to resolve a weak stdlib symbol. */
#ifdef __RTX
extern volatile int _stream_list_lock;
#define STREAM_LIST_LOCK _stream_list_lock;
#else
#define STREAM_LIST_LOCK
#endif
/* Memory resources allocated by the Flash File System */
struct iob _iob[N_FILES];
/* Exported Defines to other modules */
U16 const _NFILE = N_FILES;
U16 const _NDRV = FS_NDRV;
/*----------------------------------------------------------------------------
* FAT Name Cache definition and configuration
*---------------------------------------------------------------------------*/
#if (FAT_NAME_CACNT == 0)
FAT_NCACHE_CFG fat_ncache = {
0, 0, 0, NULL
};
#else
#if (FAT_NAME_RELOC == 1)
#define __AT_FAT_NAME __at(FAT_NAME_CADR)
#else
#define __AT_FAT_NAME
#endif
/* FAT name cache max folder depth */
#define FAT_NAME_MAX_DEPTH 8
/* FAT name cache control block size and count */
#define FAT_NAME_CB_SZ (16)
#define FAT_NAME_CB_POOL_SZ (FAT_NAME_CB_SZ * FS_FAT_NDRV)
/* FAT name cache folder depth control block size */
#define FAT_NAME_DEPTH_CB_SZ (8)
#define FAT_NAME_DEPTH_POOL_SZ (FAT_NAME_DEPTH_CB_SZ * FAT_NAME_MAX_DEPTH * FS_FAT_NDRV)
/* FAT name cache pool size */
#define FAT_NAME_LINK_SZ (48)
#define FAT_NAME_LINK_POOL_SZ (FAT_NAME_LINK_SZ * FAT_NAME_CACNT)
/* FAT name cache buffer size in bytes */
#define FAT_NAME_CACHE_SZ (FAT_NAME_CB_POOL_SZ + \
FAT_NAME_DEPTH_POOL_SZ + \
FAT_NAME_LINK_POOL_SZ)
U32 fat_name_pool[FAT_NAME_CACHE_SZ/4] __AT_FAT_NAME;
FAT_NCACHE_CFG fat_ncache = {
FAT_NAME_MAX_DEPTH,
FS_FAT_NDRV,
FAT_NAME_CACHE_SZ,
fat_name_pool
};
#endif /* FAT_NAME_CACNT */
/*----------------------------------------------------------------------------
* Parallel Flash device FL0 configuration
*---------------------------------------------------------------------------*/
#if (FL0_EN)
extern EFS_DRV fl0_drv;
/* Parallel Flash Device Configuration Table */
#define DFB(sz,adr) { (U32)adr+FL0_BADR, ((U32)(adr+sz)-4)+FL0_BADR }
#include FL0_HFILE
static EFS_CFG fl0_cfg [FL_NSECT] = { FLASH_DEVICE };
static EFS_VI fl0_vol;
#endif
/*----------------------------------------------------------------------------
* SPI Flash device SF0 configuration
*---------------------------------------------------------------------------*/
#if (SF0_EN)
extern EFS_DRV sf0_drv;
#define DSB(size,badr) { (U32)badr, ((U32)(badr+size)-4) }
#include SF0_HFILE
/* Flash Device Configuration Table */
static EFS_CFG sf0_cfg [SF_NSECT] = { SPI_FLASH_DEVICE };
static EFS_VI sf0_vol;
#endif
/*----------------------------------------------------------------------------
* RAM device RAM0 configuration
*---------------------------------------------------------------------------*/
#if (RAM0_EN)
#if (RAM0_RELOC == 1)
#define __AT_RAM0 __at(RAM0_BADR)
#else
#define __AT_RAM0
#endif
#if ((RAM0_SIZE / RAM0_NSECT) < 64)
#error "RAM drive sector size is set to low. It must be equal or higher than 64 bytes"
#endif
/* RAM Device data buffer */
static U32 ram0_buf[(RAM0_SIZE/4)] __AT_RAM0;
static EFS_VI ram0_vol;
#define RBS (RAM0_SIZE/4/RAM0_NSECT)
#define DRB(n) {(U32)&ram0_buf[(RBS*n)], (U32)&ram0_buf[(RBS*n+RBS-1)]}
#pragma diag_suppress 1296
/* Ram Device Configuration Table */
static EFS_CFG ram0_cfg [RAM0_NSECT] = {
DRB(0), DRB(1), DRB(2), DRB(3), DRB(4), DRB(5), DRB(6), DRB(7),
#if RAM0_NSECT > 8
DRB(8), DRB(9), DRB(10), DRB(11), DRB(12), DRB(13), DRB(14), DRB(15),
#endif
#if RAM0_NSECT > 16
DRB(16), DRB(17), DRB(18), DRB(19), DRB(20), DRB(21), DRB(22), DRB(23),
DRB(24), DRB(25), DRB(26), DRB(27), DRB(28), DRB(29), DRB(30), DRB(31),
#endif
#if RAM0_NSECT > 32
DRB(32), DRB(33), DRB(34), DRB(35), DRB(36), DRB(37), DRB(38), DRB(39),
DRB(40), DRB(41), DRB(42), DRB(43), DRB(44), DRB(45), DRB(46), DRB(47),
DRB(48), DRB(49), DRB(50), DRB(51), DRB(52), DRB(53), DRB(54), DRB(55),
DRB(56), DRB(57), DRB(58), DRB(59), DRB(60), DRB(61), DRB(62), DRB(63),
#endif
#if RAM0_NSECT > 64
DRB(64), DRB(65), DRB(66), DRB(67), DRB(68), DRB(69), DRB(70), DRB(71),
DRB(72), DRB(73), DRB(74), DRB(75), DRB(76), DRB(77), DRB(78), DRB(79),
DRB(80), DRB(81), DRB(82), DRB(83), DRB(84), DRB(85), DRB(86), DRB(87),
DRB(88), DRB(89), DRB(90), DRB(91), DRB(92), DRB(93), DRB(94), DRB(95),
DRB(96), DRB(97), DRB(98), DRB(99), DRB(100),DRB(101),DRB(102),DRB(103),
DRB(104),DRB(105),DRB(106),DRB(107),DRB(108),DRB(109),DRB(110),DRB(111),
DRB(112),DRB(113),DRB(114),DRB(115),DRB(116),DRB(117),DRB(118),DRB(119),
DRB(120),DRB(121),DRB(122),DRB(123),DRB(124),DRB(125),DRB(126),DRB(127),
#endif
};
#pragma diag_default 1296
#endif
/*----------------------------------------------------------------------------
* Memory Card device MC0 configuration
*---------------------------------------------------------------------------*/
#if (MC0_EN)
#if (MC0_RELOC == 1)
#define __AT_MC0 __at(MC0_CADR)
#else
#define __AT_MC0
#endif
#if (MC0_FSJ == 1)
static FSJOUR mc0_fsj;
#endif
/* MC0 Cache Buffer for Data and FAT Caching */
static U32 mc0_cache[(MC0_CASZ+1) * 256 + MC0_FSJ * 128] __AT_MC0;
static FAT_VI mc0_vol;
#if (MC0_SPI == 0)
/* SD Native bus mode */
extern MCI_DRV mci0_drv;
static MCI_DEV mci0_dev;
#define MC0_INIT(m) mci_Init (m,&mci0_dev)
#define MC0_UNINIT(m) mci_UnInit (m,&mci0_dev)
#define MC0_RDSEC(s,b,c) mci_ReadSector (s,b,c,&mci0_dev)
#define MC0_WRSEC(s,b,c) mci_WriteSector (s,b,c,&mci0_dev)
#define MC0_RDINFO(i) mci_ReadInfo (i,&mci0_dev)
#define MC0_DEVCTRL(c,p) mci_DevCtrl (c,p, &mci0_dev)
#else
/* SPI bus mode */
extern SPI_DRV spi0_drv;
static MMC_DEV mmc0_dev;
#define MC0_INIT(m) mmc_Init (m,&mmc0_dev)
#define MC0_UNINIT(m) mmc_UnInit (m,&mmc0_dev)
#define MC0_RDSEC(s,b,c) mmc_ReadSector (s,b,c,&mmc0_dev)
#define MC0_WRSEC(s,b,c) mmc_WriteSector (s,b,c,&mmc0_dev)
#define MC0_RDINFO(i) mmc_ReadInfo (i,&mmc0_dev)
#define MC0_DEVCTRL(c,p) mmc_DevCtrl (c,p,&mmc0_dev)
#endif
/* MC0 wrapper functions */
static BOOL mc0_Init (U32 mode) {
return (MC0_INIT (mode));
}
static BOOL mc0_UnInit (U32 mode) {
return (MC0_UNINIT (mode));
}
static BOOL mc0_RdSect (U32 sect, U8 *buf, U32 cnt) {
return (MC0_RDSEC (sect, buf, cnt));
}
static BOOL mc0_WrSect (U32 sect, U8 *buf, U32 cnt) {
return (MC0_WRSEC (sect, buf, cnt));
}
static BOOL mc0_RdInfo (Media_INFO *info) {
return (MC0_RDINFO (info));
}
static U32 mc0_DevCtrl (U32 code, void *p) {
return (MC0_DEVCTRL (code, p));
}
/* MC0 FAT device driver */
FAT_DRV mc0_drv = {
mc0_Init,
mc0_UnInit,
mc0_RdSect,
mc0_WrSect,
mc0_RdInfo,
mc0_DevCtrl
};
#endif
/*----------------------------------------------------------------------------
* Memory Card device MC1 configuration
*---------------------------------------------------------------------------*/
#if (MC1_EN)
#if (MC1_RELOC == 1)
#define __AT_MC1 __at(MC1_CADR)
#else
#define __AT_MC1
#endif
#if (MC1_FSJ == 1)
static FSJOUR mc1_fsj;
#endif
/* MC1 Cache Buffer for Data and FAT Caching */
static U32 mc1_cache[(MC1_CASZ+1) * 256 + MC1_FSJ * 128] __AT_MC1;
static FAT_VI mc1_vol;
#if (MC1_SPI == 0)
/* SD Native bus mode */
extern MCI_DRV mci1_drv;
static MCI_DEV mci1_dev;
#define MC1_INIT(m) mci_Init (m,&mci1_dev)
#define MC1_UNINIT(m) mci_UnInit (m,&mci1_dev)
#define MC1_RDSEC(s,b,c) mci_ReadSector (s,b,c,&mci1_dev)
#define MC1_WRSEC(s,b,c) mci_WriteSector (s,b,c,&mci1_dev)
#define MC1_RDINFO(i) mci_ReadInfo (i,&mci1_dev)
#define MC1_DEVCTRL(c,p) mci_DevCtrl (c,p, &mci1_dev)
#else
/* SPI bus mode */
extern SPI_DRV spi1_drv;
static MMC_DEV mmc1_dev;
#define MC1_INIT(m) mmc_Init (m,&mmc1_dev)
#define MC1_UNINIT(m) mmc_UnInit (m,&mmc1_dev)
#define MC1_RDSEC(s,b,c) mmc_ReadSector (s,b,c,&mmc1_dev)
#define MC1_WRSEC(s,b,c) mmc_WriteSector (s,b,c,&mmc1_dev)
#define MC1_RDINFO(i) mmc_ReadInfo (i,&mmc1_dev)
#define MC1_DEVCTRL(c,p) mmc_DevCtrl (c,p,&mmc1_dev)
#endif
/* MC1 wrapper functions */
static BOOL mc1_Init (U32 mode) {
return (MC1_INIT (mode));
}
static BOOL mc1_UnInit (U32 mode) {
return (MC1_UNINIT (mode));
}
static BOOL mc1_RdSect (U32 sect, U8 *buf, U32 cnt) {
return (MC1_RDSEC (sect, buf, cnt));
}
static BOOL mc1_WrSect (U32 sect, U8 *buf, U32 cnt) {
return (MC1_WRSEC (sect, buf, cnt));
}
static BOOL mc1_RdInfo (Media_INFO *info) {
return (MC1_RDINFO (info));
}
static U32 mc1_DevCtrl (U32 code, void *p) {
return (MC1_DEVCTRL (code, p));
}
/* MC1 FAT device driver */
FAT_DRV mc1_drv = {
mc1_Init,
mc1_UnInit,
mc1_RdSect,
mc1_WrSect,
mc1_RdInfo,
mc1_DevCtrl
};
#endif
/*----------------------------------------------------------------------------
* USB Flash device USB0 configuration
*---------------------------------------------------------------------------*/
#if (USB0_EN)
extern FAT_DRV usb0_drv;
#if (USB0_FSJ == 1)
static FSJOUR usb0_fsj;
#endif
/* USB Cache Buffer for Data and FAT Caching */
static U32 usb0_cache[(USB0_CASZ+1) * 256 + USB0_FSJ * 128];
static FAT_VI usb0_vol;
#endif
/*----------------------------------------------------------------------------
* USB Flash device USB1 configuration
*---------------------------------------------------------------------------*/
#if (USB1_EN)
extern FAT_DRV usb1_drv;
#if (USB1_FSJ == 1)
static FSJOUR usb1_fsj;
#endif
/* USB Cache Buffer for Data and FAT Caching */
static U32 usb1_cache[(USB1_CASZ+1) * 256 + USB1_FSJ * 128];
static FAT_VI usb1_vol;
#endif
/*----------------------------------------------------------------------------
* NAND Flash device NAND0 configuration
*---------------------------------------------------------------------------*/
#if (NAND0_EN)
extern NAND_DRV nand0_drv;
#if (NAND0_RELOC == 1)
#define __AT_NAND0 __at(NAND0_CADR)
#else
#define __AT_NAND0
#endif
#if (NAND0_FSJ == 1)
static FSJOUR nand0_fsj;
#endif
/* NAND Cache Buffer for FAT, Page and Block Caching */
#define NAND0_CSZ ((NAND0_CASZ+1) * 1024 + \
(NAND0_CAPG+2) * NAND0_PGSZ + \
(NAND0_CABL+2) * NAND0_PGCNT)
#define NAND0_FSJBUF (NAND0_FSJ * 512)
static U32 nand0_cache[NAND0_CSZ/4 + NAND0_FSJBUF/4] __AT_NAND0;
static PAGE_CACHE nand0_capg[NAND0_CAPG+1];
static BLOCK_CACHE nand0_cabl[NAND0_CABL+2];
static U32 nand0_ttsn[NAND_TSN_SIZE(NAND0_BLCNT,NAND0_PGSZ)];
static NAND_FTL_DEV nand0_dev;
static FAT_VI nand0_vol;
/* NAND Flash Configuration */
static NAND_FTL_CFG nand0_cfg = {
/* NAND Flash Geometry */
{ &nand0_dev.PgLay,
NAND0_BLCNT,
NAND0_PGCNT,
NAND0_PGSZ,
NAND_SEC_BLOCK (NAND0_PGCNT,NAND0_PGSZ),
NAND_SEC_PAGE (NAND0_PGSZ),
NAND_ADDR_CYCLES (NAND0_BLCNT,NAND0_PGCNT,NAND0_PGSZ),
NAND0_SWECC,
0
},
/* Block Translation Table Space */
1,
NAND_BTT_SIZE (NAND0_BLCNT),
/* Data Space */
NAND_BTT_SIZE (NAND0_BLCNT) + 1,
NAND0_BLCNT - 1,
/* Caching */
NAND0_CABL + 2,
NAND0_CAPG + 1,
NAND_TSN_SIZE(NAND0_BLCNT,NAND0_PGSZ),
/* Page buffer & Caches */
(U8 *)&nand0_cache[(NAND0_CASZ+1)*256],
&nand0_cabl[0],
(U8 *)&nand0_cache[(NAND0_CASZ+1)*256+(NAND0_CAPG+2)*NAND0_PGSZ/4],
&nand0_capg[0],
(U8 *)&nand0_cache[(NAND0_CASZ+1)*256+NAND0_PGSZ/4],
&nand0_ttsn[0]
};
/* NAND0 wrapper functions */
static BOOL nand0_Init (U32 mode) {
return (ftl_Init (mode, &nand0_dev));
}
static BOOL nand0_UnInit (U32 mode) {
return (ftl_UnInit (mode, &nand0_dev));
}
static BOOL nand0_RdSect (U32 sect, U8 *buf, U32 cnt) {
U32 retv = ftl_ReadSect (sect, buf, cnt, &nand0_dev);
if (retv == RTV_NOERR) return (__TRUE);
else return (__FALSE);
}
static BOOL nand0_WrSect (U32 sect, U8 *buf, U32 cnt) {
U32 retv = ftl_WriteSect (sect, buf, cnt, &nand0_dev);
if (retv == RTV_NOERR || retv == ERR_FTL_WARN) return (__TRUE);
else return (__FALSE);
}
static BOOL nand0_RdInfo (Media_INFO *info) {
return (ftl_ReadInfo (info, &nand0_dev));
}
static U32 nand0_DevCtrl (U32 code, void *p) {
if (code == DC_CHKMEDIA) return (M_NOCHKMEDIA);
if (code == DC_FORMAT) return (ftl_Format (&nand0_dev, p));
return (0);
}
FAT_DRV nfat0_drv = {
nand0_Init,
nand0_UnInit,
nand0_RdSect,
nand0_WrSect,
nand0_RdInfo,
nand0_DevCtrl
};
#endif
/*----------------------------------------------------------------------------
* NAND Flash device NAND1 configuration
*---------------------------------------------------------------------------*/
#if (NAND1_EN)
extern NAND_DRV nand1_drv;
#if (NAND1_RELOC == 1)
#define __AT_NAND1 __at(NAND1_CADR)
#else
#define __AT_NAND1
#endif
#if (NAND1_FSJ == 1)
static FSJOUR nand1_fsj;
#endif
/* NAND Cache Buffer for FAT, Page and Block Caching */
#define NAND1_CSZ ((NAND1_CASZ+1) * 1024 + \
(NAND1_CAPG+2) * NAND1_PGSZ + \
(NAND1_CABL+2) * NAND1_PGCNT)
#define NAND1_FSJBUF (NAND1_FSJ * 512)
static U32 nand1_cache[NAND1_CSZ/4 + NAND1_FSJBUF/4] __AT_NAND1;
static PAGE_CACHE nand1_capg[NAND1_CAPG+1];
static BLOCK_CACHE nand1_cabl[NAND1_CABL+2];
static U32 nand1_ttsn[NAND_TSN_SIZE(NAND1_BLCNT,NAND1_PGSZ)];
static NAND_FTL_DEV nand1_dev;
static FAT_VI nand1_vol;
/* NAND Flash Configuration */
static NAND_FTL_CFG nand1_cfg = {
/* NAND Flash Geometry */
{ &nand1_dev.PgLay,
NAND1_BLCNT,
NAND1_PGCNT,
NAND1_PGSZ,
NAND_SEC_BLOCK (NAND1_PGCNT,NAND1_PGSZ),
NAND_SEC_PAGE (NAND1_PGSZ),
NAND_ADDR_CYCLES (NAND1_BLCNT,NAND1_PGCNT,NAND1_PGSZ),
NAND1_SWECC,
1
},
/* Block Translation Table Space */
1,
NAND_BTT_SIZE (NAND1_BLCNT),
/* Data Space */
NAND_BTT_SIZE (NAND1_BLCNT) + 1,
NAND1_BLCNT - 1,
/* Caching */
NAND1_CABL + 2,
NAND1_CAPG + 1,
NAND_TSN_SIZE(NAND1_BLCNT,NAND1_PGSZ),
/* Page buffer & Caches */
(U8 *)&nand1_cache[(NAND1_CASZ+1)*256],
&nand1_cabl[0],
(U8 *)&nand1_cache[(NAND1_CASZ+1)*256+(NAND1_CAPG+2)*NAND1_PGSZ/4],
&nand1_capg[0],
(U8 *)&nand1_cache[(NAND1_CASZ+1)*256+NAND1_PGSZ/4],
&nand1_ttsn[0]
};
/* NAND0 wrapper functions */
static BOOL nand1_Init (U32 mode) {
return (ftl_Init (mode, &nand1_dev));
}
static BOOL nand1_UnInit (U32 mode) {
return (ftl_UnInit (mode, &nand1_dev));
}
static BOOL nand1_RdSect (U32 sect, U8 *buf, U32 cnt) {
U32 retv = ftl_ReadSect (sect, buf, cnt, &nand1_dev);
if (retv == RTV_NOERR) return (__TRUE);
else return (__FALSE);
}
static BOOL nand1_WrSect (U32 sect, U8 *buf, U32 cnt) {
U32 retv = ftl_WriteSect (sect, buf, cnt, &nand1_dev);
if (retv == RTV_NOERR || retv == ERR_FTL_WARN) return (__TRUE);
else return (__FALSE);
}
static BOOL nand1_RdInfo (Media_INFO *info) {
return (ftl_ReadInfo (info, &nand1_dev));
}
static U32 nand1_DevCtrl (U32 code, void *p) {
if (code == DC_CHKMEDIA) return (M_NOCHKMEDIA);
if (code == DC_FORMAT) return (ftl_Format (&nand1_dev, p));
return (0);
}
FAT_DRV nfat1_drv = {
nand1_Init,
nand1_UnInit,
nand1_RdSect,
nand1_WrSect,
nand1_RdInfo,
nand1_DevCtrl
};
#endif
/*----------------------------------------------------------------------------
* An array of installed Device drivers
*---------------------------------------------------------------------------*/
FS_DEV fs_DevPool[FS_NDRV] = {
#if (FL0_EN)
{ &fl0_vol, "F0", FS_EMB | FL0_DEF },
#endif
#if (SF0_EN)
{ &sf0_vol, "S0", FS_EMB | SF0_DEF },
#endif
#if (RAM0_EN)
{ &ram0_vol, "R0", FS_EMB | RAM0_DEF },
#endif
#if (MC0_EN)
{ &mc0_vol, "M0", FS_FAT | MC0_DEF | FS_IOC },
#endif
#if (MC1_EN)
{ &mc1_vol, "M1", FS_FAT | MC1_DEF | FS_IOC },
#endif
#if (USB0_EN)
{ &usb0_vol, "U0", FS_FAT | USB0_DEF },
#endif
#if (USB1_EN)
{ &usb1_vol, "U1", FS_FAT | USB1_DEF },
#endif
#if (NAND0_EN)
{ &nand0_vol,"N0", FS_FAT | NAND0_DEF| FS_IOC },
#endif
#if (NAND1_EN)
{ &nand1_vol,"N1", FS_FAT | NAND1_DEF| FS_IOC },
#endif
};
/*----------------------------------------------------------------------------
* Configure Flash File System
*---------------------------------------------------------------------------*/
void fs_config (void) {
#if (FL0_EN)
fl0_vol.BaseAdr = FL0_BADR;
fl0_vol.InitVal = (U32)0x1010101 * FL0_INITV;
fl0_vol.NumSect = sizeof(fl0_cfg)/sizeof(EFS_CFG);
fl0_vol.Size = FL0_SIZE;
fl0_vol.DevCfg = fl0_cfg;
fl0_vol.drv = &fl0_drv;
fl0_vol.CpuClk = CPU_CLK;
#endif
#if (SF0_EN)
sf0_vol.BaseAdr = 0;
sf0_vol.InitVal = (U32)0x1010101 * SF0_INITV;
sf0_vol.NumSect = sizeof(sf0_cfg)/sizeof(EFS_CFG);
sf0_vol.Size = SF0_SIZE;
sf0_vol.DevCfg = sf0_cfg;
sf0_vol.drv = &sf0_drv;
sf0_vol.CpuClk = CPU_CLK;
#endif
#if (RAM0_EN)
ram0_vol.BaseAdr= (U32)ram0_buf;
ram0_vol.InitVal= 0;
ram0_vol.NumSect= RAM0_NSECT;
ram0_vol.Size = RAM0_SIZE;
ram0_vol.DevCfg = ram0_cfg;
ram0_vol.drv = NULL;
#endif
#if (MC0_EN)
mc0_vol.CaSize = MC0_CASZ * 2;
mc0_vol.CaBuf = mc0_cache;
mc0_vol.drv = &mc0_drv;
#if (MC0_SPI == 0)
/* Register MCI driver for SD-Native mode */
mci0_dev.drv = &mci0_drv;
#else
/* Register SPI driver for SPI mode */
mmc0_dev.spi = &spi0_drv;
#endif
#if (MC0_FSJ)
/* Register file system journal */
mc0_fsj.buf = (U8 *)&mc0_cache[(MC0_CASZ+1) * 256];
mc0_vol.fsj = &mc0_fsj;
mc0_vol.RsvdS = FAT_SECT_RSVD;
#else
mc0_vol.fsj = NULL;
mc0_vol.RsvdS = 0;
#endif
#endif
#if (MC1_EN)
mc1_vol.CaSize = MC1_CASZ * 2;
mc1_vol.CaBuf = mc1_cache;
mc1_vol.drv = &mc1_drv;
#if (MC1_SPI == 0)
/* Register MCI driver for SD-Native mode */
mci1_dev.drv = &mci1_drv;
#else
/* Register SPI driver for SPI mode */
mmc1_dev.spi = &spi1_drv;
#endif
#if (MC1_FSJ)
/* Register file system journal */
mc1_fsj.buf = (U8 *)&mc1_cache[(MC1_CASZ+1) * 256];
mc1_vol.fsj = &mc1_fsj;
mc1_vol.RsvdS = FAT_SECT_RSVD;
#else
mc1_vol.fsj = NULL;
mc1_vol.RsvdS = 0;
#endif
#endif
#if (USB0_EN)
usb0_vol.CaSize = USB0_CASZ * 2;
usb0_vol.CaBuf = usb0_cache;
usb0_vol.drv = &usb0_drv;
#if (USB0_FSJ)
/* Register file system journal */
usb0_fsj.buf = (U8 *)&usb0_cache[(USB0_CASZ+1) * 256];
usb0_vol.fsj = &usb0_fsj;
usb0_vol.RsvdS = FAT_SECT_RSVD;
#else
usb0_vol.fsj = NULL;
usb0_vol.RsvdS = 0;
#endif
#endif
#if (USB1_EN)
usb1_vol.CaSize = USB1_CASZ * 2;
usb1_vol.CaBuf = usb1_cache;
usb1_vol.drv = &usb1_drv;
#if (USB1_FSJ)
/* Register file system journal */
usb1_fsj.buf = (U8 *)&usb1_cache[(USB1_CASZ+1) * 256];
usb1_vol.fsj = &usb1_fsj;
usb1_vol.RsvdS = FAT_SECT_RSVD;
#else
usb1_vol.fsj = NULL;
usb1_vol.RsvdS = 0;
#endif
#endif
#if (NAND0_EN)
nand0_vol.CaSize= NAND0_CASZ * 2;
nand0_vol.CaBuf = nand0_cache;
nand0_vol.drv = &nfat0_drv;
nand0_dev.Cfg = &nand0_cfg;
nand0_dev.Drv = &nand0_drv;
#if (NAND0_FSJ)
/* Register file system journal */
nand0_fsj.buf = (U8 *)&nand0_cache[NAND0_CSZ/4];
nand0_vol.fsj = &nand0_fsj;
nand0_vol.RsvdS = FAT_SECT_RSVD;
#else
nand0_vol.fsj = NULL;
nand0_vol.RsvdS = 0;
#endif
#endif
#if (NAND1_EN)
nand1_vol.CaSize= NAND1_CASZ * 2;
nand1_vol.CaBuf = nand1_cache;
nand1_vol.drv = &nfat1_drv;
nand1_dev.Cfg = &nand1_cfg;
nand1_dev.Drv = &nand1_drv;
#if (NAND1_FSJ)
/* Register file system journal */
nand1_fsj.buf = (U8 *)&nand1_cache[NAND1_CSZ/4];
nand1_vol.fsj = &nand1_fsj;
nand1_vol.RsvdS = FAT_SECT_RSVD;
#else
nand1_vol.fsj = NULL;
nand1_vol.RsvdS = 0;
#endif
#endif
STREAM_LIST_LOCK;
}
#if (EFS_USE == 0)
/* Empty functions to reduce image size when EFS not used */
BOOL efs_rename (const char *filename, IOB *fcb) { return (__FALSE); }
BOOL efs_create (const char *fname, IOB *fcb) { return (__FALSE); }
BOOL efs_delete (IOB *fcb) { return (__FALSE); }
U32 efs_free (EFS_VI *vi) { return (0); }
BOOL efs_format (EFS_VI *vi) { return (__FALSE); }
BOOL efs_ffind (FINFO *info, IOB *fcb) { return (__FALSE); }
BOOL efs_wclose (IOB *fcb) { return (__FALSE); }
U32 efs_read (IOB *fcb, U8 *buf, U32 len) { return (0); }
BOOL efs_write (IOB *fcb, const U8 *buf, U32 len){ return (__FALSE); }
BOOL efs_ensure (IOB *fcb) { return (__FALSE); }
BOOL efs_seek (IOB *fcb, U32 pos) { return (__FALSE); }
void efs_fsize (IOB *fcb) { ; }
BOOL efs_find (const char *name, IOB *fcb) { return (__FALSE); }
int efs_analyse (EFS_VI *vi) { return (0); }
BOOL efs_check (EFS_VI *vi) { return (__FALSE); }
BOOL efs_defrag (IOB *fcb) { return (__FALSE); }
#endif
#if (FAT_USE == 0)
/* Empty functions to reduce image size when FAT not used */
int fat_init (FAT_VI *vi) { return (-1); }
int fat_open (IOB *fh, const char *path, int openmode) { return (-1); }
int fat_close (IOB *fcb) { return (-1); }
int fat_read (IOB *fcb, U8 *buf, U32 len) { return (-1); }
int fat_write (IOB *fcb, const U8 *buf, U32 len) { return (-1); }
int fat_seek (IOB *fcb, U32 pos) { return (-1); }
int fat_delete (const char *fn, FAT_VI *vol) { return (-1); }
int fat_rename (const char *old, const char *newn, FAT_VI *vol) {
return (-1); }
U64 fat_free (FAT_VI *vi) { return (0) ; }
int fat_format (FAT_VI *vi, const char *opt) { return (-1); }
int fat_ffind (const char *fn, FINFO *info, FAT_VI *vol) {
return (-1); }
BOOL fat_jour_init (FAT_VI *vi) { return (__TRUE); }
BOOL fat_path_valid (const char *path, IOB *fcb) { return (__FALSE); }
#else
#if (FSJ_USE == 0)
/* Empty functions to reduce image size when journal not used */
BOOL fat_jour_init (FAT_VI *vi) { return (__TRUE); }
BOOL fat_jour_prep (FAT_VI *vi) { return (__TRUE); }
BOOL fsj_set_space (FSJOUR *fsj, U32 start_sect, U32 cnt) {
return (__FALSE); }
BOOL fsj_write (FSJOUR *fsj, U32 sect, U32 cnt, U8 *buf) {
return (__FALSE); }
BOOL fsj_init (FSJOUR *fsj, FAT_DRV *drv) { return (__FALSE); }
#endif
#endif
#if (FAT_NAME_CACNT == 0)
U32 elink_init (void) { return (1); }
U32 elink_init_path (const char *drvLet) { return (0xFF); }
U32 elink_flush (const char *drvLet) { return (1); }
U32 elink_cmd (U32 i, U32 j) { return (0); }
U32 elink_insert (void *p, U32 i, U32 j) { return (1); }
U32 elink_delete (void *p, U32 i) { return (0); }
U32 elink_scan (U32 i, void **pp, U32 j) { return (1); }
#endif
/*----------------------------------------------------------------------------
* end of file
*---------------------------------------------------------------------------*/