| sl@0 |      1 | // Copyright (c) 1995-2009 Nokia Corporation and/or its subsidiary(-ies).
 | 
| sl@0 |      2 | // All rights reserved.
 | 
| sl@0 |      3 | // This component and the accompanying materials are made available
 | 
| sl@0 |      4 | // under the terms of the License "Eclipse Public License v1.0"
 | 
| sl@0 |      5 | // which accompanies this distribution, and is available
 | 
| sl@0 |      6 | // at the URL "http://www.eclipse.org/legal/epl-v10.html".
 | 
| sl@0 |      7 | //
 | 
| sl@0 |      8 | // Initial Contributors:
 | 
| sl@0 |      9 | // Nokia Corporation - initial contribution.
 | 
| sl@0 |     10 | //
 | 
| sl@0 |     11 | // Contributors:
 | 
| sl@0 |     12 | //
 | 
| sl@0 |     13 | // Description:
 | 
| sl@0 |     14 | // e32\include\d32comm.h
 | 
| sl@0 |     15 | // 
 | 
| sl@0 |     16 | //
 | 
| sl@0 |     17 | 
 | 
| sl@0 |     18 | //#define _DEBUG_DEVCOMM
 | 
| sl@0 |     19 | 
 | 
| sl@0 |     20 | /**
 | 
| sl@0 |     21 | @file
 | 
| sl@0 |     22 | @publishedPartner
 | 
| sl@0 |     23 | @released
 | 
| sl@0 |     24 | */
 | 
| sl@0 |     25 | 
 | 
| sl@0 |     26 | #ifndef __D32COMM_H__
 | 
| sl@0 |     27 | #define __D32COMM_H__
 | 
| sl@0 |     28 | #include <e32cmn.h>
 | 
| sl@0 |     29 | #include <e32ver.h>
 | 
| sl@0 |     30 | #include <d32public.h>
 | 
| sl@0 |     31 | 
 | 
| sl@0 |     32 | /**
 | 
| sl@0 |     33 |  Enumeration of number of data bits for serial port configuration.
 | 
| sl@0 |     34 |  Typically, these values are used to initialize the iDataBits of 
 | 
| sl@0 |     35 |  TCommConfigV01 before calling DComm::Configure() or any other serial
 | 
| sl@0 |     36 |  comm API to configure the serial port's databits size.
 | 
| sl@0 |     37 |  */
 | 
| sl@0 |     38 | enum TDataBits {EData5,EData6,EData7,EData8};
 | 
| sl@0 |     39 | /**
 | 
| sl@0 |     40 |  Enumeration of number of stop bits for serial port configuration.
 | 
| sl@0 |     41 |  Typically, these values are used to initialize the iStopBits of 
 | 
| sl@0 |     42 |  TCommConfigV01 before calling DComm::Configure() or any other serial
 | 
| sl@0 |     43 |  comm API to configure the serial port's stopbits.
 | 
| sl@0 |     44 |  */
 | 
| sl@0 |     45 | enum TStopBits {EStop1,EStop2};
 | 
| sl@0 |     46 | /**
 | 
| sl@0 |     47 |  Enumeration of types of parity for serial port configuration.
 | 
| sl@0 |     48 |  Typically, these values are used to initialize the iParity of 
 | 
| sl@0 |     49 |  TCommConfigV01 before calling DComm::Configure() or any other serial
 | 
| sl@0 |     50 |  comm API to configure the serial port's parity setting.
 | 
| sl@0 |     51 |  */
 | 
| sl@0 |     52 | enum TParity {EParityNone,EParityEven,EParityOdd,EParityMark,EParitySpace};
 | 
| sl@0 |     53 | /**
 | 
| sl@0 |     54 |  Enumeration of baud rates in bits per second for serial port configuration.
 | 
| sl@0 |     55 |  * e.g EBps115200 is for 115200Bps data rate  
 | 
| sl@0 |     56 |  Typically, these values are used to initialize the iRate of TCommConfigV01 
 | 
| sl@0 |     57 |  before calling DComm::Configure() or any other serial comm API to configure
 | 
| sl@0 |     58 |  the serial port's baud rate.
 | 
| sl@0 |     59 |  */
 | 
| sl@0 |     60 | enum TBps
 | 
| sl@0 |     61 | 	{
 | 
| sl@0 |     62 | 	EBps50,
 | 
| sl@0 |     63 | 	EBps75,
 | 
| sl@0 |     64 | 	EBps110,
 | 
| sl@0 |     65 | 	EBps134,
 | 
| sl@0 |     66 | 	EBps150,
 | 
| sl@0 |     67 | 	EBps300,
 | 
| sl@0 |     68 | 	EBps600,
 | 
| sl@0 |     69 | 	EBps1200,
 | 
| sl@0 |     70 | 	EBps1800,
 | 
| sl@0 |     71 | 	EBps2000,
 | 
| sl@0 |     72 | 	EBps2400,
 | 
| sl@0 |     73 | 	EBps3600,
 | 
| sl@0 |     74 | 	EBps4800,
 | 
| sl@0 |     75 | 	EBps7200,
 | 
| sl@0 |     76 | 	EBps9600,
 | 
| sl@0 |     77 | 	EBps19200,
 | 
| sl@0 |     78 | 	EBps38400,
 | 
| sl@0 |     79 | 	EBps57600,
 | 
| sl@0 |     80 | 	EBps115200,
 | 
| sl@0 |     81 | 	EBps230400,
 | 
| sl@0 |     82 | 	EBps460800,
 | 
| sl@0 |     83 | 	EBps576000,
 | 
| sl@0 |     84 | 	EBps1152000,
 | 
| sl@0 |     85 | 	EBps4000000,
 | 
| sl@0 |     86 | 	EBps921600,
 | 
| sl@0 |     87 | 	EBpsAutobaud=0x40000000,
 | 
| sl@0 |     88 | 	EBpsSpecial=0x80000000,
 | 
| sl@0 |     89 | 	};
 | 
| sl@0 |     90 | /**
 | 
| sl@0 |     91 |  Enumeration of Fifo status (enable and disable) for serial port configuration.
 | 
| sl@0 |     92 |  Typically, these values are used to initialize the iFifo of TCommConfigV01 
 | 
| sl@0 |     93 |  before calling DComm::Configure() or any other serial comm API to configure
 | 
| sl@0 |     94 |  the serial port's fifo.
 | 
| sl@0 |     95 |  */
 | 
| sl@0 |     96 | enum TFifo
 | 
| sl@0 |     97 | 	{
 | 
| sl@0 |     98 | 	EFifoEnable,EFifoDisable,
 | 
| sl@0 |     99 | 	};
 | 
| sl@0 |    100 | /**
 | 
| sl@0 |    101 |  Enumeration of SIR status (enable and disable) for serial comm configuration.
 | 
| sl@0 |    102 |  Typically, these values are used to initialize the iSIREnable of TCommConfigV01 
 | 
| sl@0 |    103 |  before calling DComm::Configure() or any other serial comm API to configure
 | 
| sl@0 |    104 |  the serial port's SIR (infrared) settings.
 | 
| sl@0 |    105 |  */
 | 
| sl@0 |    106 | enum TSir 
 | 
| sl@0 |    107 | 	{
 | 
| sl@0 |    108 | 	ESIREnable,ESIRDisable,
 | 
| sl@0 |    109 | 	};
 | 
| sl@0 |    110 | 
 | 
| sl@0 |    111 | const TInt KConfigMaxTerminators=4;
 | 
| sl@0 |    112 | // DTE Constants
 | 
| sl@0 |    113 | const TUint KConfigObeyXoff=0x01;
 | 
| sl@0 |    114 | const TUint KConfigSendXoff=0x02;
 | 
| sl@0 |    115 | const TUint KConfigObeyCTS=0x04;
 | 
| sl@0 |    116 | const TUint KConfigFailCTS=0x08;
 | 
| sl@0 |    117 | const TUint KConfigObeyDSR=0x10;
 | 
| sl@0 |    118 | const TUint KConfigFailDSR=0x20;
 | 
| sl@0 |    119 | const TUint KConfigObeyDCD=0x40;
 | 
| sl@0 |    120 | const TUint KConfigFailDCD=0x80;
 | 
| sl@0 |    121 | const TUint KConfigFreeRTS=0x100;
 | 
| sl@0 |    122 | const TUint KConfigFreeDTR=0x200;
 | 
| sl@0 |    123 | // DCE Constants
 | 
| sl@0 |    124 | const TUint KConfigObeyDTR=0x400;
 | 
| sl@0 |    125 | const TUint KConfigFailDTR=0x800;
 | 
