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

📄 haldd.cpp

📁 WinCE 3.0 BSP, 包含Inter SA1110, Intel_815E, Advantech_PCM9574 等
💻 CPP
字号:
// -----------------------------------------------------------------------------
//
//  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.
//  Copyright (c) 1999  Microsoft Corporation
//
//
//    written by:     ESG Solution Center Munich
//
//    Module Name:    haldd.cpp
//  
//    abstract:       most ddraw callbacks
//
// -----------------------------------------------------------------------------

#include "precomp.h"

#ifdef DEBUG
#ifndef HAL_ZONE_INIT
#define HAL_ZONE_INIT     GPE_ZONE_INIT
#endif
#endif

#if DXPAK

DWORD WINAPI 
HalGetDriverInfo(LPDDHAL_GETDRIVERINFODATA lpInput) 
{

    DWORD dwSize;
    DEBUGMSG(HAL_ZONE_INIT,(TEXT("GetDriverInfo invoked !!\r\n")));

    lpInput->ddRVal = DDERR_CURRENTLYNOTAVAIL;

    if (IsEqualIID(lpInput->guidInfo, GUID_KernelCallbacks) ) {
        DEBUGMSG(HAL_ZONE_INIT,(TEXT("GUID_KernelCallbacks\r\n")));
        dwSize = min(lpInput->dwExpectedSize, sizeof(DDHAL_DDKERNELCALLBACKS));
        lpInput->dwActualSize = sizeof(DDHAL_DDKERNELCALLBACKS);

        memcpy(lpInput->lpvData, &KernelCallbacks, dwSize);
        lpInput->ddRVal = DD_OK;
    }
    else if (IsEqualIID(lpInput->guidInfo, GUID_HALMemory) ) {
        DEBUGMSG(HAL_ZONE_INIT,(TEXT("GUID_HALMemory\r\n")));
        dwSize = min(lpInput->dwExpectedSize, sizeof(DDHAL_DDHALMEMORYCALLBACKS));
        lpInput->dwActualSize = sizeof(DDHAL_DDHALMEMORYCALLBACKS);

        memcpy(lpInput->lpvData, &HalMemoryCallbacks, dwSize);
        lpInput->ddRVal = DD_OK;
    }
    else if (IsEqualIID(lpInput->guidInfo, GUID_KernelCaps)) {
        DEBUGMSG(HAL_ZONE_INIT,(TEXT("GUID_KernelCaps\r\n")));
        dwSize = min(lpInput->dwExpectedSize, sizeof(DDKERNELCAPS));
        lpInput->dwActualSize = sizeof(DDHAL_DDKERNELCALLBACKS);

        memcpy(lpInput->lpvData, &KernelCaps, dwSize );
        lpInput->ddRVal = DD_OK;
    }
    else if (IsEqualIID(lpInput->guidInfo, GUID_ColorControlCallbacks)) {
        DEBUGMSG(HAL_ZONE_INIT,(TEXT("GUID_ColorControlCallbacks\r\n")));
        dwSize = min(lpInput->dwExpectedSize, sizeof(DDHAL_DDCOLORCONTROLCALLBACKS));
        lpInput->dwActualSize = sizeof(DDHAL_DDCOLORCONTROLCALLBACKS);

        memcpy(lpInput->lpvData, &ColorControlCallbacks, dwSize);
        lpInput->ddRVal = DD_OK;
    }
    else if (IsEqualIID(lpInput->guidInfo, GUID_MiscellaneousCallbacks) ) {
        DEBUGMSG(HAL_ZONE_INIT,(TEXT("GUID_MiscellaneousCallbacks\r\n")));
        dwSize = min(lpInput->dwExpectedSize, sizeof(DDHAL_DDMISCELLANEOUSCALLBACKS));
        lpInput->dwActualSize = sizeof(DDHAL_DDMISCELLANEOUSCALLBACKS);

        memcpy(lpInput->lpvData, &MiscellaneousCallbacks, dwSize);
        lpInput->ddRVal = DD_OK;
    }
#ifdef VIDEOPORT_SUPPORT
    else if (IsEqualIID(lpInput->guidInfo, GUID_VideoPortCallbacks)) {
        DEBUGMSG(HAL_ZONE_INIT,(TEXT("GUID_VideoPortCallbacks\r\n")));
        dwSize = min(lpInput->dwExpectedSize, sizeof(DDHAL_DDVIDEOPORTCALLBACKS));
        lpInput->dwActualSize = sizeof(DDHAL_DDVIDEOPORTCALLBACKS);

        memcpy(lpInput->lpvData, &VideoPortCallbacks, dwSize);
        lpInput->ddRVal = DD_OK;
    }
    else if (IsEqualIID(lpInput->guidInfo, GUID_VideoPortCaps)) {
        DEBUGMSG(HAL_ZONE_INIT,(TEXT("GUID_VideoPortCaps\r\n")));
        dwSize = min(lpInput->dwExpectedSize, sizeof(DDVIDEOPORTCAPS));
        lpInput->dwActualSize = sizeof(DDVIDEOPORTCAPS);

        memcpy(lpInput->lpvData, &VideoPortCaps, dwSize);
        lpInput->ddRVal = DD_OK;
    }
#endif //VIDEOPORT_SUPPORT

#if 0
    else if (IsEqualIID(lpInput->guidInfo, GUID_NonLocalVidMemCaps) )
    {
        DEBUGMSG(HAL_ZONE_INIT,(TEXT("GUID_NonLocalVidMemCaps\r\n")));
        dwSize = min(lpInput->dwExpectedSize, sizeof(DDHAL_DDCOLORCONTROLCALLBACKS));
        lpInput->dwActualSize = sizeof(DDHAL_DDCOLORCONTROLCALLBACKS);

        memcpy(lpInput->lpvData, &VideoPortCaps, dwSize);
        lpInput->ddRVal = DD_OK;
    }
#endif //0
#ifdef DIRECT3D_SUPPORT
    else if (IsEqualIID(lpInput->guidInfo, GUID_D3DCallbacks2) )
    {
        DEBUGMSG(HAL_ZONE_INIT,(TEXT("GUID_D3DCallbacks2\r\n")));
        D3DHAL_CALLBACKS2 D3DCallbacks2;
        memset(&D3DCallbacks2, 0, sizeof(D3DCallbacks2));

        dwSize = min(lpInput->dwExpectedSize, sizeof(D3DHAL_CALLBACKS2));
        lpInput->dwActualSize = sizeof(D3DHAL_CALLBACKS2);

        D3DCallbacks2.dwSize = dwSize;
        // set up D3DCallbacks2 elements

        memcpy(lpInput->lpvData, &D3DCallbacks2, dwSize);
        lpInput->ddRVal = DD_OK;
    }
    else if (IsEqualIID(lpInput->guidInfo, GUID_D3DExtendedCaps) )
    {
        DEBUGMSG(HAL_ZONE_INIT,(TEXT("GUID_D3DExtendedCaps\r\n")));
        D3DHAL_D3DEXTENDEDCAPS ec;
        memset(&ec, 0, sizeof(ec));
        dwSize = min(lpInput->dwExpectedSize, sizeof(D3DHAL_D3DEXTENDEDCAPS));
        ec.dwSize = sizeof(ec);

        // set up ec elements
        
        memcpy(lpInput->lpvData, &ec, dwSize);
        lpInput->ddRVal = DD_OK;
    }
#endif // DIRECT3D_SUPPORT

    if( lpInput->ddRVal != DD_OK )
    {
        DEBUGMSG(HAL_ZONE_INIT,(TEXT("HalGetDriverInfo: Currently not available\r\n")));
    }

    return DDHAL_DRIVER_HANDLED;
}


