A library for zigpy which communicates with TI ZNP radios
Project description
zigpy-znp
zigpy-znp is a Python library that adds support for common Texas Instruments ZNP (Zigbee Network Processors) Zigbee radio modules to zigpy, a Python Zigbee stack project.
Together with zigpy and compatible home automation software (namely Home Assistant's ZHA (Zigbee Home Automation) integration component), you can directly control Zigbee devices such as Philips Hue, GE, OSRAM LIGHTIFY, Xiaomi/Aqara, IKEA Tradfri, Samsung SmartThings, and many more.
Installation
Python module
Install the Python module within your virtual environment:
$ virtualenv -p python3.8 venv # if you don't already have one
$ source venv/bin/activate
(venv) $ pip install git+https://github.com/zha-ng/zigpy-znp/ # latest commit from Git
(venv) $ pip install zigpy-znp # or, latest stable from PyPI
Home Assistant
If you are using Home Assistant, copy custom_components/zha_custom_radios.py
into your custom_components
folder and create a new entry in your configuration.yaml
file:
zha_custom_radios:
znp:
module: zigpy_znp.zigbee.application
description: TI CC13x2, CC26x2, ZZH, and CC2531
If you have already setup Home Assistant's ZHA component with a TI radio, ZHA will be using the zigpy-cc library to communicate with the radio hardware. Navigate to the folder containing your configuration.yaml
file and edit the .storage/core.config_entries
, changing "radio_type": "ti_cc"
to "radio_type": "znp"
.
Firmware
CC2531 users will need to upgrade their firmware to Z-Stack 3.0.1. This is quick and simple if you are already running a build of Z-Stack. Make sure to plug your CC2531 in and run the below commands within 60s:
(venv) $ curl -L -o CC2531_20190425.zip https://github.com/Koenkk/Z-Stack-firmware/raw/master/coordinator/Z-Stack_3.0.x/bin/CC2531_20190425.zip
(venv) $ unzip CC2531_20190425.zip
(venv) $ python -m zigpy_znp.tools.flash_write -i CC2531ZNP-without-SBL.bin /dev/serial/by-id/YOUR-CC2531
2020-08-22 16:37:30 computer __main__[54567] INFO Write progress: 0.00%
2020-08-22 16:37:30 computer __main__[54567] INFO Write progress: 0.03%
2020-08-22 16:37:30 computer __main__[54567] INFO Write progress: 0.05%
2020-08-22 16:37:30 computer __main__[54567] INFO Write progress: 0.08%
2020-08-22 16:37:30 computer __main__[54567] INFO Write progress: 0.11%
...
(venv) $ python -m zigpy_znp.tools.nvram_reset /dev/serial/by-id/YOUR-CC2531 # note: this will clear your network settings!
Configuration
Below are the defaults with the top-level Home Assistant zha:
key:
zha:
zigpy_config:
znp_config:
tx_power: # if set, must be between -22 (low) and 19 (high)
led_mode: # if set, must be one of: off, on, blink, flash, toggle
skip_bootloader: True # skips the 60s bootloader delay on some CC2531 sticks
Backup and restore
A complete NVRAM backup can be performed to migrate between different radios based on the same chip. Anything else likely will not work.
(venv) $ python -m zigpy_znp.tools.nvram_read /dev/serial/by-id/old_radio -o backup.json
(venv) $ python -m zigpy_znp.tools.nvram_write /dev/serial/by-id/new_radio -i backup.json
Tested migrations:
- LAUNCHXL-CC26X2R1 running 3.30.00.03 to and from the zig-a-zig-ah! running 4.10.00.78.
Energy scan
Perform an energy scan to find a quiet Zigbee channel:
$ python -m zigpy_znp.tools.energy_scan /dev/cu.usbmodem14101
Channel energy (mean of 1 / 5):
------------------------------------------------
+ Lower energy is better
+ Active Zigbee networks on a channel may still cause congestion
+ Using 26 in the USA may have lower TX power due to FCC regulations
+ Zigbee channels 15, 20, 25 fall between WiFi channels 1, 6, 11
+ Some Zigbee devices only join networks on channels 15, 20, and 25
------------------------------------------------
- 11 61.57% #############################################################
- 12 60.78% ############################################################
- 13 12.16% ############
- 14 58.43% ##########################################################
- 15 57.65% #########################################################
- 16 29.80% #############################
- 17 38.82% ######################################
- 18 47.06% ###############################################
- 19 36.86% ####################################
- 20 10.98% ##########
- 21 16.47% ################
- 22 33.73% #################################
- 23 30.59% ##############################
- 24 20.39% ####################
- 25 5.88% #####
- 26* 20.39% ####################
Hardware requirements
USB-adapters, GPIO-modules, and development-boards running recent TI Z-Stack releases (above version 3.0.0) are supported. Reference hardware for this project includes:
- (STABLE) TI LAUNCHXL-CC26X2R1 running Z-Stack 3.30.00.03. You can flash
CC26X2R1_20191106.hex
using TI's UNIFLASH. - (STABLE) Electrolama's zig-a-zig-ah! running Z-Stack 4.10.00.78. You can flash
CC26X2R1_20200417.hex
using cc2538-bsl. - (BETA) CC2531 running Z-Stack 3.0.1. You can flash
CC2531ZNP-without-SBL.bin
to your stick directly withzigpy_znp
:python -m zigpy_znp.tools.flash_write -i /path/to/CC2531ZNP-without-SBL.bin /dev/serial/by-id/YOUR-CC2531
.
Older versions of Z-Stack are not currently supported. Z-Stack versions 3.x and above are currently required and all communication with the radio module is done over the the Z-Stack Monitor and Test (MT) interface via a serial port.
Texas Instruments Chip Part Numbers
Texas Instruments (TI) has quite a few different wireless MCU chips and they are all used/mentioned in open-source Zigbee world which can be daunting if you are just starting out. Here is a quick summary of part numbers and key features.
Supported newer generation TI chips
2.4GHz frequency only chips
- CC2652R = 2.4GHz only wireless MCU for IEEE 802.15.4 multi-protocol (Zigbee, Bluetooth, Thread, IEEE 802.15.4g IPv6-enabled smart objects like 6LoWPAN, and proprietary systems). Cortex-M0 core for radio stack and Cortex-M4F core for application use, plenty of RAM. Free compiler option from TI.
- CC2652RB = Pin compatible "Crystal-less" CC2652R (so you could use it if you were to build your own zzh and omit the crystal) but not firmware compatible.
- CC2652P = CC2652R with a built-in RF PA. Not pin or firmware compatible with CC2652R/CC2652RB.
Multi frequency chips
- CC1352R = Sub 1 GHz & 2.4 GHz wireless MCU. Essentially CC2652R with an extra sub-1GHz radio.
- CC1352P = CC1352R with a built in RF PA.
Auxiliary TI chips
- CC2591 and CC2592 = 2.4 GHz range extenders. These are not wireless MCUs, just auxillary PA (Power Amplifier) and LNA (Low Noise Amplifier) in the same package to improve RF (Radio Frequency) range of any 2.4 GHz radio chip.
Releases via PyPI
Tagged versions will also be released via PyPI
- https://pypi-hypernode.com/project/zigpy-znp/
- https://pypi-hypernode.com/project/zigpy-znp/#history
- https://pypi-hypernode.com/project/zigpy-znp/#files
External documentation and reference
How to contribute
If you are looking to make a code or documentation contribution to this project we suggest that you follow the steps in these guides:
- https://github.com/firstcontributions/first-contributions/blob/master/README.md
- https://github.com/firstcontributions/first-contributions/blob/master/github-desktop-tutorial.md
Related projects
Zigpy
zigpy is Zigbee protocol stack integration project to implement the Zigbee Home Automation standard as a Python library. Zigbee Home Automation integration with zigpy allows you to connect one of many off-the-shelf Zigbee adapters using one of the available Zigbee radio library modules compatible with zigpy to control Zigbee devices. There is currently support for controlling Zigbee device types such as binary sensors (e.g. motion and door sensors), analog sensors (e.g. temperature sensors), lightbulbs, switches, and fans. Zigpy is tightly integrated with Home Assistant's ZHA component and provides a user-friendly interface for working with a Zigbee network.
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
File details
Details for the file zigpy-znp-0.1.0.tar.gz
.
File metadata
- Download URL: zigpy-znp-0.1.0.tar.gz
- Upload date:
- Size: 103.9 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/3.2.0 pkginfo/1.5.0.1 requests/2.24.0 setuptools/49.3.1 requests-toolbelt/0.9.1 tqdm/4.48.2 CPython/3.8.5
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 65c16c542514a5946b1adae13702ff7b0ba5e9e91a17db24d7ac33535d1f30d4 |
|
MD5 | 331bb55fcb1cf2606007248a009c7043 |
|
BLAKE2b-256 | 8b67686afd8a4897d0669f528d4eda225c06b9336c39abc95280d5a8661fff40 |
Provenance
File details
Details for the file zigpy_znp-0.1.0-py3-none-any.whl
.
File metadata
- Download URL: zigpy_znp-0.1.0-py3-none-any.whl
- Upload date:
- Size: 135.9 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/3.2.0 pkginfo/1.5.0.1 requests/2.24.0 setuptools/49.3.1 requests-toolbelt/0.9.1 tqdm/4.48.2 CPython/3.8.5
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 2437f7681b0e37e1e6a2b652ab9f794c504f56eb0dcb7ac9f4565cce2ecbe437 |
|
MD5 | 662dd6caf745df1be87cf50825a872f6 |
|
BLAKE2b-256 | 1945f58a6ef41b1da25715fecbcdfee98f32be560b9f41817fa8eec2a4fe1cdb |