| sl@0 |    126 | const TUint KConfigObeyRTS=0x1000;
 | 
| sl@0 |    127 | const TUint KConfigFailRTS=0x2000;
 | 
| sl@0 |    128 | const TUint KConfigFreeDSR=0x4000;
 | 
| sl@0 |    129 | const TUint KConfigFreeCTS=0x8000;
 | 
| sl@0 |    130 | const TUint KConfigFreeDCD=0x10000;
 | 
| sl@0 |    131 | const TUint KConfigFreeRI=0x20000;
 | 
| sl@0 |    132 | const TUint KConfigWriteBufferedComplete=0x80000000;
 | 
| sl@0 |    133 | //
 | 
| sl@0 |    134 | const TUint KConfigParityErrorFail=0;
 | 
| sl@0 |    135 | const TUint KConfigParityErrorIgnore=0x01;
 | 
| sl@0 |    136 | const TUint KConfigParityErrorReplaceChar=0x02;
 | 
| sl@0 |    137 | const TUint KConfigXonXoffDebug=0x80000000;
 | 
| sl@0 |    138 | //
 | 
| sl@0 |    139 | const TUint KSignalCTS=0x01;
 | 
| sl@0 |    140 | const TUint KSignalDSR=0x02;
 | 
| sl@0 |    141 | const TUint KSignalDCD=0x04;
 | 
| sl@0 |    142 | const TUint KSignalRNG=0x08;
 | 
| sl@0 |    143 | const TUint KSignalRTS=0x10; 
 | 
| sl@0 |    144 | const TUint KSignalDTR=0x20;
 | 
| sl@0 |    145 | const TUint KSignalBreak=0x40;
 | 
| sl@0 |    146 | 
 | 
| sl@0 |    147 | const TUint KSignalChanged=0x1000;
 | 
| sl@0 |    148 | const TUint KCTSChanged=KSignalCTS*KSignalChanged;
 | 
| sl@0 |    149 | const TUint KDSRChanged=KSignalDSR*KSignalChanged;
 | 
| sl@0 |    150 | const TUint KDCDChanged=KSignalDCD*KSignalChanged;
 | 
| sl@0 |    151 | const TUint KRNGChanged=KSignalRNG*KSignalChanged;
 | 
| sl@0 |    152 | const TUint KRTSChanged=KSignalRTS*KSignalChanged;
 | 
| sl@0 |    153 | const TUint KDTRChanged=KSignalDTR*KSignalChanged;
 | 
| sl@0 |    154 | const TUint KBreakChanged=KSignalBreak*KSignalChanged;
 | 
| sl@0 |    155 | 
 | 
| sl@0 |    156 | const TUint KSignalDTEOutputs=KSignalRTS|KSignalDTR;
 | 
| sl@0 |    157 | const TUint KSignalDTEInputs=KSignalCTS|KSignalDSR|KSignalDCD|KSignalRNG;
 | 
| sl@0 |    158 | const TUint KSignalDCEInputs=KSignalDTEOutputs;
 | 
| sl@0 |    159 | const TUint KSignalDCEOutputs=KSignalDTEInputs;
 | 
| sl@0 |    160 | 
 | 
| sl@0 |    161 | const TUint KConfigSIRPulseWidthMaximum=0x01;
 | 
| sl@0 |    162 | const TUint KConfigSIRPulseWidthMinimum=0x02;
 | 
| sl@0 |    163 | 
 | 
| sl@0 |    164 | // more SIRSettings for selecting the IR range
 | 
| sl@0 |    165 | const TUint KConfigSIRShutDown=0x10;
 | 
| sl@0 |    166 | const TUint KConfigSIRMinimumRange=0x20;
 | 
| sl@0 |    167 | const TUint KConfigSIRMediumRange=0x40;
 | 
| sl@0 |    168 | const TUint KConfigSIRMaximumRange=0x80;
 | 
| sl@0 |    169 | 
 | 
| sl@0 |    170 | /**
 | 
| sl@0 |    171 |  Comms configuration structure.
 | 
| sl@0 |    172 |  Class to hold the configuration settings for serial comm port
 | 
| sl@0 |    173 |  
 | 
| sl@0 |    174 |  This class provides the serial port configuration block interface of serial comms (c32).
 | 
| sl@0 |    175 |  A serial comm client sets up a serial port before use, by providing a configuration block. 
 | 
| sl@0 |    176 |  TCommConfigV01 is initialized with settings for serial port and used to configure the 
 | 
| sl@0 |    177 |  serial port by calling DComm::Configure(TCommConfigV01 &aConfig) or any other serial comm 
 | 
| sl@0 |    178 |  API to configure the serial port.
 | 
| sl@0 |    179 |  */
 | 
| sl@0 |    180 | class TCommConfigV01
 | 
| sl@0 |    181 |     {
 | 
| sl@0 |    182 | public:
 | 
| sl@0 |    183 | 	/** 
 | 
| sl@0 |    184 | 	 Data rate in bits per second.
 | 
| sl@0 |    185 | 	 @see TBps 	
 | 
| sl@0 |    186 | 	 */
 | 
| sl@0 |    187 | 	TBps iRate;
 | 
| sl@0 |    188 | 	/** 
 | 
| sl@0 |    189 | 	 Character width in bits.
 | 
| sl@0 |    190 | 	 @see TDataBits
 | 
| sl@0 |    191 | 	 */	
 | 
| sl@0 |    192 | 	TDataBits iDataBits;
 | 
| sl@0 |    193 | 	/**
 | 
| sl@0 |    194 | 	 Number of stop bits.
 | 
| sl@0 |    195 | 	 @see TStopBits
 | 
| sl@0 |    196 | 	 */
 | 
| sl@0 |    197 | 	TStopBits iStopBits;
 | 
| sl@0 |    198 | 	/**
 | 
| sl@0 |    199 | 	 Type of parity.
 | 
| sl@0 |    200 | 	 @see TParity 
 | 
| sl@0 |    201 | 	 */
 | 
| sl@0 |    202 | 	TParity iParity;
 | 
| sl@0 |    203 | 	/**
 | 
| sl@0 |    204 | 	 Type of Handshaking control.
 | 
| sl@0 |    205 | 	 Possible values can be KConfigObeyXXX or KConfigSendXXX or KConfigFailXXX or KConfigFreeXXX
 | 
| sl@0 |    206 | 	 */
 | 
| sl@0 |    207 | 	TUint iHandshake;
 | 
| sl@0 |    208 | 	/**
 | 
| sl@0 |    209 | 	 Type of error to generate on a parity failure.
 | 
| sl@0 |    210 | 	 Possible values can be KConfigParityErrorFail or KConfigParityErrorIgnore or KConfigParityErrorReplaceChar
 | 
| sl@0 |    211 | 	 */
 | 
| sl@0 |    212 | 	TUint iParityError;
 | 
| sl@0 |    213 | 	/**
 | 
| sl@0 |    214 | 	 FIFO status, enabled or disabled.
 | 
| sl@0 |    215 | 	 @see TFifo 
 | 
| sl@0 |    216 | 	 */
 | 
| sl@0 |    217 | 	TUint iFifo;
 | 
| sl@0 |    218 | 	/**
 | 
| sl@0 |    219 | 	 Special data rate, not listed under TBps. Use this, when iRate is set to EBpsSpecial 
 | 
| sl@0 |    220 | 	 */
 | 
| sl@0 |    221 | 	TInt iSpecialRate;
 | 
| sl@0 |    222 | 	/**
 | 
| sl@0 |    223 | 	 Count of number of special characters used as terminators (<=KConfigMaxTerminators) 
 | 
| sl@0 |    224 | 	 */				
 | 
| sl@0 |    225 | 	TInt iTerminatorCount;
 | 
| sl@0 |    226 | 	/**
 | 
| sl@0 |    227 | 	 Array of special characters which can be used as terminators 
 | 
| sl@0 |    228 | 	 */
 | 
| sl@0 |    229 | 	TText8 iTerminator[KConfigMaxTerminators];
 | 
| sl@0 |    230 | 	/**
 | 
| sl@0 |    231 | 	 Character used to signal the transmitter to resume sending when using XON/XOFF handshaking
 | 
| sl@0 |    232 | 	 i.e character used as XON - software flow control
 | 
| sl@0 |    233 | 	 */
 | 
| sl@0 |    234 | 	TText8 iXonChar;
 | 
| sl@0 |    235 | 	/**
 | 
| sl@0 |    236 | 	 Character used to signal the transmitter to suspend sending when using XON/XOFF handshaking
 | 
| sl@0 |    237 | 	 i.e character used as XOFF - software flow control
 | 
| sl@0 |    238 | 	 */
 | 
| sl@0 |    239 | 	TText8 iXoffChar;
 | 
| sl@0 |    240 | 	/**
 | 
| sl@0 |    241 | 	 Character used to replace the characters received with a parity error.
 | 
| sl@0 |    242 | 	 This is used when iParityError is set to KConfigParityErrorReplaceChar 
 | 
| sl@0 |    243 | 	 */	
 | 
| sl@0 |    244 | 	TText8 iParityErrorChar;
 | 
| sl@0 |    245 | 	/**
 | 
| sl@0 |    246 | 	 Switch the SIR encoding hardware on and off.
 | 
| sl@0 |    247 | 	 @see TSir
 | 
| sl@0 |    248 | 	 */
 | 
| sl@0 |    249 | 	TSir iSIREnable;
 | 
| sl@0 |    250 | 	/**
 | 
| sl@0 |    251 | 	 SIR hardware control setting. Possible value can be one of KConfigSIRXXX
 | 
| sl@0 |    252 | 	 */
 | 
| sl@0 |    253 | 	TUint iSIRSettings;
 | 
| sl@0 |    254 | 	};
 | 
