Hi Tõnis, On Wed, Mar 9, 2016 at 11:54 AM, Tõnis Tiganik <ttiganik@xxxxxxxxxxxxxxxxx> wrote: > Hi Luiz, thanks for the reply > > >> On 08 Mar 2016, at 16:38, Luiz Augusto von Dentz <luiz.dentz@xxxxxxxxx> wrote: >> >> Hi Tõnis, >> >> On Tue, Mar 8, 2016 at 1:15 PM, Tõnis Tiganik >> <ttiganik@xxxxxxxxxxxxxxxxx> wrote: >>> Hello, we have implemented our application using BlueZ and DBUS. >>> >>> All is working rather well but the service/characteristics discovery is slow after Connecting to the device. Our guess is that this is because all of the services are discovered automatically in the connection process and for instance iPhone has a lot of services extra that we are not interested in. For other platforms(iOS, BlueSDK), optional service discovery is supported and it seems to work faster. >>> >>> After looking into some threads and the device-api.txt it seems ConnectProfile() should be the method to use. However, when connecting to our UUID with the following: >>> >>> GVariant *UUIDString = g_variant_new("s", "713d0100-503e-4c75-ba94-3148f18d941e"); >>> reply = g_dbus_proxy_call_sync(device_proxy, "ConnectProfile", g_variant_new_tuple(&UUIDString, 1), >>> G_DBUS_CALL_FLAGS_NONE, -1, NULL, &error); >>> >>> the call repeatedly fails with: >>> >>> GDBus.Error:org.bluez.Error.Failed: Host is down >>> >>> We know the UUID exists because it is in the Device property UUIDs if we use the normal Connect method that discovers all the services automatically. >>> >>> Is it possible to connect and only discover the services that our application is interested in? >>> Could it be faster than the normal Connect() method? >> >> Currently we build a cache the very first time you connect to the >> device then subsequent connects will just check if there are any >> services have changed but that is actually quite fast if nothing has >> changed, this mechanism is present for a while but perhaps you have a >> dated version that don't have this implemented yet. > > I’m using blueZ 5.35. > Actually our application currently removes the device (RemoveDevice) after disconnecting. We do this to get the object-added signal the next time the device comes into proximity, so the application knows when to connect to it again. For that we do have passive scanning, but in order for that to work you need to stop removing the device since that clear the device from the list of passive scan. > We also do this to clear out the previous DBUS object, because on disconnect we change the MAC address of the device and because of this BlueZ creates a new Device object. We change the MAC for privacy concerns. If you are using Bluetooth privacy (RPAs) the kernel will actually resolve the identity address, so you don't need to remove the device because of that, if you are not doing RPA and just changing using a static address I would recommend you to stop doing that because that wont work with passive scanning since it will be interpreted as a different device. > So I guess for this reason the services aren’t cached? Could there be another way to discover only the service we are interested in, without the initial caching? Not without changing the API, but I would be against since it enables doing this short of misuse of the APIs and not taking advance of passive scanning and RPAs which the kernel is already doing for a while. >>> >>> Im also wondering if there is a signal or some other mechanism to detect when a disconnected but advertising peripheral leaves the central's proximity? >> >> Well perhaps you want a mechanism to detect if was a link-loss or just >> a regular disconnection initiated by the remote, this is not necessary >> in LE since you can program the kernel to do passive scanning for you >> and reconnect as soon it finds the peripheral is advertising. >> bluetoothd will actually attempt to set this up if your kernel support >> it (requires 3.17 or later). > > > $ uname -r > 4.2.0-30-generic > > Im guessing this does not work for us because we do the RemoveDevice on disconnect, so kernel does not reconnect automatically. > > We need a mechanism to detect when a disconnected device leaves the proximity eg when the peripheral advertisements stop. It would actually be preferred if we would receive all the advertisement packages(for RSSI for example). Don't you get disconnected when that happen? Can't you infer that whenever the device is disconnected it is out of range? > I have tried to move the device away from the computer but I do not receive the properties changed signal for RSSI - Im thinking if we would receive 0 for this we would know the device has leaved the proximity. Well if it is out of range we wont receive any signals from it, our do you mean that we would fake a RSSI for all devices out of ranges, I really fail to see what the value in this if you just want to be able to reconnect as soon as the device start to advertise. If you want to do proper proximity then I suggest you go with proximity profile. -- Luiz Augusto von Dentz -- To unsubscribe from this list: send the line "unsubscribe linux-bluetooth" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html