//////////////////////////// DDHAL_DDCALLBACKS ////////////////////////////

DWORD WINAPI 
HalDestroyDriver( LPDDHAL_DESTROYDRIVERDATA pd )
{
    DEBUGENTER( HalDestroyDriver );
    /*
    typedef struct _DDHAL_DESTROYDRIVERDATA
    {
        LPDDRAWI_DIRECTDRAW_GBL     lpDD;           // driver struct
        HRESULT                     ddRVal;         // return value
        LPDDHAL_DESTROYDRIVER       DestroyDriver;  // PRIVATE: ptr to callback
    } DDHAL_DESTROYDRIVERDATA;
    */

    pd->ddRVal = DD_OK;
    return DDHAL_DRIVER_HANDLED;
}

// not to be confused with
// DWORD WINAPI HalSetColorKey( LPDDHAL_SETCOLORKEYDATA pd )
DWORD WINAPI 
HalSetColorKey( LPDDHAL_DRVSETCOLORKEYDATA pd )
{
    DEBUGENTER( HalSetColorKey );
    /*
    typedef struct _DDHAL_DRVSETCOLORKEYDATA
    {
        LPDDRAWI_DDRAWSURFACE_LCL   lpDDSurface;    // surface struct
        DWORD                       dwFlags;        // flags
        DDCOLORKEY                  ckNew;          // new color key
        HRESULT                     ddRVal;         // return value
        LPDDHAL_SETCOLORKEY         SetColorKey;    // PRIVATE: ptr to callback
    } DDHAL_DRVSETCOLORKEYDATA;
    */

    pd->ddRVal = DD_OK;
    return DDHAL_DRIVER_HANDLED;
}

DWORD WINAPI 
HalSetMode( LPDDHAL_SETMODEDATA pd )
{
    DEBUGENTER( HalSetMode );
    /*
    typedef struct _DDHAL_SETMODEDATA
    {
        LPDDRAWI_DIRECTDRAW_GBL lpDD;               // driver struct
        DWORD               dwModeIndex;            // new mode
        HRESULT             ddRVal;                 // return value
        LPDDHAL_SETMODE     SetMode;                // PRIVATE: ptr to callback
        BOOL                inexcl;                 // in exclusive mode
    } DDHAL_SETMODEDATA;
    */

    // implementation
    pd->ddRVal = DD_OK;

    return DDHAL_DRIVER_NOTHANDLED; // We only support 1 mode
}

