2016-01-02 03:02:34 -08:00
|
|
|
/*----------------------------------------------------------------------------*/
|
2018-05-13 17:09:56 -07:00
|
|
|
/* Copyright (c) 2016-2018 FIRST. All Rights Reserved. */
|
2016-01-02 03:02:34 -08:00
|
|
|
/* 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. */
|
|
|
|
|
/*----------------------------------------------------------------------------*/
|
|
|
|
|
|
2016-05-20 17:30:37 -07:00
|
|
|
#include <jni.h>
|
2014-01-06 09:27:51 -05:00
|
|
|
|
2018-05-13 17:09:56 -07:00
|
|
|
#include <cassert>
|
2014-01-06 09:27:51 -05:00
|
|
|
|
2018-05-13 17:09:56 -07:00
|
|
|
#include "HALUtil.h"
|
|
|
|
|
#include "edu_wpi_first_wpilibj_hal_RelayJNI.h"
|
2018-07-20 00:03:45 -07:00
|
|
|
#include "hal/Ports.h"
|
|
|
|
|
#include "hal/Relay.h"
|
|
|
|
|
#include "hal/cpp/Log.h"
|
|
|
|
|
#include "hal/handles/HandlesInternal.h"
|
2014-01-06 09:27:51 -05:00
|
|
|
|
2016-10-31 23:04:49 -07:00
|
|
|
using namespace frc;
|
|
|
|
|
|
2014-01-06 09:27:51 -05:00
|
|
|
// set the logging level
|
2014-05-30 10:08:29 -04:00
|
|
|
TLogLevel relayJNILogLevel = logWARNING;
|
2014-01-06 09:27:51 -05:00
|
|
|
|
2016-05-20 17:30:37 -07:00
|
|
|
#define RELAYJNI_LOG(level) \
|
|
|
|
|
if (level > relayJNILogLevel) \
|
|
|
|
|
; \
|
|
|
|
|
else \
|
2018-05-13 17:09:56 -07:00
|
|
|
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_RelayJNI
|
2016-06-29 18:58:14 -07:00
|
|
|
* Method: initializeRelayPort
|
2018-05-13 17:09:56 -07:00
|
|
|
* Signature: (IZ)I
|
2014-01-06 09:27:51 -05:00
|
|
|
*/
|
2018-05-13 17:09:56 -07:00
|
|
|
JNIEXPORT jint JNICALL
|
|
|
|
|
Java_edu_wpi_first_wpilibj_hal_RelayJNI_initializeRelayPort
|
|
|
|
|
(JNIEnv* env, jclass, jint id, jboolean fwd)
|
|
|
|
|
{
|
2016-06-29 18:58:14 -07:00
|
|
|
RELAYJNI_LOG(logDEBUG) << "Calling RELAYJNI initializeRelayPort";
|
2016-07-09 00:24:26 -07:00
|
|
|
RELAYJNI_LOG(logDEBUG) << "Port Handle = " << (HAL_PortHandle)id;
|
2016-06-29 18:58:14 -07:00
|
|
|
RELAYJNI_LOG(logDEBUG) << "Forward = " << (jint)fwd;
|
2016-05-20 17:30:37 -07:00
|
|
|
int32_t status = 0;
|
2018-05-13 17:09:56 -07:00
|
|
|
HAL_RelayHandle handle = HAL_InitializeRelayPort(
|
|
|
|
|
(HAL_PortHandle)id, static_cast<uint8_t>(fwd), &status);
|
2016-05-20 17:30:37 -07:00
|
|
|
RELAYJNI_LOG(logDEBUG) << "Status = " << status;
|
2016-06-29 18:58:14 -07:00
|
|
|
RELAYJNI_LOG(logDEBUG) << "Relay Handle = " << handle;
|
2016-10-06 11:04:38 -07:00
|
|
|
CheckStatusRange(env, status, 0, HAL_GetNumRelayChannels(),
|
|
|
|
|
hal::getPortHandleChannel((HAL_PortHandle)id));
|
2018-05-13 17:09:56 -07:00
|
|
|
return (jint)handle;
|
2014-01-06 09:27:51 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/*
|
2018-05-13 17:09:56 -07:00
|
|
|
* Class: edu_wpi_first_wpilibj_hal_RelayJNI
|
|
|
|
|
* Method: freeRelayPort
|
|
|
|
|
* Signature: (I)V
|
|
|
|
|
*/
|
|
|
|
|
JNIEXPORT void JNICALL
|
|
|
|
|
Java_edu_wpi_first_wpilibj_hal_RelayJNI_freeRelayPort
|
|
|
|
|
(JNIEnv* env, jclass, jint id)
|
|
|
|
|
{
|
2016-06-29 18:58:14 -07:00
|
|
|
RELAYJNI_LOG(logDEBUG) << "Calling RELAYJNI freeRelayPort";
|
2016-07-09 00:24:26 -07:00
|
|
|
RELAYJNI_LOG(logDEBUG) << "Port Handle = " << (HAL_RelayHandle)id;
|
|
|
|
|
HAL_FreeRelayPort((HAL_RelayHandle)id);
|
2016-06-29 18:58:14 -07:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/*
|
2018-05-13 17:09:56 -07:00
|
|
|
* Class: edu_wpi_first_wpilibj_hal_RelayJNI
|
|
|
|
|
* Method: checkRelayChannel
|
|
|
|
|
* Signature: (I)Z
|
|
|
|
|
*/
|
|
|
|
|
JNIEXPORT jboolean JNICALL
|
|
|
|
|
Java_edu_wpi_first_wpilibj_hal_RelayJNI_checkRelayChannel
|
|
|
|
|
(JNIEnv* env, jclass, jint channel)
|
|
|
|
|
{
|
2016-06-29 18:58:14 -07:00
|
|
|
RELAYJNI_LOG(logDEBUG) << "Calling RELAYJNI checkRelayChannel";
|
|
|
|
|
RELAYJNI_LOG(logDEBUG) << "Channel = " << channel;
|
2018-05-13 17:09:56 -07:00
|
|
|
return (jboolean)HAL_CheckRelayChannel(static_cast<uint8_t>(channel));
|
2014-01-06 09:27:51 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/*
|
|
|
|
|
* Class: edu_wpi_first_wpilibj_hal_RelayJNI
|
2016-06-29 18:58:14 -07:00
|
|
|
* Method: setRelay
|
|
|
|
|
* Signature: (IZ)V
|
2014-01-06 09:27:51 -05:00
|
|
|
*/
|
2018-05-13 17:09:56 -07:00
|
|
|
JNIEXPORT void JNICALL
|
|
|
|
|
Java_edu_wpi_first_wpilibj_hal_RelayJNI_setRelay
|
|
|
|
|
(JNIEnv* env, jclass, jint id, jboolean value)
|
|
|
|
|
{
|
2016-06-29 18:58:14 -07:00
|
|
|
RELAYJNI_LOG(logDEBUG) << "Calling RELAYJNI setRelay";
|
2016-07-09 00:24:26 -07:00
|
|
|
RELAYJNI_LOG(logDEBUG) << "Port Handle = " << (HAL_RelayHandle)id;
|
2016-06-29 18:58:14 -07:00
|
|
|
RELAYJNI_LOG(logDEBUG) << "Flag = " << (jint)value;
|
2016-05-20 17:30:37 -07:00
|
|
|
int32_t status = 0;
|
2016-07-09 00:24:26 -07:00
|
|
|
HAL_SetRelay((HAL_RelayHandle)id, value, &status);
|
2016-05-20 17:30:37 -07:00
|
|
|
RELAYJNI_LOG(logDEBUG) << "Status = " << status;
|
|
|
|
|
CheckStatus(env, status);
|
2014-01-06 09:27:51 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/*
|
|
|
|
|
* Class: edu_wpi_first_wpilibj_hal_RelayJNI
|
2016-06-29 18:58:14 -07:00
|
|
|
* Method: getRelay
|
|
|
|
|
* Signature: (I)Z
|
2014-01-06 09:27:51 -05:00
|
|
|
*/
|
2016-05-20 17:30:37 -07:00
|
|
|
JNIEXPORT jboolean JNICALL
|
2018-05-13 17:09:56 -07:00
|
|
|
Java_edu_wpi_first_wpilibj_hal_RelayJNI_getRelay
|
|
|
|
|
(JNIEnv* env, jclass, jint id)
|
|
|
|
|
{
|
2016-06-29 18:58:14 -07:00
|
|
|
RELAYJNI_LOG(logDEBUG) << "Calling RELAYJNI getRelay";
|
2016-07-09 00:24:26 -07:00
|
|
|
RELAYJNI_LOG(logDEBUG) << "Port Handle = " << (HAL_RelayHandle)id;
|
2016-05-20 17:30:37 -07:00
|
|
|
int32_t status = 0;
|
2016-07-09 00:24:26 -07:00
|
|
|
jboolean returnValue = HAL_GetRelay((HAL_RelayHandle)id, &status);
|
2016-05-20 17:30:37 -07:00
|
|
|
RELAYJNI_LOG(logDEBUG) << "Status = " << status;
|
2016-06-29 18:58:14 -07:00
|
|
|
RELAYJNI_LOG(logDEBUG) << "getRelayResult = " << (jint)returnValue;
|
2016-05-20 17:30:37 -07:00
|
|
|
CheckStatus(env, status);
|
|
|
|
|
return returnValue;
|
2014-01-06 09:27:51 -05:00
|
|
|
}
|
2015-11-01 09:11:52 -08:00
|
|
|
|
|
|
|
|
} // extern "C"
|