2016-01-02 03:02:34 -08:00
|
|
|
/*----------------------------------------------------------------------------*/
|
|
|
|
|
/* Copyright (c) FIRST 2016. All Rights Reserved. */
|
|
|
|
|
/* Open Source Software - may be modified and shared by FRC teams. The code */
|
|
|
|
|
/* must be accompanied by the FIRST BSD license file in the root directory of */
|
|
|
|
|
/* the project. */
|
|
|
|
|
/*----------------------------------------------------------------------------*/
|
|
|
|
|
|
2014-01-06 09:27:51 -05:00
|
|
|
#include <assert.h>
|
2016-05-20 17:30:37 -07:00
|
|
|
#include <jni.h>
|
2016-07-14 00:17:29 -07:00
|
|
|
#include "HAL/cpp/Log.h"
|
2014-01-06 09:27:51 -05:00
|
|
|
|
|
|
|
|
#include "edu_wpi_first_wpilibj_hal_I2CJNI.h"
|
|
|
|
|
|
2016-05-24 00:58:10 -07:00
|
|
|
#include "HAL/I2C.h"
|
2015-11-01 09:11:52 -08:00
|
|
|
#include "HALUtil.h"
|
2018-04-29 23:33:19 -07:00
|
|
|
#include "wpi/jni_util.h"
|
2014-01-06 09:27:51 -05:00
|
|
|
|
2016-10-31 23:04:49 -07:00
|
|
|
using namespace frc;
|
2017-11-15 21:41:58 -08:00
|
|
|
using namespace wpi::java;
|
2016-10-31 23:04:49 -07:00
|
|
|
|
2014-01-06 09:27:51 -05:00
|
|
|
// set the logging level
|
2014-05-30 10:08:29 -04:00
|
|
|
TLogLevel i2cJNILogLevel = logWARNING;
|
2014-01-06 09:27:51 -05:00
|
|
|
|
2016-05-20 17:30:37 -07:00
|
|
|
#define I2CJNI_LOG(level) \
|
|
|
|
|
if (level > i2cJNILogLevel) \
|
|
|
|
|
; \
|
|
|
|
|
else \
|
|
|
|
|
Log().Get(level)
|
2014-01-06 09:27:51 -05:00
|
|
|
|
2015-11-01 09:11:52 -08:00
|
|
|
extern "C" {
|
|
|
|
|
|
2014-01-06 09:27:51 -05:00
|
|
|
/*
|
|
|
|
|
* Class: edu_wpi_first_wpilibj_hal_I2CJNI
|
2014-06-18 15:38:02 -04:00
|
|
|
* Method: i2cInitialize
|
2017-05-09 12:12:46 -07:00
|
|
|
* Signature: (I)V
|
2014-01-06 09:27:51 -05:00
|
|
|
*/
|
2016-05-20 17:30:37 -07:00
|
|
|
JNIEXPORT void JNICALL Java_edu_wpi_first_wpilibj_hal_I2CJNI_i2CInitialize(
|
2017-05-09 12:12:46 -07:00
|
|
|
JNIEnv* env, jclass, jint port) {
|
2016-05-20 17:30:37 -07:00
|
|
|
I2CJNI_LOG(logDEBUG) << "Calling I2CJNI i2CInititalize";
|
2017-05-09 12:12:46 -07:00
|
|
|
I2CJNI_LOG(logDEBUG) << "Port: " << port;
|
2016-05-20 17:30:37 -07:00
|
|
|
int32_t status = 0;
|
2017-05-09 12:12:46 -07:00
|
|
|
HAL_InitializeI2C(static_cast<HAL_I2CPort>(port), &status);
|
2016-05-20 17:30:37 -07:00
|
|
|
I2CJNI_LOG(logDEBUG) << "Status = " << status;
|
2016-09-29 20:18:40 -07:00
|
|
|
CheckStatusForceThrow(env, status);
|
2014-01-06 09:27:51 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/*
|
|
|
|
|
* Class: edu_wpi_first_wpilibj_hal_I2CJNI
|
2014-06-18 15:38:02 -04:00
|
|
|
* Method: i2CTransaction
|
2017-05-09 12:12:46 -07:00
|
|
|
* Signature: (IBLjava/nio/ByteBuffer;BLjava/nio/ByteBuffer;B)I
|
2014-01-06 09:27:51 -05:00
|
|
|
*/
|
2016-05-20 17:30:37 -07:00
|
|
|
JNIEXPORT jint JNICALL Java_edu_wpi_first_wpilibj_hal_I2CJNI_i2CTransaction(
|
2017-05-09 12:12:46 -07:00
|
|
|
JNIEnv* env, jclass, jint port, jbyte address, jobject dataToSend,
|
2016-05-20 17:30:37 -07:00
|
|
|
jbyte sendSize, jobject dataReceived, jbyte receiveSize) {
|
|
|
|
|
I2CJNI_LOG(logDEBUG) << "Calling I2CJNI i2CTransaction";
|
2017-05-09 12:12:46 -07:00
|
|
|
I2CJNI_LOG(logDEBUG) << "Port = " << port;
|
2016-05-20 17:30:37 -07:00
|
|
|
I2CJNI_LOG(logDEBUG) << "Address = " << (jint)address;
|
|
|
|
|
uint8_t* dataToSendPtr = nullptr;
|
|
|
|
|
if (dataToSend != 0) {
|
|
|
|
|
dataToSendPtr = (uint8_t*)env->GetDirectBufferAddress(dataToSend);
|
|
|
|
|
}
|
|
|
|
|
I2CJNI_LOG(logDEBUG) << "DataToSendPtr = " << (jint*)dataToSendPtr;
|
|
|
|
|
I2CJNI_LOG(logDEBUG) << "SendSize = " << (jint)sendSize;
|
|
|
|
|
uint8_t* dataReceivedPtr =
|
|
|
|
|
(uint8_t*)env->GetDirectBufferAddress(dataReceived);
|
|
|
|
|
I2CJNI_LOG(logDEBUG) << "DataReceivedPtr = " << (jint*)dataReceivedPtr;
|
|
|
|
|
I2CJNI_LOG(logDEBUG) << "ReceiveSize = " << (jint)receiveSize;
|
2017-05-09 12:12:46 -07:00
|
|
|
jint returnValue = HAL_TransactionI2C(static_cast<HAL_I2CPort>(port), address, dataToSendPtr, sendSize,
|
2016-05-20 17:30:37 -07:00
|
|
|
dataReceivedPtr, receiveSize);
|
|
|
|
|
I2CJNI_LOG(logDEBUG) << "ReturnValue = " << returnValue;
|
|
|
|
|
return returnValue;
|
2014-06-18 15:38:02 -04:00
|
|
|
}
|
|
|
|
|
|
2017-11-15 21:41:58 -08:00
|
|
|
/*
|
|
|
|
|
* Class: edu_wpi_first_wpilibj_hal_I2CJNI
|
|
|
|
|
* Method: i2CTransactionB
|
|
|
|
|
* Signature: (IB[BB[BB)I
|
|
|
|
|
*/
|
|
|
|
|
JNIEXPORT jint JNICALL Java_edu_wpi_first_wpilibj_hal_I2CJNI_i2CTransactionB(
|
|
|
|
|
JNIEnv* env, jclass, jint port, jbyte address, jbyteArray dataToSend,
|
|
|
|
|
jbyte sendSize, jbyteArray dataReceived, jbyte receiveSize) {
|
|
|
|
|
I2CJNI_LOG(logDEBUG) << "Calling I2CJNI i2CTransactionB";
|
|
|
|
|
I2CJNI_LOG(logDEBUG) << "Port = " << port;
|
|
|
|
|
I2CJNI_LOG(logDEBUG) << "Address = " << (jint)address;
|
|
|
|
|
I2CJNI_LOG(logDEBUG) << "SendSize = " << (jint)sendSize;
|
2018-04-29 23:33:19 -07:00
|
|
|
wpi::SmallVector<uint8_t, 128> recvBuf;
|
2017-11-15 21:41:58 -08:00
|
|
|
recvBuf.resize(receiveSize);
|
|
|
|
|
I2CJNI_LOG(logDEBUG) << "ReceiveSize = " << (jint)receiveSize;
|
|
|
|
|
jint returnValue =
|
|
|
|
|
HAL_TransactionI2C(static_cast<HAL_I2CPort>(port), address,
|
|
|
|
|
reinterpret_cast<const uint8_t *>(
|
|
|
|
|
JByteArrayRef(env, dataToSend).array().data()),
|
|
|
|
|
sendSize, recvBuf.data(), receiveSize);
|
|
|
|
|
env->SetByteArrayRegion(dataReceived, 0, receiveSize,
|
|
|
|
|
reinterpret_cast<const jbyte *>(recvBuf.data()));
|
|
|
|
|
I2CJNI_LOG(logDEBUG) << "ReturnValue = " << returnValue;
|
|
|
|
|
return returnValue;
|
|
|
|
|
}
|
|
|
|
|
|
2014-06-18 15:38:02 -04:00
|
|
|
/*
|
|
|
|
|
* Class: edu_wpi_first_wpilibj_hal_I2CJNI
|
|
|
|
|
* Method: i2CWrite
|
2017-05-09 12:12:46 -07:00
|
|
|
* Signature: (IBLjava/nio/ByteBuffer;B)I
|
2014-06-18 15:38:02 -04:00
|
|
|
*/
|
2016-05-20 17:30:37 -07:00
|
|
|
JNIEXPORT jint JNICALL Java_edu_wpi_first_wpilibj_hal_I2CJNI_i2CWrite(
|
2017-05-09 12:12:46 -07:00
|
|
|
JNIEnv* env, jclass, jint port, jbyte address, jobject dataToSend,
|
2016-05-20 17:30:37 -07:00
|
|
|
jbyte sendSize) {
|
|
|
|
|
I2CJNI_LOG(logDEBUG) << "Calling I2CJNI i2CWrite";
|
2017-05-09 12:12:46 -07:00
|
|
|
I2CJNI_LOG(logDEBUG) << "Port = " << port;
|
2016-05-20 17:30:37 -07:00
|
|
|
I2CJNI_LOG(logDEBUG) << "Address = " << (jint)address;
|
|
|
|
|
uint8_t* dataToSendPtr = nullptr;
|
|
|
|
|
|
|
|
|
|
if (dataToSend != 0) {
|
|
|
|
|
dataToSendPtr = (uint8_t*)env->GetDirectBufferAddress(dataToSend);
|
|
|
|
|
}
|
|
|
|
|
I2CJNI_LOG(logDEBUG) << "DataToSendPtr = " << dataToSendPtr;
|
2017-08-18 21:35:53 -07:00
|
|
|
I2CJNI_LOG(logDEBUG) << "SendSize = " << (jint)sendSize;
|
2017-05-09 12:12:46 -07:00
|
|
|
jint returnValue = HAL_WriteI2C(static_cast<HAL_I2CPort>(port), address, dataToSendPtr, sendSize);
|
2016-05-20 17:30:37 -07:00
|
|
|
I2CJNI_LOG(logDEBUG) << "ReturnValue = " << (jint)returnValue;
|
|
|
|
|
return returnValue;
|
2014-06-18 15:38:02 -04:00
|
|
|
}
|
|
|
|
|
|
2017-11-15 21:41:58 -08:00
|
|
|
/*
|
|
|
|
|
* Class: edu_wpi_first_wpilibj_hal_I2CJNI
|
|
|
|
|
* Method: i2CWriteB
|
|
|
|
|
* Signature: (IB[BB)I
|
|
|
|
|
*/
|
|
|
|
|
JNIEXPORT jint JNICALL Java_edu_wpi_first_wpilibj_hal_I2CJNI_i2CWriteB(
|
|
|
|
|
JNIEnv* env, jclass, jint port, jbyte address, jbyteArray dataToSend,
|
|
|
|
|
jbyte sendSize) {
|
|
|
|
|
I2CJNI_LOG(logDEBUG) << "Calling I2CJNI i2CWrite";
|
|
|
|
|
I2CJNI_LOG(logDEBUG) << "Port = " << port;
|
|
|
|
|
I2CJNI_LOG(logDEBUG) << "Address = " << (jint)address;
|
|
|
|
|
I2CJNI_LOG(logDEBUG) << "SendSize = " << (jint)sendSize;
|
|
|
|
|
jint returnValue =
|
|
|
|
|
HAL_WriteI2C(static_cast<HAL_I2CPort>(port), address,
|
|
|
|
|
reinterpret_cast<const uint8_t *>(
|
|
|
|
|
JByteArrayRef(env, dataToSend).array().data()),
|
|
|
|
|
sendSize);
|
|
|
|
|
I2CJNI_LOG(logDEBUG) << "ReturnValue = " << (jint)returnValue;
|
|
|
|
|
return returnValue;
|
|
|
|
|
}
|
|
|
|
|
|
2014-06-18 15:38:02 -04:00
|
|
|
/*
|
|
|
|
|
* Class: edu_wpi_first_wpilibj_hal_I2CJNI
|
|
|
|
|
* Method: i2CRead
|
2017-05-09 12:12:46 -07:00
|
|
|
* Signature: (IBLjava/nio/ByteBuffer;B)I
|
2014-06-18 15:38:02 -04:00
|
|
|
*/
|
2016-05-20 17:30:37 -07:00
|
|
|
JNIEXPORT jint JNICALL Java_edu_wpi_first_wpilibj_hal_I2CJNI_i2CRead(
|
2017-05-09 12:12:46 -07:00
|
|
|
JNIEnv* env, jclass, jint port, jbyte address, jobject dataReceived,
|
2016-05-20 17:30:37 -07:00
|
|
|
jbyte receiveSize) {
|
|
|
|
|
I2CJNI_LOG(logDEBUG) << "Calling I2CJNI i2CRead";
|
|
|
|
|
I2CJNI_LOG(logDEBUG) << "Port = " << port;
|
|
|
|
|
I2CJNI_LOG(logDEBUG) << "Address = " << address;
|
|
|
|
|
uint8_t* dataReceivedPtr =
|
|
|
|
|
(uint8_t*)env->GetDirectBufferAddress(dataReceived);
|
|
|
|
|
I2CJNI_LOG(logDEBUG) << "DataReceivedPtr = " << dataReceivedPtr;
|
|
|
|
|
I2CJNI_LOG(logDEBUG) << "ReceiveSize = " << receiveSize;
|
2017-05-09 12:12:46 -07:00
|
|
|
jint returnValue = HAL_ReadI2C(static_cast<HAL_I2CPort>(port), address, dataReceivedPtr, receiveSize);
|
2016-05-20 17:30:37 -07:00
|
|
|
I2CJNI_LOG(logDEBUG) << "ReturnValue = " << returnValue;
|
|
|
|
|
return returnValue;
|
2014-06-18 15:38:02 -04:00
|
|
|
}
|
|
|
|
|
|
2017-11-15 21:41:58 -08:00
|
|
|
/*
|
|
|
|
|
* Class: edu_wpi_first_wpilibj_hal_I2CJNI
|
|
|
|
|
* Method: i2CReadB
|
|
|
|
|
* Signature: (IB[BB)I
|
|
|
|
|
*/
|
|
|
|
|
JNIEXPORT jint JNICALL Java_edu_wpi_first_wpilibj_hal_I2CJNI_i2CReadB(
|
|
|
|
|
JNIEnv* env, jclass, jint port, jbyte address, jbyteArray dataReceived,
|
|
|
|
|
jbyte receiveSize) {
|
|
|
|
|
I2CJNI_LOG(logDEBUG) << "Calling I2CJNI i2CRead";
|
|
|
|
|
I2CJNI_LOG(logDEBUG) << "Port = " << port;
|
|
|
|
|
I2CJNI_LOG(logDEBUG) << "Address = " << address;
|
|
|
|
|
I2CJNI_LOG(logDEBUG) << "ReceiveSize = " << receiveSize;
|
2018-04-29 23:33:19 -07:00
|
|
|
wpi::SmallVector<uint8_t, 128> recvBuf;
|
2017-11-15 21:41:58 -08:00
|
|
|
recvBuf.resize(receiveSize);
|
|
|
|
|
jint returnValue = HAL_ReadI2C(static_cast<HAL_I2CPort>(port), address, recvBuf.data(), receiveSize);
|
|
|
|
|
env->SetByteArrayRegion(dataReceived, 0, receiveSize,
|
|
|
|
|
reinterpret_cast<const jbyte *>(recvBuf.data()));
|
|
|
|
|
I2CJNI_LOG(logDEBUG) << "ReturnValue = " << returnValue;
|
|
|
|
|
return returnValue;
|
|
|
|
|
}
|
|
|
|
|
|
2014-06-18 15:38:02 -04:00
|
|
|
/*
|
|
|
|
|
* Class: edu_wpi_first_wpilibj_hal_I2CJNI
|
|
|
|
|
* Method: i2CClose
|
2017-05-09 12:12:46 -07:00
|
|
|
* Signature: (I)V
|
2014-06-18 15:38:02 -04:00
|
|
|
*/
|
2016-05-20 17:30:37 -07:00
|
|
|
JNIEXPORT void JNICALL
|
2017-05-09 12:12:46 -07:00
|
|
|
Java_edu_wpi_first_wpilibj_hal_I2CJNI_i2CClose(JNIEnv*, jclass, jint port) {
|
2016-05-20 17:30:37 -07:00
|
|
|
I2CJNI_LOG(logDEBUG) << "Calling I2CJNI i2CClose";
|
2017-05-09 12:12:46 -07:00
|
|
|
HAL_CloseI2C(static_cast<HAL_I2CPort>(port));
|
2014-01-06 09:27:51 -05:00
|
|
|
}
|
2015-11-01 09:11:52 -08:00
|
|
|
|
|
|
|
|
} // extern "C"
|