os/kernelhwsrv/kernel/eka/include/u32hal.h
author sl
Tue, 10 Jun 2014 14:32:02 +0200
changeset 1 260cb5ec6c19
permissions -rw-r--r--
Update contrib.
sl@0
     1
// Copyright (c) 1995-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
// e32\include\u32hal.h
sl@0
    15
// 
sl@0
    16
// WARNING: This file contains some APIs which are internal and are subject
sl@0
    17
//          to change without notice. Such APIs should therefore not be used
sl@0
    18
//          outside the Kernel and Hardware Services package.
sl@0
    19
//
sl@0
    20
sl@0
    21
#ifndef __U32HAL_H__
sl@0
    22
#define __U32HAL_H__
sl@0
    23
sl@0
    24
#include <e32cmn.h>
sl@0
    25
sl@0
    26
//
sl@0
    27
// Classes used for in functions
sl@0
    28
//
sl@0
    29
sl@0
    30
/**
sl@0
    31
Used for TVariantInfoV01::iLedCapabilities
sl@0
    32
@publishedPartner
sl@0
    33
@released
sl@0
    34
*/
sl@0
    35
const TUint KLedMaskRed1=0x00000001;
sl@0
    36
sl@0
    37
/**
sl@0
    38
Used for TVariantInfoV01::iLedCapabilities
sl@0
    39
@publishedPartner
sl@0
    40
@released
sl@0
    41
*/
sl@0
    42
const TUint KLedMaskGreen1=0x00000002;
sl@0
    43
sl@0
    44
/**
sl@0
    45
Used for TVariantInfoV01::iLedCapabilities
sl@0
    46
@publishedPartner
sl@0
    47
@released
sl@0
    48
*/
sl@0
    49
const TUint KLedMaskYellow1=0x00000004;
sl@0
    50
sl@0
    51
/**
sl@0
    52
Used for TSupplyInfoV1.iFlags
sl@0
    53
@publishedPartner
sl@0
    54
@deprecated Unused by Symbian code
sl@0
    55
*/
sl@0
    56
const TUint KSupplyFlagSoundWarning=0x00000001;
sl@0
    57
sl@0
    58
/**
sl@0
    59
Used for TSupplyInfoV1.iFlags
sl@0
    60
@publishedPartner
sl@0
    61
@deprecated Unused by Symbian code
sl@0
    62
*/
sl@0
    63
const TUint KSupplyFlagBacklightWarning=0x00000002;
sl@0
    64
sl@0
    65
/**
sl@0
    66
Used for TSupplyInfoV1.iFlags
sl@0
    67
@publishedPartner
sl@0
    68
@deprecated Unused by Symbian code
sl@0
    69
*/
sl@0
    70
const TUint KSupplyFlagTimeChanged=0x80000000;
sl@0
    71
sl@0
    72
/**
sl@0
    73
@internalComponent
sl@0
    74
@deprecated Unused by Symbian code
sl@0
    75
*/
sl@0
    76
class TClearSetMask
sl@0
    77
	{
sl@0
    78
public:
sl@0
    79
	TUint iClearMask;
sl@0
    80
	TUint iSetMask;
sl@0
    81
	};
sl@0
    82
sl@0
    83
/**
sl@0
    84
@internalTechnology
sl@0
    85
@deprecated Unused by Symbian code
sl@0
    86
*/
sl@0
    87
enum TSupplyStatus
sl@0
    88
	{
sl@0
    89
	EZero,EVeryLow,ELow,EGood
sl@0
    90
	};
sl@0
    91
sl@0
    92
/**
sl@0
    93
@internalTechnology
sl@0
    94
@deprecated Unused by Symbian code
sl@0
    95
*/
sl@0
    96
class TSupplyInfoV1
sl@0
    97
	{
sl@0
    98
public:
sl@0
    99
	SInt64 iMainBatteryInsertionTime;
sl@0
   100
	TSupplyStatus iMainBatteryStatus;
sl@0
   101
	SInt64 iMainBatteryInUseMicroSeconds;
sl@0
   102
	TInt iCurrentConsumptionMilliAmps;
sl@0
   103
	TInt iMainBatteryConsumedMilliAmpSeconds;
sl@0
   104
	TInt iMainBatteryMilliVolts;
sl@0
   105
	TInt iMainBatteryMaxMilliVolts;
sl@0
   106
	TSupplyStatus iBackupBatteryStatus;
sl@0
   107
	TInt iBackupBatteryMilliVolts;
sl@0
   108
	TInt iBackupBatteryMaxMilliVolts;
sl@0
   109
	TBool iExternalPowerPresent;
sl@0
   110
	SInt64 iExternalPowerInUseMicroSeconds;
sl@0
   111
	TUint iFlags;
sl@0
   112
	};
sl@0
   113
sl@0
   114
/**
sl@0
   115
@internalTechnology
sl@0
   116
@deprecated Unused by Symbian code
sl@0
   117
*/
sl@0
   118
typedef TPckgBuf<TSupplyInfoV1> TSupplyInfoV1Buf;
sl@0
   119
sl@0
   120
/**
sl@0
   121
@publishedPartner
sl@0
   122
@deprecated Unused by Symbian code
sl@0
   123
*/
sl@0
   124
class TMouseProperties
sl@0
   125
	{
sl@0
   126
public:
sl@0
   127
	TUint8 iSpeed;
sl@0
   128
	TUint8 iAcceleration;
sl@0
   129
	};
sl@0
   130
sl@0
   131
/**
sl@0
   132
@internalTechnology Used by Symbian base ports
sl@0
   133
@deprecated Unused by Symbian code
sl@0
   134
*/
sl@0
   135
class TSoundInfoV1
sl@0
   136
	{
sl@0
   137
public:
sl@0
   138
	TBool iKeyClickEnabled;
sl@0
   139
	TBool iKeyClickLoud;
sl@0
   140
	TBool iKeyClickOverridden;
sl@0
   141
	TBool iPointerClickEnabled;
sl@0
   142
	TBool iPointerClickLoud;
sl@0
   143
	TBool iBeepEnabled;
sl@0
   144
	TBool iBeepLoud;
sl@0
   145
	TBool iSoundDriverEnabled;
sl@0
   146
	TBool iSoundDriverLoud;
sl@0
   147
	TBool iSoundEnabled;
sl@0
   148
	};
sl@0
   149
sl@0
   150
/**
sl@0
   151
@internalTechnology
sl@0
   152
@deprecated Unused by Symbian code
sl@0
   153
*/
sl@0
   154
typedef TPckgBuf<TSoundInfoV1> TSoundInfoV1Buf;
sl@0
   155
sl@0
   156
/**
sl@0
   157
@internalTechnology Used by Symbian base ports
sl@0
   158
*/
sl@0
   159
class TOnOffInfoV1
sl@0
   160
	{
sl@0
   161
public:
sl@0
   162
	TBool iPointerSwitchesOn;
sl@0
   163
	TBool iCaseOpenSwitchesOn;
sl@0
   164
	TBool iCaseCloseSwitchesOff;
sl@0
   165
	};
sl@0
   166
sl@0
   167
/**
sl@0
   168
@internalTechnology
sl@0
   169
@deprecated Unused by Symbian code
sl@0
   170
*/
sl@0
   171
typedef TPckgBuf<TOnOffInfoV1> TOnOffInfoV1Buf;
sl@0
   172
sl@0
   173
/**
sl@0
   174
@internalTechnology
sl@0
   175
@removed Unused by Symbian code
sl@0
   176
*/
sl@0
   177
enum TUserMediaFunction {EUserMediaRemount,EUserMediaNotifyChange};
sl@0
   178
sl@0
   179
sl@0
   180
sl@0
   181
sl@0
   182
//
sl@0
   183
// Hal function enumerations
sl@0
   184
//
sl@0
   185
sl@0
   186
/**
sl@0
   187
@publishedPartner
sl@0
   188
@released
sl@0
   189
sl@0
   190
Defines the set of HAL groups.
sl@0
   191
sl@0
   192
Each HAL group has an associated HAL handler. Note that the
sl@0
   193
HAL handlers for EHalGroupKernel and EHalGroupEmulator are internal
sl@0
   194
to Symbian OS.
sl@0
   195
sl@0
   196
See the Base Porting Guide documentation in the developer library for
sl@0
   197
more information on HAL groups.
sl@0
   198
*/
sl@0
   199
enum THalFunctionGroup
sl@0
   200
	{
sl@0
   201
	/**
sl@0
   202
	@internalComponent
sl@0
   203
	
sl@0
   204
	The HAL group associated with kernel related information; for example
sl@0
   205
	the reason for the most recent system boot.
sl@0
   206
	
sl@0
   207
	The function-ids associated with this HAL group are defined by the set
sl@0
   208
    of TKernelHalFunction enum values.
sl@0
   209
    */
sl@0
   210
	EHalGroupKernel=0,
sl@0
   211
sl@0
   212
sl@0
   213
    /**
sl@0
   214
    The HAL group associated with Variant specific hardware.
sl@0
   215
    
sl@0
   216
    This HAL handler is implemented by the Variant, specifically by
sl@0
   217
    the base port's implementation of Asic::VariantHal().
sl@0
   218
    
sl@0
   219
    The function-ids associated with this HAL group are defined by the set
sl@0
   220
    of TVariantHalFunction enum values. See the individual function-ids for
sl@0
   221
    the associated capabilities.
sl@0
   222
sl@0
   223
    @see TVariantHalFunction
sl@0
   224
    @see Asic::VariantHal()
sl@0
   225
    */
sl@0
   226
	EHalGroupVariant=1,
sl@0
   227
sl@0
   228
sl@0
   229
    /**
sl@0
   230
    The HAL group associated with the media driver.
sl@0
   231
    
sl@0
   232
    It is used internally by the media driver LDD.
sl@0
   233
    
sl@0
   234
    The function-ids associated with this HAL group are defined by the set
sl@0
   235
    of TMediaHalFunction enum values. See the individual function-ids for
sl@0
   236
    the associated capabilities.
sl@0
   237
    
sl@0
   238
    @see TMediaHalFunction
sl@0
   239
    */
sl@0
   240
	EHalGroupMedia=2,
sl@0
   241
sl@0
   242
sl@0
   243
    /**
sl@0
   244
    The HAL group associated with power handling.
sl@0
   245
    
sl@0
   246
    This HAL handler is implemented by the power model.
sl@0
   247
    
sl@0
   248
    The function-ids associated with this HAL group are defined by the set
sl@0
   249
    of TPowerHalFunction enum values. See the individual function-ids for
sl@0
   250
    the associated capabilities.
sl@0
   251
		
sl@0
   252
	@see TPowerHalFunction
sl@0
   253
    */
sl@0
   254
	EHalGroupPower=3,
sl@0
   255
	
sl@0
   256
	
sl@0
   257
	/**
sl@0
   258
	The HAL group associated with the main screen display.
sl@0
   259
	
sl@0
   260
	This HAL handler is implemented by the screen (i.e. LCD or video driver).
sl@0
   261
	
sl@0
   262
    The function-ids associated with this HAL group are defined by the set
sl@0
   263
    of TDisplayHalFunction enum values. See the individual function-ids for
sl@0
   264
    the associated capabilities.
sl@0
   265
		
sl@0
   266
	@see TDisplayHalFunction
sl@0
   267
	*/
sl@0
   268
	EHalGroupDisplay=4,
sl@0
   269
sl@0
   270
sl@0
   271
    /**
sl@0
   272
    The HAL group associated with the digitiser (i.e. pen or stylus).
sl@0
   273
    
sl@0
   274
    This HAL handler is implemented by the digitiser.
sl@0
   275
    
sl@0
   276
    The function-ids associated with this HAL group are defined by the set
sl@0
   277
    of TDigitiserHalFunction enum values. See the individual function-ids for
sl@0
   278
    the associated capabilities.
sl@0
   279
    
sl@0
   280
    @see TDigitiserHalFunction
sl@0
   281
    */
sl@0
   282
	EHalGroupDigitiser=5,
sl@0
   283
sl@0
   284
sl@0
   285
    /**
sl@0
   286
    The HAL group associated with a sound driver.
sl@0
   287
    	
sl@0
   288
   	This group is provided by Symbian OS for backwards compatibility with
sl@0
   289
   	the Psion Series 5MX devices.
sl@0
   290
   	
sl@0
   291
   	The function-ids associated with this HAL group are defined by the set
sl@0
   292
    of TSoundHalFunction enum values. See the individual function-ids for
sl@0
   293
    the associated capabilities.
sl@0
   294
    
sl@0
   295
    @see TSoundHalFunction
sl@0
   296
    */
sl@0
   297
	EHalGroupSound=6,
sl@0
   298
sl@0
   299
sl@0
   300
    /**
sl@0
   301
	The HAL group associated with a mouse-type device.
sl@0
   302
	
sl@0
   303
	In Symbian OS, the the only example of a mouse device is in the emulator,
sl@0
   304
	and this is a port of Symbian OS maintained by Symbian.
sl@0
   305
	
sl@0
   306
    The function-ids associated with this HAL group are defined by the set
sl@0
   307
    of TMouseHalFunction enum values. See the individual function-ids for
sl@0
   308
    the associated capabilities.
sl@0
   309
		
sl@0
   310
	@see TMouseHalFunction
sl@0
   311
    */
sl@0
   312
	EHalGroupMouse=7,
sl@0
   313
sl@0
   314
sl@0
   315
	/**
sl@0
   316
	@internalComponent
sl@0
   317
	
sl@0
   318
	The HAL group associated with the emulator.
sl@0
   319
	
sl@0
   320
	The function-ids associated with this HAL group are defined by the set
sl@0
   321
    of TEmulatorHalFunction enum values.
sl@0
   322
	*/
sl@0
   323
	EHalGroupEmulator=8,
sl@0
   324
sl@0
   325
sl@0
   326
    /**
sl@0
   327
    The HAL group associated with the keyboard.
sl@0
   328
    
sl@0
   329
    This HAL handler is implemented by the keyboard driver.
sl@0
   330
    
sl@0
   331
    The function-ids associated with this HAL group are defined by the set
sl@0
   332
    of TKeyboardHalFunction enum values. See the individual function-ids for
sl@0
   333
    the associated capabilities.
sl@0
   334
    
sl@0
   335
    @see TKeyboardHalFunction
sl@0
   336
    */
sl@0
   337
	EHalGroupKeyboard=9,
sl@0
   338
sl@0
   339
	/*
sl@0
   340
    The HAL group associated with the virtual memory system.
sl@0
   341
sl@0
   342
	The function-ids associated with this HAL group are defined by the set
sl@0
   343
    of TVMHalFunction enum values.
sl@0
   344
sl@0
   345
    @see TVMHalFunction
sl@0
   346
	*/
sl@0
   347
	EHalGroupVM=10,
sl@0
   348
sl@0
   349
	/*
sl@0
   350
    The HAL group associated with the RAM Zone configuration.
sl@0
   351
sl@0
   352
	The function-ids associated with this HAL group are defined by the set
sl@0
   353
    of TRamHalFunction enum values.
sl@0
   354
sl@0
   355
    @see TRamHalFunction
sl@0
   356
	*/
sl@0
   357
	EHalGroupRam=11,
sl@0
   358
sl@0
   359
	/**
sl@0
   360
	Reserved for platform specific use.
sl@0
   361
	*/
sl@0
   362
	EHalGroupPlatformSpecific1=29,
sl@0
   363
sl@0
   364
	/**
sl@0
   365
	Reserved for platform specific use.
sl@0
   366
	*/
sl@0
   367
	EHalGroupPlatformSpecific2=30
sl@0
   368
	};
sl@0
   369
sl@0
   370
sl@0
   371
sl@0
   372
sl@0
   373
/**
sl@0
   374
@internalComponent
sl@0
   375
*/
sl@0
   376
enum TKernelHalFunction
sl@0
   377
	{
sl@0
   378
	EKernelHalMemoryInfo,
sl@0
   379
	EKernelHalRomInfo,
sl@0
   380
	EKernelHalStartupReason,
sl@0
   381
	EKernelHalFaultReason,
sl@0
   382
	EKernelHalExceptionId,
sl@0
   383
	EKernelHalExceptionInfo,
sl@0
   384
	EKernelHalCpuInfo,
sl@0
   385
	EKernelHalPageSizeInBytes,
sl@0
   386
	EKernelHalTickPeriod,
sl@0
   387
	EKernelHalMemModelInfo,
sl@0
   388
	EKernelHalFastCounterFrequency,
sl@0
   389
	EKernelHalNTickPeriod,
sl@0
   390
	EKernelHalHardwareFloatingPoint,
sl@0
   391
	EKernelHalGetNonsecureClockOffset,
sl@0
   392
	EKernelHalSetNonsecureClockOffset,
sl@0
   393
	EKernelHalSmpSupported,
sl@0
   394
	EKernelHalNumLogicalCpus,
sl@0
   395
	EKernelHalSupervisorBarrier,
sl@0
   396
	EKernelHalFloatingPointSystemId,
sl@0
   397
	EKernelHalLockThreadToCpu,
sl@0
   398
	EKernelHalConfigFlags,
sl@0
   399
	};
sl@0
   400
sl@0
   401
sl@0
   402
sl@0
   403
sl@0
   404
/**
sl@0
   405
@publishedPartner
sl@0
   406
@released
sl@0
   407
sl@0
   408
The set of function-ids that are  associated with the EHalGroupVariant
sl@0
   409
HAL group.
sl@0
   410
sl@0
   411
Each enum value represents a specific characteristic of the Variant,
sl@0
   412
and is passed as the second parameter to
sl@0
   413
the HAL handler function dealing with this group.
sl@0
   414
 
sl@0
   415
@see EHalGroupVariant
sl@0
   416
*/
sl@0
   417
