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

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

?? usbd_udp.c

?? AT91SAM9263的USB Device端口驅(qū)動
?? C
?? 第 1 頁 / 共 3 頁
字號:
/* ----------------------------------------------------------------------------
 *         ATMEL Microcontroller Software Support  -  ROUSSET  -
 * ----------------------------------------------------------------------------
 * Copyright (c) 2006, Atmel Corporation

 * All rights reserved.
 *
 * Redistribution and use in source and binary forms, with or without
 * modification, are permitted provided that the following conditions are met:
 *
 * - Redistributions of source code must retain the above copyright notice,
 * this list of conditions and the disclaiimer below.
 *
 * - Redistributions in binary form must reproduce the above copyright notice,
 * this list of conditions and the disclaimer below in the documentation and/or
 * other materials provided with the distribution.
 *
 * Atmel's name may not be used to endorse or promote products derived from
 * this software without specific prior written permission.
 *
 * DISCLAIMER: THIS SOFTWARE IS PROVIDED BY ATMEL "AS IS" AND ANY EXPRESS OR
 * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF
 * MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NON-INFRINGEMENT ARE
 * DISCLAIMED. IN NO EVENT SHALL ATMEL BE LIABLE FOR ANY DIRECT, INDIRECT,
 * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
 * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA,
 * OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF
 * LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING
 * NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE,
 * EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
 * ----------------------------------------------------------------------------
 */

/*
    Title: USBD implementation for a UDP controller

    About: Purpose
        Implementation of USB device functions on a UDP controller.
*/

//------------------------------------------------------------------------------
//      Headers
//------------------------------------------------------------------------------


#include "USBD.h"
#include "USBDCallbacks.h"
#include <board.h>
#include <pio/pio.h>
#include <utility/trace.h>
#include <utility/led.h>
#include <usb/common/core/USBEndpointDescriptor.h>
#include <usb/common/core/USBGenericRequest.h>

#if defined(BOARD_USB_UDP)

//------------------------------------------------------------------------------
//         Definitions
//------------------------------------------------------------------------------
/*
    Constants: UDP register field values
        UDP_RXDATA - Bit mask for both banks of the UDP_CSR register.
*/
#define UDP_RXDATA              (AT91C_UDP_RX_DATA_BK0 | AT91C_UDP_RX_DATA_BK1)

/*
    Constants: Endpoint states
        UDP_ENDPOINT_DISABLED - Endpoint is disabled.
        UDP_ENDPOINT_HALTED - Endpoint is halted (i.e. STALLs every request).
        UDP_ENDPOINT_IDLE - Endpoint is idle (i.e. ready for transmission).
        UDP_ENDPOINT_SENDING - Endpoint is sending data.
        UDP_ENDPOINT_RECEIVING - Endpoint is receiving data.
*/
#define UDP_ENDPOINT_DISABLED       0
#define UDP_ENDPOINT_HALTED         1
#define UDP_ENDPOINT_IDLE           2
#define UDP_ENDPOINT_SENDING        3
#define UDP_ENDPOINT_RECEIVING      4

/*
    Macros: UDP_CSR register access
        CLEAR_CSR - Clears the specified bit(s) in the UDP_CSR register.
        SET_CSR - Sets the specified bit(s) in the UDP_CSR register.
*/
//#define UDP_CLEAREPFLAGS(pUsb, bEndpoint, dFlags) {
//    CLEAR(UDP_GetDriverInterface(pUsb)->UDP_CSR[bEndpoint], dFlags);
//    while (!ISCLEARED(UDP_GetDriverInterface(pUsb)->UDP_CSR[bEndpoint], dFlags));
//}
#define CLEAR_CSR(endpoint, bits)   AT91C_BASE_UDP->UDP_CSR[endpoint] &= ~bits;
//#define UDP_SETEPFLAGS(pUsb, bEndpoint, dFlags) {
//    while (ISCLEARED(UDP_GetDriverInterface(pUsb)->UDP_CSR[bEndpoint], dFlags))
//        SET(UDP_GetDriverInterface(pUsb)->UDP_CSR[bEndpoint], dFlags);
//}
#define SET_CSR(endpoint, bits)     AT91C_BASE_UDP->UDP_CSR[endpoint] |= bits;

