epoc32/include/ext_hdr.h
author William Roberts <williamr@symbian.org>
Tue, 16 Mar 2010 16:12:26 +0000
branchSymbian2
changeset 2 2fe1408b6811
child 4 837f303aceeb
permissions -rw-r--r--
Final list of Symbian^2 public API header files
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@2
     4
// under the terms of the License "Symbian Foundation License v1.0" to Symbian Foundation members and "Symbian Foundation End User License Agreement v1.0" to non-members
williamr@2
     5
// which accompanies this distribution, and is available
williamr@2
     6
// at the URL "http://www.symbianfoundation.org/legal/licencesv10.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
// ext_hdr.h - IPv6 extension headers
williamr@2
    15
// Defines the basic classes for accessing the extension
williamr@2
    16
// header structures within IPv6 packets.
williamr@2
    17
// All return types codified as TInt (Native form and signed)
williamr@2
    18
//
williamr@2
    19
williamr@2
    20
williamr@2
    21
williamr@2
    22
/**
williamr@2
    23
 @file ext_hdr.h
williamr@2
    24
 @ingroup ip_packet_formats
williamr@2
    25
 @publishedAll
williamr@2
    26
 @released
williamr@2
    27
*/
williamr@2
    28
williamr@2
    29
#ifndef __EXT_HDR_H__
williamr@2
    30
#define __EXT_HDR_H__
williamr@2
    31
williamr@2
    32
#include <e32def.h>
williamr@2
    33
#include "in_hdr.h"
williamr@2
    34
williamr@2
    35
/**
williamr@2
    36
* @addtogroup  ip_packet_formats
williamr@2
    37
* @{
williamr@2
    38
*/
williamr@2
    39
williamr@2
    40
/**
williamr@2
    41
* @name Additional protocol numbers
williamr@2
    42
*
williamr@2
    43
* @{
williamr@2
    44
*/
williamr@2
    45
/** Hop-by-Hop Extension Header. See TInet6HeaderHopByHop. */
williamr@2
    46
const TUint KProtocolInet6HopOptions = 0;
williamr@2
    47
/** Tunneled IPv4. The next header is TInet6HeaderIP4. */
williamr@2
    48
const TUint KProtocolInetIpip = 4;
williamr@2
    49
/** Routing Header. See TInet6HeaderRouting. */
williamr@2
    50
const TUint KProtocolInet6RoutingHeader = 43;
williamr@2
    51
/** IPv6 Fragment Header. See TInet6HeaderFragment. */
williamr@2
    52
const TUint KProtocolInet6Fragment = 44;
williamr@2
    53
/** IPsec ESP header. See TInet6HeaderESP. */
williamr@2
    54
const TUint KProtocolInetEsp	= 50;
williamr@2
    55
/** IPsec AH header. See TInet6HeaderAH. */
williamr@2
    56
const TUint KProtocolInetAh = 51;
williamr@2
    57
/** No Next Header. */
williamr@2
    58
const TUint KProtocolInet6NoNextHeader = 59;
williamr@2
    59
/** Destination Options Extension Header. See TInet6Options. */
williamr@2
    60
const TUint KProtocolInet6DestinationOptions = 60;
williamr@2
    61
/* @} */
williamr@2
    62
williamr@2
    63
//
williamr@2
    64
// TInet6HeaderExtension
williamr@2
    65
// *********************
williamr@2
    66
class TInet6HeaderExtension
williamr@2
    67
	/**
williamr@2
    68
	* Basic part of normal IPv6 extension headers.
williamr@2
    69
	*
williamr@2
    70
	* This is simple class to be used in scanning the extension headers
williamr@2
    71
	* which are known to follow the following format:
williamr@2
    72
	*
williamr@2
    73
	* - 1st octet = Next Header field
williamr@2
    74
	*
williamr@2
    75
	* - 2nd octet = Length of the extension header (= (x+1)*8 octets)
williamr@2
    76
	*
williamr@2
    77
	* @note
williamr@2
    78
	*	Extension headers do not need to follow this format. Unknown
williamr@2
    79
	*	headers cannot be skipped over by just assuming this format!
williamr@2
    80
	*
williamr@2
    81
	* @publishedAll
williamr@2
    82
	* @released
williamr@2
    83
	*/
williamr@2
    84
	{
williamr@2
    85
public:
williamr@2
    86
	inline static TInt MinHeaderLength() {return 8; }
williamr@2
    87
	inline static TInt MaxHeaderLength() {return 8; }	
williamr@2
    88
williamr@2
    89
	inline TUint8* EndPtr() { return i + HeaderLength(); }
williamr@2
    90
	inline TInt NextHeader() const { return i[0]; }
williamr@2
    91
	inline TInt HdrExtLen() const { return i[1]; }	// Return raw value
williamr@2
    92
	inline TInt HeaderLength() const { return (i[1]+1) << 3; } // Return true byte length
williamr@2
    93
private:
williamr@2
    94
	union
williamr@2
    95
		{
williamr@2
    96
		TUint8 i[8];
williamr@2
    97
		TUint32 iAlign;	// A dummy member to force the 4 byte alignment
williamr@2
    98
		};
williamr@2
    99
	};
williamr@2
   100
williamr@2
   101
williamr@2
   102