enum TVariantHalFunction
sl@0
   418
	{
sl@0
   419
	/**
sl@0
   420
	Gets Variant specifc information.
sl@0
   421
	
sl@0
   422
	Requirements of the HAL function handler's 2nd, 3rd and 4th parameters:
sl@0
   423
	
sl@0
   424
	- TInt aFunction : This enum value.
sl@0
   425
	    
sl@0
   426
	- TAny* a1 : This is a pointer to a package buffer (TPckgBuf) containing a
sl@0
   427
	TVariantInfoV01 structure. The HAL function needs to fill the members of
sl@0
   428
	this structure with the appropriate information.
sl@0
   429
									
sl@0
   430
	- TAny* a2 : NULL.
sl@0
   431
sl@0
   432
	An example of this function can be found in the Variant template;
sl@0
   433
	see the function: 
sl@0
   434
	@code
sl@0
   435
	Template::VariantHal()
sl@0
   436
	@endcode
sl@0
   437
	in  
sl@0
   438
	@code
sl@0
   439
	...\template\template_variant\specific\variant.cpp
sl@0
   440
	@endcode
sl@0
   441
	
sl@0
   442
	@see TVariantInfoV01
sl@0
   443
    @see TPckgBuf
sl@0
   444
	*/
sl@0
   445
	EVariantHalVariantInfo,
sl@0
   446
sl@0
   447
sl@0
   448
	/**
sl@0
   449
	Sets the debug port number.
sl@0
   450
	
sl@0
   451
	Requirements of the HAL function handler's 2nd, 3rd and 4th parameters:
sl@0
   452
	
sl@0
   453
	- TInt aFunction : This enum value.
sl@0
   454
sl@0
   455
	- TAny* a1 : A TInt value containing the debug port number.
sl@0
   456
									
sl@0
   457
	- TAny* a2 : NULL.
sl@0
   458
sl@0
   459
	An example of this function can be found in the Variant template;
sl@0
   460
	see the function: 
sl@0
   461
	@code
sl@0
   462
	Template::VariantHal()
sl@0
   463
	@endcode
sl@0
   464
	in  
sl@0
   465
	@code
sl@0
   466
	...\template\template_variant\specific\variant.cpp
sl@0
   467
	@endcode
sl@0
   468
	*/
sl@0
   469
	EVariantHalDebugPortSet,
sl@0
   470
sl@0
   471
sl@0
   472
	/**
sl@0
   473
	Gets the debug port number.
sl@0
   474
	
sl@0
   475
	Requirements of the HAL function handler's 2nd, 3rd and 4th parameters:
sl@0
   476
	
sl@0
   477
	- TInt aFunction : This enum value.
sl@0
   478
sl@0
   479
    - TAny* a1 : A TInt value into which the HAL handler puts the debug port value
sl@0
   480
    									
sl@0
   481
	- TAny* a2 : NULL.
sl@0
   482
sl@0
   483
	An example of this function can be found in the Variant template;
sl@0
   484
	see the function: 
sl@0
   485
	@code
sl@0
   486
	Template::VariantHal()
sl@0
   487
	@endcode
sl@0
   488
	in  
sl@0
   489
	@code
sl@0
   490
	...\template\template_variant\specific\variant.cpp
sl@0
   491
	@endcode
sl@0
   492
	*/
sl@0
   493
	EVariantHalDebugPortGet,
sl@0
   494
sl@0
   495
sl@0
   496
	/**
sl@0
   497
	Sets the current state of each LED. 
sl@0
   498
	
sl@0
   499
	Requirements of the HAL function handler's 2nd, 3rd and 4th parameters:
sl@0
   500
	
sl@0
   501
	- TInt aFunction : This enum value.
sl@0
   502
sl@0
   503
    - TAny* a1 : A TUint value containing the bitmask that
sl@0
   504
    describes the state of the LEDs. For each bit in the mask, 0 = OFF, 1 = ON.
sl@0
   505
    									
sl@0
   506
	- TAny* a2 : NULL.
sl@0
   507
	
sl@0
   508
	An example of this function can be found in the Variant template;
sl@0
   509
	see the function: 
sl@0
   510
	@code
sl@0
   511
	Template::VariantHal()
sl@0
   512
	@endcode
sl@0
   513
	in  
sl@0
   514
	@code
sl@0
   515
	...\template\template_variant\specific\variant.cpp
sl@0
   516
	@endcode
sl@0
   517
	*/
sl@0
   518
	EVariantHalLedMaskSet,
sl@0
   519
sl@0
   520
sl@0
   521
	/**
sl@0
   522
	Gets the current state of each LED.
sl@0
   523
	
sl@0
   524
	Requirements of the HAL function handler's 2nd, 3rd and 4th parameters:
sl@0
   525
	
sl@0
   526
	- TInt aFunction : This enum value.
sl@0
   527
sl@0
   528
    - TAny* a1 : A TUint value into which the HAL handler puts the bitmask that
sl@0
   529
    describes the state of the LEDs. For each bit in the mask, 0 = OFF, 1 = ON.
sl@0
   530
    									
sl@0
   531
	- TAny* a2 : NULL.
sl@0
   532
sl@0
   533
	An example of this function can be found in the Variant template;
sl@0
   534
	see the function: 
sl@0
   535
	@code
sl@0
   536
	Template::VariantHal()
sl@0
   537
	@endcode
sl@0
   538
	in  
sl@0
   539
	@code
sl@0
   540
	...\template\template_variant\specific\variant.cpp
sl@0
   541
	@endcode
sl@0
   542
	*/
sl@0
   543
	EVariantHalLedMaskGet,
sl@0
   544
sl@0
   545
sl@0
   546
	/**
sl@0
   547
	Gets the current state of any Variant specific switches. 
sl@0
   548
	
sl@0
   549
	Requirements of the HAL function handler's 2nd, 3rd and 4th parameters:
sl@0
   550
	
sl@0
   551
	- TInt aFunction : This enum value.
sl@0
   552
sl@0
   553
    - TAny* a1 : A TUint value into which the HAL handler puts the bits that
sl@0
   554
    describe the state of the switches. The meaning of the switches is entirely
sl@0
   555
    hardware dependent.
sl@0
   556
    									
sl@0
   557
	- TAny* a2 : NULL.
sl@0
   558
sl@0
   559
	An example of this function can be found in the Variant template;
sl@0
   560
	see the function: 
sl@0
   561
	@code
sl@0
   562
	Template::VariantHal()
sl@0
   563
	@endcode
sl@0
   564
	in  
sl@0
   565
	@code
sl@0
   566
	...\template\template_variant\specific\variant.cpp
sl@0
   567
	@endcode
sl@0
   568
	*/
sl@0
   569
	EVariantHalSwitches,
sl@0
   570
sl@0
   571
sl@0
   572
	/**
sl@0
   573
	Restarts the system.
sl@0
   574
	
sl@0
   575
	Requirements of the HAL function handler's 2nd, 3rd and 4th parameters:
sl@0
   576
	
sl@0
   577
	- TInt aFunction : This enum value.
sl@0
   578
sl@0
   579
    - TAny* a1 : A TUint value containing the bits defining the custom restart reasons
sl@0
   580
    that can be passed to Kern::Restart().
sl@0
   581
    									
sl@0
   582
	- TAny* a2 : NULL.
sl@0
   583
sl@0
   584
	An example of this function can be found in the Variant template;
sl@0
   585
	see the function: 
sl@0
   586
	@code
sl@0
   587
	Template::VariantHal()
sl@0
   588
	@endcode
sl@0
   589
	in  
sl@0
   590
	@code
sl@0
   591
	...\template\template_variant\specific\variant.cpp
sl@0
   592
	@endcode
sl@0
   593
		
sl@0
   594
	@capability PowerMgmt
sl@0
   595
	
sl@0
   596
	@see Kern::Restart()
sl@0
   597
	*/
sl@0
   598
	EVariantHalCustomRestart,
sl@0
   599
sl@0
   600
sl@0
   601
	/**
sl@0
   602
	Gets the reason for the system restart.
sl@0
   603
			
sl@0
   604
	Requirements of the HAL function handler's 2nd, 3rd and 4th parameters:
sl@0
   605
	
sl@0
   606
	- TInt aFunction : This enum value.
sl@0
   607
sl@0
   608
    - TAny* a1 : A TInt value into which the handler will put a value
sl@0
   609
    representing the restart reason.
sl@0
   610
        									
sl@0
   611
	- TAny* a2 : NULL.
sl@0
   612
	
sl@0
   613
	An example of this function can be found in the Variant template;
sl@0
   614
	see the function: 
sl@0
   615
	@code
sl@0
   616
	Template::VariantHal()
sl@0
   617
	@endcode
sl@0
   618
	in the file
sl@0
   619
	@code
sl@0
   620
	...\template\template_variant\specific\variant.cpp
sl@0
   621
	@endcode
sl@0
   622
	*/
sl@0
   623
	EVariantHalCustomRestartReason,
sl@0
   624
sl@0
   625
sl@0
   626
	/**
sl@0
   627
	Gets the current state of the case.
sl@0
   628
	
sl@0
   629
	Requirements of the HAL function handler's 2nd, 3rd and 4th parameters:
sl@0
   630
	
sl@0
   631
	- TInt aFunction : This enum value.
sl@0
   632
sl@0
   633
    - TAny* a1 : A TUint value into which the HAL handler puts a value representing the case state.
sl@0
   634
      Possible values are 0 for closed, and 1 for open.
sl@0
   635
    									
sl@0
   636
	- TAny* a2 : NULL.
sl@0
   637
sl@0
   638
	An example of this function can be found in the Variant template;
sl@0
   639
	see the function: 
sl@0
   640
	@code
sl@0
   641
	Template::VariantHal()
sl@0
   642
	@endcode
sl@0
   643
	in  
sl@0
   644
	@code
sl@0
   645
	...\template\template_variant\specific\variant.cpp
sl@0
   646
	@endcode
sl@0
   647
	*/
sl@0
   648
	EVariantHalCaseState,
sl@0
   649
sl@0
   650
sl@0
   651
	/**
sl@0
   652
	Gets the number of screens on this platform.
sl@0
   653
	
sl@0
   654
	Requirements of the HAL function handler's 2nd, 3rd and 4th parameters:
sl@0
   655
	
sl@0
   656
	- TInt aFunction : This enum value.
sl@0
   657
	    
sl@0
   658
	- TAny* a1 : This is a pointer to TInt that will contain the number of screens
sl@0
   659
									
sl@0
   660
	- TAny* a2 : NULL.
sl@0
   661
sl@0
   662
	*/
sl@0
   663
	EVariantHalCurrentNumberOfScreens,
sl@0
   664
sl@0
   665
	/**
sl@0
   666
	Sets the startup reason for the system restart.
sl@0
   667
	
sl@0
   668
	Requirements of the HAL function handler's 2nd, 3rd and 4th parameters:
sl@0
   669
	
sl@0
   670
	- TInt aFunction : This enum value.
sl@0
   671
sl@0
   672
    - TAny* a1 : A TUint value containing the bits defining the startup mode
sl@0
   673
    that will be passed to Kern::Restart().
sl@0
   674
    									
sl@0
   675
	- TAny* a2 : NULL.
sl@0
   676
	
sl@0
   677
	An example of this function can be found in the Variant template;
sl@0
   678
	see the function: 
sl@0
   679
	@code
sl@0
   680
	Template::VariantHal()
sl@0
   681
	@endcode
sl@0
   682
	in  
sl@0
   683
	@code
sl@0
   684
	...\template\template_variant\specific\variant.cpp
sl@0
   685
	@endcode
sl@0
   686
		
sl@0
   687
	@capability WriteDeviceData
sl@0
   688
	
sl@0
   689
	@see Kern::Restart()
sl@0
   690
	*/	
sl@0
   691
	EVariantHalPersistStartupMode,
sl@0
   692
sl@0
   693
	/**
sl@0
   694
	Gets the startup mode after a system restart.
sl@0
   695
			
sl@0
   696
	Requirements of the HAL function handler's 2nd, 3rd and 4th parameters:
sl@0
   697
	
sl@0
   698
	- TInt aFunction : This enum value.
sl@0
   699
sl@0
   700
    - TAny* a1 : A TInt that will hold the returned value
sl@0
   701
        									
sl@0
   702
	- TAny* a2 : NULL.
sl@0
   703
	
sl@0
   704
	An example of this function can be found in the Variant template;
sl@0
   705
	see the function: 
sl@0
   706
	@code
sl@0
   707
	Template::VariantHal()
sl@0
   708
	@endcode
sl@0
   709
	in the file
sl@0
   710
	@code
sl@0
   711
	...\template\template_variant\specific\variant.cpp
sl@0
   712
	@endcode
sl@0
   713
	*/
sl@0
   714
	EVariantHalGetPersistedStartupMode,
sl@0
   715
sl@0
   716
	/**
sl@0
   717
	Returns the maximum number of values that can be used to store the startup reason required for a custom restart.
sl@0
   718
	
sl@0
   719
	Requirements of the HAL function handler's 2nd, 3rd and 4th parameters:
sl@0
   720
	
sl@0
   721
	- TInt aFunction : This enum value.
sl@0
   722
sl@0
   723
    - TAny* a1 : A TInt that will hold the returned value
sl@0
   724
    									
sl@0
   725
	- TAny* a2 : NULL.
sl@0
   726
sl@0
   727
	An example of this function can be found in the Variant template;
sl@0
   728
	see the function: 
sl@0
   729
	@code
sl@0
   730
	Template::VariantHal()
sl@0
   731
	@endcode
sl@0
   732
	in  
sl@0
   733
	@code
sl@0
   734
	...\template\template_variant\specific\variant.cpp
sl@0
   735
	@endcode
sl@0
   736
	*/
sl@0
   737
	EVariantHalGetMaximumCustomRestartReasons,
sl@0
   738
sl@0
   739
	/**
sl@0
   740
	Returns the maximum number of values that can be used to store the startup mode required for a transition to
sl@0
   741
	a EPwRestart power state.
sl@0
   742
	
sl@0
   743
	Requirements of the HAL function handler's 2nd, 3rd and 4th parameters:
sl@0
   744
	
sl@0
   745
	- TInt aFunction : This enum value.
sl@0
   746
sl@0
   747
    - TAny* a1 : A TInt that will hold the returned value
sl@0
   748
    									
sl@0
   749
	- TAny* a2 : NULL.
sl@0
   750
sl@0
   751
	An example of this function can be found in the Variant template;
sl@0
   752
	see the function: 
sl@0
   753
	@code
sl@0
   754
	Template::VariantHal()
sl@0
   755
	@endcode
sl@0
   756
	in  
sl@0
   757
	@code
sl@0
   758
	...\template\template_variant\specific\variant.cpp
sl@0
   759
	@endcode
sl@0
   760
	*/
sl@0
   761
	EVariantHalGetMaximumRestartStartupModes,
sl@0
   762
sl@0
   763
	/**
sl@0
   764
	Returns a factor by which timeouts in test code should be expanded for
sl@0
   765
	exceptionally slow platforms (e.g. with cores implemented in FPGA).
sl@0
   766
sl@0
   767
	If this is not supported the factor should be assumed to be 1.
sl@0
   768
	*/
sl@0
   769
	EVariantHalTimeoutExpansion,
sl@0
   770
sl@0
   771
	/**
sl@0
   772
	Returns a serial number as an Int
sl@0
   773
	*/
sl@0
   774
	EVariantHalSerialNumber,
sl@0
   775
	
sl@0
   776
	/**
sl@0
   777
	Returns the interrupt used by sampling profiler - applicable for SMP only.
sl@0
   778
	Each CPU_i is interrupted by interrupt number ECpuProfilingInterrupt + i
sl@0
   779
	*/	
sl@0
   780
	EVariantHalProfilingDefaultInterruptBase
sl@0
   781
sl@0
   782
	};
sl@0
   783
sl@0
   784
sl@0
   785
sl@0
   786
sl@0
   787
/**
sl@0
   788
@publishedPartner
sl@0
   789
@released
sl@0
   790
sl@0
   791
The set of function-ids that are  associated with the EHalGroupMedia
sl@0
   792
HAL group.
sl@0
   793
sl@0
   794
Each enum value represents a specific characteristic of the media driver,
sl@0
   795
and is passed as the second parameter to
sl@0
   796
the HAL handler function dealing with this group.
sl@0
   797
 
sl@0
   798
@see EHalGroupMedia
sl@0
   799
*/
sl@0
   800
enum TMediaHalFunction
sl@0
   801
	{
sl@0
   802
	/**
sl@0
   803
	Gets drive information.
sl@0
   804
sl@0
   805
	Requirements of the HAL function handler's 2nd, 3rd and 4th parameters:
sl@0
   806
	
sl@0
   807
	- TInt aFunction : This enum value.
sl@0
   808
	    
sl@0
   809
	- TAny* a1 : This is a pointer to a package buffer (TPckgBuf) containing a
sl@0
   810
    TDriveInfoV1 structure. The HAL function needs to fill the members of
sl@0
   811
	this structure with the appropriate information.
sl@0
   812
									
sl@0
   813
	- TAny* a2 : NULL.
sl@0
   814
sl@0
   815
	Note that the HAL handler is implemented by Symbian OS
sl@0
   816
	
sl@0
   817
	@see TDriveInfoV1
sl@0
   818
    @see TPckgBuf
sl@0
   819
	*/
sl@0
   820
	EMediaHalDriveInfo,
sl@0
   821
sl@0
   822
	/**
sl@0
   823
	@internalTechnology
sl@0
   824
	@test
sl@0
   825
	*/
sl@0
   826
	EMediaHalGetROMConcurrencyInfo,
sl@0
   827
sl@0
   828
	/**
sl@0
   829
	@internalTechnology
sl@0
   830
	@test
sl@0
   831
	*/
sl@0
   832
	EMediaHalGetCodeConcurrencyInfo,
sl@0
   833
sl@0
   834
	/**
sl@0
   835
	@internalTechnology
sl@0
   836
	@test
sl@0
   837
	*/
sl@0
   838
	EMediaHalResetConcurrencyInfo,
sl@0
   839
sl@0
   840
	/**
sl@0
   841
	@internalTechnology
sl@0
   842
	@test
sl@0
   843
	*/
sl@0
   844
	EMediaHalGetROMPagingBenchmark,
sl@0
   845
sl@0
   846
	/**
sl@0
   847
	@internalTechnology
sl@0
   848
	@test
sl@0
   849
	*/
sl@0
   850
	EMediaHalGetCodePagingBenchmark,
sl@0
   851
sl@0
   852
	/**
sl@0
   853
	@internalTechnology
sl@0
   854
	@test
sl@0
   855
	*/
sl@0
   856
	EMediaHalResetPagingBenchmark,
sl@0
   857
sl@0
   858
	/**
sl@0
   859
	@internalTechnology
sl@0
   860
	@test
sl@0
   861
	*/
sl@0
   862
	EMediaHalGetDataConcurrencyInfo,
sl@0
   863
sl@0
   864
	/**
sl@0
   865
	@internalTechnology
sl@0
   866
	@test
sl@0
   867
	*/
sl@0
   868
	EMediaHalGetDataInPagingBenchmark,
sl@0
   869
sl@0
   870
	/**
sl@0
   871
	@internalTechnology
sl@0
   872
	@test
sl@0
   873
	*/
sl@0
   874
	EMediaHalGetDataOutPagingBenchmark,
sl@0
   875
sl@0
   876
	/**
sl@0
   877
	@internalTechnology
sl@0
   878
	@test
sl@0
   879
	*/
sl@0
   880
	EMediaHalGetPagingInfo,
sl@0
   881
	};
sl@0
   882
sl@0
   883
sl@0
   884
sl@0
   885
sl@0
   886
