source: mainline/uspace/srv/vfs/vfs.h@ 5d4e90f0

lfn serial ticket/834-toolchain-update topic/msim-upgrade topic/simplify-dev-export
Last change on this file since 5d4e90f0 was 8c20b26, checked in by Jakub Jermar <jakub@…>, 18 years ago

VFS work.
Introduce basic types representing a file system node and an open file.

  • Property mode set to 100644
File size: 3.8 KB
Line 
1/*
2 * Copyright (c) 2007 Jakub Jermar
3 * All rights reserved.
4 *
5 * Redistribution and use in source and binary forms, with or without
6 * modification, are permitted provided that the following conditions
7 * are met:
8 *
9 * - Redistributions of source code must retain the above copyright
10 * notice, this list of conditions and the following disclaimer.
11 * - Redistributions in binary form must reproduce the above copyright
12 * notice, this list of conditions and the following disclaimer in the
13 * documentation and/or other materials provided with the distribution.
14 * - The name of the author may not be used to endorse or promote products
15 * derived from this software without specific prior written permission.
16 *
17 * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR
18 * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
19 * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
20 * IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT,
21 * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT
22 * NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
23 * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
24 * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
25 * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF
26 * THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
27 */
28
29/** @addtogroup fs
30 * @{
31 */
32
33#ifndef VFS_VFS_H_
34#define VFS_VFS_H_
35
36#include <ipc/ipc.h>
37#include <libadt/list.h>
38#include <atomic.h>
39#include <types.h>
40
41#define dprintf(...) printf(__VA_ARGS__)
42
43#define VFS_FIRST FIRST_USER_METHOD
44
45#define IPC_METHOD_TO_VFS_OP(m) ((m) - VFS_FIRST)
46
47typedef int64_t off_t;
48
49typedef enum {
50 VFS_REGISTER = VFS_FIRST,
51 VFS_MOUNT,
52 VFS_UNMOUNT,
53 VFS_LOOKUP,
54 VFS_OPEN,
55 VFS_CREATE,
56 VFS_CLOSE,
57 VFS_READ,
58 VFS_WRITE,
59 VFS_SEEK,
60 VFS_LAST, /* keep this the last member of the enum */
61} vfs_request_t;
62
63
64/**
65 * An instance of this structure is associated with a particular FS operation.
66 * It tells VFS if the FS supports the operation or maybe if a default one
67 * should be used.
68 */
69typedef enum {
70 VFS_OP_NULL = 0,
71 VFS_OP_DEFAULT,
72 VFS_OP_DEFINED
73} vfs_op_t;
74
75#define FS_NAME_MAXLEN 20
76
77/**
78 * A structure like this is passed to VFS by each individual FS upon its
79 * registration. It assosiates a human-readable identifier with each
80 * registered FS. More importantly, through this structure, the FS announces
81 * what operations it supports.
82 */
83typedef struct {
84 /** Unique identifier of the fs. */
85 char name[FS_NAME_MAXLEN];
86
87 /** Operations. */
88 vfs_op_t ops[VFS_LAST - VFS_FIRST];
89} vfs_info_t;
90
91/**
92 * A structure like this will be allocated for each registered file system.
93 */
94typedef struct {
95 link_t fs_link;
96 vfs_info_t vfs_info;
97 ipcarg_t phone;
98} fs_info_t;
99
100/**
101 * Instances of this type represent a file system node (e.g. directory, file).
102 * They are abstracted away from any file system implementation and contain just
103 * enough bits to uniquely identify the object in its file system instance.
104 *
105 * @note fs_handle, dev_handle and index are meant to be returned in one
106 * IPC reply.
107 */
108typedef struct {
109 int fs_handle; /**< Global file system ID. */
110 int dev_handle; /**< Global mount device devno. */
111 uint64_t index; /**< Index of the node on its file system. */
112} vfs_node_t;
113
114/**
115 * Instances of this type represent an open file. If the file is opened by more
116 * than one task, there will be a separate structure allocated for each task.
117 */
118typedef struct {
119 vfs_node_t *node;
120
121 /** Number of file handles referencing this file. */
122 atomic_t refcnt;
123
124 /** Current position in the file. */
125 off_t pos;
126} vfs_file_t;
127
128extern link_t fs_head;
129
130extern void vfs_register(ipc_callid_t rid, ipc_call_t *request);
131
132#endif
133
134/**
135 * @}
136 */
Note: See TracBrowser for help on using the repository browser.