class TInet6HeaderHBH
williamr@2
   103
	/**
williamr@2
   104
	* IPv6 Hop-by-hop options header.
williamr@2
   105
@verbatim
williamr@2
   106
	From RFC 2460
williamr@2
   107
williamr@2
   108
    +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
williamr@2
   109
    |  Next Header  |  Hdr Ext Len  |                               |
williamr@2
   110
    +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+                               +
williamr@2
   111
    |                                                               |
williamr@2
   112
    .                                                               .
williamr@2
   113
    .                            Options                            .
williamr@2
   114
    .                                                               .
williamr@2
   115
    |                                                               |
williamr@2
   116
    +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
williamr@2
   117
williamr@2
   118
   Next Header          8-bit selector.  Identifies the type of header
williamr@2
   119
                        immediately following the Hop-by-Hop Options
williamr@2
   120
                        header.  Uses the same values as the IPv4
williamr@2
   121
                        Protocol field [RFC-1700 et seq.].
williamr@2
   122
williamr@2
   123
   Hdr Ext Len          8-bit unsigned integer.  Length of the Hop-by-
williamr@2
   124
                        Hop Options header in 8-octet units, not
williamr@2
   125
                        including the first 8 octets.
williamr@2
   126
williamr@2
   127
   Options              Variable-length field, of length such that the
williamr@2
   128
                        complete Hop-by-Hop Options header is an integer
williamr@2
   129
                        multiple of 8 octets long.  Contains one or more
williamr@2
   130
                        TLV-encoded options, as described in section
williamr@2
   131
                        4.2.
williamr@2
   132
williamr@2
   133
  And Options is:
williamr@2
   134
williamr@2
   135
	  +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+- - - - - - - - -
williamr@2
   136
      |  Option Type  |  Opt Data Len |  Option Data
williamr@2
   137
      +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+- - - - - - - - -
williamr@2
   138
williamr@2
   139
      Option Type          8-bit identifier of the type of option.
williamr@2
   140
williamr@2
   141
      Opt Data Len         8-bit unsigned integer.  Length of the Option
williamr@2
   142
                           Data field of this option, in octets.
williamr@2
   143
williamr@2
   144
      Option Data          Variable-length field.  Option-Type-specific
williamr@2
   145
                           data.
williamr@2
   146
@endverbatim
williamr@2
   147
	* @publishedAll
williamr@2
   148
	* @released
williamr@2
   149
	*/
williamr@2
   150
	{
williamr@2
   151
public:
williamr@2
   152
	inline TInt HeaderLength() const
williamr@2
   153
		{
williamr@2
   154
		return (i[1]+1) << 3;	// Return length in octets.
williamr@2
   155
		}
williamr@2
   156
williamr@2
   157
	inline TUint8* EndPtr() { return i + HeaderLength(); }
williamr@2
   158
williamr@2
   159
	inline static TInt MinHeaderLength() {return 8; }	
williamr@2
   160
	inline static TInt MaxHeaderLength() {return 8; }
williamr@2
   161
	
williamr@2
   162
	//
williamr@2
   163
	// Access, Get Hop By Hop header values from the packet
williamr@2
   164
	//
williamr@2
   165
	inline TInt NextHeader() const
williamr@2
   166
		{
williamr@2
   167
		return i[0];
williamr@2
   168
		}
williamr@2
   169
williamr@2
   170
	//From Options
williamr@2
   171
	inline TInt OptionType() const
williamr@2
   172
		/** @return The type of the first option */
williamr@2
   173
		{
williamr@2
   174
		return i[2];
williamr@2
   175
		}
williamr@2
   176
	inline TInt OptionDataLen() const
williamr@2
   177
		/** @return The data length of the first option */
williamr@2
   178
		{
williamr@2
   179
		return i[3];
williamr@2
   180
		}
williamr@2
   181
williamr@2
   182
	//
williamr@2
   183
	// Access, SET Hop By Hop header values
williamr@2
   184
	//
williamr@2
   185
	inline void SetHdrExtLen(TInt aLength)
williamr@2
   186
		{
williamr@2
   187
		i[1]=(TUint8)aLength;
williamr@2
   188
		}
williamr@2
   189
	
williamr@2
   190
	inline void SetNextHeader(TInt aNext)
williamr@2
   191
		{
williamr@2
   192
		i[0]=(TUint8)aNext;
williamr@2
   193
		}
williamr@2
   194
williamr@2
   195
	//From Options
williamr@2
   196
	inline void SetOptionType(TInt aType)
williamr@2
   197
		/** Sets type of the first option.*/
williamr@2
   198
		{
williamr@2
   199
		i[2]=(TUint8)aType;
williamr@2
   200
		}
williamr@2
   201
williamr@2
   202
	inline void SetOptionDataLen(TInt aLength)
williamr@2
   203
		/** Sets data length of the first option.*/
williamr@2
   204
		{
williamr@2
   205
		i[3]=(TUint8)aLength;
williamr@2
   206
		}
williamr@2
   207
williamr@2
   208
private:
williamr@2
   209
	union
williamr@2
   210
		{
williamr@2
   211
		TUint8 i[8];
williamr@2
   212
		TUint32 iAlign;	// A dummy member to force the 4 byte alignment
williamr@2
   213
		};
williamr@2
   214
	};
williamr@2
   215
williamr@2
   216
williamr@2
   217
class TInet6HeaderHopByHop
williamr@2
   218
	/**
williamr@2
   219
	* IPv6 Hop-by-hop options header.
williamr@2
   220
	* @publishedAll
williamr@2
   221
	* @deprecated
williamr@2
   222
	*	Because of the non-standard method naming and
williamr@2
   223
	*	semantics. Use TInet6HeaderHBH instead.
williamr@2
   224
	*/
