⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 tlp3ce.c

📁 基于windows ce环境下对smart card 基于pc/sc架构下驱动例程
💻 C
📖 第 1 页 / 共 3 页
字号:
                                NULL,0,NULL,0,NULL);
            Sleep(10);
        }
        TLP3CloseSerialPort(pSmartcardExtension );

        if (pSmartcardExtension->ReaderExtension->hBackgroundThread) {
            DWORD dwWait;
            dwWait = WaitForSingleObject(pSmartcardExtension->ReaderExtension->hBackgroundThread,1000);
            ASSERT(dwWait != WAIT_TIMEOUT);
            CloseHandle(pSmartcardExtension->ReaderExtension->hBackgroundThread);
            pSmartcardExtension->ReaderExtension->hBackgroundThread=NULL;
        }
        
        fRet = TRUE;
    }
    LeaveDevice(pSmartcardExtension);

    return fRet;
}



   
//
// I/O Control function - responds to info, read and write control codes.
//
BOOL
SCR_IOControl(
    DWORD Handle,
    DWORD dwIoControlCode,
    PBYTE pInBuf,
    DWORD nInBufSize,
    PBYTE pOutBuf,
    DWORD nOutBufSize,
    PDWORD pBytesReturned
    )
{
    NTSTATUS status;
    PSMARTCARD_EXTENSION pSmartcardExtension = (PSMARTCARD_EXTENSION) Handle;
    if (!ValidateAndEnterDevice(pSmartcardExtension))
    {
        SetLastError(ERROR_BAD_DEVICE);
        ASSERT(FALSE);
        return FALSE;
    }

    if (pSmartcardExtension->ReaderExtension->d_uReaderState != STATE_OPENED)
    {
        SmartcardDebug(DEBUG_ERROR,(TEXT("%s: DeviceIOCTL - invalid state %d\n"), szDriverName,
            pSmartcardExtension->ReaderExtension->d_uReaderState
            ));
        status = ERROR_GEN_FAILURE;
    }
    else {
        ASSERT(pSmartcardExtension->ReaderExtension->ReaderPowerState == 
            PowerReaderWorking);
        status = SmartcardDeviceControl(
            pSmartcardExtension, dwIoControlCode,
            pInBuf, nInBufSize,
            pOutBuf, nOutBufSize,
            pBytesReturned);
    };
    LeaveDevice(pSmartcardExtension);

    return (status == STATUS_SUCCESS ? TRUE: FALSE);
}
// The function Not supported.
DWORD SCR_Read(DWORD Handle, LPVOID pBuffer, DWORD dwNumBytes){return 0;}
DWORD SCR_Write(DWORD Handle, LPCVOID pBuffer, DWORD dwNumBytes){return 0;}
DWORD SCR_Seek(DWORD Handle, long lDistance, DWORD dwMoveMethod){return 0;}

// Power Up and Down Support
void SCR_PowerUp(void)
{
    SmartcardDebug(DEBUG_TRACE,(TEXT("%s: PowerUp() - entered\n"),szDriverName));

}
void SCR_PowerDown(void)
{
    SmartcardDebug(DEBUG_TRACE,(TEXT("%s: PowerDown() - entered\n"),szDriverName));
}

