blob: 820ba46cc8f4422b6c313f9bf663d898c0b3511b [file] [log] [blame]
/*
* libbrlapi - A library providing access to braille terminals for applications.
*
* Copyright (C) 2002-2023 by
* Samuel Thibault <Samuel.Thibault@ens-lyon.org>
* Sébastien Hinderer <Sebastien.Hinderer@ens-lyon.org>
*
* libbrlapi comes with ABSOLUTELY NO WARRANTY.
*
* This is free software, placed under the terms of the
* GNU Lesser General Public License, as published by the Free Software
* Foundation; either version 2.1 of the License, or (at your option) any
* later version. Please see the file LICENSE-LGPL for details.
*
* Web Page: http://brltty.app/
*
* This software is maintained by Dave Mielke <dave@mielke.cc>.
*/
/** \file
* \brief types and constants for \e BrlAPI's protocol
*/
#ifndef BRLAPI_INCLUDED_PROTOCOL
#define BRLAPI_INCLUDED_PROTOCOL
#ifdef __cplusplus
extern "C" {
#endif /* __cplusplus */
#include "brlapi.h"
/* this is for UINT32_MAX */
#include <inttypes.h>
#ifndef UINT32_MAX
#define UINT32_MAX (4294967295U)
#endif /* UINT32_MAX */
/* The type size_t is defined there! */
#include <unistd.h>
/** \defgroup brlapi_protocol BrlAPI's protocol
* \brief Instructions and constants for \e BrlAPI 's protocol
*
* These are defines for the protocol between \e BrlAPI 's server and clients.
* Understanding is not needed to use the \e BrlAPI library, so reading this
* is not needed unless really wanting to connect to \e BrlAPI without
* \e BrlAPI 's library.
*
* @{ */
#define BRLAPI_PROTOCOL_VERSION ((uint32_t) 8) /** Communication protocol version */
/** Maximum packet size for packets exchanged on sockets and with braille
* terminal */
#define BRLAPI_MAXPACKETSIZE 4096
#define BRLAPI_PACKET_VERSION 'v' /**< Version */
#define BRLAPI_PACKET_AUTH 'a' /**< Authorization */
#define BRLAPI_PACKET_GETDRIVERNAME 'n' /**< Ask which driver is used */
#define BRLAPI_PACKET_GETMODELID 'd' /**< Ask which model is used */
#define BRLAPI_PACKET_GETDISPLAYSIZE 's' /**< Dimensions of brl display */
#define BRLAPI_PACKET_ENTERTTYMODE 't' /**< Asks for a specified tty */
#define BRLAPI_PACKET_SETFOCUS 'F' /**< Set current tty focus */
#define BRLAPI_PACKET_LEAVETTYMODE 'L' /**< Release the tty */
#define BRLAPI_PACKET_KEY 'k' /**< Braille key */
#define BRLAPI_PACKET_IGNOREKEYRANGES 'm' /**< Mask key ranges */
#define BRLAPI_PACKET_ACCEPTKEYRANGES 'u' /**< Unmask key ranges */
#define BRLAPI_PACKET_WRITE 'w' /**< Write */
#define BRLAPI_PACKET_ENTERRAWMODE '*' /**< Enter in raw mode */
#define BRLAPI_PACKET_LEAVERAWMODE '#' /**< Leave raw mode */
#define BRLAPI_PACKET_PACKET 'p' /**< Raw packets */
#define BRLAPI_PACKET_ACK 'A' /**< Acknowledgement */
#define BRLAPI_PACKET_ERROR 'e' /**< non-fatal error */
#define BRLAPI_PACKET_EXCEPTION 'E' /**< Exception */
#define BRLAPI_PACKET_SUSPENDDRIVER 'S' /**< Suspend driver */
#define BRLAPI_PACKET_RESUMEDRIVER 'R' /**< Resume driver */
#define BRLAPI_PACKET_SYNCHRONIZE 'Z' /**< Synchronize exceptions */
#define BRLAPI_PACKET_PARAM_VALUE (('P'<<8) + 'V') /**< Parameter value */
#define BRLAPI_PACKET_PARAM_REQUEST (('P'<<8) + 'R') /**< Parameter request*/
#define BRLAPI_PACKET_PARAM_UPDATE (('P'<<8) + 'U') /**< Parameter update */
/** Magic number to give when sending a BRLPACKET_ENTERRAWMODE or BRLPACKET_SUSPEND packet */
#define BRLAPI_DEVICE_MAGIC (0xdeadbeefL)
/** Structure of packets headers */
typedef struct {
uint32_t size;
brlapi_packetType_t type;
} brlapi_header_t;
/** Size of packet headers */
#define BRLAPI_HEADERSIZE sizeof(brlapi_header_t)
/** Structure of version packets */
typedef struct {
uint32_t protocolVersion;
} brlapi_versionPacket_t;
/** Structure of authorization packets */
typedef struct {
uint32_t type;
unsigned char key;
} brlapi_authClientPacket_t;
typedef struct {
uint32_t type[1];
} brlapi_authServerPacket_t;
#define BRLAPI_AUTH_NONE 'N' /**< No or implicit authorization */
#define BRLAPI_AUTH_KEY 'K' /**< Key authorization */
#define BRLAPI_AUTH_CRED 'C' /**< Explicit socket credentials authorization */
/** Structure of error packets */
typedef struct {
uint32_t code;
brlapi_packetType_t type;
unsigned char packet;
} brlapi_errorPacket_t;
/** Structure of enterRawMode / suspend packets */
typedef struct {
uint32_t magic;
unsigned char nameLength;
char name;
} brlapi_getDriverSpecificModePacket_t;
/** Flags for writing */
#define BRLAPI_WF_DISPLAYNUMBER 0X01 /**< Display number */
#define BRLAPI_WF_REGION 0X02 /**< Region parameter */
#define BRLAPI_WF_TEXT 0X04 /**< Contains some text */
#define BRLAPI_WF_ATTR_AND 0X08 /**< And attributes */
#define BRLAPI_WF_ATTR_OR 0X10 /**< Or attributes */
#define BRLAPI_WF_CURSOR 0X20 /**< Cursor position */
#define BRLAPI_WF_CHARSET 0X40 /**< Charset */
/** Structure of extended write packets */
typedef struct {
uint32_t flags; /** Flags to tell which fields are present */
unsigned char data; /** Fields in the same order as flag weight */
} brlapi_writeArgumentsPacket_t;
/** Flags for parameter values */
#define BRLAPI_PVF_GLOBAL 0X01 /** Value is the global value */
#define BRLAPI_MAXPARAMSIZE (BRLAPI_MAXPACKETSIZE - (sizeof(uint32_t) + sizeof(brlapi_param_t) + 2*sizeof(uint32_t)))
/** Structure of Parameter value or update */
typedef struct {
uint32_t flags; /** Flags to tell how value was gotten */
brlapi_param_t param; /** Which parameter being transmitted */
uint32_t subparam_hi; /** Which sub-parameter being transmitted, hi 32bits */
uint32_t subparam_lo; /** Which sub-parameter being transmitted, lo 32bits */
unsigned char data[BRLAPI_MAXPARAMSIZE]; /** Content of the parameter */
} brlapi_paramValuePacket_t;
/** Flags for parameter requests */
#define BRLAPI_PARAMF_GET 0X100 /** Get current parameter value */
#define BRLAPI_PARAMF_SUBSCRIBE 0X200 /** Subscribe to parameter updates */
#define BRLAPI_PARAMF_UNSUBSCRIBE 0X400 /** Unsubscribe from parameter updates */
/** Structure of Parameter request */
typedef struct {
uint32_t flags; /** Flags to tell whether/how to get values */
brlapi_param_t param; /** Which parameter to be transmitted */
uint32_t subparam_hi; /** Which sub-parameter being transmitted, hi 32bits */
uint32_t subparam_lo; /** Which sub-parameter being transmitted, lo 32bits */
} brlapi_paramRequestPacket_t;
/** Type for packets. Should be used instead of a mere char[], since it has
* correct alignment requirements. */
typedef union {
unsigned char data[BRLAPI_MAXPACKETSIZE];
brlapi_versionPacket_t version;
brlapi_authClientPacket_t authClient;
brlapi_authServerPacket_t authServer;
brlapi_errorPacket_t error;
brlapi_getDriverSpecificModePacket_t getDriverSpecificMode;
brlapi_writeArgumentsPacket_t writeArguments;
brlapi_paramValuePacket_t paramValue;
brlapi_paramRequestPacket_t paramRequest;
uint32_t uint32;
} brlapi_packet_t;
/* brlapi_writePacket */
/** Send a packet to \e BrlAPI server
*
* This function is for internal use, but one might use it if one really knows
* what one is doing...
*
* \e type should only be one of the above defined BRLPACKET_*.
*
* The syntax is the same as write()'s.
*
* \return 0 on success, -1 on failure.
*
* \sa brlapi_readPacketHeader()
* brlapi_readPacketContent()
* brlapi_readPacket()
*/
ssize_t brlapi_writePacket(brlapi_fileDescriptor fd, brlapi_packetType_t type, const void *buf, size_t size);
/* brlapi_readPacketHeader */
/** Read the header (type+size) of a packet from \e BrlAPI server
*
* This function is for internal use, but one might use it if one really knows
* what one is doing...
*
* \e type is where the function will store the packet type; it should always
* be one of the above defined BRLPACKET_* (or else something very nasty must
* have happened :/).
*
* \return packet's size, -2 if \c EOF occurred, -1 on error or signal
* interruption.
*
* \sa brlapi_writePacket()
* brlapi_readPacketContent
* brlapi_readPacket
*/
ssize_t brlapi_readPacketHeader(brlapi_fileDescriptor fd, brlapi_packetType_t *packetType);
/* brlapi_readPacketContent */
/** Read the content of a packet from \e BrlAPI server
*
* This function is for internal use, but one might use it if one really knows
* what one is doing...
*
* \e packetSize is the size announced by \e brlapi_readPacketHeader()
*
* \e bufSize is the size of \e buf
*
* \return packetSize, -2 if \c EOF occurred, -1 on error.
*
* If the packet is larger than the supplied buffer, the buffer will be
* filled with the beginning of the packet, the rest of the packet being
* discarded. This follows the semantics of the recv system call when the
* MSG_TRUNC option is given.
*
* \sa brlapi_writePacket()
* brlapi_readPacketHeader()
* brlapi_readPacket()
*/
ssize_t brlapi_readPacketContent(brlapi_fileDescriptor fd, size_t packetSize, void *buf, size_t bufSize);
/* brlapi_readPacket */
/** Read a packet from \e BrlAPI server
*
* This function is for internal use, but one might use it if one really knows
* what one is doing...
*
* \e type is where the function will store the packet type; it should always
* be one of the above defined BRLPACKET_* (or else something very nasty must
* have happened :/).
*
* The syntax is the same as read()'s.
*
* \return packet's size, -2 if \c EOF occurred, -1 on error or signal
* interruption.
*
* If the packet is larger than the supplied buffer, the buffer will be
* filled with the beginning of the packet, the rest of the packet being
* discarded. This follows the semantics of the recv system call when the
* MSG_TRUNC option is given.
*
* \sa brlapi_writePacket()
*/
ssize_t brlapi_readPacket(brlapi_fileDescriptor fd, brlapi_packetType_t *type, void *buf, size_t size);
/* brlapi_fd_mutex */
/** Mutex for protecting concurrent fd access
*
* In order to regulate concurrent access to the library's file descriptor and
* requests to / answers from \e BrlAPI server, every function of the library
* locks this mutex, namely
*
* - brlapi_openConnection()
* - brlapi_closeConnection()
* - brlapi_enterRawMode()
* - brlapi_leaveRawMode()
* - brlapi_sendRaw()
* - brlapi_recvRaw()
* - brlapi_getDriverName()
* - brlapi_getDisplaySize()
* - brlapi_enterTtyMode()
* - brlapi_enterTtyModeWithPath()
* - brlapi_leaveTtyMode()
* - brlapi_*write*()
* - brlapi_(un)?ignorekey(Range|Set)()
* - brlapi_readKey()
*
* If both these functions and brlapi_writePacket() or brlapi_readPacket() are
* used in a multithreaded application, this mutex must be locked before calling
* brlapi_writePacket() or brlapi_readPacket(), and unlocked afterwards.
*/
#ifdef __MINGW32__
#include <windows.h>
extern HANDLE brlapi_fd_mutex;
#else /* __MINGW32__ */
#include <pthread.h>
extern pthread_mutex_t brlapi_fd_mutex;
#endif /* __MINGW32__ */
/** @} */
#ifdef __cplusplus
}
#endif /* __cplusplus */
#endif /* BRLAPI_INCLUDED_PROTOCOL */