case "${host}" in
*-*-linux*)
PKG_CHECK_MODULES([UDEV],[libudev],,[has_libudev="no"]; AC_MSG_WARN("library 'udev' is missing - adapter detection will not be available"))
- LIBS+=" -lrt"
+ AC_CHECK_HEADER(lockdev.h,, AC_MSG_ERROR("required library 'liblockdev' is missing"))
+ LIBS+=" -lrt -llockdev"
;;
*-apple-darwin*)
has_libudev="no";
Section: video
Priority: extra
Maintainer: Lars Op den Kamp <lars.opdenkamp@pulse-eight.com>
-Build-Depends: debhelper (>= 7), libudev-dev, mime-support, locales, gawk, autotools-dev, autoconf, automake, pkg-config
+Build-Depends: debhelper (>= 7), libudev-dev, mime-support, locales, gawk, autotools-dev, autoconf, automake, pkg-config, liblockdev1-dev
Standards-Version: 3.8.3
Homepage: http://www.pulse-eight.net/
Package: libcec
Architecture: any
-Depends: ${shlibs:Depends}, ${misc:Depends}
+Depends: ${shlibs:Depends}, ${misc:Depends}, liblockdev1
Description: Pulse-Eight CEC adapter control library
With this library you can access your Pulse-Eight CEC adapter.
#ifndef IUCLC
#define IUCLC 0
#endif
+#else
+#include <lockdev.h>
#endif
+
using namespace std;
using namespace PLATFORM;
void CSerialSocket::Close(void)
{
if (IsOpen())
+ {
SocketClose(m_socket);
+ #if !defined(__APPLE__) && !defined(__FreeBSD__)
+ dev_unlock(m_strName.c_str(), m_lockPid);
+ #endif
+ }
}
void CSerialSocket::Shutdown(void)
{
if (IsOpen())
+ {
SocketClose(m_socket);
+ #if !defined(__APPLE__) && !defined(__FreeBSD__)
+ dev_unlock(m_strName.c_str(), m_lockPid);
+ #endif
+ }
}
ssize_t CSerialSocket::Write(void* data, size_t len)
{
iTimeoutMs = 0;
if (IsOpen())
+ {
+ m_iError = EINVAL;
return false;
+ }
if (m_iDatabits != SERIAL_DATA_BITS_FIVE && m_iDatabits != SERIAL_DATA_BITS_SIX &&
m_iDatabits != SERIAL_DATA_BITS_SEVEN && m_iDatabits != SERIAL_DATA_BITS_EIGHT)
{
m_strError = "Databits has to be between 5 and 8";
+ m_iError = EINVAL;
return false;
}
if (m_iStopbits != SERIAL_STOP_BITS_ONE && m_iStopbits != SERIAL_STOP_BITS_TWO)
{
m_strError = "Stopbits has to be 1 or 2";
+ m_iError = EINVAL;
return false;
}
if (m_iParity != SERIAL_PARITY_NONE && m_iParity != SERIAL_PARITY_EVEN && m_iParity != SERIAL_PARITY_ODD)
{
m_strError = "Parity has to be none, even or odd";
+ m_iError = EINVAL;
+ return false;
+ }
+
+ #if !defined(__APPLE__) && !defined(__FreeBSD__)
+ m_lockPid = dev_lock(m_strName.c_str());
+ if (m_lockPid != 0)
+ {
+ m_strError = "Couldn't lock the serial port";
+ m_iError = EBUSY;
return false;
}
+ #endif
m_socket = open(m_strName.c_str(), O_RDWR | O_NOCTTY | O_NDELAY);
if (m_socket == INVALID_SERIAL_SOCKET_VALUE)
{
m_strError = strerror(errno);
+ #if !defined(__APPLE__) && !defined(__FreeBSD__)
+ m_lockPid = dev_unlock(m_strName.c_str(), m_lockPid);
+ #endif
return false;
}
if (tcsetattr(m_socket, TCSANOW, &m_options) != 0)
{
m_strError = strerror(errno);
+ #if !defined(__APPLE__) && !defined(__FreeBSD__)
+ m_lockPid = dev_unlock(m_strName.c_str(), m_lockPid);
+ #endif
return false;
}
CCommonSocket<serial_socket_t>(INVALID_SERIAL_SOCKET_VALUE, strName),
#ifdef __WINDOWS__
m_iCurrentReadTimeout(MAXDWORD),
+ #else
+ m_lockPid(0),
#endif
m_bIsOpen(false),
m_iBaudrate(iBaudrate),
protected:
#ifndef __WINDOWS__
struct termios m_options;
+ pid_t m_lockPid;
#else
bool SetTimeouts(serial_socket_t socket, int* iError, DWORD iTimeoutMs);
DWORD m_iCurrentReadTimeout;