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

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

?? usbd_udp.c

?? IAR5.2下 AT91SAM9260 ARM 對 MCP2515 控制源化碼
?? C
?? 第 1 頁 / 共 3 頁
字號:
/* ----------------------------------------------------------------------------
 *         ATMEL Microcontroller Software Support 
 * ----------------------------------------------------------------------------
 * Copyright (c) 2008, 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 disclaimer below.
 *
 * 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 CLEAR_CSR(endpoint, flags) \
    { \
        volatile unsigned int reg; \
        reg = AT91C_BASE_UDP->UDP_CSR[endpoint]; \
        reg &= ~(flags); \
        reg |= (AT91C_UDP_RX_DATA_BK0 | AT91C_UDP_RX_DATA_BK1); \
        AT91C_BASE_UDP->UDP_CSR[endpoint] = reg; \
        while ( (AT91C_BASE_UDP->UDP_CSR[endpoint] & (flags)) == (flags) ); \
    }

#define SET_CSR(endpoint, flags) \
    { \
        volatile unsigned int reg; \
        reg = AT91C_BASE_UDP->UDP_CSR[endpoint] ; \
        reg |= (flags); \
        reg |= (AT91C_UDP_RX_DATA_BK0 | AT91C_UDP_RX_DATA_BK1); \
        AT91C_BASE_UDP->UDP_CSR[endpoint] = reg; \
        while ( (AT91C_BASE_UDP->UDP_CSR[endpoint] & (flags)) != (flags) ); \
    }

//------------------------------------------------------------------------------
//      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);
        AT91C_BASE_UDP->UDP_CSR[eptnum] &= ~AT91C_UDP_RX_DATA_BK0;
        while ( (AT91C_BASE_UDP->UDP_CSR[eptnum] & AT91C_UDP_RX_DATA_BK0) == 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);
        AT91C_BASE_UDP->UDP_CSR[eptnum] &= ~AT91C_UDP_RX_DATA_BK1;
        while ( (AT91C_BASE_UDP->UDP_CSR[eptnum] & AT91C_UDP_RX_DATA_BK1) == 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.

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
成人看片黄a免费看在线| 日韩天堂在线观看| 不卡的电影网站| 国产剧情一区二区| 国产一区二区精品久久99| 久久se这里有精品| 久久97超碰色| 国产高清一区日本| 国产成人午夜视频| 成人18精品视频| 波多野结衣在线一区| k8久久久一区二区三区| 色综合av在线| 欧美精选午夜久久久乱码6080| 欧美日韩色综合| 欧美一区二区三区成人| 欧美成人精品高清在线播放| 久久亚洲一级片| 国产欧美精品一区二区色综合| 国产婷婷色一区二区三区| 国产精品国产三级国产三级人妇 | 中文字幕精品一区二区三区精品| 久久一区二区视频| 国产精品久久久久久久久久免费看| 国产日韩一级二级三级| 亚洲人成小说网站色在线| 亚洲一本大道在线| 久热成人在线视频| 国产成人亚洲综合a∨婷婷图片 | 欧美日韩精品专区| 欧美电影免费提供在线观看| 国产午夜精品久久| 一区二区在线观看视频在线观看| 天堂蜜桃91精品| 国产乱国产乱300精品| 成人动漫一区二区| 欧美日韩久久久一区| 精品久久久久av影院| 日韩码欧中文字| 五月天视频一区| 国产精品一区二区三区99| 99热精品一区二区| 欧美一级片在线观看| 国产日产精品1区| 亚洲不卡在线观看| 国产福利一区在线| 欧美午夜精品久久久久久超碰 | 日韩高清在线不卡| 成人丝袜18视频在线观看| 欧美在线视频不卡| 久久久久成人黄色影片| 韩国欧美国产1区| jvid福利写真一区二区三区| 91精品中文字幕一区二区三区| 2023国产精品| 亚洲午夜久久久| 国产精品一区在线观看你懂的| 91福利国产精品| 精品久久久久久无| 亚洲国产精品一区二区www在线| 国产精品911| 91麻豆精品国产无毒不卡在线观看 | 91色.com| 2021久久国产精品不只是精品| 亚洲精品欧美二区三区中文字幕| 韩国av一区二区| 欧美日本视频在线| 亚洲少妇屁股交4| 国产精品自在欧美一区| 欧美美女喷水视频| 亚洲欧美国产毛片在线| 国产在线日韩欧美| 5月丁香婷婷综合| 亚洲精品国产a久久久久久| 国产福利一区二区| 欧美一级片在线观看| 一区二区三区在线免费视频| 国产盗摄视频一区二区三区| 日韩欧美一二三四区| 亚洲一区二区精品视频| 99精品欧美一区| 欧美激情自拍偷拍| 国产精品一区专区| 精品剧情v国产在线观看在线| 亚洲国产欧美在线| 在线免费观看不卡av| 中文字幕免费观看一区| 久久99精品久久久久久动态图 | 欧美三级在线视频| **性色生活片久久毛片| 国产乱人伦偷精品视频不卡| 日韩精品资源二区在线| 成人avav影音| 国产免费久久精品| 国模套图日韩精品一区二区| 日韩欧美电影一区| 日本成人在线看| 欧美一级二级三级蜜桃| 日韩国产欧美三级| 在线91免费看| 日韩在线播放一区二区| 欧美日韩国产免费一区二区| 亚洲国产精品人人做人人爽| 欧美亚洲综合在线| 亚洲一区二区在线播放相泽| 91九色最新地址| 亚洲综合在线电影| 欧美在线视频你懂得| 亚洲国产精品视频| 制服丝袜中文字幕亚洲| 日韩精品欧美成人高清一区二区| 91精品国产综合久久精品app| 日韩电影免费在线看| 欧美一区二区三区在线| 日本不卡视频在线观看| 日韩美女视频在线| 国产一区二区三区免费看 | 奇米精品一区二区三区四区 | 一个色在线综合| 欧美日韩久久不卡| 免费三级欧美电影| 久久久久久99精品| 972aa.com艺术欧美| 亚洲午夜久久久久中文字幕久| 欧美男同性恋视频网站| 另类专区欧美蜜桃臀第一页| 久久亚洲精华国产精华液| 成人免费视频播放| 亚洲午夜久久久久久久久电影院| 7777精品伊人久久久大香线蕉完整版| 麻豆精品新av中文字幕| 国产亚洲精久久久久久| av毛片久久久久**hd| 亚洲小少妇裸体bbw| 欧美电影免费观看高清完整版 | 波多野结衣在线aⅴ中文字幕不卡| 亚洲欧美区自拍先锋| 91精品国产色综合久久不卡电影 | av高清不卡在线| 亚洲成va人在线观看| 精品久久五月天| 91麻豆精品一区二区三区| 丝袜诱惑制服诱惑色一区在线观看| 亚洲欧美韩国综合色| 欧美一卡在线观看| 成人开心网精品视频| 午夜免费欧美电影| 国产婷婷色一区二区三区四区| 色老汉av一区二区三区| 精品一区二区三区蜜桃| 亚洲三级小视频| 日韩精品一区二区三区中文精品| 成人精品亚洲人成在线| 日本欧美一区二区在线观看| 国产精品欧美久久久久无广告 | 国产精品青草综合久久久久99| 欧美日韩三级在线| 粉嫩av亚洲一区二区图片| 亚洲成人免费影院| 中文字幕第一区第二区| 欧美精品v国产精品v日韩精品| 精品在线免费视频| 亚洲一区二区免费视频| 国产欧美日韩另类视频免费观看| 欧美三级日韩在线| 成人av免费在线观看| 蓝色福利精品导航| 亚洲午夜久久久久| 中文字幕亚洲一区二区va在线| 91精品国产品国语在线不卡| 91在线丨porny丨国产| 久久99久久精品欧美| 亚洲国产欧美在线| 日韩伦理av电影| 国产婷婷色一区二区三区| 欧美一区午夜精品| 91色婷婷久久久久合中文| 国产一区欧美一区| 日韩制服丝袜av| 一卡二卡三卡日韩欧美| 亚洲国产高清aⅴ视频| 精品成人一区二区三区| 欧美理论片在线| 一本色道久久加勒比精品| 国产成人欧美日韩在线电影| 日韩国产欧美在线观看| 亚洲国产精品天堂| 有码一区二区三区| 亚洲婷婷国产精品电影人久久| 久久久99免费| 精品日产卡一卡二卡麻豆| 欧美高清hd18日本| 欧美日韩在线精品一区二区三区激情| 97久久超碰国产精品电影| 盗摄精品av一区二区三区| 久久99精品国产麻豆不卡| 免费成人美女在线观看| 热久久国产精品| 日韩福利电影在线| 秋霞午夜鲁丝一区二区老狼|