| 51 |      1 | /*
 | 
|  |      2 | * Copyright (c) 2009 Nokia Corporation and/or its subsidiary(-ies). 
 | 
|  |      3 | * All rights reserved.
 | 
|  |      4 | * This component and the accompanying materials are made available
 | 
|  |      5 | * under the terms of "Eclipse Public License v1.0"
 | 
|  |      6 | * which accompanies this distribution, and is available
 | 
|  |      7 | * at the URL "http://www.eclipse.org/legal/epl-v10.html".
 | 
|  |      8 | *
 | 
|  |      9 | * Initial Contributors:
 | 
|  |     10 | * Nokia Corporation - initial contribution.
 | 
|  |     11 | *
 | 
|  |     12 | * Contributors:
 | 
|  |     13 | *
 | 
|  |     14 | * Description:
 | 
|  |     15 | *
 | 
|  |     16 | */
 | 
|  |     17 | 
 | 
|  |     18 | #include "MemSpyDriverHeap.h"
 | 
|  |     19 | 
 | 
|  |     20 | // System includes
 | 
|  |     21 | #include <kern_priv.h>
 | 
|  |     22 | 
 | 
|  |     23 | // User includes
 | 
|  |     24 | #include "MemSpyDriverOSAdaption.h"
 | 
|  |     25 | #include "MemSpyDriverUtils.h"
 | 
|  |     26 | #include "heaputils.h"
 | 
|  |     27 | 
 | 
|  |     28 | 
 | 
|  |     29 | 
 | 
|  |     30 | RMemSpyDriverRHeapBase::RMemSpyDriverRHeapBase()
 | 
|  |     31 | 	: iHelper(NULL)
 | 
|  |     32 |     {
 | 
|  |     33 |     Reset();
 | 
|  |     34 |     }
 | 
|  |     35 | 
 | 
|  |     36 | LtkUtils::RAllocatorHelper* RMemSpyDriverRHeapBase::Helper()
 | 
|  |     37 | 	{
 | 
|  |     38 | 	return iHelper;
 | 
|  |     39 | 	}
 | 
|  |     40 | 
 | 
|  |     41 | TMemSpyHeapInfo::THeapImplementationType RMemSpyDriverRHeapBase::GetTypeFromHelper() const
 | 
|  |     42 | 	{
 | 
|  |     43 | 	if (iHelper)
 | 
|  |     44 | 		{
 | 
|  |     45 | 		LtkUtils::RAllocatorHelper::TType type = iHelper->GetType();
 | 
|  |     46 | 		switch (type)
 | 
|  |     47 | 			{
 | 
|  |     48 | 			case LtkUtils::RAllocatorHelper::ETypeRHeap:
 | 
|  |     49 | 				return TMemSpyHeapInfo::ETypeRHeap;
 | 
|  |     50 | 			case LtkUtils::RAllocatorHelper::ETypeRHybridHeap:
 | 
|  |     51 | 				return TMemSpyHeapInfo::ETypeRHybridHeap;
 | 
|  |     52 | 			case LtkUtils::RAllocatorHelper::ETypeUnknown:
 | 
|  |     53 | 			default:
 | 
|  |     54 | 				return TMemSpyHeapInfo::ETypeUnknown;
 | 
|  |     55 | 			}
 | 
|  |     56 | 		}
 | 
|  |     57 | 	return TMemSpyHeapInfo::ETypeUnknown;
 | 
|  |     58 | 	}
 | 
|  |     59 | 
 | 
|  |     60 | void RMemSpyDriverRHeapBase::Reset()
 | 
|  |     61 |     {
 | 
|  |     62 | 	Close();
 | 
|  |     63 | 	}
 | 
|  |     64 | 
 | 
|  |     65 | void RMemSpyDriverRHeapBase::Close()
 | 
|  |     66 | 	{
 | 
|  |     67 | 	if (iHelper)
 | 
|  |     68 | 		{
 | 
|  |     69 | 	    NKern::ThreadEnterCS();
 | 
|  |     70 | 		iHelper->Close();
 | 
|  |     71 | 		delete iHelper;
 | 
|  |     72 | 		iHelper = NULL;
 | 
|  |     73 | 		NKern::ThreadLeaveCS();
 | 
|  |     74 | 		}
 | 
|  |     75 |     }
 | 
|  |     76 | 
 | 
|  |     77 | void RMemSpyDriverRHeapBase::PrintInfo()
 | 
