tree: e3f85d22b226748fc7ce5a1e0a183afb6390ee08 [path history] [tgz]
  1. doc/
  2. main/
  3. third_party/
  4. .gn
  5. args.gni
  6. BUILD.gn
  7. chip.syscfg
  8. README.md
examples/lock-app/cc13x2x7_26x2x7/README.md

CHIP CC1352 CC2652 Lock Example Application

An example application showing the use CHIP on the Texas Instruments CC13X2_26X2 family of Wireless MCUs.



Introduction

CC1352R1_LAUNCHXL

The CC13X2_26X2 lock example application provides a working demonstration of a connected door lock device. This uses the open-source CHIP implementation and the Texas Instruments SimpleLinkā„¢ CC13x2 and CC26x2 software development kit.

This example is enabled to build for CC2652R7 devices. This upcoming devices are currently not yet in full production. For more information on device availability or early access to an engineering build of our CHIP-enabled SDK, please reach out here.

The lock example is intended to serve both as a means to explore the workings of CHIP, as well as a template for creating real products based on the Texas Instruments devices.

Device UI

This example application has a simple User Interface to depict the state of the door lock and to control the state. The user LEDs on the LaunchPad are set on when the lock is locked, and are set off when unlocked. The LEDs will flash when in the transition state between locked and unlocked.

Short presses (less than 1000ms) of the user buttons are used for requesting lock and unlock of the door lock. The left button (BTN-1) is used to request locking. The right button (BTN-2) is used to request unlocking.

Long presses (greater than 1000ms) of the user buttons are used for controlling BLE advertisements. The left button (BTN-1) is used to disable advertisements if they are enabled. The Right button (BTN-2) is used to enable advertisements.

Building

Preparation

Some initial setup is necessary for preparing the build environment. This section will need to be done when migrating to new versions of the SDK. This guide assumes that the environment is linux based, and recommends Ubuntu 20.04.

  • An engineering SDK from TI is required. Please request access for it here.

    • Follow the default installation instructions when executing the installer.

    • The version of OpenThread used in this repository is newer than the one packaged with the TI SDK. Check the following section for a list of changes needed.

  • Download and install SysConfig (recommended version)

    • This may have already been installed with your SimpleLink SDK install.
  • If you have installed different versions, the build defaults will need to be changed to reflect this in ${chip_root}/examples/build_overrides/ti_simplelink_sdk.gni.

  • Install Python 3.8 for the GN build system:

    # Linux
    $ sudo apt-get install python3.8 python3.8-distutils python3.8-dev python3.8-venv
    # Distutils listed due to a package manager error on Ubuntu 18.04
    
    
    • You will have to ensure that the default version of Python 3 is Python 3.8.

      • Check python3 version:
      $ python3 --version
      Python 3.8.0
      
      • If it is not Python 3.8:
      $ sudo update-alternatives --install /usr/bin/python3 python3 /usr/bin/python3.8 1
      
      -   This may affect your environment in other ways if there was a
          specific dependency on the prior python3 version (e.g. apt).
          After completing the build process for this example, you can
          revert the python3 version, for instance:
      
          ```
          $ sudo update-alternatives --config python3
          There are 2 choices for the alternative python3 (providing /usr/bin/python3).
      
            Selection    Path                Priority    Status
          -------------------------------------------------------------
            0            /usr/bin/python3.8   1          auto mode
            1            /usr/bin/python3.6   1          manual mode
          * 2            /usr/bin/python3.8   1          manual mode
      
          Press <enter> to keep the current choice[*], or type selection number: 1
          update-alternatives: using /usr/bin/python3.6 to provide /usr/bin/python3 (python3) in manual mode
          ```
      
  • Run the bootstrap script to setup the build environment.

    $ cd ~/connectedhomeip
    $ source ./scripts/bootstrap.sh
    
    

Compilation

It is necessary to activate the environment in every new shell. Then run GN and Ninja to build the executable.

  • Activate the build environment with the repository activate script.

    $ cd ~/connectedhomeip
    $ source ./scripts/activate.sh
    
    
  • Run the build to produce a default executable. By default on Linux both the TI SimpleLink SDK and Sysconfig are located in a ti folder in the user's home directory, and you must provide the absolute path to them. For example /home/username/ti/simplelink_cc13x2_26x2_sdk_4_40_05_02_eng and /home/username/ti/sysconfig_1.7.0. On Windows the default directory is C:\ti. Take note of this install path, as it will be used in the next step.

    $ cd ~/connectedhomeip/examples/lock-app/cc13x2x7_26x2x7
    $ export TI_SIMPLELINK_SDK_ROOT=<path-to-simplelink-sdk>
    $ export TI_SYSCONFIG_ROOT=<path-to-sysconfig-sdk>
    $ gn gen out/debug --args="ti_simplelink_sdk_root=\"${TI_SIMPLELINK_SDK_ROOT}\" ti_sysconfig_root=\"${TI_SYSCONFIG_ROOT}\""
    $ ninja -C out/debug
    
    

Programming

Loading the built image onto a LaunchPad is supported through two methods; Uniflash and Code Composer Studio (CCS). UniFlash can be used to load the image. Code Composer Studio can be used to load the image and debug the source code.

UniFlash

Programming UniFlash

Code Composer Studio

Programming and Debugging with CCS

Viewing Logging Output

By default the log output will be sent to the Application/User UART. Open a terminal emulator to that port to see the output with the following options:

ParameterValue
Speed (baud)115200
Data bits8
Stop bits1
ParityNone
Flow controlNone

Running the Example

Once a device has been flashed with this example, it can now join and operate in an existing Thread network. The following sections assume that a Thread network is already active, and has at least one OpenThread Border Router.

Provisioning

The first step to bring the CHIP device onto the network is to provision it. Our example accomplishes this with Bluetooth Low Energy (BLE) and the CHIPTool mobile app.

Bluetooth LE Advertising

To provision this example onto a Thread network, the device must be discoverable over Bluetooth LE. BLE advertising is started by long pressing the right button (greater than 1000ms), labeled BTN-2 on the silkscreen. Once the device is fully provisioned, BLE advertising will stop.

Bluetooth LE Rendezvous

In this example, the provisioning procedure (called Rendezvous) is done over Bluetooth LE between a CHIP device (lock-app) and the CHIP controller (CHIPTool), where the controller has the commissioner role.

To start the rendezvous, the controller must get the commissioning information from the CHIP device.

This is done by scanning a QR code. A URL will be displayed on the lock-app's log (UART terminal). It will look like the following:

SetupQRCode:  [CH:.81TM -00 0C9SS0]
Copy/paste the below URL in a browser to see the QR Code:
https://dhrishi.github.io/connectedhomeip/qrcode.html?data=CH%3A.81TM%20-00%200C9SS0

You can directly navigate to the webpage URL displayed (which has QR payload pre-loaded). Alternatively, you can navigate to the QR code generator and enter in the payload shown in SetupQRCode (in this case CH:.81TM -00 0C9SS0).

CHIP Remote Commands

Once the CHIP device is provisioned and operating on the network, CHIPTool can be used to control the device. During the provisioning process, the CHIP device would have sent one of its newly assigned IPv6 addresses to the CHIPTool.

In the app, you should see an On/Off cluster; this corresponds to the lock-app. You can now control the lock-app CHIP device from the smartphone!

TI Support

For technical support, please consider creating a post on TI's E2E forum. Additionally, we welcome any feedback.