Skip to content

Python library for interfacing with the MCP2210 USB-SPI interface.

License

Notifications You must be signed in to change notification settings

rdpoor/mcp2210

 
 

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

23 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

mcp2210

Python library for interfacing with the MCP2210 USB-SPI interface.

Installation

$ pip install mcp2210

or, clone this repository and install from source:

$ git clone https://github.com/arachnidlabs/mcp2210.git
$ cd mcp2210
$ sudo setup.py install

Usage

>>> from mcp2210 import MCP2210
>>> dev = MCP2210(my_vid, my_pid)
>>> dev.transfer("data")

If you have more than one MCP2210 on the USB chain, you can use its USB path with the path keyword in the in the constructor:

>>> from mcp2210 import MCP2210
>>> import hid
>>> descriptors = hid.enumerate(MCP2210.VID, MCP2210.PID) # multiple devs
>>> dev = MCP2210(path=descriptors[0]['path'])    # open first on the list
>>> dev.transfer("data")

In addition to making SPI bus transfers, device settings can be accessed and modified:

>>> dev.manufacturer_name = "Foobar Industries Ltd"
>>> print(dev.manufacturer_name)
Foobar Industries Ltd

>>> dev.product_name = "Foobinator 1.0"
>>> print(dev.product_name)
Foobinator 1.0

>>> settings = dev.boot_chip_settings
>>> settings.pin_designations[0] = 0x01  # GPIO 0 to chip select
>>> dev.boot_chip_settings = settings  # Settings are updated on property assignment

>>> spisettings = dev.boot_transfer_settings
>>> spisettings.idle_cs = 0x01
>>> spisettings.active_cs = 0x00  # Set pin 1 to go low on chip select
>>> dev.boot_transfer_settings = spisettings

... and you can read and write the 256 byte EEPROM:

>>> dev.eeprom[10:14] = [2, 4, 8, 16]
>>> print(dev.eeprom[10:14])
[2, 4, 8, 16]
>>> print(dev.eeprom[12])
8

chip_settings and boot_chip_settings define basic settings such as GPIO pin assignments. transfer_settings and boot_transfer_settings define SPI settings such as data rate, chip select value, and inter-byte timings. boot_usb_settings defines USB configuration options like VID, PID, and power requirements. On boot, the MCP2210 copies boot_transfer_settings and boot_chip_settings into transfer_settings and chip_settings respectively.

All properties are cached when fetched, and updated on the device when set, so storing results to the chip requires an assignment, as in the above code, even when the arguments are mutable.

See the MCP2210 datasheet for full details on available commands and arguments.

About

Python library for interfacing with the MCP2210 USB-SPI interface.

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • Python 100.0%