Skip to content

Commit

Permalink
Bluetooth: GATT: Add BTP Discover All Primary Services command handler
Browse files Browse the repository at this point in the history
This will handle BTP Discover All Primary Services command.

Related TC: GATT/CL/GAD/BV-01-C
Fixes: #17861
Signed-off-by: Mariusz Skamra <mariusz.skamra@codecoup.pl>
  • Loading branch information
MariuszSkamra authored and carlescufi committed Aug 7, 2019
1 parent 95deec1 commit 5a7a520
Show file tree
Hide file tree
Showing 2 changed files with 59 additions and 9 deletions.
8 changes: 7 additions & 1 deletion tests/bluetooth/tester/src/bttester.h
Original file line number Diff line number Diff line change
Expand Up @@ -409,14 +409,20 @@ struct gatt_descriptor {

#define GATT_EXCHANGE_MTU 0x0a

#define GATT_DISC_ALL_PRIM 0x0b
struct gatt_disc_all_prim_cmd {
u8_t address_type;
u8_t address[6];
} __packed;

#define GATT_DISC_PRIM_UUID 0x0c
struct gatt_disc_prim_uuid_cmd {
u8_t address_type;
u8_t address[6];
u8_t uuid_length;
u8_t uuid[0];
} __packed;
struct gatt_disc_prim_uuid_rp {
struct gatt_disc_prim_rp {
u8_t services_count;
struct gatt_service services[0];
} __packed;
Expand Down
60 changes: 52 additions & 8 deletions tests/bluetooth/tester/src/gatt.c
Original file line number Diff line number Diff line change
Expand Up @@ -206,6 +206,7 @@ static void supported_commands(u8_t *data, u16_t len)
tester_set_bit(cmds, GATT_CFG_INDICATE);
tester_set_bit(cmds, GATT_GET_ATTRIBUTES);
tester_set_bit(cmds, GATT_GET_ATTRIBUTE_VALUE);
tester_set_bit(cmds, GATT_DISC_ALL_PRIM);

tester_send(BTP_SERVICE_ID_GATT, GATT_READ_SUPPORTED_COMMANDS,
CONTROLLER_INDEX, (u8_t *) rp, sizeof(cmds));
Expand Down Expand Up @@ -919,17 +920,17 @@ static void discover_destroy(struct bt_gatt_discover_params *params)
gatt_buf_clear();
}

static u8_t disc_prim_uuid_cb(struct bt_conn *conn,
const struct bt_gatt_attr *attr,
struct bt_gatt_discover_params *params)
static u8_t disc_prim_cb(struct bt_conn *conn,
const struct bt_gatt_attr *attr,
struct bt_gatt_discover_params *params)
{
struct bt_gatt_service_val *data;
struct gatt_disc_prim_uuid_rp *rp = (void *) gatt_buf.buf;
struct gatt_disc_prim_rp *rp = (void *) gatt_buf.buf;
struct gatt_service *service;
u8_t uuid_length;

if (!attr) {
tester_send(BTP_SERVICE_ID_GATT, GATT_DISC_PRIM_UUID,
tester_send(BTP_SERVICE_ID_GATT, btp_opcode,
CONTROLLER_INDEX, gatt_buf.buf, gatt_buf.len);
discover_destroy(params);
return BT_GATT_ITER_STOP;
Expand All @@ -941,7 +942,7 @@ static u8_t disc_prim_uuid_cb(struct bt_conn *conn,

service = gatt_buf_reserve(sizeof(*service) + uuid_length);
if (!service) {
tester_rsp(BTP_SERVICE_ID_GATT, GATT_DISC_PRIM_UUID,
tester_rsp(BTP_SERVICE_ID_GATT, btp_opcode,
CONTROLLER_INDEX, BTP_STATUS_FAILED);
discover_destroy(params);
return BT_GATT_ITER_STOP;
Expand All @@ -965,6 +966,44 @@ static u8_t disc_prim_uuid_cb(struct bt_conn *conn,
return BT_GATT_ITER_CONTINUE;
}

static void disc_all_prim(u8_t *data, u16_t len)
{
struct bt_conn *conn;

conn = bt_conn_lookup_addr_le(BT_ID_DEFAULT, (bt_addr_le_t *)data);
if (!conn) {
goto fail_conn;
}

if (!gatt_buf_reserve(sizeof(struct gatt_disc_prim_rp))) {
goto fail;
}

discover_params.uuid = NULL;
discover_params.start_handle = 0x0001;
discover_params.end_handle = 0xffff;
discover_params.type = BT_GATT_DISCOVER_PRIMARY;
discover_params.func = disc_prim_cb;

btp_opcode = GATT_DISC_ALL_PRIM;

if (bt_gatt_discover(conn, &discover_params) < 0) {
discover_destroy(&discover_params);

goto fail;
}

bt_conn_unref(conn);

return;
fail:
bt_conn_unref(conn);

fail_conn:
tester_rsp(BTP_SERVICE_ID_GATT, GATT_DISC_ALL_PRIM, CONTROLLER_INDEX,
BTP_STATUS_FAILED);
}

static void disc_prim_uuid(u8_t *data, u16_t len)
{
const struct gatt_disc_prim_uuid_cmd *cmd = (void *) data;
Expand All @@ -979,15 +1018,17 @@ static void disc_prim_uuid(u8_t *data, u16_t len)
goto fail;
}

if (!gatt_buf_reserve(sizeof(struct gatt_disc_prim_uuid_rp))) {
if (!gatt_buf_reserve(sizeof(struct gatt_disc_prim_rp))) {
goto fail;
}

discover_params.uuid = &uuid.uuid;
discover_params.start_handle = 0x0001;
discover_params.end_handle = 0xffff;
discover_params.type = BT_GATT_DISCOVER_PRIMARY;
discover_params.func = disc_prim_uuid_cb;
discover_params.func = disc_prim_cb;

btp_opcode = GATT_DISC_PRIM_UUID;

if (bt_gatt_discover(conn, &discover_params) < 0) {
discover_destroy(&discover_params);
Expand Down Expand Up @@ -1933,6 +1974,9 @@ void tester_handle_gatt(u8_t opcode, u8_t index, u8_t *data,
case GATT_EXCHANGE_MTU:
exchange_mtu(data, len);
return;
case GATT_DISC_ALL_PRIM:
disc_all_prim(data, len);
return;
case GATT_DISC_PRIM_UUID:
disc_prim_uuid(data, len);
return;
Expand Down

0 comments on commit 5a7a520

Please sign in to comment.