windows-nt/Source/XPSP1/NT/admin/services/sched/idletask/idl/idlrpc.idl
2020-09-26 16:20:57 +08:00

237 lines
5.2 KiB
Plaintext

/*++
Copyright (c) 1990 Microsoft Corporation
Module Name:
idlrpc.idl
Abstract:
Contains the RPC interface specification for the idle task / idle detection APIs.
Also contains the RPC specific data structures for these API.
Author:
Cenk Ergan (cenke) 07-August-2000
Environment:
User Mode - Win32 - MIDL
Revision History:
--*/
//
// Interface Attributes
//
[
uuid(0a74ef1c-41a4-4e06-83ae-dc74fb1cdd53),
version(1.0)
]
//
// Interface Keyword
//
interface idletask
//
// Interface Body
//
{
import "wtypes.idl";
//
// IT_IDLE_TASK_ID declaration.
//
#define MIDL_PASS
#include <idletask.h>
//
// The prefered protocol sequence for connecting the server and the
// client is LPC because of its low overhead. We'd like to bind to
// dynamic endpoint, because a well known endpoint may require another
// listener thread on the server side. Note that depending on the
// other RPC servers in the process we end up in, other bindings may
// also be used.
//
const WCHAR * IT_RPC_PROTSEQ = L"ncalrpc";
//
// This is the custom binding handle type. Specifying this allows us
// to bind to the server when the interface functions are called via
// the IT_RPC_bind and _unbind functions that are part of the client.
// It is not used for any other purpose, although it has to be a
// parameter to the interface functions.
//
typedef [handle] WCHAR * ITRPC_HANDLE;
//
// This is a custom context handle. This allows the server to get
// notified when a client dies.
//
typedef [context_handle] VOID *IT_HANDLE;
//
// Status of an idle task.
//
typedef enum _IT_IDLE_TASK_STATUS {
ItIdleTaskInitializing,
ItIdleTaskQueued,
ItIdleTaskRunning,
ItIdleTaskMaxStatus
} IT_IDLE_TASK_STATUS, *PIT_IDLE_TASK_STATUS;
//
// This structure describes the idle task the client wants to register.
//
typedef struct _IT_IDLE_TASK_PROPERTIES {
//
// Size of the structure.
//
ULONG Size;
//
// Idle task identifier and which process it is in. These two
// uniquely identify the idle task.
//
IT_IDLE_TASK_ID IdleTaskId;
DWORD ProcessId;
//
// Local handle for the event to be notified when the task should
// start running.
//
ULONG_PTR StartEventHandle;
//
// Local handle for the event to be notified when the task should
// stop running.
//
ULONG_PTR StopEventHandle;
} IT_IDLE_TASK_PROPERTIES, *PIT_IDLE_TASK_PROPERTIES;
//
// This structure contains parameters that control the behaviour of
// idle detection.
//
typedef struct _IT_IDLE_DETECTION_PARAMETERS {
//
// This is how long in ms we will wait until each time we check
// for system idleness.
//
ULONG IdleDetectionPeriod;
//
// After we detect that system was idle over a long period, we
// will verify the system is still idle by checking idleness over
// a smaller period. This way we won't miss recent activity that
// seemed insignificant over a long IdleDetectionPeriod.
//
ULONG IdleVerificationPeriod;
ULONG NumVerifications;
//
// We will be polling for user input when running idle tasks every
// this many ms. We want to catch user input and notify the idle task
// to stop running as soon as possible. Even though the system is
// idle, we don't want to create too much overhead which may mislead
// ourself.
//
ULONG IdleInputCheckPeriod;
//
// We check to see if the idle task we asked to run is really running
// (i.e. it is using the disk and CPU) every this many ms. This is our
// mechanism for cleaning up after unregistered/orphaned tasks. This
// should be greater than IdleInputCheckPeriod.
//
ULONG IdleTaskRunningCheckPeriod;
//
// If the CPU is not idle more than this percent over a time interval,
// the system is not considered idle.
//
ULONG MinCpuIdlePercentage;
//
// If a disk is not idle more than this percent over a time interval,
// the system is not considered idle.
//
ULONG MinDiskIdlePercentage;
//
// This is the maximum number of registered idle tasks at one time.
//
ULONG MaxNumRegisteredTasks;
} IT_IDLE_DETECTION_PARAMETERS, *PIT_IDLE_DETECTION_PARAMETERS;
//
// Idle task server registration/unregistration API. These are not
// called from the user directly. They are called by the client side
// implementation of the RegisterIdleTask/UnregisterIdleTask API.
//
DWORD
ItSrvRegisterIdleTask (
[in,string,unique] ITRPC_HANDLE Reserved,
[out,ref] IT_HANDLE *ItHandle,
[in,ref] PIT_IDLE_TASK_PROPERTIES IdleTaskProperties
);
void
ItSrvUnregisterIdleTask (
[in,string,unique] ITRPC_HANDLE Reserved,
[in,out,ref] IT_HANDLE *ItHandle
);
//
// This function is called to process all registered tasks without
// waiting for system to become idle.
//
DWORD
ItSrvProcessIdleTasks (
[in,string,unique] ITRPC_HANDLE Reserved
);
//
// This function is implemented only in the debug builds so test
// applications can set stress parameters. It returns
// ERROR_NOT_IMPLEMENTED on free builds.
//
DWORD
ItSrvSetDetectionParameters (
[in,string,unique] ITRPC_HANDLE Reserved,
[in,ref] PIT_IDLE_DETECTION_PARAMETERS Parameters
);
}