palm-os-sdk/sdk-5r4/include/Core/System/IrLib.h
2018-08-30 15:18:26 +01:00

1513 lines
61 KiB
C
Executable File

/******************************************************************************
*
* Copyright (c) 1994-2004 PalmSource, Inc. All rights reserved.
*
* Portions of this file are:
* Copyright Counterpoint Systems Foundry, Inc. 1995, 1996
*
* File: IrLib.h
*
* Release: eclipse 5 SDK (68K) R4.
*
* Description:
* Include file for PalmOS IrDA Library.
*
*****************************************************************************/
#ifndef __IRLIB_H__
#define __IRLIB_H__
#include <PalmTypes.h>
#include <LibTraps.h>
// The Ir library is used as an Exchange library. ExgLib.h defines all the
// primary entrypoints into the library. The rest of this include file defines the
// direct stack API for apps not using the Exchange interface. The Stack API
// comes after the Exchange library API in the library interface.
#include <ExgLib.h>
// name of Ir library
#define irLibName "IrDA Library"
// Specific scheme for IR exg lib
#define exgIrObexScheme "_irobex"
// Feature Creators and numbers, for use with the FtrGet() call. This
// feature can be obtained to get the current version of the Ir Library
#define irFtrCreator sysFileCIrLib
#define irFtrNumVersion 0 // get version of Net Library
// 0xMMmfsbbb, where MM is major version, m is minor version
// f is bug fix, s is stage: 3-release,2-beta,1-alpha,0-development,
// bbb is build number for non-releases
// V1.12b3 would be: 0x01122003
// V2.00a2 would be: 0x02001002
// V1.01 would be: 0x01013000
// Options values for IrOpen
// BDDDxxxx xxxxxxxx xxxxxxxx xxxSSSSS
// Where B=background mode, DDD=disconnect timeout, SSSSS=speed
#define irOpenOptBackground 0x80000000 // Unsupported background task use
#define irOpenOptDisconnect3 0x10000000 // sets amount of time in seconds
#define irOpenOptDisconnect8 0x20000000 // after no activity from other
#define irOpenOptDisconnect12 0x30000000 // device before disconnect is
#define irOpenOptDisconnect16 0x40000000 // initiated.
#define irOpenOptDisconnect20 0x50000000 // default is 40 secs
#define irOpenOptDisconnect25 0x60000000
#define irOpenOptDisconnect30 0x70000000
#define irOpenOptDisconnect40 0x00000000
#define irOpenOptSpeed115200 0x0000003F // sets max negotiated baud rate
#define irOpenOptSpeed57600 0x0000001F // default is 57600
#define irOpenOptSpeed38400 0x0000000F
#define irOpenOptSpeed19200 0x00000007
#define irOpenOptSpeed9600 0x00000003
// Option codes for ExgLibControl
// These options are all unique to the Ir transport
#define irGetScanningMode (exgLibCtlSpecificOp | 1) // returns scanning enabled
#define irSetScanningMode (exgLibCtlSpecificOp | 2) // en/disables ir scanning mode
#define irGetStatistics (exgLibCtlSpecificOp | 3) // returns performance stats
#define irSetSerialMode (exgLibCtlSpecificOp | 4) // sets driver to use direct serial
#define irSetBaudMask (exgLibCtlSpecificOp | 5) // set possible baud rates (irOpenOpts)
#define irSetSupported (exgLibCtlSpecificOp | 6) // disables the ir not supported dialog
#define irSuppressScanning (exgLibCtlSpecificOp | 7) // temporarily disabled beam receive
#define irRestoreScanning (exgLibCtlSpecificOp | 8) // restore beam receive state
// structure returned by irGetStatistics
typedef struct {
UInt16 recLineErrors; // # of serial errors since library opend
UInt16 crcErrors; // # of crc errors ...
} IrStatsType;
//-----------------------------------------------------------------------------
// Ir library call ID's.
//-----------------------------------------------------------------------------
// These start after the old exchange library interface. If we add any more exchange
// library traps, we'll have to separate the publicly accessible "IR Library" and the
// IrOBEX exchange library.
#define irLibTrapBind (sysLibTrapCustom+10)
#define irLibTrapUnBind (sysLibTrapCustom+11)
#define irLibTrapDiscoverReq (sysLibTrapCustom+12)
#define irLibTrapConnectIrLap (sysLibTrapCustom+13)
#define irLibTrapDisconnectIrLap (sysLibTrapCustom+14)
#define irLibTrapConnectReq (sysLibTrapCustom+15)
#define irLibTrapConnectRsp (sysLibTrapCustom+16)
#define irLibTrapDataReq (sysLibTrapCustom+17)
#define irLibTrapLocalBusy (sysLibTrapCustom+18)
#define irLibTrapMaxTxSize (sysLibTrapCustom+19)
#define irLibTrapMaxRxSize (sysLibTrapCustom+20)
#define irLibTrapSetDeviceInfo (sysLibTrapCustom+21)
#define irLibTrapIsNoProgress (sysLibTrapCustom+22)
#define irLibTrapIsRemoteBusy (sysLibTrapCustom+23)
#define irLibTrapIsMediaBusy (sysLibTrapCustom+24)
#define irLibTrapIsIrLapConnected (sysLibTrapCustom+25)
#define irLibTrapTestReq (sysLibTrapCustom+26)
#define irLibTrapIAS_Add (sysLibTrapCustom+27)
#define irLibTrapIAS_Query (sysLibTrapCustom+28)
#define irLibTrapIAS_SetDeviceName (sysLibTrapCustom+29)
#define irLibTrapIAS_Next (sysLibTrapCustom+30)
#define irLibTrapIrOpen (sysLibTrapCustom+31)
#define irLibTrapHandleEvent (sysLibTrapCustom+32)
#define irLibTrapWaitForEvent (sysLibTrapCustom+33)
#define irLibTrapLast (sysLibTrapCustom+34)
/****************************************************************************
*
* Types and Constants
*
****************************************************************************/
/* Maximum size of packet that can be sent at connect time (ConnectReq or
* ConnectRsp) for IrLMP and Tiny TP connections.
*/
#define IR_MAX_CON_PACKET 60
#define IR_MAX_TTP_CON_PACKET 52
#define IR_MAX_TEST_PACKET 376
#define IR_MAX_DEVICE_INFO 23
/* Size of the device list used in discovery process
*/
#define IR_DEVICE_LIST_SIZE 6
/*---------------------------------------------------------------------------
*
* Maximum size of the XID info field used in a discovery frame. The XID
* info field contains the device hints and nickname.
*/
#define IR_MAX_XID_LEN 23
/* Maximum allowed LSAP in IrLMP
*/
#define IR_MAX_LSAP 0x6f
/* The following are used to access the hint bits in the first byte
* of the Device Info field of an XID frame (IrDeviceInfo).
*/
#define IR_HINT_PNP 0x01
#define IR_HINT_PDA 0x02
#define IR_HINT_COMPUTER 0x04
#define IR_HINT_PRINTER 0x08
#define IR_HINT_MODEM 0x10
#define IR_HINT_FAX 0x20
#define IR_HINT_LAN 0x40
#define IR_HINT_EXT 0x80
/* The following are used to access the hint bits in the second byte
* of the Device Info field of an XID frame (IrDeviceInfo). Note
* that LM_HINT_EXT works for all hint bytes.
*/
#define IR_HINT_TELEPHONY 0x01
#define IR_HINT_FILE 0x02
#define IR_HINT_IRCOMM 0x04
#define IR_HINT_MESSAGE 0x08
#define IR_HINT_HTTP 0x10
#define IR_HINT_OBEX 0x20
/*---------------------------------------------------------------------------
*
* Status of a stack operation or of the stack.
*/
typedef UInt8 IrStatus;
#define IR_STATUS_SUCCESS 0 /* Successful and complete */
#define IR_STATUS_FAILED 1 /* Operation failed */
#define IR_STATUS_PENDING 2 /* Successfully started but pending */
#define IR_STATUS_DISCONNECT 3 /* Link disconnected */
#define IR_STATUS_NO_IRLAP 4 /* No IrLAP Connection exists */
#define IR_STATUS_MEDIA_BUSY 5 /* IR Media is busy */
#define IR_STATUS_MEDIA_NOT_BUSY 6 /* IR Media is not busy */
#define IR_STATUS_NO_PROGRESS 7 /* IrLAP not making progress */
#define IR_STATUS_LINK_OK 8 /* No progress condition cleared */
// #define IR_STATUS_RESERVED1 9 /* Reserved for future use */
// #define IR_STATUS_RESERVED2 10 /* Reserved for future use */
/*---------------------------------------------------------------------------
*
* Character set for user strings. These are definitions for the character
* set in Nicknames and in IAS attributes of type User String.
*/
typedef UInt8 IrCharSet;
#define IR_CHAR_ASCII 0
#define IR_CHAR_ISO_8859_1 1
#define IR_CHAR_ISO_8859_2 2
#define IR_CHAR_ISO_8859_3 3
#define IR_CHAR_ISO_8859_4 4
#define IR_CHAR_ISO_8859_5 5
#define IR_CHAR_ISO_8859_6 6
#define IR_CHAR_ISO_8859_7 7
#define IR_CHAR_ISO_8859_8 8
#define IR_CHAR_ISO_8859_9 9
#define IR_CHAR_UNICODE 0xff
/*---------------------------------------------------------------------------
*
* All indication and confirmations are sent to the IrLMP/TTP connections
* through one callback function. The types of the events passed are
* defined below. Applications should ignore events listed as "reserved"
* as well as events not listed at all, since we may add more events in
* future versions of the IR library.
*/
typedef UInt8 IrEvent;
#define LEVENT_LM_CON_IND 0
#define LEVENT_LM_DISCON_IND 1
#define LEVENT_DATA_IND 2
#define LEVENT_PACKET_HANDLED 3
#define LEVENT_LAP_CON_IND 4
#define LEVENT_LAP_DISCON_IND 5
#define LEVENT_DISCOVERY_CNF 6
#define LEVENT_LAP_CON_CNF 7
#define LEVENT_LM_CON_CNF 8
#define LEVENT_STATUS_IND 9
#define LEVENT_TEST_IND 10
#define LEVENT_TEST_CNF 11
//#define LEVENT_RESERVED1 12 // reserved for future use
#define LEVENT_LM_SEND_IND 13 // added in Palm OS 4.0
/* LmConnect flags - used internally
*/
#define LCON_FLAGS_TTP 0x02
/****************************************************************************
*
* IAS Types and Constants
*
****************************************************************************/
/* Maximum size of a query that observes the IrDA Lite rules
*/
#define IR_MAX_QUERY_LEN 61
/* Maximum values for IAS fields. IR_MAX_IAS_NAME is the maximum allowable
* size for IAS Object names and Attribute names.
*/
#define IR_MAX_IAS_NAME 60
#define IR_MAX_ATTRIBUTES 255
/* Maximum size of an IAS attribute that fits within the IrDA Lite rules.
* Even though attribute values can be larger IrDA Lite highly recommends
* that the total size of an attribute value fit within one 64 byte packet
* thus, the allowable size is 56 bytes or less. This size is enforced by the
* code.
*/
#define IR_MAX_IAS_ATTR_SIZE 56
/* Type of the IAS entry. This is the value returned for type when parsing
* the results buffer after a successful IAS Query.
*/
#define IAS_ATTRIB_MISSING 0
#define IAS_ATTRIB_INTEGER 1
#define IAS_ATTRIB_OCTET_STRING 2
#define IAS_ATTRIB_USER_STRING 3
#define IAS_ATTRIB_UNDEFINED 0xff
/* Ias Return Codes. One of these values will be found in the IAS Query
* structure in the retCode field after a successful IAS Query.
*/
#define IAS_RET_SUCCESS 0 /* Query operation is successful */
#define IAS_RET_NO_SUCH_CLASS 1 /* Query failed no such class exists */
#define IAS_RET_NO_SUCH_ATTRIB 2 /* Query failed no such attribute exists */
#define IAS_RET_UNSUPPORTED 0xff /* Query failed operation is unsupported */
/* IAS Get Value By Class opcode number
*/
#define IAS_GET_VALUE_BY_CLASS 4
// Macros used in accessing ias structures
#define IasGetU16(ptr) (UInt16)( ((UInt16)(*((UInt8*)ptr) << 8)) | \
((UInt16) (*((UInt8*)ptr+1))))
#define IasGetU32(ptr) (UInt32)( ((UInt32)(*((UInt8*)ptr)) << 24) | \
((UInt32)(*((UInt8*)ptr+1)) << 16) | \
((UInt32)(*((UInt8*)ptr+2)) << 8) | \
((UInt32)(*((UInt8*)ptr+3))) )
/****************************************************************************
*
* Data Structures
*
****************************************************************************/
// stack functions use a diferent type for booleans
typedef int BOOL;
/*---------------------------------------------------------------------------
*
* ListEntry is used internally by the stack
*/
typedef struct _ListEntry
{
struct _ListEntry *Flink;
struct _ListEntry *Blink;
} ListEntry;
/* Forward declaration of the IrConnect structure
*/
typedef struct _hconnect IrConnect;
/*---------------------------------------------------------------------------
*
* Packet Structure for sending IrDA packets.
*/
typedef struct _IrPacket {
/* The node field must be the first field in the structure. It is used
* internally by the stack
*/
ListEntry node;
/* The buff field is used to point to a buffer of data to send and len
* field indicates the number of bytes in buff.
*/
UInt8 * buff;
UInt16 len;
/*================== For Internal Use Only =======================
*
* The following is used internally by the stack and should not be
* modified by the upper layer.
*
*==================================================================*/
IrConnect* origin; /* Pointer to connection which owns packet */
UInt8 headerLen; /* Number of bytes in the header */
UInt8 header[14]; /* Storage for the header */
UInt8 reserved; /* Explicitly account for 16-bit alignment padding */
} IrPacket;
/*---------------------------------------------------------------------------
*
* 32-bit Device Address
*/
typedef union {
UInt8 u8[4];
UInt16 u16[2];
UInt32 u32;
} IrDeviceAddr;
/*---------------------------------------------------------------------------
*
* The information returned for each device discovered during discovery.
* The maximum size of the xid field is 23. This holds the hints and
* the nickname.
*/
typedef struct {
IrDeviceAddr hDevice; /* 32-bit address of device */
UInt8 len; /* Length of xid */
UInt8 xid[IR_MAX_XID_LEN];/* XID information */
} IrDeviceInfo;
/*---------------------------------------------------------------------------
*
* List of Device Discovery info elements.
*/
typedef struct {
UInt8 nItems; /* Number items in the list */
UInt8 reserved; /* Explicitly account for 16-bit alignment padding */
IrDeviceInfo dev[IR_DEVICE_LIST_SIZE]; /* Fixed size in IrDA Lite */
} IrDeviceList;
/*---------------------------------------------------------------------------
*
* Callback Parameter Structure is used to pass information from the stack
* to the upper layer of the stack (application). Not all fields are valid
* at any given time. The type of event determines which fields are valid.
*/
typedef struct {
IrEvent event; /* Event causing callback */
UInt8 reserved1; /* Explicitly account for 16-bit alignment padding */
UInt8 * rxBuff; /* Receive buffer already advanced to app data */
UInt16 rxLen; /* Length of data in receive buffer */
IrPacket* packet; /* Pointer to packet being returned */
IrDeviceList* deviceList; /* Pointer to discovery device list */
IrStatus status; /* Status of stack */
UInt8 reserved2; /* Explicitly account for 16-bit alignment padding */
} IrCallBackParms;
/* The definitions for the callback function is given below. How the
* callback function is used in conjuction with the stack functions is
* given below in the Callback Reference.
*/
typedef void (*IrCallBack)(IrConnect*, IrCallBackParms*);
/*---------------------------------------------------------------------------
*
* Definition of IrConnect structure. This structure is used to manage an
* IrLMP or Tiny TP connection.
*/
typedef struct _hconnect {
UInt8 lLsap; /* Local LSAP this connection will listen on */
UInt8 rLsap; /* Remote Lsap */
/*================== For Internal Use Only =======================
*
* The following is used internally by the stack and should not be
* modified by the user.
*
*==================================================================*/
UInt8 flags; /* Flags containing state, type, etc. */
UInt8 reserved; /* Explicitly account for 16-bit alignment padding */
IrCallBack callBack; /* Pointer to callback function */
/* Tiny TP fields */
IrPacket packet; /* Packet for internal use */
ListEntry packets; /* List of packets to send */
UInt16 sendCredit; /* Amount of credit from peer */
UInt8 availCredit; /* Amount of credit to give to peer */
UInt8 dataOff; /* Amount of data less than IrLAP size */
} _hconnect;
/****************************************************************************
*
* IAS Data Strucutres
*
****************************************************************************/
/*---------------------------------------------------------------------------
*
* The LmIasAttribute is a strucutre that holds one attribute of an IAS
* object.
*/
typedef struct _IrIasAttribute {
UInt8 * name; /* Pointer to name of attribute */
UInt8 len; /* Length of attribute name */
UInt8 reserved1; /* Explicitly account for 16-bit alignment padding */
UInt8 * value; /* Hardcode value (see below) */
UInt8 valLen; /* Length of the value. */
UInt8 reserved2; /* Explicitly account for 16-bit alignment padding */
} IrIasAttribute;
/* The value field of the IrIasAttribute structure is a hard coded string
* which represents the actual bytes sent over the IR for the attribute
* value. The value field contains all the bytes which represent an
* attribute value based on the transmission format described in section
* 4.3 of the IrLMP specification. An example of a user string is given
* below.
*
* User String:
* 1 byte type, 1 byte Char set, 1 byte length, length byte string
*
* Example of an user string "Hello World" in ASCII
*
* U8 helloString[] = {
* IAS_ATTRIB_USER_STRING,IR_CHAR_ASCII,11,
* 'H','e','l','l','o',' ','W','o','r','l','d'
* };
*/
/*---------------------------------------------------------------------------
*
* The LmIasObject is storage for an IAS object managed by the local
* IAS server.
*/
typedef struct _IrIasObject {
UInt8 * name; /* Pointer to name of object */
UInt8 len; /* Length of object name */
UInt8 nAttribs; /* Number of attributes */
IrIasAttribute* attribs; /* A pointer to an array of attributes */
} IrIasObject;
/*---------------------------------------------------------------------------
*
* Forward declaration of a structure used for performing IAS Queries so
* that a callback type can be defined for use in the structure.
*/
typedef struct _IrIasQuery IrIasQuery;
typedef void (*IrIasQueryCallBack)(IrStatus);
/*---------------------------------------------------------------------------
*
* Actual definition of the IrIasQuery structure.
*/
typedef struct _IrIasQuery
{
/* Query fields. The query buffer contains the class name and class
* attribute whose value is being queried it is as follows:
*
* 1 byte - Length of class name
* "Length" bytes - class name
* 1 byte - length of attribute name
* "Length" bytes - attribute name
*
* queryLen - contains the total number of byte in the query
*/
UInt8 queryLen; /* Total length of the query */
UInt8 reserved; /* Explicitly account for 16-bit alignment padding */
UInt8 * queryBuf; /* Points to buffer containing the query */
/* Fields for the query result */
UInt16 resultBufSize; /* Size of the result buffer */
UInt16 resultLen; /* Actual number of bytes in the result buffer */
UInt16 listLen; /* Number of items in the result list. */
UInt16 offset; /* Offset into results buffer */
UInt8 retCode; /* Return code of operation */
UInt8 overFlow; /* Set TRUE if result exceeded result buffer size */
UInt8 * result; /* Pointer to buffer containing result; */
/* Pointer to callback function */
IrIasQueryCallBack callBack;
} _IrIasQuery;
/****************************************************************************
*
* Function Reference
*
****************************************************************************/
#ifdef __cplusplus
extern "C" {
#endif
/*---------------------------------------------------------------------------
*
* Prototype: Err IrOpen(UInt16 refnum, UInt32 options)
*
* Description: Open the Ir library. This allocates the global memory
* for the ir stack and reserves and system resources it
* requires. This must be done before any other ir libary
* calls are made.
*
* Parameters: refNum - ir library refNum
*
* options - open options flags
*
*
* Return Values: zero if no error or exgErrStackInit
*
*/
Err IrOpen(UInt16 refnum, UInt32 options)
SYS_TRAP(irLibTrapIrOpen);
/*---------------------------------------------------------------------------
*
* Prototype: Err IrClose(UInt16 refnum)
*
* Description: Close the Ir library. This releases the global memory
* for the ir stack and any system resources it uses.
* This must be called when an application is done with the
* ir library.
*
* Parameters: refNum - ir library refNum
*
* Return Values: zero if no error
*
*/
#if EMULATION_LEVEL == EMULATION_NONE
Err IrClose(UInt16 refnum)
SYS_TRAP(sysLibTrapClose);
#else
// IrClose does not actually exist in the emulator so map it to ExgLibClose
#define IrClose(refNum) ExgLibClose(refNum)
#endif
/*---------------------------------------------------------------------------
*
* Prototype: IrStatus IrBind(UInt16 refNum,IrConnect* con,
* IrCallback callBack)
*
* Description: Obtain a local LSAP selector and register the connection
* with the protocol stack. This IrConnect structure will be
* initialized. Any values stored in the structure will be
* lost. The assigned LSAP will be in the lLsap field of con.
* The type of the connection will be set to IrLMP. The
* IrConnect must be bound to the stack before it can be used.
*
* Parameters: refNum - ir library refNum
*
* con - pointer to IrConnect structure.
*
* callBack - pointer to a callBack function that handles
* the indications and confirmation from the protocol stack.
*
* Return Values: IR_STATUS_SUCCESS - operation completed successfully.
* The assigned LSAP can be found in con->lLsap.
*
* IR_STATUS_FAILED - the operation failed for one of the
* following reasons:
* - con is already bound to the stack
* - no room in the connection table
*/
IrStatus IrBind(UInt16 refNum,IrConnect* con, IrCallBack callBack)
SYS_TRAP(irLibTrapBind);
/*---------------------------------------------------------------------------
*
* Prototype: IrStatus IrUnbind(UInt16 refNum,IrConnect* con)
*
* Description: Unbind the IrConnect structure from the protocol stack
* freeing it's LSAP selector.
*
* Parameters: refNum - ir library refNum
*
* con - pointer to IrConnect structure to unbind
*
* Return Values: IR_STATUS_SUCCESS - operation competed succesfully
*
* IR_STATUS_FAILED - operation failed
* either because the IrConnect structure was not bound
* or the lLsap field contained an invalid number.
*/
IrStatus IrUnbind(UInt16 refNum,IrConnect* con)
SYS_TRAP(irLibTrapUnBind);
/*---------------------------------------------------------------------------
*
* Prototype: IrStatus IrDiscoverReq(UInt16 refNum,IrConnect* con)
*
* Description: Start an IrLMP discovery process. The result will be
* signaled via the callBack function specified in the
* IrConnect structure with the event LEVENT_DISCOVERY_CNF.
* Only one discovery can be invoked at a time.
*
* Parameters: refNum - ir library refNum
*
* con - pointer to a bound IrConnect structure.
*
* Return Values: IR_STATUS_PENDING - operation is started successfully
* result returned via callback.
*
* IR_STATUS_MEDIA_BUSY - operation failed because the media
* is busy. Media busy is caused by one of the following
* reasons:
* - Other devices are using the IR medium.
* - A discovery process is already in progress
* - An IrLAP connection exists.
*
* IR_STATUS_FAILED - operation failed
* because the IrConnect structure is not bound to the stack.
*/
IrStatus IrDiscoverReq(UInt16 refNum,IrConnect* con)
SYS_TRAP(irLibTrapDiscoverReq);
/*---------------------------------------------------------------------------
*
* Prototype: IrStatus IrConnectIrLap(UInt16 refNum,IrDeviceAddr deviceAddr)
*
* Description: Start an IrLAP connection. The result is signaled to all
* bound IrConnect structures via the callback function. The
* callback event is LEVENT_LAP_CON_CNF if successful or
* LEVENT_LAP_DISCON_IND if unsuccessful.
*
* Parameters:: refNum - ir library refNum
*
* deviceAddr - 32-bit address of device to which connection
* should be made.
*
* Return Values: IR_STATUS_PENDING - operation started successfully and
* callback will be called with result.
*
* IR_STATUS_MEDIA_BUSY - operation failed to start because
* the IR media is busy. Media busy is caused by one of the
* following reasons:
* - Other devices are using the IR medium.
* - An IrLAP connection already exists
* - A discovery process is in progress
*/
IrStatus IrConnectIrLap(UInt16 refNum,IrDeviceAddr deviceAddr)
SYS_TRAP(irLibTrapConnectIrLap);
/*---------------------------------------------------------------------------
*
* Prototype: IrStatus IrDisconnectIrLap(UInt16 refNum)
*
* Description: Disconnect the IrLAP connection. When the IrLAP connection
* goes down the callback of all bound IrConnect structures
* is called with event LEVENT_LAP_DISCON_IND.
*
* Parameters: refNum - ir library refNum
*
* Return Values: IR_STATUS_PENDING - operation started successfully and
* the all bound IrConnect structures will be called back
* when complete.
*
* IR_STATUS_NO_IRLAP - operation failed because no IrLAP
* connection exists.
*/
IrStatus IrDisconnectIrLap(UInt16 refNum)
SYS_TRAP(irLibTrapDisconnectIrLap);
/*---------------------------------------------------------------------------
*
* Prototype: IrStatus IrConnectReq(UInt16 refNum,
* IrConnect* con,
* IrPacket* packet,
* UInt8 credit);
*
* Description: Request an IrLMP or TinyTP connection. The result is
* is signaled via the callback specified in the IrConnect
* structure. The callback event is LEVENT_LM_CON_CNF
* indicates that the connection is up and LEVENT_LM_DISCON_IND
* indicates that the connection failed. Before calling this
* function the fields in the con structure must be properly
* set.
*
* Parameters: refNum - ir library refNum
*
* con - pointer to IrConnect structure for handing the
* the connection. The rLsap field must contain the LSAP
* selector for the peer on the other device. Also the type
* of the connection must be set. Use IR_SetConTypeLMP() to
* set the type to an IrLMP conneciton or IR_SetConTypeTTP()
* to set the type to a Tiny TP connection.
*
* packet - pointer to a packet that contains connection data.
* Even if no connection data is needed the packet must point
* to a valid IrPacket structure. The packet will be returned
* via the callback with the LEVENT_PACKET_HANDLED event if no
* errors occur. The maximum size of the packet is
* IR_MAX_CON_PACKET for an IrLMP connection or
* IR_MAX_TTP_CON_PACKET for a Tiny TP connection.
*
* credit - initial amount of credit advanced to the other side.
* Must be less than 127. It is ANDed with 0x7f so if it is
* greater than 127 unexpected results will occur. This
* parameter is ignored if the Connection is an IrLMP connection.
*
* Return Values: IR_STATUS_PENDING - operation has been started successfully
* and the result will be returned via the callback function with
* the event LEVENT_LM_CON_CNF if the connection is made or
* LEVENT_LM_DISCON_IND if connection fails. The packet is returned
* via the callback with the event LEVENT_PACKET_HANDLED.
*
* IR_STATUS_FAILED - operation failed because of one of the
* reasons below. Note that the packet is
* available immediately:
* - Connection is busy (already involved in a connection)
* - IrConnect structure is not bound to the stack
* - Packet size exceeds maximum allowed.
*
* IR_STATUS_NO_IRLAP - operation failed because there is no
* IrLAP connection (the packet is available immediately).
*/
IrStatus IrConnectReq(UInt16 refNum,IrConnect* con, IrPacket* packet, UInt8 credit)
SYS_TRAP(irLibTrapConnectReq);
/*---------------------------------------------------------------------------
*
* Prototype: IrStatus IrConnectRsp(UInt16 refNum,
* IrConnect* con,
* IrPacket* packet,
* UInt8 credit);
*
* Description: Accept an incoming connection that has been signaled via
* the callback with the event LEVENT_LM_CON_IND. IR_ConnectRsp
* can be called during the callback or later to accept
* the connection. The type of the connection must already have
* been set to IrLMP or Tiny TP before LEVENT_LM_CON_IND event.
*
* Parameters: refNum - ir library refNum
*
* con - pointer to IrConnect structure to managed connection.
*
* packet - pointer to a packet that contains connection data.
* Even if no connection data is needed the packet must point
* to a valid IrPacket structure. The packet will be returned
* via the callback with the LEVENT_PACKET_HANDLED event if no
* errors occur. The maximum size of the packet is
* IR_MAX_CON_PACKET for an IrLMP connection or
* IR_MAX_TTP_CON_PACKET for a Tiny TP connection.
*
* credit - initial amount of credit advanced to the other side.
* Must be less than 127. It is ANDed with 0x7f so if it is
* greater than 127 unexpected results will occur. This
* parameter is ignored if the Connection is an IrLMP connection.
*
* Return Values: IR_STATUS_PENDING - response has been started successfully
* and the packet is returned via the callback with the event
* LEVENT_PACKET_HANDLED.
*
* IR_STATUS_FAILED - operation failed because of one of the
* reasons below . Note that the packet is
* available immediately:
* - Connection is not in the proper state to require a
* response.
* - IrConnect structure is not bound to the stack
* - Packet size exceeds maximum allowed.
*
* IR_STATUS_NO_IRLAP - operation failed because there is no
* IrLAP connection (Packet is available immediately).
*/
IrStatus IrConnectRsp(UInt16 refNum,IrConnect* con,IrPacket* packet, UInt8 credit)
SYS_TRAP(irLibTrapConnectRsp);
/*---------------------------------------------------------------------------
*
* Prototype: IrStatus IR_DataReq(IrConnect* con,
* IrPacket* packet);
*
* Description: Send a data packet. The packet is owned by the stack until
* it is returned via the callback with event
* LEVENT_PACKET_HANDLED. The largest packet that can be sent
* is found by calling IR_MaxTxSize().
*
* Parameters: refNum - ir library refNum
*
* con - pointer to IrConnect structure that specifies the
* connection over which the packet should be sent.
*
* packet - pointer to a packet that contains data to send.
* The packet should exceed the max size found with
* IR_MaxTxSize().
*
* Return Values: IR_STATUS_PENDING - packet has been queued by the stack.
* The packet will be returned via the callback with event
* LEVENT_PACKET_HANDLED.
*
*
* IR_STATUS_FAILED - operation failed and packet is available
* immediately. Operation failed for one of the following
* reasons:
* - IrConnect structure is not bound to the stack (error
* checking only)
* - packet exceeds the maximum size (error checking only)
* - IrConnect does not represent an active connection
*/
IrStatus IrDataReq(UInt16 refNum,IrConnect* con, IrPacket* packet)
SYS_TRAP(irLibTrapDataReq);
/*---------------------------------------------------------------------------
*
* Prototype: void IrAdvanceCredit(IrConnect* con,
* UInt8 credit);
*
* Description: Advance credit to the other side. The total amount of
* credit should not exceed 127. The credit passed by this
* function is added to existing available credit which is
* the number that must not exceed 127. This function
* only makes sense for a Tiny TP connection.
*
* Parameters: con - pointer to IrConnect structure representing
* connection to which credit is advanced.
*
* credit - number of credit to advance.
*
* Return Values: void
*/
#define IrAdvanceCredit(con, credit) {\
(con)->availCredit += (credit);\
}
/*---------------------------------------------------------------------------
*
* Prototype: void IrLocalBusy(UInt16 refNum,BOOL flag);
*
* Description: Set the IrLAP local busy flag. If local busy is set to true
* then the local IrLAP layer will send RNR frames to the other
* side indicating it cannot receive any more data. If the
* local busy is set to false IrLAP is ready to receive frames.
* This function should not be used when using Tiny TP or when
* multiple connections exist. It takes affect the next time
* IrLAP sends an RR frame. If IrLAP has data to send the data
* will be sent first so it should be used carefully.
*
* Parameters: refNum - ir library refNum
*
* flag - value (true or false) to set IrLAP's local busy flag.
*
* Return Values: void
*/
void IrLocalBusy(UInt16 refNum,BOOL flag)
SYS_TRAP(irLibTrapLocalBusy);
/*---------------------------------------------------------------------------
*
* Prototype: void IrSetConTypeTTP(IrConnect* con)
*
* Description: Set the type of the connection to Tiny TP. This function
* must be called after the IrConnect structure is bound to
* the stack.
*
* Parameters: con - pointer to IrConnect structure.
*
* Return Values: void
*/
#define IrSetConTypeTTP(con) { \
((con)->flags |= LCON_FLAGS_TTP); \
}
/*---------------------------------------------------------------------------
*
* Prototype: void IrSetConTypeLMP(IrConnect* con)
*
* Description: Set the type of the connection to IrLMP. This function
* must be called after the IrConnect structure is bound to
* the stack.
*
* Parameters: con - pointer to IrConnect structure.
*
* Return Values: void
*/
#define IrSetConTypeLMP(con) { \
((con)->flags &= ~LCON_FLAGS_TTP); \
}
/*---------------------------------------------------------------------------
*
* Prototype: UInt16 IrMaxTxSize(UInt16 refNum,IrConnect* con);
*
* Description: Returns the maximum size allowed for a transmit packet.
* The value returned is only valid for active connections.
* The maximum size will vary for each connection and is based
* on the negotiated IrLAP parameters and the type of the
* connection.
*
* Parameters: refNum - ir library refNum
*
* con - pointer to IrConnect structure which represents
* an active connection.
*
* Return Values: Maxmum number of bytes for a transmit packet.
*/
UInt16 IrMaxTxSize(UInt16 refNum,IrConnect* con)
SYS_TRAP(irLibTrapMaxTxSize);
/*---------------------------------------------------------------------------
*
* Prototype: IrMaxRxSize(UInt16 refNum,IrConnect* con);
*
* Description: Returns the maximum size buffer that can be sent by the
* the other device. The value returned is only valid for
* active connections. The maximum size will vary for
* each connection and is based on the negotiated IrLAP
* parameters and the type of the connection.
*
* Parameters: refNum - ir library refNum
*
* con - pointer to IrConnect structure which represents
* an active connection.
*
* Return Values: Maxmum number of bytes that can be sent by the other
* device (maximum bytes that can be received).
*/
UInt16 IrMaxRxSize(UInt16 refNum,IrConnect* con)
SYS_TRAP(irLibTrapMaxRxSize);
/*---------------------------------------------------------------------------
*
* Prototype: IrStatus IrSetDeviceInfo(UInt16 refNum,UInt8 *info,UInt8 len);
*
* Description: Set the XID info string used during discovery to the given
* string and length. The XID info string contains hints and
* the nickname of the device. The size cannot exceed
* IR_MAX_DEVICE_INFO bytes.
*
* Parameters: refNum - ir library refNum
*
* info - pointer to array of bytes
*
* len - number of bytes pointed to by info
*
* Return Values: IR_STATUS_SUCCESS - operation is successful.
*
* IR_STATUS_FAILED - operation failed because info is too
* big (Error Checking only).
*/
IrStatus IrSetDeviceInfo(UInt16 refNum,UInt8 *info, UInt8 len)
SYS_TRAP(irLibTrapSetDeviceInfo);
/*---------------------------------------------------------------------------
*
* Prototype: BOOL IrIsNoProgress(UInt16 refNum);
*
* Description: Return true if IrLAP is not making progress otherwise
* return false (this is an optional function).
*
* Parameters: refNum - ir library refNum
*
* Return Values: true if IrLAP is not making progress, false otherwise.
*/
BOOL IrIsNoProgress(UInt16 refNum)
SYS_TRAP(irLibTrapIsNoProgress);
/*---------------------------------------------------------------------------
*
* Prototype: Boolean IrIsRemoteBusy(UInt16 refNum)
*
* Description: Return true if the other device's IrLAP is busy otherwise
* return false (this is an optional function).
*
* Parameters: refNum - ir library refNum
*
* Return Values: true if the other device's IrLAP is busy, false otherwise.
*/
BOOL IrIsRemoteBusy(UInt16 refNum)
SYS_TRAP(irLibTrapIsRemoteBusy);
/*---------------------------------------------------------------------------
*
* Prototype: BOOL IrIsMediaBusy(UInt16 refNum);
*
* Description: Return true if the IR media is busy. Otherwise return false
* (this is an optional function).
*
* Parameters: refNum - ir library refNum
*
* Return Values: true if IR media is busy, false otherwise.
*/
BOOL IrIsMediaBusy(UInt16 refNum)
SYS_TRAP(irLibTrapIsMediaBusy);
/*---------------------------------------------------------------------------
*
* Prototype: BOOL IrIsIrLapConnected(UInt16 refNum);
*
* Description: Return true if an IrLAP connection exists (this is an
* optional function). Only available if IR_IS_LAP_FUNCS is
* defined.
*
* Parameters: refNum - ir library refNum
*
* Return Values: true if IrLAP is connected, false otherwise.
*/
BOOL IrIsIrLapConnected(UInt16 refNum)
SYS_TRAP(irLibTrapIsIrLapConnected);
/*---------------------------------------------------------------------------
*
* Prototype: IrStatus IR_TestReq(IrDeviceAddr devAddr,
* IrConnect* con,
* IrPacket* packet)
*
* Description: Request a TEST command frame be sent in the NDM state. The
* result is signaled via the callback specified in the
* IrConnect structure. The callback event is LEVENT_TEST_CNF
* and the status field indates the result of the operation.
* IR_STATUS_SUCCESS indicates success and IR_STATUS_FAILED
* indicates no response was received. A packet must be passed
* containing the data to send in the TEST frame. The packet
* is returned when the LEVENT_TEST_CNF event is given.
*
*
* Parameters: refNum - ir library refNum
*
* devAddr - device address of device where TEST will be
* sent. This address is not checked so it can be the
* broadcast address or 0.
*
* con - pointer to IrConnect structure specifying the
* callback function to call to report the result.
*
* packet - pointer to a packet that contains the data to
* send in the TEST command packet. The maximum size data
* that can be sent is IR_MAX_TEST_PACKET. Even if no
* data is to be sent a valid packet must be passed.
*
*
* Return Values: IR_STATUS_PENDING - operation has been started successfully
* and the result will be returned via the callback function with
* the event LEVENT_TEST_CNF. This is also the indication
* returning the packet.
*
* IR_STATUS_FAILED - operation failed because of one of the
* reasons below. Note that the packet is
* available immediately:
* - IrConnect structure is not bound to the stack
* - Packet size exceeds maximum allowed.
*
* IR_STATUS_MEDIA_BUSY - operation failed because the media is
* busy or the stack is not in the NDM state (the packet is
* available immediately).
*/
IrStatus IrTestReq(UInt16 refNum,IrDeviceAddr devAddr, IrConnect* con, IrPacket* packet)
SYS_TRAP(irLibTrapTestReq);
/****************************************************************************
*
* Callback Reference
*
****************************************************************************/
/*---------------------------------------------------------------------------
*
* The stack calls the application via a callback function stored in each
* IrConnect structure. The callback function is called with a pointer to
* the IrConnect structure and a pointer to a parameter structure. The
* parameter structure contains an event field which indicates the reason
* the callback is called and other parameters which have meaning based
* on the event.
*
* The meaning of the events are as follows:
*
* LEVENT_LM_CON_IND - Other device has initiated a connection. IR_ConnectRsp
* should be called to accept the connection. Any data associated with the
* connection request can be found using fields rxBuff and rxLen for the
* data pointer and length respectively.
*
* LEVENT_LM_DISCON_IND - The IrLMP/Tiny TP connection has been disconnected.
* Any data associated with the disconnect indication can be found using
* fields rxBuff and rxLen for the data pointer and length respectively.
*
* LEVENT_DATA_IND - Data has been received. The received data is accessed
* using fields rxBuff and rxLen;
*
* LEVENT_PACKET_HANDLED - A packet is being returned. A pointer to the
* packet exists in field packet.
*
* LEVENT_LAP_CON_IND - Indicates that the IrLAP connection has come up. The
* callback of all bound IrConnect structures is called.
*
* LEVENT_LAP_DISCON_IND - Indicates that the IrLAP connection has gone
* down. This means that all IrLMP connections are also down. A callback
* with event LEVENT_LM_CON_IND will not be given. The callback function
* of all bound IrConnect structures is called.
*
* LEVENT_DISCOVERY_CNF - Indicates the completion of a discovery operation.
* The field deviceList points to the discovery list.
*
* LEVENT_LAP_CON_CNF - The requested IrLAP connection has been made
* successfully. The callback function of all bound IrConnect structures
* is called.
*
* LEVENT_LM_CON_CNF - The requested IrLMP/Tiny TP connection has been made
* successfully. Connection data from the other side is found using fields
* rxBuff and rxLen.
*
* LEVENT_STATUS_IND - Indicates that a status event from the stack has
* occured. The status field indicates the status generating the event.
* Possible statuses are as follows. Note this event is optional:
* IR_STATUS_NO_PROGRESS - means that IrLAP has no progress for 3 seconds
* threshold time (e.g. beam is blocked).
*
* IR_STATUS_LINK_OK - indicates that the no progress condition has
* cleared.
*
* IR_STATUS_MEDIA_NOT_BUSY - indicates that the IR media has
* transitioned from busy to not busy.
*
* LEVENT_TEST_IND - Indicates that a TEST command frame has been received.
* A pointer to the received data is in rxBuff and rxLen. A pointer to the
* packet that will be sent in response to the test command is in the packet
* field. The packet is currently setup to respond with the same data sent
* in the command TEST frame. If different data is desired as a response
* then modify the packet structure. This event is sent to the callback
* function in all bound IrConnect structures. The IAS connections ignore
* this event.
*
* LEVENT_TEST_CNF - Indicates that a TEST command has completed. The status
* field indicates if the test was successful. IR_STATUS_SUCCESS indicates
* that operation was successful and the data in the test response can be
* found by using the rxBuff and rxLen fields. IR_STATUS_FAILED indicates
* that no TEST response was received. The packet passed to perform the test
* command is passed back in the packet field and is now available (no
* separate packet handled event will occur).
*/
/* The following functions are used to extract U16 and U32 bit numbers
* from an IAS result. Only IasGetU16 is used internal by the stack
* but they are part of some of the IAS Query result macros. To enable
* the function versions define IR_IAS_GET_AS_FUNC
*/
/*---------------------------------------------------------------------------
*
* Prototype: IrStatus IrIAS_Add(UInt16 refNum,IrIasObject* obj)
*
* Description: Add an IAS Object to the IAS Database. The Object is
* is not copied so the memory for the object must exist
* for as long as the object is in the data base. The
* IAS database is designed to only allow objects with unique
* class names. The error checking version checks for this.
* Class names and attributes names must not exceed
* IR_MAX_IAS_NAME. Also attribute values must not exceed
* IR_MAX_IAS_ATTR_SIZE.
*
* Parameters: refNum - ir library reference number
*
* obj - pointer to an IrIasObject structure.
*
* Return Values: IR_STATUS_SUCCESS - operation is successful.
*
* IR_STATUS_FAILED - operation failed for one of the
* following reasons:
* - No space in the data base (see irconfig.h to
* increase the size of the IAS database).
* - An entry with the same class name already exists.
* Error check only.
* - The attributes of the object violate the IrDA Lite
* rules (attribute name exceeds IR_MAX_IAS_NAME or
* attribute value exceeds IR_MAX_IAS_ATTR_SIZE).
* Error check only.
* - The class name exceeds IR_MAX_IAS_NAME. Error check
* only
*/
IrStatus IrIAS_Add(UInt16 refNum,IrIasObject* obj)
SYS_TRAP(irLibTrapIAS_Add);
/*---------------------------------------------------------------------------
*
* Prototype: IrStatus IrIAS_Query(UInt16 refNum,IrIasQuery* token)
*
* Description: Make an IAS query of another devices IAS database. An IrLAP
* connection must exist to the other device. The IAS query
* token must be initialized as described below. The result is
* signaled by calling the callback function whose pointer
* exists in the IrIasQuery structure. Only one Query can be
* made at a time.
*
* Parameters: refNum - ir library reference number
*
* token - pointer to an IrIasQuery structure initialized
* as follows:
* - pointer to a callback function in which the result will
* signaled.
* - result points to a buffer large enough to hold the
* result of the query.
* - resultBufSize is set to the size of the result buffer.
* - queryBuf must point to a valid query.
* - queryLen is set to the number of bytes in queryBuf.
* The length must not exceed IR_MAX_QUERY_LEN.
*
* Return Values: IR_STATUS_PENDING - operation is started successfully and
* the result will be signaled via the calback function.
*
* IR_STATUS_FAILED - operation failed for one of the
* following reasons (Error check only):
* - The query exceeds IR_MAX_QUERY_LEN.
* - The result field of token is 0.
* - The resultBuffSize field of token is 0.
* - The callback field of token is 0.
* - A query is already in progress.
*
* IR_STATUS_NO_IRLAP - operation failed because there is no
* IrLAP connection.
*/
IrStatus IrIAS_Query(UInt16 refNum,IrIasQuery* token)
SYS_TRAP(irLibTrapIAS_Query);
/*---------------------------------------------------------------------------
*
* Prototype: IrStatus IrIAS_SetDeviceName(UInt16 refNum,UInt8 *name, UInt8 len)
*
* Description: Set the value field of the device name attribute of the
* "Device" object in the IAS Database. This function is only
* available if IR_IAS_DEVICE_NAME is defined.
*
* Parameters: name - pointer to an IAS value field for the device name
* attribute of the device object. It includes the attribute
* type, character set and device name. This value field should
* be a constant and the pointer must remain valid until
* IRIAS_SetDeviceName() is called with another pointer.
*
* len - total length of the value field. Maximum size allowed
* is IR_MAX_IAS_ATTR_SIZE.
*
* Return Values: IR_STATUS_SUCCESS - operation is successful.
*
* IR_STATUS_FAILED - len is too big or the value field is not
* a valid user string (Error Checking only).
*/
IrStatus IrIAS_SetDeviceName(UInt16 refNum,UInt8 *name, UInt8 len)
SYS_TRAP(irLibTrapIAS_SetDeviceName);
/*---------------------------------------------------------------------------
*
* Below are some functions and macros for parsing the results buffer
* after a successfull IAS Query.
*/
/*---------------------------------------------------------------------------
*
* Prototype: void IrIAS_StartResult(IrIasQuery* token)
*
* Description: Put the internal pointer to the start of the
* result buffer.
*
* Parameters: token - pointer to an IrIasQuery structure
*
* Return Values: void
*/
#define IrIAS_StartResult(t) ((t)->offset = 0)
/*---------------------------------------------------------------------------
*
* Prototype: U16 IRIAS_GetObjectID(IrIasQuery* token)
*
* Description: Return the unique object ID of the current result item.
*
* Parameters: token - pointer to an IrIasQuery structure
*
* Return Values: object ID
*/
#define IrIAS_GetObjectID(t) IasGetU16((t)->result + (t)->offset)
/*---------------------------------------------------------------------------
*
* Prototype: U8 IrIAS_GetType(IrIasQuery* token)
*
* Description: Return the type of the current result item
*
* Parameters: token - pointer to an IrIasQuery structure
*
* Return Values: Type of result item such as IAS_ATTRIB_INTEGER,
* IAS_ATTRIB_OCTET_STRING or IAS_ATTRIB_USER_STRING.
*/
#define IrIAS_GetType(t) ((t)->result[(t)->offset + 2])
/*---------------------------------------------------------------------------
*
* Prototype: U32 IrIAS_GetInteger(IrIasQuery* token)
*
* Description: Return an integer value assuming that the current result
* item is of type IAS_ATTRIB_INTEGER (call IRIAS_GetType() to
* determine the type of the current result item).
*
* Parameters: token - pointer to an IrIasQuery structure
*
* Return Values: Integer value.
*/
#define IrIAS_GetInteger(t) IasGetU32((t)->result + (t)->offset + 3)
/*---------------------------------------------------------------------------
*
* Prototype: U8 IrIAS_GetIntLsap(IrIasQuery* token)
*
* Description: Return an integer value that represents an LSAP assuming
* that the current result item is of type IAS_ATTRIB_INTEGER
* (call IRIAS_GetType() to determine the type of the current
* result item). Usually integer values returned in a query
* are LSAP selectors.
*
* Parameters: token - pointer to an IrIasQuery structure
*
* Return Values: Integer value.
*/
#define IrIAS_GetIntLsap(t) ((t)->result[(t)->offset + 6])
/*---------------------------------------------------------------------------
*
* Prototype: U16 IrIAS_GetOctetStringLen(IrIasQuery* token)
*
* Description: Get the length of an octet string assuming that the current
* result item is of type IAS_ATTRIB_OCTET_STRING (call
* IRIAS_GetType() to determine the type of the current result
* item).
*
* Parameters: token - pointer to an IrIasQuery structure
*
* Return Values: Length of octet string
*/
#define IrIAS_GetOctetStringLen(t) IasGetU16((t)->result + (t)->offset + 3)
/*---------------------------------------------------------------------------
*
* Prototype: U8* IrIAS_GetOctetString(IrIasQuery* token)
*
* Description: Return a pointer to an octet string assuming that the
* current result item is of type IAS_ATTRIB_OCTET_STRING (call
* IRIAS_GetType() to determine the type of the current result
* item).
*
* Parameters: token - pointer to an IrIasQuery structure
*
* Return Values: pointer to octet string
*/
#define IrIAS_GetOctetString(t) ((t)->result + (t)->offset + 5)
/*---------------------------------------------------------------------------
*
* Prototype: U8 IrIAS_GetUserStringLen(IrIasQuery* token)
*
* Description: Return the length of a user string assuming that the
* current result item is of type IAS_ATTRIB_USER_STRING (call
* IRIAS_GetType() to determine the type of the current result
* item).
*
* Parameters: token - pointer to an IrIasQuery structure
*
* Return Values: Length of user string
*/
#define IrIAS_GetUserStringLen(t) ((t)->result[(t)->offset + 4])
/*---------------------------------------------------------------------------
*
* Prototype: IrCharSet IrIAS_GetUserStringCharSet(IrIasQuery* token)
*
* Description: Return the character set of the user string assuming that
* the current result item is of type IAS_ATTRIB_USER_STRING
* (call IRIAS_GetType() to determine the type of the current
* result item).
*
* Parameters: token - pointer to an IrIasQuery structure
*
* Return Values: Character set
*/
#define IrIAS_GetUserStringCharSet(t) ((t)->result[(t)->offset + 3])
/*---------------------------------------------------------------------------
*
* Prototype: U8* IrIAS_GetUserString(IrIasQuery* token)
*
* Description: Return a pointer to a user string assuming that the
* current result item is of type IAS_ATTRIB_USER_STRING (call
* IRIAS_GetType() to determine the type of the current result
* item).
*
* Parameters: token - pointer to an IrIasQuery structure
*
* Return Values: Pointer to result string
*/
#define IrIAS_GetUserString(t) ((t)->result + (t)->offset + 5)
/*---------------------------------------------------------------------------
*
* Prototype: UInt8 *IrIAS_Next(UInt16 refNum,IrIasQuery* token)
*
* Description: Move the internal pointer to the next result item. This
* function returns a pointer to the start of the next result
* item. If the poiinter is 0 then there are no more result
* items. Only available if IR_IAS_NEXT is defined.
*
* Parameters: refNum - library reference number
*
* token - pointer to an IrIasQuery structure
*
* Return Values: Pointer to the next result item or 0 if no more items.
*/
UInt8 * IrIAS_Next(UInt16 refNum,IrIasQuery* token)
SYS_TRAP(irLibTrapIAS_Next);
/****************************************************************************
*
* IAS Callback Reference
*
****************************************************************************/
/*---------------------------------------------------------------------------
*
* The result of IAS query is signaled by calling the callback function
* pointed to by the callBack field of IrIasQuery structure. The callback
* has the following prototype:
*
* void callBack(IrStatus);
*
* The callback is called with a status as follows:
*
* IR_STATUS_SUCCESS - the query operation finished successfully and
* the results can be parsed
*
* IR_STATUS_DISCONNECT - the link or IrLMP connection was disconnected
* during the query so the results are not valid.
=========================================================================== */
// The following two functions are only for advances uses - do not use these.
/*---------------------------------------------------------------------------
*
* Prototype: IrHandleEvent(UInt16 refnum)
*
* Description: MemHandle background task event (ony used for special cases)
* Normally you will not use this function
*
* Parameters: refNum - library reference number
**
* Return Values: Pointer to the next result item or 0 if no more items.
*/
Boolean IrHandleEvent(UInt16 refnum)
SYS_TRAP(irLibTrapHandleEvent);
/*---------------------------------------------------------------------------
*
* Prototype: IrWaitForEvent(UInt16 libRefnum,Int32 timeout)
*
* Description: Wait for background task event (ony used for special cases)
* Normally you will not use this function
*
* Parameters: refNum - library reference number
*
* timeout - number of ticks to wait
*
* Return Values: Pointer to the next result item or 0 if no more items.
*/
Err IrWaitForEvent(UInt16 libRefnum,Int32 timeout)
SYS_TRAP(irLibTrapWaitForEvent);
#ifdef __cplusplus
}
#endif
#endif // IR_LIB_H