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

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

?? stm32f10x_sdio.c

?? 基于Cortex-M3的STM32的IAR EWARM的工程模塊
?? C
?? 第 1 頁 / 共 3 頁
字號:
/******************** (C) COPYRIGHT 2008 STMicroelectronics ********************
* File Name          : stm32f10x_sdio.c
* Author             : MCD Application Team
* Version            : V2.0
* Date               : 05/23/2008
* Description        : This file provides all the SDIO firmware functions.
********************************************************************************
* 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 SOFTWARE AND/OR THE USE MADE BY CUSTOMERS OF THE CODING
* INFORMATION CONTAINED HEREIN IN CONNECTION WITH THEIR PRODUCTS.
* FOR MORE INFORMATION PLEASE CAREFULLY READ THE LICENSE AGREEMENT FILE LOCATED 
* IN THE ROOT DIRECTORY OF THIS FIRMWARE PACKAGE.
*******************************************************************************/

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

/* Private typedef -----------------------------------------------------------*/
/* ------------ SDIO registers bit address in the alias region ----------- */
#define SDIO_OFFSET                (SDIO_BASE - PERIPH_BASE)

/* --- CLKCR Register ---*/
/* Alias word address of CLKEN bit */
#define CLKCR_OFFSET              (SDIO_OFFSET + 0x04)
#define CLKEN_BitNumber           0x08
#define CLKCR_CLKEN_BB            (PERIPH_BB_BASE + (CLKCR_OFFSET * 32) + (CLKEN_BitNumber * 4))

/* --- CMD Register ---*/
/* Alias word address of SDIOSUSPEND bit */
#define CMD_OFFSET                (SDIO_OFFSET + 0x0C)
#define SDIOSUSPEND_BitNumber     0x0B
#define CMD_SDIOSUSPEND_BB        (PERIPH_BB_BASE + (CMD_OFFSET * 32) + (SDIOSUSPEND_BitNumber * 4))

/* Alias word address of ENCMDCOMPL bit */
#define ENCMDCOMPL_BitNumber      0x0C
#define CMD_ENCMDCOMPL_BB         (PERIPH_BB_BASE + (CMD_OFFSET * 32) + (ENCMDCOMPL_BitNumber * 4))

/* Alias word address of NIEN bit */
#define NIEN_BitNumber            0x0D
#define CMD_NIEN_BB               (PERIPH_BB_BASE + (CMD_OFFSET * 32) + (NIEN_BitNumber * 4))

/* Alias word address of ATACMD bit */
#define ATACMD_BitNumber          0x0E
#define CMD_ATACMD_BB             (PERIPH_BB_BASE + (CMD_OFFSET * 32) + (ATACMD_BitNumber * 4))

/* --- DCTRL Register ---*/
/* Alias word address of DMAEN bit */
#define DCTRL_OFFSET              (SDIO_OFFSET + 0x2C)
#define DMAEN_BitNumber           0x03
#define DCTRL_DMAEN_BB            (PERIPH_BB_BASE + (DCTRL_OFFSET * 32) + (DMAEN_BitNumber * 4))

/* Alias word address of RWSTART bit */
#define RWSTART_BitNumber         0x08
#define DCTRL_RWSTART_BB          (PERIPH_BB_BASE + (DCTRL_OFFSET * 32) + (RWSTART_BitNumber * 4))

/* Alias word address of RWSTOP bit */
#define RWSTOP_BitNumber          0x09
#define DCTRL_RWSTOP_BB           (PERIPH_BB_BASE + (DCTRL_OFFSET * 32) + (RWSTOP_BitNumber * 4))

/* Alias word address of RWMOD bit */
#define RWMOD_BitNumber           0x0A
#define DCTRL_RWMOD_BB            (PERIPH_BB_BASE + (DCTRL_OFFSET * 32) + (RWMOD_BitNumber * 4))

/* Alias word address of SDIOEN bit */
#define SDIOEN_BitNumber          0x0B
#define DCTRL_SDIOEN_BB           (PERIPH_BB_BASE + (DCTRL_OFFSET * 32) + (SDIOEN_BitNumber * 4))


