esp_idf_svc::sys

Function i2c_master_receive

Source
pub unsafe extern "C" fn i2c_master_receive(
    i2c_dev: *mut i2c_master_dev_t,
    read_buffer: *mut u8,
    read_size: usize,
    xfer_timeout_ms: i32,
) -> i32
Expand description

@brief Perform a read transaction on the I2C bus. The transaction will be undergoing until it finishes or it reaches the timeout provided.

@note If a callback was registered with i2c_master_register_event_callbacks, the transaction will be asynchronous, and thus, this function will return directly, without blocking. You will get finish information from callback. Besides, data buffer should always be completely prepared when callback is registered, otherwise, the data will get corrupt.

@param[in] i2c_dev I2C master device handle that created by i2c_master_bus_add_device. @param[out] read_buffer Data bytes received from i2c bus. @param[in] read_size Size, in bytes, of the read buffer. @param[in] xfer_timeout_ms Wait timeout, in ms. Note: -1 means wait forever. @return - ESP_OK: I2C master receive success - ESP_ERR_INVALID_ARG: I2C master receive parameter invalid. - ESP_ERR_TIMEOUT: Operation timeout(larger than xfer_timeout_ms) because the bus is busy or hardware crash.