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

📄 usbfndrv.h

📁 扬创yc2440-t2-dm9000 ce 5.0 bsp
💻 H
字号:
//
// Copyright (c) Microsoft Corporation.  All rights reserved.
//
//
// Use of this source code is subject to the terms of the Microsoft end-user
// license agreement (EULA) under which you licensed this SOFTWARE PRODUCT.
// If you did not accept the terms of the EULA, you are not authorized to use
// this source code. For a copy of the EULA, please see the LICENSE.RTF on your
// install media.
//
/*++
THIS CODE AND INFORMATION IS PROVIDED "AS IS" WITHOUT WARRANTY OF
ANY KIND, EITHER EXPRESSED OR IMPLIED, INCLUDING BUT NOT LIMITED TO
THE IMPLIED WARRANTIES OF MERCHANTABILITY AND/OR FITNESS FOR A
PARTICULAR PURPOSE.

Module Name:  

Abstract:

    Platform dependent Serial definitions for usb function
    controller.

Notes: 
--*/
#ifndef __USBFNDRV_H_
#define __USBFNDRV_H_
#include <usbfntypes.h>
#include <CMthread.h>
#include <CRegEdit.h>
#include <CSync.h>
#include <cserpdd.h>

#define REG_USB_DEVICE_CLASS_NAME   TEXT("USBFNDeviceClass")
#define REG_USB_DEVICE_CLASS_VAL    REG_DWORD
#define UMS_REG_INTERFACE_SUBCLASS_VAL      (_T("InterfaceSubClass"))
#define UMS_REG_INTERFACE_PROTOCOL_VAL      (_T("InterfaceProtocol"))
#define UMS_REG_MAX_PACKET_SIZE_0_VAL       (_T("MaxPacketSize0"))
#define UMS_REG_VENDOR_VAL                  (_T("Vendor"))
#define UMS_REG_PRODUCT_VAL                 (_T("Product"))
#define UMS_REG_TIMEOUT_VAL                 (_T("Timeout"))


class CUsbFuncPipe;
class CUsbFn;
class USBSerialFn;
class CUsbFuncTransfer {
public:
    CUsbFuncTransfer(CUsbFuncPipe *hPipe, DWORD dwFlags,DWORD cbBuffer, PVOID pvBuffer, DWORD dwBufferPhysicalAddress);
    ~CUsbFuncTransfer();
    BOOL    Init();
    BOOL    IssueTransfer(DWORD dwLength = MAXDWORD);
    BOOL    IsTransferClosed() { return (m_ufnTransfer==NULL);};
    BOOL    IsTransferComplete() { return (IsTransferClosed() || WaitForTransferComplete(0));};
    BOOL    WaitForTransferComplete(DWORD dwTicks);
    HANDLE  GetCompleteEventHandle() { return m_hCompleteEvent; };
    BOOL   GetTransferStatus(PDWORD pdwBytesTranfered, PDWORD pdwError);
    BOOL   CloseTransfer();
    BOOL   AbortTransfer();
    PVOID   GetBufferPtr() { return m_pvBuffer; };
    DWORD   GetBufferSize() { return m_dwBufferSize; };
private:
    static DWORD WINAPI CompleteNotificationStub(PVOID pvNotifyParameter);
protected:
    DWORD WINAPI  CompleteNotification();
private:
    HANDLE  m_hCompleteEvent;
    const DWORD   m_dwFlags;
    CUsbFuncPipe * const m_pPipe;
    UFN_TRANSFER  m_ufnTransfer;
    const DWORD   m_dwBufferSize;
    const PVOID   m_pvBuffer;
    const DWORD   m_dwPhysAddr;
    
};
#define MAX_TRANSFER 4
class CUsbFuncPipe : public CMiniThread, public CLockObject {
public:
    CUsbFuncPipe(USBSerialFn *pSerialFn,UFN_HANDLE hDevice,PCUFN_FUNCTIONS pUfnFuncs,UCHAR bEndpointAddr,BOOL fRead,DWORD dwMaxPacketSize,  DWORD dwMaxTransferSize, DWORD dwMaxNumOfTransfer);
    ~CUsbFuncPipe();
    virtual BOOL Init();
    BOOL IsPipeOpened() { return m_hPipe!=NULL; };
    BOOL IsAnySpaceAvailable();
    BOOL OpenPipe();
    void ClosePipe();
private:
    DWORD IncIndex(DWORD dwIndex) { return ((dwIndex+1<m_dwNumOfTransfer)?dwIndex+1:0); } ;
public:
    DWORD ReadData(PUCHAR pRxBuffer,ULONG *pBufflen);  
    void WriteData(PUCHAR pRxBuffer,ULONG *pBufflen);  
    BOOL CancelTransfer();
    BOOL  TransferComplete( CUsbFuncTransfer * pTransfer) {  
#if DEBUG
        if (pTransfer) {
            for (DWORD dwIndex =0 ; dwIndex < m_dwNumOfTransfer; dwIndex++)
                if (m_pTransferArray[dwIndex] == pTransfer)
                    return TRUE;
        }
        ASSERT(FALSE);
#endif
        return TRUE;
    }
    PCUFN_FUNCTIONS GetFunctionPtr() { return m_pUfnFuncs; };
    HANDLE GetDeviceHandle() { return m_hDevice; };
    HANDLE GetPipeHandle() { return m_hPipe; };
private:
    UFN_PIPE  m_hPipe;
    const HANDLE  m_hDevice;
    const BYTE    m_bEndpointAddr;
    const BOOL    m_fRead;
    const PCUFN_FUNCTIONS m_pUfnFuncs;  
    USBSerialFn * const m_pSerialFn;
    PBYTE   m_pbBuffer;
    DWORD   m_dwBufferSize;
    DWORD   m_dwBufferPhysAddr;

