Implemented devfs_publish_file_device(); it should actually work, but I haven't tested it yet.

Also implemented the now needed devfs_read_link() function.


git-svn-id: file:///srv/svn/repos/haiku/trunk/current@9644 a95241bf-73f2-0310-859d-f6bbb57e9c96
This commit is contained in:
Axel Dörfler 2004-10-29 01:58:08 +00:00
parent 194f93689b
commit e876e8c516

View File

@ -14,6 +14,7 @@
#include <NodeMonitor.h> #include <NodeMonitor.h>
#include <kdevice_manager.h> #include <kdevice_manager.h>
#include <KPath.h>
#include <vfs.h> #include <vfs.h>
#include <debug.h> #include <debug.h>
#include <khash.h> #include <khash.h>
@ -57,7 +58,8 @@ struct devfs_stream {
IOScheduler *scheduler; IOScheduler *scheduler;
} dev; } dev;
struct stream_symlink { struct stream_symlink {
char *path; const char *path;
size_t length;
} symlink; } symlink;
} u; } u;
}; };
@ -453,16 +455,18 @@ get_node_for_path(const char *path, struct devfs_vnode **_node)
static status_t static status_t
publish_node(struct devfs *fs, const char *path, struct devfs_vnode **_node) publish_node(struct devfs *fs, const char *path, struct devfs_vnode **_node)
{ {
status_t status = B_OK; ASSERT_LOCKED_MUTEX(&fs->lock);
char temp[B_PATH_NAME_LENGTH + 1];
// copy the path over to a temp buffer so we can munge it // copy the path over to a temp buffer so we can munge it
strlcpy(temp, path, B_PATH_NAME_LENGTH); KPath tempPath(path);
char *temp = tempPath.LockBuffer();
// create the path leading to the device // create the path leading to the device
// parse the path passed in, stripping out '/' // parse the path passed in, stripping out '/'
struct devfs_vnode *dir = fs->root_vnode; struct devfs_vnode *dir = fs->root_vnode;
struct devfs_vnode *vnode = NULL; struct devfs_vnode *vnode = NULL;
status_t status = B_OK;
int32 i = 0, last = 0; int32 i = 0, last = 0;
bool atLeaf = false; bool atLeaf = false;
@ -921,6 +925,22 @@ devfs_fsync(fs_volume _fs, fs_vnode _v)
} }
static status_t
devfs_read_link(fs_volume _fs, fs_vnode _link, char *buffer, size_t bufferSize)
{
struct devfs_vnode *link = (struct devfs_vnode *)_link;
if (!S_ISLNK(link->stream.type))
return B_BAD_VALUE;
if (bufferSize < link->stream.u.symlink.length)
return B_NAME_TOO_LONG;
memcpy(buffer, link->stream.u.symlink.path, link->stream.u.symlink.length + 1);
return link->stream.u.symlink.length;
}
static status_t static status_t
devfs_read(fs_volume _fs, fs_vnode _vnode, fs_cookie _cookie, off_t pos, devfs_read(fs_volume _fs, fs_vnode _vnode, fs_cookie _cookie, off_t pos,
void *buffer, size_t *_length) void *buffer, size_t *_length)
@ -1380,7 +1400,7 @@ file_system_info gDeviceFileSystem = {
&devfs_set_flags, &devfs_set_flags,
&devfs_fsync, &devfs_fsync,
NULL, // read_link &devfs_read_link,
NULL, // write_link NULL, // write_link
NULL, // symlink NULL, // symlink
NULL, // link NULL, // link
@ -1589,7 +1609,27 @@ devfs_unpublish_file_device(const char *path)
extern "C" status_t extern "C" status_t
devfs_publish_file_device(const char *path, const char *filePath) devfs_publish_file_device(const char *path, const char *filePath)
{ {
return B_ERROR; struct devfs_vnode *node;
status_t status;
filePath = strdup(filePath);
if (filePath == NULL)
return B_NO_MEMORY;
mutex_lock(&sDeviceFileSystem->lock);
status = publish_node(sDeviceFileSystem, path, &node);
if (status != B_OK)
goto out;
// all went fine, let's initialize the node
node->stream.type = S_IFLNK | 0644;
node->stream.u.symlink.path = filePath;
node->stream.u.symlink.length = strlen(filePath);
out:
mutex_unlock(&sDeviceFileSystem->lock);
return status;
} }