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