windows-nt/Source/XPSP1/NT/public/sdk/inc/timeprov.h

209 lines
7.8 KiB
C
Raw Permalink Normal View History

2020-09-26 03:20:57 -05:00
//--------------------------------------------------------------------
// TimeProv - header
// Copyright (C) Microsoft Corporation, 1999
//
// Created by: Louis Thomas (louisth), 9-2-99
//
// Definitions for time providers
//
#ifndef TIMEPROV_H
#define TIMEPROV_H
#ifdef __cplusplus
extern "C" {
#endif
//--------------------------------------------------------------------
// Registry keys and values
// Each time provider should create their own subkey under this key
// and store their configuration there.
#define wszW32TimeRegKeyTimeProviders L"System\\CurrentControlSet\\Services\\W32Time\\TimeProviders"
// Path: ...\TimeProviders\<PrividerName>\Enabled
// Type: REG_DWORD (cast to BOOL)
// Meaning: If true, this provider will be started by the time service.
#define wszW32TimeRegValueEnabled L"Enabled"
// Path: ...\TimeProviders\<PrividerName>\DllName
// Type: REG_SZ
// Meaning: The dll that contains the provider. The time service will
// call LoadLibrary on this value.
#define wszW32TimeRegValueDllName L"DllName"
// Path: ...\TimeProviders\<PrividerName>\InputProvider
// Type: REG_DWORD (cast to BOOL)
// Meaning: If true, this provider is an input provider, and will be
// called upon to return time samples. If false, this provider
// is an output provider.
#define wszW32TimeRegValueInputProvider L"InputProvider"
//--------------------------------------------------------------------
// types
// Time Source Flags
#define TSF_Hardware 0x00000001
#define TSF_Authenticated 0x00000002
// commands that can be issued through TimeProvCommand
typedef enum TimeProvCmd {
TPC_TimeJumped, // (TpcTimeJumpedArgs *)pvArgs
TPC_UpdateConfig, // (void)pvArgs
TPC_PollIntervalChanged,// (void)pvArgs
TPC_GetSamples, // (TpcGetSamplesArgs *)pvArgs
TPC_NetTopoChange, // (TpcNetTopoChangeArgs *)pvArgs
TPC_Query, // (W32TIME_PROVIDER_STATUS *)pvArgs
TPC_Shutdown, // (void)pvArgs
} TimeProvCmd;
// info that can be requested through GetTimeSysInfo
typedef enum TimeSysInfo {
TSI_LastSyncTime, // (unsigned __int64 *)pvInfo, NtTimeEpoch, in (10^-7)s
TSI_ClockTickSize, // (unsigned __int64 *)pvInfo, NtTimePeriod, in (10^-7)s
TSI_ClockPrecision, // ( signed __int32 *)pvInfo, ClockTickSize, in log2(s)
TSI_CurrentTime, // (unsigned __int64 *)pvInfo, NtTimeEpoch, in (10^-7)s
TSI_PhaseOffset, // ( signed __int64 *)pvInfo, opaque
TSI_TickCount, // (unsigned __int64 *)pvInfo, opaque
TSI_LeapFlags, // ( BYTE *)pvInfo, a warning of an impending leap second or loss of synchronization
TSI_Stratum, // ( BYTE *)pvInfo, how far away the computer is from a reference source
TSI_ReferenceIdentifier, // ( DWORD *)pvInfo, NtpRefId
TSI_PollInterval, // ( signed __int32 *)pvInfo, poll interval, in log2(s)
TSI_RootDelay, // ( signed __int64 *)pvInfo, NtTimeOffset, in (10^-7)s
TSI_RootDispersion, // (unsigned __int64 *)pvInfo, NtTimePeriod, in (10^-7)s
TSI_TSFlags, // ( DWORD *)pvInfo, Time source flags
} TimeSysInfo;
// flags which provide information about a time jump
typedef enum TimeJumpedFlags {
TJF_Default=0,
TJF_UserRequested=1,
};
// flags which provide information about a network topography change
typedef enum NetTopoChangeFlags {
NTC_Default=0,
NTC_UserRequested=1,
};
typedef enum TimeProvState {
TPS_Running,
TPS_Error,
} TimeProvState;
struct SetProviderStatusInfo;
typedef void (__stdcall
SetProviderStatusInfoFreeFunc)
(IN struct SetProviderStatusInfo *pspsi);
// parameter to SetProviderStatusFunc
typedef struct SetProviderStatusInfo {
TimeProvState tpsCurrentState; // IN the new state of the provider.
DWORD dwStratum; // IN the new stratum of the provider.
LPWSTR wszProvName; // IN the name of the provider who's status should be adjusted
HANDLE hWaitEvent; // IN the event to signal when the operation is complete, NULL if notification is not needed
SetProviderStatusInfoFreeFunc *pfnFree; // IN function used to free the struct on completion
HRESULT *pHr; // OUT on completion, set to the result of the operation
DWORD *pdwSysStratum; // OUT on completion, set to the new system stratum
} SetProviderStatusInfo;
// Time Service provided callback to get system state information
typedef HRESULT (__stdcall
GetTimeSysInfoFunc)(
IN TimeSysInfo eInfo,
OUT void * pvInfo
);
// Time Service provided callback to log an event on behalf of the Time Provider.
typedef HRESULT (__stdcall
LogTimeProvEventFunc)(
IN WORD wType,
IN WCHAR * wszProvName,
IN WCHAR * wszMessage);
// Time Service provided callback to inform the system of newly available samples
typedef HRESULT (__stdcall
AlertSamplesAvailFunc)(
void
);
// Time Service provided callback to set the provider's stratum
typedef HRESULT (__stdcall SetProviderStatusFunc)
(IN SetProviderStatusInfo *pspsi);
// All the callbacsk provided by the Time Service to the Time Provider.
typedef struct TimeProvSysCallbacks {
DWORD dwSize;
GetTimeSysInfoFunc * pfnGetTimeSysInfo;
LogTimeProvEventFunc * pfnLogTimeProvEvent;
AlertSamplesAvailFunc * pfnAlertSamplesAvail;
SetProviderStatusFunc * pfnSetProviderStatus;
} TimeProvSysCallbacks;
typedef void * TimeProvArgs;
typedef struct TimeSample {
DWORD dwSize; // size of this structure
DWORD dwRefid; // NtpRefId
signed __int64 toOffset; // NtTimeOffset, in (10^-7)s - difference between local and remote clocks
signed __int64 toDelay; // NtTimeOffset, in (10^-7)s - round trip delay; time packets spent in flight, INCLUDING root delay
unsigned __int64 tpDispersion; // NtTimePeriod, in (10^-7)s - measurement error, INCLUDING root dispersion
unsigned __int64 nSysTickCount; // opaque, must be GetTimeSysInfo(TSI_TickCount)
signed __int64 nSysPhaseOffset; // opaque, must be GetTimeSysInfo(TSI_PhaseOffset)
BYTE nLeapFlags; // a warning of an impending leap second or loss of synchronization
BYTE nStratum; // how far away the computer is from a reference source
DWORD dwTSFlags; // time source flags
WCHAR wszUniqueName[256]; // Admin readable name that uniquely identifies this peer
} TimeSample;
typedef struct TpcGetSamplesArgs {
BYTE * pbSampleBuf;
DWORD cbSampleBuf;
DWORD dwSamplesReturned;
DWORD dwSamplesAvailable;
} TpcGetSamplesArgs;
typedef struct TpcTimeJumpedArgs {
TimeJumpedFlags tjfFlags;
} TpcTimeJumpedArgs;
typedef struct TpcNetTopoChangeArgs {
NetTopoChangeFlags ntcfFlags;
} TpcNetTopoChangeArgs;
// An opaque handle to a Time Provider used by the Time Service to identify an
// opened Provider in a dll. NULL is considered an invalid value.
typedef void * TimeProvHandle;
//--------------------------------------------------------------------
// functions that a Time Provider must implement and export
HRESULT __stdcall
TimeProvOpen(
IN WCHAR * wszName,
IN TimeProvSysCallbacks * pSysCallbacks, // copy this data, do not free it!
OUT TimeProvHandle * phTimeProv);
HRESULT __stdcall
TimeProvCommand(
IN TimeProvHandle hTimeProv,
IN TimeProvCmd eCmd,
IN TimeProvArgs pvArgs);
HRESULT __stdcall
TimeProvClose(
IN TimeProvHandle hTimeProv);
#ifdef __cplusplus
} // <- end extern "C"
#endif
#endif //TIMEPROV_H