forked from tangrs/nspire-linux-loader2
-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathkernel.c
73 lines (58 loc) · 2.29 KB
/
kernel.c
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
/*
TI-NSPIRE Linux In-Place Bootloader
Copyright (C) 2012 Daniel Tang
This program is free software: you can redistribute it and/or modify
it under the terms of the GNU General Public License as published by
the Free Software Foundation, either version 3 of the License, or
(at your option) any later version.
This program is distributed in the hope that it will be useful,
but WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
GNU General Public License for more details.
You should have received a copy of the GNU General Public License
along with this program. If not, see <http://www.gnu.org/licenses/>.
*/
#include <os.h>
#include <libfdt.h>
#include "common.h"
#include "atag.h"
#include "fdt.h"
/* Where to relocate boot parameters? Defined as start of memory + 0x100 */
#define BOOT_PARAM_RELADDR ((char*)(settings.phys.start) + 0x100)
typedef void kentry(int, int, void*);
void kernel_cmdline(char *cmdline) {
if (strlen(cmdline)) strncpy(settings.kernel_cmdline, cmdline, sizeof(settings.kernel_cmdline)-1);
printl("Kernel command line: \"%s\"" NEWLINE, settings.kernel_cmdline);
}
void kernel_boot(char *ignored UNUSED) {
kentry *entry = (kentry*)settings.kernel.addr;
if (!settings.kernel_loaded) {
printl("Kernel not loaded." NEWLINE);
return;
}
/* Kernels and initrds should already be loaded to their correct places */
/* Build atag next */
if (!settings.dtb_loaded) {
if (atag_build()) return;
}
/* Set initrd location, size and kernel cmdline in DTB using libfdt */
else {
if(update_fdt()) return;
}
/* Enable bus access to all peripherals before booting */
*(io32_t)0x900B0018 = 0;
*(io32_t)0x900B0020 = 0;
builtin_memcpy(BOOT_PARAM_RELADDR, settings.boot_param.start, settings.boot_param.size);
clear_cache();
/* Disable D-Cache and MMU */
asm volatile("mrc p15, 0, r0, c1, c0, 0 \n"
"bic r0, r0, #0x5 \n"
"mcr p15, 0, r0, c1, c0, 0 \n"
: : : "r0" );
/* Bye bye */
if (settings.break_on_entry) {
asm volatile("bkpt #0");
}
entry(0, settings.machine_id, BOOT_PARAM_RELADDR);
__builtin_unreachable();
}