Sen descrición

Fabian Peter Hammerle a6bed17c87 dev env: added upper version constraints for astroid & pylint to keep compatibility with python3.5 %!s(int64=3) %!d(string=hai) anos
.github 4414282f12 test against python3.9 %!s(int64=3) %!d(string=hai) anos
cc1101 f72c934511 fix: close & unlock SPI device file when error occurs while entering context %!s(int64=3) %!d(string=hai) anos
examples cebeeb5207 rename set/get_output_power_levels to set/get_output_power as a higher patable setting does not necessarily imply a higher output power level (see table 39) %!s(int64=3) %!d(string=hai) anos
tests f72c934511 fix: close & unlock SPI device file when error occurs while entering context %!s(int64=3) %!d(string=hai) anos
.gitignore f6fccfd243 pipeline: added pytest-cov %!s(int64=3) %!d(string=hai) anos
.pylintrc 2bc397185f setup ci pipeline %!s(int64=4) %!d(string=hai) anos
CHANGELOG.md 126915720f release v2.7.1 %!s(int64=3) %!d(string=hai) anos
COPYING 994a9a5ede added GPLv3+ %!s(int64=4) %!d(string=hai) anos
Pipfile a6bed17c87 dev env: added upper version constraints for astroid & pylint to keep compatibility with python3.5 %!s(int64=3) %!d(string=hai) anos
Pipfile.lock a6bed17c87 dev env: added upper version constraints for astroid & pylint to keep compatibility with python3.5 %!s(int64=3) %!d(string=hai) anos
README.md bd9b03db92 readme: fix typo %!s(int64=3) %!d(string=hai) anos
mypy.ini 991cc935f0 mypy: ignore missing imports %!s(int64=4) %!d(string=hai) anos
setup.py 4414282f12 test against python3.9 %!s(int64=3) %!d(string=hai) anos

README.md

python-cc1101

CI Pipeline Status Coverage Status Last Release Compatible Python Versions DOI

Python Library & Command Line Tool to Transmit RF Signals via CC1101 Transceivers

Setup

$ pip3 install --user --upgrade cc1101

On Raspbian / Raspberry Pi OS, dependencies can optionally be installed via:

$ sudo apt-get install --no-install-recommends python3-spidev

Wiring Raspberry Pi

Connect the following pins directly:

CC1101 Raspberry Pi
VDD 3.3V (Pin 1 or 17)
SI MOSI (Pin 19)
SO MISO (Pin 21)
CSn CE0 (Pin 24)
SCLK SCLK (Pin 23)
GDO2* Any GPIO pin, commonly GPIO25 (Pin 22) [1,2,3]
GDO0* Any GPIO pin, GPIO24 (Pin 18) recommended
GND Ground

No resistors required. Connection of pins marked with * is optional. GDO2 stays "high until power and crystal have stabilized" (see CHIP_RDYn in docs). GDO0 is used by .asynchronous_transmission() for data input.

If some of these pins are already in use, select a different SPI bus or chip select: https://www.raspberrypi.org/documentation/hardware/raspberrypi/spi/README.md (permalink)

Raspberry Pi GPIO docs: https://www.raspberrypi.org/documentation/usage/gpio/

Usage

Library

See examples.

import cc1101

with cc1101.CC1101() as transceiver:
    transceiver.set_base_frequency_hertz(433.92e6)
    print(transceiver)
    transceiver.transmit(b"\x01\xff\x00 message")

In case CC1101 is connected to a different SPI bus or chip select line than /dev/spidev0.0, use CC1101(spi_bus=?, spi_chip_select=?).

Command Line

$ printf '\x01\x02\x03' | cc1101-transmit -f 433920000 -r 1000

See cc1101-transmit --help.

Troubleshooting

In case a PermissionError gets raised, check the permissions of /dev/spidev*. You'll probably need sudo usermod -a -G spi $USER, followed by a re-login.

Consult CC1101's offical docs for an in-depth explanation of all options: https://www.ti.com/lit/ds/symlink/cc1101.pdf