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

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

?? stm32l1xx_dma.c

?? STM32+Grlib
?? C
?? 第 1 頁 / 共 3 頁
字號:
/**
  ******************************************************************************
  * @file    stm32l1xx_dma.c
  * @author  MCD Application Team
  * @version V1.0.0
  * @date    31-December-2010
  * @brief   This file provides firmware functions to manage the following 
  *          functionalities of the Direct Memory Access controller (DMA):           
  *           - Initialization and Configuration
  *           - Data Counter
  *           - Interrupts and flags management
  *           
  *  @verbatim
  *      
  *          ===================================================================      
  *                                 How to use this driver
  *          =================================================================== 
  *          1. Enable The DMA controller clock using RCC_AHBPeriphClockCmd(RCC_AHBPeriph_DMA1, ENABLE)
  *             function for DMA1 or using RCC_AHBPeriphClockCmd(RCC_AHBPeriph_DMA2, ENABLE)
  *             function for DMA2.
  *
  *          2. Enable and configure the peripheral to be connected to the DMA channel
  *             (except for internal SRAM / FLASH memories: no initialization is 
  *             necessary). 
  *        
  *          3. For a given Channel, program the Source and Destination addresses,  
  *             the transfer Direction, the Buffer Size, the Peripheral and Memory
  *             Incrementation mode and Data Size, the Circular or Normal mode, 
  *             the channel transfer Priority and the Memory-to-Memory transfer 
  *             mode (if needed) using the DMA_Init() function.
  *
  *          4. Enable the NVIC and the corresponding interrupt(s) using the function 
  *             DMA_ITConfig() if you need to use DMA interrupts. 
  *
  *          5. Enable the DMA channel using the DMA_Cmd() function. 
  *                
  *          6. Activate the needed channel Request using PPP_DMACmd() function for
  *             any PPP peripheral except internal SRAM and FLASH (ie. SPI, USART ...)
  *             The function allowing this operation is provided in each PPP peripheral
  *             driver (ie. SPI_DMACmd for SPI peripheral).     
  *
  *          7. Optionally, you can configure the number of data to be transferred
  *             when the channel is disabled (ie. after each Transfer Complete event
  *             or when a Transfer Error occurs) using the function DMA_SetCurrDataCounter().
  *             And you can get the number of remaining data to be transferred using 
  *             the function DMA_GetCurrDataCounter() at run time (when the DMA channel is
  *             enabled and running).  
  *                   
  *          8. To control DMA events you can use one of the following 
  *              two methods:
  *               a- Check on DMA channel flags using the function DMA_GetFlagStatus().  
  *               b- Use DMA interrupts through the function DMA_ITConfig() at initialization
  *                  phase and DMA_GetITStatus() function into interrupt routines in
  *                  communication phase.  
  *              After checking on a flag you should clear it using DMA_ClearFlag()
  *              function. And after checking on an interrupt event you should 
  *              clear it using DMA_ClearITPendingBit() function.     
  *                 
  *  @endverbatim
  *                                  
  ******************************************************************************
  * @attention
  *
  * 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 2010 STMicroelectronics</center></h2>
  ******************************************************************************  
  */ 

/* Includes ------------------------------------------------------------------*/
#include "stm32l1xx_dma.h"
#include "stm32l1xx_rcc.h"

/** @addtogroup STM32L1xx_StdPeriph_Driver
  * @{
  */

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

/* Private typedef -----------------------------------------------------------*/
/* Private define ------------------------------------------------------------*/

/* DMA1 Channelx interrupt pending bit masks */
#define DMA1_CHANNEL1_IT_MASK    ((uint32_t)(DMA_ISR_GIF1 | DMA_ISR_TCIF1 | DMA_ISR_HTIF1 | DMA_ISR_TEIF1))
#define DMA1_CHANNEL2_IT_MASK    ((uint32_t)(DMA_ISR_GIF2 | DMA_ISR_TCIF2 | DMA_ISR_HTIF2 | DMA_ISR_TEIF2))
#define DMA1_CHANNEL3_IT_MASK    ((uint32_t)(DMA_ISR_GIF3 | DMA_ISR_TCIF3 | DMA_ISR_HTIF3 | DMA_ISR_TEIF3))
#define DMA1_CHANNEL4_IT_MASK    ((uint32_t)(DMA_ISR_GIF4 | DMA_ISR_TCIF4 | DMA_ISR_HTIF4 | DMA_ISR_TEIF4))
#define DMA1_CHANNEL5_IT_MASK    ((uint32_t)(DMA_ISR_GIF5 | DMA_ISR_TCIF5 | DMA_ISR_HTIF5 | DMA_ISR_TEIF5))
#define DMA1_CHANNEL6_IT_MASK    ((uint32_t)(DMA_ISR_GIF6 | DMA_ISR_TCIF6 | DMA_ISR_HTIF6 | DMA_ISR_TEIF6))
#define DMA1_CHANNEL7_IT_MASK    ((uint32_t)(DMA_ISR_GIF7 | DMA_ISR_TCIF7 | DMA_ISR_HTIF7 | DMA_ISR_TEIF7))

