os/kernelhwsrv/kerneltest/e32test/smr/d_smr.cpp
author sl
Tue, 10 Jun 2014 14:32:02 +0200
changeset 1 260cb5ec6c19
permissions -rw-r--r--
Update contrib.
sl@0
     1
// Copyright (c) 2008-2009 Nokia Corporation and/or its subsidiary(-ies).
sl@0
     2
// All rights reserved.
sl@0
     3
// This component and the accompanying materials are made available
sl@0
     4
// under the terms of the License "Eclipse Public License v1.0"
sl@0
     5
// which accompanies this distribution, and is available
sl@0
     6
// at the URL "http://www.eclipse.org/legal/epl-v10.html".
sl@0
     7
//
sl@0
     8
// Initial Contributors:
sl@0
     9
// Nokia Corporation - initial contribution.
sl@0
    10
//
sl@0
    11
// Contributors:
sl@0
    12
//
sl@0
    13
// Description:
sl@0
    14
// Bootstrap Shadow Memory Region Test Driver
sl@0
    15
//
sl@0
    16
sl@0
    17
sl@0
    18
// -- INCLUDES ----------------------------------------------------------------
sl@0
    19
sl@0
    20
#include "d_trace.h"
sl@0
    21
sl@0
    22
#include <memmodel\epoc\platform.h>
sl@0
    23
#include <bootdefs.h>
sl@0
    24
#include <kernel/kernboot.h>
sl@0
    25
#include <kernel/kern_priv.h>
sl@0
    26
#include <platform.h>
sl@0
    27
#include <u32hal.h>
sl@0
    28
#include "d_smr.h"
sl@0
    29
sl@0
    30
sl@0
    31
// -- CLASSES -----------------------------------------------------------------
sl@0
    32
sl@0
    33
sl@0
    34
class DSMRTestFactory : public DLogicalDevice
sl@0
    35
	{
sl@0
    36
public:
sl@0
    37
	virtual TInt Install();
sl@0
    38
	virtual void GetCaps(TDes8& aDes) const;
sl@0
    39
	virtual TInt Create(DLogicalChannelBase*& aChannel);
sl@0
    40
	};
sl@0
    41
sl@0
    42
sl@0
    43
class DSMRTestChannel : public DLogicalChannelBase
sl@0
    44
	{
sl@0
    45
public:
sl@0
    46
	DSMRTestChannel();
sl@0
    47
	virtual ~DSMRTestChannel();
sl@0
    48
	
sl@0
    49
	//	Inherited from DObject
sl@0
    50
	virtual TInt RequestUserHandle(DThread* aThread, TOwnerType aType);
sl@0
    51
	
sl@0
    52
	// Inherited from DLogicalChannelBase
sl@0
    53
	virtual TInt DoCreate(TInt aUnit, const TDesC8* anInfo, const TVersion& aVer);
sl@0
    54
	virtual TInt Request(TInt aReqNo, TAny* a1, TAny* a2);
sl@0
    55
		
sl@0
    56
public:
sl@0
    57
	static void TestTrace(DSMRTestChannel* aSelf);
sl@0
    58
	
sl@0
    59
private:
sl@0
    60
	DThread* iClient;
sl@0
    61
    
sl@0
    62
	};
sl@0
    63
sl@0
    64
TInt OpenDumpCloseChunk(TUint32 aBase, TUint32 aSize);
sl@0
    65
sl@0
    66
sl@0
    67
// -- GLOBALS -----------------------------------------------------------------
sl@0
    68
//
sl@0
    69
sl@0
    70
sl@0
    71
sl@0
    72
// -- METHODS -----------------------------------------------------------------
sl@0
    73
//
sl@0
    74
// TEST FUNCTIONS
sl@0
    75
//
sl@0
    76
sl@0
    77
static TInt ECtrlCheckSMRIBPtr()
sl@0
    78
	{
sl@0
    79
	SMR_FUNC("DSMRTestChannel::Request::ECtrlCheckSMRIBPtr");
sl@0
    80
sl@0
    81
    TSuperPage& superPage = Kern::SuperPage();
sl@0
    82
    TLinAddr smrib = superPage.iSmrData;
sl@0
    83
sl@0
    84
    SMR_TRACE1("SMRIB - Virtual address %x", smrib);
sl@0
    85
sl@0
    86
    return smrib;
sl@0
    87
	}
