Rev 3386 | Go to most recent revision | Show entire file | Regard whitespace | Details | Blame | Last modification | View Log | RSS feed
Rev 3386 | Rev 4153 | ||
---|---|---|---|
Line 26... | Line 26... | ||
26 | * THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. |
26 | * THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. |
27 | */ |
27 | */ |
28 | 28 | ||
29 | #include "main.h" |
29 | #include "main.h" |
30 | #include <printf.h> |
30 | #include <printf.h> |
- | 31 | #include <align.h> |
|
- | 32 | #include <macros.h> |
|
- | 33 | #include <string.h> |
|
31 | #include "msim.h" |
34 | #include "msim.h" |
32 | #include "asm.h" |
35 | #include "asm.h" |
33 | #include "_components.h" |
36 | #include "_components.h" |
34 | 37 | ||
35 | #define KERNEL_VIRTUAL_ADDRESS 0x80100000 |
38 | #define KERNEL_VIRTUAL_ADDRESS 0x80100000 |
36 | 39 | ||
37 | char *release = RELEASE; |
40 | char *release = STRING(RELEASE); |
38 | 41 | ||
39 | #ifdef REVISION |
42 | #ifdef REVISION |
40 | char *revision = ", revision " REVISION; |
43 | char *revision = ", revision " STRING(REVISION); |
41 | #else |
44 | #else |
42 | char *revision = ""; |
45 | char *revision = ""; |
43 | #endif |
46 | #endif |
44 | 47 | ||
45 | #ifdef TIMESTAMP |
48 | #ifdef TIMESTAMP |
46 | char *timestamp = "\nBuilt on " TIMESTAMP; |
49 | char *timestamp = "\nBuilt on " STRING(TIMESTAMP); |
47 | #else |
50 | #else |
48 | char *timestamp = ""; |
51 | char *timestamp = ""; |
49 | #endif |
52 | #endif |
50 | 53 | ||
51 | /** Print version information. */ |
54 | /** Print version information. */ |
Line 70... | Line 73... | ||
70 | unsigned int i; |
73 | unsigned int i; |
71 | for (i = 0; i < COMPONENTS; i++) |
74 | for (i = 0; i < COMPONENTS; i++) |
72 | printf(" %L: %s image (size %d bytes)\n", components[i].start, components[i].name, components[i].size); |
75 | printf(" %L: %s image (size %d bytes)\n", components[i].start, components[i].name, components[i].size); |
73 | 76 | ||
74 | printf("\nCopying components\n"); |
77 | printf("\nCopying components\n"); |
- | 78 | ||
75 | unsigned int top = 0; |
79 | unsigned int top = 0; |
76 | bootinfo.cnt = 0; |
80 | bootinfo.cnt = 0; |
77 | for (i = 0; i < COMPONENTS; i++) { |
81 | for (i = 0; i < min(COMPONENTS, TASKMAP_MAX_RECORDS); i++) { |
78 | printf(" %s...", components[i].name); |
82 | printf(" %s...", components[i].name); |
79 | top = ALIGN_UP(top, PAGE_SIZE); |
83 | top = ALIGN_UP(top, PAGE_SIZE); |
80 | memcpy(((void *) KERNEL_VIRTUAL_ADDRESS) + top, components[i].start, components[i].size); |
84 | memcpy(((void *) KERNEL_VIRTUAL_ADDRESS) + top, components[i].start, components[i].size); |
81 | if (i > 0) { |
85 | if (i > 0) { |
82 | bootinfo.tasks[bootinfo.cnt].addr = ((void *) KERNEL_VIRTUAL_ADDRESS) + top; |
86 | bootinfo.tasks[bootinfo.cnt].addr = ((void *) KERNEL_VIRTUAL_ADDRESS) + top; |
83 | bootinfo.tasks[bootinfo.cnt].size = components[i].size; |
87 | bootinfo.tasks[bootinfo.cnt].size = components[i].size; |
- | 88 | strncpy(bootinfo.tasks[bootinfo.cnt].name, |
|
- | 89 | components[i].name, BOOTINFO_TASK_NAME_BUFLEN); |
|
84 | bootinfo.cnt++; |
90 | bootinfo.cnt++; |
85 | } |
91 | } |
86 | top += components[i].size; |
92 | top += components[i].size; |
87 | printf("done.\n"); |
93 | printf("done.\n"); |
88 | } |
94 | } |
89 | 95 | ||
- | 96 | unsigned int *cpumap = (unsigned int *) CPUMAP; |
|
- | 97 | bootinfo.cpumap = 0; |
|
- | 98 | for (i = 0; i < CPUMAP_MAX_RECORDS; i++) { |
|
- | 99 | if (cpumap[i] != 0) |
|
- | 100 | bootinfo.cpumap |= (1 << i); |
|
- | 101 | } |
|
- | 102 | ||
90 | printf("\nBooting the kernel...\n"); |
103 | printf("\nBooting the kernel...\n"); |
91 | jump_to_kernel((void *) KERNEL_VIRTUAL_ADDRESS, &bootinfo, sizeof(bootinfo)); |
104 | jump_to_kernel((void *) KERNEL_VIRTUAL_ADDRESS, &bootinfo); |
92 | } |
105 | } |