williamr@2
   225
	{
williamr@2
   226
public:
williamr@2
   227
	inline TInt HeaderLength() const
williamr@2
   228
		{
williamr@2
   229
		return i[1];
williamr@2
   230
		}
williamr@2
   231
williamr@2
   232
	inline TUint8* EndPtr() { return i + HeaderLength() * 8 + MinHeaderLength(); }
williamr@2
   233
williamr@2
   234
	inline static TInt MinHeaderLength() {return 8; }	
williamr@2
   235
	inline static TInt MaxHeaderLength() {return 8; }
williamr@2
   236
	
williamr@2
   237
	//
williamr@2
   238
	// Access, Get Hop By Hop header values from the packet
williamr@2
   239
	//
williamr@2
   240
	inline TInt NextHeader() const
williamr@2
   241
		/** @return The length in 8-byte units! (non-standard, should be bytes!) */
williamr@2
   242
		{
williamr@2
   243
		return i[0];
williamr@2
   244
		}
williamr@2
   245
williamr@2
   246
	//From Options
williamr@2
   247
	inline TInt OptionType() const
williamr@2
   248
		/** @return The type of the first option */
williamr@2
   249
		{
williamr@2
   250
		return i[2];
williamr@2
   251
		}
williamr@2
   252
	inline TInt OptionDataLen() const
williamr@2
   253
		/** @return The data length of the first option */
williamr@2
   254
		{
williamr@2
   255
		return i[3];
williamr@2
   256
		}
williamr@2
   257
williamr@2
   258
	//
williamr@2
   259
	// Access, SET Hop By Hop header values
williamr@2
   260
	//
williamr@2
   261
	inline void SetHeaderLength(TInt aLength)
williamr@2
   262
		{
williamr@2
   263
		i[1]=(TUint8)aLength;
williamr@2
   264
		}
williamr@2
   265
	
williamr@2
   266
	inline void SetNextHeader(TInt aNext)
williamr@2
   267
		{
williamr@2
   268
		i[0]=(TUint8)aNext;
williamr@2
   269
		}
williamr@2
   270
williamr@2
   271
	//From Options
williamr@2
   272
	inline void SetOptionType(TInt aType)
williamr@2
   273
		/** Sets type of the first option.*/
williamr@2
   274
		{
williamr@2
   275
		i[2]=(TUint8)aType;
williamr@2
   276
		}
williamr@2
   277
williamr@2
   278
	inline void SetOptionDataLen(TInt aLength)
williamr@2
   279
		/** Sets data length of the first option.*/
williamr@2
   280
		{
williamr@2
   281
		i[3]=(TUint8)aLength;
williamr@2
   282
		}
williamr@2
   283
williamr@2
   284
private:
williamr@2
   285
	union
williamr@2
   286
		{
williamr@2
   287
		TUint8 i[8];
williamr@2
   288
		TUint32 iAlign;	// A dummy member to force the 4 byte alignment
williamr@2
   289
		};
williamr@2
   290
	};
williamr@2
   291
williamr@2
   292
class TInet6HeaderRouting
williamr@2
   293
	/**
williamr@2
   294
	* IPv6 Routing Header.
williamr@2
   295
	* The Type 0 Routing header has the following format:
williamr@2
   296
@verbatim
williamr@2
   297
williamr@2
   298
    +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
williamr@2
   299
    |  Next Header  |  Hdr Ext Len  | Routing Type=0| Segments Left |
williamr@2
   300
    +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
williamr@2
   301
    |                            Reserved                           |
williamr@2
   302
    +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
williamr@2
   303
    |                                                               |
williamr@2
   304
    +                                                               +
williamr@2
   305
    |                                                               |
williamr@2
   306
    +                           Address[1]                          +
williamr@2
   307
    |                                                               |
williamr@2
   308
    +                                                               +
williamr@2
   309
    |                                                               |
williamr@2
   310
    +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
williamr@2
   311
    |                                                               |
williamr@2
   312
    +                                                               +
williamr@2
   313
    |                                                               |
williamr@2
   314
    +                           Address[2]                          +
williamr@2
   315
    |                                                               |
williamr@2
   316
    +                                                               +
williamr@2
   317
    |                                                               |
williamr@2
   318
    +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
williamr@2
   319
    .                               .                               .
williamr@2
   320
    .                               .                               .
williamr@2
   321
    .                               .                               .
williamr@2
   322
    +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
williamr@2
   323
    |                                                               |
williamr@2
   324
    +                                                               +
williamr@2
   325
    |                                                               |
williamr@2
   326
    +                           Address[n]                          +
williamr@2
   327
    |                                                               |
williamr@2
   328
    +                                                               +
williamr@2
   329
    |                                                               |
williamr@2
   330
    +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
williamr@2
   331
williamr@2
   332
   Next Header          8-bit selector.  Identifies the type of header
williamr@2
   333
                        immediately following the Routing header.  Uses
williamr@2
   334
                        the same values as the IPv4 Protocol field
williamr@2
   335
                        [RFC-1700 et seq.].
williamr@2
   336
williamr@2
   337
   Hdr Ext Len          8-bit unsigned integer.  Length of the Routing
williamr@2
   338
                        header in 8-octet units, not including the first
williamr@2
   339
                        8 octets.  For the Type 0 Routing header, Hdr
williamr@2
   340
                        Ext Len is equal to two times the number of
williamr@2
   341
                        addresses in the header.
williamr@2
   342
williamr@2
   343
   Routing Type         0.
williamr@2
   344
williamr@2
   345
williamr@2
   346
   Segments Left        8-bit unsigned integer.  Number of route
williamr@2
   347
                        segments remaining, i.e., number of explicitly
williamr@2
   348
                        listed intermediate nodes still to be visited
williamr@2
   349
                        before reaching the final destination.
williamr@2
   350
williamr@2
   351
   Reserved             32-bit reserved field.  Initialized to zero for
williamr@2
   352
                        transmission; ignored on reception.
williamr@2
   353
williamr@2
   354
   Address[1..n]        Vector of 128-bit addresses, numbered 1 to n.
williamr@2
   355
williamr@2
   356
@endverbatim
williamr@2
   357
	* This header mapping describes only the fixed part, without
williamr@2
   358
	* any addresses.
williamr@2
   359
	* @publishedAll
williamr@2
   360
	* @released
williamr@2
   361
	*/
