From: Antonio Ospite <ospite@studenti.unina.it>
To: Alan Ott <alan@signal11.us>
Cc: Antonio Ospite <ospite@studenti.unina.it>,
linux-bluetooth@vger.kernel.org,
Bastien Nocera <hadess@hadess.net>,
linux-input@vger.kernel.org, Jim Paris <jim@jtan.com>,
Ranulf Doswell <ralf@ranulf.net>,
"Pascal A . Brisset" <pascal44973@pabr.org>,
Marcin Tolysz <tolysz@gmail.com>,
Christian Birchinger <joker@netswarm.net>,
Filipe Lopes <falktx@gmail.com>,
Mikko Virkkila <virkkila@kapsi.fi>,
Simon Wood <simon@mungewell.org>, Arc Riley <arcriley@gmail.com>
Subject: [PATCH 0/4 incremental 1/2] Generalize controller handling to support different devices
Date: Thu, 18 Aug 2011 16:22:19 +0200 [thread overview]
Message-ID: <1313677340-4441-1-git-send-email-ospite@studenti.unina.it> (raw)
In-Reply-To: <20110818161357.8084ab94bff57391e7ec3284@studenti.unina.it>
Remove hardcoded #defines and put the values in a struct so we can handle
different device types.
>From the USB dumps I've seen[1], different devices have just different ways to
get and set the bdaddrs, the pairing algorithm is the same.
[1] http://ps3.jim.sh/sixaxis/dumps/
---
plugins/sixaxis.c | 80 ++++++++++++++++++++++++++++++++++------------------
1 files changed, 52 insertions(+), 28 deletions(-)
diff --git a/plugins/sixaxis.c b/plugins/sixaxis.c
index e08222c..608474f 100644
--- a/plugins/sixaxis.c
+++ b/plugins/sixaxis.c
@@ -70,12 +70,38 @@
#define BDADDR_STR_SIZE 18 /* strlen("00:00:00:00:00:00") + 1 */
-/* Vendor and product ID for the Sixaxis PS3 controller */
-#define VENDOR 0x054c
-#define PRODUCT 0x0268
-#define SIXAXIS_NAME "PLAYSTATION(R)3 Controller"
-#define SIXAXIS_PNP_RECORD "3601920900000A000100000900013503191124090004350D35061901000900113503190011090006350909656E09006A0901000900093508350619112409010009000D350F350D350619010009001335031900110901002513576972656C65737320436F6E74726F6C6C65720901012513576972656C65737320436F6E74726F6C6C6572090102251B536F6E7920436F6D707574657220456E7465727461696E6D656E740902000901000902010901000902020800090203082109020428010902052801090206359A35980822259405010904A101A102850175089501150026FF00810375019513150025013500450105091901291381027501950D0600FF8103150026FF0005010901A10075089504350046FF0009300931093209358102C0050175089527090181027508953009019102750895300901B102C0A1028502750895300901B102C0A10285EE750895300901B102C0A10285EF750895300901B102C0C0090207350835060904090901000902082800090209280109020A280109020
B09010009020C093E8009020D280009020E2800"
-#define HID_UUID "00001124-0000-1000-8000-00805f9b34fb"
+struct sony_controller {
+ uint16_t vendor_id;
+ uint16_t product_id;
+ char *name;
+ char *pnp_record;
+ char *hid_uuid;
+
+ /* device specific callbacks to get master/device bdaddr and set
+ * master bdaddr
+ */
+ char * (*get_device_bdaddr)(int);
+ char * (*get_master_bdaddr)(int);
+ int (*set_master_bdaddr) (int, char *);
+};
+
+static char *sixaxis_get_device_bdaddr(int fd);
+static char *sixaxis_get_master_bdaddr(int fd);
+static int sixaxis_set_master_bdaddr(int fd, char *adapter_bdaddr);
+
+static struct sony_controller controllers[] = {
+ {
+ .vendor_id = 0x054c,
+ .product_id = 0x0268,
+ .name = "PLAYSTATION(R)3 Controller",
+ .pnp_record = "3601920900000A000100000900013503191124090004350D35061901000900113503190011090006350909656E09006A0901000900093508350619112409010009000D350F350D350619010009001335031900110901002513576972656C65737320436F6E74726F6C6C65720901012513576972656C65737320436F6E74726F6C6C6572090102251B536F6E7920436F6D707574657220456E7465727461696E6D656E740902000901000902010901000902020800090203082109020428010902052801090206359A35980822259405010904A101A102850175089501150026FF00810375019513150025013500450105091901291381027501950D0600FF8103150026FF0005010901A10075089504350046FF0009300931093209358102C0050175089527090181027508953009019102750895300901B102C0A1028502750895300901B102C0A10285EE750895300901B102C0A10285EF750895300901B102C0C0090207350835060904090901000902082800090209280109020A280109020B0901000902
0C093E8009020D280009020E2800",
+ .hid_uuid = "00001124-0000-1000-8000-00805f9b34fb",
+ .get_device_bdaddr = sixaxis_get_device_bdaddr,
+ .get_master_bdaddr = sixaxis_get_master_bdaddr,
+ .set_master_bdaddr = sixaxis_set_master_bdaddr,
+ },
+};
+
#define LED_1 (0x01 << 1)
#define LED_2 (0x01 << 2)
@@ -90,12 +116,9 @@ static struct udev_monitor *monitor;
static guint watch_id;
-static int create_sixaxis_association(struct btd_adapter *adapter,
- const char *name,
+static int create_controller_association(struct btd_adapter *adapter,
const char *address,
- guint32 vendor_id,
- guint32 product_id,
- const char *pnp_record)
+ struct sony_controller *controller)
{
DBusConnection *conn;
sdp_record_t *rec;
@@ -108,15 +131,16 @@ static int create_sixaxis_association(struct btd_adapter *adapter,
adapter_get_address(adapter, &src);
ba2str(&src, srcaddr);
- write_device_name(&dst, &src, (char *) name);
+ write_device_name(&dst, &src, controller->name);
/* Store the device's SDP record */
- rec = record_from_string(pnp_record);
+ rec = record_from_string(controller->pnp_record);
store_record(srcaddr, address, rec);
sdp_record_free(rec);
/* Set the device id */
- store_device_id(srcaddr, address, 0xffff, vendor_id, product_id, 0);
+ store_device_id(srcaddr, address, 0xffff, controller->vendor_id,
+ controller->product_id, 0);
/* Don't write a profile here,
* it will be updated when the device connects */
@@ -137,8 +161,8 @@ static int create_sixaxis_association(struct btd_adapter *adapter,
}
device_set_temporary(device, FALSE);
- device_set_name(device, name);
- btd_device_add_uuid(device, HID_UUID);
+ device_set_name(device, controller->name);
+ btd_device_add_uuid(device, controller->hid_uuid);
fail_device:
dbus_connection_unref(conn);
@@ -184,7 +208,7 @@ static int set_feature_report(int fd, uint8_t *report, int len)
return ret;
}
-static char *get_device_bdaddr(int fd)
+static char *sixaxis_get_device_bdaddr(int fd)
{
unsigned char *buf;
char *address;
@@ -210,7 +234,7 @@ static char *get_device_bdaddr(int fd)
return address;
}
-static char *get_master_bdaddr(int fd)
+static char *sixaxis_get_master_bdaddr(int fd)
{
unsigned char *buf;
char *address;
@@ -236,7 +260,7 @@ static char *get_master_bdaddr(int fd)
return address;
}
-static int set_master_bdaddr(int fd, char *adapter_bdaddr)
+static int sixaxis_set_master_bdaddr(int fd, char *adapter_bdaddr)
{
uint8_t *report;
uint8_t addr[6];
@@ -282,7 +306,7 @@ out:
return ret;
}
-static int sixpair(int fd, struct btd_adapter *adapter)
+static int controller_pair(int fd, struct btd_adapter *adapter, struct sony_controller *controller)
{
char *device_bdaddr;
char *master_bdaddr;
@@ -294,7 +318,7 @@ static int sixpair(int fd, struct btd_adapter *adapter)
ba2str(&dst, adapter_bdaddr);
DBG("Adapter bdaddr %s", adapter_bdaddr);
- master_bdaddr = get_master_bdaddr(fd);
+ master_bdaddr = controller->get_master_bdaddr(fd);
if (master_bdaddr == NULL) {
DBG("Failed to get the Old master Bluetooth address from the device");
return -EPERM;
@@ -305,7 +329,7 @@ static int sixpair(int fd, struct btd_adapter *adapter)
*/
if (g_strcmp0(master_bdaddr, adapter_bdaddr) != 0) {
DBG("Old master Bluetooth address was: %s", master_bdaddr);
- ret = set_master_bdaddr(fd, adapter_bdaddr);
+ ret = controller->set_master_bdaddr(fd, adapter_bdaddr);
if (ret < 0) {
DBG("Failed to set the master Bluetooth address");
free(master_bdaddr);
@@ -313,7 +337,7 @@ static int sixpair(int fd, struct btd_adapter *adapter)
}
}
- device_bdaddr = get_device_bdaddr(fd);
+ device_bdaddr = controller->get_device_bdaddr(fd);
if (device_bdaddr == NULL) {
DBG("Failed to get the Bluetooth address from the device");
free(master_bdaddr);
@@ -322,10 +346,7 @@ static int sixpair(int fd, struct btd_adapter *adapter)
DBG("Device bdaddr %s", device_bdaddr);
- ret = create_sixaxis_association(adapter,
- SIXAXIS_NAME,
- device_bdaddr,
- VENDOR, PRODUCT, SIXAXIS_PNP_RECORD);
+ ret = create_controller_association(adapter, device_bdaddr, controller);
free(device_bdaddr);
free(master_bdaddr);
return ret;
@@ -424,6 +445,7 @@ static void handle_device_plug(struct udev_device *udevice)
unsigned char is_usb = FALSE;
int js_num = 0;
int fd;
+ struct sony_controller *controller;
hid_parent = udev_device_get_parent_with_subsystem_devtype(udevice,
"hid", NULL);
@@ -439,6 +461,8 @@ static void handle_device_plug(struct udev_device *udevice)
if (!is_sixaxis(hid_name))
return;
+ controller = &controllers[0];
+
DBG("Found a Sixaxis device");
hidraw_node = udev_device_get_devnode(udevice);
@@ -507,7 +531,7 @@ static void handle_device_plug(struct udev_device *udevice)
DBG("No adapters, exiting");
return;
}
- sixpair(fd, adapter);
+ controller_pair(fd, adapter, controller);
}
if (js_num > 0) {
--
1.7.5.4
next prev parent reply other threads:[~2011-08-18 14:22 UTC|newest]
Thread overview: 22+ messages / expand[flat|nested] mbox.gz Atom feed top
2011-08-05 14:09 [PATCH BlueZ 0/4] Sixaxis Plugin, almost there? Antonio Ospite
[not found] ` <1312553358-26280-1-git-send-email-ospite-aNJ+ML1ZbiP93QAQaVx+gl6hYfS7NtTn@public.gmane.org>
2011-08-05 14:09 ` [PATCH BlueZ 1/4] Remove input/sixpair.c Antonio Ospite
2011-08-05 14:09 ` [PATCH BlueZ 2/4] Add sixaxis plugin: USB pairing and LEDs settings Antonio Ospite
[not found] ` <1312553358-26280-3-git-send-email-ospite-aNJ+ML1ZbiP93QAQaVx+gl6hYfS7NtTn@public.gmane.org>
2011-08-10 2:24 ` Alan Ott
[not found] ` <4E41EBE5.7040908-yzvJWuRpmD1zbRFIqnYvSA@public.gmane.org>
2011-08-18 14:13 ` Antonio Ospite
2011-08-18 14:22 ` Antonio Ospite [this message]
2011-08-18 15:26 ` [PATCH 0/4 incremental 1/2] Generalize controller handling to support different devices Alan Ott
2011-08-19 19:14 ` Antonio Ospite
2011-08-19 20:57 ` Antonio Ospite
2011-08-20 10:11 ` Antonio Ospite
2011-08-18 14:22 ` [PATCH 2/2] Match controllers using vendor_id and product_id instead of HID_NAME Antonio Ospite
[not found] ` <20110818161357.8084ab94bff57391e7ec3284-aNJ+ML1ZbiP93QAQaVx+gl6hYfS7NtTn@public.gmane.org>
2011-08-19 19:57 ` [PATCH BlueZ 2/4] Add sixaxis plugin: USB pairing and LEDs settings Antonio Ospite
2011-08-22 20:08 ` Antonio Ospite
2011-08-05 14:09 ` [PATCH BlueZ 3/4] Link to udev only when needed Antonio Ospite
[not found] ` <1312553358-26280-4-git-send-email-ospite-aNJ+ML1ZbiP93QAQaVx+gl6hYfS7NtTn@public.gmane.org>
2011-08-18 10:44 ` Antonio Ospite
2011-08-18 23:18 ` Marcel Holtmann
2011-08-19 8:58 ` Antonio Ospite
[not found] ` <20110819105802.b7f5eda46e58b32677fdb804-aNJ+ML1ZbiP93QAQaVx+gl6hYfS7NtTn@public.gmane.org>
2011-08-19 19:08 ` Antonio Ospite
[not found] ` <20110819210854.81dff694ad455da3ed0e6e96-aNJ+ML1ZbiP93QAQaVx+gl6hYfS7NtTn@public.gmane.org>
2011-08-25 14:14 ` Antonio Ospite
[not found] ` <20110825161454.45a0b27998f577a737a2e579-aNJ+ML1ZbiP93QAQaVx+gl6hYfS7NtTn@public.gmane.org>
2011-08-25 17:06 ` Vinicius Costa Gomes
2011-08-26 12:49 ` Antonio Ospite
2011-08-05 14:09 ` [PATCH BlueZ 4/4] plugins/sixaxis: Wait for the PS button before setting the LEDs Antonio Ospite
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=1313677340-4441-1-git-send-email-ospite@studenti.unina.it \
--to=ospite@studenti.unina.it \
--cc=alan@signal11.us \
--cc=arcriley@gmail.com \
--cc=falktx@gmail.com \
--cc=hadess@hadess.net \
--cc=jim@jtan.com \
--cc=joker@netswarm.net \
--cc=linux-bluetooth@vger.kernel.org \
--cc=linux-input@vger.kernel.org \
--cc=pascal44973@pabr.org \
--cc=ralf@ranulf.net \
--cc=simon@mungewell.org \
--cc=tolysz@gmail.com \
--cc=virkkila@kapsi.fi \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).