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
|
|
|
|
2016-05-24 00:58:10 -07:00
|
|
|
#include "HAL/DIO.h"
|
|
|
|
|
#include "HAL/PWM.h"
|
2016-07-13 20:29:28 -07:00
|
|
|
#include "HAL/Ports.h"
|
2018-05-13 17:09:56 -07:00
|
|
|
#include "HAL/cpp/Log.h"
|
2016-07-13 20:29:28 -07:00
|
|
|
#include "HAL/handles/HandlesInternal.h"
|
2018-05-13 17:09:56 -07:00
|
|
|
#include "HALUtil.h"
|
|
|
|
|
#include "edu_wpi_first_wpilibj_hal_DIOJNI.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 dioJNILogLevel = logWARNING;
|
2014-01-06 09:27:51 -05:00
|
|
|
|
2016-05-20 17:30:37 -07:00
|
|
|
#define DIOJNI_LOG(level) \
|
|
|
|
|
if (level > dioJNILogLevel) \
|
|
|
|
|
; \
|
|
|
|
|
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_DIOJNI
|
2016-06-30 21:39:09 -07:00
|
|
|
* Method: initializeDIOPort
|
2018-05-13 17:09:56 -07:00
|
|
|
* Signature: (IZ)I
|
2014-01-06 09:27:51 -05:00
|
|
|
*/
|
2016-06-30 21:39:09 -07:00
|
|
|
JNIEXPORT jint JNICALL
|
2018-05-13 17:09:56 -07:00
|
|
|
Java_edu_wpi_first_wpilibj_hal_DIOJNI_initializeDIOPort
|
|
|
|
|
(JNIEnv* env, jclass, jint id, jboolean input)
|
|
|
|
|
{
|
2016-06-30 21:39:09 -07:00
|
|
|
DIOJNI_LOG(logDEBUG) << "Calling DIOJNI initializeDIOPort";
|
2016-07-09 00:24:26 -07:00
|
|
|
DIOJNI_LOG(logDEBUG) << "Port Handle = " << (HAL_PortHandle)id;
|
2016-06-30 21:39:09 -07:00
|
|
|
DIOJNI_LOG(logDEBUG) << "Input = " << (jint)input;
|
2016-05-20 17:30:37 -07:00
|
|
|
int32_t status = 0;
|
2018-05-13 17:09:56 -07:00
|
|
|
auto dio = HAL_InitializeDIOPort((HAL_PortHandle)id,
|
|
|
|
|
static_cast<uint8_t>(input), &status);
|
2016-05-20 17:30:37 -07:00
|
|
|
DIOJNI_LOG(logDEBUG) << "Status = " << status;
|
2016-06-30 21:39:09 -07:00
|
|
|
DIOJNI_LOG(logDEBUG) << "DIO Handle = " << dio;
|
2016-10-06 11:04:38 -07:00
|
|
|
CheckStatusRange(env, status, 0, HAL_GetNumDigitalChannels(),
|
|
|
|
|
hal::getPortHandleChannel((HAL_PortHandle)id));
|
2016-06-30 21:39:09 -07:00
|
|
|
return (jint)dio;
|
2014-01-06 09:27:51 -05:00
|
|
|
}
|
|
|
|
|
|
2015-10-20 10:37:04 -07:00
|
|
|
/*
|
2016-07-20 22:47:29 -07:00
|
|
|
* Class: edu_wpi_first_wpilibj_hal_DIOJNI
|
|
|
|
|
* Method: checkDIOChannel
|
2018-05-13 17:09:56 -07:00
|
|
|
* Signature: (I)Z
|
|
|
|
|
*/
|
|
|
|
|
JNIEXPORT jboolean JNICALL
|
|
|
|
|
Java_edu_wpi_first_wpilibj_hal_DIOJNI_checkDIOChannel
|
|
|
|
|
(JNIEnv* env, jclass, jint channel)
|
|
|
|
|
{
|
2016-07-20 22:47:29 -07:00
|
|
|
DIOJNI_LOG(logDEBUG) << "Calling DIOJNI checkDIOChannel";
|
|
|
|
|
DIOJNI_LOG(logDEBUG) << "Channel = " << channel;
|
|
|
|
|
return HAL_CheckDIOChannel(channel);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/*
|
|
|
|
|
* Class: edu_wpi_first_wpilibj_hal_DIOJNI
|
|
|
|
|
* Method: freeDIOPort
|
2018-05-13 17:09:56 -07:00
|
|
|
* Signature: (I)V
|
|
|
|
|
*/
|
|
|
|
|
JNIEXPORT void JNICALL
|
|
|
|
|
Java_edu_wpi_first_wpilibj_hal_DIOJNI_freeDIOPort
|
|
|
|
|
(JNIEnv* env, jclass, jint id)
|
|
|
|
|
{
|
2016-06-30 21:39:09 -07:00
|
|
|
DIOJNI_LOG(logDEBUG) << "Calling DIOJNI freeDIOPort";
|
2016-07-09 00:24:26 -07:00
|
|
|
DIOJNI_LOG(logDEBUG) << "Port Handle = " << (HAL_DigitalHandle)id;
|
|
|
|
|
HAL_FreeDIOPort((HAL_DigitalHandle)id);
|
2014-01-06 09:27:51 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/*
|
|
|
|
|
* Class: edu_wpi_first_wpilibj_hal_DIOJNI
|
|
|
|
|
* Method: setDIO
|
2016-06-30 21:39:09 -07:00
|
|
|
* Signature: (IS)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_DIOJNI_setDIO
|
|
|
|
|
(JNIEnv* env, jclass, jint id, jshort value)
|
|
|
|
|
{
|
2016-05-20 17:30:37 -07:00
|
|
|
// DIOJNI_LOG(logDEBUG) << "Calling DIOJNI setDIO";
|
2016-07-09 00:24:26 -07:00
|
|
|
// DIOJNI_LOG(logDEBUG) << "Port Handle = " << (HAL_DigitalHandle)id;
|
2016-05-20 17:30:37 -07:00
|
|
|
// DIOJNI_LOG(logDEBUG) << "Value = " << value;
|
|
|
|
|
int32_t status = 0;
|
2016-07-09 00:24:26 -07:00
|
|
|
HAL_SetDIO((HAL_DigitalHandle)id, value, &status);
|
2016-05-20 17:30:37 -07:00
|
|
|
// DIOJNI_LOG(logDEBUG) << "Status = " << status;
|
|
|
|
|
CheckStatus(env, status);
|
2018-02-12 16:05:10 -08:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/*
|
|
|
|
|
* Class: edu_wpi_first_wpilibj_hal_DIOJNI
|
|
|
|
|
* Method: setDIODirection
|
|
|
|
|
* Signature: (IZ)V
|
|
|
|
|
*/
|
2018-05-13 17:09:56 -07:00
|
|
|
JNIEXPORT void JNICALL
|
|
|
|
|
Java_edu_wpi_first_wpilibj_hal_DIOJNI_setDIODirection
|
|
|
|
|
(JNIEnv* env, jclass, jint id, jboolean input)
|
|
|
|
|
{
|
2018-02-12 16:05:10 -08:00
|
|
|
// DIOJNI_LOG(logDEBUG) << "Calling DIOJNI setDIO";
|
|
|
|
|
// DIOJNI_LOG(logDEBUG) << "Port Handle = " << (HAL_DigitalHandle)id;
|
|
|
|
|
// DIOJNI_LOG(logDEBUG) << "IsInput = " << input;
|
|
|
|
|
int32_t status = 0;
|
|
|
|
|
HAL_SetDIODirection((HAL_DigitalHandle)id, input, &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
|
2018-05-13 17:09:56 -07:00
|
|
|
* 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_DIOJNI_getDIO
|
|
|
|
|
(JNIEnv* env, jclass, jint id)
|
|
|
|
|
{
|
2016-05-20 17:30:37 -07:00
|
|
|
// DIOJNI_LOG(logDEBUG) << "Calling DIOJNI getDIO";
|
2016-07-09 00:24:26 -07:00
|
|
|
// DIOJNI_LOG(logDEBUG) << "Port Handle = " << (HAL_DigitalHandle)id;
|
2016-05-20 17:30:37 -07:00
|
|
|
int32_t status = 0;
|
2016-07-09 00:24:26 -07:00
|
|
|
jboolean returnValue = HAL_GetDIO((HAL_DigitalHandle)id, &status);
|
2016-05-20 17:30:37 -07:00
|
|
|
// DIOJNI_LOG(logDEBUG) << "Status = " << status;
|
|
|
|
|
// DIOJNI_LOG(logDEBUG) << "getDIOResult = " << (jint)returnValue;
|
|
|
|
|
CheckStatus(env, status);
|
|
|
|
|
return returnValue;
|
2014-01-06 09:27:51 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/*
|
|
|
|
|
* Class: edu_wpi_first_wpilibj_hal_DIOJNI
|
|
|
|
|
* Method: getDIODirection
|
2018-05-13 17:09:56 -07:00
|
|
|
* 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_DIOJNI_getDIODirection
|
|
|
|
|
(JNIEnv* env, jclass, jint id)
|
|
|
|
|
{
|
2016-05-20 17:30:37 -07:00
|
|
|
DIOJNI_LOG(logDEBUG) << "Calling DIOJNI getDIODirection (RR upd)";
|
2016-07-09 00:24:26 -07:00
|
|
|
// DIOJNI_LOG(logDEBUG) << "Port Handle = " << (HAL_DigitalHandle)id;
|
2016-05-20 17:30:37 -07:00
|
|
|
int32_t status = 0;
|
2016-07-09 00:24:26 -07:00
|
|
|
jboolean returnValue = HAL_GetDIODirection((HAL_DigitalHandle)id, &status);
|
2016-05-20 17:30:37 -07:00
|
|
|
// DIOJNI_LOG(logDEBUG) << "Status = " << status;
|
|
|
|
|
DIOJNI_LOG(logDEBUG) << "getDIODirectionResult = " << (jint)returnValue;
|
|
|
|
|
CheckStatus(env, status);
|
|
|
|
|
return returnValue;
|
2014-01-06 09:27:51 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/*
|
|
|
|
|
* Class: edu_wpi_first_wpilibj_hal_DIOJNI
|
|
|
|
|
* Method: pulse
|
2018-05-13 17:09:56 -07:00
|
|
|
* Signature: (ID)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_DIOJNI_pulse
|
|
|
|
|
(JNIEnv* env, jclass, jint id, jdouble value)
|
|
|
|
|
{
|
2016-05-20 17:30:37 -07:00
|
|
|
DIOJNI_LOG(logDEBUG) << "Calling DIOJNI pulse (RR upd)";
|
2016-07-09 00:24:26 -07:00
|
|
|
// DIOJNI_LOG(logDEBUG) << "Port Handle = " << (HAL_DigitalHandle)id;
|
2016-05-20 17:30:37 -07:00
|
|
|
// DIOJNI_LOG(logDEBUG) << "Value = " << value;
|
|
|
|
|
int32_t status = 0;
|
2016-07-09 00:24:26 -07:00
|
|
|
HAL_Pulse((HAL_DigitalHandle)id, value, &status);
|
2016-05-20 17:30:37 -07:00
|
|
|
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
|
2018-05-13 17:09:56 -07:00
|
|
|
* 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_DIOJNI_isPulsing
|
|
|
|
|
(JNIEnv* env, jclass, jint id)
|
|
|
|
|
{
|
2016-05-20 17:30:37 -07:00
|
|
|
DIOJNI_LOG(logDEBUG) << "Calling DIOJNI isPulsing (RR upd)";
|
2016-07-09 00:24:26 -07:00
|
|
|
// DIOJNI_LOG(logDEBUG) << "Port Handle = " << (HAL_DigitalHandle)id;
|
2016-05-20 17:30:37 -07:00
|
|
|
int32_t status = 0;
|
2016-07-09 00:24:26 -07:00
|
|
|
jboolean returnValue = HAL_IsPulsing((HAL_DigitalHandle)id, &status);
|
2016-05-20 17:30:37 -07:00
|
|
|
// DIOJNI_LOG(logDEBUG) << "Status = " << status;
|
|
|
|
|
DIOJNI_LOG(logDEBUG) << "isPulsingResult = " << (jint)returnValue;
|
|
|
|
|
CheckStatus(env, status);
|
|
|
|
|
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
|
|
|
*/
|
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_DIOJNI_isAnyPulsing
|
|
|
|
|
(JNIEnv* env, jclass)
|
|
|
|
|
{
|
2016-05-20 17:30:37 -07:00
|
|
|
DIOJNI_LOG(logDEBUG) << "Calling DIOJNI isAnyPulsing (RR upd)";
|
|
|
|
|
int32_t status = 0;
|
2016-07-09 00:24:26 -07:00
|
|
|
jboolean returnValue = HAL_IsAnyPulsing(&status);
|
2016-05-20 17:30:37 -07:00
|
|
|
// DIOJNI_LOG(logDEBUG) << "Status = " << status;
|
|
|
|
|
DIOJNI_LOG(logDEBUG) << "isAnyPulsingResult = " << (jint)returnValue;
|
|
|
|
|
CheckStatus(env, status);
|
|
|
|
|
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
|
|
|
*/
|
2016-05-20 17:30:37 -07:00
|
|
|
JNIEXPORT jshort JNICALL
|
2018-05-13 17:09:56 -07:00
|
|
|
Java_edu_wpi_first_wpilibj_hal_DIOJNI_getLoopTiming
|
|
|
|
|
(JNIEnv* env, jclass)
|
|
|
|
|
{
|
2016-05-20 17:30:37 -07:00
|
|
|
DIOJNI_LOG(logDEBUG) << "Calling DIOJNI getLoopTimeing";
|
|
|
|
|
int32_t status = 0;
|
2017-10-27 19:44:40 -07:00
|
|
|
jshort returnValue = HAL_GetPWMLoopTiming(&status);
|
2016-05-20 17:30:37 -07:00
|
|
|
DIOJNI_LOG(logDEBUG) << "Status = " << status;
|
|
|
|
|
DIOJNI_LOG(logDEBUG) << "LoopTiming = " << returnValue;
|
|
|
|
|
CheckStatus(env, status);
|
|
|
|
|
return returnValue;
|
2014-01-06 09:27:51 -05:00
|
|
|
}
|
2015-11-01 09:11:52 -08:00
|
|
|
|
2016-06-30 23:43:00 -07:00
|
|
|
/*
|
|
|
|
|
* Class: edu_wpi_first_wpilibj_hal_DIOJNI
|
|
|
|
|
* Method: allocateDigitalPWM
|
|
|
|
|
* Signature: ()I
|
|
|
|
|
*/
|
|
|
|
|
JNIEXPORT jint JNICALL
|
2018-05-13 17:09:56 -07:00
|
|
|
Java_edu_wpi_first_wpilibj_hal_DIOJNI_allocateDigitalPWM
|
|
|
|
|
(JNIEnv* env, jclass)
|
|
|
|
|
{
|
2016-06-30 23:43:00 -07:00
|
|
|
DIOJNI_LOG(logDEBUG) << "Calling DIOJNI allocateDigitalPWM";
|
|
|
|
|
int32_t status = 0;
|
2016-07-09 00:24:26 -07:00
|
|
|
auto pwm = HAL_AllocateDigitalPWM(&status);
|
2016-06-30 23:43:00 -07:00
|
|
|
DIOJNI_LOG(logDEBUG) << "Status = " << status;
|
|
|
|
|
DIOJNI_LOG(logDEBUG) << "PWM Handle = " << pwm;
|
|
|
|
|
CheckStatus(env, status);
|
|
|
|
|
return (jint)pwm;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/*
|
|
|
|
|
* Class: edu_wpi_first_wpilibj_hal_DIOJNI
|
|
|
|
|
* Method: freeDigitalPWM
|
|
|
|
|
* Signature: (I)V
|
|
|
|
|
*/
|
|
|
|
|
JNIEXPORT void JNICALL
|
2018-05-13 17:09:56 -07:00
|
|
|
Java_edu_wpi_first_wpilibj_hal_DIOJNI_freeDigitalPWM
|
|
|
|
|
(JNIEnv* env, jclass, jint id)
|
|
|
|
|
{
|
2016-06-30 23:43:00 -07:00
|
|
|
DIOJNI_LOG(logDEBUG) << "Calling DIOJNI freeDigitalPWM";
|
2016-07-09 00:24:26 -07:00
|
|
|
DIOJNI_LOG(logDEBUG) << "PWM Handle = " << (HAL_DigitalPWMHandle)id;
|
2016-06-30 23:43:00 -07:00
|
|
|
int32_t status = 0;
|
2016-07-09 00:24:26 -07:00
|
|
|
HAL_FreeDigitalPWM((HAL_DigitalPWMHandle)id, &status);
|
2016-06-30 23:43:00 -07:00
|
|
|
DIOJNI_LOG(logDEBUG) << "Status = " << status;
|
|
|
|
|
CheckStatus(env, status);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/*
|
|
|
|
|
* Class: edu_wpi_first_wpilibj_hal_DIOJNI
|
|
|
|
|
* Method: setDigitalPWMRate
|
|
|
|
|
* Signature: (D)V
|
|
|
|
|
*/
|
2018-05-13 17:09:56 -07:00
|
|
|
JNIEXPORT void JNICALL
|
|
|
|
|
Java_edu_wpi_first_wpilibj_hal_DIOJNI_setDigitalPWMRate
|
|
|
|
|
(JNIEnv* env, jclass, jdouble value)
|
|
|
|
|
{
|
2016-06-30 23:43:00 -07:00
|
|
|
DIOJNI_LOG(logDEBUG) << "Calling DIOJNI setDigitalPWMRate";
|
|
|
|
|
DIOJNI_LOG(logDEBUG) << "Rate= " << value;
|
|
|
|
|
int32_t status = 0;
|
2016-07-09 00:24:26 -07:00
|
|
|
HAL_SetDigitalPWMRate(value, &status);
|
2016-06-30 23:43:00 -07:00
|
|
|
DIOJNI_LOG(logDEBUG) << "Status = " << status;
|
|
|
|
|
CheckStatus(env, status);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/*
|
|
|
|
|
* Class: edu_wpi_first_wpilibj_hal_DIOJNI
|
|
|
|
|
* Method: setDigitalPWMDutyCycle
|
|
|
|
|
* Signature: (ID)V
|
|
|
|
|
*/
|
2018-05-13 17:09:56 -07:00
|
|
|
JNIEXPORT void JNICALL
|
|
|
|
|
Java_edu_wpi_first_wpilibj_hal_DIOJNI_setDigitalPWMDutyCycle
|
|
|
|
|
(JNIEnv* env, jclass, jint id, jdouble value)
|
|
|
|
|
{
|
2016-06-30 23:43:00 -07:00
|
|
|
DIOJNI_LOG(logDEBUG) << "Calling DIOJNI setDigitalPWMDutyCycle";
|
2016-07-09 00:24:26 -07:00
|
|
|
DIOJNI_LOG(logDEBUG) << "PWM Handle = " << (HAL_DigitalPWMHandle)id;
|
2016-06-30 23:43:00 -07:00
|
|
|
DIOJNI_LOG(logDEBUG) << "DutyCycle= " << value;
|
|
|
|
|
int32_t status = 0;
|
2016-07-09 00:24:26 -07:00
|
|
|
HAL_SetDigitalPWMDutyCycle((HAL_DigitalPWMHandle)id, value, &status);
|
2016-06-30 23:43:00 -07:00
|
|
|
DIOJNI_LOG(logDEBUG) << "Status = " << status;
|
|
|
|
|
CheckStatus(env, status);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/*
|
|
|
|
|
* Class: edu_wpi_first_wpilibj_hal_DIOJNI
|
|
|
|
|
* Method: setDigitalPWMOutputChannel
|
|
|
|
|
* Signature: (II)V
|
|
|
|
|
*/
|
|
|
|
|
JNIEXPORT void JNICALL
|
2018-05-13 17:09:56 -07:00
|
|
|
Java_edu_wpi_first_wpilibj_hal_DIOJNI_setDigitalPWMOutputChannel
|
|
|
|
|
(JNIEnv* env, jclass, jint id, jint value)
|
|
|
|
|
{
|
2016-06-30 23:43:00 -07:00
|
|
|
DIOJNI_LOG(logDEBUG) << "Calling DIOJNI setDigitalPWMOutputChannel";
|
2016-07-09 00:24:26 -07:00
|
|
|
DIOJNI_LOG(logDEBUG) << "PWM Handle = " << (HAL_DigitalPWMHandle)id;
|
2016-08-12 13:45:28 -07:00
|
|
|
DIOJNI_LOG(logDEBUG) << "Channel= " << value;
|
2016-06-30 23:43:00 -07:00
|
|
|
int32_t status = 0;
|
2018-05-13 17:09:56 -07:00
|
|
|
HAL_SetDigitalPWMOutputChannel((HAL_DigitalPWMHandle)id,
|
|
|
|
|
static_cast<uint32_t>(value), &status);
|
2016-06-30 23:43:00 -07:00
|
|
|
DIOJNI_LOG(logDEBUG) << "Status = " << status;
|
|
|
|
|
CheckStatus(env, status);
|
|
|
|
|
}
|
|
|
|
|
|
2015-11-01 09:11:52 -08:00
|
|
|
} // extern "C"
|