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 <jni.h>
|
|
|
|
|
#include <assert.h>
|
2014-05-02 17:54:01 -04:00
|
|
|
#include "Log.hpp"
|
2014-01-06 09:27:51 -05:00
|
|
|
|
|
|
|
|
#include "edu_wpi_first_wpilibj_hal_EncoderJNI.h"
|
|
|
|
|
|
2014-05-02 17:54:01 -04:00
|
|
|
#include "HAL/Digital.hpp"
|
2015-11-01 09:11:52 -08:00
|
|
|
#include "HAL/Errors.hpp"
|
|
|
|
|
#include "HALUtil.h"
|
2014-01-06 09:27:51 -05:00
|
|
|
|
|
|
|
|
// set the logging level
|
2015-01-18 18:57:34 -08:00
|
|
|
TLogLevel encoderJNILogLevel = logWARNING;
|
2014-01-06 09:27:51 -05:00
|
|
|
|
|
|
|
|
#define ENCODERJNI_LOG(level) \
|
|
|
|
|
if (level > encoderJNILogLevel) ; \
|
|
|
|
|
else Log().Get(level)
|
|
|
|
|
|
2015-11-01 09:11:52 -08:00
|
|
|
extern "C" {
|
|
|
|
|
|
2014-01-06 09:27:51 -05:00
|
|
|
/*
|
|
|
|
|
* Class: edu_wpi_first_wpilibj_hal_EncoderJNI
|
|
|
|
|
* Method: initializeEncoder
|
2015-11-01 09:11:52 -08:00
|
|
|
* Signature: (BIZBIZZLjava/nio/IntBuffer;)J
|
2014-01-06 09:27:51 -05:00
|
|
|
*/
|
2015-11-01 09:11:52 -08:00
|
|
|
JNIEXPORT jlong JNICALL Java_edu_wpi_first_wpilibj_hal_EncoderJNI_initializeEncoder
|
|
|
|
|
(JNIEnv * env, jclass, jbyte port_a_module, jint port_a_pin, jboolean port_a_analog_trigger, jbyte port_b_module, jint port_b_pin, jboolean port_b_analog_trigger, jboolean reverseDirection, jobject index)
|
2014-01-06 09:27:51 -05:00
|
|
|
{
|
|
|
|
|
ENCODERJNI_LOG(logDEBUG) << "Calling ENCODERJNI initializeEncoder";
|
|
|
|
|
ENCODERJNI_LOG(logDEBUG) << "Module A = " << (jint)port_a_module;
|
|
|
|
|
ENCODERJNI_LOG(logDEBUG) << "Pin A = " << port_a_pin;
|
|
|
|
|
ENCODERJNI_LOG(logDEBUG) << "Analog Trigger A = " << (jint)port_a_analog_trigger;
|
|
|
|
|
ENCODERJNI_LOG(logDEBUG) << "Module B = " << (jint)port_b_module;
|
|
|
|
|
ENCODERJNI_LOG(logDEBUG) << "Pin B = " << port_b_pin;
|
|
|
|
|
ENCODERJNI_LOG(logDEBUG) << "Analog Trigger B = " << (jint)port_b_analog_trigger;
|
|
|
|
|
ENCODERJNI_LOG(logDEBUG) << "Reverse direction = " << (jint)reverseDirection;
|
|
|
|
|
jint * indexPtr = (jint*)env->GetDirectBufferAddress(index);
|
|
|
|
|
ENCODERJNI_LOG(logDEBUG) << "Index Ptr = " << indexPtr;
|
2015-11-01 09:11:52 -08:00
|
|
|
int32_t status = 0;
|
|
|
|
|
void* encoder = initializeEncoder(port_a_module, port_a_pin, port_a_analog_trigger,
|
2014-01-06 09:27:51 -05:00
|
|
|
port_b_module, port_b_pin, port_b_analog_trigger,
|
2015-11-01 09:11:52 -08:00
|
|
|
reverseDirection, indexPtr, &status);
|
2014-01-06 09:27:51 -05:00
|
|
|
|
|
|
|
|
ENCODERJNI_LOG(logDEBUG) << "Index = " << *indexPtr;
|
2015-11-01 09:11:52 -08:00
|
|
|
ENCODERJNI_LOG(logDEBUG) << "Status = " << status;
|
|
|
|
|
ENCODERJNI_LOG(logDEBUG) << "ENCODER Ptr = " << encoder;
|
|
|
|
|
CheckStatus(env, status);
|
|
|
|
|
return (jlong)encoder;
|
2014-01-06 09:27:51 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/*
|
|
|
|
|
* Class: edu_wpi_first_wpilibj_hal_EncoderJNI
|
|
|
|
|
* Method: freeEncoder
|
2015-11-01 09:11:52 -08:00
|
|
|
* Signature: (J)V
|
2014-01-06 09:27:51 -05:00
|
|
|
*/
|
|
|
|
|
JNIEXPORT void JNICALL Java_edu_wpi_first_wpilibj_hal_EncoderJNI_freeEncoder
|
2015-11-01 09:11:52 -08:00
|
|
|
(JNIEnv * env, jclass, jlong id)
|
2014-01-06 09:27:51 -05:00
|
|
|
{
|
|
|
|
|
ENCODERJNI_LOG(logDEBUG) << "Calling ENCODERJNI freeEncoder";
|
2015-11-01 09:11:52 -08:00
|
|
|
ENCODERJNI_LOG(logDEBUG) << "Encoder Ptr = " << (void*)id;
|
|
|
|
|
int32_t status = 0;
|
|
|
|
|
freeEncoder((void*)id, &status);
|
|
|
|
|
ENCODERJNI_LOG(logDEBUG) << "Status = " << status;
|
|
|
|
|
CheckStatus(env, status);
|
2014-01-06 09:27:51 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/*
|
|
|
|
|
* Class: edu_wpi_first_wpilibj_hal_EncoderJNI
|
|
|
|
|
* Method: resetEncoder
|
2015-11-01 09:11:52 -08:00
|
|
|
* Signature: (J)V
|
2014-01-06 09:27:51 -05:00
|
|
|
*/
|
|
|
|
|
JNIEXPORT void JNICALL Java_edu_wpi_first_wpilibj_hal_EncoderJNI_resetEncoder
|
2015-11-01 09:11:52 -08:00
|
|
|
(JNIEnv * env, jclass, jlong id)
|
2014-01-06 09:27:51 -05:00
|
|
|
{
|
|
|
|
|
ENCODERJNI_LOG(logDEBUG) << "Calling ENCODERJNI resetEncoder";
|
2015-11-01 09:11:52 -08:00
|
|
|
ENCODERJNI_LOG(logDEBUG) << "Encoder Ptr = " << (void*)id;
|
|
|
|
|
int32_t status = 0;
|
|
|
|
|
resetEncoder((void*)id, &status);
|
|
|
|
|
ENCODERJNI_LOG(logDEBUG) << "Status = " << status;
|
|
|
|
|
CheckStatus(env, status);
|
2014-01-06 09:27:51 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/*
|
|
|
|
|
* Class: edu_wpi_first_wpilibj_hal_EncoderJNI
|
|
|
|
|
* Method: getEncoder
|
2015-11-01 09:11:52 -08:00
|
|
|
* Signature: (J)I
|
2014-01-06 09:27:51 -05:00
|
|
|
*/
|
|
|
|
|
JNIEXPORT jint JNICALL Java_edu_wpi_first_wpilibj_hal_EncoderJNI_getEncoder
|
2015-11-01 09:11:52 -08:00
|
|
|
(JNIEnv * env, jclass, jlong id)
|
2014-01-06 09:27:51 -05:00
|
|
|
{
|
|
|
|
|
ENCODERJNI_LOG(logDEBUG) << "Calling ENCODERJNI getEncoder";
|
2015-11-01 09:11:52 -08:00
|
|
|
ENCODERJNI_LOG(logDEBUG) << "Encoder Ptr = " << (void*)id;
|
|
|
|
|
int32_t status = 0;
|
|
|
|
|
jint returnValue = getEncoder((void*)id, &status);
|
|
|
|
|
ENCODERJNI_LOG(logDEBUG) << "Status = " << status;
|
2014-01-06 09:27:51 -05:00
|
|
|
ENCODERJNI_LOG(logDEBUG) << "getEncoderResult = " << returnValue;
|
2015-11-01 09:11:52 -08:00
|
|
|
CheckStatus(env, status);
|
2014-01-06 09:27:51 -05:00
|
|
|
return returnValue;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/*
|
|
|
|
|
* Class: edu_wpi_first_wpilibj_hal_EncoderJNI
|
|
|
|
|
* Method: getEncoderPeriod
|
2015-11-01 09:11:52 -08:00
|
|
|
* Signature: (J)D
|
2014-01-06 09:27:51 -05:00
|
|
|
*/
|
|
|
|
|
JNIEXPORT jdouble JNICALL Java_edu_wpi_first_wpilibj_hal_EncoderJNI_getEncoderPeriod
|
2015-11-01 09:11:52 -08:00
|
|
|
(JNIEnv * env, jclass, jlong id)
|
2014-01-06 09:27:51 -05:00
|
|
|
{
|
|
|
|
|
ENCODERJNI_LOG(logDEBUG) << "Calling ENCODERJNI getEncoderPeriod";
|
2015-11-01 09:11:52 -08:00
|
|
|
ENCODERJNI_LOG(logDEBUG) << "Encoder Ptr = " << (void*)id;
|
|
|
|
|
int32_t status = 0;
|
|
|
|
|
double returnValue = getEncoderPeriod((void*)id, &status);
|
|
|
|
|
ENCODERJNI_LOG(logDEBUG) << "Status = " << status;
|
2014-01-06 09:27:51 -05:00
|
|
|
ENCODERJNI_LOG(logDEBUG) << "getEncoderPeriodResult = " << returnValue;
|
2015-11-01 09:11:52 -08:00
|
|
|
CheckStatus(env, status);
|
2014-01-06 09:27:51 -05:00
|
|
|
return returnValue;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/*
|
|
|
|
|
* Class: edu_wpi_first_wpilibj_hal_EncoderJNI
|
|
|
|
|
* Method: setEncoderMaxPeriod
|
2015-11-01 09:11:52 -08:00
|
|
|
* Signature: (JD)V
|
2014-01-06 09:27:51 -05:00
|
|
|
*/
|
|
|
|
|
JNIEXPORT void JNICALL Java_edu_wpi_first_wpilibj_hal_EncoderJNI_setEncoderMaxPeriod
|
2015-11-01 09:11:52 -08:00
|
|
|
(JNIEnv * env, jclass, jlong id, jdouble value)
|
2014-01-06 09:27:51 -05:00
|
|
|
{
|
|
|
|
|
ENCODERJNI_LOG(logDEBUG) << "Calling ENCODERJNI setEncoderMaxPeriod";
|
2015-11-01 09:11:52 -08:00
|
|
|
ENCODERJNI_LOG(logDEBUG) << "Encoder Ptr = " << (void*)id;
|
|
|
|
|
int32_t status = 0;
|
|
|
|
|
setEncoderMaxPeriod((void*)id, value, &status);
|
|
|
|
|
ENCODERJNI_LOG(logDEBUG) << "Status = " << status;
|
|
|
|
|
CheckStatus(env, status);
|
2014-01-06 09:27:51 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/*
|
|
|
|
|
* Class: edu_wpi_first_wpilibj_hal_EncoderJNI
|
|
|
|
|
* Method: getEncoderStopped
|
2015-11-01 09:11:52 -08:00
|
|
|
* Signature: (J)Z
|
2014-01-06 09:27:51 -05:00
|
|
|
*/
|
2015-11-01 09:11:52 -08:00
|
|
|
JNIEXPORT jboolean JNICALL Java_edu_wpi_first_wpilibj_hal_EncoderJNI_getEncoderStopped
|
|
|
|
|
(JNIEnv * env, jclass, jlong id)
|
2014-01-06 09:27:51 -05:00
|
|
|
{
|
|
|
|
|
ENCODERJNI_LOG(logDEBUG) << "Calling ENCODERJNI getEncoderStopped";
|
2015-11-01 09:11:52 -08:00
|
|
|
ENCODERJNI_LOG(logDEBUG) << "Encoder Ptr = " << (void*)id;
|
|
|
|
|
int32_t status = 0;
|
|
|
|
|
jboolean returnValue = getEncoderStopped((void*)id, &status);
|
|
|
|
|
ENCODERJNI_LOG(logDEBUG) << "Status = " << status;
|
2014-01-06 09:27:51 -05:00
|
|
|
ENCODERJNI_LOG(logDEBUG) << "getEncoderStoppedResult = " << returnValue;
|
2015-11-01 09:11:52 -08:00
|
|
|
CheckStatus(env, status);
|
2014-01-06 09:27:51 -05:00
|
|
|
return returnValue;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/*
|
|
|
|
|
* Class: edu_wpi_first_wpilibj_hal_EncoderJNI
|
|
|
|
|
* Method: getEncoderDirection
|
2015-11-01 09:11:52 -08:00
|
|
|
* Signature: (J)Z
|
2014-01-06 09:27:51 -05:00
|
|
|
*/
|
2015-11-01 09:11:52 -08:00
|
|
|
JNIEXPORT jboolean JNICALL Java_edu_wpi_first_wpilibj_hal_EncoderJNI_getEncoderDirection
|
|
|
|
|
(JNIEnv * env, jclass, jlong id)
|
2014-01-06 09:27:51 -05:00
|
|
|
{
|
|
|
|
|
ENCODERJNI_LOG(logDEBUG) << "Calling ENCODERJNI getEncoderDirection";
|
2015-11-01 09:11:52 -08:00
|
|
|
ENCODERJNI_LOG(logDEBUG) << "Encoder Ptr = " << (void*)id;
|
|
|
|
|
int32_t status = 0;
|
|
|
|
|
jboolean returnValue = getEncoderDirection((void*)id, &status);
|
|
|
|
|
ENCODERJNI_LOG(logDEBUG) << "Status = " << status;
|
2014-01-06 09:27:51 -05:00
|
|
|
ENCODERJNI_LOG(logDEBUG) << "getEncoderDirectionResult = " << returnValue;
|
2015-11-01 09:11:52 -08:00
|
|
|
CheckStatus(env, status);
|
2014-01-06 09:27:51 -05:00
|
|
|
return returnValue;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/*
|
|
|
|
|
* Class: edu_wpi_first_wpilibj_hal_EncoderJNI
|
|
|
|
|
* Method: setEncoderReverseDirection
|
2015-11-01 09:11:52 -08:00
|
|
|
* Signature: (JZ)V
|
2014-01-06 09:27:51 -05:00
|
|
|
*/
|
|
|
|
|
JNIEXPORT void JNICALL Java_edu_wpi_first_wpilibj_hal_EncoderJNI_setEncoderReverseDirection
|
2015-11-01 09:11:52 -08:00
|
|
|
(JNIEnv * env, jclass, jlong id, jboolean value)
|
2014-01-06 09:27:51 -05:00
|
|
|
{
|
|
|
|
|
ENCODERJNI_LOG(logDEBUG) << "Calling ENCODERJNI setEncoderReverseDirection";
|
2015-11-01 09:11:52 -08:00
|
|
|
ENCODERJNI_LOG(logDEBUG) << "Encoder Ptr = " << (void*)id;
|
|
|
|
|
int32_t status = 0;
|
|
|
|
|
setEncoderReverseDirection((void*)id, value, &status);
|
|
|
|
|
ENCODERJNI_LOG(logDEBUG) << "Status = " << status;
|
|
|
|
|
CheckStatus(env, status);
|
2014-01-06 09:27:51 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/*
|
|
|
|
|
* Class: edu_wpi_first_wpilibj_hal_EncoderJNI
|
|
|
|
|
* Method: setEncoderSamplesToAverage
|
2015-11-01 09:11:52 -08:00
|
|
|
* Signature: (JI)V
|
2014-01-06 09:27:51 -05:00
|
|
|
*/
|
|
|
|
|
JNIEXPORT void JNICALL Java_edu_wpi_first_wpilibj_hal_EncoderJNI_setEncoderSamplesToAverage
|
2015-11-01 09:11:52 -08:00
|
|
|
(JNIEnv * env, jclass, jlong id, jint value)
|
2014-01-06 09:27:51 -05:00
|
|
|
{
|
|
|
|
|
ENCODERJNI_LOG(logDEBUG) << "Calling ENCODERJNI setEncoderSamplesToAverage";
|
2015-11-01 09:11:52 -08:00
|
|
|
ENCODERJNI_LOG(logDEBUG) << "Encoder Ptr = " << (void*)id;
|
|
|
|
|
int32_t status = 0;
|
|
|
|
|
setEncoderSamplesToAverage((void*)id, value, &status);
|
|
|
|
|
ENCODERJNI_LOG(logDEBUG) << "Status = " << status;
|
|
|
|
|
if (status == PARAMETER_OUT_OF_RANGE) {
|
|
|
|
|
ThrowBoundaryException(env, value, 1, 127);
|
|
|
|
|
return;
|
|
|
|
|
}
|
|
|
|
|
CheckStatus(env, status);
|
2014-01-06 09:27:51 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/*
|
|
|
|
|
* Class: edu_wpi_first_wpilibj_hal_EncoderJNI
|
|
|
|
|
* Method: getEncoderSamplesToAverage
|
2015-11-01 09:11:52 -08:00
|
|
|
* Signature: (J)I
|
2014-01-06 09:27:51 -05:00
|
|
|
*/
|
|
|
|
|
JNIEXPORT jint JNICALL Java_edu_wpi_first_wpilibj_hal_EncoderJNI_getEncoderSamplesToAverage
|
2015-11-01 09:11:52 -08:00
|
|
|
(JNIEnv * env, jclass, jlong id)
|
2014-01-06 09:27:51 -05:00
|
|
|
{
|
|
|
|
|
ENCODERJNI_LOG(logDEBUG) << "Calling ENCODERJNI getEncoderSamplesToAverage";
|
2015-11-01 09:11:52 -08:00
|
|
|
ENCODERJNI_LOG(logDEBUG) << "Encoder Ptr = " << (void*)id;
|
|
|
|
|
int32_t status = 0;
|
|
|
|
|
jint returnValue = getEncoderSamplesToAverage((void*)id, &status);
|
|
|
|
|
ENCODERJNI_LOG(logDEBUG) << "Status = " << status;
|
2014-01-06 09:27:51 -05:00
|
|
|
ENCODERJNI_LOG(logDEBUG) << "getEncoderSamplesToAverageResult = " << returnValue;
|
2015-11-01 09:11:52 -08:00
|
|
|
CheckStatus(env, status);
|
2014-01-06 09:27:51 -05:00
|
|
|
return returnValue;
|
|
|
|
|
}
|
2015-01-08 00:23:32 -05:00
|
|
|
|
|
|
|
|
/*
|
|
|
|
|
* Class: edu_wpi_first_wpilibj_hal_EncoderJNI
|
|
|
|
|
* Method: setEncoderIndexSource
|
2015-11-01 09:11:52 -08:00
|
|
|
* Signature: (JIZZZ)V
|
2015-01-08 00:23:32 -05:00
|
|
|
*/
|
|
|
|
|
JNIEXPORT void JNICALL Java_edu_wpi_first_wpilibj_hal_EncoderJNI_setEncoderIndexSource
|
2015-11-01 09:11:52 -08:00
|
|
|
(JNIEnv * env, jclass, jlong id, jint pin, jboolean analogTrigger, jboolean activeHigh, jboolean edgeSensitive)
|
2015-01-08 00:23:32 -05:00
|
|
|
{
|
|
|
|
|
ENCODERJNI_LOG(logDEBUG) << "Calling ENCODERJNI setEncoderIndexSource";
|
2015-11-01 09:11:52 -08:00
|
|
|
ENCODERJNI_LOG(logDEBUG) << "Encoder Ptr = " << (void*)id;
|
2015-01-08 00:23:32 -05:00
|
|
|
ENCODERJNI_LOG(logDEBUG) << "Pin = " << pin;
|
|
|
|
|
ENCODERJNI_LOG(logDEBUG) << "Analog Trigger = " << (analogTrigger?"true":"false");
|
|
|
|
|
ENCODERJNI_LOG(logDEBUG) << "Active High = " << (activeHigh?"true":"false");
|
|
|
|
|
ENCODERJNI_LOG(logDEBUG) << "Edge Sensitive = " << (edgeSensitive?"true":"false");
|
2015-11-01 09:11:52 -08:00
|
|
|
int32_t status = 0;
|
|
|
|
|
setEncoderIndexSource((void*)id, pin, analogTrigger, activeHigh, edgeSensitive, &status);
|
|
|
|
|
ENCODERJNI_LOG(logDEBUG) << "Status = " << status;
|
|
|
|
|
CheckStatus(env, status);
|
2015-01-08 00:23:32 -05:00
|
|
|
}
|
2015-11-01 09:11:52 -08:00
|
|
|
|
|
|
|
|
} // extern "C"
|