Add remaining RS-485 configuration parameters (PR #357)

This commit is contained in:
Will Hedgecock 2021-10-22 12:50:08 -05:00
parent c1684de18e
commit 2f70a93a27
4 changed files with 60 additions and 20 deletions

3
.gitignore vendored
View File

@ -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/

View File

@ -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

View File

@ -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);

View File

@ -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;