epoc32/include/tcp_hdr.h
author William Roberts <williamr@symbian.org>
Wed, 31 Mar 2010 12:33:34 +0100
branchSymbian3
changeset 4 837f303aceeb
parent 2 2fe1408b6811
permissions -rw-r--r--
Current Symbian^3 public API header files (from PDK 3.0.h)
This is the epoc32/include tree with the "platform" subtrees removed, and
all but a selected few mbg and rsg files removed.
williamr@2
     1
// Copyright (c) 2004-2009 Nokia Corporation and/or its subsidiary(-ies).
williamr@2
     2
// All rights reserved.
williamr@2
     3
// This component and the accompanying materials are made available
williamr@4
     4
// under the terms of "Eclipse Public License v1.0"
williamr@2
     5
// which accompanies this distribution, and is available
williamr@4
     6
// at the URL "http://www.eclipse.org/legal/epl-v10.html".
williamr@2
     7
//
williamr@2
     8
// Initial Contributors:
williamr@2
     9
// Nokia Corporation - initial contribution.
williamr@2
    10
//
williamr@2
    11
// Contributors:
williamr@2
    12
//
williamr@2
    13
// Description:
williamr@2
    14
// tcp_hdr.h - TCP protocol header structure
williamr@2
    15
// Defines the basic classes for accessing the header structures within TCP packets.
williamr@2
    16
//
williamr@2
    17
williamr@2
    18
williamr@2
    19
williamr@2
    20
/**
williamr@2
    21
 @file tcp_hdr.h 
williamr@2
    22
 @ingroup ip_packet_formats
williamr@2
    23
 @publishedAll
williamr@2
    24
 @released
williamr@2
    25
*/
williamr@2
    26
williamr@2
    27
#ifndef __TCP_HDR_H__
williamr@2
    28
#define __TCP_HDR_H__
williamr@2
    29
williamr@2
    30
#include <e32std.h>
williamr@2
    31
#include "in_hdr.h"
williamr@2
    32
#include "sbque.h"
williamr@2
    33
williamr@2
    34
/**
williamr@2
    35
* @addtogroup ip_packet_formats
williamr@2
    36
* @{
williamr@2
    37
*/
williamr@2
    38
williamr@2
    39
//
williamr@2
    40
// TInet6HeaderTCP
williamr@2
    41
//
williamr@2
    42
//	*NOTE*
williamr@2
    43
//		TInet6HeaderTCP declares for maximum length TCP header
williamr@2
    44
//		(64	bytes). A valid TCP packet can be shorter and failing
williamr@2
    45
//		to map full 64 bytes from a packet is not an error condition.
williamr@2
    46
//
williamr@2
    47
williamr@2
    48
/** @name TCP Header length constants
williamr@2
    49
* @{
williamr@2
    50
*/
williamr@2
    51
const TInt KTcpMinHeaderLength = 20;
williamr@2
    52
const TInt KTcpMaxHeaderLength = 60;
williamr@2
    53
const TInt KTcpMaxOptionLength = 40;
williamr@2
    54
/** @} */
williamr@2
    55
williamr@2
    56
/** @name TCP control flags
williamr@2
    57
* @{
williamr@2
    58
*/
williamr@2
    59
const TUint8 KTcpCtlFIN = 1;
williamr@2
    60
const TUint8 KTcpCtlSYN = 2;
williamr@2
    61
const TUint8 KTcpCtlRST = 4;
williamr@2
    62
const TUint8 KTcpCtlPSH = 8;
williamr@2
    63
const TUint8 KTcpCtlACK = 16;
williamr@2
    64
const TUint8 KTcpCtlURG = 32;
williamr@2
    65
const TUint8 KTcpCtlECE = 0x40;
williamr@2
    66
const TUint8 KTcpCtlCWR = 0x80;
williamr@2
    67
/** @} */
williamr@2
    68
williamr@2
    69
/** @name TCP options
williamr@2
    70
* @{
williamr@2
    71
*/
williamr@2
    72