/**
sl@0
   887
@publishedPartner
sl@0
   888
@released
sl@0
   889
sl@0
   890
The set of function-ids that are  associated with the EHalGroupPower
sl@0
   891
HAL group.
sl@0
   892
sl@0
   893
Each enum value represents a specific aspect of power handling on the device.
sl@0
   894
sl@0
   895
@see EHalGroupPower
sl@0
   896
*/
sl@0
   897
enum TPowerHalFunction
sl@0
   898
	{
sl@0
   899
	
sl@0
   900
	/**
sl@0
   901
	This is used internally by Symbian
sl@0
   902
	*/
sl@0
   903
	EPowerHalOnOffInfo,
sl@0
   904
	
sl@0
   905
	
sl@0
   906
	/**
sl@0
   907
	This is not currently used.
sl@0
   908
	*/
sl@0
   909
	EPowerHalSupplyInfo,
sl@0
   910
sl@0
   911
sl@0
   912
	/**
sl@0
   913
	This is not currently used.
sl@0
   914
	
sl@0
   915
	@capability PowerMgmt
sl@0
   916
	*/
sl@0
   917
	EPowerHalSetAutoSwitchOffBehavior,
sl@0
   918
    
sl@0
   919
    
sl@0
   920
    /**
sl@0
   921
    This is not currently used.
sl@0
   922
    */
sl@0
   923
	EPowerHalAutoSwitchOffBehavior,
sl@0
   924
sl@0
   925
sl@0
   926
	/**
sl@0
   927
	This is not currently used.
sl@0
   928
	
sl@0
   929
	@capability PowerMgmt
sl@0
   930
	*/
sl@0
   931
	EPowerHalSetAutoSwitchOffTime,
sl@0
   932
sl@0
   933
sl@0
   934
    /**
sl@0
   935
    This is not currently used.
sl@0
   936
    */
sl@0
   937
	EPowerHalAutoSwitchOffTime,
sl@0
   938
sl@0
   939
sl@0
   940
	/**
sl@0
   941
	This is not currently used.
sl@0
   942
	
sl@0
   943
	@capability PowerMgmt
sl@0
   944
	*/
sl@0
   945
	EPowerHalResetAutoSwitchOffTimer,
sl@0
   946
sl@0
   947
sl@0
   948
	/** 
sl@0
   949
	Switches the device off.
sl@0
   950
	
sl@0
   951
	Requirements of the HAL function handler's 2nd, 3rd and 4th parameters:
sl@0
   952
	
sl@0
   953
	- TInt aFunction : This enum value.
sl@0
   954
	    
sl@0
   955
    - TAny* a1 : NULL.
sl@0
   956
									
sl@0
   957
	- TAny* a2 : NULL.
sl@0
   958
	
sl@0
   959
	@capability PowerMgmt
sl@0
   960
	*/
sl@0
   961
	EPowerHalSwitchOff,
sl@0
   962
sl@0
   963
sl@0
   964
	/**
sl@0
   965
	Sets whether touching the screen with a pen or stylus will cause
sl@0
   966
    the device to switch on.
sl@0
   967
    	
sl@0
   968
	Requirements of the HAL function handler's 2nd, 3rd and 4th parameters:
sl@0
   969
	
sl@0
   970
	- TInt aFunction : This enum value.
sl@0
   971
	    
sl@0
   972
    - TAny* a1 : A TBool that needs to be set to ETrue (if touching the screen
sl@0
   973
    is to cause a power on), or EFalse (if touching the screen is not to cause
sl@0
   974
    a power on).
sl@0
   975
									
sl@0
   976
	- TAny* a2 : NULL.
sl@0
   977
sl@0
   978
	@capability WriteDeviceData
sl@0
   979
	*/
sl@0
   980
	EPowerHalSetPointerSwitchesOn,
sl@0
   981
sl@0
   982
sl@0
   983
    /**
sl@0
   984
    Tests whether touching the screen with a pen or stylus will cause
sl@0
   985
    the device to switch on.
sl@0
   986
    
sl@0
   987
    Requirements of the HAL function handler's 2nd, 3rd and 4th parameters:
sl@0
   988
	
sl@0
   989
	- TInt aFunction : This enum value.
sl@0
   990
	    
sl@0
   991
    - TAny* a1 : A TBool into which the HAL handler puts ETrue (if touching
sl@0
   992
    the screen will cause a power on), or EFalse (if touching the screen will
sl@0
   993
    not cause a power on).
sl@0
   994
									
sl@0
   995
	- TAny* a2 : NULL.
sl@0
   996
    */
sl@0
   997
	EPowerHalPointerSwitchesOn,
sl@0
   998
sl@0
   999
sl@0
  1000
	/**
sl@0
  1001
	Sets whether the opening of a 'device case' will cause
sl@0
  1002
    the device to switch on.
sl@0
  1003
    
sl@0
  1004
	Note that the meaning attached to a 'device case' depends on the hardware.
sl@0
  1005
	
sl@0
  1006
	Requirements of the HAL function handler's 2nd, 3rd and 4th parameters:
sl@0
  1007
	
sl@0
  1008
	- TInt aFunction : This enum value.
sl@0
  1009
	    
sl@0
  1010
    - TAny* a1 : A TBool that needs to be set to ETrue (if opening
sl@0
  1011
    the case is to cause a power on), or EFalse (if opening
sl@0
  1012
    the case is not to cause a power on).
sl@0
  1013
									
sl@0
  1014
	- TAny* a2 : NULL.
sl@0
  1015
sl@0
  1016
	@capability WriteDeviceData
sl@0
  1017
	*/
sl@0
  1018
	EPowerHalSetCaseOpenSwitchesOn,
sl@0
  1019
sl@0
  1020
sl@0
  1021
    /**
sl@0
  1022
    Tests whether the opening of a 'device case' will cause
sl@0
  1023
    the device to switch on.
sl@0
  1024
    
sl@0
  1025
    Note that the meaning attached to a 'device case' depends on the hardware.
sl@0
  1026
    
sl@0
  1027
    Requirements of the HAL function handler's 2nd, 3rd and 4th parameters:
sl@0
  1028
	
sl@0
  1029
	- TInt aFunction : This enum value.
sl@0
  1030
	    
sl@0
  1031
    - TAny* a1 : A TBool into which the HAL handler puts ETrue (if opening
sl@0
  1032
    the case will cause a power on), or EFalse (if opening
sl@0
  1033
    the case will not cause a power on).
sl@0
  1034
									
sl@0
  1035
	- TAny* a2 : NULL.
sl@0
  1036
    */
sl@0
  1037
	EPowerHalCaseOpenSwitchesOn,
sl@0
  1038
sl@0
  1039
sl@0
  1040
	/**
sl@0
  1041
	Sets whether the closing of a 'device case' will cause
sl@0
  1042
    the device to switch off.
sl@0
  1043
    
sl@0
  1044
	Note that the meaning attached to a 'device case' depends on the hardware.
sl@0
  1045
	
sl@0
  1046
	Requirements of the HAL function handler's 2nd, 3rd and 4th parameters:
sl@0
  1047
	
sl@0
  1048
	- TInt aFunction : This enum value.
sl@0
  1049
	    
sl@0
  1050
    - TAny* a1 : A TBool that needs to be set to ETrue (if closing
sl@0
  1051
    the case is to cause a power off), or EFalse (if closing
sl@0
  1052
    the case is not to cause a power off).
sl@0
  1053
									
sl@0
  1054
	- TAny* a2 : NULL.
sl@0
  1055
	
sl@0
  1056
	@capability WriteDeviceData
sl@0
  1057
	*/
sl@0
  1058
	EPowerHalSetCaseCloseSwitchesOff,
sl@0
  1059
    
sl@0
  1060
    
sl@0
  1061
    /**
sl@0
  1062
    Tests whether the closing of a 'device case' will cause
sl@0
  1063
    the device to switch off.
sl@0
  1064
    
sl@0
  1065
    Note that the meaning attached to a 'device case' depends on the hardware.
sl@0
  1066
    
sl@0
  1067
    Requirements of the HAL function handler's 2nd, 3rd and 4th parameters:
sl@0
  1068
	
sl@0
  1069
	- TInt aFunction : This enum value.
sl@0
  1070
	    
sl@0
  1071
    - TAny* a1 : A TBool into which the HAL handler puts ETrue (if closing
sl@0
  1072
    the case will cause a power off), or EFalse (if closing
sl@0
  1073
    the case will not cause a power off).
sl@0
  1074
									
sl@0
  1075
	- TAny* a2 : NULL.
sl@0
  1076
	*/
sl@0
  1077
	EPowerHalCaseCloseSwitchesOff,
sl@0
  1078
sl@0
  1079
sl@0
  1080
	/**
sl@0
  1081
	This is not currently used.
sl@0
  1082
	
sl@0
  1083
	@capability PowerMgmt
sl@0
  1084
	*/
sl@0
  1085
	EPowerHalSetBatteryType,
sl@0
  1086
    
sl@0
  1087
    
sl@0
  1088
    /**
sl@0
  1089
    This is not currently used.
sl@0
  1090
    */
sl@0
  1091
	EPowerHalBatteryType,
sl@0
  1092
sl@0
  1093
sl@0
  1094
	/**
sl@0
  1095
	This is not currently used.
sl@0
  1096
	
sl@0
  1097
	@capability PowerMgmt
sl@0
  1098
	*/
sl@0
  1099
	EPowerHalSetBatteryCapacity,
sl@0
  1100
sl@0
  1101
sl@0
  1102
    /**
sl@0
  1103
    This is not currently used.
sl@0
  1104
    */
sl@0
  1105
	EPowerHalBatteryCapacity,
sl@0
  1106
sl@0
  1107
sl@0
  1108
    /**
sl@0
  1109
    This is not currently used.
sl@0
  1110
    */
sl@0
  1111
	EPowerHalAutoSwitchOffType,
sl@0
  1112
	
sl@0
  1113
	
sl@0
  1114
	/**
sl@0
  1115
    This is used internally by Symbian.
sl@0
  1116
	*/
sl@0
  1117
	EPowerHalTestBootSequence,
sl@0
  1118
sl@0
  1119
	
sl@0
  1120
	/**
sl@0
  1121
    Tests whether a backup power supply is present or not.
sl@0
  1122
    
sl@0
  1123
    Requirements of the HAL function handler's 2nd, 3rd and 4th parameters:
sl@0
  1124
	
sl@0
  1125
	- TInt aFunction : This enum value.
sl@0
  1126
	    
sl@0
  1127
    - TAny* a1 : A TBool into which the HAL handler puts ETrue (if backup 
sl@0
  1128
    power is present), or EFalse (if backup power is not present).
sl@0
  1129
									
sl@0
  1130
	- TAny* a2 : NULL.
sl@0
  1131
	*/
sl@0
  1132
	EPowerHalBackupPresent,
sl@0
  1133
sl@0
  1134
	
sl@0
  1135
	/**
sl@0
  1136
    Tests whether accessory power is present or not.
sl@0
  1137
    	
sl@0
  1138
	Requirements of the HAL function handler's 2nd, 3rd and 4th parameters:
sl@0
  1139
	
sl@0
  1140
	- TInt aFunction : This enum value.
sl@0
  1141
	    
sl@0
  1142
    - TAny* a1 : A TBool into which the HAL handler puts ETrue (if accessory 
sl@0
  1143
    power is present), or EFalse (if accessory power is not present).
sl@0
  1144
									
sl@0
  1145
	- TAny* a2 : NULL.
sl@0
  1146
	*/
sl@0
  1147
	EPowerHalAcessoryPowerPresent,
sl@0
  1148
	};
sl@0
  1149
sl@0
  1150
sl@0
  1151
sl@0
  1152
sl@0
  1153
/**
sl@0
  1154
@publishedPartner
sl@0
  1155
@released
sl@0
  1156
sl@0
  1157
The set of function-ids that are  associated with the EHalGroupDisplay
sl@0
  1158
HAL group.
sl@0
  1159
sl@0
  1160
Each enum value represents a specific characteristic of the hardware display,
sl@0
  1161
i.e. the screen or the LCD, and is passed as the second parameter to
sl@0
  1162
the HAL handler function dealing with this group.
sl@0
  1163
 
sl@0
  1164
@see EHalGroupDisplay
sl@0
  1165
*/
sl@0
  1166
