mirror of
https://github.com/genodelabs/genode.git
synced 2025-06-17 22:58:26 +00:00
Generalize handling of PD-session arguments
On Linux, we want to attach additional attributes to processes, i.e., the chroot location, the designated UID, and GID. Instead of polluting the generic code with such Linux-specific platform details, I introduced the new 'Native_pd_args' type, which can be customized for each platform. The platform-dependent policy of init is factored out in the new 'pd_args' library. The new 'base-linux/run/lx_pd_args.run' script can be used to validate the propagation of those attributes into core. Note that this patch does not add the interpretation of the new UID and PID attributes by core. This will be subject of a follow-up patch. Related to #510.
This commit is contained in:
@ -14,6 +14,7 @@
|
||||
#ifndef _INCLUDE__BASE__NATIVE_TYPES_H_
|
||||
#define _INCLUDE__BASE__NATIVE_TYPES_H_
|
||||
|
||||
#include <util/string.h>
|
||||
#include <base/native_capability.h>
|
||||
#include <base/stdint.h>
|
||||
|
||||
@ -149,6 +150,35 @@ namespace Genode {
|
||||
*/
|
||||
static addr_t context_virtual_size() { return 0x00100000UL; }
|
||||
};
|
||||
|
||||
class Native_pd_args
|
||||
{
|
||||
public:
|
||||
|
||||
enum { ROOT_PATH_MAX_LEN = 256 };
|
||||
|
||||
private:
|
||||
|
||||
char _root[ROOT_PATH_MAX_LEN];
|
||||
|
||||
unsigned _uid;
|
||||
unsigned _gid;
|
||||
|
||||
public:
|
||||
|
||||
Native_pd_args() : _uid(0), _gid(0) { _root[0] = 0; }
|
||||
|
||||
Native_pd_args(char const *root, unsigned uid, unsigned gid)
|
||||
:
|
||||
_uid(uid), _gid(gid)
|
||||
{
|
||||
Genode::strncpy(_root, root, sizeof(_root));
|
||||
}
|
||||
|
||||
char const *root() const { return _root; }
|
||||
unsigned uid() const { return _uid; }
|
||||
unsigned gid() const { return _gid; }
|
||||
};
|
||||
}
|
||||
|
||||
#endif /* _INCLUDE__BASE__NATIVE_TYPES_H_ */
|
||||
|
Reference in New Issue
Block a user