/* DMA FLAG mask */
#define FLAG_MASK                ((uint32_t)0x10000000)

/* DMA registers Masks */
#define CCR_CLEAR_MASK           ((uint32_t)0xFFFF800F)

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


/** @defgroup DMA_Private_Functions
  * @{
  */

/** @defgroup DMA_Group1 Initialization and Configuration functions
 *  @brief   Initialization and Configuration functions
 *
@verbatim   
 ===============================================================================
                 Initialization and Configuration functions
 ===============================================================================  

  This subsection provides functions allowing to initialize the DMA channel source
  and destination addresses, incrementation and data sizes, transfer direction, 
  buffer size, circular/normal mode selection, memory-to-memory mode selection 
  and channel priority value.
  
  The DMA_Init() function follows the DMA configuration procedures as described in
  reference manual (RM0038).

@endverbatim
  * @{
  */
  
/**
  * @brief  Deinitializes the DMAy Channelx registers to their default reset
  *         values.
  * @param  DMAy_Channelx: where y can be 1 to select the DMA and
  *         x can be 1 to 7 for DMA1 to select the DMA Channel.
  * @retval None
  */
void DMA_DeInit(DMA_Channel_TypeDef* DMAy_Channelx)
{
  /* Check the parameters */
  assert_param(IS_DMA_ALL_PERIPH(DMAy_Channelx));

  /* Disable the selected DMAy Channelx */
  DMAy_Channelx->CCR &= (uint16_t)(~DMA_CCR1_EN);

  /* Reset DMAy Channelx control register */
  DMAy_Channelx->CCR  = 0;
  
  /* Reset DMAy Channelx remaining bytes register */
  DMAy_Channelx->CNDTR = 0;
  
  /* Reset DMAy Channelx peripheral address register */
  DMAy_Channelx->CPAR  = 0;
  
  /* Reset DMAy Channelx memory address register */
  DMAy_Channelx->CMAR = 0;
  
  if (DMAy_Channelx == DMA1_Channel1)
  {
    /* Reset interrupt pending bits for DMA1 Channel1 */
    DMA1->IFCR |= DMA1_CHANNEL1_IT_MASK;
  }
  else if (DMAy_Channelx == DMA1_Channel2)
  {
    /* Reset interrupt pending bits for DMA1 Channel2 */
    DMA1->IFCR |= DMA1_CHANNEL2_IT_MASK;
  }
  else if (DMAy_Channelx == DMA1_Channel3)
  {
    /* Reset interrupt pending bits for DMA1 Channel3 */
    DMA1->IFCR |= DMA1_CHANNEL3_IT_MASK;
  }
  else if (DMAy_Channelx == DMA1_Channel4)
  {
    /* Reset interrupt pending bits for DMA1 Channel4 */
    DMA1->IFCR |= DMA1_CHANNEL4_IT_MASK;
  }
  else if (DMAy_Channelx == DMA1_Channel5)
  {
    /* Reset interrupt pending bits for DMA1 Channel5 */
    DMA1->IFCR |= DMA1_CHANNEL5_IT_MASK;
  }
  else if (DMAy_Channelx == DMA1_Channel6)
  {
    /* Reset interrupt pending bits for DMA1 Channel6 */
    DMA1->IFCR |= DMA1_CHANNEL6_IT_MASK;
  }
  else
  {
    if (DMAy_Channelx == DMA1_Channel7)
    {
      /* Reset interrupt pending bits for DMA1 Channel7 */
      DMA1->IFCR |= DMA1_CHANNEL7_IT_MASK;    
    }
  }
}

/**
  * @brief  Initializes the DMAy Channelx according to the specified
  *         parameters in the DMA_InitStruct.
  * @param  DMAy_Channelx: where y can be 1 to select the DMA and
  *         x can be 1 to 7 for DMA1 to select the DMA Channel.
  * @param  DMA_InitStruct: pointer to a DMA_InitTypeDef structure that
  *         contains the configuration information for the specified DMA Channel.
  * @retval None
  */