| sl@0 |    255 | /** 
 | 
| sl@0 |    256 |  Package buffer for a TCommConfigV01 object.
 | 
| sl@0 |    257 |  
 | 
| sl@0 |    258 |  TCommConfig packages the comms configuration structure TCommConfigV01 to a buffer. 
 | 
| sl@0 |    259 |  This is used with API of serial comms like RComm::Config(TDes8 &aConfig) and 
 | 
| sl@0 |    260 |  RComm::SetConfig(TDesC8 &aConfig) where config structure is passed as buffer.
 | 
| sl@0 |    261 |  
 | 
| sl@0 |    262 |  @see TCommConfigV01
 | 
| sl@0 |    263 |  */		
 | 
| sl@0 |    264 | typedef TPckgBuf<TCommConfigV01> TCommConfig;
 | 
| sl@0 |    265 | 
 | 
| sl@0 |    266 | // TCommConfigV02 is deprecated.
 | 
| sl@0 |    267 | //
 | 
| sl@0 |    268 | class TCommConfigV02: public TCommConfigV01
 | 
| sl@0 |    269 | 	{
 | 
| sl@0 |    270 | public:		
 | 
| sl@0 |    271 | 	TInt iTxShutdownTimeout;
 | 
| sl@0 |    272 | 	};
 | 
| sl@0 |    273 | 
 | 
| sl@0 |    274 | // TCommConfig2 is deprecated
 | 
| sl@0 |    275 | // 
 | 
| sl@0 |    276 | typedef TPckgBuf<TCommConfigV02> TCommConfig2;
 | 
| sl@0 |    277 | 
 | 
| sl@0 |    278 | //
 | 
| sl@0 |    279 | const TUint KCapsBps50=0x00000001;
 | 
| sl@0 |    280 | const TUint KCapsBps75=0x00000002;
 | 
| sl@0 |    281 | const TUint KCapsBps110=0x00000004;
 | 
| sl@0 |    282 | const TUint KCapsBps134=0x00000008;
 | 
| sl@0 |    283 | const TUint KCapsBps150=0x00000010;
 | 
| sl@0 |    284 | const TUint KCapsBps300=0x00000020;
 | 
| sl@0 |    285 | const TUint KCapsBps600=0x00000040;
 | 
| sl@0 |    286 | const TUint KCapsBps1200=0x00000080;
 | 
| sl@0 |    287 | const TUint KCapsBps1800=0x00000100;
 | 
| sl@0 |    288 | const TUint KCapsBps2000=0x00000200;
 | 
| sl@0 |    289 | const TUint KCapsBps2400=0x00000400;
 | 
| sl@0 |    290 | const TUint KCapsBps3600=0x00000800;
 | 
| sl@0 |    291 | const TUint KCapsBps4800=0x00001000;
 | 
| sl@0 |    292 | const TUint KCapsBps7200=0x00002000;
 | 
| sl@0 |    293 | const TUint KCapsBps9600=0x00004000;
 | 
| sl@0 |    294 | const TUint KCapsBps19200=0x00008000;
 | 
| sl@0 |    295 | const TUint KCapsBps38400=0x00010000;
 | 
| sl@0 |    296 | const TUint KCapsBps57600=0x00020000;
 | 
| sl@0 |    297 | const TUint KCapsBps115200=0x00040000;
 | 
| sl@0 |    298 | const TUint KCapsBps230400=0x00080000;
 | 
| sl@0 |    299 | const TUint KCapsBps460800=0x00100000;
 | 
| sl@0 |    300 | const TUint KCapsBps576000 =0x00200000;
 | 
| sl@0 |    301 | const TUint KCapsBps1152000=0x00400000;
 | 
| sl@0 |    302 | const TUint KCapsBps4000000=0x00800000;
 | 
| sl@0 |    303 | const TUint KCapsBps921600=0x01000000;
 | 
| sl@0 |    304 | const TUint KCapsBpsAutobaud=0x40000000;
 | 
| sl@0 |    305 | const TUint KCapsBpsSpecial=0x80000000;
 | 
| sl@0 |    306 | //
 | 
| sl@0 |    307 | const TUint KCapsData5=0x01;
 | 
| sl@0 |    308 | const TUint KCapsData6=0x02;
 | 
| sl@0 |    309 | const TUint KCapsData7=0x04;
 | 
| sl@0 |    310 | const TUint KCapsData8=0x08;
 | 
| sl@0 |    311 | //
 | 
| sl@0 |    312 | const TUint KCapsStop1=0x01;
 | 
| sl@0 |    313 | const TUint KCapsStop2=0x02;
 | 
| sl@0 |    314 | //
 | 
| sl@0 |    315 | const TUint KCapsParityNone=0x01;
 | 
| sl@0 |    316 | const TUint KCapsParityEven=0x02;
 | 
| sl@0 |    317 | const TUint KCapsParityOdd=0x04;
 | 
| sl@0 |    318 | const TUint KCapsParityMark=0x08;
 | 
| sl@0 |    319 | const TUint KCapsParitySpace=0x10;
 | 
| sl@0 |    320 | //
 | 
| sl@0 |    321 | const TUint KCapsSignalCTSSupported=0x01;
 | 
| sl@0 |    322 | const TUint KCapsSignalDSRSupported=0x02;
 | 
| sl@0 |    323 | const TUint KCapsSignalDCDSupported=0x04;
 | 
| sl@0 |    324 | const TUint KCapsSignalRNGSupported=0x08;
 | 
| sl@0 |    325 | const TUint KCapsSignalRTSSupported=0x10;
 | 
| sl@0 |    326 | const TUint KCapsSignalDTRSupported=0x20;
 | 
| sl@0 |    327 | //
 | 
| sl@0 |    328 | const TUint KCapsObeyXoffSupported=0x01;
 | 
| sl@0 |    329 | const TUint KCapsSendXoffSupported=0x02;
 | 
| sl@0 |    330 | const TUint KCapsObeyCTSSupported=0x04;
 | 
| sl@0 |    331 | const TUint KCapsFailCTSSupported=0x08;
 | 
| sl@0 |    332 | const TUint KCapsObeyDSRSupported=0x10;
 | 
| sl@0 |    333 | const TUint KCapsFailDSRSupported=0x20;
 | 
| sl@0 |    334 | const TUint KCapsObeyDCDSupported=0x40;
 | 
| sl@0 |    335 | const TUint KCapsFailDCDSupported=0x80;
 | 
| sl@0 |    336 | const TUint KCapsFreeRTSSupported=0x100;
 | 
| sl@0 |    337 | const TUint KCapsFreeDTRSupported=0x200;
 | 
| sl@0 |    338 | // DCE Constants
 | 
| sl@0 |    339 | const TUint KCapsObeyRTSSupported=0x400;
 | 
| sl@0 |    340 | const TUint KCapsObeyDTRSupported=0x800;
 | 
| sl@0 |    341 | //
 | 
| sl@0 |    342 | const TUint KCapsHasFifo=0x01;
 | 
| sl@0 |    343 | //
 | 
| sl@0 |    344 | const TUint KCapsSIR115kbps=0x01;
 | 
| sl@0 |    345 | const TUint KCapsSIR2400bpsOnly=0x02;
 | 
| sl@0 |    346 | const TUint KCapsSIR4Mbs=0x04;
 | 
| sl@0 |    347 | //
 | 
| sl@0 |    348 | const TUint KNotifySignalsChangeSupported=0x01;
 | 
| sl@0 |    349 | const TUint KNotifyRateChangeSupported=0x02;
 | 
