Source-Changes-HG archive

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index][Old Index]

[src/trunk]: src/sys/compat/linux/common The gist of the Linux _IOX definitio...



details:   https://anonhg.NetBSD.org/src/rev/2255ab1047a9
branches:  trunk
changeset: 500338:2255ab1047a9
user:      fvdl <fvdl%NetBSD.org@localhost>
date:      Sun Dec 10 14:08:48 2000 +0000

description:
The gist of the Linux _IOX definitions was the same for all platforms;
move it to the MI linux_ioctl.h and only leave the MD bits in the MD
header files.

Add defintions for linux_ioctl_hdio and linux_ioctl_fdio.

diffstat:

 sys/compat/linux/common/linux_ioctl.h |  41 ++++++++++++++++++++++++++++++++++-
 1 files changed, 40 insertions(+), 1 deletions(-)

diffs (60 lines):

diff -r 3faed8bd3a1f -r 2255ab1047a9 sys/compat/linux/common/linux_ioctl.h
--- a/sys/compat/linux/common/linux_ioctl.h     Sun Dec 10 14:07:22 2000 +0000
+++ b/sys/compat/linux/common/linux_ioctl.h     Sun Dec 10 14:08:48 2000 +0000
@@ -1,4 +1,4 @@
-/*     $NetBSD: linux_ioctl.h,v 1.11 1998/12/15 19:31:39 itohy Exp $   */
+/*     $NetBSD: linux_ioctl.h,v 1.12 2000/12/10 14:08:48 fvdl Exp $    */
 
 /*-
  * Copyright (c) 1995, 1998 The NetBSD Foundation, Inc.
@@ -50,6 +50,10 @@
     register_t *));
 int linux_ioctl_socket __P((struct proc *, struct linux_sys_ioctl_args *,
     register_t *));
+int linux_ioctl_hdio __P((struct proc *, struct linux_sys_ioctl_args *,
+    register_t *));
+int linux_ioctl_fdio __P((struct proc *p, struct linux_sys_ioctl_args *uap, 
+                 register_t *retval));
 __END_DECLS
 #endif /* !_KERNEL */
 
@@ -63,4 +67,39 @@
 #error Undefined linux_ioctl.h machine type.
 #endif
 
+#define        _LINUX_IOC_NRMASK       ((1 << _LINUX_IOC_NRBITS) - 1)
+#define        _LINUX_IOC_TYPEMASK     ((1 << _LINUX_IOC_TYPEBITS) - 1)
+#define        _LINUX_IOC_SIZEMAEK     ((1 << _LINUX_IOC_SIZEBITS) - 1)
+#define _LINUX_IOC_DIRMASK     ((1 << _LINUX_IOC_DIRBITS) - 1)
+
+#define        _LINUX_IOC_TYPESHIFT    (_LINUX_IOC_NRSHIFT + _LINUX_IOC_NRBITS)
+#define        _LINUX_IOC_SIZESHIFT    (_LINUX_IOC_TYPESHIFT + _LINUX_IOC_TYPEBITS)
+#define        _LINUX_IOC_DIRSHIFT     (_LINUX_IOC_SIZESHIFT + _LINUX_IOC_SIZEBITS)
+
+#define        _LINUX_IOC(dir,type,nr,size)            \
+       (((nr)   << _LINUX_IOC_NRSHIFT) |       \
+        ((type) << _LINUX_IOC_TYPESHIFT) |     \
+        ((size) << _LINUX_IOC_SIZESHIFT) |     \
+        ((dir)  << _LINUX_IOC_DIRSHIFT))
+
+#define _LINUX_IO(type,nr)             \
+       _LINUX_IOC(_LINUX_IOC_NONE,(type),(nr),0)
+#define        _LINUX_IOR(type,nr,size)        \
+       _LINUX_IOC(_LINUX_IOC_READ,(type),(nr),sizeof(size))
+#define        _LINUX_IOW(type,nr,size)        \
+       _LINUX_IOC(_LINUX_IOC_WRITE,(type),(nr),sizeof(size))
+#define        _LINUX_IOWR(type,nr,size)       \
+       _LINUX_IOC(_LINUX_IOC_READ|_LINUX_IOC_WRITE,(type),(nr),sizeof(size))
+
+#define _LINUX_IOC_DIR(nr)     \
+       (((nr) >> _LINUX_IOC_DIRSHIFT) & _LINUX_IOC_DIRMASK)
+#define _LINUX_IOC_TYPE(nr)    \
+       (((nr) >> _LINUX_IOC_TYPESHIFT) & _LINUX_IOC_TYPEMASK)
+#define _LINUX_IOC_NR(nr)      \
+       (((nr) >> _LINUX_IOC_NRSHIFT) & _LINUX_IOC_NRMASK)
+#define _LINUX_IOC_SIZE(nr)    \
+       (((nr) >> _LINUX_IOC_SIZESHIFT) & _LINUX_IOC_SIZEMASK)
+
+#define LINUX_IOCGROUP(x)      _LINUX_IOC_TYPE(x)
+
 #endif /* !_LINUX_IOCTL_H */



Home | Main Index | Thread Index | Old Index