提交 d240423d 编写于 作者: qiuyiuestc's avatar qiuyiuestc

construct module symbol table

git-svn-id: https://rt-thread.googlecode.com/svn/trunk@1053 bbd45198-f89e-11dd-88c7-29a3b14d5316
上级 b2fb4be8
...@@ -39,15 +39,11 @@ static void open_btn_onbutton(rtgui_widget_t* widget, struct rtgui_event* event) ...@@ -39,15 +39,11 @@ static void open_btn_onbutton(rtgui_widget_t* widget, struct rtgui_event* event)
rt_memset(name, 0, sizeof(name)); rt_memset(name, 0, sizeof(name));
/* 获得图像的类型 */ /* 获得应用模块的类型 */
if (rt_strstr(path, ".mo") != RT_NULL || rt_strstr(path, ".so") != RT_NULL) if (rt_strstr(path, ".mo") != RT_NULL || rt_strstr(path, ".so") != RT_NULL)
{ {
rt_memcpy(name, "mod", 4); rt_module_open(path);
} }
/* 如果图像文件有效,创建相应的rtgui_image对象 */
if (name[0] != '\0')
rt_module_load_from_file(name, path);
} }
/* 删除 文件列表 视图 */ /* 删除 文件列表 视图 */
......
...@@ -392,6 +392,13 @@ struct rt_module ...@@ -392,6 +392,13 @@ struct rt_module
rt_list_t module_page; /* module using page */ rt_list_t module_page; /* module using page */
void* page_node_pool; void* page_node_pool;
/* module symbol table */
rt_uint32_t nsym;
struct rt_module_symtab *symtab;
/* reference count */
rt_uint32_t nref;
/* object in this module, module object is the last basic object type */ /* object in this module, module object is the last basic object type */
struct rt_object_information module_object[RT_Object_Class_Module]; struct rt_object_information module_object[RT_Object_Class_Module];
}; };
......
...@@ -308,8 +308,8 @@ rt_err_t rt_device_control(rt_device_t dev, rt_uint8_t cmd, void* arg); ...@@ -308,8 +308,8 @@ rt_err_t rt_device_control(rt_device_t dev, rt_uint8_t cmd, void* arg);
*/ */
rt_module_t rt_module_load(const rt_uint8_t* name, void* module_ptr); rt_module_t rt_module_load(const rt_uint8_t* name, void* module_ptr);
rt_module_t rt_module_load_from_file(const rt_uint8_t* name, const char* filename);
rt_err_t rt_module_unload(rt_module_t module); rt_err_t rt_module_unload(rt_module_t module);
rt_module_t rt_module_open(const char* filename);
void *rt_module_malloc(rt_size_t size); void *rt_module_malloc(rt_size_t size);
void *rt_module_realloc(void *ptr, rt_size_t size); void *rt_module_realloc(void *ptr, rt_size_t size);
void rt_module_free(rt_module_t module, void *addr); void rt_module_free(rt_module_t module, void *addr);
......
...@@ -129,13 +129,15 @@ void rt_thread_idle_excute(void) ...@@ -129,13 +129,15 @@ void rt_thread_idle_excute(void)
if((module->module_thread == RT_NULL) && if((module->module_thread == RT_NULL) &&
rt_list_isempty(&module->module_object[RT_Object_Class_Thread].object_list) ) rt_list_isempty(&module->module_object[RT_Object_Class_Thread].object_list) )
{ {
/* unload module */ module->nref--;
rt_module_unload(module);
} }
} }
#endif //RT_USING_MODULE
/* unload module */
if(module->nref == 0) rt_module_unload(module);
#endif
} }
#endif //RT_USING_HEAP #endif
} }
static void rt_thread_idle_entry(void* parameter) static void rt_thread_idle_entry(void* parameter)
......
...@@ -45,6 +45,13 @@ struct rt_module_page ...@@ -45,6 +45,13 @@ struct rt_module_page
}; };
static struct rt_module_page *rt_module_page_list; static struct rt_module_page *rt_module_page_list;
/* module memory allocator */
struct rt_mem_head
{
rt_size_t size; /* size of memory block */
struct rt_mem_head *next; /* next valid memory block */
};
static rt_module_t rt_current_module = RT_NULL; static rt_module_t rt_current_module = RT_NULL;
rt_list_t rt_module_symbol_list; rt_list_t rt_module_symbol_list;
struct rt_module_symtab *_rt_module_symtab_begin = RT_NULL, *_rt_module_symtab_end = RT_NULL; struct rt_module_symtab *_rt_module_symtab_begin = RT_NULL, *_rt_module_symtab_end = RT_NULL;
...@@ -66,6 +73,9 @@ void rt_system_module_init(void) ...@@ -66,6 +73,9 @@ void rt_system_module_init(void)
#endif #endif
rt_list_init(&rt_module_symbol_list); rt_list_init(&rt_module_symbol_list);
/* init current module */
rt_current_module = RT_NULL;
} }
static rt_uint32_t rt_module_symbol_find(const rt_uint8_t* sym_str) static rt_uint32_t rt_module_symbol_find(const rt_uint8_t* sym_str)
...@@ -330,7 +340,7 @@ rt_module_t rt_module_load(const rt_uint8_t* name, void* module_ptr) ...@@ -330,7 +340,7 @@ rt_module_t rt_module_load(const rt_uint8_t* name, void* module_ptr)
rt_module_arm_relocate( rt_module_arm_relocate(
module, module,
rel, rel,
(Elf32_Addr)((rt_uint8_t*)module->module_space + sym->st_value)); (Elf32_Addr)(module->module_space + sym->st_value));
} }
else if(linked == RT_FALSE) else if(linked == RT_FALSE)
{ {
...@@ -354,22 +364,42 @@ rt_module_t rt_module_load(const rt_uint8_t* name, void* module_ptr) ...@@ -354,22 +364,42 @@ rt_module_t rt_module_load(const rt_uint8_t* name, void* module_ptr)
} }
} }
/* construct module symbol table */
for (index = 0; index < elf_module->e_shnum; index ++)
{
rt_uint8_t* shstrab = (rt_uint8_t*) module_ptr + shdr[elf_module->e_shstrndx].sh_offset;
if (rt_strcmp(shstrab + shdr[index].sh_name, ELF_RTMSYMTAB) == 0)
{
module->symtab = (struct rt_module_symtab *)(module->module_space + shdr[index].sh_addr);
module->nsym = shdr[index].sh_size / sizeof(struct rt_module_symtab);
}
}
/* init module object container */ /* init module object container */
rt_module_init_object_container(module); rt_module_init_object_container(module);
/* create module thread */
module->stack_size = 512; module->stack_size = 512;
module->thread_priority = 90; module->thread_priority = 90;
module->module_thread = rt_thread_create(name, module->module_thread = rt_thread_create(name,
module->module_entry, RT_NULL, module->module_entry, RT_NULL,
module->stack_size, module->stack_size,
module->thread_priority, 10); module->thread_priority, 10);
module->module_thread->module_id = (void*)module; module->module_thread->module_id = (void*)module;
/* init module memory allocator */
module->module_mem_list = RT_NULL; module->module_mem_list = RT_NULL;
module->page_node_pool = rt_malloc(sizeof(struct rt_mempool)); module->page_node_pool = rt_malloc(sizeof(struct rt_mempool));
rt_memset(module->page_node_pool, 0, sizeof(struct rt_mempool)); rt_memset(module->page_node_pool, 0, sizeof(struct rt_mempool));
rt_list_init(&module->module_page); rt_list_init(&module->module_page);
/* increase module reference count */
module->nref++;
/* startup module thread */
rt_thread_startup(module->module_thread); rt_thread_startup(module->module_thread);
return module; return module;
} }
...@@ -384,7 +414,7 @@ rt_module_t rt_module_load(const rt_uint8_t* name, void* module_ptr) ...@@ -384,7 +414,7 @@ rt_module_t rt_module_load(const rt_uint8_t* name, void* module_ptr)
* @return the module object * @return the module object
* *
*/ */
rt_module_t rt_module_load_from_file(const rt_uint8_t* name, const char* filename) rt_module_t rt_module_open(const char* filename)
{ {
int fd, length; int fd, length;
struct rt_module* module; struct rt_module* module;
...@@ -403,12 +433,17 @@ rt_module_t rt_module_load_from_file(const rt_uint8_t* name, const char* filenam ...@@ -403,12 +433,17 @@ rt_module_t rt_module_load_from_file(const rt_uint8_t* name, const char* filenam
return RT_NULL; return RT_NULL;
} }
rt_kprintf("read %d bytes from file\n", length); rt_kprintf("read %d bytes from file\n", length);
module = rt_module_load(name, (void *)buffer); module = rt_module_load(filename, (void *)buffer);
rt_free(buffer); rt_free(buffer);
close(fd); close(fd);
return module; return module;
} }
#if defined(RT_USING_FINSH)
#include <finsh.h>
FINSH_FUNCTION_EXPORT(rt_module_open, load module from file);
#endif
#endif #endif
/** /**
...@@ -659,13 +694,46 @@ rt_module_t rt_module_find(char* name) ...@@ -659,13 +694,46 @@ rt_module_t rt_module_find(char* name)
return RT_NULL; return RT_NULL;
} }
/* module memory allocator */ static struct rt_mem_head *morepage(rt_size_t nu)
struct rt_mem_head
{ {
rt_size_t size; /* size of memory block */ rt_uint8_t *cp;
struct rt_mem_head *next; /* next valid memory block */ rt_uint32_t npage;
}; struct rt_mem_head *up;
static struct rt_mem_head *morepage(rt_size_t nu); struct rt_module_page *node;
RT_ASSERT (nu != 0);
npage = (nu * sizeof(struct rt_mem_head) + RT_MM_PAGE_SIZE - 1)/RT_MM_PAGE_SIZE;
cp = rt_page_alloc(npage);
if(cp == RT_NULL) return RT_NULL;
if(((struct rt_mempool*)rt_current_module->page_node_pool)->start_address == 0)
{
/* allocate a page for page node */
void *start = rt_page_alloc(1);
rt_mp_init(
(struct rt_mempool *)rt_current_module->page_node_pool,
"pnp",
start,
RT_MM_PAGE_SIZE,
sizeof(struct rt_module_page));
}
/* allocate page node from mempool */
node = rt_mp_alloc((struct rt_mempool *)rt_current_module->page_node_pool, RT_WAITING_FOREVER);
node->ptr = cp;
node->npage = npage;
/* insert page node to moudle's page list */
if(rt_module_self() != RT_NULL)
rt_list_insert_after (&rt_current_module->module_page, &node->list);
up = (struct rt_mem_head *) cp;
up->size = npage * RT_MM_PAGE_SIZE / sizeof(struct rt_mem_head);
rt_module_free(rt_current_module, (void *)(up+1));
return up;
}
/* /*
rt_module_malloc - alloc memory block in free list rt_module_malloc - alloc memory block in free list
...@@ -840,56 +908,4 @@ void *rt_module_realloc(void *ptr, rt_size_t size) ...@@ -840,56 +908,4 @@ void *rt_module_realloc(void *ptr, rt_size_t size)
} }
} }
static struct rt_mem_head *morepage(rt_size_t nu)
{
rt_uint8_t *cp;
rt_uint32_t npage;
struct rt_mem_head *up;
struct rt_module_page *node;
RT_ASSERT (nu != 0);
npage = (nu * sizeof(struct rt_mem_head) + RT_MM_PAGE_SIZE - 1)/RT_MM_PAGE_SIZE;
cp = rt_page_alloc(npage);
if(cp == RT_NULL) return RT_NULL;
if(((struct rt_mempool*)rt_current_module->page_node_pool)->start_address == 0)
{
/* allocate a page for page node */
void *start = rt_page_alloc(1);
rt_mp_init(
(struct rt_mempool *)rt_current_module->page_node_pool,
"pnp",
start,
RT_MM_PAGE_SIZE,
sizeof(struct rt_module_page));
}
/* allocate page node from mempool */
node = rt_mp_alloc((struct rt_mempool *)rt_current_module->page_node_pool, RT_WAITING_FOREVER);
node->ptr = cp;
node->npage = npage;
/* insert page node to moudle's page list */
if(rt_module_self() != RT_NULL)
rt_list_insert_after (&rt_current_module->module_page, &node->list);
up = (struct rt_mem_head *) cp;
up->size = npage * RT_MM_PAGE_SIZE / sizeof(struct rt_mem_head);
rt_module_free(rt_current_module, (void *)(up+1));
return up;
}
#if defined(RT_USING_FINSH)
#include <finsh.h>
void run_module(const rt_uint8_t* name, const char* filename)
{
rt_module_load_from_file(name, filename);
}
FINSH_FUNCTION_EXPORT(run_module, load module from file);
#endif
#endif #endif
...@@ -97,6 +97,7 @@ typedef struct { ...@@ -97,6 +97,7 @@ typedef struct {
#define ELF_STRTAB ".strtab" /* string table */ #define ELF_STRTAB ".strtab" /* string table */
#define ELF_SYMTAB ".symtab" /* symbol table */ #define ELF_SYMTAB ".symtab" /* symbol table */
#define ELF_TEXT ".text" /* code */ #define ELF_TEXT ".text" /* code */
#define ELF_RTMSYMTAB "RTMSymTab"
/* Symbol Table Entry */ /* Symbol Table Entry */
typedef struct elf32_sym { typedef struct elf32_sym {
......
...@@ -283,9 +283,9 @@ rt_object_t rt_object_allocate(enum rt_object_class_type type, const char* name) ...@@ -283,9 +283,9 @@ rt_object_t rt_object_allocate(enum rt_object_class_type type, const char* name)
#ifdef RT_USING_MODULE #ifdef RT_USING_MODULE
if(rt_module_self() != RT_NULL) if(rt_module_self() != RT_NULL)
{ {
object->module_id = (void*)rt_module_self();
object->flag |= RT_OBJECT_FLAG_MODULE; object->flag |= RT_OBJECT_FLAG_MODULE;
} }
object->module_id = (void*)rt_module_self();
#endif #endif
/* copy name */ /* copy name */
......
/* /*
* File : module.c * File : rtm.c
* This file is part of RT-Thread RTOS * This file is part of RT-Thread RTOS
* COPYRIGHT (C) 2006 - 2010, RT-Thread Development Team * COPYRIGHT (C) 2006 - 2010, RT-Thread Development Team
* *
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册