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. */
|
|
|
|
|
/*----------------------------------------------------------------------------*/
|
|
|
|
|
|
2014-05-29 14:25:09 -04:00
|
|
|
#include <jni.h>
|
2018-05-13 17:09:56 -07:00
|
|
|
|
2016-12-21 21:55:31 -08:00
|
|
|
#include "HAL/Ports.h"
|
2018-05-13 17:09:56 -07:00
|
|
|
#include "HAL/Solenoid.h"
|
2016-07-14 00:17:29 -07:00
|
|
|
#include "HAL/cpp/Log.h"
|
2018-05-13 17:09:56 -07:00
|
|
|
#include "HAL/handles/HandlesInternal.h"
|
2015-11-01 09:11:52 -08:00
|
|
|
#include "HALUtil.h"
|
2018-05-13 17:09:56 -07:00
|
|
|
#include "edu_wpi_first_wpilibj_hal_SolenoidJNI.h"
|
2015-11-01 09:11:52 -08:00
|
|
|
|
2016-10-31 23:04:49 -07:00
|
|
|
using namespace frc;
|
|
|
|
|
|
2014-05-30 14:04:05 -04:00
|
|
|
TLogLevel solenoidJNILogLevel = logERROR;
|
2014-05-29 14:25:09 -04:00
|
|
|
|
2016-05-20 17:30:37 -07:00
|
|
|
#define SOLENOIDJNI_LOG(level) \
|
|
|
|
|
if (level > solenoidJNILogLevel) \
|
|
|
|
|
; \
|
|
|
|
|
else \
|
2018-05-13 17:09:56 -07:00
|
|
|
Log().Get(level)
|
2014-05-29 14:25:09 -04:00
|
|
|
|
2015-11-01 09:11:52 -08:00
|
|
|
extern "C" {
|
2014-05-29 14:25:09 -04:00
|
|
|
|
|
|
|
|
/*
|
|
|
|
|
* Class: edu_wpi_first_wpilibj_hal_SolenoidJNI
|
|
|
|
|
* Method: initializeSolenoidPort
|
2016-07-02 09:24:54 -07:00
|
|
|
* Signature: (I)I
|
2014-05-29 14:25:09 -04:00
|
|
|
*/
|
2016-07-02 09:24:54 -07:00
|
|
|
JNIEXPORT jint JNICALL
|
2018-05-13 17:09:56 -07:00
|
|
|
Java_edu_wpi_first_wpilibj_hal_SolenoidJNI_initializeSolenoidPort
|
|
|
|
|
(JNIEnv* env, jclass, jint id)
|
|
|
|
|
{
|
2016-05-20 17:30:37 -07:00
|
|
|
SOLENOIDJNI_LOG(logDEBUG) << "Calling SolenoidJNI initializeSolenoidPort";
|
|
|
|
|
|
2016-07-13 20:29:28 -07:00
|
|
|
SOLENOIDJNI_LOG(logDEBUG) << "Port Handle = " << (HAL_PortHandle)id;
|
2016-05-20 17:30:37 -07:00
|
|
|
|
|
|
|
|
int32_t status = 0;
|
2016-07-09 00:24:26 -07:00
|
|
|
HAL_SolenoidHandle handle =
|
2016-07-13 20:29:28 -07:00
|
|
|
HAL_InitializeSolenoidPort((HAL_PortHandle)id, &status);
|
2016-05-20 17:30:37 -07:00
|
|
|
|
|
|
|
|
SOLENOIDJNI_LOG(logDEBUG) << "Status = " << status;
|
2016-07-02 09:24:54 -07:00
|
|
|
SOLENOIDJNI_LOG(logDEBUG) << "Solenoid Port Handle = " << handle;
|
2016-05-20 17:30:37 -07:00
|
|
|
|
2016-08-12 13:45:28 -07:00
|
|
|
// Use solenoid channels, as we have to pick one.
|
2016-10-06 11:04:38 -07:00
|
|
|
CheckStatusRange(env, status, 0, HAL_GetNumSolenoidChannels(),
|
2017-08-07 17:36:34 -07:00
|
|
|
hal::getPortHandleChannel((HAL_PortHandle)id));
|
2016-07-02 09:24:54 -07:00
|
|
|
return (jint)handle;
|
2014-05-29 14:25:09 -04:00
|
|
|
}
|
|
|
|
|
|
2016-07-20 22:47:29 -07:00
|
|
|
/*
|
|
|
|
|
* Class: edu_wpi_first_wpilibj_hal_SolenoidJNI
|
|
|
|
|
* Method: checkSolenoidChannel
|
2018-05-13 17:09:56 -07:00
|
|
|
* Signature: (I)Z
|
|
|
|
|
*/
|
|
|
|
|
JNIEXPORT jboolean JNICALL
|
|
|
|
|
Java_edu_wpi_first_wpilibj_hal_SolenoidJNI_checkSolenoidChannel
|
|
|
|
|
(JNIEnv* env, jclass, jint channel)
|
|
|
|
|
{
|
2016-07-20 22:47:29 -07:00
|
|
|
SOLENOIDJNI_LOG(logDEBUG) << "Calling SolenoidJNI checkSolenoidChannel";
|
|
|
|
|
SOLENOIDJNI_LOG(logDEBUG) << "Channel = " << channel;
|
|
|
|
|
return HAL_CheckSolenoidChannel(channel);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/*
|
|
|
|
|
* Class: edu_wpi_first_wpilibj_hal_SolenoidJNI
|
|
|
|
|
* Method: checkSolenoidModule
|
2018-05-13 17:09:56 -07:00
|
|
|
* Signature: (I)Z
|
|
|
|
|
*/
|
|
|
|
|
JNIEXPORT jboolean JNICALL
|
|
|
|
|
Java_edu_wpi_first_wpilibj_hal_SolenoidJNI_checkSolenoidModule
|
|
|
|
|
(JNIEnv* env, jclass, jint module)
|
|
|
|
|
{
|
2016-07-20 22:47:29 -07:00
|
|
|
SOLENOIDJNI_LOG(logDEBUG) << "Calling SolenoidJNI checkSolenoidModule";
|
|
|
|
|
SOLENOIDJNI_LOG(logDEBUG) << "Module = " << module;
|
|
|
|
|
return HAL_CheckSolenoidModule(module);
|
|
|
|
|
}
|
|
|
|
|
|
2015-10-20 10:37:04 -07:00
|
|
|
/*
|
|
|
|
|
* Class: edu_wpi_first_wpilibj_hal_SolenoidJNI
|
|
|
|
|
* Method: freeSolenoidPort
|
2016-07-02 09:24:54 -07:00
|
|
|
* Signature: (I)V
|
2015-10-20 10:37:04 -07:00
|
|
|
*/
|
2016-05-20 17:30:37 -07:00
|
|
|
JNIEXPORT void JNICALL
|
2018-05-13 17:09:56 -07:00
|
|
|
Java_edu_wpi_first_wpilibj_hal_SolenoidJNI_freeSolenoidPort
|
|
|
|
|
(JNIEnv* env, jclass, jint id)
|
|
|
|
|
{
|
2016-05-20 17:30:37 -07:00
|
|
|
SOLENOIDJNI_LOG(logDEBUG) << "Calling SolenoidJNI initializeSolenoidPort";
|
2015-10-20 10:37:04 -07:00
|
|
|
|
2016-07-09 00:24:26 -07:00
|
|
|
SOLENOIDJNI_LOG(logDEBUG) << "Port Handle = " << (HAL_SolenoidHandle)id;
|
|
|
|
|
HAL_FreeSolenoidPort((HAL_SolenoidHandle)id);
|
2015-10-20 10:37:04 -07:00
|
|
|
}
|
|
|
|
|
|
2014-05-29 14:25:09 -04:00
|
|
|
/*
|
|
|
|
|
* Class: edu_wpi_first_wpilibj_hal_SolenoidJNI
|
|
|
|
|
* Method: setSolenoid
|
2016-07-02 09:24:54 -07:00
|
|
|
* Signature: (IZ)V
|
2014-05-29 14:25:09 -04:00
|
|
|
*/
|
2018-05-13 17:09:56 -07:00
|
|
|
JNIEXPORT void JNICALL
|
|
|
|
|
Java_edu_wpi_first_wpilibj_hal_SolenoidJNI_setSolenoid
|
|
|
|
|
(JNIEnv* env, jclass, jint solenoid_port, jboolean value)
|
|
|
|
|
{
|
2016-05-20 17:30:37 -07:00
|
|
|
SOLENOIDJNI_LOG(logDEBUG) << "Calling SolenoidJNI SetSolenoid";
|
|
|
|
|
|
2018-05-13 17:09:56 -07:00
|
|
|
SOLENOIDJNI_LOG(logDEBUG)
|
|
|
|
|
<< "Solenoid Port Handle = " << (HAL_SolenoidHandle)solenoid_port;
|
2016-05-20 17:30:37 -07:00
|
|
|
|
|
|
|
|
int32_t status = 0;
|
2016-07-09 00:24:26 -07:00
|
|
|
HAL_SetSolenoid((HAL_SolenoidHandle)solenoid_port, value, &status);
|
2016-05-20 17:30:37 -07:00
|
|
|
CheckStatus(env, status);
|
2014-05-29 14:25:09 -04:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/*
|
|
|
|
|
* Class: edu_wpi_first_wpilibj_hal_SolenoidJNI
|
|
|
|
|
* Method: getSolenoid
|
2016-07-02 09:24:54 -07:00
|
|
|
* Signature: (I)Z
|
2014-05-29 14:25:09 -04: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_SolenoidJNI_getSolenoid
|
|
|
|
|
(JNIEnv* env, jclass, jint solenoid_port)
|
|
|
|
|
{
|
2016-05-20 17:30:37 -07:00
|
|
|
int32_t status = 0;
|
2016-07-09 00:24:26 -07:00
|
|
|
jboolean val = HAL_GetSolenoid((HAL_SolenoidHandle)solenoid_port, &status);
|
2016-05-20 17:30:37 -07:00
|
|
|
CheckStatus(env, status);
|
|
|
|
|
return val;
|
2014-05-29 14:25:09 -04:00
|
|
|
}
|
2014-12-26 19:40:39 -05:00
|
|
|
|
2015-11-15 10:46:18 -08:00
|
|
|
/*
|
|
|
|
|
* Class: edu_wpi_first_wpilibj_hal_SolenoidJNI
|
|
|
|
|
* Method: getAllSolenoids
|
2017-05-08 21:55:11 -07:00
|
|
|
* Signature: (I)I
|
2015-11-15 10:46:18 -08:00
|
|
|
*/
|
2017-05-08 21:55:11 -07:00
|
|
|
JNIEXPORT jint JNICALL
|
2018-05-13 17:09:56 -07:00
|
|
|
Java_edu_wpi_first_wpilibj_hal_SolenoidJNI_getAllSolenoids
|
|
|
|
|
(JNIEnv* env, jclass, jint module)
|
|
|
|
|
{
|
2016-05-20 17:30:37 -07:00
|
|
|
int32_t status = 0;
|
2017-05-08 21:55:11 -07:00
|
|
|
jint val = HAL_GetAllSolenoids(module, &status);
|
2016-05-20 17:30:37 -07:00
|
|
|
CheckStatus(env, status);
|
|
|
|
|
return val;
|
2015-11-15 10:46:18 -08:00
|
|
|
}
|
|
|
|
|
|
2014-12-26 19:40:39 -05:00
|
|
|
/*
|
|
|
|
|
* Class: edu_wpi_first_wpilibj_hal_SolenoidJNI
|
|
|
|
|
* Method: getPCMSolenoidBlackList
|
2017-05-08 21:55:11 -07:00
|
|
|
* Signature: (I)I
|
2014-12-26 19:40:39 -05:00
|
|
|
*/
|
2016-05-20 17:30:37 -07:00
|
|
|
JNIEXPORT jint JNICALL
|
2018-05-13 17:09:56 -07:00
|
|
|
Java_edu_wpi_first_wpilibj_hal_SolenoidJNI_getPCMSolenoidBlackList
|
|
|
|
|
(JNIEnv* env, jclass, jint module)
|
|
|
|
|
{
|
2016-05-20 17:30:37 -07:00
|
|
|
int32_t status = 0;
|
2016-07-09 00:24:26 -07:00
|
|
|
jint val = HAL_GetPCMSolenoidBlackList(module, &status);
|
2016-05-20 17:30:37 -07:00
|
|
|
CheckStatus(env, status);
|
|
|
|
|
return val;
|
2014-12-26 19:40:39 -05:00
|
|
|
}
|
|
|
|
|
/*
|
|
|
|
|
* Class: edu_wpi_first_wpilibj_hal_SolenoidJNI
|
|
|
|
|
* Method: getPCMSolenoidVoltageStickyFault
|
2017-05-08 21:55:11 -07:00
|
|
|
* Signature: (I)Z
|
2014-12-26 19:40:39 -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_SolenoidJNI_getPCMSolenoidVoltageStickyFault
|
|
|
|
|
(JNIEnv* env, jclass, jint module)
|
|
|
|
|
{
|
2016-05-20 17:30:37 -07:00
|
|
|
int32_t status = 0;
|
2016-07-09 00:24:26 -07:00
|
|
|
bool val = HAL_GetPCMSolenoidVoltageStickyFault(module, &status);
|
2016-05-20 17:30:37 -07:00
|
|
|
CheckStatus(env, status);
|
|
|
|
|
return val;
|
2014-12-26 19:40:39 -05:00
|
|
|
}
|
|
|
|
|
/*
|
|
|
|
|
* Class: edu_wpi_first_wpilibj_hal_SolenoidJNI
|
|
|
|
|
* Method: getPCMSolenoidVoltageFault
|
2017-05-08 21:55:11 -07:00
|
|
|
* Signature: (I)Z
|
2014-12-26 19:40:39 -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_SolenoidJNI_getPCMSolenoidVoltageFault
|
|
|
|
|
(JNIEnv* env, jclass, jint module)
|
|
|
|
|
{
|
2016-05-20 17:30:37 -07:00
|
|
|
int32_t status = 0;
|
2016-07-09 00:24:26 -07:00
|
|
|
bool val = HAL_GetPCMSolenoidVoltageFault(module, &status);
|
2016-05-20 17:30:37 -07:00
|
|
|
CheckStatus(env, status);
|
|
|
|
|
return val;
|
2014-12-26 19:40:39 -05:00
|
|
|
}
|
|
|
|
|
/*
|
|
|
|
|
* Class: edu_wpi_first_wpilibj_hal_SolenoidJNI
|
|
|
|
|
* Method: clearAllPCMStickyFaults
|
2017-05-08 21:55:11 -07:00
|
|
|
* Signature: (I)V
|
2014-12-26 19:40:39 -05:00
|
|
|
*/
|
2016-05-20 17:30:37 -07:00
|
|
|
JNIEXPORT void JNICALL
|
2018-05-13 17:09:56 -07:00
|
|
|
Java_edu_wpi_first_wpilibj_hal_SolenoidJNI_clearAllPCMStickyFaults
|
|
|
|
|
(JNIEnv* env, jclass, jint module)
|
|
|
|
|
{
|
2016-05-20 17:30:37 -07:00
|
|
|
int32_t status = 0;
|
2016-07-09 01:12:37 -07:00
|
|
|
HAL_ClearAllPCMStickyFaults(module, &status);
|
2016-05-20 17:30:37 -07:00
|
|
|
CheckStatus(env, status);
|
2014-12-26 19:40:39 -05:00
|
|
|
}
|
2015-11-01 09:11:52 -08:00
|
|
|
|
2017-11-26 12:55:21 -08:00
|
|
|
/*
|
|
|
|
|
* Class: edu_wpi_first_wpilibj_hal_SolenoidJNI
|
|
|
|
|
* Method: setOneShotDuration
|
|
|
|
|
* Signature: (IJ)V
|
|
|
|
|
*/
|
2018-05-13 17:09:56 -07:00
|
|
|
JNIEXPORT void JNICALL
|
|
|
|
|
Java_edu_wpi_first_wpilibj_hal_SolenoidJNI_setOneShotDuration
|
|
|
|
|
(JNIEnv* env, jclass, jint solenoid_port, jlong durationMS)
|
2017-11-26 12:55:21 -08:00
|
|
|
{
|
|
|
|
|
SOLENOIDJNI_LOG(logDEBUG) << "Calling SolenoidJNI SetOneShotDuration";
|
|
|
|
|
|
2018-05-13 17:09:56 -07:00
|
|
|
SOLENOIDJNI_LOG(logDEBUG)
|
|
|
|
|
<< "Solenoid Port Handle = " << (HAL_SolenoidHandle)solenoid_port;
|
2017-11-26 12:55:21 -08:00
|
|
|
SOLENOIDJNI_LOG(logDEBUG) << "Duration (MS) = " << durationMS;
|
|
|
|
|
|
|
|
|
|
int32_t status = 0;
|
2018-05-13 17:09:56 -07:00
|
|
|
HAL_SetOneShotDuration((HAL_SolenoidHandle)solenoid_port, durationMS,
|
|
|
|
|
&status);
|
2017-11-26 12:55:21 -08:00
|
|
|
CheckStatus(env, status);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/*
|
|
|
|
|
* Class: edu_wpi_first_wpilibj_hal_SolenoidJNI
|
|
|
|
|
* Method: fireOneShot
|
|
|
|
|
* Signature: (I)V
|
|
|
|
|
*/
|
2018-05-13 17:09:56 -07:00
|
|
|
JNIEXPORT void JNICALL
|
|
|
|
|
Java_edu_wpi_first_wpilibj_hal_SolenoidJNI_fireOneShot
|
|
|
|
|
(JNIEnv* env, jclass, jint solenoid_port)
|
2017-11-26 12:55:21 -08:00
|
|
|
{
|
|
|
|
|
SOLENOIDJNI_LOG(logDEBUG) << "Calling SolenoidJNI fireOneShot";
|
|
|
|
|
|
2018-05-13 17:09:56 -07:00
|
|
|
SOLENOIDJNI_LOG(logDEBUG)
|
|
|
|
|
<< "Solenoid Port Handle = " << (HAL_SolenoidHandle)solenoid_port;
|
2017-11-26 12:55:21 -08:00
|
|
|
|
|
|
|
|
int32_t status = 0;
|
|
|
|
|
HAL_FireOneShot((HAL_SolenoidHandle)solenoid_port, &status);
|
|
|
|
|
CheckStatus(env, status);
|
|
|
|
|
}
|
2015-11-01 09:11:52 -08:00
|
|
|
} // extern "C"
|