亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? hif.c

?? Atheros Communications AR6001 WLAN Driver for SDIO installation Read Me March 26,2007 (based on
?? C
字號:
//------------------------------------------------------------------------------
// <copyright file="hif.c" company="Atheros">
//    Copyright (c) 2006 Microsoft Corporation.  All rights reserved.
//    Copyright (c) 2006 Atheros Corporation.  All rights reserved.
//
//    The use and distribution terms for this software are covered by the
//    Microsoft Limited Permissive License (Ms-LPL) 
//    http://www.microsoft.com/resources/sharedsource/licensingbasics/limitedpermissivelicense.mspx 
//    which can be found in the file MS-LPL.txt at the root of this distribution.
//    By using this software in any fashion, you are agreeing to be bound by
//    the terms of this license.
//
//    You must not remove this notice, or any other, from this software.
// </copyright>
// 
// <summary>
//    Windows CE Wifi Driver for AR-6000
// </summary>
//------------------------------------------------------------------------------
//==============================================================================
// HIF CF source
//
// Author(s): ="Atheros"
//==============================================================================

#include "hif_internal.h"
#include "athtypes.h"

/* ------ Forward declarations ------ */

static BOOL
hifDeviceInserted(CF_DEVICE_HANDLE cfHandle);

static VOID
hifDeviceRemoved(CF_DEVICE_HANDLE cfHandle);

static VOID
hifISRHandler(CF_DEVICE_HANDLE cfHandle,A_BOOL *callDsr);

static void
hifDSRHandler(CF_DEVICE_HANDLE cfHandle);

static HIF_DEVICE *
addHifDevice(CF_DEVICE_HANDLE cfHandle);

static HIF_DEVICE *
getHifDevice(CF_DEVICE_HANDLE cfHandle);

static VOID
delHifDevice(CF_DEVICE_HANDLE cfHandle);

/* ------ Global Variables ------ */

HIF_DEVICE hifDevice[HIF_MAX_DEVICES];

HTC_CALLBACKS htcCallbacks;

CF_FUNCTION  cfFunction;


void
HIFRegisterCallbacks(HTC_CALLBACKS *callbacks)
{
    A_STATUS    status;
    
    /* Store the callback and event handlers */
    htcCallbacks.deviceInsertedHandler = callbacks->deviceInsertedHandler;
    htcCallbacks.deviceRemovedHandler  = callbacks->deviceRemovedHandler;
    htcCallbacks.deviceSuspendHandler  = callbacks->deviceSuspendHandler;
    htcCallbacks.deviceResumeHandler   = callbacks->deviceResumeHandler;
    htcCallbacks.deviceWakeupHandler   = callbacks->deviceWakeupHandler;
    htcCallbacks.rwCompletionHandler   = callbacks->rwCompletionHandler;
    htcCallbacks.deviceInterruptDisabler = callbacks->deviceInterruptDisabler;
    htcCallbacks.deviceInterruptEnabler = callbacks->deviceInterruptEnabler;
    htcCallbacks.dsrHandler            = callbacks->dsrHandler;

    /* Register the callback handlers with the lower driver */
    cfFunction.pName      = "cf_wlan";
    cfFunction.pProbe     = hifDeviceInserted;
    cfFunction.pRemove    = hifDeviceRemoved;
    cfFunction.pIsr       = hifISRHandler;
    cfFunction.pDsr       = hifDSRHandler;

    status = CF_RegisterFunction(&cfFunction);

    AR_DEBUG_ASSERT(status == A_OK);
}

A_STATUS 
HIFReadWrite(HIF_DEVICE *device, 
             A_UINT32 address, 
             A_UCHAR *buffer, 
             A_UINT32 length, 
             HIF_REQUEST *request, 
             void *context) 
{
    CF_REQUEST cfRequest;
	A_STATUS   status;
    A_UINT32   remainingLen;
    A_UINT32   curPos;
 
    HIF_DEBUG_PRINTF(ATH_LOG_TRC, "HIFReadWrite: Enter\n", device);
    
	A_MEMZERO(&cfRequest, sizeof(CF_REQUEST));

	if (request->emode == HIF_SYNCHRONOUS) {
		HIF_DEBUG_PRINTF(ATH_LOG_INF, "HIFReadWrite : Execution mode: Synchronous\n");
	} else if (request->emode == HIF_ASYNCHRONOUS) {
		HIF_DEBUG_PRINTF(ATH_LOG_INF, ("HIFReadWrite: Execution mode:Asynchronous\n"));
	} else {
		HIF_DEBUG_PRINTF(ATH_LOG_ERR, 
					"Invalid execution mode: %d\n", request->emode);
		return A_ERROR;
	}

    if (request->direction == HIF_WRITE) {
        cfRequest.flags |= CFREQ_FLAGS_DATA_WRITE;
        HIF_DEBUG_PRINTF(ATH_LOG_INF, ("HifReadWrite: Direction: Write\n"));
    } else if (request->direction == HIF_READ) {
        HIF_DEBUG_PRINTF(ATH_LOG_INF, ("HifReadWrite: Direction: Read\n"));
    } else {
        HIF_DEBUG_PRINTF(ATH_LOG_ERR, 
                        "Invalid direction: %d\n", request->direction);
        return A_ERROR;
    }

    if (request->amode == HIF_FIXED_ADDRESS) {
		cfRequest.flags |= CFREQ_FLAGS_FIXED_ADDRESS;
        HIF_DEBUG_PRINTF(ATH_LOG_INF, ("Address mode: Fixed\n"));
    } else if (request->amode == HIF_INCREMENTAL_ADDRESS) {
        HIF_DEBUG_PRINTF(ATH_LOG_INF, ("Address mode: Incremental\n"));
    } else {
        HIF_DEBUG_PRINTF(ATH_LOG_ERR, 
                        "Invalid address mode: %d\n", request->amode);
        return A_ERROR;
    }

	if (HIF_IS_MBOX_ADDR(address) ) {
        address = address & ~(HIF_MBOX_WIDTH-1);

#define BLK_SZ  (HIF_MBOX_WIDTH - 2)
        remainingLen = length;
        curPos = 0;

        while (remainingLen > BLK_SZ) {
		    cfRequest.address = address;
		    cfRequest.length = BLK_SZ;
			cfRequest.pDataBuffer = &buffer[curPos];

            if (request->dmode == HIF_BYTE_BASIS) {
    		    status = CF_BusRequest(device->cfHandle, &cfRequest, 8);
            } else {
    		    status = CF_BusRequest(device->cfHandle, &cfRequest, 16);
            }

    		if (status != A_OK) {
        		HIF_DEBUG_PRINTF(ATH_LOG_ERR, ("HIF Write failed\n"));
        		return A_ERROR;
    		}

            curPos += BLK_SZ;
            remainingLen -= BLK_SZ;
		}
		cfRequest.pDataBuffer = &buffer[curPos];
        cfRequest.address = address + HIF_MBOX_WIDTH - remainingLen;
		cfRequest.length = remainingLen;

#ifdef ONLY_16BIT
    	status = CF_BusRequest(device->cfHandle, &cfRequest, 16);
#else
        if (request->dmode == HIF_BYTE_BASIS) {
    		status = CF_BusRequest(device->cfHandle, &cfRequest, 8);
        } else {
    		status = CF_BusRequest(device->cfHandle, &cfRequest, 16);
        }
#endif

   		if (status != A_OK) {
        	HIF_DEBUG_PRINTF(ATH_LOG_ERR, ("HIF Write failed\n"));
        	return A_ERROR;
   		}

	} else {
		cfRequest.address = address;
        cfRequest.pDataBuffer = buffer;
	    cfRequest.length = length;
#ifdef ONLY_16BIT
    	status = CF_BusRequest(device->cfHandle, &cfRequest, 16);
#else
    	status = CF_BusRequest(device->cfHandle, &cfRequest, 8);
#endif
	}

    
    HIF_DEBUG_PRINTF(ATH_LOG_TRC, "HIFReadWrite: Exit\n", device);

    return status;
}

void
HIFShutDownDevice(HIF_DEVICE *device)
{
    A_STATUS status;
    
    HIF_DEBUG_PRINTF(ATH_LOG_TRC, "hifShutDownDevice \n");
    /* Unregister with bus driver core */
    status = CF_UnregisterFunction(&cfFunction);
}

static void
hifISRHandler(CF_DEVICE_HANDLE cfHandle,A_BOOL *callDsr)
{
    A_STATUS    status;
    HIF_DEVICE *device;

    device = getHifDevice(cfHandle);
    HIF_DEBUG_PRINTF(ATH_LOG_TRC, "hifIsrHandler: Enter\n");

	status = htcCallbacks.deviceInterruptDisabler(device, callDsr);
	AR_DEBUG_ASSERT(status == A_OK);
        
    HIF_DEBUG_PRINTF(ATH_LOG_TRC, "hifIsrHandler: Exit\n");

    return;
}

static void
hifDSRHandler(CF_DEVICE_HANDLE cfHandle)
{
    A_STATUS    status;
    HIF_DEVICE *device;

	device = getHifDevice(cfHandle);
    HIF_DEBUG_PRINTF(ATH_LOG_TRC, "hifDsrHandler: Enter\n");

    status = htcCallbacks.dsrHandler(device);
    
    AR_DEBUG_ASSERT(status == A_OK);
    
	htcCallbacks.deviceInterruptEnabler(device);

    HIF_DEBUG_PRINTF(ATH_LOG_TRC, "hifDsrHandler: Exit\n");
}


static BOOL
hifDeviceInserted(CF_DEVICE_HANDLE cfHandle)
{
    HIF_DEVICE *device;

    device = addHifDevice(cfHandle);
    HIF_DEBUG_PRINTF(ATH_LOG_TRC, "hifDeviceInserted: Enter\n");

    HIF_DEBUG_PRINTF(ATH_LOG_INF, "hifDeviceInsetred: Device = %p\n",device);

    /* Inform HTC */
    if ((htcCallbacks.deviceInsertedHandler(device)) != A_OK) {
        HIF_DEBUG_PRINTF(ATH_LOG_ERR, "hifDeviceInserted: HTC failed device inserted\n");
        return FALSE;
    }
    
    HIF_DEBUG_PRINTF(ATH_LOG_TRC, "hifDeviceInserted: Exit\n");

    return TRUE;
}

void
HIFAckInterrupt(HIF_DEVICE *device)
{
	return;
}

void
HIFUnMaskInterrupt(HIF_DEVICE *device)
{
    CF_UnMaskInterrupt(device->cfHandle);
    return;
}

void 
HIFMaskInterrupt(HIF_DEVICE *device)
{
    CF_MaskInterrupt(device->cfHandle);
    return;
}

static void
hifDeviceRemoved(CF_DEVICE_HANDLE cfHandle)
{
    A_STATUS status;
    HIF_DEVICE *device;

    device = getHifDevice(cfHandle);
    
    HIF_DEBUG_PRINTF(ATH_LOG_TRC, "hifDeviceRemoved: Enter\n");
    HIF_DEBUG_PRINTF(ATH_LOG_INF, "hifDeviceRemoved: Device = %p\n",device);

    /* Inform HTC */
    status = htcCallbacks.deviceRemovedHandler(device);
    
    delHifDevice(cfHandle);
    
    HIF_DEBUG_PRINTF(ATH_LOG_TRC, "hifDeviceRemoved: Exit\n");

    AR_DEBUG_ASSERT(status == A_OK);
}

static HIF_DEVICE *
addHifDevice(CF_DEVICE_HANDLE cfHandle)
{
    hifDevice[0].cfHandle = cfHandle;
    return &hifDevice[0];
}

static HIF_DEVICE *
getHifDevice(CF_DEVICE_HANDLE cfHandle)
{
    return &hifDevice[0];
}

static void
delHifDevice(CF_DEVICE_HANDLE cfHandle)
{
    hifDevice[0].cfHandle = NULL;
}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
99久久精品99国产精品| 欧美日韩国产一区二区三区地区| 国产精品国产三级国产普通话蜜臀 | 中文字幕免费观看一区| 北条麻妃一区二区三区| 一区二区三区在线影院| 欧美乱妇20p| 精品影视av免费| 日本一区二区久久| 一本久久a久久免费精品不卡| 亚洲国产欧美日韩另类综合| 7777精品伊人久久久大香线蕉 | 国产成人精品免费视频网站| 国产精品高潮呻吟| 欧美视频一区二区| 激情欧美日韩一区二区| 国产精品素人视频| 在线影视一区二区三区| 美女久久久精品| 亚洲国产岛国毛片在线| 欧亚一区二区三区| 久久精品二区亚洲w码| 欧美国产综合一区二区| 欧美色综合网站| 国精产品一区一区三区mba桃花 | 成人一区二区三区| 亚洲一区电影777| 26uuu亚洲| 色狠狠色狠狠综合| 久久av中文字幕片| 亚洲精品视频观看| 欧美成人官网二区| 91在线码无精品| 蜜臀国产一区二区三区在线播放| 国产精品日韩成人| 3d动漫精品啪啪1区2区免费| 国产91精品欧美| 日本最新不卡在线| 中文字幕中文字幕一区二区| 777午夜精品免费视频| a美女胸又www黄视频久久| 视频一区二区中文字幕| 国产精品天天看| 欧美一区二区三区男人的天堂| a亚洲天堂av| 精品影视av免费| 亚洲成av人片| 国产精品久久毛片av大全日韩| 91麻豆精品国产91久久久久久| 成人av免费在线| 久久国产福利国产秒拍| 一区二区三区四区在线免费观看| 亚洲精品在线三区| 欧美日韩另类一区| 不卡的av中国片| 激情都市一区二区| 天天亚洲美女在线视频| 日韩理论片网站| 久久蜜臀中文字幕| 91麻豆精品91久久久久同性| 99re视频精品| 国产成人啪午夜精品网站男同| 日韩激情视频在线观看| 亚洲视频你懂的| 欧美精彩视频一区二区三区| 91精品国产日韩91久久久久久| 色哟哟一区二区三区| 高清久久久久久| 激情欧美一区二区三区在线观看| 午夜久久久影院| 一区二区三区**美女毛片| 国产精品天干天干在线综合| 久久伊人蜜桃av一区二区| 欧美理论片在线| 91成人免费在线视频| 成人av在线资源| 豆国产96在线|亚洲| 国产在线播放一区| 麻豆精品国产91久久久久久| 亚洲一区欧美一区| 一区二区在线免费观看| 国产精品久久久久一区二区三区共| 欧美tickling挠脚心丨vk| 欧美日韩亚洲综合一区二区三区| 一区二区三区免费在线观看| 日本一区二区成人| 国产视频一区二区在线观看| 亚洲精品在线电影| 欧美一级爆毛片| 7878成人国产在线观看| 欧美人伦禁忌dvd放荡欲情| 日本电影欧美片| 色综合久久中文综合久久97| 国产91精品免费| 国产激情视频一区二区三区欧美 | 国产精品久久久久久久久久免费看 | 717成人午夜免费福利电影| 在线国产亚洲欧美| 色网站国产精品| 91视频.com| 色婷婷综合久久久久中文| 99精品欧美一区| 99国内精品久久| 99精品视频在线观看| 99热国产精品| 色综合一区二区三区| 91在线精品一区二区| 91麻豆福利精品推荐| 色网综合在线观看| 欧美视频一区二区三区四区| 欧美日本免费一区二区三区| 欧美精品色一区二区三区| 在线不卡中文字幕播放| 欧美日韩黄视频| 日韩欧美在线观看一区二区三区| 日韩午夜三级在线| 精品国产乱码久久久久久久久| 久久一二三国产| 久久一留热品黄| 国产精品卡一卡二卡三| 亚洲欧美日韩国产另类专区 | 中文字幕一区二区不卡| 亚洲欧洲综合另类| 午夜精品福利一区二区三区av| 午夜激情综合网| 精品一区二区三区久久久| 国产福利不卡视频| 不卡av在线网| 91久久精品国产91性色tv| 欧美日韩国产大片| 久久综合精品国产一区二区三区 | 久久91精品久久久久久秒播| 国产美女精品人人做人人爽| 成人国产亚洲欧美成人综合网| 91丨国产丨九色丨pron| 欧美日韩一区二区三区视频| 欧美一级生活片| 国产调教视频一区| 一区二区三区高清| 麻豆精品在线观看| 高清在线观看日韩| 在线观看不卡一区| 日韩欧美国产一二三区| 国产精品女主播av| 亚洲国产欧美在线| 精品午夜久久福利影院| 国产精品久久久久久久蜜臀 | 欧美日韩性生活| 欧美v国产在线一区二区三区| 国产日本亚洲高清| 亚洲一区在线观看免费 | 成人av网站免费观看| 欧美在线色视频| 精品99久久久久久| 亚洲色大成网站www久久九九| 日韩高清不卡一区二区三区| 国产成人精品午夜视频免费| 在线观看亚洲精品视频| 精品久久99ma| 亚洲欧美日韩中文播放 | 美腿丝袜在线亚洲一区| 99视频一区二区| 日韩美女视频一区二区在线观看| 国产精品久久久久久久蜜臀 | 日韩国产欧美在线播放| 国产a精品视频| 欧美日本在线视频| 国产精品久久久久影院老司| 日韩和欧美一区二区三区| 成人av免费在线观看| 日韩免费高清av| 亚洲久草在线视频| 国产一区二区三区精品欧美日韩一区二区三区 | 日韩免费看网站| 亚洲丝袜精品丝袜在线| 精品在线观看免费| 欧美三级视频在线观看| 国产天堂亚洲国产碰碰| 日韩成人精品在线观看| 99精品欧美一区二区三区小说| 精品少妇一区二区| 亚洲成人激情综合网| 暴力调教一区二区三区| 日韩一级高清毛片| 亚洲精品免费播放| 国产成人免费在线观看| 5月丁香婷婷综合| 亚洲女子a中天字幕| 国产精品系列在线播放| 91麻豆精品国产91| 亚洲综合在线视频| 成人黄色免费短视频| 精品国产91乱码一区二区三区| 午夜欧美大尺度福利影院在线看| 不卡的av中国片| 国产日韩欧美综合一区| 日韩电影在线观看电影| 在线亚洲精品福利网址导航| 中文字幕免费不卡在线| 国产资源在线一区|