BOOL 
TLP3UpdateReaderState(PSMARTCARD_EXTENSION SmartcardExtension)
{
    BOOL bReturn;
    
    SmartcardLockDevice(SmartcardExtension);
    ASSERT(SmartcardExtension->ReaderExtension->hSerialPort);
    bReturn=GetCommModemStatus(SmartcardExtension->ReaderExtension->hSerialPort,
        &(SmartcardExtension->ReaderExtension->ModemStatus));
    ASSERT(bReturn);
    if (!bReturn) 
        goto ErrorReturn;

    if ((SmartcardExtension->ReaderExtension->ModemStatus & MS_DSR_ON) == 0) {
        SmartcardDebug(
            DEBUG_THREAD,
            (TEXT("%s!TLP3UpdateReaderState: Reader removed\n"),
            szDriverName)
            );
        // During the reader absent, User may switch or remove the card
        // so we treat them as removing card.
        // Card is removed
		/*
        SmartcardExtension->CardCapabilities.ATR.Length = 0;
        SmartcardExtension->ReaderCapabilities.CurrentState = 
                SCARD_ABSENT;
        SmartcardExtension->CardCapabilities.Protocol.Selected = 
                SCARD_PROTOCOL_UNDEFINED;
        bReturn = FALSE;
		*/
            SmartcardExtension->ReaderCapabilities.CurrentState = 
                SCARD_SWALLOWED;

            SmartcardExtension->CardCapabilities.Protocol.Selected = 
                SCARD_PROTOCOL_UNDEFINED;

    } else {

        if (SmartcardExtension->ReaderExtension->ModemStatus & MS_CTS_ON) {

            // Card is inserted
            SmartcardExtension->ReaderCapabilities.CurrentState = 
                SCARD_SWALLOWED;

            SmartcardExtension->CardCapabilities.Protocol.Selected = 
                SCARD_PROTOCOL_UNDEFINED;

            SmartcardDebug(
                DEBUG_THREAD,
                (TEXT("%s!TLP3UpdateReaderState: Smart card inserted\n"),
                szDriverName)
                );

        } else {
            
            // Card is removed
            SmartcardExtension->CardCapabilities.ATR.Length = 0;

            SmartcardExtension->ReaderCapabilities.CurrentState = 
                SCARD_ABSENT;

            SmartcardExtension->CardCapabilities.Protocol.Selected = 
                SCARD_PROTOCOL_UNDEFINED;

            SmartcardDebug(
                DEBUG_THREAD,
                (TEXT("%s!TLP3UpdateReaderState: Smart card removed\n"),
                szDriverName)
                );
        }
    };
    SmartcardExtension->ReaderExtension->ModemStatusChanged=TRUE;
ErrorReturn:
    SmartcardUnlockDevice(SmartcardExtension);
    return bReturn;
}

// Event Track Thread Entry
static DWORD CALLBACK 
TLP3SerialEvent(PVOID pData )
/*++

Routine Description:

    This routine is called in two cases:
    a) CTS changed (card inserted or removed) or
    b) DSR changed (reader has been removed)
    
--*/
{
    PSMARTCARD_EXTENSION SmartcardExtension=(PSMARTCARD_EXTENSION)pData;
    BOOL bReturn;
    DWORD dwEventChanged;
    SmartcardDebug(DEBUG_THREAD | DEBUG_INIT,
        (TEXT("%s: TLP3SerialEvent(%x) - entered\n"),szDriverName,pData));
    bReturn=SetCommMask(SmartcardExtension->ReaderExtension->hSerialPort,
            EV_DSR|EV_CTS);
    ASSERT(bReturn ||  SmartcardExtension->ReaderExtension->d_uReaderState == STATE_CLOSED);

    while (SmartcardExtension->ReaderExtension->d_uReaderState == STATE_OPENED) { // infinit loop
        
        // wait for new event
        dwEventChanged=0;
        bReturn=WaitCommEvent(SmartcardExtension->ReaderExtension->hSerialPort,
                &dwEventChanged,NULL);
        SmartcardDebug(
                    DEBUG_THREAD,
                    (TEXT("%s!TLP3SerialEvent: Serial Event Signaled\n"),
                    szDriverName)
                    );
        ASSERT(bReturn ||  SmartcardExtension->ReaderExtension->d_uReaderState == STATE_CLOSED);
        if (!bReturn || !(dwEventChanged &(EV_DSR|EV_CTS)))
            break;      // usually means the device is being closed
        bReturn = TLP3UpdateReaderState(SmartcardExtension);
        
        // signal event
        SmartcardCompleteCardTracking(SmartcardExtension);
    }
    SmartcardDebug(
                DEBUG_THREAD,
                (TEXT("%s!TLP3SerialEvent: Thread exiting\n"),
                szDriverName)
                );
    return 0; 
}    

