Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

RXTX serial library crashing on closing port in macOS #105

Open
reinhardknoll opened this issue Apr 13, 2017 · 10 comments
Open

RXTX serial library crashing on closing port in macOS #105

reinhardknoll opened this issue Apr 13, 2017 · 10 comments

Comments

@reinhardknoll
Copy link

reinhardknoll commented Apr 13, 2017

Case ID: 00278849

We are experiencing problems on macOS when using the latest version of the RXTX serial library with Digi’s XBee Java library:

  • macOS version: 10.11.6
  • XBee Java library version 1.2.0
  • RXTX serial library version 2.2

I’ve attached the error log. Apple identifies the problem as [librxtxSerial.jnilib+0x312f] Java_gnu_io_RXTXPort_interruptEventLoop+0x6b in the error log.

It happens on closing the serial port with the RXTX serial library.
It seems like it is related to this post:
I double checked, and I am definitely using the latest version of the RXTX native libraries (version 2.2 pre2).

To prove that it is not my application I reproduced the problem with Digi’s own example code: xbee_java_library/examples/communication/SendDataSample

Here are my XStick driver details as well (from About this MAC > System Report… > Hardware > USB > XStick):

  • Product ID: 0x6001
  • Vendor ID: 0x0403 (Future Technology Devices International Limited)
  • Version: 6.00
  • Speed: Up to 12 Mb/sec
  • Manufacturer: Digi
  • Location ID: 0x14200000 / 6
  • Current Available (mA): 1000
  • Current Required (mA): 100
  • Extra Operating Current (mA): 0

hs_err_pid7372.log.txt

@rubenmoral
Copy link
Member

Hi @keplerian,

We are investigating your issue. Could you please confirm that you are having this problem when using the Send Data sample as is with just one XBee module (in your case the XStick)?

Thanks.

@reinhardknoll
Copy link
Author

reinhardknoll commented Apr 18, 2017

Yes @rubenmoral, I was using just the XStick and the Send Data sample. I think the problem is quite well known. Nrjavaserial mentions exactly the problem that I am experiencing in their bug fix list.

@rubenmoral
Copy link
Member

Where is the problem described? Do you mean

Fixed the memory access error that causes OS X to crash the JVM when serial.close() is called.

We are not able to reproduce it in the same environment using the XStick and the example.

@reinhardknoll
Copy link
Author

reinhardknoll commented Apr 18, 2017

Yes, that is it.

The RXTX website has been down for a while now, so I cannot refer you there. I've attached the jnilib file that we are using. It originated from the rxtx-2.2pre2-bins archive that was downloaded previously from the RXTX website. As far as we could tell, this is the latest available binary file.
librxtxSerial.zip

Possibly related problems:

I've also attached the system info. We tried updating to the latest version of macOS, but that did not make any difference.
mac_info

Which jnilib file are you using?

@rubenmoral
Copy link
Member

We can confirm that the JVM crashes when opening the serial connection with that native library. Why aren't you using the library that we provide in the release zip file?

@reinhardknoll
Copy link
Author

We did use the library that you provide in the release zip file, but it was causing another problem. RXTX was blocking after a while, causing us to lose communication with our devices on macOS. I used a few thread dumps to confirm that was the cause. Should I open another issue for this problem?

I decided to try the latest libraries (which I did state in the original report at the top), since all the other native libraries that you provide for the other platforms were identical to the "official" 2.2pre2 libs. So I thought somebody just forgot to update the mac library. Either way, neither library is robust and stable in our system on macOS.

Why are you using another library for macOS than the latest (2.2pre2 previously) available on the RXTX website? Which version is it?

@reinhardknoll
Copy link
Author

By the way: we tried rebuilding the library to work with the NrJavaSerial library, since it fixes a few known bugs in RXTX. So far it's a lot more stable on macOS.

We would still prefer not to use a different serial library than the XBee Java library, but at the moment (because of all the RXTX issues) that is not an option.

@rubenmoral
Copy link
Member

Sorry for the delayed message, @keplerian. We provide RXTX just as an example of serial library, we know that it is not the most robust library but one of the reasons why we chose it was its license. There are others such as SerialIO, jSSC or the one that you mention that can be easily replaced by RXTX in the XBee Java Library. Maybe we have to ask ourselves whether we should use another one.

@reinhardknoll
Copy link
Author

Judging by the number of related issues (#39 and #99) your users are having with this serial library, I agree that it might be a good idea to ask that question ;)

NrJavaSerial is probably as close to a drop in replacement as you are going to get for RXTX and it seems like it has the same license. jSSC also uses GPL. Probably the only choice that will cause a licensing problem is SerialIO.

@rubenmoral
Copy link
Member

Yeah, we have already added a task in our backlog for the next release, sorry for the inconveniences...

The idea is to merge #40 and give more options to the user regarding the serial library to use. I mentioned SerialIO because we use it in other products, but we cannot provide it here because of its license (however if a user has purchased it, it would be very easy to integrate it as well).

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

No branches or pull requests

2 participants