com.pi4j.jni.I2C Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of osgi.enroute.iot.pi.provider Show documentation
Show all versions of osgi.enroute.iot.pi.provider Show documentation
This bundle wraps Pi4j (http://pi4j.com) that wraps the native code Wiring Pi (http://wiringpi.com). It wraps these libraries to make them OSGi friendly and allow them to work together with the OSGi enRoute IoT circuit library (osgi.enroute.iot.circuit). The bundle will first use Pi4J to detect on what hardware it runs. If it runs on an appropriate type, it will register a component that can be configured with Metatype. The Metatype defines a full blown configuration template for all the Pi's functions. The GPIO's are registered as components for the circuit. Regardless of the success of the configuration, this bundle will also register a GpioController service, which is the main Pi4J class.
The newest version!
package com.pi4j.jni;
/*
* #%L
* **********************************************************************
* ORGANIZATION : Pi4J
* PROJECT : Pi4J :: Java Library (Core)
* FILENAME : I2C.java
*
* This file is part of the Pi4J project. More information about
* this project can be found here: http://www.pi4j.com/
* **********************************************************************
* %%
* Copyright (C) 2012 - 2015 Pi4J
* %%
* This program is free software: you can redistribute it and/or modify
* it under the terms of the GNU Lesser General Public License as
* published by the Free Software Foundation, either version 3 of the
* License, or (at your option) any later version.
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Lesser Public License for more details.
*
* You should have received a copy of the GNU General Lesser Public
* License along with this program. If not, see
* .
* #L%
*/
import com.pi4j.util.NativeLibraryLoader;
/**
* I2C Communication
*
*
* Set of native methods for interacting with i2c bus on RPi.
*
*
*
* Note: The file descriptor (fd) returned is a standard Linux filehandle. You can use the standard
* read(), write(), etc. system calls on this filehandle as required.
*
*
* @author Daniel Sendula
*/
public class I2C {
// private constructor
private I2C() {
// forbid object construction
}
static {
// Load the platform library
NativeLibraryLoader.load("libpi4j.so");
}
/**
* Opens linux file for r/w returning file handle.
*
* @param device file name of device. For i2c should be /dev/i2c-0 or /dev/i2c-1 for first or second bus.
* @return file descriptor or i2c bus.
*/
public static native int i2cOpen(String device);
/**
* Closes linux file.
*
* @param fd file descriptor
*/
public static native int i2cClose(int fd);
/**
* Writes one byte to i2c. It uses ioctl to define device address and then writes one byte.
*
* @param fd file descriptor of i2c bus
* @param deviceAddress device address
* @param data byte to be written to the device
* @return result of operation. Zero if everything is OK, less than zero if there was an error.
*/
public static native int i2cWriteByteDirect(int fd, int deviceAddress, byte data);
/**
* Writes several bytes to i2c. It uses ioctl to define device address and then writes number of bytes defined
* in size argument.
*
* @param fd file descriptor of i2c bus
* @param deviceAddress device address
* @param size number of bytes to be written
* @param offset offset in buffer to read from
* @param buffer data buffer to be written
* @return result of operation. Zero if everything is OK, less than zero if there was an error.
*/
public static native int i2cWriteBytesDirect(int fd, int deviceAddress, int size, int offset, byte[] buffer);
/**
* Writes one byte to i2c. It uses ioctl to define device address and then writes two bytes: address in
* the device itself and value.
*
* @param fd file descriptor of i2c bus
* @param deviceAddress device address
* @param localAddress address in the device
* @param data byte to be written to the device
* @return result of operation. Zero if everything is OK, less than zero if there was an error.
*/
public static native int i2cWriteByte(int fd, int deviceAddress, int localAddress, byte data);
/**
* Writes several bytes to i2c. It uses ioctl to define device address and then writes number of bytes defined
* in size argument plus one.
*
* @param fd file descriptor of i2c bus
* @param deviceAddress device address
* @param localAddress address in the device
* @param size number of bytes to be written
* @param offset offset in buffer to read from
* @param buffer data buffer to be written
* @return result of operation. Zero if everything is OK, less than zero if there was an error.
*/
public static native int i2cWriteBytes(int fd, int deviceAddress, int localAddress, int size, int offset, byte[] buffer);
/**
* Reads one byte from i2c device. It uses ioctl to define device address and then reads one byte.
*
* @param fd file descriptor of i2c bus
* @param deviceAddress device address
* @return positive number (or zero) to 255 if read was successful. Negative number if reading failed.
*/
public static native int i2cReadByteDirect(int fd, int deviceAddress);
/**
* Reads more bytes from i2c device. It uses ioctl to define device address and then reads
* size number of bytes.
*
* @param fd file descriptor of i2c bus
* @param deviceAddress device address
* @param size number of bytes to be read
* @param offset offset in buffer to stored read data
* @param buffer buffer for data to be written to
* @return number of bytes read or negative number if reading failed.
*/
public static native int i2cReadBytesDirect(int fd, int deviceAddress, int size, int offset, byte[] buffer);
/**
* Reads one byte from i2c device. It uses ioctl to define device address, writes addres in device and then reads
* one byte.
*
* @param fd file descriptor of i2c bus
* @param deviceAddress device address
* @param localAddress address in the device
* @return positive number (or zero) to 255 if read was successful. Negative number if reading failed.
*/
public static native int i2cReadByte(int fd, int deviceAddress, int localAddress);
/**
* Reads more bytes from i2c device. It uses ioctl to define device address, writes addres in device and then reads
* size number of bytes.
*
* @param fd file descriptor of i2c bus
* @param deviceAddress device address
* @param localAddress address in the device
* @param size number of bytes to be read
* @param offset offset in buffer to stored read data
* @param buffer buffer for data to be written to
* @return number of bytes read or negative number if reading failed.
*/
public static native int i2cReadBytes(int fd, int deviceAddress, int localAddress, int size, int offset, byte[] buffer);
/**
* Reads more bytes from i2c device. It uses ioctl to define device address, writes addres in device and then reads
* size number of bytes.
*
* @param fd file descriptor of i2c bus
* @param deviceAddress device address
* @param writeSize number of bytes to write
* @param writeOffset offset in write buffer to start write data
* @param writeBuffer buffer for data to be written from
* @param readSize number of bytes to be read
* @param readOffset offset in read buffer to stored read data
* @param readBuffer buffer for data read to be stored in
* @return number of bytes read or negative number if reading failed.
*/
public static native int i2cWriteAndReadBytes(int fd, int deviceAddress, int writeSize, int writeOffset, byte[] writeBuffer, int readSize, int readOffset, byte[] readBuffer);
}