williamr@2
   362
	{
williamr@2
   363
public:
williamr@2
   364
	inline static TInt MinHeaderLength() {return 8; }
williamr@2
   365
	inline static TInt MaxHeaderLength() {return 8; }	
williamr@2
   366
williamr@2
   367
	inline TUint8* EndPtr() { return i + HeaderLength(); }
williamr@2
   368
williamr@2
   369
	enum TOffsets
williamr@2
   370
		{
williamr@2
   371
		O_NextHeader,
williamr@2
   372
		O_HdrExtLen,
williamr@2
   373
		O_RoutingType,
williamr@2
   374
		O_SegmentsLeft,
williamr@2
   375
		O_Address = 8
williamr@2
   376
		};
williamr@2
   377
williamr@2
   378
	inline TInt NextHeader() const { return i[0]; }
williamr@2
   379
	inline TInt HdrExtLen() const { return i[1]; }	// Return raw value
williamr@2
   380
	inline TInt HeaderLength() const { return (i[1]+1) << 3; } // Return true byte length
williamr@2
   381
	inline TInt RoutingType() const { return i[2]; }
williamr@2
   382
	inline TInt SegmentsLeft() const { return i[3]; }
williamr@2
   383
	
williamr@2
   384
	//SET
williamr@2
   385
	inline void SetNextHeader(TInt aNext) { i[0] = (TInt8)aNext; }
williamr@2
   386
	inline void SetHdrExtLen(TInt aLen) { i[1] = (TUint8)aLen; }	
williamr@2
   387
	inline void SetRoutingType(TInt aType) { i[2] = (TUint8)aType; }
williamr@2
   388
	inline void SetSegmentsLeft(TInt aValue) { i[3] = (TUint8)aValue; }
williamr@2
   389
williamr@2
   390
private:
williamr@2
   391
	union
williamr@2
   392
		{
williamr@2
   393
		TUint8 i[8];
williamr@2
   394
		TUint32 iAlign;	// A dummy member to force the 4 byte alignment
williamr@2
   395
		};
williamr@2
   396
	};
williamr@2
   397
williamr@2
   398
williamr@2
   399
williamr@2
   400
class TInet6Options
williamr@2
   401
	/**
williamr@2
   402
	* IPv6 Option extension headers (Hop-by-Hop, Destination Options).
williamr@2
   403
	*
williamr@2
   404
@verbatim
williamr@2
   405
   +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
williamr@2
   406
   |  Next Header  |  Hdr Ext Len  |                               |
williamr@2
   407
   +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+                               +
williamr@2
   408
   |                                                               |
williamr@2
   409
   .                                                               .
williamr@2
   410
   .                            Options                            .
williamr@2
   411
   .                                                               .
williamr@2
   412
   |                                                               |
williamr@2
   413
   +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
williamr@2
   414
williamr@2
   415
  Next Header          8-bit selector.  Identifies the type of header
williamr@2
   416
                       immediately following the Destination Options
williamr@2
   417
                       header.  Uses the same values as the IPv4
williamr@2
   418
                       Protocol field [RFC-1700 et seq.].
williamr@2
   419
williamr@2
   420
  Hdr Ext Len          8-bit unsigned integer.  Length of the
williamr@2
   421
                       Destination Options header in 8-octet units, not
williamr@2
   422
                       including the first 8 octets.
williamr@2
   423
williamr@2
   424
  Options              Variable-length field, of length such that the
williamr@2
   425
                       complete Destination Options header is an
williamr@2
   426
                       integer multiple of 8 octets long.  Contains one
williamr@2
   427
                       or  more TLV-encoded options, as described in
williamr@2
   428
                       section 4.2.
williamr@2
   429
@endverbatim
williamr@2
   430
	* This mapping describes only the minimal 8 bytes.
williamr@2
   431
	* @publishedAll
williamr@2
   432
	* @released
williamr@2
   433
	*/