/* ---------------------- SDIO registers bit mask ------------------------ */
/* --- CLKCR Register ---*/
/* CLKCR register clear mask */
#define CLKCR_CLEAR_MASK         ((u32)0xFFFF8100) 

/* --- PWRCTRL Register ---*/
/* SDIO PWRCTRL Mask */
#define PWR_PWRCTRL_MASK         ((u32)0xFFFFFFFC)

/* --- DCTRL Register ---*/
/* SDIO DCTRL Clear Mask */
#define DCTRL_CLEAR_MASK         ((u32)0xFFFFFF08)

/* --- CMD Register ---*/
/* CMD Register clear mask */
#define CMD_CLEAR_MASK           ((u32)0xFFFFF800)

/* SDIO RESP Registers Address */
#define SDIO_RESP_ADDR           ((u32)(SDIO_BASE + 0x14))

/* Private define ------------------------------------------------------------*/
/* Private macro -------------------------------------------------------------*/
/* Private variables ---------------------------------------------------------*/
/* Private function prototypes -----------------------------------------------*/
/* Private functions ---------------------------------------------------------*/

/*******************************************************************************
* Function Name  : SDIO_DeInit
* Description    : Deinitializes the SDIO peripheral registers to their default
*                  reset values.
* Input          : None
* Output         : None
* Return         : None
*******************************************************************************/
void SDIO_DeInit(void)
{
  SDIO->POWER = 0x00000000;
  SDIO->CLKCR = 0x00000000;
  SDIO->ARG = 0x00000000;
  SDIO->CMD = 0x00000000;
  SDIO->DTIMER = 0x00000000;
  SDIO->DLEN = 0x00000000;
  SDIO->DCTRL = 0x00000000;
  SDIO->ICR = 0x00C007FF;
  SDIO->MASK = 0x00000000;
}

/*******************************************************************************
* Function Name  : SDIO_Init
* Description    : Initializes the SDIO peripheral according to the specified 
*                  parameters in the SDIO_InitStruct.
* Input          : SDIO_InitStruct : pointer to a SDIO_InitTypeDef structure 
*                  that contains the configuration information for the SDIO 
*                  peripheral.
* Output         : None
* Return         : None
*******************************************************************************/
void SDIO_Init(SDIO_InitTypeDef* SDIO_InitStruct)
{
  u32 tmpreg = 0;
    
  /* Check the parameters */
  assert_param(IS_SDIO_CLOCK_EDGE(SDIO_InitStruct->SDIO_ClockEdge));
  assert_param(IS_SDIO_CLOCK_BYPASS(SDIO_InitStruct->SDIO_ClockBypass));
  assert_param(IS_SDIO_CLOCK_POWER_SAVE(SDIO_InitStruct->SDIO_ClockPowerSave));
  assert_param(IS_SDIO_BUS_WIDE(SDIO_InitStruct->SDIO_BusWide));
  assert_param(IS_SDIO_HARDWARE_FLOW_CONTROL(SDIO_InitStruct->SDIO_HardwareFlowControl)); 
   
/*---------------------------- SDIO CLKCR Configuration ------------------------*/  
  /* Get the SDIO CLKCR value */
  tmpreg = SDIO->CLKCR;
  
  /* Clear CLKDIV, PWRSAV, BYPASS, WIDBUS, NEGEDGE, HWFC_EN bits */
  tmpreg &= CLKCR_CLEAR_MASK;
  
  /* Set CLKDIV bits according to SDIO_ClockDiv value */
  /* Set PWRSAV bit according to SDIO_ClockPowerSave value */
  /* Set BYPASS bit according to SDIO_ClockBypass value */
  /* Set WIDBUS bits according to SDIO_BusWide value */
  /* Set NEGEDGE bits according to SDIO_ClockEdge value */
  /* Set HWFC_EN bits according to SDIO_HardwareFlowControl value */
  tmpreg |= (SDIO_InitStruct->SDIO_ClockDiv  | SDIO_InitStruct->SDIO_ClockPowerSave |
             SDIO_InitStruct->SDIO_ClockBypass | SDIO_InitStruct->SDIO_BusWide |
             SDIO_InitStruct->SDIO_ClockEdge | SDIO_InitStruct->SDIO_HardwareFlowControl); 
  
  /* Write to SDIO CLKCR */
  SDIO->CLKCR = tmpreg;             
}