//------------------------------------------------------------------------------
//      Types
//------------------------------------------------------------------------------

/*
    Type: UDP transfer
        Describes an ongoing transfer on a UDP endpoint.

    Variables:
        data - Pointer to a data buffer used for emission/reception.
        buffered - Number of bytes which have been written into the UDP internal
                   FIFO buffers.
        transferred - Number of bytes which have been sent/received.
        remaining - Number of bytes which have not been buffered/transferred yet.
        callback - Optional callback to invoke when the transfer completes.
        argument - Optional argument to the callback function.
*/
typedef struct {

    char *data;
    int buffered;
    int transferred;
    int remaining;
    TransferCallback callback;
    void *argument;

} Transfer;

/*
    Type: UDP endpoint
        Describes the state of an endpoint of the UDP controller.

    Variables:
        state - Current endpoint state.
        bank - Current reception bank (0 or 1).
        size - Maximum packet size for the endpoint.
        transfer - Describes an ongoing transfer (if current state is either
                   <UDP_ENDPOINT_SENDING> or <UDP_ENDPOINT_RECEIVING>).
*/
typedef struct {

    unsigned char state;
    unsigned char bank;
    unsigned short size;
    Transfer transfer;

} Endpoint;

//------------------------------------------------------------------------------
//         Internal variables
//------------------------------------------------------------------------------

/*
    Variables: 
        endpoints - Holds the internal state for each endpoint of the UDP.
        deviceState - Device current state.
        suspended - Indicates if device is currently suspended.
*/
static Endpoint endpoints[BOARD_USB_NUMENDPOINTS];
static unsigned char deviceState;
static unsigned char previousDeviceState;

//------------------------------------------------------------------------------
//      Internal Functions
//------------------------------------------------------------------------------
/*
    Functions: Peripheral clock
        EnablePeripheralClock - Enables the clock of the UDP peripheral.
        DisablePeripheralClock - Disables the UDP peripheral clock.
*/
static inline void UDP_EnablePeripheralClock()
{
    AT91C_BASE_PMC->PMC_PCER = 1 << AT91C_ID_UDP;
}

static inline void UDP_DisablePeripheralClock()
{
    AT91C_BASE_PMC->PMC_PCDR = 1 << AT91C_ID_UDP;
}

/*
    Functions: USB clock
        EnableUsbClock - Enables the 48MHz USB clock.
        DisableUsbClock - Disables the 48MHz USB clock.
*/
static inline void UDP_EnableUsbClock()
{
    AT91C_BASE_PMC->PMC_SCER = AT91C_PMC_UDP;
}

static inline void UDP_DisableUsbClock()
{
    AT91C_BASE_PMC->PMC_SCDR = AT91C_PMC_UDP;
}

/*
    Functions: Transceiver
        UDP_EnableTransceiver - Enables the UDP transceiver.
        UDP_DisableTransceiver - Disables the UDP transceiver.
*/
static inline void UDP_EnableTransceiver()
{
    AT91C_BASE_UDP->UDP_TXVC &= ~AT91C_UDP_TXVDIS;
}

static inline void UDP_DisableTransceiver()
{
    AT91C_BASE_UDP->UDP_TXVC |= AT91C_UDP_TXVDIS;
}

/*
    Function: UDP_EndOfTransfer
        Handles a completed transfer on the given endpoint, invoking the
        configured callback if any.

    Parameters:
        eptnum - Number of the endpoint for which the transfer has completed.
        status - Result of the USB transfer.
*/
static void UDP_EndOfTransfer(unsigned char eptnum, char status)
{
    Endpoint *endpoint = &(endpoints[eptnum]);
    Transfer *transfer = &(endpoint->transfer);

    // Check that endpoint was sending or receiving data
    if ((endpoint->state == UDP_ENDPOINT_RECEIVING)
        || (endpoint->state == UDP_ENDPOINT_SENDING)) {

        trace_LOG(trace_INFO, "EoT ");

        // Endpoint returns in Idle state
        endpoint->state = UDP_ENDPOINT_IDLE;

        // Invoke callback is present
        if (transfer->callback != 0) {

            ((TransferCallback) transfer->callback)
                (transfer->argument,
                 status,
                 transfer->transferred,
                 transfer->remaining + transfer->buffered);
        }
    }
}

