Ensure that -1 is return from readBytes upon read error
This commit is contained in:
parent
71977d816b
commit
23f29278c2
|
@ -2,7 +2,7 @@
|
||||||
* SerialPort_Posix.c
|
* SerialPort_Posix.c
|
||||||
*
|
*
|
||||||
* Created on: Feb 25, 2012
|
* Created on: Feb 25, 2012
|
||||||
* Last Updated on: Jan 25, 2022
|
* Last Updated on: Jan 28, 2022
|
||||||
* Author: Will Hedgecock
|
* Author: Will Hedgecock
|
||||||
*
|
*
|
||||||
* Copyright (C) 2012-2022 Fazecast, Inc.
|
* Copyright (C) 2012-2022 Fazecast, Inc.
|
||||||
|
@ -854,7 +854,11 @@ JNIEXPORT jint JNICALL Java_com_fazecast_jSerialComm_SerialPort_readBytes(JNIEnv
|
||||||
port->errorLineNumber = __LINE__ + 1;
|
port->errorLineNumber = __LINE__ + 1;
|
||||||
do { errno = 0; numBytesRead = read(port->handle, port->readBuffer + numBytesReadTotal, bytesRemaining); port->errorNumber = errno; } while ((numBytesRead < 0) && (errno == EINTR));
|
do { errno = 0; numBytesRead = read(port->handle, port->readBuffer + numBytesReadTotal, bytesRemaining); port->errorNumber = errno; } while ((numBytesRead < 0) && (errno == EINTR));
|
||||||
if ((numBytesRead == -1) || ((numBytesRead == 0) && (ioctl(port->handle, FIONREAD, &ioctlResult) == -1)))
|
if ((numBytesRead == -1) || ((numBytesRead == 0) && (ioctl(port->handle, FIONREAD, &ioctlResult) == -1)))
|
||||||
|
{
|
||||||
|
// If all bytes were not successfully read, it is an error
|
||||||
|
numBytesRead = -1;
|
||||||
break;
|
break;
|
||||||
|
}
|
||||||
|
|
||||||
// Fix index variables
|
// Fix index variables
|
||||||
numBytesReadTotal += numBytesRead;
|
numBytesReadTotal += numBytesRead;
|
||||||
|
@ -879,7 +883,12 @@ JNIEXPORT jint JNICALL Java_com_fazecast_jSerialComm_SerialPort_readBytes(JNIEnv
|
||||||
port->errorLineNumber = __LINE__ + 1;
|
port->errorLineNumber = __LINE__ + 1;
|
||||||
do { errno = 0; numBytesRead = read(port->handle, port->readBuffer + numBytesReadTotal, bytesRemaining); port->errorNumber = errno; } while ((numBytesRead < 0) && (errno == EINTR));
|
do { errno = 0; numBytesRead = read(port->handle, port->readBuffer + numBytesReadTotal, bytesRemaining); port->errorNumber = errno; } while ((numBytesRead < 0) && (errno == EINTR));
|
||||||
if ((numBytesRead == -1) || ((numBytesRead == 0) && (ioctl(port->handle, FIONREAD, &ioctlResult) == -1)))
|
if ((numBytesRead == -1) || ((numBytesRead == 0) && (ioctl(port->handle, FIONREAD, &ioctlResult) == -1)))
|
||||||
|
{
|
||||||
|
// If any bytes were read, return those bytes
|
||||||
|
if (!numBytesReadTotal)
|
||||||
|
numBytesRead = -1;
|
||||||
break;
|
break;
|
||||||
|
}
|
||||||
|
|
||||||
// Fix index variables
|
// Fix index variables
|
||||||
numBytesReadTotal += numBytesRead;
|
numBytesReadTotal += numBytesRead;
|
||||||
|
@ -894,7 +903,9 @@ JNIEXPORT jint JNICALL Java_com_fazecast_jSerialComm_SerialPort_readBytes(JNIEnv
|
||||||
// Read from the port
|
// Read from the port
|
||||||
port->errorLineNumber = __LINE__ + 1;
|
port->errorLineNumber = __LINE__ + 1;
|
||||||
do { errno = 0; numBytesRead = read(port->handle, port->readBuffer, bytesToRead); port->errorNumber = errno; } while ((numBytesRead < 0) && (errno == EINTR));
|
do { errno = 0; numBytesRead = read(port->handle, port->readBuffer, bytesToRead); port->errorNumber = errno; } while ((numBytesRead < 0) && (errno == EINTR));
|
||||||
if (numBytesRead > 0)
|
if ((numBytesRead == -1) || ((numBytesRead == 0) && (ioctl(port->handle, FIONREAD, &ioctlResult) == -1)))
|
||||||
|
numBytesRead = -1;
|
||||||
|
else
|
||||||
numBytesReadTotal = numBytesRead;
|
numBytesReadTotal = numBytesRead;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Binary file not shown.
Binary file not shown.
Binary file not shown.
Binary file not shown.
Binary file not shown.
Binary file not shown.
Binary file not shown.
Binary file not shown.
Binary file not shown.
Binary file not shown.
Binary file not shown.
Binary file not shown.
Binary file not shown.
Binary file not shown.
Binary file not shown.
Binary file not shown.
Binary file not shown.
Binary file not shown.
Binary file not shown.
Binary file not shown.
Binary file not shown.
Binary file not shown.
Binary file not shown.
Binary file not shown.
Binary file not shown.
Binary file not shown.
Loading…
Reference in New Issue