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

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

?? stm32f10x_can.c

?? STM32SDCardSourceCodeFATFS.rar
?? C
?? 第 1 頁 / 共 3 頁
字號:
/**
  ******************************************************************************
  * @file    stm32f10x_can.c
  * @author  MCD Application Team
  * @version V3.1.2
  * @date    09/28/2009
  * @brief   This file provides all the CAN firmware functions.
  ******************************************************************************
  * @copy
  *
  * THE PRESENT FIRMWARE WHICH IS FOR GUIDANCE ONLY AIMS AT PROVIDING CUSTOMERS
  * WITH CODING INFORMATION REGARDING THEIR PRODUCTS IN ORDER FOR THEM TO SAVE
  * TIME. AS A RESULT, STMICROELECTRONICS SHALL NOT BE HELD LIABLE FOR ANY
  * DIRECT, INDIRECT OR CONSEQUENTIAL DAMAGES WITH RESPECT TO ANY CLAIMS ARISING
  * FROM THE CONTENT OF SUCH FIRMWARE AND/OR THE USE MADE BY CUSTOMERS OF THE
  * CODING INFORMATION CONTAINED HEREIN IN CONNECTION WITH THEIR PRODUCTS.
  *
  * <h2><center>&copy; COPYRIGHT 2009 STMicroelectronics</center></h2>
  */ 

/* Includes ------------------------------------------------------------------*/
#include "stm32f10x_can.h"
#include "stm32f10x_rcc.h"

/** @addtogroup STM32F10x_StdPeriph_Driver
  * @{
  */

/** @defgroup CAN 
  * @brief CAN driver modules
  * @{
  */ 

/** @defgroup CAN_Private_TypesDefinitions
  * @{
  */

/**
  * @}
  */

/** @defgroup CAN_Private_Defines
  * @{
  */

/* CAN Master Control Register bits */
#define MCR_INRQ     ((uint32_t)0x00000001) /* Initialization request */
#define MCR_SLEEP    ((uint32_t)0x00000002) /* Sleep mode request */
#define MCR_TXFP     ((uint32_t)0x00000004) /* Transmit FIFO priority */
#define MCR_RFLM     ((uint32_t)0x00000008) /* Receive FIFO locked mode */
#define MCR_NART     ((uint32_t)0x00000010) /* No automatic retransmission */
#define MCR_AWUM     ((uint32_t)0x00000020) /* Automatic wake up mode */
#define MCR_ABOM     ((uint32_t)0x00000040) /* Automatic bus-off management */
#define MCR_TTCM     ((uint32_t)0x00000080) /* time triggered communication */
#define MCR_RESET    ((uint32_t)0x00008000) /* time triggered communication */
#define MCR_DBF      ((uint32_t)0x00010000) /* software master reset */

/* CAN Master Status Register bits */
#define MSR_INAK     ((uint32_t)0x00000001)    /* Initialization acknowledge */
#define MSR_WKUI     ((uint32_t)0x00000008)    /* Wake-up interrupt */
#define MSR_SLAKI    ((uint32_t)0x00000010)    /* Sleep acknowledge interrupt */

/* CAN Transmit Status Register bits */
#define TSR_RQCP0    ((uint32_t)0x00000001)    /* Request completed mailbox0 */
#define TSR_TXOK0    ((uint32_t)0x00000002)    /* Transmission OK of mailbox0 */
#define TSR_ABRQ0    ((uint32_t)0x00000080)    /* Abort request for mailbox0 */
#define TSR_RQCP1    ((uint32_t)0x00000100)    /* Request completed mailbox1 */
#define TSR_TXOK1    ((uint32_t)0x00000200)    /* Transmission OK of mailbox1 */
#define TSR_ABRQ1    ((uint32_t)0x00008000)    /* Abort request for mailbox1 */
#define TSR_RQCP2    ((uint32_t)0x00010000)    /* Request completed mailbox2 */
#define TSR_TXOK2    ((uint32_t)0x00020000)    /* Transmission OK of mailbox2 */
#define TSR_ABRQ2    ((uint32_t)0x00800000)    /* Abort request for mailbox2 */
#define TSR_TME0     ((uint32_t)0x04000000)    /* Transmit mailbox 0 empty */
#define TSR_TME1     ((uint32_t)0x08000000)    /* Transmit mailbox 1 empty */
#define TSR_TME2     ((uint32_t)0x10000000)    /* Transmit mailbox 2 empty */

