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

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關(guān)于我們
? 蟲蟲下載站

?? usb.c

?? 有關(guān)ARM開發(fā)板上的IXP400網(wǎng)絡(luò)驅(qū)動(dòng)程序的源碼以。
?? C
?? 第 1 頁 / 共 5 頁
字號(hào):
    /* enable reset interrupt by zeroing the mask bit */    REG_SET(&registers->UDCCR, ((REG_GET(&registers->UDCCR)) & ~UDC_UDCCR_REM));    /* enable endpoint interupts */    REG_SET(&registers->UICR0, UDC_ENABLE_ALL_INT); /* 0..7  */    REG_SET(&registers->UICR1, UDC_ENABLE_ALL_INT); /* 8..15 */    /* don't enable the Start-Of-Frame interrupt by default */    REG_SET(&registers->UFNHR, UDC_UFNHR_SIM);    /* set device index */    device->deviceIndex = lastDeviceIndex++;    /* hook interrupt handler ixUSBInterruptHandler(device) to UDC IRQ */    INT_BIND_MACRO(device->interruptLevel, ixUSBInterruptHandlerWrapper, device);        {	UINT32 i = 0;	for (; i < 16 ; i++) ixOsalMutexInit(&usbBufferSubmitMutex[i]);    }#ifndef IX_USB_HAS_DUMMY_MBLK    /* init pool */    if  ((pNetPool = IX_OSAL_MBUF_POOL_INIT(NUM_MBLKS, BLK_SIZE * 2, "USB Pool")) == NULL)    {        ixOsalLog (IX_OSAL_LOG_LVL_ERROR,                   IX_OSAL_LOG_DEV_STDERR,                   "IxUSBDriverInit: netPoolInit failure\n",                   0, 0, 0, 0, 0, 0);        return IX_FAIL;    }#endif /* IX_USB_HAS_DUMMY_MBLK */        RETURN_OK(device);}PUBLIC IX_STATUSixUSBDeviceEnable(USBDevice *device, BOOL enableDevice){    UINT32 UDCCR;    UDCRegisters *registers;    USBDeviceContext *context;    CHECK_DEVICE(device);    context   = CONTEXT(device);    registers = context->registers;       UDCCR     = REG_GET(&registers->UDCCR);    if (context->enabled == enableDevice)    {        /* device is already in desired state */        RETURN_REDUNDANT(device);    }    if (enableDevice)    {        /* enable UDC */        REG_SET(&registers->UDCCR, (UDCCR | UDC_UDCCR_UDE));        /* mark as enabled */        context->enabled = TRUE;    }    else    {        UINT16 epIndex;        /* mark as disabled */        context->enabled = FALSE;        /* disable UDC */        REG_SET(&registers->UDCCR, UDCCR & ~UDC_UDCCR_UDE);        /* clear queue and buffers */        ixUSBEP0StateReset(device); /* Endpoint 0 is special, there's more to clean up */        for (epIndex = ENDPOINT_0 ; epIndex < NUM_ENDPOINTS ; epIndex++)        {            ixUSBEndpointClear(device, epIndex);        }    }        RETURN_OK(device);}PUBLIC IX_STATUSixUSBEndpointStall(USBDevice *device,                   UINT16 endpointNumber,                   BOOL stallFlag){    volatile UINT32 *UDCCS_ptr; /* pointer to the endpoint UDCCS */    UINT32 UDCCS;               /* UDCCS snapshot */    CHECK_DEVICE(device);    CHECK_DEVICE_ENABLED(device);    CHECK_ENDPOINT(device, endpointNumber);    UDCCS_ptr = EPSTATUS(device, endpointNumber)->UDCCS;    UDCCS     = REG_GET(UDCCS_ptr); /* take register snapshot */    /* check endpoint type - isochronous endpoints cannot be stalled according to the protocol */    if (EP_TYPE(EPDescriptorTable[endpointNumber]) == USB_ISOCHRONOUS)    {        RETURN_NO_STALL_CAPABILITY(device);    }    /* the FST (force stall) bit is in different places depending on the endpoint */    if (endpointNumber == ENDPOINT_0) /* endpoint 0 has UDC_UDCCS0_FST */    {        if (stallFlag)        {            if (((UDCCS & UDC_UDCCS0_FST) != 0) == stallFlag)            {                RETURN_REDUNDANT(device);            }            REG_SET(UDCCS_ptr, UDC_UDCCS0_FST);        }        else /* cannot 'unstall' endpoint 0, this happens automatically */        {            RETURN_INVALID_PARMS(device);        }    }    else if (EP_DIRECTION(EPDescriptorTable[endpointNumber]) == USB_IN) /* USB_IN endpoints */    {        if (((UDCCS & UDC_UDCCS_FST_IN) != 0) == stallFlag)        {            RETURN_REDUNDANT(device);        }        if (stallFlag)        {            REG_SET(UDCCS_ptr, UDC_UDCCS_FST_IN); /* stall endpoint */        }        else        {            REG_SET(UDCCS_ptr, UDCCS & ~UDC_UDCCS_FST_IN); /* unstall endpoint */        }    }    else /* USB_OUT endpoints */    {        IX_USB_ASSERT(EP_DIRECTION(EPDescriptorTable[endpointNumber]) == USB_OUT);        if (((UDCCS & UDC_UDCCS_FST_OUT) != 0) == stallFlag)        {            RETURN_REDUNDANT(device);        }        if (stallFlag)        {            REG_SET(UDCCS_ptr, UDC_UDCCS_FST_OUT); /* stall endpoint */        }        else        {            REG_SET(UDCCS_ptr, UDCCS & ~UDC_UDCCS_FST_OUT); /* unstall endpoint */        }    }    RETURN_OK(device);}PUBLIC IX_STATUSixUSBIsEndpointStalled(USBDevice *device, UINT16 endpointNumber, BOOL *stallState){    UINT32 UDCCS;    UINT16 direction;    CHECK_DEVICE(device);    CHECK_ENDPOINT(device, endpointNumber);    if (stallState == NULL)    {        RETURN_INVALID_PARMS(device);    }    UDCCS     = REG_GET(EPSTATUS(device, endpointNumber)->UDCCS);    direction = EP_DIRECTION(EPDescriptorTable[endpointNumber]);    if (direction == USB_IN)    {        *stallState = (UDCCS & UDC_UDCCS_FST_IN) != 0;    }    else if (direction == USB_OUT)    {        *stallState = (UDCCS & UDC_UDCCS_FST_OUT) != 0;    }    else    {        IX_USB_ASSERT(direction == USB_IN_OUT);        *stallState = (UDCCS & UDC_UDCCS0_FST) != 0;    }    RETURN_OK(device);}PUBLIC IX_STATUS ixUSBEndpointClear(USBDevice *device, UINT16 endpointNumber){    EPStatusData *epData;    CHECK_DEVICE(device);    CHECK_DEVICE_ENABLED(device);    CHECK_ENDPOINT(device, endpointNumber);    epData = EPSTATUS(device, endpointNumber);    /* discard data queue */    ixUSBQueueDiscard(epData);    /* discard current transfer */    ixUSBTransferAbort(epData);    RETURN_OK(device);}PUBLIC IX_STATUS ixUSBSignalResume(USBDevice *device){    UDCRegisters *registers;    CHECK_DEVICE(device);    CHECK_DEVICE_ENABLED(device);    registers = REGISTERS(device);    /* check if the device was enabled to signal resume */    if ((REG_GET(&registers->UDCCS0) & UDC_UDCCS0_DRWF) == 0)    {        RETURN_NO_PERMISSION(device);    }    REG_SET(&registers->UDCCR, ((REG_GET(&registers->UDCCR)) | UDC_UDCCR_RSM));    RETURN_OK(device);}PUBLIC IX_STATUS ixUSBFrameCounterGet(USBDevice *device, UINT16 *counter){    UDCRegisters *registers;    UINT32 UFNHR, UFNLR; /* frame number high (3 bits) and low (8 bits) */    CHECK_DEVICE(device);    CHECK_DEVICE_ENABLED(device);    if (counter == NULL)    {        RETURN_INVALID_PARMS(device);    }    registers = REGISTERS(device);    UFNHR     = REG_GET(&registers->UFNHR);    UFNLR     = REG_GET(&registers->UFNLR);    /* (UFNHR[2:0] & 0x7) << 8) + UFNLR[7..0] & 0xFF */    *counter = (((UFNHR & UDC_UFNHR_FN_MASK) << UDC_UFNHR_FN_SHIFT)                 | (UFNLR & UDC_UFNLR_FN_MASK));    RETURN_OK(device);}PUBLIC IX_STATUS ixUSBReceiveCallbackRegister(USBDevice *device,                              USBReceiveCallback callbackFunction){    CHECK_DEVICE(device);    if (callbackFunction != NULL)    {        EVENTS(device)->receiveCallback = callbackFunction;    }    else    {        EVENTS(device)->receiveCallback = ixUSBNullReceiveCallback;    }    RETURN_OK(device);}PUBLIC IX_STATUS ixUSBSetupCallbackRegister(USBDevice *device,                           USBSetupCallback callbackFunction){    CHECK_DEVICE(device);    if (callbackFunction != NULL)    {        EVENTS(device)->setupCallback = callbackFunction;    }    else    {        EVENTS(device)->setupCallback = ixUSBNullSetupCallback;    }    RETURN_OK(device);}PUBLIC voidixUSBDataSendAllow(USBDevice *device){    EPStatusData *epData = EPSTATUS(device, 1);    dataSendAllowed = TRUE;    IX_USB_VERBOSE4_TRACE("USB: Resuming data transfers\n", 0, 0, 0, 0, 0, 0);    ixUSBRequestSend(epData);}PUBLIC voidixUSBDataSendBlock(){	dataSendAllowed = FALSE;}PUBLIC IX_STATUS ixUSBBufferSubmit(USBDevice *device,                  UINT16 destinationEndpoint,                  IX_USB_MBLK *sendBuffer){    EPStatusData *epData;    IxOsalMutex *lock = &usbBufferSubmitMutex[destinationEndpoint];    CHECK_DEVICE(device);    CHECK_DEVICE_ENABLED(device);    CHECK_ENDPOINT(device, destinationEndpoint);    CHECK_ENDPOINT_STALL(device, destinationEndpoint);    if (sendBuffer == NULL)    {        RETURN_INVALID_PARMS(device);    }    epData = EPSTATUS(device, destinationEndpoint);    CHECK_ENDPOINT_IN_CAPABILITY(epData, device);    IX_USB_VERBOSE4_TRACE("USB: Submitted %d bytes on endpoint %d, %d packets in queue\n",                 IX_USB_MBLK_LEN(sendBuffer),                 destinationEndpoint,                 epData->queue.len,                 0, 0, 0);    ixOsalMutexLock(lock, IX_OSAL_WAIT_FOREVER);    if (ixUSBBufferEnqueue(epData, sendBuffer))    {        if (destinationEndpoint == ENDPOINT_0)        {            ixUSBEP0RequestSend(device);        }        else        {            if (dataSendAllowed || destinationEndpoint != 1)            {                ixUSBRequestSend(epData);	    }	    else	    {	    	IX_USB_TRACE("USB: Oops, packet queued, data transfers blocked\n",	    		     0, 0, 0, 0, 0, 0);	    }        }	ixOsalMutexUnlock(lock);

	RETURN_OK(device);    }    else    {        IX_USB_TRACE("USB: RETURN SEND QUEUE FULL\n",                      0, 0, 0, 0, 0, 0);	ixOsalMutexUnlock(lock);
        RETURN_SEND_QUEUE_FULL(device);    }}PUBLIC IX_STATUS ixUSBBufferCancel(USBDevice *device,                  UINT16 destinationEndpoint,                   IX_USB_MBLK *sendBuffer){    USBDataQueue *queue;    UINT32 local_index;#ifdef IX_USB_HAS_CRITICAL_DATA_LOCKS    UINT32 irqStatus;#endif /* IX_USB_HAS_CRITICAL_DATA_LOCKS */    CHECK_DEVICE(device);    CHECK_DEVICE_ENABLED(device);    CHECK_ENDPOINT(device, destinationEndpoint);    queue = EPQUEUE(device, destinationEndpoint);#ifdef IX_USB_HAS_CRITICAL_DATA_LOCKS    /* lock section */    irqStatus = IX_USB_LOCK;#endif /* IX_USB_HAS_CRITICAL_DATA_LOCKS */    for (local_index = 0 ; local_index < queue->len ; local_index++)    {        UINT32 offset = QUEUE_WRAP(queue->head + local_index);        if (queue->base[offset] == sendBuffer)        {            queue->base [offset] = NULL;            IX_USB_MBLK_FREE(sendBuffer);        }    }#ifdef IX_USB_HAS_CRITICAL_DATA_LOCKS    /* unlock section */    IX_USB_UNLOCK(irqStatus);#endif /* IX_USB_HAS_CRITICAL_DATA_LOCKS */    if (local_index == queue->len)    {        IX_USB_TRACE("USB: BUFFER NOT FOUND\n", 0, 0, 0, 0, 0, 0);        RETURN_ERROR(device); /* buffer not found */    }    else    {        RETURN_OK(device);    }}PUBLIC IX_STATUS ixUSBEventCallbackRegister(USBDevice *device, 

?? 快捷鍵說明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號(hào) Ctrl + =
減小字號(hào) Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
欧美综合一区二区三区| 五月激情丁香一区二区三区| 久久99精品国产91久久来源| 欧美精品久久99| 日韩综合在线视频| 日韩一区二区三区三四区视频在线观看| 一级做a爱片久久| 欧美日韩一区二区三区在线看| 亚洲图片欧美综合| 欧美日本不卡视频| 美女网站色91| 国产天堂亚洲国产碰碰| 成人h精品动漫一区二区三区| 中文字幕精品三区| 91污片在线观看| 亚洲18女电影在线观看| 日韩欧美国产综合一区 | 一区二区三区小说| 欧美性受xxxx| 日韩在线观看一区二区| 精品久久一区二区| 成人高清伦理免费影院在线观看| 综合色天天鬼久久鬼色| 欧美亚一区二区| 精品一区二区三区在线播放视频| 国产欧美va欧美不卡在线| 91亚洲精品一区二区乱码| 午夜精品福利久久久| 精品国产91亚洲一区二区三区婷婷| 成人一区二区三区视频 | 久久99这里只有精品| 久久久久国产一区二区三区四区| 成人一区二区三区| 一区二区在线观看av| 激情成人综合网| 国产**成人网毛片九色| 综合精品久久久| 日韩一区二区中文字幕| 97精品久久久午夜一区二区三区| 亚洲三级在线免费| 日韩一区二区三区在线| 成人性生交大片免费| 亚洲不卡在线观看| 欧美极品aⅴ影院| 欧美精三区欧美精三区| 成人h精品动漫一区二区三区| 日韩国产欧美在线播放| 中文字幕五月欧美| 欧美电影免费提供在线观看| 91在线视频播放| 国产剧情av麻豆香蕉精品| 亚洲国产裸拍裸体视频在线观看乱了| 精品99一区二区| 欧美午夜一区二区三区免费大片| 国产一区二区主播在线| 午夜不卡av免费| 中文字幕在线不卡一区二区三区 | 欧美日韩亚洲综合一区二区三区| 国产乱码精品一区二区三区忘忧草| 亚洲国产另类精品专区| 中文字幕制服丝袜成人av| 欧美大片在线观看一区二区| 欧美视频在线不卡| 成人aaaa免费全部观看| 精品一区二区三区久久| 日韩激情一二三区| 亚洲综合999| 自拍偷拍亚洲激情| 日本一区二区三区国色天香| 欧美一级片免费看| 欧美日产在线观看| 欧美在线观看一二区| 99精品在线免费| 粉嫩高潮美女一区二区三区| 精品一区二区三区在线观看国产 | 国产夜色精品一区二区av| 国产精品国产三级国产普通话蜜臀 | 亚洲图片欧美色图| 一区二区三区免费看视频| 中文字幕av不卡| 国产欧美日韩三级| 国产欧美日韩精品在线| 精品日韩欧美在线| 日韩精品最新网址| 日韩精品一区二区在线| 欧美一区二区视频在线观看2020 | 国产亚洲综合性久久久影院| 日韩免费一区二区三区在线播放| 欧美日韩一级二级| 欧美精品九九99久久| 欧美日韩精品一区二区三区蜜桃| 欧美羞羞免费网站| 欧美日韩1区2区| 日韩欧美自拍偷拍| 欧美韩日一区二区三区| 91丨porny丨户外露出| 亚洲人成伊人成综合网小说| 91麻豆swag| 国产一区二区三区高清播放| 91在线精品一区二区| 国产一区免费电影| 国产欧美日韩亚州综合| 国产无人区一区二区三区| 日韩精品专区在线影院观看| 欧美一区二区高清| 日韩无一区二区| 26uuu精品一区二区在线观看| 亚洲精品在线网站| 欧美激情一区二区三区蜜桃视频 | 欧美高清在线一区| 国产精品理论片| 亚洲一区二三区| 日本免费新一区视频| 经典三级一区二区| 成人av在线播放网站| 日本久久精品电影| 欧美一区二区人人喊爽| 久久久91精品国产一区二区精品| 国产精品狼人久久影院观看方式| ...av二区三区久久精品| 亚洲一区二区三区不卡国产欧美| 日韩福利视频网| 国产美女精品人人做人人爽| 波多野结衣中文字幕一区| 欧美亚洲愉拍一区二区| 91精品国产一区二区| 久久久久成人黄色影片| 一区二区三区四区国产精品| 奇米影视一区二区三区| 国产精品99久久久久久宅男| 一本久久a久久免费精品不卡| 在线成人高清不卡| 国产午夜亚洲精品理论片色戒| 中文字幕一区在线| 日韩精品欧美精品| 国产99久久精品| 欧美日本一区二区三区四区 | 国产精品毛片久久久久久| 一区二区三区久久| 久久99蜜桃精品| 色哟哟欧美精品| 亚洲精品在线观| 一区二区高清在线| 国产一区二区h| 欧美日韩国产区一| 亚洲欧洲精品一区二区三区| 日韩不卡一二三区| 91香蕉视频mp4| 国产亚洲一区字幕| 日本不卡一二三| 色哟哟一区二区在线观看| 国产亚洲一区二区三区| 五月天激情综合| 日本道精品一区二区三区| 久久久久国色av免费看影院| 青青青伊人色综合久久| 色噜噜狠狠色综合欧洲selulu| 欧美精品一区二区三区蜜桃视频 | 日韩一区二区电影在线| 一区二区三区国产| 色综合久久中文综合久久牛| 91精品国产综合久久精品app| 亚洲精品日韩一| 97se亚洲国产综合自在线观| 精品91自产拍在线观看一区| 蜜桃一区二区三区在线观看| 91亚洲精品久久久蜜桃网站| 久久免费电影网| 国产在线一区观看| 欧美精品一区视频| 欧美精品一卡两卡| 亚洲另类在线视频| 成人久久18免费网站麻豆| 精品久久人人做人人爰| 日本v片在线高清不卡在线观看| 日本韩国一区二区| 亚洲女人小视频在线观看| 一本一道久久a久久精品综合蜜臀| 久久精品日韩一区二区三区| 韩国成人在线视频| 欧美成人a在线| 久久国产剧场电影| 日韩久久一区二区| 成人免费高清视频在线观看| 亚洲女同女同女同女同女同69| 久久成人18免费观看| 精品国产一区二区三区不卡 | 亚洲欧洲色图综合| 国产精品12区| 亚洲激情男女视频| 欧美日韩成人综合天天影院 | 欧美日韩国产精品成人| 日日夜夜精品免费视频| 91麻豆精品国产| 日本女人一区二区三区| 精品国产麻豆免费人成网站| 丁香天五香天堂综合| 亚洲成人免费电影| 精品国产在天天线2019| 国产成+人+日韩+欧美+亚洲|