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

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

?? can.c

?? CAN_FIFO收發例程
?? C
?? 第 1 頁 / 共 5 頁
字號:
CANMessageSet(unsigned long ulBase, unsigned long ulObjID,
              tCANMsgObject *pMsgObject, tMsgObjType eMsgType)
{
    unsigned short usCmdMaskReg;
    unsigned short usMaskReg0, usMaskReg1;
    unsigned short usArbReg0, usArbReg1;
    unsigned short usMsgCtrl;
    tBoolean bTransferData;
    tBoolean bUseExtendedID;

    bTransferData = 0;

    //
    // Check the arguments.
    //
    ASSERT(CANBaseValid(ulBase));
    ASSERT((ulObjID <= 32) && (ulObjID != 0));
    ASSERT((eMsgType == MSG_OBJ_TYPE_TX) ||
           (eMsgType == MSG_OBJ_TYPE_TX_REMOTE) ||
           (eMsgType == MSG_OBJ_TYPE_RX) ||
           (eMsgType == MSG_OBJ_TYPE_RX_REMOTE) ||
           (eMsgType == MSG_OBJ_TYPE_TX_REMOTE) ||
           (eMsgType == MSG_OBJ_TYPE_RXTX_REMOTE));

    //
    // Wait for busy bit to clear
    //
    while(CANRegRead(ulBase + CAN_O_IF1CRQ) & CAN_IF1CRQ_BUSY)
    {
    }

    //
    // See if we need to use an extended identifier or not.
    //
    if((pMsgObject->ulMsgID > CAN_MAX_11BIT_MSG_ID) ||
       (pMsgObject->ulFlags & MSG_OBJ_EXTENDED_ID))
    {
        bUseExtendedID = 1;
    }
    else
    {
        bUseExtendedID = 0;
    }

    //
    // This is always a write to the Message object as this call is setting a
    // message object.  This call will also always set all size bits so it sets
    // both data bits.  The call will use the CONTROL register to set control
    // bits so this bit needs to be set as well.
    //
    usCmdMaskReg = (CAN_IF1CMSK_WRNRD | CAN_IF1CMSK_DATAA | CAN_IF1CMSK_DATAB |
                    CAN_IF1CMSK_CONTROL);

    //
    // Initialize the values to a known state before filling them in based on
    // the type of message object that is being configured.
    //
    usArbReg0 = 0;
    usArbReg1 = 0;
    usMsgCtrl = 0;
    usMaskReg0 = 0;
    usMaskReg1 = 0;

    switch(eMsgType)
    {
        //
        // Transmit message object.
        //
        case MSG_OBJ_TYPE_TX:
        {
            //
            // Set the TXRQST bit and the reset the rest of the register.
            //
            usMsgCtrl |= CAN_IF1MCTL_TXRQST;
            usArbReg1 = CAN_IF1ARB2_DIR;
            bTransferData = 1;
            break;
        }

        //
        // Transmit remote request message object
        //
        case MSG_OBJ_TYPE_TX_REMOTE:
        {
            //
            // Set the TXRQST bit and the reset the rest of the register.
            //
            usMsgCtrl |= CAN_IF1MCTL_TXRQST;
            usArbReg1 = 0;
            break;
        }

        //
        // Receive message object.
        //
        case MSG_OBJ_TYPE_RX:
        {
            //
            // This clears the DIR bit along with everything else.  The TXRQST
            // bit was cleared by defaulting usMsgCtrl to 0.
            //
            usArbReg1 = 0;
            break;
        }

        //
        // Receive remote request message object.
        //
        case MSG_OBJ_TYPE_RX_REMOTE:
        {
            //
            // The DIR bit is set to one for remote receivers.  The TXRQST bit
            // was cleared by defaulting usMsgCtrl to 0.
            //
            usArbReg1 = CAN_IF1ARB2_DIR;

            //
            // Set this object so that it only indicates that a remote frame
            // was received and allow for software to handle it by sending back
            // a data frame.
            //
            usMsgCtrl = CAN_IF1MCTL_UMASK;

            //
            // Use the full Identifier by default.
            //
            usMaskReg0 = 0xffff;
            usMaskReg1 = 0x1fff;

            //
            // Make sure to send the mask to the message object.
            //
            usCmdMaskReg |= CAN_IF1CMSK_MASK;
            break;
        }

        //
        // Remote frame receive remote, with auto-transmit message object.
        //
        case MSG_OBJ_TYPE_RXTX_REMOTE:
        {
            //
            // Oddly the DIR bit is set to one for remote receivers.
            //
            usArbReg1 = CAN_IF1ARB2_DIR;

            //
            // Set this object to auto answer if a matching identifier is seen.
            //
            usMsgCtrl = CAN_IF1MCTL_RMTEN | CAN_IF1MCTL_UMASK;

            //
            // The data to be returned needs to be filled in.
            //
            bTransferData = 1;
            break;
        }

        //
        // This case should never happen due to the ASSERT statement at the
        // beginning of this function.
        //
        default:
        {
            return;
        }
    }

    //
    // Configure the Mask Registers.
    //
    if(pMsgObject->ulFlags & MSG_OBJ_USE_ID_FILTER)
    {
        if(bUseExtendedID)
        {
            //
            // Set the 29 bits of Identifier mask that were requested.
            //
            usMaskReg0 = pMsgObject->ulMsgIDMask & CAN_IF1MSK1_IDMSK_M;
            usMaskReg1 = ((pMsgObject->ulMsgIDMask >> 16) &
                            CAN_IF1MSK2_IDMSK_M);
        }
        else
        {
            //
            // Lower 16 bit are unused so set them to zero.
            //
            usMaskReg0 = 0;

            //
            // Put the 11 bit Mask Identifier into the upper bits of the field
            // in the register.
            //
            usMaskReg1 = ((pMsgObject->ulMsgIDMask << 2) &
                            CAN_IF1MSK2_IDMSK_M);
        }
    }

    //
    // If the caller wants to filter on the extended ID bit then set it.
    //
    if((pMsgObject->ulFlags & MSG_OBJ_USE_EXT_FILTER) ==
       MSG_OBJ_USE_EXT_FILTER)
    {
        usMaskReg1 |= CAN_IF1MSK2_MXTD;
    }

    //
    // The caller wants to filter on the message direction field.
    //
    if((pMsgObject->ulFlags & MSG_OBJ_USE_DIR_FILTER) ==
       MSG_OBJ_USE_DIR_FILTER)
    {
        usMaskReg1 |= CAN_IF1MSK2_MDIR;
    }

    if(pMsgObject->ulFlags & (MSG_OBJ_USE_ID_FILTER | MSG_OBJ_USE_DIR_FILTER |
                              MSG_OBJ_USE_EXT_FILTER))
    {
        //
        // Set the UMASK bit to enable using the mask register.
        //
        usMsgCtrl |= CAN_IF1MCTL_UMASK;

        //
        // Set the MASK bit so that this gets transferred to the Message Object.
        //
        usCmdMaskReg |= CAN_IF1CMSK_MASK;
    }

    //
    // Set the Arb bit so that this gets transferred to the Message object.
    //
    usCmdMaskReg |= CAN_IF1CMSK_ARB;

    //
    // Configure the Arbitration registers.
    //
    if(bUseExtendedID)
    {
        //
        // Set the 29 bit version of the Identifier for this message object.
        //
        usArbReg0 |= pMsgObject->ulMsgID & CAN_IF1ARB1_ID_M;
        usArbReg1 |= (pMsgObject->ulMsgID >> 16) & CAN_IF1ARB2_ID_M;

        //
        // Mark the message as valid and set the extended ID bit.
        //
        usArbReg1 |= CAN_IF1ARB2_MSGVAL | CAN_IF1ARB2_XTD;
    }
    else
    {
        //
        // Set the 11 bit version of the Identifier for this message object.
        // The lower 18 bits are set to zero.
        //
        usArbReg1 |= (pMsgObject->ulMsgID << 2) & CAN_IF1ARB2_ID_M;

        //
        // Mark the message as valid.
        //
        usArbReg1 |= CAN_IF1ARB2_MSGVAL;
    }

    //
    // Set the data length since this is set for all transfers.  This is also a
    // single transfer and not a FIFO transfer so set EOB bit.
    //
    usMsgCtrl |= (pMsgObject->ulMsgLen & CAN_IF1MCTL_DLC_M);

    //
    // Mark this as the last entry if this is not the last entry in a FIFO.
    //
    if((pMsgObject->ulFlags & MSG_OBJ_FIFO) == 0)
    {
        usMsgCtrl |= CAN_IF1MCTL_EOB;
    }

    //
    // Enable transmit interrupts if they should be enabled.
    //
    if(pMsgObject->ulFlags & MSG_OBJ_TX_INT_ENABLE)
    {
        usMsgCtrl |= CAN_IF1MCTL_TXIE;
    }

    //
    // Enable receive interrupts if they should be enabled.
    //
    if(pMsgObject->ulFlags & MSG_OBJ_RX_INT_ENABLE)
    {
        usMsgCtrl |= CAN_IF1MCTL_RXIE;
    }

    //
    // Write the data out to the CAN Data registers if needed.
    //
    if(bTransferData)
    {
        CANDataRegWrite(pMsgObject->pucMsgData,
                        (unsigned long *)(ulBase + CAN_O_IF1DA1),
                        pMsgObject->ulMsgLen);
    }

    //
    // Write out the registers to program the message object.
    //
    CANRegWrite(ulBase + CAN_O_IF1CMSK, usCmdMaskReg);
    CANRegWrite(ulBase + CAN_O_IF1MSK1, usMaskReg0);
    CANRegWrite(ulBase + CAN_O_IF1MSK2, usMaskReg1);
    CANRegWrite(ulBase + CAN_O_IF1ARB1, usArbReg0);
    CANRegWrite(ulBase + CAN_O_IF1ARB2, usArbReg1);
    CANRegWrite(ulBase + CAN_O_IF1MCTL, usMsgCtrl);

    //
    // Transfer the message object to the message object specifiec by ulObjID.
    //
    CANRegWrite(ulBase + CAN_O_IF1CRQ, ulObjID & CAN_IF1CRQ_MNUM_M);

    return;
}

//*****************************************************************************
//
//! Reads a CAN message from one of the message object buffers.
//!
//! \param ulBase is the base address of the CAN controller.
//! \param ulObjID is the object number to read (1-32).
//! \param pMsgObject points to a structure containing message object fields.
//! \param bClrPendingInt indicates whether an associated interrupt should be
//! cleared.
//!
//! This function is used to read the contents of one of the 32 message objects
//! in the CAN controller, and return it to the caller.  The data returned is
//! stored in the fields of the caller-supplied structure pointed to by
//! \e pMsgObject.  The data consists of all of the parts of a CAN message,
//! plus some control and status information.
//!
//! Normally this is used to read a message object that has received and stored
//! a CAN message with a certain identifier.  However, this could also be used
//! to read the contents of a message object in order to load the fields of the
//! structure in case only part of the structure needs to be changed from a
//! previous setting.
//!
//! When using CANMessageGet, all of the same fields of the structure are
//! populated in the same way as when the CANMessageSet() function is used,
//! with the following exceptions:
//!
//! \e pMsgObject->ulFlags:
//!
//! - \b MSG_OBJ_NEW_DATA indicates if this is new data since the last time it
//! was read
//! - \b MSG_OBJ_DATA_LOST indicates that at least one message was received on
//! this message object, and not read by the host before being overwritten.
//!
//! \return None.
//
//*****************************************************************************
void
CANMessageGet(unsigned long ulBase, unsigned long ulObjID,
              tCANMsgObject *pMsgObject, tBoolean bClrPendingInt)
{
    unsigned short usCmdMaskReg;
    unsigned short usMaskReg0, usMaskReg1;
    unsigned short usArbReg0, usArbReg1;
    unsigned short usMsgCtrl;

    //
    // Check the arguments.
    //
    ASSERT(CANBaseValid(ulBase));
    ASSERT((ulObjID <= 32) && (ulObjID != 0));

    //
    // This is always a read to the Message object as this call is setting a
    // message object.
    //
    usCmdMaskReg = (CAN_IF1CMSK_DATAA | CAN_IF1CMSK_DATAB |
                    CAN_IF1CMSK_CONTROL | CAN_IF1CMSK_MASK | CAN_IF1CMSK_ARB);

    //
    // Clear a pending interrupt and new data in a message object.
    //
    if(bClrPendingInt)
    {
        usCmdMaskReg |= CAN_IF1CMSK_CLRINTPND;
    }

    //
    // Set up the 

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
亚洲一区影音先锋| 欧美一区二区三区喷汁尤物| 日本一区二区三区在线不卡| 国产精品一区在线观看乱码| 久久精品视频一区二区三区| jvid福利写真一区二区三区| 中文字幕一区二区三区四区不卡| 91丝袜美腿高跟国产极品老师| 国产精品久久久久7777按摩| 91九色最新地址| 日韩国产欧美三级| 久久久www免费人成精品| www.日韩大片| 亚洲国产sm捆绑调教视频| 日韩亚洲欧美中文三级| 国产精品99精品久久免费| 国产精品欧美久久久久无广告 | 舔着乳尖日韩一区| 久久综合色之久久综合| 91女厕偷拍女厕偷拍高清| 午夜电影久久久| 久久精品亚洲精品国产欧美| 在线一区二区视频| 精品一区二区三区在线播放视频| 欧美国产欧美亚州国产日韩mv天天看完整| 99免费精品视频| 日韩综合一区二区| 国产女同互慰高潮91漫画| 欧美影片第一页| 国产在线不卡一卡二卡三卡四卡| 亚洲素人一区二区| 日韩一级在线观看| 91免费看视频| 国产麻豆精品在线| 婷婷开心激情综合| 一色屋精品亚洲香蕉网站| 日韩欧美电影一二三| 色婷婷av一区二区三区之一色屋| 久久精品国产一区二区三区免费看| 日本一区二区免费在线观看视频| 欧美日韩在线播| 成人激情文学综合网| 久久电影网电视剧免费观看| 亚洲一二三四久久| 国产精品久久久久久久浪潮网站 | 久久机这里只有精品| 亚洲视频香蕉人妖| 久久久久高清精品| 欧美一级久久久久久久大片| 91黄色免费版| 99久久精品免费| 国产一区二区三区四区五区美女 | 亚洲成人免费视| 国产精品白丝在线| 精品av久久707| 欧美一区二区精品久久911| 欧洲国内综合视频| av在线这里只有精品| 激情综合色综合久久| 免费高清成人在线| 日韩极品在线观看| 午夜精品久久久久久久| 一区二区在线观看免费视频播放| 欧美国产一区视频在线观看| 久久综合狠狠综合| 日韩欧美一区电影| 日韩欧美久久久| 日韩三级免费观看| 日韩三级免费观看| 日韩欧美一级二级| 日韩精品一区二区三区三区免费| 欧美日韩一区中文字幕| 欧美色爱综合网| 欧美性生活一区| 欧美性受xxxx黑人xyx性爽| 91福利社在线观看| 欧美色图免费看| 欧美久久一区二区| 欧美日韩三级一区二区| 欧美欧美欧美欧美| 日韩三级视频在线观看| 日韩精品中文字幕一区| 精品少妇一区二区三区日产乱码| 精品久久久久香蕉网| 欧美精品一区二区在线播放 | 国产成a人亚洲| 成人avav在线| 91视视频在线观看入口直接观看www | 色94色欧美sute亚洲13| 91麻豆国产精品久久| 在线免费观看一区| 777xxx欧美| 欧美电影免费观看高清完整版在 | 亚洲精品一卡二卡| 午夜精品视频一区| 国内精品久久久久影院色| 激情小说欧美图片| 粉嫩av一区二区三区粉嫩| 91美女精品福利| 欧美高清dvd| 日韩欧美一区二区视频| 日本一区二区三级电影在线观看| 国产精品久久久久久久久图文区| 亚洲精品国产无天堂网2021| 午夜成人免费视频| 国产激情偷乱视频一区二区三区| 99久久免费视频.com| 欧美丝袜丝交足nylons图片| 欧美zozozo| 自拍偷在线精品自拍偷无码专区| 亚洲一区二区三区小说| 精品一区二区三区在线观看国产| 成人久久视频在线观看| 欧美精品在线视频| 国产日韩精品视频一区| 亚洲一区二区在线视频| 激情综合色综合久久综合| 色综合久久综合网欧美综合网 | 精品国产一区a| 一区在线观看视频| 蜜臀av一区二区在线免费观看| 成人性生交大片免费 | 久久综合九色综合97婷婷| 亚洲人午夜精品天堂一二香蕉| 日韩 欧美一区二区三区| 成人v精品蜜桃久久一区| 欧美人动与zoxxxx乱| 中文字幕不卡在线观看| 日韩和欧美一区二区| 94-欧美-setu| 久久婷婷国产综合国色天香| 亚洲一区二区黄色| 成人18精品视频| 欧美精品一区在线观看| 午夜影院在线观看欧美| 99免费精品在线| 国产清纯在线一区二区www| 日韩国产一二三区| 欧美午夜精品电影| ㊣最新国产の精品bt伙计久久| 美女尤物国产一区| 欧美午夜精品一区二区蜜桃| |精品福利一区二区三区| 国产大陆亚洲精品国产| 欧美一卡二卡三卡| 亚洲a一区二区| 色8久久人人97超碰香蕉987| 综合激情网...| 成人中文字幕电影| 久久综合九色欧美综合狠狠| 欧美日韩亚洲另类| 中文字幕亚洲一区二区av在线| 久久av老司机精品网站导航| 欧美高清视频不卡网| 亚洲aaa精品| 欧美日韩高清不卡| 亚洲午夜一区二区| 欧美性生交片4| 亚洲午夜久久久久久久久电影院| 日本高清视频一区二区| 亚洲色图在线播放| 一本到三区不卡视频| 亚洲视频狠狠干| 91在线观看免费视频| 亚洲精品自拍动漫在线| 91麻豆免费视频| 一区二区免费看| 在线中文字幕不卡| 午夜成人免费电影| 日韩欧美自拍偷拍| 精品一区二区综合| 国产亚洲欧美中文| 国产尤物一区二区在线| 久久影院午夜论| 成人国产视频在线观看| 亚洲区小说区图片区qvod| 欧美综合久久久| 丝袜美腿成人在线| ww亚洲ww在线观看国产| 国产精品亚洲视频| 日韩一区中文字幕| 欧美日韩精品二区第二页| 免费在线观看一区二区三区| 日韩免费看网站| 成人一区二区三区视频| 综合久久给合久久狠狠狠97色| 欧洲精品一区二区| 美腿丝袜亚洲一区| 国产欧美精品区一区二区三区| 99热这里都是精品| 性感美女久久精品| 久久综合色鬼综合色| 92精品国产成人观看免费| 亚洲国产日韩一区二区| 日韩一区二区三区电影| 成人精品gif动图一区| 亚洲成人综合网站| 久久亚洲私人国产精品va媚药| 99久久精品一区二区| 日本在线不卡视频一二三区|