A repository for smartBASIC applications that run on the Laird Connectivity BL654 (Released under the ISC License).
Laird Connectivity’s BL654 contains the latest generation silicon with Bluetooth Low Energy v5 capabilities and groundbreaking ultra-low power performance. Building on the expertise of the BL600 and BL652 Series, the BL654’s class-leading Nordic nRF52840 silicon, optimized low power schemes and smartBASIC programming language provide a secure, stable, hostless Bluetooth environment. The BL654 introduces Bluetooth v5, bringing long range connectivity, industrial security and feature expansion to Laird Connectivity’s proven Bluetooth Low Energy modules. Let Laird Connectivity’s innovative BL654 series and decades of expertise in Bluetooth module design speed your product to market.
UwTerminalX is a cross-platform utility for communicating and downloading applications onto the BL654. The latest releases are available at https://github.com/LairdCP/UwTerminalX/releases
Documentation for the BL654 can be found on the Laird Connectivity BL654 website and documentation for the BL654PA can be found on the Laird Connectivty BL654PA website, including a quick start guide for using the AT interface application and user guide for the AT interface application
The files in this repository are designed for use with the latest BL654 firmware, which at the time of writing is 29.5.7.2. For applications targeting older firmware, please check the Releases tab
- Always check the resultcode returned from an API function. Non-zero result codes usually indicate that the operation has not been successful.
- smartBASIC is event driven; ensure that the application is written in an event-driven manner. Starting with a state-machine or a flowchart is highly recommended.
- Minimize the use of WAITEVENTs; ideally, WAITEVENT should be used only once at the end of the program to ensure the app is simple and robust.
- Minimize radio usage when possible to save power.
- Use comments wherever possible to ensure that the application can be read and understood.
- Only hard-code when necessary. When hard-coding, use #defines to give meaning to the constants used.
- Follow the smartBASIC app template found here.
Please note that for simplicity reasons, some sample apps have been written without important features such as error handling or result code checking. However, when writing your applications, please ensure that result codes returned from the API functions are always checked to ensure that your applications are robust and bug-free.