bluez/profiles/input/sixaxis.h
Szymon Janc 61745d2bb8 sixaxis: Fix Bluetooth PS3 clone joypad being named like the original
When cable pairing a PS3 clone device, we should try and keep the USB device
name to create a new btd_device so that the joypad is named after its USB name
when connecting through Bluetooth.

If that isn't done, "Shanwan" clone joypads are named like the genuine joypads, and
kernel Bluetooth quirks aren't applied.

gh-issue: https://github.com/bluez/bluez/issues/46
2021-02-22 09:22:59 +01:00

94 lines
1.8 KiB
C

/* SPDX-License-Identifier: GPL-2.0-or-later */
/*
*
* BlueZ - Bluetooth protocol stack for Linux
*
* Copyright (C) 2009,2017 Bastien Nocera <hadess@hadess.net>
* Copyright (C) 2011 Antonio Ospite <ospite@studenti.unina.it>
* Copyright (C) 2013 Szymon Janc <szymon.janc@gmail.com>
*
*
*/
#ifndef _SIXAXIS_H_
#define _SIXAXIS_H_
typedef enum {
CABLE_PAIRING_UNSUPPORTED = 0,
CABLE_PAIRING_SIXAXIS,
CABLE_PAIRING_DS4,
} CablePairingType;
struct cable_pairing {
const char *name;
uint16_t source;
uint16_t vid;
uint16_t pid;
uint16_t version;
CablePairingType type;
};
static inline const struct cable_pairing *
get_pairing(uint16_t vid, uint16_t pid, const char *name)
{
static const struct cable_pairing devices[] = {
{
.name = "Sony PLAYSTATION(R)3 Controller",
.source = 0x0002,
.vid = 0x054c,
.pid = 0x0268,
.version = 0x0000,
.type = CABLE_PAIRING_SIXAXIS,
},
{
.name = "SHANWAN PS3 GamePad",
.source = 0x0002,
.vid = 0x054c,
.pid = 0x0268,
.version = 0x0000,
.type = CABLE_PAIRING_SIXAXIS,
},
{
.name = "Navigation Controller",
.source = 0x0002,
.vid = 0x054c,
.pid = 0x042f,
.version = 0x0000,
.type = CABLE_PAIRING_SIXAXIS,
},
{
.name = "Wireless Controller",
.source = 0x0002,
.vid = 0x054c,
.pid = 0x05c4,
.version = 0x0001,
.type = CABLE_PAIRING_DS4,
},
{
.name = "Wireless Controller",
.source = 0x0002,
.vid = 0x054c,
.pid = 0x09cc,
.version = 0x0001,
.type = CABLE_PAIRING_DS4,
},
};
guint i;
for (i = 0; i < G_N_ELEMENTS(devices); i++) {
if (devices[i].vid != vid)
continue;
if (devices[i].pid != pid)
continue;
if (name && strcmp(name, devices[i].name))
continue;
return &devices[i];
}
return NULL;
}
#endif /* _SIXAXIS_H_ */