mirror of
https://github.com/drasko/codezero.git
synced 2026-01-12 10:53:16 +01:00
Added setting of utcb address to l4_thread_control. This is going to be moved to exchange_registers() since we need to pass both the utcb physical and virtual address and exregs fits such context modification better than thread_control.
49 lines
1.3 KiB
Plaintext
49 lines
1.3 KiB
Plaintext
/*
|
|
* Simple linker script for userspace or svc tasks.
|
|
*
|
|
* Copyright (C) 2007 Bahadir Balban
|
|
*/
|
|
|
|
/*
|
|
* The only catch with this linker script is that everything
|
|
* is linked starting at virtual_base, and loaded starting
|
|
* at physical_base. virtual_base is the predefined region
|
|
* of virtual memory for userland applications. physical_base
|
|
* is determined at build-time, it is one of the subsequent pages
|
|
* that come after the kernel image's load area.
|
|
*/
|
|
/* USER_AREA_START, see memlayout.h */
|
|
virtual_base = 0x10000000;
|
|
__stack = (0x20000000 - 0x1000 - 8); /* First page before env/args page */
|
|
INCLUDE "include/physical_base.lds"
|
|
|
|
/* physical_base = 0x228000; */
|
|
offset = virtual_base - physical_base;
|
|
|
|
ENTRY(_start)
|
|
|
|
SECTIONS
|
|
{
|
|
. = virtual_base;
|
|
_start_text = .;
|
|
.text : AT (ADDR(.text) - offset) { crt0.o(.text) *(.text) }
|
|
/* rodata is needed else your strings will link at physical! */
|
|
.rodata : AT (ADDR(.rodata) - offset) { *(.rodata) }
|
|
.rodata1 : AT (ADDR(.rodata1) - offset) { *(.rodata1) }
|
|
.data : AT (ADDR(.data) - offset)
|
|
{
|
|
. = ALIGN(4K); /* Align UTCB to page boundary */
|
|
_start_utcb = .;
|
|
*(.utcb)
|
|
_end_utcb = .;
|
|
. = ALIGN(4K);
|
|
_start_bdev = .;
|
|
*(.data.memfs)
|
|
_end_bdev = .;
|
|
*(.data)
|
|
}
|
|
.bss : AT (ADDR(.bss) - offset) { *(.bss) }
|
|
|
|
_end = .;
|
|
}
|