summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorMarcel Holtmann <marcel@holtmann.org>2005-01-29 03:24:48 +0000
committerMarcel Holtmann <marcel@holtmann.org>2005-01-29 03:24:48 +0000
commite6589c0f2a6d1dd3060a86a27d859c8fb08bf278 (patch)
treef1d7420e04b4ac7580c9e0e8383f7a8d0c6f9311
parentf1d23ac858b0593afe27e6b8e00a55d92804a6bb (diff)
Add functions for reading the BD_ADDR and the features
-rw-r--r--include/hci.h3
-rw-r--r--include/hci_lib.h2
-rw-r--r--src/hci.c46
3 files changed, 51 insertions, 0 deletions
diff --git a/include/hci.h b/include/hci.h
index d2efb5fe..6e41642b 100644
--- a/include/hci.h
+++ b/include/hci.h
@@ -762,6 +762,7 @@ typedef struct {
uint8_t status;
uint8_t features[8];
} __attribute__ ((packed)) read_local_features_rp;
+#define READ_LOCAL_FEATURES_RP_SIZE 9
#define OCF_READ_BUFFER_SIZE 0x0005
typedef struct {
@@ -771,12 +772,14 @@ typedef struct {
uint16_t acl_max_pkt;
uint16_t sco_max_pkt;
} __attribute__ ((packed)) read_buffer_size_rp;
+#define READ_BUFFER_SIZE_RP_SIZE 8
#define OCF_READ_BD_ADDR 0x0009
typedef struct {
uint8_t status;
bdaddr_t bdaddr;
} __attribute__ ((packed)) read_bd_addr_rp;
+#define READ_BD_ADDR_RP_SIZE 7
/* Status params */
#define OGF_STATUS_PARAM 0x05
diff --git a/include/hci_lib.h b/include/hci_lib.h
index 7c53f0ed..1e5ecc96 100644
--- a/include/hci_lib.h
+++ b/include/hci_lib.h
@@ -73,6 +73,8 @@ int hci_read_remote_features(int dd, uint16_t handle, uint8_t *features, int to)
int hci_read_remote_version(int dd, uint16_t handle, struct hci_version *ver, int to);
int hci_read_clock_offset(int dd, uint16_t handle, uint16_t *clkoffset, int to);
int hci_read_local_version(int dd, struct hci_version *ver, int to);
+int hci_read_local_features(int dd, uint8_t *features, int to);
+int hci_read_bd_addr(int dd, bdaddr_t *bdaddr, int to);
int hci_read_class_of_dev(int dd, uint8_t *cls, int to);
int hci_write_class_of_dev(int dd, uint32_t cls, int to);
int hci_read_voice_setting(int dd, uint16_t *vs, int to);
diff --git a/src/hci.c b/src/hci.c
index a68f0122..822c7db4 100644
--- a/src/hci.c
+++ b/src/hci.c
@@ -1042,6 +1042,52 @@ int hci_read_local_version(int dd, struct hci_version *ver, int to)
return 0;
}
+int hci_read_local_features(int dd, uint8_t *features, int to)
+{
+ read_local_features_rp rp;
+ struct hci_request rq;
+
+ memset(&rq, 0, sizeof(rq));
+ rq.ogf = OGF_INFO_PARAM;
+ rq.ocf = OCF_READ_LOCAL_FEATURES;
+ rq.rparam = &rp;
+ rq.rlen = READ_LOCAL_FEATURES_RP_SIZE;
+
+ if (hci_send_req(dd, &rq, to) < 0)
+ return -1;
+
+ if (rp.status) {
+ errno = EIO;
+ return -1;
+ }
+
+ memcpy(features, rp.features, 8);
+ return 0;
+}
+
+int hci_read_bd_addr(int dd, bdaddr_t *bdaddr, int to)
+{
+ read_bd_addr_rp rp;
+ struct hci_request rq;
+
+ memset(&rq, 0, sizeof(rq));
+ rq.ogf = OGF_INFO_PARAM;
+ rq.ocf = OCF_READ_BD_ADDR;
+ rq.rparam = &rp;
+ rq.rlen = READ_BD_ADDR_RP_SIZE;
+
+ if (hci_send_req(dd, &rq, to) < 0)
+ return -1;
+
+ if (rp.status) {
+ errno = EIO;
+ return -1;
+ }
+
+ bacpy(bdaddr, &rp.bdaddr);
+ return 0;
+}
+
int hci_read_class_of_dev(int dd, uint8_t *cls, int to)
{
read_class_of_dev_rp rp;