| sl@0 |    350 | const TUint KNotifyDataFormatChangeSupported=0x04;
 | 
| sl@0 |    351 | const TUint KNotifyHandshakeChangeSupported=0x08;
 | 
| sl@0 |    352 | const TUint KNotifyBreakSupported=0x10;
 | 
| sl@0 |    353 | const TUint KNotifyFlowControlChangeSupported=0x20;
 | 
| sl@0 |    354 | const TUint KNotifyDataAvailableSupported=0x40;
 | 
| sl@0 |    355 | const TUint KNotifyOutputEmptySupported=0x80;
 | 
| sl@0 |    356 | //
 | 
| sl@0 |    357 | const TUint KCapsRoleSwitchSupported=0x01;
 | 
| sl@0 |    358 | //
 | 
| sl@0 |    359 | const TUint KCapsFlowControlStatusSupported=0x01;
 | 
| sl@0 |    360 | //
 | 
| sl@0 |    361 | const TUint KRateChanged=0x01;
 | 
| sl@0 |    362 | const TUint KDataFormatChanged=0x02;
 | 
| sl@0 |    363 | const TUint KHandshakeChanged=0x04;
 | 
| sl@0 |    364 | //
 | 
| sl@0 |    365 | 
 | 
| sl@0 |    366 | /**
 | 
| sl@0 |    367 |  Comms capability structure.
 | 
| sl@0 |    368 |  Class to query the capability settings for serial comm port device.
 | 
| sl@0 |    369 |  Members of this class are filled with the capabilities of the comm port device.
 | 
| sl@0 |    370 |  */
 | 
| sl@0 |    371 | 
 | 
| sl@0 |    372 | class TCommCapsV01
 | 
| sl@0 |    373 | 	{
 | 
| sl@0 |    374 | public:
 | 
| sl@0 |    375 | 	/** 
 | 
| sl@0 |    376 | 	 Data rates supported, in bits per second.
 | 
| sl@0 |    377 | 	 The value is a bitmask made by OR-ing KCapsBpsXXX values.
 | 
| sl@0 |    378 | 	 Each set bit corresponds to a supported bit rate.
 | 
| sl@0 |    379 | 	 */
 | 
| sl@0 |    380 | 	TUint iRate;
 | 
| sl@0 |    381 | 	/**
 | 
| sl@0 |    382 | 	 Character widths supported, in bits.
 | 
| sl@0 |    383 | 	 The value is a bitmask made by OR-ing a combination of KCapsData5, KCapsData6, KCapsData7 and KCapsData8 values.
 | 
| sl@0 |    384 | 	 Each set bit corresponds to a supported character width. 
 | 
| sl@0 |    385 | 	 */	
 | 
| sl@0 |    386 | 	TUint iDataBits;
 | 
| sl@0 |    387 | 	/**
 | 
| sl@0 |    388 | 	 Number of stop bits supported.
 | 
| sl@0 |    389 | 	 The value is one of KCapsStop1, KCapsStop2 or KCapsStop1|KCapsStop2.
 | 
| sl@0 |    390 | 	 Each set bit corresponds to a supported number of stop bit.
 | 
| sl@0 |    391 | 	 */
 | 
| sl@0 |    392 | 	TUint iStopBits;
 | 
| sl@0 |    393 | 	/**
 | 
| sl@0 |    394 | 	 Parity types supported.
 | 
| sl@0 |    395 | 	 The value is a bitmask made by OR-ing a combination of KCapsParityNone, KCapsParityEven, KCapsParityOdd, KCapsParityMark and KCapsParitySpace values.
 | 
| sl@0 |    396 | 	 Each set bit corresponds to a supported parity type. 
 | 
| sl@0 |    397 | 	 */
 | 
| sl@0 |    398 | 	TUint iParity;
 | 
| sl@0 |    399 | 	/**
 | 
| sl@0 |    400 | 	 Type of Handshaking protocols supported by the device.
 | 
| sl@0 |    401 | 	 The value is a bitmask made by OR-ing a combination of KCapsObeyXXX, KCapsSendXXX, KCapsFailXXX and KCapsFreeXXX values.
 | 
| sl@0 |    402 | 	 Each set bit corresponds to a supported handshaking protocol.
 | 
| sl@0 |    403 | 	 */
 | 
| sl@0 |    404 | 	TUint iHandshake;
 | 
| sl@0 |    405 | 	/**
 | 
| sl@0 |    406 | 	 Type of Signals supported by the device.
 | 
| sl@0 |    407 | 	 The value is a bitmask made by OR-ing a combination of KCapsSignalXXX values.
 | 
| sl@0 |    408 | 	 Each set bit corresponds to a supported signal.
 | 
| sl@0 |    409 | 	 */
 | 
| sl@0 |    410 | 	TUint iSignals;
 | 
| sl@0 |    411 | 	/**
 | 
| sl@0 |    412 | 	 Whether Fifo is enabled or disabled.
 | 
| sl@0 |    413 | 	 Value is KCapsHasFifo if enabled, 0 otherwise
 | 
| sl@0 |    414 | 	 */
 | 
| sl@0 |    415 | 	TUint iFifo;
 | 
| sl@0 |    416 | 	/**
 | 
| sl@0 |    417 | 	 Capabilities of the SIR encoding hardware.
 | 
| sl@0 |    418 | 	 The value is a bitmask made by OR-ing a combination of KCapsSIR115kbps, KCapsSIR2400bpsOnly and KCapsSIR4Mbps values.
 | 
| sl@0 |    419 | 	 Each set bit corresponds to a supported SIR capability.
 | 
| sl@0 |    420 | 	 */
 | 
| sl@0 |    421 | 	TUint iSIR;
 | 
| sl@0 |    422 | 	};
 | 
| sl@0 |    423 | /** 
 | 
| sl@0 |    424 |  Package buffer for a TCommCapsV01 object.
 | 
| sl@0 |    425 |  
 | 
| sl@0 |    426 |  TCommCaps packages the comms capability structure TCommCapsV01 in a buffer. 
 | 
| sl@0 |    427 |  This is used by serial comms APIs to pass the capability structure as a buffer,
 | 
| sl@0 |    428 |  for example in RComm::Caps(TDes8 &aCaps).
 | 
| sl@0 |    429 |   
 | 
| sl@0 |    430 |  @see TCommCapsV01
 | 
| sl@0 |    431 |  */		
 | 
| sl@0 |    432 | typedef TPckgBuf<TCommCapsV01> TCommCaps;
 | 
| sl@0 |    433 | 
 | 
| sl@0 |    434 | /**
 | 
| sl@0 |    435 |  Comms capability structure.
 | 
| sl@0 |    436 |  Class to query the capability settings for serial comm port.
 | 
| sl@0 |    437 |  Members of this class are filled with the capabilities of the comm port.
 | 
| sl@0 |    438 |  
 | 
| sl@0 |    439 |  @see TCommCapsV01
 | 
| sl@0 |    440 |  */
 | 
| sl@0 |    441 | class TCommCapsV02 : public TCommCapsV01
 | 
| sl@0 |    442 | 	{
 | 
| sl@0 |    443 | public:
 | 
| sl@0 |    444 | 	/**
 | 
| sl@0 |    445 | 	 Specifies the notifications that are supported for the serial comm port.
 | 
| sl@0 |    446 | 	 The field is a bitmask made by OR-ing a combination of:
 | 
| sl@0 |    447 | 	 	-KNotifySignalsChangeSupported
 | 
| sl@0 |    448 | 		-KNotifyRateChangeSupported
 | 
| sl@0 |    449 | 		-KNotifyDataFormatChangeSupported
 | 
| sl@0 |    450 | 		-KNotifyHandshakeChangeSupported
 | 
| sl@0 |    451 | 		-KNotifyBreakSupported
 | 
| sl@0 |    452 | 		-KNotifyFlowControlChangeSupported
 | 
| sl@0 |    453 | 		-KNotifyDataAvailableSupported
 | 
| sl@0 |    454 | 		-KNotifyOutputEmptySupported
 | 
| sl@0 |    455 | 	 Each set bit corresponds to a supported notification type.
 | 
| sl@0 |    456 | 	 */
 | 
| sl@0 |    457 | 	TUint iNotificationCaps;
 | 
| sl@0 |    458 | 	/**
 | 
| sl@0 |    459 | 	 Specifies whether Role Switch is supported or not.
 | 
| sl@0 |    460 | 	 If supported the value is KCapsRoleSwitchSupported, otherwise Zero
 | 
| sl@0 |    461 | 	 */
 | 
| sl@0 |    462 | 	TUint iRoleCaps;
 | 
| sl@0 |    463 | 	/**
 | 
| sl@0 |    464 | 	 Specifies whether Flow Control Status is supported or not.
 | 
| sl@0 |    465 | 	 If supported the value is KCapsFlowControlStatusSupported, otherwise Zero
 | 
| sl@0 |    466 | 	 */
 | 
| sl@0 |    467 | 	TUint iFlowControlCaps;
 | 
| sl@0 |    468 | 	};
 | 
