Go to file
silverbuddy 46d8b0a039 Handle the case when /sys/class/tty/ entries are not symlinks.
For example:

$ uname -a
Linux RT-N66U 2.6.22.19 #1 Thu Feb 12 20:33:36 CST 2015 mips GNU/Linux

$ ls -lF /sys/class/tty/
drwxr-xr-x    2 foo  root             0 May 18 18:12 ttyACM0/

$ ls -lF /sys/class/tty/ttyACM0/
-r--r--r--    1 foo  root          4096 May 18 18:12 dev
lrwxrwxrwx    1 foo  root             0 May 18 18:12 device -> ../../../devices/pci0000:00/0000:00:04.1/usb1/1-1/1-1.1/1-1.1:1.0/
lrwxrwxrwx    1 foo  root             0 May 18 18:12 subsystem -> ../../../class/tty/
-rw-r--r--    1 foo  root          4096 May 18 18:12 uevent
2015-05-27 11:09:26 +02:00
.gitignore Generate a config.h rather than passing defines on command line. 2015-03-24 23:15:32 +00:00
AUTHORS Add the usual AUTHORS file. 2014-04-13 19:54:41 +02:00
autogen.sh autogen.sh: Drop obsolete MinGW/MSYS items. 2015-04-07 02:35:03 +02:00
config-fields Add generator program for configuration accessor headers. 2013-11-23 20:45:09 +00:00
config-header.py Add generator program for configuration accessor headers. 2013-11-23 20:45:09 +00:00
config-pattern Various Doxygen comment updates and fixes. 2015-04-19 18:16:01 +02:00
configure.ac autotools: Don't set/override "user variables". 2015-04-19 19:01:08 +02:00
COPYING
Doxyfile Doxyfile: Update to Doxygen 1.8.8 template. 2015-04-18 21:54:42 +02:00
freebsd.c Various cosmetic and consistency fixes. 2015-03-26 23:57:56 +01:00
libserialport_internal.h Fix a compiler warning when -Wshadow is used. 2015-04-18 21:54:42 +02:00
libserialport.h.in Add new sp_blocking_read_next() function. 2015-05-27 11:09:26 +02:00
libserialport.pc.in configure.ac: Drop no longer needed SP_PKGLIBS. 2015-04-19 18:21:19 +02:00
linux_termios.c linux: Check for BOTHER macro at configure time. 2014-11-01 18:36:09 +01:00
linux_termios.h linux_termios.h: Add missing #include of "config.h". 2015-03-25 14:52:54 +01:00
linux.c Handle the case when /sys/class/tty/ entries are not symlinks. 2015-05-27 11:09:26 +02:00
macosx.c Various cosmetic and consistency fixes. 2015-03-26 23:57:56 +01:00
Makefile.am autotools: Don't set/override "user variables". 2015-04-19 19:01:08 +02:00
NEWS Tidy up and split most OS-specific code to separate files. 2014-06-11 15:10:29 +01:00
README README: Refer to MSYS2 only. 2015-04-07 01:32:40 +02:00
serialport.c Add new sp_blocking_read_next() function. 2015-05-27 11:09:26 +02:00
windows.c windows.c: Constify a few function parameters. 2015-04-19 19:50:56 +02:00

-------------------------------------------------------------------------------
libserialport: cross-platform library for accessing serial ports
-------------------------------------------------------------------------------

libserialport is a minimal library written in C that is intended to take care
of the OS-specific details when writing software that uses serial ports.

By writing your serial code to use libserialport, you enable it to work
transparently on any platform supported by the library.

The operations that are supported are:

- Port enumeration (obtaining a list of serial ports on the system).
- Obtaining port metadata (USB device information, Bluetooth address, etc).
- Opening and closing ports.
- Setting port parameters (baud rate, parity, etc).
- Reading, writing and flushing data.
- Obtaining error information.

libserialport is an open source project released under the LGPL3+ license.

Status
======

The library should build and work on any Windows or Unix-based system. If it
does not, please submit a bug.

Enumeration is currently implemented on Windows, Mac OS X, FreeBSD and Linux.
On other systems enumeration is not supported, but ports can still be opened
by name and then used.

If you know how to enumerate available ports on another OS, please submit a bug
with this information, or better still a patch implementing it.

Dependencies
============

No other libraries are required.

Building
========

The package uses a GNU style build system and requires a Unix style shell.

Windows builds can be created natively with the MinGW-w64 toolchain and
MSYS2 environment, or cross-compiled using a MinGW-w64 toolchain:

  http://mingw-w64.sourceforge.net/

The "old" MinGW from http://mingw.org/ is not supported.

Run "./autogen.sh" to generate the build system, "./configure" to setup, then
"make" to build the library and "make install" to install it.

API
===

Doxygen API documentation is included.

It can also be viewed online at:

  http://sigrok.org/api/libserialport/unstable/

Website
=======

http://sigrok.org/wiki/Libserialport