1e02f64d9SBrooks Davis /*-
2*4d846d26SWarner Losh * SPDX-License-Identifier: BSD-2-Clause
3e02f64d9SBrooks Davis *
4e02f64d9SBrooks Davis * Copyright (c) 2005 Wojciech A. Koszek
5e02f64d9SBrooks Davis * All rights reserved.
6e02f64d9SBrooks Davis *
7e02f64d9SBrooks Davis * Redistribution and use in source and binary forms, with or without
8e02f64d9SBrooks Davis * modification, are permitted provided that the following conditions
9e02f64d9SBrooks Davis * are met:
10e02f64d9SBrooks Davis * 1. Redistributions of source code must retain the above copyright
11e02f64d9SBrooks Davis * notice, this list of conditions and the following disclaimer.
12e02f64d9SBrooks Davis * 2. Redistributions in binary form must reproduce the above copyright
13e02f64d9SBrooks Davis * notice, this list of conditions and the following disclaimer in the
14e02f64d9SBrooks Davis * documentation and/or other materials provided with the distribution.
15e02f64d9SBrooks Davis *
16e02f64d9SBrooks Davis * THIS SOFTWARE IS PROVIDED BY THE AUTHOR AND CONTRIBUTORS ``AS IS'' AND
17e02f64d9SBrooks Davis * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
18e02f64d9SBrooks Davis * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
19e02f64d9SBrooks Davis * ARE DISCLAIMED. IN NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS BE LIABLE
20e02f64d9SBrooks Davis * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
21e02f64d9SBrooks Davis * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
22e02f64d9SBrooks Davis * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
23e02f64d9SBrooks Davis * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
24e02f64d9SBrooks Davis * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
25e02f64d9SBrooks Davis * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
26e02f64d9SBrooks Davis * SUCH DAMAGE.
27e02f64d9SBrooks Davis */
28e02f64d9SBrooks Davis
29e02f64d9SBrooks Davis #include <sys/param.h>
30e02f64d9SBrooks Davis #include <sys/proc.h>
31e02f64d9SBrooks Davis #include <sys/sbuf.h>
32e02f64d9SBrooks Davis #include <sys/syscallsubr.h>
33e02f64d9SBrooks Davis #include <sys/syslog.h>
34e02f64d9SBrooks Davis
35e02f64d9SBrooks Davis #include <compat/freebsd32/freebsd32_proto.h>
36e02f64d9SBrooks Davis
37e02f64d9SBrooks Davis int
freebsd32_abort2(struct thread * td,struct freebsd32_abort2_args * uap)38e02f64d9SBrooks Davis freebsd32_abort2(struct thread *td, struct freebsd32_abort2_args *uap)
39e02f64d9SBrooks Davis {
40e02f64d9SBrooks Davis void *uargs[16];
41e02f64d9SBrooks Davis void *uargsp;
42e02f64d9SBrooks Davis uint32_t *uargsptr;
43e02f64d9SBrooks Davis uint32_t ptr;
44e02f64d9SBrooks Davis int i, nargs;
45e02f64d9SBrooks Davis
46e02f64d9SBrooks Davis nargs = uap->nargs;
47e02f64d9SBrooks Davis if (nargs < 0 || nargs > nitems(uargs))
48e02f64d9SBrooks Davis nargs = -1;
49e02f64d9SBrooks Davis uargsp = NULL;
50e02f64d9SBrooks Davis if (nargs > 0) {
51e02f64d9SBrooks Davis if (uap->args != NULL) {
52e02f64d9SBrooks Davis uargsptr = uap->args;
53e02f64d9SBrooks Davis for (i = 0; i < nargs; i++) {
54e02f64d9SBrooks Davis if (fueword32(uargsptr + i, &ptr) != 0) {
55e02f64d9SBrooks Davis nargs = -1;
56e02f64d9SBrooks Davis break;
57e02f64d9SBrooks Davis } else
58e02f64d9SBrooks Davis uargs[i] = (void *)(uintptr_t)ptr;
59e02f64d9SBrooks Davis }
60e02f64d9SBrooks Davis if (nargs > 0)
61e02f64d9SBrooks Davis uargsp = &uargs;
62e02f64d9SBrooks Davis } else
63e02f64d9SBrooks Davis nargs = -1;
64e02f64d9SBrooks Davis }
65e02f64d9SBrooks Davis return (kern_abort2(td, uap->why, nargs, uargsp));
66e02f64d9SBrooks Davis }
67