/* CAN Receive FIFO 0 Register bits */
#define RF0R_FULL0   ((uint32_t)0x00000008)    /* FIFO 0 full */
#define RF0R_FOVR0   ((uint32_t)0x00000010)    /* FIFO 0 overrun */
#define RF0R_RFOM0   ((uint32_t)0x00000020)    /* Release FIFO 0 output mailbox */

/* CAN Receive FIFO 1 Register bits */
#define RF1R_FULL1   ((uint32_t)0x00000008)    /* FIFO 1 full */
#define RF1R_FOVR1   ((uint32_t)0x00000010)    /* FIFO 1 overrun */
#define RF1R_RFOM1   ((uint32_t)0x00000020)    /* Release FIFO 1 output mailbox */

/* CAN Error Status Register bits */
#define ESR_EWGF     ((uint32_t)0x00000001)    /* Error warning flag */
#define ESR_EPVF     ((uint32_t)0x00000002)    /* Error passive flag */
#define ESR_BOFF     ((uint32_t)0x00000004)    /* Bus-off flag */

/* CAN Mailbox Transmit Request */
#define TMIDxR_TXRQ  ((uint32_t)0x00000001) /* Transmit mailbox request */

/* CAN Filter Master Register bits */
#define FMR_FINIT    ((uint32_t)0x00000001) /* Filter init mode */

/* Time out for INAK bit */
#define INAK_TimeOut        ((uint32_t)0x0000FFFF)

/* Time out for SLAK bit */
#define SLAK_TimeOut        ((uint32_t)0x0000FFFF)

/**
  * @}
  */

/** @defgroup CAN_Private_Macros
  * @{
  */

/**
  * @}
  */

/** @defgroup CAN_Private_Variables
  * @{
  */

/**
  * @}
  */

/** @defgroup CAN_Private_FunctionPrototypes
  * @{
  */

static ITStatus CheckITStatus(uint32_t CAN_Reg, uint32_t It_Bit);

/**
  * @}
  */

/** @defgroup CAN_Private_Functions
  * @{
  */

/**
  * @brief  Deinitializes the CAN peripheral registers to their default reset values.
  * @param  CANx: where x can be 1 or 2 to select the CAN peripheral.
  * @retval None.
  */
void CAN_DeInit(CAN_TypeDef* CANx)
{
  /* Check the parameters */
  assert_param(IS_CAN_ALL_PERIPH(CANx));
 
  if (CANx == CAN1)
  {
    /* Enable CAN1 reset state */
    RCC_APB1PeriphResetCmd(RCC_APB1Periph_CAN1, ENABLE);
    /* Release CAN1 from reset state */
    RCC_APB1PeriphResetCmd(RCC_APB1Periph_CAN1, DISABLE);
  }
  else
  {  
    /* Enable CAN2 reset state */
    RCC_APB1PeriphResetCmd(RCC_APB1Periph_CAN2, ENABLE);
    /* Release CAN2 from reset state */
    RCC_APB1PeriphResetCmd(RCC_APB1Periph_CAN2, DISABLE);
  }
}

/**
  * @brief  Initializes the CAN peripheral according to the specified
  *   parameters in the CAN_InitStruct.
  * @param  CANx: where x can be 1 or 2 to to select the CAN peripheral.
  * @param  CAN_InitStruct: pointer to a CAN_InitTypeDef structure that
  *   contains the configuration information for the CAN peripheral.
  * @retval Constant indicates initialization succeed which will be 
  *   CANINITFAILED or CANINITOK.
  */
