add mount table

This commit is contained in:
bernard 2013-07-22 07:46:10 +08:00
parent adc678dabb
commit b96b35613f
6 changed files with 49 additions and 8 deletions

View File

@ -23,6 +23,7 @@ void ff_convert_init()
if (uni2gbk_fd < 0)
rt_kprintf("Unable to open Unicode to GBK look up table.\r\n");
}
INIT_APP_EXPORT(ff_convert_init);
rt_uint16_t ff_convert(rt_uint16_t src, rt_uint32_t dir)
{

View File

@ -82,6 +82,16 @@ struct dfs_partition
rt_sem_t lock;
};
/* mount table */
struct dfs_mount_tbl
{
const char *device_name;
const char *path;
const char *filesystemtype;
unsigned long rwflag;
const void *data;
};
int dfs_register(const struct dfs_filesystem_operation *ops);
struct dfs_filesystem *dfs_filesystem_lookup(const char *path);
rt_err_t dfs_filesystem_get_partition(struct dfs_partition *part,
@ -98,6 +108,7 @@ int dfs_unmount(const char *specialfile);
/* extern variable */
extern const struct dfs_filesystem_operation *filesystem_operation_table[];
extern struct dfs_filesystem filesystem_table[];
extern const struct dfs_mount_tbl mount_table[];
extern char working_directory[];

View File

@ -497,6 +497,33 @@ int dfs_statfs(const char *path, struct statfs *buffer)
return -1;
}
#ifdef RT_USING_DFS_MNTTABLE
int dfs_mount_table(void)
{
int index;
while (1)
{
if (mount_table[index].path == RT_NULL) break;
if (dfs_mount(mount_table[index].device_name,
mount_table[index].path,
mount_table[index].filesystemtype,
mount_table[index].rwflag,
mount_table[index].data) != 0)
{
rt_kprintf("mount fs[%s] on %s failed.\n", mount_table[index].filesystemtype,
mount_table[index].path);
return -RT_ERROR;
}
index ++;
}
return 0;
}
INIT_ENV_EXPORT(dfs_mount_table);
#endif
#ifdef RT_USING_FINSH
#include <finsh.h>
void mkfs(const char *fs_name, const char *device_name)

View File

@ -191,10 +191,16 @@ typedef int (*init_fn_t)(void);
/* board init routines will be called in board_init() function */
#define INIT_BOARD_EXPORT(fn) INIT_EXPORT(fn, "1")
/* device/component/fs/app init routines will be called in init_thread */
/* device initialization */
#define INIT_DEVICE_EXPORT(fn) INIT_EXPORT(fn, "2")
/* components initialization (dfs, lwip, ...) */
#define INIT_COMPONENT_EXPORT(fn) INIT_EXPORT(fn, "3")
/* file system initialization (dfs-elm, dfs-rom, ...) */
#define INIT_FS_EXPORT(fn) INIT_EXPORT(fn, "4")
#define INIT_APP_EXPORT(fn) INIT_EXPORT(fn, "5")
/* environment initialization (mount disk, ...) */
#define INIT_ENV_EXPORT(fn) INIT_EXPORT(fn, "5")
/* appliation initialization (rtgui application etc ...) */
#define INIT_APP_EXPORT(fn) INIT_EXPORT(fn, "6")
/* event length */
#define RT_EVENT_LENGTH 32

View File

@ -452,7 +452,7 @@ rt_uint8_t rt_interrupt_get_nest(void);
/**
* application module
*/
void rt_system_module_init(void);
int rt_system_module_init(void);
/**
* @addtogroup KernelService

View File

@ -80,7 +80,7 @@ static struct rt_module_symtab *_rt_module_symtab_end = RT_NULL;
*
* This function will initialize system module
*/
void rt_system_module_init(void)
int rt_system_module_init(void)
{
#ifdef __GNUC__
extern int __rtmsymtab_start;
@ -100,6 +100,7 @@ void rt_system_module_init(void)
/* initialize heap semaphore */
rt_sem_init(&mod_sem, "module", 1, RT_IPC_FLAG_FIFO);
#endif
return 0;
}
INIT_COMPONENT_EXPORT(rt_system_module_init);
@ -805,9 +806,6 @@ rt_module_t rt_module_load(const char *name, void *module_ptr)
if (elf_module->e_entry != 0)
{
rt_uint32_t *stack_size;
rt_uint8_t *priority;
#ifdef RT_USING_SLAB
/* init module memory allocator */
module->mem_list = RT_NULL;
@ -1180,8 +1178,6 @@ rt_err_t rt_module_destroy(rt_module_t module)
*/
rt_err_t rt_module_unload(rt_module_t module)
{
int i;
rt_err_t result;
struct rt_object *object;
struct rt_list_node *list;