2018-09-26 15:53:18 +02:00
|
|
|
/*
|
2020-12-18 14:08:06 +01:00
|
|
|
* \brief Client-side VM session vCPU exception handler
|
2018-09-26 15:53:18 +02:00
|
|
|
* \author Alexander Boettcher
|
2020-12-18 14:08:06 +01:00
|
|
|
* \author Christian Helmuth
|
2018-09-26 15:53:18 +02:00
|
|
|
* \date 2018-09-29
|
|
|
|
*/
|
|
|
|
|
|
|
|
/*
|
2020-12-18 14:08:06 +01:00
|
|
|
* Copyright (C) 2018-2021 Genode Labs GmbH
|
2018-09-26 15:53:18 +02:00
|
|
|
*
|
|
|
|
* This file is part of the Genode OS framework, which is distributed
|
|
|
|
* under the terms of the GNU Affero General Public License version 3.
|
|
|
|
*/
|
|
|
|
|
|
|
|
#ifndef _INCLUDE__VM_SESSION__HANDLER_H_
|
|
|
|
#define _INCLUDE__VM_SESSION__HANDLER_H_
|
|
|
|
|
|
|
|
#include <base/signal.h>
|
|
|
|
|
|
|
|
namespace Genode {
|
2020-12-18 14:08:06 +01:00
|
|
|
class Vcpu_state;
|
|
|
|
class Vcpu_handler_base;
|
|
|
|
template <typename, typename> class Vcpu_handler;
|
2018-09-26 15:53:18 +02:00
|
|
|
}
|
|
|
|
|
2020-12-18 14:08:06 +01:00
|
|
|
class Genode::Vcpu_handler_base : public Signal_dispatcher_base
|
2018-09-26 15:53:18 +02:00
|
|
|
{
|
|
|
|
protected:
|
|
|
|
|
|
|
|
Rpc_entrypoint &_rpc_ep;
|
2020-12-18 14:08:06 +01:00
|
|
|
Signal_context_capability _signal_cap { };
|
|
|
|
Genode::Semaphore _ready_semaphore { 0 };
|
2018-09-26 15:53:18 +02:00
|
|
|
|
|
|
|
public:
|
|
|
|
|
2020-12-18 14:08:06 +01:00
|
|
|
Vcpu_handler_base(Rpc_entrypoint &rpc)
|
2018-09-26 15:53:18 +02:00
|
|
|
: _rpc_ep(rpc) { }
|
2020-12-18 14:08:06 +01:00
|
|
|
|
|
|
|
Rpc_entrypoint & rpc_ep() { return _rpc_ep; }
|
|
|
|
Signal_context_capability signal_cap() { return _signal_cap; }
|
|
|
|
Genode::Semaphore & ready_semaphore() { return _ready_semaphore; }
|
2018-09-26 15:53:18 +02:00
|
|
|
};
|
|
|
|
|
|
|
|
template <typename T, typename EP = Genode::Entrypoint>
|
2020-12-18 14:08:06 +01:00
|
|
|
class Genode::Vcpu_handler : public Vcpu_handler_base
|
2018-09-26 15:53:18 +02:00
|
|
|
{
|
|
|
|
private:
|
|
|
|
|
|
|
|
EP &_ep;
|
|
|
|
T &_obj;
|
|
|
|
void (T::*_member) ();
|
|
|
|
|
|
|
|
/*
|
|
|
|
* Noncopyable
|
|
|
|
*/
|
2020-12-18 14:08:06 +01:00
|
|
|
Vcpu_handler(Vcpu_handler const &);
|
|
|
|
Vcpu_handler &operator = (Vcpu_handler const &);
|
2018-09-26 15:53:18 +02:00
|
|
|
|
|
|
|
public:
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Constructor
|
|
|
|
*
|
|
|
|
* \param obj,member object and method to call when
|
|
|
|
* the vm exception occurs
|
|
|
|
*/
|
2020-12-18 14:08:06 +01:00
|
|
|
Vcpu_handler(EP &ep, T &obj, void (T::*member)())
|
2018-09-26 15:53:18 +02:00
|
|
|
:
|
2020-12-18 14:08:06 +01:00
|
|
|
Vcpu_handler_base(ep.rpc_ep()),
|
2018-09-26 15:53:18 +02:00
|
|
|
_ep(ep),
|
|
|
|
_obj(obj),
|
2020-12-18 14:08:06 +01:00
|
|
|
_member(member)
|
2018-09-26 15:53:18 +02:00
|
|
|
{
|
2020-12-18 14:08:06 +01:00
|
|
|
_signal_cap = _ep.manage(*this);
|
2018-09-26 15:53:18 +02:00
|
|
|
}
|
|
|
|
|
2020-12-18 14:08:06 +01:00
|
|
|
~Vcpu_handler() { _ep.dissolve(*this); }
|
2018-09-26 15:53:18 +02:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Interface of Signal_dispatcher_base
|
|
|
|
*/
|
|
|
|
void dispatch(unsigned) override
|
|
|
|
{
|
|
|
|
(_obj.*_member)();
|
2020-12-18 14:08:06 +01:00
|
|
|
_ready_semaphore.up();
|
2018-09-26 15:53:18 +02:00
|
|
|
}
|
|
|
|
|
2020-12-18 14:08:06 +01:00
|
|
|
operator Capability<Signal_context>() const { return _signal_cap; }
|
2018-09-26 15:53:18 +02:00
|
|
|
};
|
|
|
|
|
|
|
|
#endif /* _INCLUDE__VM_SESSION__HANDLER_H_ */
|