uint8_t CAN_Init(CAN_TypeDef* CANx, CAN_InitTypeDef* CAN_InitStruct)
{
  uint8_t InitStatus = CANINITFAILED;
  uint32_t wait_ack = 0x00000000;
  /* Check the parameters */
  assert_param(IS_CAN_ALL_PERIPH(CANx));
  assert_param(IS_FUNCTIONAL_STATE(CAN_InitStruct->CAN_TTCM));
  assert_param(IS_FUNCTIONAL_STATE(CAN_InitStruct->CAN_ABOM));
  assert_param(IS_FUNCTIONAL_STATE(CAN_InitStruct->CAN_AWUM));
  assert_param(IS_FUNCTIONAL_STATE(CAN_InitStruct->CAN_NART));
  assert_param(IS_FUNCTIONAL_STATE(CAN_InitStruct->CAN_RFLM));
  assert_param(IS_FUNCTIONAL_STATE(CAN_InitStruct->CAN_TXFP));
  assert_param(IS_CAN_MODE(CAN_InitStruct->CAN_Mode));
  assert_param(IS_CAN_SJW(CAN_InitStruct->CAN_SJW));
  assert_param(IS_CAN_BS1(CAN_InitStruct->CAN_BS1));
  assert_param(IS_CAN_BS2(CAN_InitStruct->CAN_BS2));
  assert_param(IS_CAN_PRESCALER(CAN_InitStruct->CAN_Prescaler));

  /* exit from sleep mode */
  CANx->MCR &= ~MCR_SLEEP;

  /* Request initialisation */
  CANx->MCR |= MCR_INRQ ;

  /* Wait the acknowledge */
  while (((CANx->MSR & MSR_INAK) != MSR_INAK) && (wait_ack != INAK_TimeOut))
  {
    wait_ack++;
  }

  /* ...and check acknowledged */
  if ((CANx->MSR & MSR_INAK) != MSR_INAK)
  {
    InitStatus = CANINITFAILED;
  }
  else 
  {
    /* Set the time triggered communication mode */
    if (CAN_InitStruct->CAN_TTCM == ENABLE)
    {
      CANx->MCR |= MCR_TTCM;
    }
    else
    {
      CANx->MCR &= ~MCR_TTCM;
    }

    /* Set the automatic bus-off management */
    if (CAN_InitStruct->CAN_ABOM == ENABLE)
    {
      CANx->MCR |= MCR_ABOM;
    }
    else
    {
      CANx->MCR &= ~MCR_ABOM;
    }

    /* Set the automatic wake-up mode */
    if (CAN_InitStruct->CAN_AWUM == ENABLE)
    {
      CANx->MCR |= MCR_AWUM;
    }
    else
    {
      CANx->MCR &= ~MCR_AWUM;
    }

    /* Set the no automatic retransmission */
    if (CAN_InitStruct->CAN_NART == ENABLE)
    {
      CANx->MCR |= MCR_NART;
    }
    else
    {
      CANx->MCR &= ~MCR_NART;
    }

    /* Set the receive FIFO locked mode */
    if (CAN_InitStruct->CAN_RFLM == ENABLE)
    {
      CANx->MCR |= MCR_RFLM;
    }
    else
    {
      CANx->MCR &= ~MCR_RFLM;
    }

    /* Set the transmit FIFO priority */
    if (CAN_InitStruct->CAN_TXFP == ENABLE)
    {
      CANx->MCR |= MCR_TXFP;
    }
    else
    {
      CANx->MCR &= ~MCR_TXFP;
    }

    /* Set the bit timing register */
    CANx->BTR = (uint32_t)((uint32_t)CAN_InitStruct->CAN_Mode << 30) | ((uint32_t)CAN_InitStruct->CAN_SJW << 24) |
               ((uint32_t)CAN_InitStruct->CAN_BS1 << 16) | ((uint32_t)CAN_InitStruct->CAN_BS2 << 20) |
               ((uint32_t)CAN_InitStruct->CAN_Prescaler - 1);

    /* Request leave initialisation */
    CANx->MCR &= ~MCR_INRQ;

   /* Wait the acknowledge */
   wait_ack = 0x00;

   while (((CANx->MSR & MSR_INAK) == MSR_INAK) && (wait_ack != INAK_TimeOut))
   {
     wait_ack++;
   }

    /* ...and check acknowledged */
    if ((CANx->MSR & MSR_INAK) == MSR_INAK)
    {
      InitStatus = CANINITFAILED;
    }
    else
    {
      InitStatus = CANINITOK ;
    }
  }

  /* At this step, return the status of initialization */
  return InitStatus;
}