sl@0
    88
	
sl@0
    89
static TInt ECtrlPrintSMRIB()
sl@0
    90
	{
sl@0
    91
	SMR_FUNC("DSMRTestChannel::Request::ECtrlPrintSMRIB");
sl@0
    92
sl@0
    93
    TSuperPage& superPage = Kern::SuperPage();
sl@0
    94
    TLinAddr smrib = superPage.iSmrData;
sl@0
    95
sl@0
    96
    SMR_TRACE1("SMRIB - Virtual address %x", smrib);
sl@0
    97
sl@0
    98
    if (smrib == KSuperPageAddressFieldUndefined)
sl@0
    99
    	SMR_LOGMSG_RETURN ("SMRIB Does not exist!", KErrBadHandle);
sl@0
   100
    
sl@0
   101
    SSmrBank* smrPtr = (SSmrBank*)(smrib);
sl@0
   102
    int x=0;
sl@0
   103
    while (smrPtr->iBase != 0)
sl@0
   104
        {
sl@0
   105
        SMR_TRACE6("SMRIB entry %d (0x%x): %x, %x, %x, %x", x, smrPtr, smrPtr->iBase, smrPtr->iSize, smrPtr->iPayloadUID, smrPtr->iPayloadFlags);
sl@0
   106
        x++;
sl@0
   107
        smrPtr++;
sl@0
   108
        }
sl@0
   109
    if (x==0)
sl@0
   110
    	SMR_TRACE0("SMRIB Zero, no valid entries");
sl@0
   111
    else
sl@0
   112
    	SMR_TRACE1("SMRIB Contained %d entries", x);
sl@0
   113
sl@0
   114
    return x;
sl@0
   115
	}
sl@0
   116
sl@0
   117
sl@0
   118
static TInt ECtrlAccessAllSMRs()
sl@0
   119
	{
sl@0
   120
	SMR_FUNC("DSMRTestChannel::Request::ECtrlAccessAllSMRs");
sl@0
   121
sl@0
   122
    TInt err=0; 
sl@0
   123
    TSuperPage& superPage = Kern::SuperPage();
sl@0
   124
    TLinAddr smrib = superPage.iSmrData;
sl@0
   125
sl@0
   126
    if (smrib == KSuperPageAddressFieldUndefined)
sl@0
   127
        return KErrBadHandle;
sl@0
   128
    
sl@0
   129
    SSmrBank* smrPtr = (SSmrBank*)(smrib);
sl@0
   130
    int x=0;
sl@0
   131
    while (smrPtr->iBase != 0)
sl@0
   132
        {
sl@0
   133
        SMR_TRACE6("SMRIB item %d (0x%x): %x, %x, %x, %x", x, smrPtr, smrPtr->iBase, smrPtr->iSize, smrPtr->iPayloadUID, smrPtr->iPayloadFlags);
sl@0
   134
        
sl@0
   135
        err = OpenDumpCloseChunk(smrPtr->iBase, smrPtr->iSize);
sl@0
   136
		if (err != KErrNone)
sl@0
   137
  			return err;
sl@0
   138
  			
sl@0
   139
        x++;
sl@0
   140
        smrPtr++;
sl@0
   141
        }
sl@0
   142
    if (x==0)
sl@0
   143
    	SMR_TRACE0("SMRIB Zero, no valid entries");
sl@0
   144
    else
sl@0
   145
    	SMR_TRACE1("SMRIB Contained %d entries", x);
sl@0
   146
   
sl@0
   147
	return x;
sl@0
   148
	}
sl@0
   149
	
sl@0
   150
	
sl@0
   151
