Deleted Added
full compact
kern_sysctl.c (3308) kern_sysctl.c (3396)
1/*-
2 * Copyright (c) 1982, 1986, 1989, 1993
3 * The Regents of the University of California. All rights reserved.
4 *
5 * This code is derived from software contributed to Berkeley by
6 * Mike Karels at Berkeley Software Design, Inc.
7 *
8 * Redistribution and use in source and binary forms, with or without

--- 20 unchanged lines hidden (view full) ---

29 * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
30 * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
31 * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
32 * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
33 * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
34 * SUCH DAMAGE.
35 *
36 * @(#)kern_sysctl.c 8.4 (Berkeley) 4/14/94
1/*-
2 * Copyright (c) 1982, 1986, 1989, 1993
3 * The Regents of the University of California. All rights reserved.
4 *
5 * This code is derived from software contributed to Berkeley by
6 * Mike Karels at Berkeley Software Design, Inc.
7 *
8 * Redistribution and use in source and binary forms, with or without

--- 20 unchanged lines hidden (view full) ---

29 * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
30 * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
31 * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
32 * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
33 * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
34 * SUCH DAMAGE.
35 *
36 * @(#)kern_sysctl.c 8.4 (Berkeley) 4/14/94
37 * $Id: kern_sysctl.c,v 1.15 1994/09/23 19:07:17 wollman Exp $
37 * $Id: kern_sysctl.c,v 1.16 1994/10/02 17:35:19 phk Exp $
38 */
39
40/*
41 * sysctl system call.
42 */
43
44#include <sys/param.h>
45#include <sys/systm.h>

--- 93 unchanged lines hidden (view full) ---

139 if (uap->oldlenp &&
140 (error = copyin(uap->oldlenp, &oldlen, sizeof(oldlen))))
141 return (error);
142 if (uap->old != NULL) {
143 if (!useracc(uap->old, oldlen, B_WRITE))
144 return (EFAULT);
145 while (memlock.sl_lock) {
146 memlock.sl_want = 1;
38 */
39
40/*
41 * sysctl system call.
42 */
43
44#include <sys/param.h>
45#include <sys/systm.h>

--- 93 unchanged lines hidden (view full) ---

139 if (uap->oldlenp &&
140 (error = copyin(uap->oldlenp, &oldlen, sizeof(oldlen))))
141 return (error);
142 if (uap->old != NULL) {
143 if (!useracc(uap->old, oldlen, B_WRITE))
144 return (EFAULT);
145 while (memlock.sl_lock) {
146 memlock.sl_want = 1;
147 sleep((caddr_t)&memlock, PRIBIO+1);
147 (void) tsleep((caddr_t)&memlock, PRIBIO+1, "sysctl", 0);
148 memlock.sl_locked++;
149 }
150 memlock.sl_lock = 1;
151 if (dolock)
152 vslock(uap->old, oldlen);
153 savelen = oldlen;
154 }
155 error = (*fn)(name + 1, uap->namelen - 1, uap->old, &oldlen,

--- 684 unchanged lines hidden ---
148 memlock.sl_locked++;
149 }
150 memlock.sl_lock = 1;
151 if (dolock)
152 vslock(uap->old, oldlen);
153 savelen = oldlen;
154 }
155 error = (*fn)(name + 1, uap->namelen - 1, uap->old, &oldlen,

--- 684 unchanged lines hidden ---