/*******************************************************************************
* Function Name  : SDIO_StructInit
* Description    : Fills each SDIO_InitStruct member with its default value.
* Input          : SDIO_InitStruct: pointer to an SDIO_InitTypeDef structure which 
*                  will be initialized.
* Output         : None
* Return         : None
*******************************************************************************/
void SDIO_StructInit(SDIO_InitTypeDef* SDIO_InitStruct)
{
  /* SDIO_InitStruct members default value */
  SDIO_InitStruct->SDIO_ClockDiv = 0x00;
  SDIO_InitStruct->SDIO_ClockEdge = SDIO_ClockEdge_Rising;
  SDIO_InitStruct->SDIO_ClockBypass = SDIO_ClockBypass_Disable;
  SDIO_InitStruct->SDIO_ClockPowerSave = SDIO_ClockPowerSave_Disable;
  SDIO_InitStruct->SDIO_BusWide = SDIO_BusWide_1b;
  SDIO_InitStruct->SDIO_HardwareFlowControl = SDIO_HardwareFlowControl_Disable;
}

/*******************************************************************************
* Function Name  : SDIO_ClockCmd
* Description    : Enables or disables the SDIO Clock.
* Input          : NewState: new state of the SDIO Clock.
*                  This parameter can be: ENABLE or DISABLE.
* Output         : None
* Return         : None
*******************************************************************************/
void SDIO_ClockCmd(FunctionalState NewState)
{
  /* Check the parameters */
  assert_param(IS_FUNCTIONAL_STATE(NewState));
  
  *(vu32 *) CLKCR_CLKEN_BB = (u32)NewState;
}

/*******************************************************************************
* Function Name  : SDIO_SetPowerState
* Description    : Sets the power status of the controller.
* Input          : SDIO_PowerState: new state of the Power state. 
*                  This parameter can be one of the following values:
*                   - SDIO_PowerState_OFF
*                   - SDIO_PowerState_ON
* Output         : None
* Return         : None
*******************************************************************************/
void SDIO_SetPowerState(u32 SDIO_PowerState)
{
  /* Check the parameters */
  assert_param(IS_SDIO_POWER_STATE(SDIO_PowerState));
  
  SDIO->POWER &= PWR_PWRCTRL_MASK;
  SDIO->POWER |= SDIO_PowerState;
}

/*******************************************************************************
* Function Name  : SDIO_GetPowerState
* Description    : Gets the power status of the controller.
* Input          : None
* Output         : None
* Return         : Power status of the controller. The returned value can
*                  be one of the following:
*                       - 0x00: Power OFF
*                       - 0x02: Power UP
*                       - 0x03: Power ON 
*******************************************************************************/
u32 SDIO_GetPowerState(void)
{
  return (SDIO->POWER & (~PWR_PWRCTRL_MASK));
}

