source: mainline/uspace/srv/fs/mfs/mfs.h@ 1d6dd2a

lfn serial ticket/834-toolchain-update topic/msim-upgrade topic/simplify-dev-export
Last change on this file since 1d6dd2a was b7fd2a0, checked in by Jiří Zárevúcky <zarevucky.jiri@…>, 8 years ago

Use errno_t in all uspace and kernel code.

Change type of every variable, parameter and return value that holds an
<errno.h> constant to either errno_t (the usual case), or sys_errno_t
(some places in kernel). This is for the purpose of self-documentation,
as well as for type-checking with a bit of type definition hackery.

Although this is a massive commit, it is a simple text replacement, and thus
is very easy to verify. Simply do the following:

`
git checkout <this commit's hash>
git reset HEAD
git add .
tools/srepl '\berrno_t\b' int
git add .
tools/srepl '\bsys_errno_t\b' sysarg_t
git reset
git diff
`

While this doesn't ensure that the replacements are correct, it does ensure
that the commit doesn't do anything except those replacements. Since errno_t
is typedef'd to int in the usual case (and sys_errno_t to sysarg_t), even if
incorrect, this commit cannot change behavior.

  • Property mode set to 100644
File size: 5.9 KB
Line 
1/*
2 * Copyright (c) 2011 Maurizio Lombardi
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 _MFS_H_
34#define _MFS_H_
35
36#include <minix.h>
37#include <macros.h>
38#include <block.h>
39#include <libfs.h>
40#include <adt/list.h>
41#include <mem.h>
42#include <stdio.h>
43#include <stdlib.h>
44#include <errno.h>
45#include <assert.h>
46#include <stdbool.h>
47#include <macros.h>
48#include "../../vfs/vfs.h"
49
50#define NAME "mfs"
51
52/* #define DEBUG_MODE */
53
54#ifdef DEBUG_MODE
55#define mfsdebug(...) printf(__VA_ARGS__)
56#else
57#define mfsdebug(...)
58#endif
59
60#define MFS_BMAP_START_BLOCK(sbi, bid) \
61 ((bid) == BMAP_ZONE ? 2 + (sbi)->ibmap_blocks : 2)
62
63#define MFS_BMAP_SIZE_BITS(sbi, bid) \
64 ((bid) == BMAP_ZONE ? (sbi)->nzones - (sbi)->firstdatazone - 1 : \
65 (sbi)->ninodes - 1)
66
67#define MFS_BMAP_SIZE_BLOCKS(sbi, bid) \
68 ((bid) == BMAP_ZONE ? (sbi)->zbmap_blocks : (sbi)->ibmap_blocks)
69
70typedef uint32_t bitchunk_t;
71
72typedef enum {
73 BMAP_ZONE,
74 BMAP_INODE
75} bmap_id_t;
76
77typedef enum {
78 MFS_VERSION_V1 = 1,
79 MFS_VERSION_V2,
80 MFS_VERSION_V3
81} mfs_version_t;
82
83/* Generic MinixFS superblock */
84struct mfs_sb_info {
85 uint32_t ninodes;
86 uint32_t nzones;
87 unsigned long ibmap_blocks;
88 unsigned long zbmap_blocks;
89 unsigned long firstdatazone;
90 int log2_zone_size;
91 int block_size;
92 uint32_t max_file_size;
93 uint16_t magic;
94 uint16_t state;
95
96 /* The following fields do not exist on disk but only in memory */
97 unsigned long itable_size;
98 mfs_version_t fs_version;
99 int ino_per_block;
100 size_t dirsize;
101 int itable_off;
102 unsigned max_name_len;
103 bool long_names;
104 bool native;
105 unsigned isearch;
106 unsigned zsearch;
107
108 /* Indicates wether if the cached number of free zones
109 * is to be considered valid or not.
110 */
111 bool nfree_zones_valid;
112 /* Cached number of free zones, used to avoid to scan
113 * the whole bitmap every time the mfs_free_block_count()
114 * is invoked.
115 */
116 unsigned nfree_zones;
117};
118
119/* Generic MinixFS inode */
120struct mfs_ino_info {
121 uint16_t i_mode;
122 uint16_t i_nlinks;
123 int16_t i_uid;
124 uint16_t i_gid;
125 size_t i_size;
126 int32_t i_atime;
127 int32_t i_mtime;
128 int32_t i_ctime;
129 /* Block numbers for direct zones */
130 uint32_t i_dzone[V2_NR_DIRECT_ZONES];
131 /* Block numbers for indirect zones */
132 uint32_t i_izone[V2_NR_INDIRECT_ZONES];
133
134 /* The following fields do not exist on disk but only in memory */
135 bool dirty;
136 fs_index_t index;
137};
138
139/* Generic MFS directory entry */
140struct mfs_dentry_info {
141 uint32_t d_inum;
142 char d_name[MFS3_MAX_NAME_LEN + 1];
143
144 /* The following fields do not exist on disk but only in memory */
145
146 /* Index of the dentry in the list */
147 unsigned index;
148 /* Pointer to the node at witch the dentry belongs */
149 struct mfs_node *node;
150};
151
152struct mfs_instance {
153 service_id_t service_id;
154 struct mfs_sb_info *sbi;
155 unsigned open_nodes_cnt;
156};
157
158/* MinixFS node in core */
159struct mfs_node {
160 struct mfs_ino_info *ino_i;
161 struct mfs_instance *instance;
162 unsigned refcnt;
163 fs_node_t *fsnode;
164 ht_link_t link;
165};
166
167/* mfs_ops.c */
168extern vfs_out_ops_t mfs_ops;
169extern libfs_ops_t mfs_libfs_ops;
170
171extern errno_t
172mfs_global_init(void);
173
174/* mfs_inode.c */
175extern errno_t
176mfs_get_inode(struct mfs_instance *inst, struct mfs_ino_info **ino_i,
177 fs_index_t index);
178
179extern errno_t
180mfs_put_inode(struct mfs_node *mnode);
181
182extern errno_t
183mfs_inode_shrink(struct mfs_node *mnode, size_t size_shrink);
184
185/* mfs_rw.c */
186extern errno_t
187mfs_read_map(uint32_t *b, const struct mfs_node *mnode, const uint32_t pos);
188
189extern errno_t
190mfs_write_map(struct mfs_node *mnode, uint32_t pos, uint32_t new_zone,
191 uint32_t *old_zone);
192
193extern errno_t
194mfs_prune_ind_zones(struct mfs_node *mnode, size_t new_size);
195
196/* mfs_dentry.c */
197extern errno_t
198mfs_read_dentry(struct mfs_node *mnode,
199 struct mfs_dentry_info *d_info, unsigned index);
200
201extern errno_t
202mfs_write_dentry(struct mfs_dentry_info *d_info);
203
204extern errno_t
205mfs_remove_dentry(struct mfs_node *mnode, const char *d_name);
206
207extern errno_t
208mfs_insert_dentry(struct mfs_node *mnode, const char *d_name, fs_index_t d_inum);
209
210/* mfs_balloc.c */
211extern errno_t
212mfs_alloc_inode(struct mfs_instance *inst, uint32_t *inum);
213
214extern errno_t
215mfs_free_inode(struct mfs_instance *inst, uint32_t inum);
216
217extern errno_t
218mfs_alloc_zone(struct mfs_instance *inst, uint32_t *zone);
219
220extern errno_t
221mfs_free_zone(struct mfs_instance *inst, uint32_t zone);
222
223extern errno_t
224mfs_count_free_zones(struct mfs_instance *inst, uint32_t *zones);
225
226extern errno_t
227mfs_count_free_inodes(struct mfs_instance *inst, uint32_t *inodes);
228
229
230/* mfs_utils.c */
231extern uint16_t
232conv16(bool native, uint16_t n);
233
234extern uint32_t
235conv32(bool native, uint32_t n);
236
237extern uint64_t
238conv64(bool native, uint64_t n);
239
240#endif
241
242/**
243 * @}
244 */
245
Note: See TracBrowser for help on using the repository browser.