| sl@0 |    469 | 	
 | 
| sl@0 |    470 | /** 
 | 
| sl@0 |    471 |  Package buffer for a TCommCapsV02 object.
 | 
| sl@0 |    472 |  
 | 
| sl@0 |    473 |  TCommCaps2 packages the comms capability structure TCommCapsV02 in a buffer. 
 | 
| sl@0 |    474 |  This is used by serial comms to pass the capability structure as a buffer,
 | 
| sl@0 |    475 |  for example in RComm::Caps(TDes8 &aCaps) 
 | 
| sl@0 |    476 |  
 | 
| sl@0 |    477 |  @see TCommCapsV02
 | 
| sl@0 |    478 |  */		
 | 
| sl@0 |    479 | typedef TPckgBuf<TCommCapsV02> TCommCaps2;
 | 
| sl@0 |    480 | 
 | 
| sl@0 |    481 | 
 | 
| sl@0 |    482 | /**
 | 
| sl@0 |    483 |  Comms capability structure.
 | 
| sl@0 |    484 |  Class to hold the capability settings for serial comm port.
 | 
| sl@0 |    485 |  
 | 
| sl@0 |    486 |  This class is used to query the capabilities of the serial comm port.
 | 
| sl@0 |    487 |  Members of this class are filled with the capabilities of the comm port.
 | 
| sl@0 |    488 |  
 | 
| sl@0 |    489 |  @see TCommCapsV02
 | 
| sl@0 |    490 |  */
 | 
| sl@0 |    491 | class TCommCapsV03 : public TCommCapsV02
 | 
| sl@0 |    492 | 	{
 | 
| sl@0 |    493 | public:
 | 
| sl@0 |    494 | 	/**
 | 
| sl@0 |    495 | 	 Specifies whether break is supported or not.
 | 
| sl@0 |    496 | 	 ETrue if Supported, EFalse otherwise.
 | 
| sl@0 |    497 | 	 */
 | 
| sl@0 |    498 | 	TBool iBreakSupported;
 | 
| sl@0 |    499 | 	};
 | 
| sl@0 |    500 | 	
 | 
| sl@0 |    501 | /** 
 | 
| sl@0 |    502 |  Package buffer for a TCommCapsV03 object.
 | 
| sl@0 |    503 |  
 | 
| sl@0 |    504 |  TCommCaps3 packages the comms capability structure TCommCapsV03 in a buffer. 
 | 
| sl@0 |    505 |  This is used by serial comms APIs to pass the capability structure as a buffer,
 | 
| sl@0 |    506 |  for example in RComm::Caps(TDes8 &aCaps) 
 | 
| sl@0 |    507 |  
 | 
| sl@0 |    508 |  @see TCommCapsV03
 | 
| sl@0 |    509 |  */	
 | 
| sl@0 |    510 | typedef TPckgBuf<TCommCapsV03> TCommCaps3;
 | 
| sl@0 |    511 | 
 | 
| sl@0 |    512 | /**
 | 
| sl@0 |    513 |  Structure that holds the capabilities of the Comms factory object. Only Version is supported.
 | 
| sl@0 |    514 |  This structure is packaged within a descriptor when passed to methods such as RDevice::GetCaps()
 | 
| sl@0 |    515 |  */
 | 
| sl@0 |    516 | class TCapsDevCommV01
 | 
| sl@0 |    517 | 	{
 | 
| sl@0 |    518 | public:
 | 
| sl@0 |    519 | 	/**
 | 
| sl@0 |    520 | 	Version of the device
 | 
| sl@0 |    521 | 	@see TVersion
 | 
| sl@0 |    522 | 	*/
 | 
| sl@0 |    523 | 	TVersion version;
 | 
| sl@0 |    524 | 	};
 | 
| sl@0 |    525 | 
 | 
| sl@0 |    526 | /**
 | 
| sl@0 |    527 |  Comms Notification configuration structure
 | 
| sl@0 |    528 |  Class to hold the notification configuration of the device.
 | 
| sl@0 |    529 |  Notifications are only used with DCE (modem) comms ports.
 | 
| sl@0 |    530 |  */
 | 
| sl@0 |    531 | class TCommNotificationV01
 | 
| sl@0 |    532 | 	{
 | 
| sl@0 |    533 | public:
 | 
| sl@0 |    534 | 	/**
 | 
| sl@0 |    535 | 	 Specifies which of the configuration members have changed
 | 
| sl@0 |    536 | 	 This value is a bitmask made by OR-ing a combination of KRateChanged,KDataFormatChanged and KHandshakeChanged values.
 | 
| sl@0 |    537 | 	 Each set bit corresponds to a change in the configuration notification.
 | 
| sl@0 |    538 | 	 @see TCommCapsV01
 | 
| sl@0 |    539 | 	 */
 | 
| sl@0 |    540 | 	TUint iChangedMembers;
 | 
| sl@0 |    541 | 	/** 
 | 
| sl@0 |    542 | 	 Data rate in bits per second.
 | 
| sl@0 |    543 | 	 @see TBps 	
 | 
| sl@0 |    544 | 	 */
 | 
| sl@0 |    545 | 	TBps iRate;
 | 
| sl@0 |    546 | 	/** 
 | 
| sl@0 |    547 | 	 Character width in bits.
 | 
| sl@0 |    548 | 	 @see TDataBits
 | 
| sl@0 |    549 | 	 */	
 | 
| sl@0 |    550 | 	TDataBits iDataBits;
 | 
| sl@0 |    551 | 	/**
 | 
| sl@0 |    552 | 	 Number of stop bits.
 | 
| sl@0 |    553 | 	 @see TStopBits
 | 
| sl@0 |    554 | 	 */
 | 
| sl@0 |    555 | 	TStopBits iStopBits;
 | 
| sl@0 |    556 | 	/**
 | 
| sl@0 |    557 | 	 Type of parity.
 | 
| sl@0 |    558 | 	 @see TParity 
 | 
| sl@0 |    559 | 	 */
 | 
| sl@0 |    560 | 	TParity iParity;
 | 
| sl@0 |    561 | 	/**
 | 
| sl@0 |    562 | 	 Type of Handshaking control.
 | 
| sl@0 |    563 | 	 Possible values can be any combination of KConfigObeyXXX, KConfigSendXXX, KConfigFailXXX and KConfigFreeXXX.
 | 
| sl@0 |    564 | 	 */
 | 
| sl@0 |    565 | 	TUint iHandshake;
 | 
| sl@0 |    566 | 	};
 | 
| sl@0 |    567 | /** 
 | 
| sl@0 |    568 |  Package buffer for a TCommNotificationV01 object.
 | 
| sl@0 |    569 |  Packages TCommNotificationV01 within a buffer. 
 | 
| sl@0 |    570 |  @see TCommNotificationV01
 | 
| sl@0 |    571 |  */	
 | 
| sl@0 |    572 | typedef TPckgBuf<TCommNotificationV01> TCommNotificationPckg;
 | 
| sl@0 |    573 | //
 | 
| sl@0 |    574 | const TUint KDataAvailableNotifyFlag=0x80000000;
 | 
| sl@0 |    575 | //
 | 
| sl@0 |    576 | #ifdef _DEBUG_DEVCOMM
 | 
| sl@0 |    577 | class TCommDebugInfo
 | 
| sl@0 |    578 | 	{
 | 
| sl@0 |    579 | public:
 | 
| sl@0 |    580 | 	TBool iRxBusy;
 | 
| sl@0 |    581 | 	TBool iRxHeld;
 | 
| sl@0 |    582 | 	TInt iRxLength;
 | 
| sl@0 |    583 | 	TInt iRxOffset;
 | 
| sl@0 |    584 | 	TInt iRxIntCount;
 | 
| sl@0 |    585 | 	TInt iRxErrCount;
 | 
| sl@0 |    586 | 	TInt iRxBufCount;
 | 
| sl@0 |    587 | 	TBool iTxBusy;
 | 
| sl@0 |    588 | 	TBool iTxHeld;
 | 
| sl@0 |    589 | 	TInt iTxLength;
 | 
| sl@0 |    590 | 	TInt iTxOffset;
 | 
| sl@0 |    591 | 	TInt iTxIntCount;
 | 
| sl@0 |    592 | 	TInt iTxErrCount;
 | 
| sl@0 |    593 | 	TInt iTxBufCount;
 | 
| sl@0 |    594 | 	TBool iDrainingRxBuf;
 | 
| sl@0 |    595 | 	TBool iFillingTxBuf;
 | 
| sl@0 |    596 | 	TBool iRunningDfc;
 | 
| sl@0 |    597 | 	TInt iDfcCount;
 | 
| sl@0 |    598 | 	TInt iDfcReqSeq;
 | 
| sl@0 |    599 | 	TInt iDfcHandlerSeq;
 | 
| sl@0 |    600 | 	TInt iDoDrainSeq;
 | 
| sl@0 |    601 | 	TBool iTxDfcPend;
 | 
| sl@0 |    602 | 	TBool iRxDfcPend;
 | 
| sl@0 |    603 | 	TInt iTxChars, iRxChars;
 | 
| sl@0 |    604 | 	TInt iTxXon, iTxXoff, iRxXon, iRxXoff;
 | 
| sl@0 |    605 | 	};
 | 
