File: [local] / sys / compat / linux / linux_dummy.c (download)
Revision 1.1.1.1 (vendor branch), Tue Mar 4 16:09:02 2008 UTC (16 years, 5 months ago) by nbrk
Branch: OPENBSD_4_2_BASE, MAIN
CVS Tags: jornada-partial-support-wip, HEAD Changes since 1.1: +0 -0 lines
Import of OpenBSD 4.2 release kernel tree with initial code to support
Jornada 720/728, StrongARM 1110-based handheld PC.
At this point kernel roots on NFS and boots into vfs_mountroot() and traps.
What is supported:
- glass console, Jornada framebuffer (jfb) works in 16bpp direct color mode
(needs some palette tweaks for non black/white/blue colors, i think)
- saic, SA11x0 interrupt controller (needs cleanup)
- sacom, SA11x0 UART (supported only as boot console for now)
- SA11x0 GPIO controller fully supported (but can't handle multiple interrupt
handlers on one gpio pin)
- sassp, SSP port on SA11x0 that attaches spibus
- Jornada microcontroller (jmcu) to control kbd, battery, etc throught
the SPI bus (wskbd attaches on jmcu, but not tested)
- tod functions seem work
- initial code for SA-1111 (chip companion) : this is TODO
Next important steps, i think:
- gpio and intc on sa1111
- pcmcia support for sa11x0 (and sa1111 help logic)
- REAL root on nfs when we have PCMCIA support (we may use any of supported pccard NICs)
- root on wd0! (using already supported PCMCIA-ATA)
|
/* $OpenBSD: linux_dummy.c,v 1.16 2004/10/27 13:23:38 niklas Exp $ */
/*-
* Copyright (c) 1994-1995 Søren Schmidt
* All rights reserved.
*
* Redistribution and use in source and binary forms, with or without
* modification, are permitted provided that the following conditions
* are met:
* 1. Redistributions of source code must retain the above copyright
* notice, this list of conditions and the following disclaimer
* in this position and unchanged.
* 2. Redistributions in binary form must reproduce the above copyright
* notice, this list of conditions and the following disclaimer in the
* documentation and/or other materials provided with the distribution.
* 3. The name of the author may not be used to endorse or promote products
* derived from this software without specific prior written permission
*
* THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR
* IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
* OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
* IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT,
* INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT
* NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
* DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
* THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
* (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF
* THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
*
* $FreeBSD: src/sys/i386/linux/linux_dummy.c,v 1.21 2000/01/29 12:45:35 peter Exp $
*/
#include <sys/param.h>
#include <sys/systm.h>
#include <sys/proc.h>
#include <compat/linux/linux_types.h>
#include <compat/linux/linux_signal.h>
#include <compat/linux/linux_syscallargs.h>
#define DUMMY(s) \
int \
linux_sys_ ## s(p, v, retval) \
struct proc *p; \
void *v; \
register_t *retval; \
{ \
return (unsupported_msg(p, #s)); \
}
static int
unsupported_msg(struct proc *p, const char *fname)
{
printf("linux: syscall %s is obsolete or not implemented (pid=%ld)\n",
fname, (long)p->p_pid);
return (ENOSYS);
}
DUMMY(ostat); /* #18 */
#ifdef PTRACE
DUMMY(ptrace); /* #26 */
#endif
DUMMY(ofstat); /* #28 */
DUMMY(stty); /* #31 */
DUMMY(gtty); /* #32 */
DUMMY(ftime); /* #35 */
DUMMY(prof); /* #44 */
DUMMY(phys); /* #52 */
DUMMY(lock); /* #53 */
DUMMY(mpx); /* #56 */
DUMMY(ulimit); /* #58 */
DUMMY(ustat); /* #62 */
#ifndef __i386__
DUMMY(ioperm); /* #101 */
#endif
DUMMY(klog); /* #103 */
#ifndef __i386__
DUMMY(iopl); /* #110 */
#endif
DUMMY(vhangup); /* #111 */
DUMMY(idle); /* #112 */
DUMMY(vm86old); /* #113 */
DUMMY(swapoff); /* #115 */
#ifndef __i386__
DUMMY(modify_ldt); /* #123 */
#endif
DUMMY(adjtimex); /* #124 */
DUMMY(create_module); /* #127 */
DUMMY(init_module); /* #128 */
DUMMY(delete_module); /* #129 */
DUMMY(get_kernel_syms); /* #130 */
DUMMY(quotactl); /* #131 */
DUMMY(bdflush); /* #134 */
DUMMY(sysfs); /* #135 */
DUMMY(afs_syscall); /* #137 */
DUMMY(mlockall); /* #152 */
DUMMY(munlockall); /* #153 */
DUMMY(sched_rr_get_interval); /* #161 */
DUMMY(vm86); /* #166 */
DUMMY(query_module); /* #167 */
DUMMY(nfsservctl); /* #169 */
DUMMY(prctl); /* #172 */
DUMMY(rt_sigtimedwait); /* #177 */
DUMMY(rt_queueinfo); /* #178 */
DUMMY(capget); /* #184 */
DUMMY(capset); /* #185 */
DUMMY(sendfile); /* #187 */
DUMMY(getpmsg); /* #188 */
DUMMY(putpmsg); /* #189 */
DUMMY(lchown); /* #198 */
DUMMY(fchown); /* #207 */
DUMMY(chown); /* #212 */
DUMMY(setfsgid); /* #216 */
DUMMY(pivot_root); /* #217 */
DUMMY(mincore); /* #218 */
DUMMY(fadvise64); /* #250 */
#define DUMMY_XATTR(s) \
int \
linux_sys_ ## s ## xattr(p, v, retval) \
struct proc *p; \
void *v; \
register_t *retval; \
{ \
return (ENOATTR); \
}
DUMMY_XATTR(set);
DUMMY_XATTR(lset);
DUMMY_XATTR(fset);
DUMMY_XATTR(get);
DUMMY_XATTR(lget);
DUMMY_XATTR(fget);
DUMMY_XATTR(list);
DUMMY_XATTR(llist);
DUMMY_XATTR(flist);
DUMMY_XATTR(remove);
DUMMY_XATTR(lremove);
DUMMY_XATTR(fremove);