static TInt ECtrlFreeHalfSMR1PhysicalRam()
sl@0
   152
	{
sl@0
   153
	SMR_FUNC("DSMRTestChannel::Request::ECtrlFreeHalfSMR1PhysicalRam");
sl@0
   154
sl@0
   155
    TInt err=0; 
sl@0
   156
    TSuperPage& superPage = Kern::SuperPage();
sl@0
   157
    TLinAddr smrib = superPage.iSmrData;
sl@0
   158
    
sl@0
   159
sl@0
   160
    if (smrib == KSuperPageAddressFieldUndefined)
sl@0
   161
        return KErrBadHandle;
sl@0
   162
    
sl@0
   163
    SSmrBank* smrPtr = (SSmrBank*)(smrib);
sl@0
   164
    int x=0;
sl@0
   165
    
sl@0
   166
    if ((smrPtr->iBase == 0) || (smrPtr->iSize == 0))
sl@0
   167
        SMR_LOGMSG_RETURN("SMRIB Does not contain one entry!", 0); 
sl@0
   168
        
sl@0
   169
    SMR_TRACE6("SMRIB item before %d (0x%x): %x, %x, %x, %x", x, smrPtr, smrPtr->iBase, smrPtr->iSize, smrPtr->iPayloadUID, smrPtr->iPayloadFlags);
sl@0
   170
	
sl@0
   171
	TInt halfSize = smrPtr->iSize >> 1;
sl@0
   172
	
sl@0
   173
	NKern::ThreadEnterCS();
sl@0
   174
    err = Epoc::FreePhysicalRam(smrPtr->iBase+halfSize, halfSize);
sl@0
   175
    NKern::ThreadLeaveCS();
sl@0
   176
    if (err != KErrNone)
sl@0
   177
        SMR_LOGMSG_RETURN("Epoc::FreePhysicalRam() gave error", err) 
sl@0
   178
    else
sl@0
   179
    	SMR_TRACE0("Success - half of physical ram freed for SMR 1");	
sl@0
   180
 
sl@0
   181
	smrPtr->iSize = halfSize;
sl@0
   182
	
sl@0
   183
    SMR_TRACE6("SMRIB item after %d (0x%x): %x, %x, %x, %x", x, smrPtr, smrPtr->iBase, smrPtr->iSize, smrPtr->iPayloadUID, smrPtr->iPayloadFlags);
sl@0
   184
sl@0
   185
    err = OpenDumpCloseChunk(smrPtr->iBase, smrPtr->iSize);
sl@0
   186
	if (err != KErrNone)
sl@0
   187
  		return err;
sl@0
   188
sl@0
   189
	return halfSize;
sl@0
   190
	}
sl@0
   191
sl@0
   192
sl@0
   193
static TInt ECtrlFreeAllSMR2PhysicalRam()
sl@0
   194
	{
sl@0
   195
	SMR_FUNC("DSMRTestChannel::Request::ECtrlFreeAllSMR2PhysicalRam");
sl@0
   196
sl@0
   197
    TInt err=0; 
sl@0
   198
    TSuperPage& superPage = Kern::SuperPage();
sl@0
   199
    TLinAddr smrib = superPage.iSmrData;
sl@0
   200
sl@0
   201
    if (smrib == KSuperPageAddressFieldUndefined)
sl@0
   202
        return KErrBadHandle;
sl@0
   203
    
sl@0
   204
    SSmrBank* smrPtr = (SSmrBank*)(smrib);
sl@0
   205
    int x=0;
sl@0
   206
sl@0
   207
	if ((smrPtr->iBase == 0) || (smrPtr->iSize == 0))
sl@0
   208
        SMR_LOGMSG_RETURN("SMRIB Does not contain first entry!", 0);
sl@0
   209
    
sl@0
   210
    smrPtr++; x++;
sl@0
   211
	if ((smrPtr->iBase == 0) || (smrPtr->iSize == 0))
sl@0
   212
        SMR_LOGMSG_RETURN("SMRIB Does not contain two entries!", 0);
sl@0
   213
sl@0
   214
    smrPtr++; x++;
sl@0
   215
	if ((smrPtr->iBase == 0) || (smrPtr->iSize == 0))
sl@0
   216
        SMR_LOGMSG_RETURN("SMRIB Does not contain three entries!", 0);
sl@0
   217
sl@0
   218
    SMR_TRACE6("SMRIB item before %d (0x%x): %x, %x, %x, %x", x, smrPtr, smrPtr->iBase, smrPtr->iSize, smrPtr->iPayloadUID, smrPtr->iPayloadFlags);        
sl@0
   219
   	TInt sizeToFree = smrPtr->iSize;
sl@0
   220
	
sl@0
   221
	NKern::ThreadEnterCS();
sl@0
   222
    err = Epoc::FreePhysicalRam(smrPtr->iBase, sizeToFree);
sl@0
   223
    NKern::ThreadLeaveCS();
sl@0
   224
    if (err != KErrNone)
sl@0
   225
        SMR_LOGMSG_RETURN("Epoc::FreePhysicalRam() gave error", err) 
sl@0
   226
    else
sl@0
   227
    	SMR_TRACE0("Success - all physical ram freed for SMR 2");	
sl@0
   228
        
sl@0
   229
sl@0
   230
	smrPtr->iBase = 0;
sl@0
   231
	smrPtr->iSize = 0;
sl@0
   232
	smrPtr->iPayloadUID = 0;
sl@0
   233
	smrPtr->iPayloadFlags = 0;
sl@0
   234
	
sl@0
   235
    SMR_TRACE6("SMRIB item after %d (0x%x): %x, %x, %x, %x", x, smrPtr, smrPtr->iBase, smrPtr->iSize, smrPtr->iPayloadUID, smrPtr->iPayloadFlags);
sl@0
   236
	return sizeToFree;
sl@0
   237
	}
