1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
|
// IBM_PROLOG_BEGIN_TAG
// This is an automatically generated prolog.
//
// $Source: src/sys/vfs/vfs_init.C $
//
// IBM CONFIDENTIAL
//
// COPYRIGHT International Business Machines Corp. 2011
//
// p1
//
// Object Code Only (OCO) source materials
// Licensed Internal Code Source Materials
// IBM HostBoot Licensed Internal Code
//
// The source code for this program is not published or other-
// wise divested of its trade secrets, irrespective of what has
// been deposited with the U.S. Copyright Office.
//
// Origin: 30
//
// IBM_PROLOG_END
/**
* @file vfs_init.C
* @brief function definitions for funtions used to initialize modules
*/
#include <sys/vfs.h>
#include <kernel/console.H>
#include <limits.h>
#include <sys/mm.h>
#include <util/align.H>
VfsSystemModule VFS_MODULES[VFS_MODULE_MAX];
uint64_t VFS_LAST_ADDRESS;
int vfs_module_perms(VfsSystemModule* module)
{
int rc = 0;
uint64_t memsize = ALIGN_PAGE(module->byte_count);
uint64_t textsize= (uint64_t)module->data - (uint64_t)module->text;
uint64_t datasize = memsize - textsize;
printkd("%s text=%p:%lx data=%p:%lx\n",
module->module,
module->text,
textsize,
module->data,
datasize);
if(textsize != 0)
{
// Mark text pages(s) as executable
rc |= mm_set_permission(module->text,
textsize,
EXECUTABLE);
// Mark data pages(s) as normal
rc |= mm_set_permission(module->data,
datasize,
WRITABLE);
}
else // ro data module
{
// Mark data pages(s) as normal
rc |= mm_set_permission(module->data,
datasize,
READ_ONLY);
}
return rc;
}
// ----------------------------------------------------------------------------
void vfs_module_init()
{
printk("Initializing modules.\n");
VfsSystemModule* module = &VFS_MODULES[0];
while ('\0' != module->module[0])
{
int rc = vfs_module_perms(module);
if(rc) printk("Perms set failed on %s, rc = %d\n",
module->module,rc);
++module;
}
module = &VFS_MODULES[0];
while ('\0' != module->module[0])
{
printk("\tIniting module %s...", module->module);
if (NULL != module->init)
(module->init)(NULL);
printk("done.\n");
++module;
}
printk("Modules initialized.\n");
}
// ----------------------------------------------------------------------------
VfsSystemModule * vfs_find_module(VfsSystemModule * i_table,
const char * i_name)
{
VfsSystemModule* module = i_table;
VfsSystemModule* ret = NULL;
while ('\0' != module->module[0])
{
if (0 == strcmp(i_name,module->module))
{
ret = module;
break;
}
module++;
}
return ret;
}
|