Source code of Windows XP (NT5)
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 
 
 
 
 

349 lines
7.9 KiB

/*****************************************************************************
@doc INT EXT
******************************************************************************
* $ProjectName: $
* $ProjectRevision: $
*-----------------------------------------------------------------------------
* $Source: z:/pr/cmbp0/sw/cmbp0.ms/rcs/cmbp0wdm.h $
* $Revision: 1.3 $
*-----------------------------------------------------------------------------
* $Author: WFrischauf $
*-----------------------------------------------------------------------------
* History: see EOF
*-----------------------------------------------------------------------------
*
* Copyright © 2000 OMNIKEY AG
******************************************************************************/
#if !defined ( __CMMOB_WDM_DRV_H__ )
#define __CMMOB_WDM_DRV_H__
#ifdef NT4
#include <NTDDK.H>
#include <NTDDDISK.H>
#else
#include "WDM.H"
#endif
#include "SMCLIB.H"
#include "PCSC_CM.H"
//#define MEMORYCARD
#define IOCARD
//
// Constants -----------------------------------------------------------------
//
#undef DRIVER_NAME
#define DRIVER_NAME "CMMOB"
#define SMARTCARD_POOL_TAG 'MOCS'
#define CMMOB_MAX_DEVICE 0x02
#define CARDMAN_MOBILE_DEVICE_NAME L"\\Device\\CM_4000_0"
#define CMMOB_VENDOR_NAME "OMNIKEY"
#define CMMOB_PRODUCT_NAME "CardMan 4000"
#define CMMOB_MAJOR_VERSION 3
#define CMMOB_MINOR_VERSION 2
#define CMMOB_BUILD_NUMBER 1
// reader states
#define UNKNOWN 0xFFFFFFFF
#define REMOVED 0x00000001
#define INSERTED 0x00000002
#define POWERED 0x00000004
#define CMMOB_MAXBUFFER 262
#define CMMOB_MAX_CIS_SIZE 256
// for protocol T=0
#define T0_HEADER_LEN 0x05
#define T0_STATE_LEN 0x02
typedef enum _OS_VERSION
{
OS_Unspecified = 0,
OS_Windows95,
OS_Windows98,
OS_Windows98SE,
OS_WindowsME,
OS_Windows2000
} OS_VERSION;
#ifdef DBG
static const PCHAR szOSVersion[] =
{
"Unspecified",
"Windows95",
"Windows98",
"Windows98SE",
"WindowsME",
"Windows2000"
};
#endif
typedef struct _DEVICE_EXTENSION
{
// Dos device name
UNICODE_STRING LinkDeviceName;
#ifndef NT4
// Our PnP device name
UNICODE_STRING PnPDeviceName;
//detected OS version
OS_VERSION OSVersion;
#endif
//memory has been mapped, and must be unmapped during cleanup (remove device)
BOOLEAN fUnMapMem;
//device is opened by application (ScardSrv, CT-API)
LONG lOpenCount;
// Used to signal that the reader is able to process reqeusts
KEVENT ReaderStarted;
//device has been removed
BOOLEAN fDeviceRemoved;
//removing device now
BOOLEAN fRemovePending;
// Used to signal that update thread can run
KEVENT CanRunUpdateThread;
// incremented when any IO request is received
// decremented when any IO request is completed or passed on
LONG lIoCount;
// Used to access IoCount;
KSPIN_LOCK SpinLockIoCount;
#ifndef NT4
//Bus drivers set the appropriate values in this structure in response
//to an IRP_MN_QUERY_CAPABILITIES IRP. Function and filter drivers might
//alter the capabilities set by the bus driver.
DEVICE_CAPABILITIES DeviceCapabilities;
#endif
//attached DO
PDEVICE_OBJECT AttachedDeviceObject;
//smartcard extension
SMARTCARD_EXTENSION SmartcardExtension;
} DEVICE_EXTENSION, *PDEVICE_EXTENSION;
typedef struct _CARD_PARAMETERS
{
//
// flag if card is synchronous card
//
BOOLEAN fSynchronousCard;
//
// parameters for asynchronous cards
//
UCHAR bBaudRateHigh;
UCHAR bBaudRateLow;
UCHAR bStopBits;
UCHAR bClockFrequency;
//
// flag if card uses invers revers convention
//
BOOLEAN fInversRevers;
//
// flag if card reader is switched to T0 mode
//
BOOLEAN fT0Mode;
BOOLEAN fT0Write;
} CARD_PARAMETERS, *PCARD_PARAMETERS;
typedef enum _READER_POWER_STATE
{
PowerReaderUnspecified = 0,
PowerReaderWorking,
PowerReaderOff
} READER_POWER_STATE, *PREADER_POWER_STATE;
typedef struct _READER_EXTENSION
{
#ifdef MEMORYCARD
//
// Mem address where the reader is configured.
//
PVOID pMemBase;
ULONG ulMemWindow;
PUCHAR pbCISBase;
PUCHAR pbRegsBase;
PUCHAR pbDataBase;
#endif
#ifdef IOCARD
//
// Mem address where the reader is configured.
//
PVOID pIoBase;
ULONG ulIoWindow;
PUCHAR pbRegsBase;
#endif
//
// Software revision ID of the firmware.
//
ULONG ulFWVersion;
//
// for communication with UpdateCurrentStateThread
//
BOOLEAN fTerminateUpdateThread;
BOOLEAN fUpdateThreadRunning;
//
// state of the reader
//
ULONG ulOldCardState;
ULONG ulNewCardState;
// only used for hibernation
BOOLEAN fCardPresent;
//
// parameters of inserted card
//
CARD_PARAMETERS CardParameters;
//
// previous value of Flags1 register
//
UCHAR bPreviousFlags1;
#ifdef IOCARD
// bit 9 of data buffer address
UCHAR bAddressHigh;
// flag Tactive (access to RAM)
BOOLEAN fTActive;
// flag ReadCIS (access to CIS)
BOOLEAN fReadCIS;
#endif
//
// mutex for access to CardMan
//
KMUTEX CardManIOMutex;
//
// Handle of the update current state thread
//
PVOID ThreadObjectPointer;
//
// Current reader power state.
//
READER_POWER_STATE ReaderPowerState;
} READER_EXTENSION, *PREADER_EXTENSION;
//
// Extern declarations -----------------------------------------------------------------
//
extern BOOLEAN DeviceSlot[];
//
// Functions -----------------------------------------------------------------
//
void SysDelay( ULONG Timeout );
NTSTATUS DriverEntry(
PDRIVER_OBJECT DriverObject,
PUNICODE_STRING RegistryPath
);
NTSTATUS CMMOB_CreateDevice(
IN PDRIVER_OBJECT DriverObject,
IN PDEVICE_OBJECT PhysicalDeviceObject,
OUT PDEVICE_OBJECT *DeviceObject
);
VOID CMMOB_SetVendorAndIfdName(
IN PDEVICE_OBJECT PhysicalDeviceObject,
IN PSMARTCARD_EXTENSION SmartcardExtension
);
NTSTATUS CMMOB_StartDevice(
PDEVICE_OBJECT DeviceObject,
PCM_FULL_RESOURCE_DESCRIPTOR FullResourceDescriptor
);
VOID CMMOB_StopDevice(
PDEVICE_OBJECT DeviceObject
);
VOID CMMOB_UnloadDevice(
PDEVICE_OBJECT DeviceObject
);
VOID CMMOB_UnloadDriver(
PDRIVER_OBJECT DriverObject
);
NTSTATUS CMMOB_Cleanup(
PDEVICE_OBJECT DeviceObject,
PIRP Irp
);
NTSTATUS CMMOB_CreateClose(
PDEVICE_OBJECT DeviceObject,
PIRP Irp
);
NTSTATUS CMMOB_DeviceIoControl(
PDEVICE_OBJECT DeviceObject,
PIRP Irp
);
NTSTATUS CMMOB_SystemControl(
PDEVICE_OBJECT DeviceObject,
PIRP Irp
);
#endif // __CMMOB_WDM_DRV_H__
/*****************************************************************************
* History:
* $Log: cmbp0wdm.h $
* Revision 1.3 2000/07/27 13:53:07 WFrischauf
* No comment given
*
*
******************************************************************************/