sl@0
   238
sl@0
   239
sl@0
   240
TInt OpenDumpCloseChunk(TUint32 aBase, TUint32 aSize)
sl@0
   241
	{
sl@0
   242
	TInt err;
sl@0
   243
    TChunkCreateInfo cci;
sl@0
   244
    DChunk *chunkPtr;
sl@0
   245
    TLinAddr kernAddr = 0;
sl@0
   246
    TUint32 mapAttr = 0;
sl@0
   247
    
sl@0
   248
    cci.iType = TChunkCreateInfo::ESharedKernelSingle;
sl@0
   249
    cci.iMaxSize = 0x800000;
sl@0
   250
    cci.iMapAttr = EMapAttrCachedMax | EMapAttrSupRw;
sl@0
   251
    cci.iOwnsMemory = EFalse;
sl@0
   252
    cci.iDestroyedDfc = 0;
sl@0
   253
    
sl@0
   254
    NKern::ThreadEnterCS();
sl@0
   255
    err = Kern::ChunkCreate(cci, chunkPtr, kernAddr, mapAttr);
sl@0
   256
    NKern::ThreadLeaveCS();
sl@0
   257
    if (err != KErrNone)
sl@0
   258
    	SMR_LOGMSG_RETURN("Kern::ChunkCreate() gave error", err);
sl@0
   259
         
sl@0
   260
    NKern::ThreadEnterCS();
sl@0
   261
    err = Kern::ChunkCommitPhysical(chunkPtr, 0, aSize, aBase);
sl@0
   262
    NKern::ThreadLeaveCS();
sl@0
   263
    if (err != KErrNone)
sl@0
   264
    	SMR_LOGMSG_RETURN("Kern::ChunkCommitPhysical() gave error", err); 
sl@0
   265
        
sl@0
   266
    TUint32* setting = (TUint32*)(kernAddr); 
sl@0
   267
    SMR_TRACE1("SMR Image Memory Dump First Kb @ %08x", setting);
sl@0
   268
            
sl@0
   269
    for (TInt y=0; y < 0x80; y+=16)
sl@0
   270
        {
sl@0
   271
        SMR_TRACE5("  %08x:  %08x  %08x  %08x  %08x", setting, setting[0], setting[1], setting[2], setting[3]);
sl@0
   272
        setting+=4;
sl@0
   273
        }
sl@0
   274
        
sl@0
   275
    setting = (TUint32*)(kernAddr+aSize-0x80);
sl@0
   276
	SMR_TRACE1("SMR Image Memory Dump Last Kb @ %08x", setting);
sl@0
   277
            
sl@0
   278
    for (TInt y=0; y < 0x80; y+=16)
sl@0
   279
        {
sl@0
   280
        SMR_TRACE5("  %08x:  %08x  %08x  %08x  %08x", setting, setting[0], setting[1], setting[2], setting[3]);
sl@0
   281
        setting+=4;
sl@0
   282
        }
sl@0
   283
              
sl@0
   284
    NKern::ThreadEnterCS();
sl@0
   285
    TBool chunkRefCntZero = Kern::ChunkClose(chunkPtr);
sl@0
   286
    NKern::ThreadLeaveCS();
sl@0
   287
    if (chunkRefCntZero == 0)
sl@0
   288
		SMR_LOGMSG_RETURN("Kern::ChunkClose gave false result", KErrGeneral);
sl@0
   289
    
sl@0
   290
    return KErrNone;
sl@0
   291
	}