/*
    Function: UDP_ClearRxFlag
        Clears the correct reception flag (bank 0 or bank 1) of an endpoint.

    Parameters:
        eptnum - Number of an endpoint.
*/
static void UDP_ClearRxFlag(unsigned char eptnum)
{
    Endpoint *endpoint = &(endpoints[eptnum]);

    // Clear flag and change banks
    if (endpoint->bank == 0) {

        CLEAR_CSR(eptnum, AT91C_UDP_RX_DATA_BK0);

        // Swap bank if in dual-fifo mode
        if (BOARD_USB_ENDPOINTS_BANKS(eptnum) > 1) {

            endpoint->bank = 1;
        }
    }
    else {

        CLEAR_CSR(eptnum, AT91C_UDP_RX_DATA_BK1);
        endpoint->bank = 0;
    }
}

/*
    Function: UDP_WritePayload
        Writes a data payload into the current FIFO buffer of the UDP.

    Parameters:
        eptnum - Number of the endpoint which is sending data.
*/
static void UDP_WritePayload(unsigned char eptnum)
{
    Endpoint *endpoint = &(endpoints[eptnum]);
    Transfer *transfer = &(endpoint->transfer);
    signed int size;

    // Get the number of bytes to send
    size = endpoint->size;
    if (size > transfer->remaining) {

        size = transfer->remaining;
    }

    // Update transfer descriptor information
    transfer->buffered += size;
    transfer->remaining -= size;

    // Write packet in the FIFO buffer
    while (size > 0) {

        AT91C_BASE_UDP->UDP_FDR[eptnum] = *(transfer->data);
        transfer->data++;
        size--;
    }
}

/*
    Function: UDP_ReadPayload
        Reads a data payload from the current FIFO buffer of an endpoint.

    Parameters:
        eptnum - Endpoint number.
        size - Size of the data to read.
*/
static void UDP_ReadPayload(unsigned char eptnum, int size)
{
    Endpoint *endpoint = &(endpoints[eptnum]);
    Transfer *transfer = &(endpoint->transfer);

    // Check that the requested size is not bigger than the remaining transfer
    if (size > transfer->remaining) {

        transfer->buffered += size - transfer->remaining;
        size = transfer->remaining;
    }

    // Update transfer descriptor information
    transfer->remaining -= size;
    transfer->transferred += size;

    // Retrieve packet
    while (size > 0) {

        *(transfer->data) = (char) AT91C_BASE_UDP->UDP_FDR[eptnum];
        transfer->data++;
        size--;
    }
}

/*
    Function: UDP_ReadRequest
        Reads a SETUP request from the FIFO buffer of Control endpoint 0 and
        stores it into the global <request> variable.
*/
static void UDP_ReadRequest(USBGenericRequest *request)
{
    unsigned char *data = (unsigned char *) request;
    unsigned int i;

    // Copy packet
    for (i = 0; i < 8; i++) {

        *data = (unsigned char) AT91C_BASE_UDP->UDP_FDR[0];
        data++;
    }
}

/*
    Function: UDP_ResetEndpoints
        Resets all the endpoints of the UDP peripheral.
*/
static void UDP_ResetEndpoints()
{
    Endpoint *endpoint;
    Transfer *transfer;
    unsigned char eptnum;

    // Reset the transfer descriptor of every endpoint
    for (eptnum = 0; eptnum < BOARD_USB_NUMENDPOINTS; eptnum++) {

        endpoint = &(endpoints[eptnum]);
        transfer = &(endpoint->transfer);

        // Reset endpoint transfer descriptor
        transfer->data = 0;
        transfer->transferred = -1;
        transfer->buffered = -1;
        transfer->remaining = -1;
        transfer->callback = 0;
        transfer->argument = 0;

        // Reset endpoint state
        endpoint->bank = 0;
        endpoint->state = UDP_ENDPOINT_DISABLED;
    }
}

