Hi, I’m developing an application which uses Windows’ BLE support. The application is really simple, it implements a class for using BLE (here is a part of the code):
[...]
using Windows.Devices.Bluetooth.Advertisement;
using Windows.Devices.Enumeration;
using Windows.Devices.Bluetooth;
using Windows.Devices.Bluetooth.GenericAttributeProfile;
using Windows.Storage.Streams;
[...]
namespace Ble {
class BleDevice {
BluetoothLEDevice btdev;
public BlebDevice(string addr, int freq=100, string logfile="") {
string[] requestedProperties = { "System.Devices.Aep.DeviceAddress", "System.Devices.Aep.IsConnected" };
DeviceWatcher deviceWatcher = DeviceInformation.CreateWatcher(
BluetoothLEDevice.GetDeviceSelectorFromPairingState(false),
requestedProperties,
DeviceInformationKind.AssociationEndpoint);
deviceWatcher.Added += DeviceWatcher_Added;
deviceWatcher.Updated += DeviceWatcher_Updated;
deviceWatcher.Removed += DeviceWatcher_Removed;
deviceWatcher.Start();
private async void DeviceWatcher_Added(DeviceWatcher sender, DeviceInformation args) {
btdev = await BluetoothLEDevice.FromIdAsync(args.Id);
GattDeviceServicesResult result = await btdev.GetGattServicesAsync();
Guid customGuid = new Guid("xxx");
foreach (GattDeviceService service in result.Services) {
if (customGuid == service.Uuid) {
GattCharacteristicsResult cresult = await service.GetCharacteristicsAsync();
GattCharacteristic ch = cresult.Characteristics[0];
await ch.WriteClientCharacteristicConfigurationDescriptorAsync(GattClientCharacteristicConfigurationDescriptorValue.Notify);
ch.ValueChanged += Characteristic_ValueChanged;
}
}
}
void Characteristic_ValueChanged(GattCharacteristic sender, GattValueChangedEventArgs args) {
DataReader reader = DataReader.FromBuffer(args.CharacteristicValue);
byte[] input = new byte[reader.UnconsumedBufferLength];
reader.ReadBytes(input);
[...]
}
private async void DeviceWatcher_Removed(DeviceWatcher sender, DeviceInformationUpdate args) { }
private async void DeviceWatcher_Updated(DeviceWatcher sender, DeviceInformationUpdate args) { }
}
}
The project uses IL2CPP as scripting backend. I can create the UWP build successfully, and when I build the solution with Visual Studio, it correctly compiles. The problem is that I get several issues at runtime, and BLE is not working, e.g.
onecoreuap\drivers\wdm\bluetooth\user\winrt\common\devquerydevpropprovider.cpp(297)\Windows.Devices.Bluetooth.dll!00007FFFA4CCB4F1: (caller: 00007FFFA4CCAFC6) ReturnHr(1) tid(974) 80070490 Element not found.
onecoreuap\drivers\wdm\bluetooth\user\winrt\common\devquerydevpropprovider.cpp(131)\Windows.Devices.Bluetooth.dll!00007FFFA4CCB01A: (caller: 00007FFFA4CDEFE8) ReturnHr(3) tid(974) 80070490 Element not found.
onecoreuap\drivers\wdm\bluetooth\user\winrt\device\bluetoothledevice.cpp(1417)\Windows.Devices.Bluetooth.dll!00007FFFA4CDF000: (caller: 00007FFFA4CE9591) LogHr(1) tid(974) 80070490 Element not found.
onecoreuap\drivers\wdm\bluetooth\user\winrt\common\devquerydevpropprovider.cpp(297)\Windows.Devices.Bluetooth.dll!00007FFFA4CCB4F1: (caller: 00007FFFA4CCAFC6) ReturnHr(2) tid(56c) 80070490 Element not found.
onecoreuap\drivers\wdm\bluetooth\user\winrt\common\devquerydevpropprovider.cpp(131)\Windows.Devices.Bluetooth.dll!00007FFFA4CCB01A: (caller: 00007FFFA4CDEFE8) ReturnHr(4) tid(56c) 80070490 Element not found.
onecoreuap\drivers\wdm\bluetooth\user\winrt\device\bluetoothledevice.cpp(1417)\Windows.Devices.Bluetooth.dll!00007FFFA4CDF000: (caller: 00007FFFA4CE9591) LogHr(2) tid(56c) 80070490 Element not found.
[...]
onecoreuap\drivers\wdm\bluetooth\user\winrt\common\devquerydevpropprovider.cpp(297)\Windows.Devices.Bluetooth.dll!00007FFFA4CCB4F1: (caller: 00007FFFA4CCAFC6) ReturnHr(5) tid(2e84) 80070490 Element not found.
onecoreuap\drivers\wdm\bluetooth\user\winrt\common\devquerydevpropprovider.cpp(131)\Windows.Devices.Bluetooth.dll!00007FFFA4CCB01A: (caller: 00007FFFA4CDEFE8) ReturnHr(6) tid(2e84) 80070490 Element not found.
onecoreuap\drivers\wdm\bluetooth\user\winrt\device\bluetoothledevice.cpp(1417)\Windows.Devices.Bluetooth.dll!00007FFFA4CDF000: (caller: 00007FFFA4CE9591) LogHr(3) tid(2e84) 80070490 Element not found.
When I use the same code in isolation (i.e. in a Visual Studio project which doesn’t use Unity) it correctly works: I can use BLE devices correctly.
The entire log is attached. How can I get rid of these errors? Thank you very much!
Can we get a bug report on this? It might be a bug in il2cpp somewhere.
Another question: did you try stepping through the calls with a debugger (you can debug C# with il2cpp starting with 2018.2)? Did it get stuck on any of the calls?
Did you enable Bluetooth capability in the manifest?
If you enable native mode debugging in .NET UWP project where it works, do these errors show up too?
Unfortunately, I’ve to write BLE instructions inside preprocessor directives #if !UNITY_EDITOR since they don’t work in the editor. So, when I debug them, they’re skipped.
Oh, sorry. The problem is that when I try to attach the debugger I can see only Editor’s process and not Player’s one. In the project settings I’ve enabled: Development Build, Script Debugging and Wait For Managed Debugger (and actually I can see the waiting dialog when the application starts).
Oh thanks, now I can debug it. Here is what happens. In my non-Unity application, when I debug its C# code, the debugger correctly process this instruction (doing a step by step debug):
We’ll take a look at the bug report. And we’re looking into why that would happen with the debugger - it seems related to await keyword. Sorry for inconvenience!
We could actually never reproduce the problem. We resolved the bug as non-reproducible and the original reporter never followed up on it. It worked fine on our end.
Hey, I think I found my issue, I was using “#if NETFX_CORE” around my code in order to make it work in the editor, but I guess since the backend is il2cpp it doesn’t work for that, so i’m gonna try to replace my NETFX_CORE with WINDOWS_UWP like this dude suggested : https://forums.hololens.com/discussion/3217/enabling-ble-in-hololens-app and then I’ll see if it works and I’ll get back to you.
Yeah, NETFX_CORE isn’t defined on IL2CPP scripting backend as that define meant “reduced API surface for UWP”, while IL2CPP has access to the full API surface.
I am facing the exact same issue in Hololens 1, Can you help me with that. Below is my code for accessing Bluetooth in Unity. I can build the project but after deploying it to Hololens 1 visual studio is giving me following errors.
‘Yamaha MR AVPRO.exe’ (Win32): Loaded ‘C:\Windows\System32\Windows.Devices.Bluetooth.dll’. Symbols loaded.
‘Yamaha MR AVPRO.exe’ (Win32): Loaded ‘C:\Windows\System32\Windows.Networking.dll’. Symbols loaded.
‘Yamaha MR AVPRO.exe’ (Win32): Loaded ‘C:\Windows\System32\FirewallAPI.dll’. Symbols loaded.
‘Yamaha MR AVPRO.exe’ (Win32): Loaded ‘C:\Windows\System32\fwbase.dll’. Symbols loaded.
‘Yamaha MR AVPRO.exe’ (Win32): Loaded ‘C:\Windows\System32\Windows.Internal.Bluetooth.dll’. Symbols loaded.
‘Yamaha MR AVPRO.exe’ (Win32): Loaded ‘C:\Windows\System32\deviceaccess.dll’. Symbols loaded.
onecoreuap\drivers\wdm\bluetooth\user\winrt\common\devicehandle.cpp(117)\Windows.Devices.Bluetooth.dll!61C94C0D: (caller: 61C952C9) Exception(1) tid(10c0) 80070005 Access is denied.
Exception thrown at 0x77062DE2 in Yamaha MR AVPRO.exe: Microsoft C++ exception: wil::ResultException at memory location 0x00E8E360.
Exception thrown at 0x77062DE2 in Yamaha MR AVPRO.exe: Microsoft C++ exception: [rethrow] at memory location 0x00000000.
onecoreuap\drivers\wdm\bluetooth\user\winrt\advertisement\bluetoothleadvertisementwatcher.cpp(1510)\Windows.Devices.Bluetooth.dll!61C73426: (caller: 61C74CC2) Exception(2) tid(10c0) 80070005 Access is denied.
Exception thrown at 0x77062DE2 in Yamaha MR AVPRO.exe: Microsoft C++ exception: wil::ResultException at memory location 0x00E8E418.
Exception thrown at 0x77062DE2 in Yamaha MR AVPRO.exe: Microsoft C++ exception: [rethrow] at memory location 0x00000000.
The thread 0x1058 has exited with code 0 (0x0).
Hello,
I am trying to create a game which uses a bluetooth device to capture the heart rate of the player. I have created a WPF library with the code needed to connect to the bluetooth device and receive the values, however, I am not sure how to use it in my Unity project.
Since the library uses windows namespaces, iIhad to disable the dll for the editor and leave it only for WSAPlayer and standalone, now I am not sure how to reference the namespace of this library in my code and how to call the functions and receive values from it to be used in my project.
I tried wrapping the code inside #if NETFX_CORE and #if ENABLE_WINMD_SUPPORT and even #if WINDOWS_UWP, how am I to debug if the connections and everything is working?
Is there somewhere we can go to learn about accessing bluetooth information from the system ex Windows.Devices.Bluetooth within Unity? Seems a little crazy that Unity doesnt have something for talking to PC based bluetooth devices.