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

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

?? stm32f10x_can.c

?? STM32手持式示波器源代碼
?? 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一区二区三区免费野_久草精品视频
国产毛片精品视频| 蜜桃av一区二区三区| av亚洲精华国产精华| 亚洲丝袜自拍清纯另类| 99re热视频这里只精品| 亚洲综合成人在线视频| 884aa四虎影成人精品一区| 麻豆一区二区三| 国产亚洲欧洲997久久综合| youjizz国产精品| 亚洲精品国产无天堂网2021| 欧美日韩国产欧美日美国产精品| 日韩高清在线一区| 精品国产乱码久久久久久牛牛| 国产成人免费av在线| 一区二区在线观看免费| 日韩片之四级片| 岛国av在线一区| 亚洲最新在线观看| 欧美成人一区二区三区| 成人免费的视频| 亚洲va天堂va国产va久| xvideos.蜜桃一区二区| 日本精品视频一区二区| 奇米四色…亚洲| 亚洲欧洲一区二区在线播放| 在线成人免费视频| 成人av电影在线播放| 婷婷丁香久久五月婷婷| 国产视频一区在线观看| 欧美日韩亚州综合| 床上的激情91.| 日韩激情在线观看| 中文字幕综合网| 欧美r级电影在线观看| 99久久国产综合精品麻豆| 青青草国产精品97视觉盛宴| 国产精品久久久久久久浪潮网站| 欧美一区二区三区在线电影| 99久精品国产| 国产激情视频一区二区三区欧美 | 极品尤物av久久免费看| 亚洲色图欧美激情| 久久亚洲综合av| 91精品在线观看入口| av电影一区二区| 国产一区二区主播在线| 五月婷婷欧美视频| 亚洲特级片在线| 亚洲国产精品v| 精品免费视频一区二区| 精品视频资源站| 色一情一乱一乱一91av| 国产91精品露脸国语对白| 麻豆极品一区二区三区| 亚洲成人免费电影| 亚洲精品成人在线| **欧美大码日韩| 中文字幕精品三区| 国产目拍亚洲精品99久久精品| 91精品在线免费| 欧美久久久久免费| 欧美影院一区二区| 色天天综合久久久久综合片| 成人精品视频一区二区三区| 国产成人av电影在线播放| 久久精品国产第一区二区三区| 亚洲444eee在线观看| 亚洲国产日韩av| 亚洲国产精品精华液网站| 亚洲蜜臀av乱码久久精品蜜桃| 欧美激情综合五月色丁香小说| 久久先锋影音av| 久久午夜电影网| 久久亚洲精华国产精华液 | 2024国产精品| 2024国产精品| 国产亚洲婷婷免费| 国产精品热久久久久夜色精品三区 | 日本韩国一区二区| 91国在线观看| 欧美三级电影网| 欧美日韩情趣电影| 欧美一区二区三区播放老司机| 69久久99精品久久久久婷婷| 在线成人午夜影院| 精品国产91九色蝌蚪| 精品国产3级a| 中文字幕av资源一区| 中文字幕亚洲一区二区va在线| 日韩美女精品在线| 亚洲一区二区av在线| 日韩国产精品久久久| 麻豆91精品视频| 国产成人福利片| 99久久99久久精品国产片果冻| 色女孩综合影院| 欧美日本国产视频| www日韩大片| 国产精品久久久久久福利一牛影视| 亚洲欧美日韩小说| 日韩国产欧美视频| 国产精品自拍毛片| 色综合久久综合网欧美综合网| 欧美性videosxxxxx| 日韩免费看的电影| 亚洲国产成人私人影院tom| 亚洲欧美激情视频在线观看一区二区三区 | 欧美日韩一卡二卡三卡| 欧美sm极限捆绑bd| 亚洲视频每日更新| 蜜臀91精品一区二区三区| 国产精品538一区二区在线| 91麻豆swag| 精品乱码亚洲一区二区不卡| √…a在线天堂一区| 日韩激情一二三区| av电影一区二区| 欧美一卡二卡三卡| 亚洲欧美日韩精品久久久久| 五月婷婷综合网| jizzjizzjizz欧美| 欧美一区二区黄色| 中文字幕中文字幕一区| 日韩va欧美va亚洲va久久| 不卡视频一二三四| 日韩午夜在线播放| 亚洲欧美福利一区二区| 国产乱码字幕精品高清av| 欧亚一区二区三区| 国产女人水真多18毛片18精品视频| 亚洲国产美女搞黄色| 成人伦理片在线| 日韩精品一区二区在线观看| 一区二区三区四区在线播放 | ...av二区三区久久精品| 久久精品国产精品亚洲精品| 在线免费视频一区二区| 国产欧美精品一区二区三区四区| 日韩国产欧美在线播放| 在线免费一区三区| 自拍视频在线观看一区二区| 国产成人在线视频网址| 日韩欧美在线网站| 亚洲成人激情av| 色婷婷综合久色| 亚洲欧洲精品一区二区三区不卡| 国产一区 二区| 精品久久久久久久人人人人传媒| 天天影视色香欲综合网老头| 91精品福利在线| 中文字幕在线播放不卡一区| 国产精品一区二区在线观看网站| 日韩三区在线观看| 日韩电影一区二区三区四区| 欧美三级电影网站| 亚洲一区二区成人在线观看| 色天天综合久久久久综合片| 亚洲欧美偷拍三级| 97se亚洲国产综合在线| 中文字幕欧美一区| 99在线精品观看| ...xxx性欧美| 色婷婷精品大在线视频| 一区二区在线观看视频在线观看| 97精品久久久久中文字幕| 中文字幕一区二区视频| 91玉足脚交白嫩脚丫在线播放| 国产精品福利av| 色综合一个色综合亚洲| 夜夜嗨av一区二区三区 | 欧美精品一卡两卡| 日韩精品一卡二卡三卡四卡无卡| 91精品国模一区二区三区| 秋霞av亚洲一区二区三| 精品国产乱码久久久久久图片| 国内偷窥港台综合视频在线播放| 精品国产欧美一区二区| 国产传媒久久文化传媒| 国产精品久久国产精麻豆99网站| 99精品视频一区二区| 亚洲精品成a人| 欧美精品日日鲁夜夜添| 精品一区二区在线免费观看| 国产亚洲精品bt天堂精选| 99免费精品在线| 亚洲黄色免费电影| 欧美老肥妇做.爰bbww视频| 日本麻豆一区二区三区视频| 欧美xxxx在线观看| 成人自拍视频在线观看| 一区二区三区四区乱视频| 在线播放欧美女士性生活| 精彩视频一区二区三区| 国产精品麻豆欧美日韩ww| 欧美性一级生活| 狠狠色丁香久久婷婷综合_中 | 一区二区视频在线看| 欧美高清视频不卡网| 国产一区二区网址|