enum TDisplayHalFunction
sl@0
  1167
	{
sl@0
  1168
	
sl@0
  1169
	/**
sl@0
  1170
	Gets the screen display properties.
sl@0
  1171
	
sl@0
  1172
	Requirements of the HAL function handler's 2nd, 3rd and 4th parameters:
sl@0
  1173
sl@0
  1174
    - TInt aFunction : This enum value.
sl@0
  1175
	
sl@0
  1176
	- TAny* a1 : This is a pointer to a package buffer (TPckgBuf) containing a
sl@0
  1177
	TScreenInfoV01 structure. The HAL function needs to fill the members of
sl@0
  1178
	this structure with the appropriate information.
sl@0
  1179
	
sl@0
  1180
	- TAny* a2 : NULL.
sl@0
  1181
	
sl@0
  1182
	For example:
sl@0
  1183
	@code
sl@0
  1184
	...
sl@0
  1185
	case EDisplayHalScreenInfo:
sl@0
  1186
	    TPckgBuf<TScreenInfoV01> vPckg;
sl@0
  1187
	    // Fill details
sl@0
  1188
	    Kern::InfoCopy(*(TDes8*)a1,vPckg);
sl@0
  1189
	...
sl@0
  1190
	@endcode
sl@0
  1191
	
sl@0
  1192
	@see TScreenInfoV01
sl@0
  1193
    @see TPckgBuf
sl@0
  1194
	*/
sl@0
  1195
	EDisplayHalScreenInfo,
sl@0
  1196
	
sl@0
  1197
	
sl@0
  1198
	/**
sl@0
  1199
	Registers whether it is the Window Server's responsibility to turn
sl@0
  1200
	the screen display on or off.
sl@0
  1201
	
sl@0
  1202
	Requirements of the HAL function handler's 2nd, 3rd and 4th parameters:
sl@0
  1203
	
sl@0
  1204
	- TInt aFunction : This enum value.
sl@0
  1205
	
sl@0
  1206
	- TAny* a1 : This is a TBool value that needs to be set to ETrue or EFalse.
sl@0
  1207
	
sl@0
  1208
	- TAny* a2 : NULL.
sl@0
  1209
	
sl@0
  1210
	For example:
sl@0
  1211
	@code
sl@0
  1212
	...
sl@0
  1213
	case EDisplayHalWsRegisterSwitchOnScreenHandling:
sl@0
  1214
	    iWsSwitchOnScreen=(TBool)a1;
sl@0
  1215
	...
sl@0
  1216
	@endcode
sl@0
  1217
	
sl@0
  1218
	@see TBool
sl@0
  1219
	*/
sl@0
  1220
	EDisplayHalWsRegisterSwitchOnScreenHandling,
sl@0
  1221
	
sl@0
  1222
	
sl@0
  1223
	/**
sl@0
  1224
	Requests that the Window Server turn the screen display on.
sl@0
  1225
	
sl@0
  1226
	Requirements of the HAL function handler's 2nd, 3rd and 4th parameters:
sl@0
  1227
	
sl@0
  1228
	- TInt aFunction : This enum value.
sl@0
  1229
	
sl@0
  1230
	- TAny* a1 : NULL
sl@0
  1231
		
sl@0
  1232
	- TAny* a2 : NULL
sl@0
  1233
	*/
sl@0
  1234
	EDisplayHalWsSwitchOnScreen,
sl@0
  1235
	
sl@0
  1236
	
sl@0
  1237
	/**
sl@0
  1238
	Gets the maximum screen display contrast value.
sl@0
  1239
	
sl@0
  1240
	Requirements of the HAL function handler's 2nd, 3rd and 4th parameters:
sl@0
  1241
	
sl@0
  1242
	- TInt aFunction : This enum value.
sl@0
  1243
	
sl@0
  1244
	- TAny* a1 : A TInt value into which the HAL handler puts the maximum
sl@0
  1245
	display contrast value.
sl@0
  1246
		
sl@0
  1247
	- TAny* a2 : NULL
sl@0
  1248
	*/
sl@0
  1249
	EDisplayHalMaxDisplayContrast,
sl@0
  1250
sl@0
  1251
sl@0
  1252
	/**
sl@0
  1253
	Sets the screen display contrast value.
sl@0
  1254
	
sl@0
  1255
	Requirements of the HAL function handler's 2nd, 3rd and 4th parameters:
sl@0
  1256
	
sl@0
  1257
	- TInt aFunction : This enum value.
sl@0
  1258
	
sl@0
  1259
	- TAny* a1 : A TInt value containing the display contrast value.
sl@0
  1260
	Typically, this needs to lie within a range that is valid for the device.
sl@0
  1261
			
sl@0
  1262
	- TAny* a2 : NULL
sl@0
  1263
	
sl@0
  1264
	@capability WriteDeviceData 
sl@0
  1265
	*/
sl@0
  1266
	EDisplayHalSetDisplayContrast,
sl@0
  1267
    
sl@0
  1268
    
sl@0
  1269
    /**
sl@0
  1270
    Gets the screen display's current contrast value.
sl@0
  1271
    
sl@0
  1272
    Requirements of the HAL function handler's 2nd, 3rd and 4th parameters:
sl@0
  1273
	
sl@0
  1274
	- TInt aFunction : This enum value.
sl@0
  1275
	
sl@0
  1276
	- TAny* a1 : A TInt value into which the HAL handler puts the
sl@0
  1277
	display contrast value.
sl@0
  1278
			
sl@0
  1279
	- TAny* a2 : NULL
sl@0
  1280
	*/
sl@0
  1281
	EDisplayHalDisplayContrast,
sl@0
  1282
sl@0
  1283
sl@0
  1284
	/**
sl@0
  1285
	Sets the backlight behaviour.
sl@0
  1286
	
sl@0
  1287
	Requirements of the HAL function handler's 2nd, 3rd and 4th parameters:
sl@0
  1288
	
sl@0
  1289
	- TInt aFunction : This enum value.
sl@0
  1290
	
sl@0
  1291
	- TAny* a1 : Not specified; depends on the manufacturer's implementation.
sl@0
  1292
				
sl@0
  1293
	- TAny* a2 : Not specified; depends on the manufacturer's implementation.
sl@0
  1294
	
sl@0
  1295
	@capability WriteDeviceData
sl@0
  1296
	*/
sl@0
  1297
	EDisplayHalSetBacklightBehavior,
sl@0
  1298
sl@0
  1299
sl@0
  1300
	/**
sl@0
  1301
	Gets information about the backlight behaviour.
sl@0
  1302
	
sl@0
  1303
	Requirements of the HAL function handler's 2nd, 3rd and 4th parameters:
sl@0
  1304
	
sl@0
  1305
	- TInt aFunction : This enum value.
sl@0
  1306
	
sl@0
  1307
	- TAny* a1 : Not specified; depends on the manufacturer's implementation.
sl@0
  1308
				
sl@0
  1309
	- TAny* a2 : Not specified; depends on the manufacturer's implementation.
sl@0
  1310
	*/
sl@0
  1311
	EDisplayHalBacklightBehavior,
sl@0
  1312
sl@0
  1313
sl@0
  1314
	/**
sl@0
  1315
	Sets the backlight timeout value, i.e. the length of time that the backlight
sl@0
  1316
	will stay on.
sl@0
  1317
	
sl@0
  1318
	Requirements of the HAL function handler's 2nd, 3rd and 4th parameters:
sl@0
  1319
	
sl@0
  1320
	- TInt aFunction : This enum value.
sl@0
  1321
	
sl@0
  1322
	- TAny* a1 : Not specified; depends on the manufacturer's implementation.
sl@0
  1323
				
sl@0
  1324
	- TAny* a2 : Not specified; depends on the manufacturer's implementation.
sl@0
  1325
	
sl@0
  1326
	@capability WriteDeviceData
sl@0
  1327
	*/
sl@0
  1328
	EDisplayHalSetBacklightOnTime,
sl@0
  1329
sl@0
  1330
sl@0
  1331
    /**
sl@0
  1332
    Gets information about the backlight timeout value, i.e. the length
sl@0
  1333
    of time that the backlight will stay on.
sl@0
  1334
    
sl@0
  1335
    Requirements of the HAL function handler's 2nd, 3rd and 4th parameters:
sl@0
  1336
	
sl@0
  1337
	- TInt aFunction : This enum value.
sl@0
  1338
	
sl@0
  1339
	- TAny* a1 : Not specified; depends on the manufacturer's implementation.
sl@0
  1340
				
sl@0
  1341
	- TAny* a2 : Not specified; depends on the manufacturer's implementation.
sl@0
  1342
    */
sl@0
  1343
	EDisplayHalBacklightOnTime,
sl@0
  1344
sl@0
  1345
sl@0
  1346
	/**
sl@0
  1347
	Sets the backlight on or off.
sl@0
  1348
	
sl@0
  1349
	Requirements of the HAL function handler's 2nd, 3rd and 4th parameters:
sl@0
  1350
	
sl@0
  1351
	- TInt aFunction : This enum value.
sl@0
  1352
	
sl@0
  1353
    - TAny* a1 : A TBool that needs to be set to ETrue or EFalse.
sl@0
  1354
			
sl@0
  1355
	- TAny* a2 : NULL
sl@0
  1356
	
sl@0
  1357
	@capability WriteDeviceData
sl@0
  1358
	*/
sl@0
  1359
	EDisplayHalSetBacklightOn,
sl@0
  1360
sl@0
  1361
sl@0
  1362
	/**
sl@0
  1363
	Gets the current state of the backlight.
sl@0
  1364
	
sl@0
  1365
	Requirements of the HAL function handler's 2nd, 3rd and 4th parameters:
sl@0
  1366
	
sl@0
  1367
	- TInt aFunction : This enum value.
sl@0
  1368
	
sl@0
  1369
    - TAny* a1 : A TBool into which the HAL handler
sl@0
  1370
    puts ETrue (for On) or EFalse (for Off).
sl@0
  1371
				
sl@0
  1372
	- TAny* a2 : NULL
sl@0
  1373
	*/
sl@0
  1374
	EDisplayHalBacklightOn,
sl@0
  1375
	
sl@0
  1376
	
sl@0
  1377
	/**
sl@0
  1378
	Gets the screen display's maximum brightness value.
sl@0
  1379
	
sl@0
  1380
	Requirements of the HAL function handler's 2nd, 3rd and 4th parameters:
sl@0
  1381
	
sl@0
  1382
	- TInt aFunction : This enum value.
sl@0
  1383
	
sl@0
  1384
	- TAny* a1 : A TInt value into which the HAL handler puts the
sl@0
  1385
	maximum brightness value.
sl@0
  1386
			
sl@0
  1387
	- TAny* a2 : NULL
sl@0
  1388
	*/
sl@0
  1389
	EDisplayHalMaxDisplayBrightness,
sl@0
  1390
sl@0
  1391
sl@0
  1392
	/**
sl@0
  1393
	Sets the screen display's brightness value.
sl@0
  1394
	
sl@0
  1395
	Requirements of the HAL function handler's 2nd, 3rd and 4th parameters:
sl@0
  1396
	
sl@0
  1397
	- TInt aFunction : This enum value.
sl@0
  1398
	
sl@0
  1399
	- TAny* a1 : A TInt value containing the brightness value.
sl@0
  1400
	Typically, this needs to lie within a range that is valid for the device.
sl@0
  1401
			
sl@0
  1402
	- TAny* a2 : NULL
sl@0
  1403
	
sl@0
  1404
	@capability WriteDeviceData
sl@0
  1405
	*/
sl@0
  1406
	EDisplayHalSetDisplayBrightness,
sl@0
  1407
sl@0
  1408
sl@0
  1409
    /**
sl@0
  1410
    Gets the screen display's current brightness value.
sl@0
  1411
	
sl@0
  1412
	Requirements of the HAL function handler's 2nd, 3rd and 4th parameters:
sl@0
  1413
	
sl@0
  1414
	- TInt aFunction : This enum value.
sl@0
  1415
	
sl@0
  1416
	- TAny* a1 : A TInt value into which the HAL handler puts the
sl@0
  1417
	brightness value.
sl@0
  1418
			
sl@0
  1419
	- TAny* a2 : NULL
sl@0
  1420
    */
sl@0
  1421
	EDisplayHalDisplayBrightness,
sl@0
  1422
//
sl@0
  1423
sl@0
  1424
    /**
sl@0
  1425
    Gets the number of available display modes.
sl@0
  1426
    
sl@0
  1427
    Requirements of the HAL function handler's 2nd, 3rd and 4th parameters:
sl@0
  1428
	
sl@0
  1429
	- TInt aFunction : This enum value.
sl@0
  1430
	
sl@0
  1431
	- TAny* a1 : A TInt value into which the HAL handler puts the
sl@0
  1432
	number of display modes value.
sl@0
  1433
			
sl@0
  1434
	- TAny* a2 : NULL
sl@0
  1435
    */
sl@0
  1436
	EDisplayHalModeCount,
sl@0
  1437
sl@0
  1438
sl@0
  1439
	/**
sl@0
  1440
	Sets the display mode.
sl@0
  1441
	
sl@0
  1442
	This will normally update the information maintained by the screen driver
sl@0
  1443
	in the form of a TScreenInfoV01 struct.
sl@0
  1444
		
sl@0
  1445
	Requirements of the HAL function handler's 2nd, 3rd and 4th parameters:
sl@0
  1446
	
sl@0
  1447
	- TInt aFunction : This enum value.
sl@0
  1448
	
sl@0
  1449
	- TAny* a1 : A TInt value containing a number representing the display mode.
sl@0
  1450
	Typically, this needs to lie within a range that is valid for the device.
sl@0
  1451
	For example, the value usually needs to be positive, and be less than
sl@0
  1452
	the number of display modes.
sl@0
  1453
			
sl@0
  1454
	- TAny* a2 : NULL
sl@0
  1455
	
sl@0
  1456
	@capability MultimediaDD
sl@0
  1457
	
sl@0
  1458
	@see TScreenInfoV01
sl@0
  1459
	*/
sl@0
  1460
	EDisplayHalSetMode,
sl@0
  1461
sl@0
  1462
sl@0
  1463
    /**
sl@0
  1464
    Gets the current screen display mode.
sl@0
  1465
    
sl@0
  1466
    Requirements of the HAL function handler's 2nd, 3rd and 4th parameters:
sl@0
  1467
    
sl@0
  1468
    - TInt aFunction : This enum value.
sl@0
  1469
	
sl@0
  1470
	- TAny* a1 : A TInt value into which the HAL handler puts the 
sl@0
  1471
	the current display mode value.
sl@0
  1472
			
sl@0
  1473
	- TAny* a2 : NULL
sl@0
  1474
    */
sl@0
  1475
	EDisplayHalMode,
sl@0
  1476
sl@0
  1477
sl@0
  1478
	/**
sl@0
  1479
	Sets a colour value for the specified palette entry. 
sl@0
  1480
	
sl@0
  1481
	Requirements of the HAL function handler's 2nd, 3rd and 4th parameters:
sl@0
  1482
    
sl@0
  1483
    - TInt aFunction : This enum value.
sl@0
  1484
	
sl@0
  1485
	- TAny* a1 : A TInt value that identifies the palette entry. The value
sl@0
  1486
	occupies the junior 8 bits of the integer. The senior 24 bits are all 0.
sl@0
  1487
					
sl@0
  1488
	- TAny* a2 : A TInt value containing the colour value; it represents
sl@0
  1489
	a standard Symbian OS RGB colour value, and occupies the junior 24 bits
sl@0
  1490
	of the integer. The senior 8 bits are not defined.
sl@0
  1491
	
sl@0
  1492
	@capability MultimediaDD
sl@0
  1493
	*/
sl@0
  1494
	EDisplayHalSetPaletteEntry,
sl@0
  1495
    
sl@0
  1496
    
sl@0
  1497
    /**
sl@0
  1498
    Gets the colour value for the specified palette entry.
sl@0
  1499
    
sl@0
  1500
    Requirements of the HAL function handler's 2nd, 3rd and 4th parameters:
sl@0
  1501
    
sl@0
  1502
    - TInt aFunction : This enum value.
sl@0
  1503
	
sl@0
  1504
	- TAny* a1 : A TInt value that identifies the palette entry. The value
sl@0
  1505
	is expected to occupy the junior 8 bits of the integer. The senior 24 bits
sl@0
  1506
	are not defined.
sl@0
  1507
					
sl@0
  1508
	- TAny* a2 : On return from the HAL function, a TInt value containing
sl@0
  1509
    the colour value. The value occupies the junior 24 bits of the integer.
sl@0
  1510
    The senior 8 bits are not defined.
sl@0
  1511
    */
sl@0
  1512
	EDisplayHalPaletteEntry,
sl@0
  1513
sl@0
  1514
sl@0
  1515
	/**
sl@0
  1516
	Sets the screen display on or off.
sl@0
  1517
sl@0
  1518
    Requirements of the HAL function handler's 2nd, 3rd and 4th parameters:
sl@0
  1519
    
sl@0
  1520
    - TInt aFunction : This enum value.
sl@0
  1521
	
sl@0
  1522
	- TAny* a1 : A TBool that needs to be set to ETrue (for On),
sl@0
  1523
	or EFalse (for Off).
sl@0
  1524
					
sl@0
  1525
	- TAny* a2 : NULL.
sl@0
  1526
	
sl@0
  1527
	@capability PowerMgmt
sl@0
  1528
	*/
sl@0
  1529
	EDisplayHalSetState,
sl@0
  1530
sl@0
  1531
sl@0
  1532
    /**
sl@0
  1533
    Gets the state of the screen display, i.e. whether the display is on or off.
sl@0
  1534
    
sl@0
  1535
    Requirements of the HAL function handler's 2nd, 3rd and 4th parameters:
sl@0
  1536
    
sl@0
  1537
    - TInt aFunction : This enum value.
sl@0
  1538
	
sl@0
  1539
    - TAny* a1 : A TBool into which the HAL handler puts ETrue (for On),
sl@0
  1540
    or EFalse (for Off).
sl@0
  1541
									
sl@0
  1542
	- TAny* a2 : NULL.
sl@0
  1543
    */
sl@0
  1544
	EDisplayHalState,
sl@0
  1545
	
sl@0
  1546
	
sl@0
  1547
	/**
sl@0
  1548
	Gets the maximum number of colours that the screen display supports.
sl@0
  1549
	
sl@0
  1550
	Requirements of the HAL function handler's 2nd, 3rd and 4th parameters:
sl@0
  1551
	
sl@0
  1552
	- TInt aFunction : This enum value.
sl@0
  1553
	
sl@0
  1554
	- TAny* a1 : A TInt value into which the HAL handler puts the maximum
sl@0
  1555
	number of colours.
sl@0
  1556
		
sl@0
  1557
	- TAny* a2 : NULL
sl@0
  1558
	*/
sl@0
  1559
	EDisplayHalColors,
sl@0
  1560
	
sl@0
  1561
	
sl@0
  1562
	/**
sl@0
  1563
	Gets information about the current display mode.
sl@0
  1564
	
sl@0
  1565
	Requirements of the HAL function handler's 2nd, 3rd and 4th parameters:
sl@0
  1566
	
sl@0
  1567
	- TInt aFunction : This enum value.
sl@0
  1568
	
sl@0
  1569
	- TAny* a1 : This is a pointer to a package buffer (TPckgBuf) containing a
sl@0
  1570
	TVideoInfoV01 structure. The HAL function needs to fill the members of
sl@0
  1571
	this structure with the appropriate information.
sl@0
  1572
	
sl@0
  1573
    - TAny* a2 : NULL.
sl@0
  1574
		
sl@0
  1575
	@see TVideoInfoV01
sl@0
  1576
    @see TPckgBuf
sl@0
  1577
	*/
sl@0
  1578
	EDisplayHalCurrentModeInfo,
sl@0
  1579
	
sl@0
  1580
	
sl@0
  1581
	/**
sl@0
  1582
	Gets information about the specified display mode.
sl@0
  1583
	
sl@0
  1584
	Requirements of the HAL function handler's 2nd, 3rd and 4th parameters:
sl@0
  1585
	
sl@0
  1586
	- TInt aFunction : This enum value.
sl@0
  1587
	
sl@0
  1588
	- TAny* a1 : A TInt value containing the number of the display mode for which
sl@0
  1589
	information is to be fetched.
sl@0
  1590
	
sl@0
  1591
	- TAny* a2 : This is a pointer to a package buffer (TPckgBuf) containing a
sl@0
  1592
	TVideoInfoV01 structure. The HAL function needs to fill the members of
sl@0
  1593
	this structure with the appropriate information.
sl@0
  1594
			
sl@0
  1595
	@see TVideoInfoV01
sl@0
  1596
    @see TPckgBuf
sl@0
  1597
	*/
sl@0
  1598
	EDisplayHalSpecifiedModeInfo,
sl@0
  1599
sl@0
  1600
//	EDisplaySwitchOffScreen,
sl@0
  1601
sl@0
  1602
sl@0
  1603
    /**
sl@0
  1604
    Fills/copies an area of the screen display with a rectangle of a specified colour.
sl@0
  1605
    
sl@0
  1606
    Requirements of the HAL function handler's 2nd, 3rd and 4th parameters:
sl@0
  1607
	
sl@0
  1608
	- TInt aFunction : This enum value.
sl@0
  1609
			
sl@0
  1610
	- TAny* a1 : This is a pointer to a package buffer (TPckgBuf) containing a
sl@0
  1611
	SRectOpInfo structure. The structure contains the information that
sl@0
  1612
	is needed for the operation.
sl@0
  1613
    
sl@0
  1614
    - TAny* a1 : NULL.
sl@0
  1615
    
sl@0
  1616
	@see SRectOpInfo
sl@0
  1617
    @see TPckgBuf
sl@0
  1618
    */
sl@0
  1619
	EDisplayHalBlockFill,
sl@0
  1620
	
sl@0
  1621
	
sl@0
  1622
    /**
sl@0
  1623
    Fills/copies an area of the screen display with a rectangle of a specified colour.
sl@0
  1624
    
sl@0
  1625
    Requirements of the HAL function handler's 2nd, 3rd and 4th parameters:
sl@0
  1626
	
sl@0
  1627
	- TInt aFunction : This enum value.
sl@0
  1628
			
sl@0
  1629
	- TAny* a1 : This is a pointer to a package buffer (TPckgBuf) containing a
sl@0
  1630
	SRectOpInfo structure. The structure contains the information that
sl@0
  1631
	is needed for the operation.
sl@0
  1632
    
sl@0
  1633
    - TAny* a1 : NULL.
sl@0
  1634
    
sl@0
  1635
	@see SRectOpInfo
sl@0
  1636
    @see TPckgBuf
sl@0
  1637
    */
sl@0
  1638
	EDisplayHalBlockCopy,
sl@0
  1639
	
sl@0
  1640
	
sl@0
  1641
	/**
sl@0
  1642
	Tests whether the screen display is secure.
sl@0
  1643
	
sl@0
  1644
	Requirements of the HAL function handler's 2nd, 3rd and 4th parameters:
sl@0
  1645
	
sl@0
  1646
	- TInt aFunction : This enum value.
sl@0
  1647
	    
sl@0
  1648
    - TAny* a1 : A TBool into which the HAL handler puts ETrue (for secure mode),
sl@0
  1649
    or EFalse (for non-secure mode).
sl@0
  1650
									
sl@0
  1651
	- TAny* a2 : NULL.
sl@0
  1652
	*/
sl@0
  1653
	EDisplayHalSecure,
sl@0
  1654
sl@0
  1655
sl@0
  1656
	/**
sl@0
  1657
    Sets the screen display into secure or non-secure mode.
sl@0
  1658
    
sl@0
  1659
    Requirements of the HAL function handler's 2nd, 3rd and 4th parameters:
sl@0
  1660
	
sl@0
  1661
	- TInt aFunction : This enum value.
sl@0
  1662
	
sl@0
  1663
	- TAny* a1 : A TBool that needs to be set to ETrue (for secure mode),
sl@0
  1664
	or EFalse (for non-secure mode).
sl@0
  1665
									
sl@0
  1666
	- TAny* a2 : NULL.
sl@0
  1667
	
sl@0
  1668
	@capability MultimediaDD
sl@0
  1669
	*/
sl@0
  1670
	EDisplayHalSetSecure,
sl@0
  1671
sl@0
  1672
	
sl@0
  1673
	/**
sl@0
  1674
	Gets the address of the DSA buffer
sl@0
  1675
	
sl@0
  1676
	Requirements of the HAL function handler's 2nd, 3rd and 4th parameters:
sl@0
  1677
	
sl@0
  1678
	- TInt aFunction : This enum value.
sl@0
  1679
	
sl@0
  1680
	- TAny* a1 : A TInt value into which the HAL handler puts the address
sl@0
  1681
		
sl@0
  1682
	- TAny* a2 : NULL
sl@0
  1683
	*/
sl@0
  1684
	EDisplayHalGetDisplayMemoryAddress,
sl@0
  1685
	/**
sl@0
  1686
	Gets a handle to the DSA buffer memory
sl@0
  1687
	
sl@0
  1688
	Requirements of the HAL function handler's 2nd, 3rd and 4th parameters:
sl@0
  1689
	
sl@0
  1690
	- TInt aFunction : This enum value.
sl@0
  1691
	
sl@0
  1692
	- TAny* a1 : A TInt value into which the HAL handler puts the handle value
sl@0
  1693
		
sl@0
  1694
	- TAny* a2 : NULL
sl@0
  1695
	*/
sl@0
  1696
	EDisplayHalGetDisplayMemoryHandle,
sl@0
  1697
	
sl@0
  1698
	
sl@0
  1699
	/**
sl@0
  1700
    Ask how many resolutions there are on a specific screen
sl@0
  1701
    
sl@0
  1702
    Requirements of the HAL function handler's 2nd, 3rd and 4th parameters:
sl@0
  1703
	
sl@0
  1704
	- TInt aFunction : This enum value.
sl@0
  1705
	
sl@0
  1706
	- TAny* a1 : A TInt reference to pass back the number of resolutions.
sl@0
  1707
									
sl@0
  1708
	- TAny* a2 : NULL.
sl@0
  1709
	
sl@0
  1710
	@capability MultimediaDD
sl@0
  1711
	*/
sl@0
  1712
	EDisplayHalNumberOfResolutions,
sl@0
  1713
	
sl@0
  1714
	
sl@0
  1715
	/**
sl@0
  1716
    Gets information on a specific configuration for a particular screen
sl@0
  1717
    
sl@0
  1718
    Requirements of the HAL function handler's 2nd, 3rd and 4th parameters:
sl@0
  1719
	
sl@0
  1720
	- TInt aFunction : This enum value.
sl@0
  1721
	
sl@0
  1722
	- TAny* a1 : A TInt configuration index to get back.
sl@0
  1723
									
sl@0
  1724
	- TAny* a2 : A TVideoInfoV01 descriptor to get the info back.
sl@0
  1725
	
sl@0
  1726
	@capability MultimediaDD
sl@0
  1727
	*/
sl@0
  1728
	EDisplayHalSpecificScreenInfo,
sl@0
  1729
	
sl@0
  1730
	
sl@0
  1731
	/**
sl@0
  1732
    Gets info on the current configuration for a particular screen
sl@0
  1733
    
sl@0
  1734
    Requirements of the HAL function handler's 2nd, 3rd and 4th parameters:
sl@0
  1735
	
sl@0
  1736
	- TInt aFunction : This enum value.
sl@0
  1737
	
sl@0
  1738
	- TAny* a1 : A TVideoInfoV01 descriptor to get the info back.
sl@0
  1739
									
sl@0
  1740
	- TAny* a2 : NULL.
sl@0
  1741
	
sl@0
  1742
	@capability MultimediaDD
sl@0
  1743
	*/
sl@0
  1744
	EDisplayHalCurrentScreenInfo,
sl@0
  1745
sl@0
  1746
	
sl@0
  1747
	/**
sl@0
  1748
    Sets the screen display into a predefined state.
sl@0
  1749
    
sl@0
  1750
    Requirements of the HAL function handler's 2nd, 3rd and 4th parameters:
sl@0
  1751
	
sl@0
  1752
	- TInt aFunction : This enum value.
sl@0
  1753
	
sl@0
  1754
	- TAny* a1 : A TInt that is one of the value of TDisplayState enum
sl@0
  1755
											
sl@0
  1756
	- TAny* a2 : NULL.
sl@0
  1757
	
sl@0
  1758
	@capability MultimediaDD
sl@0
  1759
	*/
sl@0
  1760
	EDisplayHalSetDisplayState,
sl@0
  1761
	
sl@0
  1762
	/**
sl@0
  1763
    Gets the spinner of screen display state.
sl@0
  1764
    
sl@0
  1765
    Requirements of the HAL function handler's 2nd, 3rd and 4th parameters:
sl@0
  1766
	
sl@0
  1767
	- TInt aFunction : This enum value.
sl@0
  1768
	
sl@0
  1769
	- TAny* a1 : A TInt which is set to the spinner value on return
sl@0
  1770
											
sl@0
  1771
	- TAny* a2 : NULL.
sl@0
  1772
	
sl@0
  1773
	@capability MultimediaDD
sl@0
  1774
	*/
sl@0
  1775
	EDisplayHalGetStateSpinner,
sl@0
  1776
	};
