mirror of
https://github.com/genodelabs/genode.git
synced 2025-01-27 06:39:22 +00:00
parent
28117fee12
commit
9b0eb720b0
@ -63,14 +63,6 @@ namespace Genode {
|
|||||||
return tid.raw;
|
return tid.raw;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
|
||||||
* Empty UTCB type expected by the thread library
|
|
||||||
*
|
|
||||||
* On this kernel, UTCBs are not placed within the the stack area. Each
|
|
||||||
* thread can request its own UTCB pointer using the kernel interface.
|
|
||||||
*/
|
|
||||||
typedef struct { } Native_utcb;
|
|
||||||
|
|
||||||
typedef Native_capability_tpl<Cap_dst_policy> Native_capability;
|
typedef Native_capability_tpl<Cap_dst_policy> Native_capability;
|
||||||
typedef Fiasco::l4_threadid_t Native_connection_state;
|
typedef Fiasco::l4_threadid_t Native_connection_state;
|
||||||
}
|
}
|
||||||
|
23
repos/base-fiasco/src/include/base/internal/native_utcb.h
Normal file
23
repos/base-fiasco/src/include/base/internal/native_utcb.h
Normal file
@ -0,0 +1,23 @@
|
|||||||
|
/*
|
||||||
|
* \brief UTCB definition
|
||||||
|
* \author Norman Feske
|
||||||
|
* \date 2016-03-08
|
||||||
|
*
|
||||||
|
* On this kernel, UTCBs are not placed within the the stack area. Each
|
||||||
|
* thread can request its own UTCB pointer using the kernel interface.
|
||||||
|
*/
|
||||||
|
|
||||||
|
/*
|
||||||
|
* 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__NATIVE_UTCB_H_
|
||||||
|
#define _INCLUDE__BASE__INTERNAL__NATIVE_UTCB_H_
|
||||||
|
|
||||||
|
namespace Genode { struct Native_utcb { }; }
|
||||||
|
|
||||||
|
#endif /* _INCLUDE__BASE__INTERNAL__NATIVE_UTCB_H_ */
|
||||||
|
|
@ -95,17 +95,6 @@ namespace Genode {
|
|||||||
typedef Fiasco::l4_cap_idx_t Native_task;
|
typedef Fiasco::l4_cap_idx_t Native_task;
|
||||||
|
|
||||||
|
|
||||||
struct Native_utcb
|
|
||||||
{
|
|
||||||
/*
|
|
||||||
* The 'Native_utcb' is located within the stack slot of the thread.
|
|
||||||
* We merely use it for remembering a pointer to the real UTCB, which
|
|
||||||
* resides somewhere in the kernel's address space.
|
|
||||||
*/
|
|
||||||
Fiasco::l4_utcb_t *foc_utcb = nullptr;
|
|
||||||
};
|
|
||||||
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Native_capability in Fiasco.OC is just a reference to a Cap_index.
|
* Native_capability in Fiasco.OC is just a reference to a Cap_index.
|
||||||
*
|
*
|
||||||
|
33
repos/base-foc/src/include/base/internal/native_utcb.h
Normal file
33
repos/base-foc/src/include/base/internal/native_utcb.h
Normal file
@ -0,0 +1,33 @@
|
|||||||
|
/*
|
||||||
|
* \brief UTCB definition
|
||||||
|
* \author Norman Feske
|
||||||
|
* \date 2016-03-08
|
||||||
|
*
|
||||||
|
* The 'Native_utcb' is located within the stack slot of the thread. We merely
|
||||||
|
* use it for remembering a pointer to the real UTCB, which resides somewhere
|
||||||
|
* in the kernel's address space.
|
||||||
|
*/
|
||||||
|
|
||||||
|
/*
|
||||||
|
* 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__NATIVE_UTCB_H_
|
||||||
|
#define _INCLUDE__BASE__INTERNAL__NATIVE_UTCB_H_
|
||||||
|
|
||||||
|
namespace Fiasco {
|
||||||
|
#include <l4/sys/utcb.h>
|
||||||
|
}
|
||||||
|
|
||||||
|
namespace Genode { struct Native_utcb; }
|
||||||
|
|
||||||
|
struct Genode::Native_utcb
|
||||||
|
{
|
||||||
|
Fiasco::l4_utcb_t *foc_utcb = nullptr;
|
||||||
|
};
|
||||||
|
|
||||||
|
#endif /* _INCLUDE__BASE__INTERNAL__NATIVE_UTCB_H_ */
|
||||||
|
|
@ -39,21 +39,6 @@ namespace Genode
|
|||||||
* Coherent address region
|
* Coherent address region
|
||||||
*/
|
*/
|
||||||
struct Native_region;
|
struct Native_region;
|
||||||
|
|
||||||
/**
|
|
||||||
* Get the the minimal supported page-size log 2
|
|
||||||
*/
|
|
||||||
constexpr size_t get_page_size_log2() { return 12; }
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Get the the minimal supported page-size
|
|
||||||
*/
|
|
||||||
constexpr size_t get_page_size() { return 1 << get_page_size_log2(); }
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Memory region that is exclusive to every thread and known by the kernel
|
|
||||||
*/
|
|
||||||
class Native_utcb;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
@ -74,95 +59,6 @@ struct Genode::Native_region
|
|||||||
};
|
};
|
||||||
|
|
||||||
|
|
||||||
class Genode::Native_utcb
|
|
||||||
{
|
|
||||||
public:
|
|
||||||
|
|
||||||
enum { MAX_CAP_ARGS = Msgbuf_base::MAX_CAP_ARGS};
|
|
||||||
|
|
||||||
enum Offsets { THREAD_MYSELF, PARENT, UTCB_DATASPACE };
|
|
||||||
|
|
||||||
private:
|
|
||||||
|
|
||||||
Kernel::capid_t _caps[MAX_CAP_ARGS]; /* capability buffer */
|
|
||||||
size_t _cap_cnt; /* capability counter */
|
|
||||||
size_t _size; /* bytes to transfer */
|
|
||||||
uint8_t _buf[get_page_size() - sizeof(_caps) -
|
|
||||||
sizeof(_cap_cnt) - sizeof(_size)];
|
|
||||||
|
|
||||||
public:
|
|
||||||
|
|
||||||
Native_utcb& operator= (const Native_utcb &o)
|
|
||||||
{
|
|
||||||
_cap_cnt = 0;
|
|
||||||
_size = o._size;
|
|
||||||
memcpy(_buf, o._buf, _size);
|
|
||||||
return *this;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Set the destination capability id (server object identity)
|
|
||||||
*/
|
|
||||||
void destination(Kernel::capid_t id) {
|
|
||||||
*reinterpret_cast<long*>(_buf) = id; }
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Return the count of capabilities in the UTCB
|
|
||||||
*/
|
|
||||||
size_t cap_cnt() { return _cap_cnt; }
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Set the count of capabilities in the UTCB
|
|
||||||
*/
|
|
||||||
void cap_cnt(size_t cnt) { _cap_cnt = cnt; }
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Return the start address of the payload data
|
|
||||||
*/
|
|
||||||
void const * base() const { return &_buf; }
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Copy data from the message buffer 'o' to this UTCB
|
|
||||||
*/
|
|
||||||
void copy_from(Msgbuf_base &o, size_t size)
|
|
||||||
{
|
|
||||||
_size = size;
|
|
||||||
|
|
||||||
_cap_cnt = o._snd_cap_cnt;
|
|
||||||
for (unsigned i = 0; i < _cap_cnt; i++)
|
|
||||||
_caps[i] = o._caps[i].dst();
|
|
||||||
|
|
||||||
memcpy(_buf, o.buf, min(_size, o._size));
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Copy data from this UTCB to the message buffer 'o'
|
|
||||||
*/
|
|
||||||
void copy_to(Msgbuf_base &o)
|
|
||||||
{
|
|
||||||
o._snd_cap_cnt = _cap_cnt;
|
|
||||||
for (unsigned i = 0; i < _cap_cnt; i++) {
|
|
||||||
o._caps[i] = _caps[i];
|
|
||||||
if (o._caps[i].valid()) Kernel::ack_cap(o._caps[i].dst());
|
|
||||||
}
|
|
||||||
|
|
||||||
memcpy(o.buf, _buf, min(_size, o._size));
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Return the capability id at index 'i'
|
|
||||||
*/
|
|
||||||
Kernel::capid_t cap_get(unsigned i) {
|
|
||||||
return (i < _cap_cnt) ? _caps[i] : Kernel::cap_id_invalid(); }
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Set the capability id 'cap_id' at the next index
|
|
||||||
*/
|
|
||||||
void cap_add(Kernel::capid_t cap_id) {
|
|
||||||
if (_cap_cnt < MAX_CAP_ARGS) _caps[_cap_cnt++] = cap_id; }
|
|
||||||
};
|
|
||||||
|
|
||||||
|
|
||||||
namespace Genode
|
namespace Genode
|
||||||
{
|
{
|
||||||
static constexpr addr_t VIRT_ADDR_SPACE_START = 0x1000;
|
static constexpr addr_t VIRT_ADDR_SPACE_START = 0x1000;
|
||||||
|
@ -20,6 +20,9 @@
|
|||||||
#include <util/construct_at.h>
|
#include <util/construct_at.h>
|
||||||
#include <util/retry.h>
|
#include <util/retry.h>
|
||||||
|
|
||||||
|
/* base-internal includes */
|
||||||
|
#include <base/internal/native_utcb.h>
|
||||||
|
|
||||||
/* base-hw includes */
|
/* base-hw includes */
|
||||||
#include <kernel/interface.h>
|
#include <kernel/interface.h>
|
||||||
#include <kernel/log.h>
|
#include <kernel/log.h>
|
||||||
|
@ -18,6 +18,9 @@
|
|||||||
#include <base/env.h>
|
#include <base/env.h>
|
||||||
#include <base/trace/events.h>
|
#include <base/trace/events.h>
|
||||||
|
|
||||||
|
/* base-internal includes */
|
||||||
|
#include <base/internal/native_utcb.h>
|
||||||
|
|
||||||
/* base-hw includes */
|
/* base-hw includes */
|
||||||
#include <kernel/interface.h>
|
#include <kernel/interface.h>
|
||||||
|
|
||||||
|
@ -19,6 +19,7 @@
|
|||||||
|
|
||||||
/* base-internal includes */
|
/* base-internal includes */
|
||||||
#include <base/internal/stack.h>
|
#include <base/internal/stack.h>
|
||||||
|
#include <base/internal/native_utcb.h>
|
||||||
|
|
||||||
/* base-hw includes */
|
/* base-hw includes */
|
||||||
#include <kernel/interface.h>
|
#include <kernel/interface.h>
|
||||||
|
@ -20,6 +20,7 @@
|
|||||||
|
|
||||||
/* base-internal includes */
|
/* base-internal includes */
|
||||||
#include <base/internal/stack_allocator.h>
|
#include <base/internal/stack_allocator.h>
|
||||||
|
#include <base/internal/native_utcb.h>
|
||||||
|
|
||||||
using namespace Genode;
|
using namespace Genode;
|
||||||
|
|
||||||
|
@ -14,6 +14,9 @@
|
|||||||
#ifndef _CORE__INCLUDE__KERNEL__CORE_INTERFACE_H_
|
#ifndef _CORE__INCLUDE__KERNEL__CORE_INTERFACE_H_
|
||||||
#define _CORE__INCLUDE__KERNEL__CORE_INTERFACE_H_
|
#define _CORE__INCLUDE__KERNEL__CORE_INTERFACE_H_
|
||||||
|
|
||||||
|
/* base-internal includes */
|
||||||
|
#include <base/internal/native_utcb.h>
|
||||||
|
|
||||||
/* base-hw includes */
|
/* base-hw includes */
|
||||||
#include <kernel/interface.h>
|
#include <kernel/interface.h>
|
||||||
|
|
||||||
|
@ -18,6 +18,9 @@
|
|||||||
/* Genode includes */
|
/* Genode includes */
|
||||||
#include <util/construct_at.h>
|
#include <util/construct_at.h>
|
||||||
|
|
||||||
|
/* base-local includes */
|
||||||
|
#include <base/internal/native_utcb.h>
|
||||||
|
|
||||||
/* core includes */
|
/* core includes */
|
||||||
#include <kernel/fifo.h>
|
#include <kernel/fifo.h>
|
||||||
#include <kernel/interface.h>
|
#include <kernel/interface.h>
|
||||||
|
@ -20,6 +20,9 @@
|
|||||||
#include <base/native_types.h>
|
#include <base/native_types.h>
|
||||||
#include <base/thread.h>
|
#include <base/thread.h>
|
||||||
|
|
||||||
|
/* base-internal includes */
|
||||||
|
#include <base/internal/native_utcb.h>
|
||||||
|
|
||||||
/* core includes */
|
/* core includes */
|
||||||
#include <address_space.h>
|
#include <address_space.h>
|
||||||
#include <object.h>
|
#include <object.h>
|
||||||
|
@ -18,6 +18,9 @@
|
|||||||
#include <rm_session/rm_session.h>
|
#include <rm_session/rm_session.h>
|
||||||
#include <base/printf.h>
|
#include <base/printf.h>
|
||||||
|
|
||||||
|
/* base-internal includes */
|
||||||
|
#include <base/internal/page_size.h>
|
||||||
|
|
||||||
namespace Genode
|
namespace Genode
|
||||||
{
|
{
|
||||||
enum {
|
enum {
|
||||||
|
@ -16,6 +16,9 @@
|
|||||||
#include <util/string.h>
|
#include <util/string.h>
|
||||||
#include <base/native_types.h>
|
#include <base/native_types.h>
|
||||||
|
|
||||||
|
/* base-internal includes */
|
||||||
|
#include <base/internal/native_utcb.h>
|
||||||
|
|
||||||
/* core includes */
|
/* core includes */
|
||||||
#include <assert.h>
|
#include <assert.h>
|
||||||
#include <platform_pd.h>
|
#include <platform_pd.h>
|
||||||
|
@ -19,6 +19,7 @@
|
|||||||
|
|
||||||
/* base-internal includes */
|
/* base-internal includes */
|
||||||
#include <base/internal/unmanaged_singleton.h>
|
#include <base/internal/unmanaged_singleton.h>
|
||||||
|
#include <base/internal/native_utcb.h>
|
||||||
|
|
||||||
/* core includes */
|
/* core includes */
|
||||||
#include <assert.h>
|
#include <assert.h>
|
||||||
|
@ -20,9 +20,11 @@
|
|||||||
#include <rm_session_component.h>
|
#include <rm_session_component.h>
|
||||||
#include <map_local.h>
|
#include <map_local.h>
|
||||||
|
|
||||||
#include <kernel/pd.h>
|
/* base-internal includes */
|
||||||
|
#include <base/internal/native_utcb.h>
|
||||||
|
|
||||||
/* kernel includes */
|
/* kernel includes */
|
||||||
|
#include <kernel/pd.h>
|
||||||
#include <kernel/kernel.h>
|
#include <kernel/kernel.h>
|
||||||
|
|
||||||
using namespace Genode;
|
using namespace Genode;
|
||||||
|
@ -19,6 +19,7 @@
|
|||||||
|
|
||||||
/* base-internal stack */
|
/* base-internal stack */
|
||||||
#include <base/internal/stack.h>
|
#include <base/internal/stack.h>
|
||||||
|
#include <base/internal/native_utcb.h>
|
||||||
|
|
||||||
/* core includes */
|
/* core includes */
|
||||||
#include <map_local.h>
|
#include <map_local.h>
|
||||||
|
118
repos/base-hw/src/include/base/internal/native_utcb.h
Normal file
118
repos/base-hw/src/include/base/internal/native_utcb.h
Normal file
@ -0,0 +1,118 @@
|
|||||||
|
/*
|
||||||
|
* \brief UTCB definition
|
||||||
|
* \author Martin Stein
|
||||||
|
* \author Stefan Kalkowski
|
||||||
|
* \date 2012-01-02
|
||||||
|
*/
|
||||||
|
|
||||||
|
/*
|
||||||
|
* 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__NATIVE_UTCB_H_
|
||||||
|
#define _INCLUDE__BASE__INTERNAL__NATIVE_UTCB_H_
|
||||||
|
|
||||||
|
/* Genode includes */
|
||||||
|
#include <base/stdint.h>
|
||||||
|
#include <base/ipc_msgbuf.h>
|
||||||
|
|
||||||
|
/* base-internal includes */
|
||||||
|
#include <base/internal/page_size.h>
|
||||||
|
|
||||||
|
/* kernel includes */
|
||||||
|
#include <kernel/interface.h>
|
||||||
|
|
||||||
|
namespace Genode { struct Native_utcb; }
|
||||||
|
|
||||||
|
class Genode::Native_utcb
|
||||||
|
{
|
||||||
|
public:
|
||||||
|
|
||||||
|
enum { MAX_CAP_ARGS = Msgbuf_base::MAX_CAP_ARGS};
|
||||||
|
|
||||||
|
enum Offsets { THREAD_MYSELF, PARENT, UTCB_DATASPACE };
|
||||||
|
|
||||||
|
private:
|
||||||
|
|
||||||
|
Kernel::capid_t _caps[MAX_CAP_ARGS]; /* capability buffer */
|
||||||
|
size_t _cap_cnt; /* capability counter */
|
||||||
|
size_t _size; /* bytes to transfer */
|
||||||
|
uint8_t _buf[get_page_size() - sizeof(_caps) -
|
||||||
|
sizeof(_cap_cnt) - sizeof(_size)];
|
||||||
|
|
||||||
|
public:
|
||||||
|
|
||||||
|
Native_utcb& operator= (const Native_utcb &o)
|
||||||
|
{
|
||||||
|
_cap_cnt = 0;
|
||||||
|
_size = o._size;
|
||||||
|
memcpy(_buf, o._buf, _size);
|
||||||
|
return *this;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Set the destination capability id (server object identity)
|
||||||
|
*/
|
||||||
|
void destination(Kernel::capid_t id) {
|
||||||
|
*reinterpret_cast<long*>(_buf) = id; }
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Return the count of capabilities in the UTCB
|
||||||
|
*/
|
||||||
|
size_t cap_cnt() { return _cap_cnt; }
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Set the count of capabilities in the UTCB
|
||||||
|
*/
|
||||||
|
void cap_cnt(size_t cnt) { _cap_cnt = cnt; }
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Return the start address of the payload data
|
||||||
|
*/
|
||||||
|
void const * base() const { return &_buf; }
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Copy data from the message buffer 'o' to this UTCB
|
||||||
|
*/
|
||||||
|
void copy_from(Msgbuf_base &o, size_t size)
|
||||||
|
{
|
||||||
|
_size = size;
|
||||||
|
|
||||||
|
_cap_cnt = o._snd_cap_cnt;
|
||||||
|
for (unsigned i = 0; i < _cap_cnt; i++)
|
||||||
|
_caps[i] = o._caps[i].dst();
|
||||||
|
|
||||||
|
memcpy(_buf, o.buf, min(_size, o._size));
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Copy data from this UTCB to the message buffer 'o'
|
||||||
|
*/
|
||||||
|
void copy_to(Msgbuf_base &o)
|
||||||
|
{
|
||||||
|
o._snd_cap_cnt = _cap_cnt;
|
||||||
|
for (unsigned i = 0; i < _cap_cnt; i++) {
|
||||||
|
o._caps[i] = _caps[i];
|
||||||
|
if (o._caps[i].valid()) Kernel::ack_cap(o._caps[i].dst());
|
||||||
|
}
|
||||||
|
|
||||||
|
memcpy(o.buf, _buf, min(_size, o._size));
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Return the capability id at index 'i'
|
||||||
|
*/
|
||||||
|
Kernel::capid_t cap_get(unsigned i) {
|
||||||
|
return (i < _cap_cnt) ? _caps[i] : Kernel::cap_id_invalid(); }
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Set the capability id 'cap_id' at the next index
|
||||||
|
*/
|
||||||
|
void cap_add(Kernel::capid_t cap_id) {
|
||||||
|
if (_cap_cnt < MAX_CAP_ARGS) _caps[_cap_cnt++] = cap_id; }
|
||||||
|
};
|
||||||
|
|
||||||
|
#endif /* _INCLUDE__BASE__INTERNAL__NATIVE_UTCB_H_ */
|
@ -12,3 +12,6 @@ LIBS += core
|
|||||||
|
|
||||||
# add C++ sources
|
# add C++ sources
|
||||||
SRC_CC += kernel/test.cc
|
SRC_CC += kernel/test.cc
|
||||||
|
|
||||||
|
# allow the test to use base-internal headers, i.e., page_size.h
|
||||||
|
INC_DIR += $(BASE_DIR)/src/include
|
||||||
|
@ -95,11 +95,6 @@ namespace Genode {
|
|||||||
static void copy(void* dst, Native_capability_tpl<Cap_dst_policy>* src);
|
static void copy(void* dst, Native_capability_tpl<Cap_dst_policy>* src);
|
||||||
};
|
};
|
||||||
|
|
||||||
/**
|
|
||||||
* Empty UTCB type expected by the thread library, unused on Linux
|
|
||||||
*/
|
|
||||||
typedef struct { } Native_utcb;
|
|
||||||
|
|
||||||
typedef Native_capability_tpl<Cap_dst_policy> Native_capability;
|
typedef Native_capability_tpl<Cap_dst_policy> Native_capability;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
19
repos/base-linux/src/include/base/internal/native_utcb.h
Normal file
19
repos/base-linux/src/include/base/internal/native_utcb.h
Normal file
@ -0,0 +1,19 @@
|
|||||||
|
/*
|
||||||
|
* \brief UTCB definition
|
||||||
|
* \author Norman Feske
|
||||||
|
* \date 2016-03-08
|
||||||
|
*/
|
||||||
|
|
||||||
|
/*
|
||||||
|
* 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__NATIVE_UTCB_H_
|
||||||
|
#define _INCLUDE__BASE__INTERNAL__NATIVE_UTCB_H_
|
||||||
|
|
||||||
|
namespace Genode { struct Native_utcb { }; }
|
||||||
|
|
||||||
|
#endif /* _INCLUDE__BASE__INTERNAL__NATIVE_UTCB_H_ */
|
@ -43,32 +43,13 @@ namespace Genode {
|
|||||||
return (t1.ec_sel == t2.ec_sel) &&
|
return (t1.ec_sel == t2.ec_sel) &&
|
||||||
(t1.exc_pt_sel == t2.exc_pt_sel);
|
(t1.exc_pt_sel == t2.exc_pt_sel);
|
||||||
}
|
}
|
||||||
|
|
||||||
inline bool operator != (Native_thread_id t1, Native_thread_id t2)
|
inline bool operator != (Native_thread_id t1, Native_thread_id t2)
|
||||||
{
|
{
|
||||||
return (t1.ec_sel != t2.ec_sel) &&
|
return (t1.ec_sel != t2.ec_sel) &&
|
||||||
(t1.exc_pt_sel != t2.exc_pt_sel);
|
(t1.exc_pt_sel != t2.exc_pt_sel);
|
||||||
}
|
}
|
||||||
|
|
||||||
class Native_utcb
|
|
||||||
{
|
|
||||||
private:
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Size of the NOVA-specific user-level thread-control
|
|
||||||
* block
|
|
||||||
*/
|
|
||||||
enum { UTCB_SIZE = 4096 };
|
|
||||||
|
|
||||||
/**
|
|
||||||
* User-level thread control block
|
|
||||||
*
|
|
||||||
* The UTCB is one 4K page, shared between the kernel
|
|
||||||
* and the user process. It is not backed by a
|
|
||||||
* dataspace but provided by the kernel.
|
|
||||||
*/
|
|
||||||
addr_t _utcb[UTCB_SIZE/sizeof(addr_t)];
|
|
||||||
};
|
|
||||||
|
|
||||||
class Native_capability
|
class Native_capability
|
||||||
{
|
{
|
||||||
public:
|
public:
|
||||||
|
@ -442,6 +442,11 @@ namespace Nova {
|
|||||||
*/
|
*/
|
||||||
struct Utcb
|
struct Utcb
|
||||||
{
|
{
|
||||||
|
/**
|
||||||
|
* Return physical size of UTCB in bytes
|
||||||
|
*/
|
||||||
|
static constexpr mword_t size() { return 4096; }
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Number of untyped items uses lowest 16 bit, number of typed items
|
* Number of untyped items uses lowest 16 bit, number of typed items
|
||||||
* uses bit 16-31, bit 32+ are ignored on 64bit
|
* uses bit 16-31, bit 32+ are ignored on 64bit
|
||||||
|
@ -24,6 +24,7 @@
|
|||||||
/* base-internal includes */
|
/* base-internal includes */
|
||||||
#include <base/internal/stack.h>
|
#include <base/internal/stack.h>
|
||||||
#include <base/internal/stack_area.h>
|
#include <base/internal/stack_area.h>
|
||||||
|
#include <base/internal/native_utcb.h>
|
||||||
|
|
||||||
/* base-nova includes */
|
/* base-nova includes */
|
||||||
#include <base/cap_map.h>
|
#include <base/cap_map.h>
|
||||||
|
@ -29,6 +29,7 @@
|
|||||||
|
|
||||||
/* base-internal includes */
|
/* base-internal includes */
|
||||||
#include <base/internal/stack_area.h>
|
#include <base/internal/stack_area.h>
|
||||||
|
#include <base/internal/native_utcb.h>
|
||||||
|
|
||||||
/* NOVA includes */
|
/* NOVA includes */
|
||||||
#include <nova/syscalls.h>
|
#include <nova/syscalls.h>
|
||||||
|
42
repos/base-nova/src/include/base/internal/native_utcb.h
Normal file
42
repos/base-nova/src/include/base/internal/native_utcb.h
Normal file
@ -0,0 +1,42 @@
|
|||||||
|
/*
|
||||||
|
* \brief UTCB definition
|
||||||
|
* \author Norman Feske
|
||||||
|
* \date 2016-03-08
|
||||||
|
*/
|
||||||
|
|
||||||
|
/*
|
||||||
|
* 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__NATIVE_UTCB_H_
|
||||||
|
#define _INCLUDE__BASE__INTERNAL__NATIVE_UTCB_H_
|
||||||
|
|
||||||
|
#include <base/stdint.h>
|
||||||
|
|
||||||
|
namespace Genode { struct Native_utcb; }
|
||||||
|
|
||||||
|
class Genode::Native_utcb
|
||||||
|
{
|
||||||
|
private:
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Size of the NOVA-specific user-level thread-control
|
||||||
|
* block
|
||||||
|
*/
|
||||||
|
enum { UTCB_SIZE = 4096 };
|
||||||
|
|
||||||
|
/**
|
||||||
|
* User-level thread control block
|
||||||
|
*
|
||||||
|
* The UTCB is one 4K page, shared between the kernel
|
||||||
|
* and the user process. It is not backed by a
|
||||||
|
* dataspace but provided by the kernel.
|
||||||
|
*/
|
||||||
|
addr_t _utcb[UTCB_SIZE/sizeof(addr_t)];
|
||||||
|
};
|
||||||
|
|
||||||
|
#endif /* _INCLUDE__BASE__INTERNAL__NATIVE_UTCB_H_ */
|
||||||
|
|
@ -71,14 +71,6 @@ namespace Genode {
|
|||||||
return tid.raw;
|
return tid.raw;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
|
||||||
* Empty UTCB type expected by the thread library, unused on OKL4
|
|
||||||
*
|
|
||||||
* On this kernel, UTCBs are not placed within the stack area. Each
|
|
||||||
* thread can request its own UTCB pointer using the kernel interface.
|
|
||||||
*/
|
|
||||||
typedef struct { } Native_utcb;
|
|
||||||
|
|
||||||
struct Cap_dst_policy
|
struct Cap_dst_policy
|
||||||
{
|
{
|
||||||
typedef Okl4::L4_ThreadId_t Dst;
|
typedef Okl4::L4_ThreadId_t Dst;
|
||||||
|
23
repos/base-okl4/src/include/base/internal/native_utcb.h
Normal file
23
repos/base-okl4/src/include/base/internal/native_utcb.h
Normal file
@ -0,0 +1,23 @@
|
|||||||
|
/*
|
||||||
|
* \brief UTCB definition
|
||||||
|
* \author Norman Feske
|
||||||
|
* \date 2016-03-08
|
||||||
|
*
|
||||||
|
* On this kernel, UTCBs are not placed within the stack area. Each thread
|
||||||
|
* can request its own UTCB pointer using the kernel interface.
|
||||||
|
*/
|
||||||
|
|
||||||
|
/*
|
||||||
|
* 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__NATIVE_UTCB_H_
|
||||||
|
#define _INCLUDE__BASE__INTERNAL__NATIVE_UTCB_H_
|
||||||
|
|
||||||
|
namespace Genode { struct Native_utcb { }; }
|
||||||
|
|
||||||
|
#endif /* _INCLUDE__BASE__INTERNAL__NATIVE_UTCB_H_ */
|
||||||
|
|
@ -53,23 +53,6 @@ namespace Genode {
|
|||||||
Platform_thread *pt;
|
Platform_thread *pt;
|
||||||
};
|
};
|
||||||
|
|
||||||
inline unsigned long convert_native_thread_id_to_badge(Native_thread_id tid)
|
|
||||||
{
|
|
||||||
/*
|
|
||||||
* Pistachio has no server-defined badges for page-fault messages.
|
|
||||||
* Therefore, we have to interpret the sender ID as badge.
|
|
||||||
*/
|
|
||||||
return tid.raw;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Empty UTCB type expected by the thread library
|
|
||||||
*
|
|
||||||
* On this kernel, UTCBs are not placed within the stack area. Each thread
|
|
||||||
* can request its own UTCB pointer using the kernel interface.
|
|
||||||
*/
|
|
||||||
typedef struct { } Native_utcb;
|
|
||||||
|
|
||||||
typedef Native_capability_tpl<Cap_dst_policy> Native_capability;
|
typedef Native_capability_tpl<Cap_dst_policy> Native_capability;
|
||||||
|
|
||||||
typedef Pistachio::L4_ThreadId_t Native_connection_state;
|
typedef Pistachio::L4_ThreadId_t Native_connection_state;
|
||||||
|
@ -28,6 +28,17 @@ namespace Pistachio {
|
|||||||
#include <l4/types.h>
|
#include <l4/types.h>
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
inline unsigned long convert_native_thread_id_to_badge(Genode::Native_thread_id tid)
|
||||||
|
{
|
||||||
|
/*
|
||||||
|
* Pistachio has no server-defined badges for page-fault messages.
|
||||||
|
* Therefore, we have to interpret the sender ID as badge.
|
||||||
|
*/
|
||||||
|
return tid.raw;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
namespace Genode {
|
namespace Genode {
|
||||||
|
|
||||||
class Platform_pd;
|
class Platform_pd;
|
||||||
|
23
repos/base-pistachio/src/include/base/internal/native_utcb.h
Normal file
23
repos/base-pistachio/src/include/base/internal/native_utcb.h
Normal file
@ -0,0 +1,23 @@
|
|||||||
|
/*
|
||||||
|
* \brief Pistachio-specific UTCB definition
|
||||||
|
* \author Norman Feske
|
||||||
|
* \date 2016-03-08
|
||||||
|
*
|
||||||
|
* On this kernel, UTCBs are not placed within the stack area. Each thread
|
||||||
|
* can request its own UTCB pointer using the kernel interface.
|
||||||
|
*/
|
||||||
|
|
||||||
|
/*
|
||||||
|
* 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__NATIVE_UTCB_H_
|
||||||
|
#define _INCLUDE__BASE__INTERNAL__NATIVE_UTCB_H_
|
||||||
|
|
||||||
|
namespace Genode { struct Native_utcb { }; }
|
||||||
|
|
||||||
|
#endif /* _INCLUDE__BASE__INTERNAL__NATIVE_UTCB_H_ */
|
||||||
|
|
@ -108,24 +108,6 @@ namespace Genode {
|
|||||||
bool valid() const;
|
bool valid() const;
|
||||||
};
|
};
|
||||||
|
|
||||||
struct Native_utcb
|
|
||||||
{
|
|
||||||
/**
|
|
||||||
* On seL4, the UTCB is called IPC buffer. We use one page
|
|
||||||
* for each IPC buffer.
|
|
||||||
*/
|
|
||||||
enum { IPC_BUFFER_SIZE = 4096 };
|
|
||||||
|
|
||||||
union {
|
|
||||||
|
|
||||||
addr_t raw[IPC_BUFFER_SIZE/sizeof(addr_t)];
|
|
||||||
|
|
||||||
struct {
|
|
||||||
addr_t ep_sel;
|
|
||||||
};
|
|
||||||
};
|
|
||||||
};
|
|
||||||
|
|
||||||
typedef int Native_connection_state;
|
typedef int Native_connection_state;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -21,6 +21,7 @@
|
|||||||
|
|
||||||
/* base-internal includes */
|
/* base-internal includes */
|
||||||
#include <base/internal/capability_space_sel4.h>
|
#include <base/internal/capability_space_sel4.h>
|
||||||
|
#include <base/internal/native_utcb.h>
|
||||||
|
|
||||||
using namespace Genode;
|
using namespace Genode;
|
||||||
|
|
||||||
|
37
repos/base-sel4/src/include/base/internal/native_utcb.h
Normal file
37
repos/base-sel4/src/include/base/internal/native_utcb.h
Normal file
@ -0,0 +1,37 @@
|
|||||||
|
/*
|
||||||
|
* \brief UTCB definition
|
||||||
|
* \author Norman Feske
|
||||||
|
* \date 2016-03-08
|
||||||
|
*/
|
||||||
|
|
||||||
|
/*
|
||||||
|
* 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__NATIVE_UTCB_H_
|
||||||
|
#define _INCLUDE__BASE__INTERNAL__NATIVE_UTCB_H_
|
||||||
|
|
||||||
|
#include <base/stdint.h>
|
||||||
|
|
||||||
|
namespace Genode { struct Native_utcb; }
|
||||||
|
|
||||||
|
struct Genode::Native_utcb
|
||||||
|
{
|
||||||
|
/**
|
||||||
|
* On seL4, the UTCB is called IPC buffer. We use one page
|
||||||
|
* for each IPC buffer.
|
||||||
|
*/
|
||||||
|
enum { IPC_BUFFER_SIZE = 4096 };
|
||||||
|
|
||||||
|
union {
|
||||||
|
|
||||||
|
addr_t raw[IPC_BUFFER_SIZE/sizeof(addr_t)];
|
||||||
|
|
||||||
|
struct { addr_t ep_sel; };
|
||||||
|
};
|
||||||
|
};
|
||||||
|
|
||||||
|
#endif /* _INCLUDE__BASE__INTERNAL__NATIVE_UTCB_H_ */
|
@ -28,6 +28,7 @@
|
|||||||
|
|
||||||
namespace Genode {
|
namespace Genode {
|
||||||
|
|
||||||
|
struct Native_utcb;
|
||||||
class Rm_session;
|
class Rm_session;
|
||||||
class Thread_base;
|
class Thread_base;
|
||||||
class Stack;
|
class Stack;
|
||||||
|
@ -16,6 +16,7 @@
|
|||||||
|
|
||||||
/* base-internal includes */
|
/* base-internal includes */
|
||||||
#include <base/internal/stack.h>
|
#include <base/internal/stack.h>
|
||||||
|
#include <base/internal/native_utcb.h>
|
||||||
|
|
||||||
using namespace Genode;
|
using namespace Genode;
|
||||||
|
|
||||||
|
23
repos/base/src/include/base/internal/page_size.h
Normal file
23
repos/base/src/include/base/internal/page_size.h
Normal file
@ -0,0 +1,23 @@
|
|||||||
|
/*
|
||||||
|
* \brief Page size utilities
|
||||||
|
* \author Norman Feske
|
||||||
|
* \date 2016-03-08
|
||||||
|
*/
|
||||||
|
|
||||||
|
/*
|
||||||
|
* 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__PAGE_SIZE_H_
|
||||||
|
#define _INCLUDE__BASE__INTERNAL__PAGE_SIZE_H_
|
||||||
|
|
||||||
|
namespace Genode
|
||||||
|
{
|
||||||
|
constexpr size_t get_page_size_log2() { return 12; }
|
||||||
|
constexpr size_t get_page_size() { return 1 << get_page_size_log2(); }
|
||||||
|
}
|
||||||
|
|
||||||
|
#endif /* _INCLUDE__BASE__INTERNAL__PAGE_SIZE_H_ */
|
@ -59,6 +59,9 @@
|
|||||||
#include <cpu/consts.h>
|
#include <cpu/consts.h>
|
||||||
#include <ram_session/ram_session.h> /* for 'Ram_dataspace_capability' type */
|
#include <ram_session/ram_session.h> /* for 'Ram_dataspace_capability' type */
|
||||||
|
|
||||||
|
/* base-internal includes */
|
||||||
|
#include <base/internal/native_utcb.h>
|
||||||
|
|
||||||
namespace Genode { class Stack; }
|
namespace Genode { class Stack; }
|
||||||
|
|
||||||
|
|
||||||
|
@ -19,6 +19,9 @@
|
|||||||
#include <base/lock.h>
|
#include <base/lock.h>
|
||||||
#include <base/printf.h>
|
#include <base/printf.h>
|
||||||
|
|
||||||
|
/* NOVA includes */
|
||||||
|
#include <nova/syscalls.h>
|
||||||
|
|
||||||
namespace Vmm {
|
namespace Vmm {
|
||||||
|
|
||||||
using namespace Genode;
|
using namespace Genode;
|
||||||
@ -35,17 +38,19 @@ inline void Vmm::printf(const char *format, ...)
|
|||||||
va_list list;
|
va_list list;
|
||||||
va_start(list, format);
|
va_start(list, format);
|
||||||
|
|
||||||
|
struct Utcb_backup { char buf[Nova::Utcb::size()]; };
|
||||||
|
|
||||||
static Lock lock;
|
static Lock lock;
|
||||||
static Native_utcb utcb_backup;
|
static Utcb_backup utcb_backup;
|
||||||
|
|
||||||
Lock::Guard guard(lock);
|
Lock::Guard guard(lock);
|
||||||
|
|
||||||
utcb_backup = *Thread_base::myself()->utcb();
|
utcb_backup = *(Utcb_backup *)Thread_base::myself()->utcb();
|
||||||
|
|
||||||
Genode::printf("VMM: ");
|
Genode::printf("VMM: ");
|
||||||
Genode::vprintf(format, list);
|
Genode::vprintf(format, list);
|
||||||
|
|
||||||
*Thread_base::myself()->utcb() = utcb_backup;
|
*(Utcb_backup *)Thread_base::myself()->utcb() = utcb_backup;
|
||||||
|
|
||||||
va_end(list);
|
va_end(list);
|
||||||
}
|
}
|
||||||
|
@ -30,13 +30,17 @@ namespace Vmm {
|
|||||||
|
|
||||||
class Vmm::Utcb_guard
|
class Vmm::Utcb_guard
|
||||||
{
|
{
|
||||||
|
public:
|
||||||
|
|
||||||
|
struct Utcb_backup { char buf[Nova::Utcb::size()]; };
|
||||||
|
|
||||||
private:
|
private:
|
||||||
|
|
||||||
Native_utcb &_backup_utcb;
|
Utcb_backup &_backup_utcb;
|
||||||
|
|
||||||
public:
|
public:
|
||||||
|
|
||||||
Utcb_guard(Native_utcb &backup_utcb) : _backup_utcb(backup_utcb)
|
Utcb_guard(Utcb_backup &backup_utcb) : _backup_utcb(backup_utcb)
|
||||||
{
|
{
|
||||||
Nova::Utcb *utcb =
|
Nova::Utcb *utcb =
|
||||||
reinterpret_cast<Nova::Utcb *>(Thread_base::myself()->utcb());
|
reinterpret_cast<Nova::Utcb *>(Thread_base::myself()->utcb());
|
||||||
|
@ -181,7 +181,7 @@ void Vancouver_disk::_signal_dispatch_entry(unsigned disknr)
|
|||||||
|
|
||||||
bool Vancouver_disk::receive(MessageDisk &msg)
|
bool Vancouver_disk::receive(MessageDisk &msg)
|
||||||
{
|
{
|
||||||
static Genode::Native_utcb utcb_backup;
|
static Vmm::Utcb_guard::Utcb_backup utcb_backup;
|
||||||
Vmm::Utcb_guard guard(utcb_backup);
|
Vmm::Utcb_guard guard(utcb_backup);
|
||||||
|
|
||||||
if (msg.disknr >= MAX_DISKS)
|
if (msg.disknr >= MAX_DISKS)
|
||||||
|
@ -52,6 +52,7 @@
|
|||||||
#include <vmm/guest_memory.h>
|
#include <vmm/guest_memory.h>
|
||||||
#include <vmm/vcpu_thread.h>
|
#include <vmm/vcpu_thread.h>
|
||||||
#include <vmm/vcpu_dispatcher.h>
|
#include <vmm/vcpu_dispatcher.h>
|
||||||
|
#include <vmm/utcb_guard.h>
|
||||||
|
|
||||||
/* NOVA includes that come with Genode */
|
/* NOVA includes that come with Genode */
|
||||||
#include <nova/syscalls.h>
|
#include <nova/syscalls.h>
|
||||||
@ -77,7 +78,10 @@ enum { verbose_debug = false };
|
|||||||
enum { verbose_npt = false };
|
enum { verbose_npt = false };
|
||||||
enum { verbose_io = false };
|
enum { verbose_io = false };
|
||||||
|
|
||||||
static Genode::Native_utcb utcb_backup;
|
typedef Vmm::Utcb_guard::Utcb_backup Utcb_backup;
|
||||||
|
|
||||||
|
static Utcb_backup utcb_backup;
|
||||||
|
|
||||||
Genode::Lock *utcb_lock()
|
Genode::Lock *utcb_lock()
|
||||||
{
|
{
|
||||||
static Genode::Lock inst;
|
static Genode::Lock inst;
|
||||||
@ -1143,7 +1147,9 @@ class Machine : public StaticReceiver<Machine>
|
|||||||
bool receive(MessageTime &msg)
|
bool receive(MessageTime &msg)
|
||||||
{
|
{
|
||||||
Genode::Lock::Guard guard(*utcb_lock());
|
Genode::Lock::Guard guard(*utcb_lock());
|
||||||
utcb_backup = *Genode::Thread_base::myself()->utcb();
|
|
||||||
|
Vmm::Utcb_guard utcb_guard(utcb_backup);
|
||||||
|
utcb_backup = *(Utcb_backup *)Genode::Thread_base::myself()->utcb();
|
||||||
|
|
||||||
if (!_rtc) {
|
if (!_rtc) {
|
||||||
try {
|
try {
|
||||||
@ -1152,7 +1158,7 @@ class Machine : public StaticReceiver<Machine>
|
|||||||
Logging::printf("No RTC present, returning dummy time.\n");
|
Logging::printf("No RTC present, returning dummy time.\n");
|
||||||
msg.wallclocktime = msg.timestamp = 0;
|
msg.wallclocktime = msg.timestamp = 0;
|
||||||
|
|
||||||
*Genode::Thread_base::myself()->utcb() = utcb_backup;
|
*(Utcb_backup *)Genode::Thread_base::myself()->utcb() = utcb_backup;
|
||||||
|
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
@ -1166,7 +1172,7 @@ class Machine : public StaticReceiver<Machine>
|
|||||||
Logging::printf("Got time %llx\n", msg.wallclocktime);
|
Logging::printf("Got time %llx\n", msg.wallclocktime);
|
||||||
msg.timestamp = _unsynchronized_motherboard.clock()->clock(MessageTime::FREQUENCY);
|
msg.timestamp = _unsynchronized_motherboard.clock()->clock(MessageTime::FREQUENCY);
|
||||||
|
|
||||||
*Genode::Thread_base::myself()->utcb() = utcb_backup;
|
*(Utcb_backup *)Genode::Thread_base::myself()->utcb() = utcb_backup;
|
||||||
|
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
@ -1176,7 +1182,8 @@ class Machine : public StaticReceiver<Machine>
|
|||||||
if (msg.type != MessageNetwork::PACKET) return false;
|
if (msg.type != MessageNetwork::PACKET) return false;
|
||||||
|
|
||||||
Genode::Lock::Guard guard(*utcb_lock());
|
Genode::Lock::Guard guard(*utcb_lock());
|
||||||
utcb_backup = *Genode::Thread_base::myself()->utcb();
|
|
||||||
|
Vmm::Utcb_guard utcb_guard(utcb_backup);
|
||||||
|
|
||||||
if (msg.buffer == _forward_pkt) {
|
if (msg.buffer == _forward_pkt) {
|
||||||
/* don't end in an endless forwarding loop */
|
/* don't end in an endless forwarding loop */
|
||||||
@ -1211,8 +1218,6 @@ class Machine : public StaticReceiver<Machine>
|
|||||||
/* release sent packet to free the space in the tx communication buffer */
|
/* release sent packet to free the space in the tx communication buffer */
|
||||||
_nic->tx()->release_packet(tx_packet);
|
_nic->tx()->release_packet(tx_packet);
|
||||||
|
|
||||||
*Genode::Thread_base::myself()->utcb() = utcb_backup;
|
|
||||||
|
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -17,6 +17,9 @@
|
|||||||
#include <base/sleep.h>
|
#include <base/sleep.h>
|
||||||
#include <base/thread.h>
|
#include <base/thread.h>
|
||||||
|
|
||||||
|
/* VMM utils */
|
||||||
|
#include <vmm/utcb_guard.h>
|
||||||
|
|
||||||
/* NOVA userland includes */
|
/* NOVA userland includes */
|
||||||
#include <service/logging.h>
|
#include <service/logging.h>
|
||||||
#include <service/memory.h>
|
#include <service/memory.h>
|
||||||
@ -31,7 +34,9 @@ Genode::Lock *printf_lock()
|
|||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
static Genode::Native_utcb utcb_backup;
|
typedef Vmm::Utcb_guard::Utcb_backup Utcb_backup;
|
||||||
|
|
||||||
|
static Utcb_backup utcb_backup;
|
||||||
|
|
||||||
|
|
||||||
void Logging::printf(const char *format, ...)
|
void Logging::printf(const char *format, ...)
|
||||||
@ -41,12 +46,12 @@ void Logging::printf(const char *format, ...)
|
|||||||
|
|
||||||
Genode::Lock::Guard guard(*printf_lock());
|
Genode::Lock::Guard guard(*printf_lock());
|
||||||
|
|
||||||
utcb_backup = *Genode::Thread_base::myself()->utcb();
|
utcb_backup = *(Utcb_backup *)Genode::Thread_base::myself()->utcb();
|
||||||
|
|
||||||
Genode::printf("VMM: ");
|
Genode::printf("VMM: ");
|
||||||
Genode::vprintf(format, list);
|
Genode::vprintf(format, list);
|
||||||
|
|
||||||
*Genode::Thread_base::myself()->utcb() = utcb_backup;
|
*(Utcb_backup *)Genode::Thread_base::myself()->utcb() = utcb_backup;
|
||||||
|
|
||||||
va_end(list);
|
va_end(list);
|
||||||
}
|
}
|
||||||
@ -56,13 +61,13 @@ void Logging::vprintf(const char *format, va_list &ap)
|
|||||||
{
|
{
|
||||||
Genode::Lock::Guard guard(*printf_lock());
|
Genode::Lock::Guard guard(*printf_lock());
|
||||||
|
|
||||||
utcb_backup = *Genode::Thread_base::myself()->utcb();
|
utcb_backup = *(Utcb_backup *)Genode::Thread_base::myself()->utcb();
|
||||||
|
|
||||||
Genode::printf("VMM: ");
|
Genode::printf("VMM: ");
|
||||||
Genode::printf(format);
|
Genode::printf(format);
|
||||||
PWRN("Logging::vprintf not implemented");
|
PWRN("Logging::vprintf not implemented");
|
||||||
|
|
||||||
*Genode::Thread_base::myself()->utcb() = utcb_backup;
|
*(Utcb_backup *)Genode::Thread_base::myself()->utcb() = utcb_backup;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@ -15,8 +15,6 @@
|
|||||||
#include <base/printf.h>
|
#include <base/printf.h>
|
||||||
#include <util/string.h>
|
#include <util/string.h>
|
||||||
|
|
||||||
#include <vmm/printf.h>
|
|
||||||
|
|
||||||
/* VirtualBox includes */
|
/* VirtualBox includes */
|
||||||
#include "PGMInternal.h" /* enable access to pgm.s.* */
|
#include "PGMInternal.h" /* enable access to pgm.s.* */
|
||||||
#include "EMInternal.h"
|
#include "EMInternal.h"
|
||||||
@ -644,8 +642,8 @@ extern "C" int MMIO2_MAPPED_SYNC(PVM pVM, RTGCPHYS GCPhys, size_t cbWrite,
|
|||||||
return VINF_SUCCESS;
|
return VINF_SUCCESS;
|
||||||
}
|
}
|
||||||
|
|
||||||
Vmm::printf("%s: GCPhys=0x%llx failed - unexpected rc=%d\n",
|
// Vmm::printf("%s: GCPhys=0x%llx failed - unexpected rc=%d\n",
|
||||||
__func__, (Genode::uint64_t)GCPhys, rc);
|
// __func__, (Genode::uint64_t)GCPhys, rc);
|
||||||
return rc;
|
return rc;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -659,10 +657,10 @@ extern "C" int MMIO2_MAPPED_SYNC(PVM pVM, RTGCPHYS GCPhys, size_t cbWrite,
|
|||||||
Assert(pv);
|
Assert(pv);
|
||||||
|
|
||||||
fli = Flexpage_iterator((addr_t)pv, map_size, map_start, map_size, map_start);
|
fli = Flexpage_iterator((addr_t)pv, map_size, map_start, map_size, map_start);
|
||||||
if (verbose_debug)
|
// if (verbose_debug)
|
||||||
Vmm::printf("%s: GCPhys=0x%llx - %llx+%zx\n", __func__,
|
// Vmm::printf("%s: GCPhys=0x%llx - %llx+%zx\n", __func__,
|
||||||
(Genode::uint64_t)GCPhys, (Genode::uint64_t)map_start,
|
// (Genode::uint64_t)GCPhys, (Genode::uint64_t)map_start,
|
||||||
map_size);
|
// map_size);
|
||||||
|
|
||||||
*ppv = pv;
|
*ppv = pv;
|
||||||
|
|
||||||
|
@ -68,8 +68,10 @@ static int create_thread(pthread_t *thread, const pthread_attr_t *attr,
|
|||||||
|
|
||||||
Assert(rtthread);
|
Assert(rtthread);
|
||||||
|
|
||||||
|
size_t const utcb_size = 4096;
|
||||||
|
|
||||||
size_t stack_size = Genode::Thread_base::stack_virtual_size() -
|
size_t stack_size = Genode::Thread_base::stack_virtual_size() -
|
||||||
sizeof(Genode::Native_utcb) - 2 * (1UL << 12);
|
utcb_size - 2 * (1UL << 12);
|
||||||
|
|
||||||
if (rtthread->cbStack < stack_size)
|
if (rtthread->cbStack < stack_size)
|
||||||
stack_size = rtthread->cbStack;
|
stack_size = rtthread->cbStack;
|
||||||
|
Loading…
x
Reference in New Issue
Block a user