Rev 3042 | Show entire file | Ignore whitespace | Details | Blame | Last modification | View Log | RSS feed
| Rev 3042 | Rev 4377 | ||
|---|---|---|---|
| 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 | } |