| sl@0 |    606 | typedef TPckgBuf<TCommDebugInfo> TCommDebugInfoPckg;
 | 
| sl@0 |    607 | #endif
 | 
| sl@0 |    608 | //
 | 
| sl@0 |    609 | 
 | 
| sl@0 |    610 | /**
 | 
| sl@0 |    611 |  The externally visible interface through which the clients can access serial devices.
 | 
| sl@0 |    612 |  It also represents a user side handle to the serial device driver. 
 | 
| sl@0 |    613 |  */
 | 
| sl@0 |    614 | class RBusDevComm : public RBusLogicalChannel
 | 
| sl@0 |    615 | 	{
 | 
| sl@0 |    616 | public:
 | 
| sl@0 |    617 | 	/**
 | 
| sl@0 |    618 | 	 Serial device driver build version.
 | 
| sl@0 |    619 | 	 */
 | 
| sl@0 |    620 | 	enum TVer
 | 
| sl@0 |    621 | 		{
 | 
| sl@0 |    622 | 		/** Major Version */
 | 
| sl@0 |    623 | 		EMajorVersionNumber=1,
 | 
| sl@0 |    624 | 		/** Minor Version */
 | 
| sl@0 |    625 | 		EMinorVersionNumber=0,
 | 
| sl@0 |    626 | 		/** Build Version */
 | 
| sl@0 |    627 | 		EBuildVersionNumber=KE32BuildVersionNumber
 | 
| sl@0 |    628 | 		};
 | 
| sl@0 |    629 | 	
 | 
| sl@0 |    630 | 	/**
 | 
| sl@0 |    631 | 	 Asynchronous request types
 | 
| sl@0 |    632 | 	 */
 | 
| sl@0 |    633 | 	enum TRequest
 | 
| sl@0 |    634 | 		{
 | 
| sl@0 |    635 | 		/** Read request */
 | 
| sl@0 |    636 | 		ERequestRead=0x0,
 | 
| sl@0 |    637 | 		/** Cancel read request */
 | 
| sl@0 |    638 | 		ERequestReadCancel=0x1,
 | 
| sl@0 |    639 | 		/** Write reqeust */
 | 
| sl@0 |    640 | 		ERequestWrite=0x1,
 | 
| sl@0 |    641 | 		/** Cancel write request */
 | 
| sl@0 |    642 | 		ERequestWriteCancel=0x2,
 | 
| sl@0 |    643 | 		/** Break request */
 | 
| sl@0 |    644 | 		ERequestBreak=0x2,
 | 
| sl@0 |    645 | 		/** Cancel break request */
 | 
| sl@0 |    646 | 		ERequestBreakCancel=0x4,
 | 
| sl@0 |    647 | 		/** Signal change notification request */
 | 
| sl@0 |    648 | 		ERequestNotifySignalChange=0x3,
 | 
| sl@0 |    649 | 		/** Cancel signal change notification request */
 | 
| sl@0 |    650 | 		ERequestNotifySignalChangeCancel=0x8,
 | 
| sl@0 |    651 | 		};
 | 
| sl@0 |    652 | 		
 | 
| sl@0 |    653 | 	/**
 | 
| sl@0 |    654 | 	 Synchronous request types
 | 
| sl@0 |    655 | 	 */
 | 
| sl@0 |    656 | 	enum TControl
 | 
| sl@0 |    657 | 		{
 | 
| sl@0 |    658 | 		/** Get the current configuration */
 | 
| sl@0 |    659 | 		EControlConfig,
 | 
| sl@0 |    660 | 		/** Set the device configuration */
 | 
| sl@0 |    661 | 		EControlSetConfig,
 | 
| sl@0 |    662 | 		/** Get the device capabilities */
 | 
| sl@0 |    663 | 		EControlCaps,
 | 
| sl@0 |    664 | 		/** Read the state of Modem control signals supported */
 | 
| sl@0 |    665 | 		EControlSignals,
 | 
| sl@0 |    666 | 		/** Set the state of output modem control signals */
 | 
| sl@0 |    667 | 		EControlSetSignals,
 | 
| sl@0 |    668 | 		/** Query the driver receive buffer for data availability */
 | 
| sl@0 |    669 | 		EControlQueryReceiveBuffer,
 | 
| sl@0 |    670 | 		/** Reset the driver buffers */
 | 
| sl@0 |    671 | 		EControlResetBuffers,
 | 
| sl@0 |    672 | 		/** Get the driver receive buffer length */
 | 
| sl@0 |    673 | 		EControlReceiveBufferLength,
 | 
| sl@0 |    674 | 		/** Set the driver receive buffer length */
 | 
| sl@0 |    675 | 		EControlSetReceiveBufferLength,
 | 
| sl@0 |    676 | 		/** Get the minimum turnaround time between a receive and subsequent transmission operation */
 | 
| sl@0 |    677 | 		EControlMinTurnaroundTime,
 | 
| sl@0 |    678 | 		/** Set the minimum turnaround time between a receive and subsequent transmission operation */
 | 
| sl@0 |    679 | 		EControlSetMinTurnaroundTime,
 | 
| sl@0 |    680 | #ifdef _DEBUG_DEVCOMM
 | 
| sl@0 |    681 |         /** Get debug information from the driver */
 | 
| sl@0 |    682 | 		EControlDebugInfo
 | 
| sl@0 |    683 | #endif
 | 
| sl@0 |    684 | 		};
 | 
| sl@0 |    685 | 				
 | 
| sl@0 |    686 | public:
 | 
| sl@0 |    687 | #ifndef __KERNEL_MODE__
 | 
| sl@0 |    688 | 
 | 
| sl@0 |    689 | 	/**
 | 
| sl@0 |    690 | 	 This function opens a channel and creates a handle to the serial driver.
 | 
| sl@0 |    691 | 	 @param aUnit The unit number of the serial device.
 | 
| sl@0 |    692 | 	 @return KErrNone, if successful;
 | 
| sl@0 |    693 | 	         otherwise one of the other system-wide error codes.
 | 
| sl@0 |    694 | 	         KErrPermissionDenied if the port given in aName is wrong or if the request fails the CSY's own security check; 
 | 
| sl@0 |    695 | 	         KErrNotSupported if this port is not supported by the CSY or the hardware; 
 | 
| sl@0 |    696 | 	         KErrLocked if the port has already been opened; 
 | 
| sl@0 |    697 | 	         KErrAccessDenied if the device driver encounteres a problem opening the hardware port.
 | 
| sl@0 |    698 | 	 */
 | 
| sl@0 |    699 | 	inline TInt Open(TInt aUnit);
 | 
| sl@0 |    700 | 	
 | 
| sl@0 |    701 | 	/**
 | 
| sl@0 |    702 | 	 Get the version number required by the driver 
 | 
| sl@0 |    703 | 	 @return The version number required by the driver
 | 
| sl@0 |    704 | 	 @see TVersion
 | 
| sl@0 |    705 | 	 */
 | 
| sl@0 |    706 | 	inline TVersion VersionRequired() const;
 | 
| sl@0 |    707 | 	
 | 
| sl@0 |    708 | 	/**
 | 
| sl@0 |    709 | 	 Read from the channel
 | 
| sl@0 |    710 | 	 @param aStatus The asynchronous request status 
 | 
| sl@0 |    711 | 	 @param aDes Buffer to be filled in by the driver
 | 
| sl@0 |    712 | 	 */
 | 
| sl@0 |    713 | 	inline void Read(TRequestStatus &aStatus,TDes8 &aDes);
 | 
| sl@0 |    714 | 	
 | 
| sl@0 |    715 | 	/**
 | 
| sl@0 |    716 | 	 Read from the channel
 | 
| sl@0 |    717 | 	 @param aStatus The asynchronous request status 
 | 
| sl@0 |    718 | 	 @param aDes Buffer to be filled in by the driver
 | 
| sl@0 |    719 | 	 @param aLength The length of the data to be read
 | 
| sl@0 |    720 | 	 */
 | 
| sl@0 |    721 | 	inline void Read(TRequestStatus &aStatus,TDes8 &aDes,TInt aLength);
 | 
| sl@0 |    722 | 	
 | 
| sl@0 |    723 | 	/**
 | 
| sl@0 |    724 | 	 Read one or more characters from the channel.
 | 
| sl@0 |    725 | 	 If there is data in the serial driver's buffer when ReadOneOrMore() is called it will 
 | 
| sl@0 |    726 | 	 read as much data as possible (up to the maximum length of the supplied buffer) 
 | 
| sl@0 |    727 | 	 and then return.
 | 
| sl@0 |    728 | 	 If there is no data in the buffer the request will complete as soon as one or more bytes arrive at the serial hardware.
 | 
| sl@0 |    729 | 	 @param aStatus The asynchronous request status 
 | 
| sl@0 |    730 | 	 @param aDes Buffer to be filled in by the driver
 | 
| sl@0 |    731 | 	 */
 | 
| sl@0 |    732 | 	inline void ReadOneOrMore(TRequestStatus &aStatus,TDes8 &aDes);
 | 
| sl@0 |    733 | 	
 | 
| sl@0 |    734 | 	/**
 | 
| sl@0 |    735 | 	 Cancel a pending read request
 | 
| sl@0 |    736 | 	 */
 | 
| sl@0 |    737 | 	inline void ReadCancel();
 | 
| sl@0 |    738 | 	
 | 
| sl@0 |    739 | 	/**
 | 
| sl@0 |    740 | 	 Write to the channel
 | 
| sl@0 |    741 | 	 @param aStatus The asynchronous request status 
 | 
| sl@0 |    742 | 	 @param aDes Buffer containing the data to be sent
 | 
| sl@0 |    743 | 	 */
 | 
| sl@0 |    744 | 	inline void Write(TRequestStatus &aStatus,const TDesC8 &aDes);
 | 
| sl@0 |    745 | 
 | 
| sl@0 |    746 | 	/**
 | 
| sl@0 |    747 | 	 Write to the channel
 | 
| sl@0 |    748 | 	 @param aStatus The asynchronous request status 
 | 
| sl@0 |    749 | 	 @param aDes Buffer containing the data to be sent
 | 
| sl@0 |    750 | 	 @param aLength The length of the data to be sent
 | 
| sl@0 |    751 | 	 */        
 | 
| sl@0 |    752 | 	inline void Write(TRequestStatus &aStatus,const TDesC8 &aDes,TInt aLength);
 | 
| sl@0 |    753 | 	
 | 
| sl@0 |    754 | 	/**
 | 
| sl@0 |    755 | 	 Cancel a pending write request
 | 
| sl@0 |    756 | 	 */
 | 
| sl@0 |    757 | 	inline void WriteCancel();
 | 
| sl@0 |    758 | 	
 | 
| sl@0 |    759 | 	/**
 | 
| sl@0 |    760 | 	 Causes a break condition to be transmitted to the receiving device
 | 
| sl@0 |    761 | 	 @param aStatus The asynchronous request status
 | 
| sl@0 |    762 | 	 @param aTime The time interval in microseconds after which the break condition will be released	
 | 
| sl@0 |    763 | 	 */
 | 
| sl@0 |    764 | 	inline void Break(TRequestStatus &aStatus,TInt aTime);
 | 
| sl@0 |    765 | 	
 | 
| sl@0 |    766 | 	/**
 | 
| sl@0 |    767 | 	 Cancel a pending break request
 | 
| sl@0 |    768 | 	 */
 | 
| sl@0 |    769 | 	inline void BreakCancel();
 | 
| sl@0 |    770 | 	
 | 
| sl@0 |    771 | 	/**
 | 
| sl@0 |    772 | 	 Get the current configuration of the serial device
 | 
| sl@0 |    773 | 	 @param aConfig A packaged object to be filled with the configuration information by the driver
 | 
| sl@0 |    774 | 	 @see TCommConfigV02
 | 
| sl@0 |    775 | 	 */
 | 
| sl@0 |    776 | 	inline void Config(TDes8 &aConfig);
 | 
| sl@0 |    777 | 	
 | 
| sl@0 |    778 | 	/**
 | 
| sl@0 |    779 | 	 Set the cofiguration of the serial device
 | 
| sl@0 |    780 | 	 @param aConfig A packaged object containing the configuration information
 | 
| sl@0 |    781 | 	 @see TCommConfigV02
 | 
| sl@0 |    782 | 	 */
 | 
| sl@0 |    783 | 	inline TInt SetConfig(const TDesC8 &aConfig);
 | 
| sl@0 |    784 | 	
 | 
| sl@0 |    785 | 	/**
 | 
| sl@0 |    786 | 	 Get the capabilities of the serial device.
 | 
| sl@0 |    787 | 	 @param aCaps A packaged object to be filled with the capabilities of the device.
 | 
| sl@0 |    788 | 	 @see TCommCapsV03
 | 
| sl@0 |    789 | 	*/
 | 
| sl@0 |    790 | 	inline void Caps(TDes8 &aCaps);
 | 
| sl@0 |    791 | 	
 | 
| sl@0 |    792 | 	/**
 | 
| sl@0 |    793 | 	 Get the status of the control lines
 | 
| sl@0 |    794 | 	 @return  A bitmask of KSignalCTS, KSignalDSR, KSignalDCD, KSignalRNG,
 | 
| sl@0 |    795 |               KSignalRTS, KSignalDTR, KSignalBreak
 | 
| sl@0 |    796 | 	 */
 | 
| sl@0 |    797 | 	inline TUint Signals();
 | 
| sl@0 |    798 | 	
 | 
| sl@0 |    799 | 	/**
 | 
| sl@0 |    800 | 	 Set and clear the control lines
 | 
| sl@0 |    801 | 	 @param aSetMask    Bitmask of signals to set
 | 
| sl@0 |    802 | 	 @param aClearMask  Bitmask of signals to clear
 | 
| sl@0 |    803 | 	 @see Signals for a list of signals
 | 
| sl@0 |    804 | 	 */
 | 
| sl@0 |    805 | 	inline void SetSignals(TUint aSetMask,TUint aClearMask);
 | 
| sl@0 |    806 | 	
 | 
| sl@0 |    807 | 	/**
 | 
| sl@0 |    808 | 	 Get the number of unread characters in the receive buffer of the driver
 | 
| sl@0 |    809 | 	 @return The number of unread characters
 | 
| sl@0 |    810 | 	 */
 | 
| sl@0 |    811 | 	inline TInt QueryReceiveBuffer();
 | 
| sl@0 |    812 | 	
 | 
| sl@0 |    813 | 	/**
 | 
| sl@0 |    814 | 	 Reset the receive and transmit buffers.
 | 
| sl@0 |    815 | 	 */
 | 
| sl@0 |    816 | 	inline void ResetBuffers();
 | 
| sl@0 |    817 | 	
 | 
| sl@0 |    818 | 	/**
 | 
| sl@0 |    819 | 	 Get the length of the receive buffer
 | 
| sl@0 |    820 | 	 @return The length of the receive buffer
 | 
| sl@0 |    821 | 	 */	
 | 
| sl@0 |    822 | 	inline TInt ReceiveBufferLength();
 | 
| sl@0 |    823 | 	
 | 
| sl@0 |    824 | 	/**
 | 
| sl@0 |    825 | 	 Set the length of the receive buffer
 | 
| sl@0 |    826 | 	 @param aLength The length of the receive buffer to be set
 | 
| sl@0 |    827 | 	 */
 | 
| sl@0 |    828 | 	inline TInt SetReceiveBufferLength(TInt aLength);
 | 
| sl@0 |    829 | 		
 | 
| sl@0 |    830 | 	/**
 | 
| sl@0 |    831 | 	 Request notification when one of the signals change.
 | 
| sl@0 |    832 | 	 The signals that could change are KSignalCTS, KSignalDSR, KSignalDCD, KSignalRNG,
 | 
| sl@0 |    833 | 	 KSignalRTS, KSignalDTR, KSignalBreak.
 | 
| sl@0 |    834 | 	 @param aStatus  The asynchronous request status
 | 
| sl@0 |    835 | 	 @param aSignals Pointer to the bitmask containing the changed signals
 | 
| sl@0 |    836 | 	 @param aSignalMask Bitmask of signals to be monitored
 | 
| sl@0 |    837 | 	 */
 | 
| sl@0 |    838 | 	inline void NotifySignalChange(TRequestStatus& aStatus,TUint& aSignals,TUint aSignalMask=0x3F);
 | 
| sl@0 |    839 | 	
 | 
| sl@0 |    840 | 	/**
 | 
| sl@0 |    841 | 	 Cancel a pending signal change notification request
 | 
| sl@0 |    842 | 	 */
 | 
| sl@0 |    843 | 	inline void NotifySignalChangeCancel();
 | 
| sl@0 |    844 | 	
 | 
| sl@0 |    845 | 	/**
 | 
| sl@0 |    846 | 	 Request notification when there is data available to be read from the driver receive buffer
 | 
| sl@0 |    847 | 	 @param aStatus The asynchronous request status
 | 
| sl@0 |    848 | 	 */
 | 
| sl@0 |    849 | 	inline void NotifyReceiveDataAvailable(TRequestStatus& aStatus);
 | 
| sl@0 |    850 | 	
 | 
| sl@0 |    851 | 	/**
 | 
| sl@0 |    852 | 	 Cancel a pending data notification request
 | 
| sl@0 |    853 | 	 */
 | 
| sl@0 |    854 | 	inline void NotifyReceiveDataAvailableCancel();
 | 
| sl@0 |    855 | 	
 | 
| sl@0 |    856 | 	/**
 | 
| sl@0 |    857 | 	 Get the minimum turnaround time before a transmission can begin after a receive operation
 | 
| sl@0 |    858 | 	 @return The turnaround time in microseconds 
 | 
| sl@0 |    859 | 	 */
 | 
| sl@0 |    860 | 	inline TUint MinTurnaroundTime();
 | 
| sl@0 |    861 | 	
 | 
| sl@0 |    862 | 	/**
 | 
| sl@0 |    863 | 	 Set the minimum turnaround time between a receive and the next transmission operation
 | 
| sl@0 |    864 | 	 @param aMicroSeconds The turnaround time in microseconds	               	
 | 
| sl@0 |    865 | 	 */
 | 
| sl@0 |    866 | 	inline TInt SetMinTurnaroundTime(TUint aMicroSeconds);
 | 
| sl@0 |    867 | 	
 | 
| sl@0 |    868 | #ifdef _DEBUG_DEVCOMM
 | 
| sl@0 |    869 | 	/**
 | 
| sl@0 |    870 | 	 Get the debug information
 | 
| sl@0 |    871 | 	 @param aInfo a packaged object to be filled by the driver with debug information
 | 
| sl@0 |    872 | 	 @see TCommDebugInfo
 | 
| sl@0 |    873 | 	 */
 | 
| sl@0 |    874 | 	inline void DebugInfo(TDes8 &aInfo);
 | 
| sl@0 |    875 | #endif
 | 
| sl@0 |    876 | #endif
 | 
| sl@0 |    877 | 	};
 | 
