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

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

?? stm32f10x_can.c

?? STM32SDCardSourceCodeFATFS.rar
?? C
?? 第 1 頁(yè) / 共 3 頁(yè)
字號(hào):
/**
  ******************************************************************************
  * @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;

?? 快捷鍵說(shuō)明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號(hào) Ctrl + =
減小字號(hào) Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
精品99一区二区三区| 成人蜜臀av电影| 日本一区二区动态图| eeuss鲁片一区二区三区 | 久久久久久久精| 91在线国产福利| 蜜桃传媒麻豆第一区在线观看| 欧美一级二级三级乱码| 国产真实精品久久二三区| 一区二区三区在线免费观看 | 97se亚洲国产综合自在线观| 国产成人日日夜夜| 亚洲电影一区二区| 欧美日韩精品一区二区三区蜜桃 | 国产在线播放一区二区三区| 亚洲精品亚洲人成人网| 日韩手机在线导航| 亚洲国产精品高清| 最新中文字幕一区二区三区| 国产午夜精品一区二区| 欧美手机在线视频| 欧美四级电影在线观看| 久久毛片高清国产| 奇米影视一区二区三区小说| 亚洲一卡二卡三卡四卡五卡| 亚洲在线视频网站| 强制捆绑调教一区二区| 国产美女精品人人做人人爽| eeuss国产一区二区三区| 欧美性大战xxxxx久久久| 国产欧美日韩综合| 亚洲色图视频网| 欧美激情中文字幕一区二区| 亚洲成av人在线观看| 成人成人成人在线视频| 波多野结衣视频一区| 日韩欧美国产1| 国产精品色一区二区三区| 国产欧美日韩在线视频| 激情综合色综合久久| 久久er精品视频| 99国产精品视频免费观看| 精品日韩av一区二区| 久久综合九色综合欧美亚洲| 欧美激情资源网| 激情六月婷婷久久| 欧美精品一区二区三区蜜桃视频| 日韩黄色小视频| 亚洲欧美日韩在线| 日韩国产在线观看一区| 美女视频黄久久| wwww国产精品欧美| 国产精品亚洲一区二区三区妖精 | 在线成人av网站| 亚洲欧洲综合另类| 欧美精品久久天天躁| 男人的天堂久久精品| 久久亚洲一级片| 在线视频中文字幕一区二区| 国产女同性恋一区二区| 色诱视频网站一区| 五月天婷婷综合| 欧美刺激午夜性久久久久久久| 偷拍亚洲欧洲综合| 91视频一区二区三区| av电影在线观看完整版一区二区| 亚洲另类春色国产| 5858s免费视频成人| 亚洲蜜臀av乱码久久精品蜜桃| 色天使久久综合网天天| 奇米777欧美一区二区| 亚洲人精品午夜| 中文子幕无线码一区tr| 欧美一区二区三区免费大片| 亚洲永久精品国产| 国产精品日产欧美久久久久| 欧美人与禽zozo性伦| eeuss鲁片一区二区三区| 高清在线观看日韩| 国产精品久久久久影视| 日本道在线观看一区二区| 成人免费三级在线| av在线不卡免费看| 高清日韩电视剧大全免费| 久热成人在线视频| 久久电影网站中文字幕| 蜜桃传媒麻豆第一区在线观看| 亚洲综合成人在线视频| 日本免费在线视频不卡一不卡二| 夜夜嗨av一区二区三区四季av| 欧美国产精品中文字幕| 久久久久久日产精品| 9191成人精品久久| 日韩一区二区三区电影在线观看| 欧美日韩美少妇| 精品久久人人做人人爽| 国产精品日日摸夜夜摸av| 1区2区3区国产精品| 日韩美女视频19| 丝袜诱惑制服诱惑色一区在线观看| 一区二区免费在线播放| 男女男精品视频| 99久久精品国产麻豆演员表| 日本福利一区二区| 7777精品伊人久久久大香线蕉超级流畅| 欧美高清dvd| 久久伊99综合婷婷久久伊| 国产三级精品在线| 婷婷六月综合网| 91社区在线播放| 国产日韩精品一区二区三区| 亚洲欧美在线视频观看| 午夜欧美2019年伦理| 国产成人精品免费网站| 色婷婷综合激情| 国产欧美一区二区三区沐欲| 亚洲午夜日本在线观看| 成人av小说网| 国产三级精品视频| 蜜臀99久久精品久久久久久软件| 久草热8精品视频在线观看| 欧美三级电影在线看| 国产精品视频一区二区三区不卡| 激情文学综合丁香| 精品国产a毛片| 日韩成人一区二区三区在线观看| 国产mv日韩mv欧美| 欧美一区二区美女| 日韩电影在线观看网站| 欧洲亚洲精品在线| 日韩电影在线免费观看| 日韩欧美国产综合一区| 五月激情综合色| 欧美日韩免费电影| 日本在线不卡视频一二三区| 5858s免费视频成人| 国产美女精品人人做人人爽| 久久综合资源网| 极品美女销魂一区二区三区| 日韩三级在线免费观看| 老司机精品视频在线| 精品久久久久久最新网址| 国产电影一区二区三区| 亚洲高清在线视频| 久久综合久久99| 91视频xxxx| 麻豆国产欧美日韩综合精品二区| 久久伊人蜜桃av一区二区| 97se亚洲国产综合自在线观| 亚洲不卡av一区二区三区| 欧美一区二区女人| 国产一区二区三区蝌蚪| 亚洲精品中文字幕在线观看| 欧美精品777| 在线免费观看视频一区| 久久97超碰国产精品超碰| 国产日韩精品一区二区三区| 色菇凉天天综合网| 蜜桃精品视频在线观看| 亚洲在线视频一区| 亚洲三级在线看| 中文字幕免费不卡| 欧美va亚洲va国产综合| 欧美日韩国产首页| 在线观看视频一区| 欧美性受xxxx| 欧美午夜免费电影| 成人av网址在线观看| 蜜桃av一区二区| 一区二区三区四区精品在线视频| 91精品国产综合久久久蜜臀粉嫩| 成人av电影在线观看| 亚洲综合激情网| 艳妇臀荡乳欲伦亚洲一区| 中文字幕一区二区视频| 国产精品丝袜一区| 亚洲自拍偷拍av| 久久精品国产精品青草| 久久99国产精品免费| 国内久久婷婷综合| 波多野结衣在线一区| 成人国产视频在线观看| 成人晚上爱看视频| 丁香天五香天堂综合| 国产精品白丝jk黑袜喷水| 日产精品久久久久久久性色| 视频在线观看国产精品| 欧美一区二区在线视频| 日本高清免费不卡视频| 欧美日韩色一区| 91精品蜜臀在线一区尤物| 精品国产电影一区二区| 国产一区二区三区电影在线观看| 中文字幕av一区二区三区| 欧美日韩在线播放一区| 国产99久久久精品| 美女爽到高潮91| 韩国一区二区视频| 国产一区二区三区四区五区入口| 一区二区三区四区在线播放|