udf_subr.h revision 1.4.16.2 1 1.4.16.2 rpaulo /* $NetBSD: udf_subr.h,v 1.4.16.2 2006/09/09 02:57:06 rpaulo Exp $ */
2 1.4.16.2 rpaulo
3 1.4.16.2 rpaulo /*
4 1.4.16.2 rpaulo * Copyright (c) 2006 Reinoud Zandijk
5 1.4.16.2 rpaulo * All rights reserved.
6 1.4.16.2 rpaulo *
7 1.4.16.2 rpaulo * Redistribution and use in source and binary forms, with or without
8 1.4.16.2 rpaulo * modification, are permitted provided that the following conditions
9 1.4.16.2 rpaulo * are met:
10 1.4.16.2 rpaulo * 1. Redistributions of source code must retain the above copyright
11 1.4.16.2 rpaulo * notice, this list of conditions and the following disclaimer.
12 1.4.16.2 rpaulo * 2. Redistributions in binary form must reproduce the above copyright
13 1.4.16.2 rpaulo * notice, this list of conditions and the following disclaimer in the
14 1.4.16.2 rpaulo * documentation and/or other materials provided with the distribution.
15 1.4.16.2 rpaulo * 3. All advertising materials mentioning features or use of this software
16 1.4.16.2 rpaulo * must display the following acknowledgement:
17 1.4.16.2 rpaulo * This product includes software developed for the
18 1.4.16.2 rpaulo * NetBSD Project. See http://www.NetBSD.org/ for
19 1.4.16.2 rpaulo * information about NetBSD.
20 1.4.16.2 rpaulo * 4. The name of the author may not be used to endorse or promote products
21 1.4.16.2 rpaulo * derived from this software without specific prior written permission.
22 1.4.16.2 rpaulo *
23 1.4.16.2 rpaulo * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR
24 1.4.16.2 rpaulo * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
25 1.4.16.2 rpaulo * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
26 1.4.16.2 rpaulo * IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT,
27 1.4.16.2 rpaulo * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT
28 1.4.16.2 rpaulo * NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
29 1.4.16.2 rpaulo * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
30 1.4.16.2 rpaulo * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
31 1.4.16.2 rpaulo * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF
32 1.4.16.2 rpaulo * THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
33 1.4.16.2 rpaulo *
34 1.4.16.2 rpaulo */
35 1.4.16.2 rpaulo
36 1.4.16.2 rpaulo
37 1.4.16.2 rpaulo #ifndef _FS_UDF_UDF_SUBR_H_
38 1.4.16.2 rpaulo #define _FS_UDF_UDF_SUBR_H_
39 1.4.16.2 rpaulo
40 1.4.16.2 rpaulo /* device information updating */
41 1.4.16.2 rpaulo int udf_update_trackinfo(struct udf_mount *ump, struct mmc_trackinfo *trackinfo);
42 1.4.16.2 rpaulo int udf_update_discinfo(struct udf_mount *ump);
43 1.4.16.2 rpaulo
44 1.4.16.2 rpaulo /* tags and read/write descriptors */
45 1.4.16.2 rpaulo int udf_check_tag(void *blob);
46 1.4.16.2 rpaulo int udf_check_tag_payload(void *blob, uint32_t max_length);
47 1.4.16.2 rpaulo int udf_validate_tag_sum(void *blob);
48 1.4.16.2 rpaulo int udf_validate_tag_and_crc_sums(void *blob);
49 1.4.16.2 rpaulo int udf_tagsize(union dscrptr *dscr, uint32_t udf_sector_size);
50 1.4.16.2 rpaulo
51 1.4.16.2 rpaulo int udf_read_descriptor(
52 1.4.16.2 rpaulo struct udf_mount *ump,
53 1.4.16.2 rpaulo uint32_t sector,
54 1.4.16.2 rpaulo struct malloc_type *mtype, /* where to allocate */
55 1.4.16.2 rpaulo union dscrptr **dstp); /* out */
56 1.4.16.2 rpaulo
57 1.4.16.2 rpaulo
58 1.4.16.2 rpaulo /* volume descriptors readers and checkers */
59 1.4.16.2 rpaulo int udf_read_anchors(struct udf_mount *ump, struct udf_args *args);
60 1.4.16.2 rpaulo
61 1.4.16.2 rpaulo int udf_read_vds_space(struct udf_mount *ump);
62 1.4.16.2 rpaulo int udf_process_vds(struct udf_mount *ump, struct udf_args *args);
63 1.4.16.2 rpaulo int udf_read_vds_tables(struct udf_mount *ump, struct udf_args *args);
64 1.4.16.2 rpaulo int udf_read_rootdirs(struct udf_mount *ump, struct udf_args *args);
65 1.4.16.2 rpaulo
66 1.4.16.2 rpaulo /* translation services */
67 1.4.16.2 rpaulo int udf_translate_vtop(struct udf_mount *ump, struct long_ad *icb_loc, uint32_t *lb_numres, uint32_t *extres);
68 1.4.16.2 rpaulo int udf_translate_file_extent(struct udf_node *node, uint32_t from, uint32_t pages, uint64_t *map);
69 1.4.16.2 rpaulo
70 1.4.16.2 rpaulo /* node readers and writers */
71 1.4.16.2 rpaulo int udf_get_node(struct udf_mount *ump, struct long_ad *icbloc, struct udf_node **noderes);
72 1.4.16.2 rpaulo int udf_dispose_node(struct udf_node *node);
73 1.4.16.2 rpaulo int udf_dispose_locked_node(struct udf_node *node);
74 1.4.16.2 rpaulo void udf_read_filebuf(struct udf_node *node, struct buf *buf);
75 1.4.16.2 rpaulo int udf_read_file_extent(struct udf_node *node, uint32_t from, uint32_t sectors, uint8_t *blob);
76 1.4.16.2 rpaulo
77 1.4.16.2 rpaulo /* directory read and parse utils */
78 1.4.16.2 rpaulo void udf_to_unix_name(char *result, char *id, int len, struct charspec *chsp);
79 1.4.16.2 rpaulo void unix_to_udf_name(char *result, char *name, uint8_t *result_len, struct charspec *chsp);
80 1.4.16.2 rpaulo int udf_lookup_name_in_dir(struct vnode *vp, const char *name, int namelen, struct long_ad *icb_loc);
81 1.4.16.2 rpaulo int udf_read_fid_stream(struct vnode *vp, uint64_t *offset, struct fileid_desc *fid, struct dirent *dirent);
82 1.4.16.2 rpaulo
83 1.4.16.2 rpaulo /* vnode operations */
84 1.4.16.2 rpaulo int udf_inactive(void *v);
85 1.4.16.2 rpaulo int udf_reclaim(void *v);
86 1.4.16.2 rpaulo int udf_readdir(void *v);
87 1.4.16.2 rpaulo int udf_getattr(void *v);
88 1.4.16.2 rpaulo int udf_setattr(void *v);
89 1.4.16.2 rpaulo int udf_pathconf(void *v);
90 1.4.16.2 rpaulo int udf_open(void *v);
91 1.4.16.2 rpaulo int udf_close(void *v);
92 1.4.16.2 rpaulo int udf_access(void *v);
93 1.4.16.2 rpaulo int udf_read(void *v);
94 1.4.16.2 rpaulo int udf_write(void *v);
95 1.4.16.2 rpaulo int udf_trivial_bmap(void *v);
96 1.4.16.2 rpaulo int udf_strategy(void *v);
97 1.4.16.2 rpaulo int udf_lookup(void *v);
98 1.4.16.2 rpaulo int udf_create(void *v);
99 1.4.16.2 rpaulo int udf_mknod(void *v);
100 1.4.16.2 rpaulo int udf_link(void *);
101 1.4.16.2 rpaulo int udf_symlink(void *v);
102 1.4.16.2 rpaulo int udf_readlink(void *v);
103 1.4.16.2 rpaulo int udf_rename(void *v);
104 1.4.16.2 rpaulo int udf_remove(void *v);
105 1.4.16.2 rpaulo int udf_mkdir(void *v);
106 1.4.16.2 rpaulo int udf_rmdir(void *v);
107 1.4.16.2 rpaulo int udf_fsync(void *v);
108 1.4.16.2 rpaulo int udf_advlock(void *v);
109 1.4.16.2 rpaulo
110 1.4.16.2 rpaulo
111 1.4.16.2 rpaulo /* helpers and converters */
112 1.4.16.2 rpaulo long udf_calchash(struct long_ad *icbptr); /* for `inode' numbering */
113 1.4.16.2 rpaulo uint32_t udf_getaccessmode(struct udf_node *node);
114 1.4.16.2 rpaulo void udf_timestamp_to_timespec(struct udf_mount *ump, struct timestamp *timestamp, struct timespec *timespec);
115 1.4.16.2 rpaulo
116 1.4.16.2 rpaulo #endif /* !_FS_UDF_UDF_SUBR_H_ */
117