sl@0
  1777
sl@0
  1778
/**
sl@0
  1779
@internalComponent
sl@0
  1780
@test
sl@0
  1781
The set of display state ids that are associated with EDisplayHalSetDisplayState
sl@0
  1782
sl@0
  1783
@see EDisplayHalSetDisplayState
sl@0
  1784
*/
sl@0
  1785
sl@0
  1786
enum TDisplayConnectState
sl@0
  1787
	{
sl@0
  1788
	ENormalResolution,
sl@0
  1789
	ENoResolution,
sl@0
  1790
	EDisconnect,
sl@0
  1791
	ESingleResolution,
sl@0
  1792
	EDisplayStateTooHigh
sl@0
  1793
	};
sl@0
  1794
sl@0
  1795
/**
sl@0
  1796
@publishedPartner
sl@0
  1797
@released
sl@0
  1798
sl@0
  1799
The set of function-ids that are  associated with the EHalGroupDigitiser
sl@0
  1800
HAL group.
sl@0
  1801
sl@0
  1802
Each enum value represents a specific characteristic of the digitiser,
sl@0
  1803
and is passed as the second parameter to the HAL handler function
sl@0
  1804
dealing with this group.
sl@0
  1805
sl@0
  1806
@see EHalGroupDigitiser
sl@0
  1807
*/
sl@0
  1808
enum TDigitiserHalFunction
sl@0
  1809
	{
sl@0
  1810
	
sl@0
  1811
	/**
sl@0
  1812
	Sets the calibration data (i.e. the values of the digitiser to
sl@0
  1813
	screen constants) for the digitiser device.
sl@0
  1814
	
sl@0
  1815
	Requirements of the HAL function handler's 2nd, 3rd and 4th parameters:
sl@0
  1816
	
sl@0
  1817
	- TInt aFunction : This enum value.
sl@0
  1818
	
sl@0
  1819
    - TAny* a1 : A pointer to a TDigitizerCalibration object.
sl@0
  1820
				
sl@0
  1821
	- TAny* a2 : NULL	
sl@0
  1822
	
sl@0
  1823
	@see TDigitizerCalibration
sl@0
  1824
	
sl@0
  1825
	@capability WriteDeviceData
sl@0
  1826
	*/
sl@0
  1827
	EDigitiserHalSetXYInputCalibration,
sl@0
  1828
sl@0
  1829
sl@0
  1830
    /**
sl@0
  1831
    Gets the calibration data (i.e. the values of the digitiser to
sl@0
  1832
	screen constants) for the digitiser device.
sl@0
  1833
	
sl@0
  1834
	Requirements of the HAL function handler's 2nd, 3rd and 4th parameters:
sl@0
  1835
	
sl@0
  1836
	- TInt aFunction : This enum value.
sl@0
  1837
	
sl@0
  1838
    - TAny* a1 : A pointer to a TDigitizerCalibration object; the HAL function
sl@0
  1839
    needs to fill the members of this structure with
sl@0
  1840
    the appropriate information.
sl@0
  1841
				
sl@0
  1842
	- TAny* a2 : NULL	
sl@0
  1843
	
sl@0
  1844
	@see TDigitizerCalibration
sl@0
  1845
    */
sl@0
  1846
	EDigitiserHalCalibrationPoints,
sl@0
  1847
sl@0
  1848
sl@0
  1849
    /**
sl@0
  1850
    Saves the calibration data (i.e. the values of the digitiser to
sl@0
  1851
	screen constants) for the digitiser device in a persistent memory area so
sl@0
  1852
	that they can be restored after a power cycle.
sl@0
  1853
	
sl@0
  1854
	Requirements of the HAL function handler's 2nd, 3rd and 4th parameters:
sl@0
  1855
	
sl@0
  1856
	- TInt aFunction : This enum value.
sl@0
  1857
	
sl@0
  1858
    - TAny* a1 : NULL.
sl@0
  1859
				
sl@0
  1860
	- TAny* a2 : NULL	
sl@0
  1861
    */
sl@0
  1862
	EDigitiserHalSaveXYInputCalibration,
sl@0
  1863
sl@0
  1864
sl@0
  1865
	/**
sl@0
  1866
	Restores the calibration data (i.e. the values of the digitiser to
sl@0
  1867
	screen constants) for the digitiser device from a persistent memory area so
sl@0
  1868
	that they can be restored after a power cycle.
sl@0
  1869
sl@0
  1870
    Requirements of the HAL function handler's 2nd, 3rd and 4th parameters:
sl@0
  1871
	
sl@0
  1872
	- TInt aFunction : This enum value.
sl@0
  1873
	
sl@0
  1874
    - TAny* a1 : NULL.
sl@0
  1875
				
sl@0
  1876
	- TAny* a2 : NULL	
sl@0
  1877
	
sl@0
  1878
	@capability WriteDeviceData
sl@0
  1879
	*/
sl@0
  1880
	EDigitiserHalRestoreXYInputCalibration,
sl@0
  1881
sl@0
  1882
sl@0
  1883
    /**
sl@0
  1884
    Gets digitiser information as defined by the content of
sl@0
  1885
    a TDigitiserInfoV01 (or TDigitiserInfoV02) struct.
sl@0
  1886
    
sl@0
  1887
    Requirements of the HAL function handler's 2nd, 3rd and 4th parameters:
sl@0
  1888
	
sl@0
  1889
	- TInt aFunction : This enum value.
sl@0
  1890
	
sl@0
  1891
   	- TAny* a1 : This is a pointer to a package buffer (TPckgBuf) containing a
sl@0
  1892
	TDigitiserInfoV01 (or TDigitiserInfoV02) structure. The HAL function needs 
sl@0
  1893
	to fill the members of this structure with the appropriate information.
sl@0
  1894
				
sl@0
  1895
	- TAny* a2 : NULL	
sl@0
  1896
    
sl@0
  1897
    @see TPckgBuf
sl@0
  1898
    @see TDigitiserInfoV01
sl@0
  1899
    */
sl@0
  1900
	EDigitiserHalXYInfo,
sl@0
  1901
sl@0
  1902
sl@0
  1903
    /**
sl@0
  1904
    Tests whether the digitiser is on or off.
sl@0
  1905
    
sl@0
  1906
    Requirements of the HAL function handler's 2nd, 3rd and 4th parameters:
sl@0
  1907
	
sl@0
  1908
	- TInt aFunction : This enum value.
sl@0
  1909
	
sl@0
  1910
   	- TAny* a1 : A TBool value that needs to be set to ETrue (On), or EFalse (Off).
sl@0
  1911
	
sl@0
  1912
	- TAny* a2 : NULL	
sl@0
  1913
    */
sl@0
  1914
	EDigitiserHalXYState,
sl@0
  1915
sl@0
  1916
sl@0
  1917
	/**
sl@0
  1918
	Sets the digitiser either on or off.
sl@0
  1919
	
sl@0
  1920
	Requirements of the HAL function handler's 2nd, 3rd and 4th parameters:
sl@0
  1921
	
sl@0
  1922
	- TInt aFunction : This enum value.
sl@0
  1923
	
sl@0
  1924
	- TAny* a1 : A TBool that needs to be set to ETrue (On), or EFalse (Off).
sl@0
  1925
	
sl@0
  1926
	- TAny* a2 : NULL	
sl@0
  1927
	
sl@0
  1928
	@capability PowerMgmt
sl@0
  1929
	*/
sl@0
  1930
	EDigitiserHalSetXYState,
sl@0
  1931
sl@0
  1932
    /**
sl@0
  1933
	Checks whether the pointing device supports 3rd dimension.
sl@0
  1934
    
sl@0
  1935
    Requirements of the HAL function handler's 2nd, 3rd and 4th parameters:
sl@0
  1936
	
sl@0
  1937
	- TInt aFunction : This enum value.
sl@0
  1938
	
sl@0
  1939
   	- TAny* a1 : A TBool value that needs to be set to ETrue (3D supported), or EFalse (3D not supported).
sl@0
  1940
	
sl@0
  1941
	- TAny* a2 : NULL	
sl@0
  1942
    */
sl@0
  1943
	EDigitiserHal3DPointer,
sl@0
  1944
sl@0
  1945
    /**	
sl@0
  1946
    Sets the detection range above the screen.
sl@0
  1947
    
sl@0
  1948
    Requirements of the HAL function handler's 2nd, 3rd and 4th parameters:
sl@0
  1949
	
sl@0
  1950
	- TInt aFunction : This enum value.
sl@0
  1951
	
sl@0
  1952
   	- TAny* a1 : A TInt value that is the detection range in units of distance above the screen.
sl@0
  1953
	
sl@0
  1954
	- TAny* a2 : NULL	
sl@0
  1955
    */
sl@0
  1956
	EDigitiserHalSetZRange,
sl@0
  1957
    
sl@0
  1958
	/**
sl@0
  1959
	@prototype
sl@0
  1960
	
sl@0
  1961
    Sets the  number of pointers it supports on the digitiser.
sl@0
  1962
    
sl@0
  1963
    Requirements of the HAL function handler's 2nd, 3rd and 4th parameters:
sl@0
  1964
	
sl@0
  1965
	- TInt aFunction : This enum value.
sl@0
  1966
	
sl@0
  1967
   	- TAny* a1 : A TInt value that 	sets the number of pointer to be supported by the digitiser driver
sl@0
  1968
	
sl@0
  1969
	- TAny* a2 : NULL	
sl@0
  1970
    */
sl@0
  1971
	EDigitiserHalSetNumberOfPointers,
sl@0
  1972
	
sl@0
  1973
	/**
sl@0
  1974
	@prototype
sl@0
  1975
sl@0
  1976
    Gets digitiser information as defined by the content of
sl@0
  1977
    a  TDigitiserInfoV02 struct.
sl@0
  1978
    
sl@0
  1979
    Requirements of the HAL function handler's 2nd, 3rd and 4th parameters:
sl@0
  1980
	
sl@0
  1981
	- TInt aFunction : This enum value.
sl@0
  1982
	
sl@0
  1983
   	- TAny* a1 : This is a pointer to a package buffer (TPckgBuf) containing a
sl@0
  1984
	 TDigitiserInfoV02 structure. The HAL function needs 
sl@0
  1985
	to fill the members of this structure with the appropriate information.
sl@0
  1986
				
sl@0
  1987
	- TAny* a2 : NULL	
sl@0
  1988
    
sl@0
  1989
    @see TPckgBuf
sl@0
  1990
    @see TDigitiserInfoV02
sl@0
  1991
    */
sl@0
  1992
	EDigitiserHal3DInfo
sl@0
  1993
sl@0
  1994
	};
sl@0
  1995
sl@0
  1996
sl@0
  1997
sl@0
  1998
sl@0
  1999
/**
sl@0
  2000
@publishedPartner
sl@0
  2001
@released
sl@0
  2002
sl@0
  2003
The set of function-ids that are  associated with the EHalGroupSound
sl@0
  2004
HAL group.
sl@0
  2005
sl@0
  2006
Each enum value represents a specific characteristic of the sound driver,
sl@0
  2007
and is passed as the second parameter to the HAL handler function
sl@0
  2008
dealing with this group.
sl@0
  2009
sl@0
  2010
Note that a sound driver in Symbian OS is only maintained for backwards
sl@0
  2011
compatibility with the Psion Series 5MX devices.
sl@0
  2012
sl@0
  2013
@see EHalGroupSound
sl@0
  2014
*/
sl@0
  2015
enum TSoundHalFunction
sl@0
  2016
	{
sl@0
  2017
	/**
sl@0
  2018
	Gets sound driver information.
sl@0
  2019
	
sl@0
  2020
	Requirements of the HAL function handler's 2nd, 3rd and 4th parameters:
sl@0
  2021
	
sl@0
  2022
	- TInt aFunction : This enum value.
sl@0
  2023
	    
sl@0
  2024
	- TAny* a1 : This is a pointer to a package buffer (TPckgBuf) containing a
sl@0
  2025
    TSoundInfoV1 structure. The HAL function needs to fill the members of
sl@0
  2026
	this structure with the appropriate information.
sl@0
  2027
									
sl@0
  2028
	- TAny* a2 : NULL.
sl@0
  2029
	
sl@0
  2030
	@see TSoundInfoV1
sl@0
  2031
    @see TPckgBuf
sl@0
  2032
	*/
sl@0
  2033
	ESoundHalSoundInfo,
sl@0
  2034
sl@0
  2035
sl@0
  2036
	/**
sl@0
  2037
	Sets whether a click is to be sounded on a key press.
sl@0
  2038
	
sl@0
  2039
	Requirements of the HAL function handler's 2nd, 3rd and 4th parameters:
sl@0
  2040
	
sl@0
  2041
	- TInt aFunction : This enum value.
sl@0
  2042
	    
sl@0
  2043
	- TAny* a1 : A TBool that needs to be set to ETrue (click is to be sounded),
sl@0
  2044
	or EFalse (click is not to be sounded).
sl@0
  2045
									
sl@0
  2046
	- TAny* a2 : NULL.
sl@0
  2047
	
sl@0
  2048
	@capability WriteDeviceData
sl@0
  2049
	*/
sl@0
  2050
	ESoundHalSetKeyClickEnabled,
sl@0
  2051
sl@0
  2052
sl@0
  2053
	/**
sl@0
  2054
	Sets whether a click that is to be sounded on a key press, is loud or not.
sl@0
  2055
sl@0
  2056
	Requirements of the HAL function handler's 2nd, 3rd and 4th parameters:
sl@0
  2057
	
sl@0
  2058
	- TInt aFunction : This enum value.
sl@0
  2059
	    
sl@0
  2060
	- TAny* a1 : A TBool that needs to be set to ETrue (click is to be loud),
sl@0
  2061
	or EFalse (click is not to be loud).
sl@0
  2062
									
sl@0
  2063
	- TAny* a2 : NULL.
sl@0
  2064
	
sl@0
  2065
	@capability WriteDeviceData
sl@0
  2066
	*/
sl@0
  2067
	ESoundHalSetKeyClickLoud,
sl@0
  2068
sl@0
  2069
sl@0
  2070
	/**
sl@0
  2071
	Sets whether a click is to be sounded when a pointing device touches
sl@0
  2072
	the screen.
sl@0
  2073
sl@0
  2074
	Requirements of the HAL function handler's 2nd, 3rd and 4th parameters:
sl@0
  2075
	
sl@0
  2076
	- TInt aFunction : This enum value.
sl@0
  2077
	    
sl@0
  2078
	- TAny* a1 : A TBool that needs to be set to ETrue (click is to be sounded),
sl@0
  2079
	or EFalse (click is not to be sounded).
sl@0
  2080
									
sl@0
  2081
	- TAny* a2 : NULL.
sl@0
  2082
	
sl@0
  2083
	@capability WriteDeviceData
sl@0
  2084
	*/
sl@0
  2085
	ESoundHalSetPointerClickEnabled,
sl@0
  2086
sl@0
  2087
sl@0
  2088
	/**
sl@0
  2089
	Sets whether a click that is to be sounded when a pointing device touches
sl@0
  2090
	the screen, is loud or not.
sl@0
  2091
	
sl@0
  2092
	Requirements of the HAL function handler's 2nd, 3rd and 4th parameters:
sl@0
  2093
	
sl@0
  2094
	- TInt aFunction : This enum value.
sl@0
  2095
	    
sl@0
  2096
	- TAny* a1 : A TBool that needs to be set to ETrue (click is to be loud),
sl@0
  2097
	or EFalse (click is not to be loud).
sl@0
  2098
									
sl@0
  2099
	- TAny* a2 : NULL.
sl@0
  2100
	
sl@0
  2101
	@capability WriteDeviceData
sl@0
  2102
	*/
sl@0
  2103
	ESoundHalSetPointerClickLoud,
sl@0
  2104
sl@0
  2105
sl@0
  2106
	/**
sl@0
  2107
	Sets whether the beep sound is enabled.
sl@0
  2108
	
sl@0
  2109
	Requirements of the HAL function handler's 2nd, 3rd and 4th parameters:
sl@0
  2110
	
sl@0
  2111
	- TInt aFunction : This enum value.
sl@0
  2112
	    
sl@0
  2113
	- TAny* a1 : A TBool that needs to be set to ETrue (beep is enabled),
sl@0
  2114
	or EFalse (beep is not enabled).
sl@0
  2115
									
sl@0
  2116
	- TAny* a2 : NULL.
sl@0
  2117
	
sl@0
  2118
	@capability WriteDeviceData
sl@0
  2119
	*/
sl@0
  2120
	ESoundHalSetBeepEnabled,
sl@0
  2121
sl@0
  2122
sl@0
  2123
	/**
sl@0
  2124
	Sets whether the beep sound is to be loud.
sl@0
  2125
	
sl@0
  2126
	Requirements of the HAL function handler's 2nd, 3rd and 4th parameters:
sl@0
  2127
	
sl@0
  2128
	- TInt aFunction : This enum value.
sl@0
  2129
	    
sl@0
  2130
	- TAny* a1 : A TBool that needs to be set to ETrue (beep is loud),
sl@0
  2131
	or EFalse (beep is not loud).
sl@0
  2132
									
sl@0
  2133
	- TAny* a2 : NULL.
sl@0
  2134
	
sl@0
  2135
	@capability WriteDeviceData
sl@0
  2136
	*/
sl@0
  2137
	ESoundHalSetBeepLoud,
sl@0
  2138
sl@0
  2139
sl@0
  2140
	/**
sl@0
  2141
	Sets whether the sound driver is enabled.
sl@0
  2142
	
sl@0
  2143
	Requirements of the HAL function handler's 2nd, 3rd and 4th parameters:
sl@0
  2144
	
sl@0
  2145
	- TInt aFunction : This enum value.
sl@0
  2146
	    
sl@0
  2147
	- TAny* a1 : A TBool that needs to be set to ETrue (driver is enabled),
sl@0
  2148
	or EFalse (driver is not enabled).
sl@0
  2149
									
sl@0
  2150
	- TAny* a2 : NULL.
sl@0
  2151
	
sl@0
  2152
	@capability PowerMgmt
sl@0
  2153
	*/
sl@0
  2154
	ESoundHalSetSoundDriverEnabled,
sl@0
  2155
sl@0
  2156
sl@0
  2157
	/**
sl@0
  2158
	Sets whether the sound driver is to generate loud sounds.
sl@0
  2159
	
sl@0
  2160
	Requirements of the HAL function handler's 2nd, 3rd and 4th parameters:
sl@0
  2161
	
sl@0
  2162
	- TInt aFunction : This enum value.
sl@0
  2163
	    
sl@0
  2164
	- TAny* a1 : A TBool that needs to be set to ETrue (driver is to generate loud sounds),
sl@0
  2165
	or EFalse (driver is not to generate loud sounds).
sl@0
  2166
									
sl@0
  2167
	- TAny* a2 : NULL.
sl@0
  2168
	
sl@0
  2169
	@capability WriteDeviceData
sl@0
  2170
	*/
sl@0
  2171
	ESoundHalSetSoundDriverLoud,
sl@0
  2172
sl@0
  2173
sl@0
  2174
	/**
sl@0
  2175
	Sets whether sound generation is enabled.
sl@0
  2176
	
sl@0
  2177
	Requirements of the HAL function handler's 2nd, 3rd and 4th parameters:
sl@0
  2178
	
sl@0
  2179
	- TInt aFunction : This enum value.
sl@0
  2180
	    
sl@0
  2181
	- TAny* a1 : A TBool that needs to be set to ETrue (sound generation is enabled),
sl@0
  2182
	or EFalse (sound generation is not enabled).
sl@0
  2183
									
sl@0
  2184
	- TAny* a2 : NULL.
sl@0
  2185
	
sl@0
  2186
	@capability WriteDeviceData
sl@0
  2187
	*/
sl@0
  2188
	ESoundHalSetSoundEnabled,
sl@0
  2189
sl@0
  2190
sl@0
  2191
	/**
sl@0
  2192
	Sets whether generation of key clicks is to be overridden.
sl@0
  2193
	
sl@0
  2194
	Requirements of the HAL function handler's 2nd, 3rd and 4th parameters:
sl@0
  2195
	
sl@0
  2196
	- TInt aFunction : This enum value.
sl@0
  2197
	    
sl@0
  2198
	- TAny* a1 : A TBool that needs to be set to ETrue (key clicks to be overridden),
sl@0
  2199
	or EFalse (key clicks not to be overridden).
sl@0
  2200
									
sl@0
  2201
	- TAny* a2 : NULL.
sl@0
  2202
		
sl@0
  2203
	@capability WriteDeviceData
sl@0
  2204
	*/
sl@0
  2205
	ESoundHalSetKeyClickOverridden,
sl@0
  2206
sl@0
  2207
sl@0
  2208
    /**
sl@0
  2209
    Tests whether the generation of key clicks is overridden.
sl@0
  2210
    	
sl@0
  2211
	Requirements of the HAL function handler's 2nd, 3rd and 4th parameters:
sl@0
  2212
	
sl@0
  2213
	- TInt aFunction : This enum value.
sl@0
  2214
	    
sl@0
  2215
	- TAny* a1 : A TBool into which the HAL handler puts ETrue (key clicks are overridden),
sl@0
  2216
	or EFalse (key clicks are not overridden).
sl@0
  2217
									
sl@0
  2218
	- TAny* a2 : NULL.
sl@0
  2219
    */
sl@0
  2220
	ESoundHalKeyClickOverridden,
sl@0
  2221
sl@0
  2222
sl@0
  2223
    /**
sl@0
  2224
    Tests whether a click that is to be sounded on a key press, is loud or not.
sl@0
  2225
sl@0
  2226
	Requirements of the HAL function handler's 2nd, 3rd and 4th parameters:
sl@0
  2227
	
sl@0
  2228
	- TInt aFunction : This enum value.
sl@0
  2229
	    
sl@0
  2230
	- TAny* a1 : A TBool into which the HAL handler puts ETrue (click is loud),
sl@0
  2231
	or EFalse (click is not loud).
sl@0
  2232
									
sl@0
  2233
	- TAny* a2 : NULL.
sl@0
  2234
    */
sl@0
  2235
	ESoundHalKeyClickLoud,
sl@0
  2236
sl@0
  2237
sl@0
  2238
    /**
sl@0
  2239
    Tests whether a click is to be sounded on a key press.
sl@0
  2240
	
sl@0
  2241
	Requirements of the HAL function handler's 2nd, 3rd and 4th parameters:
sl@0
  2242
	
sl@0
  2243
	- TInt aFunction : This enum value.
sl@0
  2244
	    
sl@0
  2245
	- TAny* a1 : A TBool into which the HAL handler puts ETrue (click is sounded),
sl@0
  2246
	or EFalse (click is not sounded).
sl@0
  2247
									
sl@0
  2248
	- TAny* a2 : NULL.
sl@0
  2249
    */
sl@0
  2250
	ESoundHalKeyClickEnabled,
sl@0
  2251
sl@0
  2252
sl@0
  2253
    /**
sl@0
  2254
    Tests whether a click that is to be sounded when a pointing device touches
sl@0
  2255
	the screen, is loud or not.
sl@0
  2256
	
sl@0
  2257
	Requirements of the HAL function handler's 2nd, 3rd and 4th parameters:
sl@0
  2258
	
sl@0
  2259
	- TInt aFunction : This enum value.
sl@0
  2260
	    
sl@0
  2261
	- TAny* a1 : A TBool into which the HAL handler puts ETrue (click is loud),
sl@0
  2262
	or EFalse (click is not loud).
sl@0
  2263
									
sl@0
  2264
	- TAny* a2 : NULL.
sl@0
  2265
    */
sl@0
  2266
	ESoundHalPointerClickLoud,
sl@0
  2267
sl@0
  2268
sl@0
  2269
    /**
sl@0
  2270
    Tests whether a click is to be sounded when a pointing device touches
sl@0
  2271
	the screen.
sl@0
  2272
sl@0
  2273
	Requirements of the HAL function handler's 2nd, 3rd and 4th parameters:
sl@0
  2274
	
sl@0
  2275
	- TInt aFunction : This enum value.
sl@0
  2276
	    
sl@0
  2277
	- TAny* a1 : A TBool into which teh HAL handler puts ETrue (click is to be sounded),
sl@0
  2278
	or EFalse (click is not to be sounded).
sl@0
  2279
									
sl@0
  2280
	- TAny* a2 : NULL.
sl@0
  2281
    */
sl@0
  2282
	ESoundHalPointerClickEnabled,
sl@0
  2283
sl@0
  2284
sl@0
  2285
    /**
sl@0
  2286
    Generates a key click sound.
sl@0
  2287
    
sl@0
  2288
    Requirements of the HAL function handler's 2nd, 3rd and 4th parameters:
sl@0
  2289
	
sl@0
  2290
	- TInt aFunction : This enum value.
sl@0
  2291
	    
sl@0
  2292
	- TAny* a1 : NULL.
sl@0
  2293
									
sl@0
  2294
	- TAny* a2 : NULL.
sl@0
  2295
    */
sl@0
  2296
	ESoundHalKeyClick,
sl@0
  2297
sl@0
  2298
sl@0
  2299
    /**
sl@0
  2300
    Generates a pointer click sound.
sl@0
  2301
    
sl@0
  2302
    Requirements of the HAL function handler's 2nd, 3rd and 4th parameters:
sl@0
  2303
	
sl@0
  2304
	- TInt aFunction : This enum value.
sl@0
  2305
	    
sl@0
  2306
	- TAny* a1 : NULL.
sl@0
  2307
									
sl@0
  2308
	- TAny* a2 : NULL.
sl@0
  2309
    */
sl@0
  2310
	ESoundHalPointerClick,
sl@0
  2311
sl@0
  2312
sl@0
  2313
    /**
sl@0
  2314
    Generates a beep sound.
sl@0
  2315
    
sl@0
  2316
    Requirements of the HAL function handler's 2nd, 3rd and 4th parameters:
sl@0
  2317
	
sl@0
  2318
	- TInt aFunction : This enum value.
sl@0
  2319
	    
sl@0
  2320
	- TAny* a1 : NULL.
sl@0
  2321
									
sl@0
  2322
	- TAny* a2 : NULL.
sl@0
  2323
    */
sl@0
  2324
	ESoundHalBeep,
sl@0
  2325
sl@0
  2326
sl@0
  2327
    /**
sl@0
  2328
    Gets the maximum volume of the key click.
sl@0
  2329
    
sl@0
  2330
    Requirements of the HAL function handler's 2nd, 3rd and 4th parameters:
sl@0
  2331
	
sl@0
  2332
	- TInt aFunction : This enum value.
sl@0
  2333
	    
sl@0
  2334
	- TAny* a1 : A TInt value into which the HAL handler puts the maximum volume value.
sl@0
  2335
									
sl@0
  2336
	- TAny* a2 : NULL.
sl@0
  2337
    */
sl@0
  2338
	ESoundHalKeyClickVolumeMax,
sl@0
  2339
sl@0
  2340
sl@0
  2341
    /**
sl@0
  2342
    Gets the maximum volume of the pointer click.
sl@0
  2343
    
sl@0
  2344
    Requirements of the HAL function handler's 2nd, 3rd and 4th parameters:
sl@0
  2345
	
sl@0
  2346
	- TInt aFunction : This enum value.
sl@0
  2347
	    
sl@0
  2348
	- TAny* a1 : A TInt value into which the HAL handler puts the maximum volume value.
sl@0
  2349
									
sl@0
  2350
	- TAny* a2 : NULL.
sl@0
  2351
    */
sl@0
  2352
	ESoundHalPointerClickVolumeMax,
sl@0
  2353
	};
sl@0
  2354
sl@0
  2355
sl@0
  2356
sl@0
  2357
sl@0
  2358
/**
sl@0
  2359
@publishedPartner
sl@0
  2360
@released
sl@0
  2361
sl@0
  2362
The set of function-ids that are  associated with the EHalGroupMouse
sl@0
  2363
HAL group.
sl@0
  2364
sl@0
  2365
Each enum value represents a specific characteristic of the mouse device,
sl@0
  2366
and is passed as the second parameter to the HAL handler function
sl@0
  2367
dealing with this group.
sl@0
  2368
 
sl@0
  2369
@see EHalGroupMouse
sl@0
  2370
*/
sl@0
  2371
enum TMouseHalFunction
sl@0
  2372
	{
sl@0
  2373
	
sl@0
  2374
	
sl@0
  2375
	/**
sl@0
  2376
	Tests whether a mouse device is visible.
sl@0
  2377
	
sl@0
  2378
	Requirements of the HAL function handler's 2nd, 3rd and 4th parameters:
sl@0
  2379
	
sl@0
  2380
	- TInt aFunction : This enum value.
sl@0
  2381
	
sl@0
  2382
    - TAny* a1 : A TBool into which the HAL handler
sl@0
  2383
    puts ETrue (for visible) or EFalse (for not-visible).
sl@0
  2384
				
sl@0
  2385
	- TAny* a2 : NULL
sl@0
  2386
	*/
sl@0
  2387
	EMouseHalMouseState,
sl@0
  2388
sl@0
  2389
sl@0
  2390
	/**
sl@0
  2391
	Sets the state of the mouse device, i.e. whether it is visible or invisible.
sl@0
  2392
	
sl@0
  2393
	Requirements of the HAL function handler's 2nd, 3rd and 4th parameters:
sl@0
  2394
	
sl@0
  2395
	- TInt aFunction : This enum value.
sl@0
  2396
	
sl@0
  2397
    - TAny* a1 : A TBool that needs to be set to ETrue (for visible)
sl@0
  2398
    or EFalse (for not-visible).
sl@0
  2399
				
sl@0
  2400
	- TAny* a2 : NULL
sl@0
  2401
	
sl@0
  2402
	@capability MultimediaDD
sl@0
  2403
	*/
sl@0
  2404
	EMouseHalSetMouseState,
sl@0
  2405
sl@0
  2406
sl@0
  2407
    /**
sl@0
  2408
    Gets the mouse speed, i.e. how fast the mouse pointer moves.
sl@0
  2409
    
sl@0
  2410
    Requirements of the HAL function handler's 2nd, 3rd and 4th parameters:
sl@0
  2411
	
sl@0
  2412
	- TInt aFunction : This enum value.
sl@0
  2413
	
sl@0
  2414
    - TAny* a1 : A TInt value into which the HAL handler puts the speed value.
sl@0
  2415
    This is expected to be a value in the range 0 to 255.
sl@0
  2416
				
sl@0
  2417
	- TAny* a2 : NULL
sl@0
  2418
    */
sl@0
  2419
	EMouseHalMouseSpeed,
sl@0
  2420
sl@0
  2421
sl@0
  2422
	/**
sl@0
  2423
	Sets the mouse speed, i.e. how fast the mouse pointer moves.
sl@0
  2424
	
sl@0
  2425
	Requirements of the HAL function handler's 2nd, 3rd and 4th parameters:
sl@0
  2426
	
sl@0
  2427
	- TInt aFunction : This enum value.
sl@0
  2428
	
sl@0
  2429
    - TAny* a1 : A TInt value containing the speed value to be set
sl@0
  2430
    This is expected to be a value in the range 0 to 255.
sl@0
  2431
				
sl@0
  2432
	- TAny* a2 : NULL
sl@0
  2433
	
sl@0
  2434
	@capability MultimediaDD
sl@0
  2435
	*/
sl@0
  2436
	EMouseHalSetMouseSpeed,
sl@0
  2437
 
sl@0
  2438
 
sl@0
  2439
    /**
sl@0
  2440
    Gets the mouse acceleration, i.e. how much the mouse pointer accelerates
sl@0
  2441
    as the user moves it faster.
sl@0
  2442
    
sl@0
  2443
    Requirements of the HAL function handler's 2nd, 3rd and 4th parameters:
sl@0
  2444
	
sl@0
  2445
	- TInt aFunction : This enum value.
sl@0
  2446
	
sl@0
  2447
    - TAny* a1 : A TInt value into which the HAL handler puts the acceleration value.
sl@0
  2448
    This is expected to be a value in the range 0 to 255.
sl@0
  2449
				
sl@0
  2450
	- TAny* a2 : NULL
sl@0
  2451
    */
sl@0
  2452
	EMouseHalMouseAcceleration,
sl@0
  2453
sl@0
  2454
sl@0
  2455
	/**
sl@0
  2456
	Sets the mouse acceleration, i.e. how much the mouse pointer accelerates
sl@0
  2457
    as the user moves it faster.
sl@0
  2458
	
sl@0
  2459
	Requirements of the HAL function handler's 2nd, 3rd and 4th parameters:
sl@0
  2460
	
sl@0
  2461
	- TInt aFunction : This enum value.
sl@0
  2462
	
sl@0
  2463
    - TAny* a1 : A TInt value containing the acceleration value to be set
sl@0
  2464
    This is expected to be a value in the range 0 to 255.
sl@0
  2465
				
sl@0
  2466
	- TAny* a2 : NULL
sl@0
  2467
	
sl@0
  2468
	@capability MultimediaDD
sl@0
  2469
	*/
sl@0
  2470
	EMouseHalSetMouseAcceleration,
sl@0
  2471
sl@0
  2472
sl@0
  2473
    /**
sl@0
  2474
    Gets the state of the mouse buttons.
sl@0
  2475
    
sl@0
  2476
    This is not currently supported.
sl@0
  2477
	*/
sl@0
  2478
	EMouseHalMouseButtonState,
sl@0
  2479
	
sl@0
  2480
	
sl@0
  2481
	/**
sl@0
  2482
	Gets information about the mouse display characteristics. 
sl@0
  2483
	
sl@0
  2484
	Requirements of the HAL function handler's 2nd, 3rd and 4th parameters:
sl@0
  2485
	
sl@0
  2486
	- TInt aFunction : This enum value.
sl@0
  2487
	
sl@0
  2488
	- TAny* a1 : This is a pointer to a package buffer (TPckgBuf) containing a
sl@0
  2489
	TMouseInfoV01 structure. The HAL function needs to fill the members of
sl@0
  2490
	this structure with the appropriate information.
sl@0
  2491
	
sl@0
  2492
    - TAny* a2 : NULL.
sl@0
  2493
    
sl@0
  2494
    @see TMouseInfoV01
sl@0
  2495
    @see TPckgBuf
sl@0
  2496
	*/
sl@0
  2497
	EMouseHalMouseInfo,
sl@0
  2498
	};
sl@0
  2499
sl@0
  2500
/**
sl@0
  2501
@internalComponent
sl@0
  2502
*/
sl@0
  2503
enum TEmulatorHalFunction
sl@0
  2504
	{
sl@0
  2505
	EEmulatorHalStringProperty,
sl@0
  2506
	EEmulatorHalIntProperty,
sl@0
  2507
	EEmulatorHalBoolProperty,
sl@0
  2508
	EEmulatorHalMapFilename,
sl@0
  2509
	EEmulatorHalColorDepth,
sl@0
  2510
	EEmulatorHalSetFlip,
sl@0
  2511
	EEmulatorHalCPUSpeed,
sl@0
  2512
	EEmulatorHalNumberOfScreens,
sl@0
  2513
	EEmulatorHalSetDisplayChannel,
sl@0
  2514
	};
sl@0
  2515
sl@0
  2516
/**
sl@0
  2517
@publishedPartner
sl@0
  2518
@released
sl@0
  2519
sl@0
  2520
The set of function-ids that are  associated with the EHalGroupKeyboard
sl@0
  2521
HAL group.
sl@0
  2522
sl@0
  2523
Each enum value represents a specific characteristic of the keyboard,
sl@0
  2524
and is passed as the second parameter to the HAL handler function
sl@0
  2525
dealing with this group.
sl@0
  2526
  
sl@0
  2527
@see EHalGroupKeyboard
sl@0
  2528
*/
sl@0
  2529
enum TKeyboardHalFunction
sl@0
  2530
	{
sl@0
  2531
	
sl@0
  2532
	/**
sl@0
  2533
    Tests whether the keyboard is on or off.
sl@0
  2534
    
sl@0
  2535
    Requirements of the HAL function handler's 2nd, 3rd and 4th parameters:
sl@0
  2536
	
sl@0
  2537
	- TInt aFunction : This enum value.
sl@0
  2538
	
sl@0
  2539
   	- TAny* a1 : A TBool into which the HAL handler puts ETrue (for On),
sl@0
  2540
    or EFalse (for Off).
sl@0
  2541
	
sl@0
  2542
	- TAny* a2 : NULL	
sl@0
  2543
	*/
sl@0
  2544
	EKeyboardHalKeyboardState,
sl@0
  2545
sl@0
  2546
sl@0
  2547
	/**
sl@0
  2548
	Sets the keyboard either on or off.
sl@0
  2549
	
sl@0
  2550
	Requirements of the HAL function handler's 2nd, 3rd and 4th parameters:
sl@0
  2551
	
sl@0
  2552
	- TInt aFunction : This enum value.
sl@0
  2553
	
sl@0
  2554
	- TAny* a1 :A TBool that needs to be set to ETrue (On), or EFalse (Off).
sl@0
  2555
	
sl@0
  2556
	- TAny* a2 : NULL	
sl@0
  2557
	
sl@0
  2558
	@capability PowerMgmt
sl@0
  2559
	*/
sl@0
  2560
	EKeyboardHalSetKeyboardState,
sl@0
  2561
sl@0
  2562
sl@0
  2563
    /**
sl@0
  2564
    Gets information about the keyboard.
sl@0
  2565
    
sl@0
  2566
    Requirements of the HAL function handler's 2nd, 3rd and 4th parameters:
sl@0
  2567
	
sl@0
  2568
	- TInt aFunction : This enum value.
sl@0
  2569
	
sl@0
  2570
	- TAny* a1 : This is a pointer to a package buffer (TPckgBuf) containing a
sl@0
  2571
	TKeyboardInfoV01 structure. The HAL function needs to fill the members of
sl@0
  2572
	this structure with the appropriate information.
sl@0
  2573
	
sl@0
  2574
    - TAny* a2 : NULL.
sl@0
  2575
    
sl@0
  2576
    @see TKeyboardInfoV01
sl@0
  2577
    @see TPckgBuf
sl@0
  2578
    */
sl@0
  2579
	EKeyboardHalKeyboardInfo,
sl@0
  2580
	};
sl@0
  2581
sl@0
  2582
/**
sl@0
  2583
@publishedPartner
sl@0
  2584
@released
sl@0
  2585
sl@0
  2586
The set of function-ids that are  associated with the EHalGroupVM
sl@0
  2587
HAL group.
sl@0
  2588
sl@0
  2589
@see EHalGroupVM
sl@0
  2590
*/
sl@0
  2591
enum TVMHalFunction
sl@0
  2592
	{
sl@0
  2593
	/**
sl@0
  2594
	Evict the contents of the virtual memory cache and reduce it to its minimum size.
sl@0
  2595
sl@0
  2596
	@capability WriteDeviceData
sl@0
  2597
	@test
sl@0
  2598
	*/
sl@0
  2599
	EVMHalFlushCache,
sl@0
  2600
sl@0
  2601
	/**
sl@0
  2602
	Change the minimum and maximum RAM sizes used for the virtual memory cache.
sl@0
  2603
	These values may be silently restricted to platforn specific limits.
sl@0
  2604
	If required, GetCacheSize can be used to verify sizes actually applied to the system.
sl@0
  2605
sl@0
  2606
	If there is not enough memory to set the specified cache size then KErrNoMemory is
sl@0
  2607
	returned, however the cache size may still have been modified in an attempt to 
sl@0
  2608
	service the request.
sl@0
  2609
sl@0
  2610
	This hal function expects two TUint arguments.
sl@0
  2611
	The first argument (a1)	is the minimum size for cache in bytes.
sl@0
  2612
	The second argument (a2) is the maximum size for cache in bytes; using zero for
sl@0
  2613
	this value will restore cache sizes to the initial values used after boot.
sl@0
  2614
sl@0
  2615
	The return value from the function is one of:
sl@0
  2616
			KErrNone, if successful; 
sl@0
  2617
			KErrNoMemory if there is not enough memory;
sl@0
  2618
			KErrArgument if a1>a2;
sl@0
  2619
			otherwise one of the other system wide error codes.
sl@0
  2620
sl@0
  2621
	Example usage:
sl@0
  2622
	@code
sl@0
  2623
	TUint minRam = 128*1024; // 128k
sl@0
  2624
	TUint maxRam = KMaxTUint; // unlimited
sl@0
  2625
	TInt r = UserSvr::HalFunction(EHalGroupVM,EVMHalSetCacheSize,(TAny*)minRam,(TAny*)maxRam));
sl@0
  2626
	if(r!=KErrNone)
sl@0
  2627
		anErrorOccured();
sl@0
  2628
	@endcode
sl@0
  2629
sl@0
  2630
	@capability WriteDeviceData
sl@0
  2631
	@test
sl@0
  2632
	*/
sl@0
  2633
	EVMHalSetCacheSize,
sl@0
  2634
sl@0
  2635
	/**
sl@0
  2636
	Get the sizes for the virtual memory cache.
sl@0
  2637
	The first argument (a1) is a pointer to a #SVMCacheInfo object.
sl@0
  2638
	The second argument (a2) must be zero.
sl@0
  2639
	@test
sl@0
  2640
	*/
sl@0
  2641
	EVMHalGetCacheSize,
sl@0
  2642
sl@0
  2643
	/**
sl@0
  2644
	Get paging event information.
sl@0
  2645
	The first argument (a1) is a pointer to a descriptor whose contents will be filled
sl@0
  2646
	with a #SVMEventInfo object.
sl@0
  2647
	The second argument (a2) must be zero.
sl@0
  2648
	@test
sl@0
  2649
	*/
sl@0
  2650
	EVMHalGetEventInfo,
sl@0
  2651
sl@0
  2652
	/**
sl@0
  2653
	Reset the counters obtained with EVMHalGetEventInfo.
sl@0
  2654
	@test
sl@0
  2655
	*/
sl@0
  2656
	EVMHalResetEventInfo,
sl@0
  2657
sl@0
  2658
	/**
sl@0
  2659
	@internalTechnology
sl@0
  2660
	@test
sl@0
  2661
	*/
sl@0
  2662
	EVMHalGetOriginalRomPages,
sl@0
  2663
sl@0
  2664
	/**
sl@0
  2665
	@internalTechnology
sl@0
  2666
	@test
sl@0
  2667
	*/
sl@0
  2668
	EVMPageState,
sl@0
  2669
sl@0
  2670
	/**
sl@0
  2671
	@internalTechnology
sl@0
  2672
	@test
sl@0
  2673
	*/
sl@0
  2674
	EVMHalGetConcurrencyInfo,
sl@0
  2675
sl@0
  2676
	/**
sl@0
  2677
	@internalTechnology
sl@0
  2678
	@test
sl@0
  2679
	*/
sl@0
  2680
	EVMHalResetConcurrencyInfo,
sl@0
  2681
sl@0
  2682
	/**
sl@0
  2683
	@internalTechnology
sl@0
  2684
	@test
sl@0
  2685
	*/
sl@0
  2686
	EVMHalGetPagingBenchmark,
sl@0
  2687
sl@0
  2688
	/**
sl@0
  2689
	@internalTechnology
sl@0
  2690
	@test
sl@0
  2691
	*/
sl@0
  2692
	EVMHalResetPagingBenchmark,
sl@0
  2693
sl@0
  2694
	/**
sl@0
  2695
	Gets information about the size of the swap partition, and how much is currently used.
sl@0
  2696
	The first argument (a1) should be a pointer to the SVMSwapInfo structure to write.
sl@0
  2697
	@return KErrNone if successful, or KErrNotSupported if data paging is not supported.
sl@0
  2698
	@internalTechnology
sl@0
  2699
	@prototype
sl@0
  2700
	*/
sl@0
  2701
	EVMHalGetSwapInfo,
sl@0
  2702
sl@0
  2703
	/**
sl@0
  2704
	Gets information about the current thrashing level.
sl@0
  2705
sl@0
  2706
	This is a number between 0 and 255 representing how close the system is to thrashing, where 0
sl@0
  2707
	indicates no thrashing and 255 indicates severe thrashing.
sl@0
  2708
sl@0
  2709
	@return The current thrashing level.
sl@0
  2710
	@internalTechnology
sl@0
  2711
	@prototype
sl@0
  2712
	*/
sl@0
  2713
	EVMHalGetThrashLevel,
sl@0
  2714
sl@0
  2715
	/**
sl@0
  2716
	Set the available swap space thresholds at which low memory notifications will be generated.
sl@0
  2717
sl@0
  2718
	Notifications are generated through the RChangeNotifier API, using the enumeration value
sl@0
  2719
	EChangesFreeMemory.
sl@0
  2720
	
sl@0
  2721
	The first argument (a1) should contain a pointer to a SVMSwapThresholds structure. The
sl@0
  2722
	thresholds are specified in bytes.
sl@0
  2723
sl@0
  2724
	@return KErrNone if successful, KErrNotSupported if data paging is not supported or KErrArgument
sl@0
  2725
	if the thresholds are larger than the size of the swap partition, or if the low threshold is
sl@0
  2726
	larger than the good threshold.
sl@0
  2727
	
sl@0
  2728
	@see RChangeNotifier
sl@0
  2729
	@see TChanges
sl@0
  2730
	*/ 
sl@0
  2731
	EVMHalSetSwapThresholds,
sl@0
  2732
	
sl@0
  2733
	/**
sl@0
  2734
	Set the thrash level thresholds at which thrash level notifications will be generated.
sl@0
  2735
sl@0
  2736
	Notifications are generated through the RChangeNotifier API, using the enumeration value
sl@0
  2737
	EChangesThrashLevel.
sl@0
  2738
	
sl@0
  2739
	The first argument (a1) should contain the thrashing threshold, and the seond one (a2) should
sl@0
  2740
	contain the good threshold.
sl@0
  2741
sl@0
  2742
	The thresholds are specified as numbers between 0 and 255 inclusive.
sl@0
  2743
sl@0
  2744
	@return KErrNone if successful, KErrArgument if the thresholds are out of range or if the
sl@0
  2745
	thrashing threshold is smaller than the good threshold.
sl@0
  2746
	
sl@0
  2747
	@see RChangeNotifier
sl@0
  2748
	@see TChanges
sl@0
  2749
	*/ 
sl@0
  2750
	EVMHalSetThrashThresholds,
sl@0
  2751
	};
sl@0
  2752
sl@0
  2753
sl@0
  2754
/**
sl@0
  2755
Paging event information.
sl@0
  2756
@publishedPartner
sl@0
  2757
@test
sl@0
  2758
*/
sl@0
  2759
struct SVMEventInfo
sl@0
  2760
	{
sl@0
  2761
	/**
sl@0
  2762
	The total number of page faults which have occurred.
sl@0
  2763
	*/
sl@0
  2764
	TUint64 iPageFaultCount;
sl@0
  2765
sl@0
  2766
	/**
sl@0
  2767
	The total number of page faults which resulted in reading a page
sl@0
  2768
	from storage media.
sl@0
  2769
	*/
sl@0
  2770
	TUint64 iPageInReadCount;
sl@0
  2771
sl@0
  2772
	// do not add new members to this struct.
sl@0
  2773
	// instead, derive a new SVMEventInfoV2 class from this and add new members to that.
sl@0
  2774
	};
sl@0
  2775
sl@0
  2776
	
sl@0
  2777
/**
sl@0
  2778
VM cache information.
sl@0
  2779
@publishedPartner
sl@0
  2780
@test
sl@0
  2781
*/
sl@0
  2782
struct SVMCacheInfo
sl@0
  2783
	{
sl@0
  2784
	/**
sl@0
  2785
	The minimum size of virtual memory cache, in bytes.
sl@0
  2786
	*/
sl@0
  2787
	TUint32 iMinSize;
sl@0
  2788
sl@0
  2789
	/**
sl@0
  2790
	The maximum size of virtual memory cache, in bytes.
sl@0
  2791
	*/
sl@0
  2792
	TUint32 iMaxSize;
sl@0
  2793
sl@0
  2794
	/**
sl@0
  2795
	The current size of virtual memory cache, in bytes.
sl@0
  2796
	This may be larger than iMaxSize.
sl@0
  2797
	*/
sl@0
  2798
	TUint32 iCurrentSize;
sl@0
  2799
sl@0
  2800
	/**
sl@0
  2801
	The current size of the freeable memory in the virtual memory cache, in bytes.
sl@0
  2802
	*/
sl@0
  2803
	TUint32 iMaxFreeSize;
sl@0
  2804
sl@0
  2805
	// do not add new members to this struct, this is a compatability break
sl@0
  2806
	};
sl@0
  2807
sl@0
  2808
sl@0
  2809
/**
sl@0
  2810
Enumeration defining the bitmask returned from a call to the demnd paging HAL function
sl@0
  2811
EDemandPagingGetPageState.
sl@0
  2812
sl@0
  2813
@internalComponent
sl@0
  2814
@test
sl@0
  2815
*/
sl@0
  2816
enum TDemandPagingPageState
sl@0
  2817
	{
sl@0
  2818
	// Values common to both moving and multiple memory models
sl@0
  2819
	EPageStateInRom					= 1<<16,
sl@0
  2820
	EPageStateInRamCode				= 1<<17,
sl@0
  2821
	EPageStatePaged					= 1<<18,
sl@0
  2822
	EPageStatePageTablePresent		= 1<<19,
sl@0
  2823
	EPageStatePtePresent			= 1<<20,
sl@0
  2824
	EPageStatePteValid				= 1<<21,
sl@0
  2825
	// Values specific to multiple memory model
sl@0
  2826
	EPageStateCodeChunkPresent		= 1<<22,		
sl@0
  2827
	EPageStatePhysAddrPresent		= 1<<23
sl@0
  2828
	};
sl@0
  2829
sl@0
  2830
sl@0
  2831
/**
sl@0
  2832
Information about concurrency in the demand paging system.
sl@0
  2833
sl@0
  2834
@internalComponent
sl@0
  2835
@test
sl@0
  2836
*/
sl@0
  2837
struct SPagingConcurrencyInfo
sl@0
  2838
	{
sl@0
  2839
	/**
sl@0
  2840
	The maximum observed number of threads waiting to page in.
sl@0
  2841
	*/
sl@0
  2842
	TInt iMaxWaitingCount;
sl@0
  2843
sl@0
  2844
	/**
sl@0
  2845
	The maximum observed number of threads paging in.
sl@0
  2846
	*/
sl@0
  2847
	TInt iMaxPagingCount;
sl@0
  2848
	};
sl@0
  2849
sl@0
  2850
sl@0
  2851
/**
sl@0
  2852
Enumeration of demand paging benchmarks.
sl@0
  2853
sl@0
  2854
@internalComponent
sl@0
  2855
@test
sl@0
  2856
*/
sl@0
  2857
enum TPagingBenchmark
sl@0
  2858
	{
sl@0
  2859
	EPagingBmReadRomPage,
sl@0
  2860
	EPagingBmReadCodePage,
sl@0
  2861
	EPagingBmDecompress,
sl@0
  2862
	EPagingBmSetCodePageFree,
sl@0
  2863
	EPagingBmSetCodePageOld,
sl@0
  2864
	EPagingBmReadMedia,
sl@0
  2865
	EPagingBmFixupCodePage,
sl@0
  2866
	EPagingBmReadDataPage,
sl@0
  2867
	EPagingBmWriteDataPage,
sl@0
  2868
	EPagingBmDeleteNotifyDataPage,
sl@0
  2869
	EPagingBmReadDataMedia,
sl@0
  2870
	EPagingBmWriteDataMedia,
sl@0
  2871
		
sl@0
  2872
	EMaxPagingBm
sl@0
  2873
	};
sl@0
  2874
sl@0
  2875
sl@0
  2876
/**
sl@0
  2877
Benchmark information for a specific operation.  All times are in terms of the system's fast timer.
sl@0
  2878
sl@0
  2879
@internalComponent
sl@0
  2880
@test
sl@0
  2881
*/
sl@0
  2882
