I don't even know what to write at this point
This commit is contained in:
parent
df0ebbbbcd
commit
72a46bc7ce
12 changed files with 235 additions and 96 deletions
|
@ -21,48 +21,64 @@
|
||||||
#include <mm/vmm.h>
|
#include <mm/vmm.h>
|
||||||
#include <lib/string.h>
|
#include <lib/string.h>
|
||||||
#include <print.h>
|
#include <print.h>
|
||||||
|
#include <axboot.h>
|
||||||
#include <stdint.h>
|
#include <stdint.h>
|
||||||
|
|
||||||
/* Trimmed down version of */
|
/* Trimmed down version of */
|
||||||
/* https://github.com/KevinAlavik/nekonix/blob/main/kernel/src/mm/vmm.c */
|
/* https://github.com/KevinAlavik/nekonix/blob/main/kernel/src/mm/vmm.c */
|
||||||
/* Thanks, Kevin <3 */
|
/* Thanks, Kevin <3 */
|
||||||
|
|
||||||
void map_page(uintptr_t *pm, uintptr_t virt, uintptr_t phys, uint64_t flags)
|
void map_pages(pagetable *pm, uintptr_t virt, uintptr_t phys, size_t size, uint64_t flags)
|
||||||
{
|
{
|
||||||
uint64_t pml1_idx = (virt & (uint64_t)0x1ff << 12) >> 12;
|
for (size_t i = 0; i < ROUND_UP(size, PAGE_SIZE); i += PAGE_SIZE) {
|
||||||
uint64_t pml2_idx = (virt & (uint64_t)0x1ff << 21) >> 21;
|
map_page(pm, virt + i, phys + i, flags);
|
||||||
uint64_t pml3_idx = (virt & (uint64_t)0x1ff << 30) >> 30;
|
|
||||||
uint64_t pml4_idx = (virt & (uint64_t)0x1ff << 39) >> 39;
|
|
||||||
|
|
||||||
if (!(pm[pml4_idx] & 1)) {
|
|
||||||
pm[pml4_idx] = (uint64_t)mem_alloc(PAGE_SIZE) | flags;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
uint64_t *pml3_table = (uint64_t *)(pm[pml4_idx] & 0x000FFFFFFFFFF000);
|
|
||||||
if (!(pml3_table[pml3_idx] & 1)) {
|
|
||||||
pml3_table[pml3_idx] = (uint64_t)mem_alloc(PAGE_SIZE) | flags;
|
|
||||||
}
|
|
||||||
|
|
||||||
uint64_t *pml2_table = (uint64_t *)(pml3_table[pml3_idx] & 0x000FFFFFFFFFF000);
|
|
||||||
if (!(pml2_table[pml2_idx] & 1)) {
|
|
||||||
pml2_table[pml2_idx] = (uint64_t)mem_alloc(PAGE_SIZE) | flags;
|
|
||||||
}
|
|
||||||
|
|
||||||
uint64_t *pml1_table = (uint64_t *)(pml2_table[pml2_idx] & 0x000FFFFFFFFFF000);
|
|
||||||
pml1_table[pml1_idx] = phys | flags;
|
|
||||||
|
|
||||||
debug("map_page(): Mapped 0x%lx -> 0x%lx\n", phys, virt);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
uintptr_t *create_pagemap()
|
void map_page(pagetable *pm, uintptr_t virt, uintptr_t phys, uint64_t flags)
|
||||||
{
|
{
|
||||||
uint64_t *pm = (uint64_t *)mem_alloc(PAGE_SIZE);
|
uint64_t pml1_idx = (virt >> 12) & 0x1ff;
|
||||||
|
uint64_t pml2_idx = (virt >> 21) & 0x1ff;
|
||||||
|
uint64_t pml3_idx = (virt >> 30) & 0x1ff;
|
||||||
|
uint64_t pml4_idx = (virt >> 39) & 0x1ff;
|
||||||
|
|
||||||
|
if (!(pm->entries[pml4_idx] & 1)) {
|
||||||
|
void *pml4 = mem_alloc(PAGE_SIZE);
|
||||||
|
memset(pml4, 0, sizeof(pagetable));
|
||||||
|
pm->entries[pml4_idx] = (uint64_t)pml4 | VMM_PRESENT | VMM_WRITABLE | VMM_USER;
|
||||||
|
}
|
||||||
|
|
||||||
|
pagetable *pml3_table = (pagetable *)(pm->entries[pml4_idx] & 0x000FFFFFFFFFF000);
|
||||||
|
if (!(pml3_table->entries[pml3_idx] & 1)) {
|
||||||
|
void *pml3 = mem_alloc(PAGE_SIZE);
|
||||||
|
memset(pml3, 0, sizeof(pagetable));
|
||||||
|
pml3_table->entries[pml3_idx] = (uint64_t)pml3 | VMM_PRESENT | VMM_WRITABLE | VMM_USER;
|
||||||
|
}
|
||||||
|
|
||||||
|
pagetable *pml2_table = (pagetable *)(pml3_table->entries[pml3_idx] & 0x000FFFFFFFFFF000);
|
||||||
|
if (!(pml2_table->entries[pml2_idx] & 1)) {
|
||||||
|
void *pml2 = mem_alloc(PAGE_SIZE);
|
||||||
|
memset(pml2, 0, sizeof(pagetable));
|
||||||
|
pml2_table->entries[pml2_idx] = (uint64_t)pml2 | VMM_PRESENT | VMM_WRITABLE | VMM_USER;
|
||||||
|
}
|
||||||
|
|
||||||
|
pagetable *pml1_table = (pagetable *)(pml2_table->entries[pml2_idx] & 0x000FFFFFFFFFF000);
|
||||||
|
if (!(pml1_table->entries[pml1_idx] & 1)) {
|
||||||
|
pml1_table->entries[pml1_idx] = (phys | 0x000FFFFFFFFFF000) | flags;
|
||||||
|
}
|
||||||
|
|
||||||
|
debug("map_page(): Mapped 0x%llx -> 0x%llx\n", phys, virt);
|
||||||
|
}
|
||||||
|
|
||||||
|
pagetable *create_pagemap()
|
||||||
|
{
|
||||||
|
pagetable *pm = (pagetable *)mem_alloc(PAGE_SIZE);
|
||||||
if (!pm) {
|
if (!pm) {
|
||||||
debug("create_pagemap(): Failed to allocate memory for a new pm.\n");
|
debug("create_pagemap(): Failed to allocate memory for a new pm.\n");
|
||||||
return NULL;
|
return NULL;
|
||||||
}
|
}
|
||||||
memset(pm, 0, PAGE_SIZE);
|
memset(pm, 0, sizeof(pagetable));
|
||||||
|
|
||||||
debug("create_pagemap(): Created new pm at 0x%lx\n", (uint64_t)pm);
|
debug("create_pagemap(): Created new pm at 0x%llx\n", (uint64_t)pm);
|
||||||
return pm;
|
return pm;
|
||||||
}
|
}
|
||||||
|
|
11
boot/arch/x86_64/common/proto/aurix_handoff.S
Normal file
11
boot/arch/x86_64/common/proto/aurix_handoff.S
Normal file
|
@ -0,0 +1,11 @@
|
||||||
|
.globl _aurix_handoff_start
|
||||||
|
.globl _aurix_handoff_end
|
||||||
|
.globl aurix_handoff
|
||||||
|
|
||||||
|
aurix_handoff:
|
||||||
|
cli
|
||||||
|
movq %rsi, %rsp
|
||||||
|
_aurix_handoff_start:
|
||||||
|
movq %rdi, %cr3
|
||||||
|
jmpq *%rdx
|
||||||
|
_aurix_handoff_end:
|
|
@ -20,7 +20,7 @@
|
||||||
#include <vfs/vfs.h>
|
#include <vfs/vfs.h>
|
||||||
#include <mm/mman.h>
|
#include <mm/mman.h>
|
||||||
#include <mm/vmm.h>
|
#include <mm/vmm.h>
|
||||||
#include <loader/elf.h>
|
#include <proto/aurix.h>
|
||||||
#include <print.h>
|
#include <print.h>
|
||||||
|
|
||||||
void axboot_init()
|
void axboot_init()
|
||||||
|
@ -31,22 +31,7 @@ void axboot_init()
|
||||||
while (1);
|
while (1);
|
||||||
}
|
}
|
||||||
|
|
||||||
// read kernel -> test read
|
aurix_load("\\System\\axkrnl");
|
||||||
char *kbuf = NULL;
|
|
||||||
vfs_read("\\System\\axkrnl", &kbuf);
|
|
||||||
|
|
||||||
// TODO: Do something with the kernel :p
|
|
||||||
uintptr_t *pm = create_pagemap();
|
|
||||||
if (!pm) {
|
|
||||||
debug("axboot_init(): Failed to create kernel pagemap! Halting...\n");
|
|
||||||
// TODO: Halt
|
|
||||||
while (1);
|
|
||||||
}
|
|
||||||
|
|
||||||
void *kernel_entry = (void *)elf_load(kbuf, pm);
|
|
||||||
(void)kernel_entry;
|
|
||||||
|
|
||||||
mem_free(kbuf);
|
|
||||||
|
|
||||||
while (1);
|
while (1);
|
||||||
}
|
}
|
|
@ -28,7 +28,61 @@
|
||||||
/* https://github.com/KevinAlavik/nekonix/blob/main/kernel/src/proc/elf.c */
|
/* https://github.com/KevinAlavik/nekonix/blob/main/kernel/src/proc/elf.c */
|
||||||
/* Thanks, Kevin <3 */
|
/* Thanks, Kevin <3 */
|
||||||
|
|
||||||
uint64_t elf_load(char *data, uintptr_t *pagemap)
|
uintptr_t elf32_load(char *data, pagetable *pagemap)
|
||||||
|
{
|
||||||
|
(void)data;
|
||||||
|
(void)pagemap;
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
uintptr_t elf64_load(char *data, pagetable *pagemap)
|
||||||
|
{
|
||||||
|
struct elf_header *header = (struct elf_header *)data;
|
||||||
|
struct elf_program_header *ph = (struct elf_program_header *)((uint8_t *)data + header->e_phoff);
|
||||||
|
|
||||||
|
uint64_t lowest = UINT64_MAX;
|
||||||
|
uint64_t max_align = 0;
|
||||||
|
|
||||||
|
for (uint16_t i = 0; i < header->e_phnum; i++) {
|
||||||
|
if (ph[i].p_type != PT_LOAD)
|
||||||
|
continue;
|
||||||
|
|
||||||
|
if (ph[i].p_align > max_align) {
|
||||||
|
max_align = ph[i].p_align;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
for (uint16_t i = 0; i < header->e_phnum; i++) {
|
||||||
|
if (ph[i].p_type != PT_LOAD)
|
||||||
|
continue;
|
||||||
|
|
||||||
|
if ((ph[i].p_vaddr & (~(max_align - 1))) < lowest) {
|
||||||
|
lowest = ph[i].p_vaddr & ~(max_align - 1);
|
||||||
|
}
|
||||||
|
|
||||||
|
uint64_t flags = VMM_PRESENT;
|
||||||
|
if (ph[i].p_flags & PF_W)
|
||||||
|
flags |= VMM_WRITABLE;
|
||||||
|
if (!(ph[i].p_flags & PF_X))
|
||||||
|
flags |= VMM_NX;
|
||||||
|
|
||||||
|
debug("elf64_load(): phys=0x%llx, virt=0x%llx, size=%lu\n", ph[i].p_paddr, ph[i].p_vaddr, ph[i].p_filesz);
|
||||||
|
|
||||||
|
uint64_t phys = (uint64_t)mem_alloc(ph[i].p_memsz);
|
||||||
|
if (!phys) {
|
||||||
|
debug("elf64_load(): Out of memory\n");
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
map_page(pagemap, ph[i].p_vaddr, phys, flags);
|
||||||
|
memcpy((void*)ph[i].p_vaddr - lowest, data + ph[i].p_offset, ph[i].p_filesz);
|
||||||
|
}
|
||||||
|
|
||||||
|
debug("elf64_load(): ELF loaded successfully, entry: 0x%llx\n", header->e_entry);
|
||||||
|
return (uintptr_t)((uint8_t *)data + (header->e_entry - lowest));
|
||||||
|
}
|
||||||
|
|
||||||
|
uintptr_t elf_load(char *data, pagetable *pagemap)
|
||||||
{
|
{
|
||||||
struct elf_header *header = (struct elf_header *)data;
|
struct elf_header *header = (struct elf_header *)data;
|
||||||
|
|
||||||
|
@ -42,44 +96,14 @@ uint64_t elf_load(char *data, uintptr_t *pagemap)
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
struct elf_program_header *ph = (struct elf_program_header *)(data + header->e_phoff);
|
if (header->e_machine == 20 ||
|
||||||
|
header->e_machine == 3 ||
|
||||||
for (uint16_t i = 0; i < header->e_phnum; i++) {
|
header->e_machine == 40) {
|
||||||
if (ph[i].p_type != PT_LOAD)
|
return elf32_load(data, pagemap);
|
||||||
continue;
|
} else if (header->e_machine == 62) {
|
||||||
|
return elf64_load(data, pagemap);
|
||||||
uint64_t vaddr_start = ALIGN_DOWN(ph[i].p_vaddr, PAGE_SIZE);
|
|
||||||
uint64_t vaddr_end = ALIGN_UP(ph[i].p_vaddr + ph[i].p_memsz, PAGE_SIZE);
|
|
||||||
uint64_t offset = ph[i].p_offset;
|
|
||||||
|
|
||||||
uint64_t flags = VMM_PRESENT;
|
|
||||||
if (ph[i].p_flags & PF_W)
|
|
||||||
flags |= VMM_WRITABLE;
|
|
||||||
if (!(ph[i].p_flags & PF_X))
|
|
||||||
flags |= VMM_NX;
|
|
||||||
|
|
||||||
for (uint64_t addr = vaddr_start; addr < vaddr_end; addr += PAGE_SIZE) {
|
|
||||||
uint64_t phys = (uint64_t)mem_alloc(PAGE_SIZE);
|
|
||||||
if (!phys) {
|
|
||||||
debug("Out of physical memory");
|
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
map_page(pagemap, addr, phys, flags);
|
|
||||||
|
|
||||||
uint64_t file_offset = offset + (addr - vaddr_start);
|
|
||||||
if (file_offset < offset + ph[i].p_filesz) {
|
|
||||||
uint64_t to_copy = PAGE_SIZE;
|
|
||||||
if (file_offset + PAGE_SIZE > offset + ph[i].p_filesz)
|
|
||||||
to_copy = offset + ph[i].p_filesz - file_offset;
|
|
||||||
|
|
||||||
memcpy((void *)phys, data + file_offset, to_copy);
|
|
||||||
} else {
|
|
||||||
memset((void *)phys, 0, PAGE_SIZE);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
debug("ELF loaded successfully, entry: 0x%lx", header->e_entry);
|
debug("Unsupported ELF machine: %u", header->e_machine);
|
||||||
return header->e_entry;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
|
@ -21,7 +21,7 @@
|
||||||
#define NANOPRINTF_USE_FIELD_WIDTH_FORMAT_SPECIFIERS 1
|
#define NANOPRINTF_USE_FIELD_WIDTH_FORMAT_SPECIFIERS 1
|
||||||
#define NANOPRINTF_USE_PRECISION_FORMAT_SPECIFIERS 0
|
#define NANOPRINTF_USE_PRECISION_FORMAT_SPECIFIERS 0
|
||||||
#define NANOPRINTF_USE_FLOAT_FORMAT_SPECIFIERS 0
|
#define NANOPRINTF_USE_FLOAT_FORMAT_SPECIFIERS 0
|
||||||
#define NANOPRINTF_USE_LARGE_FORMAT_SPECIFIERS 0
|
#define NANOPRINTF_USE_LARGE_FORMAT_SPECIFIERS 1
|
||||||
#define NANOPRINTF_USE_BINARY_FORMAT_SPECIFIERS 0
|
#define NANOPRINTF_USE_BINARY_FORMAT_SPECIFIERS 0
|
||||||
#define NANOPRINTF_USE_WRITEBACK_FORMAT_SPECIFIERS 0
|
#define NANOPRINTF_USE_WRITEBACK_FORMAT_SPECIFIERS 0
|
||||||
#include <nanoprintf.h>
|
#include <nanoprintf.h>
|
||||||
|
|
69
boot/common/proto/aurix.c
Normal file
69
boot/common/proto/aurix.c
Normal file
|
@ -0,0 +1,69 @@
|
||||||
|
/*********************************************************************************/
|
||||||
|
/* Module Name: aurix.c */
|
||||||
|
/* Project: AurixOS */
|
||||||
|
/* */
|
||||||
|
/* Copyright (c) 2024-2025 Jozef Nagy */
|
||||||
|
/* */
|
||||||
|
/* This source is subject to the MIT License. */
|
||||||
|
/* See License.txt in the root of this repository. */
|
||||||
|
/* All other rights reserved. */
|
||||||
|
/* */
|
||||||
|
/* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR */
|
||||||
|
/* IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, */
|
||||||
|
/* FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE */
|
||||||
|
/* AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER */
|
||||||
|
/* LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, */
|
||||||
|
/* OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE */
|
||||||
|
/* SOFTWARE. */
|
||||||
|
/*********************************************************************************/
|
||||||
|
|
||||||
|
#include <proto/aurix.h>
|
||||||
|
#include <loader/elf.h>
|
||||||
|
#include <mm/mman.h>
|
||||||
|
#include <mm/vmm.h>
|
||||||
|
#include <vfs/vfs.h>
|
||||||
|
#include <print.h>
|
||||||
|
|
||||||
|
extern __attribute__((noreturn)) void aurix_handoff(void *pagemap, void *stack, uint64_t entry, void *params);
|
||||||
|
extern char _aurix_handoff_start[], _aurix_handoff_end[];
|
||||||
|
|
||||||
|
void aurix_load(char *kernel)
|
||||||
|
{
|
||||||
|
// read kernel -> test read
|
||||||
|
char *kbuf = NULL;
|
||||||
|
vfs_read(kernel, &kbuf);
|
||||||
|
|
||||||
|
// TODO: Do something with the kernel :p
|
||||||
|
pagetable *pm = create_pagemap();
|
||||||
|
if (!pm) {
|
||||||
|
debug("aurix_load(): Failed to create kernel pagemap! Halting...\n");
|
||||||
|
// TODO: Halt
|
||||||
|
while (1);
|
||||||
|
}
|
||||||
|
|
||||||
|
map_pages(pm, (uintptr_t)_aurix_handoff_start, (uintptr_t)_aurix_handoff_start, (uint64_t)_aurix_handoff_end - (uint64_t)_aurix_handoff_start, VMM_PRESENT | VMM_USER | VMM_WRITABLE);
|
||||||
|
|
||||||
|
void *stack = mem_alloc(16*1024); // 16 KiB stack should be well more than enough
|
||||||
|
if (!stack) {
|
||||||
|
debug("aurix_load(): Failed to allocate stack! Halting...\n");
|
||||||
|
while (1);
|
||||||
|
}
|
||||||
|
|
||||||
|
void *kernel_entry = (void *)elf_load(kbuf, pm);
|
||||||
|
if (!kernel_entry) {
|
||||||
|
debug("aurix_load(): Failed to load '%s'! Halting...\n", kernel);
|
||||||
|
mem_free(kbuf);
|
||||||
|
while (1);
|
||||||
|
}
|
||||||
|
|
||||||
|
void *parameters = NULL;
|
||||||
|
|
||||||
|
debug("aurix_load(): Handoff state: pm=0x%llx, stack=0x%llx, kernel_entry=0x%llx\n", pm, stack, kernel_entry);
|
||||||
|
|
||||||
|
aurix_handoff(pm, (void *)((uint8_t)stack - 16*1024), (uint64_t)kernel_entry, (void *)parameters);
|
||||||
|
|
||||||
|
// __asm__ volatile("movq %[pml4], %%cr3\n" :: [pml4]"r"(pm) : "memory");
|
||||||
|
// __asm__ volatile("callq *%[entry]\n"
|
||||||
|
// :: [entry]"r"(kernel_entry));
|
||||||
|
|
||||||
|
}
|
|
@ -20,6 +20,17 @@
|
||||||
#ifndef _MM_PAGING_H
|
#ifndef _MM_PAGING_H
|
||||||
#define _MM_PAGING_H
|
#define _MM_PAGING_H
|
||||||
|
|
||||||
|
#include <stdint.h>
|
||||||
|
|
||||||
#define PAGE_SIZE 0x1000
|
#define PAGE_SIZE 0x1000
|
||||||
|
|
||||||
|
#define VMM_PRESENT 1
|
||||||
|
#define VMM_WRITABLE 2
|
||||||
|
#define VMM_NX (1ull << 63)
|
||||||
|
#define VMM_USER 4
|
||||||
|
|
||||||
|
typedef struct {
|
||||||
|
uint64_t entries[512];
|
||||||
|
} pagetable;
|
||||||
|
|
||||||
#endif /* _MM_PAGING_H */
|
#endif /* _MM_PAGING_H */
|
|
@ -20,6 +20,7 @@
|
||||||
#ifndef _LOADER_ELF_H
|
#ifndef _LOADER_ELF_H
|
||||||
#define _LOADER_ELF_H
|
#define _LOADER_ELF_H
|
||||||
|
|
||||||
|
#include <mm/vmm.h>
|
||||||
#include <stdint.h>
|
#include <stdint.h>
|
||||||
//#include <stddef.h>
|
//#include <stddef.h>
|
||||||
|
|
||||||
|
@ -72,6 +73,6 @@ struct elf_program_header {
|
||||||
#define PF_W 0x2
|
#define PF_W 0x2
|
||||||
#define PF_R 0x4
|
#define PF_R 0x4
|
||||||
|
|
||||||
uint64_t elf_load(char *kernel, uintptr_t *pagemap);
|
uintptr_t elf_load(char *kernel, pagetable *pagemap);
|
||||||
|
|
||||||
#endif /* _LOADER_ELF_H */
|
#endif /* _LOADER_ELF_H */
|
||||||
|
|
|
@ -23,13 +23,9 @@
|
||||||
#include <arch/mm/paging.h>
|
#include <arch/mm/paging.h>
|
||||||
#include <stdint.h>
|
#include <stdint.h>
|
||||||
|
|
||||||
#define VMM_PRESENT 1
|
pagetable *create_pagemap(void);
|
||||||
#define VMM_WRITABLE 2
|
|
||||||
#define VMM_NX (1ull << 63)
|
|
||||||
#define VMM_USER 4
|
|
||||||
|
|
||||||
uintptr_t *create_pagemap(void);
|
void map_page(pagetable *pm, uintptr_t virt, uintptr_t phys, uint64_t flags);
|
||||||
|
void map_pages(pagetable *pm, uintptr_t virt, uintptr_t phys, size_t size, uint64_t flags);
|
||||||
void map_page(uintptr_t *pm, uintptr_t virt, uintptr_t phys, uint64_t flags);
|
|
||||||
|
|
||||||
#endif /* _MM_VMM_H */
|
#endif /* _MM_VMM_H */
|
25
boot/include/proto/aurix.h
Normal file
25
boot/include/proto/aurix.h
Normal file
|
@ -0,0 +1,25 @@
|
||||||
|
/*********************************************************************************/
|
||||||
|
/* Module Name: aurix.h */
|
||||||
|
/* Project: AurixOS */
|
||||||
|
/* */
|
||||||
|
/* Copyright (c) 2024-2025 Jozef Nagy */
|
||||||
|
/* */
|
||||||
|
/* This source is subject to the MIT License. */
|
||||||
|
/* See License.txt in the root of this repository. */
|
||||||
|
/* All other rights reserved. */
|
||||||
|
/* */
|
||||||
|
/* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR */
|
||||||
|
/* IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, */
|
||||||
|
/* FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE */
|
||||||
|
/* AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER */
|
||||||
|
/* LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, */
|
||||||
|
/* OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE */
|
||||||
|
/* SOFTWARE. */
|
||||||
|
/*********************************************************************************/
|
||||||
|
|
||||||
|
#ifndef _PROTO_AURIX_H
|
||||||
|
#define _PROTO_AURIX_H
|
||||||
|
|
||||||
|
void aurix_load(char *kernel);
|
||||||
|
|
||||||
|
#endif /* _PROTO_AURIX_H */
|
|
@ -47,14 +47,15 @@ KERNEL_CFLAGS := $(foreach d, $(INCLUDE_DIRS), -I$d) \
|
||||||
-fno-omit-frame-pointer \
|
-fno-omit-frame-pointer \
|
||||||
-fno-stack-protector \
|
-fno-stack-protector \
|
||||||
-fno-stack-check \
|
-fno-stack-check \
|
||||||
-fno-pie \
|
-fpic \
|
||||||
|
-fpie \
|
||||||
-MMD \
|
-MMD \
|
||||||
-MP
|
-MP
|
||||||
|
|
||||||
KERNEL_LDFLAGS := -Tarch/$(ARCH)/linker.ld \
|
KERNEL_LDFLAGS := -Tarch/$(ARCH)/linker.ld \
|
||||||
-nostdlib \
|
-nostdlib \
|
||||||
-static \
|
-static \
|
||||||
-no-pie
|
#-no-pie
|
||||||
|
|
||||||
ifeq ($(BUILD_TYPE),debug)
|
ifeq ($(BUILD_TYPE),debug)
|
||||||
KERNEL_CFLAGS += -O0 -g3
|
KERNEL_CFLAGS += -O0 -g3
|
||||||
|
|
|
@ -31,8 +31,8 @@ PHDRS
|
||||||
|
|
||||||
SECTIONS
|
SECTIONS
|
||||||
{
|
{
|
||||||
/* AxBoot remaps this to 0xffffffff80000000 for us */
|
/* TODO: 0xffffffff80000000 */
|
||||||
. = 0x1000;
|
. = 0xffffffff80000000;
|
||||||
|
|
||||||
_linker_start_text = .;
|
_linker_start_text = .;
|
||||||
|
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue