userlibandfileserver/domainmgr/inc/domainmanager.h
author hgs
Wed, 06 Oct 2010 17:13:14 +0100
changeset 285 ff5437e4337c
parent 279 957c583b417b
permissions -rw-r--r--
201039_09

// Copyright (c) 2002-2010 Nokia Corporation and/or its subsidiary(-ies).
// All rights reserved.
// This component and the accompanying materials are made available
// under the terms of the License "Eclipse Public License v1.0"
// which accompanies this distribution, and is available
// at the URL "http://www.eclipse.org/legal/epl-v10.html".
//
// Initial Contributors:
// Nokia Corporation - initial contribution.
//
// Contributors:
//
// Description:
// Contains the Domain Manager interface for clients acting in the role of
// "Domain Controller".
// 
// WARNING: This file contains some APIs which are internal and are subject
//          to change without notice. Such APIs should therefore not be used
//          outside the Kernel and Hardware Services package.
//

#ifndef __DOMAIN_MANAGER_H__
#define __DOMAIN_MANAGER_H__

#include <e32std.h>

#include <domaindefs.h>


/**
Internal macro used by EStart source. It provides the filename of the Domain 
Manager server.
Not to be used outside the KernelHwSrv package.
*/
#define KDmManagerFileNameLit	_L("domainSrv.exe")



/**
Internal session class used inside the Domain Manager client library. 
Not to be used outside the KernelHwSrv package.
*/
class RDmManagerSession : public RSessionBase
	{
public:
	// Power hierarchy connect	
	TInt Connect();
	 	
	// Specified hierarchy connect
	TInt Connect(TDmHierarchyId aHierarchyId);
	TInt ConnectObserver(TDmHierarchyId aHierarchyId);
	
	// Controller related functions
	void RequestSystemTransition(TDmDomainState aState, TDmTraverseDirection aDirection, TRequestStatus& aStatus);
	void RequestDomainTransition(TDmDomainId, TDmDomainState, TDmTraverseDirection aDirection, TRequestStatus& aStatus);
	void CancelTransition();
	TInt AddDomainHierarchy(TDmHierarchyId aHierarchyId);
	TInt GetTransitionFailureCount();
	TInt GetTransitionFailures(RArray<const TTransitionFailure>& aTransitionFailures);
	
	// Observer related functions
	TInt StartObserver(TDmDomainId aDomainId,TDmNotifyType aNotifyType);
	void GetNotification(TRequestStatus& aStatus);
	TInt GetEventCount();
	TInt GetEvents(RArray<const TTransInfo>& aTransitions);
	void CancelObserver();
	TInt ObserverDomainCount();
	};


/**
Published platform interface of the Domain Manager for clients performing
the "Domain Controller" role implementing domain policy on the platform.

Controllers can use this class to request domain state transitions either
system-wide across the whole domain hierarchy or only within a specific domain 
subtree. 

The Domain Manager may utilize the Transition Monitoring feature for some state
transitions (as defined in the policy) which allows trusted clients to request
more time to complete their work for the transition e.g. power down transitions.

It also provides utility methods allowing policy controllers to load additional
hierarchies (from a domain policy library) and to monitor the Domain Manager's
start-up.

See the RDmDomain class for the interface used by Domain Member clients. 
 
Also see domaindefs.h for Domain Manager specific error codes used with this
API.
*/
class RDmDomainManager
	{
public:
	IMPORT_C static TInt WaitForInitialization();
		
public:
	// Power Hierarchy
	IMPORT_C TInt Connect();
	IMPORT_C void RequestSystemTransition(TPowerState aState, TRequestStatus& aStatus);
	IMPORT_C void RequestDomainTransition(TDmDomainId aDomain, TPowerState aState, TRequestStatus& aStatus);
	IMPORT_C void SystemShutdown();

	// Controller Specified Hierarchy
	IMPORT_C static TInt AddDomainHierarchy(TDmHierarchyId aHierarchyId);
	IMPORT_C TInt Connect(TDmHierarchyId aHierarchyId);
	IMPORT_C void RequestSystemTransition(TDmDomainState aState, TDmTraverseDirection aDirection, TRequestStatus& aStatus);
	IMPORT_C void RequestDomainTransition(TDmDomainId aDomain, TDmDomainState aState, TDmTraverseDirection aDirection, TRequestStatus& aStatus);
	
	// Common session/hierarchy 
	IMPORT_C TInt GetTransitionFailures(RArray<const TTransitionFailure>& aTransitionFailures);
	IMPORT_C TInt GetTransitionFailureCount();
	IMPORT_C void CancelTransition();
	IMPORT_C void Close();
	
private:
	RDmManagerSession	iSession;
	};



#endif