struct SPagingBenchmarkInfo
sl@0
  2883
	{
sl@0
  2884
	/**
sl@0
  2885
	Number of times the operation has been executed.
sl@0
  2886
	*/
sl@0
  2887
	TInt iCount;
sl@0
  2888
	
sl@0
  2889
	/**
sl@0
  2890
	Total time elapsed while executing the operation.
sl@0
  2891
	*/
sl@0
  2892
	TInt64 iTotalTime;
sl@0
  2893
sl@0
  2894
	/**
sl@0
  2895
	Maximum time recorded for a single execution.
sl@0
  2896
	*/
sl@0
  2897
	TInt iMaxTime;
sl@0
  2898
sl@0
  2899
	/**
sl@0
  2900
	Minimum time recorded for a single execution.
sl@0
  2901
	*/
sl@0
  2902
	TInt iMinTime;
sl@0
  2903
	};
sl@0
  2904
sl@0
  2905
/**
sl@0
  2906
Information about concurrency of ROM demand paging requests in the media subsystem.
sl@0
  2907
sl@0
  2908
@internalComponent
sl@0
  2909
@test
sl@0
  2910
*/
sl@0
  2911
struct SMediaROMPagingConcurrencyInfo
sl@0
  2912
	{
sl@0
  2913
	/**
sl@0
  2914
	The maximum number of pending page in requests in the main queue any time during this session.
sl@0
  2915
	*/
sl@0
  2916
	TUint8 iMaxReqsInPending;
sl@0
  2917
sl@0
  2918
	/**
sl@0
  2919
	The maximum number of pending page in requests in the deferred queue any time during this session.
sl@0
  2920
	*/
sl@0
  2921
	TUint8 iMaxReqsInDeferred;
sl@0
  2922
sl@0
  2923
	/**
sl@0
  2924
	The maximum number of deferrals of any single page in request during this session.
sl@0
  2925
	*/
sl@0
  2926
	TUint8 iMaxDeferrals;
sl@0
  2927
sl@0
  2928
	/**
sl@0
  2929
	The total number of times the page in DFC run with an empty main queue during this session.
sl@0
  2930
	*/
sl@0
  2931
	TUint8 iTotalRunDry;
sl@0
  2932
sl@0
  2933
	/**
sl@0
  2934
	The total number of page in requests first-time deferred during this session.
sl@0
  2935
	*/
sl@0
  2936
	TUint iTotalFirstTimeDeferrals;
sl@0
  2937
sl@0
  2938
	/**
sl@0
  2939
	The total number of page in requests re-deferred during this session (deferred again after being picked out of deferred queue).
sl@0
  2940
	*/
sl@0
  2941
	TUint iTotalReDeferrals;
sl@0
  2942
sl@0
  2943
	/**
sl@0
  2944
	The total number of page in requests serviced from main queue when completing an asynchronous request.
sl@0
  2945
	*/
sl@0
  2946
	TUint iTotalSynchServicedFromMainQ;
sl@0
  2947
sl@0
  2948
	/**
sl@0
  2949
	The total number of page in requests deferred after being picked out of main queue when completing an asynchronous request.
sl@0
  2950
	*/
sl@0
  2951
	TUint iTotalSynchDeferredFromMainQ;
sl@0
  2952
	
sl@0
  2953
	/**
sl@0
  2954
	The total number of page in requests issued whilst processing other page in requests.
sl@0
  2955
	*/
sl@0
  2956
	TUint iTotalConcurrentReqs;
sl@0
  2957
sl@0
  2958
	/**
sl@0
  2959
	The total number of page in requests issued with at least one queue not empty.
sl@0
  2960
	*/
sl@0
  2961
	TUint iTotalReqIssuedNonEmptyQ;
sl@0
  2962
sl@0
  2963
	/**
sl@0
  2964
	The total number of times the main queue was emptied when completing an asynchronous request during this session.
sl@0
  2965
	*/
sl@0
  2966
	TUint iTotalSynchEmptiedMainQ;
sl@0
  2967
sl@0
  2968
	/**
sl@0
  2969
	The total number of times the page in DFC was cancelled because the main queue was synchronously emptied.
sl@0
  2970
	*/
sl@0
  2971
	TUint iTotalDryRunsAvoided;
sl@0
  2972
	};
sl@0
  2973
sl@0
  2974
/**
sl@0
  2975
Information about concurrency of Code demand paging requests in the media subsystem.
sl@0
  2976
sl@0
  2977
@internalComponent
sl@0
  2978
@test
sl@0
  2979
*/
sl@0
  2980
struct SMediaCodePagingConcurrencyInfo
sl@0
  2981
	{
sl@0
  2982
	/**
sl@0
  2983
	The maximum number of pending page in requests in the main queue any time during this session.
sl@0
  2984
	*/
sl@0
  2985
	TUint8 iMaxReqsInPending;
sl@0
  2986
sl@0
  2987
	/**
sl@0
  2988
	The maximum number of pending page in requests in the deferred queue any time during this session.
sl@0
  2989
	*/
sl@0
  2990
	TUint8 iMaxReqsInDeferred;
sl@0
  2991
sl@0
  2992
	/**
sl@0
  2993
	The maximum number of deferrals of any single page in request during this session.
sl@0
  2994
	*/
sl@0
  2995
	TUint8 iMaxDeferrals;
sl@0
  2996
sl@0
  2997
	/**
sl@0
  2998
	Spare field
sl@0
  2999
	*/
sl@0
  3000
	TUint8 iSpare;
sl@0
  3001
sl@0
  3002
	/**
sl@0
  3003
	The total number of page in requests first-time deferred during this session.
sl@0
  3004
	*/
sl@0
  3005
	TUint iTotalFirstTimeDeferrals;
sl@0
  3006
sl@0
  3007
	/**
sl@0
  3008
	The total number of page in requests re-deferred during this session (deferred again after being picked out of deferred queue).
sl@0
  3009
	*/
sl@0
  3010
	TUint iTotalReDeferrals;
sl@0
  3011
sl@0
  3012
	/**
sl@0
  3013
	The total number of page in requests serviced from main queue when completing an asynchronous request.
sl@0
  3014
	*/
sl@0
  3015
	TUint iTotalSynchServicedFromMainQ;
sl@0
  3016
sl@0
  3017
	/**
sl@0
  3018
	The total number of page in requests deferred after being picked out of main queue when completing an asynchronous request.
sl@0
  3019
	*/
sl@0
  3020
	TUint iTotalSynchDeferredFromMainQ;
sl@0
  3021
	
sl@0
  3022
	/**
sl@0
  3023
	The total number of page in requests issued whilst processing other page in requests.
sl@0
  3024
	*/
sl@0
  3025
	TUint iTotalConcurrentReqs;
sl@0
  3026
sl@0
  3027
	/**
sl@0
  3028
	The total number of page in requests issued with at least one queue not empty.
sl@0
  3029
	*/
sl@0
  3030
	TUint iTotalReqIssuedNonEmptyQ;
sl@0
  3031
	};
sl@0
  3032
sl@0
  3033
sl@0
  3034
/**
sl@0
  3035
Information about concurrency of Data demand paging requests in the media subsystem.
sl@0
  3036
sl@0
  3037
@internalComponent
sl@0
  3038
@test
sl@0
  3039
*/
sl@0
  3040
struct SMediaDataPagingConcurrencyInfo
sl@0
  3041
	{
sl@0
  3042
	/**
sl@0
  3043
	The maximum number of pending page in requests in the main queue any time during this session.
sl@0
  3044
	*/
sl@0
  3045
	TUint8 iMaxReqsInPending;
sl@0
  3046
sl@0
  3047
	/**
sl@0
  3048
	The maximum number of pending page in requests in the deferred queue any time during this session.
sl@0
  3049
	*/
sl@0
  3050
	TUint8 iMaxReqsInDeferred;
sl@0
  3051
sl@0
  3052
	/**
sl@0
  3053
	The maximum number of deferrals of any single page in request during this session.
sl@0
  3054
	*/
sl@0
  3055
	TUint8 iMaxDeferrals;
sl@0
  3056
sl@0
  3057
	/**
sl@0
  3058
	The total number of times the page in DFC run with an empty main queue during this session.
sl@0
  3059
	*/
sl@0
  3060
	TUint8 iTotalRunDry;
sl@0
  3061
sl@0
  3062
	/**
sl@0
  3063
	The total number of page in requests first-time deferred during this session.
sl@0
  3064
	*/
sl@0
  3065
	TUint iTotalFirstTimeDeferrals;
sl@0
  3066
sl@0
  3067
	/**
sl@0
  3068
	The total number of page in requests re-deferred during this session (deferred again after being picked out of deferred queue).
sl@0
  3069
	*/
sl@0
  3070
	TUint iTotalReDeferrals;
sl@0
  3071
sl@0
  3072
	/**
sl@0
  3073
	The total number of page in requests serviced from main queue when completing an asynchronous request.
sl@0
  3074
	*/
sl@0
  3075
	TUint iTotalSynchServicedFromMainQ;
sl@0
  3076
sl@0
  3077
	/**
sl@0
  3078
	The total number of page in requests deferred after being picked out of main queue when completing an asynchronous request.
sl@0
  3079
	*/
sl@0
  3080
	TUint iTotalSynchDeferredFromMainQ;
sl@0
  3081
	
sl@0
  3082
	/**
sl@0
  3083
	The total number of page in requests issued whilst processing other page in requests.
sl@0
  3084
	*/
sl@0
  3085
	TUint iTotalConcurrentReqs;
sl@0
  3086
sl@0
  3087
	/**
sl@0
  3088
	The total number of page in requests issued with at least one queue not empty.
sl@0
  3089
	*/
sl@0
  3090
	TUint iTotalReqIssuedNonEmptyQ;
sl@0
  3091
sl@0
  3092
	/**
sl@0
  3093
	The total number of times the main queue was emptied when completing an asynchronous request during this session.
sl@0
  3094
	*/
sl@0
  3095
	TUint iTotalSynchEmptiedMainQ;
sl@0
  3096
sl@0
  3097
	/**
sl@0
  3098
	The total number of times the page in DFC was cancelled because the main queue was synchronously emptied.
sl@0
  3099
	*/
sl@0
  3100
	TUint iTotalDryRunsAvoided;
sl@0
  3101
	};
sl@0
  3102
sl@0
  3103
sl@0
  3104
/**
sl@0
  3105
Information about paging requests in the media subsystem.
sl@0
  3106
sl@0
  3107
@internalComponent
sl@0
  3108
@test
sl@0
  3109
*/
sl@0
  3110
struct SMediaPagingInfo
sl@0
  3111
	{
sl@0
  3112
	/**
sl@0
  3113
	The total number of ROM page in requests
sl@0
  3114
	*/
sl@0
  3115
	TInt	iRomPageInCount;
sl@0
  3116
	/**
sl@0
  3117
	The total number of Code page in requests
sl@0
  3118
	*/
sl@0
  3119
	TInt	iCodePageInCount;
sl@0
  3120
	/**
sl@0
  3121
	The total number of Data page in requests
sl@0
  3122
	*/
sl@0
  3123
	TInt	iDataPageInCount;
sl@0
  3124
	/**
sl@0
  3125
	The total number of Data page out requests
sl@0
  3126
	*/
sl@0
  3127
	TInt	iDataPageOutCount;
sl@0
  3128
	/**
sl@0
  3129
	The total number of "background" Data page out requests
sl@0
  3130
	i.e. a page out which only occurs when the media is otherwise idle
sl@0
  3131
	*/
sl@0
  3132
	TInt	iDataPageOutBackgroundCount;
sl@0
  3133
	};
sl@0
  3134
sl@0
  3135
sl@0
  3136
sl@0
  3137
/**
sl@0
  3138
Swap partition information.
sl@0
  3139
@internalAll
sl@0
  3140
@prototype
sl@0
  3141
*/
sl@0
  3142
struct SVMSwapInfo
sl@0
  3143
	{
sl@0
  3144
	/**
sl@0
  3145
	The size of the swap partition, in bytes.
sl@0
  3146
	*/
sl@0
  3147
	TUint64 iSwapSize;
sl@0
  3148
sl@0
  3149
	/**
sl@0
  3150
	The amount of swap currently free, in bytes.
sl@0
  3151
	*/
sl@0
  3152
	TUint64 iSwapFree;
sl@0
  3153
sl@0
  3154
	// do not add new members to this struct, this is a compatability break
sl@0
  3155
	};
sl@0
  3156
sl@0
  3157
sl@0
  3158
sl@0
  3159
/**
sl@0
  3160
Free swap notification thresholds.
sl@0
  3161
@internalAll
sl@0
  3162
@prototype
sl@0
  3163
*/
sl@0
  3164
struct SVMSwapThresholds
sl@0
  3165
	{
sl@0
  3166
	/**
sl@0
  3167
	The low threshold, in bytes
sl@0
  3168
	*/
sl@0
  3169
	TUint64 iLowThreshold;
sl@0
  3170
sl@0
  3171
	/**
sl@0
  3172
	The good threshold, in bytes.
sl@0
  3173
	*/
sl@0
  3174
	TUint64 iGoodThreshold;
sl@0
  3175
sl@0
  3176
	// do not add new members to this struct, this is a compatability break
sl@0
  3177
	};
sl@0
  3178
sl@0
  3179
sl@0
  3180
sl@0
  3181
/**
sl@0
  3182
@internalComponent
sl@0
  3183
sl@0
  3184
The set of function-ids that are  associated with the EHalGroupRam
sl@0
  3185
HAL group.
sl@0
  3186
sl@0
  3187
@see EHalGroupRam
sl@0
  3188
@test
sl@0
  3189
*/
sl@0
  3190
enum TRamHalFunction
sl@0
  3191
	{
sl@0
  3192
	/**
sl@0
  3193
	Retrieve the number of RAM Zones configured for this variant.
sl@0
  3194
sl@0
  3195
	The first argument (a1) is a TUint in which to store the zone count.
sl@0
  3196
	The second argument (a2) must be zero.
sl@0
  3197
	@test
sl@0
  3198
	*/
sl@0
  3199
	ERamHalGetZoneCount,
sl@0
  3200
	
sl@0
  3201
	/**
sl@0
  3202
	Retrieve configuration information about a zone.
sl@0
  3203
sl@0
  3204
	The first argument (a1) is a TUint indicating the index of the zone into the zone array.
sl@0
  3205
	The second argument (a2) is a pointer to a struct SRamZoneConfig in which to store the data.
sl@0
  3206
	@test
sl@0
  3207
	*/
sl@0
  3208
	ERamHalGetZoneConfig,
sl@0
  3209
	
sl@0
  3210
	/**
sl@0
  3211
	Retrieve utilisation information about a zone.
sl@0
  3212
sl@0
  3213
	The first argument (a1) is a TUint indicating the index of the zone into the zone array.
sl@0
  3214
	The second argument (a2) is a pointer to a struct SRamZoneUtilisation in which to store the data.
sl@0
  3215
	@test
sl@0
  3216
	*/
sl@0
  3217
	ERamHalGetZoneUtilisation,
sl@0
  3218
sl@0
  3219
	};
sl@0
  3220
sl@0
  3221
/**
sl@0
  3222
Ram zone configuration information.
sl@0
  3223
@internalComponent
sl@0
  3224
@test
sl@0
  3225
*/
sl@0
  3226
struct SRamZoneConfig
sl@0
  3227
	{
sl@0
  3228
	/**
sl@0
  3229
	ID number of the RAM zone
sl@0
  3230
	*/
sl@0
  3231
	TUint iZoneId;
sl@0
  3232
sl@0
  3233
	/**
sl@0
  3234
	The index of the RAM zone in the RAM zone array 
sl@0
  3235
	*/
sl@0
  3236
	TUint8 iZoneIndex;
sl@0
  3237
sl@0
  3238
	/**
sl@0
  3239
	Physical base address of the RAM zone
sl@0
  3240
	*/
sl@0
  3241
	TUint32 iPhysBase;
sl@0
  3242
sl@0
  3243
	/**
sl@0
  3244
	Physical end address of the RAM zone
sl@0
  3245
	*/
sl@0
  3246
	TUint32 iPhysEnd;
sl@0
  3247
sl@0
  3248
	/**
sl@0
  3249
	The total number of pages that are in the RAM zone
sl@0
  3250
	*/
sl@0
  3251
	TUint32 iPhysPages;
sl@0
  3252
	
sl@0
  3253
	/**
sl@0
  3254
	Preference value for the RAM zone, lower preference RAM zones are used first
sl@0
  3255
	*/
sl@0
  3256
	TUint8 iPref;	
sl@0
  3257
sl@0
  3258
	/**
sl@0
  3259
	Zone flags - specify whether the RAM zone should be reserved for contiguous buffer or h/w etc
sl@0
  3260
	*/
sl@0
  3261
	TUint iFlags;
sl@0
  3262
sl@0
  3263
	};
sl@0
  3264
sl@0
  3265
/**
sl@0
  3266
Ram zone utilisation information.
sl@0
  3267
@internalComponent
sl@0
  3268
@test
sl@0
  3269
*/
sl@0
  3270
struct SRamZoneUtilisation
sl@0
  3271
	{
sl@0
  3272
	/**
sl@0
  3273
	ID number of the RAM zone
sl@0
  3274
	*/
sl@0
  3275
	TUint iZoneId;			
sl@0
  3276
sl@0
  3277
	/**
sl@0
  3278
	The index of the RAM zone in the zone array 
sl@0
  3279
	*/
sl@0
  3280
	TUint8 iZoneIndex;		
sl@0
  3281
sl@0
  3282
	/**
sl@0
  3283
	The total number of pages that are in the RAM zone
sl@0
  3284
	*/
sl@0
  3285
	TUint32 iPhysPages;		
sl@0
  3286
sl@0
  3287
	/**
sl@0
  3288
	The number of pages free in the RAM zone 
sl@0
  3289
	*/
sl@0
  3290
	TUint32 iFreePages;	
sl@0
  3291
	
sl@0
  3292
	/**
sl@0
  3293
	The number of 'unknown' (reserved at startup or holes in the zone) pages allocated in the RAM zone
sl@0
  3294
	*/
sl@0
  3295
	TUint32 iAllocUnknown;
sl@0
  3296
sl@0
  3297
	/**
sl@0
  3298
	The number of fixed pages allocated in the RAM zone 
sl@0
  3299
	*/
sl@0
  3300
	TUint32 iAllocFixed; 
sl@0
  3301
sl@0
  3302
	/**
sl@0
  3303
	The number of movable pages allocated in the RAM zone 
sl@0
  3304
	*/
sl@0
  3305
	TUint32 iAllocMovable; 
sl@0
  3306
sl@0
  3307
	/**
sl@0
  3308
	The number of discardable pages allocated in the RAM zone 
sl@0
  3309
	*/
sl@0
  3310
	TUint32 iAllocDiscardable; 
sl@0
  3311
sl@0
  3312
	/**
sl@0
  3313
	The number of other pages allocated in the RAM zone 
sl@0
  3314
	*/
sl@0
  3315
	TUint32 iAllocOther; 
sl@0
  3316
sl@0
  3317
	};
sl@0
  3318
#endif