Add remaining RS-485 configuration parameters (PR #357)
This commit is contained in:
parent
c1684de18e
commit
2f70a93a27
|
@ -3,6 +3,9 @@ bin
|
||||||
site
|
site
|
||||||
build
|
build
|
||||||
|
|
||||||
|
# Generated files for JNI
|
||||||
|
src/main/c/com_fazecast_jSerialComm_SerialPort.h
|
||||||
|
|
||||||
# Mobile Tools for Java (J2ME)
|
# Mobile Tools for Java (J2ME)
|
||||||
.mtj.tmp/
|
.mtj.tmp/
|
||||||
|
|
||||||
|
|
|
@ -1,7 +1,7 @@
|
||||||
# Architecture-dependent library variables
|
# Architecture-dependent library variables
|
||||||
COMPILE := gcc
|
COMPILE := gcc
|
||||||
COMPILE_ARM32 := arm32-unknown-linux-gnueabi-gcc
|
COMPILE_ARM32 := arm-unknown-linux-gnueabi-gcc
|
||||||
COMPILE_ARM32HF := arm32hf-unknown-linux-gnueabi-gcc
|
COMPILE_ARM32HF := arm-unknown-linux-gnueabihf-gcc
|
||||||
COMPILE_ARM64 := aarch64-unknown-linux-gnueabi-gcc
|
COMPILE_ARM64 := aarch64-unknown-linux-gnueabi-gcc
|
||||||
COMPILE_PPC64LE := powerpc64le-unknown-linux-gnu-gcc
|
COMPILE_PPC64LE := powerpc64le-unknown-linux-gnu-gcc
|
||||||
COMPILE_SOLARIS_X86 := x86_64-sun-solaris2.10-gcc
|
COMPILE_SOLARIS_X86 := x86_64-sun-solaris2.10-gcc
|
||||||
|
|
|
@ -67,6 +67,8 @@ jfieldID receiveDeviceQueueSizeField;
|
||||||
jfieldID disableExclusiveLockField;
|
jfieldID disableExclusiveLockField;
|
||||||
jfieldID rs485ModeField;
|
jfieldID rs485ModeField;
|
||||||
jfieldID rs485ActiveHighField;
|
jfieldID rs485ActiveHighField;
|
||||||
|
jfieldID rs485EnableTerminationField;
|
||||||
|
jfieldID rs485RxDuringTxField;
|
||||||
jfieldID rs485DelayBeforeField;
|
jfieldID rs485DelayBeforeField;
|
||||||
jfieldID rs485DelayAfterField;
|
jfieldID rs485DelayAfterField;
|
||||||
jfieldID timeoutModeField;
|
jfieldID timeoutModeField;
|
||||||
|
@ -233,6 +235,8 @@ JNIEXPORT void JNICALL Java_com_fazecast_jSerialComm_SerialPort_initializeLibrar
|
||||||
disableExclusiveLockField = (*env)->GetFieldID(env, serialCommClass, "disableExclusiveLock", "Z");
|
disableExclusiveLockField = (*env)->GetFieldID(env, serialCommClass, "disableExclusiveLock", "Z");
|
||||||
rs485ModeField = (*env)->GetFieldID(env, serialCommClass, "rs485Mode", "Z");
|
rs485ModeField = (*env)->GetFieldID(env, serialCommClass, "rs485Mode", "Z");
|
||||||
rs485ActiveHighField = (*env)->GetFieldID(env, serialCommClass, "rs485ActiveHigh", "Z");
|
rs485ActiveHighField = (*env)->GetFieldID(env, serialCommClass, "rs485ActiveHigh", "Z");
|
||||||
|
rs485EnableTerminationField = (*env)->GetFieldID(env, serialCommClass, "rs485EnableTermination", "Z");
|
||||||
|
rs485RxDuringTxField = (*env)->GetFieldID(env, serialCommClass, "rs485RxDuringTx", "Z");
|
||||||
rs485DelayBeforeField = (*env)->GetFieldID(env, serialCommClass, "rs485DelayBefore", "I");
|
rs485DelayBeforeField = (*env)->GetFieldID(env, serialCommClass, "rs485DelayBefore", "I");
|
||||||
rs485DelayAfterField = (*env)->GetFieldID(env, serialCommClass, "rs485DelayAfter", "I");
|
rs485DelayAfterField = (*env)->GetFieldID(env, serialCommClass, "rs485DelayAfter", "I");
|
||||||
timeoutModeField = (*env)->GetFieldID(env, serialCommClass, "timeoutMode", "I");
|
timeoutModeField = (*env)->GetFieldID(env, serialCommClass, "timeoutMode", "I");
|
||||||
|
@ -324,6 +328,8 @@ JNIEXPORT jboolean JNICALL Java_com_fazecast_jSerialComm_SerialPort_configPort(J
|
||||||
unsigned char configDisabled = (*env)->GetBooleanField(env, obj, disableConfigField);
|
unsigned char configDisabled = (*env)->GetBooleanField(env, obj, disableConfigField);
|
||||||
unsigned char rs485ModeEnabled = (*env)->GetBooleanField(env, obj, rs485ModeField);
|
unsigned char rs485ModeEnabled = (*env)->GetBooleanField(env, obj, rs485ModeField);
|
||||||
unsigned char rs485ActiveHigh = (*env)->GetBooleanField(env, obj, rs485ActiveHighField);
|
unsigned char rs485ActiveHigh = (*env)->GetBooleanField(env, obj, rs485ActiveHighField);
|
||||||
|
unsigned char rs485EnableTermination = (*env)->GetBooleanField(env, obj, rs485EnableTerminationField);
|
||||||
|
unsigned char rs485RxDuringTx = (*env)->GetBooleanField(env, obj, rs485RxDuringTxField);
|
||||||
unsigned char isDtrEnabled = (*env)->GetBooleanField(env, obj, isDtrEnabledField);
|
unsigned char isDtrEnabled = (*env)->GetBooleanField(env, obj, isDtrEnabledField);
|
||||||
unsigned char isRtsEnabled = (*env)->GetBooleanField(env, obj, isRtsEnabledField);
|
unsigned char isRtsEnabled = (*env)->GetBooleanField(env, obj, isRtsEnabledField);
|
||||||
tcflag_t byteSize = (byteSizeInt == 5) ? CS5 : (byteSizeInt == 6) ? CS6 : (byteSizeInt == 7) ? CS7 : CS8;
|
tcflag_t byteSize = (byteSizeInt == 5) ? CS5 : (byteSizeInt == 6) ? CS6 : (byteSizeInt == 7) ? CS7 : CS8;
|
||||||
|
@ -396,9 +402,14 @@ JNIEXPORT jboolean JNICALL Java_com_fazecast_jSerialComm_SerialPort_configPort(J
|
||||||
rs485Conf.flags &= ~(SER_RS485_RTS_ON_SEND);
|
rs485Conf.flags &= ~(SER_RS485_RTS_ON_SEND);
|
||||||
rs485Conf.flags |= SER_RS485_RTS_AFTER_SEND;
|
rs485Conf.flags |= SER_RS485_RTS_AFTER_SEND;
|
||||||
}
|
}
|
||||||
// SerialPort defines delays in microseconds and Linux expects
|
if (rs485RxDuringTx)
|
||||||
// milliseconds (see
|
rs485Conf.flags |= SER_RS485_RX_DURING_TX;
|
||||||
// https://github.com/torvalds/linux/blob/0c18f29aae7ce3dadd26d8ee3505d07cc982df75/include/uapi/linux/serial.h#L129).
|
else
|
||||||
|
rs485Conf.flags &= ~(SER_RS485_RX_DURING_TX);
|
||||||
|
if (rs485EnableTermination)
|
||||||
|
rs485Conf.flags |= SER_RS485_TERMINATE_BUS;
|
||||||
|
else
|
||||||
|
rs485Conf.flags &= ~(SER_RS485_TERMINATE_BUS);
|
||||||
rs485Conf.delay_rts_before_send = rs485DelayBefore / 1000;
|
rs485Conf.delay_rts_before_send = rs485DelayBefore / 1000;
|
||||||
rs485Conf.delay_rts_after_send = rs485DelayAfter / 1000;
|
rs485Conf.delay_rts_after_send = rs485DelayAfter / 1000;
|
||||||
ioctl(serialPortFD, TIOCSRS485, &rs485Conf);
|
ioctl(serialPortFD, TIOCSRS485, &rs485Conf);
|
||||||
|
|
|
@ -401,7 +401,8 @@ public final class SerialPort
|
||||||
private volatile SerialPortEventListener serialEventListener = null;
|
private volatile SerialPortEventListener serialEventListener = null;
|
||||||
private volatile String comPort, friendlyName, portDescription;
|
private volatile String comPort, friendlyName, portDescription;
|
||||||
private volatile boolean eventListenerRunning = false, disableConfig = false, disableExclusiveLock = false;
|
private volatile boolean eventListenerRunning = false, disableConfig = false, disableExclusiveLock = false;
|
||||||
private volatile boolean rs485Mode = false, rs485ActiveHigh = true, isRtsEnabled = true, isDtrEnabled = true;
|
private volatile boolean rs485Mode = false, rs485ActiveHigh = true, rs485RxDuringTx = false, rs485EnableTermination = false;
|
||||||
|
private volatile boolean isRtsEnabled = true, isDtrEnabled = true;
|
||||||
private SerialPortInputStream inputStream = null;
|
private SerialPortInputStream inputStream = null;
|
||||||
private SerialPortOutputStream outputStream = null;
|
private SerialPortOutputStream outputStream = null;
|
||||||
|
|
||||||
|
@ -1183,28 +1184,53 @@ public final class SerialPort
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Sets whether to enable RS-485 mode for this device.
|
* Sets RS-485 mode and its parameters for the device. This is a wrapper around
|
||||||
* <p>
|
* {@link #setRs485ModeParameters(boolean, boolean, boolean, boolean, int, int)} for backward-compatibility which disables bus termination and
|
||||||
* RS-485 mode can be used to enable transmit/receive mode signaling using the RTS pin. This mode should be set if you plan
|
* receiving data while transmitting.
|
||||||
* to use this library with an RS-485 device. Note that this mode requires support from the underlying device driver, so it
|
*
|
||||||
* may not work with all RS-485 devices.
|
* @see #setRs485ModeParameters(boolean, boolean, boolean, boolean, int, int)
|
||||||
* <p>
|
|
||||||
* The RTS "active high" parameter specifies that the logical level of the RTS line will be set to 1 when transmitting and
|
|
||||||
* 0 when receiving.
|
|
||||||
* <p>
|
|
||||||
* The delay parameters specify how long to wait before or after transmission of data before enabling or disabling
|
|
||||||
* transmission mode via the RTS pin.
|
|
||||||
*
|
*
|
||||||
* @param useRS485Mode Whether to enable RS-485 mode.
|
* @param useRS485Mode Whether to enable RS-485 mode.
|
||||||
* @param rs485RtsActiveHigh Whether to set the RTS line to 1 when transmitting.
|
* @param rs485RtsActiveHigh Whether to set the RTS line to 1 when transmitting (effective only on Linux).
|
||||||
* @param delayBeforeSendMicroseconds The time to wait after enabling transmit mode before sending the first data bit.
|
* @param delayBeforeSendMicroseconds The time to wait after enabling transmit mode before sending the first data bit (effective only on Linux).
|
||||||
* @param delayAfterSendMicroseconds The time to wait after sending the last data bit before disabling transmit mode.
|
* @param delayAfterSendMicroseconds The time to wait after sending the last data bit before disabling transmit mode (effective only on Linux).
|
||||||
* @return Whether the port configuration is valid or disallowed on this system (only meaningful after the port is already opened).
|
* @return Whether the port configuration is valid or disallowed on this system (only meaningful after the port is already opened).
|
||||||
*/
|
*/
|
||||||
public final synchronized boolean setRs485ModeParameters(boolean useRS485Mode, boolean rs485RtsActiveHigh, int delayBeforeSendMicroseconds, int delayAfterSendMicroseconds)
|
public final synchronized boolean setRs485ModeParameters(boolean useRS485Mode, boolean rs485RtsActiveHigh, int delayBeforeSendMicroseconds, int delayAfterSendMicroseconds)
|
||||||
|
{
|
||||||
|
return setRs485ModeParameters(useRS485Mode, rs485RtsActiveHigh, false, false, delayBeforeSendMicroseconds, delayAfterSendMicroseconds);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Sets RS-485 mode and its parameters for the device.
|
||||||
|
* <p>
|
||||||
|
* RS-485 mode can be used to enable transmit/receive mode signaling using the RTS pin. This mode should be set if you plan
|
||||||
|
* to use this library with an RS-485 device. Note that this mode requires support from the underlying device driver, so it
|
||||||
|
* may not work with all RS-485 devices. On the other hand there are devices that operate in RS-485 mode by
|
||||||
|
* default and do not require explicit configuration (like some USB to RS-485 adapters).
|
||||||
|
* <p>
|
||||||
|
* Please note that the parameters beyond <i>useRS485Mode</i> are only effective on Linux.
|
||||||
|
* <p>
|
||||||
|
* The RTS "active high" parameter specifies that the logical level of the RTS line will be set to 1 when transmitting and
|
||||||
|
* 0 when receiving.
|
||||||
|
* <p>
|
||||||
|
* The delay parameters specify how long to wait before or after transmission of data after enabling or before disabling
|
||||||
|
* transmission mode via the RTS pin.
|
||||||
|
*
|
||||||
|
* @param useRS485Mode Whether to enable RS-485 mode.
|
||||||
|
* @param rs485RtsActiveHigh Whether to set the RTS line to 1 when transmitting (effective only on Linux).
|
||||||
|
* @param enableTermination Whether to enable RS-485 bus termination on systems supporting this feature (effective only on Linux).
|
||||||
|
* @param rxDuringTx Whether to receive data while transmitting. This usually means that data sent will be read back (effective only on Linux).
|
||||||
|
* @param delayBeforeSendMicroseconds The time to wait after enabling transmit mode before sending the first data bit (effective only on Linux).
|
||||||
|
* @param delayAfterSendMicroseconds The time to wait after sending the last data bit before disabling transmit mode (effective only on Linux).
|
||||||
|
* @return Whether the port configuration is valid or disallowed on this system (only meaningful after the port is already opened).
|
||||||
|
*/
|
||||||
|
public final synchronized boolean setRs485ModeParameters(boolean useRS485Mode, boolean rs485RtsActiveHigh, boolean enableTermination, boolean rxDuringTx,int delayBeforeSendMicroseconds, int delayAfterSendMicroseconds)
|
||||||
{
|
{
|
||||||
rs485Mode = useRS485Mode;
|
rs485Mode = useRS485Mode;
|
||||||
rs485ActiveHigh = rs485RtsActiveHigh;
|
rs485ActiveHigh = rs485RtsActiveHigh;
|
||||||
|
rs485EnableTermination = enableTermination;
|
||||||
|
rs485RxDuringTx = rxDuringTx;
|
||||||
rs485DelayBefore = delayBeforeSendMicroseconds;
|
rs485DelayBefore = delayBeforeSendMicroseconds;
|
||||||
rs485DelayAfter = delayAfterSendMicroseconds;
|
rs485DelayAfter = delayAfterSendMicroseconds;
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue