input: hog: Attempt to set security level if not bonded
authorLuiz Augusto von Dentz <luiz.von.dentz@intel.com>
Tue, 10 Mar 2020 16:59:07 +0000 (09:59 -0700)
committerAyush Garg <ayush.garg@samsung.com>
Mon, 12 Apr 2021 09:00:48 +0000 (14:30 +0530)
This attempts to set the security if the device is not bonded, the
kernel will block any communication on the ATT socket while bumping
the security and if that fails the device will be disconnected which
is better than having the device dangling around without being able to
communicate with it until it is properly bonded.

Signed-off-by: Anuj Jain <anuj01.jain@samsung.com>
Signed-off-by: Ayush Garg <ayush.garg@samsung.com>
profiles/input/hog.c

index dfac689..f0226eb 100755 (executable)
@@ -49,6 +49,8 @@
 #include "src/shared/util.h"
 #include "src/shared/uhid.h"
 #include "src/shared/queue.h"
+#include "src/shared/att.h"
+#include "src/shared/gatt-client.h"
 #include "src/plugin.h"
 
 #include "suspend.h"
@@ -187,8 +189,15 @@ static int hog_accept(struct btd_service *service)
        }
 
        /* HOGP 1.0 Section 6.1 requires bonding */
-       if (!device_is_bonded(device, btd_device_get_bdaddr_type(device)))
-               return -ECONNREFUSED;
+       if (!device_is_bonded(device, btd_device_get_bdaddr_type(device))) {
+               struct bt_gatt_client *client;
+
+               client = btd_device_get_gatt_client(device);
+               if (!bt_gatt_client_set_security(client,
+                                               BT_ATT_SECURITY_MEDIUM)) {
+                       return -ECONNREFUSED;
+               }
+       }
 
        /* TODO: Replace GAttrib with bt_gatt_client */
        bt_hog_attach(dev->hog, attrib);