void DMA_Init(DMA_Channel_TypeDef* DMAy_Channelx, DMA_InitTypeDef* DMA_InitStruct)
{
  uint32_t tmpreg = 0;

  /* Check the parameters */
  assert_param(IS_DMA_ALL_PERIPH(DMAy_Channelx));
  assert_param(IS_DMA_DIR(DMA_InitStruct->DMA_DIR));
  assert_param(IS_DMA_BUFFER_SIZE(DMA_InitStruct->DMA_BufferSize));
  assert_param(IS_DMA_PERIPHERAL_INC_STATE(DMA_InitStruct->DMA_PeripheralInc));
  assert_param(IS_DMA_MEMORY_INC_STATE(DMA_InitStruct->DMA_MemoryInc));   
  assert_param(IS_DMA_PERIPHERAL_DATA_SIZE(DMA_InitStruct->DMA_PeripheralDataSize));
  assert_param(IS_DMA_MEMORY_DATA_SIZE(DMA_InitStruct->DMA_MemoryDataSize));
  assert_param(IS_DMA_MODE(DMA_InitStruct->DMA_Mode));
  assert_param(IS_DMA_PRIORITY(DMA_InitStruct->DMA_Priority));
  assert_param(IS_DMA_M2M_STATE(DMA_InitStruct->DMA_M2M));

/*--------------------------- DMAy Channelx CCR Configuration -----------------*/
  /* Get the DMAy_Channelx CCR value */
  tmpreg = DMAy_Channelx->CCR;
  /* Clear MEM2MEM, PL, MSIZE, PSIZE, MINC, PINC, CIRC and DIR bits */
  tmpreg &= CCR_CLEAR_MASK;
  /* Configure DMAy Channelx: data transfer, data size, priority level and mode */
  /* Set DIR bit according to DMA_DIR value */
  /* Set CIRC bit according to DMA_Mode value */
  /* Set PINC bit according to DMA_PeripheralInc value */
  /* Set MINC bit according to DMA_MemoryInc value */
  /* Set PSIZE bits according to DMA_PeripheralDataSize value */
  /* Set MSIZE bits according to DMA_MemoryDataSize value */
  /* Set PL bits according to DMA_Priority value */
  /* Set the MEM2MEM bit according to DMA_M2M value */
  tmpreg |= DMA_InitStruct->DMA_DIR | DMA_InitStruct->DMA_Mode |
            DMA_InitStruct->DMA_PeripheralInc | DMA_InitStruct->DMA_MemoryInc |
            DMA_InitStruct->DMA_PeripheralDataSize | DMA_InitStruct->DMA_MemoryDataSize |
            DMA_InitStruct->DMA_Priority | DMA_InitStruct->DMA_M2M;

  /* Write to DMAy Channelx CCR */
  DMAy_Channelx->CCR = tmpreg;

/*--------------------------- DMAy Channelx CNDTR Configuration ---------------*/
  /* Write to DMAy Channelx CNDTR */

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
欧美夫妻性生活| 91在线播放网址| 2023国产精品视频| 东方aⅴ免费观看久久av| 久久精品人人爽人人爽| 成人激情免费视频| 亚洲综合偷拍欧美一区色| 欧美日韩色一区| 激情另类小说区图片区视频区| 久久一区二区三区四区| 成人小视频免费在线观看| 一区二区三区在线免费观看| 在线电影院国产精品| 国产一区高清在线| 亚洲视频香蕉人妖| 91精品国产黑色紧身裤美女| 国产精品一区三区| 一区二区三区免费在线观看| 日韩美一区二区三区| 9久草视频在线视频精品| 天堂av在线一区| 国产亚洲成aⅴ人片在线观看| 色综合中文字幕| 麻豆视频一区二区| 成人欧美一区二区三区视频网页 | 1000精品久久久久久久久| 色老汉av一区二区三区| 久久国产精品72免费观看| 国产精品高清亚洲| 欧美一区二区三区电影| www.性欧美| 九九热在线视频观看这里只有精品| 国产精品国产三级国产aⅴ中文| 欧美日韩成人高清| 成人综合在线视频| 日本成人在线电影网| 最新国产精品久久精品| 欧美本精品男人aⅴ天堂| 色欧美日韩亚洲| 成人午夜在线免费| 紧缚捆绑精品一区二区| 亚洲国产精品久久人人爱蜜臀| 国产午夜亚洲精品不卡| 91精品福利在线一区二区三区| 99久久免费精品| 国产精品性做久久久久久| 日本视频在线一区| 亚洲综合成人在线| 国产精品久久久久一区| 精品噜噜噜噜久久久久久久久试看| 在线区一区二视频| 99这里只有精品| 欧美三日本三级三级在线播放| 大白屁股一区二区视频| 精品在线你懂的| 丝袜亚洲精品中文字幕一区| 亚洲美腿欧美偷拍| 中文字幕一区二区在线播放| 久久久久久久精| www国产成人| 欧美精品一区二区三区在线播放| 正在播放亚洲一区| 欧美日韩三级视频| 欧美巨大另类极品videosbest | 精品一区二区在线观看| 日韩专区一卡二卡| 偷拍自拍另类欧美| 午夜a成v人精品| 亚洲国产aⅴ成人精品无吗| 一区二区三区四区在线免费观看| 欧美激情中文字幕一区二区| 国产亚洲欧美在线| 国产拍揄自揄精品视频麻豆| 欧美激情一区在线观看| 欧美国产丝袜视频| 中文字幕一区二区三区色视频| 国产精品久久毛片a| 亚洲欧洲精品天堂一级| 亚洲欧美一区二区三区孕妇| 有码一区二区三区| 偷拍自拍另类欧美| 老鸭窝一区二区久久精品| 久久99热这里只有精品| 久久99国产精品久久| 国产曰批免费观看久久久| 国产精品一区二区黑丝| 成人国产一区二区三区精品| 91美女片黄在线| 欧美日韩一区二区三区免费看| 欧美日韩电影在线播放| 日韩女优电影在线观看| 国产亚洲欧美在线| 亚洲欧美经典视频| 视频在线观看91| 国产激情精品久久久第一区二区 | 麻豆精品国产传媒mv男同| 麻豆精品一区二区综合av| 国产精品伊人色| 91女神在线视频| 欧美理论电影在线| 久久久不卡影院| 一区二区在线免费| 麻豆精品一区二区综合av| 国产在线不卡视频| 色嗨嗨av一区二区三区| 日韩三级在线免费观看| 国产精品久久久久久久蜜臀| 亚洲不卡av一区二区三区| 蜜臀91精品一区二区三区| 成熟亚洲日本毛茸茸凸凹| 欧美日韩一区二区三区在线看| 亚洲精品在线观| 一区二区三区精品视频| 精品一区二区国语对白| 91看片淫黄大片一级在线观看| 日韩一区二区视频| 1024精品合集| 国内一区二区在线| 欧美图区在线视频| 久久久久久黄色| 日本午夜精品一区二区三区电影| 成人国产视频在线观看| 日韩欧美一级精品久久| 成人动漫在线一区| 7777精品伊人久久久大香线蕉超级流畅 | 欧美日韩精品系列| 久久亚洲一级片| 香蕉影视欧美成人| jiyouzz国产精品久久| 51精品秘密在线观看| 亚洲视频在线观看一区| 国产乱码精品一品二品| 555夜色666亚洲国产免| 亚洲欧美自拍偷拍| 国产一区二区电影| 91精品国产欧美一区二区| 一区二区三区中文字幕| 成人激情免费视频| 久久久久久久综合色一本| 免费成人在线影院| 欧美日韩视频在线一区二区| 亚洲视频免费在线| 成人动漫一区二区| 亚洲精品在线免费观看视频| 琪琪一区二区三区| 欧美喷潮久久久xxxxx| 亚洲欧美日韩成人高清在线一区| 高清在线成人网| 久久免费看少妇高潮| 激情欧美一区二区三区在线观看| 3d成人h动漫网站入口| 亚洲成人av在线电影| 91精彩视频在线| 亚洲欧美日韩国产一区二区三区 | 久久久噜噜噜久久中文字幕色伊伊| 婷婷成人激情在线网| 欧美日韩一卡二卡三卡 | 中文字幕在线不卡一区二区三区| 国产自产v一区二区三区c| 日韩欧美激情一区| 日本成人在线网站| 欧美一区二区三区日韩视频| 天天做天天摸天天爽国产一区| 欧美三级三级三级爽爽爽| 亚洲免费观看高清完整| 91久久奴性调教| 亚洲午夜羞羞片| 欧美精品vⅰdeose4hd| 蜜芽一区二区三区| 精品久久久久久久久久久久包黑料 | 丁香桃色午夜亚洲一区二区三区| 精品对白一区国产伦| 国产麻豆成人精品| 欧美成人高清电影在线| 国产精品一区二区视频| 欧美国产成人在线| 91在线精品秘密一区二区| 亚洲狼人国产精品| 欧美男生操女生| 蜜臀av亚洲一区中文字幕| 日韩一区二区免费视频| 韩国av一区二区三区| 欧美激情一区二区在线| 不卡视频免费播放| 亚洲在线成人精品| 日韩午夜在线观看视频| 国产成人三级在线观看| 亚洲视频小说图片| 69堂成人精品免费视频| 国内精品伊人久久久久av影院| 欧美极品aⅴ影院| 在线观看日韩国产| 久久成人麻豆午夜电影| 麻豆成人91精品二区三区| 国产色91在线| 日本黄色一区二区| 激情综合色综合久久| 亚洲日本乱码在线观看| 3atv一区二区三区| 不卡一卡二卡三乱码免费网站|