diff --git a/android/gatt.c b/android/gatt.c
index adf7041..fdf4d9a 100644
--- a/android/gatt.c
+++ b/android/gatt.c
HAL_STATUS_UNSUPPORTED);
}
+static void handle_client_scan_filter_clear(const void *buf, uint16_t len)
+{
+ const struct hal_cmd_gatt_client_scan_filter_clear *cmd = buf;
+
+ DBG("client_if %u", cmd->client_if);
+
+ /* TODO */
+
+ ipc_send_rsp(hal_ipc, HAL_SERVICE_ID_GATT,
+ HAL_OP_GATT_CLIENT_SCAN_FILTER_CLEAR,
+ HAL_STATUS_UNSUPPORTED);
+}
+
static const struct ipc_handler cmd_handlers[] = {
/* HAL_OP_GATT_CLIENT_REGISTER */
{ handle_client_register, false,
/* HAL_OP_GATT_CLIENT_SCAN_FILTER_ADD_REMOVE */
{ handle_client_scan_filter_add_remove, true,
sizeof(struct hal_cmd_gatt_client_scan_filter_add_remove) },
+ /* HAL_OP_GATT_CLIENT_SCAN_FILTER_CLEAR */
+ { handle_client_scan_filter_clear, false,
+ sizeof(struct hal_cmd_gatt_client_scan_filter_clear) },
};
static uint8_t read_by_group_type(const uint8_t *cmd, uint16_t cmd_len,
diff --git a/android/hal-gatt.c b/android/hal-gatt.c
index 3291d47..d82bbca 100644
--- a/android/hal-gatt.c
+++ b/android/hal-gatt.c
static bt_status_t scan_filter_clear(int client_if, int filt_index)
{
- DBG("");
+ struct hal_cmd_gatt_client_scan_filter_clear cmd;
- /* TODO */
+ if (!interface_ready())
+ return BT_STATUS_NOT_READY;
- return BT_STATUS_UNSUPPORTED;
-}
+ cmd.client_if = client_if;
+ cmd.index = filt_index;
+ return hal_ipc_cmd(HAL_SERVICE_ID_GATT,
+ HAL_OP_GATT_CLIENT_SCAN_FILTER_CLEAR,
+ sizeof(cmd), &cmd, NULL, NULL, NULL);
+}
static bt_status_t scan_filter_enable(int client_if, bool enable)
{
diff --git a/android/hal-msg.h b/android/hal-msg.h
index 90efc77..dd740b4 100644
--- a/android/hal-msg.h
+++ b/android/hal-msg.h
uint8_t data_mask[0]; /* common buffer for data and mask */
} __attribute__((packed));
+#define HAL_OP_GATT_CLIENT_SCAN_FILTER_CLEAR 0x26
+struct hal_cmd_gatt_client_scan_filter_clear {
+ int32_t client_if;
+ int32_t index;
+} __attribute__((packed));
+
/* Handsfree client HAL API */
#define HAL_OP_HF_CLIENT_CONNECT 0x01