DWORD WINAPI 
HalWaitForVerticalBlank( LPDDHAL_WAITFORVERTICALBLANKDATA pd )
{
    DEBUGENTER( HalWaitForVerticalBlank );
    /*
    typedef struct _DDHAL_WAITFORVERTICALBLANKDATA
    {
        LPDDRAWI_DIRECTDRAW_GBL lpDD;               // driver struct
        DWORD                   dwFlags;            // flags
        DWORD                   bIsInVB;            // is in vertical blank
        DWORD                   hEvent;             // event
        HRESUL                  ddRVal;             // return value
        LPDDHAL_WAITFORVERTICALBLANK WaitForVerticalBlank;
                                                    // PRIVATE: ptr to callback
    } DDHAL_WAITFORVERTICALBLANKDATA;
    */

    GPE *pGPE=(GPE *)pd->lpDD->hInstance;

    switch (pd->dwFlags) {
    case DDWAITVB_I_TESTVB:
        // If TESTVB, it's just a request for the current vertical blank
        // status:
        if (pGPE->InVBlank())
            pd->bIsInVB = TRUE;
        else
            pd->bIsInVB = FALSE;
        break;
    case DDWAITVB_BLOCKBEGIN:
        // If BLOCKBEGIN is requested, we wait until the vertical blank
        // is over, and then wait for the display period to end:
        while (pGPE->InVBlank());
        while (!pGPE->InVBlank());
        break;
    case DDWAITVB_BLOCKEND:
        // If BLOCKEND is requested, we wait for the vblank interval to end:
        while (!pGPE->InVBlank());
        while (pGPE->InVBlank());
        break;

    default: // anything else is an error
    case DDWAITVB_BLOCKBEGINEVENT:
        // we don't support this
        return DDHAL_DRIVER_NOTHANDLED;
    }

    pd->ddRVal = DD_OK;
    return DDHAL_DRIVER_HANDLED;
}

DWORD WINAPI 
HalGetScanLine( LPDDHAL_GETSCANLINEDATA pd )
{
    DEBUGENTER( HalGetScanLine );
    /*
    typedef struct _DDHAL_GETSCANLINEDATA
    {
        LPDDRAWI_DIRECTDRAW_GBL     lpDD;           // driver struct
        DWORD                       dwScanLine;     // returned scan line
        HRESULT                     ddRVal;         // return value
        LPDDHAL_GETSCANLINE         GetScanLine;    // PRIVATE: ptr to callback
    } DDHAL_GETSCANLINEDATA;
    */

    CT69000 *pGPE=(CT69000 *)pd->lpDD->hInstance;

    pd->dwScanLine = pGPE->ScanLine();

    pd->ddRVal = DD_OK;
    return DDHAL_DRIVER_HANDLED;
}

DWORD WINAPI 
HalSetExclusiveMode( LPDDHAL_SETEXCLUSIVEMODEDATA pd )
{
    DEBUGENTER( HalSetExclusiveMode );
    /*typedef struct _DDHAL_SETEXCLUSIVEMODEDATA
    {
        LPDDRAWI_DIRECTDRAW_GBL    lpDD;             // driver struct
        DWORD                      dwEnterExcl;      // TRUE if entering exclusive mode, FALSE is leaving
        DWORD                      dwReserved;       // reserved for future use
        HRESULT                    ddRVal;           // return value
        LPDDHAL_SETEXCLUSIVEMODE   SetExclusiveMode; // PRIVATE: ptr to callback
    } DDHAL_SETEXCLUSIVEMODEDATA;*/

    //
    //  This is one of our options:
    //  demote all video memory bitmaps if we enter exclusive mode
    //
    if (pd->dwEnterExcl)
    {
        CT69000Surf *p=NULL;
        p->DemoteSurf(TRUE);
    }

    // implementation
    pd->ddRVal = DD_OK;

    return DDHAL_DRIVER_HANDLED;
}

DWORD WINAPI 
HalGetVidMem( LPDDHAL_HALGETVIDMEMDATA pd )
{
    DEBUGENTER( HalGetVidMem );
    /*typedef struct _DDHAL_HALGETVIDMEMDATA
    {
        DWORD           dwSize;                 // Size of this structure
        LPDDSCAPS       lpDDSCaps;              // Hardware caps of 
                                                // proposed surface
        LPDWORD         lpdwTotal;              // Total amount of memory
        LPDWORD         lpdwFree;               // Available amount of memory
        HRESULT         ddrval;
    } DDHAL_HALGETVIDMEMDATA;*/

    //
    //  bugbug: pd MUST contain LPDDRAWI_DIRECTDRAW_GBL 
    //
    // CT69000 *pGPE=(CT69000 *)pd->lpDD->hInstance;

    //*(pd->lpdwTotal) = pGPE->VideoMemorySize();
    //*(pd->lpdwFree)  = pGPE->VideoMemoryFree();

    pd->ddrval = DD_OK;

    return DDHAL_DRIVER_NOTHANDLED;
}

#endif

⌨️ 快捷键说明

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