Module Name:    src
Committed By:   macallan
Date:           Tue Feb 19 15:21:08 UTC 2013

Modified Files:
        src/sys/dev/wscons: wsdisplay_compat_usl.c

Log Message:
fix a bunch of _IO() ioctl()s to actually work on LP64/BE
( the data pointer is abused to pass an integer, we get a pointer to it so
  we need to deref it to something the same size as a pointer to get the
  correct value )
now the PCVT compat code ( which is used for VT switching in and out of X )
works on sparc64


To generate a diff of this commit:
cvs rdiff -u -r1.47 -r1.48 src/sys/dev/wscons/wsdisplay_compat_usl.c

Please note that diffs are not public domain; they are subject to the
copyright notices on the relevant files.

Modified files:

Index: src/sys/dev/wscons/wsdisplay_compat_usl.c
diff -u src/sys/dev/wscons/wsdisplay_compat_usl.c:1.47 src/sys/dev/wscons/wsdisplay_compat_usl.c:1.48
--- src/sys/dev/wscons/wsdisplay_compat_usl.c:1.47	Thu Jul  1 02:38:29 2010
+++ src/sys/dev/wscons/wsdisplay_compat_usl.c	Tue Feb 19 15:21:08 2013
@@ -1,4 +1,4 @@
-/* $NetBSD: wsdisplay_compat_usl.c,v 1.47 2010/07/01 02:38:29 rmind Exp $ */
+/* $NetBSD: wsdisplay_compat_usl.c,v 1.48 2013/02/19 15:21:08 macallan Exp $ */
 
 /*
  * Copyright (c) 1998
@@ -27,7 +27,7 @@
  */
 
 #include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: wsdisplay_compat_usl.c,v 1.47 2010/07/01 02:38:29 rmind Exp $");
+__KERNEL_RCSID(0, "$NetBSD: wsdisplay_compat_usl.c,v 1.48 2013/02/19 15:21:08 macallan Exp $");
 
 #include "opt_compat_freebsd.h"
 #include "opt_compat_netbsd.h"
@@ -449,7 +449,7 @@ wsdisplay_usl_ioctl2(struct wsdisplay_so
 	     */
 	    case KDSETMODE:
 		req = WSDISPLAYIO_SMODE;
-#define d (*(int *)data)
+#define d (*(long *)data)
 		switch (d) {
 		    case KD_GRAPHICS:
 			intarg = WSDISPLAYIO_MODE_MAPPED;
@@ -465,7 +465,7 @@ wsdisplay_usl_ioctl2(struct wsdisplay_so
 		break;
 	    case KDMKTONE:
 		req = WSKBDIO_COMPLEXBELL;
-#define d (*(int *)data)
+#define d (*(long *)data)
 		if (d) {
 #define PCVT_SYSBEEPF	1193182
 			if (d >> 16) {
@@ -486,7 +486,7 @@ wsdisplay_usl_ioctl2(struct wsdisplay_so
 	    case KDSETLED:
 		req = WSKBDIO_SETLEDS;
 		intarg = 0;
-#define d (*(int *)data)
+#define d (*(long *)data)
 		if (d & LED_CAP)
 			intarg |= WSKBD_LED_CAPS;
 		if (d & LED_NUM)
@@ -503,7 +503,7 @@ wsdisplay_usl_ioctl2(struct wsdisplay_so
 #ifdef WSDISPLAY_COMPAT_RAWKBD
 	    case KDSKBMODE:
 		req = WSKBDIO_SETMODE;
-		switch (*(int *)data) {
+		switch (*(long *)data) {
 		    case K_RAW:
 			intarg = WSKBD_RAW;
 			break;

Reply via email to