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_DIOJNI.h"
|
|
|
|
|
|
2014-05-02 17:54:01 -04:00
|
|
|
#include "HAL/Digital.hpp"
|
2015-11-01 09:11:52 -08:00
|
|
|
#include "HALUtil.h"
|
2014-01-06 09:27:51 -05:00
|
|
|
|
|
|
|
|
// set the logging level
|
2014-05-30 10:08:29 -04:00
|
|
|
TLogLevel dioJNILogLevel = logWARNING;
|
2014-01-06 09:27:51 -05:00
|
|
|
|
|
|
|
|
#define DIOJNI_LOG(level) \
|
|
|
|
|
if (level > dioJNILogLevel) ; \
|
|
|
|
|
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_DIOJNI
|
|
|
|
|
* Method: initializeDigitalPort
|
2015-11-01 09:11:52 -08:00
|
|
|
* Signature: (J)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_DIOJNI_initializeDigitalPort
|
|
|
|
|
(JNIEnv * env, jclass, jlong id)
|
2014-01-06 09:27:51 -05:00
|
|
|
{
|
|
|
|
|
DIOJNI_LOG(logDEBUG) << "Calling DIOJNI initializeDigitalPort";
|
2015-11-01 09:11:52 -08:00
|
|
|
DIOJNI_LOG(logDEBUG) << "Port Ptr = " << (void*)id;
|
|
|
|
|
int32_t status = 0;
|
|
|
|
|
void* dio = initializeDigitalPort((void*)id, &status);
|
|
|
|
|
DIOJNI_LOG(logDEBUG) << "Status = " << status;
|
|
|
|
|
DIOJNI_LOG(logDEBUG) << "DIO Ptr = " << dio;
|
|
|
|
|
CheckStatus(env, status);
|
|
|
|
|
return (jlong)dio;
|
2014-01-06 09:27:51 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/*
|
|
|
|
|
* Class: edu_wpi_first_wpilibj_hal_DIOJNI
|
|
|
|
|
* Method: allocateDIO
|
2015-11-01 09:11:52 -08:00
|
|
|
* Signature: (JZ)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_DIOJNI_allocateDIO
|
|
|
|
|
(JNIEnv * env, jclass, jlong id, jboolean value)
|
2014-01-06 09:27:51 -05:00
|
|
|
{
|
|
|
|
|
DIOJNI_LOG(logDEBUG) << "Calling DIOJNI allocateDIO";
|
2015-11-01 09:11:52 -08:00
|
|
|
DIOJNI_LOG(logDEBUG) << "Port Ptr = " << (void*)id;
|
|
|
|
|
int32_t status = 0;
|
|
|
|
|
jboolean returnValue = allocateDIO((void*)id, value, &status);
|
|
|
|
|
DIOJNI_LOG(logDEBUG) << "Status = " << status;
|
2014-01-06 09:27:51 -05:00
|
|
|
DIOJNI_LOG(logDEBUG) << "allocateDIOResult = " << (jint)returnValue;
|
2015-11-01 09:11:52 -08:00
|
|
|
CheckStatus(env, status);
|
|
|
|
|
return returnValue;
|
2014-01-06 09:27:51 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/*
|
|
|
|
|
* Class: edu_wpi_first_wpilibj_hal_DIOJNI
|
|
|
|
|
* Method: freeDIO
|
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_DIOJNI_freeDIO
|
2015-11-01 09:11:52 -08:00
|
|
|
(JNIEnv * env, jclass, jlong id)
|
2014-01-06 09:27:51 -05:00
|
|
|
{
|
|
|
|
|
DIOJNI_LOG(logDEBUG) << "Calling DIOJNI freeDIO";
|
2015-11-01 09:11:52 -08:00
|
|
|
DIOJNI_LOG(logDEBUG) << "Port Ptr = " << (void*)id;
|
|
|
|
|
int32_t status = 0;
|
|
|
|
|
freeDIO((void*)id, &status);
|
|
|
|
|
DIOJNI_LOG(logDEBUG) << "Status = " << status;
|
|
|
|
|
CheckStatus(env, status);
|
2014-01-06 09:27:51 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/*
|
|
|
|
|
* Class: edu_wpi_first_wpilibj_hal_DIOJNI
|
|
|
|
|
* Method: setDIO
|
2015-11-01 09:11:52 -08:00
|
|
|
* Signature: (JS)V
|
2014-01-06 09:27:51 -05:00
|
|
|
*/
|
|
|
|
|
JNIEXPORT void JNICALL Java_edu_wpi_first_wpilibj_hal_DIOJNI_setDIO
|
2015-11-01 09:11:52 -08:00
|
|
|
(JNIEnv *env, jclass, jlong id, jshort value)
|
2014-01-06 09:27:51 -05:00
|
|
|
{
|
|
|
|
|
//DIOJNI_LOG(logDEBUG) << "Calling DIOJNI setDIO";
|
2015-11-01 09:11:52 -08:00
|
|
|
//DIOJNI_LOG(logDEBUG) << "Port Ptr = " << (void*)id;
|
2014-01-06 09:27:51 -05:00
|
|
|
//DIOJNI_LOG(logDEBUG) << "Value = " << value;
|
2015-11-01 09:11:52 -08:00
|
|
|
int32_t status = 0;
|
|
|
|
|
setDIO((void*)id, value, &status);
|
|
|
|
|
//DIOJNI_LOG(logDEBUG) << "Status = " << status;
|
|
|
|
|
CheckStatus(env, status);
|
2014-01-06 09:27:51 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/*
|
|
|
|
|
* Class: edu_wpi_first_wpilibj_hal_DIOJNI
|
|
|
|
|
* Method: getDIO
|
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_DIOJNI_getDIO
|
|
|
|
|
(JNIEnv * env, jclass, jlong id)
|
2014-01-06 09:27:51 -05:00
|
|
|
{
|
|
|
|
|
//DIOJNI_LOG(logDEBUG) << "Calling DIOJNI getDIO";
|
2015-11-01 09:11:52 -08:00
|
|
|
//DIOJNI_LOG(logDEBUG) << "Port Ptr = " << (void*)id;
|
|
|
|
|
int32_t status = 0;
|
|
|
|
|
jboolean returnValue = getDIO((void*)id, &status);
|
|
|
|
|
//DIOJNI_LOG(logDEBUG) << "Status = " << status;
|
2014-01-06 09:27:51 -05:00
|
|
|
//DIOJNI_LOG(logDEBUG) << "getDIOResult = " << (jint)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_DIOJNI
|
|
|
|
|
* Method: getDIODirection
|
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_DIOJNI_getDIODirection
|
|
|
|
|
(JNIEnv *env, jclass, jlong id)
|
2014-01-06 09:27:51 -05:00
|
|
|
{
|
2015-01-11 14:29:03 -05:00
|
|
|
DIOJNI_LOG(logDEBUG) << "Calling DIOJNI getDIODirection (RR upd)";
|
2015-11-01 09:11:52 -08:00
|
|
|
//DIOJNI_LOG(logDEBUG) << "Port Ptr = " << (void*)id;
|
|
|
|
|
int32_t status = 0;
|
|
|
|
|
jboolean returnValue = getDIODirection((void*)id, &status);
|
|
|
|
|
//DIOJNI_LOG(logDEBUG) << "Status = " << status;
|
|
|
|
|
DIOJNI_LOG(logDEBUG) << "getDIODirectionResult = " << (jint)returnValue;
|
|
|
|
|
CheckStatus(env, status);
|
2015-01-11 14:29:03 -05:00
|
|
|
return returnValue;
|
2014-01-06 09:27:51 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/*
|
|
|
|
|
* Class: edu_wpi_first_wpilibj_hal_DIOJNI
|
|
|
|
|
* Method: pulse
|
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_DIOJNI_pulse
|
2015-11-01 09:11:52 -08:00
|
|
|
(JNIEnv *env, jclass, jlong id, jdouble value)
|
2014-01-06 09:27:51 -05:00
|
|
|
{
|
2015-01-11 14:29:03 -05:00
|
|
|
DIOJNI_LOG(logDEBUG) << "Calling DIOJNI pulse (RR upd)";
|
2015-11-01 09:11:52 -08:00
|
|
|
//DIOJNI_LOG(logDEBUG) << "Port Ptr = " << (void*)id;
|
2015-01-11 14:29:03 -05:00
|
|
|
//DIOJNI_LOG(logDEBUG) << "Value = " << value;
|
2015-11-01 09:11:52 -08:00
|
|
|
int32_t status = 0;
|
|
|
|
|
pulse((void*)id, value, &status);
|
|
|
|
|
DIOJNI_LOG(logDEBUG) << "Did it work? Status = " << status;
|
|
|
|
|
CheckStatus(env, status);
|
2014-01-06 09:27:51 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/*
|
|
|
|
|
* Class: edu_wpi_first_wpilibj_hal_DIOJNI
|
|
|
|
|
* Method: isPulsing
|
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_DIOJNI_isPulsing
|
|
|
|
|
(JNIEnv *env, jclass, jlong id)
|
2014-01-06 09:27:51 -05:00
|
|
|
{
|
2015-01-11 14:29:03 -05:00
|
|
|
DIOJNI_LOG(logDEBUG) << "Calling DIOJNI isPulsing (RR upd)";
|
2015-11-01 09:11:52 -08:00
|
|
|
//DIOJNI_LOG(logDEBUG) << "Port Ptr = " << (void*)id;
|
|
|
|
|
int32_t status = 0;
|
|
|
|
|
jboolean returnValue = isPulsing((void*)id, &status);
|
|
|
|
|
//DIOJNI_LOG(logDEBUG) << "Status = " << status;
|
|
|
|
|
DIOJNI_LOG(logDEBUG) << "isPulsingResult = " << (jint)returnValue;
|
|
|
|
|
CheckStatus(env, status);
|
2015-01-11 14:29:03 -05:00
|
|
|
return returnValue;
|
|
|
|
|
|
2014-01-06 09:27:51 -05:00
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/*
|
|
|
|
|
* Class: edu_wpi_first_wpilibj_hal_DIOJNI
|
|
|
|
|
* Method: isAnyPulsing
|
2015-11-01 09:11:52 -08:00
|
|
|
* Signature: ()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_DIOJNI_isAnyPulsing
|
|
|
|
|
(JNIEnv *env, jclass)
|
2014-01-06 09:27:51 -05:00
|
|
|
{
|
2015-01-11 14:29:03 -05:00
|
|
|
DIOJNI_LOG(logDEBUG) << "Calling DIOJNI isAnyPulsing (RR upd)";
|
2015-11-01 09:11:52 -08:00
|
|
|
int32_t status = 0;
|
|
|
|
|
jboolean returnValue = isAnyPulsing( &status );
|
|
|
|
|
//DIOJNI_LOG(logDEBUG) << "Status = " << status;
|
|
|
|
|
DIOJNI_LOG(logDEBUG) << "isAnyPulsingResult = " << (jint)returnValue;
|
|
|
|
|
CheckStatus(env, status);
|
2015-01-11 14:29:03 -05:00
|
|
|
return returnValue;
|
2014-01-06 09:27:51 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/*
|
|
|
|
|
* Class: edu_wpi_first_wpilibj_hal_DIOJNI
|
|
|
|
|
* Method: getLoopTiming
|
2015-11-01 09:11:52 -08:00
|
|
|
* Signature: ()S
|
2014-01-06 09:27:51 -05:00
|
|
|
*/
|
|
|
|
|
JNIEXPORT jshort JNICALL Java_edu_wpi_first_wpilibj_hal_DIOJNI_getLoopTiming
|
2015-11-01 09:11:52 -08:00
|
|
|
(JNIEnv * env, jclass)
|
2014-01-06 09:27:51 -05:00
|
|
|
{
|
|
|
|
|
DIOJNI_LOG(logDEBUG) << "Calling DIOJNI getLoopTimeing";
|
2015-11-01 09:11:52 -08:00
|
|
|
int32_t status = 0;
|
|
|
|
|
jshort returnValue = getLoopTiming( &status );
|
|
|
|
|
DIOJNI_LOG(logDEBUG) << "Status = " << status;
|
2014-01-06 09:27:51 -05:00
|
|
|
DIOJNI_LOG(logDEBUG) << "LoopTiming = " << returnValue;
|
2015-11-01 09:11:52 -08:00
|
|
|
CheckStatus(env, status);
|
2014-01-06 09:27:51 -05:00
|
|
|
return returnValue;
|
|
|
|
|
|
|
|
|
|
}
|
2015-11-01 09:11:52 -08:00
|
|
|
|
|
|
|
|
} // extern "C"
|