const TUint8 KTcpOptEnd		=  0;
williamr@2
    73
const TUint8 KTcpOptNop		=  1;
williamr@2
    74
const TUint8 KTcpOptMSS		=  2;
williamr@2
    75
const TUint8 KTcpOptWScale	=  3;
williamr@2
    76
const TUint8 KTcpOptSackOk	=  4;
williamr@2
    77
const TUint8 KTcpOptSack	=  5;
williamr@2
    78
const TUint8 KTcpOptTimeStamps  =  8;
williamr@2
    79
const TUint8 KTcpOptCount	=  9;
williamr@2
    80
williamr@2
    81
const TUint8 KTcpOptMinLen[] =  {1,  1,  4,  3,  2,  6,  2,  2, 10};
williamr@2
    82
const TUint8 KTcpOptMaxLen[] =  {1,  1,  4,  3,  2, 36, 40, 40, 10};
williamr@2
    83
const TUint32 KTcpOptAlignFlag = 0x00000001;
williamr@2
    84
/** @} */
williamr@2
    85
williamr@2
    86
williamr@2
    87
class TTcpOptions
williamr@2
    88
/** TCP Options Header.
williamr@2
    89
@publishedAll
williamr@2
    90
@released
williamr@2
    91
*/
williamr@2
    92
	{
williamr@2
    93
public:
williamr@2
    94
  	inline TTcpOptions()			      { Init(); }
williamr@2
    95
  	IMPORT_C void Init();
williamr@2
    96
  	IMPORT_C TInt Length() const;
williamr@2
    97
  	inline TBool Error() const		  { return iError; }
williamr@2
    98
  	inline void ClearError()		      { iError = EFalse; }
williamr@2
    99
williamr@2
   100
  	inline TInt MSS() const		      { return iMSS; }
williamr@2
   101
  	inline void SetMSS(TInt aMSS)		  { iMSS = aMSS; }
williamr@2
   102
  	inline void ClearMSS()		      { iMSS = -1; }
williamr@2
   103
williamr@2
   104
  	inline TBool TimeStamps() const	  { return iTimeStamps; }
williamr@2
   105
  	inline TBool TimeStamps(TUint32& aTsVal, TUint32& aTsEcr) const
williamr@2
   106
    	{
williamr@2
   107
      	aTsVal = iTsVal;
williamr@2
   108
      	aTsEcr = iTsEcr;
williamr@2
   109
      	return iTimeStamps;
williamr@2
   110
    	}
williamr@2
   111
  	inline void SetTimeStamps(TUint32 aTsVal, TUint32 aTsEcr)
williamr@2
   112
    	{
williamr@2
   113
      	iTsVal = aTsVal;
williamr@2
   114
      	iTsEcr = aTsEcr;
williamr@2
   115
      	iTimeStamps = ETrue;
williamr@2
   116
    	}
williamr@2
   117
  	inline void ClearTimeStamps()		  { iTimeStamps = EFalse; }
williamr@2
   118
williamr@2
   119
  	inline TBool SackOk() const		  { return iSackOk; }
williamr@2
   120
  	inline void SetSackOk()		      { iSackOk = ETrue; }
williamr@2
   121
  	inline void ClearSackOk()		      { iSackOk = EFalse; }
williamr@2
   122
  	inline void SuppressSack(TBool aBool=ETrue) { iSuppressSack = aBool; }
williamr@2
   123
  	inline SequenceBlockQueue& SackBlocks()     { return iBlocks; }
williamr@2
   124
williamr@2
   125
  	inline TInt Unknown() const		  { return iUnknown; }
williamr@2
   126
  	inline void ClearUnknown()		  { iUnknown = 0; }
williamr@2
   127
  
williamr@4
   128
  	// Query window scale option from TCP header options.
williamr@4
   129
  	// Wscale == 1 means scale factor 1, i.e. shift count of 0 is used in TCP option.
williamr@4
   130
  	// Wscale == 0 means that wscale option is not used in TCP header.
williamr@2
   131
  	inline TUint WindowScale() const		{ return iWscale; }
williamr@2
   132
williamr@2
   133
  	inline void SetWindowScale(TUint8 aWscale)	{ iWscale = aWscale; }
williamr@2
   134
  	
williamr@2
   135
  	/**
williamr@2
   136
  	If set, each option will be aligned to 32-bit longword boundaries with Nop padding.
williamr@2
   137
  	By default the Nop padding is not applied.
williamr@2
   138
  	
williamr@2
   139
  	@param aAlignNop	ETrue if option alignment should be applied. 
williamr@2
   140
	*/
williamr@2
   141
  	inline void SetAlignOpt(TBool aAlignOpt) 
williamr@2
   142
  		{ 
williamr@2
   143
  		if(aAlignOpt) 
williamr@2
   144
  			iFlags |= KTcpOptAlignFlag; 
williamr@2
   145
  		else 
williamr@2
   146
  			iFlags &= ~KTcpOptAlignFlag;
williamr@2
   147
  		}
williamr@2
   148
williamr@2
   149
private:
williamr@2
   150
  	friend class TInet6HeaderTCP;
williamr@2
   151
williamr@2
   152
  	IMPORT_C TBool ProcessOptions(const TUint8 *aPtr, TUint aLen);
williamr@2
   153
  	IMPORT_C TUint OutputOptions(TUint8 *aPtr, TUint aMaxLen);
williamr@2
   154
  	
williamr@2
   155
  	void CheckOptAlignment(TUint8* aPtr, TUint& aI, TUint aNumBytes);
williamr@2
   156
  	
williamr@2
   157
  	inline TInt AlignedLength(TInt aLength) const
williamr@2
   158
  	/**
williamr@2
   159
  	Calculate the actual space requirement for option with given length.
williamr@2
   160
  	
williamr@2
   161
  	Takes optional 32-bit alignment into account.
williamr@2
   162
  	*/
williamr@2
   163
  		{ if (iFlags & KTcpOptAlignFlag) return (aLength + 3) & ~3; else return aLength; }
williamr@2
   164
williamr@2
   165
  	TInt	              iMSS;
williamr@2
   166
  	TInt	              iUnknown;
williamr@2
   167
  	TUint32             iTsVal;
williamr@2
   168
  	TUint32             iTsEcr;
williamr@2
   169
  	SequenceBlockQueue  iBlocks;
williamr@2
   170
  	TBool	              iError;
williamr@2
   171
  	TBool	              iTimeStamps;
williamr@2
   172
  	TBool	              iSackOk;
williamr@2
   173
  	TBool               iSuppressSack;
williamr@4
   174
  	TUint				iWscale;	//< Window scale option [RFC 1323].
williamr@4
   175
  	TUint32				iFlags;	//< ETrue if options are to be aligned.
williamr@2
   176
	};
