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>
|
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_CounterJNI.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
|
2014-05-30 10:08:29 -04:00
|
|
|
TLogLevel counterJNILogLevel = logWARNING;
|
2014-01-06 09:27:51 -05:00
|
|
|
|
2016-05-20 17:30:37 -07:00
|
|
|
#define COUNTERJNI_LOG(level) \
|
|
|
|
|
if (level > counterJNILogLevel) \
|
|
|
|
|
; \
|
|
|
|
|
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_CounterJNI
|
|
|
|
|
* Method: initializeCounter
|
2015-11-01 09:11:52 -08:00
|
|
|
* Signature: (ILjava/nio/IntBuffer;)J
|
2014-01-06 09:27:51 -05:00
|
|
|
*/
|
2016-05-20 17:30:37 -07:00
|
|
|
JNIEXPORT jlong JNICALL
|
|
|
|
|
Java_edu_wpi_first_wpilibj_hal_CounterJNI_initializeCounter(
|
|
|
|
|
JNIEnv* env, jclass, jint mode, jobject index) {
|
|
|
|
|
COUNTERJNI_LOG(logDEBUG) << "Calling COUNTERJNI initializeCounter";
|
|
|
|
|
COUNTERJNI_LOG(logDEBUG) << "Mode = " << mode;
|
|
|
|
|
jint* indexPtr = (jint*)env->GetDirectBufferAddress(index);
|
|
|
|
|
COUNTERJNI_LOG(logDEBUG) << "Index Ptr = " << (uint32_t*)indexPtr;
|
|
|
|
|
int32_t status = 0;
|
|
|
|
|
void* counter = initializeCounter((Mode)mode, (uint32_t*)indexPtr, &status);
|
|
|
|
|
COUNTERJNI_LOG(logDEBUG) << "Index = " << *indexPtr;
|
|
|
|
|
COUNTERJNI_LOG(logDEBUG) << "Status = " << status;
|
|
|
|
|
COUNTERJNI_LOG(logDEBUG) << "COUNTER Ptr = " << counter;
|
|
|
|
|
CheckStatus(env, status);
|
|
|
|
|
return (jlong)counter;
|
2014-01-06 09:27:51 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/*
|
|
|
|
|
* Class: edu_wpi_first_wpilibj_hal_CounterJNI
|
|
|
|
|
* Method: freeCounter
|
2015-11-01 09:11:52 -08:00
|
|
|
* Signature: (J)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_CounterJNI_freeCounter(
|
|
|
|
|
JNIEnv* env, jclass, jlong id) {
|
|
|
|
|
COUNTERJNI_LOG(logDEBUG) << "Calling COUNTERJNI freeCounter";
|
|
|
|
|
COUNTERJNI_LOG(logDEBUG) << "Counter Ptr = " << (void*)id;
|
|
|
|
|
int32_t status = 0;
|
|
|
|
|
freeCounter((void*)id, &status);
|
|
|
|
|
COUNTERJNI_LOG(logDEBUG) << "Status = " << status;
|
|
|
|
|
CheckStatus(env, status);
|
2014-01-06 09:27:51 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/*
|
|
|
|
|
* Class: edu_wpi_first_wpilibj_hal_CounterJNI
|
|
|
|
|
* Method: setCounterAverageSize
|
2015-11-01 09:11:52 -08:00
|
|
|
* Signature: (JI)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_CounterJNI_setCounterAverageSize(
|
|
|
|
|
JNIEnv* env, jclass, jlong id, jint value) {
|
|
|
|
|
COUNTERJNI_LOG(logDEBUG) << "Calling COUNTERJNI setCounterAverageSize";
|
|
|
|
|
COUNTERJNI_LOG(logDEBUG) << "Counter Ptr = " << (void*)id;
|
|
|
|
|
COUNTERJNI_LOG(logDEBUG) << "AverageSize = " << value;
|
|
|
|
|
int32_t status = 0;
|
|
|
|
|
setCounterAverageSize((void*)id, value, &status);
|
|
|
|
|
COUNTERJNI_LOG(logDEBUG) << "Status = " << status;
|
|
|
|
|
CheckStatus(env, status);
|
2014-01-06 09:27:51 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/*
|
|
|
|
|
* Class: edu_wpi_first_wpilibj_hal_CounterJNI
|
2014-08-01 15:00:41 -04:00
|
|
|
* Method: setCounterUpSource
|
2015-11-01 09:11:52 -08:00
|
|
|
* Signature: (JIZ)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_CounterJNI_setCounterUpSource(
|
|
|
|
|
JNIEnv* env, jclass, jlong id, jint pin, jboolean analogTrigger) {
|
|
|
|
|
COUNTERJNI_LOG(logDEBUG) << "Calling COUNTERJNI setCounterUpSource";
|
|
|
|
|
COUNTERJNI_LOG(logDEBUG) << "Counter Ptr = " << (void*)id;
|
|
|
|
|
COUNTERJNI_LOG(logDEBUG) << "Pin = " << pin;
|
|
|
|
|
COUNTERJNI_LOG(logDEBUG) << "AnalogTrigger = " << (jint)analogTrigger;
|
|
|
|
|
int32_t status = 0;
|
|
|
|
|
setCounterUpSource((void*)id, pin, analogTrigger, &status);
|
|
|
|
|
COUNTERJNI_LOG(logDEBUG) << "Status = " << status;
|
|
|
|
|
CheckStatus(env, status);
|
2014-01-06 09:27:51 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/*
|
|
|
|
|
* Class: edu_wpi_first_wpilibj_hal_CounterJNI
|
|
|
|
|
* Method: setCounterUpSourceEdge
|
2015-11-01 09:11:52 -08:00
|
|
|
* Signature: (JZZ)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_CounterJNI_setCounterUpSourceEdge(
|
|
|
|
|
JNIEnv* env, jclass, jlong id, jboolean valueRise, jboolean valueFall) {
|
|
|
|
|
COUNTERJNI_LOG(logDEBUG) << "Calling COUNTERJNI setCounterUpSourceEdge";
|
|
|
|
|
COUNTERJNI_LOG(logDEBUG) << "Counter Ptr = " << (void*)id;
|
|
|
|
|
COUNTERJNI_LOG(logDEBUG) << "Rise = " << (jint)valueRise;
|
|
|
|
|
COUNTERJNI_LOG(logDEBUG) << "Fall = " << (jint)valueFall;
|
|
|
|
|
int32_t status = 0;
|
|
|
|
|
setCounterUpSourceEdge((void*)id, valueRise, valueFall, &status);
|
|
|
|
|
COUNTERJNI_LOG(logDEBUG) << "Status = " << status;
|
|
|
|
|
CheckStatus(env, status);
|
2014-01-06 09:27:51 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/*
|
|
|
|
|
* Class: edu_wpi_first_wpilibj_hal_CounterJNI
|
|
|
|
|
* Method: clearCounterUpSource
|
2015-11-01 09:11:52 -08:00
|
|
|
* Signature: (J)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_CounterJNI_clearCounterUpSource(
|
|
|
|
|
JNIEnv* env, jclass, jlong id) {
|
|
|
|
|
COUNTERJNI_LOG(logDEBUG) << "Calling COUNTERJNI clearCounterUpSource";
|
|
|
|
|
COUNTERJNI_LOG(logDEBUG) << "Counter Ptr = " << (void*)id;
|
|
|
|
|
int32_t status = 0;
|
|
|
|
|
clearCounterUpSource((void*)id, &status);
|
|
|
|
|
COUNTERJNI_LOG(logDEBUG) << "Status = " << status;
|
|
|
|
|
CheckStatus(env, status);
|
2014-01-06 09:27:51 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/*
|
|
|
|
|
* Class: edu_wpi_first_wpilibj_hal_CounterJNI
|
2014-08-01 15:00:41 -04:00
|
|
|
* Method: setCounterDownSource
|
2015-11-01 09:11:52 -08:00
|
|
|
* Signature: (JIZ)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_CounterJNI_setCounterDownSource(
|
|
|
|
|
JNIEnv* env, jclass, jlong id, jint pin, jboolean analogTrigger) {
|
|
|
|
|
COUNTERJNI_LOG(logDEBUG) << "Calling COUNTERJNI setCounterDownSource";
|
|
|
|
|
COUNTERJNI_LOG(logDEBUG) << "Counter Ptr = " << (void*)id;
|
|
|
|
|
COUNTERJNI_LOG(logDEBUG) << "Pin = " << pin;
|
|
|
|
|
COUNTERJNI_LOG(logDEBUG) << "AnalogTrigger = " << (jint)analogTrigger;
|
|
|
|
|
int32_t status = 0;
|
|
|
|
|
setCounterDownSource((void*)id, pin, analogTrigger, &status);
|
|
|
|
|
COUNTERJNI_LOG(logDEBUG) << "Status = " << status;
|
|
|
|
|
if (status == PARAMETER_OUT_OF_RANGE) {
|
|
|
|
|
ThrowIllegalArgumentException(env,
|
|
|
|
|
"Counter only supports DownSource in "
|
|
|
|
|
"TwoPulse and ExternalDirection modes.");
|
|
|
|
|
return;
|
|
|
|
|
}
|
|
|
|
|
CheckStatus(env, status);
|
2014-01-06 09:27:51 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/*
|
|
|
|
|
* Class: edu_wpi_first_wpilibj_hal_CounterJNI
|
|
|
|
|
* Method: setCounterDownSourceEdge
|
2015-11-01 09:11:52 -08:00
|
|
|
* Signature: (JZZ)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_CounterJNI_setCounterDownSourceEdge(
|
|
|
|
|
JNIEnv* env, jclass, jlong id, jboolean valueRise, jboolean valueFall) {
|
|
|
|
|
COUNTERJNI_LOG(logDEBUG) << "Calling COUNTERJNI setCounterDownSourceEdge";
|
|
|
|
|
COUNTERJNI_LOG(logDEBUG) << "Counter Ptr = " << (void*)id;
|
|
|
|
|
COUNTERJNI_LOG(logDEBUG) << "Rise = " << (jint)valueRise;
|
|
|
|
|
COUNTERJNI_LOG(logDEBUG) << "Fall = " << (jint)valueFall;
|
|
|
|
|
int32_t status = 0;
|
|
|
|
|
setCounterDownSourceEdge((void*)id, valueRise, valueFall, &status);
|
|
|
|
|
COUNTERJNI_LOG(logDEBUG) << "Status = " << status;
|
|
|
|
|
CheckStatus(env, status);
|
2014-01-06 09:27:51 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/*
|
|
|
|
|
* Class: edu_wpi_first_wpilibj_hal_CounterJNI
|
|
|
|
|
* Method: clearCounterDownSource
|
2015-11-01 09:11:52 -08:00
|
|
|
* Signature: (J)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_CounterJNI_clearCounterDownSource(
|
|
|
|
|
JNIEnv* env, jclass, jlong id) {
|
|
|
|
|
COUNTERJNI_LOG(logDEBUG) << "Calling COUNTERJNI clearCounterDownSource";
|
|
|
|
|
COUNTERJNI_LOG(logDEBUG) << "Counter Ptr = " << (void*)id;
|
|
|
|
|
int32_t status = 0;
|
|
|
|
|
clearCounterDownSource((void*)id, &status);
|
|
|
|
|
COUNTERJNI_LOG(logDEBUG) << "Status = " << status;
|
|
|
|
|
CheckStatus(env, status);
|
2014-01-06 09:27:51 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/*
|
|
|
|
|
* Class: edu_wpi_first_wpilibj_hal_CounterJNI
|
|
|
|
|
* Method: setCounterUpDownMode
|
2015-11-01 09:11:52 -08:00
|
|
|
* Signature: (J)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_CounterJNI_setCounterUpDownMode(
|
|
|
|
|
JNIEnv* env, jclass, jlong id) {
|
|
|
|
|
COUNTERJNI_LOG(logDEBUG) << "Calling COUNTERJNI setCounterUpDownMode";
|
|
|
|
|
COUNTERJNI_LOG(logDEBUG) << "Counter Ptr = " << (void*)id;
|
|
|
|
|
int32_t status = 0;
|
|
|
|
|
setCounterUpDownMode((void*)id, &status);
|
|
|
|
|
COUNTERJNI_LOG(logDEBUG) << "Status = " << status;
|
|
|
|
|
CheckStatus(env, status);
|
2014-01-06 09:27:51 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/*
|
|
|
|
|
* Class: edu_wpi_first_wpilibj_hal_CounterJNI
|
|
|
|
|
* Method: setCounterExternalDirectionMode
|
2015-11-01 09:11:52 -08:00
|
|
|
* Signature: (J)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_CounterJNI_setCounterExternalDirectionMode(
|
|
|
|
|
JNIEnv* env, jclass, jlong id) {
|
|
|
|
|
COUNTERJNI_LOG(logDEBUG)
|
|
|
|
|
<< "Calling COUNTERJNI setCounterExternalDirectionMode";
|
|
|
|
|
COUNTERJNI_LOG(logDEBUG) << "Counter Ptr = " << (void*)id;
|
|
|
|
|
int32_t status = 0;
|
|
|
|
|
setCounterExternalDirectionMode((void*)id, &status);
|
|
|
|
|
COUNTERJNI_LOG(logDEBUG) << "Status = " << status;
|
|
|
|
|
CheckStatus(env, status);
|
2014-01-06 09:27:51 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/*
|
|
|
|
|
* Class: edu_wpi_first_wpilibj_hal_CounterJNI
|
|
|
|
|
* Method: setCounterSemiPeriodMode
|
2015-11-01 09:11:52 -08:00
|
|
|
* Signature: (JZ)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_CounterJNI_setCounterSemiPeriodMode(
|
|
|
|
|
JNIEnv* env, jclass, jlong id, jboolean value) {
|
|
|
|
|
COUNTERJNI_LOG(logDEBUG) << "Calling COUNTERJNI setCounterSemiPeriodMode";
|
|
|
|
|
COUNTERJNI_LOG(logDEBUG) << "Counter Ptr = " << (void*)id;
|
|
|
|
|
COUNTERJNI_LOG(logDEBUG) << "SemiPeriodMode = " << (jint)value;
|
|
|
|
|
int32_t status = 0;
|
|
|
|
|
setCounterSemiPeriodMode((void*)id, value, &status);
|
|
|
|
|
COUNTERJNI_LOG(logDEBUG) << "Status = " << status;
|
|
|
|
|
CheckStatus(env, status);
|
2014-01-06 09:27:51 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/*
|
|
|
|
|
* Class: edu_wpi_first_wpilibj_hal_CounterJNI
|
|
|
|
|
* Method: setCounterPulseLengthMode
|
2015-11-01 09:11:52 -08:00
|
|
|
* Signature: (JD)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_CounterJNI_setCounterPulseLengthMode(
|
|
|
|
|
JNIEnv* env, jclass, jlong id, jdouble value) {
|
|
|
|
|
COUNTERJNI_LOG(logDEBUG) << "Calling COUNTERJNI setCounterPulseLengthMode";
|
|
|
|
|
COUNTERJNI_LOG(logDEBUG) << "Counter Ptr = " << (void*)id;
|
|
|
|
|
COUNTERJNI_LOG(logDEBUG) << "PulseLengthMode = " << value;
|
|
|
|
|
int32_t status = 0;
|
|
|
|
|
setCounterPulseLengthMode((void*)id, value, &status);
|
|
|
|
|
COUNTERJNI_LOG(logDEBUG) << "Status = " << status;
|
|
|
|
|
CheckStatus(env, status);
|
2014-01-06 09:27:51 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/*
|
|
|
|
|
* Class: edu_wpi_first_wpilibj_hal_CounterJNI
|
|
|
|
|
* Method: getCounterSamplesToAverage
|
2015-11-01 09:11:52 -08:00
|
|
|
* Signature: (J)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_CounterJNI_getCounterSamplesToAverage(
|
|
|
|
|
JNIEnv* env, jclass, jlong id) {
|
|
|
|
|
COUNTERJNI_LOG(logDEBUG) << "Calling COUNTERJNI getCounterSamplesToAverage";
|
|
|
|
|
COUNTERJNI_LOG(logDEBUG) << "Counter Ptr = " << (void*)id;
|
|
|
|
|
int32_t status = 0;
|
|
|
|
|
jint returnValue = getCounterSamplesToAverage((void*)id, &status);
|
|
|
|
|
COUNTERJNI_LOG(logDEBUG) << "Status = " << status;
|
|
|
|
|
COUNTERJNI_LOG(logDEBUG) << "getCounterSamplesToAverageResult = "
|
|
|
|
|
<< returnValue;
|
|
|
|
|
CheckStatus(env, status);
|
|
|
|
|
return returnValue;
|
2014-01-06 09:27:51 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/*
|
|
|
|
|
* Class: edu_wpi_first_wpilibj_hal_CounterJNI
|
|
|
|
|
* Method: setCounterSamplesToAverage
|
2015-11-01 09:11:52 -08:00
|
|
|
* Signature: (JI)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_CounterJNI_setCounterSamplesToAverage(
|
|
|
|
|
JNIEnv* env, jclass, jlong id, jint value) {
|
|
|
|
|
COUNTERJNI_LOG(logDEBUG) << "Calling COUNTERJNI setCounterSamplesToAverage";
|
|
|
|
|
COUNTERJNI_LOG(logDEBUG) << "Counter Ptr = " << (void*)id;
|
|
|
|
|
COUNTERJNI_LOG(logDEBUG) << "SamplesToAverage = " << value;
|
|
|
|
|
int32_t status = 0;
|
|
|
|
|
setCounterSamplesToAverage((void*)id, value, &status);
|
|
|
|
|
COUNTERJNI_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_CounterJNI
|
|
|
|
|
* Method: resetCounter
|
2015-11-01 09:11:52 -08:00
|
|
|
* Signature: (J)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_CounterJNI_resetCounter(
|
|
|
|
|
JNIEnv* env, jclass, jlong id) {
|
|
|
|
|
COUNTERJNI_LOG(logDEBUG) << "Calling COUNTERJNI resetCounter";
|
|
|
|
|
COUNTERJNI_LOG(logDEBUG) << "Counter Ptr = " << (void*)id;
|
|
|
|
|
int32_t status = 0;
|
|
|
|
|
resetCounter((void*)id, &status);
|
|
|
|
|
COUNTERJNI_LOG(logDEBUG) << "Status = " << status;
|
|
|
|
|
CheckStatus(env, status);
|
2014-01-06 09:27:51 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/*
|
|
|
|
|
* Class: edu_wpi_first_wpilibj_hal_CounterJNI
|
|
|
|
|
* Method: getCounter
|
2015-11-01 09:11:52 -08:00
|
|
|
* Signature: (J)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_CounterJNI_getCounter(
|
|
|
|
|
JNIEnv* env, jclass, jlong id) {
|
|
|
|
|
// COUNTERJNI_LOG(logDEBUG) << "Calling COUNTERJNI getCounter";
|
|
|
|
|
// COUNTERJNI_LOG(logDEBUG) << "Counter Ptr = " << (void*)id;
|
|
|
|
|
int32_t status = 0;
|
|
|
|
|
jint returnValue = getCounter((void*)id, &status);
|
|
|
|
|
// COUNTERJNI_LOG(logDEBUG) << "Status = " << status;
|
|
|
|
|
// COUNTERJNI_LOG(logDEBUG) << "getCounterResult = " << returnValue;
|
|
|
|
|
CheckStatus(env, status);
|
|
|
|
|
return returnValue;
|
2014-01-06 09:27:51 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/*
|
|
|
|
|
* Class: edu_wpi_first_wpilibj_hal_CounterJNI
|
|
|
|
|
* Method: getCounterPeriod
|
2015-11-01 09:11:52 -08:00
|
|
|
* Signature: (J)D
|
2014-01-06 09:27:51 -05:00
|
|
|
*/
|
2016-05-20 17:30:37 -07:00
|
|
|
JNIEXPORT jdouble JNICALL
|
|
|
|
|
Java_edu_wpi_first_wpilibj_hal_CounterJNI_getCounterPeriod(
|
|
|
|
|
JNIEnv* env, jclass, jlong id) {
|
|
|
|
|
COUNTERJNI_LOG(logDEBUG) << "Calling COUNTERJNI getCounterPeriod";
|
|
|
|
|
COUNTERJNI_LOG(logDEBUG) << "Counter Ptr = " << (void*)id;
|
|
|
|
|
int32_t status = 0;
|
|
|
|
|
jdouble returnValue = getCounterPeriod((void*)id, &status);
|
|
|
|
|
COUNTERJNI_LOG(logDEBUG) << "Status = " << status;
|
|
|
|
|
COUNTERJNI_LOG(logDEBUG) << "getCounterPeriodResult = " << returnValue;
|
|
|
|
|
CheckStatus(env, status);
|
|
|
|
|
return returnValue;
|
2014-01-06 09:27:51 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/*
|
|
|
|
|
* Class: edu_wpi_first_wpilibj_hal_CounterJNI
|
|
|
|
|
* Method: setCounterMaxPeriod
|
2015-11-01 09:11:52 -08:00
|
|
|
* Signature: (JD)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_CounterJNI_setCounterMaxPeriod(
|
|
|
|
|
JNIEnv* env, jclass, jlong id, jdouble value) {
|
|
|
|
|
COUNTERJNI_LOG(logDEBUG) << "Calling COUNTERJNI setCounterMaxPeriod";
|
|
|
|
|
COUNTERJNI_LOG(logDEBUG) << "Counter Ptr = " << (void*)id;
|
|
|
|
|
COUNTERJNI_LOG(logDEBUG) << "MaxPeriod = " << value;
|
|
|
|
|
int32_t status = 0;
|
|
|
|
|
setCounterMaxPeriod((void*)id, value, &status);
|
|
|
|
|
COUNTERJNI_LOG(logDEBUG) << "Status = " << status;
|
|
|
|
|
CheckStatus(env, status);
|
2014-01-06 09:27:51 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/*
|
|
|
|
|
* Class: edu_wpi_first_wpilibj_hal_CounterJNI
|
|
|
|
|
* Method: setCounterUpdateWhenEmpty
|
2015-11-01 09:11:52 -08:00
|
|
|
* Signature: (JZ)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_CounterJNI_setCounterUpdateWhenEmpty(
|
|
|
|
|
JNIEnv* env, jclass, jlong id, jboolean value) {
|
|
|
|
|
COUNTERJNI_LOG(logDEBUG) << "Calling COUNTERJNI setCounterMaxPeriod";
|
|
|
|
|
COUNTERJNI_LOG(logDEBUG) << "Counter Ptr = " << (void*)id;
|
|
|
|
|
COUNTERJNI_LOG(logDEBUG) << "UpdateWhenEmpty = " << (jint)value;
|
|
|
|
|
int32_t status = 0;
|
|
|
|
|
setCounterUpdateWhenEmpty((void*)id, value, &status);
|
|
|
|
|
COUNTERJNI_LOG(logDEBUG) << "Status = " << status;
|
|
|
|
|
CheckStatus(env, status);
|
2014-01-06 09:27:51 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/*
|
|
|
|
|
* Class: edu_wpi_first_wpilibj_hal_CounterJNI
|
|
|
|
|
* Method: getCounterStopped
|
2015-11-01 09:11:52 -08:00
|
|
|
* Signature: (J)Z
|
2014-01-06 09:27:51 -05:00
|
|
|
*/
|
2016-05-20 17:30:37 -07:00
|
|
|
JNIEXPORT jboolean JNICALL
|
|
|
|
|
Java_edu_wpi_first_wpilibj_hal_CounterJNI_getCounterStopped(
|
|
|
|
|
JNIEnv* env, jclass, jlong id) {
|
|
|
|
|
COUNTERJNI_LOG(logDEBUG) << "Calling COUNTERJNI getCounterStopped";
|
|
|
|
|
COUNTERJNI_LOG(logDEBUG) << "Counter Ptr = " << (void*)id;
|
|
|
|
|
int32_t status = 0;
|
|
|
|
|
jboolean returnValue = getCounterStopped((void*)id, &status);
|
|
|
|
|
COUNTERJNI_LOG(logDEBUG) << "Status = " << status;
|
|
|
|
|
COUNTERJNI_LOG(logDEBUG) << "getCounterStoppedResult = " << (jint)returnValue;
|
|
|
|
|
CheckStatus(env, status);
|
|
|
|
|
return returnValue;
|
2014-01-06 09:27:51 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/*
|
|
|
|
|
* Class: edu_wpi_first_wpilibj_hal_CounterJNI
|
|
|
|
|
* Method: getCounterDirection
|
2015-11-01 09:11:52 -08:00
|
|
|
* Signature: (J)Z
|
2014-01-06 09:27:51 -05:00
|
|
|
*/
|
2016-05-20 17:30:37 -07:00
|
|
|
JNIEXPORT jboolean JNICALL
|
|
|
|
|
Java_edu_wpi_first_wpilibj_hal_CounterJNI_getCounterDirection(
|
|
|
|
|
JNIEnv* env, jclass, jlong id) {
|
|
|
|
|
COUNTERJNI_LOG(logDEBUG) << "Calling COUNTERJNI getCounterDirection";
|
|
|
|
|
COUNTERJNI_LOG(logDEBUG) << "Counter Ptr = " << (void*)id;
|
|
|
|
|
int32_t status = 0;
|
|
|
|
|
jboolean returnValue = getCounterDirection((void*)id, &status);
|
|
|
|
|
COUNTERJNI_LOG(logDEBUG) << "Status = " << status;
|
|
|
|
|
COUNTERJNI_LOG(logDEBUG) << "getCounterDirectionResult = "
|
|
|
|
|
<< (jint)returnValue;
|
|
|
|
|
CheckStatus(env, status);
|
|
|
|
|
return returnValue;
|
2014-01-06 09:27:51 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/*
|
|
|
|
|
* Class: edu_wpi_first_wpilibj_hal_CounterJNI
|
|
|
|
|
* Method: setCounterReverseDirection
|
2015-11-01 09:11:52 -08:00
|
|
|
* Signature: (JZ)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_CounterJNI_setCounterReverseDirection(
|
|
|
|
|
JNIEnv* env, jclass, jlong id, jboolean value) {
|
|
|
|
|
COUNTERJNI_LOG(logDEBUG) << "Calling COUNTERJNI setCounterReverseDirection";
|
|
|
|
|
COUNTERJNI_LOG(logDEBUG) << "Counter Ptr = " << (void*)id;
|
|
|
|
|
COUNTERJNI_LOG(logDEBUG) << "ReverseDirection = " << (jint)value;
|
|
|
|
|
int32_t status = 0;
|
|
|
|
|
setCounterReverseDirection((void*)id, value, &status);
|
|
|
|
|
COUNTERJNI_LOG(logDEBUG) << "Status = " << status;
|
|
|
|
|
CheckStatus(env, status);
|
2014-01-06 09:27:51 -05:00
|
|
|
}
|
2015-11-01 09:11:52 -08:00
|
|
|
|
|
|
|
|
} // extern "C"
|