/*
    Function: UDP_DisableEndpoints
        Disables all endpoints of the UDP peripheral except Control endpoint 0.
*/
static void UDP_DisableEndpoints()
{
    unsigned char eptnum;

    // Disable each endpoint, terminating any pending transfer
    for (eptnum = 1; eptnum < BOARD_USB_NUMENDPOINTS; eptnum++) {

        UDP_EndOfTransfer(eptnum, USBD_STATUS_ABORTED);
        endpoints[eptnum].state = UDP_ENDPOINT_DISABLED;
    }
}

/*
    Function: UDP_IsTransferFinished
        Checks if an ongoing transfer on an endpoint has been completed.

    Parameters:
        eptnum - Endpoint number.

    Returns:
        1 if the current transfer on the given endpoint is complete; otherwise
        0.
*/
static unsigned char UDP_IsTransferFinished(unsigned char eptnum)
{
    Endpoint *endpoint = &(endpoints[eptnum]);

?? 快捷鍵說明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
欧美日韩一区高清| 99re这里只有精品6| 亚洲国产成人自拍| 欧美在线小视频| 国产黑丝在线一区二区三区| 亚洲成人在线免费| 黄页网站大全一区二区| 一区二区三区免费网站| 久久久综合精品| 欧美区在线观看| 一本色道久久综合狠狠躁的推荐| 麻豆一区二区三区| 偷拍与自拍一区| 亚洲乱码国产乱码精品精小说 | 日韩你懂的在线播放| 日本高清不卡在线观看| 风流少妇一区二区| 麻豆精品视频在线观看免费 | 国产精品一品视频| 免费国产亚洲视频| 午夜精品福利在线| 亚洲欧美一区二区三区国产精品| 国产丝袜在线精品| 2021中文字幕一区亚洲| 日韩一区二区在线看| 欧美日韩黄色影视| 欧美三级午夜理伦三级中视频| 成人av手机在线观看| 久久综合五月天婷婷伊人| 欧美乱妇一区二区三区不卡视频| 99久久精品国产导航| 国产91在线观看| 国产成人在线观看| 国产乱码精品一区二区三区五月婷| 蜜臀av性久久久久蜜臀aⅴ| 三级一区在线视频先锋 | 青青草91视频| 日韩国产高清影视| 三级成人在线视频| 日本 国产 欧美色综合| 午夜亚洲福利老司机| 一区二区三区av电影| 亚洲乱码中文字幕| 亚洲一级二级在线| 午夜精品久久久| 天天综合日日夜夜精品| 日韩精品久久理论片| 免费人成黄页网站在线一区二区| 婷婷中文字幕一区三区| 日本中文在线一区| 蜜臀av性久久久久蜜臀av麻豆 | 久久99最新地址| 国内一区二区视频| 国产成人鲁色资源国产91色综 | 欧美电影免费观看高清完整版在线| 91麻豆精品国产91久久久更新时间| 欧美日韩大陆在线| 精品国产一区久久| 久久久噜噜噜久久人人看| 国产欧美日韩三区| 樱花影视一区二区| 日韩电影在线一区二区| 精品无人区卡一卡二卡三乱码免费卡| 国产裸体歌舞团一区二区| 国产成人在线网站| 色嗨嗨av一区二区三区| 91精品国产91久久综合桃花| 欧美成人欧美edvon| 国产日韩精品久久久| 亚洲欧美日韩国产另类专区| 五月婷婷色综合| 国产乱理伦片在线观看夜一区| 成人综合在线网站| 欧美色老头old∨ideo| 日韩精品一区二区三区蜜臀| 国产精品短视频| 天堂成人国产精品一区| 国产夫妻精品视频| 欧美主播一区二区三区美女| 欧美xxxx老人做受| 国产精品国产三级国产有无不卡| 亚洲小说欧美激情另类| 国产精品456| 欧美主播一区二区三区美女| 久久综合久久鬼色| 一区二区三区美女视频| 国产一区二区久久| 欧美日韩的一区二区| 国产精品色呦呦| 爽爽淫人综合网网站 | 欧美一级高清大全免费观看| 国产色一区二区| 性做久久久久久免费观看欧美| 高清av一区二区| 在线观看视频一区二区欧美日韩| 国产色综合久久| 理论片日本一区| 欧美主播一区二区三区| 国产精品毛片高清在线完整版| 天堂影院一区二区| 91小视频在线观看| 久久久无码精品亚洲日韩按摩| 一片黄亚洲嫩模| 国产sm精品调教视频网站| 日韩区在线观看| 亚洲一区二区三区免费视频| 高清国产一区二区三区| 欧美一区二区人人喊爽| 亚洲一区中文在线| 成人亚洲一区二区一| 精品国产网站在线观看| 午夜精品123| 欧美中文一区二区三区| 亚洲日本va午夜在线影院| 国产伦精品一区二区三区免费迷 | www久久精品| 免费在线观看精品| 欧美日韩在线一区二区| 亚洲欧美偷拍另类a∨色屁股| 国产不卡视频在线播放| 精品日韩av一区二区| 人人狠狠综合久久亚洲| 欧美精品日韩综合在线| 亚洲成人动漫一区| 欧美色综合久久| 一区二区三区**美女毛片| 日本韩国精品在线| 亚洲综合无码一区二区| 日本韩国一区二区三区| 亚洲一区免费在线观看| 91久久精品一区二区| 亚洲天堂中文字幕| 日本久久电影网| 亚洲精品日产精品乱码不卡| 91亚洲资源网| 亚洲精品中文字幕乱码三区| 91日韩精品一区| 亚洲精品老司机| 在线区一区二视频| 亚洲一区二区av在线| 欧美日韩不卡在线| 麻豆久久久久久| 精品va天堂亚洲国产| 久久国产精品99久久人人澡| 精品剧情在线观看| 国产经典欧美精品| 国产精品电影院| 欧美在线观看一二区| 婷婷国产在线综合| 日韩美女一区二区三区四区| 国产在线看一区| 欧美激情一区二区在线| 91小宝寻花一区二区三区| 亚洲精品网站在线观看| 欧美精品精品一区| 国产一区二区三区四区五区美女| 国产片一区二区三区| 一本大道久久a久久精二百| 亚洲mv在线观看| 日韩精品资源二区在线| 岛国av在线一区| 亚洲自拍偷拍麻豆| 日韩亚洲欧美在线| 不卡的电影网站| 亚洲国产成人av好男人在线观看| 91精品国产综合久久久蜜臀粉嫩| 久久精工是国产品牌吗| 国产精品午夜久久| 欧美日韩一卡二卡三卡| 久久99精品久久久| 国产精品人成在线观看免费| 欧洲中文字幕精品| 精品一区二区在线视频| 国产精品乱人伦一区二区| 欧美久久久久久久久久| 成人性生交大合| 丝袜美腿亚洲一区| 国产日本一区二区| 欧美日本在线一区| 成人动漫在线一区| 日本不卡在线视频| 亚洲国产成人私人影院tom| 欧美精品三级日韩久久| 99久久精品一区| 久久国产剧场电影| 亚洲精品成人悠悠色影视| 精品国产乱码久久久久久牛牛| 91免费版在线| 国产综合色在线视频区| 亚洲国产婷婷综合在线精品| 久久久精品黄色| 欧美日韩国产天堂| a在线播放不卡| 久久不见久久见免费视频1| 亚洲一区二区三区国产| 国产精品拍天天在线| 欧美大尺度电影在线| 欧美在线观看一二区| www.亚洲激情.com| 国产精品一区专区|