pkgsrc-Changes-HG archive

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

[pkgsrc/trunk]: pkgsrc/devel/SDL add wsmouse support to wscons driver



details:   https://anonhg.NetBSD.org/pkgsrc/rev/556becc86915
branches:  trunk
changeset: 645456:556becc86915
user:      jmcneill <jmcneill%pkgsrc.org@localhost>
date:      Thu Jan 29 01:56:02 2015 +0000

description:
add wsmouse support to wscons driver

diffstat:

 devel/SDL/distinfo                                              |    8 +-
 devel/SDL/patches/patch-src_video_wscons_SDL__wsconsevents.c    |  122 +++++++++-
 devel/SDL/patches/patch-src_video_wscons_SDL__wsconsevents__c.h |   13 +
 devel/SDL/patches/patch-src_video_wscons_SDL__wsconsvideo.c     |   65 ++++-
 devel/SDL/patches/patch-src_video_wscons_SDL__wsconsvideo.h     |   12 +
 5 files changed, 205 insertions(+), 15 deletions(-)

diffs (288 lines):

diff -r ec347d6388eb -r 556becc86915 devel/SDL/distinfo
--- a/devel/SDL/distinfo        Thu Jan 29 01:27:30 2015 +0000
+++ b/devel/SDL/distinfo        Thu Jan 29 01:56:02 2015 +0000
@@ -1,4 +1,4 @@
-$NetBSD: distinfo,v 1.67 2015/01/28 17:14:47 jmcneill Exp $
+$NetBSD: distinfo,v 1.68 2015/01/29 01:56:02 jmcneill Exp $
 
 SHA1 (SDL-1.2.15.tar.gz) = 0c5f193ced810b0d7ce3ab06d808cbb5eef03a2c
 RMD160 (SDL-1.2.15.tar.gz) = d4802a090cb4a24eeb0c8ce5690802f596d394c3
@@ -8,6 +8,8 @@
 SHA1 (patch-src_audio_sun_SDL__sunaudio.c) = 4b492b40d39e6444037dfda55766e4a149cc6c30
 SHA1 (patch-src_joystick_bsd_SDL__sysjoystick.c) = 4ea0136f231729129b82e5f7ee4b9eaf68a13876
 SHA1 (patch-src_video_quartz_SDL__QuartzVideo.h) = 19d952bade06dbd646e94f42139c38436969b1a8
-SHA1 (patch-src_video_wscons_SDL__wsconsevents.c) = 6ae894622078c2cc2a0add0b496944567d38f797
-SHA1 (patch-src_video_wscons_SDL__wsconsvideo.c) = 356a8817cc41dde5e24cb23f032215931f85a84b
+SHA1 (patch-src_video_wscons_SDL__wsconsevents.c) = f7519864e9c13ad69eae9a42df22a944586ab93b
+SHA1 (patch-src_video_wscons_SDL__wsconsevents__c.h) = 97206e2aca0b620005217d9d07ad1177516cac92
+SHA1 (patch-src_video_wscons_SDL__wsconsvideo.c) = 17e048ccb201ae961e820ab880d5a588b2db2639
+SHA1 (patch-src_video_wscons_SDL__wsconsvideo.h) = 82028df57cf3de95152278924ffe3134fe32f85a
 SHA1 (patch-src_video_x11_SDL_x11video.c) = 624fbb7e701d6de6ec93096beea7c085125934aa
diff -r ec347d6388eb -r 556becc86915 devel/SDL/patches/patch-src_video_wscons_SDL__wsconsevents.c
--- a/devel/SDL/patches/patch-src_video_wscons_SDL__wsconsevents.c      Thu Jan 29 01:27:30 2015 +0000
+++ b/devel/SDL/patches/patch-src_video_wscons_SDL__wsconsevents.c      Thu Jan 29 01:56:02 2015 +0000
@@ -1,6 +1,4 @@
-$NetBSD: patch-src_video_wscons_SDL__wsconsevents.c,v 1.5 2015/01/28 17:14:47 jmcneill Exp $
-
-Add support for USB keyboards on NetBSD.
+$NetBSD: patch-src_video_wscons_SDL__wsconsevents.c,v 1.6 2015/01/29 01:56:02 jmcneill Exp $
 
 --- src/video/wscons/SDL_wsconsevents.c.orig   2012-01-19 06:30:06.000000000 +0000
 +++ src/video/wscons/SDL_wsconsevents.c
@@ -18,7 +16,121 @@
    if (tcgetattr(private->fd, &private->saved_tty) == -1) {
      WSCONS_ReportError("cannot get terminal attributes: %s", strerror(errno));
      return -1;
-@@ -146,7 +153,72 @@ void WSCONS_InitOSKeymap(_THIS)
+@@ -65,6 +72,7 @@ int WSCONS_InitKeyboard(_THIS)
+     WSCONS_ReportError("cannot set terminal attributes: %s", strerror(errno));
+     return -1;
+   }
++
+   if (ioctl(private->fd, KDSKBMODE, K_RAW) == -1) {
+     WSCONS_ReportError("cannot set raw keyboard mode: %s", strerror(errno));
+     return -1;
+@@ -89,8 +97,57 @@ void WSCONS_ReleaseKeyboard(_THIS)
+   }
+ }
+ 
+-static void updateMouse()
++int WSCONS_InitMouse(_THIS)
++{
++  if (private->mouseFd != -1) {
++#if defined(WSMOUSEIO_SETVERSION)
++    int version = WSMOUSE_EVENT_VERSION;
++    if (ioctl(private->mouseFd, WSMOUSEIO_SETVERSION, &version) == -1) {
++      WSCONS_ReportError("cannot set mouse API version: %s", strerror(errno));
++      return -1;
++    }
++#endif
++  }
++  return 0;
++}
++
++void WSCONS_ReleaseMouse(_THIS)
++{
++}
++
++#define NUMEVENTS 64
++
++static void updateMouse(_THIS)
+ {
++  struct wscons_event evlist[NUMEVENTS];
++  struct wscons_event *ev = evlist;
++  int nev, i;
++  ssize_t len;
++
++  len = read(private->mouseFd, evlist, sizeof(evlist));
++  if (len == -1) {
++    WSCONS_ReportError("Failed to read wsmouse event: %s", strerror(errno));
++    return;
++  }
++
++  nev = len / sizeof(*ev);
++
++  for (i = 0; i < nev; i++, ev++) {
++    switch (ev->type) {
++    case WSCONS_EVENT_MOUSE_UP:
++      posted += SDL_PrivateMouseButton(SDL_RELEASED, ev->value+1, 0, 0);
++      break;
++    case WSCONS_EVENT_MOUSE_DOWN:
++      posted += SDL_PrivateMouseButton(SDL_PRESSED, ev->value+1, 0, 0);
++      break;
++    case WSCONS_EVENT_MOUSE_DELTA_X:
++      posted += SDL_PrivateMouseMotion(0, 1, ev->value, 0);
++      break;
++    case WSCONS_EVENT_MOUSE_DELTA_Y:
++      posted += SDL_PrivateMouseMotion(0, 1, 0, -ev->value);
++      break;
++    }
++  }
+ }
+ 
+ static SDLKey keymap[128];
+@@ -120,19 +177,42 @@ static void updateKeyboard(_THIS)
+     for (i = 0; i < n; i++) {
+       unsigned char c = buf[i] & 0x7f;
+       if (c == 224) // special key prefix -- what should we do with it?
+-      continue;
++       continue;
+       posted += SDL_PrivateKeyboard((buf[i] & 0x80) ? SDL_RELEASED : SDL_PRESSED,
+-                                  TranslateKey(c, &keysym));
++                                   TranslateKey(c, &keysym));
+     }
+   }
+ }
+ 
+ void WSCONS_PumpEvents(_THIS)
+ {
++  static struct timeval zero;
++  int maxfd = 0;
++
++  if (private->fd > maxfd)
++    maxfd = private->fd;
++  if (private->mouseFd > maxfd)
++    maxfd = private->mouseFd;
++
+   do {
++    fd_set fds;
++
+     posted = 0;
+-    updateMouse();
+-    updateKeyboard(this);
++
++    FD_ZERO(&fds);
++    if (private->fd != -1)
++      FD_SET(private->fd, &fds);
++    if (private->mouseFd != -1)
++      FD_SET(private->mouseFd, &fds);
++
++    if (select(maxfd+1, &fds, NULL, NULL, &zero) > 0) {
++      if (private->mouseFd != -1 && FD_ISSET(private->mouseFd, &fds)) {
++        updateMouse(this);
++      }
++      if (private->fd != -1 && FD_ISSET(private->fd, &fds)) {
++        updateKeyboard(this);
++      }
++    }
+   } while (posted);
+ }
+ 
+@@ -146,7 +226,72 @@ void WSCONS_InitOSKeymap(_THIS)
    }
  
    switch (private->kbdType) {
@@ -92,7 +204,7 @@
    case WSKBD_TYPE_ZAURUS:
      /* top row */
      keymap[2] = SDLK_1;
-@@ -220,7 +292,7 @@ void WSCONS_InitOSKeymap(_THIS)
+@@ -220,7 +365,7 @@ void WSCONS_InitOSKeymap(_THIS)
      keymap[77] = SDLK_RIGHT;
      keymap[80] = SDLK_DOWN;
      break;
diff -r ec347d6388eb -r 556becc86915 devel/SDL/patches/patch-src_video_wscons_SDL__wsconsevents__c.h
--- /dev/null   Thu Jan 01 00:00:00 1970 +0000
+++ b/devel/SDL/patches/patch-src_video_wscons_SDL__wsconsevents__c.h   Thu Jan 29 01:56:02 2015 +0000
@@ -0,0 +1,13 @@
+$NetBSD: patch-src_video_wscons_SDL__wsconsevents__c.h,v 1.1 2015/01/29 01:56:23 jmcneill Exp $
+
+--- src/video/wscons/SDL_wsconsevents_c.h.orig 2012-01-19 06:30:06.000000000 +0000
++++ src/video/wscons/SDL_wsconsevents_c.h
+@@ -25,6 +25,8 @@
+ 
+ int WSCONS_InitKeyboard(_THIS);
+ void WSCONS_ReleaseKeyboard(_THIS);
++int WSCONS_InitMouse(_THIS);
++void WSCONS_ReleaseMouse(_THIS);
+ 
+ /* Variables and functions exported by SDL_sysevents.c to other parts 
+    of the native video subsystem (SDL_sysvideo.c)
diff -r ec347d6388eb -r 556becc86915 devel/SDL/patches/patch-src_video_wscons_SDL__wsconsvideo.c
--- a/devel/SDL/patches/patch-src_video_wscons_SDL__wsconsvideo.c       Thu Jan 29 01:27:30 2015 +0000
+++ b/devel/SDL/patches/patch-src_video_wscons_SDL__wsconsvideo.c       Thu Jan 29 01:56:02 2015 +0000
@@ -1,10 +1,8 @@
-$NetBSD: patch-src_video_wscons_SDL__wsconsvideo.c,v 1.3 2012/01/24 15:17:05 wiz Exp $
-
-Fix tty device and color patterns for wscons driver on NetBSD.
+$NetBSD: patch-src_video_wscons_SDL__wsconsvideo.c,v 1.4 2015/01/29 01:56:02 jmcneill Exp $
 
---- src/video/wscons/SDL_wsconsvideo.c.orig    2009-10-12 23:07:14.000000000 +0000
+--- src/video/wscons/SDL_wsconsvideo.c.orig    2012-01-19 06:30:06.000000000 +0000
 +++ src/video/wscons/SDL_wsconsvideo.c
-@@ -141,7 +141,13 @@ VideoBootStrap WSCONS_bootstrap = {
+@@ -141,12 +141,18 @@ VideoBootStrap WSCONS_bootstrap = {
    WSCONS_CreateDevice
  };
  
@@ -18,7 +16,37 @@
  
  int WSCONS_VideoInit(_THIS, SDL_PixelFormat *vformat)
  {
-@@ -184,6 +190,11 @@ int WSCONS_VideoInit(_THIS, SDL_PixelFor
+   char devnamebuf[30];
+-  char *devname;
++  char *devname, *mouse_devname;
+   char *rotation;
+   int wstype;
+   int wsmode = WSDISPLAYIO_MODE_DUMBFB;
+@@ -166,11 +172,23 @@ int WSCONS_VideoInit(_THIS, SDL_PixelFor
+     devname = devnamebuf;
+   }
+ 
++  mouse_devname = SDL_getenv("SDL_WSMOUSEDEV");
++  if (mouse_devname == NULL) {
++    mouse_devname = "/dev/wsmouse";
++  }
++
+   private->fd = open(devname, O_RDWR | O_NONBLOCK, 0);
+   if (private->fd == -1) {
+     WSCONS_ReportError("open %s: %s", devname, strerror(errno));
+     return -1;
+   }
++
++  private->mouseFd = open(mouse_devname, O_RDWR | O_NONBLOCK, 0);
++  if (private->mouseFd == -1) {
++    WSCONS_ReportError("open %s: %s", mouse_devname, strerror(errno));
++    return -1;
++  }
++
+   if (ioctl(private->fd, WSDISPLAYIO_GINFO, &private->info) == -1) {
+     WSCONS_ReportError("ioctl WSDISPLAY_GINFO: %s", strerror(errno));
+     return -1;
+@@ -184,6 +202,11 @@ int WSCONS_VideoInit(_THIS, SDL_PixelFor
      return -1;
    }
    if (private->info.depth > 8) {
@@ -30,7 +58,7 @@
      if (wstype == WSDISPLAY_TYPE_SUN24 ||
        wstype == WSDISPLAY_TYPE_SUNCG12 ||
        wstype == WSDISPLAY_TYPE_SUNCG14 ||
-@@ -202,6 +213,7 @@ int WSCONS_VideoInit(_THIS, SDL_PixelFor
+@@ -202,6 +225,7 @@ int WSCONS_VideoInit(_THIS, SDL_PixelFor
        WSCONS_ReportError("Unknown video hardware");
        return -1;
      }
@@ -38,3 +66,26 @@
    } else {
      WSCONS_ReportError("Displays with 8 bpp or less are not supported");
      return -1;
+@@ -326,6 +350,9 @@ int WSCONS_VideoInit(_THIS, SDL_PixelFor
+   if (WSCONS_InitKeyboard(this) == -1) {
+     return -1;
+   }
++  if (WSCONS_InitMouse(this) == -1) {
++    return -1;
++  }
+   
+   return 0;
+ }
+@@ -601,7 +628,12 @@ void WSCONS_VideoQuit(_THIS)
+   }
+ 
+   WSCONS_ReleaseKeyboard(this);
++  WSCONS_ReleaseMouse(this);
+ 
++  if (private->mouseFd != -1) {
++    close(private->mouseFd);
++    private->mouseFd = -1;
++  }
+   if (private->fd != -1) {
+     close(private->fd);
+     private->fd = -1;
diff -r ec347d6388eb -r 556becc86915 devel/SDL/patches/patch-src_video_wscons_SDL__wsconsvideo.h
--- /dev/null   Thu Jan 01 00:00:00 1970 +0000
+++ b/devel/SDL/patches/patch-src_video_wscons_SDL__wsconsvideo.h       Thu Jan 29 01:56:02 2015 +0000
@@ -0,0 +1,12 @@
+$NetBSD: patch-src_video_wscons_SDL__wsconsvideo.h,v 1.1 2015/01/29 01:56:23 jmcneill Exp $
+
+--- src/video/wscons/SDL_wsconsvideo.h.orig    2012-01-19 06:30:06.000000000 +0000
++++ src/video/wscons/SDL_wsconsvideo.h
+@@ -50,6 +50,7 @@ typedef void WSCONS_bitBlit(Uint8 *src_p
+ 
+ struct SDL_PrivateVideoData {
+   int fd;                       /* file descriptor of open device */
++  int mouseFd;                        /* file descriptor of open mouse device */
+   struct wsdisplay_fbinfo info; /* frame buffer characteristics */
+   int physlinebytes;            /* number of bytes per row */
+   int redMask, greenMask, blueMask;



Home | Main Index | Thread Index | Old Index