/*******************************************************************************
* Function Name  : SDIO_ITConfig
* Description    : Enables or disables the SDIO interrupts.
* Input          : - SDIO_IT: specifies the SDIO interrupt sources to be 
*                    enabled or disabled.
*                    This parameter can be one or a combination of the following
*                    values:
*                      - SDIO_IT_CCRCFAIL: Command response received (CRC check
*                                          failed) interrupt    
*                      - SDIO_IT_DCRCFAIL: Data block sent/received (CRC check 
*                                          failed) interrupt    
*                      - SDIO_IT_CTIMEOUT: Command response timeout interrupt    
*                      - SDIO_IT_DTIMEOUT: Data timeout interrupt    
*                      - SDIO_IT_TXUNDERR: Transmit FIFO underrun error interrupt    
*                      - SDIO_IT_RXOVERR:  Received FIFO overrun error interrupt     
*                      - SDIO_IT_CMDREND:  Command response received (CRC check 
*                                          passed) interrupt     
*                      - SDIO_IT_CMDSENT:  Command sent (no response required) 
*                                          interrupt     
*                      - SDIO_IT_DATAEND:  Data end (data counter, SDIDCOUNT, is 
*                                          zero) interrupt     
*                      - SDIO_IT_STBITERR: Start bit not detected on all data 
*                                          signals in wide bus mode interrupt    
*                      - SDIO_IT_DBCKEND:  Data block sent/received (CRC check 
*                                          passed) interrupt    
*                      - SDIO_IT_CMDACT:   Command transfer in progress interrupt     
*                      - SDIO_IT_TXACT:    Data transmit in progress interrupt       
*                      - SDIO_IT_RXACT:    Data receive in progress interrupt      
*                      - SDIO_IT_TXFIFOHE: Transmit FIFO Half Empty interrupt    
*                      - SDIO_IT_RXFIFOHF: Receive FIFO Half Full interrupt   
*                      - SDIO_IT_TXFIFOF:  Transmit FIFO full interrupt     
*                      - SDIO_IT_RXFIFOF:  Receive FIFO full interrupt     
*                      - SDIO_IT_TXFIFOE:  Transmit FIFO empty interrupt      
*                      - SDIO_IT_RXFIFOE:  Receive FIFO empty interrupt     
*                      - SDIO_IT_TXDAVL:   Data available in transmit FIFO interrupt      
*                      - SDIO_IT_RXDAVL:   Data available in receive FIFO interrupt      
*                      - SDIO_IT_SDIOIT:   SD I/O interrupt received interrupt      
*                      - SDIO_IT_CEATAEND: CE-ATA command completion signal 
*                                          received for CMD61 interrupt
*                  - NewState: new state of the specified SDIO interrupts.
*                  This parameter can be: ENABLE or DISABLE.  
* Output         : None
* Return         : None 
*******************************************************************************/
void SDIO_ITConfig(u32 SDIO_IT, FunctionalState NewState)
{
  /* Check the parameters */
  assert_param(IS_SDIO_IT(SDIO_IT));

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
日本欧美加勒比视频| 欧美日韩一区二区欧美激情| 91在线视频18| 欧美一激情一区二区三区| 国产精品乱人伦| 免费成人在线播放| jizz一区二区| 欧美大片日本大片免费观看| 亚洲线精品一区二区三区| 国产精品一级片| 欧美一区永久视频免费观看| 亚洲精品中文在线影院| 国产乱色国产精品免费视频| 5858s免费视频成人| 依依成人综合视频| www.日韩精品| 久久亚洲春色中文字幕久久久| 亚洲电影中文字幕在线观看| 99精品国产热久久91蜜凸| 国产网站一区二区三区| 麻豆专区一区二区三区四区五区| 在线观看欧美精品| 亚洲图片你懂的| 成人激情电影免费在线观看| 精品sm捆绑视频| 久久成人免费网| 日韩欧美在线网站| 看电影不卡的网站| 欧美一区二区三区播放老司机| 亚洲一区二区三区视频在线| 91视频免费观看| 中文字幕日韩av资源站| 99国产精品国产精品久久| 日韩毛片在线免费观看| 日本韩国精品一区二区在线观看| 国产精品国产三级国产| jizzjizzjizz欧美| 亚洲免费av高清| 日本丰满少妇一区二区三区| 一区二区在线看| 欧美猛男gaygay网站| 天堂va蜜桃一区二区三区漫画版| 欧美精品 国产精品| 免费看日韩精品| 久久久综合网站| 成人激情动漫在线观看| 一区二区三区高清在线| 欧美日韩一卡二卡| 精品夜夜嗨av一区二区三区| 国产性天天综合网| 91丨国产丨九色丨pron| 亚洲成人手机在线| 精品福利一区二区三区| 99久久精品国产一区二区三区 | 婷婷综合另类小说色区| 制服丝袜av成人在线看| 精品制服美女丁香| 国产精品系列在线| 欧美日韩一区二区三区四区| 激情综合网av| 国产精品嫩草影院av蜜臀| 日本韩国欧美一区二区三区| 免费在线欧美视频| 亚洲国产精品99久久久久久久久| 色综合久久六月婷婷中文字幕| 亚洲线精品一区二区三区 | 中文字幕一区二区三| 日本精品裸体写真集在线观看 | 欧美一区二区在线视频| 国产盗摄一区二区| 偷拍亚洲欧洲综合| 国产精品免费久久久久| 欧美一级视频精品观看| 91在线观看成人| 美女视频一区在线观看| 亚洲精品亚洲人成人网| 亚洲精品一区二区三区蜜桃下载 | 欧美精品粉嫩高潮一区二区| 丁香一区二区三区| 日精品一区二区| 亚洲区小说区图片区qvod| 欧美xxxxxxxxx| 欧美无砖砖区免费| 国产一区二区成人久久免费影院 | 亚洲免费资源在线播放| 亚洲精品一区二区三区香蕉| 欧美日韩一区二区三区视频 | 欧美日韩黄视频| 国产精品综合一区二区三区| 午夜电影久久久| 综合分类小说区另类春色亚洲小说欧美| 欧美疯狂做受xxxx富婆| 91丨九色丨黑人外教| 高清不卡在线观看| 精品一二三四在线| 麻豆成人综合网| 亚洲激情成人在线| 国产精品妹子av| 国产欧美精品一区二区色综合朱莉| 欧美伦理电影网| 色婷婷久久综合| 91看片淫黄大片一级| 丁香另类激情小说| 国产精品一二三| 狠狠色丁香九九婷婷综合五月 | 亚洲一区二区综合| 中文字幕亚洲不卡| 国产精品视频yy9299一区| 精品久久久久久久久久久久久久久久久| 欧美日韩成人综合天天影院| 国产精品影视天天线| 九九**精品视频免费播放| 久久av中文字幕片| 免费在线看成人av| 久久99国产精品久久| 久久国产生活片100| 极品美女销魂一区二区三区 | 国产性做久久久久久| 久久天天做天天爱综合色| 精品av综合导航| 国产日韩欧美高清| 国产精品久久免费看| 国产精品久久一级| 亚洲日韩欧美一区二区在线| 亚洲欧洲精品天堂一级| 亚洲天堂中文字幕| 一区二区三区欧美久久| 亚洲一区二区三区爽爽爽爽爽| 亚洲成a天堂v人片| 日韩专区在线视频| 国产一区美女在线| 成人激情文学综合网| 色综合婷婷久久| 欧美精选午夜久久久乱码6080| 91精品午夜视频| 久久久久99精品一区| 亚洲视频你懂的| 亚洲成a人v欧美综合天堂| 蜜桃av噜噜一区| 成人av在线网| 欧美日韩国产系列| 精品成人佐山爱一区二区| 国产精品每日更新在线播放网址| 1区2区3区精品视频| 亚洲午夜久久久久久久久久久| 免费观看在线综合色| 国产高清不卡一区二区| 在线观看亚洲一区| 精品三级在线观看| 亚洲色图都市小说| 蜜桃一区二区三区在线观看| 国产大陆a不卡| 欧美亚日韩国产aⅴ精品中极品| 91精品国产一区二区三区香蕉| 久久先锋影音av| 综合久久综合久久| 寂寞少妇一区二区三区| 色悠久久久久综合欧美99| 日韩久久久精品| 亚洲视频一区在线观看| 激情六月婷婷综合| 欧美色图一区二区三区| 国产女同互慰高潮91漫画| 亚洲成av人片| 成人午夜av电影| 日韩亚洲欧美成人一区| 亚洲欧洲美洲综合色网| 精品亚洲成a人| 欧美在线观看禁18| 欧美极品另类videosde| 免费成人在线影院| 欧美中文字幕一区二区三区亚洲| 26uuu精品一区二区三区四区在线 26uuu精品一区二区在线观看 | 91首页免费视频| 久久久精品综合| 日韩成人伦理电影在线观看| 色综合久久久久网| 国产欧美日韩一区二区三区在线观看| 天堂在线亚洲视频| 91在线一区二区三区| 国产欧美精品一区二区色综合| 日本不卡一区二区| 91国产免费观看| 国产精品毛片大码女人| 国产超碰在线一区| 26uuu国产在线精品一区二区| 亚洲成av人片观看| 精品视频123区在线观看| 国产精品国产三级国产普通话蜜臀| 久久99国产精品尤物| 欧美成人乱码一区二区三区| 日韩精品免费视频人成| 欧美精品久久久久久久多人混战| 自拍偷拍欧美激情| voyeur盗摄精品| 亚洲色图制服丝袜| 91九色最新地址| 亚洲精品久久久久久国产精华液| 99精品视频一区二区三区| 中文字幕在线免费不卡|