|  |     78 |     {
 | 
|  |     79 | 	/* TOMSCI TODO replace with tracing based on latest struct info. See DMemSpyDriverLogChanHeapBase::PrintHeapInfo
 | 
|  |     80 | 	 * Alternatively just call DMemSpyDriverLogChanHeapBase::PrintHeapInfo() somehow?
 | 
|  |     81 | 	 
 | 
|  |     82 | #if defined(TRACE_TYPE_KERNELHEAP) || defined(TRACE_TYPE_USERHEAP)
 | 
|  |     83 |     Kern::Printf(" " );
 | 
|  |     84 |     Kern::Printf("RMemSpyDriverRHeapBase::PrintInfo - RAllocator - iAccessCount:    0x%08x", iAccessCount );
 | 
|  |     85 |     Kern::Printf("RMemSpyDriverRHeapBase::PrintInfo - RAllocator - iHandleCount:    0x%08x", iHandleCount );
 | 
|  |     86 |     Kern::Printf("RMemSpyDriverRHeapBase::PrintInfo - RAllocator - iHandles:        0x%08x", iHandles );
 | 
|  |     87 |     Kern::Printf("RMemSpyDriverRHeapBase::PrintInfo - RAllocator - iFlags:          0x%08x", iFlags );
 | 
|  |     88 |     Kern::Printf("RMemSpyDriverRHeapBase::PrintInfo - RAllocator - iCellCount:      0x%08x", iCellCount );
 | 
|  |     89 |     Kern::Printf("RMemSpyDriverRHeapBase::PrintInfo - RAllocator - iTotalAllocSize: 0x%08x", iTotalAllocSize );
 | 
|  |     90 | 
 | 
|  |     91 |     Kern::Printf("RMemSpyDriverRHeapBase::PrintInfo - RHeap -      iMinLength:      0x%08x", iMinLength );
 | 
|  |     92 |     Kern::Printf("RMemSpyDriverRHeapBase::PrintInfo - RHeap -      iMaxLength:      0x%08x", iMaxLength );
 | 
|  |     93 |     Kern::Printf("RMemSpyDriverRHeapBase::PrintInfo - RHeap -      iOffset:         0x%08x", iOffset);
 | 
|  |     94 |     Kern::Printf("RMemSpyDriverRHeapBase::PrintInfo - RHeap -      iGrowBy:         0x%08x", iGrowBy);
 | 
|  |     95 |     Kern::Printf("RMemSpyDriverRHeapBase::PrintInfo - RHeap -      iChunkHandle:    0x%08x", iChunkHandle);
 | 
|  |     96 |     Kern::Printf("RMemSpyDriverRHeapBase::PrintInfo - RHeap -      iBase:           0x%08x", Base());
 | 
|  |     97 |     Kern::Printf("RMemSpyDriverRHeapBase::PrintInfo - RHeap -      iTop:            0x%08x", iTop );
 | 
|  |     98 |     Kern::Printf("RMemSpyDriverRHeapBase::PrintInfo - RHeap -      iAlign:          0x%08x", iAlign);
 | 
|  |     99 |     Kern::Printf("RMemSpyDriverRHeapBase::PrintInfo - RHeap -      iMinCell:        0x%08x", iMinCell);
 | 
|  |    100 |     Kern::Printf("RMemSpyDriverRHeapBase::PrintInfo - RHeap -      iPageSize:       0x%08x", iPageSize);
 | 
|  |    101 |     Kern::Printf("RMemSpyDriverRHeapBase::PrintInfo - RHeap -      iFree len:       0x%08x", iFree.len);
 | 
|  |    102 |     Kern::Printf("RMemSpyDriverRHeapBase::PrintInfo - RHeap -      iFree next:      0x%08x", iFree.next);
 | 
|  |    103 |     Kern::Printf("RMemSpyDriverRHeapBase::PrintInfo - RHeap -      iNestingLevel:   0x%08x", iNestingLevel);
 | 
|  |    104 |     Kern::Printf("RMemSpyDriverRHeapBase::PrintInfo - RHeap -      iAllocCount:     0x%08x", iAllocCount);
 | 
|  |    105 |     Kern::Printf("RMemSpyDriverRHeapBase::PrintInfo - RHeap -      size:              %8d",  Size() );
 | 
|  |    106 |     Kern::Printf(" " );
 | 
|  |    107 |     Kern::Printf(" " );
 | 
|  |    108 | #endif
 | 
|  |    109 | 	*/
 | 
|  |    110 |     }
 | 
|  |    111 | 
 | 
| 52 |    112 | 
 | 
|  |    113 | 
 | 
|  |    114 | 
 | 
|  |    115 | RMemSpyDriverRHeapUser::RMemSpyDriverRHeapUser( DMemSpyDriverOSAdaption& aOSAdaption )
 | 
|  |    116 |     : RMemSpyDriverRHeapBase(), iOSAdaption(aOSAdaption)
 | 
