source: mainline/uspace/srv/fs/mfs/mfs.h@ 09d6695

lfn serial ticket/834-toolchain-update topic/msim-upgrade topic/simplify-dev-export
Last change on this file since 09d6695 was b2c96093, checked in by Maurizio Lombardi <m.lombardi85@…>, 12 years ago

mfs: add functions to get the number of free entries in the bitmaps.

  • Property mode set to 100644
File size: 5.6 KB
RevLine 
[1ffbbc1]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 * @{
[8a49fed]31 */
[1ffbbc1]32
33#ifndef _MFS_H_
34#define _MFS_H_
35
[86d0b4b3]36#include <minix.h>
[668f1949]37#include <macros.h>
[f73b291]38#include <block.h>
[3b08178]39#include <libfs.h>
[953a823]40#include <adt/list.h>
[2874547]41#include <malloc.h>
42#include <mem.h>
43#include <stdio.h>
44#include <errno.h>
45#include <assert.h>
[1ffbbc1]46#include "../../vfs/vfs.h"
47
[ac28650]48#define NAME "mfs"
49
[50a01a9]50/* #define DEBUG_MODE */
[92dd5c8]51
[bd64680]52#define min(a, b) ((a) < (b) ? (a) : (b))
53
[92dd5c8]54#ifdef DEBUG_MODE
55#define mfsdebug(...) printf(__VA_ARGS__)
56#else
57#define mfsdebug(...)
58#endif
59
[b2c96093]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
[152610a8]70typedef uint32_t bitchunk_t;
71
[fde8a276]72typedef enum {
73 BMAP_ZONE,
74 BMAP_INODE
75} bmap_id_t;
76
[82650385]77typedef enum {
78 MFS_VERSION_V1 = 1,
79 MFS_VERSION_V2,
80 MFS_VERSION_V3
81} mfs_version_t;
82
[50a01a9]83/* Generic MinixFS superblock */
[953a823]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;
[7a96476]95
[50a01a9]96 /* The following fields do not exist on disk but only in memory */
[7a96476]97 unsigned long itable_size;
98 mfs_version_t fs_version;
99 int ino_per_block;
[07dcec5]100 size_t dirsize;
[10eb754]101 int itable_off;
[bd64680]102 unsigned max_name_len;
[953a823]103 bool long_names;
104 bool native;
[ef76d72]105 unsigned isearch;
106 unsigned zsearch;
[953a823]107};
108
[50a01a9]109/* Generic MinixFS inode */
[155f792]110struct mfs_ino_info {
[8a49fed]111 uint16_t i_mode;
112 uint16_t i_nlinks;
113 int16_t i_uid;
114 uint16_t i_gid;
115 size_t i_size;
116 int32_t i_atime;
117 int32_t i_mtime;
118 int32_t i_ctime;
[50a01a9]119 /* Block numbers for direct zones */
[8a49fed]120 uint32_t i_dzone[V2_NR_DIRECT_ZONES];
[50a01a9]121 /* Block numbers for indirect zones */
[8a49fed]122 uint32_t i_izone[V2_NR_INDIRECT_ZONES];
[54caa41b]123
[50a01a9]124 /* The following fields do not exist on disk but only in memory */
[54caa41b]125 bool dirty;
[41202a9]126 fs_index_t index;
[54caa41b]127};
128
[50a01a9]129/* Generic MFS directory entry */
[54caa41b]130struct mfs_dentry_info {
131 uint32_t d_inum;
[07dcec5]132 char d_name[MFS3_MAX_NAME_LEN + 1];
[54caa41b]133
[50a01a9]134 /* The following fields do not exist on disk but only in memory */
[c4eeb2f]135
[50a01a9]136 /* Index of the dentry in the list */
[87d4422]137 unsigned index;
[50a01a9]138 /* Pointer to the node at witch the dentry belongs */
[87d4422]139 struct mfs_node *node;
[155f792]140};
141
[953a823]142struct mfs_instance {
[03bc76a]143 service_id_t service_id;
[953a823]144 struct mfs_sb_info *sbi;
[ee257b2]145 unsigned open_nodes_cnt;
[953a823]146};
147
[50a01a9]148/* MinixFS node in core */
[e54ba607]149struct mfs_node {
[155f792]150 struct mfs_ino_info *ino_i;
[e54ba607]151 struct mfs_instance *instance;
[ee257b2]152 unsigned refcnt;
153 fs_node_t *fsnode;
[062d900]154 ht_link_t link;
[e54ba607]155};
156
[50a01a9]157/* mfs_ops.c */
[03bc76a]158extern vfs_out_ops_t mfs_ops;
159extern libfs_ops_t mfs_libfs_ops;
[51db5aeb]160
[ee257b2]161extern int
162mfs_global_init(void);
163
[50a01a9]164/* mfs_inode.c */
[8a49fed]165extern int
[3a5ee6c]166mfs_get_inode(struct mfs_instance *inst, struct mfs_ino_info **ino_i,
[802f0b7]167 fs_index_t index);
[f213ae7]168
[10eb754]169extern int
[5f509cc]170mfs_put_inode(struct mfs_node *mnode);
[10eb754]171
[8a49fed]172extern int
[3a5ee6c]173mfs_inode_shrink(struct mfs_node *mnode, size_t size_shrink);
[8a49fed]174
[50a01a9]175/* mfs_rw.c */
[2bbbfd3]176extern int
[3a5ee6c]177mfs_read_map(uint32_t *b, const struct mfs_node *mnode, const uint32_t pos);
[2bbbfd3]178
179extern int
[3a5ee6c]180mfs_write_map(struct mfs_node *mnode, uint32_t pos, uint32_t new_zone,
[802f0b7]181 uint32_t *old_zone);
[2bbbfd3]182
[1878386]183extern int
[3a5ee6c]184mfs_prune_ind_zones(struct mfs_node *mnode, size_t new_size);
[1878386]185
[50a01a9]186/* mfs_dentry.c */
[488f7ed]187extern int
[3a5ee6c]188mfs_read_dentry(struct mfs_node *mnode,
[802f0b7]189 struct mfs_dentry_info *d_info, unsigned index);
[54caa41b]190
[87d4422]191extern int
[3a5ee6c]192mfs_write_dentry(struct mfs_dentry_info *d_info);
[87d4422]193
[c955be91]194extern int
[3a5ee6c]195mfs_remove_dentry(struct mfs_node *mnode, const char *d_name);
[c955be91]196
[8a49fed]197extern int
[3a5ee6c]198mfs_insert_dentry(struct mfs_node *mnode, const char *d_name, fs_index_t d_inum);
[07dcec5]199
[50a01a9]200/* mfs_balloc.c */
[ba5beaf]201extern int
[70ac0af]202mfs_alloc_inode(struct mfs_instance *inst, uint32_t *inum);
[2cf95e8]203
204extern int
[70ac0af]205mfs_free_inode(struct mfs_instance *inst, uint32_t inum);
206
207extern int
208mfs_alloc_zone(struct mfs_instance *inst, uint32_t *zone);
209
210extern int
211mfs_free_zone(struct mfs_instance *inst, uint32_t zone);
[ba5beaf]212
[b2c96093]213extern int
214mfs_count_free_zones(struct mfs_instance *inst, uint32_t *zones);
215
216extern int
217mfs_count_free_inodes(struct mfs_instance *inst, uint32_t *inodes);
218
219
[50a01a9]220/* mfs_utils.c */
[88be951e]221extern uint16_t
222conv16(bool native, uint16_t n);
223
224extern uint32_t
225conv32(bool native, uint32_t n);
226
227extern uint64_t
228conv64(bool native, uint64_t n);
229
[1ffbbc1]230#endif
231
232/**
233 * @}
[8a49fed]234 */
[1ffbbc1]235
Note: See TracBrowser for help on using the repository browser.