BOOL 
GetSerialPort(LPTSTR pSerialPort,LPTSTR ActiveKey)
{
    HKEY hActiveKey;
    DWORD ValType,ValLen;
    DWORD status;
    TCHAR buildInPath[REG_PATH_LEN];

    SmartcardDebug(DEBUG_INIT|DEBUG_TRACE,
        (TEXT("%s:TLP_Init Active Key %s \r\n"),szDriverName,ActiveKey));

    //
    // Get Device Name & Serial Port Device Name
    if ((status=RegOpenKeyEx(HKEY_LOCAL_MACHINE,ActiveKey,0,0,&hActiveKey))!=ERROR_SUCCESS) {
        SmartcardDebug(DEBUG_INIT|DEBUG_ERROR,
            (TEXT("%s: RegOpenKeyEx failed for key %s. Error Code \r\n"),szDriverName,ActiveKey,status));
        return FALSE;
    };
    ValLen=sizeof(buildInPath);
    status = RegQueryValueEx(hActiveKey,DEVLOAD_DEVKEY_VALNAME,NULL,
            &ValType,(LPBYTE)&buildInPath[0],&ValLen);
    RegCloseKey(hActiveKey);
    if (status!=ERROR_SUCCESS) {
        SmartcardDebug(DEBUG_INIT|DEBUG_ERROR,
            (TEXT("%s: RegQueryValueEx failed for name %s. Error Code \r\n"),szDriverName,DEVLOAD_DEVKEY_VALNAME,status));
        return FALSE;
    };

    if ((status=RegOpenKeyEx(HKEY_LOCAL_MACHINE,buildInPath,0,0,&hActiveKey))!=ERROR_SUCCESS) {
        SmartcardDebug(DEBUG_INIT|DEBUG_ERROR,
            (TEXT("%s: RegOpenKeyEx failed for key %s. Error Code \r\n"),szDriverName,ActiveKey,status));
        return FALSE;
    };
    ValLen=DEVNAME_LEN*sizeof(TCHAR);
    status = RegQueryValueEx(hActiveKey,TEXT(TLP_DEVKEY_SERIALPORT),NULL,
            &ValType,(LPBYTE)pSerialPort,&ValLen);
    RegCloseKey(hActiveKey);
    if (status!=ERROR_SUCCESS) {
        SmartcardDebug(DEBUG_INIT|DEBUG_ERROR,
            (TEXT("%s: RegQueryValueEx failed Null buffer for name %s. Error Code \r\n"),szDriverName,TLP_DEVKEY_SERIALPORT,status));
        return FALSE;
    };
    return TRUE;
};


DWORD
GetDeviceName(
    LPTSTR ActivePath,
    LPTSTR szDeviceName
    )
{
    DWORD ValType;
    DWORD ValLen;
    HKEY hCardKey;
    DWORD status;

    //
    // Open active device registry key
    //
    status = RegOpenKeyEx(
                HKEY_LOCAL_MACHINE,
                ActivePath,
                0,
                0,
                &hCardKey);
    if (status) {
        SmartcardDebug(DEBUG_INIT|DEBUG_ERROR,
                 (TEXT("GetDeviceName RegOpenKeyEx(HLM\\%s) returned %d!!!\r\n"),
                  ActivePath, status));
        return status;
    }
    // get our device name (eg. PSC1:)
    ValLen = DEVNAME_LEN*sizeof(TCHAR);
    status = RegQueryValueEx(
                hCardKey,
                DEVLOAD_DEVNAME_VALNAME,
                NULL,
                &ValType,
                (PUCHAR)szDeviceName,
                &ValLen);
    if (status != ERROR_SUCCESS) {
        SmartcardDebug(DEBUG_INIT|DEBUG_ERROR,
                 (TEXT("GetDeviceName - RegQueryValueEx(%s) returned %d\r\n"),
                  DEVLOAD_DEVNAME_VALNAME, status));
    }
    RegCloseKey(hCardKey);
    return status;
}

