xref: /netbsd-src/external/cddl/osnet/sys/kern/misc.c (revision e3c82a0cc6ca5b9adb4aa6f57f91f73d9d4cd9dc)
1*e3c82a0cSriastradh /*	$NetBSD: misc.c,v 1.10 2022/07/30 13:09:19 riastradh Exp $	*/
2fc8ec0b8Shaad 
3fc8ec0b8Shaad /*-
4fc8ec0b8Shaad  * Copyright (c) 2009 The NetBSD Foundation, Inc.
5fc8ec0b8Shaad  * All rights reserved.
6fc8ec0b8Shaad  *
7fc8ec0b8Shaad  * This code is derived from software contributed to The NetBSD Foundation
8fc8ec0b8Shaad  * by Andrew Doran.
9fc8ec0b8Shaad  *
10fc8ec0b8Shaad  * Redistribution and use in source and binary forms, with or without
11fc8ec0b8Shaad  * modification, are permitted provided that the following conditions
12fc8ec0b8Shaad  * are met:
13fc8ec0b8Shaad  * 1. Redistributions of source code must retain the above copyright
14fc8ec0b8Shaad  *    notice, this list of conditions and the following disclaimer.
15fc8ec0b8Shaad  * 2. Redistributions in binary form must reproduce the above copyright
16fc8ec0b8Shaad  *    notice, this list of conditions and the following disclaimer in the
17fc8ec0b8Shaad  *    documentation and/or other materials provided with the distribution.
18fc8ec0b8Shaad  *
19fc8ec0b8Shaad  * THIS SOFTWARE IS PROVIDED BY THE NETBSD FOUNDATION, INC. AND CONTRIBUTORS
20fc8ec0b8Shaad  * ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED
21fc8ec0b8Shaad  * TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
22fc8ec0b8Shaad  * PURPOSE ARE DISCLAIMED.  IN NO EVENT SHALL THE FOUNDATION OR CONTRIBUTORS
23fc8ec0b8Shaad  * BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
24fc8ec0b8Shaad  * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
25fc8ec0b8Shaad  * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
26fc8ec0b8Shaad  * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
27fc8ec0b8Shaad  * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
28fc8ec0b8Shaad  * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
29fc8ec0b8Shaad  * POSSIBILITY OF SUCH DAMAGE.
30fc8ec0b8Shaad  */
31fc8ec0b8Shaad 
32fc8ec0b8Shaad /*-
33fc8ec0b8Shaad  * Copyright (c) 2007 Pawel Jakub Dawidek <pjd@FreeBSD.org>
34fc8ec0b8Shaad  * All rights reserved.
35fc8ec0b8Shaad  *
36fc8ec0b8Shaad  * Redistribution and use in source and binary forms, with or without
37fc8ec0b8Shaad  * modification, are permitted provided that the following conditions
38fc8ec0b8Shaad  * are met:
39fc8ec0b8Shaad  * 1. Redistributions of source code must retain the above copyright
40fc8ec0b8Shaad  *    notice, this list of conditions and the following disclaimer.
41fc8ec0b8Shaad  * 2. Redistributions in binary form must reproduce the above copyright
42fc8ec0b8Shaad  *    notice, this list of conditions and the following disclaimer in the
43fc8ec0b8Shaad  *    documentation and/or other materials provided with the distribution.
44fc8ec0b8Shaad  *
45fc8ec0b8Shaad  * THIS SOFTWARE IS PROVIDED BY THE AUTHORS AND CONTRIBUTORS ``AS IS'' AND
46fc8ec0b8Shaad  * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
47fc8ec0b8Shaad  * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
48fc8ec0b8Shaad  * ARE DISCLAIMED.  IN NO EVENT SHALL THE AUTHORS OR CONTRIBUTORS BE LIABLE
49fc8ec0b8Shaad  * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
50fc8ec0b8Shaad  * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
51fc8ec0b8Shaad  * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
52fc8ec0b8Shaad  * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
53fc8ec0b8Shaad  * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
54fc8ec0b8Shaad  * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
55fc8ec0b8Shaad  * SUCH DAMAGE.
56fc8ec0b8Shaad  */
57fc8ec0b8Shaad 
58fc8ec0b8Shaad #include <sys/cdefs.h>
59ba2539a9Schs /* __FBSDID("$FreeBSD: head/sys/cddl/compat/opensolaris/kern/opensolaris_misc.c 219089 2011-02-27 19:41:40Z pjd $"); */
60ba2539a9Schs 
61fc8ec0b8Shaad 
62fc8ec0b8Shaad #include <sys/mount.h>
63fc8ec0b8Shaad #include <sys/param.h>
64fc8ec0b8Shaad #include <sys/kernel.h>
65fc8ec0b8Shaad #include <sys/systm.h>
66fc8ec0b8Shaad #include <sys/misc.h>
67fc8ec0b8Shaad #include <sys/sunddi.h>
68fc8ec0b8Shaad #include <sys/utsname.h>
69fc8ec0b8Shaad #include <sys/vnode.h>
70fc8ec0b8Shaad #include <sys/mount.h>
71fc8ec0b8Shaad #include <sys/pool.h>
72fc8ec0b8Shaad #include <sys/buf.h>
73fc8ec0b8Shaad 
74fc8ec0b8Shaad char hw_serial[11] = "0";
75fc8ec0b8Shaad 
76ba2539a9Schs struct utsname utsname;
77ba2539a9Schs 
78ba2539a9Schs void
opensolaris_utsname_init(void * arg)79ba2539a9Schs opensolaris_utsname_init(void *arg)
80ba2539a9Schs {
81ba2539a9Schs 
82ba2539a9Schs 	strlcpy(utsname.sysname, ostype, sizeof(utsname.sysname));
83ba2539a9Schs 	strlcpy(utsname.nodename, hostname, sizeof(utsname.nodename));
84ba2539a9Schs 	strlcpy(utsname.release, osrelease, sizeof(utsname.release));
8569aded6dSriastradh 	strlcpy(utsname.version, version, sizeof(utsname.version));
86ba2539a9Schs 	strlcpy(utsname.machine, machine, sizeof(utsname.machine));
87ba2539a9Schs }
88fc8ec0b8Shaad 
89fc8ec0b8Shaad int
vn_is_readonly(vnode_t * vp)90fc8ec0b8Shaad vn_is_readonly(vnode_t *vp)
91fc8ec0b8Shaad {
92fc8ec0b8Shaad 
93fc8ec0b8Shaad 	return (vp->v_mount->mnt_flag & MNT_RDONLY);
94fc8ec0b8Shaad }
95fc8ec0b8Shaad 
96fc8ec0b8Shaad kthread_t *
solaris__thread_create(void * stk,size_t stksize,void (* proc)(),void * arg,size_t len,proc_t * pp,int state,pri_t pri,const char * name)97*e3c82a0cSriastradh solaris__thread_create(void * stk, size_t stksize, void (*proc)(), void *arg,
98*e3c82a0cSriastradh     size_t len, proc_t *pp, int state, pri_t pri, const char *name)
99fc8ec0b8Shaad {
100fc8ec0b8Shaad 	int error;
101fc8ec0b8Shaad 	lwp_t *thr;
102fc8ec0b8Shaad 
103eb632577Spooka 	//ASSERT(stk == NULL && stksize == 0 && len == 0);
104eb632577Spooka 	ASSERT(stk == NULL && len == 0);
105fc8ec0b8Shaad 	ASSERT(state == TS_RUN);
106fc8ec0b8Shaad 
107fc8ec0b8Shaad 	error = kthread_create(pri, KTHREAD_MPSAFE, NULL,
108*e3c82a0cSriastradh 	    proc, arg, &thr, "%s", name);
109fc8ec0b8Shaad 	KASSERT(error == 0);
110fc8ec0b8Shaad 	return thr;
111fc8ec0b8Shaad }
112fc8ec0b8Shaad 
113fc8ec0b8Shaad void
thread_exit(void)114fc8ec0b8Shaad thread_exit(void)
115fc8ec0b8Shaad {
116fc8ec0b8Shaad 
117fc8ec0b8Shaad 	kthread_exit(0);
118fc8ec0b8Shaad }
119fc8ec0b8Shaad 
120fc8ec0b8Shaad void
thread_join(uint64_t kid)121a3bfe6d9Shaad thread_join(uint64_t kid)
122a3bfe6d9Shaad {
123a3bfe6d9Shaad 
124a3bfe6d9Shaad 	return;
125a3bfe6d9Shaad }
126a3bfe6d9Shaad 
127a3bfe6d9Shaad void
kmem_reap(void)128fc8ec0b8Shaad kmem_reap(void)
129fc8ec0b8Shaad {
130fc8ec0b8Shaad 	int bufcnt;
131fc8ec0b8Shaad 	struct pool *pp;
132fc8ec0b8Shaad 
1334b8a875aSad 	bufcnt = uvmexp.freetarg - uvm_availmem(false);
134fc8ec0b8Shaad 	if (bufcnt < 0)
135fc8ec0b8Shaad 		bufcnt = 0;
136ba2539a9Schs 
137fc8ec0b8Shaad 	/*
138fc8ec0b8Shaad 	 * kill unused metadata buffers.
139fc8ec0b8Shaad 	 */
140fc8ec0b8Shaad 	mutex_enter(&bufcache_lock);
141fc8ec0b8Shaad 	buf_drain(bufcnt << PAGE_SHIFT);
142fc8ec0b8Shaad 	mutex_exit(&bufcache_lock);
143fc8ec0b8Shaad 
144fc8ec0b8Shaad 	/*
14557d7988fSjym 	 * drain the pools.
146fc8ec0b8Shaad 	 */
14757d7988fSjym 	pool_drain(&pp);
148fc8ec0b8Shaad }
149fc8ec0b8Shaad 
150fc8ec0b8Shaad /*
151fc8ec0b8Shaad  * Zero out the structure, set the size of the requested/returned bitmaps,
152fc8ec0b8Shaad  * set AT_XVATTR in the embedded vattr_t's va_mask, and set up the pointer
153fc8ec0b8Shaad  * to the returned attributes array.
154fc8ec0b8Shaad  */
155fc8ec0b8Shaad void
xva_init(xvattr_t * xvap)156fc8ec0b8Shaad xva_init(xvattr_t *xvap)
157fc8ec0b8Shaad {
158fc8ec0b8Shaad 	bzero(xvap, sizeof (xvattr_t));
159fc8ec0b8Shaad 	xvap->xva_mapsize = XVA_MAPSIZE;
160fc8ec0b8Shaad 	xvap->xva_magic = XVA_MAGIC;
161fc8ec0b8Shaad 	xvap->xva_vattr.va_mask = AT_XVATTR;
162fc8ec0b8Shaad 	xvap->xva_rtnattrmapp = &(xvap->xva_rtnattrmap)[0];
163fc8ec0b8Shaad }
164fc8ec0b8Shaad 
165fc8ec0b8Shaad 
166fc8ec0b8Shaad /*
167fc8ec0b8Shaad  * If AT_XVATTR is set, returns a pointer to the embedded xoptattr_t
168fc8ec0b8Shaad  * structure.  Otherwise, returns NULL.
169fc8ec0b8Shaad  */
170fc8ec0b8Shaad xoptattr_t *
xva_getxoptattr(xvattr_t * xvap)171fc8ec0b8Shaad xva_getxoptattr(xvattr_t *xvap)
172fc8ec0b8Shaad {
173fc8ec0b8Shaad 	xoptattr_t *xoap = NULL;
174fc8ec0b8Shaad 	if (xvap->xva_vattr.va_mask & AT_XVATTR)
175fc8ec0b8Shaad 		xoap = &xvap->xva_xoptattrs;
176fc8ec0b8Shaad 	return (xoap);
177fc8ec0b8Shaad }
178