1 /* $NetBSD: udf_subr.h,v 1.19 2013/07/07 19:49:44 reinoud Exp $ */
4 * Copyright (c) 2006, 2008 Reinoud Zandijk
7 * Redistribution and use in source and binary forms, with or without
8 * modification, are permitted provided that the following conditions
10 * 1. Redistributions of source code must retain the above copyright
11 * notice, this list of conditions and the following disclaimer.
12 * 2. Redistributions in binary form must reproduce the above copyright
13 * notice, this list of conditions and the following disclaimer in the
14 * documentation and/or other materials provided with the distribution.
16 * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR
17 * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
18 * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
19 * IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT,
20 * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT
21 * NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
22 * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
23 * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
24 * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF
25 * THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
29 #ifndef _FS_UDF_UDF_SUBR_H_
30 #define _FS_UDF_UDF_SUBR_H_
33 #define VFSTOUDF(mp) ((struct udf_mount *)mp->mnt_data)
36 /* device information updating */
37 int udf_update_trackinfo(struct udf_mount
*ump
, struct mmc_trackinfo
*trackinfo
);
38 int udf_update_discinfo(struct udf_mount
*ump
);
39 int udf_search_tracks(struct udf_mount
*ump
, struct udf_args
*args
,
40 int *first_tracknr
, int *last_tracknr
);
41 int udf_search_writing_tracks(struct udf_mount
*ump
);
42 int udf_setup_writeparams(struct udf_mount
*ump
);
43 int udf_synchronise_caches(struct udf_mount
*ump
);
46 int udf_fidsize(struct fileid_desc
*fid
);
47 int udf_check_tag(void *blob
);
48 int udf_check_tag_payload(void *blob
, uint32_t max_length
);
49 void udf_validate_tag_sum(void *blob
);
50 void udf_validate_tag_and_crc_sums(void *blob
);
51 int udf_tagsize(union dscrptr
*dscr
, uint32_t udf_sector_size
);
53 /* read/write descriptors */
54 int udf_read_phys_sectors(struct udf_mount
*ump
, int what
, void *blob
,
55 uint32_t start
, uint32_t sectors
);
56 int udf_write_phys_sectors(struct udf_mount
*ump
, int what
, void *blob
,
57 uint32_t start
, uint32_t sectors
);
58 int udf_read_phys_dscr(
59 struct udf_mount
*ump
,
61 struct malloc_type
*mtype
, /* where to allocate */
62 union dscrptr
**dstp
); /* out */
64 int udf_write_phys_dscr_sync(struct udf_mount
*ump
, struct udf_node
*udf_node
,
65 int what
, union dscrptr
*dscr
,
66 uint32_t sector
, uint32_t logsector
);
67 int udf_write_phys_dscr_async(struct udf_mount
*ump
, struct udf_node
*udf_node
,
68 int what
, union dscrptr
*dscr
,
69 uint32_t sector
, uint32_t logsector
,
70 void (*dscrwr_callback
)(struct buf
*));
72 /* read/write node descriptors */
73 int udf_create_logvol_dscr(struct udf_mount
*ump
, struct udf_node
*udf_node
,
74 struct long_ad
*icb
, union dscrptr
**dscrptr
);
75 void udf_free_logvol_dscr(struct udf_mount
*ump
, struct long_ad
*icb_loc
,
77 int udf_read_logvol_dscr(struct udf_mount
*ump
, struct long_ad
*icb
,
78 union dscrptr
**dscrptr
);
79 int udf_write_logvol_dscr(struct udf_node
*udf_node
, union dscrptr
*dscr
,
80 struct long_ad
*icb
, int waitfor
);
83 /* volume descriptors readers and checkers */
84 int udf_read_anchors(struct udf_mount
*ump
);
85 int udf_read_vds_space(struct udf_mount
*ump
);
86 int udf_process_vds(struct udf_mount
*ump
);
87 int udf_read_vds_tables(struct udf_mount
*ump
);
88 int udf_read_rootdirs(struct udf_mount
*ump
);
90 /* open/close and sync volumes */
91 int udf_open_logvol(struct udf_mount
*ump
);
92 int udf_close_logvol(struct udf_mount
*ump
, int mntflags
);
93 int udf_writeout_vat(struct udf_mount
*ump
);
94 int udf_write_physical_partition_spacetables(struct udf_mount
*ump
, int waitfor
);
95 int udf_write_metadata_partition_spacetable(struct udf_mount
*ump
, int waitfor
);
96 void udf_do_sync(struct udf_mount
*ump
, kauth_cred_t cred
, int waitfor
);
97 void udf_synchronise_metadatamirror_node(struct udf_mount
*ump
);
99 /* translation services */
100 int udf_translate_vtop(struct udf_mount
*ump
, struct long_ad
*icb_loc
,
101 uint32_t *lb_numres
, uint32_t *extres
);
102 void udf_translate_vtop_list(struct udf_mount
*ump
, uint32_t sectors
,
103 uint16_t vpart_num
, uint64_t *lmapping
, uint64_t *pmapping
);
104 int udf_translate_file_extent(struct udf_node
*node
,
105 uint32_t from
, uint32_t num_lb
, uint64_t *map
);
106 void udf_get_adslot(struct udf_node
*udf_node
, int slot
, struct long_ad
*icb
, int *eof
);
107 int udf_append_adslot(struct udf_node
*udf_node
, int *slot
, struct long_ad
*icb
);
109 int udf_vat_read(struct udf_node
*vat_node
, uint8_t *blob
, int size
, uint32_t offset
);
110 int udf_vat_write(struct udf_node
*vat_node
, uint8_t *blob
, int size
, uint32_t offset
);
112 /* disc allocation */
113 int udf_get_c_type(struct udf_node
*udf_node
);
114 int udf_get_record_vpart(struct udf_mount
*ump
, int udf_c_type
);
115 void udf_do_reserve_space(struct udf_mount
*ump
, struct udf_node
*udf_node
, uint16_t vpart_num
, uint32_t num_lb
);
116 void udf_do_unreserve_space(struct udf_mount
*ump
, struct udf_node
*udf_node
, uint16_t vpart_num
, uint32_t num_lb
);
117 int udf_reserve_space(struct udf_mount
*ump
, struct udf_node
*udf_node
, int udf_c_type
, uint16_t vpart_num
, uint32_t num_lb
, int can_fail
);
118 void udf_cleanup_reservation(struct udf_node
*udf_node
);
119 int udf_allocate_space(struct udf_mount
*ump
, struct udf_node
*udf_node
, int udf_c_type
, uint16_t vpart_num
, uint32_t num_lb
, uint64_t *lmapping
);
120 void udf_free_allocated_space(struct udf_mount
*ump
, uint32_t lb_num
, uint16_t vpart_num
, uint32_t num_lb
);
121 void udf_late_allocate_buf(struct udf_mount
*ump
, struct buf
*buf
, uint64_t *lmapping
, struct long_ad
*node_ad_cpy
, uint16_t *vpart_num
);
122 int udf_grow_node(struct udf_node
*node
, uint64_t new_size
);
123 int udf_shrink_node(struct udf_node
*node
, uint64_t new_size
);
124 void udf_calc_freespace(struct udf_mount
*ump
, uint64_t *sizeblks
, uint64_t *freeblks
);
126 /* node readers and writers */
127 uint64_t udf_advance_uniqueid(struct udf_mount
*ump
);
129 #define UDF_LOCK_NODE(udf_node, flag) udf_lock_node(udf_node, (flag), __FILE__, __LINE__)
130 #define UDF_UNLOCK_NODE(udf_node, flag) udf_unlock_node(udf_node, (flag))
131 void udf_lock_node(struct udf_node
*udf_node
, int flag
, char const *fname
, const int lineno
);
132 void udf_unlock_node(struct udf_node
*udf_node
, int flag
);
134 int udf_get_node(struct udf_mount
*ump
, struct long_ad
*icbloc
, struct udf_node
**noderes
);
135 int udf_writeout_node(struct udf_node
*udf_node
, int waitfor
);
136 int udf_dispose_node(struct udf_node
*node
);
139 int udf_resize_node(struct udf_node
*node
, uint64_t new_size
, int *extended
);
140 int udf_extattr_search_intern(struct udf_node
*node
, uint32_t sattr
, char const *sattrname
, uint32_t *offsetp
, uint32_t *lengthp
);
142 /* node data buffer read/write */
143 void udf_read_filebuf(struct udf_node
*node
, struct buf
*buf
);
144 void udf_write_filebuf(struct udf_node
*node
, struct buf
*buf
);
145 void udf_fixup_fid_block(uint8_t *blob
, int lb_size
, int rfix_pos
, int max_rfix_pos
, uint32_t lb_num
);
146 void udf_fixup_internal_extattr(uint8_t *blob
, uint32_t lb_num
);
147 void udf_fixup_node_internals(struct udf_mount
*ump
, uint8_t *blob
, int udf_c_type
);
149 /* device strategy */
150 void udf_discstrat_init(struct udf_mount
*ump
);
151 void udf_discstrat_finish(struct udf_mount
*ump
);
152 void udf_discstrat_queuebuf(struct udf_mount
*ump
, struct buf
*nestbuf
);
154 /* structure writers */
155 int udf_write_terminator(struct udf_mount
*ump
, uint32_t sector
);
157 /* structure creators */
158 void udf_inittag(struct udf_mount
*ump
, struct desc_tag
*tag
, int tagid
, uint32_t sector
);
159 void udf_set_regid(struct regid
*regid
, char const *name
);
160 void udf_add_domain_regid(struct udf_mount
*ump
, struct regid
*regid
);
161 void udf_add_udf_regid(struct udf_mount
*ump
, struct regid
*regid
);
162 void udf_add_impl_regid(struct udf_mount
*ump
, struct regid
*regid
);
163 void udf_add_app_regid(struct udf_mount
*ump
, struct regid
*regid
);
165 /* directory operations and helpers */
166 void udf_osta_charset(struct charspec
*charspec
);
167 int udf_read_fid_stream(struct vnode
*vp
, uint64_t *offset
, struct fileid_desc
*fid
, struct dirent
*dirent
);
168 int udf_lookup_name_in_dir(struct vnode
*vp
, const char *name
, int namelen
, struct long_ad
*icb_loc
, int *found
);
169 int udf_create_node(struct vnode
*dvp
, struct vnode
**vpp
, struct vattr
*vap
, struct componentname
*cnp
);
170 void udf_delete_node(struct udf_node
*udf_node
);
172 int udf_chsize(struct vnode
*vp
, u_quad_t newsize
, kauth_cred_t cred
);
174 int udf_dir_detach(struct udf_mount
*ump
, struct udf_node
*dir_node
, struct udf_node
*udf_node
, struct componentname
*cnp
);
175 int udf_dir_attach(struct udf_mount
*ump
, struct udf_node
*dir_node
, struct udf_node
*udf_node
, struct vattr
*vap
, struct componentname
*cnp
);
176 int udf_dir_update_rootentry(struct udf_mount
*ump
, struct udf_node
*dir_node
, struct udf_node
*new_parent_node
);
177 int udf_dirhash_fill(struct udf_node
*dir_node
);
179 /* update and times */
180 void udf_add_to_dirtylist(struct udf_node
*udf_node
);
181 void udf_remove_from_dirtylist(struct udf_node
*udf_node
);
182 void udf_itimes(struct udf_node
*udf_node
, struct timespec
*acc
,
183 struct timespec
*mod
, struct timespec
*birth
);
184 int udf_update(struct vnode
*node
, struct timespec
*acc
,
185 struct timespec
*mod
, struct timespec
*birth
, int updflags
);
187 /* helpers and converters */
188 void udf_init_nodes_tree(struct udf_mount
*ump
);
189 long udf_get_node_id(const struct long_ad
*icbptr
); /* for `inode' numbering */
190 int udf_compare_icb(const struct long_ad
*a
, const struct long_ad
*b
);
191 uint32_t udf_getaccessmode(struct udf_node
*node
);
192 void udf_setaccessmode(struct udf_node
*udf_node
, mode_t mode
);
193 void udf_getownership(struct udf_node
*udf_node
, uid_t
*uidp
, gid_t
*gidp
);
194 void udf_setownership(struct udf_node
*udf_node
, uid_t uid
, gid_t gid
);
196 void udf_to_unix_name(char *result
, int result_len
, char *id
, int len
, struct charspec
*chsp
);
197 void unix_to_udf_name(char *result
, uint8_t *result_len
, char const *name
, int name_len
, struct charspec
*chsp
);
199 void udf_timestamp_to_timespec(struct udf_mount
*ump
, struct timestamp
*timestamp
, struct timespec
*timespec
);
200 void udf_timespec_to_timestamp(struct timespec
*timespec
, struct timestamp
*timestamp
);
202 /* vnode operations */
203 int udf_inactive(void *v
);
204 int udf_reclaim(void *v
);
205 int udf_readdir(void *v
);
206 int udf_getattr(void *v
);
207 int udf_setattr(void *v
);
208 int udf_pathconf(void *v
);
209 int udf_open(void *v
);
210 int udf_close(void *v
);
211 int udf_access(void *v
);
212 int udf_read(void *v
);
213 int udf_write(void *v
);
214 int udf_trivial_bmap(void *v
);
215 int udf_vfsstrategy(void *v
);
216 int udf_lookup(void *v
);
217 int udf_create(void *v
);
218 int udf_mknod(void *v
);
219 int udf_link(void *);
220 int udf_symlink(void *v
);
221 int udf_readlink(void *v
);
222 int udf_rename(void *v
);
223 int udf_remove(void *v
);
224 int udf_mkdir(void *v
);
225 int udf_rmdir(void *v
);
226 int udf_fsync(void *v
);
227 int udf_advlock(void *v
);
229 #endif /* !_FS_UDF_UDF_SUBR_H_ */