    HANDLE      m_TerminateEvent;
    const DWORD m_dwNumOfTransfer;
    const DWORD m_dwTranferSize;
    const DWORD m_dwMaxPacketSize;
    DWORD       m_dwCompleteIndex;
    DWORD       m_dwWriteIndex;
    DWORD       m_dwCurPosition;
    BOOL        m_fZeroLengthNeeded;
    CUsbFuncTransfer *m_pTransferArray[MAX_TRANSFER];
private:
    virtual DWORD ThreadRun();   // IST
    void WriteDataOnce(PUCHAR pTxBuffer, ULONG *pBuffLen) ;
    
};

#define SET_CONTROL_LINE_STATE  0x22

enum CONTROL_RESPONSE {
    CR_SUCCESS = 0,
    CR_SUCCESS_SEND_CONTROL_HANDSHAKE, // Use if no data stage
    CR_STALL_DEFAULT_PIPE,
    CR_UNHANDLED_REQUEST,
};


class CUsbFn  {
public:
    CUsbFn(LPCTSTR lpActivePath);
    virtual ~CUsbFn();
    BOOL    Init();
// Function related to USB Class Specific function.
    virtual void CableDetached() = 0;
    virtual void CableAttached() = 0;
    virtual DWORD ModemSignal(DWORD dwNewModemStatus) { return 0;};
// USB function
    virtual CONTROL_RESPONSE HandleClearFeature(USB_DEVICE_REQUEST udr) { return CR_SUCCESS;};
    virtual CONTROL_RESPONSE HandleClassRequest(USB_DEVICE_REQUEST udr);
// Control Line State - sent to device on default control pipe
#define USB_COMM_DTR    0x0001
#define USB_COMM_RTS    0x0002    
    void HandleRequest( DWORD dwMsg, USB_DEVICE_REQUEST udr );
protected:
    UFN_HANDLE  m_hDevice;
    UFN_FUNCTIONS   m_UfnFuncs;
    PCUFN_FUNCTIONS m_pUfnFuncs;
    PVOID       m_pvInterface;
    LPTSTR      m_lpActivePath;
    BOOL    m_fInterrupt ;        
    // Default Endpoint Handling
protected:
    UFN_PIPE m_hDefaultPipe;
    UFN_BUS_SPEED m_CurrentSpeed;
    static BOOL WINAPI DeviceNotifyStub(PVOID   pvNotifyParameter, DWORD   dwMsg, DWORD   dwParam);
    BOOL DeviceNotify(DWORD dwMsg, DWORD dwParam);
};

