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