2 * Copyright (c) 2007 The DragonFly Project. All rights reserved.
4 * This code is derived from software contributed to The DragonFly Project
5 * by Matthew Dillon <dillon@backplane.com>
7 * Redistribution and use in source and binary forms, with or without
8 * modification, are permitted provided that the following conditions
11 * 1. Redistributions of source code must retain the above copyright
12 * notice, this list of conditions and the following disclaimer.
13 * 2. Redistributions in binary form must reproduce the above copyright
14 * notice, this list of conditions and the following disclaimer in
15 * the documentation and/or other materials provided with the
17 * 3. Neither the name of The DragonFly Project nor the names of its
18 * contributors may be used to endorse or promote products derived
19 * from this software without specific, prior written permission.
21 * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
22 * ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
23 * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS
24 * FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE
25 * COPYRIGHT HOLDERS OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT,
26 * INCIDENTAL, SPECIAL, EXEMPLARY OR CONSEQUENTIAL DAMAGES (INCLUDING,
27 * BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
28 * LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED
29 * AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,
30 * OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT
31 * OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
35 #ifndef HAMMER_UTIL_H_
36 #define HAMMER_UTIL_H_
38 #include <sys/types.h>
41 #include <sys/queue.h>
42 #include <sys/mount.h>
62 #include <vfs/hammer/hammer_disk.h>
63 #include <vfs/hammer/hammer_ioctl.h>
64 #include <vfs/hammer/hammer_crc.h>
66 #define HAMMER_BUFLISTS 64
67 #define HAMMER_BUFLISTMASK (HAMMER_BUFLISTS - 1)
70 * These structures are used by hammer(8) and newfs_hammer(8)
71 * to track the filesystem buffers.
73 * vol_free_off and vol_free_end are zone-2 offsets.
74 * These two are initialized only when newly creating a filesystem.
76 typedef struct volume_info
{
77 TAILQ_ENTRY(volume_info
) entry
;
86 hammer_off_t vol_free_off
;
87 hammer_off_t vol_free_end
;
89 hammer_volume_ondisk_t ondisk
;
91 TAILQ_HEAD(, buffer_info
) buffer_lists
[HAMMER_BUFLISTS
];
94 typedef struct cache_info
{
95 TAILQ_ENTRY(cache_info
) entry
;
96 int refs
; /* structural references */
97 int modified
; /* ondisk modified flag */
98 int delete; /* delete flag - delete on last ref */
101 typedef struct buffer_info
{
102 struct cache_info cache
; /* must be at offset 0 */
103 TAILQ_ENTRY(buffer_info
) entry
;
104 hammer_off_t zone2_offset
; /* zone-2 offset */
105 int64_t raw_offset
; /* physical offset */
106 volume_info_t volume
;
111 * Data structure for zone statistics.
113 typedef struct zone_stat
{
114 int64_t blocks
; /* number of big-blocks */
115 int64_t items
; /* number of items */
116 int64_t used
; /* bytes used */
119 extern hammer_uuid_t Hammer_FSType
;
120 extern hammer_uuid_t Hammer_FSId
;
121 extern int UseReadBehind
;
122 extern int UseReadAhead
;
124 extern uint32_t HammerVersion
;
125 extern const char *zone_labels
[];
127 volume_info_t
init_volume(const char *filename
, int oflags
, int32_t vol_no
);
128 volume_info_t
load_volume(const char *filename
, int oflags
, int verify_volume
);
129 int is_regfile(const volume_info_t volume
);
130 void assert_volume_offset(const volume_info_t volume
);
131 volume_info_t
get_volume(int32_t vol_no
);
132 volume_info_t
get_root_volume(void);
133 void rel_buffer(buffer_info_t buffer
);
134 void *get_buffer_data(hammer_off_t buf_offset
, buffer_info_t
*bufferp
,
136 hammer_node_ondisk_t
alloc_btree_node(hammer_off_t
*offp
,
137 buffer_info_t
*data_bufferp
);
138 void *alloc_meta_element(hammer_off_t
*offp
, int32_t data_len
,
139 buffer_info_t
*data_bufferp
);
140 void format_blockmap(volume_info_t root_vol
, int zone
, hammer_off_t offset
);
141 void format_freemap(volume_info_t root_vol
);
142 int64_t initialize_freemap(volume_info_t volume
);
143 int64_t count_freemap(const volume_info_t volume
);
144 void format_undomap(volume_info_t root_vol
, int64_t *undo_buffer_size
);
145 void print_blockmap(const volume_info_t volume
);
146 void flush_all_volumes(void);
147 void flush_volume(volume_info_t volume
);
148 void flush_buffer(buffer_info_t buffer
);
149 int64_t init_boot_area_size(int64_t value
, off_t avg_vol_size
);
150 int64_t init_memory_log_size(int64_t value
, off_t avg_vol_size
);
152 hammer_off_t
bootstrap_bigblock(volume_info_t volume
);
153 hammer_off_t
alloc_undo_bigblock(volume_info_t volume
);
154 void *alloc_blockmap(int zone
, int bytes
, hammer_off_t
*result_offp
,
155 buffer_info_t
*bufferp
);
156 hammer_off_t
blockmap_lookup(hammer_off_t bmap_off
, int *errorp
);
157 hammer_off_t
blockmap_lookup_save(hammer_off_t bmap_off
,
158 hammer_blockmap_layer1_t layer1
,
159 hammer_blockmap_layer2_t layer2
,
162 int hammer_parse_cache_size(const char *arg
);
163 void hammer_cache_add(cache_info_t cache
);
164 void hammer_cache_del(cache_info_t cache
);
165 void hammer_cache_used(cache_info_t cache
);
166 void hammer_cache_flush(void);
168 void hammer_key_beg_init(hammer_base_elm_t base
);
169 void hammer_key_end_init(hammer_base_elm_t base
);
171 const char *sizetostr(off_t size
);
172 int hammer_fs_to_vol(const char *fs
, struct hammer_ioc_volume_list
*iocp
);
173 int hammer_fs_to_rootvol(const char *fs
, char *buf
, int len
);
174 zone_stat_t
hammer_init_zone_stat(void);
175 zone_stat_t
hammer_init_zone_stat_bits(void);
176 void hammer_cleanup_zone_stat(zone_stat_t stats
);
177 void hammer_add_zone_stat(zone_stat_t stats
, hammer_off_t offset
, int bytes
);
178 void hammer_add_zone_stat_layer2(zone_stat_t stats
,
179 hammer_blockmap_layer2_t layer2
);
180 void hammer_print_zone_stat(const zone_stat_t stats
);
182 void hammer_uuid_create(hammer_uuid_t
*uuid
);
183 int hammer_uuid_from_string(const char *str
, hammer_uuid_t
*uuid
);
184 int hammer_uuid_to_string(const hammer_uuid_t
*uuid
, char **str
);
185 int hammer_uuid_name_lookup(hammer_uuid_t
*uuid
, const char *str
);
186 int hammer_uuid_compare(const hammer_uuid_t
*uuid1
, const hammer_uuid_t
*uuid2
);
188 #define hwarn(format, args...) warn("WARNING: "format,## args)
189 #define hwarnx(format, args...) warnx("WARNING: "format,## args)
191 #endif /* !HAMMER_UTIL_H_ */