usbmgmt/usbmgr/device/classdrivers/ncm/classimplementation/ncmpktdrv/pktdrv/inc/ncmntbbuilder.h
author hgs
Wed, 07 Jul 2010 14:16:40 +0800
changeset 28 f1fd07aa74c9
permissions -rw-r--r--
201025_08
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
28
f1fd07aa74c9 201025_08
hgs
parents:
diff changeset
     1
/*
f1fd07aa74c9 201025_08
hgs
parents:
diff changeset
     2
* Copyright (c) 2010 Nokia Corporation and/or its subsidiary(-ies).
f1fd07aa74c9 201025_08
hgs
parents:
diff changeset
     3
* All rights reserved.
f1fd07aa74c9 201025_08
hgs
parents:
diff changeset
     4
* This component and the accompanying materials are made available
f1fd07aa74c9 201025_08
hgs
parents:
diff changeset
     5
* under the terms of "Eclipse Public License v1.0"
f1fd07aa74c9 201025_08
hgs
parents:
diff changeset
     6
* which accompanies this distribution, and is available
f1fd07aa74c9 201025_08
hgs
parents:
diff changeset
     7
* at the URL "http://www.eclipse.org/legal/epl-v10.html".
f1fd07aa74c9 201025_08
hgs
parents:
diff changeset
     8
*
f1fd07aa74c9 201025_08
hgs
parents:
diff changeset
     9
* Initial Contributors:
f1fd07aa74c9 201025_08
hgs
parents:
diff changeset
    10
* Nokia Corporation - initial contribution.
f1fd07aa74c9 201025_08
hgs
parents:
diff changeset
    11
*
f1fd07aa74c9 201025_08
hgs
parents:
diff changeset
    12
* Contributors:
f1fd07aa74c9 201025_08
hgs
parents:
diff changeset
    13
*
f1fd07aa74c9 201025_08
hgs
parents:
diff changeset
    14
* Description:
f1fd07aa74c9 201025_08
hgs
parents:
diff changeset
    15
* header file for NTB build  base class
f1fd07aa74c9 201025_08
hgs
parents:
diff changeset
    16
*
f1fd07aa74c9 201025_08
hgs
parents:
diff changeset
    17
*/
f1fd07aa74c9 201025_08
hgs
parents:
diff changeset
    18
f1fd07aa74c9 201025_08
hgs
parents:
diff changeset
    19
f1fd07aa74c9 201025_08
hgs
parents:
diff changeset
    20
f1fd07aa74c9 201025_08
hgs
parents:
diff changeset
    21
/**
f1fd07aa74c9 201025_08
hgs
parents:
diff changeset
    22
@file
f1fd07aa74c9 201025_08
hgs
parents:
diff changeset
    23
@internalComponent
f1fd07aa74c9 201025_08
hgs
parents:
diff changeset
    24
*/
f1fd07aa74c9 201025_08
hgs
parents:
diff changeset
    25
f1fd07aa74c9 201025_08
hgs
parents:
diff changeset
    26
f1fd07aa74c9 201025_08
hgs
parents:
diff changeset
    27
#ifndef NCMNTBBUILDER_H
f1fd07aa74c9 201025_08
hgs
parents:
diff changeset
    28
#define NCMNTBBUILDER_H
f1fd07aa74c9 201025_08
hgs
parents:
diff changeset
    29
f1fd07aa74c9 201025_08
hgs
parents:
diff changeset
    30
#include <e32base.h>
f1fd07aa74c9 201025_08
hgs
parents:
diff changeset
    31
f1fd07aa74c9 201025_08
hgs
parents:
diff changeset
    32
#include "ncmpktdrvcommon.h"
f1fd07aa74c9 201025_08
hgs
parents:
diff changeset
    33
f1fd07aa74c9 201025_08
hgs
parents:
diff changeset
    34
f1fd07aa74c9 201025_08
hgs
parents:
diff changeset
    35
class MNcmNtbBuildObserver;
f1fd07aa74c9 201025_08
hgs
parents:
diff changeset
    36
class RMBufChain;
f1fd07aa74c9 201025_08
hgs
parents:
diff changeset
    37
class CNcmNtbBuildPolicy;
f1fd07aa74c9 201025_08
hgs
parents:
diff changeset
    38
class TNcmNtbInParam;
f1fd07aa74c9 201025_08
hgs
parents:
diff changeset
    39
f1fd07aa74c9 201025_08
hgs
parents:
diff changeset
    40
f1fd07aa74c9 201025_08
hgs
parents:
diff changeset
    41
const TInt KErrBufferFull = -6667;
f1fd07aa74c9 201025_08
hgs
parents:
diff changeset
    42
f1fd07aa74c9 201025_08
hgs
parents:
diff changeset
    43