sl@0
   292
sl@0
   293
// -- METHODS -----------------------------------------------------------------
sl@0
   294
//
sl@0
   295
// DSMRTestFactory
sl@0
   296
//
sl@0
   297
sl@0
   298
TInt DSMRTestFactory::Install()
sl@0
   299
	{
sl@0
   300
    SMR_FUNC("DSMRTestFactory::Install");
sl@0
   301
	return SetName(&RSMRTest::Name());
sl@0
   302
	}
sl@0
   303
sl@0
   304
void DSMRTestFactory::GetCaps(TDes8& aDes) const
sl@0
   305
	{
sl@0
   306
    SMR_FUNC("DSMRTestFactory::GetCaps");
sl@0
   307
  	Kern::InfoCopy(aDes,0,0);
sl@0
   308
	}
sl@0
   309
sl@0
   310
TInt DSMRTestFactory::Create(DLogicalChannelBase*& aChannel)
sl@0
   311
	{
sl@0
   312
    SMR_FUNC("DSMRTestFactory::Create");
sl@0
   313
   
sl@0
   314
   	aChannel=new DSMRTestChannel();
sl@0
   315
	if(!aChannel)
sl@0
   316
		return KErrNoMemory;
sl@0
   317
	return KErrNone;
sl@0
   318
	}
sl@0
   319
sl@0
   320
sl@0
   321
// -- METHODS -----------------------------------------------------------------
sl@0
   322
//
sl@0
   323
// DSMRTestChannel
sl@0
   324
//
sl@0
   325
sl@0
   326
DSMRTestChannel::DSMRTestChannel()
sl@0
   327
	{
sl@0
   328
    SMR_FUNC("DSMRTestChannel");
sl@0
   329
   	}
sl@0
   330
sl@0
   331
DSMRTestChannel::~DSMRTestChannel()
sl@0
   332
	{
sl@0
   333
    SMR_FUNC("~DSMRTestChannel");
sl@0
   334
	}
sl@0
   335
sl@0
   336
TInt DSMRTestChannel::DoCreate(TInt /*aUnit*/, const TDesC8* /*aInfo*/, const TVersion& /*aVer*/)
sl@0
   337
	{
sl@0
   338
    SMR_FUNC("DSMRTestChannel::DoCreate");
sl@0
   339
   	
sl@0
   340
    iClient = &Kern::CurrentThread();
sl@0
   341
	return KErrNone;
sl@0
   342
	}
sl@0
   343
sl@0
   344
TInt DSMRTestChannel::RequestUserHandle(DThread* aThread, TOwnerType aType)
sl@0
   345
	{
sl@0
   346
    SMR_FUNC("DSMRTestChannel::RequestUserHandle");
sl@0
   347
    
sl@0
   348
	if (aType!=EOwnerThread || aThread!=iClient)
sl@0
   349
		return KErrAccessDenied;
sl@0
   350
	return KErrNone;
sl@0
   351
	}
sl@0
   352
sl@0
   353
