genode/repos/dde_rump/include/util/hard_context.h
Norman Feske 17c79a9e23 base: avoid use of deprecated base/printf.h
Besides adapting the components to the use of base/log.h, the patch
cleans up a few base headers, i.e., it removes unused includes from
root/component.h, specifically base/heap.h and
ram_session/ram_session.h. Hence, components that relied on the implicit
inclusion of those headers have to manually include those headers now.

While adjusting the log messages, I repeatedly stumbled over the problem
that printing char * arguments is ambiguous. It is unclear whether to
print the argument as pointer or null-terminated string. To overcome
this problem, the patch introduces a new type 'Cstring' that allows the
caller to express that the argument should be handled as null-terminated
string. As a nice side effect, with this type in place, the optional len
argument of the 'String' class could be removed. Instead of supplying a
pair of (char const *, size_t), the constructor accepts a 'Cstring'.
This, in turn, clears the way let the 'String' constructor use the new
output mechanism to assemble a string from multiple arguments (and
thereby getting rid of snprintf within Genode in the near future).

To enforce the explicit resolution of the char * ambiguity, the 'char *'
overload of the 'print' function is marked as deleted.

Issue #1987
2016-08-29 17:27:10 +02:00

82 lines
1.4 KiB
C++

/**
* \brief Hard-context for use within rump kernel
* \author Sebastian Sumpf
* \date 2014-02-05
*/
/*
* 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__HARD_CONTEXT_H_
#define _INCLUDE__HARD_CONTEXT_H_
extern "C" {
#include <sys/cdefs.h>
#include <sys/types.h>
#include <rump/rump.h>
}
#include <base/thread.h>
#include <base/log.h>
/*************
** Threads **
*************/
typedef void *(*func)(void *);
namespace Timer {
class Connection;
};
class Hard_context
{
private:
int _cookie;
lwp *_lwp = 0;
public:
Hard_context(int cookie)
: _cookie(cookie){ }
void set_lwp(lwp *l) { _lwp = l; }
lwp *get_lwp() { return _lwp; }
static Timer::Connection *timer();
};
class Hard_context_thread : public Hard_context,
public Genode::Thread_deprecated<sizeof(Genode::addr_t) * 2048>
{
private:
func _func;
void *_arg;
protected:
void entry()
{
_func(_arg);
Genode::log(__func__, " returned from func");
}
public:
Hard_context_thread(char const *name, func f, void *arg, int cookie, bool run = true)
: Hard_context(cookie), Thread_deprecated(name),
_func(f), _arg(arg) { if (run) start(); }
};
#endif /* _INCLUDE__HARD_CONTEXT_H_ */