f1fd07aa74c9 201025_08
hgs
parents:
diff changeset
    44
/**
f1fd07aa74c9 201025_08
hgs
parents:
diff changeset
    45
Base class for build NTB
f1fd07aa74c9 201025_08
hgs
parents:
diff changeset
    46
*/
f1fd07aa74c9 201025_08
hgs
parents:
diff changeset
    47
f1fd07aa74c9 201025_08
hgs
parents:
diff changeset
    48
NONSHARABLE_CLASS(CNcmNtbBuilder) : public CBase
f1fd07aa74c9 201025_08
hgs
parents:
diff changeset
    49
    {
f1fd07aa74c9 201025_08
hgs
parents:
diff changeset
    50
public:
f1fd07aa74c9 201025_08
hgs
parents:
diff changeset
    51
    /**
f1fd07aa74c9 201025_08
hgs
parents:
diff changeset
    52
    * append a ethernet frame to current NTB
f1fd07aa74c9 201025_08
hgs
parents:
diff changeset
    53
    *
f1fd07aa74c9 201025_08
hgs
parents:
diff changeset
    54
    * @param aPacket ethernet packet buffer
f1fd07aa74c9 201025_08
hgs
parents:
diff changeset
    55
    * @return KErrNone        if success
f1fd07aa74c9 201025_08
hgs
parents:
diff changeset
    56
    *         KErrBufferFull  if current NTB is full and can't insert the new packet to NTB and send the current NTB immediately
f1fd07aa74c9 201025_08
hgs
parents:
diff changeset
    57
    */
f1fd07aa74c9 201025_08
hgs
parents:
diff changeset
    58
    virtual TInt AppendPacket(const RMBufChain& aPacket) = 0;  
f1fd07aa74c9 201025_08
hgs
parents:
diff changeset
    59
    /**
f1fd07aa74c9 201025_08
hgs
parents:
diff changeset
    60
    * complete the current NTB
f1fd07aa74c9 201025_08
hgs
parents:
diff changeset
    61
    *
f1fd07aa74c9 201025_08
hgs
parents:
diff changeset
    62
    */
f1fd07aa74c9 201025_08
hgs
parents:
diff changeset
    63
    virtual void CompleteNtbBuild();
f1fd07aa74c9 201025_08
hgs
parents:
diff changeset
    64
    /**
f1fd07aa74c9 201025_08
hgs
parents:
diff changeset
    65
    * change the NtbInMaxSize
f1fd07aa74c9 201025_08
hgs
parents:
diff changeset
    66
    *
f1fd07aa74c9 201025_08
hgs
parents:
diff changeset
    67
    * @param aSize new size
f1fd07aa74c9 201025_08
hgs
parents:
diff changeset
    68
    * @return  KErrNone        if success   
f1fd07aa74c9 201025_08
hgs
parents:
diff changeset
    69
    *          KErrArgument    if the size is bigger than allowed size in NCM spec.
f1fd07aa74c9 201025_08
hgs
parents:
diff changeset
    70
    */
f1fd07aa74c9 201025_08
hgs
parents:
diff changeset
    71
    virtual TInt SetNtbInMaxSize(TInt aSize) = 0;
f1fd07aa74c9 201025_08
hgs
parents:
diff changeset
    72
    /**
f1fd07aa74c9 201025_08
hgs
parents:
diff changeset
    73
    * prepare build a new NTB
f1fd07aa74c9 201025_08
hgs
parents:
diff changeset
    74
    *
f1fd07aa74c9 201025_08
hgs
parents:
diff changeset
    75
    * @param aBuffer buffer to construct NTB
f1fd07aa74c9 201025_08
hgs
parents:
diff changeset
    76
    */
f1fd07aa74c9 201025_08
hgs
parents:
diff changeset
    77
    virtual void StartNewNtb(const TNcmBuffer& aBuffer);
f1fd07aa74c9 201025_08
hgs
parents:
diff changeset
    78
    /**
f1fd07aa74c9 201025_08
hgs
parents:
diff changeset
    79
    * reset builder to intial state.
f1fd07aa74c9 201025_08
hgs
parents:
diff changeset
    80
    */
f1fd07aa74c9 201025_08
hgs
parents:
diff changeset
    81
    virtual void Reset();
f1fd07aa74c9 201025_08
hgs
parents:
diff changeset
    82
f1fd07aa74c9 201025_08
hgs
parents:
diff changeset
    83
public:
f1fd07aa74c9 201025_08
hgs
parents:
diff changeset
    84
    ~CNcmNtbBuilder();
f1fd07aa74c9 201025_08
hgs
parents:
diff changeset
    85
    void GetNtbParam(TNcmNtbInParam& aParam);
f1fd07aa74c9 201025_08
hgs
parents:
diff changeset
    86
    inline void SetBuildPolicy(CNcmNtbBuildPolicy& aPolicy);
f1fd07aa74c9 201025_08
hgs
parents:
diff changeset
    87
    /**
f1fd07aa74c9 201025_08
hgs
parents:
diff changeset
    88
    * @return  ETrue        if has called StartNewNtb for current NTB   
f1fd07aa74c9 201025_08
hgs
parents:
diff changeset
    89
    *          EFalse       otherwise
f1fd07aa74c9 201025_08
hgs
parents:
diff changeset
    90
    */
f1fd07aa74c9 201025_08
hgs
parents:
diff changeset
    91
    inline TBool IsNtbStarted();
f1fd07aa74c9 201025_08
hgs
parents:
diff changeset
    92
    inline TInt NtbInMaxSize();
f1fd07aa74c9 201025_08
hgs
parents:
diff changeset
    93
    inline TInt MinNtbInMaxSize();	
f1fd07aa74c9 201025_08
hgs
parents:
diff changeset
    94
f1fd07aa74c9 201025_08
hgs
parents:
diff changeset
    95
protected:
f1fd07aa74c9 201025_08
hgs
parents:
diff changeset
    96
    CNcmNtbBuilder(MNcmNtbBuildObserver&);
f1fd07aa74c9 201025_08
hgs
parents:
diff changeset
    97
    void SendNtbPayload();
f1fd07aa74c9 201025_08
hgs
parents:
diff changeset
    98
f1fd07aa74c9 201025_08
hgs
parents:
diff changeset
    99
protected:
f1fd07aa74c9 201025_08
hgs
parents:
diff changeset
   100
    /**
f1fd07aa74c9 201025_08
hgs
parents:
diff changeset
   101
    * refer to NCM spec for following five variable meaning.
f1fd07aa74c9 201025_08
hgs
parents:
diff changeset
   102
    */    
f1fd07aa74c9 201025_08
hgs
parents:
diff changeset
   103
    TInt                     iNtbInMaxSize;
f1fd07aa74c9 201025_08
hgs
parents:
diff changeset
   104
    TInt                     iNdpInDivisor;
f1fd07aa74c9 201025_08
hgs
parents:
diff changeset
   105
    TInt                     iNdpInPayloadRemainder;
f1fd07aa74c9 201025_08
hgs
parents:
diff changeset
   106
    TInt                     iNdpInAlignment;    
f1fd07aa74c9 201025_08
hgs
parents:
diff changeset
   107
    TUint16                  iSequence;
f1fd07aa74c9 201025_08
hgs
parents:
diff changeset
   108
f1fd07aa74c9 201025_08
hgs
parents:
diff changeset
   109
    MNcmNtbBuildObserver&    iObserver;
f1fd07aa74c9 201025_08
hgs
parents:
diff changeset
   110
    /**
f1fd07aa74c9 201025_08
hgs
parents:
diff changeset
   111
    * buffer contains NTB
f1fd07aa74c9 201025_08
hgs
parents:
diff changeset
   112
    */    
f1fd07aa74c9 201025_08
hgs
parents:
diff changeset
   113
    TNcmBuffer               iBuffer;
f1fd07aa74c9 201025_08
hgs
parents:
diff changeset
   114
    /**
f1fd07aa74c9 201025_08
hgs
parents:
diff changeset
   115
    * point to builder policy, this is not ownership
f1fd07aa74c9 201025_08
hgs
parents:
diff changeset
   116
    */     
f1fd07aa74c9 201025_08
hgs
parents:
diff changeset
   117
    CNcmNtbBuildPolicy*      iBuildPolicy;
f1fd07aa74c9 201025_08
hgs
parents:
diff changeset
   118
    /**
f1fd07aa74c9 201025_08
hgs
parents:
diff changeset
   119
    * a NTB is started or not.
f1fd07aa74c9 201025_08
hgs
parents:
diff changeset
   120
    */    
f1fd07aa74c9 201025_08
hgs
parents:
diff changeset
   121
    TBool                    iNtbStarted;
f1fd07aa74c9 201025_08
hgs
parents:
diff changeset
   122
    };
f1fd07aa74c9 201025_08
hgs
parents:
diff changeset
   123
f1fd07aa74c9 201025_08
hgs
parents:
diff changeset
   124
f1fd07aa74c9 201025_08
hgs
parents:
diff changeset
   125
// Inline functions
f1fd07aa74c9 201025_08
hgs
parents:
diff changeset
   126
#include "ncmntbbuilder.inl"
f1fd07aa74c9 201025_08
hgs
parents:
diff changeset
   127
f1fd07aa74c9 201025_08
hgs
parents:
diff changeset
   128
f1fd07aa74c9 201025_08
hgs
parents:
diff changeset
   129
#endif /* NCMNTBBUILDER_H */