williamr@2
   177
williamr@2
   178
williamr@2
   179
williamr@2
   180
class TInet6HeaderTCP
williamr@2
   181
/**  TCP segment header.
williamr@2
   182
@verbatim
williamr@2
   183
Extract from RFC-793
williamr@2
   184
williamr@2
   185
    0                   1                   2                   3
williamr@2
   186
    0 1 2 3 4 5 6 7 8 9 0 1 2 3 4 5 6 7 8 9 0 1 2 3 4 5 6 7 8 9 0 1
williamr@2
   187
   +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
williamr@2
   188
   |          Source Port          |       Destination Port        |
williamr@2
   189
   +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
williamr@2
   190
   |                        Sequence Number                        |
williamr@2
   191
   +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
williamr@2
   192
   |                    Acknowledgment Number                      |
williamr@2
   193
   +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
williamr@2
   194
   |  Data |           |U|A|P|R|S|F|                               |
williamr@2
   195
   | Offset| Reserved  |R|C|S|S|Y|I|            Window             |
williamr@2
   196
   |       |           |G|K|H|T|N|N|                               |
williamr@2
   197
   +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
williamr@2
   198
   |           Checksum            |         Urgent Pointer        |
williamr@2
   199
   +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
williamr@2
   200
   |                    Options                    |    Padding    |
williamr@2
   201
   +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
williamr@2
   202
   |                             data                              |
williamr@2
   203
   +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
williamr@2
   204
@endverbatim
williamr@2
   205
@publishedAll
williamr@2
   206
@released
williamr@2
   207
*/
williamr@2
   208
	{
williamr@2
   209
public:
williamr@2
   210
	//
williamr@2
   211
	// Basic
williamr@2
   212
	//
williamr@2
   213
	inline static TInt MinHeaderLength() {return KTcpMinHeaderLength; }
williamr@2
   214
	inline static TInt MaxHeaderLength() {return KTcpMaxHeaderLength; }
williamr@2
   215
	inline TUint8 *EndPtr() {return i + HeaderLength();}
williamr@2
   216
	//
williamr@2
   217
	// Access, Get TCP field values from the packet
williamr@2
   218
	//
williamr@2
   219
	inline TUint SrcPort() const
williamr@2
   220
		{
williamr@2
   221
		return (i[0] << 8) + i[1];
williamr@2
   222
		}
williamr@2
   223
	inline TUint DstPort() const
williamr@2
   224
		{
williamr@2
   225
		return (i[2] << 8) + i[3];
williamr@2
   226
		}
williamr@2
   227
	inline TTcpSeqNum Sequence() const
williamr@2
   228
		{
williamr@2
   229
		return (i[4] << 24) | (i[5] << 16) | (i[6] << 8) | i[7];
williamr@2
   230
		}
williamr@2
   231
	inline TTcpSeqNum Acknowledgment() const
williamr@2
   232
		{
williamr@2
   233
		return (i[8] << 24) | (i[9] << 16) | (i[10] << 8) | i[11];
williamr@2
   234
		}
williamr@2
   235
	inline TInt HeaderLength() const
williamr@2
   236
		{
williamr@2
   237
		// Return TCP Header Length in bytes (including options and padding)
williamr@2
   238
		return (i[12] >> 2) & (0xF << 2);
williamr@2
   239
		}
williamr@2
   240
	//
williamr@2
   241
	// A testing method for each individual Control Bit is provided
williamr@2
   242
	// (It remains to be seen whether this is useful or not). Note
williamr@2
   243
	// also that the result of the AND is returned, not 0 and 1.
williamr@2
   244
	//
williamr@2
   245
	inline TInt FIN() const
williamr@2
   246
		{
williamr@2
   247
		return i[13] & KTcpCtlFIN;
williamr@2
   248
		}
williamr@2
   249
	inline TInt SYN() const
williamr@2
   250
		{
williamr@2
   251
		return i[13] & KTcpCtlSYN;
williamr@2
   252
		}
williamr@2
   253
	inline TInt RST() const
williamr@2
   254
		{
williamr@2
   255
		return i[13] & KTcpCtlRST;
williamr@2
   256
		}
williamr@2
   257
	inline TInt PSH() const
williamr@2
   258
		{
williamr@2
   259
		return i[13] & KTcpCtlPSH;
williamr@2
   260
		}
williamr@2
   261
	inline TInt ACK() const
williamr@2
   262
		{
williamr@2
   263
		return i[13] & KTcpCtlACK;
williamr@2
   264
		}
williamr@2
   265
	inline TInt URG() const
williamr@2
   266
		{
williamr@2
   267
		return i[13] & KTcpCtlURG;
williamr@2
   268
		}
williamr@2
   269
williamr@4
   270
	// ECN Echo flag [RFC 3168].
williamr@2
   271
	inline TInt ECE() const
williamr@2
   272
		{
williamr@2
   273
		return i[13] & KTcpCtlECE;
williamr@2
   274
		}
williamr@2
   275
williamr@4
   276
	// ECN: Congestion Window Reduced [RFC 3168].
williamr@2
   277
	inline TInt CWR() const
williamr@2
   278
		{
williamr@2
   279
		return i[13] & KTcpCtlCWR;
williamr@2
   280
		}	
williamr@2
   281
		
williamr@2
   282
	// A method to access all of the above as is. Note that this
williamr@2
   283
	// also returns the reserved unspecified bits. Value can be
williamr@2
   284
	// non-zero, even if none of the above is set. However, it only
williamr@2
   285
	// returns unspecified bits from the 13th byte, not any from 12th!
williamr@2
   286
	inline TUint8 Control() const
williamr@2
   287
		{
williamr@2
   288
		return i[13];
williamr@2
   289
		}
williamr@2
   290
	//
williamr@2
   291
	inline TUint Window() const
williamr@2
   292
		{
williamr@2
   293
		return (i[14] << 8) + i[15];
williamr@2
   294
		}
williamr@2
   295
	inline TUint Checksum() const
williamr@2
   296
		{
williamr@2
   297
		// Checksum is used in network byte order
williamr@2
   298
		return *((TUint16 *)&i[16]);
williamr@2
   299
		}
williamr@2
   300
	inline TUint Urgent() const
williamr@2
   301
		{
williamr@2
   302
		return (i[18] << 8) + i[19];
williamr@2
   303
		}
williamr@2
   304
	inline TBool Options(TTcpOptions& aOptions) const
williamr@2
   305
		{
williamr@2
   306
		return aOptions.ProcessOptions(i + KTcpMinHeaderLength, HeaderLength() - KTcpMinHeaderLength);
williamr@2
   307
		}
williamr@2
   308
	//Backwards compatibility, mainly for IPRotor.
williamr@2
   309
	inline TPtr8 Options() const
williamr@2
   310
		{
williamr@2
   311
		TInt len = HeaderLength() - 20;
williamr@2
   312
		return TPtr8((TUint8 *)&i[20], len, len);
williamr@2
   313
		}
williamr@2
   314
williamr@2
   315
	//
williamr@2
   316
	// Build, Set TCP field value to the packet
williamr@2
   317
	//
williamr@2
   318
	inline void SetSrcPort(TUint aPort)
williamr@2
   319
		{
williamr@2
   320
		i[0] = (TUint8)(aPort >> 8);
williamr@2
   321
		i[1] = (TUint8)aPort;
williamr@2
   322
		}
williamr@2
   323
	inline void SetDstPort(TUint aPort)
williamr@2
   324
		{
williamr@2
   325
		i[2] = (TUint8)(aPort >> 8);
williamr@2
   326
		i[3] = (TUint8)aPort;
williamr@2
   327
		}
williamr@2
   328
	inline void SetSequence(TTcpSeqNum aSeq)
williamr@2
   329
		{
williamr@2
   330
		i[7] = (TUint8)aSeq.Uint32();
williamr@2
   331
		i[6] = (TUint8)(aSeq.Uint32() >> 8);
williamr@2
   332
		i[5] = (TUint8)(aSeq.Uint32() >> 16);
williamr@2
   333
		i[4] = (TUint8)(aSeq.Uint32() >> 24);
williamr@2
   334
		}
williamr@2
   335
	inline void SetAcknowledgment(TTcpSeqNum aAck)
williamr@2
   336
		{
williamr@2
   337
		i[11] = (TUint8)aAck.Uint32();
williamr@2
   338
		i[10] = (TUint8)(aAck.Uint32() >> 8);
williamr@2
   339
		i[9] = (TUint8)(aAck.Uint32() >> 16);
williamr@2
   340
		i[8] = (TUint8)(aAck.Uint32() >> 24);
williamr@2
   341
		}
williamr@2
   342
	inline void SetHeaderLength(TUint aLength)
williamr@2
   343
		{
williamr@2
   344
		// *NOTE* A very low level function, no sanity
williamr@2
   345
		// checks on value, no rounding up. Value is just
williamr@2
   346
		// truncated and shifted to the proper position
williamr@2
   347
		// (all other bits of this byte should always
williamr@2
   348
		// be zero!)
williamr@2
   349
		i[12] = (TUint8)((aLength >> 2) <<4);
williamr@2
   350
		}
williamr@2
   351
	//
williamr@2
   352
	// A set method for each individual Control Bit is provided
williamr@2
   353
	// (It remains to be seen whether this is sensible or not).
williamr@2
   354
	//
williamr@2
   355
	inline void SetFIN()
williamr@2
   356
		{
williamr@2
   357
		i[13] |= KTcpCtlFIN;
williamr@2
   358
		}
williamr@2
   359
	inline void SetSYN()
williamr@2
   360
		{
williamr@2
   361
		i[13] |= KTcpCtlSYN;
williamr@2
   362
		}
williamr@2
   363
	inline void SetRST()
williamr@2
   364
		{
williamr@2
   365
		i[13] |= KTcpCtlRST;
williamr@2
   366
		}
williamr@2
   367
	inline void SetPSH()
williamr@2
   368
		{
williamr@2
   369
		i[13] |= KTcpCtlPSH;
williamr@2
   370
		}
williamr@2
   371
	inline void SetACK()
williamr@2
   372
		{
williamr@2
   373
		i[13] |= KTcpCtlACK;
williamr@2
   374
		}
williamr@2
   375
	inline void SetURG()
williamr@2
   376
		{
williamr@2
   377
		i[13] |= KTcpCtlURG;
williamr@2
   378
		}
williamr@2
   379
		
williamr@4
   380
	// Set ECN Echo flag [RFC 3168].
williamr@2
   381
	inline void SetECE()
williamr@2
   382
		{
williamr@2
   383
		i[13] |= KTcpCtlECE;
williamr@2
   384
		}
williamr@2
   385
		
williamr@4
   386
	// Set ECN Congestion Window Reduced [RFC 3168].
williamr@2
   387
	inline void SetCWR()
williamr@2
   388
		{
williamr@2
   389
		i[13] |= KTcpCtlCWR;
williamr@2
   390
		}
williamr@2
   391
		
williamr@2
   392
	//
williamr@2
   393
	// Note: does not touch the unused control bits at 12th byte!!!
williamr@2
   394
	//
williamr@2
   395
	inline void SetControl(TUint8 aFlags)
williamr@2
   396
		{
williamr@2
   397
		i[13] = aFlags;
williamr@2
   398
		}
williamr@2
   399
	//
williamr@2
   400
	inline void SetWindow(TUint aWin)
williamr@2
   401
		{
williamr@2
   402
		i[15] = (TUint8)aWin;
williamr@2
   403
		i[14] = (TUint8)(aWin >> 8);
williamr@2
   404
		}
williamr@2
   405
	inline void SetChecksum(TUint aSum)
williamr@2
   406
		{
williamr@2
   407
		// Checksum is used in network byte order
williamr@2
   408
		*((TUint16 *)&i[16]) = (TUint16)aSum;
williamr@2
   409
		}
williamr@2
   410
	inline void SetUrgent(TUint aOff)
williamr@2
   411
		{
williamr@2
   412
		i[19] = (TUint8)aOff;
williamr@2
   413
		i[18] = (TUint8)(aOff >> 8);
williamr@2
   414
		}
williamr@2
   415
	inline TInt SetOptions(TTcpOptions& aOptions)
williamr@2
   416
		{
williamr@2
   417
		TInt optLen = aOptions.OutputOptions(i + KTcpMinHeaderLength, KTcpMaxOptionLength);
williamr@2
   418
		SetHeaderLength(KTcpMinHeaderLength + optLen);
williamr@2
   419
		return optLen;
williamr@2
   420
		}
williamr@2
   421
williamr@2
   422
protected:
williamr@2
   423
	TUint8 i[KTcpMaxHeaderLength];
williamr@2
   424
	};
williamr@2
   425
williamr@2
   426
/** @} */
williamr@2
   427
#endif