| 51 |    117 |     {
 | 
|  |    118 |     }
 | 
|  |    119 | 
 | 
|  |    120 | 
 | 
| 52 |    121 | TInt RMemSpyDriverRHeapUser::OpenUserHeap(DThread& aThread, TBool aEuserUdeb)
 | 
|  |    122 |     {
 | 
|  |    123 |     TLinAddr allocatorAddr = (TLinAddr)OSAdaption().DThread().GetAllocator(aThread);
 | 
|  |    124 |     NKern::ThreadEnterCS();
 | 
|  |    125 |     LtkUtils::RUserAllocatorHelper* helper = new LtkUtils::RUserAllocatorHelper;
 | 
|  |    126 |     if (!helper)
 | 
|  |    127 |         {
 | 
|  |    128 |         NKern::ThreadLeaveCS();
 | 
|  |    129 |         return KErrNoMemory;
 | 
|  |    130 |         }
 | 
|  |    131 |     TInt err = helper->OpenUserHeap(OSAdaption().DThread().GetId(aThread), allocatorAddr, aEuserUdeb);
 | 
|  |    132 |     if (!err)
 | 
|  |    133 |         {
 | 
|  |    134 |         iChunk = helper->OpenUnderlyingChunk();
 | 
|  |    135 |         if (!iChunk) err = KErrNotFound;
 | 
|  |    136 |         }
 | 
|  |    137 |     if (err)
 | 
|  |    138 |         {
 | 
|  |    139 |         delete helper;
 | 
|  |    140 |         }
 | 
|  |    141 |     else
 | 
|  |    142 |         {
 | 
|  |    143 |         iHelper = helper;
 | 
|  |    144 |         }
 | 
|  |    145 |     NKern::ThreadLeaveCS();
 | 
|  |    146 |     return err;
 | 
|  |    147 |     }
 | 
|  |    148 | 
 | 
|  |    149 | 
 | 
|  |    150 | RMemSpyDriverRHeapKernelFromCopy::RMemSpyDriverRHeapKernelFromCopy( DMemSpyDriverOSAdaption& aOSAdaption )
 | 
|  |    151 | :   iOSAdaption( aOSAdaption ), iChunk( NULL )
 | 
|  |    152 |     {
 | 
|  |    153 |     }
 | 
|  |    154 | 
 | 
|  |    155 | 
 | 
|  |    156 | void RMemSpyDriverRHeapKernelFromCopy::Reset()
 | 
| 51 |    157 |     {
 | 
|  |    158 |     RMemSpyDriverRHeapBase::Reset();
 | 
|  |    159 | 	//
 | 
|  |    160 |     iChunk = NULL;
 | 
|  |    161 |     }
 | 
|  |    162 | 
 | 
|  |    163 | 
 | 
| 52 |    164 | TInt RMemSpyDriverRHeapKernelFromCopy::AssociateWithKernelChunk( DChunk* aKernelChunk, DChunk* aCopiedChunk, TLinAddr aCopiedChunkBase, TInt aOffset )
 | 
| 51 |    165 |     {
 | 
| 52 |    166 |     TRACE_KH( Kern::Printf("RMemSpyDriverRHeapKernelFromCopy::AssociateWithKernelChunk() - START - aChunk: 0x%08x, aOffset: %d", 
 | 
|  |    167 |                             aCopiedChunk, aOffset) );
 | 
|  |    168 | 
 | 
|  |    169 |     iChunk = aCopiedChunk;
 | 
|  |    170 |     iChunkBase = aCopiedChunkBase;
 | 
| 51 |    171 | 
 | 
|  |    172 |     NKern::ThreadEnterCS();
 | 
| 52 |    173 |     TInt ret = KErrNone;
 | 
|  |    174 |     LtkUtils::RKernelCopyAllocatorHelper* helper = new LtkUtils::RKernelCopyAllocatorHelper();
 | 
|  |    175 |     if (helper)
 | 
| 51 |    176 |         {
 | 
| 52 |    177 |         helper->OpenCopiedHeap(aKernelChunk, aCopiedChunk, aOffset);
 | 
|  |    178 |         iHelper = helper;        
 | 
|  |    179 |         }
 | 
|  |    180 |     else
 | 
|  |    181 |         {
 | 
|  |    182 |         ret = KErrNoMemory;
 | 
| 51 |    183 |         }
 | 
|  |    184 |     NKern::ThreadLeaveCS();
 | 
| 52 |    185 |     
 | 
|  |    186 |     TRACE_KH( Kern::Printf("RMemSpyDriverRHeapKernelFromCopy::AssociateWithKernelChunk() - END") );
 | 
|  |    187 |     return ret;
 | 
| 51 |    188 |     }
 | 
