290 lines
7.4 KiB
C
290 lines
7.4 KiB
C
//=======================================================================
|
|
//
|
|
// Copyright (c) 1995-2000 Microsoft Corporation. All Rights Reserved.
|
|
//
|
|
// File: cdm.h
|
|
//
|
|
// Description:
|
|
//
|
|
// Public header file for the IU (V4) Code Download Manager (CDM.DLL).
|
|
//
|
|
//=======================================================================
|
|
|
|
#ifndef _INC_CDM
|
|
#define _INC_CDM
|
|
|
|
#if defined(__cplusplus)
|
|
extern "C" {
|
|
#endif
|
|
|
|
//
|
|
// Define API decoration for direct importing of DLL references.
|
|
//
|
|
#if !defined(_CDM_)
|
|
#define CDMAPI DECLSPEC_IMPORT
|
|
#else
|
|
#define CDMAPI
|
|
#endif
|
|
|
|
//
|
|
// HWID_LEN must remain 2048 for backwards CDM compatibility, however note that the maximum
|
|
// length for a hardware ID is defined in //depot/Lab04_N/Root/Public/sdk/inc/cfgmgr32.h
|
|
// as #define MAX_DEVICE_ID_LEN 200
|
|
//
|
|
#define HWID_LEN 2048
|
|
#ifndef LINE_LEN
|
|
#define LINE_LEN 256 // Win95-compatible maximum for displayable
|
|
// strings coming from a device INF.
|
|
#endif
|
|
|
|
//Win 98 DOWNLOADINFO
|
|
typedef struct _DOWNLOADINFOWIN98
|
|
{
|
|
DWORD dwDownloadInfoSize; //size of this structure
|
|
LPTSTR lpHardwareIDs; //multi_sz list of Hardware PnP IDs
|
|
LPTSTR lpCompatIDs; //multi_sz list of compatible IDs
|
|
LPTSTR lpFile; //File name (string)
|
|
OSVERSIONINFO OSVersionInfo; //OSVERSIONINFO from GetVersionEx()
|
|
DWORD dwFlags; //Flags
|
|
DWORD dwClientID; //Client ID
|
|
} DOWNLOADINFOWIN98, *PDOWNLOADINFOWIN98;
|
|
|
|
typedef struct _DOWNLOADINFO {
|
|
DWORD dwDownloadInfoSize; // size of this structure
|
|
LPCWSTR lpHardwareIDs; // multi_sz list of Hardware PnP IDs
|
|
LPCWSTR lpDeviceInstanceID; // Device Instance ID
|
|
LPCWSTR lpFile; // File name (string)
|
|
OSVERSIONINFOW OSVersionInfo; // OSVERSIONINFO from GetVersionEx()
|
|
DWORD dwArchitecture; // Specifies the system's processor architecture.
|
|
//This value can be one of the following values:
|
|
//PROCESSOR_ARCHITECTURE_INTEL
|
|
//Windows NT only: PROCESSOR_ARCHITECTURE_MIPS
|
|
//Windows NT only: PROCESSOR_ARCHITECTURE_ALPHA
|
|
//Windows NT only: PROCESSOR_ARCHITECTURE_PPC
|
|
//Windows NT only: PROCESSOR_ARCHITECTURE_UNKNOWN
|
|
DWORD dwFlags; // Flags
|
|
DWORD dwClientID; // Client ID
|
|
LCID localid; // local id
|
|
} DOWNLOADINFO, *PDOWNLOADINFO;
|
|
|
|
|
|
typedef struct _WUDRIVERINFO
|
|
{
|
|
DWORD dwStructSize; // size of this structure
|
|
WCHAR wszHardwareID[HWID_LEN]; // ID being used to match
|
|
WCHAR wszDescription[LINE_LEN]; // from INF
|
|
WCHAR wszMfgName[LINE_LEN]; // from INF
|
|
WCHAR wszProviderName[LINE_LEN]; // INF provider
|
|
WCHAR wszDriverVer[LINE_LEN]; // from INF
|
|
} WUDRIVERINFO, *PWUDRIVERINFO;
|
|
|
|
typedef void (*PFN_QueryDetectionFilesCallback)(void* pCallbackParam, LPCWSTR pszURL, LPCWSTR pszLocalFile);
|
|
|
|
//
|
|
// CDM exported function declarations
|
|
//
|
|
|
|
CDMAPI
|
|
VOID
|
|
WINAPI
|
|
CloseCDMContext(
|
|
IN HANDLE hConnection
|
|
);
|
|
|
|
CDMAPI
|
|
void
|
|
WINAPI
|
|
DetFilesDownloaded(
|
|
IN HANDLE hConnection
|
|
);
|
|
//
|
|
// IMPORTANT: DownloadGetUpdatedFiles is only exported from the IU CDM.DLL stub.
|
|
// It is NOT present in the Whistler version of the "Classic" V3 control.
|
|
//
|
|
CDMAPI
|
|
BOOL
|
|
DownloadGetUpdatedFiles(
|
|
IN PDOWNLOADINFOWIN98 pDownloadInfoWin98,
|
|
IN OUT LPTSTR lpDownloadPath,
|
|
IN UINT uSize
|
|
);
|
|
|
|
CDMAPI
|
|
BOOL
|
|
WINAPI
|
|
DownloadIsInternetAvailable(
|
|
void
|
|
);
|
|
|
|
CDMAPI
|
|
BOOL
|
|
WINAPI
|
|
DownloadUpdatedFiles(
|
|
IN HANDLE hConnection,
|
|
IN HWND hwnd,
|
|
IN PDOWNLOADINFO pDownloadInfo,
|
|
OUT LPWSTR lpDownloadPath,
|
|
IN UINT uSize,
|
|
OUT PUINT puRequiredSize
|
|
);
|
|
|
|
CDMAPI
|
|
BOOL
|
|
WINAPI
|
|
FindMatchingDriver(
|
|
IN HANDLE hConnection,
|
|
IN PDOWNLOADINFO pDownloadInfo,
|
|
OUT PWUDRIVERINFO pWuDriverInfo
|
|
);
|
|
|
|
CDMAPI
|
|
void
|
|
WINAPI
|
|
LogDriverNotFound(
|
|
IN HANDLE hConnection,
|
|
IN LPCWSTR lpDeviceInstanceID,
|
|
IN DWORD dwFlags
|
|
);
|
|
|
|
CDMAPI
|
|
HANDLE
|
|
WINAPI
|
|
OpenCDMContext(
|
|
IN HWND hwnd
|
|
);
|
|
|
|
CDMAPI
|
|
HANDLE
|
|
WINAPI
|
|
OpenCDMContextEx(
|
|
IN BOOL fConnectIfNotConnected
|
|
);
|
|
|
|
CDMAPI
|
|
int
|
|
WINAPI
|
|
QueryDetectionFiles(
|
|
IN HANDLE hConnection,
|
|
IN void* pCallbackParam,
|
|
IN PFN_QueryDetectionFilesCallback pCallback
|
|
);
|
|
|
|
//
|
|
// 502965 Windows Error Reporting bucket 2096553: Hang following NEWDEV.DLL!CancelDriverSearch
|
|
//
|
|
CDMAPI
|
|
HRESULT
|
|
WINAPI
|
|
CancelCDMOperation(
|
|
void
|
|
);
|
|
|
|
|
|
|
|
//
|
|
// CDM prototypes
|
|
//
|
|
|
|
typedef VOID (WINAPI *CLOSE_CDM_CONTEXT_PROC)(
|
|
IN HANDLE hConnection
|
|
);
|
|
|
|
typedef void (WINAPI *DET_FILES_DOWNLOADED_PROC)(
|
|
IN HANDLE hConnection
|
|
);
|
|
|
|
typedef BOOL (WINAPI *DOWNLOAD_GET_UPDATED_FILES)(
|
|
IN PDOWNLOADINFOWIN98 pDownloadInfoWin98,
|
|
IN OUT LPTSTR lpDownloadPath,
|
|
IN UINT uSize
|
|
);
|
|
|
|
typedef BOOL (WINAPI *CDM_INTERNET_AVAILABLE_PROC)(
|
|
void
|
|
);
|
|
|
|
typedef BOOL (WINAPI *DOWNLOAD_UPDATED_FILES_PROC)(
|
|
IN HANDLE hConnection,
|
|
IN HWND hwnd,
|
|
IN PDOWNLOADINFO pDownloadInfo,
|
|
OUT LPWSTR lpDownloadPath,
|
|
IN UINT uSize,
|
|
OUT PUINT puRequiredSize
|
|
);
|
|
|
|
typedef BOOL (WINAPI *FIND_MATCHING_DRIVER_PROC)(
|
|
IN HANDLE hConnection,
|
|
IN PDOWNLOADINFO pDownloadInfo,
|
|
OUT PWUDRIVERINFO pWuDriverInfo
|
|
);
|
|
|
|
typedef void (WINAPI *LOG_DRIVER_NOT_FOUND_PROC)(
|
|
IN HANDLE hConnection,
|
|
IN LPCWSTR lpDeviceInstanceID,
|
|
IN DWORD dwFlags
|
|
);
|
|
|
|
typedef HANDLE (WINAPI *OPEN_CDM_CONTEXT_PROC)(
|
|
IN HWND hwnd
|
|
);
|
|
|
|
typedef HANDLE (WINAPI *OPEN_CDM_CONTEXT_EX_PROC)(
|
|
IN BOOL fConnectIfNotConnected
|
|
);
|
|
|
|
typedef int (WINAPI *QUERY_DETECTION_FILES_PROC)(
|
|
IN HANDLE hConnection,
|
|
IN void* pCallbackParam,
|
|
IN PFN_QueryDetectionFilesCallback pCallback
|
|
);
|
|
|
|
typedef HRESULT (WINAPI *CANCEL_CDM_OPERATION_PROC)(
|
|
void
|
|
);
|
|
|
|
|
|
//
|
|
// The following defines and structures are private internal interfaces so
|
|
// they are in cdm.h and not in setupapi.h
|
|
//
|
|
#define DIF_GETWINDOWSUPDATEINFO 0x00000025
|
|
|
|
#define DI_FLAGSEX_SHOWWINDOWSUPDATE 0x00400000L
|
|
|
|
|
|
//For dwFlags parameter of LogDriverNotFound(...)
|
|
//used with bitwising
|
|
#define BEGINLOGFLAG 0x00000002 //if 1, batch logging ends, flushing internal hardware id list to file
|
|
|
|
|
|
//
|
|
// Structure corresponding to a DIF_GETWINDOWSUPDATEINFO install function.
|
|
//
|
|
typedef struct _SP_WINDOWSUPDATE_PARAMS_A {
|
|
SP_CLASSINSTALL_HEADER ClassInstallHeader;
|
|
CHAR PackageId[MAX_PATH];
|
|
HANDLE CDMContext;
|
|
} SP_WINDOWSUPDATE_PARAMS_A, *PSP_WINDOWSUPDATE_PARAMS_A;
|
|
|
|
typedef struct _SP_WINDOWSUPDATE_PARAMS_W {
|
|
SP_CLASSINSTALL_HEADER ClassInstallHeader;
|
|
WCHAR PackageId[MAX_PATH];
|
|
HANDLE CDMContext;
|
|
} SP_WINDOWSUPDATE_PARAMS_W, *PSP_WINDOWSUPDATE_PARAMS_W;
|
|
|
|
|
|
#ifdef UNICODE
|
|
typedef SP_WINDOWSUPDATE_PARAMS_W SP_WINDOWSUPDATE_PARAMS;
|
|
typedef PSP_WINDOWSUPDATE_PARAMS_W PSP_WINDOWSUPDATE_PARAMS;
|
|
#else
|
|
typedef SP_WINDOWSUPDATE_PARAMS_A SP_WINDOWSUPDATE_PARAMS;
|
|
typedef PSP_WINDOWSUPDATE_PARAMS_A PSP_WINDOWSUPDATE_PARAMS;
|
|
#endif
|
|
|
|
#if defined(__cplusplus)
|
|
} // end extern "C"
|
|
#endif
|
|
|
|
#endif // _INC_CDM
|
|
|