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