Subversion Repositories HelenOS-historic

Rev

Rev 1018 | Go to most recent revision | Show entire file | Ignore whitespace | Details | Blame | Last modification | View Log | RSS feed

Rev 1018 Rev 1685
Line 28... Line 28...
28
 
28
 
29
#include "main.h" 
29
#include "main.h" 
30
#include "printf.h"
30
#include "printf.h"
31
#include "msim.h"
31
#include "msim.h"
32
#include "asm.h"
32
#include "asm.h"
-
 
33
#include "_components.h"
33
 
34
 
34
#define KERNEL_VIRTUAL_ADDRESS 0x80100000
35
#define KERNEL_VIRTUAL_ADDRESS 0x80100000
35
#define KERNEL_START &_binary_____________kernel_kernel_bin_start
-
 
36
#define KERNEL_END &_binary_____________kernel_kernel_bin_end
-
 
37
#define KERNEL_SIZE ((unsigned int) KERNEL_END - (unsigned int) KERNEL_START)
-
 
38
 
36
 
39
void bootstrap(void)
37
void bootstrap(void)
40
{
38
{
41
    printf("HelenOS MIPS Bootloader\n");
39
    printf("HelenOS MIPS Bootloader\n");
42
    printf("loaded at %L\n", &start);
-
 
43
    printf("kernel memory at %L (size %d bytes)\n", KERNEL_VIRTUAL_ADDRESS, KERNEL_SIZE);
-
 
44
   
40
   
-
 
41
    component_t components[COMPONENTS];
-
 
42
    bootinfo_t bootinfo;
45
    // TODO: implement memcpy
43
    init_components(components);
-
 
44
   
-
 
45
    printf("\nMemory statistics\n");
-
 
46
    printf(" kernel entry point at %L\n", KERNEL_VIRTUAL_ADDRESS);
-
 
47
    printf(" %L: boot info structure\n", &bootinfo);
-
 
48
   
46
    int i;
49
    unsigned int i;
47
    for (i = 0; i < KERNEL_SIZE; i++) {
50
    for (i = 0; i < COMPONENTS; i++)
-
 
51
        printf(" %L: %s image (size %d bytes)\n", components[i].start, components[i].name, components[i].size);
-
 
52
   
-
 
53
    printf("\nCopying components\n");
48
        if (i % 4096 == 0)
54
    unsigned int top = 0;
49
            printf(".");
55
    bootinfo.cnt = 0;
-
 
56
    for (i = 0; i < COMPONENTS; i++) {
-
 
57
        printf(" %s...", components[i].name);
-
 
58
        top = ALIGN_UP(top, PAGE_SIZE);
50
        ((char *) KERNEL_VIRTUAL_ADDRESS)[i] = ((char *) KERNEL_START)[i];
59
        memcpy(((void *) KERNEL_VIRTUAL_ADDRESS) + top, components[i].start, components[i].size);
-
 
60
        if (i > 0) {
-
 
61
            bootinfo.tasks[bootinfo.cnt].addr = ((void *) KERNEL_VIRTUAL_ADDRESS) + top;
-
 
62
            bootinfo.tasks[bootinfo.cnt].size = components[i].size;
-
 
63
            bootinfo.cnt++;
-
 
64
        }
-
 
65
        top += components[i].size;
-
 
66
        printf("done.\n");
51
    }
67
    }
52
   
68
   
53
    printf("\nBooting the kernel...\n");
69
    printf("\nBooting the kernel...\n");
54
   
-
 
55
    jump_to_kernel((void *) KERNEL_VIRTUAL_ADDRESS);
70
    jump_to_kernel((void *) KERNEL_VIRTUAL_ADDRESS, &bootinfo, sizeof(bootinfo));
56
}
71
}