This patch simplifies the system call bindings. The common syscall bindings in 'src/platform/' have been reduced to the syscalls needed by non-core programs. The additional syscalls that are needed solely by core have been moved to 'src/core/include/core_linux_syscalls.h'. Furthermore, the resource path is not used outside of core anymore. Hence, we could get rid of the rpath library. The resource-path code has been moved to 'src/core/include/resource_path.h'. The IPC-related parts of 'src/platform' have been moved to the IPC library. So there is now a clean separation between low-level syscall bindings (in 'src/platform') and higher-level code. The code for the socket-descriptor registry is now located in the 'src/base/ipc/socket_descriptor_registry.h' header. The interface is separated from 'ipc.cc' because core needs to access the registry from outside the ipc library.
53 lines
1.3 KiB
C++
53 lines
1.3 KiB
C++
/*
|
|
* \brief Linux-specific extension of the CPU session implementation
|
|
* \author Norman Feske
|
|
* \date 2012-08-09
|
|
*/
|
|
|
|
/* core includes */
|
|
#include <cpu_session_component.h>
|
|
|
|
/* Linux includes */
|
|
#include <core_linux_syscalls.h>
|
|
|
|
using namespace Genode;
|
|
|
|
|
|
void Cpu_session_component::thread_id(Thread_capability thread_cap, int pid, int tid)
|
|
{
|
|
Lock::Guard lock_guard(_thread_list_lock);
|
|
|
|
Cpu_thread_component *thread = _lookup_thread(thread_cap);
|
|
if (!thread) return;
|
|
|
|
thread->platform_thread()->thread_id(pid, tid);
|
|
}
|
|
|
|
|
|
Untyped_capability Cpu_session_component::server_sd(Thread_capability thread_cap)
|
|
{
|
|
Lock::Guard lock_guard(_thread_list_lock);
|
|
|
|
Cpu_thread_component *thread = _lookup_thread(thread_cap);
|
|
if (!thread) return Untyped_capability();
|
|
|
|
enum { DUMMY_LOCAL_NAME = 0 };
|
|
typedef Native_capability::Dst Dst;
|
|
return Untyped_capability(Dst(thread->platform_thread()->server_sd()),
|
|
DUMMY_LOCAL_NAME);
|
|
}
|
|
|
|
|
|
Untyped_capability Cpu_session_component::client_sd(Thread_capability thread_cap)
|
|
{
|
|
Lock::Guard lock_guard(_thread_list_lock);
|
|
|
|
Cpu_thread_component *thread = _lookup_thread(thread_cap);
|
|
if (!thread) return Untyped_capability();
|
|
|
|
enum { DUMMY_LOCAL_NAME = 0 };
|
|
typedef Native_capability::Dst Dst;
|
|
return Untyped_capability(Dst(thread->platform_thread()->client_sd()),
|
|
DUMMY_LOCAL_NAME);
|
|
}
|