diff -r 000000000000 -r 818e61de6cd1 crashanalysercmd/PerfToolsSharedLibraries/Engine/SymbianETMLib/Common/Packets/Implementations/ETMPcktOutOfOrderData.cs --- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/crashanalysercmd/PerfToolsSharedLibraries/Engine/SymbianETMLib/Common/Packets/Implementations/ETMPcktOutOfOrderData.cs Thu Feb 11 15:50:58 2010 +0200 @@ -0,0 +1,88 @@ +/* +* Copyright (c) 2009 Nokia Corporation and/or its subsidiary(-ies). +* All rights reserved. +* This component and the accompanying materials are made available +* under the terms of "Eclipse Public License v1.0" +* which accompanies this distribution, and is available +* at the URL "http://www.eclipse.org/legal/epl-v10.html". +* +* Initial Contributors: +* Nokia Corporation - initial contribution. +* +* Contributors: +* +* Description: +* +*/ + +using System; +using System.Collections.Generic; +using System.Text; +using SymbianUtils.BasicTypes; +using SymbianETMLib.Common.Types; + +namespace SymbianETMLib.Common.Packets +{ + public class ETMPcktOutOfOrderData : ETMPcktBase + { + #region Constructors + public ETMPcktOutOfOrderData() + { + base.SetMask( "0##0##00" ); + } + + public ETMPcktOutOfOrderData( SymByte aByte ) + : base( aByte ) + { + } + #endregion + + #region API + #endregion + + #region From PcktBase + public override int Priority + { + get + { + return int.MinValue + 2; + } + } + + public override bool Matches( SymByte aOpCode ) + { + bool ret = base.Matches( aOpCode ); + if ( ret ) + { + // Tag has to be > 0 + SymMask mask = new SymMask( "1100000", SymMask.TShiftDirection.ERight, 5 ); + uint tag = mask.Apply( aOpCode ); + ret = ( tag > 0 && tag < 4 ); + } + // + return ret; + } + #endregion + + #region Properties + public int Size + { + get + { + SymMask mask = new SymMask( "1100", SymMask.TShiftDirection.ERight, 2 ); + int ret = (int) mask.Apply( base.RawByte ); + return ret; + } + } + #endregion + + #region Internal constants + #endregion + + #region From System.Object + #endregion + + #region Data members + #endregion + } +}