2011-12-22 16:19:25 +01:00
|
|
|
/*
|
|
|
|
* \brief Linux-specific layout of IPC message buffer
|
|
|
|
* \author Norman Feske
|
|
|
|
* \date 2006-06-14
|
|
|
|
*/
|
|
|
|
|
|
|
|
/*
|
2013-01-10 21:44:47 +01:00
|
|
|
* Copyright (C) 2006-2013 Genode Labs GmbH
|
2011-12-22 16:19:25 +01:00
|
|
|
*
|
|
|
|
* 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__IPC_MSGBUF_H_
|
|
|
|
#define _INCLUDE__BASE__IPC_MSGBUF_H_
|
|
|
|
|
|
|
|
namespace Genode {
|
|
|
|
|
|
|
|
/**
|
|
|
|
* IPC message buffer layout
|
|
|
|
*/
|
|
|
|
class Msgbuf_base
|
|
|
|
{
|
2012-07-26 20:29:45 +02:00
|
|
|
public:
|
|
|
|
|
|
|
|
enum { MAX_CAPS_PER_MSG = 8 };
|
|
|
|
|
2011-12-22 16:19:25 +01:00
|
|
|
protected:
|
|
|
|
|
2012-07-26 20:29:45 +02:00
|
|
|
/*
|
|
|
|
* Capabilities (file descriptors) to be transferred
|
|
|
|
*/
|
|
|
|
int _caps[MAX_CAPS_PER_MSG];
|
|
|
|
Genode::size_t _used_caps;
|
|
|
|
Genode::size_t _read_cap_index;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Maximum size of plain-data message payload
|
|
|
|
*/
|
2011-12-22 16:19:25 +01:00
|
|
|
Genode::size_t _size;
|
2012-07-26 20:29:45 +02:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Actual size of plain-data message payload
|
|
|
|
*/
|
|
|
|
Genode::size_t _used_size;
|
|
|
|
|
|
|
|
char _msg_start[]; /* symbol marks start of message buffer data */
|
2011-12-22 16:19:25 +01:00
|
|
|
|
|
|
|
/*
|
|
|
|
* No member variables are allowed beyond this point!
|
|
|
|
*/
|
|
|
|
|
|
|
|
public:
|
|
|
|
|
|
|
|
char buf[];
|
|
|
|
|
2012-07-26 20:29:45 +02:00
|
|
|
Msgbuf_base() { reset_caps(); }
|
|
|
|
|
2011-12-22 16:19:25 +01:00
|
|
|
/**
|
|
|
|
* Return size of message buffer
|
|
|
|
*/
|
|
|
|
inline Genode::size_t size() const { return _size; };
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Return address of message buffer
|
|
|
|
*/
|
|
|
|
inline void *addr() { return &_msg_start[0]; };
|
2012-07-26 20:29:45 +02:00
|
|
|
|
|
|
|
void reset_caps() { _used_caps = 0; _read_cap_index = 0; }
|
|
|
|
|
|
|
|
bool append_cap(int cap)
|
|
|
|
{
|
|
|
|
if (_used_caps == MAX_CAPS_PER_MSG)
|
|
|
|
return false;
|
|
|
|
|
|
|
|
_caps[_used_caps++] = cap;
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
|
|
|
|
int read_cap()
|
|
|
|
{
|
|
|
|
if (_read_cap_index == _used_caps)
|
|
|
|
return -1;
|
|
|
|
|
|
|
|
return _caps[_read_cap_index++];
|
|
|
|
}
|
|
|
|
|
|
|
|
size_t used_caps() const { return _used_caps; }
|
|
|
|
|
|
|
|
int cap(unsigned index) const
|
|
|
|
{
|
|
|
|
return index < _used_caps ? _caps[index] : -1;
|
|
|
|
}
|
2011-12-22 16:19:25 +01:00
|
|
|
};
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Pump up IPC message buffer to specified buffer size
|
|
|
|
*/
|
|
|
|
template <unsigned BUF_SIZE>
|
|
|
|
class Msgbuf : public Msgbuf_base
|
|
|
|
{
|
|
|
|
public:
|
|
|
|
|
|
|
|
char buf[BUF_SIZE];
|
|
|
|
|
|
|
|
Msgbuf() { _size = BUF_SIZE; }
|
|
|
|
};
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
#endif /* _INCLUDE__BASE__IPC_MSGBUF_H_ */
|