/* * \brief Linux-specific utilities for stack area * \author Christian Helmuth * \date 2013-09-26 */ /* * Copyright (C) 2010-2013 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_ /* Genode includes */ #include #include #include /* Linux includes */ #include 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(); int ret; if ((ret = lx_munmap(base, size)) < 0) { PERR("%s: failed ret=%d", __func__, ret); throw Rm_session::Region_conflict(); } } static inline Genode::addr_t reserve_stack_area() { using namespace Genode; 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(); void * const addr_out = lx_mmap(addr_in, size, prot, flags, -1, 0); /* reserve at local address failed - unmap incorrect mapping */ if (addr_in != addr_out) { lx_munmap((void *)addr_out, size); PERR("%s: failed addr_in=%p addr_out=%p ret=%ld)", __func__, addr_in, addr_out, (long)addr_out); throw Rm_session::Region_conflict(); } return (addr_t) addr_out; } #endif /* _INCLUDE__BASE__INTERNAL__STACK_AREA_H_ */