void
MakeFriendlyName(PSMARTCARD_EXTENSION SmartcardExtension, LPTSTR szFriendlyName)
{
    TCHAR szUnitNoPart[] = L" [ ]";
    szFriendlyName[0] = 0;  // NULL in case IfdType is empty
    mbstowcs(szFriendlyName,SmartcardExtension->VendorAttr.IfdType.Buffer,SmartcardExtension->VendorAttr.IfdType.Length);
    szUnitNoPart[2] = (WCHAR)(SmartcardExtension->VendorAttr.UnitNo % 10 + '0');
    lstrcatW(szFriendlyName,szUnitNoPart);

}

//
// TLP3LoadDevice:
// 1. Allocate and init the SMARTCARDEXTENSION struct
// 2. Configure Serial Port.
// 3. Create Serial Reader Status Changed Thread
// 4. Init the device
//
// ActivePath is the registry path to our device's active key under
// HKEY_LOCAL_MACHINE\Drivers\Active
//
// Return pointer to new device structure or NULL.
//
PSMARTCARD_EXTENSION
TLP3LoadDevice(
    LPTSTR ActiveKey
    )
{
    DWORD status;
    PREADER_EXTENSION readerExtension;
    PSMARTCARD_EXTENSION smartcardExtension;

    static ULONG dataRatesSupported[] = { 9600, 19200, 38400, 57600, 115200 };

    // allocate the device context (including smartcard and reader extension)
    smartcardExtension = LocalAlloc( 
            LPTR, 
            sizeof( SMARTCARD_EXTENSION )
            + sizeof(READER_EXTENSION)
            );

    ASSERT(smartcardExtension);
    if( smartcardExtension == NULL ) 
        return NULL;
   
    //point to the reader extension
    readerExtension = (PREADER_EXTENSION)(smartcardExtension +1);
    smartcardExtension->ReaderExtension = readerExtension;

    SmartcardDebug( DEBUG_TRACE | DEBUG_INIT, 
        ( TEXT("%s!TLP3CreateDevice: Device created\n"),szDriverName));

    if (!GetSerialPort(readerExtension->d_SerialPort,ActiveKey))
    {
        SmartcardDebug(DEBUG_INIT|DEBUG_ERROR,(TEXT("%s: SmartcardInitialize: no COM Port configured\n"),
                    szDriverName));
        LocalFree(smartcardExtension);
        return NULL;
    }

   // Write the version of the lib we use to the smartcard extension
    smartcardExtension->Version = SMCLIB_VERSION;
    smartcardExtension->SmartcardRequest.BufferSize = 
    smartcardExtension->SmartcardReply.BufferSize = MIN_BUFFER_SIZE;

    //
    // Now let the lib allocate the buffer for data transmission
    // We can either tell the lib how big the buffer should be
    // by assigning a value to BufferSize or let the lib
    // allocate the default size
    //
    status = SmartcardInitialize(smartcardExtension);
    if (status != STATUS_SUCCESS) {
        SmartcardDebug(DEBUG_INIT|DEBUG_ERROR,(TEXT("%s: SmartcardInitialize failed - %x\n"),
                    szDriverName, status));
        LocalFree(smartcardExtension);
        return NULL;
    }
    //    setup smartcard extension - callback's
    smartcardExtension->ReaderFunction[RDF_CARD_POWER] = TLP3ReaderPower;
    smartcardExtension->ReaderFunction[RDF_TRANSMIT] = TLP3Transmit;
    smartcardExtension->ReaderFunction[RDF_CARD_TRACKING] = TLP3CardTracking;
    smartcardExtension->ReaderFunction[RDF_SET_PROTOCOL] = TLP3SetProtocol;

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -