Bluetooth: Add hardware error MGMT event
authorSudha Bheemanna <b.sudha@samsung.com>
Wed, 7 Sep 2016 10:12:22 +0000 (15:42 +0530)
committerJaehoon Chung <jh80.chung@samsung.com>
Tue, 29 Apr 2025 03:38:23 +0000 (12:38 +0900)
Add code to handle hardware error MGMT event.

Change-Id: Iab14eccae8265fa84a35297ff929218f6cee8d20
Signed-off-by: Sudha Bheemanna <b.sudha@samsung.com>
Signed-off-by: Amit Purwar <amit.purwar@samsung.com>
Signed-off-by: Wootak Jung <wootak.jung@samsung.com>
Signed-off-by: Jaehoon Chung <jh80.chung@samsung.com>
include/net/bluetooth/hci_core.h
include/net/bluetooth/mgmt_tizen.h
net/bluetooth/hci_event.c
net/bluetooth/mgmt.c

index 83c881f0dbd176dee59ca4e03f3e8fcee0c8117f..79822a0eeb65b8038d160791d4e4033f4e0b6a1a 100644 (file)
@@ -2417,6 +2417,7 @@ int mgmt_le_conn_updated(struct hci_dev *hdev, bdaddr_t *bdaddr, u8 type,
                u16 supervision_timeout);
 int mgmt_le_conn_update_failed(struct hci_dev *hdev, bdaddr_t *bdaddr,
                u8 link_type, u8 addr_type, u8 status);
+void mgmt_hardware_error(struct hci_dev *hdev, u8 err_code);
 #endif
 
 int hci_abort_conn(struct hci_conn *conn, u8 reason);
index 4c2e9d0c54d6820beb7626be0a6088a9b4764592..680ad8b9b1a00d3eb04b7e0e5854c9d71ff1b588 100644 (file)
@@ -162,6 +162,13 @@ struct mgmt_ev_device_name_update {
 } __packed;
 /* Device name update changes */
 
+/* For handling of hardware error event */
+#define MGMT_EV_HARDWARE_ERROR                 (TIZEN_EV_BASE + 0x02)
+struct mgmt_ev_hardware_error {
+       __u8    error_code;
+} __packed;
+/* handling of hardware error event */
+
 /* For handling of RSSI Events */
 #define MGMT_EV_RSSI_ALERT                     (TIZEN_EV_BASE + 0x04)
 struct mgmt_ev_vendor_specific_rssi_alert {
index 55f170f9777a50a514a59b1b3f7ab3dece12f48b..dd08abdd4d1bbab88e09c0b4af410f3709ef4515 100644 (file)
@@ -4462,6 +4462,11 @@ static void hci_hardware_error_evt(struct hci_dev *hdev, void *data,
 
        bt_dev_dbg(hdev, "code 0x%2.2x", ev->code);
 
+#ifdef TIZEN_BT
+       hci_dev_lock(hdev);
+       mgmt_hardware_error(hdev, ev->code);
+       hci_dev_unlock(hdev);
+#endif
        hdev->hw_error_code = ev->code;
 
        queue_work(hdev->req_workqueue, &hdev->error_reset);
index 663912186a5f0a29c9d05bb590f00a2f152629f7..162d57c21bcd8275a9b70692e7dabcf0cbd45f1d 100644 (file)
@@ -8808,6 +8808,14 @@ static int le_set_scan_params(struct sock *sk, struct hci_dev *hdev,
 
        return err;
 }
+
+void mgmt_hardware_error(struct hci_dev *hdev, u8 err_code)
+{
+       struct mgmt_ev_hardware_error ev;
+
+       ev.error_code = err_code;
+       mgmt_event(MGMT_EV_HARDWARE_ERROR, hdev, &ev, sizeof(ev), NULL);
+}
 #endif /* TIZEN_BT */
 
 static bool ltk_is_valid(struct mgmt_ltk_info *key)