|  |    189 | 
 | 
| 52 |    190 | DChunk& RMemSpyDriverRHeapKernelFromCopy::Chunk()
 | 
| 51 |    191 |     {
 | 
|  |    192 |     return *iChunk;
 | 
|  |    193 |     }
 | 
|  |    194 | 
 | 
|  |    195 | 
 | 
| 52 |    196 | const DChunk& RMemSpyDriverRHeapKernelFromCopy::Chunk() const
 | 
| 51 |    197 |     {
 | 
| 52 |    198 |     return *iChunk;
 | 
| 51 |    199 |     }
 | 
|  |    200 | 
 | 
|  |    201 | void RMemSpyDriverRHeapKernelFromCopy::Close()
 | 
|  |    202 | 	{
 | 
| 52 |    203 |     if  ( iChunk != NULL )
 | 
|  |    204 |         {
 | 
|  |    205 |         NKern::ThreadEnterCS();
 | 
|  |    206 |         Kern::ChunkClose( iChunk );
 | 
|  |    207 |         iChunk = NULL;
 | 
|  |    208 |         NKern::ThreadLeaveCS();
 | 
|  |    209 |         }
 | 
|  |    210 |     RMemSpyDriverRHeapBase::Close();
 | 
| 51 |    211 | 	}
 | 
|  |    212 | 
 | 
| 52 |    213 | TBool RMemSpyDriverRHeapKernelFromCopy::IsOpen()
 | 
|  |    214 |     {
 | 
|  |    215 |     return (iChunk != NULL);
 | 
|  |    216 |     }
 | 
|  |    217 | 
 | 
|  |    218 | RMemSpyDriverRHeapKernelInPlace::RMemSpyDriverRHeapKernelInPlace( DMemSpyDriverOSAdaption& aOSAdaption )
 | 
|  |    219 | :   iOSAdaption( aOSAdaption ), iChunk( NULL )
 | 
| 51 |    220 |     {
 | 
|  |    221 |     }
 | 
|  |    222 | 
 | 
|  |    223 | TInt RMemSpyDriverRHeapKernelInPlace::OpenKernelHeap()
 | 
|  |    224 | 	{
 | 
|  |    225 | 	NKern::ThreadEnterCS();
 | 
|  |    226 | 	LtkUtils::RAllocatorHelper* helper = new LtkUtils::RAllocatorHelper;
 | 
|  |    227 | 	if (!helper)
 | 
|  |    228 | 		{
 | 
|  |    229 | 		NKern::ThreadLeaveCS();
 | 
|  |    230 | 		return KErrNoMemory;
 | 
|  |    231 | 		}
 | 
|  |    232 | 	TInt err = helper->OpenKernelHeap();
 | 
|  |    233 | 	if (!err)
 | 
|  |    234 | 		{
 | 
|  |    235 | 		iChunk = helper->OpenUnderlyingChunk();
 | 
|  |    236 | 		if (!iChunk) err = KErrNotFound;
 | 
|  |    237 | 		}
 | 
|  |    238 | 
 | 
|  |    239 | 	if (err)
 | 
|  |    240 | 		{
 | 
|  |    241 | 		delete helper;
 | 
|  |    242 | 		}
 | 
|  |    243 | 	else
 | 
|  |    244 | 		{
 | 
|  |    245 | 		iHelper = helper;
 | 
|  |    246 | 		}
 | 
|  |    247 | 	NKern::ThreadLeaveCS();
 | 
|  |    248 | 	return err;
 | 
|  |    249 | 	}
 | 
|  |    250 | 
 | 
|  |    251 | void RMemSpyDriverRHeapKernelInPlace::Close()
 | 
|  |    252 |     {
 | 
|  |    253 | 	NKern::ThreadEnterCS();
 | 
|  |    254 | 	iChunk->Close(NULL);
 | 
|  |    255 | 	iChunk = NULL;
 | 
|  |    256 | 	RMemSpyDriverRHeapBase::Close();
 | 
|  |    257 | 	NKern::ThreadLeaveCS();
 | 
|  |    258 |     }
 | 
|  |    259 | 
 | 
|  |    260 | DChunk& RMemSpyDriverRHeapKernelInPlace::Chunk()
 | 
|  |    261 |     {
 | 
|  |    262 |     return *iChunk;
 | 
|  |    263 |     }
 | 
|  |    264 | 
 | 
|  |    265 | 
 | 
|  |    266 | const DChunk& RMemSpyDriverRHeapKernelInPlace::Chunk() const
 | 
|  |    267 |     {
 | 
|  |    268 |     return *iChunk;
 | 
|  |    269 |     }
 | 
|  |    270 | 
 |