TInt DSMRTestChannel::Request(TInt aReqNo, TAny* a1, TAny*)
sl@0
   354
	{
sl@0
   355
    SMR_FUNC("DSMRTestChannel::Request");
sl@0
   356
	TBool aEnforce = (TBool) a1;
sl@0
   357
	
sl@0
   358
	switch(aReqNo)
sl@0
   359
		{
sl@0
   360
		
sl@0
   361
	case RSMRTest::ECtrlCheckSMRIBPtr:
sl@0
   362
		{
sl@0
   363
		TInt rc = ECtrlCheckSMRIBPtr();
sl@0
   364
		if (rc < 0)
sl@0
   365
    		return rc;
sl@0
   366
		if (aEnforce && rc == 0)
sl@0
   367
    		return KErrBadHandle;
sl@0
   368
    		
sl@0
   369
		break; // fall through, return KErrNone
sl@0
   370
		}
sl@0
   371
		
sl@0
   372
	case RSMRTest::ECtrlPrintSMRIB:
sl@0
   373
		{
sl@0
   374
		TInt rc = ECtrlPrintSMRIB();
sl@0
   375
		if (rc < 0)
sl@0
   376
    		return rc;
sl@0
   377
		if (aEnforce && rc == 0)
sl@0
   378
    		return KErrNotFound;
sl@0
   379
    		
sl@0
   380
		break; // fall through, return KErrNone
sl@0
   381
		}
sl@0
   382
	
sl@0
   383
	case RSMRTest::ECtrlAccessAllSMRs:
sl@0
   384
		{
sl@0
   385
        TInt rc = ECtrlAccessAllSMRs();
sl@0
   386
		if (rc < 0)
sl@0
   387
    		return rc;
sl@0
   388
		if (aEnforce && rc == 0)
sl@0
   389
    		return KErrNotFound;
sl@0
   390
    		
sl@0
   391
    	break; // fall through, return KErrNone
sl@0
   392
		}
sl@0
   393
	
sl@0
   394
	case RSMRTest::ECtrlFreeHalfSMR1PhysicalRam:
sl@0
   395
		{
sl@0
   396
		TInt rc = ECtrlFreeHalfSMR1PhysicalRam();
sl@0
   397
		if (rc < 0)
sl@0
   398
    		return rc;
sl@0
   399
		if (aEnforce && rc == 0)
sl@0
   400
    		return KErrNotFound;
sl@0
   401
		
sl@0
   402
		break; // fall through, return KErrNone
sl@0
   403
		}
sl@0
   404
	
sl@0
   405
	case RSMRTest::ECtrlFreeAllSMR2PhysicalRam:
sl@0
   406
		{
sl@0
   407
		
sl@0
   408
		TInt rc = ECtrlFreeAllSMR2PhysicalRam();
sl@0
   409
		if (rc < 0)
sl@0
   410
    		return rc;
sl@0
   411
		if (aEnforce && rc == 0)
sl@0
   412
    		return KErrNotFound;
sl@0
   413
		
sl@0
   414
		break; // fall through, return KErrNone
sl@0
   415
		}
sl@0
   416
	
sl@0
   417
	default:
sl@0
   418
		return KErrNotSupported;
sl@0
   419
		}
sl@0
   420
		
sl@0
   421
	return KErrNone;
sl@0
   422
	}
sl@0
   423
sl@0
   424
sl@0
   425
// -- GLOBALS -----------------------------------------------------------------
sl@0
   426
sl@0
   427
sl@0
   428
DECLARE_STANDARD_LDD()
sl@0
   429
	{
sl@0
   430
    SMR_FUNC("D_SMR_DECLARE_STANDARD_LDD");
sl@0
   431
sl@0
   432
    const TRomHeader& romHdr = Epoc::RomHeader();
sl@0
   433
    
sl@0
   434
    TInt RHsize = sizeof(TRomHeader);
sl@0
   435
    SMR_TRACE2("RomHeader - addr %0x; size %d", &romHdr, RHsize);
sl@0
   436
sl@0
   437
    TSuperPage& superPage = Kern::SuperPage();
sl@0
   438
    TInt SPsize = sizeof(SSuperPageBase);
sl@0
   439
    
sl@0
   440
    TInt startupReason = superPage.iHwStartupReason;
sl@0
   441
    TLinAddr rootDirList = superPage.iRootDirList;
sl@0
   442
    
sl@0
   443
    SMR_TRACE2("SuperPage  - addr %0x; size %d", &superPage, SPsize);
sl@0
   444
    SMR_TRACE2("SuperPage - StartupReason: %0x; rootDirList %0x", startupReason, rootDirList);
sl@0
   445
                  
sl@0
   446
   	return new DSMRTestFactory;
sl@0
   447
	}
sl@0
   448