summaryrefslogtreecommitdiffstats
path: root/src/sys/vfs/vfs_init.C
blob: 91e09876f264191a4b82e93779a249c0b942cd1a (plain)
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;
}


OpenPOWER on IntegriCloud