base: retire 'Native_config'

This commit moves the parameters of the stack area to the base-internal
header 'stack_area.h'.

Issue #1832
This commit is contained in:
Norman Feske 2016-03-03 17:57:29 +01:00
parent 2490e399dc
commit 76db3b9c06
48 changed files with 292 additions and 303 deletions

View File

@ -14,6 +14,7 @@
#ifndef _INCLUDE__BASE__NATIVE_TYPES_H_
#define _INCLUDE__BASE__NATIVE_TYPES_H_
/* Genode includes */
#include <base/native_capability.h>
#include <base/stdint.h>
@ -73,22 +74,6 @@ namespace Genode {
typedef Native_capability_tpl<Cap_dst_policy> Native_capability;
typedef Fiasco::l4_threadid_t Native_connection_state;
struct Native_config
{
/**
* Stack area configuration
*/
static constexpr addr_t stack_area_virtual_base() {
return 0x40000000UL; }
static constexpr addr_t stack_area_virtual_size() {
return 0x10000000UL; }
/**
* Size of virtual address region holding the stack of one thread
*/
static constexpr addr_t stack_virtual_size() { return 0x00100000UL; }
};
struct Native_pd_args { };
}

View File

@ -20,6 +20,7 @@
/* base-internal includes */
#include <base/internal/crt0.h>
#include <base/internal/fiasco_thread_helper.h>
#include <base/internal/stack_area.h>
/* core includes */
#include <core_parent.h>
@ -306,8 +307,8 @@ void Platform::_setup_mem_alloc()
}
region.start = addr; region.end = addr + size;
if (!region.intersects(Native_config::stack_area_virtual_base(),
Native_config::stack_area_virtual_size())) {
if (!region.intersects(stack_area_virtual_base(),
stack_area_virtual_size())) {
add_region(region, _ram_alloc);
add_region(region, _core_address_ranges());
}
@ -412,8 +413,8 @@ void Platform::_setup_basics()
_region_alloc.add_range(_vm_start, _vm_size);
/* preserve stack area in core's virtual address space */
_region_alloc.remove_range(Native_config::stack_area_virtual_base(),
Native_config::stack_area_virtual_size());
_region_alloc.remove_range(stack_area_virtual_base(),
stack_area_virtual_size());
/* I/O memory could be the whole user address space */
/* FIXME if the kernel helps to find out max address - use info here */

View File

@ -14,7 +14,6 @@
#ifndef _INCLUDE__BASE__NATIVE_TYPES_H_
#define _INCLUDE__BASE__NATIVE_TYPES_H_
#include <base/native_config.h>
#include <base/cap_map.h>
namespace Fiasco {

View File

@ -1,38 +0,0 @@
/*
* \brief Platform-specific stack area definitions
* \author Stefan Kalkowski
* \date 2014-01-24
*/
/*
* Copyright (C) 2014 Genode Labs GmbH
*
* This file is part of the Genode OS framework, which is distributed
* under the terms of the GNU General Public License version 2.
*/
#ifndef _INCLUDE__SPEC__ARM__BASE__NATIVE_CONFIG_H_
#define _INCLUDE__SPEC__ARM__BASE__NATIVE_CONFIG_H_
#include <base/stdint.h>
namespace Genode {
struct Native_config
{
/**
* Stack area configuration
*/
static constexpr addr_t stack_area_virtual_base() {
return 0x20000000UL; }
static constexpr addr_t stack_area_virtual_size() {
return 0x10000000UL; }
/**
* Size of virtual address region holding the stack of one thread
*/
static constexpr addr_t stack_virtual_size() { return 0x00100000UL; }
};
}
#endif /* _INCLUDE__SPEC__ARM__BASE__NATIVE_CONFIG_H_ */

View File

@ -1,38 +0,0 @@
/*
* \brief Platform-specific stack area definitions
* \author Stefan Kalkowski
* \date 2014-01-24
*/
/*
* Copyright (C) 2014 Genode Labs GmbH
*
* This file is part of the Genode OS framework, which is distributed
* under the terms of the GNU General Public License version 2.
*/
#ifndef _INCLUDE__SPEC__X86__BASE__NATIVE_CONFIG_H_
#define _INCLUDE__SPEC__X86__BASE__NATIVE_CONFIG_H_
#include <base/stdint.h>
namespace Genode {
struct Native_config
{
/**
* Stack area configuration
*/
static constexpr addr_t stack_area_virtual_base() {
return 0x40000000UL; }
static constexpr addr_t stack_area_virtual_size() {
return 0x10000000UL; }
/**
* Size of virtual address region holding the stack of one thread
*/
static constexpr addr_t stack_virtual_size() { return 0x00100000UL; }
};
}
#endif /* _INCLUDE__SPEC__X86__BASE__NATIVE_CONFIG_H_ */

View File

@ -0,0 +1,4 @@
# override default stack-area location
INC_DIR += $(REP_DIR)/src/include/spec/arm
include $(REP_DIR)/lib/mk/base-common.inc

View File

@ -0,0 +1,4 @@
# override default stack-area location
INC_DIR += $(REP_DIR)/src/include/spec/arm
include $(REP_DIR)/lib/mk/base.inc

View File

@ -0,0 +1 @@
include $(REP_DIR)/lib/mk/base-common.inc

View File

@ -0,0 +1 @@
include $(REP_DIR)/lib/mk/base.inc

View File

@ -29,6 +29,9 @@
#include <cap_mapping.h>
#include <address_space.h>
/* base-internal includes */
#include <base/internal/stack_area.h>
/* Fiasco.OC includes */
namespace Fiasco {
#include <l4/sys/consts.h>
@ -48,8 +51,8 @@ namespace Genode {
addr_t utcb_area_start()
{
return (Native_config::stack_area_virtual_base() +
THREAD_MAX * Native_config::stack_virtual_size());
return stack_area_virtual_base() +
THREAD_MAX*stack_virtual_size();
}
Cap_mapping _task;

View File

@ -20,6 +20,7 @@
/* base-internal includes */
#include <base/internal/crt0.h>
#include <base/internal/stack_area.h>
/* core includes */
#include <core_parent.h>
@ -327,8 +328,8 @@ void Platform::_setup_mem_alloc()
}
region.start = addr; region.end = addr + size;
if (!region.intersects(Native_config::stack_area_virtual_base(),
Native_config::stack_area_virtual_size())) {
if (!region.intersects(stack_area_virtual_base(),
stack_area_virtual_size())) {
add_region(region, _ram_alloc);
add_region(region, _core_address_ranges());
}
@ -403,8 +404,8 @@ void Platform::_setup_basics()
_region_alloc.add_range(_vm_start, _vm_size);
/* preserve stack area in core's virtual address space */
_region_alloc.remove_range(Native_config::stack_area_virtual_base(),
Native_config::stack_area_virtual_size());
_region_alloc.remove_range(stack_area_virtual_base(),
stack_area_virtual_size());
/* preserve utcb- area in core's virtual address space */
_region_alloc.remove_range((addr_t)l4_utcb(), L4_PAGESIZE * 16);

View File

@ -2,6 +2,9 @@ REQUIRES += arm
SRC_CC += spec/arm/platform_arm.cc \
spec/arm/ipc_pager.cc
# override default stack-area location
INC_DIR += $(REP_DIR)/src/include/spec/arm
include $(REP_DIR)/src/core/target.inc
vpath platform_services.cc $(GEN_CORE_DIR)

View File

@ -0,0 +1,33 @@
/*
* \brief Stack area layout parameters
* \author Norman Feske
* \date 2016-03-03
*/
/*
* Copyright (C) 2016 Genode Labs GmbH
*
* This file is part of the Genode OS framework, which is distributed
* under the terms of the GNU General Public License version 2.
*/
#ifndef _INCLUDE__BASE__INTERNAL__STACK_AREA_H_
#define _INCLUDE__BASE__INTERNAL__STACK_AREA_H_
#include <base/stdint.h>
namespace Genode {
/*
* The base address of the context area differs between ARM and x86 because
* roottask on Fiasco.OC uses identity mappings. The virtual address range
* of the stack area must not overlap with physical memory. We pick an
* address range that lies outside of the RAM of the currently supported
* ARM platforms.
*/
static constexpr addr_t stack_area_virtual_base() { return 0x20000000UL; }
static constexpr addr_t stack_area_virtual_size() { return 0x10000000UL; }
static constexpr addr_t stack_virtual_size() { return 0x00100000UL; }
}
#endif /* _INCLUDE__BASE__INTERNAL__STACK_AREA_H_ */

View File

@ -40,8 +40,6 @@ namespace Genode
*/
struct Native_region;
struct Native_config;
struct Native_pd_args { };
/**
@ -78,23 +76,6 @@ struct Genode::Native_region
};
struct Genode::Native_config
{
/**
* Stack area configuration
*/
static constexpr addr_t stack_area_virtual_base() {
return 0xe0000000UL; }
static constexpr addr_t stack_area_virtual_size() {
return 0x10000000UL; }
/**
* Size of virtual address region holding the stack of one thread
*/
static constexpr addr_t stack_virtual_size() { return 0x00100000UL; }
};
class Genode::Native_utcb
{
public:

View File

@ -48,7 +48,7 @@ void Thread_base::_init_platform_thread(size_t weight, Type type)
}
/* if we got reinitialized we have to get rid of the old UTCB */
size_t const utcb_size = sizeof(Native_utcb);
addr_t const stack_area = Native_config::stack_area_virtual_base();
addr_t const stack_area = stack_area_virtual_base();
addr_t const utcb_new = (addr_t)&_stack->utcb() - stack_area;
Rm_session * const rm = env_stack_area_rm_session();
@ -76,8 +76,7 @@ void Thread_base::_deinit_platform_thread()
/* detach userland stack */
size_t const size = sizeof(_stack->utcb());
addr_t utcb = Stack_allocator::addr_to_base(_stack) +
Native_config::stack_virtual_size() - size -
Native_config::stack_area_virtual_base();
stack_virtual_size() - size - stack_area_virtual_base();
env_stack_area_rm_session()->detach(utcb);
if (_pager_cap.valid()) {
@ -100,8 +99,7 @@ void Thread_base::start()
Ram_dataspace_capability ds = _cpu_session->utcb(_thread_cap);
size_t const size = sizeof(_stack->utcb());
addr_t dst = Stack_allocator::addr_to_base(_stack) +
Native_config::stack_virtual_size() - size -
Native_config::stack_area_virtual_base();
stack_virtual_size() - size - stack_area_virtual_base();
env_stack_area_rm_session()->attach_at(ds, dst, size);
} catch (...) {
PERR("failed to attach userland stack");

View File

@ -29,6 +29,9 @@
#include <translation_table.h>
#include <trustzone.h>
/* base-internal includes */
#include <base/internal/stack_area.h>
using namespace Genode;
extern int _prog_img_beg;
@ -137,9 +140,8 @@ Platform::Platform()
_core_only_ram_regions, get_page_size_log2());
/* preserve stack area in core's virtual address space */
_core_mem_alloc.virt_alloc()->remove_range(
Native_config::stack_area_virtual_base(),
Native_config::stack_area_virtual_size());
_core_mem_alloc.virt_alloc()->remove_range(stack_area_virtual_base(),
stack_area_virtual_size());
_init_io_port_alloc();

View File

@ -0,0 +1,26 @@
/*
* \brief Stack area layout parameters
* \author Norman Feske
* \date 2016-03-03
*/
/*
* Copyright (C) 2016 Genode Labs GmbH
*
* This file is part of the Genode OS framework, which is distributed
* under the terms of the GNU General Public License version 2.
*/
#ifndef _INCLUDE__BASE__INTERNAL__STACK_AREA_H_
#define _INCLUDE__BASE__INTERNAL__STACK_AREA_H_
#include <base/stdint.h>
namespace Genode {
static constexpr addr_t stack_area_virtual_base() { return 0xe0000000UL; }
static constexpr addr_t stack_area_virtual_size() { return 0x10000000UL; }
static constexpr addr_t stack_virtual_size() { return 0x00100000UL; }
}
#endif /* _INCLUDE__BASE__INTERNAL__STACK_AREA_H_ */

View File

@ -18,16 +18,6 @@
#include <base/native_capability.h>
#include <base/stdint.h>
/*
* We cannot just include <semaphore.h> and <pthread.h> here
* because this would imply the nested inclusion of a myriad
* of Linux types and would pollute the namespace for everyone
* who includes this header file. We want to cleanly separate
* Genode from POSIX.
*/
extern Genode::addr_t _stack_area_start;
namespace Genode {
/**
@ -125,26 +115,6 @@ namespace Genode {
enum { PARENT_SOCKET_HANDLE = 100 };
struct Native_config
{
/**
* Stack area configuration
*
* Please update platform-specific files after changing these
* functions, e.g., 'base-linux/src/ld/stack_area.*.ld'.
*/
static addr_t stack_area_virtual_base() {
return align_addr((addr_t)&_stack_area_start, 20); }
static constexpr addr_t stack_area_virtual_size() {
return 0x10000000UL; }
/**
* Size of virtual address region holding the stack of one thread
*/
static constexpr addr_t stack_virtual_size() { return 0x00100000UL; }
};
class Native_pd_args
{
public:

View File

@ -60,8 +60,8 @@ addr_t Platform_env_base::Rm_session_mmap::_reserve_local(bool use_loc
{
/* special handling for stack area */
if (use_local_addr
&& local_addr == Native_config::stack_area_virtual_base()
&& size == Native_config::stack_area_virtual_size()) {
&& local_addr == stack_area_virtual_base()
&& size == stack_area_virtual_size()) {
/*
* On the first request to reserve the stack area, we flush the

View File

@ -50,8 +50,7 @@ class Stack_area_rm_session : public Genode::Rm_session
using namespace Genode;
/* convert stack-area-relative to absolute virtual address */
addr_t addr = local_addr;
addr += Native_config::stack_area_virtual_base();
addr_t addr = (addr_t)local_addr + stack_area_virtual_base();
/* use anonymous mmap for allocating stack backing store */
int flags = MAP_FIXED | MAP_ANONYMOUS | MAP_PRIVATE;

View File

@ -1,5 +1,5 @@
/*
* \brief Linux-specific utilities for stack area
* \brief Linux-specific definitions and utilities for the stack area
* \author Christian Helmuth
* \date 2013-09-26
*/
@ -24,12 +24,31 @@
#include <sys/mman.h>
extern Genode::addr_t _stack_area_start;
namespace Genode {
/**
* Stack area base address
*
* Please update platform-specific files after changing these
* functions, e.g., 'base-linux/src/ld/stack_area.*.ld'.
*/
static addr_t stack_area_virtual_base() {
return align_addr((addr_t)&_stack_area_start, 20); }
static constexpr addr_t stack_area_virtual_size() { return 0x10000000UL; }
static constexpr addr_t stack_virtual_size() { return 0x00100000UL; }
}
static inline void flush_stack_area()
{
using namespace Genode;
void * const base = (void *) Native_config::stack_area_virtual_base();
size_t const size = Native_config::stack_area_virtual_size();
void * const base = (void *)stack_area_virtual_base();
size_t const size = stack_area_virtual_size();
int ret;
if ((ret = lx_munmap(base, size)) < 0) {
@ -45,8 +64,8 @@ static inline Genode::addr_t reserve_stack_area()
int const flags = MAP_ANONYMOUS | MAP_PRIVATE;
int const prot = PROT_NONE;
size_t const size = Native_config::stack_area_virtual_size();
void * const addr_in = (void *)Native_config::stack_area_virtual_base();
size_t const size = stack_area_virtual_size();
void * const addr_in = (void *)stack_area_virtual_base();
void * const addr_out = lx_mmap(addr_in, size, prot, flags, -1, 0);
/* reserve at local address failed - unmap incorrect mapping */

View File

@ -238,22 +238,6 @@ namespace Genode {
typedef int Native_connection_state;
struct Native_config
{
/**
* Stack area configuration
*/
static constexpr addr_t stack_area_virtual_base() {
return 0xa0000000UL; }
static constexpr addr_t stack_area_virtual_size() {
return 0x10000000UL; }
/**
* Size of virtual address region holding the stack of one thread
*/
static constexpr addr_t stack_virtual_size() { return 0x00100000UL; }
};
struct Native_pd_args { };
}

View File

@ -23,6 +23,7 @@
/* base-internal includes */
#include <base/internal/stack.h>
#include <base/internal/stack_area.h>
/* base-nova includes */
#include <base/cap_map.h>
@ -40,8 +41,7 @@ Native_utcb * main_thread_utcb()
{
using namespace Genode;
return reinterpret_cast<Native_utcb *>(
Native_config::stack_area_virtual_base() +
Native_config::stack_virtual_size() - Nova::PAGE_SIZE_BYTE);
stack_area_virtual_base() + stack_virtual_size() - Nova::PAGE_SIZE_BYTE);
}

View File

@ -27,6 +27,9 @@
#include <util.h>
#include <ipc_pager.h>
/* base-internal includes */
#include <base/internal/stack_area.h>
/* NOVA includes */
#include <nova/syscalls.h>
@ -126,13 +129,13 @@ static void page_fault_handler()
pf_type & Ipc_pager::ERR_W ? "W" : "w",
pf_type & Ipc_pager::ERR_P ? "P" : "p");
if ((Native_config::stack_area_virtual_base() <= pf_sp) &&
(pf_sp < Native_config::stack_area_virtual_base() +
Native_config::stack_area_virtual_size()))
if ((stack_area_virtual_base() <= pf_sp) &&
(pf_sp < stack_area_virtual_base() +
stack_area_virtual_size()))
{
addr_t utcb_addr_f = pf_sp / Native_config::stack_virtual_size();
utcb_addr_f *= Native_config::stack_virtual_size();
utcb_addr_f += Native_config::stack_virtual_size();
addr_t utcb_addr_f = pf_sp / stack_virtual_size();
utcb_addr_f *= stack_virtual_size();
utcb_addr_f += stack_virtual_size();
utcb_addr_f -= 4096;
Nova::Utcb * utcb_fault = reinterpret_cast<Nova::Utcb *>(utcb_addr_f);
@ -398,8 +401,8 @@ Platform::Platform() :
region_alloc()->remove_range(BDA_VIRT_ADDR, 0x1000);
/* preserve stack area in core's virtual address space */
region_alloc()->remove_range(Native_config::stack_area_virtual_base(),
Native_config::stack_area_virtual_size());
region_alloc()->remove_range(stack_area_virtual_base(),
stack_area_virtual_size());
/* exclude utcb of core pager thread + empty guard pages before and after */
region_alloc()->remove_range(CORE_PAGER_UTCB_ADDR - get_page_size(),
@ -420,14 +423,12 @@ Platform::Platform() :
};
for (unsigned i = 0; i < sizeof(check) / sizeof(check[0]); i++) {
if (Native_config::stack_area_virtual_base() <= check[i] &&
check[i] < Native_config::stack_area_virtual_base() +
Native_config::stack_area_virtual_size())
if (stack_area_virtual_base() <= check[i] &&
check[i] < stack_area_virtual_base() + stack_area_virtual_size())
{
PERR("overlapping area - [%lx, %lx) vs %lx",
Native_config::stack_area_virtual_base(),
Native_config::stack_area_virtual_base() +
Native_config::stack_area_virtual_size(), check[i]);
stack_area_virtual_base(), stack_area_virtual_base() +
stack_area_virtual_size(), check[i]);
nova_die();
}
}

View File

@ -23,6 +23,9 @@
#include <util.h>
#include <nova_util.h>
/* base-internal includes */
#include <base/internal/stack_area.h>
/* NOVA includes */
#include <nova/syscalls.h>
#include <nova/util.h>
@ -119,8 +122,7 @@ int Platform_thread::start(void *ip, void *sp)
_sel_exc_base = is_vcpu() ? _pager->exc_pt_vcpu() : _pager->exc_pt_sel_client();
if (!is_vcpu()) {
pd_utcb = Native_config::stack_area_virtual_base() +
Native_config::stack_virtual_size() - get_page_size();
pd_utcb = stack_area_virtual_base() + stack_virtual_size() - get_page_size();
addr_t remap_src[] = { _pd->parent_pt_sel(), _pager->Object_pool<Pager_object>::Entry::cap().local_name() };
addr_t remap_dst[] = { PT_SEL_PARENT, PT_SEL_MAIN_PAGER };

View File

@ -0,0 +1,26 @@
/*
* \brief Stack area layout parameters
* \author Norman Feske
* \date 2016-03-03
*/
/*
* Copyright (C) 2016 Genode Labs GmbH
*
* This file is part of the Genode OS framework, which is distributed
* under the terms of the GNU General Public License version 2.
*/
#ifndef _INCLUDE__BASE__INTERNAL__STACK_AREA_H_
#define _INCLUDE__BASE__INTERNAL__STACK_AREA_H_
#include <base/stdint.h>
namespace Genode {
static constexpr addr_t stack_area_virtual_base() { return 0xa0000000UL; }
static constexpr addr_t stack_area_virtual_size() { return 0x10000000UL; }
static constexpr addr_t stack_virtual_size() { return 0x00100000UL; }
}
#endif /* _INCLUDE__BASE__INTERNAL__STACK_AREA_H_ */

View File

@ -90,22 +90,6 @@ namespace Genode {
typedef Native_capability_tpl<Cap_dst_policy> Native_capability;
typedef Okl4::L4_ThreadId_t Native_connection_state;
struct Native_config
{
/**
* Stack area configuration
*/
static constexpr addr_t stack_area_virtual_base() {
return 0x40000000UL; }
static constexpr addr_t stack_area_virtual_size() {
return 0x10000000UL; }
/**
* Size of virtual address region holding the stack of one thread
*/
static constexpr addr_t stack_virtual_size() { return 0x00100000UL; }
};
struct Native_pd_args { };
}

View File

@ -19,6 +19,7 @@
/* base-internal includes */
#include <base/internal/crt0.h>
#include <base/internal/stack_area.h>
/* core includes */
#include <core_parent.h>
@ -272,8 +273,8 @@ Platform::Platform() :
_io_port_alloc.add_range(0, 0x10000);
/* preserve stack area in core's virtual address space */
_core_mem_alloc.virt_alloc()->remove_range(Native_config::stack_area_virtual_base(),
Native_config::stack_area_virtual_size());
_core_mem_alloc.virt_alloc()->remove_range(stack_area_virtual_base(),
stack_area_virtual_size());
_vm_start = 0x1000;
_vm_size = 0xb0000000 - 0x1000;

View File

@ -74,22 +74,6 @@ namespace Genode {
typedef Pistachio::L4_ThreadId_t Native_connection_state;
struct Native_config
{
/**
* Stack area configuration
*/
static constexpr addr_t stack_area_virtual_base() {
return 0x40000000UL; }
static constexpr addr_t stack_area_virtual_size() {
return 0x10000000UL; }
/**
* Size of virtual address region holding the stack of one thread
*/
static constexpr addr_t stack_virtual_size() { return 0x00100000UL; }
};
struct Native_pd_args { };
}

View File

@ -20,6 +20,7 @@
/* base-internal includes */
#include <base/internal/crt0.h>
#include <base/internal/stack_area.h>
/* core includes */
#include <core_parent.h>
@ -434,8 +435,8 @@ void Platform::_setup_mem_alloc()
} else {
region.start = addr; region.end = addr + size;
if (region.intersects(Native_config::stack_area_virtual_base(),
Native_config::stack_area_virtual_size()) ||
if (region.intersects(stack_area_virtual_base(),
stack_area_virtual_size()) ||
intersects_kip_archdep(kip, addr, size)) {
unmap_local(region.start, size >> get_page_size_log2());
} else {
@ -566,8 +567,8 @@ void Platform::_setup_basics()
/* configure core's virtual memory, exclude KIP, stack area */
_region_alloc.add_range(_vm_start, _vm_size);
_region_alloc.remove_range((addr_t)kip, kip_size);
_region_alloc.remove_range(Native_config::stack_area_virtual_base(),
Native_config::stack_area_virtual_size());
_region_alloc.remove_range(stack_area_virtual_base(),
stack_area_virtual_size());
/* remove KIP and MBI area from region and IO_MEM allocator */
remove_region(Region((addr_t)kip, (addr_t)kip + kip_size), _region_alloc);

View File

@ -126,22 +126,6 @@ namespace Genode {
};
};
struct Native_config
{
/**
* Stack-area configuration.
*/
static constexpr addr_t stack_area_virtual_base() {
return 0x40000000UL; }
static constexpr addr_t stack_area_virtual_size() {
return 0x10000000UL; }
/**
* Size of virtual address region holding the stack of one thread
*/
static constexpr addr_t stack_virtual_size() { return 0x00100000UL; }
};
struct Native_pd_args { };
typedef int Native_connection_state;

View File

@ -23,6 +23,9 @@
#include <cnode.h>
#include <untyped_memory.h>
/* base-internal includes */
#include <base/internal/stack_area.h>
using namespace Genode;
static bool const verbose_boot_info = true;
@ -156,8 +159,8 @@ void Platform::_init_allocators()
}
/* preserve stack area in core's virtual address space */
_core_mem_alloc.virt_alloc()->remove_range(Native_config::stack_area_virtual_base(),
Native_config::stack_area_virtual_size());
_core_mem_alloc.virt_alloc()->remove_range(stack_area_virtual_base(),
stack_area_virtual_size());
}

View File

@ -25,6 +25,9 @@
#include <dataspace_component.h>
#include <untyped_memory.h>
/* base-internal includes */
#include <base/internal/stack_area.h>
using namespace Genode;
@ -76,7 +79,7 @@ class Stack_area_rm_session : public Rm_session
}
addr_t const core_local_addr =
Native_config::stack_area_virtual_base() + (addr_t)local_addr;
stack_area_virtual_base() + (addr_t)local_addr;
if (verbose)
PDBG("core_local_addr = %lx, phys_addr = %lx, size = 0x%zx",

View File

@ -280,6 +280,21 @@ class Genode::Thread_base
*/
void *stack_base() const;
/**
* Return virtual size reserved for each stack within the stack area
*/
static size_t stack_virtual_size();
/**
* Return the local base address of the stack area
*/
static addr_t stack_area_virtual_base();
/**
* Return total size of the stack area
*/
static size_t stack_area_virtual_size();
/**
* Return 'Thread_base' object corresponding to the calling thread
*

View File

@ -16,6 +16,7 @@
/* base-internal includes */
#include <base/internal/platform_env_common.h>
#include <base/internal/stack_area.h>
using namespace Genode;
@ -39,10 +40,10 @@ struct Expanding_rm_connection : Connection<Rm_session>, Expanding_rm_session_cl
struct Stack_area_rm_session : Expanding_rm_connection
{
Stack_area_rm_session()
: Expanding_rm_connection(0, Native_config::stack_area_virtual_size())
: Expanding_rm_connection(0, stack_area_virtual_size())
{
addr_t local_base = Native_config::stack_area_virtual_base();
size_t size = Native_config::stack_area_virtual_size();
addr_t const local_base = stack_area_virtual_base();
size_t const size = stack_area_virtual_size();
env()->rm_session()->attach_at(dataspace(), local_base, size);
}

View File

@ -16,6 +16,7 @@
/* base-internal includes */
#include <base/internal/stack_allocator.h>
#include <base/internal/stack_area.h>
Genode::Thread_base *Genode::Thread_base::myself()
@ -28,9 +29,8 @@ Genode::Thread_base *Genode::Thread_base::myself()
* thread.
*/
addr_t sp = (addr_t)(&dummy);
if (sp < Native_config::stack_area_virtual_base() ||
sp >= Native_config::stack_area_virtual_base() +
Native_config::stack_area_virtual_size())
if (sp < Genode::stack_area_virtual_base() ||
sp >= Genode::stack_area_virtual_base() + Genode::stack_area_virtual_size())
return 0;
addr_t base = Stack_allocator::addr_to_base(&dummy);

View File

@ -20,7 +20,7 @@ using namespace Genode;
Stack *Stack_allocator::base_to_stack(addr_t base)
{
addr_t result = base + Native_config::stack_virtual_size()
addr_t result = base + stack_virtual_size()
- sizeof(Stack);
return reinterpret_cast<Stack *>(result);
}
@ -28,21 +28,19 @@ Stack *Stack_allocator::base_to_stack(addr_t base)
addr_t Stack_allocator::addr_to_base(void *addr)
{
return ((addr_t)addr) & ~(Native_config::stack_virtual_size() - 1);
return ((addr_t)addr) & ~(stack_virtual_size() - 1);
}
size_t Stack_allocator::base_to_idx(addr_t base)
{
return (base - Native_config::stack_area_virtual_base()) /
Native_config::stack_virtual_size();
return (base - stack_area_virtual_base()) / stack_virtual_size();
}
addr_t Stack_allocator::idx_to_base(size_t idx)
{
return Native_config::stack_area_virtual_base() +
idx * Native_config::stack_virtual_size();
return stack_area_virtual_base() + idx * stack_virtual_size();
}
@ -51,7 +49,7 @@ Stack_allocator::alloc(Thread_base *thread_base, bool main_thread)
{
if (main_thread)
/* the main-thread stack is the first one */
return base_to_stack(Native_config::stack_area_virtual_base());
return base_to_stack(stack_area_virtual_base());
try {
Lock::Guard _lock_guard(_threads_lock);

View File

@ -56,8 +56,7 @@ void Stack::size(size_t const size)
throw Thread_base::Stack_too_large();
/* allocate and attach backing store for the stack enhancement */
addr_t const ds_addr = _base - ds_size -
Native_config::stack_area_virtual_base();
addr_t const ds_addr = _base - ds_size - stack_area_virtual_base();
try {
Ram_session * const ram = env_stack_area_ram_session();
Ram_dataspace_capability const ds_cap = ram->alloc(ds_size);
@ -96,7 +95,7 @@ Thread_base::_alloc_stack(size_t stack_size, char const *name, bool main_thread)
enum { PAGE_SIZE_LOG2 = 12 };
size_t ds_size = align_addr(stack_size, PAGE_SIZE_LOG2);
if (stack_size >= Native_config::stack_virtual_size() -
if (stack_size >= stack_virtual_size() -
sizeof(Native_utcb) - (1UL << PAGE_SIZE_LOG2))
throw Stack_too_large();
@ -106,8 +105,7 @@ Thread_base::_alloc_stack(size_t stack_size, char const *name, bool main_thread)
* The stack pointer is always located at the top of the stack header.
*/
addr_t ds_addr = Stack_allocator::addr_to_base(stack) +
Native_config::stack_virtual_size() -
ds_size;
stack_virtual_size() - ds_size;
/* add padding for UTCB if defined for the platform */
if (sizeof(Native_utcb) >= (1 << PAGE_SIZE_LOG2))
@ -117,7 +115,7 @@ Thread_base::_alloc_stack(size_t stack_size, char const *name, bool main_thread)
Ram_dataspace_capability ds_cap;
try {
ds_cap = env_stack_area_ram_session()->alloc(ds_size);
addr_t attach_addr = ds_addr - Native_config::stack_area_virtual_base();
addr_t attach_addr = ds_addr - stack_area_virtual_base();
if (attach_addr != (addr_t)env_stack_area_rm_session()->attach_at(ds_cap, attach_addr, ds_size))
throw Stack_alloc_failed();
}
@ -139,7 +137,7 @@ Thread_base::_alloc_stack(size_t stack_size, char const *name, bool main_thread)
void Thread_base::_free_stack(Stack *stack)
{
addr_t ds_addr = stack->base() - Native_config::stack_area_virtual_base();
addr_t ds_addr = stack->base() - stack_area_virtual_base();
Ram_dataspace_capability ds_cap = stack->ds_cap();
/* call de-constructor explicitly before memory gets detached */
@ -185,6 +183,24 @@ void *Thread_base::stack_base() const { return (void*)_stack->base(); }
void Thread_base::stack_size(size_t const size) { _stack->size(size); }
size_t Thread_base::stack_virtual_size()
{
return Genode::stack_virtual_size();
}
addr_t Thread_base::stack_area_virtual_base()
{
return Genode::stack_area_virtual_base();
}
size_t Thread_base::stack_area_virtual_size()
{
return Genode::stack_area_virtual_size();
}
Thread_base::Thread_base(size_t weight, const char *name, size_t stack_size,
Type type, Cpu_session *cpu_session)
:

View File

@ -19,6 +19,9 @@
#include <base/synced_allocator.h>
#include <base/thread.h>
/* base-internal includes */
#include <base/internal/stack_area.h>
/* local includes */
#include <platform.h>
#include <map_local.h>
@ -80,8 +83,7 @@ class Stack_area_rm_session : public Rm_session
return (addr_t)0;
}
addr_t core_local_addr = Native_config::stack_area_virtual_base() +
(addr_t)local_addr;
addr_t core_local_addr = stack_area_virtual_base() + (addr_t)local_addr;
if (verbose)
PDBG("core_local_addr = %lx, phys_addr = %lx, size = 0x%zx",
@ -103,12 +105,11 @@ class Stack_area_rm_session : public Rm_session
{
using Genode::addr_t;
if ((addr_t)local_addr >= Native_config::stack_area_virtual_size())
if ((addr_t)local_addr >= stack_area_virtual_size())
return;
addr_t const detach = Native_config::stack_area_virtual_base() +
(addr_t)local_addr;
addr_t const stack = Native_config::stack_virtual_size();
addr_t const detach = stack_area_virtual_base() + (addr_t)local_addr;
addr_t const stack = stack_virtual_size();
addr_t const pages = ((detach & ~(stack - 1)) + stack - detach)
>> get_page_size_log2();

View File

@ -16,6 +16,7 @@
/* base-internal includes */
#include <base/internal/stack.h>
#include <base/internal/stack_area.h>
namespace Genode { class Stack_allocator; }
@ -30,8 +31,8 @@ class Genode::Stack_allocator
private:
static constexpr size_t MAX_THREADS =
Native_config::stack_area_virtual_size() /
Native_config::stack_virtual_size();
stack_area_virtual_size() /
stack_virtual_size();
struct Stack_bit_allocator : Bit_allocator<MAX_THREADS>
{

View File

@ -0,0 +1,26 @@
/*
* \brief Stack area layout parameters
* \author Norman Feske
* \date 2016-03-03
*/
/*
* Copyright (C) 2016 Genode Labs GmbH
*
* This file is part of the Genode OS framework, which is distributed
* under the terms of the GNU General Public License version 2.
*/
#ifndef _INCLUDE__BASE__INTERNAL__STACK_AREA_H_
#define _INCLUDE__BASE__INTERNAL__STACK_AREA_H_
#include <base/stdint.h>
namespace Genode {
static constexpr addr_t stack_area_virtual_base() { return 0x40000000UL; }
static constexpr addr_t stack_area_virtual_size() { return 0x10000000UL; }
static constexpr addr_t stack_virtual_size() { return 0x00100000UL; }
}
#endif /* _INCLUDE__BASE__INTERNAL__STACK_AREA_H_ */

View File

@ -11,12 +11,15 @@
* under the terms of the GNU General Public License version 2.
*/
/* Genode includes */
#include <base/env.h>
#include <base/printf.h>
#include <os/config.h>
#include <util/list.h>
#include <util/string.h>
#include <base/thread.h>
/* local includes */
#include <dynamic.h>
#include <init.h>
@ -578,9 +581,10 @@ int main()
/* print loaded object information */
try {
if (Genode::config()->xml_node().attribute("ld_verbose").has_value("yes")) {
PINF(" %lx .. %lx: stack area", Genode::Native_config::stack_area_virtual_base(),
Genode::Native_config::stack_area_virtual_base() +
Genode::Native_config::stack_area_virtual_size() - 1);
PINF(" %lx .. %lx: stack area",
Genode::Thread_base::stack_area_virtual_base(),
Genode::Thread_base::stack_area_virtual_base() +
Genode::Thread_base::stack_area_virtual_size() - 1);
dump_loaded();
}
} catch (...) { }

View File

@ -136,8 +136,8 @@ static void test_main_thread()
printf("thread base %p\n", myself);
/* check whether my stack is inside the first stack region */
addr_t const stack_slot_base = Native_config::stack_area_virtual_base();
addr_t const stack_slot_size = Native_config::stack_area_virtual_size();
addr_t const stack_slot_base = Thread_base::stack_area_virtual_base();
addr_t const stack_slot_size = Thread_base::stack_area_virtual_size();
addr_t const stack_slot_top = stack_slot_base + stack_slot_size;
addr_t const stack_top = (addr_t)myself->stack_top();
@ -271,10 +271,10 @@ static void test_create_as_many_threads()
{
printf("running '%s'\n", __func__);
addr_t const max = Native_config::stack_area_virtual_size() /
Native_config::stack_virtual_size();
addr_t const max = Thread_base::stack_area_virtual_size() /
Thread_base::stack_virtual_size();
static Cpu_helper * threads[max];
Cpu_helper * threads[max];
static char thread_name[8];
unsigned i = 0;

View File

@ -127,8 +127,8 @@ static void register_reserved_areas()
size_t bin_sz = (addr_t)&_prog_img_end - (addr_t)&_prog_img_beg;
L4lx::Env::env()->rm()->reserve_range((addr_t)&_prog_img_beg, bin_sz, "Binary");
L4lx::Env::env()->rm()->reserve_range(Native_config::stack_area_virtual_base(),
Native_config::stack_area_virtual_size(),
L4lx::Env::env()->rm()->reserve_range(Thread_base::stack_area_virtual_base(),
Thread_base::stack_area_virtual_size(),
"Stack Area");
}

View File

@ -1414,7 +1414,7 @@ int main(int argc, char **argv)
* with the actual VM size which is determined below inside this scope.
*/
Vmm::Virtual_reservation
reservation(Genode::Native_config::stack_area_virtual_base());
reservation(Genode::Thread_base::stack_area_virtual_base());
Genode::printf("--- Vancouver VMM starting ---\n");
@ -1468,9 +1468,9 @@ int main(int argc, char **argv)
fb_size / 1024 / 1024);
Genode::printf("[0x%012lx, 0x%012lx) - Genode stack area\n",
Genode::Native_config::stack_area_virtual_base(),
Genode::Native_config::stack_area_virtual_base() +
Genode::Native_config::stack_area_virtual_size());
Genode::Thread_base::stack_area_virtual_base(),
Genode::Thread_base::stack_area_virtual_base() +
Genode::Thread_base::stack_area_virtual_size());
Genode::printf("[0x%012lx, 0x%012lx) - VMM program image\n",
(Genode::addr_t)&_prog_img_beg,

View File

@ -68,7 +68,7 @@ static int create_thread(pthread_t *thread, const pthread_attr_t *attr,
Assert(rtthread);
size_t stack_size = Genode::Native_config::stack_virtual_size() -
size_t stack_size = Genode::Thread_base::stack_virtual_size() -
sizeof(Genode::Native_utcb) - 2 * (1UL << 12);
if (rtthread->cbStack < stack_size)