2011-12-22 16:19:25 +01:00
|
|
|
/*
|
|
|
|
* \brief file descriptor allocator interface
|
|
|
|
* \author Christian Prochaska
|
|
|
|
* \date 2010-01-21
|
|
|
|
*
|
|
|
|
*/
|
|
|
|
|
|
|
|
/*
|
2017-02-20 13:23:52 +01:00
|
|
|
* Copyright (C) 2010-2017 Genode Labs GmbH
|
2011-12-22 16:19:25 +01:00
|
|
|
*
|
|
|
|
* This file is part of the Genode OS framework, which is distributed
|
2017-02-20 13:23:52 +01:00
|
|
|
* under the terms of the GNU Affero General Public License version 3.
|
2011-12-22 16:19:25 +01:00
|
|
|
*/
|
|
|
|
|
|
|
|
#ifndef _LIBC_PLUGIN__FD_ALLOC_H_
|
|
|
|
#define _LIBC_PLUGIN__FD_ALLOC_H_
|
|
|
|
|
|
|
|
#include <base/allocator_avl.h>
|
2013-11-13 13:36:18 +01:00
|
|
|
#include <base/lock.h>
|
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-07-13 19:07:09 +02:00
|
|
|
#include <base/log.h>
|
2012-10-08 14:44:31 +02:00
|
|
|
#include <os/path.h>
|
|
|
|
|
|
|
|
/* libc includes */
|
|
|
|
#include <stdlib.h>
|
|
|
|
#include <string.h>
|
2011-12-22 16:19:25 +01:00
|
|
|
|
|
|
|
#include <libc-plugin/plugin.h>
|
|
|
|
|
|
|
|
enum { MAX_NUM_FDS = 1024 };
|
|
|
|
|
|
|
|
namespace Libc {
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Plugin-specific file-descriptor context
|
|
|
|
*/
|
2016-04-04 21:13:18 +02:00
|
|
|
struct Plugin_context { virtual ~Plugin_context() { } };
|
2011-12-22 16:19:25 +01:00
|
|
|
|
2012-10-08 14:44:31 +02:00
|
|
|
enum { ANY_FD = -1 };
|
2011-12-22 16:19:25 +01:00
|
|
|
|
|
|
|
struct File_descriptor
|
|
|
|
{
|
2014-04-11 18:32:17 +02:00
|
|
|
int libc_fd = -1;
|
2014-04-12 00:03:40 +02:00
|
|
|
char const *fd_path = 0; /* for 'fchdir', 'fstat' */
|
2014-04-11 18:32:17 +02:00
|
|
|
Plugin *plugin = 0;
|
|
|
|
Plugin_context *context = 0;
|
|
|
|
unsigned flags = 0; /* for 'fcntl' */
|
|
|
|
unsigned status = 0; /* for 'fcntl' */
|
2013-11-13 13:36:18 +01:00
|
|
|
Genode::Lock lock;
|
2012-10-08 14:44:31 +02:00
|
|
|
|
|
|
|
void path(char const *newpath)
|
|
|
|
{
|
2017-02-16 19:02:19 +01:00
|
|
|
if (fd_path) { Genode::warning("may leak former FD path memory"); }
|
2012-10-08 14:44:31 +02:00
|
|
|
if (newpath) {
|
2016-09-15 14:40:37 +02:00
|
|
|
Genode::size_t const path_size = ::strlen(newpath) + 1;
|
2014-04-12 00:03:40 +02:00
|
|
|
char *buf = (char*)malloc(path_size);
|
|
|
|
if (!buf) {
|
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-07-13 19:07:09 +02:00
|
|
|
Genode::error("could not allocate path buffer for libc_fd ",
|
|
|
|
libc_fd, libc_fd == ANY_FD ? " (any)" : "");
|
2012-10-08 14:44:31 +02:00
|
|
|
return;
|
|
|
|
}
|
2014-04-12 00:03:40 +02:00
|
|
|
::memcpy(buf, newpath, path_size);
|
|
|
|
fd_path = buf;
|
2012-10-08 14:44:31 +02:00
|
|
|
} else
|
|
|
|
fd_path = 0;
|
|
|
|
}
|
2011-12-22 16:19:25 +01:00
|
|
|
};
|
|
|
|
|
|
|
|
|
|
|
|
class File_descriptor_allocator : Allocator_avl_tpl<File_descriptor>
|
|
|
|
{
|
|
|
|
public:
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Constructor
|
|
|
|
*/
|
2017-02-22 13:26:33 +01:00
|
|
|
File_descriptor_allocator(Genode::Allocator &md_alloc);
|
2011-12-22 16:19:25 +01:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Allocate file descriptor
|
|
|
|
*/
|
|
|
|
File_descriptor *alloc(Plugin *plugin, Plugin_context *context, int libc_fd = -1);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Release file descriptor
|
|
|
|
*/
|
|
|
|
void free(File_descriptor *fdo);
|
|
|
|
|
|
|
|
File_descriptor *find_by_libc_fd(int libc_fd);
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Return singleton instance of file-descriptor allocator
|
|
|
|
*/
|
|
|
|
extern File_descriptor_allocator *file_descriptor_allocator();
|
|
|
|
}
|
|
|
|
|
|
|
|
#endif /* _LIBC_PLUGIN__FD_ALLOC_H_ */
|