Hi Jamie, On Fri, Oct 14, 2016, Jamie Mccrae wrote: >> The LE & BR/EDR D-Bus interface proposal from Szymon (that I >> mentioned in my earlier email) would likely be the cleanest way to do >> this. > > Do you have a link to this proposal? http://thread.gmane.org/gmane.linux.bluez.kernel/67182 >> What API does Qt use to connect? The first connection to LE devices >> is usually either through the Pair() or Connect() D-Bus method. >> Neither one requires knowledge of the address type. After the >> initial connection re-connections are typically done through passive >> background scanning by the kernel, and in this case the application >> also doesn't need knowledge of the address type. > > Qt is using the DBus API but it seems they don't store the device > handles/IDs and instead when connecting to a device just require the > Bluetooth address (which is why this would be failing as it's not > using the kernels cached entries and is specifically setting if it's > connecting to a random address or public address before passing it to > BlueZ) The D-Bus API doesn't take addresses as input. The app selects a device based on its object path. It might of course be doing matching against the Address property, but when requesting to connect it's just based on what object path you direct your call to. Is Qt persistently caching something rather than just at run-time? That sounds odd (i.e. unnecessary). If it's just run-time then the object path would be the most reliable identifier. >> That's only true for BR/EDR Security Mode 4, and even that has some >> exceptions like SDP. > > I'm not sure I follow you? BLE does not require any bonding unless > mandated by the service/characteristics. It's possible to have many > BLE devices and have them all interacting without any of them ever > bonding with another device, yes this means there is no encryption or > security but in some instances it is not required. True. My comment above was about BR/EDR (which would have been cleared if you had also quoted the text I was responding to). >> I suppose you're referring to the Address property on the Device1 >> interface? It'd be help understand what exactly your concern is if >> you could be more specific in this regard. I'll assume you're >> talking about the Address property. This property was originally >> created for BR/EDR devices and probably isn't that useful for LE >> where you need to know the random vs public information. The new >> LE-specific D-Bus interface talked about earlier would provide this >> missing info. > > I think the confusion comes from how we envisage the address type. > When I think of the address type I think of it as part of the BLE > address itself and prepend it to the address so with > 00:11:22:33:44:55:66 the 00 is indicating that it is a public address > and with 01:11:22:33:44:55:66 the 01 is indicating that it is a random > address. It's a fair point that we could consider extending the Address property this way since it's just a string. I'm not sure we want to do that however since it'd break compatibility with applications that rely on the current format of this property. Johan -- 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