xref: /freebsd/lib/libprocstat/udf.c (revision 0daf62d9f5f7d2c15d00d71eb519b90516df016f)
1*0daf62d9SStanislav Sedov /*-
2*0daf62d9SStanislav Sedov  * Copyright (c) 2005-2009 Stanislav Sedov <stas@FreeBSD.org>
3*0daf62d9SStanislav Sedov  * All rights reserved.
4*0daf62d9SStanislav Sedov  *
5*0daf62d9SStanislav Sedov  * Redistribution and use in source and binary forms, with or without
6*0daf62d9SStanislav Sedov  * modification, are permitted provided that the following conditions
7*0daf62d9SStanislav Sedov  * are met:
8*0daf62d9SStanislav Sedov  * 1. Redistributions of source code must retain the above copyright
9*0daf62d9SStanislav Sedov  *    notice, this list of conditions and the following disclaimer.
10*0daf62d9SStanislav Sedov  * 2. Redistributions in binary form must reproduce the above copyright
11*0daf62d9SStanislav Sedov  *    notice, this list of conditions and the following disclaimer in the
12*0daf62d9SStanislav Sedov  *    documentation and/or other materials provided with the distribution.
13*0daf62d9SStanislav Sedov  *
14*0daf62d9SStanislav Sedov  * THIS SOFTWARE IS PROVIDED BY THE AUTHOR AND CONTRIBUTORS ``AS IS'' AND
15*0daf62d9SStanislav Sedov  * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
16*0daf62d9SStanislav Sedov  * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
17*0daf62d9SStanislav Sedov  * ARE DISCLAIMED.  IN NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS BE LIABLE
18*0daf62d9SStanislav Sedov  * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
19*0daf62d9SStanislav Sedov  * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
20*0daf62d9SStanislav Sedov  * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
21*0daf62d9SStanislav Sedov  * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
22*0daf62d9SStanislav Sedov  * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
23*0daf62d9SStanislav Sedov  * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
24*0daf62d9SStanislav Sedov  * SUCH DAMAGE.
25*0daf62d9SStanislav Sedov  */
26*0daf62d9SStanislav Sedov #include <sys/cdefs.h>
27*0daf62d9SStanislav Sedov __FBSDID("$FreeBSD$");
28*0daf62d9SStanislav Sedov 
29*0daf62d9SStanislav Sedov #include <sys/param.h>
30*0daf62d9SStanislav Sedov #include <sys/stat.h>
31*0daf62d9SStanislav Sedov #include <sys/time.h>
32*0daf62d9SStanislav Sedov #include <sys/vnode.h>
33*0daf62d9SStanislav Sedov #include <sys/buf.h>
34*0daf62d9SStanislav Sedov #define _KERNEL
35*0daf62d9SStanislav Sedov #include <sys/mount.h>
36*0daf62d9SStanislav Sedov #undef _KERNEL
37*0daf62d9SStanislav Sedov 
38*0daf62d9SStanislav Sedov #include <netinet/in.h>
39*0daf62d9SStanislav Sedov 
40*0daf62d9SStanislav Sedov #include <assert.h>
41*0daf62d9SStanislav Sedov #include <err.h>
42*0daf62d9SStanislav Sedov #include <kvm.h>
43*0daf62d9SStanislav Sedov #include <stdlib.h>
44*0daf62d9SStanislav Sedov 
45*0daf62d9SStanislav Sedov #include <fs/udf/ecma167-udf.h>
46*0daf62d9SStanislav Sedov 
47*0daf62d9SStanislav Sedov #include "libprocstat.h"
48*0daf62d9SStanislav Sedov #include "common_kvm.h"
49*0daf62d9SStanislav Sedov 
50*0daf62d9SStanislav Sedov /* XXX */
51*0daf62d9SStanislav Sedov struct udf_mnt {
52*0daf62d9SStanislav Sedov 	int			im_flags;
53*0daf62d9SStanislav Sedov 	struct mount		*im_mountp;
54*0daf62d9SStanislav Sedov 	struct g_consumer	*im_cp;
55*0daf62d9SStanislav Sedov 	struct bufobj		*im_bo;
56*0daf62d9SStanislav Sedov 	struct cdev		*im_dev;
57*0daf62d9SStanislav Sedov 	struct vnode		*im_devvp;
58*0daf62d9SStanislav Sedov 	int			bsize;
59*0daf62d9SStanislav Sedov 	int			bshift;
60*0daf62d9SStanislav Sedov 	int			bmask;
61*0daf62d9SStanislav Sedov 	uint32_t		part_start;
62*0daf62d9SStanislav Sedov 	uint32_t		part_len;
63*0daf62d9SStanislav Sedov 	uint64_t		root_id;
64*0daf62d9SStanislav Sedov 	struct long_ad		root_icb;
65*0daf62d9SStanislav Sedov 	int			p_sectors;
66*0daf62d9SStanislav Sedov 	int			s_table_entries;
67*0daf62d9SStanislav Sedov 	void			*s_table;
68*0daf62d9SStanislav Sedov 	void			*im_d2l;
69*0daf62d9SStanislav Sedov };
70*0daf62d9SStanislav Sedov struct udf_node {
71*0daf62d9SStanislav Sedov 	struct vnode	*i_vnode;
72*0daf62d9SStanislav Sedov 	struct udf_mnt	*udfmp;
73*0daf62d9SStanislav Sedov 	ino_t		hash_id;
74*0daf62d9SStanislav Sedov 	long		diroff;
75*0daf62d9SStanislav Sedov 	struct file_entry *fentry;
76*0daf62d9SStanislav Sedov };
77*0daf62d9SStanislav Sedov #define VTON(vp)	((struct udf_node *)((vp)->v_data))
78*0daf62d9SStanislav Sedov 
79*0daf62d9SStanislav Sedov int
80*0daf62d9SStanislav Sedov udf_filestat(kvm_t *kd, struct vnode *vp, struct vnstat *vn)
81*0daf62d9SStanislav Sedov {
82*0daf62d9SStanislav Sedov 	struct udf_node node;
83*0daf62d9SStanislav Sedov 	struct udf_mnt mnt;
84*0daf62d9SStanislav Sedov 	int error;
85*0daf62d9SStanislav Sedov 
86*0daf62d9SStanislav Sedov 	assert(kd);
87*0daf62d9SStanislav Sedov 	assert(vn);
88*0daf62d9SStanislav Sedov 	error = kvm_read_all(kd, (unsigned long)VTON(vp), &node, sizeof(node));
89*0daf62d9SStanislav Sedov 	if (error != 0) {
90*0daf62d9SStanislav Sedov 		warnx("can't read udf fnode at %p", (void *)VTON(vp));
91*0daf62d9SStanislav Sedov 		return (1);
92*0daf62d9SStanislav Sedov 	}
93*0daf62d9SStanislav Sedov         error = kvm_read_all(kd, (unsigned long)node.udfmp, &mnt, sizeof(mnt));
94*0daf62d9SStanislav Sedov         if (error != 0) {
95*0daf62d9SStanislav Sedov                 warnx("can't read udf_mnt at %p for vnode %p",
96*0daf62d9SStanislav Sedov                     (void *)node.udfmp, vp);
97*0daf62d9SStanislav Sedov                 return (1);
98*0daf62d9SStanislav Sedov         }
99*0daf62d9SStanislav Sedov 	vn->vn_fileid = node.hash_id;
100*0daf62d9SStanislav Sedov 	vn->vn_fsid = dev2udev(kd, mnt.im_dev);
101*0daf62d9SStanislav Sedov 	return (0);
102*0daf62d9SStanislav Sedov }
103