williamr@2
   434
	{
williamr@2
   435
public:
williamr@2
   436
	inline TInt HeaderLength() const { return (i[1]+1) << 3; } // Return true byte length
williamr@2
   437
williamr@2
   438
	inline static TInt MinHeaderLength() {return 8; }
williamr@2
   439
	inline static TInt MaxHeaderLength() {return 8; }	
williamr@2
   440
williamr@2
   441
	inline TUint8* EndPtr() { return i + HeaderLength(); }
williamr@2
   442
williamr@2
   443
	enum TOffsets
williamr@2
   444
		{
williamr@2
   445
		O_NextHeader,
williamr@2
   446
		O_HdrExtLen,
williamr@2
   447
		O_Options
williamr@2
   448
		};
williamr@2
   449
williamr@2
   450
	inline TInt NextHeader() const { return i[0]; }
williamr@2
   451
	inline TInt HdrExtLen() const { return i[1]; }	// Return raw value
williamr@2
   452
	
williamr@2
   453
	inline void SetNextHeader(TInt aNext) { i[0] = (TInt8)aNext; }
williamr@2
   454
	inline void SetHdrExtLen(TInt aLen) { i[1] = (TUint8)aLen; }
williamr@2
   455
	
williamr@2
   456
private:
williamr@2
   457
	TUint8 i[8];
williamr@2
   458
	};
williamr@2
   459
williamr@2
   460
williamr@2
   461
/**
williamr@2
   462
* @name Destination option types.
williamr@2
   463
*
williamr@2
   464
* @{
williamr@2
   465
*/
williamr@2
   466
/** One octet padding. */
williamr@2
   467
const TUint8 KDstOptionPad1				= 0;
williamr@2
   468
/** N octets padding */
williamr@2
   469
const TUint8 KDstOptionPadN				= 1;
williamr@2
   470
/** not used? (MIP6) */
williamr@2
   471
const TUint8 KDstOptionBindingAck		= 7;
williamr@2
   472
/** not used? (MIP6) */
williamr@2
   473
const TUint8 KDstOptionBindingRequest	= 8;
williamr@2
   474
/** not used? (MIP6) */
williamr@2
   475
const TUint8 KDstOptionBindingUpdate	= 0xC6;
williamr@2
   476
/** Home Address option (MIP6) */
williamr@2
   477
const TUint8 KDstOptionHomeAddress		= 0xC9;
williamr@2
   478
/** @} */
williamr@2
   479
williamr@2
   480
class TInet6OptionBase
williamr@2
   481
	/**
williamr@2
   482
	* IPv6 Option value header.
williamr@2
   483
	*
williamr@2
   484
	* A basic class for handling Type-Length-Value (TLV) options.
williamr@2
   485
	*
williamr@2
   486
@verbatim
williamr@2
   487
	  +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+- - - - - - - - -
williamr@2
   488
      |  Option Type  |  Opt Data Len |  Option Data
williamr@2
   489
      +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+- - - - - - - - -
williamr@2
   490
williamr@2
   491
      Option Type          8-bit identifier of the type of option.
williamr@2
   492
williamr@2
   493
      Opt Data Len         8-bit unsigned integer.  Length of the Option
williamr@2
   494
                           Data field of this option, in octets.
williamr@2
   495
williamr@2
   496
      Option Data          Variable-length field.  Option-Type-specific
williamr@2
   497
                           data.
williamr@2
   498
@endverbatim
williamr@2
   499
	* Option values are used inside option headers (for example:
williamr@2
   500
	* Hop-by-Hop options and Destination options).
williamr@2
   501
	*
williamr@2
   502
	* @publishedAll
williamr@2
   503
	* @released
williamr@2
   504
	*/
williamr@2
   505
	{
williamr@2
   506
public:
williamr@2
   507
	inline static TInt MinHeaderLength()	{ return 2; }
williamr@2
   508
	inline static TInt MaxHeaderLength()	{ return 2; }
williamr@2
   509
williamr@2
   510
	inline TInt Type() const				{ return i[0]; }
williamr@2
   511
	inline TInt HeaderLength() const { return i[1] + 2; }
williamr@2
   512
	
williamr@2
   513
	inline void SetType(TInt aType)			{ i[0] = (TUint8)aType; }
williamr@2
   514
	inline void SetDataLen(TInt aLen)		{ i[1] = (TUint8)aLen; }
williamr@2
   515
williamr@2
   516
	inline TUint8* EndPtr() { return i + HeaderLength(); }
williamr@2
   517
williamr@2
   518
private:
williamr@2
   519
	TUint8	i[2];
williamr@2
   520
	};
williamr@2
   521
williamr@2
   522
class TInet6DstOptionBase
williamr@2
   523
	/**
williamr@2
   524
	* IPv6 Option value header.
williamr@2
   525
	* @publishedAll
williamr@2
   526
	* @deprecated
williamr@2
   527
	*	Because of the non-standard method naming and
williamr@2
   528
	*	semantics. Use TInet6OptionBase instead.
williamr@2
   529
	*/
williamr@2
   530
	{
williamr@2
   531
public:
williamr@2
   532
	inline static TInt MinHeaderLength()	{ return 2; }
williamr@2
   533
	inline static TInt MaxHeaderLength()	{ return 2; }
williamr@2
   534
williamr@2
   535
	inline TInt Type() const				{ return i[0]; }
williamr@2
   536
	inline TInt HeaderLength() const { return i[1]; }
williamr@2
   537
	
williamr@2
   538
	inline void SetType(TInt aType)			{ i[0] = (TUint8)aType; }
williamr@2
   539
	inline void SetHeaderLength(TInt aLen)	{ i[1] = (TUint8)aLen; }
williamr@2
   540
williamr@2
   541
	inline TUint8* EndPtr() { return i + 2 + HeaderLength(); }
williamr@2
   542
williamr@2
   543
private:
williamr@2
   544
	TUint8	i[2];
williamr@2
   545
	};
williamr@2
   546
williamr@2
   547
williamr@2
   548