/**
  * @brief  Initializes the CAN peripheral according to the specified
  *   parameters in the CAN_FilterInitStruct.
  * @param  CAN_FilterInitStruct: pointer to a CAN_FilterInitTypeDef
  *   structure that contains the configuration information.
  * @retval None.
  */
void CAN_FilterInit(CAN_FilterInitTypeDef* CAN_FilterInitStruct)
{
  uint32_t filter_number_bit_pos = 0;
  /* Check the parameters */
  assert_param(IS_CAN_FILTER_NUMBER(CAN_FilterInitStruct->CAN_FilterNumber));
  assert_param(IS_CAN_FILTER_MODE(CAN_FilterInitStruct->CAN_FilterMode));
  assert_param(IS_CAN_FILTER_SCALE(CAN_FilterInitStruct->CAN_FilterScale));
  assert_param(IS_CAN_FILTER_FIFO(CAN_FilterInitStruct->CAN_FilterFIFOAssignment));
  assert_param(IS_FUNCTIONAL_STATE(CAN_FilterInitStruct->CAN_FilterActivation));

  filter_number_bit_pos = ((uint32_t)0x00000001) << CAN_FilterInitStruct->CAN_FilterNumber;

  /* Initialisation mode for the filter */
  CAN1->FMR |= FMR_FINIT;

  /* Filter Deactivation */
  CAN1->FA1R &= ~(uint32_t)filter_number_bit_pos;

  /* Filter Scale */
  if (CAN_FilterInitStruct->CAN_FilterScale == CAN_FilterScale_16bit)
  {
    /* 16-bit scale for the filter */
    CAN1->FS1R &= ~(uint32_t)filter_number_bit_pos;

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
欧美日韩久久久一区| 极品少妇xxxx精品少妇偷拍| 美女网站视频久久| 国产精品一级二级三级| 成人av集中营| 欧美四级电影网| 欧美mv日韩mv亚洲| 国产精品久久综合| 亚洲高清免费在线| 经典三级在线一区| 色综合久久久久久久| 91精品国产综合久久久久| 国产拍揄自揄精品视频麻豆| 亚洲精品综合在线| 久久av中文字幕片| 97精品国产97久久久久久久久久久久| 欧美日韩国产一二三| 国产亚洲一区字幕| 亚洲国产精品综合小说图片区| 久久97超碰色| 欧美性三三影院| 久久久久久久综合| 午夜精品久久久久久| 成人午夜免费电影| 欧美久久久久久蜜桃| 国产精品久线在线观看| 美脚の诱脚舐め脚责91| 91福利国产成人精品照片| 精品福利一区二区三区免费视频| 亚洲日本青草视频在线怡红院 | 成人av在线播放网址| 欧美色网一区二区| 国产日韩欧美精品综合| 午夜欧美2019年伦理| 成人福利在线看| 亚洲女性喷水在线观看一区| 美女被吸乳得到大胸91| 在线观看日韩av先锋影音电影院| 久久久久久久久久电影| 视频一区二区三区中文字幕| 99精品视频免费在线观看| 欧美成va人片在线观看| 亚洲国产精品人人做人人爽| caoporm超碰国产精品| 久久久美女艺术照精彩视频福利播放| 亚洲二区在线观看| 97超碰欧美中文字幕| 久久久久久久久岛国免费| 天堂影院一区二区| 91精品91久久久中77777| 国产清纯白嫩初高生在线观看91 | 欧美一级在线观看| 一区二区三区免费| 成人av片在线观看| 久久精品一区二区三区四区| 麻豆成人在线观看| 777午夜精品免费视频| 亚洲成人激情av| 欧洲一区二区三区免费视频| 最新热久久免费视频| 成人一区二区在线观看| 久久老女人爱爱| 国产自产视频一区二区三区| 日韩三级免费观看| 奇米精品一区二区三区在线观看 | 奇米影视7777精品一区二区| 69堂国产成人免费视频| 日韩精品亚洲一区| 5858s免费视频成人| 午夜激情综合网| 欧美日韩国产一级| 午夜视频在线观看一区二区三区| 色爱区综合激月婷婷| 亚洲日本乱码在线观看| 日本韩国欧美三级| 亚洲色欲色欲www| 91国在线观看| 亚洲成人午夜电影| 欧美日本一区二区在线观看| 视频一区欧美日韩| 777欧美精品| 黄页网站大全一区二区| 久久网站最新地址| 国产福利一区在线观看| 中文字幕av一区二区三区免费看 | 亚洲免费电影在线| 色综合天天做天天爱| 一区二区三区在线免费观看| 欧美影院午夜播放| 国产69精品一区二区亚洲孕妇| 久久精品日产第一区二区三区高清版| 国产传媒一区在线| 中文字幕在线不卡视频| 在线观看免费亚洲| 午夜一区二区三区在线观看| 日韩三级av在线播放| 激情综合五月婷婷| 国产精品理论在线观看| 一本大道久久a久久精二百| 亚洲国产精品久久人人爱| 欧美一个色资源| 国产精品一区二区果冻传媒| ●精品国产综合乱码久久久久| 日本精品一区二区三区高清| 丝袜国产日韩另类美女| www精品美女久久久tv| 成人黄页毛片网站| 亚洲午夜羞羞片| 欧美成人性战久久| av中文字幕亚洲| 亚洲成人在线免费| 国产网站一区二区| 色婷婷激情一区二区三区| 青青草国产成人av片免费| 欧美国产一区二区| 欧美亚一区二区| 激情亚洲综合在线| 成人欧美一区二区三区在线播放| 欧美日韩的一区二区| 激情文学综合丁香| 亚洲视频电影在线| 精品福利在线导航| 91美女视频网站| 久久99国产精品免费网站| 亚洲特黄一级片| 日韩欧美视频一区| 不卡的av网站| 蜜桃精品在线观看| 亚洲日本护士毛茸茸| 精品99一区二区三区| 91美女精品福利| 韩国精品在线观看| 亚洲国产视频网站| 国产女人水真多18毛片18精品视频| 色噜噜狠狠色综合中国| 国产精品一区在线| 亚洲午夜三级在线| 欧美国产禁国产网站cc| 91精品国产色综合久久不卡电影| av在线这里只有精品| 极品销魂美女一区二区三区| 一区二区三区小说| 久久精品日产第一区二区三区高清版| 欧美日韩国产成人在线91| 成人激情av网| 国产一区二区视频在线播放| 亚洲va欧美va人人爽午夜| 国产精品成人在线观看| 日韩欧美国产系列| 精品污污网站免费看| 菠萝蜜视频在线观看一区| 久久不见久久见中文字幕免费| 一区二区三区91| 国产精品久久久一区麻豆最新章节| 日韩欧美区一区二| 欧美肥妇毛茸茸| 色婷婷综合久久久久中文一区二区 | 岛国av在线一区| 美女视频黄a大片欧美| 亚洲国产综合91精品麻豆 | 99天天综合性| 国产成人亚洲综合a∨婷婷图片| 日韩高清一区二区| 亚洲国产视频在线| 亚洲黄色小视频| 亚洲日本免费电影| 国产精品无码永久免费888| www久久精品| 亚洲精品在线三区| 日韩三级在线观看| 日韩一级片在线播放| 在线综合+亚洲+欧美中文字幕| 色香色香欲天天天影视综合网| 成人av资源在线观看| 成人美女视频在线看| 成人一级片在线观看| 国产一区二区三区精品视频| 狠狠色狠狠色合久久伊人| 免费成人av资源网| 蜜桃一区二区三区四区| 日韩高清不卡一区二区三区| 成人免费看视频| 高清成人在线观看| 成人黄色777网| 不卡av在线免费观看| 97精品视频在线观看自产线路二| va亚洲va日韩不卡在线观看| 99久久免费国产| 96av麻豆蜜桃一区二区| 色婷婷久久一区二区三区麻豆| 色综合久久88色综合天天免费| 色婷婷香蕉在线一区二区| 欧亚洲嫩模精品一区三区| 欧美日韩色一区| 6080日韩午夜伦伦午夜伦| 精品成人佐山爱一区二区| 久久久久久久久久久久久女国产乱| 久久免费精品国产久精品久久久久| 亚洲国产成人在线| 亚洲同性同志一二三专区|