• sales

    +86-0755-88291180

【MicroPython】machine.SPI Function

  • machine.SPI(id,baudrate=1000000, polarity=0, phase=0, bits=8, firstbit=SPI.MSB, sck=None, mosi=None, miso=None)
    • SPI object constructor, used to initialize the corresponding channel and pin
    • id: use SPI channel, can be 0 or 1
    • baudrate: SPI communication rate, which is the frequency on the SCK pin
    • polarity: Clock polarity, if it is 0, SCK outputs a low level when the bus is idle, otherwise it outputs a high level.
    • phase: the clock phase, if it is 0, the data is captured on the first clock edge, otherwise, the data is captured on the second clock edge.
    • bits: the number of data bits per transfer
    • firstbit: transmit high or low bits first
    • sck: SCK pin, should be a Pin object
    • mosi: MOSI pin, should be a Pin object
    • miso: MISO pin, should be a Pin object
    • sck, mosi and miso are all pins used by SPI and should be Pin objects
  • SPI.init()
    • init function, used to restart SPI
  • SPI.deinit()
    • deinit function, used to close the SPI
  • SPI.read(nbytes,write=0x00)
    • read function, used to read data from the device and return
    • nbytes: number of bytes read
    • write: When reading data, MOSI outputs data.
  • SPI.readinto(buf,write=0x00)
    • The readinto function is used to read data from the device and store it in the specified character array.
    • buf: character array, used to store received data
    • write: When reading data, MOSI outputs data.
  • SPI.write(buf)
    • write function, which writes a character array to the slave device.
    • buf: character array, used to store transmission data
  • SPI.write_readinto(write_buf, read_buf)
    • write_readinto function for sending and receiving data at the same time
    • write_buf: character array, used to store transmission data
    • read_buf: character array, used to store received data
  • PS: The length of the character array for transmitting and receiving data here is required to be consistent.

Demo Address

This article is only for RP2040 MicroPython firmware, and the source code shall prevail. This article is written according to the official source code at the time of writing, which is used to provide convenience for beginners and is for reference only. Those who are capable are recommended to refer to MicroPython.

TAG: ESP32 Thermal imaging camera Raspberry Pi 5 PCIe to USB3 HUB Double 2.5G ETH RJ45 and M.2 NVMe SSD PI5 Expansion board HAT+ Sipeed FPGA Tang Primer 20K Dock/Lite 128M DDR3 Development Board GW2A-LV18PG256C8/I7 Desktop Trinket Raspberry Pi Monitor Official Original DisplayScreen 15.6 inch LCD Full HD 1920x1080 15.6inch ESP32 S3 N16R8 Development board 1.9 inch LCD Display 1.9inch TouchScreen 170×320 SD-Port RGB LED QMI8658 6-Axis ST7789 CST816 Raspberry Pi screen BPI-M4 Berry Raspberry Pi 8inch LCD 768x1024 Capacitive TouchScreen HDMI Display Raspberry Pi Pico 2 RP2350 bit board Size & Port high Compatible With BBC Micro:bit Python HTTP Request Communication MPS2280D Raspberry Pi 5 PCIe to M.2 NVMe Dual SSD Adapter Board HAT Pi5 Double 2280 RS485 to RJ45 Raspberry Pi 5 Raspberry Pi Camera 8MP IMX415 also For Luckfox-Omni3576 RK3576 RP2040-Keyboard-3 Milk-V Duo HUB Raspberry Pi 8 inch DSI MIPI LCD TouchScreen Display 8inch 800x1280 For Luckfox Lyra RK3506/ESP32-P4/Luckfox Omni3576 Raspberry Pi 5 PCIe Core3566102032