class TInet6HeaderFragment
williamr@2
   549
	/**
williamr@2
   550
	* IPv6 Fragment Header.
williamr@2
   551
@verbatim
williamr@2
   552
RFC2460
williamr@2
   553
williamr@2
   554
   +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
williamr@2
   555
   |  Next Header  |   Reserved    |      Fragment Offset    |Res|M|
williamr@2
   556
   +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
williamr@2
   557
   |                         Identification                        |
williamr@2
   558
   +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
williamr@2
   559
williamr@2
   560
   Next Header          8-bit selector.  Identifies the initial header
williamr@2
   561
                        type of the Fragmentable Part of the original
williamr@2
   562
                        packet (defined below).  Uses the same values as
williamr@2
   563
                        the IPv4 Protocol field [RFC-1700 et seq.].
williamr@2
   564
williamr@2
   565
   Reserved             8-bit reserved field.  Initialized to zero for
williamr@2
   566
                        transmission; ignored on reception.
williamr@2
   567
williamr@2
   568
   Fragment Offset      13-bit unsigned integer.  The offset, in 8-octet
williamr@2
   569
                        units, of the data following this header,
williamr@2
   570
                        relative to the start of the Fragmentable Part
williamr@2
   571
                        of the original packet.
williamr@2
   572
williamr@2
   573
   Res                  2-bit reserved field.  Initialized to zero for
williamr@2
   574
                        transmission; ignored on reception.
williamr@2
   575
williamr@2
   576
   M flag               1 = more fragments; 0 = last fragment.
williamr@2
   577
williamr@2
   578
   Identification       32 bits.  See description below.
williamr@2
   579
@endverbatim
williamr@2
   580
	* @publishedAll
williamr@2
   581
	* @released
williamr@2
   582
	*/
williamr@2
   583
	{
williamr@2
   584
public:
williamr@2
   585
	enum TOffsets
williamr@2
   586
		{
williamr@2
   587
		O_FragmentOffset = 2
williamr@2
   588
		};
williamr@2
   589
williamr@2
   590
	inline TInt HeaderLength() const
williamr@2
   591
		{
williamr@2
   592
		return 8;
williamr@2
   593
		}
williamr@2
   594
williamr@2
   595
	inline TUint8* EndPtr() { return i + HeaderLength(); }
williamr@2
   596
williamr@2
   597
	inline static TInt MinHeaderLength() {return 8; }
williamr@2
   598
	inline static TInt MaxHeaderLength() {return 8; }
williamr@2
   599
	
williamr@2
   600
	//
williamr@2
   601
	// Access, Get Fragmentation header values from the packet
williamr@2
   602
	//
williamr@2
   603
	inline TInt NextHeader() const { return i[0]; }
williamr@2
   604
williamr@2
   605
	inline TInt FragmentOffset() const
williamr@2
   606
		{
williamr@2
   607
		//
williamr@2
   608
		//	The Offset is returned as octet count (3 righmost bits are zero)
williamr@2
   609
		//
williamr@2
   610
		return ((i[2] << 8) + i[3]) & 0xfff8;
williamr@2
   611
		}
williamr@2
   612
williamr@2
   613
	inline TInt MFlag() const
williamr@2
   614
		{
williamr@2
   615
		return i[3] & 0x01;
williamr@2
   616
		}
williamr@2
   617
williamr@2
   618
	inline TInt32 Id() const
williamr@2
   619
		{
williamr@2
   620
		return *(TInt32 *)(&i[4]);	// *ASSUMES* proper aligment!!!
williamr@2
   621
		}
williamr@2
   622
	//
williamr@2
   623
	// Building methods
williamr@2
   624
	//
williamr@2
   625
	inline void ZeroAll()
williamr@2
   626
		{
williamr@2
   627
		*((TInt32 *)&i[0]) = 0;		// *ASSUMES* proper aligment!!!
williamr@2
   628
		*((TInt32 *)&i[4]) = 0;		// *ASSUMES* proper aligment!!!
williamr@2
   629
		}
williamr@2
   630
	inline void SetNextHeader(TInt aNext)
williamr@2
   631
		{
williamr@2
   632
		i[0] = (TUint8)aNext;
williamr@2
   633
		}
williamr@2
   634
	inline void SetFragmentOffset(TInt aOffset)
williamr@2
   635
		{
williamr@2
   636
		//
williamr@2
   637
		// The aOffset is assumed to be given in octets. The least significant
williamr@2
   638
		// 3 bits should be ZERO (bits are just masked away).
williamr@2
   639
		//
williamr@2
   640
		i[2]=(TUint8)(aOffset >> 8);
williamr@2
   641
		i[3]=(TUint8)((i[3] & 0x7) | (aOffset & ~0x7));
williamr@2
   642
		}
williamr@2
   643
williamr@2
   644
	inline void SetMFlag(TInt aFlag)
williamr@2
   645
		{
williamr@2
   646
		i[3]= (TUint8)((i[3] & ~0x1) | (aFlag & 0x1));
williamr@2
   647
		}
williamr@2
   648
williamr@2
   649
	inline void SetId(TInt32 aId)
williamr@2
   650
		{
williamr@2
   651
		*((TInt32 *)&i[4]) = aId;	// *ASSUMES* proper aligment!!!
williamr@2
   652
		}
williamr@2
   653
private:
williamr@2
   654
	union
williamr@2
   655
		{
williamr@2
   656
		TUint8 i[8];
williamr@2
   657
		TUint32 iAlign;	// A dummy member to force the 4 byte alignment
williamr@2
   658
		};
williamr@2
   659
	};