| sl@0 |    878 | 
 | 
| sl@0 |    879 | class RBusDevCommDCE : public RBusLogicalChannel
 | 
| sl@0 |    880 | 	{
 | 
| sl@0 |    881 | public:
 | 
| sl@0 |    882 | 	enum TVer {EMajorVersionNumber=1,EMinorVersionNumber=0,EBuildVersionNumber=KE32BuildVersionNumber};
 | 
| sl@0 |    883 | 	enum TRequest
 | 
| sl@0 |    884 | 		{
 | 
| sl@0 |    885 | 		ERequestRead=0x0,ERequestReadCancel=0x1,
 | 
| sl@0 |    886 | 		ERequestWrite=0x1,ERequestWriteCancel=0x2,
 | 
| sl@0 |    887 | 		ERequestBreak=0x2,ERequestBreakCancel=0x4,
 | 
| sl@0 |    888 | 		ERequestNotifySignalChange=0x3,ERequestNotifySignalChangeCancel=0x8,
 | 
| sl@0 |    889 | 		ERequestNotifyFlowControlChange=0x4,ERequestNotifyFlowControlChangeCancel=0x10,
 | 
| sl@0 |    890 | 		ERequestNotifyConfigChange=0x5,ERequestNotifyConfigChangeCancel=0x20
 | 
| sl@0 |    891 | 		};
 | 
| sl@0 |    892 | 	enum TControl
 | 
| sl@0 |    893 | 		{
 | 
| sl@0 |    894 | 		EControlConfig,EControlSetConfig,EControlCaps,
 | 
| sl@0 |    895 | 		EControlSignals,EControlSetSignals,
 | 
| sl@0 |    896 | 		EControlQueryReceiveBuffer,EControlResetBuffers,
 | 
| sl@0 |    897 | 		EControlReceiveBufferLength,EControlSetReceiveBufferLength,
 | 
| sl@0 |    898 | 		EControlFlowControlStatus,
 | 
| sl@0 |    899 | #ifdef _DEBUG_DEVCOMM
 | 
| sl@0 |    900 | 		EControlDebugInfo
 | 
| sl@0 |    901 | #endif
 | 
| sl@0 |    902 | 		};
 | 
| sl@0 |    903 | public:
 | 
| sl@0 |    904 | #ifndef __KERNEL_MODE__
 | 
| sl@0 |    905 | 	inline TInt Open(TInt aUnit);
 | 
| sl@0 |    906 | 	inline TVersion VersionRequired() const;
 | 
| sl@0 |    907 | 	inline void Read(TRequestStatus &aStatus,TDes8 &aDes);
 | 
| sl@0 |    908 | 	inline void Read(TRequestStatus &aStatus,TDes8 &aDes,TInt aLength);
 | 
| sl@0 |    909 | 	inline void ReadOneOrMore(TRequestStatus &aStatus,TDes8 &aDes);
 | 
| sl@0 |    910 | 	inline void ReadCancel();
 | 
| sl@0 |    911 | 	inline void Write(TRequestStatus &aStatus,const TDesC8 &aDes);
 | 
| sl@0 |    912 | 	inline void Write(TRequestStatus &aStatus,const TDesC8 &aDes,TInt aLength);
 | 
| sl@0 |    913 | 	inline void WriteCancel();
 | 
| sl@0 |    914 | 	inline void Break(TRequestStatus &aStatus,TInt aTime);
 | 
| sl@0 |    915 | 	inline void BreakCancel();
 | 
| sl@0 |    916 | 	inline void Config(TDes8 &aConfig);
 | 
| sl@0 |    917 | 	inline TInt SetConfig(const TDesC8 &aConfig);
 | 
| sl@0 |    918 | 	inline void Caps(TDes8 &aCaps);
 | 
| sl@0 |    919 | 	inline TUint Signals();
 | 
| sl@0 |    920 | 	inline void SetSignals(TUint aSetMask,TUint aClearMask);
 | 
| sl@0 |    921 | 	inline TInt QueryReceiveBuffer();
 | 
| sl@0 |    922 | 	inline void ResetBuffers();
 | 
| sl@0 |    923 | 	inline TInt ReceiveBufferLength();
 | 
| sl@0 |    924 | 	inline TInt SetReceiveBufferLength(TInt aLength);
 | 
| sl@0 |    925 | 	inline void NotifySignalChange(TRequestStatus& aStatus,TUint& aSignals,TUint aSignalMask=0x3F);
 | 
| sl@0 |    926 | 	inline void NotifySignalChangeCancel();
 | 
| sl@0 |    927 | 	inline void NotifyReceiveDataAvailable(TRequestStatus& aStatus);
 | 
| sl@0 |    928 | 	inline void NotifyReceiveDataAvailableCancel();
 | 
| sl@0 |    929 | 	inline void NotifyFlowControlChange(TRequestStatus& aStatus);
 | 
| sl@0 |    930 | 	inline void NotifyFlowControlChangeCancel();
 | 
| sl@0 |    931 | 	inline void GetFlowControlStatus(TFlowControl& aFlowControl);
 | 
| sl@0 |    932 | 	inline void NotifyConfigChange(TRequestStatus& aStatus, TDes8& aNewConfig);
 | 
| sl@0 |    933 | 	inline void NotifyConfigChangeCancel();
 | 
| sl@0 |    934 | #ifdef _DEBUG_DEVCOMM
 | 
| sl@0 |    935 | 	inline void DebugInfo(TDes8 &aInfo);
 | 
| sl@0 |    936 | #endif
 | 
| sl@0 |    937 | #endif
 | 
| sl@0 |    938 | 	};
 | 
| sl@0 |    939 | 
 | 
| sl@0 |    940 | #include <d32comm.inl>
 | 
| sl@0 |    941 | #endif
 |