All Downloads are FREE. Search and download functionalities are using the official Maven repository.

uk.pigpioj.PigpioBitBangI2C Maven / Gradle / Ivy

package uk.pigpioj;

public class PigpioBitBangI2C {
	/**
	 * 

This function selects a pair of GPIO for bit banging I2C at a specified baud rate. * Bit banging I2C allows for certain operations which are not possible with the standard I2C driver.

*
    *
  • baud rates as low as 50
  • *
  • repeated starts
  • *
  • clock stretching
  • *
  • I2C on any pair of spare GPIO
  • *
*

NOTE: The GPIO used for SDA and SCL must have pull-ups to 3V3 connected. As a guide the hardware pull-ups on pins 3 and 5 are 1k8 in value.

* @param sda 0-31 * @param scl 0-31 * @param baud 50-500000 * @return 0 if OK, otherwise PI_BAD_USER_GPIO, PI_BAD_I2C_BAUD, or PI_GPIO_IN_USE. */ public static native int bbI2COpen(int sda, int scl, int baud); /** * This function stops bit banging I2C on a pair of GPIO previously opened with bbI2COpen. * @param sda 0-31, the SDA GPIO used in a prior call to bbI2COpen * @return 0 if OK, otherwise PI_BAD_USER_GPIO, or PI_NOT_I2C_GPIO */ public static native int bbI2CClose(int sda); /** *

This function executes a sequence of bit banged I2C operations. The operations to be performed are specified by the contents of inBuf which contains the concatenated command codes and associated data.

*

The address, read, and write commands take a parameter P. Normally P is one byte (0-255). If the command is preceded by the Escape command then P is two bytes (0-65535, least significant byte first).

*

The following command codes are supported:

*
	 * Name     Cmd & Data  Meaning
	 * End      0           No more commands
	 * Escape   1           Next P is two bytes
	 * Start    2           Start condition
	 * Stop     3           Stop condition
	 * Address  4 P         Set I2C address to P
	 * Flags    5 lsb msb   Set I2C flags to lsb + (msb << 8)
	 * Read     6 P         Read P bytes of data
	 * Write    7 P ...     Write P bytes of data
	 * 
*

The address and flags default to 0. The address and flags maintain their previous value until updated.

*

No flags are currently defined.

*

The returned I2C data is stored in consecutive locations of outBuf.

* @param sda 0-31 (as used in a prior call to bbI2COpen) * @param inBuf buffer the concatenated I2C commands, see below * @param inLen size of command buffer * @param outBuf buffer to hold returned data * @param outLen size of output buffer * @return 0 if OK (the number of bytes read), otherwise PI_BAD_USER_GPIO, PI_NOT_I2C_GPIO, PI_BAD_POINTER, PI_BAD_I2C_CMD, PI_BAD_I2C_RLEN, PI_BAD_I2C_WLEN, PI_I2C_READ_FAILED, or PI_I2C_WRITE_FAILED */ public static native int bbI2CZip(int sda, byte[] inBuf, int inLen, byte[] outBuf, int outLen); }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy