Skip to main content

smbus2 is a drop-in replacement for smbus-cffi/smbus-python in pure Python

Project description

smbus2

A drop-in replacement for smbus-cffi/smbus-python in pure Python

Build Status Documentation Status CodeQL Quality Gate Status

Python Versions PyPi Version PyPI - Downloads

Introduction

smbus2 is a pure Python, drop-in replacement for the python-smbus / python3-smbus Linux SMBus bindings.

It was designed with two goals in mind:

  1. Provide an interface that is familiar to users of smbus.
  2. Support more complete Linux I2C/SMBus functionality, including features such as i2c_rdwr.

Currently supported features are:

  • Get i2c capabilities (I2C_FUNCS)
  • SMBus Packet Error Checking (PEC) support
  • read_byte
  • write_byte
  • read_byte_data
  • write_byte_data
  • read_word_data
  • write_word_data
  • read_i2c_block_data
  • write_i2c_block_data
  • write_quick
  • process_call
  • read_block_data
  • write_block_data
  • block_process_call
  • i2c_rdwr - combined write/read transactions with repeated start

It is developed on Python 2.7 but works without any modifications in Python 3.X too.

More information about updates and general changes are recorded in the change log.

SMBus code examples

smbus2 installs next to smbus as the package, so it's not really a 100% replacement. You must change the module name.

Example 1a: Read a byte

from smbus2 import SMBus

# Open i2c bus 1 and read one byte from address 80, offset 0
bus = SMBus(1)
b = bus.read_byte_data(80, 0)
print(b)
bus.close()

Example 1b: Read a byte using 'with'

This is the very same example but safer to use since the smbus will be closed automatically when exiting the with block.

from smbus2 import SMBus

with SMBus(1) as bus:
    b = bus.read_byte_data(80, 0)
    print(b)

Example 1c: Read a byte with PEC enabled

Same example with Packet Error Checking enabled.

from smbus2 import SMBus

with SMBus(1) as bus:
    bus.pec = 1  # Enable PEC
    b = bus.read_byte_data(80, 0)
    print(b)

Example 2: Read a block of data

You can read up to 32 bytes at once.

from smbus2 import SMBus

with SMBus(1) as bus:
    # Read a block of 16 bytes from address 80, offset 0
    block = bus.read_i2c_block_data(80, 0, 16)
    # Returned value is a list of 16 bytes
    print(block)

Example 3: Write a byte

from smbus2 import SMBus

with SMBus(1) as bus:
    # Write a byte to address 80, offset 0
    data = 45
    bus.write_byte_data(80, 0, data)

Example 4: Write a block of data

It is possible to write 32 bytes at the time, but I have found that error-prone. Write less and add a delay in between if you run into trouble.

from smbus2 import SMBus

with SMBus(1) as bus:
    # Write a block of 8 bytes to address 80 from offset 0
    data = [1, 2, 3, 4, 5, 6, 7, 8]
    bus.write_i2c_block_data(80, 0, data)

I2C

Starting with v0.2, the smbus2 library also has support for combined read and write transactions. i2c_rdwr is not really a SMBus feature but comes in handy when the master needs to:

  1. read or write bulks of data larger than SMBus' 32 bytes limit.
  2. write some data and then read from the slave with a repeated start and no stop bit between.

Each operation is represented by a i2c_msg message object.

Example 5: Single i2c_rdwr

from smbus2 import SMBus, i2c_msg

with SMBus(1) as bus:
    # Read 64 bytes from address 80
    msg = i2c_msg.read(80, 64)
    bus.i2c_rdwr(msg)
    
    # Write a single byte to address 80
    msg = i2c_msg.write(80, [65])
    bus.i2c_rdwr(msg)
    
    # Write some bytes to address 80
    msg = i2c_msg.write(80, [65, 66, 67, 68])
    bus.i2c_rdwr(msg)

Example 6: Dual i2c_rdwr

To perform dual operations just add more i2c_msg instances to the bus call:

from smbus2 import SMBus, i2c_msg

# Single transaction writing two bytes then read two at address 80
write = i2c_msg.write(80, [40, 50])
read = i2c_msg.read(80, 2)
with SMBus(1) as bus:
    bus.i2c_rdwr(write, read)

Example 7: Access i2c_msg data

All data is contained in the i2c_msg instances. Here are some data access alternatives.

# 1: Convert message content to list
msg = i2c_msg.write(60, [1, 2, 3, 4, 5, 6, 7, 8, 9, 10])
data = list(msg)  # data = [1, 2, 3, ...]
print(len(data))  # => 10

# 2: i2c_msg is iterable
for value in msg:
    print(value)

# 3: Through i2c_msg properties
for k in range(msg.len):
    print(msg.buf[k])

Installation instructions

From PyPi with pip:

pip install smbus2

From conda-forge using conda:

conda install -c conda-forge smbus2

Installation from source code is straight forward:

python setup.py install

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

smbus2-0.6.1.tar.gz (17.3 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

smbus2-0.6.1-py2.py3-none-any.whl (11.8 kB view details)

Uploaded Python 2Python 3

File details

Details for the file smbus2-0.6.1.tar.gz.

File metadata

  • Download URL: smbus2-0.6.1.tar.gz
  • Upload date:
  • Size: 17.3 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.14.3

File hashes

Hashes for smbus2-0.6.1.tar.gz
Algorithm Hash digest
SHA256 2b043372abf8f6029a632c3aab36b641c5d5872b1cbad599fc68e17ac4fd90a5
MD5 c401511f61d5296d4750ef7af4c121f2
BLAKE2b-256 8737b3f7b501502c4915ba3819d1dc277bf3f5fae4a9d067caa4f502aaddd889

See more details on using hashes here.

File details

Details for the file smbus2-0.6.1-py2.py3-none-any.whl.

File metadata

  • Download URL: smbus2-0.6.1-py2.py3-none-any.whl
  • Upload date:
  • Size: 11.8 kB
  • Tags: Python 2, Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.14.3

File hashes

Hashes for smbus2-0.6.1-py2.py3-none-any.whl
Algorithm Hash digest
SHA256 650feeb27ca0ed58b07db4c10201c2a662c41305b7bf6e5fab9d888056f48180
MD5 f6974ef0d94fa727683d1be6dd2cc236
BLAKE2b-256 96f2c78a68bd739ac8fc608747cff73a4db3b19f3135658ed4e64374f6425cbf

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page