* [Bluez-devel] [PATCH 3/4] input/fakehid: introduce support to fakehid devices
@ 2008-02-12 3:07 Aristeu Sergio Rozanski Filho
2008-02-12 4:58 ` [Bluez-devel] [PATCH 3/4] input/fakehid: introduce support to fakehid devices (V4) Aristeu Sergio Rozanski Filho
0 siblings, 1 reply; 3+ messages in thread
From: Aristeu Sergio Rozanski Filho @ 2008-02-12 3:07 UTC (permalink / raw)
To: bluez-devel
This patch adds support to fake HID devices. Instead of registering with
kernel, the fake HID will be handled in user level and an uinput device
will be created in order to get the events into input layer.
---
input/Makefile.am | 3 +-
input/device.c | 46 ++++++++++++++++++++++++++----------
input/device.h | 12 +++++++++
input/fakehid.c | 69 ++++++++++++++++++++++++++++++++++++++++++++++++++++++
input/fakehid.h | 20 +++++++++++++++
5 files changed, 137 insertions(+), 13 deletions(-)
--- a/input/device.c 2008-02-04 22:29:58.000000000 -0500
+++ b/input/device.c 2008-02-11 21:08:48.000000000 -0500
@@ -52,6 +52,7 @@
#include "error.h"
#include "manager.h"
#include "storage.h"
+#include "fakehid.h"
#define INPUT_DEVICE_INTERFACE "org.bluez.input.Device"
@@ -61,16 +62,6 @@
#define FI_FLAG_CONNECTED 1
-struct fake_input {
- int flags;
- GIOChannel *io;
- int rfcomm; /* RFCOMM socket */
- int uinput; /* uinput socket */
- uint8_t ch; /* RFCOMM channel number */
- gboolean (*connect)(struct device *idev);
- int (*disconnect)(struct device *idev);
-};
-
struct device {
bdaddr_t src;
bdaddr_t dst;
@@ -1334,16 +1325,47 @@ int input_device_close_channels(bdaddr_t
return 0;
}
+static gboolean fake_hid_connect(struct device *dev)
+{
+ struct fake_hid *fhid = dev->fake->priv;
+
+ return fhid->connect(dev->fake);
+}
+
+
+static int fake_hid_disconnect(struct device *dev)
+{
+ struct fake_hid *fhid = dev->fake->priv;
+
+ return fhid->disconnect(dev->fake);
+}
+
int input_device_connadd(bdaddr_t *src, bdaddr_t *dst)
{
struct device *idev;
- int err;
+ struct fake_hid *fake_hid;
+ int err = 0;
idev = find_device(src, dst);
if (!idev)
return -ENOENT;
- err = hidp_connadd(src, dst, idev->ctrl_sk, idev->intr_sk, idev->name);
+ fake_hid = is_fake_hid(idev->vendor, idev->product);
+ if (fake_hid) {
+ struct fake_input *fake;
+
+ err = ENOMEM;
+ fake = malloc(sizeof(struct fake_input));
+ if (fake != NULL) {
+ memset(fake, 0, sizeof(struct fake_input));
+
+ fake->connect = fake_hid_connect;
+ fake->disconnect = fake_hid_disconnect;
+ fake->priv = fake_hid;
+ err = fake_hid_connadd(fake, idev->intr_sk, fake_hid);
+ }
+ } else
+ err = hidp_connadd(src, dst, idev->ctrl_sk, idev->intr_sk, idev->name);
if (err < 0) {
close(idev->ctrl_sk);
close(idev->intr_sk);
--- /dev/null 1970-01-01 00:00:00.000000000 +0000
+++ b/input/fakehid.h 2008-02-11 20:58:49.000000000 -0500
@@ -0,0 +1,20 @@
+#ifndef FAKEHID_H
+#define FAKEHID_H
+#include <glib.h>
+struct fake_hid;
+struct fake_input;
+
+struct fake_hid {
+ uint16_t vendor;
+ uint16_t product;
+ gboolean (*connect)(struct fake_input *fake_input);
+ int (*disconnect)(struct fake_input *fake_input);
+ gboolean (*event)(GIOChannel *chan, GIOCondition cond, gpointer data);
+ int (*setup_uinput)(struct fake_input *fake, struct fake_hid *fake_hid);
+};
+
+struct fake_hid *is_fake_hid(uint16_t vendor, uint16_t product);
+int fake_hid_connadd(struct fake_input *fake, int intr_sk,
+ struct fake_hid *fake_hid);
+#endif /* FAKEHID_H */
+
--- /dev/null 1970-01-01 00:00:00.000000000 +0000
+++ b/input/fakehid.c 2008-02-11 21:18:07.000000000 -0500
@@ -0,0 +1,69 @@
+#include <stdio.h>
+#include <stdlib.h>
+#include <errno.h>
+#include <sys/types.h>
+#include <glib.h>
+#include <dbus/dbus.h>
+#include <bluetooth/bluetooth.h>
+#include <bluetooth/hidp.h>
+#include <bluetooth/l2cap.h>
+#include "logging.h"
+#include "device.h"
+#include "fakehid.h"
+
+#define FAKE_HID_ENTRY(v, p, c, d, i, e, s) { \
+ .vendor = BLUETOOTH_VENDOR_ID_##v, \
+ .product = BLUETOOTH_DEVICE_ID_##p, \
+ .connect = c, \
+ .disconnect = d, \
+ .event = e, \
+ .setup_uinput = s, \
+ }
+
+static gboolean fake_hid_common_connect(struct fake_input *fake)
+{
+ return TRUE;
+}
+
+static int fake_hid_common_disconnect(struct fake_input *fake)
+{
+ return 0;
+}
+
+static struct fake_hid fake_hid_table[] = {
+ { },
+};
+
+static inline int fake_hid_match_device(uint16_t vendor, uint16_t product,
+ struct fake_hid *fhid)
+{
+ return vendor == fhid->vendor && product == fhid->product;
+}
+
+struct fake_hid *is_fake_hid(uint16_t vendor, uint16_t product)
+{
+ int i;
+
+ for (i = 0; fake_hid_table[i].vendor != 0; i++)
+ if (fake_hid_match_device(vendor, product, &fake_hid_table[i]))
+ return &fake_hid_table[i];
+
+ return NULL;
+}
+
+int fake_hid_connadd(struct fake_input *fake, int intr_sk,
+ struct fake_hid *fake_hid)
+{
+ if (fake_hid->setup_uinput(fake, fake_hid)) {
+ error("Error setting up uinput");
+ return ENOMEM;
+ }
+
+ fake->io = g_io_channel_unix_new(intr_sk);
+ g_io_channel_set_close_on_unref(fake->io, TRUE);
+ g_io_add_watch(fake->io, G_IO_IN | G_IO_ERR | G_IO_HUP | G_IO_NVAL,
+ (GIOFunc) fake_hid->event, fake);
+
+ return 0;
+}
+
--- a/input/device.h 2008-02-04 22:29:58.000000000 -0500
+++ b/input/device.h 2008-02-11 21:06:49.000000000 -0500
@@ -23,6 +23,18 @@
#define L2CAP_PSM_HIDP_CTRL 0x11
#define L2CAP_PSM_HIDP_INTR 0x13
+struct device;
+
+struct fake_input {
+ int flags;
+ GIOChannel *io;
+ int rfcomm; /* RFCOMM socket */
+ int uinput; /* uinput socket */
+ uint8_t ch; /* RFCOMM channel number */
+ gboolean (*connect)(struct device *dev);
+ int (*disconnect)(struct device *dev);
+ void *priv;
+};
int input_device_register(DBusConnection *conn, bdaddr_t *src, bdaddr_t *dst,
struct hidp_connadd_req *hidp, const char **ppath);
--- a/input/Makefile.am 2008-02-04 22:29:58.000000000 -0500
+++ b/input/Makefile.am 2008-02-04 22:30:02.000000000 -0500
@@ -12,7 +12,8 @@ service_PROGRAMS = bluetoothd-service-in
bluetoothd_service_input_SOURCES = main.c \
manager.h manager.c \
- server.h server.c device.h device.c storage.h storage.c
+ server.h server.c device.h device.c storage.h storage.c \
+ fakehid.c fakehid.h
LDADD = $(top_builddir)/common/libhelper.a \
@GLIB_LIBS@ @DBUS_LIBS@ @BLUEZ_LIBS@
-------------------------------------------------------------------------
This SF.net email is sponsored by: Microsoft
Defy all challenges. Microsoft(R) Visual Studio 2008.
http://clk.atdmt.com/MRT/go/vse0120000070mrt/direct/01/
_______________________________________________
Bluez-devel mailing list
Bluez-devel@lists.sourceforge.net
https://lists.sourceforge.net/lists/listinfo/bluez-devel
^ permalink raw reply [flat|nested] 3+ messages in thread* Re: [Bluez-devel] [PATCH 3/4] input/fakehid: introduce support to fakehid devices (V4)
2008-02-12 3:07 [Bluez-devel] [PATCH 3/4] input/fakehid: introduce support to fakehid devices Aristeu Sergio Rozanski Filho
@ 2008-02-12 4:58 ` Aristeu Sergio Rozanski Filho
2008-02-21 2:04 ` [Bluez-devel] [PATCH 3/4] input/fakehid: introduce support to fakehid devices (V5) Aristeu Sergio Rozanski Filho
0 siblings, 1 reply; 3+ messages in thread
From: Aristeu Sergio Rozanski Filho @ 2008-02-12 4:58 UTC (permalink / raw)
To: bluez-devel
This patch adds support to fake HID devices. Instead of registering with
kernel, the fake HID will be handled in user level and an uinput device
will be created in order to get the events into input layer.
---
input/Makefile.am | 3 +-
input/device.c | 43 ++++++++++++++++++++++++++++----------
input/device.h | 12 ++++++++++
input/fakehid.c | 60 ++++++++++++++++++++++++++++++++++++++++++++++++++++++
input/fakehid.h | 21 ++++++++++++++++++
5 files changed, 127 insertions(+), 12 deletions(-)
--- a/input/device.c 2008-02-11 23:55:01.000000000 -0500
+++ b/input/device.c 2008-02-11 23:56:52.000000000 -0500
@@ -52,6 +52,7 @@
#include "error.h"
#include "manager.h"
#include "storage.h"
+#include "fakehid.h"
#define INPUT_DEVICE_INTERFACE "org.bluez.input.Device"
@@ -63,16 +64,6 @@
struct device;
-struct fake_input {
- int flags;
- GIOChannel *io;
- int rfcomm; /* RFCOMM socket */
- int uinput; /* uinput socket */
- uint8_t ch; /* RFCOMM channel number */
- gboolean (*connect)(struct device *idev);
- int (*disconnect)(struct device *idev);
-};
-
struct device {
bdaddr_t src;
bdaddr_t dst;
@@ -1336,16 +1327,46 @@ int input_device_close_channels(bdaddr_t
return 0;
}
+static gboolean fake_hid_connect(struct device *dev)
+{
+ struct fake_hid *fhid = dev->fake->priv;
+
+ return fhid->connect(dev->fake);
+}
+
+static int fake_hid_disconnect(struct device *dev)
+{
+ struct fake_hid *fhid = dev->fake->priv;
+
+ return fhid->disconnect(dev->fake);
+}
+
int input_device_connadd(bdaddr_t *src, bdaddr_t *dst)
{
struct device *idev;
+ struct fake_hid *fake_hid;
int err;
idev = find_device(src, dst);
if (!idev)
return -ENOENT;
- err = hidp_connadd(src, dst, idev->ctrl_sk, idev->intr_sk, idev->name);
+ fake_hid = is_fake_hid(idev->vendor, idev->product);
+ if (fake_hid) {
+ struct fake_input *fake;
+
+ err = ENOMEM;
+ fake = malloc(sizeof(struct fake_input));
+ if (fake != NULL) {
+ memset(fake, 0, sizeof(struct fake_input));
+
+ fake->connect = fake_hid_connect;
+ fake->disconnect = fake_hid_disconnect;
+ fake->priv = fake_hid;
+ err = fake_hid_connadd(fake, idev->intr_sk, fake_hid);
+ }
+ } else
+ err = hidp_connadd(src, dst, idev->ctrl_sk, idev->intr_sk, idev->name);
if (err < 0) {
close(idev->ctrl_sk);
close(idev->intr_sk);
--- /dev/null 1970-01-01 00:00:00.000000000 +0000
+++ b/input/fakehid.h 2008-02-11 23:56:52.000000000 -0500
@@ -0,0 +1,21 @@
+#ifndef FAKEHID_H
+#define FAKEHID_H
+#include <glib.h>
+
+struct fake_hid;
+struct fake_input;
+
+struct fake_hid {
+ uint16_t vendor;
+ uint16_t product;
+ gboolean (*connect)(struct fake_input *fake_input);
+ int (*disconnect)(struct fake_input *fake_input);
+ gboolean (*event)(GIOChannel *chan, GIOCondition cond, gpointer data);
+ int (*setup_uinput)(struct fake_input *fake, struct fake_hid *fake_hid);
+};
+
+struct fake_hid *is_fake_hid(uint16_t vendor, uint16_t product);
+int fake_hid_connadd(struct fake_input *fake, int intr_sk,
+ struct fake_hid *fake_hid);
+#endif /* FAKEHID_H */
+
--- /dev/null 1970-01-01 00:00:00.000000000 +0000
+++ b/input/fakehid.c 2008-02-11 23:56:52.000000000 -0500
@@ -0,0 +1,60 @@
+#include <stdio.h>
+#include <stdlib.h>
+#include <errno.h>
+#include <sys/types.h>
+#include <glib.h>
+#include <dbus/dbus.h>
+#include <bluetooth/bluetooth.h>
+#include <bluetooth/hidp.h>
+#include <bluetooth/l2cap.h>
+#include "logging.h"
+#include "device.h"
+#include "fakehid.h"
+
+static gboolean fake_hid_common_connect(struct fake_input *fake)
+{
+ return TRUE;
+}
+
+static int fake_hid_common_disconnect(struct fake_input *fake)
+{
+ return 0;
+}
+
+static struct fake_hid fake_hid_table[] = {
+ { },
+};
+
+static inline int fake_hid_match_device(uint16_t vendor, uint16_t product,
+ struct fake_hid *fhid)
+{
+ return vendor == fhid->vendor && product == fhid->product;
+}
+
+struct fake_hid *is_fake_hid(uint16_t vendor, uint16_t product)
+{
+ int i;
+
+ for (i = 0; fake_hid_table[i].vendor != 0; i++)
+ if (fake_hid_match_device(vendor, product, &fake_hid_table[i]))
+ return &fake_hid_table[i];
+
+ return NULL;
+}
+
+int fake_hid_connadd(struct fake_input *fake, int intr_sk,
+ struct fake_hid *fake_hid)
+{
+ if (fake_hid->setup_uinput(fake, fake_hid)) {
+ error("Error setting up uinput");
+ return ENOMEM;
+ }
+
+ fake->io = g_io_channel_unix_new(intr_sk);
+ g_io_channel_set_close_on_unref(fake->io, TRUE);
+ g_io_add_watch(fake->io, G_IO_IN | G_IO_ERR | G_IO_HUP | G_IO_NVAL,
+ (GIOFunc) fake_hid->event, fake);
+
+ return 0;
+}
+
--- a/input/device.h 2008-02-11 22:53:04.000000000 -0500
+++ b/input/device.h 2008-02-11 23:56:52.000000000 -0500
@@ -23,6 +23,18 @@
#define L2CAP_PSM_HIDP_CTRL 0x11
#define L2CAP_PSM_HIDP_INTR 0x13
+struct device;
+
+struct fake_input {
+ int flags;
+ GIOChannel *io;
+ int rfcomm; /* RFCOMM socket */
+ int uinput; /* uinput socket */
+ uint8_t ch; /* RFCOMM channel number */
+ gboolean (*connect)(struct device *dev);
+ int (*disconnect)(struct device *dev);
+ void *priv;
+};
int input_device_register(DBusConnection *conn, bdaddr_t *src, bdaddr_t *dst,
struct hidp_connadd_req *hidp, const char **ppath);
--- a/input/Makefile.am 2008-02-11 22:53:04.000000000 -0500
+++ b/input/Makefile.am 2008-02-11 23:56:52.000000000 -0500
@@ -12,7 +12,8 @@ service_PROGRAMS = bluetoothd-service-in
bluetoothd_service_input_SOURCES = main.c \
manager.h manager.c \
- server.h server.c device.h device.c storage.h storage.c
+ server.h server.c device.h device.c storage.h storage.c \
+ fakehid.c fakehid.h
LDADD = $(top_builddir)/common/libhelper.a \
@GLIB_LIBS@ @DBUS_LIBS@ @BLUEZ_LIBS@
-------------------------------------------------------------------------
This SF.net email is sponsored by: Microsoft
Defy all challenges. Microsoft(R) Visual Studio 2008.
http://clk.atdmt.com/MRT/go/vse0120000070mrt/direct/01/
_______________________________________________
Bluez-devel mailing list
Bluez-devel@lists.sourceforge.net
https://lists.sourceforge.net/lists/listinfo/bluez-devel
^ permalink raw reply [flat|nested] 3+ messages in thread* Re: [Bluez-devel] [PATCH 3/4] input/fakehid: introduce support to fakehid devices (V5)
2008-02-12 4:58 ` [Bluez-devel] [PATCH 3/4] input/fakehid: introduce support to fakehid devices (V4) Aristeu Sergio Rozanski Filho
@ 2008-02-21 2:04 ` Aristeu Sergio Rozanski Filho
0 siblings, 0 replies; 3+ messages in thread
From: Aristeu Sergio Rozanski Filho @ 2008-02-21 2:04 UTC (permalink / raw)
To: bluez-devel
This patch adds support to fake HID devices. Instead of registering with
kernel, the fake HID will be handled in user level and an uinput device
will be created in order to get the events into input layer.
---
input/Makefile.am | 3 +-
input/device.c | 64 +++++++++++++++++++++++++++++++++++++-----------------
input/device.h | 11 +++++++++
input/fakehid.c | 60 ++++++++++++++++++++++++++++++++++++++++++++++++++
input/fakehid.h | 18 +++++++++++++++
5 files changed, 135 insertions(+), 21 deletions(-)
--- a/input/device.c 2008-02-12 00:03:49.000000000 -0500
+++ b/input/device.c 2008-02-20 20:44:17.000000000 -0500
@@ -52,6 +52,7 @@
#include "error.h"
#include "manager.h"
#include "storage.h"
+#include "fakehid.h"
#define INPUT_DEVICE_INTERFACE "org.bluez.input.Device"
@@ -63,16 +64,6 @@
struct device;
-struct fake_input {
- int flags;
- GIOChannel *io;
- int rfcomm; /* RFCOMM socket */
- int uinput; /* uinput socket */
- uint8_t ch; /* RFCOMM channel number */
- gboolean (*connect)(struct device *idev);
- int (*disconnect)(struct device *idev);
-};
-
struct device {
bdaddr_t src;
bdaddr_t dst;
@@ -1336,24 +1327,48 @@ int input_device_close_channels(bdaddr_t
return 0;
}
+static gboolean fake_hid_connect(struct device *dev)
+{
+ struct fake_hid *fhid = dev->fake->priv;
+
+ return fhid->connect(dev->fake);
+}
+
+static int fake_hid_disconnect(struct device *dev)
+{
+ struct fake_hid *fhid = dev->fake->priv;
+
+ return fhid->disconnect(dev->fake);
+}
+
int input_device_connadd(bdaddr_t *src, bdaddr_t *dst)
{
struct device *idev;
+ struct fake_hid *fake_hid;
+ struct fake_input *fake = NULL;
int err;
idev = find_device(src, dst);
if (!idev)
return -ENOENT;
- err = hidp_connadd(src, dst, idev->ctrl_sk, idev->intr_sk, idev->name);
- if (err < 0) {
- close(idev->ctrl_sk);
- close(idev->intr_sk);
- idev->ctrl_sk = -1;
- idev->intr_sk = -1;
-
- return err;
- }
+ fake_hid = get_fake_hid(idev->vendor, idev->product);
+ if (fake_hid) {
+ err = -ENOMEM;
+ fake = malloc(sizeof(struct fake_input));
+ if (!fake)
+ goto error;
+
+ memset(fake, 0, sizeof(struct fake_input));
+
+ fake->connect = fake_hid_connect;
+ fake->disconnect = fake_hid_disconnect;
+ fake->priv = fake_hid;
+ err = fake_hid_connadd(fake, idev->intr_sk, fake_hid);
+ } else
+ err = hidp_connadd(src, dst, idev->ctrl_sk, idev->intr_sk, idev->name);
+ if (err < 0)
+ goto error;
idev->intr_watch = create_watch(idev->intr_sk, intr_watch_cb, idev);
idev->ctrl_watch = create_watch(idev->ctrl_sk, ctrl_watch_cb, idev);
@@ -1362,5 +1377,14 @@ int input_device_connadd(bdaddr_t *src,
INPUT_DEVICE_INTERFACE,
"Connected",
DBUS_TYPE_INVALID);
- return 0;
+exit:
+ return err;
+error:
+ close(idev->ctrl_sk);
+ close(idev->intr_sk);
+ idev->ctrl_sk = -1;
+ idev->intr_sk = -1;
+ if (fake)
+ free(fake);
+ goto exit;
}
--- /dev/null 1970-01-01 00:00:00.000000000 +0000
+++ b/input/fakehid.h 2008-02-20 20:37:40.000000000 -0500
@@ -0,0 +1,18 @@
+#ifndef FAKEHID_H
+#define FAKEHID_H
+#include <glib.h>
+struct fake_hid;
+struct fake_input;
+
+struct fake_hid {
+ uint16_t vendor;
+ uint16_t product;
+ gboolean (*connect)(struct fake_input *fake_input);
+ int (*disconnect)(struct fake_input *fake_input);
+ gboolean (*event)(GIOChannel *chan, GIOCondition cond, gpointer data);
+ int (*setup_uinput)(struct fake_input *fake, struct fake_hid *fake_hid);
+};
+struct fake_hid *get_fake_hid(uint16_t vendor, uint16_t product);
+int fake_hid_connadd(struct fake_input *fake, int intr_sk,
+ struct fake_hid *fake_hid);
+#endif /* FAKEHID_H */
--- /dev/null 1970-01-01 00:00:00.000000000 +0000
+++ b/input/fakehid.c 2008-02-20 21:00:36.000000000 -0500
@@ -0,0 +1,60 @@
+#include <stdio.h>
+#include <stdlib.h>
+#include <errno.h>
+#include <sys/types.h>
+#include <glib.h>
+#include <dbus/dbus.h>
+#include <bluetooth/bluetooth.h>
+#include <bluetooth/hidp.h>
+#include <bluetooth/l2cap.h>
+#include "logging.h"
+#include "device.h"
+#include "fakehid.h"
+
+static gboolean fake_hid_common_connect(struct fake_input *fake)
+{
+ return TRUE;
+}
+
+static int fake_hid_common_disconnect(struct fake_input *fake)
+{
+ return 0;
+}
+
+static struct fake_hid fake_hid_table[] = {
+ { },
+};
+
+static inline int fake_hid_match_device(uint16_t vendor, uint16_t product,
+ struct fake_hid *fhid)
+{
+ return vendor == fhid->vendor && product == fhid->product;
+}
+
+struct fake_hid *get_fake_hid(uint16_t vendor, uint16_t product)
+{
+ int i;
+
+ for (i = 0; fake_hid_table[i].vendor != 0; i++)
+ if (fake_hid_match_device(vendor, product, &fake_hid_table[i]))
+ return &fake_hid_table[i];
+
+ return NULL;
+}
+
+int fake_hid_connadd(struct fake_input *fake, int intr_sk,
+ struct fake_hid *fake_hid)
+{
+ if (fake_hid->setup_uinput(fake, fake_hid)) {
+ error("Error setting up uinput");
+ return ENOMEM;
+ }
+
+ fake->io = g_io_channel_unix_new(intr_sk);
+ g_io_channel_set_close_on_unref(fake->io, TRUE);
+ g_io_add_watch(fake->io, G_IO_IN | G_IO_ERR | G_IO_HUP | G_IO_NVAL,
+ (GIOFunc) fake_hid->event, fake);
+
+ return 0;
+}
+
--- a/input/device.h 2008-02-12 00:03:49.000000000 -0500
+++ b/input/device.h 2008-02-20 20:38:25.000000000 -0500
@@ -23,6 +23,17 @@
#define L2CAP_PSM_HIDP_CTRL 0x11
#define L2CAP_PSM_HIDP_INTR 0x13
+struct device;
+struct fake_input {
+ int flags;
+ GIOChannel *io;
+ int rfcomm; /* RFCOMM socket */
+ int uinput; /* uinput socket */
+ uint8_t ch; /* RFCOMM channel number */
+ gboolean (*connect)(struct device *dev);
+ int (*disconnect)(struct device *dev);
+ void *priv;
+};
int input_device_register(DBusConnection *conn, bdaddr_t *src, bdaddr_t *dst,
struct hidp_connadd_req *hidp, const char **ppath);
--- a/input/Makefile.am 2008-02-12 00:03:49.000000000 -0500
+++ b/input/Makefile.am 2008-02-12 00:03:52.000000000 -0500
@@ -12,7 +12,8 @@ service_PROGRAMS = bluetoothd-service-in
bluetoothd_service_input_SOURCES = main.c \
manager.h manager.c \
- server.h server.c device.h device.c storage.h storage.c
+ server.h server.c device.h device.c storage.h storage.c \
+ fakehid.c fakehid.h
LDADD = $(top_builddir)/common/libhelper.a \
@GLIB_LIBS@ @DBUS_LIBS@ @BLUEZ_LIBS@
-------------------------------------------------------------------------
This SF.net email is sponsored by: Microsoft
Defy all challenges. Microsoft(R) Visual Studio 2008.
http://clk.atdmt.com/MRT/go/vse0120000070mrt/direct/01/
_______________________________________________
Bluez-devel mailing list
Bluez-devel@lists.sourceforge.net
https://lists.sourceforge.net/lists/listinfo/bluez-devel
^ permalink raw reply [flat|nested] 3+ messages in thread
end of thread, other threads:[~2008-02-21 2:04 UTC | newest]
Thread overview: 3+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2008-02-12 3:07 [Bluez-devel] [PATCH 3/4] input/fakehid: introduce support to fakehid devices Aristeu Sergio Rozanski Filho
2008-02-12 4:58 ` [Bluez-devel] [PATCH 3/4] input/fakehid: introduce support to fakehid devices (V4) Aristeu Sergio Rozanski Filho
2008-02-21 2:04 ` [Bluez-devel] [PATCH 3/4] input/fakehid: introduce support to fakehid devices (V5) Aristeu Sergio Rozanski Filho
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox