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

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

?? stm32f10x_can.c

?? 基于STM32的 模擬時序
?? C
?? 第 1 頁 / 共 3 頁
字號:
    MessagePending = 0;
  }
  return MessagePending;
}

/*******************************************************************************
* Function Name  : CAN_Receive
* Description    : Receives a message.
* Input          : FIFONumber: Receive FIFO number, CAN_FIFO0 or CAN_FIFO1.
* Output         : RxMessage: pointer to a structure which contains CAN Id,
*                  CAN DLC, CAN datas and FMI number.
* Return         : None.
*******************************************************************************/
void CAN_Receive(u8 FIFONumber, CanRxMsg* RxMessage)
{
  /* Check the parameters */
  assert_param(IS_CAN_FIFO(FIFONumber));

  /* Get the Id */
  RxMessage->IDE = (u8)0x04 & CAN->sFIFOMailBox[FIFONumber].RIR;
  if (RxMessage->IDE == CAN_ID_STD)
  {
    RxMessage->StdId = (u32)0x000007FF & (CAN->sFIFOMailBox[FIFONumber].RIR >> 21);
  }
  else
  {
    RxMessage->ExtId = (u32)0x1FFFFFFF & (CAN->sFIFOMailBox[FIFONumber].RIR >> 3);
  }
  
  RxMessage->RTR = (u8)0x02 & CAN->sFIFOMailBox[FIFONumber].RIR;

  /* Get the DLC */
  RxMessage->DLC = (u8)0x0F & CAN->sFIFOMailBox[FIFONumber].RDTR;

  /* Get the FMI */
  RxMessage->FMI = (u8)0xFF & (CAN->sFIFOMailBox[FIFONumber].RDTR >> 8);

  /* Get the data field */
  RxMessage->Data[0] = (u8)0xFF & CAN->sFIFOMailBox[FIFONumber].RDLR;
  RxMessage->Data[1] = (u8)0xFF & (CAN->sFIFOMailBox[FIFONumber].RDLR >> 8);
  RxMessage->Data[2] = (u8)0xFF & (CAN->sFIFOMailBox[FIFONumber].RDLR >> 16);
  RxMessage->Data[3] = (u8)0xFF & (CAN->sFIFOMailBox[FIFONumber].RDLR >> 24);

  RxMessage->Data[4] = (u8)0xFF & CAN->sFIFOMailBox[FIFONumber].RDHR;
  RxMessage->Data[5] = (u8)0xFF & (CAN->sFIFOMailBox[FIFONumber].RDHR >> 8);
  RxMessage->Data[6] = (u8)0xFF & (CAN->sFIFOMailBox[FIFONumber].RDHR >> 16);
  RxMessage->Data[7] = (u8)0xFF & (CAN->sFIFOMailBox[FIFONumber].RDHR >> 24);

  /* Release the FIFO */
  CAN_FIFORelease(FIFONumber);
}

/*******************************************************************************
* Function Name  : CAN_Sleep
* Description    : Enters the low power mode.
* Input          : None.
* Output         : None.
* Return         : CANSLEEPOK if sleep entered, CANSLEEPFAILED in an other case.
*******************************************************************************/
u8 CAN_Sleep(void)
{
  u8 SleepStatus = 0;

  /* Sleep mode entering request */
  CAN->MCR |= CAN_MCR_SLEEP;
  SleepStatus = CANSLEEPOK;

  /* Sleep mode status */
  if ((CAN->MCR&CAN_MCR_SLEEP) == 0)
  {
    /* Sleep mode not entered */
    SleepStatus = CANSLEEPFAILED;
  }

  /* At this step, sleep mode status */
  return SleepStatus;
}

/*******************************************************************************
* Function Name  : CAN_WakeUp
* Description    : Wakes the CAN up.
* Input          : None.
* Output         : None.
* Return         : CANWAKEUPOK if sleep mode left, CANWAKEUPFAILED in an other
*                  case.
*******************************************************************************/
u8 CAN_WakeUp(void)
{
  u8 WakeUpStatus = 0;

  /* Wake up request */
  CAN->MCR &= ~CAN_MCR_SLEEP;
  WakeUpStatus = CANWAKEUPFAILED;

  /* Sleep mode status */
  if ((CAN->MCR&CAN_MCR_SLEEP) == 0)
  {
    /* Sleep mode exited */
    WakeUpStatus = CANWAKEUPOK;
  }

  /* At this step, sleep mode status */
  return WakeUpStatus;
}

/*******************************************************************************
* Function Name  : CAN_GetFlagStatus
* Description    : Checks whether the specified CAN flag is set or not.
* Input          : CAN_FLAG: specifies the flag to check.
*                  This parameter can be: CAN_FLAG_EWG, CAN_FLAG_EPV or
*                                         CAN_FLAG_BOF.
* Output         : None.
* Return         : The new state of CAN_FLAG (SET or RESET).
*******************************************************************************/
FlagStatus CAN_GetFlagStatus(u32 CAN_FLAG)
{
  FlagStatus bitstatus = RESET;

  /* Check the parameters */
  assert_param(IS_CAN_FLAG(CAN_FLAG));

  /* Check the status of the specified CAN flag */
  if ((CAN->ESR & CAN_FLAG) != (u32)RESET)
  {
    /* CAN_FLAG is set */
    bitstatus = SET;
  }
  else
  {
    /* CAN_FLAG is reset */
    bitstatus = RESET;
  }
  /* Return the CAN_FLAG status */
  return  bitstatus;
}

/*******************************************************************************
* Function Name  : CAN_ClearFlag
* Description    : Clears the CAN's pending flags.
* Input          : CAN_FLAG: specifies the flag to clear.
* Output         : None.
* Return         : None.
*******************************************************************************/
void CAN_ClearFlag(u32 CAN_FLAG)
{
  /* Check the parameters */
  assert_param(IS_CAN_FLAG(CAN_FLAG));

  /* Clear the selected CAN flags */
  CAN->ESR &= ~CAN_FLAG;
}

/*******************************************************************************
* Function Name  : CAN_GetITStatus
* Description    : Checks whether the specified CAN interrupt has occurred or 
*                  not.
* Input          : CAN_IT: specifies the CAN interrupt source to check.
*                  This parameter can be: CAN_IT_RQCP0, CAN_IT_RQCP1, CAN_IT_RQCP2,
*                                         CAN_IT_FF0, CAN_IT_FOV0, CAN_IT_FF1,
*                                         CAN_IT_FOV1, CAN_IT_EWG, CAN_IT_EPV, 
*                                         CAN_IT_BOF, CAN_IT_WKU or CAN_IT_SLK.
* Output         : None.
* Return         : The new state of CAN_IT (SET or RESET).
*******************************************************************************/
ITStatus CAN_GetITStatus(u32 CAN_IT)
{
  ITStatus pendingbitstatus = RESET;

  /* Check the parameters */
  assert_param(IS_CAN_ITStatus(CAN_IT));

  switch (CAN_IT)
  {
    case CAN_IT_RQCP0:
      pendingbitstatus = CheckITStatus(CAN->TSR, CAN_TSR_RQCP0);
      break;
    case CAN_IT_RQCP1:
      pendingbitstatus = CheckITStatus(CAN->TSR, CAN_TSR_RQCP1);
      break;
    case CAN_IT_RQCP2:
      pendingbitstatus = CheckITStatus(CAN->TSR, CAN_TSR_RQCP2);
      break;
    case CAN_IT_FF0:
      pendingbitstatus = CheckITStatus(CAN->RF0R, CAN_RF0R_FULL0);
      break;
    case CAN_IT_FOV0:
      pendingbitstatus = CheckITStatus(CAN->RF0R, CAN_RF0R_FOVR0);
      break;
    case CAN_IT_FF1:
      pendingbitstatus = CheckITStatus(CAN->RF1R, CAN_RF1R_FULL1);
      break;
    case CAN_IT_FOV1:
      pendingbitstatus = CheckITStatus(CAN->RF1R, CAN_RF1R_FOVR1);
      break;
    case CAN_IT_EWG:
      pendingbitstatus = CheckITStatus(CAN->ESR, CAN_ESR_EWGF);
      break;
    case CAN_IT_EPV:
      pendingbitstatus = CheckITStatus(CAN->ESR, CAN_ESR_EPVF);
      break;
    case CAN_IT_BOF:
      pendingbitstatus = CheckITStatus(CAN->ESR, CAN_ESR_BOFF);
      break;
    case CAN_IT_SLK:
      pendingbitstatus = CheckITStatus(CAN->MSR, CAN_MSR_SLAKI);
      break;
    case CAN_IT_WKU:
      pendingbitstatus = CheckITStatus(CAN->MSR, CAN_MSR_WKUI);
      break;

    default :
      pendingbitstatus = RESET;
      break;
  }

  /* Return the CAN_IT status */
  return  pendingbitstatus;
}

/*******************************************************************************
* Function Name  : CAN_ClearITPendingBit
* Description    : Clears the CAN抯 interrupt pending bits.
* Input          : CAN_IT: specifies the interrupt pending bit to clear.
* Output         : None.
* Return         : None.
*******************************************************************************/
void CAN_ClearITPendingBit(u32 CAN_IT)
{
  /* Check the parameters */
  assert_param(IS_CAN_ITStatus(CAN_IT));

  switch (CAN_IT)
  {
    case CAN_IT_RQCP0:
      CAN->TSR = CAN_TSR_RQCP0; /* rc_w1*/
      break;
    case CAN_IT_RQCP1:
      CAN->TSR = CAN_TSR_RQCP1; /* rc_w1*/
      break;
    case CAN_IT_RQCP2:
      CAN->TSR = CAN_TSR_RQCP2; /* rc_w1*/
      break;
    case CAN_IT_FF0:
      CAN->RF0R = CAN_RF0R_FULL0; /* rc_w1*/
      break;
    case CAN_IT_FOV0:
      CAN->RF0R = CAN_RF0R_FOVR0; /* rc_w1*/
      break;
    case CAN_IT_FF1:
      CAN->RF1R = CAN_RF1R_FULL1; /* rc_w1*/
      break;
    case CAN_IT_FOV1:
      CAN->RF1R = CAN_RF1R_FOVR1; /* rc_w1*/
      break;
    case CAN_IT_EWG:
      CAN->ESR &= ~ CAN_ESR_EWGF; /* rw */
      break;
    case CAN_IT_EPV:
      CAN->ESR &= ~ CAN_ESR_EPVF; /* rw */
      break;
    case CAN_IT_BOF:
      CAN->ESR &= ~ CAN_ESR_BOFF; /* rw */
      break;
    case CAN_IT_WKU:
      CAN->MSR = CAN_MSR_WKUI;  /* rc_w1*/
      break;
    case CAN_IT_SLK:
      CAN->MSR = CAN_MSR_SLAKI;  /* rc_w1*/
      break;
    default :
      break;
  }
}

/*******************************************************************************
* Function Name  : CheckITStatus
* Description    : Checks whether the CAN interrupt has occurred or not.
* Input          : CAN_Reg: specifies the CAN interrupt register to check.
*                  It_Bit: specifies the interrupt source bit to check.
* Output         : None.
* Return         : The new state of the CAN Interrupt (SET or RESET).
*******************************************************************************/
static ITStatus CheckITStatus(u32 CAN_Reg, u32 It_Bit)
{
  ITStatus pendingbitstatus = RESET;

  if ((CAN_Reg & It_Bit) != (u32)RESET)
  {
    /* CAN_IT is set */
    pendingbitstatus = SET;
  }
  else
  {
    /* CAN_IT is reset */
    pendingbitstatus = RESET;
  }

  return pendingbitstatus;
}

/******************* (C) COPYRIGHT 2008 STMicroelectronics *****END OF FILE****/

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
亚洲bt欧美bt精品| 国产成a人亚洲精品| 91丨国产丨九色丨pron| 中文字幕高清不卡| 国产真实乱子伦精品视频| 日韩欧美在线观看一区二区三区| 蜜臀av一区二区| 精品欧美一区二区在线观看| 国产在线不卡一区| 国产精品丝袜久久久久久app| av激情成人网| 亚洲一区视频在线观看视频| 欧美日韩一区二区三区高清| 蜜臀精品一区二区三区在线观看 | 天天av天天翘天天综合网色鬼国产| 欧美性一区二区| 日韩av一区二| 国产亚洲精品久| 99久久99久久精品免费观看 | 国产.欧美.日韩| 亚洲欧洲av在线| 7777精品伊人久久久大香线蕉经典版下载| 婷婷丁香激情综合| 久久精品一区四区| 91丝袜呻吟高潮美腿白嫩在线观看| 亚洲一区二区在线视频| 日韩一级片网址| 99国产精品久久久久久久久久久| 亚洲国产人成综合网站| 精品播放一区二区| 91美女片黄在线观看91美女| 久久激情综合网| 亚洲婷婷综合久久一本伊一区| 在线不卡的av| 国产成人亚洲综合a∨婷婷图片| 一区二区三区**美女毛片| 日韩欧美在线网站| 在线精品视频一区二区三四| 精品在线一区二区三区| 亚洲美女免费在线| 欧美sm极限捆绑bd| 欧美性大战久久| 国产iv一区二区三区| 丝袜美腿亚洲一区二区图片| 国产精品乱码人人做人人爱| 欧美一区二区精品| av在线一区二区三区| 免费精品99久久国产综合精品| 一区二区三区日韩在线观看| 久久久99久久精品欧美| 欧美日韩黄视频| 97se亚洲国产综合自在线不卡| 久久精品国产色蜜蜜麻豆| 亚洲一区二区欧美| 亚洲欧洲www| 久久精品一二三| 欧美va亚洲va香蕉在线| 欧美日韩激情一区二区| 在线区一区二视频| 91在线观看成人| 国产成人精品影视| 国产综合一区二区| 日韩成人午夜精品| 亚洲午夜精品17c| 亚洲品质自拍视频| 国产精品高潮久久久久无| 久久色.com| 精品久久久久久久久久久院品网| 欧美美女一区二区| 欧美视频在线观看一区二区| 色噜噜久久综合| 91色porny在线视频| 99久久精品国产导航| 成人午夜免费电影| 成人一二三区视频| 国产白丝网站精品污在线入口| 国产精品一线二线三线精华| 激情小说亚洲一区| 国产米奇在线777精品观看| 麻豆精品视频在线| 美女脱光内衣内裤视频久久影院| 丝袜脚交一区二区| 日本人妖一区二区| 六月婷婷色综合| 麻豆精品一区二区av白丝在线| 免费美女久久99| 久草这里只有精品视频| 一区二区久久久久久| 欧美高清在线一区| 中文一区一区三区高中清不卡| 精品处破学生在线二十三| 精品国产三级a在线观看| 337p日本欧洲亚洲大胆精品| 国产亚洲精品aa| 国产精品美女www爽爽爽| 综合分类小说区另类春色亚洲小说欧美| 国产精品久久99| 亚洲激情一二三区| 亚洲综合久久av| 欧美三级午夜理伦三级中视频| 欧美午夜精品久久久久久超碰| 国产精品的网站| 不卡一区中文字幕| 午夜电影一区二区三区| 亚洲精品免费一二三区| 一区二区三区久久| 蜜桃视频第一区免费观看| 国产精品一区免费视频| 欧美人xxxx| 日韩美女视频一区二区| 麻豆成人综合网| 色狠狠一区二区| 欧美激情在线观看视频免费| 成人午夜激情在线| 18欧美亚洲精品| 欧美日韩视频在线观看一区二区三区 | 97久久精品人人做人人爽50路| 国产欧美在线观看一区| 国产一区在线观看麻豆| 在线91免费看| 中文字幕中文字幕一区二区 | 天堂成人国产精品一区| 极品尤物av久久免费看| 欧洲亚洲精品在线| 亚洲免费在线电影| 国产.欧美.日韩| 欧美精品一区二区三区一线天视频| 亚洲欧美区自拍先锋| 色婷婷久久久久swag精品| 亚洲国产精品v| 亚洲超丰满肉感bbw| 成人精品免费网站| 久久人人97超碰com| 亚洲一区二区在线免费看| 国产视频视频一区| 欧美日韩在线三级| 欧美韩国一区二区| 亚洲激情成人在线| 91精品办公室少妇高潮对白| 亚洲精品菠萝久久久久久久| 91麻豆免费看片| 五月天久久比比资源色| 精品久久久久久最新网址| 国产成人综合亚洲网站| 亚洲午夜精品一区二区三区他趣| 色猫猫国产区一区二在线视频| 综合激情网...| av午夜精品一区二区三区| 国产精品美女久久久久av爽李琼| 成人高清视频在线观看| 五月激情六月综合| 中文字幕欧美国产| 欧美一卡2卡3卡4卡| 91免费版在线看| 国产成人精品一区二区三区网站观看| 麻豆国产精品官网| 欧美一级欧美三级在线观看| 欧美另类z0zxhd电影| 日韩免费一区二区三区在线播放| 欧美一区二区三区色| 精品久久久久久久久久久久久久久久久 | 国产精品久久看| 欧美欧美欧美欧美| 成人高清视频在线观看| 日韩精品福利网| 亚洲精品va在线观看| 欧美激情中文字幕| 欧美不卡一区二区三区四区| 一本高清dvd不卡在线观看| 蜜臀av国产精品久久久久| 中文字幕精品一区二区精品绿巨人 | 亚洲精品欧美综合四区| 精品久久久久香蕉网| 欧美经典一区二区| 国产精品久久一级| 亚洲综合图片区| 《视频一区视频二区| 国产无人区一区二区三区| 欧美精品aⅴ在线视频| 欧美日韩美少妇| 中文字幕av一区二区三区免费看| 一区二区三区国产| 3atv一区二区三区| 欧美日韩一区成人| 色婷婷一区二区三区四区| 欧美bbbbb| 老司机午夜精品| av电影一区二区| 欧美在线免费播放| 成人黄色电影在线| 91精品国产日韩91久久久久久| 中文字幕在线观看一区| 日韩国产在线观看| 欧美日韩亚洲综合| 蜜臀久久99精品久久久画质超高清| 欧美无砖专区一中文字| 精品视频123区在线观看| 午夜视频在线观看一区| 日韩视频永久免费| 国产·精品毛片|