williamr@2
   660
williamr@2
   661
class TInet6HeaderAH
williamr@2
   662
	/**
williamr@2
   663
	* IPsec Authentication Header.
williamr@2
   664
	*
williamr@2
   665
	* The function parameters and return values are in host order,
williamr@2
   666
	* except SPI, which is always in network byte order.
williamr@2
   667
@verbatim
williamr@2
   668
Extract from RFC-2402
williamr@2
   669
williamr@2
   670
    0                   1                   2                   3
williamr@2
   671
    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
   672
   +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
williamr@2
   673
   | Next Header   |  Payload Len  |          RESERVED             |
williamr@2
   674
   +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
williamr@2
   675
   |                 Security Parameters Index (SPI)               |
williamr@2
   676
   +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
williamr@2
   677
   |                    Sequence Number Field                      |
williamr@2
   678
   +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
williamr@2
   679
   |                                                               |
williamr@2
   680
   +                Authentication Data (variable)                 |
williamr@2
   681
   |                                                               |
williamr@2
   682
   +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
williamr@2
   683
@endverbatim
williamr@2
   684
	* @publishedAll
williamr@2
   685
	* @released
williamr@2
   686
	*/
williamr@2
   687
	{
williamr@2
   688
public:
williamr@2
   689
	//
williamr@2
   690
	// Basic
williamr@2
   691
	//
williamr@2
   692
	inline static TInt MinHeaderLength() {return 3*4; }
williamr@2
   693
	inline static TInt MaxHeaderLength() {return 3*4; }
williamr@2
   694
	inline TUint8 *EndPtr() {return i + HeaderLength();}
williamr@2
   695
	//
williamr@2
   696
	// Access, get values
williamr@2
   697
	//
williamr@2
   698
	inline TInt NextHeader() const
williamr@2
   699
		{
williamr@2
   700
		return i[0];
williamr@2
   701
		}
williamr@2
   702
	//
williamr@2
   703
	// PayloadLength returns the raw value
williamr@2
   704
	//
williamr@2
   705
	inline TInt PayloadLength() const
williamr@2
   706
		{
williamr@2
   707
		return i[1];
williamr@2
   708
		}
williamr@2
   709
	//
williamr@2
   710
	// *NOTE* AH is called IPv6 extension header, but its
williamr@2
   711
	// length field semantics does not follow the normal
williamr@2
   712
	// IPv6 extension header logic (it follows the IPv4)
williamr@2
   713
	//
williamr@2
   714
	inline TInt HeaderLength() const
williamr@2
   715
		{
williamr@2
   716
		return (i[1]+2) << 2;	// IPv4 and IPv6
williamr@2
   717
		}
williamr@2
   718
	//
williamr@2
   719
	// SPI is returned in network byte order
williamr@2
   720
	//
williamr@2
   721
	inline TUint32 SPI() const
williamr@2
   722
		{
williamr@2
   723
		return *((TUint32 *)(i + 4));
williamr@2
   724
		}
williamr@2
   725
	inline TUint32 Sequence() const
williamr@2
   726
		{
williamr@2
   727
		return (i[8] << 24) | (i[9] << 16) | (i[10] << 8) | i[11];
williamr@2
   728
		}
williamr@2
   729
williamr@2
   730
	// The length of the Authentication Data (in octets).
williamr@2
   731
	// *NOTE* This will include the potential padding! -- msa
williamr@2
   732
	inline TInt DataLength() const		{
williamr@2
   733
		return HeaderLength() - 12;
williamr@2
   734
		}
williamr@2
   735
	inline TPtr8 ICV()
williamr@2
   736
		{
williamr@2
   737
		return TPtr8((TUint8 *)&i[12], DataLength(), DataLength());
williamr@2
   738
		}
williamr@2
   739
	//
williamr@2
   740
	// Build
williamr@2
   741
	//
williamr@2
   742
	inline void SetNextHeader(TInt aNext)
williamr@2
   743
		{
williamr@2
   744
		i[0] = (TUint8)aNext;
williamr@2
   745
		}
williamr@2
   746
	inline void SetPayloadLength(TInt aByte)
williamr@2
   747
		{
williamr@2
   748
		i[1] = (TUint8)aByte;
williamr@2
   749
		}
williamr@2
   750
	//
williamr@2
   751
	// *NOTE* AH is called IPv6 extension header, but its
williamr@2
   752
	// length field semantics does not follow the normal
williamr@2
   753
	// IPv6 extension header logic (it follows the IPv4)
williamr@2
   754
	// As this is bit tricky, a "cooked version" of PayloadLength
williamr@2
   755
	// setting is also provided (e.g. take in bytes, and compute
williamr@2
   756
	// the real payload length value) -- msa
williamr@2
   757
	inline void SetHeaderLength(TInt aLength)
williamr@2
   758
		{
williamr@2
   759
		i[1] = (TUint8)((aLength >> 2) - 2);
williamr@2
   760
		}
williamr@2
   761
	inline void SetSPI(TUint32 aSPI)
williamr@2
   762
		{
williamr@2
   763
		*((TUint32 *)(i + 4)) = aSPI;
williamr@2
   764
		}
williamr@2
   765
	inline void SetReserved(TInt aValue)
williamr@2
   766
		{
williamr@2
   767
		i[3] = (TUint8)aValue;
williamr@2
   768
		i[2] = (TUint8)(aValue >> 8);
williamr@2
   769
		}
williamr@2
   770
	inline void SetSequence(TUint32 aSeq)
williamr@2
   771
		{
williamr@2
   772
		i[11] = (TUint8)aSeq;
williamr@2
   773
		i[10] = (TUint8)(aSeq >> 8);
williamr@2
   774
		i[9] = (TUint8)(aSeq >> 16);
williamr@2
   775
		i[8] = (TUint8)(aSeq >> 24);
williamr@2
   776
		}
williamr@2
   777
protected:
williamr@2
   778
	union
williamr@2
   779
		{
williamr@2
   780
		TUint8 i[3*4];
williamr@2
   781
		TUint32 iAlign;	// A dummy member to force the 4 byte alignment
williamr@2
   782
		};
williamr@2
   783
	};
