This code example demonstrates how to monitor the CapSense™ data and tune CapSense™ sensors over Bluetooth® LE communication with CapSense™ tuner GUI using PSoC™ 6 CY8C63x7 MCU with AIROC™ Bluetooth® LE.
This code example has two applications:
-
Tuning CapSense™ over Bluetooth® LE - server: This design has a self-capacitance (CSD) based 5-segment CapSense™ slider and two mutual capacitance (CSX)-based CapSense™ buttons. It has a PSoC™ 6 CY8C63x7 MCU with AIROC™ Bluetooth® LE configured as a Bluetooth® LE Peripheral and GATT Server that sends CapSense™ raw data to the GATT Client. This project should be run on a board with CapSense™ sensors that needs to be tuned over Bluetooth® LE communication.
-
Tuning CapSense™ over Bluetooth® LE - client: The design has a PSoC™ 6 CY8C63x7 MCU with AIROC™ Bluetooth® LE configured as a GATT Client to receive CapSense™ raw data from a GATT Server. It also has an EZI2C interface to communicate with the CapSense™ tuner. This project needs to be run on a board that has Bluetooth® LE capability and has a connection to the CapSense™ tuner through the EZI2C interface.
Note: This code example shows the GATT Server-side of the example project. See PSoC™ 6 MCU: tuning CapSense™ over Bluetooth® LE- client for the GATT Client-side of the project.
Figure 1. High-level block diagram
Provide feedback on this code example.
-
ModusToolbox™ software v2.2 or later
Note: This code example version requires ModusToolbox™ software version 2.2 or later and is not backward compatible with v2.1 or older versions. If you cannot move to ModusToolbox™ v2.2, use the latest compatible version of this example: latest-v1.X.
-
Board support package (BSP) minimum required version: 2.0.0
-
Programming language: C
-
Associated parts: All PSoC™ 6 MCU parts
- GNU Arm® embedded compiler v9.3.1 (
GCC_ARM
) - Default value ofTOOLCHAIN
- Arm® compiler v6.13 (
ARM
) - IAR C/C++ compiler v8.42.2 (
IAR
)
- PSoC™ 6 Bluetooth® LE pioneer kit (
CY8CKIT-062-BLE
) - Default value ofTARGET
- PSoC™ 6 Bluetooth® LE pioneer kit (CY8CKIT-062-BLE) - Default value of
TARGET
- PSoC™ 6 Bluetooth® LE prototyping kit (CY8CPROTO-063-BLE)
- EZ-BLE Arduino evaluation board (CYBLE-416045-EVAL)
This example uses the board's default configuration. See the kit user guide to ensure that the board is configured correctly.
Two PSoC™ 6 Bluetooth® LE boards are required to test this code example: one for the application Tuning CapSense™ over Bluetooth® LE - server and another for the application Tuning CapSense™ over Bluetooth® LE - client. See Supported kits for the list of kits supported by each code example.
Note: The PSoC™ 6 Bluetooth® LE pioneer kit (CY8CKIT-062-BLE) and the PSoC™ 6 Wi-Fi Bluetooth® pioneer kit (CY8CKIT-062-WIFI-BT) ship with KitProg2 installed. The ModusToolbox™ software requires KitProg3. Before using this code example, make sure that the board is upgraded to KitProg3. The tool and instructions are available in the Firmware Loader GitHub repository. If you do not upgrade, you will see an error like "unable to find CMSIS-DAP device" or "KitProg firmware is out of date".
Install a terminal emulator if you don't have one. Instructions in this document use Tera Term.
This example requires no additional software or tools.
Create the project and open it using one of the following:
In Eclipse IDE for ModusToolbox™
-
Click the New Application link in the Quick Panel (or, use File > New > ModusToolbox Application). This launches the Project Creator tool.
-
Pick a kit supported by the code example from the list shown in the Project Creator - Choose Board Support Package (BSP) dialog.
When you select a supported kit, the example is reconfigured automatically to work with the kit. To work with a different supported kit later, use the Library manager to choose the BSP for the supported kit. You can use the Library Manager to select or update the BSP and firmware libraries used in this application. To access the Library manager, click the link from the Quick Panel.
You can also just start the application creation process again and select a different kit.
If you want to use the application for a kit not listed here, you may need to update the source files. If the kit does not have the required resources, the application may not work.
-
In the Project Creator - Select Application dialog, choose the examples CapSense Tuning Over BLE - Server and CapSense Tuning Over BLE - Client by enabling the checkbox.
-
Optionally, change the suggested New Application Name.
-
Enter the local path in the Application(s) Root Path field to indicate where the application needs to be created.
Applications that can share libraries can be placed in the same root path.
-
Click Create to complete the application creation process.
For more details, see the Eclipse IDE for ModusToolbox™ user guide (locally available at {ModusToolbox™ install directory}/ide_{version}/docs/mt_ide_user_guide.pdf).
In command-line interface (CLI)
ModusToolbox™ provides the Project Creator as both a GUI tool and a command line tool to easily create one or more ModusToolbox™ applications. See the "Project Creator tools" section of the ModusToolbox™ user guide for more details.
Alternatively, you can manually create the application using the following steps:
-
Download and unzip this repository onto your local machine, or clone the repository.
-
Open a CLI terminal and navigate to the application folder.
On Windows, use the command line "modus-shell" program provided in the ModusToolbox™ installation instead of a standard Windows command line application. This shell provides access to all ModusToolbox™ tools. You can access it by typing
modus-shell
in the search box in the Windows menu.In Linux and macOS, you can use any terminal application.
Note: The cloned application contains a default BSP file (TARGET_xxx.mtb) in the deps folder. Use the Library manager (
make modlibs
command) to select and download a different BSP file, if required. If the selected kit does not have the required resources or is not supported, the application may not work. -
Import the required libraries by executing the
make getlibs
command. -
Repeat steps 1 to 3 for the repository PSoC™ 6 MCU: tuning CapSense™ over Bluetooth® LE - client and place it in the same workspace folder.
Various CLI tools include a -h
option that prints help information to the terminal screen about that tool. For more details, see the ModusToolbox™ user guide (locally available at {ModusToolbox™ install directory}/docs_{version}/mtb_user_guide.pdf).
In third-party IDEs
-
Follow the instructions from the In command-line interface (CLI) section to create the application, and import the libraries using the
make getlibs
command. -
Export the application to a supported IDE using the
make <ide>
command.For a list of supported IDEs and more details, see the "Exporting to IDEs" section of the ModusToolbox™ user guide (locally available at {ModusToolbox™ install directory}/docs_{version}/mtb_user_guide.pdf.
-
Follow the instructions displayed in the terminal to create or import the application as an IDE project.
See Supported kits for the list of kits supported by this code example.
-
Connect the board to your PC using the provided USB cable through the KitProg3 USB connector.
-
Open a terminal program and select the KitProg3 COM port. Set the serial port parameters to 8N1 and 115200 baud.
-
Program the board using one of the following:
Using Eclipse IDE for ModusToolbox™
-
Select the application project Tuning CapSense™ over Bluetooth® LE - server in the Project Explorer.
-
In the Quick Panel, scroll down, and click <Application Name> Program (KitProg3_MiniProg4).
Using CLI
From the terminal, execute the
make program
command to build and program the application using the default toolchain to the default target. You can specify a target and toolchain manually:make program TARGET=<BSP> TOOLCHAIN=<toolchain>
Example:
make program TARGET=CY8CKIT-062-BLE TOOLCHAIN=GCC_ARM
-
-
After programming, the application starts automatically. Confirm that "Tuning CapSense over BLE - Server" is displayed on the UART terminal.
Figure 2. Terminal output of the GATT Server while advertising
See Supported kits for the list of kits supported by this project.
-
Connect the board to your PC using the provided USB cable through the KitProg3 USB connector.
-
Open a terminal program and select the KitProg3 COM port. Set the serial port parameters to 8N1 and 115200 baud.
-
Program the board using one of the following:
Using Eclipse IDE for ModusToolbox™
-
Select the application project Tuning CapSense™ over Bluetooth® LE - client in the Project Explorer.
-
In the Quick Panel, scroll down, and click <Application Name> Program (KitProg3_MiniProg4).
Using CLI
From the terminal, execute the
make program
command to build and program the application using the default toolchain to the default target. You can specify a target and toolchain manually:make program TARGET=<BSP> TOOLCHAIN=<toolchain>
Example:
make program TARGET=CY8CPROTO-063-BLE TOOLCHAIN=GCC_ARM
-
-
After programming, the application starts automatically. Confirm that "Tuning CapSense over BLE - Client" is displayed on the UART terminal.
Figure 3. Terminal output of the GATT Client while scanning
-
Connect both boards to your PC and open the corresponding terminals to view UART messages. If required, reset the board after opening the UART terminal.
-
Observe that the USER_LED1 is turned ON in both boards indicating that the Bluetooth® LE connection is established between the two PSoC™ 6 MCU devices.
-
Verify that the tuner bridge initialization data is sent from the GATT Server to the GATT Client. See Figure 4 and Figure 5.
Figure 4. Terminal output of the GATT Server
Figure 5. Terminal output of the GATT Client
-
Select File > Disconnect and disconnect the UART terminal connected to the device programmed with Tuning CapSense™ over Bluetooth® LE - client.
-
Launch the CapSense™ tuner for the Tuning CapSense™ over Bluetooth® LE - server application. See the "Launch the CapSense™ tuner" section of the CapSense™ tuner guide.
-
In CapSense™ tuner, click the Setup Tuner Communication button. Alternatively, select Tools > Setup Tuner Communication.
-
Connect to the KitProg of the kit that is programmed with Tuning CapSense™ over Bluetooth® LE - client. Check the I2C checkbox and set the following values in the port configuration section:
- I2C Address : 8
- Sub-address : 2-Bytes
- Speed (kHz) : 1000
-
Click Connect, and then click Start to extract the CapSense™ data. You can see the data rate of the packets in the bottom panel.
-
Touch the sensors on the board that is programmed with Tuning CapSense™ over Bluetooth® LE - server and notice the change in the sensor/widget status on the Widget View tab.
-
Open the Graph View tab. Check the sensors in the Widget Explorer pane to observe sensor signals in the graph. Touch the sensors and notice the signal change on the Graph View tab.
-
Change widget/sensor parameter values as needed, and then click Apply to Device to apply the new settings to the device.
Note: The Apply to Device option requires the CapSense™ tuner to be in Synchronized mode of operation.
For more details on monitoring CapSense™ data, tuning CapSense™ parameter tuning, and measuring SNR, see the CapSense™ tuner guide. See AN85951 – PSoC™ 4 and PSoC™ 6 MCU CapSense™ design guide for more details on selecting the right tuning parameters.
You can debug the example to step through the code. In the IDE, use the <Application Name> Debug (KitProg3_MiniProg4) configuration in the Quick Panel. For more details, see the "Program and debug" section in the Eclipse IDE for ModusToolbox™ user guide.
Note: (Only while debugging) On the CM4 CPU, some code in main()
may execute before the debugger halts at the beginning of main()
. This means that some code executes twice - once before the debugger stops execution, and again after the debugger resets the program counter to the beginning of main()
. See KBA231071 to learn about this and for the workaround.
The design has a PSoC™ 6 CY8C63x7 MCU with AIROC™ Bluetooth® LE device configured as a GAP Peripheral and a GATT Server with the CapSense_Tuner custom service. This service has two custom characteristics: CapSense_DS and Tuner_Command. The CapSense_DS characteristic is loaded with the CapSense™ context structure cy_capsense_tuner. The Tuner_Command characteristic is used to receive command packets from the GATT Client which were received from the CapSense™ tuner. This code example supports 2M PHY and data length extension (DLE) features to maximize the throughput.
The design also has a CSD-based, 5-segment CapSense™ slider and two CSX-based CapSense™ buttons. The project uses the CapSense™ middleware. See ModusToolbox™ user guide for more details on selecting a middleware. See AN85951 – PSoC™ 4 and PSoC™ 6 MCU CapSense™ design guide for more details of CapSense™ features and usage.
When the kit is powered up, the CapSense™ and Bluetooth® LE blocks are initialized. The PSoC™ 6 CY8C63x7 MCU with AIROC™ Bluetooth® LE device is configured as Bluetooth® LE GAP Peripheral and GATT Server. The Bluetooth® LE initialization function initializes the Bluetooth® LE stack and registers the Bluetooth® LE stack event handler (an application-level callback function to process Bluetooth® LE events). The tuner_send_callback function (an application-level callback function to facilitate data transmission using Bluetooth® LE) is registered in the CapSense™ middleware to send the cy_capsense_tuner CapSense™ context structure to the GATT Client.
When the Bluetooth® LE connection to the GATT Client device is successful, USER_LED1 will turn ON.
After a successful Bluetooth® LE connection, the GATT Client enables the notifications of the CapSense_DS characteristic using client characteristic configuration descriptor (CCCD). Once notifications are enabled, tuner bridge initialization parameters such as the size of CapSense™ context structure and the number of notification packets required to send the complete CapSense™ context structure are sent to the peer GATT Client device.
The application periodically scans the CapSense™ buttons for user inputs. The Cy_CapSense_RunTuner()
function is called periodically in the application program to establish synchronized communication with the CapSense™ tuner application. The Cy_CapSense_RunTuner()
function calls the user-registered callback function tuner_send_callback
to send the CapSense™ data structure cy_capsense_tuner
to the GATT Client. The cy_capsense_tuner
structure is sent as notification packets using the CapSense_DS characteristic.
When you change the CapSense™ hardware parameters such as resolution, number of sub-conversions, and so on from the CapSense™ tuner, it modifies the CapSense™ context structure. The GATT Server receives this as a write command through the Tuner_Command characteristic. The write command contains the offset address of the CapSense™ context structure that is modified, actual data modified, and the number of bytes modified by the CapSense™ tuner. The application is notified of this event through the Bluetooth® LE stack event handler. The application then modifies the CapSense™ context structure directly using this information.
Figure 6. High-level firmware flowchart
Table 1. Application resources
Resource | Alias/object | Purpose |
---|---|---|
Bluetooth® LE | CYBSP_BLE | Establish Bluetooth® LE communication with the GATT Client |
CSD | CYBSP_CSD | CapSense™ driver to interface touch sensors |
UART (HAL) | cy_retarget_io_uart_obj | UART HAL object used by Retarget-IO for debug UART port |
GPIO (HAL) | CYBSP_USER_LED1 | User LED |
The design has a PSoC™ 6 CY8C63x7 MCU with AIROC™ Bluetooth® LE device configured as Bluetooth® LE GAP Central and GATT Client with the CapSense_Tuner custom service. The design also uses a serial communication block (SCB) configured as EZIZC to establish I2C communication with the onboard KitProg, which enables the CapSense™ tuner to read the CapSense™ raw data. The CapSense™ tuner is a standalone tool that runs on a PC, and is included in the ModusToolbox™ software to tune CapSense™ applications. This code example supports 2M PHY and data length extension (DLE) features to maximize the throughput.
When the kit is powered up, the Bluetooth® LE and SCB (configured as EZI2C) blocks are initialized. The Bluetooth® LE initialization function initializes the Bluetooth® LE stack and registers the Bluetooth® LE stack event handler (an application-level callback function to process Bluetooth® LE events).
When the Bluetooth® LE connection to the GATT Server device is successful, USER_LED1 will turn ON.
After the Bluetooth® LE connection is established, the notifications are enabled to receive data from the GATT Server using the CCCD handle of the CapSense_DS characteristic. Once notifications are enabled, the tuner bridge initialization parameters such as size of CapSense™ context structure and the number of notification packets required to send the complete CapSense™ context structure are received from the peer GATT Server device. This is used to set the size of the EZI2C buffer.
When you change the CapSense™ hardware parameters such as resolution, number of sub-conversions, and so on from the CapSense™ tuner, it modifies the CapSense™ context structure (EZI2C buffer).
The application does the following:
-
Checks whether a notification event is received from the GATT Server device through the CapSense_DS characteristic. Once a notification containing the CapSense™ context structure is received, it is loaded to the EZI2C buffer to be read by the CapSense™ tuner (I2C Master).
-
Checks whether a I2C write event has been triggered by the CapSense™ tuner (I2C master). Once write event is received, the application finds the offset, number of bytes modified, and the data written on the CapSense™ context structure by the CapSense™ tuner. This data is communicated to the peer GATT Server through a GATT write command using the Tuner_Command characteristic handle.
Figure 7. High-level firmware flowchart
Table 2. Application resources
Resource | Alias/object | Purpose |
---|---|---|
Bluetooth® LE | CYBSP_BLE | Establish Bluetooth® LE communication with the GATT Server |
SCB | EZI2C | EZI2C driver to interface with the CapSense™ tuner |
UART (HAL) | cy_retarget_io_uart_obj | UART HAL object used by Retarget-IO for Debug UART port |
GPIO (HAL) | CYBSP_USER_LED1 | User LED |
Application notes | |
---|---|
AN228571 – Getting started with PSoC™ 6 MCU on ModusToolbox™ | Describes PSoC™ 6 MCU devices and how to build your first application with ModusToolbox™ |
AN221774 – Getting started with PSoC™ 6 MCU on PSoC™ Creator™ | Describes PSoC™ 6 MCU devices and how to build your first application with PSoC™ Creator™ |
AN210781 – Getting started with PSoC™ 6 MCU with Bluetooth® Low Energy connectivity on PSoC™ Creator™ | Describes PSoC™ 6 MCU with Bluetooth® LE connectivity devices and how to build your first application with PSoC™ Creator™ |
AN215656 – PSoC™ 6 MCU: dual-CPU system design | Describes the dual-CPU architecture in PSoC™ 6 MCU, and shows how to build a simple dual-CPU design |
AN85951 – PSoC™ 4 and PSoC™ 6 MCU CapSense™ design guide | Describes how to design capacitive touch sensing applications with the PSoC™ 6 MCU families of devices |
Code examples | |
Using ModusToolbox™ | Using PSoC™ Creator™ |
Device documentation | |
PSoC™ 6 MCU datasheets | PSoC™ 6 technical reference manuals |
Development kits | Buy at www.cypress.com |
CY8CKIT-062-BLE PSoC™ 6 Bluetooth® LE pioneer kit | CY8CPROTO-063-BLE PSoC™ 6 Bluetooth® LE prototyping kit |
CYBLE-416045-EVAL EZ-BLE Arduino evaluation board | |
Libraries | |
PSoC™ 6 peripheral driver library (PDL) and docs | mtb-pdl-cat1 on GitHub |
Hardware abstraction layer (HAL) Library and docs | mtb-hal-cat1 on GitHub |
Retarget-IO - A utility library to retarget the standard input/output (STDIO) messages to a UART port | retarget-io on GitHub |
Middleware | |
BLESS library and documents | bless on GitHub |
CapSense™ library and documents | capsense on GitHub |
Links to all PSoC™ 6 MCU middleware | psoc6-middleware on GitHub |
Tools | |
Eclipse IDE for ModusToolbox™ | The cross-platform, Eclipse-based IDE for IoT designers that supports application configuration and development targeting converged MCU and wireless systems. |
PSoC™ Creator™ | The legacy Cypress IDE for PSoC™ and FM0+ MCU development. |
Cypress provides a wealth of data at www.cypress.com to help you select the right device, and quickly and effectively integrate it into your design.
For PSoC™ 6 MCU devices, see How to design with PSoC™ 6 MCU - KBA223067 in the Cypress community.
Document title: CE230220 - PSoC™ 6 MCU: Tuning CapSense™ over Bluetooth® LE - server
Version | Description of Change |
---|---|
1.0.0 | New code example |
2.0.0 | Major update to support ModusToolbox™ software v2.2 This version is not backward compatible with ModusToolbox™ software v2.1 |
2.1.0 | Added support for new kit in client project Updated CE to use HAL drivers |
All other trademarks or registered trademarks referenced herein are the property of their respective owners.
© Cypress Semiconductor Corporation, 2016-2021. This document is the property of Cypress Semiconductor Corporation, an Infineon Technologies company, and its affiliates ("Cypress"). This document, including any software or firmware included or referenced in this document ("Software"), is owned by Cypress under the intellectual property laws and treaties of the United States and other countries worldwide. Cypress reserves all rights under such laws and treaties and does not, except as specifically stated in this paragraph, grant any license under its patents, copyrights, trademarks, or other intellectual property rights. If the Software is not accompanied by a license agreement and you do not otherwise have a written agreement with Cypress governing the use of the Software, then Cypress hereby grants you a personal, non-exclusive, nontransferable license (without the right to sublicense) (1) under its copyright rights in the Software (a) for Software provided in source code form, to modify and reproduce the Software solely for use with Cypress hardware products, only internally within your organization, and (b) to distribute the Software in binary code form externally to end users (either directly or indirectly through resellers and distributors), solely for use on Cypress hardware product units, and (2) under those claims of Cypress’s patents that are infringed by the Software (as provided by Cypress, unmodified) to make, use, distribute, and import the Software solely for use with Cypress hardware products. Any other use, reproduction, modification, translation, or compilation of the Software is prohibited.
TO THE EXTENT PERMITTED BY APPLICABLE LAW, CYPRESS MAKES NO WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, WITH REGARD TO THIS DOCUMENT OR ANY SOFTWARE OR ACCOMPANYING HARDWARE, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE. No computing device can be absolutely secure. Therefore, despite security measures implemented in Cypress hardware or software products, Cypress shall have no liability arising out of any security breach, such as unauthorized access to or use of a Cypress product. CYPRESS DOES NOT REPRESENT, WARRANT, OR GUARANTEE THAT CYPRESS PRODUCTS, OR SYSTEMS CREATED USING CYPRESS PRODUCTS, WILL BE FREE FROM CORRUPTION, ATTACK, VIRUSES, INTERFERENCE, HACKING, DATA LOSS OR THEFT, OR OTHER SECURITY INTRUSION (collectively, "Security Breach"). Cypress disclaims any liability relating to any Security Breach, and you shall and hereby do release Cypress from any claim, damage, or other liability arising from any Security Breach. In addition, the products described in these materials may contain design defects or errors known as errata which may cause the product to deviate from published specifications. To the extent permitted by applicable law, Cypress reserves the right to make changes to this document without further notice. Cypress does not assume any liability arising out of the application or use of any product or circuit described in this document. Any information provided in this document, including any sample design information or programming code, is provided only for reference purposes. It is the responsibility of the user of this document to properly design, program, and test the functionality and safety of any application made of this information and any resulting product. "High-Risk Device" means any device or system whose failure could cause personal injury, death, or property damage. Examples of High-Risk Devices are weapons, nuclear installations, surgical implants, and other medical devices. "Critical Component" means any component of a High-Risk Device whose failure to perform can be reasonably expected to cause, directly or indirectly, the failure of the High-Risk Device, or to affect its safety or effectiveness. Cypress is not liable, in whole or in part, and you shall and hereby do release Cypress from any claim, damage, or other liability arising from any use of a Cypress product as a Critical Component in a High-Risk Device. You shall indemnify and hold Cypress, including its affiliates, and its directors, officers, employees, agents, distributors, and assigns harmless from and against all claims, costs, damages, and expenses, arising out of any claim, including claims for product liability, personal injury or death, or property damage arising from any use of a Cypress product as a Critical Component in a High-Risk Device. Cypress products are not intended or authorized for use as a Critical Component in any High-Risk Device except to the limited extent that (i) Cypress’s published data sheet for the product explicitly states Cypress has qualified the product for use in a specific High-Risk Device, or (ii) Cypress has given you advance written authorization to use the product as a Critical Component in the specific High-Risk Device and you have signed a separate indemnification agreement.
Cypress, the Cypress logo, and combinations thereof, WICED, ModusToolBox, PSoC, CapSense, EZ-USB, F-RAM, and Traveo are trademarks or registered trademarks of Cypress or a subsidiary of Cypress in the United States or in other countries. For a more complete list of Cypress trademarks, visit cypress.com. Other names and brands may be claimed as property of their respective owners.