class USBSerialFn: public CSerialPDD ,public CUsbFn {
public:
    USBSerialFn(LPTSTR lpActivePath, PVOID pMdd, PHWOBJ pHwObj );
    ~USBSerialFn();
    virtual BOOL Init();
private:
    BOOL OpenPipe(CUsbFuncPipe **ppPipe,UFN_HANDLE hDevice,PCUFN_FUNCTIONS pUfnFuncs,UCHAR bEndpointAddr,BOOL fRead,DWORD dwMaxPacketSize, DWORD dwMaxTransferSize, DWORD dwMaxNumOfTransfer) {
        PREFAST_ASSERT(ppPipe!=NULL);        
        m_HardwareLock.Lock();
        if ( *ppPipe == NULL) {
            *ppPipe = new CUsbFuncPipe ( this,hDevice,pUfnFuncs,bEndpointAddr,fRead,dwMaxPacketSize,dwMaxTransferSize,dwMaxNumOfTransfer);
            if (*ppPipe && !(*ppPipe)->Init()) {
                delete *ppPipe;
                *ppPipe = NULL;
            }
            if (*ppPipe) {
                (*ppPipe)->OpenPipe();
            }
        }
        m_HardwareLock.Unlock();        
        return (*ppPipe!=NULL);
    };
    BOOL ClosePipe (CUsbFuncPipe **ppPipe) {
        PREFAST_ASSERT(ppPipe!=NULL);
        m_HardwareLock.Lock();
        if ( *ppPipe!= NULL) {
            delete *ppPipe ;
            *ppPipe = NULL;
        }
        m_HardwareLock.Unlock();
        return TRUE;
    }
public:
    BOOL OpenBulkIn(UFN_HANDLE hDevice,PCUFN_FUNCTIONS pUfnFuncs,UCHAR bEndpointAddr,BOOL fRead,DWORD dwMaxPacketSize, DWORD dwMaxTransferSize, DWORD dwMaxNumOfTransfer) {
        return OpenPipe(&m_pBulkIn,hDevice,pUfnFuncs,bEndpointAddr,fRead,dwMaxPacketSize,dwMaxTransferSize,dwMaxNumOfTransfer);
    };
    BOOL OpenBulkOut(UFN_HANDLE hDevice,PCUFN_FUNCTIONS pUfnFuncs,UCHAR bEndpointAddr,BOOL fRead,DWORD dwMaxPacketSize, DWORD dwMaxTransferSize, DWORD dwMaxNumOfTransfer) {
        return OpenPipe(&m_pBulkOut,hDevice,pUfnFuncs,bEndpointAddr,fRead,dwMaxPacketSize,dwMaxTransferSize,dwMaxNumOfTransfer);
    }
    BOOL OpenInterruptIn(UFN_HANDLE hDevice,PCUFN_FUNCTIONS pUfnFuncs,UCHAR bEndpointAddr,BOOL fRead,DWORD dwMaxPacketSize, DWORD dwMaxTransferSize, DWORD dwMaxNumOfTransfer) {
        return OpenPipe(& m_pInterruptIn, hDevice,pUfnFuncs,bEndpointAddr,fRead,dwMaxPacketSize,dwMaxTransferSize,dwMaxNumOfTransfer);
    }
    BOOL CloseBulkIn() { return ClosePipe(&m_pBulkIn);};
    BOOL CloseBulkOut() { return ClosePipe(&m_pBulkOut); };
    BOOL CloseInterruptIn() { return ClosePipe(&m_pInterruptIn); };
private:
    CUsbFuncPipe * m_pBulkIn;
    CUsbFuncPipe * m_pBulkOut;
    CUsbFuncPipe * m_pInterruptIn;
    DWORD       m_curHostModemStatus;
public:
    BOOL    EndpointNotification(CUsbFuncPipe * pPipe);
public: // USB Class Specific.
    virtual void CableDetached();
    virtual void CableAttached();
    virtual DWORD   ModemSignal(DWORD dwNewModemStatus) {
        m_curHostModemStatus = dwNewModemStatus;
        NotifyPDDInterrupt(INTR_MODEM);
        return m_curHostModemStatus;
    }
//
//Power Managment Operation
    virtual void    SerialRegisterBackup() {;};
    virtual void    SerialRegisterRestore() {;};
// 
//  Tx Function.
public:
    virtual BOOL    InitXmit(BOOL ) { return TRUE;};
    virtual void    XmitInterruptHandler(PUCHAR pTxBuffer, ULONG *pBuffLen);
    virtual void    XmitComChar(UCHAR ComChar) ;
    virtual BOOL    EnableXmitInterrupt(BOOL /*bEnable*/) { return TRUE; };
    virtual BOOL    CancelXmit() ;
//
//  Rx Function.
    virtual BOOL    InitReceive(BOOL ) { return TRUE; };
    virtual ULONG   ReceiveInterruptHandler(PUCHAR pRxBuffer,ULONG *pBufflen);
    virtual ULONG   CancelReceive() ;
// 
//  Line Function is meaningless. fake it.
    virtual BOOL    InitLine(BOOL ) { return TRUE; };
    virtual void    LineInterruptHandler() {;};
    virtual void    SetBreak(BOOL ) { ;     };
    virtual BOOL    SetBaudRate(ULONG ,BOOL ) { return TRUE; };
    virtual BOOL    SetByteSize(ULONG ) { return TRUE; };
    virtual BOOL    SetParity(ULONG ) { return TRUE; };
    virtual BOOL    SetStopBits(ULONG StopBits) { return TRUE; };
//
//  Modem
private:
//D2      DSR state  (1=Active, 0=Inactive)
//D1      CTS state  (1=Active, 0=Inactive)
//D0      Data Available  - (1=Host should read IN endpoint, 0=No data currently available)
#define USBFN_SERIAL_DSR_SET 0x4
#define USBFN_SERIAL_CTS_SET 0x2
#define USBFN_SERIAL_DATA_AVAILABLE 0x1
    void SetModemSignal(BOOL bSet, BYTE bBitSet) ;
public:
    virtual BOOL    InitModem(BOOL ) { return TRUE; };
    virtual void    ModemInterruptHandler() {GetModemStatus();} // This is Used to Indicate Modem Signal Changes.
    virtual ULONG   GetModemStatus();
    virtual void    SetDTR(BOOL bSet) { return SetModemSignal(bSet, USBFN_SERIAL_DSR_SET); };
    virtual void    SetRTS(BOOL bSet) { return SetModemSignal(bSet, USBFN_SERIAL_CTS_SET); };
private:
    BYTE    m_bModemSetState[2];
    BYTE    m_bOldModemState;
    DWORD   m_bOldHostModemStatus;

};
#endif


⌨️ 快捷键说明

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