summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
Diffstat (limited to 'media-libs/freeglut/files/freeglut-3.0.0-bsd-usb-joystick.patch')
-rw-r--r--media-libs/freeglut/files/freeglut-3.0.0-bsd-usb-joystick.patch753
1 files changed, 0 insertions, 753 deletions
diff --git a/media-libs/freeglut/files/freeglut-3.0.0-bsd-usb-joystick.patch b/media-libs/freeglut/files/freeglut-3.0.0-bsd-usb-joystick.patch
deleted file mode 100644
index 505b3467ec46..000000000000
--- a/media-libs/freeglut/files/freeglut-3.0.0-bsd-usb-joystick.patch
+++ /dev/null
@@ -1,753 +0,0 @@
-From 5908c36a4a3964cdc8db5c7bfdfd4381ec0996df Mon Sep 17 00:00:00 2001
-From: dcnieho <dcnieho@7f0cb862-5218-0410-a997-914c9d46530a>
-Date: Wed, 12 Jul 2017 20:44:35 +0000
-Subject: [PATCH] Fix build on NetBSD.
-
-(cherry picked from commit 06e1d815cf9abda49b845754ff420734446eb95b)
-
-(cherry picked from commit c4294ad59093c27159ea6028d33e3c9581df5354)
-
-git-svn-id: http://svn.code.sf.net/p/freeglut/code/trunk/freeglut/freeglut@1829 7f0cb862-5218-0410-a997-914c9d46530a
----
- src/fg_joystick.c | 5 ++---
- src/x11/fg_joystick_x11.c | 10 +++++-----
- 2 files changed, 7 insertions(+), 8 deletions(-)
-
-diff --git a/src/fg_joystick.c b/src/fg_joystick.c
-index 6f6771c..b73d7e7 100644
---- a/src/fg_joystick.c
-+++ b/src/fg_joystick.c
-@@ -46,21 +46,20 @@
-
- # ifdef HAVE_USB_JS
- # if defined(__NetBSD__)
--/* XXX The below hack is done until freeglut's autoconf is updated. */
--# define HAVE_USBHID_H 1
- # ifdef HAVE_USBHID_H
- # include <usbhid.h>
- # else
- # include <usb.h>
- # endif
-+# include <dev/usb/usb.h>
- # elif defined(__FreeBSD__) || defined(__FreeBSD_kernel__)
- # ifdef HAVE_USBHID_H
- # include <usbhid.h>
- # else
- # include <libusbhid.h>
- # endif
-+# include <legacy/dev/usb/usb.h>
- # endif
--# include <legacy/dev/usb/usb.h>
- # include <dev/usb/usbhid.h>
-
- /* Compatibility with older usb.h revisions */
-diff --git a/src/x11/fg_joystick_x11.c b/src/x11/fg_joystick_x11.c
-index a37388b..04bc373 100644
---- a/src/x11/fg_joystick_x11.c
-+++ b/src/x11/fg_joystick_x11.c
-@@ -50,7 +50,7 @@ void fgPlatformJoystickRawRead( SFG_Joystick* joy, int* buttons, float* axes )
- {
- int status;
-
--#if defined(__FreeBSD__) || defined(__FreeBSD_kernel__) || defined(__NetBSD__)
-+#if defined(__FreeBSD__) || defined(__FreeBSD_kernel__)
- int len;
-
- if ( joy->pJoystick.os->is_analog )
-@@ -215,7 +215,7 @@ void fgPlatformJoystickRawRead( SFG_Joystick* joy, int* buttons, float* axes )
-
- void fgPlatformJoystickOpen( SFG_Joystick* joy )
- {
--#if defined( __FreeBSD__ ) || defined(__FreeBSD_kernel__) || defined( __NetBSD__ )
-+#if defined( __FreeBSD__ ) || defined(__FreeBSD_kernel__)
- int i = 0;
- char *cp;
- #endif
-@@ -229,7 +229,7 @@ void fgPlatformJoystickOpen( SFG_Joystick* joy )
- # endif
- #endif
-
--#if defined( __FreeBSD__ ) || defined(__FreeBSD_kernel__) || defined( __NetBSD__ )
-+#if defined( __FreeBSD__ ) || defined(__FreeBSD_kernel__)
- for( i = 0; i < _JS_MAX_AXES; i++ )
- joy->pJoystick.os->cache_axes[ i ] = 0.0f;
-
-@@ -409,7 +409,7 @@ void fgPlatformJoystickOpen( SFG_Joystick* joy )
-
- void fgPlatformJoystickInit( SFG_Joystick *fgJoystick[], int ident )
- {
--#if defined( __FreeBSD__ ) || defined(__FreeBSD_kernel__) || defined( __NetBSD__ )
-+#if defined( __FreeBSD__ ) || defined(__FreeBSD_kernel__)
- fgJoystick[ ident ]->id = ident;
- fgJoystick[ ident ]->error = GL_FALSE;
-
-@@ -436,7 +436,7 @@ void fgPlatformJoystickInit( SFG_Joystick *fgJoystick[], int ident )
-
- void fgPlatformJoystickClose ( int ident )
- {
--#if defined( __FreeBSD__ ) || defined(__FreeBSD_kernel__) || defined( __NetBSD__ )
-+#if defined( __FreeBSD__ ) || defined(__FreeBSD_kernel__)
- if( fgJoystick[ident]->pJoystick.os )
- {
- if( ! fgJoystick[ ident ]->error )
---
-2.19.2
-
-From c0f0f1e0903a5dd848825db0fe1f01d5db37c4e1 Mon Sep 17 00:00:00 2001
-From: dcnieho <dcnieho@7f0cb862-5218-0410-a997-914c9d46530a>
-Date: Wed, 12 Jul 2017 20:44:47 +0000
-Subject: [PATCH] some whitespace cleanup
-
-(cherry picked from commit 2dd5aa4aa1b5c19392f9abd00e0f6893907df205)
-
-git-svn-id: http://svn.code.sf.net/p/freeglut/code/trunk/freeglut/freeglut@1830 7f0cb862-5218-0410-a997-914c9d46530a
----
- src/fg_init.c | 32 ++--
- src/fg_joystick.c | 8 +-
- src/fg_main.c | 14 +-
- src/freeglutdll.def.in | 312 +++++++++++++++++-----------------
- src/mswin/fg_joystick_mswin.c | 2 +-
- src/mswin/fg_main_mswin.c | 160 ++++++++---------
- 6 files changed, 264 insertions(+), 264 deletions(-)
-
-diff --git a/src/fg_joystick.c b/src/fg_joystick.c
-index b73d7e7..2f4f6ed 100644
---- a/src/fg_joystick.c
-+++ b/src/fg_joystick.c
-@@ -581,7 +581,7 @@ void fgPlatformJoystickRawRead( SFG_Joystick* joy, int* buttons, float* axes )
-
- void fgPlatformJoystickOpen( SFG_Joystick* joy )
- {
-- int i = 0;
-+ int i = 0;
- OSStatus err;
-
- /* XXX FIXME: get joystick name in Mac */
-@@ -856,7 +856,7 @@ static void fghJoystickOpen( SFG_Joystick* joy )
- joy->num_axes = joy->num_buttons = 0;
- joy->name[ 0 ] = '\0';
-
-- fgPlatformJoystickOpen ( joy );
-+ fgPlatformJoystickOpen ( joy );
-
- }
-
-@@ -878,7 +878,7 @@ static void fghJoystickInit( int ident )
- fgJoystick[ ident ]->num_axes = fgJoystick[ ident ]->num_buttons = 0;
- fgJoystick[ ident ]->error = GL_TRUE;
-
-- fgPlatformJoystickInit( fgJoystick, ident );
-+ fgPlatformJoystickInit( fgJoystick, ident );
-
- fghJoystickOpen( fgJoystick[ ident ] );
- }
-@@ -906,7 +906,7 @@ void fgJoystickClose( void )
- {
- if( fgJoystick[ ident ] )
- {
-- fgPlatformJoystickClose ( ident );
-+ fgPlatformJoystickClose ( ident );
-
- free( fgJoystick[ ident ] );
- fgJoystick[ ident ] = NULL;
---
-2.19.2
-
-From 6096caf2468ad4557968b9156ea9fcab2efb3fd1 Mon Sep 17 00:00:00 2001
-From: dcnieho <dcnieho@7f0cb862-5218-0410-a997-914c9d46530a>
-Date: Wed, 12 Jul 2017 20:45:07 +0000
-Subject: [PATCH] moved static variables and functions that should not have
- stuck behind in fg_joystick.c, but should have been in fg_joystick_x11.c
-
-(cherry picked from commit 0d98472817921dc95d070f13bba59b72d792a7b2)
-
-git-svn-id: http://svn.code.sf.net/p/freeglut/code/trunk/freeglut/freeglut@1832 7f0cb862-5218-0410-a997-914c9d46530a
----
- src/fg_joystick.c | 173 ----------------------------------
- src/x11/fg_joystick_x11.c | 190 +++++++++++++++++++++++++++++++++++++-
- 2 files changed, 185 insertions(+), 178 deletions(-)
-
-diff --git a/src/fg_joystick.c b/src/fg_joystick.c
-index 2f4f6ed..e548c04 100644
---- a/src/fg_joystick.c
-+++ b/src/fg_joystick.c
-@@ -68,8 +68,6 @@
- # endif
- # endif
-
--static int hatmap_x[9] = { 0, 0, 1, 1, 1, 0, -1, -1, -1 };
--static int hatmap_y[9] = { 0, 1, 1, 0, -1, -1, -1, 0, 1 };
- struct os_specific_s {
- char fname [128 ];
- int fd;
-@@ -98,178 +96,7 @@ struct os_specific_s {
- # define UHIDDEV "/dev/uhid"
- # define AJSDEV "/dev/joy"
-
--# ifdef HAVE_USB_JS
--/*
-- * fghJoystickFindUSBdev (and its helper, fghJoystickWalkUSBdev) try to locate
-- * the full name of a USB device. If /dev/usbN isn't readable, we punt and
-- * return the uhidN device name. We warn the user of this situation once.
-- */
--static char *fghJoystickWalkUSBdev(int f, char *dev, char *out, int outlen)
--{
-- struct usb_device_info di;
-- int i, a;
-- char *cp;
--
-- for (a = 1; a < USB_MAX_DEVICES; a++) {
-- di.udi_addr = a;
-- if (ioctl(f, USB_DEVICEINFO, &di) != 0)
-- return NULL;
-- for (i = 0; i < USB_MAX_DEVNAMES; i++)
-- if (di.udi_devnames[i][0] &&
-- strcmp(di.udi_devnames[i], dev) == 0) {
-- cp = calloc( 1, strlen(di.udi_vendor) + strlen(di.udi_product) + 2);
-- strcpy(cp, di.udi_vendor);
-- strcat(cp, " ");
-- strcat(cp, di.udi_product);
-- strncpy(out, cp, outlen - 1);
-- out[outlen - 1] = 0;
-- free( cp );
-- return out;
-- }
-- }
-- return NULL;
--}
--
--static int fghJoystickFindUSBdev(char *name, char *out, int outlen)
--{
-- int i, f;
-- char buf[50];
-- char *cp;
-- static int protection_warned = 0;
--
-- for (i = 0; i < 16; i++) {
-- snprintf(buf, sizeof(buf), "%s%d", USBDEV, i);
-- f = open(buf, O_RDONLY);
-- if (f >= 0) {
-- cp = fghJoystickWalkUSBdev(f, name, out, outlen);
-- close(f);
-- if (cp)
-- return 1;
-- }
-- else if (errno == EACCES) {
-- if (!protection_warned) {
-- fgWarning ( "Can't open %s for read!", buf );
-- protection_warned = 1;
-- }
-- }
-- }
-- return 0;
--}
-
--static int fghJoystickInitializeHID(struct os_specific_s *os,
-- int *num_axes, int *num_buttons)
--{
-- int size, is_joystick;
--# ifdef HAVE_USBHID_H
-- int report_id = 0;
--# endif
-- struct hid_data *d;
-- struct hid_item h;
-- report_desc_t rd;
--
-- if ( ( rd = hid_get_report_desc( os->fd ) ) == 0 )
-- {
-- fgWarning ( "error: %s: %s", os->fname, strerror( errno ) );
-- return FALSE;
-- }
--
-- os->hids = NULL;
--
--# ifdef HAVE_USBHID_H
-- if( ioctl( os->fd, USB_GET_REPORT_ID, &report_id ) < 0)
-- {
-- /*** XXX {report_id} may not be the right variable? ***/
-- fgWarning ( "error: %s%d: %s", UHIDDEV, report_id, strerror( errno ) );
-- return FALSE;
-- }
--
-- size = hid_report_size( rd, hid_input, report_id );
--# else
-- size = hid_report_size( rd, 0, hid_input );
--# endif
-- os->hid_data_buf = calloc( 1, size );
-- os->hid_dlen = size;
--
-- is_joystick = 0;
--# ifdef HAVE_USBHID_H
-- d = hid_start_parse( rd, 1 << hid_input, report_id );
--# else
-- d = hid_start_parse( rd, 1 << hid_input );
--# endif
-- while( hid_get_item( d, &h ) )
-- {
-- int usage, page, interesting_hid;
--
-- page = HID_PAGE( h.usage );
-- usage = HID_USAGE( h.usage );
--
-- /* This test is somewhat too simplistic, but this is how MicroSoft
-- * does, so I guess it works for all joysticks/game pads. */
-- is_joystick = is_joystick ||
-- ( h.kind == hid_collection &&
-- page == HUP_GENERIC_DESKTOP &&
-- ( usage == HUG_JOYSTICK || usage == HUG_GAME_PAD ) );
--
-- if( h.kind != hid_input )
-- continue;
--
-- if( !is_joystick )
-- continue;
--
-- interesting_hid = TRUE;
-- if( page == HUP_GENERIC_DESKTOP )
-- {
-- switch( usage )
-- {
-- case HUG_X:
-- case HUG_RX:
-- case HUG_Y:
-- case HUG_RY:
-- case HUG_Z:
-- case HUG_RZ:
-- case HUG_SLIDER:
-- if( *num_axes < _JS_MAX_AXES )
-- {
-- os->axes_usage[ *num_axes ] = usage;
-- ( *num_axes )++;
-- }
-- break;
-- case HUG_HAT_SWITCH:
-- /* Allocate two axes for a hat */
-- if( *num_axes + 1 < _JS_MAX_AXES )
-- {
-- os->axes_usage[ *num_axes ] = usage;
-- (*num_axes)++;
-- os->axes_usage[ *num_axes ] = usage;
-- (*num_axes)++;
-- }
-- break;
-- default:
-- interesting_hid = FALSE;
-- break;
-- }
-- }
-- else if( page == HUP_BUTTON )
-- {
-- interesting_hid = ( usage > 0 ) &&
-- ( usage <= _JS_MAX_BUTTONS );
--
-- if( interesting_hid && usage - 1 > *num_buttons )
-- *num_buttons = usage - 1;
-- }
--
-- if( interesting_hid )
-- {
-- h.next = os->hids;
-- os->hids = calloc( 1, sizeof ( struct hid_item ) );
-- *os->hids = h;
-- }
-- }
-- hid_end_parse( d );
--
-- return os->hids != NULL;
--}
--# endif
- #endif
-
- /*
-diff --git a/src/x11/fg_joystick_x11.c b/src/x11/fg_joystick_x11.c
-index 04bc373..30ad4b5 100644
---- a/src/x11/fg_joystick_x11.c
-+++ b/src/x11/fg_joystick_x11.c
-@@ -42,8 +42,188 @@
- #include <fcntl.h>
-
-
-+#if defined(__NetBSD__) || defined(__FreeBSD__) || defined(__FreeBSD_kernel__)
-+
-+static int hatmap_x[9] = {0, 0, 1, 1, 1, 0, -1, -1, -1};
-+static int hatmap_y[9] = {0, 1, 1, 0, -1, -1, -1, 0, 1};
-+
-+# ifdef HAVE_USB_JS
-+/*
-+* fghJoystickFindUSBdev (and its helper, fghJoystickWalkUSBdev) try to locate
-+* the full name of a USB device. If /dev/usbN isn't readable, we punt and
-+* return the uhidN device name. We warn the user of this situation once.
-+*/
-+static char *fghJoystickWalkUSBdev(int f, char *dev, char *out, int outlen)
-+{
-+ struct usb_device_info di;
-+ int i, a;
-+ char *cp;
-+
-+ for (a = 1; a < USB_MAX_DEVICES; a++) {
-+ di.udi_addr = a;
-+ if (ioctl(f, USB_DEVICEINFO, &di) != 0)
-+ return NULL;
-+ for (i = 0; i < USB_MAX_DEVNAMES; i++)
-+ if (di.udi_devnames[i][0] &&
-+ strcmp(di.udi_devnames[i], dev) == 0) {
-+ cp = calloc(1, strlen(di.udi_vendor) + strlen(di.udi_product) + 2);
-+ strcpy(cp, di.udi_vendor);
-+ strcat(cp, " ");
-+ strcat(cp, di.udi_product);
-+ strncpy(out, cp, outlen - 1);
-+ out[outlen - 1] = 0;
-+ free(cp);
-+ return out;
-+ }
-+ }
-+ return NULL;
-+}
-+
-+static int fghJoystickFindUSBdev(char *name, char *out, int outlen)
-+{
-+ int i, f;
-+ char buf[50];
-+ char *cp;
-+ static int protection_warned = 0;
-+
-+ for (i = 0; i < 16; i++) {
-+ snprintf(buf, sizeof(buf), "%s%d", USBDEV, i);
-+ f = open(buf, O_RDONLY);
-+ if (f >= 0) {
-+ cp = fghJoystickWalkUSBdev(f, name, out, outlen);
-+ close(f);
-+ if (cp)
-+ return 1;
-+ }
-+ else if (errno == EACCES) {
-+ if (!protection_warned) {
-+ fgWarning("Can't open %s for read!", buf);
-+ protection_warned = 1;
-+ }
-+ }
-+ }
-+ return 0;
-+}
-+
-+static int fghJoystickInitializeHID(struct os_specific_s *os,
-+ int *num_axes, int *num_buttons)
-+{
-+ int size, is_joystick;
-+# ifdef HAVE_USBHID_H
-+ int report_id = 0;
-+# endif
-+ struct hid_data *d;
-+ struct hid_item h;
-+ report_desc_t rd;
-+
-+ if ((rd = hid_get_report_desc(os->fd)) == 0)
-+ {
-+ fgWarning("error: %s: %s", os->fname, strerror(errno));
-+ return FALSE;
-+ }
-+
-+ os->hids = NULL;
-+
-+# ifdef HAVE_USBHID_H
-+ if (ioctl(os->fd, USB_GET_REPORT_ID, &report_id) < 0)
-+ {
-+ /*** XXX {report_id} may not be the right variable? ***/
-+ fgWarning("error: %s%d: %s", UHIDDEV, report_id, strerror(errno));
-+ return FALSE;
-+ }
-+
-+ size = hid_report_size(rd, hid_input, report_id);
-+# else
-+ size = hid_report_size(rd, 0, hid_input);
-+# endif
-+ os->hid_data_buf = calloc(1, size);
-+ os->hid_dlen = size;
-+
-+ is_joystick = 0;
-+# ifdef HAVE_USBHID_H
-+ d = hid_start_parse(rd, 1 << hid_input, report_id);
-+# else
-+ d = hid_start_parse(rd, 1 << hid_input);
-+# endif
-+ while (hid_get_item(d, &h))
-+ {
-+ int usage, page, interesting_hid;
-+
-+ page = HID_PAGE(h.usage);
-+ usage = HID_USAGE(h.usage);
-+
-+ /* This test is somewhat too simplistic, but this is how MicroSoft
-+ * does, so I guess it works for all joysticks/game pads. */
-+ is_joystick = is_joystick ||
-+ (h.kind == hid_collection &&
-+ page == HUP_GENERIC_DESKTOP &&
-+ (usage == HUG_JOYSTICK || usage == HUG_GAME_PAD));
-+
-+ if (h.kind != hid_input)
-+ continue;
-+
-+ if (!is_joystick)
-+ continue;
-+
-+ interesting_hid = TRUE;
-+ if (page == HUP_GENERIC_DESKTOP)
-+ {
-+ switch (usage)
-+ {
-+ case HUG_X:
-+ case HUG_RX:
-+ case HUG_Y:
-+ case HUG_RY:
-+ case HUG_Z:
-+ case HUG_RZ:
-+ case HUG_SLIDER:
-+ if (*num_axes < _JS_MAX_AXES)
-+ {
-+ os->axes_usage[*num_axes] = usage;
-+ (*num_axes)++;
-+ }
-+ break;
-+ case HUG_HAT_SWITCH:
-+ /* Allocate two axes for a hat */
-+ if (*num_axes + 1 < _JS_MAX_AXES)
-+ {
-+ os->axes_usage[*num_axes] = usage;
-+ (*num_axes)++;
-+ os->axes_usage[*num_axes] = usage;
-+ (*num_axes)++;
-+ }
-+ break;
-+ default:
-+ interesting_hid = FALSE;
-+ break;
-+ }
-+ }
-+ else if (page == HUP_BUTTON)
-+ {
-+ interesting_hid = (usage > 0) &&
-+ (usage <= _JS_MAX_BUTTONS);
-+
-+ if (interesting_hid && usage - 1 > *num_buttons)
-+ *num_buttons = usage - 1;
-+ }
-+
-+ if (interesting_hid)
-+ {
-+ h.next = os->hids;
-+ os->hids = calloc(1, sizeof(struct hid_item));
-+ *os->hids = h;
-+ }
-+ }
-+ hid_end_parse(d);
-+
-+ return os->hids != NULL;
-+}
-+# endif
-+#endif
-+
-+
- /*this should be defined in a header file */
--#define MAX_NUM_JOYSTICKS 2
-+#define MAX_NUM_JOYSTICKS 2
- extern SFG_Joystick *fgJoystick [ MAX_NUM_JOYSTICKS ];
-
- void fgPlatformJoystickRawRead( SFG_Joystick* joy, int* buttons, float* axes )
-@@ -216,15 +396,15 @@ void fgPlatformJoystickRawRead( SFG_Joystick* joy, int* buttons, float* axes )
- void fgPlatformJoystickOpen( SFG_Joystick* joy )
- {
- #if defined( __FreeBSD__ ) || defined(__FreeBSD_kernel__)
-- int i = 0;
-+ int i = 0;
- char *cp;
- #endif
- #ifdef JS_NEW
- unsigned char u;
-- int i=0;
-+ int i=0;
- #else
- # if defined( __linux__ ) || TARGET_HOST_SOLARIS
-- int i = 0;
-+ int i = 0;
- int counter = 0;
- # endif
- #endif
-@@ -448,7 +628,7 @@ void fgPlatformJoystickClose ( int ident )
- free( fgJoystick[ ident ]->pJoystick.os->hid_data_buf );
- #endif
- free( fgJoystick[ident]->pJoystick.os );
-- }
-+ }
- #endif
-
- if( ! fgJoystick[ident]->error )
---
-2.19.2
-
-From f310b56bb6f93e255cf880c8970c794e0f2efc8d Mon Sep 17 00:00:00 2001
-From: dcnieho <dcnieho@7f0cb862-5218-0410-a997-914c9d46530a>
-Date: Mon, 31 Jul 2017 20:49:26 +0000
-Subject: [PATCH] Fix build on NetBSD.
-
-(cherry picked from commit 1236c7644508227b616e97e29e123b34257e36d1)
-
-git-svn-id: http://svn.code.sf.net/p/freeglut/code/trunk/freeglut/freeglut@1835 7f0cb862-5218-0410-a997-914c9d46530a
----
- src/fg_joystick.c | 59 -------------------------------------
- src/x11/fg_joystick_x11.c | 61 +++++++++++++++++++++++++++++++++++++++
- 2 files changed, 61 insertions(+), 59 deletions(-)
-
-diff --git a/src/fg_joystick.c b/src/fg_joystick.c
-index e548c04..b24476a 100644
---- a/src/fg_joystick.c
-+++ b/src/fg_joystick.c
-@@ -40,65 +40,6 @@
- #define JS_TRUE 1
- #define JS_FALSE 0
-
--/* BSD defines from "jsBSD.cxx" around lines 42-270 */
--
--#if defined(__NetBSD__) || defined(__FreeBSD__) || defined(__FreeBSD_kernel__)
--
--# ifdef HAVE_USB_JS
--# if defined(__NetBSD__)
--# ifdef HAVE_USBHID_H
--# include <usbhid.h>
--# else
--# include <usb.h>
--# endif
--# include <dev/usb/usb.h>
--# elif defined(__FreeBSD__) || defined(__FreeBSD_kernel__)
--# ifdef HAVE_USBHID_H
--# include <usbhid.h>
--# else
--# include <libusbhid.h>
--# endif
--# include <legacy/dev/usb/usb.h>
--# endif
--# include <dev/usb/usbhid.h>
--
--/* Compatibility with older usb.h revisions */
--# if !defined(USB_MAX_DEVNAMES) && defined(MAXDEVNAMES)
--# define USB_MAX_DEVNAMES MAXDEVNAMES
--# endif
--# endif
--
--struct os_specific_s {
-- char fname [128 ];
-- int fd;
-- int is_analog;
-- /* The following structure members are specific to analog joysticks */
-- struct joystick ajs;
--# ifdef HAVE_USB_JS
-- /* The following structure members are specific to USB joysticks */
-- struct hid_item *hids;
-- int hid_dlen;
-- int hid_offset;
-- char *hid_data_buf;
-- int axes_usage [ _JS_MAX_AXES ];
--# endif
-- /* We keep button and axes state ourselves, as they might not be updated
-- * on every read of a USB device
-- */
-- int cache_buttons;
-- float cache_axes [ _JS_MAX_AXES ];
--};
--
--/* Idents lower than USB_IDENT_OFFSET are for analog joysticks. */
--# define USB_IDENT_OFFSET 2
--
--# define USBDEV "/dev/usb"
--# define UHIDDEV "/dev/uhid"
--# define AJSDEV "/dev/joy"
--
--
--#endif
--
- /*
- * Functions associated with the "jsJoystick" class in PLIB
- */
-diff --git a/src/x11/fg_joystick_x11.c b/src/x11/fg_joystick_x11.c
-index 30ad4b5..8c75bbe 100644
---- a/src/x11/fg_joystick_x11.c
-+++ b/src/x11/fg_joystick_x11.c
-@@ -42,8 +42,68 @@
- #include <fcntl.h>
-
-
-+/* BSD defines from "jsBSD.cxx" around lines 42-270 */
-+
-+#if defined(__NetBSD__) || defined(__FreeBSD__) || defined(__FreeBSD_kernel__)
-+
-+# ifdef HAVE_USB_JS
-+# if defined(__NetBSD__)
-+# ifdef HAVE_USBHID_H
-+# include <usbhid.h>
-+# else
-+# include <usb.h>
-+# endif
-+# include <dev/usb/usb.h>
-+# elif defined(__FreeBSD__) || defined(__FreeBSD_kernel__)
-+# ifdef HAVE_USBHID_H
-+# include <usbhid.h>
-+# else
-+# include <libusbhid.h>
-+# endif
-+# include <legacy/dev/usb/usb.h>
-+# endif
-+# include <dev/usb/usbhid.h>
-+
-+/* Compatibility with older usb.h revisions */
-+# if !defined(USB_MAX_DEVNAMES) && defined(MAXDEVNAMES)
-+# define USB_MAX_DEVNAMES MAXDEVNAMES
-+# endif
-+# endif
-+
-+struct os_specific_s {
-+ char fname [128 ];
-+ int fd;
-+ int is_analog;
-+ /* The following structure members are specific to analog joysticks */
-+ struct joystick ajs;
-+# ifdef HAVE_USB_JS
-+ /* The following structure members are specific to USB joysticks */
-+ struct hid_item *hids;
-+ int hid_dlen;
-+ int hid_offset;
-+ char *hid_data_buf;
-+ int axes_usage [ _JS_MAX_AXES ];
-+# endif
-+ /* We keep button and axes state ourselves, as they might not be updated
-+ * on every read of a USB device
-+ */
-+ int cache_buttons;
-+ float cache_axes [ _JS_MAX_AXES ];
-+};
-+
-+/* Idents lower than USB_IDENT_OFFSET are for analog joysticks. */
-+# define USB_IDENT_OFFSET 2
-+
-+# define USBDEV "/dev/usb"
-+# define UHIDDEV "/dev/uhid"
-+# define AJSDEV "/dev/joy"
-+
-+
-+#endif
-+
- #if defined(__NetBSD__) || defined(__FreeBSD__) || defined(__FreeBSD_kernel__)
-
-+#if defined(__FreeBSD__) || defined(__FreeBSD_kernel__)
- static int hatmap_x[9] = {0, 0, 1, 1, 1, 0, -1, -1, -1};
- static int hatmap_y[9] = {0, 1, 1, 0, -1, -1, -1, 0, 1};
-
-@@ -104,6 +164,7 @@ static int fghJoystickFindUSBdev(char *name, char *out, int outlen)
- }
- return 0;
- }
-+#endif
-
- static int fghJoystickInitializeHID(struct os_specific_s *os,
- int *num_axes, int *num_buttons)
---
-2.19.2
-