mirror of
https://github.com/genodelabs/genode.git
synced 2025-01-27 14:49:31 +00:00
6862ab481a
Unify handling of UTCBs. The utcb of the main thread is with commit ea38aad30e6166a0da1ac8bd84b53d6e1962cfaf at a fixed location - per convention. So we can remove all the ugly code to transfer the utcb address during process creation. To do so also the UTCB of the main thread of Core must be inside Genode's thread context area to handle it the same way. Unfortunately the UTCB of the main thread of Core can't be chosen, it is defined by the kernel. Possible solutions: - make virtual address of first thread UTCB configurable in hypervisor - map the utcb of the first thread inside Core to the desired location This commit implements the second option. Kernel patch: make utcb map-able With the patch the Utcb of the main thread of Core is map-able. Fixes #374 Noux actually uses the sp variable during thread creation and expects to be set accordingly. This wasn't the case for the main thread, it was ever set to the address of the main thread UTCB.
56 lines
1.3 KiB
C++
56 lines
1.3 KiB
C++
/*
|
|
* \brief Helper code used by core as base framework
|
|
* \author Alexander Boettcher
|
|
* \date 2012-08-08
|
|
*/
|
|
|
|
/*
|
|
* Copyright (C) 2012-2012 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 _NOVA__INCLUDE__UTIL_H_
|
|
#define _NOVA__INCLUDE__UTIL_H_
|
|
|
|
#include <base/printf.h>
|
|
#include <base/thread.h>
|
|
|
|
__attribute__((always_inline))
|
|
inline void nova_die(const char * text = 0)
|
|
{
|
|
/*
|
|
* If thread is de-constructed the sessions are already gone.
|
|
* Be careful when enabling printf here.
|
|
*/
|
|
while (1)
|
|
asm volatile ("ud2a" : : "a"(text));
|
|
}
|
|
|
|
inline void request_event_portal(Genode::Native_capability cap,
|
|
Genode::addr_t exc_base, Genode::addr_t event)
|
|
{
|
|
using namespace Nova;
|
|
Utcb *utcb = (Utcb *)Genode::Thread_base::myself()->utcb();
|
|
|
|
/* save original receive window */
|
|
Crd orig_crd = utcb->crd_rcv;
|
|
|
|
/* request event-handler portal */
|
|
utcb->crd_rcv = Obj_crd(exc_base + event, 0);
|
|
utcb->msg[0] = event;
|
|
utcb->set_msg_word(1);
|
|
|
|
uint8_t res = call(cap.local_name());
|
|
if (res)
|
|
PERR("request of event (%lu) capability selector failed",
|
|
event);
|
|
|
|
/* restore original receive window */
|
|
utcb->crd_rcv = orig_crd;
|
|
}
|
|
|
|
|
|
#endif /* _NOVA__INCLUDE__UTIL_H_ */
|