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_PWMJNI.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 pwmJNILogLevel = logWARNING;
|
2014-01-06 09:27:51 -05:00
|
|
|
|
|
|
|
|
#define PWMJNI_LOG(level) \
|
|
|
|
|
if (level > pwmJNILogLevel) ; \
|
|
|
|
|
else Log().Get(level)
|
|
|
|
|
|
2015-11-01 09:11:52 -08:00
|
|
|
extern "C" {
|
2014-01-06 09:27:51 -05:00
|
|
|
|
2014-08-05 17:27:43 -04:00
|
|
|
/*
|
|
|
|
|
* Class: edu_wpi_first_wpilibj_hal_PWMJNI
|
|
|
|
|
* Method: allocatePWMChannel
|
2015-11-01 09:11:52 -08:00
|
|
|
* Signature: (J)Z
|
2014-08-05 17:27:43 -04:00
|
|
|
*/
|
|
|
|
|
JNIEXPORT jboolean JNICALL Java_edu_wpi_first_wpilibj_hal_PWMJNI_allocatePWMChannel
|
2015-11-01 09:11:52 -08:00
|
|
|
(JNIEnv * env, jclass, jlong id)
|
2014-08-05 17:27:43 -04:00
|
|
|
{
|
|
|
|
|
PWMJNI_LOG(logDEBUG) << "Calling DIOJNI allocatePWMChannel";
|
2015-11-01 09:11:52 -08:00
|
|
|
PWMJNI_LOG(logDEBUG) << "Port Ptr = " << (void*)id;
|
|
|
|
|
int32_t status = 0;
|
|
|
|
|
jboolean returnValue = allocatePWMChannel((void*)id, &status);
|
|
|
|
|
PWMJNI_LOG(logDEBUG) << "Status = " << status;
|
2014-08-05 17:27:43 -04:00
|
|
|
PWMJNI_LOG(logDEBUG) << "allocatePWMChannelResult = " << (jint)returnValue;
|
2015-11-01 09:11:52 -08:00
|
|
|
CheckStatus(env, status);
|
|
|
|
|
return returnValue;
|
2014-08-05 17:27:43 -04:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/*
|
|
|
|
|
* Class: edu_wpi_first_wpilibj_hal_PWMJNI
|
|
|
|
|
* Method: freePWMChannel
|
2015-11-01 09:11:52 -08:00
|
|
|
* Signature: (J)V
|
2014-08-05 17:27:43 -04:00
|
|
|
*/
|
|
|
|
|
JNIEXPORT void JNICALL Java_edu_wpi_first_wpilibj_hal_PWMJNI_freePWMChannel
|
2015-11-01 09:11:52 -08:00
|
|
|
(JNIEnv * env, jclass, jlong id)
|
2014-08-05 17:27:43 -04:00
|
|
|
{
|
|
|
|
|
PWMJNI_LOG(logDEBUG) << "Calling DIOJNI freePWMChannel";
|
2015-11-01 09:11:52 -08:00
|
|
|
PWMJNI_LOG(logDEBUG) << "Port Ptr = " << (void*)id;
|
|
|
|
|
int32_t status = 0;
|
|
|
|
|
freePWMChannel((void*)id, &status);
|
|
|
|
|
PWMJNI_LOG(logDEBUG) << "Status = " << status;
|
|
|
|
|
CheckStatus(env, status);
|
2014-08-05 17:27:43 -04:00
|
|
|
}
|
|
|
|
|
|
2014-01-06 09:27:51 -05:00
|
|
|
/*
|
|
|
|
|
* Class: edu_wpi_first_wpilibj_hal_PWMJNI
|
|
|
|
|
* Method: setPWM
|
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_PWMJNI_setPWM
|
2015-11-01 09:11:52 -08:00
|
|
|
(JNIEnv * env, jclass, jlong id, jshort value)
|
2014-01-06 09:27:51 -05:00
|
|
|
{
|
2015-11-01 09:11:52 -08:00
|
|
|
PWMJNI_LOG(logDEBUG) << "DigitalPort Ptr = " << (void*)id;
|
2014-01-06 09:27:51 -05:00
|
|
|
PWMJNI_LOG(logDEBUG) << "PWM Value = " << value;
|
2015-11-01 09:11:52 -08:00
|
|
|
int32_t status = 0;
|
|
|
|
|
setPWM((void*)id, value, &status);
|
|
|
|
|
PWMJNI_LOG(logDEBUG) << "Status = " << status;
|
|
|
|
|
CheckStatus(env, status);
|
2014-01-06 09:27:51 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/*
|
|
|
|
|
* Class: edu_wpi_first_wpilibj_hal_PWMJNI
|
|
|
|
|
* Method: getPWM
|
2015-11-01 09:11:52 -08:00
|
|
|
* Signature: (J)S
|
2014-01-06 09:27:51 -05:00
|
|
|
*/
|
|
|
|
|
JNIEXPORT jshort JNICALL Java_edu_wpi_first_wpilibj_hal_PWMJNI_getPWM
|
2015-11-01 09:11:52 -08:00
|
|
|
(JNIEnv * env, jclass, jlong id)
|
2014-01-06 09:27:51 -05:00
|
|
|
{
|
2015-11-01 09:11:52 -08:00
|
|
|
PWMJNI_LOG(logDEBUG) << "PWM Ptr = " << (void*)id;
|
|
|
|
|
int32_t status = 0;
|
|
|
|
|
jshort returnValue = getPWM((void*)id, &status);
|
|
|
|
|
PWMJNI_LOG(logDEBUG) << "Status = " << status;
|
2014-01-06 09:27:51 -05:00
|
|
|
PWMJNI_LOG(logDEBUG) << "Value = " << returnValue;
|
2015-11-01 09:11:52 -08:00
|
|
|
CheckStatus(env, status);
|
2014-01-06 09:27:51 -05:00
|
|
|
return returnValue;
|
|
|
|
|
}
|
|
|
|
|
|
2014-09-26 17:20:57 -04:00
|
|
|
/*
|
|
|
|
|
* Class: edu_wpi_first_wpilibj_hal_PWMJNI
|
|
|
|
|
* Method: latchPWMZero
|
2015-11-01 09:11:52 -08:00
|
|
|
* Signature: (J)V
|
2014-09-26 17:20:57 -04:00
|
|
|
*/
|
|
|
|
|
JNIEXPORT void JNICALL Java_edu_wpi_first_wpilibj_hal_PWMJNI_latchPWMZero
|
2015-11-01 09:11:52 -08:00
|
|
|
(JNIEnv * env, jclass, jlong id)
|
2014-09-26 17:20:57 -04:00
|
|
|
{
|
2015-11-01 09:11:52 -08:00
|
|
|
PWMJNI_LOG(logDEBUG) << "PWM Ptr = " << (void*)id;
|
|
|
|
|
int32_t status = 0;
|
|
|
|
|
latchPWMZero((void*)id, &status);
|
|
|
|
|
PWMJNI_LOG(logDEBUG) << "Status = " << status;
|
|
|
|
|
CheckStatus(env, status);
|
2014-09-26 17:20:57 -04:00
|
|
|
}
|
|
|
|
|
|
2014-01-06 09:27:51 -05:00
|
|
|
/*
|
|
|
|
|
* Class: edu_wpi_first_wpilibj_hal_PWMJNI
|
|
|
|
|
* Method: setPWMPeriodScale
|
2015-11-01 09:11:52 -08:00
|
|
|
* Signature: (JI)V
|
2014-01-06 09:27:51 -05:00
|
|
|
*/
|
|
|
|
|
JNIEXPORT void JNICALL Java_edu_wpi_first_wpilibj_hal_PWMJNI_setPWMPeriodScale
|
2015-11-01 09:11:52 -08:00
|
|
|
(JNIEnv * env, jclass, jlong id, jint value)
|
2014-01-06 09:27:51 -05:00
|
|
|
{
|
2015-11-01 09:11:52 -08:00
|
|
|
PWMJNI_LOG(logDEBUG) << "DigitalPort Ptr = " << (void*)id;
|
2014-01-06 09:27:51 -05:00
|
|
|
PWMJNI_LOG(logDEBUG) << "PeriodScale Value = " << value;
|
2015-11-01 09:11:52 -08:00
|
|
|
int32_t status = 0;
|
|
|
|
|
setPWMPeriodScale((void*)id, value, &status);
|
|
|
|
|
PWMJNI_LOG(logDEBUG) << "Status = " << status;
|
|
|
|
|
CheckStatus(env, status);
|
2014-01-06 09:27:51 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/*
|
|
|
|
|
* Class: edu_wpi_first_wpilibj_hal_PWMJNI
|
|
|
|
|
* Method: allocatePWM
|
2015-11-01 09:11:52 -08:00
|
|
|
* Signature: ()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_PWMJNI_allocatePWM
|
|
|
|
|
(JNIEnv * env, jclass)
|
2014-01-06 09:27:51 -05:00
|
|
|
{
|
|
|
|
|
PWMJNI_LOG(logDEBUG) << "Calling PWMJNI allocatePWM";
|
2015-11-01 09:11:52 -08:00
|
|
|
int32_t status = 0;
|
|
|
|
|
void* pwm = allocatePWM(&status);
|
|
|
|
|
PWMJNI_LOG(logDEBUG) << "Status = " << status;
|
|
|
|
|
PWMJNI_LOG(logDEBUG) << "PWM Ptr = " << pwm;
|
|
|
|
|
CheckStatus(env, status);
|
|
|
|
|
return (jlong)pwm;
|
2014-01-06 09:27:51 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/*
|
|
|
|
|
* Class: edu_wpi_first_wpilibj_hal_PWMJNI
|
|
|
|
|
* Method: freePWM
|
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_PWMJNI_freePWM
|
2015-11-01 09:11:52 -08:00
|
|
|
(JNIEnv * env, jclass, jlong id)
|
2014-01-06 09:27:51 -05:00
|
|
|
{
|
|
|
|
|
PWMJNI_LOG(logDEBUG) << "Calling PWMJNI freePWM";
|
2015-11-01 09:11:52 -08:00
|
|
|
PWMJNI_LOG(logDEBUG) << "PWM Ptr = " << (void*)id;
|
|
|
|
|
int32_t status = 0;
|
|
|
|
|
freePWM((void*)id, &status);
|
|
|
|
|
PWMJNI_LOG(logDEBUG) << "Status = " << status;
|
|
|
|
|
CheckStatus(env, status);
|
2014-01-06 09:27:51 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/*
|
|
|
|
|
* Class: edu_wpi_first_wpilibj_hal_PWMJNI
|
|
|
|
|
* Method: setPWMRate
|
2015-11-01 09:11:52 -08:00
|
|
|
* Signature: (D)V
|
2014-01-06 09:27:51 -05:00
|
|
|
*/
|
|
|
|
|
JNIEXPORT void JNICALL Java_edu_wpi_first_wpilibj_hal_PWMJNI_setPWMRate
|
2015-11-01 09:11:52 -08:00
|
|
|
(JNIEnv * env, jclass, jdouble value)
|
2014-01-06 09:27:51 -05:00
|
|
|
{
|
|
|
|
|
PWMJNI_LOG(logDEBUG) << "Calling PWMJNI setPWMRate";
|
|
|
|
|
PWMJNI_LOG(logDEBUG) << "Rate= " << value;
|
2015-11-01 09:11:52 -08:00
|
|
|
int32_t status = 0;
|
|
|
|
|
setPWMRate(value, &status);
|
|
|
|
|
PWMJNI_LOG(logDEBUG) << "Status = " << status;
|
|
|
|
|
CheckStatus(env, status);
|
2014-01-06 09:27:51 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/*
|
|
|
|
|
* Class: edu_wpi_first_wpilibj_hal_PWMJNI
|
|
|
|
|
* Method: setPWMDutyCycle
|
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_PWMJNI_setPWMDutyCycle
|
2015-11-01 09:11:52 -08:00
|
|
|
(JNIEnv * env, jclass, jlong id, jdouble value)
|
2014-01-06 09:27:51 -05:00
|
|
|
{
|
|
|
|
|
PWMJNI_LOG(logDEBUG) << "Calling PWMJNI setPWMDutyCycle";
|
2015-11-01 09:11:52 -08:00
|
|
|
PWMJNI_LOG(logDEBUG) << "PWM Ptr = " << (void*)id;
|
2014-01-06 09:27:51 -05:00
|
|
|
PWMJNI_LOG(logDEBUG) << "DutyCycle= " << value;
|
2015-11-01 09:11:52 -08:00
|
|
|
int32_t status = 0;
|
|
|
|
|
setPWMDutyCycle((void*)id, value, &status);
|
|
|
|
|
PWMJNI_LOG(logDEBUG) << "Status = " << status;
|
|
|
|
|
CheckStatus(env, status);
|
2014-01-06 09:27:51 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/*
|
|
|
|
|
* Class: edu_wpi_first_wpilibj_hal_PWMJNI
|
|
|
|
|
* Method: setPWMOutputChannel
|
2015-11-01 09:11:52 -08:00
|
|
|
* Signature: (JI)V
|
2014-01-06 09:27:51 -05:00
|
|
|
*/
|
|
|
|
|
JNIEXPORT void JNICALL Java_edu_wpi_first_wpilibj_hal_PWMJNI_setPWMOutputChannel
|
2015-11-01 09:11:52 -08:00
|
|
|
(JNIEnv * env, jclass, jlong id, jint value)
|
2014-01-06 09:27:51 -05:00
|
|
|
{
|
|
|
|
|
PWMJNI_LOG(logDEBUG) << "Calling PWMJNI setPWMOutputChannel";
|
2015-11-01 09:11:52 -08:00
|
|
|
PWMJNI_LOG(logDEBUG) << "PWM Ptr = " << (void*)id;
|
2014-01-06 09:27:51 -05:00
|
|
|
PWMJNI_LOG(logDEBUG) << "Pin= " << value;
|
2015-11-01 09:11:52 -08:00
|
|
|
int32_t status = 0;
|
|
|
|
|
setPWMOutputChannel((void*)id, (uint32_t) value, &status);
|
|
|
|
|
PWMJNI_LOG(logDEBUG) << "Status = " << status;
|
|
|
|
|
CheckStatus(env, status);
|
2014-01-06 09:27:51 -05:00
|
|
|
}
|
2015-11-01 09:11:52 -08:00
|
|
|
|
|
|
|
|
} // extern "C"
|