%global _empty_manifest_terminate_build 0 Name: python-zigpy-znp Version: 0.10.0 Release: 1 Summary: A library for zigpy which communicates with TI ZNP radios License: GPL-3.0 URL: https://pypi.org/project/zigpy-znp/ Source0: https://mirrors.nju.edu.cn/pypi/web/packages/2e/e3/6a40af9078a875b66bea4000ec28ce560b321faa2cf1e713e0963d0dc334/zigpy-znp-0.10.0.tar.gz BuildArch: noarch Requires: python3-zigpy Requires: python3-async-timeout Requires: python3-voluptuous Requires: python3-coloredlogs Requires: python3-jsonschema Requires: python3-pytest Requires: python3-pytest-asyncio Requires: python3-pytest-timeout Requires: python3-pytest-mock Requires: python3-pytest-cov Requires: python3-coveralls %description # zigpy-znp [![Build Status](https://github.com/zigpy/zigpy-znp/workflows/CI/badge.svg)](https://github.com/zigpy/zigpy-znp/actions) [![Coverage Status](https://codecov.io/gh/zigpy/zigpy-znp/branch/dev/graph/badge.svg?token=Y1994N9D74)](https://codecov.io/gh/zigpy/zigpy-znp) **[zigpy-znp](https://github.com/zigpy/zigpy-znp/)** is a Python library that adds support for common [Texas Instruments ZNP (Zigbee Network Processors)](http://dev.ti.com/tirex/content/simplelink_zigbee_sdk_plugin_2_20_00_06/docs/zigbee_user_guide/html/zigbee/introduction.html) [Zigbee](https://www.zigbee.org) radio modules to [zigpy](https://github.com/zigpy/), a Python Zigbee stack project. Together with zigpy and compatible home automation software (namely Home Assistant's [ZHA (Zigbee Home Automation) integration component](https://www.home-assistant.io/integrations/zha/)), 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: ```console $ virtualenv -p python3.8 venv # if you don't already have one $ source venv/bin/activate (venv) $ pip install git+https://github.com/zigpy/zigpy-znp/ # latest commit from Git (venv) $ pip install zigpy-znp # or, latest stable from PyPI ``` ## Home Assistant Stable releases of zigpy-znp are automatically installed when you install the ZHA component. ### Testing `dev` with Home Assistant Core Upgrade the package within your virtual environment (requires `git`): ```console (venv) $ pip install git+https://github.com/zigpy/zigpy-znp/ ``` Launch Home Assistant with the `--skip-pip` command line option to prevent zigpy-znp from being downgraded. Running with this option may prevent newly added integrations from installing required packages. ### Testing `dev` with Home Assistant OS - Add https://github.com/home-assistant/hassio-addons-development as an addon repository. - Install the "Custom deps deployment" addon. - Add the following to your `configuration.yaml` file: ```yaml apk: [] pypi: - git+https://github.com/zigpy/zigpy-znp/ ``` # Configuration Below are the defaults with the top-level Home Assistant `zha:` key. **You do not need to copy this configuration, it is provided only for reference**: ```yaml zha: zigpy_config: znp_config: # Only if your stick has a built-in power amplifier (i.e. CC1352P and CC2592) # If set, must be between: # * CC1352/2652: -22 and 19 # * CC253x: -22 and 22 tx_power: # Only if your stick has a controllable LED (the CC2531) # If set, must be one of: off, on, blink, flash, toggle led_mode: off ### Internal configuration, there's no reason to touch these values # Skips the 60s bootloader delay on CC2531 sticks skip_bootloader: True # Timeout for synchronous requests' responses sreq_timeout: 15 # Timeout for asynchronous requests' callback responses arsp_timeout: 30 # Delay between auto-reconnect attempts in case the device gets disconnected auto_reconnect_retry_delay: 5 # Pin states for skipping the bootloader connect_rts_pin_states: [off, on, off] connect_dtr_pin_states: [off, off, off] ``` # Tools Various command line Zigbee utilities are a part of the zigpy-znp package and can be run with `python -m zigpy_znp.tools.name_of_tool`. More detailed documentation can be found in **[`TOOLS.md`](./TOOLS.md)** but a brief description of each tool is included below: - **`energy_scan`**: Performs a continuous energy scan to check for non-Zigbee interference. - **`flash_read`**: For CC2531s, reads firmware from flash. - **`flash_write`**: For CC2531s, writes a firmware `.bin` to flash. - **`form_network`**: Forms a network with randomized settings on channel 15. - **`network_backup`**: Backs up the network data and device information into a human-readable JSON document. - **`network_restore`**: Restores a JSON network backup to the adapter. - **`network_scan`**: Actively sends beacon requests for network stumbling. - **`nvram_read`**: Reads all possible NVRAM entries into a JSON document. - **`nvram_reset`**: Deletes all possible NVRAM entries - **`nvram_write`**: Writes all NVRAM entries from a JSON document. # Hardware requirements USB-adapters, GPIO-modules, and development-boards flashed with TI's Z-Stack are compatible with zigpy-znp: - CC2652P/CC2652R/CC2652RB USB stick and dev board hardware - CC1352P/CC1352R USB stick and dev board hardware - CC2538 + CC2592 USB stick and dev board hardware (**not recommended, old hardware and end-of-life firmware**) - CC2531 USB stick hardware (**not recommended for Zigbee networks with more than 20 devices**) - CC2530 + CC2591/CC2592 USB stick hardware (**not recommended for Zigbee networks with more than 20 devices**) Tip! Adapters listed as "[Texas Instruments sticks compatible with Zigbee2MQTT](https://www.zigbee2mqtt.io/information/supported_adapters)" also works with zigpy-znp. ## Reference hardware for this project These specific adapters are used as reference hardware for development and testing by zigpy-znp developers: - [TI LAUNCHXL-CC26X2R1](https://www.ti.com/tool/LAUNCHXL-CC26X2R1) running [Z-Stack 3 firmware (based on version 4.40.00.44)](https://github.com/Koenkk/Z-Stack-firmware/tree/master/coordinator/Z-Stack_3.x.0/bin). You can flash `CC2652R_20210120.hex` using [TI's UNIFLASH](https://www.ti.com/tool/download/UNIFLASH). - [Electrolama zzh CC2652R](https://electrolama.com/projects/zig-a-zig-ah/) and [Slaesh CC2652R](https://slae.sh/projects/cc2652/) sticks running [Z-Stack 3 firmware (based on version 4.40.00.44)](https://github.com/Koenkk/Z-Stack-firmware/tree/master/coordinator/Z-Stack_3.x.0/bin). You can flash `CC2652R_20210120.hex` or `CC2652RB_20210120.hex` respectively using [cc2538-bsl](https://github.com/JelmerT/cc2538-bsl). - CC2531 running [Z-Stack Home 1.2](https://github.com/Koenkk/Z-Stack-firmware/blob/master/coordinator/Z-Stack_Home_1.2/bin/default/CC2531_DEFAULT_20190608.zip). You can flash `CC2531ZNP-Prod.bin` to your stick directly with `zigpy_znp`: `python -m zigpy_znp.tools.flash_write -i /path/to/CC2531ZNP-Prod.bin /dev/serial/by-id/YOUR-CC2531` if your stick already has a serial bootloader. ## 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. ### Supported older generation TI chips - CC2538: 2.4GHz Zigbee, 6LoWPAN, and IEEE 802.15.4 wireless MCU. ARM Cortex-M3 core with with 512kB Flash and 32kB RAM. - CC2531: CC2530 with a built-in UART/TTL to USB Bridge. Used in the cheap "Zigbee sticks" sold everywhere. Intel 8051 core, 256 Flash, only has 8kB RAM. - CC2530: 2.4GHz Zigbee and IEEE 802.15.4 wireless MCU. Intel 8051 core, 256 Flash, only has 8kB RAM. ### Auxiliary TI chips - CC2591 and CC2592: 2.4 GHz range extenders. These are not wireless MCUs, just auxiliary 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.org/project/zigpy-znp/ - https://pypi.org/project/zigpy-znp/#history - https://pypi.org/project/zigpy-znp/#files # External documentation and reference - http://www.ti.com/tool/LAUNCHXL-CC26X2R1 - http://www.ti.com/tool/LAUNCHXL-CC1352P # 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](https://github.com/zigpy/zigpy)** is [Zigbee protocol stack](https://en.wikipedia.org/wiki/Zigbee) integration project to implement the **[Zigbee Home Automation](https://www.zigbee.org/)** 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](https://www.home-assistant.io)'s [ZHA component](https://www.home-assistant.io/components/zha/) and provides a user-friendly interface for working with a Zigbee network. %package -n python3-zigpy-znp Summary: A library for zigpy which communicates with TI ZNP radios Provides: python-zigpy-znp BuildRequires: python3-devel BuildRequires: python3-setuptools BuildRequires: python3-pip %description -n python3-zigpy-znp # zigpy-znp [![Build Status](https://github.com/zigpy/zigpy-znp/workflows/CI/badge.svg)](https://github.com/zigpy/zigpy-znp/actions) [![Coverage Status](https://codecov.io/gh/zigpy/zigpy-znp/branch/dev/graph/badge.svg?token=Y1994N9D74)](https://codecov.io/gh/zigpy/zigpy-znp) **[zigpy-znp](https://github.com/zigpy/zigpy-znp/)** is a Python library that adds support for common [Texas Instruments ZNP (Zigbee Network Processors)](http://dev.ti.com/tirex/content/simplelink_zigbee_sdk_plugin_2_20_00_06/docs/zigbee_user_guide/html/zigbee/introduction.html) [Zigbee](https://www.zigbee.org) radio modules to [zigpy](https://github.com/zigpy/), a Python Zigbee stack project. Together with zigpy and compatible home automation software (namely Home Assistant's [ZHA (Zigbee Home Automation) integration component](https://www.home-assistant.io/integrations/zha/)), 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: ```console $ virtualenv -p python3.8 venv # if you don't already have one $ source venv/bin/activate (venv) $ pip install git+https://github.com/zigpy/zigpy-znp/ # latest commit from Git (venv) $ pip install zigpy-znp # or, latest stable from PyPI ``` ## Home Assistant Stable releases of zigpy-znp are automatically installed when you install the ZHA component. ### Testing `dev` with Home Assistant Core Upgrade the package within your virtual environment (requires `git`): ```console (venv) $ pip install git+https://github.com/zigpy/zigpy-znp/ ``` Launch Home Assistant with the `--skip-pip` command line option to prevent zigpy-znp from being downgraded. Running with this option may prevent newly added integrations from installing required packages. ### Testing `dev` with Home Assistant OS - Add https://github.com/home-assistant/hassio-addons-development as an addon repository. - Install the "Custom deps deployment" addon. - Add the following to your `configuration.yaml` file: ```yaml apk: [] pypi: - git+https://github.com/zigpy/zigpy-znp/ ``` # Configuration Below are the defaults with the top-level Home Assistant `zha:` key. **You do not need to copy this configuration, it is provided only for reference**: ```yaml zha: zigpy_config: znp_config: # Only if your stick has a built-in power amplifier (i.e. CC1352P and CC2592) # If set, must be between: # * CC1352/2652: -22 and 19 # * CC253x: -22 and 22 tx_power: # Only if your stick has a controllable LED (the CC2531) # If set, must be one of: off, on, blink, flash, toggle led_mode: off ### Internal configuration, there's no reason to touch these values # Skips the 60s bootloader delay on CC2531 sticks skip_bootloader: True # Timeout for synchronous requests' responses sreq_timeout: 15 # Timeout for asynchronous requests' callback responses arsp_timeout: 30 # Delay between auto-reconnect attempts in case the device gets disconnected auto_reconnect_retry_delay: 5 # Pin states for skipping the bootloader connect_rts_pin_states: [off, on, off] connect_dtr_pin_states: [off, off, off] ``` # Tools Various command line Zigbee utilities are a part of the zigpy-znp package and can be run with `python -m zigpy_znp.tools.name_of_tool`. More detailed documentation can be found in **[`TOOLS.md`](./TOOLS.md)** but a brief description of each tool is included below: - **`energy_scan`**: Performs a continuous energy scan to check for non-Zigbee interference. - **`flash_read`**: For CC2531s, reads firmware from flash. - **`flash_write`**: For CC2531s, writes a firmware `.bin` to flash. - **`form_network`**: Forms a network with randomized settings on channel 15. - **`network_backup`**: Backs up the network data and device information into a human-readable JSON document. - **`network_restore`**: Restores a JSON network backup to the adapter. - **`network_scan`**: Actively sends beacon requests for network stumbling. - **`nvram_read`**: Reads all possible NVRAM entries into a JSON document. - **`nvram_reset`**: Deletes all possible NVRAM entries - **`nvram_write`**: Writes all NVRAM entries from a JSON document. # Hardware requirements USB-adapters, GPIO-modules, and development-boards flashed with TI's Z-Stack are compatible with zigpy-znp: - CC2652P/CC2652R/CC2652RB USB stick and dev board hardware - CC1352P/CC1352R USB stick and dev board hardware - CC2538 + CC2592 USB stick and dev board hardware (**not recommended, old hardware and end-of-life firmware**) - CC2531 USB stick hardware (**not recommended for Zigbee networks with more than 20 devices**) - CC2530 + CC2591/CC2592 USB stick hardware (**not recommended for Zigbee networks with more than 20 devices**) Tip! Adapters listed as "[Texas Instruments sticks compatible with Zigbee2MQTT](https://www.zigbee2mqtt.io/information/supported_adapters)" also works with zigpy-znp. ## Reference hardware for this project These specific adapters are used as reference hardware for development and testing by zigpy-znp developers: - [TI LAUNCHXL-CC26X2R1](https://www.ti.com/tool/LAUNCHXL-CC26X2R1) running [Z-Stack 3 firmware (based on version 4.40.00.44)](https://github.com/Koenkk/Z-Stack-firmware/tree/master/coordinator/Z-Stack_3.x.0/bin). You can flash `CC2652R_20210120.hex` using [TI's UNIFLASH](https://www.ti.com/tool/download/UNIFLASH). - [Electrolama zzh CC2652R](https://electrolama.com/projects/zig-a-zig-ah/) and [Slaesh CC2652R](https://slae.sh/projects/cc2652/) sticks running [Z-Stack 3 firmware (based on version 4.40.00.44)](https://github.com/Koenkk/Z-Stack-firmware/tree/master/coordinator/Z-Stack_3.x.0/bin). You can flash `CC2652R_20210120.hex` or `CC2652RB_20210120.hex` respectively using [cc2538-bsl](https://github.com/JelmerT/cc2538-bsl). - CC2531 running [Z-Stack Home 1.2](https://github.com/Koenkk/Z-Stack-firmware/blob/master/coordinator/Z-Stack_Home_1.2/bin/default/CC2531_DEFAULT_20190608.zip). You can flash `CC2531ZNP-Prod.bin` to your stick directly with `zigpy_znp`: `python -m zigpy_znp.tools.flash_write -i /path/to/CC2531ZNP-Prod.bin /dev/serial/by-id/YOUR-CC2531` if your stick already has a serial bootloader. ## 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. ### Supported older generation TI chips - CC2538: 2.4GHz Zigbee, 6LoWPAN, and IEEE 802.15.4 wireless MCU. ARM Cortex-M3 core with with 512kB Flash and 32kB RAM. - CC2531: CC2530 with a built-in UART/TTL to USB Bridge. Used in the cheap "Zigbee sticks" sold everywhere. Intel 8051 core, 256 Flash, only has 8kB RAM. - CC2530: 2.4GHz Zigbee and IEEE 802.15.4 wireless MCU. Intel 8051 core, 256 Flash, only has 8kB RAM. ### Auxiliary TI chips - CC2591 and CC2592: 2.4 GHz range extenders. These are not wireless MCUs, just auxiliary 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.org/project/zigpy-znp/ - https://pypi.org/project/zigpy-znp/#history - https://pypi.org/project/zigpy-znp/#files # External documentation and reference - http://www.ti.com/tool/LAUNCHXL-CC26X2R1 - http://www.ti.com/tool/LAUNCHXL-CC1352P # 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](https://github.com/zigpy/zigpy)** is [Zigbee protocol stack](https://en.wikipedia.org/wiki/Zigbee) integration project to implement the **[Zigbee Home Automation](https://www.zigbee.org/)** 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](https://www.home-assistant.io)'s [ZHA component](https://www.home-assistant.io/components/zha/) and provides a user-friendly interface for working with a Zigbee network. %package help Summary: Development documents and examples for zigpy-znp Provides: python3-zigpy-znp-doc %description help # zigpy-znp [![Build Status](https://github.com/zigpy/zigpy-znp/workflows/CI/badge.svg)](https://github.com/zigpy/zigpy-znp/actions) [![Coverage Status](https://codecov.io/gh/zigpy/zigpy-znp/branch/dev/graph/badge.svg?token=Y1994N9D74)](https://codecov.io/gh/zigpy/zigpy-znp) **[zigpy-znp](https://github.com/zigpy/zigpy-znp/)** is a Python library that adds support for common [Texas Instruments ZNP (Zigbee Network Processors)](http://dev.ti.com/tirex/content/simplelink_zigbee_sdk_plugin_2_20_00_06/docs/zigbee_user_guide/html/zigbee/introduction.html) [Zigbee](https://www.zigbee.org) radio modules to [zigpy](https://github.com/zigpy/), a Python Zigbee stack project. Together with zigpy and compatible home automation software (namely Home Assistant's [ZHA (Zigbee Home Automation) integration component](https://www.home-assistant.io/integrations/zha/)), 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: ```console $ virtualenv -p python3.8 venv # if you don't already have one $ source venv/bin/activate (venv) $ pip install git+https://github.com/zigpy/zigpy-znp/ # latest commit from Git (venv) $ pip install zigpy-znp # or, latest stable from PyPI ``` ## Home Assistant Stable releases of zigpy-znp are automatically installed when you install the ZHA component. ### Testing `dev` with Home Assistant Core Upgrade the package within your virtual environment (requires `git`): ```console (venv) $ pip install git+https://github.com/zigpy/zigpy-znp/ ``` Launch Home Assistant with the `--skip-pip` command line option to prevent zigpy-znp from being downgraded. Running with this option may prevent newly added integrations from installing required packages. ### Testing `dev` with Home Assistant OS - Add https://github.com/home-assistant/hassio-addons-development as an addon repository. - Install the "Custom deps deployment" addon. - Add the following to your `configuration.yaml` file: ```yaml apk: [] pypi: - git+https://github.com/zigpy/zigpy-znp/ ``` # Configuration Below are the defaults with the top-level Home Assistant `zha:` key. **You do not need to copy this configuration, it is provided only for reference**: ```yaml zha: zigpy_config: znp_config: # Only if your stick has a built-in power amplifier (i.e. CC1352P and CC2592) # If set, must be between: # * CC1352/2652: -22 and 19 # * CC253x: -22 and 22 tx_power: # Only if your stick has a controllable LED (the CC2531) # If set, must be one of: off, on, blink, flash, toggle led_mode: off ### Internal configuration, there's no reason to touch these values # Skips the 60s bootloader delay on CC2531 sticks skip_bootloader: True # Timeout for synchronous requests' responses sreq_timeout: 15 # Timeout for asynchronous requests' callback responses arsp_timeout: 30 # Delay between auto-reconnect attempts in case the device gets disconnected auto_reconnect_retry_delay: 5 # Pin states for skipping the bootloader connect_rts_pin_states: [off, on, off] connect_dtr_pin_states: [off, off, off] ``` # Tools Various command line Zigbee utilities are a part of the zigpy-znp package and can be run with `python -m zigpy_znp.tools.name_of_tool`. More detailed documentation can be found in **[`TOOLS.md`](./TOOLS.md)** but a brief description of each tool is included below: - **`energy_scan`**: Performs a continuous energy scan to check for non-Zigbee interference. - **`flash_read`**: For CC2531s, reads firmware from flash. - **`flash_write`**: For CC2531s, writes a firmware `.bin` to flash. - **`form_network`**: Forms a network with randomized settings on channel 15. - **`network_backup`**: Backs up the network data and device information into a human-readable JSON document. - **`network_restore`**: Restores a JSON network backup to the adapter. - **`network_scan`**: Actively sends beacon requests for network stumbling. - **`nvram_read`**: Reads all possible NVRAM entries into a JSON document. - **`nvram_reset`**: Deletes all possible NVRAM entries - **`nvram_write`**: Writes all NVRAM entries from a JSON document. # Hardware requirements USB-adapters, GPIO-modules, and development-boards flashed with TI's Z-Stack are compatible with zigpy-znp: - CC2652P/CC2652R/CC2652RB USB stick and dev board hardware - CC1352P/CC1352R USB stick and dev board hardware - CC2538 + CC2592 USB stick and dev board hardware (**not recommended, old hardware and end-of-life firmware**) - CC2531 USB stick hardware (**not recommended for Zigbee networks with more than 20 devices**) - CC2530 + CC2591/CC2592 USB stick hardware (**not recommended for Zigbee networks with more than 20 devices**) Tip! Adapters listed as "[Texas Instruments sticks compatible with Zigbee2MQTT](https://www.zigbee2mqtt.io/information/supported_adapters)" also works with zigpy-znp. ## Reference hardware for this project These specific adapters are used as reference hardware for development and testing by zigpy-znp developers: - [TI LAUNCHXL-CC26X2R1](https://www.ti.com/tool/LAUNCHXL-CC26X2R1) running [Z-Stack 3 firmware (based on version 4.40.00.44)](https://github.com/Koenkk/Z-Stack-firmware/tree/master/coordinator/Z-Stack_3.x.0/bin). You can flash `CC2652R_20210120.hex` using [TI's UNIFLASH](https://www.ti.com/tool/download/UNIFLASH). - [Electrolama zzh CC2652R](https://electrolama.com/projects/zig-a-zig-ah/) and [Slaesh CC2652R](https://slae.sh/projects/cc2652/) sticks running [Z-Stack 3 firmware (based on version 4.40.00.44)](https://github.com/Koenkk/Z-Stack-firmware/tree/master/coordinator/Z-Stack_3.x.0/bin). You can flash `CC2652R_20210120.hex` or `CC2652RB_20210120.hex` respectively using [cc2538-bsl](https://github.com/JelmerT/cc2538-bsl). - CC2531 running [Z-Stack Home 1.2](https://github.com/Koenkk/Z-Stack-firmware/blob/master/coordinator/Z-Stack_Home_1.2/bin/default/CC2531_DEFAULT_20190608.zip). You can flash `CC2531ZNP-Prod.bin` to your stick directly with `zigpy_znp`: `python -m zigpy_znp.tools.flash_write -i /path/to/CC2531ZNP-Prod.bin /dev/serial/by-id/YOUR-CC2531` if your stick already has a serial bootloader. ## 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. ### Supported older generation TI chips - CC2538: 2.4GHz Zigbee, 6LoWPAN, and IEEE 802.15.4 wireless MCU. ARM Cortex-M3 core with with 512kB Flash and 32kB RAM. - CC2531: CC2530 with a built-in UART/TTL to USB Bridge. Used in the cheap "Zigbee sticks" sold everywhere. Intel 8051 core, 256 Flash, only has 8kB RAM. - CC2530: 2.4GHz Zigbee and IEEE 802.15.4 wireless MCU. Intel 8051 core, 256 Flash, only has 8kB RAM. ### Auxiliary TI chips - CC2591 and CC2592: 2.4 GHz range extenders. These are not wireless MCUs, just auxiliary 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.org/project/zigpy-znp/ - https://pypi.org/project/zigpy-znp/#history - https://pypi.org/project/zigpy-znp/#files # External documentation and reference - http://www.ti.com/tool/LAUNCHXL-CC26X2R1 - http://www.ti.com/tool/LAUNCHXL-CC1352P # 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](https://github.com/zigpy/zigpy)** is [Zigbee protocol stack](https://en.wikipedia.org/wiki/Zigbee) integration project to implement the **[Zigbee Home Automation](https://www.zigbee.org/)** 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](https://www.home-assistant.io)'s [ZHA component](https://www.home-assistant.io/components/zha/) and provides a user-friendly interface for working with a Zigbee network. %prep %autosetup -n zigpy-znp-0.10.0 %build %py3_build %install %py3_install install -d -m755 %{buildroot}/%{_pkgdocdir} if [ -d doc ]; then cp -arf doc %{buildroot}/%{_pkgdocdir}; fi if [ -d docs ]; then cp -arf docs %{buildroot}/%{_pkgdocdir}; fi if [ -d example ]; then cp -arf example %{buildroot}/%{_pkgdocdir}; fi if [ -d examples ]; then cp -arf examples %{buildroot}/%{_pkgdocdir}; fi pushd %{buildroot} if [ -d usr/lib ]; then find usr/lib -type f -printf "/%h/%f\n" >> filelist.lst fi if [ -d usr/lib64 ]; then find usr/lib64 -type f -printf "/%h/%f\n" >> filelist.lst fi if [ -d usr/bin ]; then find usr/bin -type f -printf "/%h/%f\n" >> filelist.lst fi if [ -d usr/sbin ]; then find usr/sbin -type f -printf "/%h/%f\n" >> filelist.lst fi touch doclist.lst if [ -d usr/share/man ]; then find usr/share/man -type f -printf "/%h/%f.gz\n" >> doclist.lst fi popd mv %{buildroot}/filelist.lst . mv %{buildroot}/doclist.lst . %files -n python3-zigpy-znp -f filelist.lst %dir %{python3_sitelib}/* %files help -f doclist.lst %{_docdir}/* %changelog * Wed Apr 12 2023 Python_Bot - 0.10.0-1 - Package Spec generated