Find a file
h2zero e6249623d5 Fix race condition in NimBLEScan::clearResults.
If clear results is called from more than one task a race condition exists that may delete the same advertisedDevice twice.
This prevents this by swapping with an empty vector and testing for empty before freeing the resources.
2025-01-12 18:11:57 -07:00
.github/workflows Release 2.0.0 2024-12-14 16:25:52 -07:00
docs Update new user guide 2025-01-10 09:11:49 -07:00
examples Increase timeout paramter in server example. 2025-01-05 14:31:43 -07:00
src Fix race condition in NimBLEScan::clearResults. 2025-01-12 18:11:57 -07:00
.clang-format Add clang-format. 2024-07-18 17:17:54 -06:00
.gitignore Fix NimBLEHIDDevice not being able to create more than one in/out/feature report + temporal coupling 2024-12-20 13:29:50 -07:00
CHANGELOG.md Release 2.0.3 2025-01-05 15:11:08 -07:00
CMakeLists.txt [BREAKING] Remove Eddystone URL 2024-12-01 16:00:28 -07:00
idf_component.yml Release 2.0.3 2025-01-05 15:11:08 -07:00
Kconfig NimBLEAddress default to including delimiter in string format 2025-01-08 15:24:08 -07:00
library.json Release 2.0.3 2025-01-05 15:11:08 -07:00
LICENSE Update license 2024-12-12 20:41:04 -07:00
NOTICE Update license 2024-12-12 20:41:04 -07:00
README.md Release 2.0.0 2024-12-14 16:25:52 -07:00

Release Version Release Date

Important

Version 2 is now released! Check out the 1.x to 2.x Migration Guide and Release Notes

esp-nimble-cpp

NimBLE CPP library for use with ESP32 that attempts to maintain compatibility with the nkolban cpp_utils BLE API.

An Arduino version of this library, including NimBLE, can be found here.

This library significantly reduces resource usage and improves performance for ESP32 BLE applications as compared
with the bluedroid based library. The goal is to maintain, as much as reasonable, compatibility with the original
library but using the NimBLE stack. In addition, this library will be more actively developed and maintained
to provide improved capabilities and stability over the original.

Testing shows a nearly 50% reduction in flash use and approx. 100kB less ram consumed vs the original!
Your results may vary

What is NimBLE?

NimBLE is a completely open source Bluetooth Low Energy stack produced by Apache.
It is more suited to resource constrained devices than bluedroid and has now been ported to the ESP32 by Espressif.

Installation

ESP-IDF v4.0+

Download as .zip and extract or clone into the components folder in your esp-idf project.

Run menuconfig, go to Component config->Bluetooth enable Bluetooth and in Bluetooth host NimBLE.
Configure settings in NimBLE Options.
#include "NimBLEDevice.h" in main.cpp.
Call NimBLEDevice::init(""); in app_main.

Using

This library is intended to be compatible with the original ESP32 BLE functions and types with minor changes.

If you have not used the original Bluedroid library please refer to the New user guide.

If you are familiar with the original library, see: The migration guide for details about breaking changes and migration.

Also see Improvements_and_updates for information about non-breaking changes.

Full API documentation and class list can be found here.

Using with Arduino as an IDF component and CMake

When using this library along with Arduino and compiling with CMake you must add add_compile_definitions(ARDUINO_ARCH_ESP32=1)
in your project/CMakeLists.txt after the line include($ENV{IDF_PATH}/tools/cmake/project.cmake) to prevent Arduino from releasing BLE memory.

Sponsors

Thank you to all the sponsors who support this project!

If you use this library for a commercial product please consider sponsoring the development to ensure the continued updates and maintenance.

Acknowledgments