Files
allwpilib/hal/src/main/native/cpp/jni/RelayJNI.cpp

120 lines
3.7 KiB
C++
Raw Normal View History

/*----------------------------------------------------------------------------*/
2018-05-13 17:09:56 -07:00
/* Copyright (c) 2016-2018 FIRST. 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. */
/*----------------------------------------------------------------------------*/
#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"
#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
using namespace frc;
2014-01-06 09:27:51 -05:00
// set the logging level
TLogLevel relayJNILogLevel = logWARNING;
2014-01-06 09:27:51 -05: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
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";
RELAYJNI_LOG(logDEBUG) << "Port Handle = " << (HAL_PortHandle)id;
2016-06-29 18:58:14 -07:00
RELAYJNI_LOG(logDEBUG) << "Forward = " << (jint)fwd;
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);
RELAYJNI_LOG(logDEBUG) << "Status = " << status;
2016-06-29 18:58:14 -07:00
RELAYJNI_LOG(logDEBUG) << "Relay Handle = " << handle;
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";
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";
RELAYJNI_LOG(logDEBUG) << "Port Handle = " << (HAL_RelayHandle)id;
2016-06-29 18:58:14 -07:00
RELAYJNI_LOG(logDEBUG) << "Flag = " << (jint)value;
int32_t status = 0;
HAL_SetRelay((HAL_RelayHandle)id, value, &status);
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
*/
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";
RELAYJNI_LOG(logDEBUG) << "Port Handle = " << (HAL_RelayHandle)id;
int32_t status = 0;
jboolean returnValue = HAL_GetRelay((HAL_RelayHandle)id, &status);
RELAYJNI_LOG(logDEBUG) << "Status = " << status;
2016-06-29 18:58:14 -07:00
RELAYJNI_LOG(logDEBUG) << "getRelayResult = " << (jint)returnValue;
CheckStatus(env, status);
return returnValue;
2014-01-06 09:27:51 -05:00
}
} // extern "C"