williamr@2
   784
williamr@2
   785
williamr@2
   786
williamr@2
   787
class TInet6HeaderESP
williamr@2
   788
	/**
williamr@2
   789
	* IPsec Encapsulating Security Payload Packet Format.
williamr@2
   790
	*
williamr@2
   791
	* The function parameters and return values are in host
williamr@2
   792
	* order (except SPI, which is always in network byte order)
williamr@2
   793
	*
williamr@2
   794
@verbatim
williamr@2
   795
RFC-2406
williamr@2
   796
 0                   1                   2                   3
williamr@2
   797
 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
   798
+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+ ----
williamr@2
   799
|               Security Parameters Index (SPI)                 | ^Auth.
williamr@2
   800
+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+ |Cov-
williamr@2
   801
|                      Sequence Number                          | |erage
williamr@2
   802
+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+ | ----
williamr@2
   803
|                    Payload Data* (variable)                   | |   ^
williamr@2
   804
~                                                               ~ |   |
williamr@2
   805
|                                                               | |Conf.
williamr@2
   806
+               +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+ |Cov-
williamr@2
   807
|               |     Padding (0-255 bytes)                     | |erage*
williamr@2
   808
+-+-+-+-+-+-+-+-+               +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+ |   |
williamr@2
   809
|                               |  Pad Length   | Next Header   | v   v
williamr@2
   810
+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+ ------
williamr@2
   811
|                 Authentication Data (variable)                |
williamr@2
   812
~                                                               ~
williamr@2
   813
|                                                               |
williamr@2
   814
+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
williamr@2
   815
@endverbatim
williamr@2
   816
	* This only defines the fixed portion of the ESP, 8 bytes).
williamr@2
   817
	* @publishedAll
williamr@2
   818
	* @released
williamr@2
   819
	*/
williamr@2
   820
	{
williamr@2
   821
public:
williamr@2
   822
	//
williamr@2
   823
	// Basic
williamr@2
   824
	//
williamr@2
   825
	inline static TInt MinHeaderLength() {return 2*4; }
williamr@2
   826
	inline static TInt MaxHeaderLength() {return 2*4; }
williamr@2
   827
	inline TInt HeaderLength() const {return 2*4; }
williamr@2
   828
	inline TUint8 *EndPtr() {return i + HeaderLength();}
williamr@2
   829
williamr@2
   830
	//
williamr@2
   831
	// Access, get values
williamr@2
   832
	//
williamr@2
   833
	//
williamr@2
   834
	// SPI is returned in network byte order
williamr@2
   835
	//
williamr@2
   836
	inline TUint32 SPI() const
williamr@2
   837
		{
williamr@2
   838
		return *((TUint32 *)(i + 0));
williamr@2
   839
		}
williamr@2
   840
	inline TUint32 Sequence() const
williamr@2
   841
		{
williamr@2
   842
		return (i[4] << 24) | (i[5] << 16) | (i[6] << 8) | i[7];
williamr@2
   843
		}
williamr@2
   844
	//
williamr@2
   845
	// IV is not exactly part of the header, but provide
williamr@2
   846
	// a method that returns a Ptr to it (assuming the
williamr@2
   847
	// IV is accessible directly after the fixed part).
williamr@2
   848
	//
williamr@2
   849
	inline TPtr8 IV(TInt aLen)
williamr@2
   850
		{
williamr@2
   851
		return TPtr8((TUint8 *)&i[sizeof(i)], aLen, aLen);
williamr@2
   852
		}
williamr@2
   853
williamr@2
   854
	//
williamr@2
   855
	// Build
williamr@2
   856
	//
williamr@2
   857
	inline void SetSPI(TUint32 aSPI)
williamr@2
   858
		{
williamr@2
   859
		*((TUint32 *)(i + 0)) = aSPI;
williamr@2
   860
		}
williamr@2
   861
	inline void SetSequence(TUint32 aSeq)
williamr@2
   862
		{
williamr@2
   863
		i[7] = (TUint8)aSeq;
williamr@2
   864
		i[6] = (TUint8)(aSeq >> 8);
williamr@2
   865
		i[5] = (TUint8)(aSeq >> 16);
williamr@2
   866
		i[4] = (TUint8)(aSeq >> 24);
williamr@2
   867
		}
williamr@2
   868
protected:
williamr@2
   869
	union
williamr@2
   870
		{
williamr@2
   871
		TUint8 i[2*4];
williamr@2
   872
		TUint32 iAlign;	// A dummy member to force the 4 byte alignment
williamr@2
   873
		};
williamr@2
   874
	};
williamr@2
   875
williamr@2
   876
/** @} */
williamr@2
   877
#endif