亚洲欧美第一页_禁久久精品乱码_粉嫩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一区二区三区免费野_久草精品视频
亚洲成人免费在线观看| av一区二区久久| 亚洲成人动漫在线观看| 国产一区二区免费看| 一区二区三区日韩欧美精品| 欧美在线视频全部完| 风间由美一区二区av101| 成人性生交大片免费看在线播放| 五月开心婷婷久久| 亚洲嫩草精品久久| 国产精品国产三级国产aⅴ入口| 成人欧美一区二区三区黑人麻豆| 中文久久乱码一区二区| 国产精品毛片高清在线完整版| 国产精品伦理在线| 亚洲国产精品t66y| 亚洲午夜精品一区二区三区他趣| 日韩专区一卡二卡| 国内精品免费**视频| 久88久久88久久久| 国产一区二区精品久久| 成人午夜av电影| 在线观看成人小视频| 欧美一区二区三区电影| 欧美唯美清纯偷拍| 在线免费观看视频一区| 欧美日韩国产免费一区二区| 91精品在线一区二区| 久久久噜噜噜久噜久久综合| 亚洲一区二区三区在线看| 成人免费视频视频| 日韩欧美一区二区久久婷婷| 国产免费成人在线视频| 亚洲成人福利片| 国产精品一区二区视频| 夫妻av一区二区| 欧美日韩在线免费视频| 精品国产伦一区二区三区观看方式| 国产精品久久久一本精品| 精品夜夜嗨av一区二区三区| 欧美日韩国产天堂| 亚洲色大成网站www久久九九| 免费视频最近日韩| 日韩精品一区二区三区三区免费 | 久久久噜噜噜久噜久久综合| 麻豆国产精品视频| 51精品秘密在线观看| 久久国产婷婷国产香蕉| 制服丝袜在线91| 久草精品在线观看| 久久精品日产第一区二区三区高清版 | 欧美一区二区三区不卡| 国产福利91精品| 亚洲女与黑人做爰| 99视频一区二区| 中文字幕在线观看一区二区| 99久久精品99国产精品| 五月激情丁香一区二区三区| 欧美猛男男办公室激情| 免费成人你懂的| 一区二区三区中文字幕电影| 在线视频一区二区三区| 亚洲观看高清完整版在线观看 | 国产视频一区在线播放| 色一区在线观看| 国产在线精品视频| 天堂成人国产精品一区| 久久久亚洲国产美女国产盗摄| av成人动漫在线观看| 奇米一区二区三区av| 日本一区二区三区四区 | 国产日韩欧美精品一区| 91精品国产综合久久婷婷香蕉| 国产精品888| 久久国产精品免费| 日韩精品欧美精品| 亚洲人成网站在线| 国产精品毛片大码女人| 久久综合资源网| 欧美精品成人一区二区三区四区| 成人激情动漫在线观看| 蜜臀av国产精品久久久久| 亚洲乱码国产乱码精品精可以看| 亚洲国产aⅴ天堂久久| 欧美精品v国产精品v日韩精品| 天堂蜜桃91精品| 国产清纯美女被跳蛋高潮一区二区久久w| 99精品视频在线观看| 久久精品噜噜噜成人88aⅴ | 男女男精品网站| 男女性色大片免费观看一区二区 | 美国三级日本三级久久99| 精品一区二区三区免费毛片爱 | 99精品视频在线播放观看| 国产69精品久久777的优势| 麻豆精品国产传媒mv男同| 日韩不卡免费视频| 日韩av电影免费观看高清完整版| 亚洲高清免费观看| 亚洲国产成人porn| 亚洲成人777| 香蕉加勒比综合久久| 日日夜夜一区二区| 美女久久久精品| 免费成人美女在线观看| 韩日欧美一区二区三区| 福利一区二区在线| 欧美午夜理伦三级在线观看| 欧美一区二区在线播放| 欧美tk—视频vk| 一区二区三区在线视频免费 | 国产在线观看免费一区| 国产精品亚洲视频| 91视频观看免费| 久久精品国产在热久久| 丝袜亚洲另类丝袜在线| 久久精品国产色蜜蜜麻豆| 国产91对白在线观看九色| 91精品午夜视频| 亚洲男同性视频| 成人天堂资源www在线| 欧美男男青年gay1069videost| 国产精品三级在线观看| 日韩不卡一二三区| 欧美天堂亚洲电影院在线播放| 久久久久久久av麻豆果冻| 午夜日韩在线观看| 色美美综合视频| 亚洲精品乱码久久久久久黑人| 国产精品99久久不卡二区| 制服丝袜激情欧洲亚洲| 亚洲私人影院在线观看| 国产一区二区视频在线| 91久久精品国产91性色tv| 日韩亚洲欧美综合| 成人免费在线观看入口| 经典三级在线一区| 久久综合精品国产一区二区三区 | 日韩国产欧美在线播放| 91麻豆精品国产| 久久精品国产澳门| 一区在线中文字幕| 欧美一三区三区四区免费在线看 | 蜜桃在线一区二区三区| 丁香亚洲综合激情啪啪综合| 国产精品五月天| 色狠狠一区二区| 日韩专区中文字幕一区二区| 欧美影片第一页| 日韩影院精彩在线| 欧美三区在线视频| 精品一区二区免费在线观看| 日韩一区二区三区免费看 | 黑人巨大精品欧美一区| 伊人夜夜躁av伊人久久| 精品区一区二区| 欧美怡红院视频| 99国产精品久久久久久久久久久 | 在线综合+亚洲+欧美中文字幕| 日韩精品五月天| 国产精品高清亚洲| 欧美女孩性生活视频| 国产精品2024| 一区二区免费看| **欧美大码日韩| 国产精品久久久久久久久快鸭| 日韩欧美国产综合| 色国产精品一区在线观看| 久久97超碰国产精品超碰| 亚洲成人午夜影院| 亚洲欧美视频在线观看视频| 日韩免费性生活视频播放| 91丨porny丨蝌蚪视频| 亚洲成人777| 亚洲激情av在线| 亚洲黄色性网站| 亚洲精品欧美专区| 亚洲综合区在线| 亚洲成人精品在线观看| 亚洲欧美激情在线| 中文字幕日韩av资源站| 亚洲免费观看高清完整版在线| 亚洲欧洲国产日本综合| 亚洲同性gay激情无套| 日本一区二区久久| 亚洲三级在线观看| 亚洲激情欧美激情| 亚洲一区在线看| 久久国产精品一区二区| 国产精品白丝jk白祙喷水网站| 粉嫩欧美一区二区三区高清影视| 成人白浆超碰人人人人| 色综合久久中文字幕| 欧美精品aⅴ在线视频| 欧美一区二区视频在线观看| 欧美一级夜夜爽| 在线成人av网站| 欧美日韩精品是欧美日韩精品| 国产精品2024| 欧美日韩美女一区二区|