xref: /xnu-11215.1.10/bsd/tests/vm_parameter_validation_kern_bsd.c (revision 8d741a5de7ff4191bf97d57b9f54c2f6d4a15585)
1*8d741a5dSApple OSS Distributions #include <sys/cdefs.h>
2*8d741a5dSApple OSS Distributions #include <sys/proc_internal.h>
3*8d741a5dSApple OSS Distributions #include <sys/vnode_internal.h>
4*8d741a5dSApple OSS Distributions #include <sys/ubc_internal.h>
5*8d741a5dSApple OSS Distributions #include <sys/file_internal.h>
6*8d741a5dSApple OSS Distributions #include <sys/vnode.h>
7*8d741a5dSApple OSS Distributions 
8*8d741a5dSApple OSS Distributions // From vm_parameter_validation_kern.c
9*8d741a5dSApple OSS Distributions void testprintf(const char *format, ...);
10*8d741a5dSApple OSS Distributions 
11*8d741a5dSApple OSS Distributions struct file_control_return {
12*8d741a5dSApple OSS Distributions 	void * control;
13*8d741a5dSApple OSS Distributions 	struct fileproc * fp;
14*8d741a5dSApple OSS Distributions 	struct vnode * vp;
15*8d741a5dSApple OSS Distributions 	int fd;
16*8d741a5dSApple OSS Distributions };
17*8d741a5dSApple OSS Distributions struct file_control_return get_control_from_fd(int fd);
18*8d741a5dSApple OSS Distributions 
19*8d741a5dSApple OSS Distributions struct file_control_return
get_control_from_fd(int fd)20*8d741a5dSApple OSS Distributions get_control_from_fd(int fd)
21*8d741a5dSApple OSS Distributions {
22*8d741a5dSApple OSS Distributions 	struct fileproc                 *fp = NULL;
23*8d741a5dSApple OSS Distributions 	struct vnode                    *vp = NULL;
24*8d741a5dSApple OSS Distributions 	size_t                          file_size;
25*8d741a5dSApple OSS Distributions 	off_t                           fs;
26*8d741a5dSApple OSS Distributions 	memory_object_control_t         file_control = NULL;
27*8d741a5dSApple OSS Distributions 	int                             error;
28*8d741a5dSApple OSS Distributions 	struct file_control_return ret = {NULL, NULL, NULL, fd};
29*8d741a5dSApple OSS Distributions 
30*8d741a5dSApple OSS Distributions 
31*8d741a5dSApple OSS Distributions 	proc_t p = current_proc();
32*8d741a5dSApple OSS Distributions 
33*8d741a5dSApple OSS Distributions 	/* get file structure from file descriptor */
34*8d741a5dSApple OSS Distributions 	error = fp_get_ftype(p, fd, DTYPE_VNODE, EINVAL, &fp);
35*8d741a5dSApple OSS Distributions 	if (error) {
36*8d741a5dSApple OSS Distributions 		testprintf("%s: [%d(%s)]: fp_get_ftype() failed, error %d\n",
37*8d741a5dSApple OSS Distributions 		    __func__, proc_getpid(p), p->p_comm, error);
38*8d741a5dSApple OSS Distributions 		return ret;
39*8d741a5dSApple OSS Distributions 	}
40*8d741a5dSApple OSS Distributions 	ret.fp = fp;
41*8d741a5dSApple OSS Distributions 
42*8d741a5dSApple OSS Distributions 	/* We need at least read permission on the file */
43*8d741a5dSApple OSS Distributions 	if (!(fp->fp_glob->fg_flag & FREAD)) {
44*8d741a5dSApple OSS Distributions 		testprintf("%s: [%d(%s)]: not readable\n",
45*8d741a5dSApple OSS Distributions 		    __func__, proc_getpid(p), p->p_comm);
46*8d741a5dSApple OSS Distributions 		return ret;
47*8d741a5dSApple OSS Distributions 	}
48*8d741a5dSApple OSS Distributions 
49*8d741a5dSApple OSS Distributions 	/* Get the vnode from file structure */
50*8d741a5dSApple OSS Distributions 	vp = (struct vnode *)fp_get_data(fp);
51*8d741a5dSApple OSS Distributions 	error = vnode_getwithref(vp);
52*8d741a5dSApple OSS Distributions 	if (error) {
53*8d741a5dSApple OSS Distributions 		testprintf("%s: [%d(%s)]: failed to get vnode, error %d\n",
54*8d741a5dSApple OSS Distributions 		    __func__, proc_getpid(p), p->p_comm, error);
55*8d741a5dSApple OSS Distributions 		return ret;
56*8d741a5dSApple OSS Distributions 	}
57*8d741a5dSApple OSS Distributions 	ret.vp = vp;
58*8d741a5dSApple OSS Distributions 
59*8d741a5dSApple OSS Distributions 	/* Make sure the vnode is a regular file */
60*8d741a5dSApple OSS Distributions 	if (vp->v_type != VREG) {
61*8d741a5dSApple OSS Distributions 		testprintf("%s: [%d(%s)]: vnode not VREG\n",
62*8d741a5dSApple OSS Distributions 		    __func__, proc_getpid(p), p->p_comm);
63*8d741a5dSApple OSS Distributions 		return ret;
64*8d741a5dSApple OSS Distributions 	}
65*8d741a5dSApple OSS Distributions 
66*8d741a5dSApple OSS Distributions 	/* get vnode size */
67*8d741a5dSApple OSS Distributions 	error = vnode_size(vp, &fs, vfs_context_current());
68*8d741a5dSApple OSS Distributions 	if (error) {
69*8d741a5dSApple OSS Distributions 		return ret;
70*8d741a5dSApple OSS Distributions 	}
71*8d741a5dSApple OSS Distributions 	file_size = fs;
72*8d741a5dSApple OSS Distributions 
73*8d741a5dSApple OSS Distributions 	/* get the file's memory object handle */
74*8d741a5dSApple OSS Distributions 	file_control = ubc_getobject(vp, UBC_HOLDOBJECT);
75*8d741a5dSApple OSS Distributions 	if (file_control == MEMORY_OBJECT_CONTROL_NULL) {
76*8d741a5dSApple OSS Distributions 		testprintf("%s: [%d(%s)]: no memory object\n",
77*8d741a5dSApple OSS Distributions 		    __func__, proc_getpid(p), p->p_comm);
78*8d741a5dSApple OSS Distributions 		return ret;
79*8d741a5dSApple OSS Distributions 	}
80*8d741a5dSApple OSS Distributions 	ret.control = file_control;
81*8d741a5dSApple OSS Distributions 
82*8d741a5dSApple OSS Distributions 	return ret;
83*8d741a5dSApple OSS Distributions }
84*8d741a5dSApple OSS Distributions 
85*8d741a5dSApple OSS Distributions void cleanup_control_related_data(struct file_control_return info);
86*8d741a5dSApple OSS Distributions 
87*8d741a5dSApple OSS Distributions void
cleanup_control_related_data(struct file_control_return info)88*8d741a5dSApple OSS Distributions cleanup_control_related_data(struct file_control_return info)
89*8d741a5dSApple OSS Distributions {
90*8d741a5dSApple OSS Distributions 	if (info.fp != NULL) {
91*8d741a5dSApple OSS Distributions 		/* release the file descriptor */
92*8d741a5dSApple OSS Distributions 		fp_drop(current_proc(), info.fd, info.fp, 0);
93*8d741a5dSApple OSS Distributions 	}
94*8d741a5dSApple OSS Distributions 	if (info.vp != NULL) {
95*8d741a5dSApple OSS Distributions 		(void)vnode_put(info.vp);
96*8d741a5dSApple OSS Distributions 	}
97*8d741a5dSApple OSS Distributions }
98