mirror of
				https://github.com/FreeRTOS/FreeRTOS-Kernel.git
				synced 2025-10-24 21:57:46 -04:00 
			
		
		
		
	Remove unused files from STM32L discovery board demo directory structure and build.
This commit is contained in:
		
							parent
							
								
									751103d848
								
							
						
					
					
						commit
						0028cc48c1
					
				
					 48 changed files with 330 additions and 21393 deletions
				
			
		|  | @ -991,15 +991,9 @@ | |||
|       <file> | ||||
|         <name>$PROJ_DIR$\ST_Code\Libraries\STM32L1xx_StdPeriph_Driver\src\misc.c</name> | ||||
|       </file> | ||||
|       <file> | ||||
|         <name>$PROJ_DIR$\ST_Code\Libraries\STM32L1xx_StdPeriph_Driver\src\stm32l1xx_adc.c</name> | ||||
|       </file> | ||||
|       <file> | ||||
|         <name>$PROJ_DIR$\ST_Code\Libraries\STM32L1xx_StdPeriph_Driver\src\stm32l1xx_exti.c</name> | ||||
|       </file> | ||||
|       <file> | ||||
|         <name>$PROJ_DIR$\ST_Code\Libraries\STM32L1xx_StdPeriph_Driver\src\stm32l1xx_flash.c</name> | ||||
|       </file> | ||||
|       <file> | ||||
|         <name>$PROJ_DIR$\ST_Code\Libraries\STM32L1xx_StdPeriph_Driver\src\stm32l1xx_gpio.c</name> | ||||
|       </file> | ||||
|  | @ -1022,48 +1016,6 @@ | |||
|         <name>$PROJ_DIR$\ST_Code\Libraries\STM32L1xx_StdPeriph_Driver\src\stm32l1xx_tim.c</name> | ||||
|       </file> | ||||
|     </group> | ||||
|     <group> | ||||
|       <name>TouchSensingDriver</name> | ||||
|       <excluded> | ||||
|         <configuration>Debug</configuration> | ||||
|       </excluded> | ||||
|       <file> | ||||
|         <name>$PROJ_DIR$\ST_Code\Libraries\STMTouch_Driver\src\tsl.c</name> | ||||
|       </file> | ||||
|       <file> | ||||
|         <name>$PROJ_DIR$\ST_Code\Libraries\STMTouch_Driver\src\tsl_acq.c</name> | ||||
|       </file> | ||||
|       <file> | ||||
|         <name>$PROJ_DIR$\ST_Code\Libraries\STMTouch_Driver\src\tsl_acq_stm32l1xx_sw.c</name> | ||||
|       </file> | ||||
|       <file> | ||||
|         <name>$PROJ_DIR$\ST_Code\Libraries\STMTouch_Driver\src\tsl_dxs.c</name> | ||||
|       </file> | ||||
|       <file> | ||||
|         <name>$PROJ_DIR$\ST_Code\Libraries\STMTouch_Driver\src\tsl_ecs.c</name> | ||||
|       </file> | ||||
|       <file> | ||||
|         <name>$PROJ_DIR$\ST_Code\Libraries\STMTouch_Driver\src\tsl_filter.c</name> | ||||
|       </file> | ||||
|       <file> | ||||
|         <name>$PROJ_DIR$\ST_Code\Libraries\STMTouch_Driver\src\tsl_globals.c</name> | ||||
|       </file> | ||||
|       <file> | ||||
|         <name>$PROJ_DIR$\ST_Code\Libraries\STMTouch_Driver\src\tsl_linrot.c</name> | ||||
|       </file> | ||||
|       <file> | ||||
|         <name>$PROJ_DIR$\ST_Code\Libraries\STMTouch_Driver\src\tsl_object.c</name> | ||||
|       </file> | ||||
|       <file> | ||||
|         <name>$PROJ_DIR$\ST_Code\Libraries\STMTouch_Driver\src\tsl_time.c</name> | ||||
|       </file> | ||||
|       <file> | ||||
|         <name>$PROJ_DIR$\ST_Code\Libraries\STMTouch_Driver\src\tsl_time_stm32l1xx.c</name> | ||||
|       </file> | ||||
|       <file> | ||||
|         <name>$PROJ_DIR$\ST_Code\Libraries\STMTouch_Driver\src\tsl_touchkey.c</name> | ||||
|       </file> | ||||
|     </group> | ||||
|   </group> | ||||
|   <group> | ||||
|     <name>Standard Demo Tasks</name> | ||||
|  | @ -1101,18 +1053,9 @@ | |||
|       <name>$PROJ_DIR$\System\system_stm32l1xx.c</name> | ||||
|     </file> | ||||
|   </group> | ||||
|   <file> | ||||
|     <name>$PROJ_DIR$\discover_functions.c</name> | ||||
|   </file> | ||||
|   <file> | ||||
|     <name>$PROJ_DIR$\include\FreeRTOSConfig.h</name> | ||||
|   </file> | ||||
|   <file> | ||||
|     <name>$PROJ_DIR$\icc_measure.c</name> | ||||
|   </file> | ||||
|   <file> | ||||
|     <name>$PROJ_DIR$\icc_measure_Ram.c</name> | ||||
|   </file> | ||||
|   <file> | ||||
|     <name>$PROJ_DIR$\main.c</name> | ||||
|   </file> | ||||
|  | @ -1128,9 +1071,6 @@ | |||
|   <file> | ||||
|     <name>$PROJ_DIR$\STM32L_low_power_tick_management.c</name> | ||||
|   </file> | ||||
|   <file> | ||||
|     <name>$PROJ_DIR$\tsl_user.c</name> | ||||
|   </file> | ||||
| </project> | ||||
| 
 | ||||
| 
 | ||||
|  |  | |||
|  | @ -1,650 +0,0 @@ | |||
| /**
 | ||||
|   ****************************************************************************** | ||||
|   * @file    stm32l1xx_adc.h | ||||
|   * @author  MCD Application Team | ||||
|   * @version V1.1.1 | ||||
|   * @date    05-March-2012 | ||||
|   * @brief   This file contains all the functions prototypes for the ADC firmware  | ||||
|   *          library. | ||||
|   ****************************************************************************** | ||||
|   * @attention | ||||
|   * | ||||
|   * <h2><center>© COPYRIGHT 2012 STMicroelectronics</center></h2> | ||||
|   * | ||||
|   * Licensed under MCD-ST Liberty SW License Agreement V2, (the "License"); | ||||
|   * You may not use this file except in compliance with the License. | ||||
|   * You may obtain a copy of the License at: | ||||
|   * | ||||
|   *        http://www.st.com/software_license_agreement_liberty_v2
 | ||||
|   * | ||||
|   * Unless required by applicable law or agreed to in writing, software  | ||||
|   * distributed under the License is distributed on an "AS IS" BASIS,  | ||||
|   * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. | ||||
|   * See the License for the specific language governing permissions and | ||||
|   * limitations under the License. | ||||
|   * | ||||
|   ****************************************************************************** | ||||
|   */ | ||||
| 
 | ||||
| /* Define to prevent recursive inclusion -------------------------------------*/ | ||||
| #ifndef __STM32L1xx_ADC_H | ||||
| #define __STM32L1xx_ADC_H | ||||
| 
 | ||||
| #ifdef __cplusplus | ||||
|  extern "C" { | ||||
| #endif | ||||
| 
 | ||||
| /* Includes ------------------------------------------------------------------*/ | ||||
| #include "stm32l1xx.h" | ||||
| 
 | ||||
| /** @addtogroup STM32L1xx_StdPeriph_Driver
 | ||||
|   * @{ | ||||
|   */ | ||||
| 
 | ||||
| /** @addtogroup ADC
 | ||||
|   * @{ | ||||
|   */ | ||||
| 
 | ||||
| /* Exported types ------------------------------------------------------------*/ | ||||
| 
 | ||||
| /** 
 | ||||
|   * @brief  ADC Init structure definition   | ||||
|   */ | ||||
|    | ||||
| typedef struct | ||||
| { | ||||
|   uint32_t ADC_Resolution;                /*!< Selects the resolution of the conversion.
 | ||||
|                                                This parameter can be a value of @ref ADC_Resolution */ | ||||
|    | ||||
|   FunctionalState ADC_ScanConvMode;       /*!< Specifies whether the conversion is performed in
 | ||||
|                                                Scan (multichannel) or Single (one channel) mode. | ||||
|                                                This parameter can be set to ENABLE or DISABLE */ | ||||
|    | ||||
|   FunctionalState ADC_ContinuousConvMode; /*!< Specifies whether the conversion is performed in
 | ||||
|                                                Continuous or Single mode. | ||||
|                                                This parameter can be set to ENABLE or DISABLE. */ | ||||
|    | ||||
|   uint32_t ADC_ExternalTrigConvEdge;      /*!< Selects the external trigger Edge and enables the
 | ||||
|                                                trigger of a regular group. This parameter can be a value | ||||
|                                                of @ref ADC_external_trigger_edge_for_regular_channels_conversion */ | ||||
|    | ||||
|   uint32_t ADC_ExternalTrigConv;          /*!< Defines the external trigger used to start the analog
 | ||||
|                                                to digital conversion of regular channels. This parameter | ||||
|                                                can be a value of @ref ADC_external_trigger_sources_for_regular_channels_conversion */ | ||||
|    | ||||
|   uint32_t ADC_DataAlign;                 /*!< Specifies whether the ADC data alignment is left or right.
 | ||||
|                                                This parameter can be a value of @ref ADC_data_align */ | ||||
|    | ||||
|   uint8_t  ADC_NbrOfConversion;           /*!< Specifies the number of ADC conversions that will be done
 | ||||
|                                                using the sequencer for regular channel group. | ||||
|                                                This parameter must range from 1 to 27. */ | ||||
| }ADC_InitTypeDef; | ||||
| 
 | ||||
| typedef struct  | ||||
| {                                               | ||||
|   uint32_t ADC_Prescaler;                 /*!< Selects the ADC prescaler.
 | ||||
|                                                This parameter can be a value  | ||||
|                                                of @ref ADC_Prescaler */ | ||||
| }ADC_CommonInitTypeDef; | ||||
| 
 | ||||
| /* Exported constants --------------------------------------------------------*/ | ||||
| 
 | ||||
| /** @defgroup ADC_Exported_Constants
 | ||||
|   * @{ | ||||
|   */  | ||||
| #define IS_ADC_ALL_PERIPH(PERIPH)                  ((PERIPH) == ADC1) | ||||
| #define IS_ADC_DMA_PERIPH(PERIPH)                  ((PERIPH) == ADC1) | ||||
| 
 | ||||
| /** @defgroup ADC_Power_down_during_Idle_and_or_Delay_phase 
 | ||||
|   * @{ | ||||
|   */  | ||||
| #define ADC_PowerDown_Delay                        ((uint32_t)0x00010000) | ||||
| #define ADC_PowerDown_Idle                         ((uint32_t)0x00020000) | ||||
| #define ADC_PowerDown_Idle_Delay                   ((uint32_t)0x00030000) | ||||
| 
 | ||||
| #define IS_ADC_POWER_DOWN(DWON) (((DWON) == ADC_PowerDown_Delay) || \ | ||||
|                                  ((DWON) == ADC_PowerDown_Idle) || \ | ||||
|                                  ((DWON) == ADC_PowerDown_Idle_Delay)) | ||||
| /**
 | ||||
|   * @} | ||||
|   */  | ||||
| 
 | ||||
| 
 | ||||
| /** @defgroup ADC_Prescaler 
 | ||||
|   * @{ | ||||
|   */  | ||||
| #define ADC_Prescaler_Div1                         ((uint32_t)0x00000000) | ||||
| #define ADC_Prescaler_Div2                         ((uint32_t)0x00010000) | ||||
| #define ADC_Prescaler_Div4                         ((uint32_t)0x00020000) | ||||
| 
 | ||||
| #define IS_ADC_PRESCALER(PRESCALER) (((PRESCALER) == ADC_Prescaler_Div1) || \ | ||||
|                                      ((PRESCALER) == ADC_Prescaler_Div2) || \ | ||||
|                                      ((PRESCALER) == ADC_Prescaler_Div4)) | ||||
| /**
 | ||||
|   * @} | ||||
|   */  | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| /** @defgroup ADC_Resolution 
 | ||||
|   * @{ | ||||
|   */  | ||||
| #define ADC_Resolution_12b                         ((uint32_t)0x00000000) | ||||
| #define ADC_Resolution_10b                         ((uint32_t)0x01000000) | ||||
| #define ADC_Resolution_8b                          ((uint32_t)0x02000000) | ||||
| #define ADC_Resolution_6b                          ((uint32_t)0x03000000) | ||||
| 
 | ||||
| #define IS_ADC_RESOLUTION(RESOLUTION) (((RESOLUTION) == ADC_Resolution_12b) || \ | ||||
|                                        ((RESOLUTION) == ADC_Resolution_10b) || \ | ||||
|                                        ((RESOLUTION) == ADC_Resolution_8b) || \ | ||||
|                                        ((RESOLUTION) == ADC_Resolution_6b)) | ||||
| 
 | ||||
| /**
 | ||||
|   * @} | ||||
|   */  | ||||
| 
 | ||||
| /** @defgroup ADC_external_trigger_edge_for_regular_channels_conversion 
 | ||||
|   * @{ | ||||
|   */  | ||||
| #define ADC_ExternalTrigConvEdge_None              ((uint32_t)0x00000000) | ||||
| #define ADC_ExternalTrigConvEdge_Rising            ((uint32_t)0x10000000) | ||||
| #define ADC_ExternalTrigConvEdge_Falling           ((uint32_t)0x20000000) | ||||
| #define ADC_ExternalTrigConvEdge_RisingFalling     ((uint32_t)0x30000000) | ||||
| 
 | ||||
| #define IS_ADC_EXT_TRIG_EDGE(EDGE) (((EDGE) == ADC_ExternalTrigConvEdge_None) || \ | ||||
|                                     ((EDGE) == ADC_ExternalTrigConvEdge_Rising) || \ | ||||
|                                     ((EDGE) == ADC_ExternalTrigConvEdge_Falling) || \ | ||||
|                                     ((EDGE) == ADC_ExternalTrigConvEdge_RisingFalling)) | ||||
| /**
 | ||||
|   * @} | ||||
|   */  | ||||
| 
 | ||||
| /** @defgroup ADC_external_trigger_sources_for_regular_channels_conversion
 | ||||
|   * @{ | ||||
|   */  | ||||
| 
 | ||||
| /* TIM2 */ | ||||
| #define ADC_ExternalTrigConv_T2_CC3                ((uint32_t)0x02000000) | ||||
| #define ADC_ExternalTrigConv_T2_CC2                ((uint32_t)0x03000000) | ||||
| #define ADC_ExternalTrigConv_T2_TRGO               ((uint32_t)0x06000000) | ||||
| 
 | ||||
| /* TIM3 */ | ||||
| #define ADC_ExternalTrigConv_T3_CC1                ((uint32_t)0x07000000) | ||||
| #define ADC_ExternalTrigConv_T3_CC3                ((uint32_t)0x08000000) | ||||
| #define ADC_ExternalTrigConv_T3_TRGO               ((uint32_t)0x04000000) | ||||
| 
 | ||||
| /* TIM4 */ | ||||
| #define ADC_ExternalTrigConv_T4_CC4                ((uint32_t)0x05000000) | ||||
| #define ADC_ExternalTrigConv_T4_TRGO               ((uint32_t)0x09000000) | ||||
| 
 | ||||
| /* TIM6 */ | ||||
| #define ADC_ExternalTrigConv_T6_TRGO               ((uint32_t)0x0A000000) | ||||
| 
 | ||||
| /* TIM9 */ | ||||
| #define ADC_ExternalTrigConv_T9_CC2                ((uint32_t)0x00000000) | ||||
| #define ADC_ExternalTrigConv_T9_TRGO               ((uint32_t)0x01000000) | ||||
| 
 | ||||
| /* EXTI */ | ||||
| #define ADC_ExternalTrigConv_Ext_IT11              ((uint32_t)0x0F000000) | ||||
| 
 | ||||
| #define IS_ADC_EXT_TRIG(REGTRIG) (((REGTRIG) == ADC_ExternalTrigConv_T9_CC2)  || \ | ||||
|                                   ((REGTRIG) == ADC_ExternalTrigConv_T9_TRGO) || \ | ||||
|                                   ((REGTRIG) == ADC_ExternalTrigConv_T2_CC3)  || \ | ||||
|                                   ((REGTRIG) == ADC_ExternalTrigConv_T2_CC2)  || \ | ||||
|                                   ((REGTRIG) == ADC_ExternalTrigConv_T3_TRGO) || \ | ||||
|                                   ((REGTRIG) == ADC_ExternalTrigConv_T4_CC4)  || \ | ||||
|                                   ((REGTRIG) == ADC_ExternalTrigConv_T2_TRGO) || \ | ||||
|                                   ((REGTRIG) == ADC_ExternalTrigConv_T3_CC1)  || \ | ||||
|                                   ((REGTRIG) == ADC_ExternalTrigConv_T3_CC3)  || \ | ||||
|                                   ((REGTRIG) == ADC_ExternalTrigConv_T4_TRGO) || \ | ||||
|                                   ((REGTRIG) == ADC_ExternalTrigConv_T6_TRGO) || \ | ||||
|                                   ((REGTRIG) == ADC_ExternalTrigConv_Ext_IT11)) | ||||
| /**
 | ||||
|   * @} | ||||
|   */  | ||||
| 
 | ||||
| /** @defgroup ADC_data_align 
 | ||||
|   * @{ | ||||
|   */  | ||||
|    | ||||
| #define ADC_DataAlign_Right                        ((uint32_t)0x00000000) | ||||
| #define ADC_DataAlign_Left                         ((uint32_t)0x00000800) | ||||
| 
 | ||||
| #define IS_ADC_DATA_ALIGN(ALIGN) (((ALIGN) == ADC_DataAlign_Right) || \ | ||||
|                                   ((ALIGN) == ADC_DataAlign_Left)) | ||||
| /**
 | ||||
|   * @} | ||||
|   */  | ||||
| 
 | ||||
| /** @defgroup ADC_channels 
 | ||||
|   * @{ | ||||
|   */  | ||||
| /* ADC Bank A Channels -------------------------------------------------------*/   | ||||
| #define ADC_Channel_0                              ((uint8_t)0x00) | ||||
| #define ADC_Channel_1                              ((uint8_t)0x01) | ||||
| #define ADC_Channel_2                              ((uint8_t)0x02) | ||||
| #define ADC_Channel_3                              ((uint8_t)0x03) | ||||
| 
 | ||||
| #define ADC_Channel_6                              ((uint8_t)0x06) | ||||
| #define ADC_Channel_7                              ((uint8_t)0x07) | ||||
| #define ADC_Channel_8                              ((uint8_t)0x08) | ||||
| #define ADC_Channel_9                              ((uint8_t)0x09) | ||||
| #define ADC_Channel_10                             ((uint8_t)0x0A) | ||||
| #define ADC_Channel_11                             ((uint8_t)0x0B) | ||||
| #define ADC_Channel_12                             ((uint8_t)0x0C) | ||||
| 
 | ||||
| 
 | ||||
| /* ADC Bank B Channels -------------------------------------------------------*/   | ||||
| #define ADC_Channel_0b                             ADC_Channel_0 | ||||
| #define ADC_Channel_1b                             ADC_Channel_1 | ||||
| #define ADC_Channel_2b                             ADC_Channel_2 | ||||
| #define ADC_Channel_3b                             ADC_Channel_3 | ||||
| 
 | ||||
| #define ADC_Channel_6b                             ADC_Channel_6 | ||||
| #define ADC_Channel_7b                             ADC_Channel_7 | ||||
| #define ADC_Channel_8b                             ADC_Channel_8 | ||||
| #define ADC_Channel_9b                             ADC_Channel_9 | ||||
| #define ADC_Channel_10b                            ADC_Channel_10 | ||||
| #define ADC_Channel_11b                            ADC_Channel_11 | ||||
| #define ADC_Channel_12b                            ADC_Channel_12 | ||||
| 
 | ||||
| /* ADC Common Channels (ADC Bank A and B) ------------------------------------*/ | ||||
| #define ADC_Channel_4                              ((uint8_t)0x04) | ||||
| #define ADC_Channel_5                              ((uint8_t)0x05) | ||||
| 
 | ||||
| #define ADC_Channel_13                             ((uint8_t)0x0D) | ||||
| #define ADC_Channel_14                             ((uint8_t)0x0E) | ||||
| #define ADC_Channel_15                             ((uint8_t)0x0F) | ||||
| #define ADC_Channel_16                             ((uint8_t)0x10) | ||||
| #define ADC_Channel_17                             ((uint8_t)0x11) | ||||
| #define ADC_Channel_18                             ((uint8_t)0x12) | ||||
| #define ADC_Channel_19                             ((uint8_t)0x13) | ||||
| #define ADC_Channel_20                             ((uint8_t)0x14) | ||||
| #define ADC_Channel_21                             ((uint8_t)0x15) | ||||
| #define ADC_Channel_22                             ((uint8_t)0x16) | ||||
| #define ADC_Channel_23                             ((uint8_t)0x17) | ||||
| #define ADC_Channel_24                             ((uint8_t)0x18) | ||||
| #define ADC_Channel_25                             ((uint8_t)0x19) | ||||
| 
 | ||||
| #define ADC_Channel_27                             ((uint8_t)0x1B) | ||||
| #define ADC_Channel_28                             ((uint8_t)0x1C) | ||||
| #define ADC_Channel_29                             ((uint8_t)0x1D) | ||||
| #define ADC_Channel_30                             ((uint8_t)0x1E) | ||||
| #define ADC_Channel_31                             ((uint8_t)0x1F) | ||||
| 
 | ||||
| #define ADC_Channel_TempSensor                     ((uint8_t)ADC_Channel_16) | ||||
| #define ADC_Channel_Vrefint                        ((uint8_t)ADC_Channel_17) | ||||
| 
 | ||||
| #define IS_ADC_CHANNEL(CHANNEL) (((CHANNEL) == ADC_Channel_0)  || ((CHANNEL) == ADC_Channel_1)  || \ | ||||
|                                  ((CHANNEL) == ADC_Channel_2)  || ((CHANNEL) == ADC_Channel_3)  || \ | ||||
|                                  ((CHANNEL) == ADC_Channel_4)  || ((CHANNEL) == ADC_Channel_5)  || \ | ||||
|                                  ((CHANNEL) == ADC_Channel_6)  || ((CHANNEL) == ADC_Channel_7)  || \ | ||||
|                                  ((CHANNEL) == ADC_Channel_8)  || ((CHANNEL) == ADC_Channel_9)  || \ | ||||
|                                  ((CHANNEL) == ADC_Channel_10) || ((CHANNEL) == ADC_Channel_11) || \ | ||||
|                                  ((CHANNEL) == ADC_Channel_12) || ((CHANNEL) == ADC_Channel_13) || \ | ||||
|                                  ((CHANNEL) == ADC_Channel_14) || ((CHANNEL) == ADC_Channel_15) || \ | ||||
|                                  ((CHANNEL) == ADC_Channel_16) || ((CHANNEL) == ADC_Channel_17) || \ | ||||
|                                  ((CHANNEL) == ADC_Channel_18) || ((CHANNEL) == ADC_Channel_19) || \ | ||||
|                                  ((CHANNEL) == ADC_Channel_20) || ((CHANNEL) == ADC_Channel_21) || \ | ||||
|                                  ((CHANNEL) == ADC_Channel_22) || ((CHANNEL) == ADC_Channel_23) || \ | ||||
|                                  ((CHANNEL) == ADC_Channel_24) || ((CHANNEL) == ADC_Channel_25) || \ | ||||
|                                  ((CHANNEL) == ADC_Channel_27) || ((CHANNEL) == ADC_Channel_28) || \ | ||||
|                                  ((CHANNEL) == ADC_Channel_29) || ((CHANNEL) == ADC_Channel_30) || \ | ||||
|                                  ((CHANNEL) == ADC_Channel_31)) | ||||
| /**
 | ||||
|   * @} | ||||
|   */  | ||||
| 
 | ||||
| /** @defgroup ADC_sampling_times 
 | ||||
|   * @{ | ||||
|   */  | ||||
| 
 | ||||
| #define ADC_SampleTime_4Cycles                     ((uint8_t)0x00) | ||||
| #define ADC_SampleTime_9Cycles                     ((uint8_t)0x01) | ||||
| #define ADC_SampleTime_16Cycles                    ((uint8_t)0x02) | ||||
| #define ADC_SampleTime_24Cycles                    ((uint8_t)0x03) | ||||
| #define ADC_SampleTime_48Cycles                    ((uint8_t)0x04) | ||||
| #define ADC_SampleTime_96Cycles                    ((uint8_t)0x05) | ||||
| #define ADC_SampleTime_192Cycles                   ((uint8_t)0x06) | ||||
| #define ADC_SampleTime_384Cycles                   ((uint8_t)0x07) | ||||
| 
 | ||||
| #define IS_ADC_SAMPLE_TIME(TIME) (((TIME) == ADC_SampleTime_4Cycles)   || \ | ||||
|                                   ((TIME) == ADC_SampleTime_9Cycles)   || \ | ||||
|                                   ((TIME) == ADC_SampleTime_16Cycles)  || \ | ||||
|                                   ((TIME) == ADC_SampleTime_24Cycles)  || \ | ||||
|                                   ((TIME) == ADC_SampleTime_48Cycles)  || \ | ||||
|                                   ((TIME) == ADC_SampleTime_96Cycles)  || \ | ||||
|                                   ((TIME) == ADC_SampleTime_192Cycles) || \ | ||||
|                                   ((TIME) == ADC_SampleTime_384Cycles)) | ||||
| /**
 | ||||
|   * @} | ||||
|   */  | ||||
| 
 | ||||
| /** @defgroup ADC_Delay_length 
 | ||||
|   * @{ | ||||
|   */  | ||||
| 
 | ||||
| #define ADC_DelayLength_None                       ((uint8_t)0x00) | ||||
| #define ADC_DelayLength_Freeze                     ((uint8_t)0x10) | ||||
| #define ADC_DelayLength_7Cycles                    ((uint8_t)0x20) | ||||
| #define ADC_DelayLength_15Cycles                   ((uint8_t)0x30) | ||||
| #define ADC_DelayLength_31Cycles                   ((uint8_t)0x40) | ||||
| #define ADC_DelayLength_63Cycles                   ((uint8_t)0x50) | ||||
| #define ADC_DelayLength_127Cycles                  ((uint8_t)0x60) | ||||
| #define ADC_DelayLength_255Cycles                  ((uint8_t)0x70) | ||||
| 
 | ||||
| #define IS_ADC_DELAY_LENGTH(LENGTH) (((LENGTH) == ADC_DelayLength_None)      || \ | ||||
|                                      ((LENGTH) == ADC_DelayLength_Freeze)    || \ | ||||
|                                      ((LENGTH) == ADC_DelayLength_7Cycles)   || \ | ||||
|                                      ((LENGTH) == ADC_DelayLength_15Cycles)  || \ | ||||
|                                      ((LENGTH) == ADC_DelayLength_31Cycles)  || \ | ||||
|                                      ((LENGTH) == ADC_DelayLength_63Cycles)  || \ | ||||
|                                      ((LENGTH) == ADC_DelayLength_127Cycles) || \ | ||||
|                                      ((LENGTH) == ADC_DelayLength_255Cycles)) | ||||
| 
 | ||||
| /**
 | ||||
|   * @} | ||||
|   */ | ||||
| 
 | ||||
| /** @defgroup ADC_external_trigger_edge_for_injected_channels_conversion 
 | ||||
|   * @{ | ||||
|   */  | ||||
| #define ADC_ExternalTrigInjecConvEdge_None          ((uint32_t)0x00000000) | ||||
| #define ADC_ExternalTrigInjecConvEdge_Rising        ((uint32_t)0x00100000) | ||||
| #define ADC_ExternalTrigInjecConvEdge_Falling       ((uint32_t)0x00200000) | ||||
| #define ADC_ExternalTrigInjecConvEdge_RisingFalling ((uint32_t)0x00300000) | ||||
| 
 | ||||
| #define IS_ADC_EXT_INJEC_TRIG_EDGE(EDGE) (((EDGE) == ADC_ExternalTrigInjecConvEdge_None)    || \ | ||||
|                                           ((EDGE) == ADC_ExternalTrigInjecConvEdge_Rising)  || \ | ||||
|                                           ((EDGE) == ADC_ExternalTrigInjecConvEdge_Falling) || \ | ||||
|                                           ((EDGE) == ADC_ExternalTrigInjecConvEdge_RisingFalling)) | ||||
| /**
 | ||||
|   * @} | ||||
|   */  | ||||
| 
 | ||||
| 
 | ||||
| /** @defgroup ADC_external_trigger_sources_for_injected_channels_conversion 
 | ||||
|   * @{ | ||||
|   */  | ||||
| 
 | ||||
| 
 | ||||
| /* TIM2 */ | ||||
| #define ADC_ExternalTrigInjecConv_T2_TRGO          ((uint32_t)0x00020000) | ||||
| #define ADC_ExternalTrigInjecConv_T2_CC1           ((uint32_t)0x00030000) | ||||
| 
 | ||||
| /* TIM3 */ | ||||
| #define ADC_ExternalTrigInjecConv_T3_CC4           ((uint32_t)0x00040000) | ||||
| 
 | ||||
| /* TIM4 */ | ||||
| #define ADC_ExternalTrigInjecConv_T4_TRGO          ((uint32_t)0x00050000) | ||||
| #define ADC_ExternalTrigInjecConv_T4_CC1           ((uint32_t)0x00060000) | ||||
| #define ADC_ExternalTrigInjecConv_T4_CC2           ((uint32_t)0x00070000) | ||||
| #define ADC_ExternalTrigInjecConv_T4_CC3           ((uint32_t)0x00080000) | ||||
| 
 | ||||
| /* TIM7 */ | ||||
| #define ADC_ExternalTrigInjecConv_T7_TRGO          ((uint32_t)0x000A0000) | ||||
| 
 | ||||
| /* TIM9 */ | ||||
| #define ADC_ExternalTrigInjecConv_T9_CC1           ((uint32_t)0x00000000) | ||||
| #define ADC_ExternalTrigInjecConv_T9_TRGO          ((uint32_t)0x00010000) | ||||
| 
 | ||||
| /* TIM10 */ | ||||
| #define ADC_ExternalTrigInjecConv_T10_CC1          ((uint32_t)0x00090000) | ||||
| 
 | ||||
| /* EXTI */ | ||||
| #define ADC_ExternalTrigInjecConv_Ext_IT15         ((uint32_t)0x000F0000) | ||||
| 
 | ||||
| #define IS_ADC_EXT_INJEC_TRIG(INJTRIG) (((INJTRIG) == ADC_ExternalTrigInjecConv_T9_CC1)  || \ | ||||
|                                         ((INJTRIG) == ADC_ExternalTrigInjecConv_T9_TRGO) || \ | ||||
|                                         ((INJTRIG) == ADC_ExternalTrigInjecConv_T2_TRGO) || \ | ||||
|                                         ((INJTRIG) == ADC_ExternalTrigInjecConv_T2_CC1)  || \ | ||||
|                                         ((INJTRIG) == ADC_ExternalTrigInjecConv_T3_CC4)  || \ | ||||
|                                         ((INJTRIG) == ADC_ExternalTrigInjecConv_T4_TRGO) || \ | ||||
|                                         ((INJTRIG) == ADC_ExternalTrigInjecConv_T4_CC1)  || \ | ||||
|                                         ((INJTRIG) == ADC_ExternalTrigInjecConv_T4_CC2)  || \ | ||||
|                                         ((INJTRIG) == ADC_ExternalTrigInjecConv_T4_CC3)  || \ | ||||
|                                         ((INJTRIG) == ADC_ExternalTrigInjecConv_T10_CC1) || \ | ||||
|                                         ((INJTRIG) == ADC_ExternalTrigInjecConv_T7_TRGO) || \ | ||||
|                                         ((INJTRIG) == ADC_ExternalTrigInjecConv_Ext_IT15)) | ||||
| /**
 | ||||
|   * @} | ||||
|   */  | ||||
| 
 | ||||
| /** @defgroup ADC_injected_channel_selection 
 | ||||
|   * @{ | ||||
|   */  | ||||
| #define ADC_InjectedChannel_1                      ((uint8_t)0x18) | ||||
| #define ADC_InjectedChannel_2                      ((uint8_t)0x1C) | ||||
| #define ADC_InjectedChannel_3                      ((uint8_t)0x20) | ||||
| #define ADC_InjectedChannel_4                      ((uint8_t)0x24) | ||||
| 
 | ||||
| #define IS_ADC_INJECTED_CHANNEL(CHANNEL) (((CHANNEL) == ADC_InjectedChannel_1) || \ | ||||
|                                           ((CHANNEL) == ADC_InjectedChannel_2) || \ | ||||
|                                           ((CHANNEL) == ADC_InjectedChannel_3) || \ | ||||
|                                           ((CHANNEL) == ADC_InjectedChannel_4)) | ||||
| /**
 | ||||
|   * @} | ||||
|   */  | ||||
| 
 | ||||
| /** @defgroup ADC_analog_watchdog_selection 
 | ||||
|   * @{ | ||||
|   */  | ||||
|    | ||||
| #define ADC_AnalogWatchdog_SingleRegEnable         ((uint32_t)0x00800200) | ||||
| #define ADC_AnalogWatchdog_SingleInjecEnable       ((uint32_t)0x00400200) | ||||
| #define ADC_AnalogWatchdog_SingleRegOrInjecEnable  ((uint32_t)0x00C00200)  | ||||
| #define ADC_AnalogWatchdog_AllRegEnable            ((uint32_t)0x00800000) | ||||
| #define ADC_AnalogWatchdog_AllInjecEnable          ((uint32_t)0x00400000) | ||||
| #define ADC_AnalogWatchdog_AllRegAllInjecEnable    ((uint32_t)0x00C00000) | ||||
| #define ADC_AnalogWatchdog_None                    ((uint32_t)0x00000000) | ||||
| 
 | ||||
| #define IS_ADC_ANALOG_WATCHDOG(WATCHDOG) (((WATCHDOG) == ADC_AnalogWatchdog_SingleRegEnable)        || \ | ||||
|                                           ((WATCHDOG) == ADC_AnalogWatchdog_SingleInjecEnable)      || \ | ||||
|                                           ((WATCHDOG) == ADC_AnalogWatchdog_SingleRegOrInjecEnable) || \ | ||||
|                                           ((WATCHDOG) == ADC_AnalogWatchdog_AllRegEnable)           || \ | ||||
|                                           ((WATCHDOG) == ADC_AnalogWatchdog_AllInjecEnable)         || \ | ||||
|                                           ((WATCHDOG) == ADC_AnalogWatchdog_AllRegAllInjecEnable)   || \ | ||||
|                                           ((WATCHDOG) == ADC_AnalogWatchdog_None)) | ||||
| /**
 | ||||
|   * @} | ||||
|   */  | ||||
| 
 | ||||
| /** @defgroup ADC_interrupts_definition 
 | ||||
|   * @{ | ||||
|   */  | ||||
|    | ||||
| #define ADC_IT_AWD                                 ((uint16_t)0x0106)  | ||||
| #define ADC_IT_EOC                                 ((uint16_t)0x0205)  | ||||
| #define ADC_IT_JEOC                                ((uint16_t)0x0407)   | ||||
| #define ADC_IT_OVR                                 ((uint16_t)0x201A)  | ||||
|   | ||||
| #define IS_ADC_IT(IT) (((IT) == ADC_IT_AWD) || ((IT) == ADC_IT_EOC) || \ | ||||
|                        ((IT) == ADC_IT_JEOC)|| ((IT) == ADC_IT_OVR))  | ||||
| /**
 | ||||
|   * @} | ||||
|   */  | ||||
| 
 | ||||
| /** @defgroup ADC_flags_definition 
 | ||||
|   * @{ | ||||
|   */  | ||||
|    | ||||
| #define ADC_FLAG_AWD                               ((uint16_t)0x0001) | ||||
| #define ADC_FLAG_EOC                               ((uint16_t)0x0002) | ||||
| #define ADC_FLAG_JEOC                              ((uint16_t)0x0004) | ||||
| #define ADC_FLAG_JSTRT                             ((uint16_t)0x0008) | ||||
| #define ADC_FLAG_STRT                              ((uint16_t)0x0010) | ||||
| #define ADC_FLAG_OVR                               ((uint16_t)0x0020) | ||||
| #define ADC_FLAG_ADONS                             ((uint16_t)0x0040) | ||||
| #define ADC_FLAG_RCNR                              ((uint16_t)0x0100) | ||||
| #define ADC_FLAG_JCNR                              ((uint16_t)0x0200)  | ||||
|    | ||||
| #define IS_ADC_CLEAR_FLAG(FLAG) ((((FLAG) & (uint16_t)0xFFC0) == 0x00) && ((FLAG) != 0x00)) | ||||
|     | ||||
| #define IS_ADC_GET_FLAG(FLAG) (((FLAG) == ADC_FLAG_AWD)   || ((FLAG) == ADC_FLAG_EOC)  || \ | ||||
|                                ((FLAG) == ADC_FLAG_JEOC)  || ((FLAG)== ADC_FLAG_JSTRT) || \ | ||||
|                                ((FLAG) == ADC_FLAG_STRT)  || ((FLAG)== ADC_FLAG_OVR)   || \ | ||||
|                                ((FLAG) == ADC_FLAG_ADONS) || ((FLAG)== ADC_FLAG_RCNR)  || \ | ||||
|                                ((FLAG) == ADC_FLAG_JCNR)) | ||||
| /**
 | ||||
|   * @} | ||||
|   */  | ||||
| 
 | ||||
| /** @defgroup ADC_thresholds 
 | ||||
|   * @{ | ||||
|   */  | ||||
|    | ||||
| #define IS_ADC_THRESHOLD(THRESHOLD) ((THRESHOLD) <= 0xFFF) | ||||
| 
 | ||||
| /**
 | ||||
|   * @} | ||||
|   */  | ||||
| 
 | ||||
| /** @defgroup ADC_injected_offset 
 | ||||
|   * @{ | ||||
|   */ | ||||
|     | ||||
| #define IS_ADC_OFFSET(OFFSET) ((OFFSET) <= 0xFFF) | ||||
| 
 | ||||
| /**
 | ||||
|   * @} | ||||
|   */  | ||||
| 
 | ||||
| /** @defgroup ADC_injected_length 
 | ||||
|   * @{ | ||||
|   */ | ||||
|     | ||||
| #define IS_ADC_INJECTED_LENGTH(LENGTH) (((LENGTH) >= 0x1) && ((LENGTH) <= 0x4)) | ||||
| 
 | ||||
| /**
 | ||||
|   * @} | ||||
|   */  | ||||
| 
 | ||||
| /** @defgroup ADC_injected_rank 
 | ||||
|   * @{ | ||||
|   */  | ||||
|    | ||||
| #define IS_ADC_INJECTED_RANK(RANK) (((RANK) >= 0x1) && ((RANK) <= 0x4)) | ||||
| 
 | ||||
| /**
 | ||||
|   * @} | ||||
|   */  | ||||
| 
 | ||||
| /** @defgroup ADC_regular_length 
 | ||||
|   * @{ | ||||
|   */ | ||||
|     | ||||
| #define IS_ADC_REGULAR_LENGTH(LENGTH) (((LENGTH) >= 1) && ((LENGTH) <= 28)) | ||||
| 
 | ||||
| /**
 | ||||
|   * @} | ||||
|   */  | ||||
| 
 | ||||
| /** @defgroup ADC_regular_rank 
 | ||||
|   * @{ | ||||
|   */  | ||||
|    | ||||
| #define IS_ADC_REGULAR_RANK(RANK) (((RANK) >= 1) && ((RANK) <= 28)) | ||||
| 
 | ||||
| /**
 | ||||
|   * @} | ||||
|   */  | ||||
| 
 | ||||
| /** @defgroup ADC_regular_discontinuous_mode_number 
 | ||||
|   * @{ | ||||
|   */ | ||||
|     | ||||
| #define IS_ADC_REGULAR_DISC_NUMBER(NUMBER) (((NUMBER) >= 0x1) && ((NUMBER) <= 0x8)) | ||||
| 
 | ||||
| /**
 | ||||
|   * @} | ||||
|   */  | ||||
| 
 | ||||
| /** @defgroup ADC_Bank_Selection 
 | ||||
|   * @{ | ||||
|   */  | ||||
| #define ADC_Bank_A                                 ((uint8_t)0x00) | ||||
| #define ADC_Bank_B                                 ((uint8_t)0x01)   | ||||
| #define IS_ADC_BANK(BANK) (((BANK) == ADC_Bank_A)   || ((BANK) == ADC_Bank_B)) | ||||
| 
 | ||||
| /**
 | ||||
|   * @} | ||||
|   */  | ||||
| 
 | ||||
| /**
 | ||||
|   * @} | ||||
|   */  | ||||
| 
 | ||||
| /* Exported macro ------------------------------------------------------------*/ | ||||
| /* Exported functions ------------------------------------------------------- */  | ||||
| 
 | ||||
| /*  Function used to set the ADC configuration to the default reset state *****/    | ||||
| void ADC_DeInit(ADC_TypeDef* ADCx);  | ||||
| 
 | ||||
| /* Initialization and Configuration functions *********************************/  | ||||
| void ADC_Init(ADC_TypeDef* ADCx, ADC_InitTypeDef* ADC_InitStruct); | ||||
| void ADC_StructInit(ADC_InitTypeDef* ADC_InitStruct); | ||||
| void ADC_CommonInit(ADC_CommonInitTypeDef* ADC_CommonInitStruct); | ||||
| void ADC_CommonStructInit(ADC_CommonInitTypeDef* ADC_CommonInitStruct); | ||||
| void ADC_Cmd(ADC_TypeDef* ADCx, FunctionalState NewState); | ||||
| void ADC_BankSelection(ADC_TypeDef* ADCx, uint8_t ADC_Bank); | ||||
| 
 | ||||
| /* Power saving functions *****************************************************/ | ||||
| void ADC_PowerDownCmd(ADC_TypeDef* ADCx, uint32_t ADC_PowerDown, FunctionalState NewState); | ||||
| void ADC_DelaySelectionConfig(ADC_TypeDef* ADCx, uint8_t ADC_DelayLength); | ||||
| 
 | ||||
| /* Analog Watchdog configuration functions ************************************/ | ||||
| void ADC_AnalogWatchdogCmd(ADC_TypeDef* ADCx, uint32_t ADC_AnalogWatchdog); | ||||
| void ADC_AnalogWatchdogThresholdsConfig(ADC_TypeDef* ADCx, uint16_t HighThreshold,uint16_t LowThreshold); | ||||
| void ADC_AnalogWatchdogSingleChannelConfig(ADC_TypeDef* ADCx, uint8_t ADC_Channel); | ||||
| 
 | ||||
| /* Temperature Sensor & Vrefint (Voltage Reference internal) management function */ | ||||
| void ADC_TempSensorVrefintCmd(FunctionalState NewState); | ||||
| 
 | ||||
| /* Regular Channels Configuration functions ***********************************/ | ||||
| void ADC_RegularChannelConfig(ADC_TypeDef* ADCx, uint8_t ADC_Channel, uint8_t Rank, uint8_t ADC_SampleTime); | ||||
| void ADC_SoftwareStartConv(ADC_TypeDef* ADCx); | ||||
| FlagStatus ADC_GetSoftwareStartConvStatus(ADC_TypeDef* ADCx); | ||||
| void ADC_EOCOnEachRegularChannelCmd(ADC_TypeDef* ADCx, FunctionalState NewState); | ||||
| void ADC_ContinuousModeCmd(ADC_TypeDef* ADCx, FunctionalState NewState); | ||||
| void ADC_DiscModeChannelCountConfig(ADC_TypeDef* ADCx, uint8_t Number); | ||||
| void ADC_DiscModeCmd(ADC_TypeDef* ADCx, FunctionalState NewState); | ||||
| uint16_t ADC_GetConversionValue(ADC_TypeDef* ADCx); | ||||
| 
 | ||||
| /* Regular Channels DMA Configuration functions *******************************/ | ||||
| void ADC_DMACmd(ADC_TypeDef* ADCx, FunctionalState NewState); | ||||
| void ADC_DMARequestAfterLastTransferCmd(ADC_TypeDef* ADCx, FunctionalState NewState); | ||||
| 
 | ||||
| /* Injected channels Configuration functions **********************************/ | ||||
| void ADC_InjectedChannelConfig(ADC_TypeDef* ADCx, uint8_t ADC_Channel, uint8_t Rank, uint8_t ADC_SampleTime); | ||||
| void ADC_InjectedSequencerLengthConfig(ADC_TypeDef* ADCx, uint8_t Length); | ||||
| void ADC_SetInjectedOffset(ADC_TypeDef* ADCx, uint8_t ADC_InjectedChannel, uint16_t Offset); | ||||
| void ADC_ExternalTrigInjectedConvConfig(ADC_TypeDef* ADCx, uint32_t ADC_ExternalTrigInjecConv); | ||||
| void ADC_ExternalTrigInjectedConvEdgeConfig(ADC_TypeDef* ADCx, uint32_t ADC_ExternalTrigInjecConvEdge); | ||||
| void ADC_SoftwareStartInjectedConv(ADC_TypeDef* ADCx); | ||||
| FlagStatus ADC_GetSoftwareStartInjectedConvCmdStatus(ADC_TypeDef* ADCx); | ||||
| void ADC_AutoInjectedConvCmd(ADC_TypeDef* ADCx, FunctionalState NewState); | ||||
| void ADC_InjectedDiscModeCmd(ADC_TypeDef* ADCx, FunctionalState NewState); | ||||
| uint16_t ADC_GetInjectedConversionValue(ADC_TypeDef* ADCx, uint8_t ADC_InjectedChannel); | ||||
| 
 | ||||
| /* Interrupts and flags management functions **********************************/ | ||||
| void ADC_ITConfig(ADC_TypeDef* ADCx, uint16_t ADC_IT, FunctionalState NewState); | ||||
| FlagStatus ADC_GetFlagStatus(ADC_TypeDef* ADCx, uint16_t ADC_FLAG); | ||||
| void ADC_ClearFlag(ADC_TypeDef* ADCx, uint16_t ADC_FLAG); | ||||
| ITStatus ADC_GetITStatus(ADC_TypeDef* ADCx, uint16_t ADC_IT); | ||||
| void ADC_ClearITPendingBit(ADC_TypeDef* ADCx, uint16_t ADC_IT); | ||||
| 
 | ||||
| #ifdef __cplusplus | ||||
| } | ||||
| #endif | ||||
| 
 | ||||
| #endif /*__STM32L1xx_ADC_H */ | ||||
| 
 | ||||
| /**
 | ||||
|   * @} | ||||
|   */  | ||||
| 
 | ||||
| /**
 | ||||
|   * @} | ||||
|   */  | ||||
| 
 | ||||
| /************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE****/ | ||||
|  | @ -1,236 +0,0 @@ | |||
| /**
 | ||||
|   ****************************************************************************** | ||||
|   * @file    stm32l1xx_aes.h | ||||
|   * @author  MCD Application Team | ||||
|   * @version V1.1.1 | ||||
|   * @date    05-March-2012 | ||||
|   * @brief   This file contains all the functions prototypes for the AES firmware  | ||||
|   *          library. | ||||
|   ****************************************************************************** | ||||
|   * @attention | ||||
|   * | ||||
|   * <h2><center>© COPYRIGHT 2012 STMicroelectronics</center></h2> | ||||
|   * | ||||
|   * Licensed under MCD-ST Liberty SW License Agreement V2, (the "License"); | ||||
|   * You may not use this file except in compliance with the License. | ||||
|   * You may obtain a copy of the License at: | ||||
|   * | ||||
|   *        http://www.st.com/software_license_agreement_liberty_v2
 | ||||
|   * | ||||
|   * Unless required by applicable law or agreed to in writing, software  | ||||
|   * distributed under the License is distributed on an "AS IS" BASIS,  | ||||
|   * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. | ||||
|   * See the License for the specific language governing permissions and | ||||
|   * limitations under the License. | ||||
|   * | ||||
|   ****************************************************************************** | ||||
|   */ | ||||
| 
 | ||||
| /* Define to prevent recursive inclusion -------------------------------------*/ | ||||
| #ifndef __STM32L1xx_AES_H | ||||
| #define __STM32L1xx_AES_H | ||||
| 
 | ||||
| #ifdef __cplusplus | ||||
|  extern "C" { | ||||
| #endif | ||||
| 
 | ||||
| /* Includes ------------------------------------------------------------------*/ | ||||
| #include "stm32l1xx.h" | ||||
| 
 | ||||
| /** @addtogroup STM32L1xx_StdPeriph_Driver
 | ||||
|   * @{ | ||||
|   */ | ||||
| 
 | ||||
| /** @addtogroup AES
 | ||||
|   * @{ | ||||
|   */ | ||||
| 
 | ||||
| /* Exported types ------------------------------------------------------------*/ | ||||
| 
 | ||||
| /**
 | ||||
|   * @brief   AES Init structure definition | ||||
|   */ | ||||
| typedef struct | ||||
| { | ||||
|   uint32_t AES_Operation; /*!< Specifies the AES mode of operation.
 | ||||
|                                This parameter can be a value of @ref AES_possible_Operation_modes */ | ||||
|   uint32_t AES_Chaining;  /*!< Specifies the AES Chaining modes: ECB, CBC or CTR.
 | ||||
|                                This parameter can be a value of @ref AES_possible_chaining_modes */ | ||||
|   uint32_t AES_DataType;  /*!< Specifies the AES data swapping: 32-bit, 16-bit, 8-bit or 1-bit.
 | ||||
|                                This parameter can be a value of @ref AES_Data_Types */ | ||||
| }AES_InitTypeDef; | ||||
| 
 | ||||
| /** 
 | ||||
|   * @brief   AES Key(s) structure definition | ||||
|   */  | ||||
| typedef struct | ||||
| { | ||||
|   uint32_t AES_Key0;  /*!< Key[31:0]   */ | ||||
|   uint32_t AES_Key1;  /*!< Key[63:32]  */ | ||||
|   uint32_t AES_Key2;  /*!< Key[95:64]  */ | ||||
|   uint32_t AES_Key3;  /*!< Key[127:96] */ | ||||
| }AES_KeyInitTypeDef; | ||||
| 
 | ||||
| /** 
 | ||||
|   * @brief   AES Initialization Vectors (IV) structure definition | ||||
|   */  | ||||
| typedef struct | ||||
| { | ||||
|   uint32_t AES_IV0;  /*!< Init Vector IV[31:0]   */ | ||||
|   uint32_t AES_IV1;  /*!< Init Vector IV[63:32]  */ | ||||
|   uint32_t AES_IV2;  /*!< Init Vector IV[95:64]  */ | ||||
|   uint32_t AES_IV3;  /*!< Init Vector IV[127:96] */ | ||||
| }AES_IVInitTypeDef; | ||||
| 
 | ||||
| /* Exported constants --------------------------------------------------------*/ | ||||
| 
 | ||||
| /** @defgroup AES_Exported_Constants
 | ||||
|   * @{ | ||||
|   */  | ||||
| 
 | ||||
| /** @defgroup AES_possible_Operation_modes
 | ||||
|   * @{ | ||||
|   */   | ||||
| #define AES_Operation_Encryp               ((uint32_t)0x00000000) /*!< AES in Encryption mode */ | ||||
| #define AES_Operation_KeyDeriv             AES_CR_MODE_0          /*!< AES in Key Derivation mode */ | ||||
| #define AES_Operation_Decryp               AES_CR_MODE_1          /*!< AES in Decryption mode */ | ||||
| #define AES_Operation_KeyDerivAndDecryp    AES_CR_MODE            /*!< AES in Key Derivation and Decryption mode */ | ||||
| 
 | ||||
| #define IS_AES_MODE(OPERATION) (((OPERATION) == AES_Operation_Encryp)    || \ | ||||
|                                 ((OPERATION) == AES_Operation_KeyDeriv)  || \ | ||||
|                                 ((OPERATION) == AES_Operation_Decryp)    || \ | ||||
|                                 ((OPERATION) == AES_Operation_KeyDerivAndDecryp)) | ||||
| 
 | ||||
| /**
 | ||||
|   * @} | ||||
|   */  | ||||
| 
 | ||||
| /** @defgroup AES_possible_chaining_modes
 | ||||
|   * @{ | ||||
|   */  | ||||
| #define AES_Chaining_ECB                   ((uint32_t)0x00000000) /*!< AES in ECB chaining mode */ | ||||
| #define AES_Chaining_CBC                   AES_CR_CHMOD_0         /*!< AES in CBC chaining mode */ | ||||
| #define AES_Chaining_CTR                   AES_CR_CHMOD_1         /*!< AES in CTR chaining mode */ | ||||
| 
 | ||||
| #define IS_AES_CHAINING(CHAINING) (((CHAINING) == AES_Chaining_ECB) || \ | ||||
|                                    ((CHAINING) == AES_Chaining_CBC) || \ | ||||
|                                    ((CHAINING) == AES_Chaining_CTR)) | ||||
| /**
 | ||||
|   * @} | ||||
|   */ | ||||
| 
 | ||||
| /** @defgroup AES_Data_Types
 | ||||
|   * @{ | ||||
|   */  | ||||
| #define AES_DataType_32b                   ((uint32_t)0x00000000) /*!< 32-bit data. No swapping */ | ||||
| #define AES_DataType_16b                   AES_CR_DATATYPE_0      /*!< 16-bit data. Each half word is swapped */ | ||||
| #define AES_DataType_8b                    AES_CR_DATATYPE_1      /*!< 8-bit data. All bytes are swapped */ | ||||
| #define AES_DataType_1b                    AES_CR_DATATYPE        /*!< 1-bit data. In the word all bits are swapped */ | ||||
| 
 | ||||
| #define IS_AES_DATATYPE(DATATYPE) (((DATATYPE) == AES_DataType_32b) || \ | ||||
|                                     ((DATATYPE) == AES_DataType_16b)|| \ | ||||
|                                     ((DATATYPE) == AES_DataType_8b) || \ | ||||
|                                     ((DATATYPE) == AES_DataType_1b)) | ||||
| /**
 | ||||
|   * @} | ||||
|   */ | ||||
| 
 | ||||
| /** @defgroup AES_Flags
 | ||||
|   * @{ | ||||
|   */  | ||||
| #define AES_FLAG_CCF                       AES_SR_CCF    /*!< Computation Complete Flag */ | ||||
| #define AES_FLAG_RDERR                     AES_SR_RDERR  /*!< Read Error Flag           */ | ||||
| #define AES_FLAG_WRERR                     AES_SR_WRERR  /*!< Write Error Flag          */ | ||||
| 
 | ||||
| #define IS_AES_FLAG(FLAG) (((FLAG) == AES_FLAG_CCF)    || \ | ||||
|                            ((FLAG) == AES_FLAG_RDERR)  || \ | ||||
|                            ((FLAG) == AES_FLAG_WRERR)) | ||||
| /**
 | ||||
|   * @} | ||||
|   */  | ||||
| 
 | ||||
| /** @defgroup AES_Interrupts
 | ||||
|   * @{ | ||||
|   */  | ||||
| #define AES_IT_CC                          AES_CR_CCIE  /*!< Computation Complete interrupt */ | ||||
| #define AES_IT_ERR                         AES_CR_ERRIE /*!< Error interrupt                */ | ||||
| 
 | ||||
| #define IS_AES_IT(IT) ((((IT) & (uint32_t)0xFFFFF9FF) == 0x00) && ((IT) != 0x00)) | ||||
| #define IS_AES_GET_IT(IT) (((IT) == AES_IT_CC) || ((IT) == AES_IT_ERR)) | ||||
| 
 | ||||
| /**
 | ||||
|   * @} | ||||
|   */ | ||||
| 
 | ||||
| /** @defgroup AES_DMA_Transfer_modes
 | ||||
|   * @{ | ||||
|   */  | ||||
| #define AES_DMATransfer_In                 AES_CR_DMAINEN                     /*!< DMA requests enabled for input transfer phase */ | ||||
| #define AES_DMATransfer_Out                AES_CR_DMAOUTEN                    /*!< DMA requests enabled for input transfer phase */ | ||||
| #define AES_DMATransfer_InOut              (AES_CR_DMAINEN | AES_CR_DMAOUTEN) /*!< DMA requests enabled for both input and output phases */ | ||||
| 
 | ||||
| #define IS_AES_DMA_TRANSFER(TRANSFER)   (((TRANSFER) == AES_DMATransfer_In)  || \ | ||||
|                                          ((TRANSFER) == AES_DMATransfer_Out)  || \ | ||||
|                                          ((TRANSFER) == AES_DMATransfer_InOut)) | ||||
| /**
 | ||||
|   * @} | ||||
|   */ | ||||
| 
 | ||||
| /**
 | ||||
|   * @} | ||||
|   */ | ||||
| 
 | ||||
| /* Exported macro ------------------------------------------------------------*/ | ||||
| /* Exported functions ------------------------------------------------------- */ | ||||
| 
 | ||||
| /* Initialization and configuration functions *********************************/ | ||||
| void AES_DeInit(void); | ||||
| void AES_Init(AES_InitTypeDef* AES_InitStruct); | ||||
| void AES_KeyInit(AES_KeyInitTypeDef* AES_KeyInitStruct); | ||||
| void AES_IVInit(AES_IVInitTypeDef* AES_IVInitStruct); | ||||
| void AES_Cmd(FunctionalState NewState); | ||||
| 
 | ||||
| /* Structures initialization functions ****************************************/ | ||||
| void AES_StructInit(AES_InitTypeDef* AES_InitStruct); | ||||
| void AES_KeyStructInit(AES_KeyInitTypeDef* AES_KeyInitStruct); | ||||
| void AES_IVStructInit(AES_IVInitTypeDef* AES_IVInitStruct); | ||||
| 
 | ||||
| /* AES Read and Write functions **********************************************/   | ||||
| void AES_WriteSubData(uint32_t Data); | ||||
| uint32_t AES_ReadSubData(void); | ||||
| void AES_ReadKey(AES_KeyInitTypeDef* AES_KeyInitStruct); | ||||
| void AES_ReadIV(AES_IVInitTypeDef* AES_IVInitStruct); | ||||
| 
 | ||||
| /* DMA transfers management function ******************************************/ | ||||
| void AES_DMAConfig(uint32_t AES_DMATransfer, FunctionalState NewState); | ||||
| 
 | ||||
| /* Interrupts and flags management functions **********************************/ | ||||
| void AES_ITConfig(uint32_t AES_IT, FunctionalState NewState); | ||||
| FlagStatus AES_GetFlagStatus(uint32_t AES_FLAG); | ||||
| void AES_ClearFlag(uint32_t AES_FLAG); | ||||
| ITStatus AES_GetITStatus(uint32_t AES_IT); | ||||
| void AES_ClearITPendingBit(uint32_t AES_IT); | ||||
| 
 | ||||
| /* High Level AES functions **************************************************/ | ||||
| ErrorStatus AES_ECB_Encrypt(uint8_t* Key, uint8_t* Input, uint32_t Ilength, uint8_t* Output); | ||||
| ErrorStatus AES_ECB_Decrypt(uint8_t* Key, uint8_t* Input, uint32_t Ilength, uint8_t* Output); | ||||
| ErrorStatus AES_CBC_Encrypt(uint8_t* Key, uint8_t InitVectors[16], uint8_t* Input, uint32_t Ilength, uint8_t* Output); | ||||
| ErrorStatus AES_CBC_Decrypt(uint8_t* Key, uint8_t InitVectors[16], uint8_t* Input, uint32_t Ilength, uint8_t* Output); | ||||
| ErrorStatus AES_CTR_Encrypt(uint8_t* Key, uint8_t InitVectors[16], uint8_t* Input, uint32_t Ilength, uint8_t* Output); | ||||
| ErrorStatus AES_CTR_Decrypt(uint8_t* Key, uint8_t InitVectors[16], uint8_t* Input, uint32_t Ilength, uint8_t* Output); | ||||
| 
 | ||||
| #ifdef __cplusplus | ||||
| } | ||||
| #endif | ||||
| 
 | ||||
| #endif /*__STM32L1xx_AES_H */ | ||||
| 
 | ||||
| /**
 | ||||
|   * @} | ||||
|   */  | ||||
| 
 | ||||
| /**
 | ||||
|   * @} | ||||
|   */ | ||||
| 
 | ||||
| /************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE****/ | ||||
|  | @ -1,187 +0,0 @@ | |||
| /**
 | ||||
|   ****************************************************************************** | ||||
|   * @file    stm32l1xx_comp.h | ||||
|   * @author  MCD Application Team | ||||
|   * @version V1.1.1 | ||||
|   * @date    05-March-2012 | ||||
|   * @brief   This file contains all the functions prototypes for the COMP firmware  | ||||
|   *          library. | ||||
|   ****************************************************************************** | ||||
|   * @attention | ||||
|   * | ||||
|   * <h2><center>© COPYRIGHT 2012 STMicroelectronics</center></h2> | ||||
|   * | ||||
|   * Licensed under MCD-ST Liberty SW License Agreement V2, (the "License"); | ||||
|   * You may not use this file except in compliance with the License. | ||||
|   * You may obtain a copy of the License at: | ||||
|   * | ||||
|   *        http://www.st.com/software_license_agreement_liberty_v2
 | ||||
|   * | ||||
|   * Unless required by applicable law or agreed to in writing, software  | ||||
|   * distributed under the License is distributed on an "AS IS" BASIS,  | ||||
|   * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. | ||||
|   * See the License for the specific language governing permissions and | ||||
|   * limitations under the License. | ||||
|   * | ||||
|   ****************************************************************************** | ||||
|   */ | ||||
| 
 | ||||
| /* Define to prevent recursive inclusion -------------------------------------*/ | ||||
| #ifndef __STM32L1xx_COMP_H | ||||
| #define __STM32L1xx_COMP_H | ||||
| 
 | ||||
| #ifdef __cplusplus | ||||
|  extern "C" { | ||||
| #endif | ||||
| 
 | ||||
| /* Includes ------------------------------------------------------------------*/ | ||||
| #include "stm32l1xx.h" | ||||
| 
 | ||||
| /** @addtogroup STM32L1xx_StdPeriph_Driver
 | ||||
|   * @{ | ||||
|   */ | ||||
| 
 | ||||
| /** @addtogroup COMP
 | ||||
|   * @{ | ||||
|   */ | ||||
| 
 | ||||
| /* Exported types ------------------------------------------------------------*/ | ||||
| 
 | ||||
| /** 
 | ||||
|   * @brief  COMP Init structure definition   | ||||
|   */ | ||||
|    | ||||
| typedef struct | ||||
| { | ||||
|   uint32_t COMP_Speed;               /*!< Defines the speed of comparator 2.
 | ||||
|                                           This parameter can be a value of @ref COMP_Speed */ | ||||
|   uint32_t COMP_InvertingInput;      /*!< Selects the inverting input of the comparator 2.
 | ||||
|                                           This parameter can be a value of @ref COMP_InvertingInput */ | ||||
|   uint32_t COMP_OutputSelect;        /*!< Selects the output redirection of the comparator 2.
 | ||||
|                                           This parameter can be a value of @ref COMP_OutputSelect */ | ||||
|     | ||||
| }COMP_InitTypeDef; | ||||
| 
 | ||||
| /* Exported constants --------------------------------------------------------*/ | ||||
|     | ||||
| /** @defgroup COMP_Exported_Constants
 | ||||
|   * @{ | ||||
|   */  | ||||
| 
 | ||||
| #define COMP_OutputLevel_High                   ((uint32_t)0x00000001) | ||||
| #define COMP_OutputLevel_Low                    ((uint32_t)0x00000000) | ||||
| 
 | ||||
| /** @defgroup COMP_Selection
 | ||||
|   * @{ | ||||
|   */ | ||||
| 
 | ||||
| #define COMP_Selection_COMP1                    ((uint32_t)0x00000001) | ||||
| #define COMP_Selection_COMP2                    ((uint32_t)0x00000002) | ||||
| 
 | ||||
| #define IS_COMP_ALL_PERIPH(PERIPH) (((PERIPH) == COMP_Selection_COMP1) || \ | ||||
|                                     ((PERIPH) == COMP_Selection_COMP2)) | ||||
|   | ||||
| /**
 | ||||
|   * @} | ||||
|   */  | ||||
| 
 | ||||
| /** @defgroup COMP_InvertingInput
 | ||||
|   * @{ | ||||
|   */ | ||||
| 
 | ||||
| #define COMP_InvertingInput_None                ((uint32_t)0x00000000) /* COMP2 is disabled when this parameter is selected */ | ||||
| #define COMP_InvertingInput_IO                  ((uint32_t)0x00040000) | ||||
| #define COMP_InvertingInput_VREFINT             ((uint32_t)0x00080000) | ||||
| #define COMP_InvertingInput_3_4VREFINT          ((uint32_t)0x000C0000) | ||||
| #define COMP_InvertingInput_1_2VREFINT          ((uint32_t)0x00100000) | ||||
| #define COMP_InvertingInput_1_4VREFINT          ((uint32_t)0x00140000) | ||||
| #define COMP_InvertingInput_DAC1                ((uint32_t)0x00180000) | ||||
| #define COMP_InvertingInput_DAC2                ((uint32_t)0x001C0000) | ||||
| 
 | ||||
| #define IS_COMP_INVERTING_INPUT(INPUT) (((INPUT) == COMP_InvertingInput_None) || \ | ||||
|                                         ((INPUT) == COMP_InvertingInput_IO) || \ | ||||
|                                         ((INPUT) == COMP_InvertingInput_VREFINT) || \ | ||||
|                                         ((INPUT) == COMP_InvertingInput_3_4VREFINT) || \ | ||||
|                                         ((INPUT) == COMP_InvertingInput_1_2VREFINT) || \ | ||||
|                                         ((INPUT) == COMP_InvertingInput_1_4VREFINT) || \ | ||||
|                                         ((INPUT) == COMP_InvertingInput_DAC1) || \ | ||||
|                                         ((INPUT) == COMP_InvertingInput_DAC2)) | ||||
| /**
 | ||||
|   * @} | ||||
|   */  | ||||
| 
 | ||||
| /** @defgroup COMP_OutputSelect
 | ||||
|   * @{ | ||||
|   */ | ||||
| 
 | ||||
| #define COMP_OutputSelect_TIM2IC4               ((uint32_t)0x00000000) | ||||
| #define COMP_OutputSelect_TIM2OCREFCLR          ((uint32_t)0x00200000) | ||||
| #define COMP_OutputSelect_TIM3IC4               ((uint32_t)0x00400000) | ||||
| #define COMP_OutputSelect_TIM3OCREFCLR          ((uint32_t)0x00600000) | ||||
| #define COMP_OutputSelect_TIM4IC4               ((uint32_t)0x00800000) | ||||
| #define COMP_OutputSelect_TIM4OCREFCLR          ((uint32_t)0x00A00000) | ||||
| #define COMP_OutputSelect_TIM10IC1              ((uint32_t)0x00C00000) | ||||
| #define COMP_OutputSelect_None                  ((uint32_t)0x00E00000) | ||||
| 
 | ||||
| #define IS_COMP_OUTPUT(OUTPUT) (((OUTPUT) == COMP_OutputSelect_TIM2IC4) || \ | ||||
|                                 ((OUTPUT) == COMP_OutputSelect_TIM2OCREFCLR) || \ | ||||
|                                 ((OUTPUT) == COMP_OutputSelect_TIM3IC4) || \ | ||||
|                                 ((OUTPUT) == COMP_OutputSelect_TIM3OCREFCLR) || \ | ||||
|                                 ((OUTPUT) == COMP_OutputSelect_TIM4IC4) || \ | ||||
|                                 ((OUTPUT) == COMP_OutputSelect_TIM4OCREFCLR) || \ | ||||
|                                 ((OUTPUT) == COMP_OutputSelect_TIM10IC1) || \ | ||||
|                                 ((OUTPUT) == COMP_OutputSelect_None)) | ||||
| /**
 | ||||
|   * @} | ||||
|   */  | ||||
|    | ||||
| /** @defgroup COMP_Speed
 | ||||
|   * @{ | ||||
|   */ | ||||
| 
 | ||||
| #define COMP_Speed_Slow                         ((uint32_t)0x00000000) | ||||
| #define COMP_Speed_Fast                         ((uint32_t)0x00001000) | ||||
| 
 | ||||
| #define IS_COMP_SPEED(SPEED)    (((SPEED) == COMP_Speed_Slow) || \ | ||||
|                                  ((SPEED) == COMP_Speed_Fast)) | ||||
| /**
 | ||||
|   * @} | ||||
|   */ | ||||
|    | ||||
| /**
 | ||||
|   * @} | ||||
|   */  | ||||
| 
 | ||||
| /* Exported macro ------------------------------------------------------------*/ | ||||
| /* Exported functions ------------------------------------------------------- */ | ||||
| 
 | ||||
| /*  Function used to set the COMP configuration to the default reset state ****/ | ||||
| void COMP_DeInit(void); | ||||
| 
 | ||||
| /* Initialization and Configuration functions *********************************/ | ||||
| void COMP_Init(COMP_InitTypeDef* COMP_InitStruct); | ||||
| void COMP_Cmd(FunctionalState NewState); | ||||
| uint8_t COMP_GetOutputLevel(uint32_t COMP_Selection); | ||||
| void COMP_SW1SwitchConfig(FunctionalState NewState); | ||||
| 
 | ||||
| /* Window mode control function ***********************************************/ | ||||
| void COMP_WindowCmd(FunctionalState NewState); | ||||
| 
 | ||||
| /* Internal Reference Voltage (VREFINT) output function ***********************/ | ||||
| void COMP_VrefintOutputCmd(FunctionalState NewState); | ||||
| 
 | ||||
| #ifdef __cplusplus | ||||
| } | ||||
| #endif | ||||
| 
 | ||||
| #endif /*__STM32L1xx_COMP_H */ | ||||
| 
 | ||||
| /**
 | ||||
|   * @} | ||||
|   */  | ||||
| 
 | ||||
| /**
 | ||||
|   * @} | ||||
|   */ | ||||
| 
 | ||||
| /************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE****/ | ||||
|  | @ -1,83 +0,0 @@ | |||
| /**
 | ||||
|   ****************************************************************************** | ||||
|   * @file    stm32l1xx_crc.h | ||||
|   * @author  MCD Application Team | ||||
|   * @version V1.1.1 | ||||
|   * @date    05-March-2012 | ||||
|   * @brief   This file contains all the functions prototypes for the CRC firmware  | ||||
|   *          library. | ||||
|   ****************************************************************************** | ||||
|   * @attention | ||||
|   * | ||||
|   * <h2><center>© COPYRIGHT 2012 STMicroelectronics</center></h2> | ||||
|   * | ||||
|   * Licensed under MCD-ST Liberty SW License Agreement V2, (the "License"); | ||||
|   * You may not use this file except in compliance with the License. | ||||
|   * You may obtain a copy of the License at: | ||||
|   * | ||||
|   *        http://www.st.com/software_license_agreement_liberty_v2
 | ||||
|   * | ||||
|   * Unless required by applicable law or agreed to in writing, software  | ||||
|   * distributed under the License is distributed on an "AS IS" BASIS,  | ||||
|   * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. | ||||
|   * See the License for the specific language governing permissions and | ||||
|   * limitations under the License. | ||||
|   * | ||||
|   ****************************************************************************** | ||||
|   */ | ||||
| 
 | ||||
| /* Define to prevent recursive inclusion -------------------------------------*/ | ||||
| #ifndef __STM32L1xx_CRC_H | ||||
| #define __STM32L1xx_CRC_H | ||||
| 
 | ||||
| #ifdef __cplusplus | ||||
|  extern "C" { | ||||
| #endif | ||||
| 
 | ||||
| /* Includes ------------------------------------------------------------------*/ | ||||
| #include "stm32l1xx.h" | ||||
| 
 | ||||
| /** @addtogroup STM32L1xx_StdPeriph_Driver
 | ||||
|   * @{ | ||||
|   */ | ||||
| 
 | ||||
| /** @addtogroup CRC
 | ||||
|   * @{ | ||||
|   */ | ||||
| 
 | ||||
| /* Exported types ------------------------------------------------------------*/ | ||||
| /* Exported constants --------------------------------------------------------*/ | ||||
| 
 | ||||
| /** @defgroup CRC_Exported_Constants
 | ||||
|   * @{ | ||||
|   */ | ||||
| 
 | ||||
| /**
 | ||||
|   * @} | ||||
|   */ | ||||
| 
 | ||||
| /* Exported macro ------------------------------------------------------------*/ | ||||
| /* Exported functions ------------------------------------------------------- */  | ||||
| 
 | ||||
| void CRC_ResetDR(void); | ||||
| uint32_t CRC_CalcCRC(uint32_t Data); | ||||
| uint32_t CRC_CalcBlockCRC(uint32_t pBuffer[], uint32_t BufferLength); | ||||
| uint32_t CRC_GetCRC(void); | ||||
| void CRC_SetIDRegister(uint8_t IDValue); | ||||
| uint8_t CRC_GetIDRegister(void); | ||||
| 
 | ||||
| #ifdef __cplusplus | ||||
| } | ||||
| #endif | ||||
| 
 | ||||
| #endif /* __STM32L1xx_CRC_H */ | ||||
| 
 | ||||
| /**
 | ||||
|   * @} | ||||
|   */ | ||||
| 
 | ||||
| /**
 | ||||
|   * @} | ||||
|   */ | ||||
| 
 | ||||
| /************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE****/ | ||||
|  | @ -1,305 +0,0 @@ | |||
| /**
 | ||||
|   ****************************************************************************** | ||||
|   * @file    stm32l1xx_dac.h | ||||
|   * @author  MCD Application Team | ||||
|   * @version V1.1.1 | ||||
|   * @date    05-March-2012 | ||||
|   * @brief   This file contains all the functions prototypes for the DAC firmware  | ||||
|   *          library. | ||||
|   ****************************************************************************** | ||||
|   * @attention | ||||
|   * | ||||
|   * <h2><center>© COPYRIGHT 2012 STMicroelectronics</center></h2> | ||||
|   * | ||||
|   * Licensed under MCD-ST Liberty SW License Agreement V2, (the "License"); | ||||
|   * You may not use this file except in compliance with the License. | ||||
|   * You may obtain a copy of the License at: | ||||
|   * | ||||
|   *        http://www.st.com/software_license_agreement_liberty_v2
 | ||||
|   * | ||||
|   * Unless required by applicable law or agreed to in writing, software  | ||||
|   * distributed under the License is distributed on an "AS IS" BASIS,  | ||||
|   * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. | ||||
|   * See the License for the specific language governing permissions and | ||||
|   * limitations under the License. | ||||
|   * | ||||
|   ****************************************************************************** | ||||
|   */ | ||||
| 
 | ||||
| /* Define to prevent recursive inclusion -------------------------------------*/ | ||||
| #ifndef __STM32L1xx_DAC_H | ||||
| #define __STM32L1xx_DAC_H | ||||
| 
 | ||||
| #ifdef __cplusplus | ||||
|  extern "C" { | ||||
| #endif | ||||
| 
 | ||||
| /* Includes ------------------------------------------------------------------*/ | ||||
| #include "stm32l1xx.h" | ||||
|   | ||||
| /** @addtogroup STM32L1xx_StdPeriph_Driver
 | ||||
|   * @{ | ||||
|   */ | ||||
| 
 | ||||
| /** @addtogroup DAC
 | ||||
|   * @{ | ||||
|   */ | ||||
| 
 | ||||
| /* Exported types ------------------------------------------------------------*/ | ||||
| 
 | ||||
| /** 
 | ||||
|   * @brief  DAC Init structure definition | ||||
|   */ | ||||
|    | ||||
| typedef struct | ||||
| { | ||||
|   uint32_t DAC_Trigger;                      /*!< Specifies the external trigger for the selected DAC channel.
 | ||||
|                                                   This parameter can be a value of @ref DAC_trigger_selection */ | ||||
| 
 | ||||
|   uint32_t DAC_WaveGeneration;               /*!< Specifies whether DAC channel noise waves or triangle waves
 | ||||
|                                                   are generated, or whether no wave is generated. | ||||
|                                                   This parameter can be a value of @ref DAC_wave_generation */ | ||||
| 
 | ||||
|   uint32_t DAC_LFSRUnmask_TriangleAmplitude; /*!< Specifies the LFSR mask for noise wave generation or
 | ||||
|                                                   the maximum amplitude triangle generation for the DAC channel.  | ||||
|                                                   This parameter can be a value of @ref DAC_lfsrunmask_triangleamplitude */ | ||||
| 
 | ||||
|   uint32_t DAC_OutputBuffer;                 /*!< Specifies whether the DAC channel output buffer is enabled or disabled.
 | ||||
|                                                   This parameter can be a value of @ref DAC_output_buffer */ | ||||
| }DAC_InitTypeDef; | ||||
| 
 | ||||
| /* Exported constants --------------------------------------------------------*/ | ||||
| 
 | ||||
| /** @defgroup DAC_Exported_Constants
 | ||||
|   * @{ | ||||
|   */ | ||||
| 
 | ||||
| /** @defgroup DAC_trigger_selection 
 | ||||
|   * @{ | ||||
|   */ | ||||
|    | ||||
| #define DAC_Trigger_None                   ((uint32_t)0x00000000) /*!< Conversion is automatic once the DAC1_DHRxxxx register  | ||||
|                                                                        has been loaded, and not by external trigger */ | ||||
| #define DAC_Trigger_T6_TRGO                ((uint32_t)0x00000004) /*!< TIM6 TRGO selected as external conversion trigger for DAC channel */ | ||||
| #define DAC_Trigger_T7_TRGO                ((uint32_t)0x00000014) /*!< TIM7 TRGO selected as external conversion trigger for DAC channel */ | ||||
| #define DAC_Trigger_T9_TRGO                ((uint32_t)0x0000001C) /*!< TIM9 TRGO selected as external conversion trigger for DAC channel */ | ||||
| #define DAC_Trigger_T2_TRGO                ((uint32_t)0x00000024) /*!< TIM2 TRGO selected as external conversion trigger for DAC channel */ | ||||
| #define DAC_Trigger_T4_TRGO                ((uint32_t)0x0000002C) /*!< TIM4 TRGO selected as external conversion trigger for DAC channel */ | ||||
| #define DAC_Trigger_Ext_IT9                ((uint32_t)0x00000034) /*!< EXTI Line9 event selected as external conversion trigger for DAC channel */ | ||||
| #define DAC_Trigger_Software               ((uint32_t)0x0000003C) /*!< Conversion started by software trigger for DAC channel */ | ||||
| 
 | ||||
| #define IS_DAC_TRIGGER(TRIGGER) (((TRIGGER) == DAC_Trigger_None) || \ | ||||
|                                  ((TRIGGER) == DAC_Trigger_T6_TRGO) || \ | ||||
|                                  ((TRIGGER) == DAC_Trigger_T7_TRGO) || \ | ||||
|                                  ((TRIGGER) == DAC_Trigger_T9_TRGO) || \ | ||||
|                                  ((TRIGGER) == DAC_Trigger_T2_TRGO) || \ | ||||
|                                  ((TRIGGER) == DAC_Trigger_T4_TRGO) || \ | ||||
|                                  ((TRIGGER) == DAC_Trigger_Ext_IT9) || \ | ||||
|                                  ((TRIGGER) == DAC_Trigger_Software)) | ||||
|                                   | ||||
| /**
 | ||||
|   * @} | ||||
|   */ | ||||
|    | ||||
| /** @defgroup DAC_wave_generation 
 | ||||
|   * @{ | ||||
|   */ | ||||
| 
 | ||||
| #define DAC_WaveGeneration_None            ((uint32_t)0x00000000) | ||||
| #define DAC_WaveGeneration_Noise           ((uint32_t)0x00000040) | ||||
| #define DAC_WaveGeneration_Triangle        ((uint32_t)0x00000080) | ||||
| #define IS_DAC_GENERATE_WAVE(WAVE) (((WAVE) == DAC_WaveGeneration_None) || \ | ||||
|                                     ((WAVE) == DAC_WaveGeneration_Noise) || \ | ||||
|                                     ((WAVE) == DAC_WaveGeneration_Triangle)) | ||||
| /**
 | ||||
|   * @} | ||||
|   */ | ||||
|    | ||||
| /** @defgroup DAC_lfsrunmask_triangleamplitude
 | ||||
|   * @{ | ||||
|   */ | ||||
| 
 | ||||
| #define DAC_LFSRUnmask_Bit0                ((uint32_t)0x00000000) /*!< Unmask DAC channel LFSR bit0 for noise wave generation */ | ||||
| #define DAC_LFSRUnmask_Bits1_0             ((uint32_t)0x00000100) /*!< Unmask DAC channel LFSR bit[1:0] for noise wave generation */ | ||||
| #define DAC_LFSRUnmask_Bits2_0             ((uint32_t)0x00000200) /*!< Unmask DAC channel LFSR bit[2:0] for noise wave generation */ | ||||
| #define DAC_LFSRUnmask_Bits3_0             ((uint32_t)0x00000300) /*!< Unmask DAC channel LFSR bit[3:0] for noise wave generation */ | ||||
| #define DAC_LFSRUnmask_Bits4_0             ((uint32_t)0x00000400) /*!< Unmask DAC channel LFSR bit[4:0] for noise wave generation */ | ||||
| #define DAC_LFSRUnmask_Bits5_0             ((uint32_t)0x00000500) /*!< Unmask DAC channel LFSR bit[5:0] for noise wave generation */ | ||||
| #define DAC_LFSRUnmask_Bits6_0             ((uint32_t)0x00000600) /*!< Unmask DAC channel LFSR bit[6:0] for noise wave generation */ | ||||
| #define DAC_LFSRUnmask_Bits7_0             ((uint32_t)0x00000700) /*!< Unmask DAC channel LFSR bit[7:0] for noise wave generation */ | ||||
| #define DAC_LFSRUnmask_Bits8_0             ((uint32_t)0x00000800) /*!< Unmask DAC channel LFSR bit[8:0] for noise wave generation */ | ||||
| #define DAC_LFSRUnmask_Bits9_0             ((uint32_t)0x00000900) /*!< Unmask DAC channel LFSR bit[9:0] for noise wave generation */ | ||||
| #define DAC_LFSRUnmask_Bits10_0            ((uint32_t)0x00000A00) /*!< Unmask DAC channel LFSR bit[10:0] for noise wave generation */ | ||||
| #define DAC_LFSRUnmask_Bits11_0            ((uint32_t)0x00000B00) /*!< Unmask DAC channel LFSR bit[11:0] for noise wave generation */ | ||||
| #define DAC_TriangleAmplitude_1            ((uint32_t)0x00000000) /*!< Select max triangle amplitude of 1 */ | ||||
| #define DAC_TriangleAmplitude_3            ((uint32_t)0x00000100) /*!< Select max triangle amplitude of 3 */ | ||||
| #define DAC_TriangleAmplitude_7            ((uint32_t)0x00000200) /*!< Select max triangle amplitude of 7 */ | ||||
| #define DAC_TriangleAmplitude_15           ((uint32_t)0x00000300) /*!< Select max triangle amplitude of 15 */ | ||||
| #define DAC_TriangleAmplitude_31           ((uint32_t)0x00000400) /*!< Select max triangle amplitude of 31 */ | ||||
| #define DAC_TriangleAmplitude_63           ((uint32_t)0x00000500) /*!< Select max triangle amplitude of 63 */ | ||||
| #define DAC_TriangleAmplitude_127          ((uint32_t)0x00000600) /*!< Select max triangle amplitude of 127 */ | ||||
| #define DAC_TriangleAmplitude_255          ((uint32_t)0x00000700) /*!< Select max triangle amplitude of 255 */ | ||||
| #define DAC_TriangleAmplitude_511          ((uint32_t)0x00000800) /*!< Select max triangle amplitude of 511 */ | ||||
| #define DAC_TriangleAmplitude_1023         ((uint32_t)0x00000900) /*!< Select max triangle amplitude of 1023 */ | ||||
| #define DAC_TriangleAmplitude_2047         ((uint32_t)0x00000A00) /*!< Select max triangle amplitude of 2047 */ | ||||
| #define DAC_TriangleAmplitude_4095         ((uint32_t)0x00000B00) /*!< Select max triangle amplitude of 4095 */ | ||||
| 
 | ||||
| #define IS_DAC_LFSR_UNMASK_TRIANGLE_AMPLITUDE(VALUE) (((VALUE) == DAC_LFSRUnmask_Bit0) || \ | ||||
|                                                       ((VALUE) == DAC_LFSRUnmask_Bits1_0) || \ | ||||
|                                                       ((VALUE) == DAC_LFSRUnmask_Bits2_0) || \ | ||||
|                                                       ((VALUE) == DAC_LFSRUnmask_Bits3_0) || \ | ||||
|                                                       ((VALUE) == DAC_LFSRUnmask_Bits4_0) || \ | ||||
|                                                       ((VALUE) == DAC_LFSRUnmask_Bits5_0) || \ | ||||
|                                                       ((VALUE) == DAC_LFSRUnmask_Bits6_0) || \ | ||||
|                                                       ((VALUE) == DAC_LFSRUnmask_Bits7_0) || \ | ||||
|                                                       ((VALUE) == DAC_LFSRUnmask_Bits8_0) || \ | ||||
|                                                       ((VALUE) == DAC_LFSRUnmask_Bits9_0) || \ | ||||
|                                                       ((VALUE) == DAC_LFSRUnmask_Bits10_0) || \ | ||||
|                                                       ((VALUE) == DAC_LFSRUnmask_Bits11_0) || \ | ||||
|                                                       ((VALUE) == DAC_TriangleAmplitude_1) || \ | ||||
|                                                       ((VALUE) == DAC_TriangleAmplitude_3) || \ | ||||
|                                                       ((VALUE) == DAC_TriangleAmplitude_7) || \ | ||||
|                                                       ((VALUE) == DAC_TriangleAmplitude_15) || \ | ||||
|                                                       ((VALUE) == DAC_TriangleAmplitude_31) || \ | ||||
|                                                       ((VALUE) == DAC_TriangleAmplitude_63) || \ | ||||
|                                                       ((VALUE) == DAC_TriangleAmplitude_127) || \ | ||||
|                                                       ((VALUE) == DAC_TriangleAmplitude_255) || \ | ||||
|                                                       ((VALUE) == DAC_TriangleAmplitude_511) || \ | ||||
|                                                       ((VALUE) == DAC_TriangleAmplitude_1023) || \ | ||||
|                                                       ((VALUE) == DAC_TriangleAmplitude_2047) || \ | ||||
|                                                       ((VALUE) == DAC_TriangleAmplitude_4095)) | ||||
| /**
 | ||||
|   * @} | ||||
|   */ | ||||
| 
 | ||||
| /** @defgroup DAC_output_buffer 
 | ||||
|   * @{ | ||||
|   */ | ||||
| 
 | ||||
| #define DAC_OutputBuffer_Enable            ((uint32_t)0x00000000) | ||||
| #define DAC_OutputBuffer_Disable           ((uint32_t)0x00000002) | ||||
| #define IS_DAC_OUTPUT_BUFFER_STATE(STATE) (((STATE) == DAC_OutputBuffer_Enable) || \ | ||||
|                                            ((STATE) == DAC_OutputBuffer_Disable)) | ||||
| /**
 | ||||
|   * @} | ||||
|   */ | ||||
|    | ||||
| /** @defgroup DAC_Channel_selection 
 | ||||
|   * @{ | ||||
|   */ | ||||
| 
 | ||||
| #define DAC_Channel_1                      ((uint32_t)0x00000000) | ||||
| #define DAC_Channel_2                      ((uint32_t)0x00000010) | ||||
| #define IS_DAC_CHANNEL(CHANNEL) (((CHANNEL) == DAC_Channel_1) || \ | ||||
|                                  ((CHANNEL) == DAC_Channel_2)) | ||||
| /**
 | ||||
|   * @} | ||||
|   */ | ||||
| 
 | ||||
| /** @defgroup DAC_data_alignment 
 | ||||
|   * @{ | ||||
|   */ | ||||
| 
 | ||||
| #define DAC_Align_12b_R                    ((uint32_t)0x00000000) | ||||
| #define DAC_Align_12b_L                    ((uint32_t)0x00000004) | ||||
| #define DAC_Align_8b_R                     ((uint32_t)0x00000008) | ||||
| #define IS_DAC_ALIGN(ALIGN) (((ALIGN) == DAC_Align_12b_R) || \ | ||||
|                              ((ALIGN) == DAC_Align_12b_L) || \ | ||||
|                              ((ALIGN) == DAC_Align_8b_R)) | ||||
| /**
 | ||||
|   * @} | ||||
|   */ | ||||
| 
 | ||||
| /** @defgroup DAC_wave_generation 
 | ||||
|   * @{ | ||||
|   */ | ||||
| 
 | ||||
| #define DAC_Wave_Noise                     ((uint32_t)0x00000040) | ||||
| #define DAC_Wave_Triangle                  ((uint32_t)0x00000080) | ||||
| #define IS_DAC_WAVE(WAVE) (((WAVE) == DAC_Wave_Noise) || \ | ||||
|                            ((WAVE) == DAC_Wave_Triangle)) | ||||
| /**
 | ||||
|   * @} | ||||
|   */ | ||||
| 
 | ||||
| /** @defgroup DAC_data 
 | ||||
|   * @{ | ||||
|   */ | ||||
| 
 | ||||
| #define IS_DAC_DATA(DATA) ((DATA) <= 0xFFF0)  | ||||
| 
 | ||||
| /**
 | ||||
|   * @} | ||||
|   */ | ||||
| 
 | ||||
| /** @defgroup DAC_interrupts_definition 
 | ||||
|   * @{ | ||||
|   */  | ||||
|    | ||||
| #define DAC_IT_DMAUDR                      ((uint32_t)0x00002000)   | ||||
| #define IS_DAC_IT(IT) (((IT) == DAC_IT_DMAUDR))  | ||||
| 
 | ||||
| /**
 | ||||
|   * @} | ||||
|   */  | ||||
| 
 | ||||
| 
 | ||||
| /** @defgroup DAC_flags_definition 
 | ||||
|   * @{ | ||||
|   */  | ||||
|    | ||||
| #define DAC_FLAG_DMAUDR                    ((uint32_t)0x00002000)    | ||||
|    | ||||
| #define IS_DAC_FLAG(FLAG) (((FLAG) == DAC_FLAG_DMAUDR))   | ||||
| 
 | ||||
| /**
 | ||||
|   * @} | ||||
|   */  | ||||
| 
 | ||||
| /**
 | ||||
|   * @} | ||||
|   */  | ||||
| 
 | ||||
| /* Exported macro ------------------------------------------------------------*/ | ||||
| /* Exported functions ------------------------------------------------------- */  | ||||
| 
 | ||||
| /*  Function used to set the DAC configuration to the default reset state *****/   | ||||
| void DAC_DeInit(void); | ||||
| 
 | ||||
| /*  DAC channels configuration: trigger, output buffer, data format functions */ | ||||
| void DAC_Init(uint32_t DAC_Channel, DAC_InitTypeDef* DAC_InitStruct); | ||||
| void DAC_StructInit(DAC_InitTypeDef* DAC_InitStruct); | ||||
| void DAC_Cmd(uint32_t DAC_Channel, FunctionalState NewState); | ||||
| void DAC_SoftwareTriggerCmd(uint32_t DAC_Channel, FunctionalState NewState); | ||||
| void DAC_DualSoftwareTriggerCmd(FunctionalState NewState); | ||||
| void DAC_WaveGenerationCmd(uint32_t DAC_Channel, uint32_t DAC_Wave, FunctionalState NewState); | ||||
| void DAC_SetChannel1Data(uint32_t DAC_Align, uint16_t Data); | ||||
| void DAC_SetChannel2Data(uint32_t DAC_Align, uint16_t Data); | ||||
| void DAC_SetDualChannelData(uint32_t DAC_Align, uint16_t Data2, uint16_t Data1); | ||||
| uint16_t DAC_GetDataOutputValue(uint32_t DAC_Channel); | ||||
| 
 | ||||
| /* DMA management functions ***************************************************/ | ||||
| void DAC_DMACmd(uint32_t DAC_Channel, FunctionalState NewState); | ||||
| 
 | ||||
| /* Interrupts and flags management functions **********************************/ | ||||
| void DAC_ITConfig(uint32_t DAC_Channel, uint32_t DAC_IT, FunctionalState NewState); | ||||
| FlagStatus DAC_GetFlagStatus(uint32_t DAC_Channel, uint32_t DAC_FLAG); | ||||
| void DAC_ClearFlag(uint32_t DAC_Channel, uint32_t DAC_FLAG); | ||||
| ITStatus DAC_GetITStatus(uint32_t DAC_Channel, uint32_t DAC_IT); | ||||
| void DAC_ClearITPendingBit(uint32_t DAC_Channel, uint32_t DAC_IT); | ||||
| 
 | ||||
| #ifdef __cplusplus | ||||
| } | ||||
| #endif | ||||
| 
 | ||||
| #endif /*__STM32L1xx_DAC_H */ | ||||
| 
 | ||||
| /**
 | ||||
|   * @} | ||||
|   */  | ||||
| 
 | ||||
| /**
 | ||||
|   * @} | ||||
|   */  | ||||
| 
 | ||||
| /************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE****/ | ||||
|  | @ -1,105 +0,0 @@ | |||
| /**
 | ||||
|   ****************************************************************************** | ||||
|   * @file    stm32l1xx_dbgmcu.h | ||||
|   * @author  MCD Application Team | ||||
|   * @version V1.1.1 | ||||
|   * @date    05-March-2012 | ||||
|   * @brief   This file contains all the functions prototypes for the DBGMCU  | ||||
|   *          firmware library. | ||||
|   ****************************************************************************** | ||||
|   * @attention | ||||
|   * | ||||
|   * <h2><center>© COPYRIGHT 2012 STMicroelectronics</center></h2> | ||||
|   * | ||||
|   * Licensed under MCD-ST Liberty SW License Agreement V2, (the "License"); | ||||
|   * You may not use this file except in compliance with the License. | ||||
|   * You may obtain a copy of the License at: | ||||
|   * | ||||
|   *        http://www.st.com/software_license_agreement_liberty_v2
 | ||||
|   * | ||||
|   * Unless required by applicable law or agreed to in writing, software  | ||||
|   * distributed under the License is distributed on an "AS IS" BASIS,  | ||||
|   * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. | ||||
|   * See the License for the specific language governing permissions and | ||||
|   * limitations under the License. | ||||
|   * | ||||
|   ****************************************************************************** | ||||
|   */ | ||||
| 
 | ||||
| /* Define to prevent recursive inclusion -------------------------------------*/ | ||||
| #ifndef __STM32L1xx_DBGMCU_H | ||||
| #define __STM32L1xx_DBGMCU_H | ||||
| 
 | ||||
| #ifdef __cplusplus | ||||
|  extern "C" { | ||||
| #endif | ||||
| 
 | ||||
| /* Includes ------------------------------------------------------------------*/ | ||||
| #include "stm32l1xx.h" | ||||
| 
 | ||||
| /** @addtogroup STM32L1xx_StdPeriph_Driver
 | ||||
|   * @{ | ||||
|   */ | ||||
| 
 | ||||
| /** @addtogroup DBGMCU
 | ||||
|   * @{ | ||||
|   */ | ||||
| 
 | ||||
| /* Exported types ------------------------------------------------------------*/ | ||||
| /* Exported constants --------------------------------------------------------*/ | ||||
| 
 | ||||
| /** @defgroup DBGMCU_Exported_Constants
 | ||||
|   * @{ | ||||
|   */ | ||||
| 
 | ||||
| #define DBGMCU_SLEEP                 ((uint32_t)0x00000001) | ||||
| #define DBGMCU_STOP                  ((uint32_t)0x00000002) | ||||
| #define DBGMCU_STANDBY               ((uint32_t)0x00000004) | ||||
| #define IS_DBGMCU_PERIPH(PERIPH) ((((PERIPH) & 0xFFFFFFF8) == 0x00) && ((PERIPH) != 0x00)) | ||||
| 
 | ||||
| #define DBGMCU_TIM2_STOP             ((uint32_t)0x00000001) | ||||
| #define DBGMCU_TIM3_STOP             ((uint32_t)0x00000002) | ||||
| #define DBGMCU_TIM4_STOP             ((uint32_t)0x00000004) | ||||
| #define DBGMCU_TIM5_STOP             ((uint32_t)0x00000008) | ||||
| #define DBGMCU_TIM6_STOP             ((uint32_t)0x00000010) | ||||
| #define DBGMCU_TIM7_STOP             ((uint32_t)0x00000020) | ||||
| #define DBGMCU_RTC_STOP              ((uint32_t)0x00000400) | ||||
| #define DBGMCU_WWDG_STOP             ((uint32_t)0x00000800) | ||||
| #define DBGMCU_IWDG_STOP             ((uint32_t)0x00001000) | ||||
| #define DBGMCU_I2C1_SMBUS_TIMEOUT    ((uint32_t)0x00200000) | ||||
| #define DBGMCU_I2C2_SMBUS_TIMEOUT    ((uint32_t)0x00400000) | ||||
| #define IS_DBGMCU_APB1PERIPH(PERIPH) ((((PERIPH) & 0xFF9FE3C0) == 0x00) && ((PERIPH) != 0x00)) | ||||
| 
 | ||||
| #define DBGMCU_TIM9_STOP             ((uint32_t)0x00000004) | ||||
| #define DBGMCU_TIM10_STOP            ((uint32_t)0x00000008) | ||||
| #define DBGMCU_TIM11_STOP            ((uint32_t)0x00000010) | ||||
| #define IS_DBGMCU_APB2PERIPH(PERIPH) ((((PERIPH) & 0xFFFFFFE3) == 0x00) && ((PERIPH) != 0x00)) | ||||
| 
 | ||||
| /**
 | ||||
|   * @} | ||||
|   */  | ||||
| 
 | ||||
| /* Exported macro ------------------------------------------------------------*/ | ||||
| /* Exported functions ------------------------------------------------------- */ | ||||
| 
 | ||||
| uint32_t DBGMCU_GetREVID(void); | ||||
| uint32_t DBGMCU_GetDEVID(void); | ||||
| void DBGMCU_Config(uint32_t DBGMCU_Periph, FunctionalState NewState); | ||||
| void DBGMCU_APB1PeriphConfig(uint32_t DBGMCU_Periph, FunctionalState NewState); | ||||
| void DBGMCU_APB2PeriphConfig(uint32_t DBGMCU_Periph, FunctionalState NewState); | ||||
| 
 | ||||
| #ifdef __cplusplus | ||||
| } | ||||
| #endif | ||||
| 
 | ||||
| #endif /* __STM32L1xx_DBGMCU_H */ | ||||
| 
 | ||||
| /**
 | ||||
|   * @} | ||||
|   */ | ||||
| 
 | ||||
| /**
 | ||||
|   * @} | ||||
|   */ | ||||
| 
 | ||||
| /************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE****/ | ||||
|  | @ -1,435 +0,0 @@ | |||
| /**
 | ||||
|   ****************************************************************************** | ||||
|   * @file    stm32l1xx_dma.h | ||||
|   * @author  MCD Application Team | ||||
|   * @version V1.1.1 | ||||
|   * @date    05-March-2012 | ||||
|   * @brief   This file contains all the functions prototypes for the DMA firmware  | ||||
|   *          library. | ||||
|   ****************************************************************************** | ||||
|   * @attention | ||||
|   * | ||||
|   * <h2><center>© COPYRIGHT 2012 STMicroelectronics</center></h2> | ||||
|   * | ||||
|   * Licensed under MCD-ST Liberty SW License Agreement V2, (the "License"); | ||||
|   * You may not use this file except in compliance with the License. | ||||
|   * You may obtain a copy of the License at: | ||||
|   * | ||||
|   *        http://www.st.com/software_license_agreement_liberty_v2
 | ||||
|   * | ||||
|   * Unless required by applicable law or agreed to in writing, software  | ||||
|   * distributed under the License is distributed on an "AS IS" BASIS,  | ||||
|   * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. | ||||
|   * See the License for the specific language governing permissions and | ||||
|   * limitations under the License. | ||||
|   * | ||||
|   ****************************************************************************** | ||||
|   */ | ||||
| 
 | ||||
| /* Define to prevent recursive inclusion -------------------------------------*/ | ||||
| #ifndef __STM32L1xx_DMA_H | ||||
| #define __STM32L1xx_DMA_H | ||||
| 
 | ||||
| #ifdef __cplusplus | ||||
|  extern "C" { | ||||
| #endif | ||||
| 
 | ||||
| /* Includes ------------------------------------------------------------------*/ | ||||
| #include "stm32l1xx.h" | ||||
| 
 | ||||
| /** @addtogroup STM32L1xx_StdPeriph_Driver
 | ||||
|   * @{ | ||||
|   */ | ||||
| 
 | ||||
| /** @addtogroup DMA
 | ||||
|   * @{ | ||||
|   */ | ||||
| 
 | ||||
| /* Exported types ------------------------------------------------------------*/ | ||||
| 
 | ||||
| /** 
 | ||||
|   * @brief  DMA Init structure definition | ||||
|   */ | ||||
| 
 | ||||
| typedef struct | ||||
| { | ||||
|   uint32_t DMA_PeripheralBaseAddr; /*!< Specifies the peripheral base address for DMAy Channelx. */ | ||||
| 
 | ||||
|   uint32_t DMA_MemoryBaseAddr;     /*!< Specifies the memory base address for DMAy Channelx. */ | ||||
| 
 | ||||
|   uint32_t DMA_DIR;                /*!< Specifies if the peripheral is the source or destination.
 | ||||
|                                         This parameter can be a value of @ref DMA_data_transfer_direction */ | ||||
| 
 | ||||
|   uint32_t DMA_BufferSize;         /*!< Specifies the buffer size, in data unit, of the specified Channel. 
 | ||||
|                                         The data unit is equal to the configuration set in DMA_PeripheralDataSize | ||||
|                                         or DMA_MemoryDataSize members depending in the transfer direction. */ | ||||
| 
 | ||||
|   uint32_t DMA_PeripheralInc;      /*!< Specifies whether the Peripheral address register is incremented or not.
 | ||||
|                                         This parameter can be a value of @ref DMA_peripheral_incremented_mode */ | ||||
| 
 | ||||
|   uint32_t DMA_MemoryInc;          /*!< Specifies whether the memory address register is incremented or not.
 | ||||
|                                         This parameter can be a value of @ref DMA_memory_incremented_mode */ | ||||
| 
 | ||||
|   uint32_t DMA_PeripheralDataSize; /*!< Specifies the Peripheral data width.
 | ||||
|                                         This parameter can be a value of @ref DMA_peripheral_data_size */ | ||||
| 
 | ||||
|   uint32_t DMA_MemoryDataSize;     /*!< Specifies the Memory data width.
 | ||||
|                                         This parameter can be a value of @ref DMA_memory_data_size */ | ||||
| 
 | ||||
|   uint32_t DMA_Mode;               /*!< Specifies the operation mode of the DMAy Channelx.
 | ||||
|                                         This parameter can be a value of @ref DMA_circular_normal_mode | ||||
|                                         @note: The circular buffer mode cannot be used if the memory-to-memory | ||||
|                                               data transfer is configured on the selected Channel */ | ||||
| 
 | ||||
|   uint32_t DMA_Priority;           /*!< Specifies the software priority for the DMAy Channelx.
 | ||||
|                                         This parameter can be a value of @ref DMA_priority_level */ | ||||
| 
 | ||||
|   uint32_t DMA_M2M;                /*!< Specifies if the DMAy Channelx will be used in memory-to-memory transfer.
 | ||||
|                                         This parameter can be a value of @ref DMA_memory_to_memory */ | ||||
| }DMA_InitTypeDef; | ||||
| 
 | ||||
| /* Exported constants --------------------------------------------------------*/ | ||||
| 
 | ||||
| /** @defgroup DMA_Exported_Constants
 | ||||
|   * @{ | ||||
|   */ | ||||
| 
 | ||||
| #define IS_DMA_ALL_PERIPH(PERIPH) (((PERIPH) == DMA1_Channel1) || \ | ||||
|                                    ((PERIPH) == DMA1_Channel2) || \ | ||||
|                                    ((PERIPH) == DMA1_Channel3) || \ | ||||
|                                    ((PERIPH) == DMA1_Channel4) || \ | ||||
|                                    ((PERIPH) == DMA1_Channel5) || \ | ||||
|                                    ((PERIPH) == DMA1_Channel6) || \ | ||||
|                                    ((PERIPH) == DMA1_Channel7) || \ | ||||
|                                    ((PERIPH) == DMA2_Channel1) || \ | ||||
|                                    ((PERIPH) == DMA2_Channel2) || \ | ||||
|                                    ((PERIPH) == DMA2_Channel3) || \ | ||||
|                                    ((PERIPH) == DMA2_Channel4) || \ | ||||
|                                    ((PERIPH) == DMA2_Channel5)) | ||||
| 
 | ||||
| /** @defgroup DMA_data_transfer_direction 
 | ||||
|   * @{ | ||||
|   */ | ||||
| 
 | ||||
| #define DMA_DIR_PeripheralDST              ((uint32_t)0x00000010) | ||||
| #define DMA_DIR_PeripheralSRC              ((uint32_t)0x00000000) | ||||
| #define IS_DMA_DIR(DIR) (((DIR) == DMA_DIR_PeripheralDST) || \ | ||||
|                          ((DIR) == DMA_DIR_PeripheralSRC)) | ||||
| /**
 | ||||
|   * @} | ||||
|   */ | ||||
| 
 | ||||
| /** @defgroup DMA_peripheral_incremented_mode 
 | ||||
|   * @{ | ||||
|   */ | ||||
| 
 | ||||
| #define DMA_PeripheralInc_Enable           ((uint32_t)0x00000040) | ||||
| #define DMA_PeripheralInc_Disable          ((uint32_t)0x00000000) | ||||
| #define IS_DMA_PERIPHERAL_INC_STATE(STATE) (((STATE) == DMA_PeripheralInc_Enable) || \ | ||||
|                                             ((STATE) == DMA_PeripheralInc_Disable)) | ||||
| /**
 | ||||
|   * @} | ||||
|   */ | ||||
| 
 | ||||
| /** @defgroup DMA_memory_incremented_mode 
 | ||||
|   * @{ | ||||
|   */ | ||||
| 
 | ||||
| #define DMA_MemoryInc_Enable               ((uint32_t)0x00000080) | ||||
| #define DMA_MemoryInc_Disable              ((uint32_t)0x00000000) | ||||
| #define IS_DMA_MEMORY_INC_STATE(STATE) (((STATE) == DMA_MemoryInc_Enable) || \ | ||||
|                                         ((STATE) == DMA_MemoryInc_Disable)) | ||||
| /**
 | ||||
|   * @} | ||||
|   */ | ||||
| 
 | ||||
| /** @defgroup DMA_peripheral_data_size 
 | ||||
|   * @{ | ||||
|   */ | ||||
| 
 | ||||
| #define DMA_PeripheralDataSize_Byte        ((uint32_t)0x00000000) | ||||
| #define DMA_PeripheralDataSize_HalfWord    ((uint32_t)0x00000100) | ||||
| #define DMA_PeripheralDataSize_Word        ((uint32_t)0x00000200) | ||||
| #define IS_DMA_PERIPHERAL_DATA_SIZE(SIZE) (((SIZE) == DMA_PeripheralDataSize_Byte) || \ | ||||
|                                            ((SIZE) == DMA_PeripheralDataSize_HalfWord) || \ | ||||
|                                            ((SIZE) == DMA_PeripheralDataSize_Word)) | ||||
| /**
 | ||||
|   * @} | ||||
|   */ | ||||
| 
 | ||||
| /** @defgroup DMA_memory_data_size 
 | ||||
|   * @{ | ||||
|   */ | ||||
| 
 | ||||
| #define DMA_MemoryDataSize_Byte            ((uint32_t)0x00000000) | ||||
| #define DMA_MemoryDataSize_HalfWord        ((uint32_t)0x00000400) | ||||
| #define DMA_MemoryDataSize_Word            ((uint32_t)0x00000800) | ||||
| #define IS_DMA_MEMORY_DATA_SIZE(SIZE) (((SIZE) == DMA_MemoryDataSize_Byte) || \ | ||||
|                                        ((SIZE) == DMA_MemoryDataSize_HalfWord) || \ | ||||
|                                        ((SIZE) == DMA_MemoryDataSize_Word)) | ||||
| /**
 | ||||
|   * @} | ||||
|   */ | ||||
| 
 | ||||
| /** @defgroup DMA_circular_normal_mode 
 | ||||
|   * @{ | ||||
|   */ | ||||
| 
 | ||||
| #define DMA_Mode_Circular                  ((uint32_t)0x00000020) | ||||
| #define DMA_Mode_Normal                    ((uint32_t)0x00000000) | ||||
| #define IS_DMA_MODE(MODE) (((MODE) == DMA_Mode_Circular) || ((MODE) == DMA_Mode_Normal)) | ||||
| /**
 | ||||
|   * @} | ||||
|   */ | ||||
| 
 | ||||
| /** @defgroup DMA_priority_level 
 | ||||
|   * @{ | ||||
|   */ | ||||
| 
 | ||||
| #define DMA_Priority_VeryHigh              ((uint32_t)0x00003000) | ||||
| #define DMA_Priority_High                  ((uint32_t)0x00002000) | ||||
| #define DMA_Priority_Medium                ((uint32_t)0x00001000) | ||||
| #define DMA_Priority_Low                   ((uint32_t)0x00000000) | ||||
| #define IS_DMA_PRIORITY(PRIORITY) (((PRIORITY) == DMA_Priority_VeryHigh) || \ | ||||
|                                    ((PRIORITY) == DMA_Priority_High) || \ | ||||
|                                    ((PRIORITY) == DMA_Priority_Medium) || \ | ||||
|                                    ((PRIORITY) == DMA_Priority_Low)) | ||||
| /**
 | ||||
|   * @} | ||||
|   */ | ||||
| 
 | ||||
| /** @defgroup DMA_memory_to_memory 
 | ||||
|   * @{ | ||||
|   */ | ||||
| 
 | ||||
| #define DMA_M2M_Enable                     ((uint32_t)0x00004000) | ||||
| #define DMA_M2M_Disable                    ((uint32_t)0x00000000) | ||||
| #define IS_DMA_M2M_STATE(STATE) (((STATE) == DMA_M2M_Enable) || ((STATE) == DMA_M2M_Disable)) | ||||
| 
 | ||||
| /**
 | ||||
|   * @} | ||||
|   */ | ||||
| 
 | ||||
| /** @defgroup DMA_interrupts_definition 
 | ||||
|   * @{ | ||||
|   */ | ||||
| 
 | ||||
| #define DMA_IT_TC                          ((uint32_t)0x00000002) | ||||
| #define DMA_IT_HT                          ((uint32_t)0x00000004) | ||||
| #define DMA_IT_TE                          ((uint32_t)0x00000008) | ||||
| #define IS_DMA_CONFIG_IT(IT) ((((IT) & 0xFFFFFFF1) == 0x00) && ((IT) != 0x00)) | ||||
| 
 | ||||
| #define DMA1_IT_GL1                        ((uint32_t)0x00000001) | ||||
| #define DMA1_IT_TC1                        ((uint32_t)0x00000002) | ||||
| #define DMA1_IT_HT1                        ((uint32_t)0x00000004) | ||||
| #define DMA1_IT_TE1                        ((uint32_t)0x00000008) | ||||
| #define DMA1_IT_GL2                        ((uint32_t)0x00000010) | ||||
| #define DMA1_IT_TC2                        ((uint32_t)0x00000020) | ||||
| #define DMA1_IT_HT2                        ((uint32_t)0x00000040) | ||||
| #define DMA1_IT_TE2                        ((uint32_t)0x00000080) | ||||
| #define DMA1_IT_GL3                        ((uint32_t)0x00000100) | ||||
| #define DMA1_IT_TC3                        ((uint32_t)0x00000200) | ||||
| #define DMA1_IT_HT3                        ((uint32_t)0x00000400) | ||||
| #define DMA1_IT_TE3                        ((uint32_t)0x00000800) | ||||
| #define DMA1_IT_GL4                        ((uint32_t)0x00001000) | ||||
| #define DMA1_IT_TC4                        ((uint32_t)0x00002000) | ||||
| #define DMA1_IT_HT4                        ((uint32_t)0x00004000) | ||||
| #define DMA1_IT_TE4                        ((uint32_t)0x00008000) | ||||
| #define DMA1_IT_GL5                        ((uint32_t)0x00010000) | ||||
| #define DMA1_IT_TC5                        ((uint32_t)0x00020000) | ||||
| #define DMA1_IT_HT5                        ((uint32_t)0x00040000) | ||||
| #define DMA1_IT_TE5                        ((uint32_t)0x00080000) | ||||
| #define DMA1_IT_GL6                        ((uint32_t)0x00100000) | ||||
| #define DMA1_IT_TC6                        ((uint32_t)0x00200000) | ||||
| #define DMA1_IT_HT6                        ((uint32_t)0x00400000) | ||||
| #define DMA1_IT_TE6                        ((uint32_t)0x00800000) | ||||
| #define DMA1_IT_GL7                        ((uint32_t)0x01000000) | ||||
| #define DMA1_IT_TC7                        ((uint32_t)0x02000000) | ||||
| #define DMA1_IT_HT7                        ((uint32_t)0x04000000) | ||||
| #define DMA1_IT_TE7                        ((uint32_t)0x08000000) | ||||
| 
 | ||||
| #define DMA2_IT_GL1                        ((uint32_t)0x10000001) | ||||
| #define DMA2_IT_TC1                        ((uint32_t)0x10000002) | ||||
| #define DMA2_IT_HT1                        ((uint32_t)0x10000004) | ||||
| #define DMA2_IT_TE1                        ((uint32_t)0x10000008) | ||||
| #define DMA2_IT_GL2                        ((uint32_t)0x10000010) | ||||
| #define DMA2_IT_TC2                        ((uint32_t)0x10000020) | ||||
| #define DMA2_IT_HT2                        ((uint32_t)0x10000040) | ||||
| #define DMA2_IT_TE2                        ((uint32_t)0x10000080) | ||||
| #define DMA2_IT_GL3                        ((uint32_t)0x10000100) | ||||
| #define DMA2_IT_TC3                        ((uint32_t)0x10000200) | ||||
| #define DMA2_IT_HT3                        ((uint32_t)0x10000400) | ||||
| #define DMA2_IT_TE3                        ((uint32_t)0x10000800) | ||||
| #define DMA2_IT_GL4                        ((uint32_t)0x10001000) | ||||
| #define DMA2_IT_TC4                        ((uint32_t)0x10002000) | ||||
| #define DMA2_IT_HT4                        ((uint32_t)0x10004000) | ||||
| #define DMA2_IT_TE4                        ((uint32_t)0x10008000) | ||||
| #define DMA2_IT_GL5                        ((uint32_t)0x10010000) | ||||
| #define DMA2_IT_TC5                        ((uint32_t)0x10020000) | ||||
| #define DMA2_IT_HT5                        ((uint32_t)0x10040000) | ||||
| #define DMA2_IT_TE5                        ((uint32_t)0x10080000) | ||||
| 
 | ||||
| #define IS_DMA_CLEAR_IT(IT) (((((IT) & 0xF0000000) == 0x00) || (((IT) & 0xEFF00000) == 0x00)) && ((IT) != 0x00)) | ||||
| 
 | ||||
| #define IS_DMA_GET_IT(IT) (((IT) == DMA1_IT_GL1) || ((IT) == DMA1_IT_TC1) || \ | ||||
|                            ((IT) == DMA1_IT_HT1) || ((IT) == DMA1_IT_TE1) || \ | ||||
|                            ((IT) == DMA1_IT_GL2) || ((IT) == DMA1_IT_TC2) || \ | ||||
|                            ((IT) == DMA1_IT_HT2) || ((IT) == DMA1_IT_TE2) || \ | ||||
|                            ((IT) == DMA1_IT_GL3) || ((IT) == DMA1_IT_TC3) || \ | ||||
|                            ((IT) == DMA1_IT_HT3) || ((IT) == DMA1_IT_TE3) || \ | ||||
|                            ((IT) == DMA1_IT_GL4) || ((IT) == DMA1_IT_TC4) || \ | ||||
|                            ((IT) == DMA1_IT_HT4) || ((IT) == DMA1_IT_TE4) || \ | ||||
|                            ((IT) == DMA1_IT_GL5) || ((IT) == DMA1_IT_TC5) || \ | ||||
|                            ((IT) == DMA1_IT_HT5) || ((IT) == DMA1_IT_TE5) || \ | ||||
|                            ((IT) == DMA1_IT_GL6) || ((IT) == DMA1_IT_TC6) || \ | ||||
|                            ((IT) == DMA1_IT_HT6) || ((IT) == DMA1_IT_TE6) || \ | ||||
|                            ((IT) == DMA1_IT_GL7) || ((IT) == DMA1_IT_TC7) || \ | ||||
|                            ((IT) == DMA1_IT_HT7) || ((IT) == DMA1_IT_TE7) || \ | ||||
|                            ((IT) == DMA2_IT_GL1) || ((IT) == DMA2_IT_TC1) || \ | ||||
|                            ((IT) == DMA2_IT_HT1) || ((IT) == DMA2_IT_TE1) || \ | ||||
|                            ((IT) == DMA2_IT_GL2) || ((IT) == DMA2_IT_TC2) || \ | ||||
|                            ((IT) == DMA2_IT_HT2) || ((IT) == DMA2_IT_TE2) || \ | ||||
|                            ((IT) == DMA2_IT_GL3) || ((IT) == DMA2_IT_TC3) || \ | ||||
|                            ((IT) == DMA2_IT_HT3) || ((IT) == DMA2_IT_TE3) || \ | ||||
|                            ((IT) == DMA2_IT_GL4) || ((IT) == DMA2_IT_TC4) || \ | ||||
|                            ((IT) == DMA2_IT_HT4) || ((IT) == DMA2_IT_TE4) || \ | ||||
|                            ((IT) == DMA2_IT_GL5) || ((IT) == DMA2_IT_TC5) || \ | ||||
|                            ((IT) == DMA2_IT_HT5) || ((IT) == DMA2_IT_TE5)) | ||||
| /**
 | ||||
|   * @} | ||||
|   */ | ||||
| 
 | ||||
| /** @defgroup DMA_flags_definition 
 | ||||
|   * @{ | ||||
|   */ | ||||
| #define DMA1_FLAG_GL1                      ((uint32_t)0x00000001) | ||||
| #define DMA1_FLAG_TC1                      ((uint32_t)0x00000002) | ||||
| #define DMA1_FLAG_HT1                      ((uint32_t)0x00000004) | ||||
| #define DMA1_FLAG_TE1                      ((uint32_t)0x00000008) | ||||
| #define DMA1_FLAG_GL2                      ((uint32_t)0x00000010) | ||||
| #define DMA1_FLAG_TC2                      ((uint32_t)0x00000020) | ||||
| #define DMA1_FLAG_HT2                      ((uint32_t)0x00000040) | ||||
| #define DMA1_FLAG_TE2                      ((uint32_t)0x00000080) | ||||
| #define DMA1_FLAG_GL3                      ((uint32_t)0x00000100) | ||||
| #define DMA1_FLAG_TC3                      ((uint32_t)0x00000200) | ||||
| #define DMA1_FLAG_HT3                      ((uint32_t)0x00000400) | ||||
| #define DMA1_FLAG_TE3                      ((uint32_t)0x00000800) | ||||
| #define DMA1_FLAG_GL4                      ((uint32_t)0x00001000) | ||||
| #define DMA1_FLAG_TC4                      ((uint32_t)0x00002000) | ||||
| #define DMA1_FLAG_HT4                      ((uint32_t)0x00004000) | ||||
| #define DMA1_FLAG_TE4                      ((uint32_t)0x00008000) | ||||
| #define DMA1_FLAG_GL5                      ((uint32_t)0x00010000) | ||||
| #define DMA1_FLAG_TC5                      ((uint32_t)0x00020000) | ||||
| #define DMA1_FLAG_HT5                      ((uint32_t)0x00040000) | ||||
| #define DMA1_FLAG_TE5                      ((uint32_t)0x00080000) | ||||
| #define DMA1_FLAG_GL6                      ((uint32_t)0x00100000) | ||||
| #define DMA1_FLAG_TC6                      ((uint32_t)0x00200000) | ||||
| #define DMA1_FLAG_HT6                      ((uint32_t)0x00400000) | ||||
| #define DMA1_FLAG_TE6                      ((uint32_t)0x00800000) | ||||
| #define DMA1_FLAG_GL7                      ((uint32_t)0x01000000) | ||||
| #define DMA1_FLAG_TC7                      ((uint32_t)0x02000000) | ||||
| #define DMA1_FLAG_HT7                      ((uint32_t)0x04000000) | ||||
| #define DMA1_FLAG_TE7                      ((uint32_t)0x08000000) | ||||
| 
 | ||||
| #define DMA2_FLAG_GL1                      ((uint32_t)0x10000001) | ||||
| #define DMA2_FLAG_TC1                      ((uint32_t)0x10000002) | ||||
| #define DMA2_FLAG_HT1                      ((uint32_t)0x10000004) | ||||
| #define DMA2_FLAG_TE1                      ((uint32_t)0x10000008) | ||||
| #define DMA2_FLAG_GL2                      ((uint32_t)0x10000010) | ||||
| #define DMA2_FLAG_TC2                      ((uint32_t)0x10000020) | ||||
| #define DMA2_FLAG_HT2                      ((uint32_t)0x10000040) | ||||
| #define DMA2_FLAG_TE2                      ((uint32_t)0x10000080) | ||||
| #define DMA2_FLAG_GL3                      ((uint32_t)0x10000100) | ||||
| #define DMA2_FLAG_TC3                      ((uint32_t)0x10000200) | ||||
| #define DMA2_FLAG_HT3                      ((uint32_t)0x10000400) | ||||
| #define DMA2_FLAG_TE3                      ((uint32_t)0x10000800) | ||||
| #define DMA2_FLAG_GL4                      ((uint32_t)0x10001000) | ||||
| #define DMA2_FLAG_TC4                      ((uint32_t)0x10002000) | ||||
| #define DMA2_FLAG_HT4                      ((uint32_t)0x10004000) | ||||
| #define DMA2_FLAG_TE4                      ((uint32_t)0x10008000) | ||||
| #define DMA2_FLAG_GL5                      ((uint32_t)0x10010000) | ||||
| #define DMA2_FLAG_TC5                      ((uint32_t)0x10020000) | ||||
| #define DMA2_FLAG_HT5                      ((uint32_t)0x10040000) | ||||
| #define DMA2_FLAG_TE5                      ((uint32_t)0x10080000) | ||||
| 
 | ||||
| #define IS_DMA_CLEAR_FLAG(FLAG) (((((FLAG) & 0xF0000000) == 0x00) || (((FLAG) & 0xEFF00000) == 0x00)) && ((FLAG) != 0x00)) | ||||
| 
 | ||||
| #define IS_DMA_GET_FLAG(FLAG) (((FLAG) == DMA1_FLAG_GL1) || ((FLAG) == DMA1_FLAG_TC1) || \ | ||||
|                                ((FLAG) == DMA1_FLAG_HT1) || ((FLAG) == DMA1_FLAG_TE1) || \ | ||||
|                                ((FLAG) == DMA1_FLAG_GL2) || ((FLAG) == DMA1_FLAG_TC2) || \ | ||||
|                                ((FLAG) == DMA1_FLAG_HT2) || ((FLAG) == DMA1_FLAG_TE2) || \ | ||||
|                                ((FLAG) == DMA1_FLAG_GL3) || ((FLAG) == DMA1_FLAG_TC3) || \ | ||||
|                                ((FLAG) == DMA1_FLAG_HT3) || ((FLAG) == DMA1_FLAG_TE3) || \ | ||||
|                                ((FLAG) == DMA1_FLAG_GL4) || ((FLAG) == DMA1_FLAG_TC4) || \ | ||||
|                                ((FLAG) == DMA1_FLAG_HT4) || ((FLAG) == DMA1_FLAG_TE4) || \ | ||||
|                                ((FLAG) == DMA1_FLAG_GL5) || ((FLAG) == DMA1_FLAG_TC5) || \ | ||||
|                                ((FLAG) == DMA1_FLAG_HT5) || ((FLAG) == DMA1_FLAG_TE5) || \ | ||||
|                                ((FLAG) == DMA1_FLAG_GL6) || ((FLAG) == DMA1_FLAG_TC6) || \ | ||||
|                                ((FLAG) == DMA1_FLAG_HT6) || ((FLAG) == DMA1_FLAG_TE6) || \ | ||||
|                                ((FLAG) == DMA1_FLAG_GL7) || ((FLAG) == DMA1_FLAG_TC7) || \ | ||||
|                                ((FLAG) == DMA1_FLAG_HT7) || ((FLAG) == DMA1_FLAG_TE7) || \ | ||||
|                                ((FLAG) == DMA2_FLAG_GL1) || ((FLAG) == DMA2_FLAG_TC1) || \ | ||||
|                                ((FLAG) == DMA2_FLAG_HT1) || ((FLAG) == DMA2_FLAG_TE1) || \ | ||||
|                                ((FLAG) == DMA2_FLAG_GL2) || ((FLAG) == DMA2_FLAG_TC2) || \ | ||||
|                                ((FLAG) == DMA2_FLAG_HT2) || ((FLAG) == DMA2_FLAG_TE2) || \ | ||||
|                                ((FLAG) == DMA2_FLAG_GL3) || ((FLAG) == DMA2_FLAG_TC3) || \ | ||||
|                                ((FLAG) == DMA2_FLAG_HT3) || ((FLAG) == DMA2_FLAG_TE3) || \ | ||||
|                                ((FLAG) == DMA2_FLAG_GL4) || ((FLAG) == DMA2_FLAG_TC4) || \ | ||||
|                                ((FLAG) == DMA2_FLAG_HT4) || ((FLAG) == DMA2_FLAG_TE4) || \ | ||||
|                                ((FLAG) == DMA2_FLAG_GL5) || ((FLAG) == DMA2_FLAG_TC5) || \ | ||||
|                                ((FLAG) == DMA2_FLAG_HT5) || ((FLAG) == DMA2_FLAG_TE5)) | ||||
| /**
 | ||||
|   * @} | ||||
|   */ | ||||
| 
 | ||||
| /** @defgroup DMA_Buffer_Size 
 | ||||
|   * @{ | ||||
|   */ | ||||
| 
 | ||||
| #define IS_DMA_BUFFER_SIZE(SIZE) (((SIZE) >= 0x1) && ((SIZE) < 0x10000)) | ||||
| 
 | ||||
| /**
 | ||||
|   * @} | ||||
|   */ | ||||
| 
 | ||||
| /**
 | ||||
|   * @} | ||||
|   */ | ||||
| 
 | ||||
| /* Exported macro ------------------------------------------------------------*/ | ||||
| /* Exported functions ------------------------------------------------------- */ | ||||
| 
 | ||||
| /*  Function used to set the DMA configuration to the default reset state *****/  | ||||
| void DMA_DeInit(DMA_Channel_TypeDef* DMAy_Channelx); | ||||
| 
 | ||||
| /* Initialization and Configuration functions *********************************/ | ||||
| void DMA_Init(DMA_Channel_TypeDef* DMAy_Channelx, DMA_InitTypeDef* DMA_InitStruct); | ||||
| void DMA_StructInit(DMA_InitTypeDef* DMA_InitStruct); | ||||
| void DMA_Cmd(DMA_Channel_TypeDef* DMAy_Channelx, FunctionalState NewState); | ||||
| 
 | ||||
| /* Data Counter functions *****************************************************/ | ||||
| void DMA_SetCurrDataCounter(DMA_Channel_TypeDef* DMAy_Channelx, uint16_t DataNumber); | ||||
| uint16_t DMA_GetCurrDataCounter(DMA_Channel_TypeDef* DMAy_Channelx); | ||||
| 
 | ||||
| /* Interrupts and flags management functions **********************************/ | ||||
| void DMA_ITConfig(DMA_Channel_TypeDef* DMAy_Channelx, uint32_t DMA_IT, FunctionalState NewState); | ||||
| FlagStatus DMA_GetFlagStatus(uint32_t DMAy_FLAG); | ||||
| void DMA_ClearFlag(uint32_t DMAy_FLAG); | ||||
| ITStatus DMA_GetITStatus(uint32_t DMAy_IT); | ||||
| void DMA_ClearITPendingBit(uint32_t DMAy_IT); | ||||
| 
 | ||||
| #ifdef __cplusplus | ||||
| } | ||||
| #endif | ||||
| 
 | ||||
| #endif /*__STM32L1xx_DMA_H */ | ||||
| 
 | ||||
| /**
 | ||||
|   * @} | ||||
|   */ | ||||
| 
 | ||||
| /**
 | ||||
|   * @} | ||||
|   */ | ||||
| 
 | ||||
| /************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE****/ | ||||
|  | @ -1,464 +0,0 @@ | |||
| /**
 | ||||
|   ****************************************************************************** | ||||
|   * @file    stm32l1xx_flash.h | ||||
|   * @author  MCD Application Team | ||||
|   * @version V1.1.1 | ||||
|   * @date    05-March-2012 | ||||
|   * @brief   This file contains all the functions prototypes for the FLASH  | ||||
|   *          firmware library. | ||||
|   ****************************************************************************** | ||||
|   * @attention | ||||
|   * | ||||
|   * <h2><center>© COPYRIGHT 2012 STMicroelectronics</center></h2> | ||||
|   * | ||||
|   * Licensed under MCD-ST Liberty SW License Agreement V2, (the "License"); | ||||
|   * You may not use this file except in compliance with the License. | ||||
|   * You may obtain a copy of the License at: | ||||
|   * | ||||
|   *        http://www.st.com/software_license_agreement_liberty_v2
 | ||||
|   * | ||||
|   * Unless required by applicable law or agreed to in writing, software  | ||||
|   * distributed under the License is distributed on an "AS IS" BASIS,  | ||||
|   * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. | ||||
|   * See the License for the specific language governing permissions and | ||||
|   * limitations under the License. | ||||
|   * | ||||
|   ****************************************************************************** | ||||
|   */ | ||||
| 
 | ||||
| /* Define to prevent recursive inclusion -------------------------------------*/ | ||||
| #ifndef __STM32L1xx_FLASH_H | ||||
| #define __STM32L1xx_FLASH_H | ||||
| 
 | ||||
| #ifdef __cplusplus | ||||
|  extern "C" { | ||||
| #endif | ||||
| 
 | ||||
| /* Includes ------------------------------------------------------------------*/ | ||||
| #include "stm32l1xx.h" | ||||
| 
 | ||||
| /** @addtogroup STM32L1xx_StdPeriph_Driver
 | ||||
|   * @{ | ||||
|   */ | ||||
| 
 | ||||
| /** @addtogroup FLASH
 | ||||
|   * @{ | ||||
|   */ | ||||
| 
 | ||||
| /* Exported types ------------------------------------------------------------*/ | ||||
| 
 | ||||
| /** 
 | ||||
|   * @brief  FLASH Status   | ||||
|   */  | ||||
| typedef enum | ||||
| {  | ||||
|   FLASH_BUSY = 1, | ||||
|   FLASH_ERROR_WRP, | ||||
|   FLASH_ERROR_PROGRAM, | ||||
|   FLASH_COMPLETE, | ||||
|   FLASH_TIMEOUT | ||||
| }FLASH_Status; | ||||
| 
 | ||||
| /* Exported constants --------------------------------------------------------*/ | ||||
|    | ||||
| /** @defgroup FLASH_Exported_Constants
 | ||||
|   * @{ | ||||
|   */  | ||||
|    | ||||
| /** @defgroup FLASH_Latency 
 | ||||
|   * @{ | ||||
|   */  | ||||
| #define FLASH_Latency_0                ((uint8_t)0x00)  /*!< FLASH Zero Latency cycle */ | ||||
| #define FLASH_Latency_1                ((uint8_t)0x01)  /*!< FLASH One Latency cycle */ | ||||
| 
 | ||||
| #define IS_FLASH_LATENCY(LATENCY) (((LATENCY) == FLASH_Latency_0) || \ | ||||
|                                    ((LATENCY) == FLASH_Latency_1)) | ||||
| /**
 | ||||
|   * @} | ||||
|   */  | ||||
| 
 | ||||
| /** @defgroup FLASH_Interrupts 
 | ||||
|   * @{ | ||||
|   */ | ||||
|     | ||||
| #define FLASH_IT_EOP               FLASH_PECR_EOPIE  /*!< End of programming interrupt source */ | ||||
| #define FLASH_IT_ERR               FLASH_PECR_ERRIE  /*!< Error interrupt source */ | ||||
| #define IS_FLASH_IT(IT) ((((IT) & (uint32_t)0xFFFCFFFF) == 0x00000000) && (((IT) != 0x00000000))) | ||||
| /**
 | ||||
|   * @} | ||||
|   */  | ||||
| 
 | ||||
| /** @defgroup FLASH_Address 
 | ||||
|   * @{ | ||||
|   */ | ||||
|    | ||||
| #define IS_FLASH_DATA_ADDRESS(ADDRESS) (((ADDRESS) >= 0x08080000) && ((ADDRESS) <= 0x08082FFF)) | ||||
| #define IS_FLASH_PROGRAM_ADDRESS(ADDRESS) (((ADDRESS) >= 0x08000000) && ((ADDRESS) <= 0x0805FFFF))   | ||||
| 
 | ||||
| /**
 | ||||
|   * @} | ||||
|   */  | ||||
| 
 | ||||
| /** @defgroup Option_Bytes_Write_Protection 
 | ||||
|   * @{ | ||||
|   */ | ||||
|    | ||||
| #define OB_WRP_Pages0to15              ((uint32_t)0x00000001) /* Write protection of Sector0 */ | ||||
| #define OB_WRP_Pages16to31             ((uint32_t)0x00000002) /* Write protection of Sector1 */ | ||||
| #define OB_WRP_Pages32to47             ((uint32_t)0x00000004) /* Write protection of Sector2 */ | ||||
| #define OB_WRP_Pages48to63             ((uint32_t)0x00000008) /* Write protection of Sector3 */ | ||||
| #define OB_WRP_Pages64to79             ((uint32_t)0x00000010) /* Write protection of Sector4 */ | ||||
| #define OB_WRP_Pages80to95             ((uint32_t)0x00000020) /* Write protection of Sector5 */ | ||||
| #define OB_WRP_Pages96to111            ((uint32_t)0x00000040) /* Write protection of Sector6 */ | ||||
| #define OB_WRP_Pages112to127           ((uint32_t)0x00000080) /* Write protection of Sector7 */ | ||||
| #define OB_WRP_Pages128to143           ((uint32_t)0x00000100) /* Write protection of Sector8 */ | ||||
| #define OB_WRP_Pages144to159           ((uint32_t)0x00000200) /* Write protection of Sector9 */ | ||||
| #define OB_WRP_Pages160to175           ((uint32_t)0x00000400) /* Write protection of Sector10 */ | ||||
| #define OB_WRP_Pages176to191           ((uint32_t)0x00000800) /* Write protection of Sector11 */ | ||||
| #define OB_WRP_Pages192to207           ((uint32_t)0x00001000) /* Write protection of Sector12 */ | ||||
| #define OB_WRP_Pages208to223           ((uint32_t)0x00002000) /* Write protection of Sector13 */ | ||||
| #define OB_WRP_Pages224to239           ((uint32_t)0x00004000) /* Write protection of Sector14 */ | ||||
| #define OB_WRP_Pages240to255           ((uint32_t)0x00008000) /* Write protection of Sector15 */ | ||||
| #define OB_WRP_Pages256to271           ((uint32_t)0x00010000) /* Write protection of Sector16 */ | ||||
| #define OB_WRP_Pages272to287           ((uint32_t)0x00020000) /* Write protection of Sector17 */ | ||||
| #define OB_WRP_Pages288to303           ((uint32_t)0x00040000) /* Write protection of Sector18 */ | ||||
| #define OB_WRP_Pages304to319           ((uint32_t)0x00080000) /* Write protection of Sector19 */ | ||||
| #define OB_WRP_Pages320to335           ((uint32_t)0x00100000) /* Write protection of Sector20 */ | ||||
| #define OB_WRP_Pages336to351           ((uint32_t)0x00200000) /* Write protection of Sector21 */ | ||||
| #define OB_WRP_Pages352to367           ((uint32_t)0x00400000) /* Write protection of Sector22 */ | ||||
| #define OB_WRP_Pages368to383           ((uint32_t)0x00800000) /* Write protection of Sector23 */ | ||||
| #define OB_WRP_Pages384to399           ((uint32_t)0x01000000) /* Write protection of Sector24 */ | ||||
| #define OB_WRP_Pages400to415           ((uint32_t)0x02000000) /* Write protection of Sector25 */ | ||||
| #define OB_WRP_Pages416to431           ((uint32_t)0x04000000) /* Write protection of Sector26 */ | ||||
| #define OB_WRP_Pages432to447           ((uint32_t)0x08000000) /* Write protection of Sector27 */ | ||||
| #define OB_WRP_Pages448to463           ((uint32_t)0x10000000) /* Write protection of Sector28 */ | ||||
| #define OB_WRP_Pages464to479           ((uint32_t)0x20000000) /* Write protection of Sector29 */ | ||||
| #define OB_WRP_Pages480to495           ((uint32_t)0x40000000) /* Write protection of Sector30 */ | ||||
| #define OB_WRP_Pages496to511           ((uint32_t)0x80000000) /* Write protection of Sector31 */ | ||||
| 
 | ||||
| #define OB_WRP_AllPages                ((uint32_t)0xFFFFFFFF) /*!< Write protection of all Sectors */ | ||||
| 
 | ||||
| #define OB_WRP1_Pages512to527          ((uint32_t)0x00000001) /* Write protection of Sector32 */ | ||||
| #define OB_WRP1_Pages528to543          ((uint32_t)0x00000002) /* Write protection of Sector33 */ | ||||
| #define OB_WRP1_Pages544to559          ((uint32_t)0x00000004) /* Write protection of Sector34 */ | ||||
| #define OB_WRP1_Pages560to575          ((uint32_t)0x00000008) /* Write protection of Sector35 */ | ||||
| #define OB_WRP1_Pages576to591          ((uint32_t)0x00000010) /* Write protection of Sector36 */ | ||||
| #define OB_WRP1_Pages592to607          ((uint32_t)0x00000020) /* Write protection of Sector37 */ | ||||
| #define OB_WRP1_Pages608to623          ((uint32_t)0x00000040) /* Write protection of Sector38 */ | ||||
| #define OB_WRP1_Pages624to639          ((uint32_t)0x00000080) /* Write protection of Sector39 */ | ||||
| #define OB_WRP1_Pages640to655          ((uint32_t)0x00000100) /* Write protection of Sector40 */ | ||||
| #define OB_WRP1_Pages656to671          ((uint32_t)0x00000200) /* Write protection of Sector41 */ | ||||
| #define OB_WRP1_Pages672to687          ((uint32_t)0x00000400) /* Write protection of Sector42 */ | ||||
| #define OB_WRP1_Pages688to703          ((uint32_t)0x00000800) /* Write protection of Sector43 */ | ||||
| #define OB_WRP1_Pages704to719          ((uint32_t)0x00001000) /* Write protection of Sector44 */ | ||||
| #define OB_WRP1_Pages720to735          ((uint32_t)0x00002000) /* Write protection of Sector45 */ | ||||
| #define OB_WRP1_Pages736to751          ((uint32_t)0x00004000) /* Write protection of Sector46 */ | ||||
| #define OB_WRP1_Pages752to767          ((uint32_t)0x00008000) /* Write protection of Sector47 */ | ||||
| #define OB_WRP1_Pages768to783          ((uint32_t)0x00010000) /* Write protection of Sector48 */ | ||||
| #define OB_WRP1_Pages784to799          ((uint32_t)0x00020000) /* Write protection of Sector49 */ | ||||
| #define OB_WRP1_Pages800to815          ((uint32_t)0x00040000) /* Write protection of Sector50 */ | ||||
| #define OB_WRP1_Pages816to831          ((uint32_t)0x00080000) /* Write protection of Sector51 */ | ||||
| #define OB_WRP1_Pages832to847          ((uint32_t)0x00100000) /* Write protection of Sector52 */ | ||||
| #define OB_WRP1_Pages848to863          ((uint32_t)0x00200000) /* Write protection of Sector53 */ | ||||
| #define OB_WRP1_Pages864to879          ((uint32_t)0x00400000) /* Write protection of Sector54 */ | ||||
| #define OB_WRP1_Pages880to895          ((uint32_t)0x00800000) /* Write protection of Sector55 */ | ||||
| #define OB_WRP1_Pages896to911          ((uint32_t)0x01000000) /* Write protection of Sector56 */ | ||||
| #define OB_WRP1_Pages912to927          ((uint32_t)0x02000000) /* Write protection of Sector57 */ | ||||
| #define OB_WRP1_Pages928to943          ((uint32_t)0x04000000) /* Write protection of Sector58 */ | ||||
| #define OB_WRP1_Pages944to959          ((uint32_t)0x08000000) /* Write protection of Sector59 */ | ||||
| #define OB_WRP1_Pages960to975          ((uint32_t)0x10000000) /* Write protection of Sector60 */ | ||||
| #define OB_WRP1_Pages976to991          ((uint32_t)0x20000000) /* Write protection of Sector61 */ | ||||
| #define OB_WRP1_Pages992to1007         ((uint32_t)0x40000000) /* Write protection of Sector62 */ | ||||
| #define OB_WRP1_Pages1008to1023        ((uint32_t)0x80000000) /* Write protection of Sector63 */ | ||||
| 
 | ||||
| #define OB_WRP1_AllPages               ((uint32_t)0xFFFFFFFF) /*!< Write protection of all Sectors */ | ||||
| 
 | ||||
| #define OB_WRP2_Pages1024to1039        ((uint32_t)0x00000001) /* Write protection of Sector64 */ | ||||
| #define OB_WRP2_Pages1040to1055        ((uint32_t)0x00000002) /* Write protection of Sector65 */ | ||||
| #define OB_WRP2_Pages1056to1071        ((uint32_t)0x00000004) /* Write protection of Sector66 */ | ||||
| #define OB_WRP2_Pages1072to1087        ((uint32_t)0x00000008) /* Write protection of Sector67 */ | ||||
| #define OB_WRP2_Pages1088to1103        ((uint32_t)0x00000010) /* Write protection of Sector68 */ | ||||
| #define OB_WRP2_Pages1104to1119        ((uint32_t)0x00000020) /* Write protection of Sector69 */ | ||||
| #define OB_WRP2_Pages1120to1135        ((uint32_t)0x00000040) /* Write protection of Sector70 */ | ||||
| #define OB_WRP2_Pages1136to1151        ((uint32_t)0x00000080) /* Write protection of Sector71 */ | ||||
| #define OB_WRP2_Pages1152to1167        ((uint32_t)0x00000100) /* Write protection of Sector72 */ | ||||
| #define OB_WRP2_Pages1168to1183        ((uint32_t)0x00000200) /* Write protection of Sector73 */ | ||||
| #define OB_WRP2_Pages1184to1199        ((uint32_t)0x00000400) /* Write protection of Sector74 */ | ||||
| #define OB_WRP2_Pages1200to1215        ((uint32_t)0x00000800) /* Write protection of Sector75 */ | ||||
| #define OB_WRP2_Pages1216to1231        ((uint32_t)0x00001000) /* Write protection of Sector76 */ | ||||
| #define OB_WRP2_Pages1232to1247        ((uint32_t)0x00002000) /* Write protection of Sector77 */ | ||||
| #define OB_WRP2_Pages1248to1263        ((uint32_t)0x00004000) /* Write protection of Sector78 */ | ||||
| #define OB_WRP2_Pages1264to1279        ((uint32_t)0x00008000) /* Write protection of Sector79 */ | ||||
| #define OB_WRP2_Pages1280to1295        ((uint32_t)0x00010000) /* Write protection of Sector80 */ | ||||
| #define OB_WRP2_Pages1296to1311        ((uint32_t)0x00020000) /* Write protection of Sector81 */ | ||||
| #define OB_WRP2_Pages1312to1327        ((uint32_t)0x00040000) /* Write protection of Sector82 */ | ||||
| #define OB_WRP2_Pages1328to1343        ((uint32_t)0x00080000) /* Write protection of Sector83 */ | ||||
| #define OB_WRP2_Pages1344to1359        ((uint32_t)0x00100000) /* Write protection of Sector84 */ | ||||
| #define OB_WRP2_Pages1360to1375        ((uint32_t)0x00200000) /* Write protection of Sector85 */ | ||||
| #define OB_WRP2_Pages1376to1391        ((uint32_t)0x00400000) /* Write protection of Sector86 */ | ||||
| #define OB_WRP2_Pages1392to1407        ((uint32_t)0x00800000) /* Write protection of Sector87 */ | ||||
| #define OB_WRP2_Pages1408to1423        ((uint32_t)0x01000000) /* Write protection of Sector88 */ | ||||
| #define OB_WRP2_Pages1424to1439        ((uint32_t)0x02000000) /* Write protection of Sector89 */ | ||||
| #define OB_WRP2_Pages1440to1455        ((uint32_t)0x04000000) /* Write protection of Sector90 */ | ||||
| #define OB_WRP2_Pages1456to1471        ((uint32_t)0x08000000) /* Write protection of Sector91 */ | ||||
| #define OB_WRP2_Pages1472to1487        ((uint32_t)0x10000000) /* Write protection of Sector92 */ | ||||
| #define OB_WRP2_Pages1488to1503        ((uint32_t)0x20000000) /* Write protection of Sector93 */ | ||||
| #define OB_WRP2_Pages1504to1519        ((uint32_t)0x40000000) /* Write protection of Sector94 */ | ||||
| #define OB_WRP2_Pages1520to1535        ((uint32_t)0x80000000) /* Write protection of Sector95 */ | ||||
| 
 | ||||
| #define OB_WRP2_AllPages               ((uint32_t)0xFFFFFFFF) /*!< Write protection of all Sectors */ | ||||
| 
 | ||||
| #define IS_OB_WRP(PAGE) (((PAGE) != 0x0000000)) | ||||
| 
 | ||||
| /**
 | ||||
|   * @} | ||||
|   */ | ||||
| 
 | ||||
| /** @defgroup Option_Bytes_Read_Protection 
 | ||||
|   * @{ | ||||
|   */  | ||||
| 
 | ||||
| /** 
 | ||||
|   * @brief  Read Protection Level   | ||||
|   */  | ||||
| #define OB_RDP_Level_0   ((uint8_t)0xAA) | ||||
| #define OB_RDP_Level_1   ((uint8_t)0xBB) | ||||
| /*#define OB_RDP_Level_2   ((uint8_t)0xCC)*/ /* Warning: When enabling read protection level 2 
 | ||||
|                                                 it's no more possible to go back to level 1 or 0 */ | ||||
| 
 | ||||
| #define IS_OB_RDP(LEVEL) (((LEVEL) == OB_RDP_Level_0)||\ | ||||
|                           ((LEVEL) == OB_RDP_Level_1))/*||\
 | ||||
|                           ((LEVEL) == OB_RDP_Level_2))*/ | ||||
| /**
 | ||||
|   * @} | ||||
|   */  | ||||
| 
 | ||||
| /** @defgroup Option_Bytes_IWatchdog 
 | ||||
|   * @{ | ||||
|   */ | ||||
| 
 | ||||
| #define OB_IWDG_SW                     ((uint8_t)0x10)  /*!< Software WDG selected */ | ||||
| #define OB_IWDG_HW                     ((uint8_t)0x00)  /*!< Hardware WDG selected */ | ||||
| #define IS_OB_IWDG_SOURCE(SOURCE) (((SOURCE) == OB_IWDG_SW) || ((SOURCE) == OB_IWDG_HW)) | ||||
| 
 | ||||
| /**
 | ||||
|   * @} | ||||
|   */ | ||||
| 
 | ||||
| /** @defgroup Option_Bytes_nRST_STOP 
 | ||||
|   * @{ | ||||
|   */ | ||||
| 
 | ||||
| #define OB_STOP_NoRST                  ((uint8_t)0x20) /*!< No reset generated when entering in STOP */ | ||||
| #define OB_STOP_RST                    ((uint8_t)0x00) /*!< Reset generated when entering in STOP */ | ||||
| #define IS_OB_STOP_SOURCE(SOURCE) (((SOURCE) == OB_STOP_NoRST) || ((SOURCE) == OB_STOP_RST)) | ||||
| 
 | ||||
| /**
 | ||||
|   * @} | ||||
|   */ | ||||
| 
 | ||||
| /** @defgroup Option_Bytes_nRST_STDBY 
 | ||||
|   * @{ | ||||
|   */ | ||||
| 
 | ||||
| #define OB_STDBY_NoRST                 ((uint8_t)0x40) /*!< No reset generated when entering in STANDBY */ | ||||
| #define OB_STDBY_RST                   ((uint8_t)0x00) /*!< Reset generated when entering in STANDBY */ | ||||
| #define IS_OB_STDBY_SOURCE(SOURCE) (((SOURCE) == OB_STDBY_NoRST) || ((SOURCE) == OB_STDBY_RST)) | ||||
| 
 | ||||
| /**
 | ||||
|   * @} | ||||
|   */ | ||||
| 
 | ||||
| /** @defgroup Option_Bytes_BOOT
 | ||||
|   * @{ | ||||
|   */ | ||||
| 
 | ||||
| #define OB_BOOT_BANK2                  ((uint8_t)0x00) /*!< At startup, if boot pins are set in boot from user Flash position | ||||
|                                                             and this parameter is selected the device will boot from Bank 2  | ||||
|                                                             or Bank 1, depending on the activation of the bank */ | ||||
| #define OB_BOOT_BANK1                  ((uint8_t)0x80) /*!< At startup, if boot pins are set in boot from user Flash position | ||||
|                                                             and this parameter is selected the device will boot from Bank1(Default) */ | ||||
| #define IS_OB_BOOT_BANK(BANK) (((BANK) == OB_BOOT_BANK2) || ((BANK) == OB_BOOT_BANK1)) | ||||
| 
 | ||||
| /**
 | ||||
|   * @} | ||||
|   */ | ||||
| 
 | ||||
| /** @defgroup Option_Bytes_BOR_Level 
 | ||||
|   * @{ | ||||
|   */ | ||||
| 
 | ||||
| #define OB_BOR_OFF       ((uint8_t)0x00) /*!< BOR is disabled at power down, the reset is asserted when the VDD  | ||||
|                                               power supply reaches the PDR(Power Down Reset) threshold (1.5V) */ | ||||
| #define OB_BOR_LEVEL1    ((uint8_t)0x08) /*!< BOR Reset threshold levels for 1.7V - 1.8V VDD power supply    */ | ||||
| #define OB_BOR_LEVEL2    ((uint8_t)0x09) /*!< BOR Reset threshold levels for 1.9V - 2.0V VDD power supply    */ | ||||
| #define OB_BOR_LEVEL3    ((uint8_t)0x0A) /*!< BOR Reset threshold levels for 2.3V - 2.4V VDD power supply    */ | ||||
| #define OB_BOR_LEVEL4    ((uint8_t)0x0B) /*!< BOR Reset threshold levels for 2.55V - 2.65V VDD power supply  */ | ||||
| #define OB_BOR_LEVEL5    ((uint8_t)0x0C) /*!< BOR Reset threshold levels for 2.8V - 2.9V VDD power supply    */ | ||||
| 
 | ||||
| #define IS_OB_BOR_LEVEL(LEVEL)  (((LEVEL) == OB_BOR_OFF) || \ | ||||
|                                  ((LEVEL) == OB_BOR_LEVEL1) || \ | ||||
|                                  ((LEVEL) == OB_BOR_LEVEL2) || \ | ||||
|                                  ((LEVEL) == OB_BOR_LEVEL3) || \ | ||||
|                                  ((LEVEL) == OB_BOR_LEVEL4) || \ | ||||
|                                  ((LEVEL) == OB_BOR_LEVEL5)) | ||||
| 
 | ||||
| /**
 | ||||
|   * @} | ||||
|   */ | ||||
|    | ||||
| /** @defgroup FLASH_Flags 
 | ||||
|   * @{ | ||||
|   */  | ||||
| 
 | ||||
| #define FLASH_FLAG_BSY                 FLASH_SR_BSY  /*!< FLASH Busy flag */ | ||||
| #define FLASH_FLAG_EOP                 FLASH_SR_EOP  /*!< FLASH End of Programming flag */ | ||||
| #define FLASH_FLAG_ENDHV               FLASH_SR_ENHV  /*!< FLASH End of High Voltage flag */ | ||||
| #define FLASH_FLAG_READY               FLASH_SR_READY  /*!< FLASH Ready flag after low power mode */ | ||||
| #define FLASH_FLAG_WRPERR              FLASH_SR_WRPERR  /*!< FLASH Write protected error flag */ | ||||
| #define FLASH_FLAG_PGAERR              FLASH_SR_PGAERR  /*!< FLASH Programming Alignment error flag */ | ||||
| #define FLASH_FLAG_SIZERR              FLASH_SR_SIZERR  /*!< FLASH Size error flag  */ | ||||
| #define FLASH_FLAG_OPTVERR             FLASH_SR_OPTVERR  /*!< FLASH Option Validity error flag  */ | ||||
| #define FLASH_FLAG_OPTVERRUSR          FLASH_SR_OPTVERRUSR  /*!< FLASH Option User Validity error flag  */ | ||||
|   | ||||
| #define IS_FLASH_CLEAR_FLAG(FLAG) ((((FLAG) & (uint32_t)0xFFFFE0FD) == 0x00000000) && ((FLAG) != 0x00000000)) | ||||
| 
 | ||||
| #define IS_FLASH_GET_FLAG(FLAG)  (((FLAG) == FLASH_FLAG_BSY) || ((FLAG) == FLASH_FLAG_EOP) || \ | ||||
|                                   ((FLAG) == FLASH_FLAG_ENDHV) || ((FLAG) == FLASH_FLAG_READY ) || \ | ||||
|                                   ((FLAG) ==  FLASH_FLAG_WRPERR) || ((FLAG) == FLASH_FLAG_PGAERR ) || \ | ||||
|                                   ((FLAG) ==  FLASH_FLAG_SIZERR) || ((FLAG) == FLASH_FLAG_OPTVERR) || \ | ||||
|                                   ((FLAG) ==  FLASH_FLAG_OPTVERRUSR)) | ||||
| /**
 | ||||
|   * @} | ||||
|   */  | ||||
| 
 | ||||
| /** @defgroup FLASH_Keys 
 | ||||
|   * @{ | ||||
|   */  | ||||
| 
 | ||||
| #define FLASH_PDKEY1               ((uint32_t)0x04152637) /*!< Flash power down key1 */ | ||||
| #define FLASH_PDKEY2               ((uint32_t)0xFAFBFCFD) /*!< Flash power down key2: used with FLASH_PDKEY1  | ||||
|                                                               to unlock the RUN_PD bit in FLASH_ACR */ | ||||
| 
 | ||||
| #define FLASH_PEKEY1               ((uint32_t)0x89ABCDEF) /*!< Flash program erase key1 */ | ||||
| #define FLASH_PEKEY2               ((uint32_t)0x02030405) /*!< Flash program erase key: used with FLASH_PEKEY2 | ||||
|                                                                to unlock the write access to the FLASH_PECR register and | ||||
|                                                                data EEPROM */ | ||||
| 
 | ||||
| #define FLASH_PRGKEY1              ((uint32_t)0x8C9DAEBF) /*!< Flash program memory key1 */ | ||||
| #define FLASH_PRGKEY2              ((uint32_t)0x13141516) /*!< Flash program memory key2: used with FLASH_PRGKEY2 | ||||
|                                                                to unlock the program memory */ | ||||
| 
 | ||||
| #define FLASH_OPTKEY1              ((uint32_t)0xFBEAD9C8) /*!< Flash option key1 */ | ||||
| #define FLASH_OPTKEY2              ((uint32_t)0x24252627) /*!< Flash option key2: used with FLASH_OPTKEY1 to | ||||
|                                                               unlock the write access to the option byte block */ | ||||
| /**
 | ||||
|   * @} | ||||
|   */ | ||||
|    | ||||
| /** @defgroup Timeout_definition 
 | ||||
|   * @{ | ||||
|   */  | ||||
| #define FLASH_ER_PRG_TIMEOUT         ((uint32_t)0x8000) | ||||
| 
 | ||||
| /**
 | ||||
|   * @} | ||||
|   */  | ||||
| 
 | ||||
| /** @defgroup CMSIS_Legacy 
 | ||||
|   * @{ | ||||
|   */ | ||||
| #if defined ( __ICCARM__ )    | ||||
| #define InterruptType_ACTLR_DISMCYCINT_Msk         IntType_ACTLR_DISMCYCINT_Msk | ||||
| #endif | ||||
| /**
 | ||||
|   * @} | ||||
|   */  | ||||
| /**
 | ||||
|   * @} | ||||
|   */  | ||||
| 
 | ||||
| /* Exported macro ------------------------------------------------------------*/ | ||||
| /* Exported functions ------------------------------------------------------- */ | ||||
|    | ||||
| /** 
 | ||||
|   * @brief  FLASH memory functions that can be executed from FLASH.   | ||||
|   */   | ||||
| /* FLASH Interface configuration functions ************************************/   | ||||
| void FLASH_SetLatency(uint32_t FLASH_Latency); | ||||
| void FLASH_PrefetchBufferCmd(FunctionalState NewState); | ||||
| void FLASH_ReadAccess64Cmd(FunctionalState NewState); | ||||
| void FLASH_SLEEPPowerDownCmd(FunctionalState NewState); | ||||
| 
 | ||||
| /* FLASH Memory Programming functions *****************************************/    | ||||
| void FLASH_Unlock(void); | ||||
| void FLASH_Lock(void); | ||||
| FLASH_Status FLASH_ErasePage(uint32_t Page_Address); | ||||
| FLASH_Status FLASH_FastProgramWord(uint32_t Address, uint32_t Data); | ||||
| 
 | ||||
| /* DATA EEPROM Programming functions ******************************************/   | ||||
| void DATA_EEPROM_Unlock(void); | ||||
| void DATA_EEPROM_Lock(void); | ||||
| void DATA_EEPROM_FixedTimeProgramCmd(FunctionalState NewState); | ||||
| FLASH_Status DATA_EEPROM_EraseByte(uint32_t Address); | ||||
| FLASH_Status DATA_EEPROM_EraseHalfWord(uint32_t Address); | ||||
| FLASH_Status DATA_EEPROM_EraseWord(uint32_t Address); | ||||
| FLASH_Status DATA_EEPROM_FastProgramByte(uint32_t Address, uint8_t Data); | ||||
| FLASH_Status DATA_EEPROM_FastProgramHalfWord(uint32_t Address, uint16_t Data); | ||||
| FLASH_Status DATA_EEPROM_FastProgramWord(uint32_t Address, uint32_t Data); | ||||
| FLASH_Status DATA_EEPROM_ProgramByte(uint32_t Address, uint8_t Data); | ||||
| FLASH_Status DATA_EEPROM_ProgramHalfWord(uint32_t Address, uint16_t Data); | ||||
| FLASH_Status DATA_EEPROM_ProgramWord(uint32_t Address, uint32_t Data); | ||||
| 
 | ||||
| /* Option Bytes Programming functions *****************************************/ | ||||
| void FLASH_OB_Unlock(void); | ||||
| void FLASH_OB_Lock(void); | ||||
| void FLASH_OB_Launch(void); | ||||
| FLASH_Status FLASH_OB_WRPConfig(uint32_t OB_WRP, FunctionalState NewState); | ||||
| FLASH_Status FLASH_OB_WRP1Config(uint32_t OB_WRP1, FunctionalState NewState); | ||||
| FLASH_Status FLASH_OB_WRP2Config(uint32_t OB_WRP2, FunctionalState NewState); | ||||
| FLASH_Status FLASH_OB_RDPConfig(uint8_t OB_RDP); | ||||
| FLASH_Status FLASH_OB_UserConfig(uint8_t OB_IWDG, uint8_t OB_STOP, uint8_t OB_STDBY); | ||||
| FLASH_Status FLASH_OB_BORConfig(uint8_t OB_BOR); | ||||
| FLASH_Status FLASH_OB_BootConfig(uint8_t OB_BOOT); | ||||
| uint8_t FLASH_OB_GetUser(void); | ||||
| uint32_t FLASH_OB_GetWRP(void); | ||||
| uint32_t FLASH_OB_GetWRP1(void); | ||||
| uint32_t FLASH_OB_GetWRP2(void); | ||||
| FlagStatus FLASH_OB_GetRDP(void); | ||||
| uint8_t FLASH_OB_GetBOR(void); | ||||
| 
 | ||||
| /* Interrupts and flags management functions **********************************/   | ||||
| void FLASH_ITConfig(uint32_t FLASH_IT, FunctionalState NewState); | ||||
| FlagStatus FLASH_GetFlagStatus(uint32_t FLASH_FLAG); | ||||
| void FLASH_ClearFlag(uint32_t FLASH_FLAG); | ||||
| FLASH_Status FLASH_GetStatus(void); | ||||
| FLASH_Status FLASH_WaitForLastOperation(uint32_t Timeout); | ||||
| 
 | ||||
| /** 
 | ||||
|   * @brief  FLASH memory functions that should be executed from internal SRAM. | ||||
|   *         These functions are defined inside the "stm32l1xx_flash_ramfunc.c" | ||||
|   *         file. | ||||
|   */  | ||||
| __RAM_FUNC FLASH_RUNPowerDownCmd(FunctionalState NewState); | ||||
| __RAM_FUNC FLASH_EraseParallelPage(uint32_t Page_Address1, uint32_t Page_Address2); | ||||
| __RAM_FUNC FLASH_ProgramHalfPage(uint32_t Address, uint32_t* pBuffer); | ||||
| __RAM_FUNC FLASH_ProgramParallelHalfPage(uint32_t Address1, uint32_t* pBuffer1, uint32_t Address2, uint32_t* pBuffer2); | ||||
| __RAM_FUNC DATA_EEPROM_EraseDoubleWord(uint32_t Address); | ||||
| __RAM_FUNC DATA_EEPROM_ProgramDoubleWord(uint32_t Address, uint64_t Data); | ||||
|    | ||||
| #ifdef __cplusplus | ||||
| } | ||||
| #endif | ||||
| 
 | ||||
| #endif /* __STM32L1xx_FLASH_H */ | ||||
| 
 | ||||
| /**
 | ||||
|   * @} | ||||
|   */ | ||||
| 
 | ||||
| /**
 | ||||
|   * @} | ||||
|   */  | ||||
| 
 | ||||
| /************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE****/ | ||||
|  | @ -1,438 +0,0 @@ | |||
| /**
 | ||||
|   ****************************************************************************** | ||||
|   * @file    stm32l1xx_fsmc.h | ||||
|   * @author  MCD Application Team | ||||
|   * @version V1.1.1 | ||||
|   * @date    05-March-2012 | ||||
|   * @brief   This file contains all the functions prototypes for the FSMC firmware  | ||||
|   *          library. | ||||
|   ****************************************************************************** | ||||
|   * @attention | ||||
|   * | ||||
|   * <h2><center>© COPYRIGHT 2012 STMicroelectronics</center></h2> | ||||
|   * | ||||
|   * Licensed under MCD-ST Liberty SW License Agreement V2, (the "License"); | ||||
|   * You may not use this file except in compliance with the License. | ||||
|   * You may obtain a copy of the License at: | ||||
|   * | ||||
|   *        http://www.st.com/software_license_agreement_liberty_v2
 | ||||
|   * | ||||
|   * Unless required by applicable law or agreed to in writing, software  | ||||
|   * distributed under the License is distributed on an "AS IS" BASIS,  | ||||
|   * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. | ||||
|   * See the License for the specific language governing permissions and | ||||
|   * limitations under the License. | ||||
|   * | ||||
|   ****************************************************************************** | ||||
|   */ | ||||
| 
 | ||||
| /* Define to prevent recursive inclusion -------------------------------------*/ | ||||
| #ifndef __STM32L1xx_FSMC_H | ||||
| #define __STM32L1xx_FSMC_H | ||||
| 
 | ||||
| #ifdef __cplusplus | ||||
|  extern "C" { | ||||
| #endif | ||||
| 
 | ||||
| /* Includes ------------------------------------------------------------------*/ | ||||
| #include "stm32l1xx.h" | ||||
| 
 | ||||
| /** @addtogroup STM32L1xx_StdPeriph_Driver
 | ||||
|   * @{ | ||||
|   */ | ||||
| 
 | ||||
| /** @addtogroup FSMC
 | ||||
|   * @{ | ||||
|   */ | ||||
| 
 | ||||
| /* Exported types ------------------------------------------------------------*/ | ||||
| 
 | ||||
| /** 
 | ||||
|   * @brief  Timing parameters For NOR/SRAM Banks   | ||||
|   */ | ||||
| 
 | ||||
| typedef struct | ||||
| { | ||||
|   uint32_t FSMC_AddressSetupTime;       /*!< Defines the number of HCLK cycles to configure
 | ||||
|                                              the duration of the address setup time.  | ||||
|                                              This parameter can be a value between 0 and 0xF. | ||||
|                                              @note It is not used with synchronous NOR Flash memories. */ | ||||
| 
 | ||||
|   uint32_t FSMC_AddressHoldTime;        /*!< Defines the number of HCLK cycles to configure
 | ||||
|                                              the duration of the address hold time. | ||||
|                                              This parameter can be a value between 0 and 0xF.  | ||||
|                                              @note It is not used with synchronous NOR Flash memories.*/ | ||||
| 
 | ||||
|   uint32_t FSMC_DataSetupTime;          /*!< Defines the number of HCLK cycles to configure
 | ||||
|                                              the duration of the data setup time. | ||||
|                                              This parameter can be a value between 0 and 0xFF. | ||||
|                                              @note It is used for SRAMs, ROMs and asynchronous multiplexed NOR Flash memories. */ | ||||
| 
 | ||||
|   uint32_t FSMC_BusTurnAroundDuration;  /*!< Defines the number of HCLK cycles to configure
 | ||||
|                                              the duration of the bus turnaround. | ||||
|                                              This parameter can be a value between 0 and 0xF. | ||||
|                                              @note It is only used for multiplexed NOR Flash memories. */ | ||||
| 
 | ||||
|   uint32_t FSMC_CLKDivision;            /*!< Defines the period of CLK clock output signal, expressed in number of HCLK cycles.
 | ||||
|                                              This parameter can be a value between 1 and 0xF. | ||||
|                                              @note This parameter is not used for asynchronous NOR Flash, SRAM or ROM accesses. */ | ||||
| 
 | ||||
|   uint32_t FSMC_DataLatency;            /*!< Defines the number of memory clock cycles to issue
 | ||||
|                                              to the memory before getting the first data. | ||||
|                                              The parameter value depends on the memory type as shown below: | ||||
|                                               - It must be set to 0 in case of a CRAM | ||||
|                                               - It is don't care in asynchronous NOR, SRAM or ROM accesses | ||||
|                                               - It may assume a value between 0 and 0xF in NOR Flash memories | ||||
|                                                 with synchronous burst mode enable */ | ||||
| 
 | ||||
|   uint32_t FSMC_AccessMode;             /*!< Specifies the asynchronous access mode. 
 | ||||
|                                              This parameter can be a value of @ref FSMC_Access_Mode */ | ||||
| }FSMC_NORSRAMTimingInitTypeDef; | ||||
| 
 | ||||
| /** 
 | ||||
|   * @brief  FSMC NOR/SRAM Init structure definition | ||||
|   */ | ||||
| 
 | ||||
| typedef struct | ||||
| { | ||||
|   uint32_t FSMC_Bank;                /*!< Specifies the NOR/SRAM memory bank that will be used.
 | ||||
|                                           This parameter can be a value of @ref FSMC_NORSRAM_Bank */ | ||||
| 
 | ||||
|   uint32_t FSMC_DataAddressMux;      /*!< Specifies whether the address and data values are
 | ||||
|                                           multiplexed on the databus or not.  | ||||
|                                           This parameter can be a value of @ref FSMC_Data_Address_Bus_Multiplexing */ | ||||
| 
 | ||||
|   uint32_t FSMC_MemoryType;          /*!< Specifies the type of external memory attached to
 | ||||
|                                           the corresponding memory bank. | ||||
|                                           This parameter can be a value of @ref FSMC_Memory_Type */ | ||||
| 
 | ||||
|   uint32_t FSMC_MemoryDataWidth;     /*!< Specifies the external memory device width.
 | ||||
|                                           This parameter can be a value of @ref FSMC_Data_Width */ | ||||
| 
 | ||||
|   uint32_t FSMC_BurstAccessMode;     /*!< Enables or disables the burst access mode for Flash memory,
 | ||||
|                                           valid only with synchronous burst Flash memories. | ||||
|                                           This parameter can be a value of @ref FSMC_Burst_Access_Mode */ | ||||
|                                         | ||||
|   uint32_t FSMC_AsynchronousWait;     /*!< Enables or disables wait signal during asynchronous transfers,
 | ||||
|                                           valid only with asynchronous Flash memories. | ||||
|                                           This parameter can be a value of @ref FSMC_AsynchronousWait */ | ||||
| 
 | ||||
|   uint32_t FSMC_WaitSignalPolarity;  /*!< Specifies the wait signal polarity, valid only when accessing
 | ||||
|                                           the Flash memory in burst mode. | ||||
|                                           This parameter can be a value of @ref FSMC_Wait_Signal_Polarity */ | ||||
| 
 | ||||
|   uint32_t FSMC_WrapMode;            /*!< Enables or disables the Wrapped burst access mode for Flash
 | ||||
|                                           memory, valid only when accessing Flash memories in burst mode. | ||||
|                                           This parameter can be a value of @ref FSMC_Wrap_Mode */ | ||||
| 
 | ||||
|   uint32_t FSMC_WaitSignalActive;    /*!< Specifies if the wait signal is asserted by the memory one
 | ||||
|                                           clock cycle before the wait state or during the wait state, | ||||
|                                           valid only when accessing memories in burst mode.  | ||||
|                                           This parameter can be a value of @ref FSMC_Wait_Timing */ | ||||
| 
 | ||||
|   uint32_t FSMC_WriteOperation;      /*!< Enables or disables the write operation in the selected bank by the FSMC. 
 | ||||
|                                           This parameter can be a value of @ref FSMC_Write_Operation */ | ||||
| 
 | ||||
|   uint32_t FSMC_WaitSignal;          /*!< Enables or disables the wait-state insertion via wait
 | ||||
|                                           signal, valid for Flash memory access in burst mode.  | ||||
|                                           This parameter can be a value of @ref FSMC_Wait_Signal */ | ||||
| 
 | ||||
|   uint32_t FSMC_ExtendedMode;        /*!< Enables or disables the extended mode.
 | ||||
|                                           This parameter can be a value of @ref FSMC_Extended_Mode */ | ||||
| 
 | ||||
|   uint32_t FSMC_WriteBurst;          /*!< Enables or disables the write burst operation.
 | ||||
|                                           This parameter can be a value of @ref FSMC_Write_Burst */  | ||||
| 
 | ||||
|   FSMC_NORSRAMTimingInitTypeDef* FSMC_ReadWriteTimingStruct; /*!< Timing Parameters for write and read access if the  ExtendedMode is not used*/   | ||||
| 
 | ||||
|   FSMC_NORSRAMTimingInitTypeDef* FSMC_WriteTimingStruct;     /*!< Timing Parameters for write access if the  ExtendedMode is used*/       | ||||
| }FSMC_NORSRAMInitTypeDef; | ||||
| 
 | ||||
| /* Exported constants --------------------------------------------------------*/ | ||||
| 
 | ||||
| /** @defgroup FSMC_Exported_Constants
 | ||||
|   * @{ | ||||
|   */ | ||||
| 
 | ||||
| /** @defgroup FSMC_NORSRAM_Bank 
 | ||||
|   * @{ | ||||
|   */ | ||||
| #define FSMC_Bank1_NORSRAM1                             ((uint32_t)0x00000000) | ||||
| #define FSMC_Bank1_NORSRAM2                             ((uint32_t)0x00000002) | ||||
| #define FSMC_Bank1_NORSRAM3                             ((uint32_t)0x00000004) | ||||
| #define FSMC_Bank1_NORSRAM4                             ((uint32_t)0x00000006) | ||||
| 
 | ||||
| #define IS_FSMC_NORSRAM_BANK(BANK) (((BANK) == FSMC_Bank1_NORSRAM1) || \ | ||||
|                                     ((BANK) == FSMC_Bank1_NORSRAM2) || \ | ||||
|                                     ((BANK) == FSMC_Bank1_NORSRAM3) || \ | ||||
|                                     ((BANK) == FSMC_Bank1_NORSRAM4)) | ||||
| /**
 | ||||
|   * @} | ||||
|   */ | ||||
| 
 | ||||
| /** @defgroup NOR_SRAM_Controller 
 | ||||
|   * @{ | ||||
|   */ | ||||
| 
 | ||||
| /** @defgroup FSMC_Data_Address_Bus_Multiplexing 
 | ||||
|   * @{ | ||||
|   */ | ||||
| 
 | ||||
| #define FSMC_DataAddressMux_Disable                       ((uint32_t)0x00000000) | ||||
| #define FSMC_DataAddressMux_Enable                        ((uint32_t)0x00000002) | ||||
| #define IS_FSMC_MUX(MUX) (((MUX) == FSMC_DataAddressMux_Disable) || \ | ||||
|                           ((MUX) == FSMC_DataAddressMux_Enable)) | ||||
| 
 | ||||
| /**
 | ||||
|   * @} | ||||
|   */ | ||||
| 
 | ||||
| /** @defgroup FSMC_Memory_Type 
 | ||||
|   * @{ | ||||
|   */ | ||||
| 
 | ||||
| #define FSMC_MemoryType_SRAM                            ((uint32_t)0x00000000) | ||||
| #define FSMC_MemoryType_PSRAM                           ((uint32_t)0x00000004) | ||||
| #define FSMC_MemoryType_NOR                             ((uint32_t)0x00000008) | ||||
| #define IS_FSMC_MEMORY(MEMORY) (((MEMORY) == FSMC_MemoryType_SRAM) || \ | ||||
|                                 ((MEMORY) == FSMC_MemoryType_PSRAM)|| \ | ||||
|                                 ((MEMORY) == FSMC_MemoryType_NOR)) | ||||
| 
 | ||||
| /**
 | ||||
|   * @} | ||||
|   */ | ||||
| 
 | ||||
| /** @defgroup FSMC_Data_Width 
 | ||||
|   * @{ | ||||
|   */ | ||||
| 
 | ||||
| #define FSMC_MemoryDataWidth_8b                         ((uint32_t)0x00000000) | ||||
| #define FSMC_MemoryDataWidth_16b                        ((uint32_t)0x00000010) | ||||
| #define IS_FSMC_MEMORY_WIDTH(WIDTH) (((WIDTH) == FSMC_MemoryDataWidth_8b) || \ | ||||
|                                      ((WIDTH) == FSMC_MemoryDataWidth_16b)) | ||||
| 
 | ||||
| /**
 | ||||
|   * @} | ||||
|   */ | ||||
| 
 | ||||
| /** @defgroup FSMC_Burst_Access_Mode 
 | ||||
|   * @{ | ||||
|   */ | ||||
| 
 | ||||
| #define FSMC_BurstAccessMode_Disable                    ((uint32_t)0x00000000)  | ||||
| #define FSMC_BurstAccessMode_Enable                     ((uint32_t)0x00000100) | ||||
| #define IS_FSMC_BURSTMODE(STATE) (((STATE) == FSMC_BurstAccessMode_Disable) || \ | ||||
|                                   ((STATE) == FSMC_BurstAccessMode_Enable)) | ||||
| /**
 | ||||
|   * @} | ||||
|   */ | ||||
|    | ||||
| /** @defgroup FSMC_AsynchronousWait 
 | ||||
|   * @{ | ||||
|   */ | ||||
| #define FSMC_AsynchronousWait_Disable                   ((uint32_t)0x00000000) | ||||
| #define FSMC_AsynchronousWait_Enable                    ((uint32_t)0x00008000) | ||||
| #define IS_FSMC_ASYNWAIT(STATE) (((STATE) == FSMC_AsynchronousWait_Disable) || \ | ||||
|                                  ((STATE) == FSMC_AsynchronousWait_Enable)) | ||||
| 
 | ||||
| /**
 | ||||
|   * @} | ||||
|   */ | ||||
|    | ||||
| /** @defgroup FSMC_Wait_Signal_Polarity 
 | ||||
|   * @{ | ||||
|   */ | ||||
| 
 | ||||
| #define FSMC_WaitSignalPolarity_Low                     ((uint32_t)0x00000000) | ||||
| #define FSMC_WaitSignalPolarity_High                    ((uint32_t)0x00000200) | ||||
| #define IS_FSMC_WAIT_POLARITY(POLARITY) (((POLARITY) == FSMC_WaitSignalPolarity_Low) || \ | ||||
|                                          ((POLARITY) == FSMC_WaitSignalPolarity_High))  | ||||
| 
 | ||||
| /**
 | ||||
|   * @} | ||||
|   */ | ||||
| 
 | ||||
| /** @defgroup FSMC_Wrap_Mode 
 | ||||
|   * @{ | ||||
|   */ | ||||
| 
 | ||||
| #define FSMC_WrapMode_Disable                           ((uint32_t)0x00000000) | ||||
| #define FSMC_WrapMode_Enable                            ((uint32_t)0x00000400)  | ||||
| #define IS_FSMC_WRAP_MODE(MODE) (((MODE) == FSMC_WrapMode_Disable) || \ | ||||
|                                  ((MODE) == FSMC_WrapMode_Enable)) | ||||
| 
 | ||||
| /**
 | ||||
|   * @} | ||||
|   */ | ||||
| 
 | ||||
| /** @defgroup FSMC_Wait_Timing 
 | ||||
|   * @{ | ||||
|   */ | ||||
| 
 | ||||
| #define FSMC_WaitSignalActive_BeforeWaitState           ((uint32_t)0x00000000) | ||||
| #define FSMC_WaitSignalActive_DuringWaitState           ((uint32_t)0x00000800)  | ||||
| #define IS_FSMC_WAIT_SIGNAL_ACTIVE(ACTIVE) (((ACTIVE) == FSMC_WaitSignalActive_BeforeWaitState) || \ | ||||
|                                             ((ACTIVE) == FSMC_WaitSignalActive_DuringWaitState)) | ||||
| 
 | ||||
| /**
 | ||||
|   * @} | ||||
|   */ | ||||
| 
 | ||||
| /** @defgroup FSMC_Write_Operation 
 | ||||
|   * @{ | ||||
|   */ | ||||
| 
 | ||||
| #define FSMC_WriteOperation_Disable                     ((uint32_t)0x00000000) | ||||
| #define FSMC_WriteOperation_Enable                      ((uint32_t)0x00001000) | ||||
| #define IS_FSMC_WRITE_OPERATION(OPERATION) (((OPERATION) == FSMC_WriteOperation_Disable) || \ | ||||
|                                             ((OPERATION) == FSMC_WriteOperation_Enable)) | ||||
|                                | ||||
| /**
 | ||||
|   * @} | ||||
|   */ | ||||
| 
 | ||||
| /** @defgroup FSMC_Wait_Signal 
 | ||||
|   * @{ | ||||
|   */ | ||||
| 
 | ||||
| #define FSMC_WaitSignal_Disable                         ((uint32_t)0x00000000) | ||||
| #define FSMC_WaitSignal_Enable                          ((uint32_t)0x00002000)  | ||||
| #define IS_FSMC_WAITE_SIGNAL(SIGNAL) (((SIGNAL) == FSMC_WaitSignal_Disable) || \ | ||||
|                                       ((SIGNAL) == FSMC_WaitSignal_Enable)) | ||||
| /**
 | ||||
|   * @} | ||||
|   */ | ||||
| 
 | ||||
| /** @defgroup FSMC_Extended_Mode 
 | ||||
|   * @{ | ||||
|   */ | ||||
| 
 | ||||
| #define FSMC_ExtendedMode_Disable                       ((uint32_t)0x00000000) | ||||
| #define FSMC_ExtendedMode_Enable                        ((uint32_t)0x00004000) | ||||
| 
 | ||||
| #define IS_FSMC_EXTENDED_MODE(MODE) (((MODE) == FSMC_ExtendedMode_Disable) || \ | ||||
|                                      ((MODE) == FSMC_ExtendedMode_Enable))  | ||||
| 
 | ||||
| /**
 | ||||
|   * @} | ||||
|   */ | ||||
| 
 | ||||
| /** @defgroup FSMC_Write_Burst 
 | ||||
|   * @{ | ||||
|   */ | ||||
| 
 | ||||
| #define FSMC_WriteBurst_Disable                         ((uint32_t)0x00000000) | ||||
| #define FSMC_WriteBurst_Enable                          ((uint32_t)0x00080000)  | ||||
| #define IS_FSMC_WRITE_BURST(BURST) (((BURST) == FSMC_WriteBurst_Disable) || \ | ||||
|                                     ((BURST) == FSMC_WriteBurst_Enable)) | ||||
| /**
 | ||||
|   * @} | ||||
|   */ | ||||
| 
 | ||||
| /** @defgroup FSMC_Address_Setup_Time 
 | ||||
|   * @{ | ||||
|   */ | ||||
| 
 | ||||
| #define IS_FSMC_ADDRESS_SETUP_TIME(TIME) ((TIME) <= 0xF) | ||||
| 
 | ||||
| /**
 | ||||
|   * @} | ||||
|   */ | ||||
| 
 | ||||
| /** @defgroup FSMC_Address_Hold_Time 
 | ||||
|   * @{ | ||||
|   */ | ||||
| 
 | ||||
| #define IS_FSMC_ADDRESS_HOLD_TIME(TIME) ((TIME) <= 0xF) | ||||
| 
 | ||||
| /**
 | ||||
|   * @} | ||||
|   */ | ||||
| 
 | ||||
| /** @defgroup FSMC_Data_Setup_Time 
 | ||||
|   * @{ | ||||
|   */ | ||||
| 
 | ||||
| #define IS_FSMC_DATASETUP_TIME(TIME) (((TIME) > 0) && ((TIME) <= 0xFF)) | ||||
| 
 | ||||
| /**
 | ||||
|   * @} | ||||
|   */ | ||||
| 
 | ||||
| /** @defgroup FSMC_Bus_Turn_around_Duration 
 | ||||
|   * @{ | ||||
|   */ | ||||
| 
 | ||||
| #define IS_FSMC_TURNAROUND_TIME(TIME) ((TIME) <= 0xF) | ||||
| 
 | ||||
| /**
 | ||||
|   * @} | ||||
|   */ | ||||
| 
 | ||||
| /** @defgroup FSMC_CLK_Division 
 | ||||
|   * @{ | ||||
|   */ | ||||
| 
 | ||||
| #define IS_FSMC_CLK_DIV(DIV) ((DIV) <= 0xF) | ||||
| 
 | ||||
| /**
 | ||||
|   * @} | ||||
|   */ | ||||
| 
 | ||||
| /** @defgroup FSMC_Data_Latency 
 | ||||
|   * @{ | ||||
|   */ | ||||
| 
 | ||||
| #define IS_FSMC_DATA_LATENCY(LATENCY) ((LATENCY) <= 0xF) | ||||
| 
 | ||||
| /**
 | ||||
|   * @} | ||||
|   */ | ||||
| 
 | ||||
| /** @defgroup FSMC_Access_Mode 
 | ||||
|   * @{ | ||||
|   */ | ||||
| 
 | ||||
| #define FSMC_AccessMode_A                               ((uint32_t)0x00000000) | ||||
| #define FSMC_AccessMode_B                               ((uint32_t)0x10000000)  | ||||
| #define FSMC_AccessMode_C                               ((uint32_t)0x20000000) | ||||
| #define FSMC_AccessMode_D                               ((uint32_t)0x30000000) | ||||
| #define IS_FSMC_ACCESS_MODE(MODE) (((MODE) == FSMC_AccessMode_A) || \ | ||||
|                                    ((MODE) == FSMC_AccessMode_B) || \ | ||||
|                                    ((MODE) == FSMC_AccessMode_C) || \ | ||||
|                                    ((MODE) == FSMC_AccessMode_D))  | ||||
| 
 | ||||
| /**
 | ||||
|   * @} | ||||
|   */ | ||||
| 
 | ||||
| /**
 | ||||
|   * @} | ||||
|   */ | ||||
| 
 | ||||
| /**
 | ||||
|   * @} | ||||
|   */ | ||||
| 
 | ||||
| /* Exported macro ------------------------------------------------------------*/ | ||||
| /* Exported functions ------------------------------------------------------- */  | ||||
| /* NOR/SRAM Controller functions **********************************************/ | ||||
| void FSMC_NORSRAMDeInit(uint32_t FSMC_Bank); | ||||
| void FSMC_NORSRAMInit(FSMC_NORSRAMInitTypeDef* FSMC_NORSRAMInitStruct); | ||||
| void FSMC_NORSRAMStructInit(FSMC_NORSRAMInitTypeDef* FSMC_NORSRAMInitStruct); | ||||
| void FSMC_NORSRAMCmd(uint32_t FSMC_Bank, FunctionalState NewState); | ||||
| 
 | ||||
| #ifdef __cplusplus | ||||
| } | ||||
| #endif | ||||
| 
 | ||||
| #endif /*__STM32L1xx_FSMC_H */ | ||||
| /**
 | ||||
|   * @} | ||||
|   */ | ||||
| 
 | ||||
| /**
 | ||||
|   * @} | ||||
|   */  | ||||
| 
 | ||||
| /************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE****/ | ||||
|  | @ -1,703 +0,0 @@ | |||
| /**
 | ||||
|   ****************************************************************************** | ||||
|   * @file    stm32l1xx_i2c.h | ||||
|   * @author  MCD Application Team | ||||
|   * @version V1.1.1 | ||||
|   * @date    05-March-2012 | ||||
|   * @brief   This file contains all the functions prototypes for the I2C firmware  | ||||
|   *          library. | ||||
|   ****************************************************************************** | ||||
|   * @attention | ||||
|   * | ||||
|   * <h2><center>© COPYRIGHT 2012 STMicroelectronics</center></h2> | ||||
|   * | ||||
|   * Licensed under MCD-ST Liberty SW License Agreement V2, (the "License"); | ||||
|   * You may not use this file except in compliance with the License. | ||||
|   * You may obtain a copy of the License at: | ||||
|   * | ||||
|   *        http://www.st.com/software_license_agreement_liberty_v2
 | ||||
|   * | ||||
|   * Unless required by applicable law or agreed to in writing, software  | ||||
|   * distributed under the License is distributed on an "AS IS" BASIS,  | ||||
|   * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. | ||||
|   * See the License for the specific language governing permissions and | ||||
|   * limitations under the License. | ||||
|   * | ||||
|   ****************************************************************************** | ||||
|   */ | ||||
| 
 | ||||
| /* Define to prevent recursive inclusion -------------------------------------*/ | ||||
| #ifndef __STM32L1xx_I2C_H | ||||
| #define __STM32L1xx_I2C_H | ||||
| 
 | ||||
| #ifdef __cplusplus | ||||
|  extern "C" { | ||||
| #endif | ||||
| 
 | ||||
| /* Includes ------------------------------------------------------------------*/ | ||||
| #include "stm32l1xx.h" | ||||
| 
 | ||||
| /** @addtogroup STM32L1xx_StdPeriph_Driver
 | ||||
|   * @{ | ||||
|   */ | ||||
| 
 | ||||
| /** @addtogroup I2C
 | ||||
|   * @{ | ||||
|   */ | ||||
| 
 | ||||
| /* Exported types ------------------------------------------------------------*/ | ||||
| 
 | ||||
| /** 
 | ||||
|   * @brief  I2C Init structure definition   | ||||
|   */ | ||||
| 
 | ||||
| typedef struct | ||||
| { | ||||
|   uint32_t I2C_ClockSpeed;          /*!< Specifies the clock frequency.
 | ||||
|                                          This parameter must be set to a value lower than 400kHz */ | ||||
| 
 | ||||
|   uint16_t I2C_Mode;                /*!< Specifies the I2C mode.
 | ||||
|                                          This parameter can be a value of @ref I2C_mode */ | ||||
| 
 | ||||
|   uint16_t I2C_DutyCycle;           /*!< Specifies the I2C fast mode duty cycle.
 | ||||
|                                          This parameter can be a value of @ref I2C_duty_cycle_in_fast_mode */ | ||||
| 
 | ||||
|   uint16_t I2C_OwnAddress1;         /*!< Specifies the first device own address.
 | ||||
|                                          This parameter can be a 7-bit or 10-bit address. */ | ||||
| 
 | ||||
|   uint16_t I2C_Ack;                 /*!< Enables or disables the acknowledgement.
 | ||||
|                                          This parameter can be a value of @ref I2C_acknowledgement */ | ||||
| 
 | ||||
|   uint16_t I2C_AcknowledgedAddress; /*!< Specifies if 7-bit or 10-bit address is acknowledged.
 | ||||
|                                          This parameter can be a value of @ref I2C_acknowledged_address */ | ||||
| }I2C_InitTypeDef; | ||||
| 
 | ||||
| /* Exported constants --------------------------------------------------------*/ | ||||
| 
 | ||||
| 
 | ||||
| /** @defgroup I2C_Exported_Constants
 | ||||
|   * @{ | ||||
|   */ | ||||
| 
 | ||||
| #define IS_I2C_ALL_PERIPH(PERIPH) (((PERIPH) == I2C1) || \ | ||||
|                                    ((PERIPH) == I2C2)) | ||||
| /** @defgroup I2C_mode 
 | ||||
|   * @{ | ||||
|   */ | ||||
| 
 | ||||
| #define I2C_Mode_I2C                    ((uint16_t)0x0000) | ||||
| #define I2C_Mode_SMBusDevice            ((uint16_t)0x0002)   | ||||
| #define I2C_Mode_SMBusHost              ((uint16_t)0x000A) | ||||
| #define IS_I2C_MODE(MODE) (((MODE) == I2C_Mode_I2C) || \ | ||||
|                            ((MODE) == I2C_Mode_SMBusDevice) || \ | ||||
|                            ((MODE) == I2C_Mode_SMBusHost)) | ||||
| /**
 | ||||
|   * @} | ||||
|   */ | ||||
| 
 | ||||
| /** @defgroup I2C_duty_cycle_in_fast_mode 
 | ||||
|   * @{ | ||||
|   */ | ||||
| 
 | ||||
| #define I2C_DutyCycle_16_9              ((uint16_t)0x4000) /*!< I2C fast mode Tlow/Thigh = 16/9 */ | ||||
| #define I2C_DutyCycle_2                 ((uint16_t)0xBFFF) /*!< I2C fast mode Tlow/Thigh = 2 */ | ||||
| #define IS_I2C_DUTY_CYCLE(CYCLE) (((CYCLE) == I2C_DutyCycle_16_9) || \ | ||||
|                                   ((CYCLE) == I2C_DutyCycle_2)) | ||||
| /**
 | ||||
|   * @} | ||||
|   */  | ||||
| 
 | ||||
| /** @defgroup I2C_acknowledgement
 | ||||
|   * @{ | ||||
|   */ | ||||
| 
 | ||||
| #define I2C_Ack_Enable                  ((uint16_t)0x0400) | ||||
| #define I2C_Ack_Disable                 ((uint16_t)0x0000) | ||||
| #define IS_I2C_ACK_STATE(STATE) (((STATE) == I2C_Ack_Enable) || \ | ||||
|                                  ((STATE) == I2C_Ack_Disable)) | ||||
| /**
 | ||||
|   * @} | ||||
|   */ | ||||
| 
 | ||||
| /** @defgroup I2C_transfer_direction 
 | ||||
|   * @{ | ||||
|   */ | ||||
| 
 | ||||
| #define  I2C_Direction_Transmitter      ((uint8_t)0x00) | ||||
| #define  I2C_Direction_Receiver         ((uint8_t)0x01) | ||||
| #define IS_I2C_DIRECTION(DIRECTION) (((DIRECTION) == I2C_Direction_Transmitter) || \ | ||||
|                                      ((DIRECTION) == I2C_Direction_Receiver)) | ||||
| /**
 | ||||
|   * @} | ||||
|   */ | ||||
| 
 | ||||
| /** @defgroup I2C_acknowledged_address 
 | ||||
|   * @{ | ||||
|   */ | ||||
| 
 | ||||
| #define I2C_AcknowledgedAddress_7bit    ((uint16_t)0x4000) | ||||
| #define I2C_AcknowledgedAddress_10bit   ((uint16_t)0xC000) | ||||
| #define IS_I2C_ACKNOWLEDGE_ADDRESS(ADDRESS) (((ADDRESS) == I2C_AcknowledgedAddress_7bit) || \ | ||||
|                                              ((ADDRESS) == I2C_AcknowledgedAddress_10bit)) | ||||
| /**
 | ||||
|   * @} | ||||
|   */  | ||||
| 
 | ||||
| /** @defgroup I2C_registers 
 | ||||
|   * @{ | ||||
|   */ | ||||
| 
 | ||||
| #define I2C_Register_CR1                ((uint8_t)0x00) | ||||
| #define I2C_Register_CR2                ((uint8_t)0x04) | ||||
| #define I2C_Register_OAR1               ((uint8_t)0x08) | ||||
| #define I2C_Register_OAR2               ((uint8_t)0x0C) | ||||
| #define I2C_Register_DR                 ((uint8_t)0x10) | ||||
| #define I2C_Register_SR1                ((uint8_t)0x14) | ||||
| #define I2C_Register_SR2                ((uint8_t)0x18) | ||||
| #define I2C_Register_CCR                ((uint8_t)0x1C) | ||||
| #define I2C_Register_TRISE              ((uint8_t)0x20) | ||||
| #define IS_I2C_REGISTER(REGISTER) (((REGISTER) == I2C_Register_CR1) || \ | ||||
|                                    ((REGISTER) == I2C_Register_CR2) || \ | ||||
|                                    ((REGISTER) == I2C_Register_OAR1) || \ | ||||
|                                    ((REGISTER) == I2C_Register_OAR2) || \ | ||||
|                                    ((REGISTER) == I2C_Register_DR) || \ | ||||
|                                    ((REGISTER) == I2C_Register_SR1) || \ | ||||
|                                    ((REGISTER) == I2C_Register_SR2) || \ | ||||
|                                    ((REGISTER) == I2C_Register_CCR) || \ | ||||
|                                    ((REGISTER) == I2C_Register_TRISE)) | ||||
| /**
 | ||||
|   * @} | ||||
|   */ | ||||
| 
 | ||||
| /** @defgroup I2C_SMBus_alert_pin_level 
 | ||||
|   * @{ | ||||
|   */ | ||||
| 
 | ||||
| #define I2C_SMBusAlert_Low              ((uint16_t)0x2000) | ||||
| #define I2C_SMBusAlert_High             ((uint16_t)0xDFFF) | ||||
| #define IS_I2C_SMBUS_ALERT(ALERT) (((ALERT) == I2C_SMBusAlert_Low) || \ | ||||
|                                    ((ALERT) == I2C_SMBusAlert_High)) | ||||
| /**
 | ||||
|   * @} | ||||
|   */ | ||||
| 
 | ||||
| /** @defgroup I2C_PEC_position 
 | ||||
|   * @{ | ||||
|   */ | ||||
| 
 | ||||
| #define I2C_PECPosition_Next            ((uint16_t)0x0800) | ||||
| #define I2C_PECPosition_Current         ((uint16_t)0xF7FF) | ||||
| #define IS_I2C_PEC_POSITION(POSITION) (((POSITION) == I2C_PECPosition_Next) || \ | ||||
|                                        ((POSITION) == I2C_PECPosition_Current)) | ||||
| /**
 | ||||
|   * @} | ||||
|   */  | ||||
| 
 | ||||
| /** @defgroup I2C_NACK_position 
 | ||||
|   * @{ | ||||
|   */ | ||||
| 
 | ||||
| #define I2C_NACKPosition_Next           ((uint16_t)0x0800) | ||||
| #define I2C_NACKPosition_Current        ((uint16_t)0xF7FF) | ||||
| #define IS_I2C_NACK_POSITION(POSITION)  (((POSITION) == I2C_NACKPosition_Next) || \ | ||||
|                                          ((POSITION) == I2C_NACKPosition_Current)) | ||||
| /**
 | ||||
|   * @} | ||||
|   */  | ||||
| 
 | ||||
| /** @defgroup I2C_interrupts_definition 
 | ||||
|   * @{ | ||||
|   */ | ||||
| 
 | ||||
| #define I2C_IT_BUF                      ((uint16_t)0x0400) | ||||
| #define I2C_IT_EVT                      ((uint16_t)0x0200) | ||||
| #define I2C_IT_ERR                      ((uint16_t)0x0100) | ||||
| #define IS_I2C_CONFIG_IT(IT) ((((IT) & (uint16_t)0xF8FF) == 0x00) && ((IT) != 0x00)) | ||||
| /**
 | ||||
|   * @} | ||||
|   */  | ||||
| 
 | ||||
| /** @defgroup I2C_interrupts_definition 
 | ||||
|   * @{ | ||||
|   */ | ||||
| 
 | ||||
| #define I2C_IT_SMBALERT                 ((uint32_t)0x01008000) | ||||
| #define I2C_IT_TIMEOUT                  ((uint32_t)0x01004000) | ||||
| #define I2C_IT_PECERR                   ((uint32_t)0x01001000) | ||||
| #define I2C_IT_OVR                      ((uint32_t)0x01000800) | ||||
| #define I2C_IT_AF                       ((uint32_t)0x01000400) | ||||
| #define I2C_IT_ARLO                     ((uint32_t)0x01000200) | ||||
| #define I2C_IT_BERR                     ((uint32_t)0x01000100) | ||||
| #define I2C_IT_TXE                      ((uint32_t)0x06000080) | ||||
| #define I2C_IT_RXNE                     ((uint32_t)0x06000040) | ||||
| #define I2C_IT_STOPF                    ((uint32_t)0x02000010) | ||||
| #define I2C_IT_ADD10                    ((uint32_t)0x02000008) | ||||
| #define I2C_IT_BTF                      ((uint32_t)0x02000004) | ||||
| #define I2C_IT_ADDR                     ((uint32_t)0x02000002) | ||||
| #define I2C_IT_SB                       ((uint32_t)0x02000001) | ||||
| 
 | ||||
| #define IS_I2C_CLEAR_IT(IT) ((((IT) & (uint16_t)0x20FF) == 0x00) && ((IT) != (uint16_t)0x00)) | ||||
| 
 | ||||
| #define IS_I2C_GET_IT(IT) (((IT) == I2C_IT_SMBALERT) || ((IT) == I2C_IT_TIMEOUT) || \ | ||||
|                            ((IT) == I2C_IT_PECERR) || ((IT) == I2C_IT_OVR) || \ | ||||
|                            ((IT) == I2C_IT_AF) || ((IT) == I2C_IT_ARLO) || \ | ||||
|                            ((IT) == I2C_IT_BERR) || ((IT) == I2C_IT_TXE) || \ | ||||
|                            ((IT) == I2C_IT_RXNE) || ((IT) == I2C_IT_STOPF) || \ | ||||
|                            ((IT) == I2C_IT_ADD10) || ((IT) == I2C_IT_BTF) || \ | ||||
|                            ((IT) == I2C_IT_ADDR) || ((IT) == I2C_IT_SB)) | ||||
| /**
 | ||||
|   * @} | ||||
|   */ | ||||
| 
 | ||||
| /** @defgroup I2C_flags_definition 
 | ||||
|   * @{ | ||||
|   */ | ||||
| 
 | ||||
| /** 
 | ||||
|   * @brief  SR2 register flags   | ||||
|   */ | ||||
| 
 | ||||
| #define I2C_FLAG_DUALF                  ((uint32_t)0x00800000) | ||||
| #define I2C_FLAG_SMBHOST                ((uint32_t)0x00400000) | ||||
| #define I2C_FLAG_SMBDEFAULT             ((uint32_t)0x00200000) | ||||
| #define I2C_FLAG_GENCALL                ((uint32_t)0x00100000) | ||||
| #define I2C_FLAG_TRA                    ((uint32_t)0x00040000) | ||||
| #define I2C_FLAG_BUSY                   ((uint32_t)0x00020000) | ||||
| #define I2C_FLAG_MSL                    ((uint32_t)0x00010000) | ||||
| 
 | ||||
| /** 
 | ||||
|   * @brief  SR1 register flags   | ||||
|   */ | ||||
| 
 | ||||
| #define I2C_FLAG_SMBALERT               ((uint32_t)0x10008000) | ||||
| #define I2C_FLAG_TIMEOUT                ((uint32_t)0x10004000) | ||||
| #define I2C_FLAG_PECERR                 ((uint32_t)0x10001000) | ||||
| #define I2C_FLAG_OVR                    ((uint32_t)0x10000800) | ||||
| #define I2C_FLAG_AF                     ((uint32_t)0x10000400) | ||||
| #define I2C_FLAG_ARLO                   ((uint32_t)0x10000200) | ||||
| #define I2C_FLAG_BERR                   ((uint32_t)0x10000100) | ||||
| #define I2C_FLAG_TXE                    ((uint32_t)0x10000080) | ||||
| #define I2C_FLAG_RXNE                   ((uint32_t)0x10000040) | ||||
| #define I2C_FLAG_STOPF                  ((uint32_t)0x10000010) | ||||
| #define I2C_FLAG_ADD10                  ((uint32_t)0x10000008) | ||||
| #define I2C_FLAG_BTF                    ((uint32_t)0x10000004) | ||||
| #define I2C_FLAG_ADDR                   ((uint32_t)0x10000002) | ||||
| #define I2C_FLAG_SB                     ((uint32_t)0x10000001) | ||||
| 
 | ||||
| #define IS_I2C_CLEAR_FLAG(FLAG) ((((FLAG) & (uint16_t)0x20FF) == 0x00) && ((FLAG) != (uint16_t)0x00)) | ||||
| 
 | ||||
| #define IS_I2C_GET_FLAG(FLAG) (((FLAG) == I2C_FLAG_DUALF) || ((FLAG) == I2C_FLAG_SMBHOST) || \ | ||||
|                                ((FLAG) == I2C_FLAG_SMBDEFAULT) || ((FLAG) == I2C_FLAG_GENCALL) || \ | ||||
|                                ((FLAG) == I2C_FLAG_TRA) || ((FLAG) == I2C_FLAG_BUSY) || \ | ||||
|                                ((FLAG) == I2C_FLAG_MSL) || ((FLAG) == I2C_FLAG_SMBALERT) || \ | ||||
|                                ((FLAG) == I2C_FLAG_TIMEOUT) || ((FLAG) == I2C_FLAG_PECERR) || \ | ||||
|                                ((FLAG) == I2C_FLAG_OVR) || ((FLAG) == I2C_FLAG_AF) || \ | ||||
|                                ((FLAG) == I2C_FLAG_ARLO) || ((FLAG) == I2C_FLAG_BERR) || \ | ||||
|                                ((FLAG) == I2C_FLAG_TXE) || ((FLAG) == I2C_FLAG_RXNE) || \ | ||||
|                                ((FLAG) == I2C_FLAG_STOPF) || ((FLAG) == I2C_FLAG_ADD10) || \ | ||||
|                                ((FLAG) == I2C_FLAG_BTF) || ((FLAG) == I2C_FLAG_ADDR) || \ | ||||
|                                ((FLAG) == I2C_FLAG_SB)) | ||||
| /**
 | ||||
|   * @} | ||||
|   */ | ||||
| 
 | ||||
| /** @defgroup I2C_Events 
 | ||||
|   * @{ | ||||
|   */ | ||||
| 
 | ||||
| /**
 | ||||
|  =============================================================================== | ||||
|                I2C Master Events (Events grouped in order of communication) | ||||
|  =============================================================================== | ||||
|  */ | ||||
| 
 | ||||
| /** 
 | ||||
|   * @brief  Communication start | ||||
|   *  | ||||
|   * After sending the START condition (I2C_GenerateSTART() function) the master  | ||||
|   * has to wait for this event. It means that the Start condition has been correctly  | ||||
|   * released on the I2C bus (the bus is free, no other devices is communicating). | ||||
|   *  | ||||
|   */ | ||||
| /* --EV5 */ | ||||
| #define  I2C_EVENT_MASTER_MODE_SELECT                      ((uint32_t)0x00030001)  /* BUSY, MSL and SB flag */ | ||||
| 
 | ||||
| /** 
 | ||||
|   * @brief  Address Acknowledge | ||||
|   *  | ||||
|   * After checking on EV5 (start condition correctly released on the bus), the  | ||||
|   * master sends the address of the slave(s) with which it will communicate  | ||||
|   * (I2C_Send7bitAddress() function, it also determines the direction of the communication:  | ||||
|   * Master transmitter or Receiver). Then the master has to wait that a slave acknowledges  | ||||
|   * his address. If an acknowledge is sent on the bus, one of the following events will  | ||||
|   * be set: | ||||
|   *  | ||||
|   *  1) In case of Master Receiver (7-bit addressing): the I2C_EVENT_MASTER_RECEIVER_MODE_SELECTED  | ||||
|   *     event is set. | ||||
|   *   | ||||
|   *  2) In case of Master Transmitter (7-bit addressing): the I2C_EVENT_MASTER_TRANSMITTER_MODE_SELECTED  | ||||
|   *     is set | ||||
|   *   | ||||
|   *  3) In case of 10-Bit addressing mode, the master (just after generating the START  | ||||
|   *  and checking on EV5) has to send the header of 10-bit addressing mode (I2C_SendData()  | ||||
|   *  function). Then master should wait on EV9. It means that the 10-bit addressing  | ||||
|   *  header has been correctly sent on the bus. Then master should send the second part of  | ||||
|   *  the 10-bit address (LSB) using the function I2C_Send7bitAddress(). Then master  | ||||
|   *  should wait for event EV6.  | ||||
|   *      | ||||
|   */ | ||||
| 
 | ||||
| /* --EV6 */ | ||||
| #define  I2C_EVENT_MASTER_TRANSMITTER_MODE_SELECTED        ((uint32_t)0x00070082)  /* BUSY, MSL, ADDR, TXE and TRA flags */ | ||||
| #define  I2C_EVENT_MASTER_RECEIVER_MODE_SELECTED           ((uint32_t)0x00030002)  /* BUSY, MSL and ADDR flags */ | ||||
| /* --EV9 */ | ||||
| #define  I2C_EVENT_MASTER_MODE_ADDRESS10                   ((uint32_t)0x00030008)  /* BUSY, MSL and ADD10 flags */ | ||||
| 
 | ||||
| /** 
 | ||||
|   * @brief Communication events | ||||
|   *  | ||||
|   * If a communication is established (START condition generated and slave address  | ||||
|   * acknowledged) then the master has to check on one of the following events for  | ||||
|   * communication procedures: | ||||
|   *   | ||||
|   * 1) Master Receiver mode: The master has to wait on the event EV7 then to read  | ||||
|   *    the data received from the slave (I2C_ReceiveData() function). | ||||
|   *  | ||||
|   * 2) Master Transmitter mode: The master has to send data (I2C_SendData()  | ||||
|   *    function) then to wait on event EV8 or EV8_2. | ||||
|   *    These two events are similar:  | ||||
|   *     - EV8 means that the data has been written in the data register and is  | ||||
|   *       being shifted out. | ||||
|   *     - EV8_2 means that the data has been physically shifted out and output  | ||||
|   *       on the bus. | ||||
|   *     In most cases, using EV8 is sufficient for the application. | ||||
|   *     Using EV8_2 leads to a slower communication but ensure more reliable test. | ||||
|   *     EV8_2 is also more suitable than EV8 for testing on the last data transmission  | ||||
|   *     (before Stop condition generation). | ||||
|   *      | ||||
|   *  @note In case the  user software does not guarantee that this event EV7 is  | ||||
|   *  managed before the current byte end of transfer, then user may check on EV7  | ||||
|   *  and BTF flag at the same time (ie. (I2C_EVENT_MASTER_BYTE_RECEIVED | I2C_FLAG_BTF)). | ||||
|   *  In this case the communication may be slower. | ||||
|   *  | ||||
|   */ | ||||
| 
 | ||||
| /* Master RECEIVER mode -----------------------------*/  | ||||
| /* --EV7 */ | ||||
| #define  I2C_EVENT_MASTER_BYTE_RECEIVED                    ((uint32_t)0x00030040)  /* BUSY, MSL and RXNE flags */ | ||||
| 
 | ||||
| /* Master TRANSMITTER mode --------------------------*/ | ||||
| /* --EV8 */ | ||||
| #define I2C_EVENT_MASTER_BYTE_TRANSMITTING                 ((uint32_t)0x00070080) /* TRA, BUSY, MSL, TXE flags */ | ||||
| /* --EV8_2 */ | ||||
| #define  I2C_EVENT_MASTER_BYTE_TRANSMITTED                 ((uint32_t)0x00070084)  /* TRA, BUSY, MSL, TXE and BTF flags */ | ||||
| 
 | ||||
| 
 | ||||
| /**
 | ||||
|  =============================================================================== | ||||
|                I2C Slave Events (Events grouped in order of communication) | ||||
|  =============================================================================== | ||||
|  */ | ||||
| 
 | ||||
| 
 | ||||
| /** 
 | ||||
|   * @brief  Communication start events | ||||
|   *  | ||||
|   * Wait on one of these events at the start of the communication. It means that  | ||||
|   * the I2C peripheral detected a Start condition on the bus (generated by master  | ||||
|   * device) followed by the peripheral address. The peripheral generates an ACK  | ||||
|   * condition on the bus (if the acknowledge feature is enabled through function  | ||||
|   * I2C_AcknowledgeConfig()) and the events listed above are set : | ||||
|   *   | ||||
|   * 1) In normal case (only one address managed by the slave), when the address  | ||||
|   *   sent by the master matches the own address of the peripheral (configured by  | ||||
|   *   I2C_OwnAddress1 field) the I2C_EVENT_SLAVE_XXX_ADDRESS_MATCHED event is set  | ||||
|   *   (where XXX could be TRANSMITTER or RECEIVER). | ||||
|   *     | ||||
|   * 2) In case the address sent by the master matches the second address of the  | ||||
|   *   peripheral (configured by the function I2C_OwnAddress2Config() and enabled  | ||||
|   *   by the function I2C_DualAddressCmd()) the events I2C_EVENT_SLAVE_XXX_SECONDADDRESS_MATCHED  | ||||
|   *   (where XXX could be TRANSMITTER or RECEIVER) are set. | ||||
|   *    | ||||
|   * 3) In case the address sent by the master is General Call (address 0x00) and  | ||||
|   *   if the General Call is enabled for the peripheral (using function I2C_GeneralCallCmd())  | ||||
|   *   the following event is set I2C_EVENT_SLAVE_GENERALCALLADDRESS_MATCHED.    | ||||
|   *  | ||||
|   */ | ||||
| 
 | ||||
| /* --EV1  (all the events below are variants of EV1) */    | ||||
| /* 1) Case of One Single Address managed by the slave */ | ||||
| #define  I2C_EVENT_SLAVE_RECEIVER_ADDRESS_MATCHED          ((uint32_t)0x00020002) /* BUSY and ADDR flags */ | ||||
| #define  I2C_EVENT_SLAVE_TRANSMITTER_ADDRESS_MATCHED       ((uint32_t)0x00060082) /* TRA, BUSY, TXE and ADDR flags */ | ||||
| 
 | ||||
| /* 2) Case of Dual address managed by the slave */ | ||||
| #define  I2C_EVENT_SLAVE_RECEIVER_SECONDADDRESS_MATCHED    ((uint32_t)0x00820000)  /* DUALF and BUSY flags */ | ||||
| #define  I2C_EVENT_SLAVE_TRANSMITTER_SECONDADDRESS_MATCHED ((uint32_t)0x00860080)  /* DUALF, TRA, BUSY and TXE flags */ | ||||
| 
 | ||||
| /* 3) Case of General Call enabled for the slave */ | ||||
| #define  I2C_EVENT_SLAVE_GENERALCALLADDRESS_MATCHED        ((uint32_t)0x00120000)  /* GENCALL and BUSY flags */ | ||||
| 
 | ||||
| /** 
 | ||||
|   * @brief  Communication events | ||||
|   *  | ||||
|   * Wait on one of these events when EV1 has already been checked and:  | ||||
|   *  | ||||
|   * - Slave RECEIVER mode: | ||||
|   *     - EV2: When the application is expecting a data byte to be received.  | ||||
|   *     - EV4: When the application is expecting the end of the communication: master  | ||||
|   *       sends a stop condition and data transmission is stopped. | ||||
|   *     | ||||
|   * - Slave Transmitter mode: | ||||
|   *    - EV3: When a byte has been transmitted by the slave and the application is expecting  | ||||
|   *      the end of the byte transmission. The two events I2C_EVENT_SLAVE_BYTE_TRANSMITTED and | ||||
|   *      I2C_EVENT_SLAVE_BYTE_TRANSMITTING are similar. The second one can optionally be  | ||||
|   *      used when the user software doesn't guarantee the EV3 is managed before the | ||||
|   *      current byte end of transfer. | ||||
|   *    - EV3_2: When the master sends a NACK in order to tell slave that data transmission  | ||||
|   *      shall end (before sending the STOP condition). In this case slave has to stop sending  | ||||
|   *      data bytes and expect a Stop condition on the bus. | ||||
|   *       | ||||
|   *  @note In case the  user software does not guarantee that the event EV2 is  | ||||
|   *  managed before the current byte end of transfer, then user may check on EV2  | ||||
|   *  and BTF flag at the same time (ie. (I2C_EVENT_SLAVE_BYTE_RECEIVED | I2C_FLAG_BTF)). | ||||
|   *  In this case the communication may be slower. | ||||
|   * | ||||
|   */ | ||||
| 
 | ||||
| /* Slave RECEIVER mode --------------------------*/  | ||||
| /* --EV2 */ | ||||
| #define  I2C_EVENT_SLAVE_BYTE_RECEIVED                     ((uint32_t)0x00020040)  /* BUSY and RXNE flags */ | ||||
| /* --EV4  */ | ||||
| #define  I2C_EVENT_SLAVE_STOP_DETECTED                     ((uint32_t)0x00000010)  /* STOPF flag */ | ||||
| 
 | ||||
| /* Slave TRANSMITTER mode -----------------------*/ | ||||
| /* --EV3 */ | ||||
| #define  I2C_EVENT_SLAVE_BYTE_TRANSMITTED                  ((uint32_t)0x00060084)  /* TRA, BUSY, TXE and BTF flags */ | ||||
| #define  I2C_EVENT_SLAVE_BYTE_TRANSMITTING                 ((uint32_t)0x00060080)  /* TRA, BUSY and TXE flags */ | ||||
| /* --EV3_2 */ | ||||
| #define  I2C_EVENT_SLAVE_ACK_FAILURE                       ((uint32_t)0x00000400)  /* AF flag */ | ||||
| 
 | ||||
| /*
 | ||||
|  =============================================================================== | ||||
|                           End of Events Description | ||||
|  =============================================================================== | ||||
|  */ | ||||
| 
 | ||||
| #define IS_I2C_EVENT(EVENT) (((EVENT) == I2C_EVENT_SLAVE_TRANSMITTER_ADDRESS_MATCHED) || \ | ||||
|                              ((EVENT) == I2C_EVENT_SLAVE_RECEIVER_ADDRESS_MATCHED) || \ | ||||
|                              ((EVENT) == I2C_EVENT_SLAVE_TRANSMITTER_SECONDADDRESS_MATCHED) || \ | ||||
|                              ((EVENT) == I2C_EVENT_SLAVE_RECEIVER_SECONDADDRESS_MATCHED) || \ | ||||
|                              ((EVENT) == I2C_EVENT_SLAVE_GENERALCALLADDRESS_MATCHED) || \ | ||||
|                              ((EVENT) == I2C_EVENT_SLAVE_BYTE_RECEIVED) || \ | ||||
|                              ((EVENT) == (I2C_EVENT_SLAVE_BYTE_RECEIVED | I2C_FLAG_DUALF)) || \ | ||||
|                              ((EVENT) == (I2C_EVENT_SLAVE_BYTE_RECEIVED | I2C_FLAG_GENCALL)) || \ | ||||
|                              ((EVENT) == I2C_EVENT_SLAVE_BYTE_TRANSMITTED) || \ | ||||
|                              ((EVENT) == (I2C_EVENT_SLAVE_BYTE_TRANSMITTED | I2C_FLAG_DUALF)) || \ | ||||
|                              ((EVENT) == (I2C_EVENT_SLAVE_BYTE_TRANSMITTED | I2C_FLAG_GENCALL)) || \ | ||||
|                              ((EVENT) == I2C_EVENT_SLAVE_STOP_DETECTED) || \ | ||||
|                              ((EVENT) == I2C_EVENT_MASTER_MODE_SELECT) || \ | ||||
|                              ((EVENT) == I2C_EVENT_MASTER_TRANSMITTER_MODE_SELECTED) || \ | ||||
|                              ((EVENT) == I2C_EVENT_MASTER_RECEIVER_MODE_SELECTED) || \ | ||||
|                              ((EVENT) == I2C_EVENT_MASTER_BYTE_RECEIVED) || \ | ||||
|                              ((EVENT) == I2C_EVENT_MASTER_BYTE_TRANSMITTED) || \ | ||||
|                              ((EVENT) == I2C_EVENT_MASTER_BYTE_TRANSMITTING) || \ | ||||
|                              ((EVENT) == I2C_EVENT_MASTER_MODE_ADDRESS10) || \ | ||||
|                              ((EVENT) == I2C_EVENT_SLAVE_ACK_FAILURE)) | ||||
| /**
 | ||||
|   * @} | ||||
|   */ | ||||
| 
 | ||||
| /** @defgroup I2C_own_address1 
 | ||||
|   * @{ | ||||
|   */ | ||||
| 
 | ||||
| #define IS_I2C_OWN_ADDRESS1(ADDRESS1) ((ADDRESS1) <= 0x3FF) | ||||
| /**
 | ||||
|   * @} | ||||
|   */ | ||||
| 
 | ||||
| /** @defgroup I2C_clock_speed 
 | ||||
|   * @{ | ||||
|   */ | ||||
| 
 | ||||
| #define IS_I2C_CLOCK_SPEED(SPEED) (((SPEED) >= 0x1) && ((SPEED) <= 400000)) | ||||
| /**
 | ||||
|   * @} | ||||
|   */ | ||||
| 
 | ||||
| /**
 | ||||
|   * @} | ||||
|   */ | ||||
| 
 | ||||
| /* Exported macro ------------------------------------------------------------*/ | ||||
| /* Exported functions ------------------------------------------------------- */ | ||||
| 
 | ||||
| /*  Function used to set the I2C configuration to the default reset state *****/ | ||||
| void I2C_DeInit(I2C_TypeDef* I2Cx); | ||||
| 
 | ||||
| /* Initialization and Configuration functions *********************************/ | ||||
| void I2C_Init(I2C_TypeDef* I2Cx, I2C_InitTypeDef* I2C_InitStruct); | ||||
| void I2C_StructInit(I2C_InitTypeDef* I2C_InitStruct); | ||||
| void I2C_Cmd(I2C_TypeDef* I2Cx, FunctionalState NewState); | ||||
| void I2C_GenerateSTART(I2C_TypeDef* I2Cx, FunctionalState NewState); | ||||
| void I2C_GenerateSTOP(I2C_TypeDef* I2Cx, FunctionalState NewState); | ||||
| void I2C_AcknowledgeConfig(I2C_TypeDef* I2Cx, FunctionalState NewState); | ||||
| void I2C_OwnAddress2Config(I2C_TypeDef* I2Cx, uint8_t Address); | ||||
| void I2C_DualAddressCmd(I2C_TypeDef* I2Cx, FunctionalState NewState); | ||||
| void I2C_GeneralCallCmd(I2C_TypeDef* I2Cx, FunctionalState NewState); | ||||
| void I2C_SoftwareResetCmd(I2C_TypeDef* I2Cx, FunctionalState NewState); | ||||
| void I2C_SMBusAlertConfig(I2C_TypeDef* I2Cx, uint16_t I2C_SMBusAlert); | ||||
| void I2C_ARPCmd(I2C_TypeDef* I2Cx, FunctionalState NewState); | ||||
| void I2C_StretchClockCmd(I2C_TypeDef* I2Cx, FunctionalState NewState); | ||||
| void I2C_FastModeDutyCycleConfig(I2C_TypeDef* I2Cx, uint16_t I2C_DutyCycle); | ||||
| void I2C_Send7bitAddress(I2C_TypeDef* I2Cx, uint8_t Address, uint8_t I2C_Direction); | ||||
| 
 | ||||
| /* Data transfers functions ***************************************************/  | ||||
| void I2C_SendData(I2C_TypeDef* I2Cx, uint8_t Data); | ||||
| uint8_t I2C_ReceiveData(I2C_TypeDef* I2Cx); | ||||
| void I2C_NACKPositionConfig(I2C_TypeDef* I2Cx, uint16_t I2C_NACKPosition); | ||||
| 
 | ||||
| /* PEC management functions ***************************************************/  | ||||
| void I2C_TransmitPEC(I2C_TypeDef* I2Cx, FunctionalState NewState); | ||||
| void I2C_PECPositionConfig(I2C_TypeDef* I2Cx, uint16_t I2C_PECPosition); | ||||
| void I2C_CalculatePEC(I2C_TypeDef* I2Cx, FunctionalState NewState); | ||||
| uint8_t I2C_GetPEC(I2C_TypeDef* I2Cx); | ||||
| 
 | ||||
| /* DMA transfers management functions *****************************************/ | ||||
| void I2C_DMACmd(I2C_TypeDef* I2Cx, FunctionalState NewState); | ||||
| void I2C_DMALastTransferCmd(I2C_TypeDef* I2Cx, FunctionalState NewState); | ||||
| 
 | ||||
| 
 | ||||
| /* Interrupts, events and flags management functions **************************/ | ||||
| uint16_t I2C_ReadRegister(I2C_TypeDef* I2Cx, uint8_t I2C_Register); | ||||
| void I2C_ITConfig(I2C_TypeDef* I2Cx, uint16_t I2C_IT, FunctionalState NewState); | ||||
| 
 | ||||
| /*
 | ||||
| 
 | ||||
|  =============================================================================== | ||||
|                           I2C State Monitoring Functions | ||||
|  =============================================================================== | ||||
|   This I2C driver provides three different ways for I2C state monitoring | ||||
|   depending on the application requirements and constraints: | ||||
|           | ||||
|     | ||||
|      1. Basic state monitoring (Using I2C_CheckEvent() function) | ||||
|      ----------------------------------------------------------- | ||||
|         It compares the status registers (SR1 and SR2) content to a given event | ||||
|         (can be the combination of one or more flags). | ||||
|         It returns SUCCESS if the current status includes the given flags  | ||||
|         and returns ERROR if one or more flags are missing in the current status. | ||||
| 
 | ||||
|           - When to use | ||||
|              - This function is suitable for most applications as well as for startup  | ||||
|                activity since the events are fully described in the product reference  | ||||
|                manual (RM0038). | ||||
|              - It is also suitable for users who need to define their own events. | ||||
| 
 | ||||
|           - Limitations | ||||
|              - If an error occurs (ie. error flags are set besides to the monitored  | ||||
|                flags), the I2C_CheckEvent() function may return SUCCESS despite  | ||||
|                the communication hold or corrupted real state.  | ||||
|                In this case, it is advised to use error interrupts to monitor  | ||||
|                the error events and handle them in the interrupt IRQ handler. | ||||
|           | ||||
|      Note | ||||
|          For error management, it is advised to use the following functions: | ||||
|            - I2C_ITConfig() to configure and enable the error interrupts (I2C_IT_ERR). | ||||
|            - I2Cx_ER_IRQHandler() which is called when the error interrupt occurs. | ||||
|              Where x is the peripheral instance (I2C1, I2C2 ...) | ||||
|            - I2C_GetFlagStatus() or I2C_GetITStatus()  to be called into the  | ||||
|              I2Cx_ER_IRQHandler() function in order to determine which error occurred. | ||||
|            - I2C_ClearFlag() or I2C_ClearITPendingBit() and/or I2C_SoftwareResetCmd()  | ||||
|              and/or I2C_GenerateStop() in order to clear the error flag and source  | ||||
|              and return to correct  communciation status. | ||||
|               | ||||
|   | ||||
|      2. Advanced state monitoring (Using the function I2C_GetLastEvent()) | ||||
|      --------------------------------------------------------------------  | ||||
|         Using the function I2C_GetLastEvent() which returns the image of both status  | ||||
|         registers in a single word (uint32_t) (Status Register 2 value is shifted left  | ||||
|         by 16 bits and concatenated to Status Register 1). | ||||
| 
 | ||||
|           - When to use | ||||
|              - This function is suitable for the same applications above but it  | ||||
|                allows to overcome the mentioned limitation of I2C_GetFlagStatus()  | ||||
|                function. | ||||
|              - The returned value could be compared to events already defined in  | ||||
|                the library (stm32l1xx_i2c.h) or to custom values defined by user. | ||||
|                This function is suitable when multiple flags are monitored at the  | ||||
|                same time. | ||||
|              - At the opposite of I2C_CheckEvent() function, this function allows  | ||||
|                user to choose when an event is accepted (when all events flags are  | ||||
|                set and no other flags are set or just when the needed flags are set  | ||||
|                like I2C_CheckEvent() function. | ||||
| 
 | ||||
|           - Limitations | ||||
|              - User may need to define his own events. | ||||
|              - Same remark concerning the error management is applicable for this  | ||||
|                function if user decides to check only regular communication flags  | ||||
|                (and ignores error flags). | ||||
|        | ||||
|   | ||||
|      3. Flag-based state monitoring (Using the function I2C_GetFlagStatus()) | ||||
|      ----------------------------------------------------------------------- | ||||
|       | ||||
|       Using the function I2C_GetFlagStatus() which simply returns the status of  | ||||
|       one single flag (ie. I2C_FLAG_RXNE ...).  | ||||
| 
 | ||||
|           - When to use | ||||
|              - This function could be used for specific applications or in debug  | ||||
|                phase. | ||||
|              - It is suitable when only one flag checking is needed (most I2C  | ||||
|                events are monitored through multiple flags). | ||||
|           - Limitations:  | ||||
|              - When calling this function, the Status register is accessed.  | ||||
|                Some flags are cleared when the status register is accessed.  | ||||
|                So checking the status of one Flag, may clear other ones. | ||||
|              - Function may need to be called twice or more in order to monitor  | ||||
|                one single event. | ||||
| 
 | ||||
|    For detailed description of Events, please refer to section I2C_Events in  | ||||
|    stm32l1xx_i2c.h file. | ||||
| 
 | ||||
| */ | ||||
| 
 | ||||
| /*
 | ||||
|  =============================================================================== | ||||
|                           1. Basic state monitoring | ||||
|  =============================================================================== | ||||
|  */ | ||||
| ErrorStatus I2C_CheckEvent(I2C_TypeDef* I2Cx, uint32_t I2C_EVENT); | ||||
| /*
 | ||||
|  =============================================================================== | ||||
|                           2. Advanced state monitoring | ||||
|  =============================================================================== | ||||
|  */ | ||||
| uint32_t I2C_GetLastEvent(I2C_TypeDef* I2Cx); | ||||
| /*
 | ||||
|  =============================================================================== | ||||
|                           3. Flag-based state monitoring | ||||
|  =============================================================================== | ||||
|  */ | ||||
| FlagStatus I2C_GetFlagStatus(I2C_TypeDef* I2Cx, uint32_t I2C_FLAG); | ||||
| 
 | ||||
| 
 | ||||
| void I2C_ClearFlag(I2C_TypeDef* I2Cx, uint32_t I2C_FLAG); | ||||
| ITStatus I2C_GetITStatus(I2C_TypeDef* I2Cx, uint32_t I2C_IT); | ||||
| void I2C_ClearITPendingBit(I2C_TypeDef* I2Cx, uint32_t I2C_IT); | ||||
| 
 | ||||
| #ifdef __cplusplus | ||||
| } | ||||
| #endif | ||||
| 
 | ||||
| #endif /*__STM32L1xx_I2C_H */ | ||||
| 
 | ||||
| /**
 | ||||
|   * @} | ||||
|   */  | ||||
| 
 | ||||
| /**
 | ||||
|   * @} | ||||
|   */  | ||||
| 
 | ||||
| /************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE****/ | ||||
|  | @ -1,134 +0,0 @@ | |||
| /**
 | ||||
|   ****************************************************************************** | ||||
|   * @file    stm32l1xx_iwdg.h | ||||
|   * @author  MCD Application Team | ||||
|   * @version V1.1.1 | ||||
|   * @date    05-March-2012 | ||||
|   * @brief   This file contains all the functions prototypes for the IWDG  | ||||
|   *          firmware library. | ||||
|   ****************************************************************************** | ||||
|   * @attention | ||||
|   * | ||||
|   * <h2><center>© COPYRIGHT 2012 STMicroelectronics</center></h2> | ||||
|   * | ||||
|   * Licensed under MCD-ST Liberty SW License Agreement V2, (the "License"); | ||||
|   * You may not use this file except in compliance with the License. | ||||
|   * You may obtain a copy of the License at: | ||||
|   * | ||||
|   *        http://www.st.com/software_license_agreement_liberty_v2
 | ||||
|   * | ||||
|   * Unless required by applicable law or agreed to in writing, software  | ||||
|   * distributed under the License is distributed on an "AS IS" BASIS,  | ||||
|   * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. | ||||
|   * See the License for the specific language governing permissions and | ||||
|   * limitations under the License. | ||||
|   * | ||||
|   ****************************************************************************** | ||||
|   */ | ||||
| 
 | ||||
| /* Define to prevent recursive inclusion -------------------------------------*/ | ||||
| #ifndef __STM32L1xx_IWDG_H | ||||
| #define __STM32L1xx_IWDG_H | ||||
| 
 | ||||
| #ifdef __cplusplus | ||||
|  extern "C" { | ||||
| #endif | ||||
| 
 | ||||
| /* Includes ------------------------------------------------------------------*/ | ||||
| #include "stm32l1xx.h" | ||||
| 
 | ||||
| /** @addtogroup STM32L1xx_StdPeriph_Driver
 | ||||
|   * @{ | ||||
|   */ | ||||
| 
 | ||||
| /** @addtogroup IWDG
 | ||||
|   * @{ | ||||
|   */ | ||||
| 
 | ||||
| /* Exported types ------------------------------------------------------------*/ | ||||
| /* Exported constants --------------------------------------------------------*/ | ||||
| 
 | ||||
| /** @defgroup IWDG_Exported_Constants
 | ||||
|   * @{ | ||||
|   */ | ||||
| 
 | ||||
| /** @defgroup IWDG_WriteAccess
 | ||||
|   * @{ | ||||
|   */ | ||||
| 
 | ||||
| #define IWDG_WriteAccess_Enable     ((uint16_t)0x5555) | ||||
| #define IWDG_WriteAccess_Disable    ((uint16_t)0x0000) | ||||
| #define IS_IWDG_WRITE_ACCESS(ACCESS) (((ACCESS) == IWDG_WriteAccess_Enable) || \ | ||||
|                                       ((ACCESS) == IWDG_WriteAccess_Disable)) | ||||
| /**
 | ||||
|   * @} | ||||
|   */ | ||||
| 
 | ||||
| /** @defgroup IWDG_prescaler 
 | ||||
|   * @{ | ||||
|   */ | ||||
| 
 | ||||
| #define IWDG_Prescaler_4            ((uint8_t)0x00) | ||||
| #define IWDG_Prescaler_8            ((uint8_t)0x01) | ||||
| #define IWDG_Prescaler_16           ((uint8_t)0x02) | ||||
| #define IWDG_Prescaler_32           ((uint8_t)0x03) | ||||
| #define IWDG_Prescaler_64           ((uint8_t)0x04) | ||||
| #define IWDG_Prescaler_128          ((uint8_t)0x05) | ||||
| #define IWDG_Prescaler_256          ((uint8_t)0x06) | ||||
| #define IS_IWDG_PRESCALER(PRESCALER) (((PRESCALER) == IWDG_Prescaler_4)  || \ | ||||
|                                       ((PRESCALER) == IWDG_Prescaler_8)  || \ | ||||
|                                       ((PRESCALER) == IWDG_Prescaler_16) || \ | ||||
|                                       ((PRESCALER) == IWDG_Prescaler_32) || \ | ||||
|                                       ((PRESCALER) == IWDG_Prescaler_64) || \ | ||||
|                                       ((PRESCALER) == IWDG_Prescaler_128)|| \ | ||||
|                                       ((PRESCALER) == IWDG_Prescaler_256)) | ||||
| /**
 | ||||
|   * @} | ||||
|   */ | ||||
| 
 | ||||
| /** @defgroup IWDG_Flag 
 | ||||
|   * @{ | ||||
|   */ | ||||
| 
 | ||||
| #define IWDG_FLAG_PVU               ((uint16_t)0x0001) | ||||
| #define IWDG_FLAG_RVU               ((uint16_t)0x0002) | ||||
| #define IS_IWDG_FLAG(FLAG) (((FLAG) == IWDG_FLAG_PVU) || ((FLAG) == IWDG_FLAG_RVU)) | ||||
| #define IS_IWDG_RELOAD(RELOAD) ((RELOAD) <= 0xFFF) | ||||
| /**
 | ||||
|   * @} | ||||
|   */ | ||||
| 
 | ||||
| /**
 | ||||
|   * @} | ||||
|   */ | ||||
| 
 | ||||
| /* Exported macro ------------------------------------------------------------*/ | ||||
| /* Exported functions ------------------------------------------------------- */ | ||||
| 
 | ||||
| /* Prescaler and Counter configuration functions ******************************/ | ||||
| void IWDG_WriteAccessCmd(uint16_t IWDG_WriteAccess); | ||||
| void IWDG_SetPrescaler(uint8_t IWDG_Prescaler); | ||||
| void IWDG_SetReload(uint16_t Reload); | ||||
| void IWDG_ReloadCounter(void); | ||||
| 
 | ||||
| /* IWDG activation function ***************************************************/ | ||||
| void IWDG_Enable(void); | ||||
| 
 | ||||
| /* Flag management function ***************************************************/ | ||||
| FlagStatus IWDG_GetFlagStatus(uint16_t IWDG_FLAG); | ||||
| 
 | ||||
| #ifdef __cplusplus | ||||
| } | ||||
| #endif | ||||
| 
 | ||||
| #endif /* __STM32L1xx_IWDG_H */ | ||||
| 
 | ||||
| /**
 | ||||
|   * @} | ||||
|   */ | ||||
| 
 | ||||
| /**
 | ||||
|   * @} | ||||
|   */ | ||||
| 
 | ||||
| /************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE****/ | ||||
|  | @ -1,187 +0,0 @@ | |||
| /**
 | ||||
|   ****************************************************************************** | ||||
|   * @file    stm32l1xx_opamp.h | ||||
|   * @author  MCD Application Team | ||||
|   * @version V1.1.1 | ||||
|   * @date    05-March-2012 | ||||
|   * @brief   This file contains all the functions prototypes for the operational | ||||
|   *          amplifiers (opamp) firmware library. | ||||
|   ****************************************************************************** | ||||
|   * @attention | ||||
|   * | ||||
|   * <h2><center>© COPYRIGHT 2012 STMicroelectronics</center></h2> | ||||
|   * | ||||
|   * Licensed under MCD-ST Liberty SW License Agreement V2, (the "License"); | ||||
|   * You may not use this file except in compliance with the License. | ||||
|   * You may obtain a copy of the License at: | ||||
|   * | ||||
|   *        http://www.st.com/software_license_agreement_liberty_v2
 | ||||
|   * | ||||
|   * Unless required by applicable law or agreed to in writing, software  | ||||
|   * distributed under the License is distributed on an "AS IS" BASIS,  | ||||
|   * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. | ||||
|   * See the License for the specific language governing permissions and | ||||
|   * limitations under the License. | ||||
|   * | ||||
|   ****************************************************************************** | ||||
|   */  | ||||
| 
 | ||||
| /* Define to prevent recursive inclusion -------------------------------------*/ | ||||
| #ifndef __STM32L1xx_OPAMP_H | ||||
| #define __STM32L1xx_OPAMP_H | ||||
| 
 | ||||
| #ifdef __cplusplus | ||||
|  extern "C" { | ||||
| #endif | ||||
| 
 | ||||
| /* Includes ------------------------------------------------------------------*/ | ||||
| #include "stm32l1xx.h" | ||||
| 
 | ||||
| /** @addtogroup STM32L1xx_StdPeriph_Driver
 | ||||
|   * @{ | ||||
|   */ | ||||
| 
 | ||||
| /** @addtogroup OPAMP
 | ||||
|   * @{ | ||||
|   */ | ||||
| 
 | ||||
| /* Exported types ------------------------------------------------------------*/ | ||||
| /* Exported constants --------------------------------------------------------*/ | ||||
| 
 | ||||
| /** @defgroup OPAMP_Exported_Constants
 | ||||
|   * @{ | ||||
|   */  | ||||
| 
 | ||||
| /** @defgroup OPAMP_Selection
 | ||||
|   * @{ | ||||
|   */ | ||||
| 
 | ||||
| #define OPAMP_Selection_OPAMP1                    OPAMP_CSR_OPA1PD | ||||
| #define OPAMP_Selection_OPAMP2                    OPAMP_CSR_OPA2PD | ||||
| #define OPAMP_Selection_OPAMP3                    OPAMP_CSR_OPA3PD | ||||
| 
 | ||||
| #define IS_OPAMP_ALL_PERIPH(PERIPH) (((PERIPH) == OPAMP_Selection_OPAMP1) || \ | ||||
|                                      ((PERIPH) == OPAMP_Selection_OPAMP2) || \ | ||||
|                                      ((PERIPH) == OPAMP_Selection_OPAMP3)) | ||||
| 
 | ||||
| /**
 | ||||
|   * @} | ||||
|   */  | ||||
| 
 | ||||
| /** @defgroup OPAMP_Switches
 | ||||
|   * @{ | ||||
|   */ | ||||
| 
 | ||||
| /* OPAMP1 Switches */ | ||||
| #define OPAMP_OPAMP1Switch3           OPAMP_CSR_S3SEL1 /*!< OPAMP1 Switch 3 */ | ||||
| #define OPAMP_OPAMP1Switch4           OPAMP_CSR_S4SEL1 /*!< OPAMP1 Switch 4 */ | ||||
| #define OPAMP_OPAMP1Switch5           OPAMP_CSR_S5SEL1 /*!< OPAMP1 Switch 5 */ | ||||
| #define OPAMP_OPAMP1Switch6           OPAMP_CSR_S6SEL1 /*!< OPAMP1 Switch 6 */ | ||||
| #define OPAMP_OPAMP1SwitchANA         OPAMP_CSR_ANAWSEL1 /*!< OPAMP1 Switch ANA */ | ||||
| 
 | ||||
| /* OPAMP2 Switches */ | ||||
| #define OPAMP_OPAMP2Switch3           OPAMP_CSR_S3SEL2 /*!< OPAMP2 Switch 3 */ | ||||
| #define OPAMP_OPAMP2Switch4           OPAMP_CSR_S4SEL2 /*!< OPAMP2 Switch 4 */ | ||||
| #define OPAMP_OPAMP2Switch5           OPAMP_CSR_S5SEL2 /*!< OPAMP2 Switch 5 */ | ||||
| #define OPAMP_OPAMP2Switch6           OPAMP_CSR_S6SEL2 /*!< OPAMP2 Switch 6 */ | ||||
| #define OPAMP_OPAMP2Switch7           OPAMP_CSR_S7SEL2 /*!< OPAMP2 Switch 7 */ | ||||
| #define OPAMP_OPAMP2SwitchANA         OPAMP_CSR_ANAWSEL2 /*!< OPAMP2 Switch ANA */ | ||||
| 
 | ||||
| /* OPAMP3 Switches */ | ||||
| #define OPAMP_OPAMP3Switch3           OPAMP_CSR_S3SEL3 /*!< OPAMP3 Switch 3 */ | ||||
| #define OPAMP_OPAMP3Switch4           OPAMP_CSR_S4SEL3 /*!< OPAMP3 Switch 4 */ | ||||
| #define OPAMP_OPAMP3Switch5           OPAMP_CSR_S5SEL3 /*!< OPAMP3 Switch 5 */ | ||||
| #define OPAMP_OPAMP3Switch6           OPAMP_CSR_S6SEL3 /*!< OPAMP3 Switch 6 */ | ||||
| #define OPAMP_OPAMP3SwitchANA         OPAMP_CSR_ANAWSEL3 /*!< OPAMP3 Switch ANA */ | ||||
| 
 | ||||
| #define IS_OPAMP_SWITCH(SWITCH) ((((SWITCH) & (uint32_t)0xF0E1E1E1) == 0x00) && ((SWITCH) != 0x00)) | ||||
| 
 | ||||
| /**
 | ||||
|   * @} | ||||
|   */  | ||||
| 
 | ||||
| /** @defgroup OPAMP_Trimming
 | ||||
|   * @{ | ||||
|   */ | ||||
| 
 | ||||
| #define OPAMP_Trimming_Factory        ((uint32_t)0x00000000) /*!< Factory trimming */ | ||||
| #define OPAMP_Trimming_User           OPAMP_OTR_OT_USER /*!< User trimming */ | ||||
| 
 | ||||
| #define IS_OPAMP_TRIMMING(TRIMMING) (((TRIMMING) == OPAMP_Trimming_Factory) || \ | ||||
|                                      ((TRIMMING) == OPAMP_Trimming_User)) | ||||
| 
 | ||||
| /**
 | ||||
|   * @} | ||||
|   */  | ||||
| 
 | ||||
| /** @defgroup OPAMP_Input
 | ||||
|   * @{ | ||||
|   */ | ||||
| 
 | ||||
| #define OPAMP_Input_NMOS              OPAMP_CSR_OPA1CAL_H /*!< NMOS input */ | ||||
| #define OPAMP_Input_PMOS              OPAMP_CSR_OPA1CAL_L /*!< PMOS input */ | ||||
| 
 | ||||
| #define IS_OPAMP_INPUT(INPUT) (((INPUT) == OPAMP_Input_NMOS) || \ | ||||
|                                ((INPUT) == OPAMP_Input_PMOS)) | ||||
| 
 | ||||
| /**
 | ||||
|   * @} | ||||
|   */  | ||||
| 
 | ||||
| /** @defgroup OPAMP_TrimValue
 | ||||
|   * @{ | ||||
|   */ | ||||
| 
 | ||||
| #define IS_OPAMP_TRIMMINGVALUE(VALUE) ((VALUE) <= 0x0000001F) /*!< Trimming value */ | ||||
| 
 | ||||
| /**
 | ||||
|   * @} | ||||
|   */ | ||||
| 
 | ||||
| /** @defgroup OPAMP_PowerRange
 | ||||
|   * @{ | ||||
|   */ | ||||
| 
 | ||||
| #define OPAMP_PowerRange_Low          ((uint32_t)0x00000000) /*!< Low power range is selected (VDDA is lower than 2.4V) */ | ||||
| #define OPAMP_PowerRange_High         OPAMP_CSR_AOP_RANGE    /*!< High power range is selected (VDDA is higher than 2.4V) */ | ||||
| 
 | ||||
| #define IS_OPAMP_RANGE(RANGE) (((RANGE) == OPAMP_PowerRange_Low) || \ | ||||
|                                ((RANGE) == OPAMP_PowerRange_High)) | ||||
| 
 | ||||
| /**
 | ||||
|   * @} | ||||
|   */  | ||||
| /**
 | ||||
|   * @} | ||||
|   */ | ||||
| 
 | ||||
| /* Exported macro ------------------------------------------------------------*/ | ||||
| /* Exported functions ------------------------------------------------------- */ | ||||
| /* Initialization and Configuration functions *********************************/ | ||||
| void OPAMP_DeInit(void); | ||||
| void OPAMP_SwitchCmd(uint32_t OPAMP_OPAMPxSwitchy, FunctionalState NewState); | ||||
| void OPAMP_Cmd(uint32_t OPAMP_Selection, FunctionalState NewState); | ||||
| void OPAMP_LowPowerCmd(uint32_t OPAMP_Selection, FunctionalState NewState); | ||||
| void OPAMP_PowerRangeSelect(uint32_t OPAMP_PowerRange); | ||||
| 
 | ||||
| /* Calibration functions ******************************************************/ | ||||
| void OPAMP_OffsetTrimmingModeSelect(uint32_t OPAMP_Trimming); | ||||
| void OPAMP_OffsetTrimConfig(uint32_t OPAMP_Selection, uint32_t OPAMP_Input, uint32_t OPAMP_TrimValue); | ||||
| void OPAMP_OffsetTrimLowPowerConfig(uint32_t OPAMP_Selection, uint32_t OPAMP_Input, uint32_t OPAMP_TrimValue); | ||||
| FlagStatus OPAMP_GetFlagStatus(uint32_t OPAMP_Selection); | ||||
| 
 | ||||
| #ifdef __cplusplus | ||||
| } | ||||
| #endif | ||||
| 
 | ||||
| #endif /*__STM32L1xx_OPAMP_H */ | ||||
| 
 | ||||
| /**
 | ||||
|   * @} | ||||
|   */  | ||||
| 
 | ||||
| /**
 | ||||
|   * @} | ||||
|   */ | ||||
| 
 | ||||
| /************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE****/ | ||||
|  | @ -1,535 +0,0 @@ | |||
| /**
 | ||||
|   ****************************************************************************** | ||||
|   * @file    stm32l1xx_sdio.h | ||||
|   * @author  MCD Application Team | ||||
|   * @version V1.1.1 | ||||
|   * @date    05-March-2012 | ||||
|   * @brief   This file contains all the functions prototypes for the SDIO firmware | ||||
|   *          library. | ||||
|   ****************************************************************************** | ||||
|   * @attention | ||||
|   * | ||||
|   * <h2><center>© COPYRIGHT 2012 STMicroelectronics</center></h2> | ||||
|   * | ||||
|   * Licensed under MCD-ST Liberty SW License Agreement V2, (the "License"); | ||||
|   * You may not use this file except in compliance with the License. | ||||
|   * You may obtain a copy of the License at: | ||||
|   * | ||||
|   *        http://www.st.com/software_license_agreement_liberty_v2
 | ||||
|   * | ||||
|   * Unless required by applicable law or agreed to in writing, software  | ||||
|   * distributed under the License is distributed on an "AS IS" BASIS,  | ||||
|   * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. | ||||
|   * See the License for the specific language governing permissions and | ||||
|   * limitations under the License. | ||||
|   * | ||||
|   ****************************************************************************** | ||||
|   */ | ||||
| 
 | ||||
| /* Define to prevent recursive inclusion -------------------------------------*/ | ||||
| #ifndef __STM32L1xx_SDIO_H | ||||
| #define __STM32L1xx_SDIO_H | ||||
| 
 | ||||
| #ifdef __cplusplus | ||||
|  extern "C" { | ||||
| #endif | ||||
| 
 | ||||
| /* Includes ------------------------------------------------------------------*/ | ||||
| #include "stm32l1xx.h" | ||||
| 
 | ||||
| /** @addtogroup STM32L1xx_StdPeriph_Driver
 | ||||
|   * @{ | ||||
|   */ | ||||
| 
 | ||||
| /** @addtogroup SDIO
 | ||||
|   * @{ | ||||
|   */ | ||||
| 
 | ||||
| /* Exported types ------------------------------------------------------------*/ | ||||
| 
 | ||||
| typedef struct | ||||
| { | ||||
|   uint32_t SDIO_ClockEdge;            /*!< Specifies the clock transition on which the bit capture is made.
 | ||||
|                                            This parameter can be a value of @ref SDIO_Clock_Edge */ | ||||
| 
 | ||||
|   uint32_t SDIO_ClockBypass;          /*!< Specifies whether the SDIO Clock divider bypass is
 | ||||
|                                            enabled or disabled. | ||||
|                                            This parameter can be a value of @ref SDIO_Clock_Bypass */ | ||||
| 
 | ||||
|   uint32_t SDIO_ClockPowerSave;       /*!< Specifies whether SDIO Clock output is enabled or
 | ||||
|                                            disabled when the bus is idle. | ||||
|                                            This parameter can be a value of @ref SDIO_Clock_Power_Save */ | ||||
| 
 | ||||
|   uint32_t SDIO_BusWide;              /*!< Specifies the SDIO bus width.
 | ||||
|                                            This parameter can be a value of @ref SDIO_Bus_Wide */ | ||||
| 
 | ||||
|   uint32_t SDIO_HardwareFlowControl;  /*!< Specifies whether the SDIO hardware flow control is enabled or disabled.
 | ||||
|                                            This parameter can be a value of @ref SDIO_Hardware_Flow_Control */ | ||||
| 
 | ||||
|   uint8_t SDIO_ClockDiv;              /*!< Specifies the clock frequency of the SDIO controller.
 | ||||
|                                            This parameter can be a value between 0x00 and 0xFF. */ | ||||
| 
 | ||||
| } SDIO_InitTypeDef; | ||||
| 
 | ||||
| typedef struct | ||||
| { | ||||
|   uint32_t SDIO_Argument;  /*!< Specifies the SDIO command argument which is sent
 | ||||
|                                 to a card as part of a command message. If a command | ||||
|                                 contains an argument, it must be loaded into this register | ||||
|                                 before writing the command to the command register */ | ||||
| 
 | ||||
|   uint32_t SDIO_CmdIndex;  /*!< Specifies the SDIO command index. It must be lower than 0x40. */ | ||||
| 
 | ||||
|   uint32_t SDIO_Response;  /*!< Specifies the SDIO response type.
 | ||||
|                                 This parameter can be a value of @ref SDIO_Response_Type */ | ||||
| 
 | ||||
|   uint32_t SDIO_Wait;      /*!< Specifies whether SDIO wait-for-interrupt request is enabled or disabled.
 | ||||
|                                 This parameter can be a value of @ref SDIO_Wait_Interrupt_State */ | ||||
| 
 | ||||
|   uint32_t SDIO_CPSM;      /*!< Specifies whether SDIO Command path state machine (CPSM)
 | ||||
|                                 is enabled or disabled. | ||||
|                                 This parameter can be a value of @ref SDIO_CPSM_State */ | ||||
| } SDIO_CmdInitTypeDef; | ||||
| 
 | ||||
| typedef struct | ||||
| { | ||||
|   uint32_t SDIO_DataTimeOut;    /*!< Specifies the data timeout period in card bus clock periods. */ | ||||
| 
 | ||||
|   uint32_t SDIO_DataLength;     /*!< Specifies the number of data bytes to be transferred. */ | ||||
|   | ||||
|   uint32_t SDIO_DataBlockSize;  /*!< Specifies the data block size for block transfer.
 | ||||
|                                      This parameter can be a value of @ref SDIO_Data_Block_Size */ | ||||
|   | ||||
|   uint32_t SDIO_TransferDir;    /*!< Specifies the data transfer direction, whether the transfer
 | ||||
|                                      is a read or write. | ||||
|                                      This parameter can be a value of @ref SDIO_Transfer_Direction */ | ||||
|   | ||||
|   uint32_t SDIO_TransferMode;   /*!< Specifies whether data transfer is in stream or block mode.
 | ||||
|                                      This parameter can be a value of @ref SDIO_Transfer_Type */ | ||||
|   | ||||
|   uint32_t SDIO_DPSM;           /*!< Specifies whether SDIO Data path state machine (DPSM)
 | ||||
|                                      is enabled or disabled. | ||||
|                                      This parameter can be a value of @ref SDIO_DPSM_State */ | ||||
| } SDIO_DataInitTypeDef; | ||||
| 
 | ||||
| /* Exported constants --------------------------------------------------------*/ | ||||
| 
 | ||||
| /** @defgroup SDIO_Exported_Constants
 | ||||
|   * @{ | ||||
|   */ | ||||
| 
 | ||||
| /** @defgroup SDIO_Clock_Edge 
 | ||||
|   * @{ | ||||
|   */ | ||||
| 
 | ||||
| #define SDIO_ClockEdge_Rising               ((uint32_t)0x00000000) | ||||
| #define SDIO_ClockEdge_Falling              ((uint32_t)0x00002000) | ||||
| #define IS_SDIO_CLOCK_EDGE(EDGE) (((EDGE) == SDIO_ClockEdge_Rising) || \ | ||||
|                                   ((EDGE) == SDIO_ClockEdge_Falling)) | ||||
| /**
 | ||||
|   * @} | ||||
|   */ | ||||
| 
 | ||||
| /** @defgroup SDIO_Clock_Bypass 
 | ||||
|   * @{ | ||||
|   */ | ||||
| 
 | ||||
| #define SDIO_ClockBypass_Disable             ((uint32_t)0x00000000) | ||||
| #define SDIO_ClockBypass_Enable              ((uint32_t)0x00000400)     | ||||
| #define IS_SDIO_CLOCK_BYPASS(BYPASS) (((BYPASS) == SDIO_ClockBypass_Disable) || \ | ||||
|                                      ((BYPASS) == SDIO_ClockBypass_Enable)) | ||||
| /**
 | ||||
|   * @} | ||||
|   */  | ||||
| 
 | ||||
| /** @defgroup SDIO_Clock_Power_Save 
 | ||||
|   * @{ | ||||
|   */ | ||||
| 
 | ||||
| #define SDIO_ClockPowerSave_Disable         ((uint32_t)0x00000000) | ||||
| #define SDIO_ClockPowerSave_Enable          ((uint32_t)0x00000200)  | ||||
| #define IS_SDIO_CLOCK_POWER_SAVE(SAVE) (((SAVE) == SDIO_ClockPowerSave_Disable) || \ | ||||
|                                         ((SAVE) == SDIO_ClockPowerSave_Enable)) | ||||
| /**
 | ||||
|   * @} | ||||
|   */ | ||||
| 
 | ||||
| /** @defgroup SDIO_Bus_Wide 
 | ||||
|   * @{ | ||||
|   */ | ||||
| 
 | ||||
| #define SDIO_BusWide_1b                     ((uint32_t)0x00000000) | ||||
| #define SDIO_BusWide_4b                     ((uint32_t)0x00000800) | ||||
| #define SDIO_BusWide_8b                     ((uint32_t)0x00001000) | ||||
| #define IS_SDIO_BUS_WIDE(WIDE) (((WIDE) == SDIO_BusWide_1b) || ((WIDE) == SDIO_BusWide_4b) || \ | ||||
|                                 ((WIDE) == SDIO_BusWide_8b)) | ||||
| 
 | ||||
| /**
 | ||||
|   * @} | ||||
|   */ | ||||
| 
 | ||||
| /** @defgroup SDIO_Hardware_Flow_Control 
 | ||||
|   * @{ | ||||
|   */ | ||||
| 
 | ||||
| #define SDIO_HardwareFlowControl_Disable    ((uint32_t)0x00000000) | ||||
| #define SDIO_HardwareFlowControl_Enable     ((uint32_t)0x00004000) | ||||
| #define IS_SDIO_HARDWARE_FLOW_CONTROL(CONTROL) (((CONTROL) == SDIO_HardwareFlowControl_Disable) || \ | ||||
|                                                 ((CONTROL) == SDIO_HardwareFlowControl_Enable)) | ||||
| /**
 | ||||
|   * @} | ||||
|   */ | ||||
| 
 | ||||
| /** @defgroup SDIO_Power_State 
 | ||||
|   * @{ | ||||
|   */ | ||||
| 
 | ||||
| #define SDIO_PowerState_OFF                 ((uint32_t)0x00000000) | ||||
| #define SDIO_PowerState_ON                  ((uint32_t)0x00000003) | ||||
| #define IS_SDIO_POWER_STATE(STATE) (((STATE) == SDIO_PowerState_OFF) || ((STATE) == SDIO_PowerState_ON))  | ||||
| /**
 | ||||
|   * @} | ||||
|   */  | ||||
| 
 | ||||
| 
 | ||||
| /** @defgroup SDIO_Interrupt_soucres 
 | ||||
|   * @{ | ||||
|   */ | ||||
| 
 | ||||
| #define SDIO_IT_CCRCFAIL                    ((uint32_t)0x00000001) | ||||
| #define SDIO_IT_DCRCFAIL                    ((uint32_t)0x00000002) | ||||
| #define SDIO_IT_CTIMEOUT                    ((uint32_t)0x00000004) | ||||
| #define SDIO_IT_DTIMEOUT                    ((uint32_t)0x00000008) | ||||
| #define SDIO_IT_TXUNDERR                    ((uint32_t)0x00000010) | ||||
| #define SDIO_IT_RXOVERR                     ((uint32_t)0x00000020) | ||||
| #define SDIO_IT_CMDREND                     ((uint32_t)0x00000040) | ||||
| #define SDIO_IT_CMDSENT                     ((uint32_t)0x00000080) | ||||
| #define SDIO_IT_DATAEND                     ((uint32_t)0x00000100) | ||||
| #define SDIO_IT_STBITERR                    ((uint32_t)0x00000200) | ||||
| #define SDIO_IT_DBCKEND                     ((uint32_t)0x00000400) | ||||
| #define SDIO_IT_CMDACT                      ((uint32_t)0x00000800) | ||||
| #define SDIO_IT_TXACT                       ((uint32_t)0x00001000) | ||||
| #define SDIO_IT_RXACT                       ((uint32_t)0x00002000) | ||||
| #define SDIO_IT_TXFIFOHE                    ((uint32_t)0x00004000) | ||||
| #define SDIO_IT_RXFIFOHF                    ((uint32_t)0x00008000) | ||||
| #define SDIO_IT_TXFIFOF                     ((uint32_t)0x00010000) | ||||
| #define SDIO_IT_RXFIFOF                     ((uint32_t)0x00020000) | ||||
| #define SDIO_IT_TXFIFOE                     ((uint32_t)0x00040000) | ||||
| #define SDIO_IT_RXFIFOE                     ((uint32_t)0x00080000) | ||||
| #define SDIO_IT_TXDAVL                      ((uint32_t)0x00100000) | ||||
| #define SDIO_IT_RXDAVL                      ((uint32_t)0x00200000) | ||||
| #define SDIO_IT_SDIOIT                      ((uint32_t)0x00400000) | ||||
| #define SDIO_IT_CEATAEND                    ((uint32_t)0x00800000) | ||||
| #define IS_SDIO_IT(IT) ((((IT) & (uint32_t)0xFF000000) == 0x00) && ((IT) != (uint32_t)0x00)) | ||||
| /**
 | ||||
|   * @} | ||||
|   */  | ||||
| 
 | ||||
| /** @defgroup SDIO_Command_Index
 | ||||
|   * @{ | ||||
|   */ | ||||
| 
 | ||||
| #define IS_SDIO_CMD_INDEX(INDEX)            ((INDEX) < 0x40) | ||||
| /**
 | ||||
|   * @} | ||||
|   */ | ||||
| 
 | ||||
| /** @defgroup SDIO_Response_Type 
 | ||||
|   * @{ | ||||
|   */ | ||||
| 
 | ||||
| #define SDIO_Response_No                    ((uint32_t)0x00000000) | ||||
| #define SDIO_Response_Short                 ((uint32_t)0x00000040) | ||||
| #define SDIO_Response_Long                  ((uint32_t)0x000000C0) | ||||
| #define IS_SDIO_RESPONSE(RESPONSE) (((RESPONSE) == SDIO_Response_No) || \ | ||||
|                                     ((RESPONSE) == SDIO_Response_Short) || \ | ||||
|                                     ((RESPONSE) == SDIO_Response_Long)) | ||||
| /**
 | ||||
|   * @} | ||||
|   */ | ||||
| 
 | ||||
| /** @defgroup SDIO_Wait_Interrupt_State 
 | ||||
|   * @{ | ||||
|   */ | ||||
| 
 | ||||
| #define SDIO_Wait_No                        ((uint32_t)0x00000000) /*!< SDIO No Wait, TimeOut is enabled */ | ||||
| #define SDIO_Wait_IT                        ((uint32_t)0x00000100) /*!< SDIO Wait Interrupt Request */ | ||||
| #define SDIO_Wait_Pend                      ((uint32_t)0x00000200) /*!< SDIO Wait End of transfer */ | ||||
| #define IS_SDIO_WAIT(WAIT) (((WAIT) == SDIO_Wait_No) || ((WAIT) == SDIO_Wait_IT) || \ | ||||
|                             ((WAIT) == SDIO_Wait_Pend)) | ||||
| /**
 | ||||
|   * @} | ||||
|   */ | ||||
| 
 | ||||
| /** @defgroup SDIO_CPSM_State 
 | ||||
|   * @{ | ||||
|   */ | ||||
| 
 | ||||
| #define SDIO_CPSM_Disable                    ((uint32_t)0x00000000) | ||||
| #define SDIO_CPSM_Enable                     ((uint32_t)0x00000400) | ||||
| #define IS_SDIO_CPSM(CPSM) (((CPSM) == SDIO_CPSM_Enable) || ((CPSM) == SDIO_CPSM_Disable)) | ||||
| /**
 | ||||
|   * @} | ||||
|   */  | ||||
| 
 | ||||
| /** @defgroup SDIO_Response_Registers 
 | ||||
|   * @{ | ||||
|   */ | ||||
| 
 | ||||
| #define SDIO_RESP1                          ((uint32_t)0x00000000) | ||||
| #define SDIO_RESP2                          ((uint32_t)0x00000004) | ||||
| #define SDIO_RESP3                          ((uint32_t)0x00000008) | ||||
| #define SDIO_RESP4                          ((uint32_t)0x0000000C) | ||||
| #define IS_SDIO_RESP(RESP) (((RESP) == SDIO_RESP1) || ((RESP) == SDIO_RESP2) || \ | ||||
|                             ((RESP) == SDIO_RESP3) || ((RESP) == SDIO_RESP4)) | ||||
| /**
 | ||||
|   * @} | ||||
|   */ | ||||
| 
 | ||||
| /** @defgroup SDIO_Data_Length 
 | ||||
|   * @{ | ||||
|   */ | ||||
| 
 | ||||
| #define IS_SDIO_DATA_LENGTH(LENGTH) ((LENGTH) <= 0x01FFFFFF) | ||||
| /**
 | ||||
|   * @} | ||||
|   */ | ||||
| 
 | ||||
| /** @defgroup SDIO_Data_Block_Size 
 | ||||
|   * @{ | ||||
|   */ | ||||
| 
 | ||||
| #define SDIO_DataBlockSize_1b               ((uint32_t)0x00000000) | ||||
| #define SDIO_DataBlockSize_2b               ((uint32_t)0x00000010) | ||||
| #define SDIO_DataBlockSize_4b               ((uint32_t)0x00000020) | ||||
| #define SDIO_DataBlockSize_8b               ((uint32_t)0x00000030) | ||||
| #define SDIO_DataBlockSize_16b              ((uint32_t)0x00000040) | ||||
| #define SDIO_DataBlockSize_32b              ((uint32_t)0x00000050) | ||||
| #define SDIO_DataBlockSize_64b              ((uint32_t)0x00000060) | ||||
| #define SDIO_DataBlockSize_128b             ((uint32_t)0x00000070) | ||||
| #define SDIO_DataBlockSize_256b             ((uint32_t)0x00000080) | ||||
| #define SDIO_DataBlockSize_512b             ((uint32_t)0x00000090) | ||||
| #define SDIO_DataBlockSize_1024b            ((uint32_t)0x000000A0) | ||||
| #define SDIO_DataBlockSize_2048b            ((uint32_t)0x000000B0) | ||||
| #define SDIO_DataBlockSize_4096b            ((uint32_t)0x000000C0) | ||||
| #define SDIO_DataBlockSize_8192b            ((uint32_t)0x000000D0) | ||||
| #define SDIO_DataBlockSize_16384b           ((uint32_t)0x000000E0) | ||||
| #define IS_SDIO_BLOCK_SIZE(SIZE) (((SIZE) == SDIO_DataBlockSize_1b) || \ | ||||
|                                   ((SIZE) == SDIO_DataBlockSize_2b) || \ | ||||
|                                   ((SIZE) == SDIO_DataBlockSize_4b) || \ | ||||
|                                   ((SIZE) == SDIO_DataBlockSize_8b) || \ | ||||
|                                   ((SIZE) == SDIO_DataBlockSize_16b) || \ | ||||
|                                   ((SIZE) == SDIO_DataBlockSize_32b) || \ | ||||
|                                   ((SIZE) == SDIO_DataBlockSize_64b) || \ | ||||
|                                   ((SIZE) == SDIO_DataBlockSize_128b) || \ | ||||
|                                   ((SIZE) == SDIO_DataBlockSize_256b) || \ | ||||
|                                   ((SIZE) == SDIO_DataBlockSize_512b) || \ | ||||
|                                   ((SIZE) == SDIO_DataBlockSize_1024b) || \ | ||||
|                                   ((SIZE) == SDIO_DataBlockSize_2048b) || \ | ||||
|                                   ((SIZE) == SDIO_DataBlockSize_4096b) || \ | ||||
|                                   ((SIZE) == SDIO_DataBlockSize_8192b) || \ | ||||
|                                   ((SIZE) == SDIO_DataBlockSize_16384b))  | ||||
| /**
 | ||||
|   * @} | ||||
|   */ | ||||
| 
 | ||||
| /** @defgroup SDIO_Transfer_Direction 
 | ||||
|   * @{ | ||||
|   */ | ||||
| 
 | ||||
| #define SDIO_TransferDir_ToCard             ((uint32_t)0x00000000) | ||||
| #define SDIO_TransferDir_ToSDIO             ((uint32_t)0x00000002) | ||||
| #define IS_SDIO_TRANSFER_DIR(DIR) (((DIR) == SDIO_TransferDir_ToCard) || \ | ||||
|                                    ((DIR) == SDIO_TransferDir_ToSDIO)) | ||||
| /**
 | ||||
|   * @} | ||||
|   */ | ||||
| 
 | ||||
| /** @defgroup SDIO_Transfer_Type 
 | ||||
|   * @{ | ||||
|   */ | ||||
| 
 | ||||
| #define SDIO_TransferMode_Block             ((uint32_t)0x00000000) | ||||
| #define SDIO_TransferMode_Stream            ((uint32_t)0x00000004) | ||||
| #define IS_SDIO_TRANSFER_MODE(MODE) (((MODE) == SDIO_TransferMode_Stream) || \ | ||||
|                                      ((MODE) == SDIO_TransferMode_Block)) | ||||
| /**
 | ||||
|   * @} | ||||
|   */ | ||||
| 
 | ||||
| /** @defgroup SDIO_DPSM_State 
 | ||||
|   * @{ | ||||
|   */ | ||||
| 
 | ||||
| #define SDIO_DPSM_Disable                    ((uint32_t)0x00000000) | ||||
| #define SDIO_DPSM_Enable                     ((uint32_t)0x00000001) | ||||
| #define IS_SDIO_DPSM(DPSM) (((DPSM) == SDIO_DPSM_Enable) || ((DPSM) == SDIO_DPSM_Disable)) | ||||
| /**
 | ||||
|   * @} | ||||
|   */ | ||||
| 
 | ||||
| /** @defgroup SDIO_Flags 
 | ||||
|   * @{ | ||||
|   */ | ||||
| 
 | ||||
| #define SDIO_FLAG_CCRCFAIL                  ((uint32_t)0x00000001) | ||||
| #define SDIO_FLAG_DCRCFAIL                  ((uint32_t)0x00000002) | ||||
| #define SDIO_FLAG_CTIMEOUT                  ((uint32_t)0x00000004) | ||||
| #define SDIO_FLAG_DTIMEOUT                  ((uint32_t)0x00000008) | ||||
| #define SDIO_FLAG_TXUNDERR                  ((uint32_t)0x00000010) | ||||
| #define SDIO_FLAG_RXOVERR                   ((uint32_t)0x00000020) | ||||
| #define SDIO_FLAG_CMDREND                   ((uint32_t)0x00000040) | ||||
| #define SDIO_FLAG_CMDSENT                   ((uint32_t)0x00000080) | ||||
| #define SDIO_FLAG_DATAEND                   ((uint32_t)0x00000100) | ||||
| #define SDIO_FLAG_STBITERR                  ((uint32_t)0x00000200) | ||||
| #define SDIO_FLAG_DBCKEND                   ((uint32_t)0x00000400) | ||||
| #define SDIO_FLAG_CMDACT                    ((uint32_t)0x00000800) | ||||
| #define SDIO_FLAG_TXACT                     ((uint32_t)0x00001000) | ||||
| #define SDIO_FLAG_RXACT                     ((uint32_t)0x00002000) | ||||
| #define SDIO_FLAG_TXFIFOHE                  ((uint32_t)0x00004000) | ||||
| #define SDIO_FLAG_RXFIFOHF                  ((uint32_t)0x00008000) | ||||
| #define SDIO_FLAG_TXFIFOF                   ((uint32_t)0x00010000) | ||||
| #define SDIO_FLAG_RXFIFOF                   ((uint32_t)0x00020000) | ||||
| #define SDIO_FLAG_TXFIFOE                   ((uint32_t)0x00040000) | ||||
| #define SDIO_FLAG_RXFIFOE                   ((uint32_t)0x00080000) | ||||
| #define SDIO_FLAG_TXDAVL                    ((uint32_t)0x00100000) | ||||
| #define SDIO_FLAG_RXDAVL                    ((uint32_t)0x00200000) | ||||
| #define SDIO_FLAG_SDIOIT                    ((uint32_t)0x00400000) | ||||
| #define SDIO_FLAG_CEATAEND                  ((uint32_t)0x00800000) | ||||
| #define IS_SDIO_FLAG(FLAG) (((FLAG)  == SDIO_FLAG_CCRCFAIL) || \ | ||||
|                             ((FLAG)  == SDIO_FLAG_DCRCFAIL) || \ | ||||
|                             ((FLAG)  == SDIO_FLAG_CTIMEOUT) || \ | ||||
|                             ((FLAG)  == SDIO_FLAG_DTIMEOUT) || \ | ||||
|                             ((FLAG)  == SDIO_FLAG_TXUNDERR) || \ | ||||
|                             ((FLAG)  == SDIO_FLAG_RXOVERR) || \ | ||||
|                             ((FLAG)  == SDIO_FLAG_CMDREND) || \ | ||||
|                             ((FLAG)  == SDIO_FLAG_CMDSENT) || \ | ||||
|                             ((FLAG)  == SDIO_FLAG_DATAEND) || \ | ||||
|                             ((FLAG)  == SDIO_FLAG_STBITERR) || \ | ||||
|                             ((FLAG)  == SDIO_FLAG_DBCKEND) || \ | ||||
|                             ((FLAG)  == SDIO_FLAG_CMDACT) || \ | ||||
|                             ((FLAG)  == SDIO_FLAG_TXACT) || \ | ||||
|                             ((FLAG)  == SDIO_FLAG_RXACT) || \ | ||||
|                             ((FLAG)  == SDIO_FLAG_TXFIFOHE) || \ | ||||
|                             ((FLAG)  == SDIO_FLAG_RXFIFOHF) || \ | ||||
|                             ((FLAG)  == SDIO_FLAG_TXFIFOF) || \ | ||||
|                             ((FLAG)  == SDIO_FLAG_RXFIFOF) || \ | ||||
|                             ((FLAG)  == SDIO_FLAG_TXFIFOE) || \ | ||||
|                             ((FLAG)  == SDIO_FLAG_RXFIFOE) || \ | ||||
|                             ((FLAG)  == SDIO_FLAG_TXDAVL) || \ | ||||
|                             ((FLAG)  == SDIO_FLAG_RXDAVL) || \ | ||||
|                             ((FLAG)  == SDIO_FLAG_SDIOIT) || \ | ||||
|                             ((FLAG)  == SDIO_FLAG_CEATAEND)) | ||||
| 
 | ||||
| #define IS_SDIO_CLEAR_FLAG(FLAG) ((((FLAG) & (uint32_t)0xFF3FF800) == 0x00) && ((FLAG) != (uint32_t)0x00)) | ||||
| 
 | ||||
| #define IS_SDIO_GET_IT(IT) (((IT)  == SDIO_IT_CCRCFAIL) || \ | ||||
|                             ((IT)  == SDIO_IT_DCRCFAIL) || \ | ||||
|                             ((IT)  == SDIO_IT_CTIMEOUT) || \ | ||||
|                             ((IT)  == SDIO_IT_DTIMEOUT) || \ | ||||
|                             ((IT)  == SDIO_IT_TXUNDERR) || \ | ||||
|                             ((IT)  == SDIO_IT_RXOVERR) || \ | ||||
|                             ((IT)  == SDIO_IT_CMDREND) || \ | ||||
|                             ((IT)  == SDIO_IT_CMDSENT) || \ | ||||
|                             ((IT)  == SDIO_IT_DATAEND) || \ | ||||
|                             ((IT)  == SDIO_IT_STBITERR) || \ | ||||
|                             ((IT)  == SDIO_IT_DBCKEND) || \ | ||||
|                             ((IT)  == SDIO_IT_CMDACT) || \ | ||||
|                             ((IT)  == SDIO_IT_TXACT) || \ | ||||
|                             ((IT)  == SDIO_IT_RXACT) || \ | ||||
|                             ((IT)  == SDIO_IT_TXFIFOHE) || \ | ||||
|                             ((IT)  == SDIO_IT_RXFIFOHF) || \ | ||||
|                             ((IT)  == SDIO_IT_TXFIFOF) || \ | ||||
|                             ((IT)  == SDIO_IT_RXFIFOF) || \ | ||||
|                             ((IT)  == SDIO_IT_TXFIFOE) || \ | ||||
|                             ((IT)  == SDIO_IT_RXFIFOE) || \ | ||||
|                             ((IT)  == SDIO_IT_TXDAVL) || \ | ||||
|                             ((IT)  == SDIO_IT_RXDAVL) || \ | ||||
|                             ((IT)  == SDIO_IT_SDIOIT) || \ | ||||
|                             ((IT)  == SDIO_IT_CEATAEND)) | ||||
| 
 | ||||
| #define IS_SDIO_CLEAR_IT(IT) ((((IT) & (uint32_t)0xFF3FF800) == 0x00) && ((IT) != (uint32_t)0x00)) | ||||
| 
 | ||||
| /**
 | ||||
|   * @} | ||||
|   */ | ||||
| 
 | ||||
| /** @defgroup SDIO_Read_Wait_Mode 
 | ||||
|   * @{ | ||||
|   */ | ||||
| 
 | ||||
| #define SDIO_ReadWaitMode_CLK               ((uint32_t)0x00000001) | ||||
| #define SDIO_ReadWaitMode_DATA2             ((uint32_t)0x00000000) | ||||
| #define IS_SDIO_READWAIT_MODE(MODE) (((MODE) == SDIO_ReadWaitMode_CLK) || \ | ||||
|                                      ((MODE) == SDIO_ReadWaitMode_DATA2)) | ||||
| /**
 | ||||
|   * @} | ||||
|   */ | ||||
| 
 | ||||
| /**
 | ||||
|   * @} | ||||
|   */ | ||||
| 
 | ||||
| /* Exported macro ------------------------------------------------------------*/ | ||||
| /* Exported functions ------------------------------------------------------- */  | ||||
| /*  Function used to set the SDIO configuration to the default reset state ****/ | ||||
| void SDIO_DeInit(void); | ||||
| 
 | ||||
| /* Initialization and Configuration functions *********************************/ | ||||
| void SDIO_Init(SDIO_InitTypeDef* SDIO_InitStruct); | ||||
| void SDIO_StructInit(SDIO_InitTypeDef* SDIO_InitStruct); | ||||
| void SDIO_ClockCmd(FunctionalState NewState); | ||||
| void SDIO_SetPowerState(uint32_t SDIO_PowerState); | ||||
| uint32_t SDIO_GetPowerState(void); | ||||
| 
 | ||||
| /* DMA transfers management functions *****************************************/ | ||||
| void SDIO_DMACmd(FunctionalState NewState); | ||||
| 
 | ||||
| /* Command path state machine (CPSM) management functions *********************/ | ||||
| void SDIO_SendCommand(SDIO_CmdInitTypeDef *SDIO_CmdInitStruct); | ||||
| void SDIO_CmdStructInit(SDIO_CmdInitTypeDef* SDIO_CmdInitStruct); | ||||
| uint8_t SDIO_GetCommandResponse(void); | ||||
| uint32_t SDIO_GetResponse(uint32_t SDIO_RESP); | ||||
| 
 | ||||
| /* Data path state machine (DPSM) management functions ************************/ | ||||
| void SDIO_DataConfig(SDIO_DataInitTypeDef* SDIO_DataInitStruct); | ||||
| void SDIO_DataStructInit(SDIO_DataInitTypeDef* SDIO_DataInitStruct); | ||||
| uint32_t SDIO_GetDataCounter(void); | ||||
| uint32_t SDIO_ReadData(void); | ||||
| void SDIO_WriteData(uint32_t Data); | ||||
| uint32_t SDIO_GetFIFOCount(void); | ||||
| 
 | ||||
| /* SDIO IO Cards mode management functions ************************************/ | ||||
| void SDIO_StartSDIOReadWait(FunctionalState NewState); | ||||
| void SDIO_StopSDIOReadWait(FunctionalState NewState); | ||||
| void SDIO_SetSDIOReadWaitMode(uint32_t SDIO_ReadWaitMode); | ||||
| void SDIO_SetSDIOOperation(FunctionalState NewState); | ||||
| void SDIO_SendSDIOSuspendCmd(FunctionalState NewState); | ||||
| 
 | ||||
| /* CE-ATA mode management functions *******************************************/ | ||||
| void SDIO_CommandCompletionCmd(FunctionalState NewState); | ||||
| void SDIO_CEATAITCmd(FunctionalState NewState); | ||||
| void SDIO_SendCEATACmd(FunctionalState NewState); | ||||
| 
 | ||||
| /* Interrupts and flags management functions **********************************/ | ||||
| void SDIO_ITConfig(uint32_t SDIO_IT, FunctionalState NewState); | ||||
| FlagStatus SDIO_GetFlagStatus(uint32_t SDIO_FLAG); | ||||
| void SDIO_ClearFlag(uint32_t SDIO_FLAG); | ||||
| ITStatus SDIO_GetITStatus(uint32_t SDIO_IT); | ||||
| void SDIO_ClearITPendingBit(uint32_t SDIO_IT); | ||||
| 
 | ||||
| #ifdef __cplusplus | ||||
| } | ||||
| #endif | ||||
| 
 | ||||
| #endif /* __STM32L1xx_SDIO_H */ | ||||
| 
 | ||||
| /**
 | ||||
|   * @} | ||||
|   */ | ||||
| 
 | ||||
| /**
 | ||||
|   * @} | ||||
|   */ | ||||
| 
 | ||||
| /************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE****/ | ||||
|  | @ -1,524 +0,0 @@ | |||
| /**
 | ||||
|   ****************************************************************************** | ||||
|   * @file    stm32l1xx_spi.h | ||||
|   * @author  MCD Application Team | ||||
|   * @version V1.1.1 | ||||
|   * @date    05-March-2012 | ||||
|   * @brief   This file contains all the functions prototypes for the SPI  | ||||
|   *          firmware library. | ||||
|   ****************************************************************************** | ||||
|   * @attention | ||||
|   * | ||||
|   * <h2><center>© COPYRIGHT 2012 STMicroelectronics</center></h2> | ||||
|   * | ||||
|   * Licensed under MCD-ST Liberty SW License Agreement V2, (the "License"); | ||||
|   * You may not use this file except in compliance with the License. | ||||
|   * You may obtain a copy of the License at: | ||||
|   * | ||||
|   *        http://www.st.com/software_license_agreement_liberty_v2
 | ||||
|   * | ||||
|   * Unless required by applicable law or agreed to in writing, software  | ||||
|   * distributed under the License is distributed on an "AS IS" BASIS,  | ||||
|   * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. | ||||
|   * See the License for the specific language governing permissions and | ||||
|   * limitations under the License. | ||||
|   * | ||||
|   ****************************************************************************** | ||||
|   */ | ||||
| 
 | ||||
| /* Define to prevent recursive inclusion -------------------------------------*/ | ||||
| #ifndef __STM32L1xx_SPI_H | ||||
| #define __STM32L1xx_SPI_H | ||||
| 
 | ||||
| #ifdef __cplusplus | ||||
|  extern "C" { | ||||
| #endif | ||||
| 
 | ||||
| /* Includes ------------------------------------------------------------------*/ | ||||
| #include "stm32l1xx.h" | ||||
| 
 | ||||
| /** @addtogroup STM32L1xx_StdPeriph_Driver
 | ||||
|   * @{ | ||||
|   */ | ||||
| 
 | ||||
| /** @addtogroup SPI
 | ||||
|   * @{ | ||||
|   */  | ||||
| 
 | ||||
| /* Exported types ------------------------------------------------------------*/ | ||||
| 
 | ||||
| /** 
 | ||||
|   * @brief  SPI Init structure definition   | ||||
|   */ | ||||
| 
 | ||||
| typedef struct | ||||
| { | ||||
|   uint16_t SPI_Direction;           /*!< Specifies the SPI unidirectional or bidirectional data mode.
 | ||||
|                                          This parameter can be a value of @ref SPI_data_direction */ | ||||
| 
 | ||||
|   uint16_t SPI_Mode;                /*!< Specifies the SPI operating mode.
 | ||||
|                                          This parameter can be a value of @ref SPI_mode */ | ||||
| 
 | ||||
|   uint16_t SPI_DataSize;            /*!< Specifies the SPI data size.
 | ||||
|                                          This parameter can be a value of @ref SPI_data_size */ | ||||
| 
 | ||||
|   uint16_t SPI_CPOL;                /*!< Specifies the serial clock steady state.
 | ||||
|                                          This parameter can be a value of @ref SPI_Clock_Polarity */ | ||||
| 
 | ||||
|   uint16_t SPI_CPHA;                /*!< Specifies the clock active edge for the bit capture.
 | ||||
|                                          This parameter can be a value of @ref SPI_Clock_Phase */ | ||||
| 
 | ||||
|   uint16_t SPI_NSS;                 /*!< Specifies whether the NSS signal is managed by
 | ||||
|                                          hardware (NSS pin) or by software using the SSI bit. | ||||
|                                          This parameter can be a value of @ref SPI_Slave_Select_management */ | ||||
|   | ||||
|   uint16_t SPI_BaudRatePrescaler;   /*!< Specifies the Baud Rate prescaler value which will be
 | ||||
|                                          used to configure the transmit and receive SCK clock. | ||||
|                                          This parameter can be a value of @ref SPI_BaudRate_Prescaler | ||||
|                                          @note The communication clock is derived from the master | ||||
|                                                clock. The slave clock does not need to be set. */ | ||||
| 
 | ||||
|   uint16_t SPI_FirstBit;            /*!< Specifies whether data transfers start from MSB or LSB bit.
 | ||||
|                                          This parameter can be a value of @ref SPI_MSB_LSB_transmission */ | ||||
| 
 | ||||
|   uint16_t SPI_CRCPolynomial;       /*!< Specifies the polynomial used for the CRC calculation. */ | ||||
| }SPI_InitTypeDef; | ||||
| 
 | ||||
| /** 
 | ||||
|   * @brief  I2S Init structure definition   | ||||
|   */ | ||||
| 
 | ||||
| typedef struct | ||||
| { | ||||
| 
 | ||||
|   uint16_t I2S_Mode;         /*!< Specifies the I2S operating mode.
 | ||||
|                                   This parameter can be a value of @ref SPI_I2S_Mode */ | ||||
| 
 | ||||
|   uint16_t I2S_Standard;     /*!< Specifies the standard used for the I2S communication.
 | ||||
|                                   This parameter can be a value of @ref SPI_I2S_Standard */ | ||||
| 
 | ||||
|   uint16_t I2S_DataFormat;   /*!< Specifies the data format for the I2S communication.
 | ||||
|                                   This parameter can be a value of @ref SPI_I2S_Data_Format */ | ||||
| 
 | ||||
|   uint16_t I2S_MCLKOutput;   /*!< Specifies whether the I2S MCLK output is enabled or not.
 | ||||
|                                   This parameter can be a value of @ref SPI_I2S_MCLK_Output */ | ||||
| 
 | ||||
|   uint32_t I2S_AudioFreq;    /*!< Specifies the frequency selected for the I2S communication.
 | ||||
|                                   This parameter can be a value of @ref SPI_I2S_Audio_Frequency */ | ||||
| 
 | ||||
|   uint16_t I2S_CPOL;         /*!< Specifies the idle state of the I2S clock.
 | ||||
|                                   This parameter can be a value of @ref SPI_I2S_Clock_Polarity */ | ||||
| }I2S_InitTypeDef; | ||||
| 
 | ||||
| /* Exported constants --------------------------------------------------------*/ | ||||
| 
 | ||||
| /** @defgroup SPI_Exported_Constants
 | ||||
|   * @{ | ||||
|   */ | ||||
| 
 | ||||
| #define IS_SPI_ALL_PERIPH(PERIPH) (((PERIPH) == SPI1) || \ | ||||
|                                    ((PERIPH) == SPI2) || \ | ||||
|                                    ((PERIPH) == SPI3)) | ||||
| #define IS_SPI_23_PERIPH(PERIPH)  (((PERIPH) == SPI2) || \ | ||||
|                                    ((PERIPH) == SPI3)) | ||||
| 
 | ||||
| /** @defgroup SPI_data_direction 
 | ||||
|   * @{ | ||||
|   */ | ||||
|    | ||||
| #define SPI_Direction_2Lines_FullDuplex ((uint16_t)0x0000) | ||||
| #define SPI_Direction_2Lines_RxOnly     ((uint16_t)0x0400) | ||||
| #define SPI_Direction_1Line_Rx          ((uint16_t)0x8000) | ||||
| #define SPI_Direction_1Line_Tx          ((uint16_t)0xC000) | ||||
| #define IS_SPI_DIRECTION_MODE(MODE) (((MODE) == SPI_Direction_2Lines_FullDuplex) || \ | ||||
|                                      ((MODE) == SPI_Direction_2Lines_RxOnly) || \ | ||||
|                                      ((MODE) == SPI_Direction_1Line_Rx) || \ | ||||
|                                      ((MODE) == SPI_Direction_1Line_Tx)) | ||||
| /**
 | ||||
|   * @} | ||||
|   */ | ||||
| 
 | ||||
| /** @defgroup SPI_mode 
 | ||||
|   * @{ | ||||
|   */ | ||||
| 
 | ||||
| #define SPI_Mode_Master                 ((uint16_t)0x0104) | ||||
| #define SPI_Mode_Slave                  ((uint16_t)0x0000) | ||||
| #define IS_SPI_MODE(MODE) (((MODE) == SPI_Mode_Master) || \ | ||||
|                            ((MODE) == SPI_Mode_Slave)) | ||||
| /**
 | ||||
|   * @} | ||||
|   */ | ||||
| 
 | ||||
| /** @defgroup SPI_data_size 
 | ||||
|   * @{ | ||||
|   */ | ||||
| 
 | ||||
| #define SPI_DataSize_16b                ((uint16_t)0x0800) | ||||
| #define SPI_DataSize_8b                 ((uint16_t)0x0000) | ||||
| #define IS_SPI_DATASIZE(DATASIZE) (((DATASIZE) == SPI_DataSize_16b) || \ | ||||
|                                    ((DATASIZE) == SPI_DataSize_8b)) | ||||
| /**
 | ||||
|   * @} | ||||
|   */  | ||||
| 
 | ||||
| /** @defgroup SPI_Clock_Polarity 
 | ||||
|   * @{ | ||||
|   */ | ||||
| 
 | ||||
| #define SPI_CPOL_Low                    ((uint16_t)0x0000) | ||||
| #define SPI_CPOL_High                   ((uint16_t)0x0002) | ||||
| #define IS_SPI_CPOL(CPOL) (((CPOL) == SPI_CPOL_Low) || \ | ||||
|                            ((CPOL) == SPI_CPOL_High)) | ||||
| /**
 | ||||
|   * @} | ||||
|   */ | ||||
| 
 | ||||
| /** @defgroup SPI_Clock_Phase 
 | ||||
|   * @{ | ||||
|   */ | ||||
| 
 | ||||
| #define SPI_CPHA_1Edge                  ((uint16_t)0x0000) | ||||
| #define SPI_CPHA_2Edge                  ((uint16_t)0x0001) | ||||
| #define IS_SPI_CPHA(CPHA) (((CPHA) == SPI_CPHA_1Edge) || \ | ||||
|                            ((CPHA) == SPI_CPHA_2Edge)) | ||||
| /**
 | ||||
|   * @} | ||||
|   */ | ||||
| 
 | ||||
| /** @defgroup SPI_Slave_Select_management 
 | ||||
|   * @{ | ||||
|   */ | ||||
| 
 | ||||
| #define SPI_NSS_Soft                    ((uint16_t)0x0200) | ||||
| #define SPI_NSS_Hard                    ((uint16_t)0x0000) | ||||
| #define IS_SPI_NSS(NSS) (((NSS) == SPI_NSS_Soft) || \ | ||||
|                          ((NSS) == SPI_NSS_Hard)) | ||||
| /**
 | ||||
|   * @} | ||||
|   */  | ||||
| 
 | ||||
| /** @defgroup SPI_BaudRate_Prescaler 
 | ||||
|   * @{ | ||||
|   */ | ||||
| 
 | ||||
| #define SPI_BaudRatePrescaler_2         ((uint16_t)0x0000) | ||||
| #define SPI_BaudRatePrescaler_4         ((uint16_t)0x0008) | ||||
| #define SPI_BaudRatePrescaler_8         ((uint16_t)0x0010) | ||||
| #define SPI_BaudRatePrescaler_16        ((uint16_t)0x0018) | ||||
| #define SPI_BaudRatePrescaler_32        ((uint16_t)0x0020) | ||||
| #define SPI_BaudRatePrescaler_64        ((uint16_t)0x0028) | ||||
| #define SPI_BaudRatePrescaler_128       ((uint16_t)0x0030) | ||||
| #define SPI_BaudRatePrescaler_256       ((uint16_t)0x0038) | ||||
| #define IS_SPI_BAUDRATE_PRESCALER(PRESCALER) (((PRESCALER) == SPI_BaudRatePrescaler_2) || \ | ||||
|                                               ((PRESCALER) == SPI_BaudRatePrescaler_4) || \ | ||||
|                                               ((PRESCALER) == SPI_BaudRatePrescaler_8) || \ | ||||
|                                               ((PRESCALER) == SPI_BaudRatePrescaler_16) || \ | ||||
|                                               ((PRESCALER) == SPI_BaudRatePrescaler_32) || \ | ||||
|                                               ((PRESCALER) == SPI_BaudRatePrescaler_64) || \ | ||||
|                                               ((PRESCALER) == SPI_BaudRatePrescaler_128) || \ | ||||
|                                               ((PRESCALER) == SPI_BaudRatePrescaler_256)) | ||||
| /**
 | ||||
|   * @} | ||||
|   */  | ||||
| 
 | ||||
| /** @defgroup SPI_MSB_LSB_transmission 
 | ||||
|   * @{ | ||||
|   */ | ||||
| 
 | ||||
| #define SPI_FirstBit_MSB                ((uint16_t)0x0000) | ||||
| #define SPI_FirstBit_LSB                ((uint16_t)0x0080) | ||||
| #define IS_SPI_FIRST_BIT(BIT) (((BIT) == SPI_FirstBit_MSB) || \ | ||||
|                                ((BIT) == SPI_FirstBit_LSB)) | ||||
| /**
 | ||||
|   * @} | ||||
|   */ | ||||
| 
 | ||||
| /** @defgroup SPI_I2S_Mode 
 | ||||
|   * @{ | ||||
|   */ | ||||
| 
 | ||||
| #define I2S_Mode_SlaveTx                ((uint16_t)0x0000) | ||||
| #define I2S_Mode_SlaveRx                ((uint16_t)0x0100) | ||||
| #define I2S_Mode_MasterTx               ((uint16_t)0x0200) | ||||
| #define I2S_Mode_MasterRx               ((uint16_t)0x0300) | ||||
| #define IS_I2S_MODE(MODE) (((MODE) == I2S_Mode_SlaveTx) || \ | ||||
|                            ((MODE) == I2S_Mode_SlaveRx) || \ | ||||
|                            ((MODE) == I2S_Mode_MasterTx)|| \ | ||||
|                            ((MODE) == I2S_Mode_MasterRx)) | ||||
| /**
 | ||||
|   * @} | ||||
|   */ | ||||
|    | ||||
| 
 | ||||
| /** @defgroup SPI_I2S_Standard 
 | ||||
|   * @{ | ||||
|   */ | ||||
| 
 | ||||
| #define I2S_Standard_Phillips           ((uint16_t)0x0000) | ||||
| #define I2S_Standard_MSB                ((uint16_t)0x0010) | ||||
| #define I2S_Standard_LSB                ((uint16_t)0x0020) | ||||
| #define I2S_Standard_PCMShort           ((uint16_t)0x0030) | ||||
| #define I2S_Standard_PCMLong            ((uint16_t)0x00B0) | ||||
| #define IS_I2S_STANDARD(STANDARD) (((STANDARD) == I2S_Standard_Phillips) || \ | ||||
|                                    ((STANDARD) == I2S_Standard_MSB) || \ | ||||
|                                    ((STANDARD) == I2S_Standard_LSB) || \ | ||||
|                                    ((STANDARD) == I2S_Standard_PCMShort) || \ | ||||
|                                    ((STANDARD) == I2S_Standard_PCMLong)) | ||||
| /**
 | ||||
|   * @} | ||||
|   */ | ||||
|    | ||||
| /** @defgroup SPI_I2S_Data_Format 
 | ||||
|   * @{ | ||||
|   */ | ||||
| 
 | ||||
| #define I2S_DataFormat_16b              ((uint16_t)0x0000) | ||||
| #define I2S_DataFormat_16bextended      ((uint16_t)0x0001) | ||||
| #define I2S_DataFormat_24b              ((uint16_t)0x0003) | ||||
| #define I2S_DataFormat_32b              ((uint16_t)0x0005) | ||||
| #define IS_I2S_DATA_FORMAT(FORMAT) (((FORMAT) == I2S_DataFormat_16b) || \ | ||||
|                                     ((FORMAT) == I2S_DataFormat_16bextended) || \ | ||||
|                                     ((FORMAT) == I2S_DataFormat_24b) || \ | ||||
|                                     ((FORMAT) == I2S_DataFormat_32b)) | ||||
| /**
 | ||||
|   * @} | ||||
|   */ | ||||
| 
 | ||||
| /** @defgroup SPI_I2S_MCLK_Output 
 | ||||
|   * @{ | ||||
|   */ | ||||
| 
 | ||||
| #define I2S_MCLKOutput_Enable           ((uint16_t)0x0200) | ||||
| #define I2S_MCLKOutput_Disable          ((uint16_t)0x0000) | ||||
| #define IS_I2S_MCLK_OUTPUT(OUTPUT) (((OUTPUT) == I2S_MCLKOutput_Enable) || \ | ||||
|                                     ((OUTPUT) == I2S_MCLKOutput_Disable)) | ||||
| /**
 | ||||
|   * @} | ||||
|   */ | ||||
| 
 | ||||
| /** @defgroup SPI_I2S_Audio_Frequency 
 | ||||
|   * @{ | ||||
|   */ | ||||
| 
 | ||||
| #define I2S_AudioFreq_192k               ((uint32_t)192000) | ||||
| #define I2S_AudioFreq_96k                ((uint32_t)96000) | ||||
| #define I2S_AudioFreq_48k                ((uint32_t)48000) | ||||
| #define I2S_AudioFreq_44k                ((uint32_t)44100) | ||||
| #define I2S_AudioFreq_32k                ((uint32_t)32000) | ||||
| #define I2S_AudioFreq_22k                ((uint32_t)22050) | ||||
| #define I2S_AudioFreq_16k                ((uint32_t)16000) | ||||
| #define I2S_AudioFreq_11k                ((uint32_t)11025) | ||||
| #define I2S_AudioFreq_8k                 ((uint32_t)8000) | ||||
| #define I2S_AudioFreq_Default            ((uint32_t)2) | ||||
| 
 | ||||
| #define IS_I2S_AUDIO_FREQ(FREQ) ((((FREQ) >= I2S_AudioFreq_8k) && \ | ||||
|                                  ((FREQ) <= I2S_AudioFreq_192k)) || \ | ||||
|                                  ((FREQ) == I2S_AudioFreq_Default)) | ||||
| /**
 | ||||
|   * @} | ||||
|   */ | ||||
|              | ||||
| /** @defgroup SPI_I2S_Clock_Polarity 
 | ||||
|   * @{ | ||||
|   */ | ||||
| 
 | ||||
| #define I2S_CPOL_Low                    ((uint16_t)0x0000) | ||||
| #define I2S_CPOL_High                   ((uint16_t)0x0008) | ||||
| #define IS_I2S_CPOL(CPOL) (((CPOL) == I2S_CPOL_Low) || \ | ||||
|                            ((CPOL) == I2S_CPOL_High)) | ||||
| /**
 | ||||
|   * @} | ||||
|   */ | ||||
| 
 | ||||
| /** @defgroup SPI_I2S_DMA_transfer_requests 
 | ||||
|   * @{ | ||||
|   */ | ||||
| 
 | ||||
| #define SPI_I2S_DMAReq_Tx               ((uint16_t)0x0002) | ||||
| #define SPI_I2S_DMAReq_Rx               ((uint16_t)0x0001) | ||||
| #define IS_SPI_I2S_DMAREQ(DMAREQ) ((((DMAREQ) & (uint16_t)0xFFFC) == 0x00) && ((DMAREQ) != 0x00)) | ||||
| /**
 | ||||
|   * @} | ||||
|   */ | ||||
| 
 | ||||
| /** @defgroup SPI_NSS_internal_software_management 
 | ||||
|   * @{ | ||||
|   */ | ||||
| 
 | ||||
| #define SPI_NSSInternalSoft_Set         ((uint16_t)0x0100) | ||||
| #define SPI_NSSInternalSoft_Reset       ((uint16_t)0xFEFF) | ||||
| #define IS_SPI_NSS_INTERNAL(INTERNAL) (((INTERNAL) == SPI_NSSInternalSoft_Set) || \ | ||||
|                                        ((INTERNAL) == SPI_NSSInternalSoft_Reset)) | ||||
| /**
 | ||||
|   * @} | ||||
|   */ | ||||
| 
 | ||||
| /** @defgroup SPI_CRC_Transmit_Receive 
 | ||||
|   * @{ | ||||
|   */ | ||||
| 
 | ||||
| #define SPI_CRC_Tx                      ((uint8_t)0x00) | ||||
| #define SPI_CRC_Rx                      ((uint8_t)0x01) | ||||
| #define IS_SPI_CRC(CRC) (((CRC) == SPI_CRC_Tx) || ((CRC) == SPI_CRC_Rx)) | ||||
| /**
 | ||||
|   * @} | ||||
|   */ | ||||
| 
 | ||||
| /** @defgroup SPI_direction_transmit_receive 
 | ||||
|   * @{ | ||||
|   */ | ||||
| 
 | ||||
| #define SPI_Direction_Rx                ((uint16_t)0xBFFF) | ||||
| #define SPI_Direction_Tx                ((uint16_t)0x4000) | ||||
| #define IS_SPI_DIRECTION(DIRECTION) (((DIRECTION) == SPI_Direction_Rx) || \ | ||||
|                                      ((DIRECTION) == SPI_Direction_Tx)) | ||||
| /**
 | ||||
|   * @} | ||||
|   */ | ||||
| 
 | ||||
| /** @defgroup SPI_I2S_interrupts_definition 
 | ||||
|   * @{ | ||||
|   */ | ||||
| 
 | ||||
| #define SPI_I2S_IT_TXE                  ((uint8_t)0x71) | ||||
| #define SPI_I2S_IT_RXNE                 ((uint8_t)0x60) | ||||
| #define SPI_I2S_IT_ERR                  ((uint8_t)0x50) | ||||
| #define I2S_IT_UDR                      ((uint8_t)0x53) | ||||
| #define SPI_I2S_IT_FRE                  ((uint8_t)0x58) | ||||
| 
 | ||||
| #define IS_SPI_I2S_CONFIG_IT(IT) (((IT) == SPI_I2S_IT_TXE) || \ | ||||
|                                   ((IT) == SPI_I2S_IT_RXNE) || \ | ||||
|                                   ((IT) == SPI_I2S_IT_ERR)) | ||||
| 
 | ||||
| #define SPI_I2S_IT_OVR                  ((uint8_t)0x56) | ||||
| #define SPI_IT_MODF                     ((uint8_t)0x55) | ||||
| #define SPI_IT_CRCERR                   ((uint8_t)0x54) | ||||
| 
 | ||||
| #define IS_SPI_I2S_CLEAR_IT(IT) (((IT) == SPI_IT_CRCERR)) | ||||
| 
 | ||||
| #define IS_SPI_I2S_GET_IT(IT) (((IT) == SPI_I2S_IT_RXNE) || ((IT) == SPI_I2S_IT_TXE) || \ | ||||
|                                ((IT) == SPI_IT_CRCERR)   || ((IT) == SPI_IT_MODF) || \ | ||||
|                                ((IT) == SPI_I2S_IT_OVR)  || ((IT) == I2S_IT_UDR) ||\ | ||||
|                                ((IT) == SPI_I2S_IT_FRE)) | ||||
| /**
 | ||||
|   * @} | ||||
|   */ | ||||
| 
 | ||||
| /** @defgroup SPI_I2S_flags_definition 
 | ||||
|   * @{ | ||||
|   */ | ||||
| 
 | ||||
| #define SPI_I2S_FLAG_RXNE               ((uint16_t)0x0001) | ||||
| #define SPI_I2S_FLAG_TXE                ((uint16_t)0x0002) | ||||
| #define I2S_FLAG_CHSIDE                 ((uint16_t)0x0004) | ||||
| #define I2S_FLAG_UDR                    ((uint16_t)0x0008) | ||||
| #define SPI_FLAG_CRCERR                 ((uint16_t)0x0010) | ||||
| #define SPI_FLAG_MODF                   ((uint16_t)0x0020) | ||||
| #define SPI_I2S_FLAG_OVR                ((uint16_t)0x0040) | ||||
| #define SPI_I2S_FLAG_BSY                ((uint16_t)0x0080) | ||||
| #define SPI_I2S_FLAG_FRE                ((uint16_t)0x0100) | ||||
| 
 | ||||
| #define IS_SPI_I2S_CLEAR_FLAG(FLAG) (((FLAG) == SPI_FLAG_CRCERR)) | ||||
| #define IS_SPI_I2S_GET_FLAG(FLAG) (((FLAG) == SPI_I2S_FLAG_BSY) || ((FLAG) == SPI_I2S_FLAG_OVR) || \ | ||||
|                                    ((FLAG) == SPI_FLAG_MODF) || ((FLAG) == SPI_FLAG_CRCERR) || \ | ||||
|                                    ((FLAG) == I2S_FLAG_UDR) || ((FLAG) == I2S_FLAG_CHSIDE) || \ | ||||
|                                    ((FLAG) == SPI_I2S_FLAG_TXE) || ((FLAG) == SPI_I2S_FLAG_RXNE)|| \ | ||||
|                                    ((FLAG) == SPI_I2S_FLAG_FRE)) | ||||
| /**
 | ||||
|   * @} | ||||
|   */ | ||||
| 
 | ||||
| /** @defgroup SPI_CRC_polynomial 
 | ||||
|   * @{ | ||||
|   */ | ||||
| 
 | ||||
| #define IS_SPI_CRC_POLYNOMIAL(POLYNOMIAL) ((POLYNOMIAL) >= 0x1) | ||||
| /**
 | ||||
|   * @} | ||||
|   */ | ||||
| 
 | ||||
| /** @defgroup SPI_I2S_Legacy 
 | ||||
|   * @{ | ||||
|   */ | ||||
| 
 | ||||
| #define SPI_DMAReq_Tx                SPI_I2S_DMAReq_Tx | ||||
| #define SPI_DMAReq_Rx                SPI_I2S_DMAReq_Rx | ||||
| #define SPI_IT_TXE                   SPI_I2S_IT_TXE | ||||
| #define SPI_IT_RXNE                  SPI_I2S_IT_RXNE | ||||
| #define SPI_IT_ERR                   SPI_I2S_IT_ERR | ||||
| #define SPI_IT_OVR                   SPI_I2S_IT_OVR | ||||
| #define SPI_FLAG_RXNE                SPI_I2S_FLAG_RXNE | ||||
| #define SPI_FLAG_TXE                 SPI_I2S_FLAG_TXE | ||||
| #define SPI_FLAG_OVR                 SPI_I2S_FLAG_OVR | ||||
| #define SPI_FLAG_BSY                 SPI_I2S_FLAG_BSY | ||||
| #define SPI_DeInit                   SPI_I2S_DeInit | ||||
| #define SPI_ITConfig                 SPI_I2S_ITConfig | ||||
| #define SPI_DMACmd                   SPI_I2S_DMACmd | ||||
| #define SPI_SendData                 SPI_I2S_SendData | ||||
| #define SPI_ReceiveData              SPI_I2S_ReceiveData | ||||
| #define SPI_GetFlagStatus            SPI_I2S_GetFlagStatus | ||||
| #define SPI_ClearFlag                SPI_I2S_ClearFlag | ||||
| #define SPI_GetITStatus              SPI_I2S_GetITStatus | ||||
| #define SPI_ClearITPendingBit        SPI_I2S_ClearITPendingBit | ||||
| /**
 | ||||
|   * @} | ||||
|   */ | ||||
|    | ||||
| /**
 | ||||
|   * @} | ||||
|   */ | ||||
| 
 | ||||
| /* Exported macro ------------------------------------------------------------*/ | ||||
| /* Exported functions ------------------------------------------------------- */ | ||||
| 
 | ||||
| /*  Function used to set the SPI configuration to the default reset state *****/  | ||||
| void SPI_I2S_DeInit(SPI_TypeDef* SPIx); | ||||
| 
 | ||||
| /* Initialization and Configuration functions *********************************/ | ||||
| void SPI_Init(SPI_TypeDef* SPIx, SPI_InitTypeDef* SPI_InitStruct); | ||||
| void I2S_Init(SPI_TypeDef* SPIx, I2S_InitTypeDef* I2S_InitStruct); | ||||
| void SPI_StructInit(SPI_InitTypeDef* SPI_InitStruct); | ||||
| void I2S_StructInit(I2S_InitTypeDef* I2S_InitStruct); | ||||
| void SPI_Cmd(SPI_TypeDef* SPIx, FunctionalState NewState); | ||||
| void I2S_Cmd(SPI_TypeDef* SPIx, FunctionalState NewState); | ||||
| void SPI_DataSizeConfig(SPI_TypeDef* SPIx, uint16_t SPI_DataSize); | ||||
| void SPI_BiDirectionalLineConfig(SPI_TypeDef* SPIx, uint16_t SPI_Direction); | ||||
| void SPI_NSSInternalSoftwareConfig(SPI_TypeDef* SPIx, uint16_t SPI_NSSInternalSoft); | ||||
| void SPI_SSOutputCmd(SPI_TypeDef* SPIx, FunctionalState NewState); | ||||
| 
 | ||||
| /* Data transfers functions ***************************************************/  | ||||
| void SPI_I2S_SendData(SPI_TypeDef* SPIx, uint16_t Data); | ||||
| uint16_t SPI_I2S_ReceiveData(SPI_TypeDef* SPIx); | ||||
| 
 | ||||
| /* Hardware CRC Calculation functions *****************************************/ | ||||
| void SPI_CalculateCRC(SPI_TypeDef* SPIx, FunctionalState NewState); | ||||
| void SPI_TransmitCRC(SPI_TypeDef* SPIx); | ||||
| uint16_t SPI_GetCRC(SPI_TypeDef* SPIx, uint8_t SPI_CRC); | ||||
| uint16_t SPI_GetCRCPolynomial(SPI_TypeDef* SPIx); | ||||
| 
 | ||||
| /* DMA transfers management functions *****************************************/ | ||||
| void SPI_I2S_DMACmd(SPI_TypeDef* SPIx, uint16_t SPI_I2S_DMAReq, FunctionalState NewState); | ||||
| 
 | ||||
| /* Interrupts and flags management functions **********************************/ | ||||
| void SPI_I2S_ITConfig(SPI_TypeDef* SPIx, uint8_t SPI_I2S_IT, FunctionalState NewState); | ||||
| FlagStatus SPI_I2S_GetFlagStatus(SPI_TypeDef* SPIx, uint16_t SPI_I2S_FLAG); | ||||
| void SPI_I2S_ClearFlag(SPI_TypeDef* SPIx, uint16_t SPI_I2S_FLAG); | ||||
| ITStatus SPI_I2S_GetITStatus(SPI_TypeDef* SPIx, uint8_t SPI_I2S_IT); | ||||
| void SPI_I2S_ClearITPendingBit(SPI_TypeDef* SPIx, uint8_t SPI_I2S_IT); | ||||
| 
 | ||||
| #ifdef __cplusplus | ||||
| } | ||||
| #endif | ||||
| 
 | ||||
| #endif /*__STM32L1xx_SPI_H */ | ||||
| 
 | ||||
| /**
 | ||||
|   * @} | ||||
|   */ | ||||
| 
 | ||||
| /**
 | ||||
|   * @} | ||||
|   */ | ||||
| 
 | ||||
| /************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE****/ | ||||
|  | @ -1,427 +0,0 @@ | |||
| /**
 | ||||
|   ****************************************************************************** | ||||
|   * @file    stm32l1xx_usart.h | ||||
|   * @author  MCD Application Team | ||||
|   * @version V1.1.1 | ||||
|   * @date    05-March-2012 | ||||
|   * @brief   This file contains all the functions prototypes for the USART  | ||||
|   *          firmware library. | ||||
|   ****************************************************************************** | ||||
|   * @attention | ||||
|   * | ||||
|   * <h2><center>© COPYRIGHT 2012 STMicroelectronics</center></h2> | ||||
|   * | ||||
|   * Licensed under MCD-ST Liberty SW License Agreement V2, (the "License"); | ||||
|   * You may not use this file except in compliance with the License. | ||||
|   * You may obtain a copy of the License at: | ||||
|   * | ||||
|   *        http://www.st.com/software_license_agreement_liberty_v2
 | ||||
|   * | ||||
|   * Unless required by applicable law or agreed to in writing, software  | ||||
|   * distributed under the License is distributed on an "AS IS" BASIS,  | ||||
|   * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. | ||||
|   * See the License for the specific language governing permissions and | ||||
|   * limitations under the License. | ||||
|   * | ||||
|   ****************************************************************************** | ||||
|   */ | ||||
| 
 | ||||
| /* Define to prevent recursive inclusion -------------------------------------*/ | ||||
| #ifndef __STM32L1xx_USART_H | ||||
| #define __STM32L1xx_USART_H | ||||
| 
 | ||||
| #ifdef __cplusplus | ||||
|  extern "C" { | ||||
| #endif | ||||
| 
 | ||||
| /* Includes ------------------------------------------------------------------*/ | ||||
| #include "stm32l1xx.h" | ||||
| 
 | ||||
| /** @addtogroup STM32L1xx_StdPeriph_Driver
 | ||||
|   * @{ | ||||
|   */ | ||||
| 
 | ||||
| /** @addtogroup USART
 | ||||
|   * @{ | ||||
|   */  | ||||
| 
 | ||||
| /* Exported types ------------------------------------------------------------*/  | ||||
| 
 | ||||
| /** 
 | ||||
|   * @brief  USART Init Structure definition   | ||||
|   */  | ||||
|    | ||||
| typedef struct | ||||
| { | ||||
|   uint32_t USART_BaudRate;            /*!< This member configures the USART communication baud rate.
 | ||||
|                                            The baud rate is computed using the following formula: | ||||
|                                             - IntegerDivider = ((PCLKx) / (8 * (OVR8+1) * (USART_InitStruct->USART_BaudRate))) | ||||
|                                             - FractionalDivider = ((IntegerDivider - ((u32) IntegerDivider)) * 8 * (OVR8+1)) + 0.5  | ||||
|                                            Where OVR8 is the "oversampling by 8 mode" configuration bit in the CR1 register. */ | ||||
| 
 | ||||
|   uint16_t USART_WordLength;          /*!< Specifies the number of data bits transmitted or received in a frame.
 | ||||
|                                            This parameter can be a value of @ref USART_Word_Length */ | ||||
| 
 | ||||
|   uint16_t USART_StopBits;            /*!< Specifies the number of stop bits transmitted.
 | ||||
|                                            This parameter can be a value of @ref USART_Stop_Bits */ | ||||
| 
 | ||||
|   uint16_t USART_Parity;              /*!< Specifies the parity mode.
 | ||||
|                                            This parameter can be a value of @ref USART_Parity | ||||
|                                            @note When parity is enabled, the computed parity is inserted | ||||
|                                                  at the MSB position of the transmitted data (9th bit when | ||||
|                                                  the word length is set to 9 data bits; 8th bit when the | ||||
|                                                  word length is set to 8 data bits). */ | ||||
|   | ||||
|   uint16_t USART_Mode;                /*!< Specifies wether the Receive or Transmit mode is enabled or disabled.
 | ||||
|                                            This parameter can be a value of @ref USART_Mode */ | ||||
| 
 | ||||
|   uint16_t USART_HardwareFlowControl; /*!< Specifies wether the hardware flow control mode is enabled
 | ||||
|                                            or disabled. | ||||
|                                            This parameter can be a value of @ref USART_Hardware_Flow_Control */ | ||||
| } USART_InitTypeDef; | ||||
| 
 | ||||
| /** 
 | ||||
|   * @brief  USART Clock Init Structure definition   | ||||
|   */  | ||||
|    | ||||
| typedef struct | ||||
| { | ||||
| 
 | ||||
|   uint16_t USART_Clock;   /*!< Specifies whether the USART clock is enabled or disabled.
 | ||||
|                                This parameter can be a value of @ref USART_Clock */ | ||||
| 
 | ||||
|   uint16_t USART_CPOL;    /*!< Specifies the steady state of the serial clock.
 | ||||
|                                This parameter can be a value of @ref USART_Clock_Polarity */ | ||||
| 
 | ||||
|   uint16_t USART_CPHA;    /*!< Specifies the clock transition on which the bit capture is made.
 | ||||
|                                This parameter can be a value of @ref USART_Clock_Phase */ | ||||
| 
 | ||||
|   uint16_t USART_LastBit; /*!< Specifies whether the clock pulse corresponding to the last transmitted
 | ||||
|                                data bit (MSB) has to be output on the SCLK pin in synchronous mode. | ||||
|                                This parameter can be a value of @ref USART_Last_Bit */ | ||||
| } USART_ClockInitTypeDef; | ||||
| 
 | ||||
| /* Exported constants --------------------------------------------------------*/ | ||||
| 
 | ||||
| /** @defgroup USART_Exported_Constants
 | ||||
|   * @{ | ||||
|   */  | ||||
|    | ||||
| #define IS_USART_ALL_PERIPH(PERIPH) (((PERIPH) == USART1) || \ | ||||
|                                      ((PERIPH) == USART2) || \ | ||||
|                                      ((PERIPH) == USART3) || \ | ||||
|                                      ((PERIPH) == UART4) || \ | ||||
|                                      ((PERIPH) == UART5)) | ||||
| 
 | ||||
| #define IS_USART_123_PERIPH(PERIPH) (((PERIPH) == USART1) || \ | ||||
|                                      ((PERIPH) == USART2) || \ | ||||
|                                      ((PERIPH) == USART3)) | ||||
| 
 | ||||
| /** @defgroup USART_Word_Length 
 | ||||
|   * @{ | ||||
|   */  | ||||
|    | ||||
| #define USART_WordLength_8b                  ((uint16_t)0x0000) | ||||
| #define USART_WordLength_9b                  ((uint16_t)0x1000) | ||||
|                                      | ||||
| #define IS_USART_WORD_LENGTH(LENGTH) (((LENGTH) == USART_WordLength_8b) || \ | ||||
|                                       ((LENGTH) == USART_WordLength_9b)) | ||||
| /**
 | ||||
|   * @} | ||||
|   */  | ||||
| 
 | ||||
| /** @defgroup USART_Stop_Bits 
 | ||||
|   * @{ | ||||
|   */  | ||||
|    | ||||
| #define USART_StopBits_1                     ((uint16_t)0x0000) | ||||
| #define USART_StopBits_0_5                   ((uint16_t)0x1000) | ||||
| #define USART_StopBits_2                     ((uint16_t)0x2000) | ||||
| #define USART_StopBits_1_5                   ((uint16_t)0x3000) | ||||
| #define IS_USART_STOPBITS(STOPBITS) (((STOPBITS) == USART_StopBits_1) || \ | ||||
|                                      ((STOPBITS) == USART_StopBits_0_5) || \ | ||||
|                                      ((STOPBITS) == USART_StopBits_2) || \ | ||||
|                                      ((STOPBITS) == USART_StopBits_1_5)) | ||||
| /**
 | ||||
|   * @} | ||||
|   */  | ||||
| 
 | ||||
| /** @defgroup USART_Parity 
 | ||||
|   * @{ | ||||
|   */  | ||||
|    | ||||
| #define USART_Parity_No                      ((uint16_t)0x0000) | ||||
| #define USART_Parity_Even                    ((uint16_t)0x0400) | ||||
| #define USART_Parity_Odd                     ((uint16_t)0x0600)  | ||||
| #define IS_USART_PARITY(PARITY) (((PARITY) == USART_Parity_No) || \ | ||||
|                                  ((PARITY) == USART_Parity_Even) || \ | ||||
|                                  ((PARITY) == USART_Parity_Odd)) | ||||
| /**
 | ||||
|   * @} | ||||
|   */  | ||||
| 
 | ||||
| /** @defgroup USART_Mode 
 | ||||
|   * @{ | ||||
|   */  | ||||
|    | ||||
| #define USART_Mode_Rx                        ((uint16_t)0x0004) | ||||
| #define USART_Mode_Tx                        ((uint16_t)0x0008) | ||||
| #define IS_USART_MODE(MODE) ((((MODE) & (uint16_t)0xFFF3) == 0x00) && ((MODE) != (uint16_t)0x00)) | ||||
| /**
 | ||||
|   * @} | ||||
|   */  | ||||
| 
 | ||||
| /** @defgroup USART_Hardware_Flow_Control 
 | ||||
|   * @{ | ||||
|   */  | ||||
| #define USART_HardwareFlowControl_None       ((uint16_t)0x0000) | ||||
| #define USART_HardwareFlowControl_RTS        ((uint16_t)0x0100) | ||||
| #define USART_HardwareFlowControl_CTS        ((uint16_t)0x0200) | ||||
| #define USART_HardwareFlowControl_RTS_CTS    ((uint16_t)0x0300) | ||||
| #define IS_USART_HARDWARE_FLOW_CONTROL(CONTROL)\ | ||||
|                               (((CONTROL) == USART_HardwareFlowControl_None) || \ | ||||
|                                ((CONTROL) == USART_HardwareFlowControl_RTS) || \ | ||||
|                                ((CONTROL) == USART_HardwareFlowControl_CTS) || \ | ||||
|                                ((CONTROL) == USART_HardwareFlowControl_RTS_CTS)) | ||||
| /**
 | ||||
|   * @} | ||||
|   */  | ||||
| 
 | ||||
| /** @defgroup USART_Clock 
 | ||||
|   * @{ | ||||
|   */  | ||||
| #define USART_Clock_Disable                  ((uint16_t)0x0000) | ||||
| #define USART_Clock_Enable                   ((uint16_t)0x0800) | ||||
| #define IS_USART_CLOCK(CLOCK) (((CLOCK) == USART_Clock_Disable) || \ | ||||
|                                ((CLOCK) == USART_Clock_Enable)) | ||||
| /**
 | ||||
|   * @} | ||||
|   */  | ||||
| 
 | ||||
| /** @defgroup USART_Clock_Polarity 
 | ||||
|   * @{ | ||||
|   */ | ||||
|    | ||||
| #define USART_CPOL_Low                       ((uint16_t)0x0000) | ||||
| #define USART_CPOL_High                      ((uint16_t)0x0400) | ||||
| #define IS_USART_CPOL(CPOL) (((CPOL) == USART_CPOL_Low) || ((CPOL) == USART_CPOL_High)) | ||||
| 
 | ||||
| /**
 | ||||
|   * @} | ||||
|   */  | ||||
| 
 | ||||
| /** @defgroup USART_Clock_Phase
 | ||||
|   * @{ | ||||
|   */ | ||||
| 
 | ||||
| #define USART_CPHA_1Edge                     ((uint16_t)0x0000) | ||||
| #define USART_CPHA_2Edge                     ((uint16_t)0x0200) | ||||
| #define IS_USART_CPHA(CPHA) (((CPHA) == USART_CPHA_1Edge) || ((CPHA) == USART_CPHA_2Edge)) | ||||
| 
 | ||||
| /**
 | ||||
|   * @} | ||||
|   */ | ||||
| 
 | ||||
| /** @defgroup USART_Last_Bit
 | ||||
|   * @{ | ||||
|   */ | ||||
| 
 | ||||
| #define USART_LastBit_Disable                ((uint16_t)0x0000) | ||||
| #define USART_LastBit_Enable                 ((uint16_t)0x0100) | ||||
| #define IS_USART_LASTBIT(LASTBIT) (((LASTBIT) == USART_LastBit_Disable) || \ | ||||
|                                    ((LASTBIT) == USART_LastBit_Enable)) | ||||
| /**
 | ||||
|   * @} | ||||
|   */  | ||||
| 
 | ||||
| /** @defgroup USART_Interrupt_definition 
 | ||||
|   * @{ | ||||
|   */ | ||||
|    | ||||
| #define USART_IT_PE                          ((uint16_t)0x0028) | ||||
| #define USART_IT_TXE                         ((uint16_t)0x0727) | ||||
| #define USART_IT_TC                          ((uint16_t)0x0626) | ||||
| #define USART_IT_RXNE                        ((uint16_t)0x0525) | ||||
| #define USART_IT_IDLE                        ((uint16_t)0x0424) | ||||
| #define USART_IT_LBD                         ((uint16_t)0x0846) | ||||
| #define USART_IT_ORE_RX                      ((uint16_t)0x0325) /* In case interrupt is generated if the RXNEIE bit is set */ | ||||
| #define USART_IT_CTS                         ((uint16_t)0x096A) | ||||
| #define USART_IT_ERR                         ((uint16_t)0x0060) | ||||
| #define USART_IT_ORE_ER                      ((uint16_t)0x0360) /* In case interrupt is generated if the EIE bit is set */ | ||||
| #define USART_IT_NE                          ((uint16_t)0x0260) | ||||
| #define USART_IT_FE                          ((uint16_t)0x0160) | ||||
| 
 | ||||
| /** @defgroup USART_Legacy 
 | ||||
|   * @{ | ||||
|   */ | ||||
| #define USART_IT_ORE                          USART_IT_ORE_ER                | ||||
| /**
 | ||||
|   * @} | ||||
|   */ | ||||
| 
 | ||||
| #define IS_USART_CONFIG_IT(IT) (((IT) == USART_IT_PE) || ((IT) == USART_IT_TXE) || \ | ||||
|                                 ((IT) == USART_IT_TC) || ((IT) == USART_IT_RXNE) || \ | ||||
|                                 ((IT) == USART_IT_IDLE) || ((IT) == USART_IT_LBD) || \ | ||||
|                                 ((IT) == USART_IT_CTS) || ((IT) == USART_IT_ERR)) | ||||
| #define IS_USART_GET_IT(IT) (((IT) == USART_IT_PE) || ((IT) == USART_IT_TXE) || \ | ||||
|                              ((IT) == USART_IT_TC) || ((IT) == USART_IT_RXNE) || \ | ||||
|                              ((IT) == USART_IT_IDLE) || ((IT) == USART_IT_LBD) || \ | ||||
|                              ((IT) == USART_IT_CTS) || ((IT) == USART_IT_ORE_RX) || \ | ||||
|                              ((IT) == USART_IT_ORE_ER) || ((IT) == USART_IT_NE) || \ | ||||
|                              ((IT) == USART_IT_FE)) | ||||
| #define IS_USART_CLEAR_IT(IT) (((IT) == USART_IT_TC) || ((IT) == USART_IT_RXNE) || \ | ||||
|                                ((IT) == USART_IT_LBD) || ((IT) == USART_IT_CTS)) | ||||
| /**
 | ||||
|   * @} | ||||
|   */ | ||||
| 
 | ||||
| /** @defgroup USART_DMA_Requests 
 | ||||
|   * @{ | ||||
|   */ | ||||
| 
 | ||||
| #define USART_DMAReq_Tx                      ((uint16_t)0x0080) | ||||
| #define USART_DMAReq_Rx                      ((uint16_t)0x0040) | ||||
| #define IS_USART_DMAREQ(DMAREQ) ((((DMAREQ) & (uint16_t)0xFF3F) == 0x00) && ((DMAREQ) != (uint16_t)0x00)) | ||||
| 
 | ||||
| /**
 | ||||
|   * @} | ||||
|   */  | ||||
| 
 | ||||
| /** @defgroup USART_WakeUp_methods
 | ||||
|   * @{ | ||||
|   */ | ||||
| 
 | ||||
| #define USART_WakeUp_IdleLine                ((uint16_t)0x0000) | ||||
| #define USART_WakeUp_AddressMark             ((uint16_t)0x0800) | ||||
| #define IS_USART_WAKEUP(WAKEUP) (((WAKEUP) == USART_WakeUp_IdleLine) || \ | ||||
|                                  ((WAKEUP) == USART_WakeUp_AddressMark)) | ||||
| /**
 | ||||
|   * @} | ||||
|   */ | ||||
| 
 | ||||
| /** @defgroup USART_LIN_Break_Detection_Length 
 | ||||
|   * @{ | ||||
|   */ | ||||
|    | ||||
| #define USART_LINBreakDetectLength_10b      ((uint16_t)0x0000) | ||||
| #define USART_LINBreakDetectLength_11b      ((uint16_t)0x0020) | ||||
| #define IS_USART_LIN_BREAK_DETECT_LENGTH(LENGTH) \ | ||||
|                                (((LENGTH) == USART_LINBreakDetectLength_10b) || \ | ||||
|                                 ((LENGTH) == USART_LINBreakDetectLength_11b)) | ||||
| /**
 | ||||
|   * @} | ||||
|   */ | ||||
| 
 | ||||
| /** @defgroup USART_IrDA_Low_Power 
 | ||||
|   * @{ | ||||
|   */ | ||||
| 
 | ||||
| #define USART_IrDAMode_LowPower              ((uint16_t)0x0004) | ||||
| #define USART_IrDAMode_Normal                ((uint16_t)0x0000) | ||||
| #define IS_USART_IRDA_MODE(MODE) (((MODE) == USART_IrDAMode_LowPower) || \ | ||||
|                                   ((MODE) == USART_IrDAMode_Normal)) | ||||
| /**
 | ||||
|   * @} | ||||
|   */  | ||||
| 
 | ||||
| /** @defgroup USART_Flags 
 | ||||
|   * @{ | ||||
|   */ | ||||
| 
 | ||||
| #define USART_FLAG_CTS                       ((uint16_t)0x0200) | ||||
| #define USART_FLAG_LBD                       ((uint16_t)0x0100) | ||||
| #define USART_FLAG_TXE                       ((uint16_t)0x0080) | ||||
| #define USART_FLAG_TC                        ((uint16_t)0x0040) | ||||
| #define USART_FLAG_RXNE                      ((uint16_t)0x0020) | ||||
| #define USART_FLAG_IDLE                      ((uint16_t)0x0010) | ||||
| #define USART_FLAG_ORE                       ((uint16_t)0x0008) | ||||
| #define USART_FLAG_NE                        ((uint16_t)0x0004) | ||||
| #define USART_FLAG_FE                        ((uint16_t)0x0002) | ||||
| #define USART_FLAG_PE                        ((uint16_t)0x0001) | ||||
| #define IS_USART_FLAG(FLAG) (((FLAG) == USART_FLAG_PE) || ((FLAG) == USART_FLAG_TXE) || \ | ||||
|                              ((FLAG) == USART_FLAG_TC) || ((FLAG) == USART_FLAG_RXNE) || \ | ||||
|                              ((FLAG) == USART_FLAG_IDLE) || ((FLAG) == USART_FLAG_LBD) || \ | ||||
|                              ((FLAG) == USART_FLAG_CTS) || ((FLAG) == USART_FLAG_ORE) || \ | ||||
|                              ((FLAG) == USART_FLAG_NE) || ((FLAG) == USART_FLAG_FE)) | ||||
|                                | ||||
| #define IS_USART_CLEAR_FLAG(FLAG) ((((FLAG) & (uint16_t)0xFC9F) == 0x00) && ((FLAG) != (uint16_t)0x00)) | ||||
| 
 | ||||
| #define IS_USART_BAUDRATE(BAUDRATE) (((BAUDRATE) > 0) && ((BAUDRATE) < 0x003D0901)) | ||||
| #define IS_USART_ADDRESS(ADDRESS) ((ADDRESS) <= 0xF) | ||||
| #define IS_USART_DATA(DATA) ((DATA) <= 0x1FF) | ||||
| 
 | ||||
| /**
 | ||||
|   * @} | ||||
|   */  | ||||
| 
 | ||||
| /**
 | ||||
|   * @} | ||||
|   */  | ||||
| 
 | ||||
| /* Exported macro ------------------------------------------------------------*/ | ||||
| /* Exported functions ------------------------------------------------------- */  | ||||
| 
 | ||||
| /*  Function used to set the USART configuration to the default reset state ***/  | ||||
| void USART_DeInit(USART_TypeDef* USARTx); | ||||
| 
 | ||||
| /* Initialization and Configuration functions *********************************/ | ||||
| void USART_Init(USART_TypeDef* USARTx, USART_InitTypeDef* USART_InitStruct); | ||||
| void USART_StructInit(USART_InitTypeDef* USART_InitStruct); | ||||
| void USART_ClockInit(USART_TypeDef* USARTx, USART_ClockInitTypeDef* USART_ClockInitStruct); | ||||
| void USART_ClockStructInit(USART_ClockInitTypeDef* USART_ClockInitStruct); | ||||
| void USART_Cmd(USART_TypeDef* USARTx, FunctionalState NewState); | ||||
| void USART_SetPrescaler(USART_TypeDef* USARTx, uint8_t USART_Prescaler); | ||||
| void USART_OverSampling8Cmd(USART_TypeDef* USARTx, FunctionalState NewState); | ||||
| void USART_OneBitMethodCmd(USART_TypeDef* USARTx, FunctionalState NewState); | ||||
| 
 | ||||
| /* Data transfers functions ***************************************************/  | ||||
| void USART_SendData(USART_TypeDef* USARTx, uint16_t Data); | ||||
| uint16_t USART_ReceiveData(USART_TypeDef* USARTx); | ||||
| 
 | ||||
| /* Multi-Processor Communication functions ************************************/ | ||||
| void USART_SetAddress(USART_TypeDef* USARTx, uint8_t USART_Address); | ||||
| void USART_WakeUpConfig(USART_TypeDef* USARTx, uint16_t USART_WakeUp); | ||||
| void USART_ReceiverWakeUpCmd(USART_TypeDef* USARTx, FunctionalState NewState); | ||||
| 
 | ||||
| /* LIN mode functions *********************************************************/ | ||||
| void USART_LINBreakDetectLengthConfig(USART_TypeDef* USARTx, uint16_t USART_LINBreakDetectLength); | ||||
| void USART_LINCmd(USART_TypeDef* USARTx, FunctionalState NewState); | ||||
| void USART_SendBreak(USART_TypeDef* USARTx); | ||||
| 
 | ||||
| /* Half-duplex mode function **************************************************/ | ||||
| void USART_HalfDuplexCmd(USART_TypeDef* USARTx, FunctionalState NewState); | ||||
| 
 | ||||
| /* Smartcard mode functions ***************************************************/ | ||||
| void USART_SmartCardCmd(USART_TypeDef* USARTx, FunctionalState NewState); | ||||
| void USART_SmartCardNACKCmd(USART_TypeDef* USARTx, FunctionalState NewState); | ||||
| void USART_SetGuardTime(USART_TypeDef* USARTx, uint8_t USART_GuardTime); | ||||
| 
 | ||||
| /* IrDA mode functions ********************************************************/ | ||||
| void USART_IrDAConfig(USART_TypeDef* USARTx, uint16_t USART_IrDAMode); | ||||
| void USART_IrDACmd(USART_TypeDef* USARTx, FunctionalState NewState); | ||||
| 
 | ||||
| /* DMA transfers management functions *****************************************/ | ||||
| void USART_DMACmd(USART_TypeDef* USARTx, uint16_t USART_DMAReq, FunctionalState NewState); | ||||
| 
 | ||||
| /* Interrupts and flags management functions **********************************/ | ||||
| void USART_ITConfig(USART_TypeDef* USARTx, uint16_t USART_IT, FunctionalState NewState); | ||||
| FlagStatus USART_GetFlagStatus(USART_TypeDef* USARTx, uint16_t USART_FLAG); | ||||
| void USART_ClearFlag(USART_TypeDef* USARTx, uint16_t USART_FLAG); | ||||
| ITStatus USART_GetITStatus(USART_TypeDef* USARTx, uint16_t USART_IT); | ||||
| void USART_ClearITPendingBit(USART_TypeDef* USARTx, uint16_t USART_IT); | ||||
| 
 | ||||
| #ifdef __cplusplus | ||||
| } | ||||
| #endif | ||||
| 
 | ||||
| #endif /* __STM32L1xx_USART_H */ | ||||
| 
 | ||||
| /**
 | ||||
|   * @} | ||||
|   */  | ||||
| 
 | ||||
| /**
 | ||||
|   * @} | ||||
|   */  | ||||
| 
 | ||||
| /************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE****/ | ||||
|  | @ -1,110 +0,0 @@ | |||
| /**
 | ||||
|   ****************************************************************************** | ||||
|   * @file    stm32l1xx_wwdg.h | ||||
|   * @author  MCD Application Team | ||||
|   * @version V1.1.1 | ||||
|   * @date    05-March-2012 | ||||
|   * @brief   This file contains all the functions prototypes for the WWDG  | ||||
|   *          firmware library. | ||||
|   ****************************************************************************** | ||||
|   * @attention | ||||
|   * | ||||
|   * <h2><center>© COPYRIGHT 2012 STMicroelectronics</center></h2> | ||||
|   * | ||||
|   * Licensed under MCD-ST Liberty SW License Agreement V2, (the "License"); | ||||
|   * You may not use this file except in compliance with the License. | ||||
|   * You may obtain a copy of the License at: | ||||
|   * | ||||
|   *        http://www.st.com/software_license_agreement_liberty_v2
 | ||||
|   * | ||||
|   * Unless required by applicable law or agreed to in writing, software  | ||||
|   * distributed under the License is distributed on an "AS IS" BASIS,  | ||||
|   * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. | ||||
|   * See the License for the specific language governing permissions and | ||||
|   * limitations under the License. | ||||
|   * | ||||
|   ****************************************************************************** | ||||
|   */ | ||||
| 
 | ||||
| /* Define to prevent recursive inclusion -------------------------------------*/ | ||||
| #ifndef __STM32L1xx_WWDG_H | ||||
| #define __STM32L1xx_WWDG_H | ||||
| 
 | ||||
| #ifdef __cplusplus | ||||
|  extern "C" { | ||||
| #endif | ||||
| 
 | ||||
| /* Includes ------------------------------------------------------------------*/ | ||||
| #include "stm32l1xx.h" | ||||
| 
 | ||||
| /** @addtogroup STM32L1xx_StdPeriph_Driver
 | ||||
|   * @{ | ||||
|   */ | ||||
| 
 | ||||
| /** @addtogroup WWDG
 | ||||
|   * @{ | ||||
|   */  | ||||
| 
 | ||||
| /* Exported types ------------------------------------------------------------*/ | ||||
| /* Exported constants --------------------------------------------------------*/ | ||||
| 
 | ||||
| /** @defgroup WWDG_Exported_Constants
 | ||||
|   * @{ | ||||
|   */  | ||||
|    | ||||
| /** @defgroup WWDG_Prescaler 
 | ||||
|   * @{ | ||||
|   */  | ||||
|    | ||||
| #define WWDG_Prescaler_1    ((uint32_t)0x00000000) | ||||
| #define WWDG_Prescaler_2    ((uint32_t)0x00000080) | ||||
| #define WWDG_Prescaler_4    ((uint32_t)0x00000100) | ||||
| #define WWDG_Prescaler_8    ((uint32_t)0x00000180) | ||||
| #define IS_WWDG_PRESCALER(PRESCALER) (((PRESCALER) == WWDG_Prescaler_1) || \ | ||||
|                                       ((PRESCALER) == WWDG_Prescaler_2) || \ | ||||
|                                       ((PRESCALER) == WWDG_Prescaler_4) || \ | ||||
|                                       ((PRESCALER) == WWDG_Prescaler_8)) | ||||
| #define IS_WWDG_WINDOW_VALUE(VALUE) ((VALUE) <= 0x7F) | ||||
| #define IS_WWDG_COUNTER(COUNTER) (((COUNTER) >= 0x40) && ((COUNTER) <= 0x7F)) | ||||
| 
 | ||||
| /**
 | ||||
|   * @} | ||||
|   */  | ||||
| 
 | ||||
| /**
 | ||||
|   * @} | ||||
|   */  | ||||
| 
 | ||||
| /* Exported macro ------------------------------------------------------------*/ | ||||
| /* Exported functions ------------------------------------------------------- */ | ||||
| /*  Function used to set the WWDG configuration to the default reset state ****/   | ||||
| void WWDG_DeInit(void); | ||||
| 
 | ||||
| /* Prescaler, Refresh window and Counter configuration functions **************/ | ||||
| void WWDG_SetPrescaler(uint32_t WWDG_Prescaler); | ||||
| void WWDG_SetWindowValue(uint8_t WindowValue); | ||||
| void WWDG_EnableIT(void); | ||||
| void WWDG_SetCounter(uint8_t Counter); | ||||
| 
 | ||||
| /* WWDG activation functions **************************************************/ | ||||
| void WWDG_Enable(uint8_t Counter); | ||||
| 
 | ||||
| /* Interrupts and flags management functions **********************************/ | ||||
| FlagStatus WWDG_GetFlagStatus(void); | ||||
| void WWDG_ClearFlag(void); | ||||
| 
 | ||||
| #ifdef __cplusplus | ||||
| } | ||||
| #endif | ||||
| 
 | ||||
| #endif /* __STM32L1xx_WWDG_H */ | ||||
| 
 | ||||
| /**
 | ||||
|   * @} | ||||
|   */  | ||||
| 
 | ||||
| /**
 | ||||
|   * @} | ||||
|   */  | ||||
| 
 | ||||
| /************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE****/ | ||||
										
											
												File diff suppressed because it is too large
												Load diff
											
										
									
								
							|  | @ -1,599 +0,0 @@ | |||
| /**
 | ||||
|   ****************************************************************************** | ||||
|   * @file    stm32l1xx_aes.c | ||||
|   * @author  MCD Application Team | ||||
|   * @version V1.1.1 | ||||
|   * @date    05-March-2012 | ||||
|   * @brief   This file provides firmware functions to manage the following  | ||||
|   *          functionalities of the AES peripheral:            | ||||
|   *           + Configuration | ||||
|   *           + Read/Write operations | ||||
|   *           + DMA transfers management   | ||||
|   *           + Interrupts and flags management | ||||
|   *  | ||||
|   *  @verbatim | ||||
|  =============================================================================== | ||||
|                         ##### AES Peripheral features ##### | ||||
|  =============================================================================== | ||||
| ....[..] | ||||
|    (#) The Advanced Encryption Standard hardware accelerator (AES) can be used | ||||
|        to both encipher and decipher data using AES algorithm. | ||||
|    (#) The AES supports 4 operation modes: | ||||
|        (++) Encryption: It consumes 214 clock cycle when processing one 128-bit block | ||||
|        (++) Decryption: It consumes 214 clock cycle when processing one 128-bit block | ||||
|        (++) Key derivation for decryption: It consumes 80 clock cycle when processing one 128-bit block | ||||
|        (++) Key Derivation and decryption: It consumes 288 clock cycle when processing one 128-bit blobk | ||||
|    (#) Moreover 3 chaining modes are supported: | ||||
|        (++) Electronic codebook (ECB): Each plain text is encrypted/decrypted separately | ||||
|        (++) Cipher block chaining (CBC): Each block is XORed with the previous block | ||||
|        (++) Counter mode (CTR): A 128-bit counter is encrypted and then XORed with the | ||||
|           plain text to give the cipher text | ||||
|   (#) The AES peripheral supports data swapping: 1-bit, 8-bit, 16-bit and 32-bit. | ||||
|   (#) The AES peripheral supports write/read error handling with interrupt capability. | ||||
|   (#) Automatic data flow control with support of direct memory access (DMA) using | ||||
|       2 channels, one for incoming data (DMA2 Channel5), and one for outcoming data | ||||
|       (DMA2 Channel3). | ||||
| 
 | ||||
|                       ##### How to use this driver ##### | ||||
|  =============================================================================== | ||||
|     [..] | ||||
|         (#) AES AHB clock must be enabled to get write access to AES registers  | ||||
|             using RCC_AHBPeriphClockCmd(RCC_AHBPeriph_AES, ENABLE). | ||||
|         (#) Initialize the key using AES_KeyInit(). | ||||
|         (#) Configure the AES operation mode using AES_Init(). | ||||
|         (#) If required, enable interrupt source using AES_ITConfig() and | ||||
|             enable the AES interrupt vector using NVIC_Init(). | ||||
|         (#) If required, when using the DMA mode. | ||||
|             (##) Configure the DMA using DMA_Init(). | ||||
|             (##) Enable DMA requests using AES_DMAConfig(). | ||||
|         (#) Enable the AES peripheral using AES_Cmd(). | ||||
|     @endverbatim | ||||
|    | ||||
|   ****************************************************************************** | ||||
|   * @attention | ||||
|   * | ||||
|   * <h2><center>© COPYRIGHT 2012 STMicroelectronics</center></h2> | ||||
|   * | ||||
|   * Licensed under MCD-ST Liberty SW License Agreement V2, (the "License"); | ||||
|   * You may not use this file except in compliance with the License. | ||||
|   * You may obtain a copy of the License at: | ||||
|   * | ||||
|   *        http://www.st.com/software_license_agreement_liberty_v2
 | ||||
|   * | ||||
|   * Unless required by applicable law or agreed to in writing, software  | ||||
|   * distributed under the License is distributed on an "AS IS" BASIS,  | ||||
|   * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. | ||||
|   * See the License for the specific language governing permissions and | ||||
|   * limitations under the License. | ||||
|   * | ||||
|   ****************************************************************************** | ||||
|   */ | ||||
| 
 | ||||
| /* Includes ------------------------------------------------------------------*/ | ||||
| #include "stm32l1xx_aes.h" | ||||
| #include "stm32l1xx_rcc.h" | ||||
| 
 | ||||
| /** @addtogroup STM32L1xx_StdPeriph_Driver
 | ||||
|   * @{ | ||||
|   */ | ||||
| 
 | ||||
| /** @defgroup AES 
 | ||||
|   * @brief AES driver modules | ||||
|   * @{ | ||||
|   */  | ||||
| 
 | ||||
| /* Private typedef -----------------------------------------------------------*/ | ||||
| /* Private define ------------------------------------------------------------*/ | ||||
| #define CR_CLEAR_MASK  ((uint32_t)0xFFFFFF81) | ||||
| 
 | ||||
| /* Private macro -------------------------------------------------------------*/ | ||||
| /* Private variables ---------------------------------------------------------*/ | ||||
| /* Private function prototypes -----------------------------------------------*/ | ||||
| /* Private functions ---------------------------------------------------------*/ | ||||
| 
 | ||||
| /** @defgroup AES_Private_Functions
 | ||||
|   * @{ | ||||
|   */ | ||||
| 
 | ||||
| /** @defgroup AES_Group1 Initialization and configuration
 | ||||
|  *  @brief   Initialization and configuration. | ||||
|  * | ||||
| @verbatim | ||||
|  =============================================================================== | ||||
|                 ##### Initialization and configuration ##### | ||||
|  =============================================================================== | ||||
| 
 | ||||
| @endverbatim | ||||
|   * @{ | ||||
|   */   | ||||
| 
 | ||||
|   /**
 | ||||
|   * @brief  Deinitializes AES peripheral registers to their default reset values. | ||||
|   * @param  None | ||||
|   * @retval None | ||||
|   */ | ||||
| void AES_DeInit(void) | ||||
| { | ||||
|   /* Enable AES reset state */ | ||||
|   RCC_AHBPeriphResetCmd(RCC_AHBPeriph_AES, ENABLE); | ||||
|   /* Release AES from reset state */ | ||||
|   RCC_AHBPeriphResetCmd(RCC_AHBPeriph_AES, DISABLE); | ||||
| } | ||||
| 
 | ||||
| /**
 | ||||
|   * @brief  Initializes the AES peripheral according to the specified parameters | ||||
|   *         in the AES_InitStruct: | ||||
|   *           - AES_Operation: specifies the operation mode (encryption, decryption...). | ||||
|   *           - AES_Chaining: specifies the chaining mode (ECB, CBC or CTR). | ||||
|   *           - AES_DataType: specifies the data swapping type: 32-bit, 16-bit, 8-bit or 1-bit. | ||||
|   * @note   If AES is already enabled, use AES_Cmd(DISABLE) before setting the new  | ||||
|   *         configuration (When AES is enabled, setting configuration is forbidden). | ||||
|   * @param  AES_InitStruct: pointer to an AES_InitTypeDef structure that contains  | ||||
|   *         the configuration information for AES peripheral. | ||||
|   * @retval None | ||||
|   */ | ||||
| void AES_Init(AES_InitTypeDef* AES_InitStruct) | ||||
| { | ||||
|   uint32_t tmpreg = 0; | ||||
|    | ||||
|   /* Check the parameters */ | ||||
|   assert_param(IS_AES_MODE(AES_InitStruct->AES_Operation)); | ||||
|   assert_param(IS_AES_CHAINING(AES_InitStruct->AES_Chaining)); | ||||
|   assert_param(IS_AES_DATATYPE(AES_InitStruct->AES_DataType)); | ||||
| 
 | ||||
|   /* Get AES CR register value */ | ||||
|   tmpreg = AES->CR; | ||||
|    | ||||
|   /* Clear DATATYPE[1:0], MODE[1:0] and CHMOD[1:0] bits */ | ||||
|   tmpreg &= (uint32_t)CR_CLEAR_MASK; | ||||
|    | ||||
|   tmpreg |= (AES_InitStruct->AES_Operation | AES_InitStruct->AES_Chaining | AES_InitStruct->AES_DataType); | ||||
| 
 | ||||
|   AES->CR = (uint32_t) tmpreg; | ||||
| } | ||||
| 
 | ||||
| /**
 | ||||
|   * @brief  Initializes the AES Keys according to the specified parameters in the AES_KeyInitStruct. | ||||
|   * @param  AES_KeyInitStruct: pointer to an AES_KeyInitTypeDef structure that | ||||
|   *         contains the configuration information for the specified AES Keys. | ||||
|   * @note   This function must be called while the AES is disabled. | ||||
|   * @note   In encryption, key derivation and key derivation + decryption modes, | ||||
|   *         AES_KeyInitStruct must contain the encryption key. | ||||
|   *         In decryption mode, AES_KeyInitStruct must contain the decryption key. | ||||
|   * @retval None | ||||
|   */ | ||||
| void AES_KeyInit(AES_KeyInitTypeDef* AES_KeyInitStruct) | ||||
| { | ||||
|   AES->KEYR0 = AES_KeyInitStruct->AES_Key0; | ||||
|   AES->KEYR1 = AES_KeyInitStruct->AES_Key1; | ||||
|   AES->KEYR2 = AES_KeyInitStruct->AES_Key2; | ||||
|   AES->KEYR3 = AES_KeyInitStruct->AES_Key3; | ||||
| } | ||||
| 
 | ||||
| /**
 | ||||
|   * @brief  Initializes the AES Initialization Vector IV according to  | ||||
|   *         the specified parameters in the AES_IVInitStruct. | ||||
|   * @param  AES_KeyInitStruct: pointer to an AES_IVInitTypeDef structure that | ||||
|   *         contains the configuration information for the specified AES IV. | ||||
|   * @note   When ECB chaining mode is selected, Initialization Vector IV has no | ||||
|   *         meaning. | ||||
|   *         When CTR chaining mode is selected, AES_IV0 contains the CTR value. | ||||
|   *         AES_IV1, AES_IV2 and AES_IV3 contains nonce value. | ||||
|   * @retval None | ||||
|   */ | ||||
| void AES_IVInit(AES_IVInitTypeDef* AES_IVInitStruct) | ||||
| { | ||||
|   AES->IVR0 = AES_IVInitStruct->AES_IV0; | ||||
|   AES->IVR1 = AES_IVInitStruct->AES_IV1; | ||||
|   AES->IVR2 = AES_IVInitStruct->AES_IV2; | ||||
|   AES->IVR3 = AES_IVInitStruct->AES_IV3; | ||||
| } | ||||
| 
 | ||||
| /**
 | ||||
|   * @brief  Enable or disable the AES peripheral. | ||||
|   * @param  NewState: new state of the AES peripheral. | ||||
|   *         This parameter can be: ENABLE or DISABLE. | ||||
|   * @note   The key must be written while AES is disabled. | ||||
|   * @retval None | ||||
|   */ | ||||
| void AES_Cmd(FunctionalState NewState) | ||||
| { | ||||
|   /* Check the parameter */ | ||||
|   assert_param(IS_FUNCTIONAL_STATE(NewState)); | ||||
| 
 | ||||
|   if (NewState != DISABLE) | ||||
|   { | ||||
|     /* Enable the AES peripheral */ | ||||
|     AES->CR |= (uint32_t) AES_CR_EN;   /**< AES Enable */ | ||||
|   } | ||||
|   else | ||||
|   { | ||||
|     /* Disable the AES peripheral */ | ||||
|     AES->CR &= (uint32_t)(~AES_CR_EN);  /**< AES Disable */ | ||||
|   } | ||||
| } | ||||
| 
 | ||||
| /**
 | ||||
|   * @} | ||||
|   */ | ||||
| 
 | ||||
| /** @defgroup AES_Group2 Structures initialization functions
 | ||||
|  *  @brief   Structures initialization. | ||||
|  * | ||||
| @verbatim | ||||
|  =============================================================================== | ||||
|               ##### Structures initialization functions ##### | ||||
|  =============================================================================== | ||||
| 
 | ||||
| @endverbatim | ||||
|   * @{ | ||||
|   */ | ||||
| 
 | ||||
| /**
 | ||||
|   * @brief  Fills each AES_InitStruct member with its default value. | ||||
|   * @param  AES_InitStruct: pointer to an AES_InitTypeDef structure which will  | ||||
|   *         be initialized. | ||||
|   * @retval None | ||||
|   */ | ||||
| void AES_StructInit(AES_InitTypeDef* AES_InitStruct) | ||||
| { | ||||
|   AES_InitStruct->AES_Operation = AES_Operation_Encryp; | ||||
|   AES_InitStruct->AES_Chaining = AES_Chaining_ECB; | ||||
|   AES_InitStruct->AES_DataType = AES_DataType_32b; | ||||
| } | ||||
| 
 | ||||
| /**
 | ||||
|   * @brief  Fills each AES_KeyInitStruct member with its default value. | ||||
|   * @param  AES_KeyInitStruct: pointer to an AES_KeyInitStruct structure which  | ||||
|   *         will be initialized. | ||||
|   * @retval None | ||||
|   */ | ||||
| void AES_KeyStructInit(AES_KeyInitTypeDef* AES_KeyInitStruct) | ||||
| { | ||||
|   AES_KeyInitStruct->AES_Key0 = 0x00000000; | ||||
|   AES_KeyInitStruct->AES_Key1 = 0x00000000; | ||||
|   AES_KeyInitStruct->AES_Key2 = 0x00000000; | ||||
|   AES_KeyInitStruct->AES_Key3 = 0x00000000; | ||||
| } | ||||
| 
 | ||||
| /**
 | ||||
|   * @brief  Fills each AES_IVInitStruct member with its default value. | ||||
|   * @param  AES_IVInitStruct: pointer to an AES_IVInitTypeDef structure which | ||||
|   *         will be initialized. | ||||
|   * @retval None | ||||
|   */ | ||||
| void AES_IVStructInit(AES_IVInitTypeDef* AES_IVInitStruct) | ||||
| { | ||||
|   AES_IVInitStruct->AES_IV0 = 0x00000000; | ||||
|   AES_IVInitStruct->AES_IV1 = 0x00000000; | ||||
|   AES_IVInitStruct->AES_IV2 = 0x00000000; | ||||
|   AES_IVInitStruct->AES_IV3 = 0x00000000; | ||||
| } | ||||
| 
 | ||||
| /**
 | ||||
|   * @} | ||||
|   */ | ||||
| 
 | ||||
| /** @defgroup AES_Group3 AES Read and Write
 | ||||
|  *  @brief   AES Read and Write. | ||||
|  * | ||||
| @verbatim | ||||
|  =============================================================================== | ||||
|                   ##### AES Read and Write functions ##### | ||||
|  =============================================================================== | ||||
| 
 | ||||
| @endverbatim | ||||
|   * @{ | ||||
|   */ | ||||
| 
 | ||||
| /**
 | ||||
|   * @brief  Write data in DINR register to be processed by AES peripheral. | ||||
|   * @note   To process 128-bit data (4 * 32-bit), this function must be called | ||||
|   *         four times to write the 128-bit data in the 32-bit register DINR. | ||||
|   * @note   When an unexpected write to DOUTR register is detected, WRERR flag is | ||||
|   *         set. | ||||
|   * @param  Data: The data to be processed. | ||||
|   * @retval None | ||||
|   */ | ||||
| void AES_WriteSubData(uint32_t Data) | ||||
| { | ||||
|   /* Write Data */ | ||||
|   AES->DINR = Data; | ||||
| } | ||||
| 
 | ||||
| /**
 | ||||
|   * @brief  Returns the data in DOUTR register processed by AES peripheral. | ||||
|   * @note   This function must be called four times to get the 128-bit data. | ||||
|   * @note   When an unexpected read of DINR register is detected, RDERR flag is | ||||
|   *         set. | ||||
|   * @retval The processed data. | ||||
|   */ | ||||
| uint32_t AES_ReadSubData(void) | ||||
| { | ||||
|   /* Read Data */ | ||||
|   return AES->DOUTR; | ||||
| } | ||||
| 
 | ||||
| /**
 | ||||
|   * @brief  Read the Key value. | ||||
|   * @param  AES_KeyInitStruct: pointer to an AES_KeyInitTypeDef structure which | ||||
|   *         will contain the key. | ||||
|   * @note   When the key derivation mode is selected, AES must be disabled | ||||
|   *         (AES_Cmd(DISABLE)) before reading the decryption key. | ||||
|   *         Reading the key while the AES is enabled will return unpredictable | ||||
|   *         value. | ||||
|   * @retval None | ||||
|   */ | ||||
| void AES_ReadKey(AES_KeyInitTypeDef* AES_KeyInitStruct) | ||||
| { | ||||
|   AES_KeyInitStruct->AES_Key0 = AES->KEYR0; | ||||
|   AES_KeyInitStruct->AES_Key1 = AES->KEYR1; | ||||
|   AES_KeyInitStruct->AES_Key2 = AES->KEYR2; | ||||
|   AES_KeyInitStruct->AES_Key3 = AES->KEYR3; | ||||
| } | ||||
| 
 | ||||
| /**
 | ||||
|   * @brief  Read the Initialization Vector IV value. | ||||
|   * @param  AES_IVInitStruct: pointer to an AES_IVInitTypeDef structure which | ||||
|   *         will contain the Initialization Vector IV. | ||||
|   * @note   When the AES is enabled Reading the Initialization Vector IV value | ||||
|   *         will return 0. The AES must be disabled using AES_Cmd(DISABLE) | ||||
|   *         to get the right value. | ||||
|   * @note   When ECB chaining mode is selected, Initialization Vector IV has no | ||||
|   *         meaning. | ||||
|   *         When CTR chaining mode is selected, AES_IV0 contains 32-bit Counter value. | ||||
|   *         AES_IV1, AES_IV2 and AES_IV3 contains nonce value. | ||||
|   * @retval None | ||||
|   */ | ||||
| void AES_ReadIV(AES_IVInitTypeDef* AES_IVInitStruct) | ||||
| { | ||||
|   AES_IVInitStruct->AES_IV0 = AES->IVR0; | ||||
|   AES_IVInitStruct->AES_IV1 = AES->IVR1; | ||||
|   AES_IVInitStruct->AES_IV2 = AES->IVR2; | ||||
|   AES_IVInitStruct->AES_IV3 = AES->IVR3; | ||||
| } | ||||
| 
 | ||||
| /**
 | ||||
|   * @} | ||||
|   */ | ||||
| 
 | ||||
| /** @defgroup AES_Group4 DMA transfers management functions
 | ||||
|  *  @brief   DMA transfers management function. | ||||
|  * | ||||
| @verbatim | ||||
|  =============================================================================== | ||||
|                ##### DMA transfers management functions ##### | ||||
|  =============================================================================== | ||||
| 
 | ||||
| @endverbatim | ||||
|   * @{ | ||||
|   */ | ||||
| 
 | ||||
| /**
 | ||||
|   * @brief  Configures the AES DMA interface. | ||||
|   * @param  AES_DMATransfer: Specifies the AES DMA transfer. | ||||
|   *   This parameter can be one of the following values: | ||||
|   *     @arg AES_DMATransfer_In: When selected, DMA manages the data input phase. | ||||
|   *     @arg AES_DMATransfer_Out: When selected, DMA manages the data output phase. | ||||
|   *     @arg AES_DMATransfer_InOut: When selected, DMA manages both the data input/output phases. | ||||
|   * @param  NewState Indicates the new state of the AES DMA interface. | ||||
|   *           This parameter can be: ENABLE or DISABLE. | ||||
|   * @note   The DMA has no action in key derivation mode. | ||||
|   * @retval None | ||||
|   */ | ||||
| void AES_DMAConfig(uint32_t AES_DMATransfer, FunctionalState NewState) | ||||
| { | ||||
|   /* Check the parameter */ | ||||
|   assert_param(IS_AES_DMA_TRANSFER(AES_DMATransfer)); | ||||
| 
 | ||||
|   if (NewState != DISABLE) | ||||
|   { | ||||
|     /* Enable the DMA transfer */ | ||||
|     AES->CR |= (uint32_t) AES_DMATransfer; | ||||
|   } | ||||
|   else | ||||
|   { | ||||
|     /* Disable the DMA transfer */ | ||||
|     AES->CR &= (uint32_t)(~AES_DMATransfer); | ||||
|   } | ||||
| } | ||||
| 
 | ||||
| /**
 | ||||
|   * @} | ||||
|   */ | ||||
| 
 | ||||
| /** @defgroup AES_Group5 Interrupts and flags management functions
 | ||||
|  *  @brief   Interrupts and flags management functions. | ||||
|  * | ||||
| @verbatim | ||||
| 
 | ||||
|  =============================================================================== | ||||
|            ##### Interrupts and flags management functions ##### | ||||
|  =============================================================================== | ||||
| @endverbatim | ||||
|   * @{ | ||||
|   */ | ||||
| 
 | ||||
| /**
 | ||||
|   * @brief  Enables or disables the specified AES interrupt. | ||||
|   * @param  AES_IT: Specifies the AES interrupt source to enable/disable. | ||||
|   *     This parameter can be any combinations of the following values: | ||||
|   *     @arg AES_IT_CC: Computation Complete Interrupt. If enabled, once CCF  | ||||
|   *                     flag is set an interrupt is generated. | ||||
|   *     @arg AES_IT_ERR: Error Interrupt. If enabled, once a read error | ||||
|   *                      flags (RDERR) or write error flag (WRERR) is set, | ||||
|   *                      an interrupt is generated. | ||||
|   * @param  NewState: The new state of the AES interrupt source. | ||||
|   *                   This parameter can be: ENABLE or DISABLE. | ||||
|   * @retval None | ||||
|   */ | ||||
| void AES_ITConfig(uint32_t AES_IT, FunctionalState NewState) | ||||
| { | ||||
|   /* Check the parameters */ | ||||
|   assert_param(IS_FUNCTIONAL_STATE(NewState)); | ||||
|   assert_param(IS_AES_IT(AES_IT)); | ||||
| 
 | ||||
|   if (NewState != DISABLE) | ||||
|   { | ||||
|     AES->CR |= (uint32_t) AES_IT;    /**< AES_IT Enable */ | ||||
|   } | ||||
|   else | ||||
|   { | ||||
|     AES->CR &= (uint32_t)(~AES_IT);  /**< AES_IT Disable */ | ||||
|   } | ||||
| } | ||||
| 
 | ||||
| /**
 | ||||
|   * @brief  Checks whether the specified AES flag is set or not. | ||||
|   * @param  AES_FLAG specifies the flag to check. | ||||
|   *   This parameter can be one of the following values: | ||||
|   *     @arg AES_FLAG_CCF: Computation Complete Flag is set by hardware when | ||||
|   *                        he computation phase is completed. | ||||
|   *     @arg AES_FLAG_RDERR: Read Error Flag is set when an unexpected read | ||||
|   *                          operation of DOUTR register is detected. | ||||
|   *     @arg AES_FLAG_WRERR: Write Error Flag  is set when an unexpected write | ||||
|   *                          operation in DINR is detected. | ||||
|   * @retval FlagStatus (SET or RESET) | ||||
|   */ | ||||
| FlagStatus AES_GetFlagStatus(uint32_t AES_FLAG) | ||||
| { | ||||
|   FlagStatus bitstatus = RESET; | ||||
| 
 | ||||
|   /* Check parameters */ | ||||
|   assert_param(IS_AES_FLAG(AES_FLAG)); | ||||
| 
 | ||||
|   if ((AES->SR & AES_FLAG) != (uint32_t)RESET) | ||||
|   { | ||||
|     bitstatus = SET; | ||||
|   } | ||||
|   else | ||||
|   { | ||||
|     bitstatus = RESET; | ||||
|   } | ||||
|      | ||||
|   /* Return the AES_FLAG status */ | ||||
|   return  bitstatus; | ||||
| } | ||||
| 
 | ||||
| /**
 | ||||
|   * @brief  Clears the AES flags. | ||||
|   * @param  AES_FLAG: specifies the flag to clear. | ||||
|   *         This parameter can be: | ||||
|   *     @arg AES_FLAG_CCF: Computation Complete Flag is cleared by setting CCFC | ||||
|   *                        bit in CR register. | ||||
|   *     @arg AES_FLAG_RDERR: Read Error is cleared by setting ERRC bit in  | ||||
|   *                          CR register. | ||||
|   *     @arg AES_FLAG_WRERR: Write Error is cleared by setting ERRC bit in | ||||
|   *                          CR register. | ||||
|   * @retval None | ||||
|   */ | ||||
| void AES_ClearFlag(uint32_t AES_FLAG) | ||||
| { | ||||
|   /* Check the parameters */ | ||||
|   assert_param(IS_AES_FLAG(AES_FLAG)); | ||||
| 
 | ||||
|   /* Check if AES_FLAG is AES_FLAG_CCF */ | ||||
|   if (AES_FLAG == AES_FLAG_CCF) | ||||
|   { | ||||
|     /* Clear CCF flag by setting CCFC bit */ | ||||
|     AES->CR |= (uint32_t) AES_CR_CCFC; | ||||
|   } | ||||
|   else /* AES_FLAG is AES_FLAG_RDERR or AES_FLAG_WRERR */ | ||||
|   { | ||||
|     /* Clear RDERR and WRERR flags by setting ERRC bit */ | ||||
|     AES->CR |= (uint32_t) AES_CR_ERRC; | ||||
|   } | ||||
| } | ||||
| 
 | ||||
| /**
 | ||||
|   * @brief  Checks whether the specified AES interrupt has occurred or not. | ||||
|   * @param  AES_IT: Specifies the AES interrupt pending bit to check. | ||||
|   *         This parameter can be: | ||||
|   *     @arg AES_IT_CC: Computation Complete Interrupt. | ||||
|   *     @arg AES_IT_ERR: Error Interrupt. | ||||
|   * @retval ITStatus The new state of AES_IT (SET or RESET). | ||||
|   */ | ||||
| ITStatus AES_GetITStatus(uint32_t AES_IT) | ||||
| { | ||||
|   ITStatus itstatus = RESET; | ||||
|   uint32_t cciebitstatus = RESET, ccfbitstatus = RESET; | ||||
| 
 | ||||
|   /* Check parameters */ | ||||
|   assert_param(IS_AES_GET_IT(AES_IT)); | ||||
| 
 | ||||
|   cciebitstatus = AES->CR & AES_CR_CCIE; | ||||
|   ccfbitstatus =  AES->SR & AES_SR_CCF; | ||||
| 
 | ||||
|   /* Check if AES_IT is AES_IT_CC */ | ||||
|   if (AES_IT == AES_IT_CC) | ||||
|   { | ||||
|     /* Check the status of the specified AES interrupt */ | ||||
|     if (((cciebitstatus) != (uint32_t)RESET) && ((ccfbitstatus) != (uint32_t)RESET)) | ||||
|     { | ||||
|       /* Interrupt occurred */ | ||||
|       itstatus = SET; | ||||
|     } | ||||
|     else | ||||
|     { | ||||
|       /* Interrupt didn't occur */ | ||||
|       itstatus = RESET; | ||||
|     } | ||||
|   } | ||||
|   else /* AES_IT is AES_IT_ERR */ | ||||
|   { | ||||
|     /* Check the status of the specified AES interrupt */ | ||||
|     if ((AES->CR & AES_CR_ERRIE) != RESET) | ||||
|     { | ||||
|       /* Check if WRERR or RDERR flags are set */ | ||||
|       if ((AES->SR & (uint32_t)(AES_SR_WRERR | AES_SR_RDERR)) != (uint16_t)RESET) | ||||
|       { | ||||
|         /* Interrupt occurred */ | ||||
|         itstatus = SET; | ||||
|       } | ||||
|       else | ||||
|       { | ||||
|         /* Interrupt didn't occur */ | ||||
|         itstatus = RESET; | ||||
|       } | ||||
|     } | ||||
|     else | ||||
|     { | ||||
|       /* Interrupt didn't occur */ | ||||
|       itstatus = (ITStatus) RESET; | ||||
|     } | ||||
|   } | ||||
| 
 | ||||
|   /* Return the AES_IT status */ | ||||
|   return itstatus; | ||||
| } | ||||
| 
 | ||||
| /**
 | ||||
|   * @brief  Clears the AES's interrupt pending bits. | ||||
|   * @param  AES_IT: specifies the interrupt pending bit to clear. | ||||
|   *   This parameter can be any combinations of the following values: | ||||
|   *     @arg AES_IT_CC: Computation Complete Interrupt. | ||||
|   *     @arg AES_IT_ERR: Error Interrupt. | ||||
|   * @retval None | ||||
|   */ | ||||
| void AES_ClearITPendingBit(uint32_t AES_IT) | ||||
| { | ||||
|   /* Check the parameters */ | ||||
|   assert_param(IS_AES_IT(AES_IT)); | ||||
| 
 | ||||
|   /* Clear the interrupt pending bit */ | ||||
|   AES->CR |= (uint32_t) (AES_IT >> (uint32_t) 0x00000002); | ||||
| } | ||||
| 
 | ||||
| /**
 | ||||
|   * @} | ||||
|   */ | ||||
| 
 | ||||
| /**
 | ||||
|   * @} | ||||
|   */ | ||||
| 
 | ||||
| /**
 | ||||
|   * @} | ||||
|   */ | ||||
| 
 | ||||
| /************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE****/ | ||||
|  | @ -1,679 +0,0 @@ | |||
| /**
 | ||||
|   ****************************************************************************** | ||||
|   * @file    stm32l1xx_aes_util.c | ||||
|   * @author  MCD Application Team | ||||
|   * @version V1.1.1 | ||||
|   * @date    05-March-2012 | ||||
|   * @brief   This file provides high level functions to encrypt and decrypt an  | ||||
|   *          input message using AES in ECB/CBC/CTR modes. | ||||
|   * | ||||
|   *  @verbatim | ||||
| 
 | ||||
| ================================================================================ | ||||
|                         ##### How to use this driver ##### | ||||
| ================================================================================ | ||||
|           [..] | ||||
|            (#) Enable The AES controller clock using  | ||||
|                RCC_AHBPeriphClockCmd(RCC_AHBPeriph_AES, ENABLE); function. | ||||
| 
 | ||||
|            (#) Use AES_ECB_Encrypt() function to encrypt an input message in ECB mode. | ||||
|            (#) Use AES_ECB_Decrypt() function to decrypt an input message in ECB mode. | ||||
| 
 | ||||
|            (#) Use AES_CBC_Encrypt() function to encrypt an input message in CBC mode. | ||||
|            (#) Use AES_CBC_Decrypt() function to decrypt an input message in CBC mode. | ||||
| 
 | ||||
|            (#) Use AES_CTR_Encrypt() function to encrypt an input message in CTR mode. | ||||
|            (#) Use AES_CTR_Decrypt() function to decrypt an input message in CTR mode. | ||||
| 
 | ||||
|   *  @endverbatim | ||||
|   * | ||||
|   ****************************************************************************** | ||||
|   * @attention | ||||
|   * | ||||
|   * <h2><center>© COPYRIGHT 2012 STMicroelectronics</center></h2> | ||||
|   * | ||||
|   * Licensed under MCD-ST Liberty SW License Agreement V2, (the "License"); | ||||
|   * You may not use this file except in compliance with the License. | ||||
|   * You may obtain a copy of the License at: | ||||
|   * | ||||
|   *        http://www.st.com/software_license_agreement_liberty_v2
 | ||||
|   * | ||||
|   * Unless required by applicable law or agreed to in writing, software  | ||||
|   * distributed under the License is distributed on an "AS IS" BASIS,  | ||||
|   * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. | ||||
|   * See the License for the specific language governing permissions and | ||||
|   * limitations under the License. | ||||
|   * | ||||
|   ****************************************************************************** | ||||
|   */ | ||||
| 
 | ||||
| /* Includes ------------------------------------------------------------------*/ | ||||
| #include "stm32l1xx_aes.h" | ||||
| 
 | ||||
| /** @addtogroup STM32L1xx_StdPeriph_Driver
 | ||||
|   * @{ | ||||
|   */ | ||||
| 
 | ||||
| /** @addtogroup AES 
 | ||||
|   * @brief AES driver modules | ||||
|   * @{ | ||||
|   */ | ||||
| 
 | ||||
| /* Private typedef -----------------------------------------------------------*/ | ||||
| /* Private define ------------------------------------------------------------*/ | ||||
| #define AES_CC_TIMEOUT    ((uint32_t) 0x00010000) | ||||
| 
 | ||||
| /* Private macro -------------------------------------------------------------*/ | ||||
| /* Private variables ---------------------------------------------------------*/ | ||||
| /* Private function prototypes -----------------------------------------------*/ | ||||
| /* Private functions ---------------------------------------------------------*/ | ||||
| 
 | ||||
| /** @defgroup AES_Private_Functions
 | ||||
|   * @{ | ||||
|   */  | ||||
| 
 | ||||
| /** @defgroup AES_Group6 High Level AES functions
 | ||||
|  *  @brief   High Level AES functions  | ||||
|  * | ||||
| @verbatim | ||||
| ================================================================================ | ||||
|                          ##### High Level AES functions ##### | ||||
| ================================================================================ | ||||
| 
 | ||||
| @endverbatim | ||||
|   * @{ | ||||
|   */ | ||||
| 
 | ||||
| /**
 | ||||
|   * @brief  Encrypt using AES in ECB Mode | ||||
|   * @param  Key: Key used for AES algorithm. | ||||
|   * @param  Input: pointer to the Input buffer. | ||||
|   * @param  Ilength: length of the Input buffer, must be a multiple of 16 bytes. | ||||
|   * @param  Output: pointer to the returned buffer. | ||||
|   * @retval An ErrorStatus enumeration value: | ||||
|   *          - SUCCESS: Operation done | ||||
|   *          - ERROR: Operation failed | ||||
|   */ | ||||
| ErrorStatus AES_ECB_Encrypt(uint8_t* Key, uint8_t* Input, uint32_t Ilength, uint8_t* Output) | ||||
| { | ||||
|   AES_InitTypeDef AES_InitStructure; | ||||
|   AES_KeyInitTypeDef  AES_KeyInitStructure; | ||||
|   ErrorStatus status = SUCCESS; | ||||
|   uint32_t keyaddr    = (uint32_t)Key; | ||||
|   uint32_t inputaddr  = (uint32_t)Input; | ||||
|   uint32_t outputaddr = (uint32_t)Output; | ||||
|   __IO uint32_t counter = 0; | ||||
|   uint32_t ccstatus = 0; | ||||
|   uint32_t i = 0; | ||||
| 
 | ||||
|   /* AES Key initialisation */ | ||||
|   AES_KeyInitStructure.AES_Key3 = __REV(*(uint32_t*)(keyaddr)); | ||||
|   keyaddr += 4; | ||||
|   AES_KeyInitStructure.AES_Key2 = __REV(*(uint32_t*)(keyaddr)); | ||||
|   keyaddr += 4; | ||||
|   AES_KeyInitStructure.AES_Key1 = __REV(*(uint32_t*)(keyaddr)); | ||||
|   keyaddr += 4; | ||||
|   AES_KeyInitStructure.AES_Key0 = __REV(*(uint32_t*)(keyaddr)); | ||||
|   AES_KeyInit(&AES_KeyInitStructure); | ||||
| 
 | ||||
|   /* AES configuration */ | ||||
|   AES_InitStructure.AES_Operation = AES_Operation_Encryp; | ||||
|   AES_InitStructure.AES_Chaining = AES_Chaining_ECB; | ||||
|   AES_InitStructure.AES_DataType = AES_DataType_8b; | ||||
|   AES_Init(&AES_InitStructure); | ||||
| 
 | ||||
|   /* Enable AES */ | ||||
|   AES_Cmd(ENABLE); | ||||
| 
 | ||||
|   for(i = 0; ((i < Ilength) && (status != ERROR)); i += 16) | ||||
|   { | ||||
|     AES_WriteSubData(*(uint32_t*)(inputaddr)); | ||||
|     inputaddr += 4; | ||||
|     AES_WriteSubData(*(uint32_t*)(inputaddr)); | ||||
|     inputaddr += 4; | ||||
|     AES_WriteSubData(*(uint32_t*)(inputaddr)); | ||||
|     inputaddr += 4; | ||||
|     AES_WriteSubData(*(uint32_t*)(inputaddr)); | ||||
|     inputaddr += 4; | ||||
|      | ||||
|     /* Wait for CCF flag to be set */ | ||||
|     counter = 0; | ||||
|     do | ||||
|     { | ||||
|       ccstatus = AES_GetFlagStatus(AES_FLAG_CCF); | ||||
|       counter++; | ||||
|     }while((counter != AES_CC_TIMEOUT) && (ccstatus == RESET)); | ||||
|      | ||||
|     if (ccstatus == RESET) | ||||
|     { | ||||
|       status = ERROR; | ||||
|     } | ||||
|     else | ||||
|     { | ||||
|       /* Clear CCF flag */ | ||||
|       AES_ClearFlag(AES_FLAG_CCF); | ||||
|       /* Read cipher text */ | ||||
|       *(uint32_t*)(outputaddr) = AES_ReadSubData(); | ||||
|       outputaddr += 4; | ||||
|       *(uint32_t*)(outputaddr) = AES_ReadSubData(); | ||||
|       outputaddr += 4; | ||||
|       *(uint32_t*)(outputaddr) = AES_ReadSubData(); | ||||
|       outputaddr += 4; | ||||
|       *(uint32_t*)(outputaddr) = AES_ReadSubData(); | ||||
|       outputaddr += 4; | ||||
|     } | ||||
|   } | ||||
|    | ||||
|   /* Disable AES before starting new processing */ | ||||
|   AES_Cmd(DISABLE); | ||||
| 
 | ||||
|   return status; | ||||
| } | ||||
| 
 | ||||
| /**
 | ||||
|   * @brief  Decrypt using AES in ECB Mode | ||||
|   * @param  Key: Key used for AES algorithm. | ||||
|   * @param  Input: pointer to the Input buffer. | ||||
|   * @param  Ilength: length of the Input buffer, must be a multiple of 16 bytes. | ||||
|   * @param  Output: pointer to the returned buffer. | ||||
|   * @retval An ErrorStatus enumeration value: | ||||
|   *          - SUCCESS: Operation done | ||||
|   *          - ERROR: Operation failed | ||||
|   */ | ||||
| ErrorStatus AES_ECB_Decrypt(uint8_t* Key, uint8_t* Input, uint32_t Ilength, uint8_t* Output) | ||||
| { | ||||
|   AES_InitTypeDef AES_InitStructure; | ||||
|   AES_KeyInitTypeDef  AES_KeyInitStructure; | ||||
|   ErrorStatus status = SUCCESS; | ||||
|   uint32_t keyaddr    = (uint32_t)Key; | ||||
|   uint32_t inputaddr  = (uint32_t)Input; | ||||
|   uint32_t outputaddr = (uint32_t)Output; | ||||
|   __IO uint32_t counter = 0; | ||||
|   uint32_t ccstatus = 0; | ||||
|   uint32_t i = 0; | ||||
| 
 | ||||
|   /* AES Key initialisation */ | ||||
|   AES_KeyInitStructure.AES_Key3 = __REV(*(uint32_t*)(keyaddr)); | ||||
|   keyaddr += 4; | ||||
|   AES_KeyInitStructure.AES_Key2 = __REV(*(uint32_t*)(keyaddr)); | ||||
|   keyaddr += 4; | ||||
|   AES_KeyInitStructure.AES_Key1 = __REV(*(uint32_t*)(keyaddr)); | ||||
|   keyaddr += 4; | ||||
|   AES_KeyInitStructure.AES_Key0 = __REV(*(uint32_t*)(keyaddr)); | ||||
|   AES_KeyInit(&AES_KeyInitStructure); | ||||
| 
 | ||||
|   /* AES configuration */ | ||||
|   AES_InitStructure.AES_Operation = AES_Operation_KeyDerivAndDecryp; | ||||
|   AES_InitStructure.AES_Chaining = AES_Chaining_ECB; | ||||
|   AES_InitStructure.AES_DataType = AES_DataType_8b; | ||||
|   AES_Init(&AES_InitStructure); | ||||
| 
 | ||||
|   /* Enable AES */ | ||||
|   AES_Cmd(ENABLE); | ||||
| 
 | ||||
|   for(i = 0; ((i < Ilength) && (status != ERROR)); i += 16) | ||||
|   { | ||||
|     AES_WriteSubData(*(uint32_t*)(inputaddr)); | ||||
|     inputaddr += 4; | ||||
|     AES_WriteSubData(*(uint32_t*)(inputaddr)); | ||||
|     inputaddr += 4; | ||||
|     AES_WriteSubData(*(uint32_t*)(inputaddr)); | ||||
|     inputaddr += 4; | ||||
|     AES_WriteSubData(*(uint32_t*)(inputaddr)); | ||||
|     inputaddr += 4; | ||||
|      | ||||
|      /* Wait for CCF flag to be set */ | ||||
|     counter = 0; | ||||
|     do | ||||
|     { | ||||
|       ccstatus = AES_GetFlagStatus(AES_FLAG_CCF); | ||||
|       counter++; | ||||
|     }while((counter != AES_CC_TIMEOUT) && (ccstatus == RESET)); | ||||
|      | ||||
|     if (ccstatus == RESET) | ||||
|     { | ||||
|       status = ERROR; | ||||
|     } | ||||
|     else | ||||
|     { | ||||
|       /* Clear CCF flag */ | ||||
|       AES_ClearFlag(AES_FLAG_CCF); | ||||
| 
 | ||||
|       /* Read cipher text */ | ||||
|       *(uint32_t*)(outputaddr) = AES_ReadSubData(); | ||||
|       outputaddr += 4; | ||||
|       *(uint32_t*)(outputaddr) = AES_ReadSubData(); | ||||
|       outputaddr += 4; | ||||
|       *(uint32_t*)(outputaddr) = AES_ReadSubData(); | ||||
|       outputaddr += 4; | ||||
|       *(uint32_t*)(outputaddr) = AES_ReadSubData(); | ||||
|       outputaddr += 4; | ||||
|     } | ||||
|   } | ||||
| 
 | ||||
|   /* Disable AES before starting new processing */ | ||||
|   AES_Cmd(DISABLE); | ||||
| 
 | ||||
|   return status; | ||||
| } | ||||
| 
 | ||||
| /**
 | ||||
|   * @brief  Encrypt using AES in CBC Mode | ||||
|   * @param  InitVectors: Initialisation Vectors used for AES algorithm. | ||||
|   * @param  Key: Key used for AES algorithm. | ||||
|   * @param  Input: pointer to the Input buffer. | ||||
|   * @param  Ilength: length of the Input buffer, must be a multiple of 16 bytes. | ||||
|   * @param  Output: pointer to the returned buffer. | ||||
|   * @retval An ErrorStatus enumeration value: | ||||
|   *          - SUCCESS: Operation done | ||||
|   *          - ERROR: Operation failed | ||||
|   */ | ||||
| ErrorStatus AES_CBC_Encrypt(uint8_t* Key, uint8_t InitVectors[16], uint8_t* Input, uint32_t Ilength, uint8_t* Output) | ||||
| { | ||||
|   AES_InitTypeDef AES_InitStructure; | ||||
|   AES_KeyInitTypeDef  AES_KeyInitStructure; | ||||
|   AES_IVInitTypeDef AES_IVInitStructure; | ||||
|   ErrorStatus status = SUCCESS; | ||||
|   uint32_t keyaddr    = (uint32_t)Key; | ||||
|   uint32_t inputaddr  = (uint32_t)Input; | ||||
|   uint32_t outputaddr = (uint32_t)Output; | ||||
|   uint32_t ivaddr     = (uint32_t)InitVectors; | ||||
|   __IO uint32_t counter = 0; | ||||
|   uint32_t ccstatus = 0; | ||||
|   uint32_t i = 0; | ||||
| 
 | ||||
|   /* AES Key initialisation*/ | ||||
|   AES_KeyInitStructure.AES_Key3 = __REV(*(uint32_t*)(keyaddr)); | ||||
|   keyaddr += 4; | ||||
|   AES_KeyInitStructure.AES_Key2 = __REV(*(uint32_t*)(keyaddr)); | ||||
|   keyaddr += 4; | ||||
|   AES_KeyInitStructure.AES_Key1 = __REV(*(uint32_t*)(keyaddr)); | ||||
|   keyaddr += 4; | ||||
|   AES_KeyInitStructure.AES_Key0 = __REV(*(uint32_t*)(keyaddr)); | ||||
|   AES_KeyInit(&AES_KeyInitStructure); | ||||
| 
 | ||||
|   /* AES Initialization Vectors */ | ||||
|   AES_IVInitStructure.AES_IV3 = __REV(*(uint32_t*)(ivaddr)); | ||||
|   ivaddr += 4; | ||||
|   AES_IVInitStructure.AES_IV2 = __REV(*(uint32_t*)(ivaddr)); | ||||
|   ivaddr += 4; | ||||
|   AES_IVInitStructure.AES_IV1 = __REV(*(uint32_t*)(ivaddr)); | ||||
|   ivaddr += 4; | ||||
|   AES_IVInitStructure.AES_IV0 = __REV(*(uint32_t*)(ivaddr)); | ||||
|   AES_IVInit(&AES_IVInitStructure); | ||||
| 
 | ||||
|   /* AES configuration */ | ||||
|   AES_InitStructure.AES_Operation = AES_Operation_Encryp; | ||||
|   AES_InitStructure.AES_Chaining = AES_Chaining_CBC; | ||||
|   AES_InitStructure.AES_DataType = AES_DataType_8b; | ||||
|   AES_Init(&AES_InitStructure); | ||||
| 
 | ||||
|   /* Enable AES */ | ||||
|   AES_Cmd(ENABLE); | ||||
| 
 | ||||
|   for(i = 0; ((i < Ilength) && (status != ERROR)); i += 16) | ||||
|   { | ||||
|     AES_WriteSubData(*(uint32_t*)(inputaddr)); | ||||
|     inputaddr += 4; | ||||
|     AES_WriteSubData(*(uint32_t*)(inputaddr)); | ||||
|     inputaddr += 4; | ||||
|     AES_WriteSubData(*(uint32_t*)(inputaddr)); | ||||
|     inputaddr += 4; | ||||
|     AES_WriteSubData(*(uint32_t*)(inputaddr)); | ||||
|     inputaddr += 4; | ||||
|      | ||||
|     /* Wait for CCF flag to be set */ | ||||
|     counter = 0; | ||||
|     do | ||||
|     { | ||||
|       ccstatus = AES_GetFlagStatus(AES_FLAG_CCF); | ||||
|       counter++; | ||||
|     }while((counter != AES_CC_TIMEOUT) && (ccstatus == RESET)); | ||||
|      | ||||
|     if (ccstatus == RESET) | ||||
|     { | ||||
|       status = ERROR; | ||||
|     } | ||||
|     else | ||||
|     { | ||||
|       /* Clear CCF flag */ | ||||
|       AES_ClearFlag(AES_FLAG_CCF); | ||||
| 
 | ||||
|       /* Read cipher text */ | ||||
|       *(uint32_t*)(outputaddr) = AES_ReadSubData(); | ||||
|       outputaddr += 4; | ||||
|       *(uint32_t*)(outputaddr) = AES_ReadSubData(); | ||||
|       outputaddr += 4; | ||||
|       *(uint32_t*)(outputaddr) = AES_ReadSubData(); | ||||
|       outputaddr += 4; | ||||
|       *(uint32_t*)(outputaddr) = AES_ReadSubData(); | ||||
|       outputaddr += 4; | ||||
|     } | ||||
|   } | ||||
| 
 | ||||
|   /* Disable AES before starting new processing */ | ||||
|   AES_Cmd(DISABLE); | ||||
| 
 | ||||
|   return status; | ||||
| } | ||||
| 
 | ||||
| /**
 | ||||
|   * @brief  Decrypt using AES in CBC Mode | ||||
|   * @param  InitVectors: Initialisation Vectors used for AES algorithm. | ||||
|   * @param  Key: Key used for AES algorithm. | ||||
|   * @param  Input: pointer to the Input buffer. | ||||
|   * @param  Ilength: length of the Input buffer, must be a multiple of 16 bytes. | ||||
|   * @param  Output: pointer to the returned buffer. | ||||
|   * @retval An ErrorStatus enumeration value: | ||||
|   *          - SUCCESS: Operation done | ||||
|   *          - ERROR: Operation failed | ||||
|   */ | ||||
| ErrorStatus AES_CBC_Decrypt(uint8_t* Key, uint8_t InitVectors[16], uint8_t* Input, uint32_t Ilength, uint8_t* Output) | ||||
| { | ||||
|   AES_InitTypeDef AES_InitStructure; | ||||
|   AES_KeyInitTypeDef  AES_KeyInitStructure; | ||||
|   AES_IVInitTypeDef AES_IVInitStructure; | ||||
|   ErrorStatus status = SUCCESS; | ||||
|   uint32_t keyaddr    = (uint32_t)Key; | ||||
|   uint32_t inputaddr  = (uint32_t)Input; | ||||
|   uint32_t outputaddr = (uint32_t)Output; | ||||
|   uint32_t ivaddr     = (uint32_t)InitVectors; | ||||
|   __IO uint32_t counter = 0; | ||||
|   uint32_t ccstatus = 0; | ||||
|   uint32_t i = 0; | ||||
|    | ||||
|   /* AES Key initialisation*/ | ||||
|   AES_KeyInitStructure.AES_Key3 = __REV(*(uint32_t*)(keyaddr)); | ||||
|   keyaddr += 4; | ||||
|   AES_KeyInitStructure.AES_Key2 = __REV(*(uint32_t*)(keyaddr)); | ||||
|   keyaddr += 4; | ||||
|   AES_KeyInitStructure.AES_Key1 = __REV(*(uint32_t*)(keyaddr)); | ||||
|   keyaddr += 4; | ||||
|   AES_KeyInitStructure.AES_Key0 = __REV(*(uint32_t*)(keyaddr)); | ||||
|   AES_KeyInit(&AES_KeyInitStructure); | ||||
| 
 | ||||
|   /* AES Initialization Vectors */ | ||||
|   AES_IVInitStructure.AES_IV3 = __REV(*(uint32_t*)(ivaddr)); | ||||
|   ivaddr += 4; | ||||
|   AES_IVInitStructure.AES_IV2 = __REV(*(uint32_t*)(ivaddr)); | ||||
|   ivaddr += 4; | ||||
|   AES_IVInitStructure.AES_IV1 = __REV(*(uint32_t*)(ivaddr)); | ||||
|   ivaddr += 4; | ||||
|   AES_IVInitStructure.AES_IV0 = __REV(*(uint32_t*)(ivaddr)); | ||||
|   AES_IVInit(&AES_IVInitStructure); | ||||
| 
 | ||||
|   /* AES configuration */ | ||||
|   AES_InitStructure.AES_Operation = AES_Operation_KeyDerivAndDecryp; | ||||
|   AES_InitStructure.AES_Chaining = AES_Chaining_CBC; | ||||
|   AES_InitStructure.AES_DataType = AES_DataType_8b; | ||||
|   AES_Init(&AES_InitStructure); | ||||
| 
 | ||||
|   /* Enable AES */ | ||||
|   AES_Cmd(ENABLE); | ||||
| 
 | ||||
|   for(i = 0; ((i < Ilength) && (status != ERROR)); i += 16) | ||||
|   { | ||||
|     AES_WriteSubData(*(uint32_t*)(inputaddr)); | ||||
|     inputaddr += 4; | ||||
|     AES_WriteSubData(*(uint32_t*)(inputaddr)); | ||||
|     inputaddr += 4; | ||||
|     AES_WriteSubData(*(uint32_t*)(inputaddr)); | ||||
|     inputaddr += 4; | ||||
|     AES_WriteSubData(*(uint32_t*)(inputaddr)); | ||||
|     inputaddr += 4; | ||||
|      | ||||
|     /* Wait for CCF flag to be set */ | ||||
|     counter = 0; | ||||
|     do | ||||
|     { | ||||
|       ccstatus = AES_GetFlagStatus(AES_FLAG_CCF); | ||||
|       counter++; | ||||
|     }while((counter != AES_CC_TIMEOUT) && (ccstatus == RESET)); | ||||
| 
 | ||||
|     if (ccstatus == RESET) | ||||
|     { | ||||
|       status = ERROR; | ||||
|     } | ||||
|     else | ||||
|     { | ||||
|       /* Clear CCF flag */ | ||||
|       AES_ClearFlag(AES_FLAG_CCF); | ||||
| 
 | ||||
|       /* Read cipher text */ | ||||
|       *(uint32_t*)(outputaddr) = AES_ReadSubData(); | ||||
|       outputaddr += 4; | ||||
|       *(uint32_t*)(outputaddr) = AES_ReadSubData(); | ||||
|       outputaddr += 4; | ||||
|       *(uint32_t*)(outputaddr) = AES_ReadSubData(); | ||||
|       outputaddr += 4; | ||||
|       *(uint32_t*)(outputaddr) = AES_ReadSubData(); | ||||
|       outputaddr += 4; | ||||
|     } | ||||
|   } | ||||
| 
 | ||||
|   /* Disable AES before starting new processing */ | ||||
|   AES_Cmd(DISABLE); | ||||
| 
 | ||||
|   return status; | ||||
| } | ||||
| 
 | ||||
| /**
 | ||||
|   * @brief  Encrypt using AES in CTR Mode | ||||
|   * @param  InitVectors: Initialisation Vectors used for AES algorithm. | ||||
|   * @param  Key: Key used for AES algorithm. | ||||
|   * @param  Input: pointer to the Input buffer. | ||||
|   * @param  Ilength: length of the Input buffer, must be a multiple of 16 bytes. | ||||
|   * @param  Output: pointer to the returned buffer. | ||||
|   * @retval An ErrorStatus enumeration value: | ||||
|   *          - SUCCESS: Operation done | ||||
|   *          - ERROR: Operation failed | ||||
|   */ | ||||
| ErrorStatus AES_CTR_Encrypt(uint8_t* Key, uint8_t InitVectors[16], uint8_t* Input, uint32_t Ilength, uint8_t* Output) | ||||
| { | ||||
|   AES_InitTypeDef AES_InitStructure; | ||||
|   AES_KeyInitTypeDef  AES_KeyInitStructure; | ||||
|   AES_IVInitTypeDef AES_IVInitStructure; | ||||
| 
 | ||||
|   ErrorStatus status = SUCCESS; | ||||
|   uint32_t keyaddr    = (uint32_t)Key; | ||||
|   uint32_t inputaddr  = (uint32_t)Input; | ||||
|   uint32_t outputaddr = (uint32_t)Output; | ||||
|   uint32_t ivaddr     = (uint32_t)InitVectors; | ||||
|   __IO uint32_t counter = 0; | ||||
|   uint32_t ccstatus = 0; | ||||
|   uint32_t i = 0; | ||||
| 
 | ||||
|   /* AES key initialisation*/ | ||||
|   AES_KeyInitStructure.AES_Key3 = __REV(*(uint32_t*)(keyaddr)); | ||||
|   keyaddr += 4; | ||||
|   AES_KeyInitStructure.AES_Key2 = __REV(*(uint32_t*)(keyaddr)); | ||||
|   keyaddr += 4; | ||||
|   AES_KeyInitStructure.AES_Key1 = __REV(*(uint32_t*)(keyaddr)); | ||||
|   keyaddr += 4; | ||||
|   AES_KeyInitStructure.AES_Key0 = __REV(*(uint32_t*)(keyaddr)); | ||||
|   AES_KeyInit(&AES_KeyInitStructure); | ||||
| 
 | ||||
|   /* AES Initialization Vectors */ | ||||
|   AES_IVInitStructure.AES_IV3 = __REV(*(uint32_t*)(ivaddr)); | ||||
|   ivaddr += 4; | ||||
|   AES_IVInitStructure.AES_IV2= __REV(*(uint32_t*)(ivaddr)); | ||||
|   ivaddr += 4; | ||||
|   AES_IVInitStructure.AES_IV1 = __REV(*(uint32_t*)(ivaddr)); | ||||
|   ivaddr += 4; | ||||
|   AES_IVInitStructure.AES_IV0= __REV(*(uint32_t*)(ivaddr)); | ||||
|   AES_IVInit(&AES_IVInitStructure); | ||||
| 
 | ||||
|   /* AES configuration */ | ||||
|   AES_InitStructure.AES_Operation = AES_Operation_Encryp; | ||||
|   AES_InitStructure.AES_Chaining = AES_Chaining_CTR; | ||||
|   AES_InitStructure.AES_DataType = AES_DataType_8b; | ||||
|   AES_Init(&AES_InitStructure); | ||||
| 
 | ||||
|   /* Enable AES */ | ||||
|   AES_Cmd(ENABLE); | ||||
| 
 | ||||
|   for(i = 0; ((i < Ilength) && (status != ERROR)); i += 16) | ||||
|   { | ||||
|     AES_WriteSubData(*(uint32_t*)(inputaddr)); | ||||
|     inputaddr += 4; | ||||
|     AES_WriteSubData(*(uint32_t*)(inputaddr)); | ||||
|     inputaddr += 4; | ||||
|     AES_WriteSubData(*(uint32_t*)(inputaddr)); | ||||
|     inputaddr += 4; | ||||
|     AES_WriteSubData(*(uint32_t*)(inputaddr)); | ||||
|     inputaddr += 4; | ||||
|      | ||||
|     /* Wait for CCF flag to be set */ | ||||
|     counter = 0; | ||||
|     do | ||||
|     { | ||||
|       ccstatus = AES_GetFlagStatus(AES_FLAG_CCF); | ||||
|       counter++; | ||||
|     }while((counter != AES_CC_TIMEOUT) && (ccstatus == RESET)); | ||||
| 
 | ||||
|     if (ccstatus == RESET) | ||||
|     { | ||||
|       status = ERROR; | ||||
|     } | ||||
|     else | ||||
|     { | ||||
|       /* Clear CCF flag */ | ||||
|       AES_ClearFlag(AES_FLAG_CCF); | ||||
| 
 | ||||
|       /* Read cipher text */ | ||||
|       *(uint32_t*)(outputaddr) = AES_ReadSubData(); | ||||
|       outputaddr += 4; | ||||
|       *(uint32_t*)(outputaddr) = AES_ReadSubData(); | ||||
|       outputaddr += 4; | ||||
|       *(uint32_t*)(outputaddr) = AES_ReadSubData(); | ||||
|       outputaddr += 4; | ||||
|       *(uint32_t*)(outputaddr) = AES_ReadSubData(); | ||||
|       outputaddr += 4; | ||||
|     } | ||||
|   } | ||||
| 
 | ||||
|   /* Disable AES before starting new processing */ | ||||
|   AES_Cmd(DISABLE); | ||||
| 
 | ||||
|   return status; | ||||
| } | ||||
| 
 | ||||
| /**
 | ||||
|   * @brief  Decrypt using AES in CTR Mode | ||||
|   * @param  InitVectors: Initialisation Vectors used for AES algorithm. | ||||
|   * @param  Key: Key used for AES algorithm. | ||||
|   * @param  Input: pointer to the Input buffer. | ||||
|   * @param  Ilength: length of the Input buffer, must be a multiple of 16 bytes. | ||||
|   * @param  Output: pointer to the returned buffer. | ||||
|   * @retval An ErrorStatus enumeration value: | ||||
|   *          - SUCCESS: Operation done | ||||
|   *          - ERROR: Operation failed | ||||
|   */ | ||||
| ErrorStatus AES_CTR_Decrypt(uint8_t* Key, uint8_t InitVectors[16], uint8_t* Input, uint32_t Ilength, uint8_t* Output) | ||||
| { | ||||
|   AES_InitTypeDef AES_InitStructure; | ||||
|   AES_KeyInitTypeDef  AES_KeyInitStructure; | ||||
|   AES_IVInitTypeDef AES_IVInitStructure; | ||||
| 
 | ||||
|   ErrorStatus status = SUCCESS; | ||||
|   uint32_t keyaddr    = (uint32_t)Key; | ||||
|   uint32_t inputaddr  = (uint32_t)Input; | ||||
|   uint32_t outputaddr = (uint32_t)Output; | ||||
|   uint32_t ivaddr     = (uint32_t)InitVectors; | ||||
|   __IO uint32_t counter = 0; | ||||
|   uint32_t ccstatus = 0; | ||||
|   uint32_t i = 0; | ||||
| 
 | ||||
|   /* AES Key initialisation*/ | ||||
|   AES_KeyInitStructure.AES_Key3 = __REV(*(uint32_t*)(keyaddr)); | ||||
|   keyaddr += 4; | ||||
|   AES_KeyInitStructure.AES_Key2 = __REV(*(uint32_t*)(keyaddr)); | ||||
|   keyaddr += 4; | ||||
|   AES_KeyInitStructure.AES_Key1 = __REV(*(uint32_t*)(keyaddr)); | ||||
|   keyaddr += 4; | ||||
|   AES_KeyInitStructure.AES_Key0 = __REV(*(uint32_t*)(keyaddr)); | ||||
|   AES_KeyInit(&AES_KeyInitStructure); | ||||
| 
 | ||||
|   /* AES Initialization Vectors */ | ||||
|   AES_IVInitStructure.AES_IV3 = __REV(*(uint32_t*)(ivaddr)); | ||||
|   ivaddr += 4; | ||||
|   AES_IVInitStructure.AES_IV2 = __REV(*(uint32_t*)(ivaddr)); | ||||
|   ivaddr += 4; | ||||
|   AES_IVInitStructure.AES_IV1 = __REV(*(uint32_t*)(ivaddr)); | ||||
|   ivaddr += 4; | ||||
|   AES_IVInitStructure.AES_IV0 = __REV(*(uint32_t*)(ivaddr)); | ||||
|   AES_IVInit(&AES_IVInitStructure); | ||||
| 
 | ||||
|   /* AES configuration */ | ||||
|   AES_InitStructure.AES_Operation = AES_Operation_KeyDerivAndDecryp; | ||||
|   AES_InitStructure.AES_Chaining = AES_Chaining_CTR; | ||||
|   AES_InitStructure.AES_DataType = AES_DataType_8b; | ||||
|   AES_Init(&AES_InitStructure); | ||||
| 
 | ||||
|   /* Enable AES */ | ||||
|   AES_Cmd(ENABLE); | ||||
| 
 | ||||
|   for(i = 0; ((i < Ilength) && (status != ERROR)); i += 16) | ||||
|   { | ||||
|     AES_WriteSubData(*(uint32_t*)(inputaddr)); | ||||
|     inputaddr += 4; | ||||
|     AES_WriteSubData(*(uint32_t*)(inputaddr)); | ||||
|     inputaddr += 4; | ||||
|     AES_WriteSubData(*(uint32_t*)(inputaddr)); | ||||
|     inputaddr += 4; | ||||
|     AES_WriteSubData(*(uint32_t*)(inputaddr)); | ||||
|     inputaddr += 4; | ||||
|      | ||||
|     /* Wait for CCF flag to be set */ | ||||
|     counter = 0; | ||||
|     do | ||||
|     { | ||||
|       ccstatus = AES_GetFlagStatus(AES_FLAG_CCF); | ||||
|       counter++; | ||||
|     }while((counter != AES_CC_TIMEOUT) && (ccstatus == RESET)); | ||||
| 
 | ||||
|     if (ccstatus == RESET) | ||||
|     { | ||||
|       status = ERROR; | ||||
|     } | ||||
|     else | ||||
|     { | ||||
|       /* Clear CCF flag */ | ||||
|       AES_ClearFlag(AES_FLAG_CCF); | ||||
|      | ||||
|       /* Read cipher text */ | ||||
|       *(uint32_t*)(outputaddr) = AES_ReadSubData(); | ||||
|       outputaddr += 4; | ||||
|       *(uint32_t*)(outputaddr) = AES_ReadSubData(); | ||||
|       outputaddr += 4; | ||||
|       *(uint32_t*)(outputaddr) = AES_ReadSubData(); | ||||
|       outputaddr += 4; | ||||
|       *(uint32_t*)(outputaddr) = AES_ReadSubData(); | ||||
|       outputaddr += 4; | ||||
|     } | ||||
|   } | ||||
| 
 | ||||
|   /* Disable AES before starting new processing */ | ||||
|   AES_Cmd(DISABLE); | ||||
| 
 | ||||
|   return status; | ||||
| } | ||||
| 
 | ||||
| /**
 | ||||
|   * @} | ||||
|   */ | ||||
| 
 | ||||
| /**
 | ||||
|   * @} | ||||
|   */  | ||||
| 
 | ||||
| /**
 | ||||
|   * @} | ||||
|   */  | ||||
| 
 | ||||
| /**
 | ||||
|   * @} | ||||
|   */  | ||||
| 
 | ||||
| /************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE****/ | ||||
| 
 | ||||
|  | @ -1,378 +0,0 @@ | |||
| /**
 | ||||
|   ****************************************************************************** | ||||
|   * @file    stm32l1xx_comp.c | ||||
|   * @author  MCD Application Team | ||||
|   * @version V1.1.1 | ||||
|   * @date    05-March-2012 | ||||
|   * @brief   This file provides firmware functions to manage the following  | ||||
|   *          functionalities of the comparators (COMP1 and COMP2) peripheral:  | ||||
|   *           + Comparators configuration | ||||
|   *           + Window mode control | ||||
|   *           + Internal Reference Voltage (VREFINT) output | ||||
|   * | ||||
|   *  @verbatim | ||||
|  =============================================================================== | ||||
|                      ##### How to use this driver ##### | ||||
|  =============================================================================== | ||||
|     [..] The device integrates two analog comparators COMP1 and COMP2: | ||||
|          (+) COMP1 is a fixed threshold (VREFINT) that shares the non inverting | ||||
|              input with the ADC channels. | ||||
|          (+) COMP2 is a rail-to-rail comparator whose the inverting input can be  | ||||
|              selected among: DAC_OUT1, DAC_OUT2, 1/4 VREFINT, 1/2 VERFINT, 3/4  | ||||
|              VREFINT, VREFINT, PB3 and whose the output can be redirected to  | ||||
|              embedded timers: TIM2, TIM3, TIM4, TIM10. | ||||
|    | ||||
|          (+) The two comparators COMP1 and COMP2 can be combined in window mode. | ||||
| 
 | ||||
|          -@- | ||||
|             (#@) Comparator APB clock must be enabled to get write access | ||||
|                  to comparator register using | ||||
|                  RCC_APB1PeriphClockCmd(RCC_APB1Periph_COMP, ENABLE). | ||||
|    | ||||
|             (#@) COMP1 comparator and ADC can't be used at the same time since | ||||
|                  they share the same ADC switch matrix (analog switches). | ||||
|    | ||||
|             (#@) When an I/O is used as comparator input, the corresponding GPIO  | ||||
|                  registers should be configured in analog mode. | ||||
|    | ||||
|             (#@) Comparators outputs (CMP1OUT and CMP2OUT) are not mapped on | ||||
|                  GPIO pin. They are only internal. | ||||
|                  To get the comparator output level, use COMP_GetOutputLevel(). | ||||
|    | ||||
|             (#@) COMP1 and COMP2 outputs are internally connected to EXTI Line 21 | ||||
|                  and EXTI Line 22 respectively. | ||||
|                  Interrupts can be used by configuring the EXTI Line using the  | ||||
|                  EXTI peripheral driver. | ||||
|    | ||||
|             (#@) After enabling the comparator (COMP1 or COMP2), user should wait | ||||
|                  for start-up time (tSTART) to get right output levels. | ||||
|                  Please refer to product datasheet for more information on tSTART. | ||||
|    | ||||
|             (#@) Comparators cannot be used to exit the device from Sleep or Stop  | ||||
|                  mode when the internal reference voltage is switched off using  | ||||
|                  the PWR_UltraLowPowerCmd() function (ULP bit in the PWR_CR register). | ||||
|    | ||||
|     @endverbatim | ||||
|   ****************************************************************************** | ||||
|   * @attention | ||||
|   * | ||||
|   * <h2><center>© COPYRIGHT 2012 STMicroelectronics</center></h2> | ||||
|   * | ||||
|   * Licensed under MCD-ST Liberty SW License Agreement V2, (the "License"); | ||||
|   * You may not use this file except in compliance with the License. | ||||
|   * You may obtain a copy of the License at: | ||||
|   * | ||||
|   *        http://www.st.com/software_license_agreement_liberty_v2
 | ||||
|   * | ||||
|   * Unless required by applicable law or agreed to in writing, software  | ||||
|   * distributed under the License is distributed on an "AS IS" BASIS,  | ||||
|   * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. | ||||
|   * See the License for the specific language governing permissions and | ||||
|   * limitations under the License. | ||||
|   * | ||||
|   ****************************************************************************** | ||||
|   */ | ||||
| 
 | ||||
| /* Includes ------------------------------------------------------------------*/ | ||||
| #include "stm32l1xx_comp.h" | ||||
| 
 | ||||
| /** @addtogroup STM32L1xx_StdPeriph_Driver
 | ||||
|   * @{ | ||||
|   */ | ||||
| 
 | ||||
| /** @defgroup COMP 
 | ||||
|   * @brief COMP driver modules. | ||||
|   * @{ | ||||
|   */  | ||||
| 
 | ||||
| /* Private typedef -----------------------------------------------------------*/ | ||||
| /* Private define ------------------------------------------------------------*/ | ||||
| /* Private macro -------------------------------------------------------------*/ | ||||
| /* Private variables ---------------------------------------------------------*/ | ||||
| /* Private function prototypes -----------------------------------------------*/ | ||||
| /* Private functions ---------------------------------------------------------*/ | ||||
| 
 | ||||
| /** @defgroup COMP_Private_Functions
 | ||||
|   * @{ | ||||
|   */ | ||||
| 
 | ||||
| /** @defgroup COMP_Group1 Initialization and Configuration functions
 | ||||
|  *  @brief   Initialization and Configuration functions. | ||||
|  * | ||||
| @verbatim | ||||
|  =============================================================================== | ||||
|               ##### Initialization and Configuration functions ##### | ||||
|  =============================================================================== | ||||
| 
 | ||||
| @endverbatim | ||||
|   * @{ | ||||
|   */ | ||||
|     | ||||
| /**
 | ||||
|   * @brief  Deinitializes COMP peripheral registers to their default reset values. | ||||
|   * @param  None | ||||
|   * @retval None | ||||
|   */ | ||||
| void COMP_DeInit(void) | ||||
| { | ||||
|   COMP->CSR = ((uint32_t)0x00000000);    /*!< Set COMP->CSR to reset value */ | ||||
| } | ||||
| 
 | ||||
| /**
 | ||||
|   * @brief  Initializes the COMP2 peripheral according to the specified parameters | ||||
|   *         in the COMP_InitStruct. | ||||
|   * @note   This function configures only COMP2. | ||||
|   * @note   COMP2 comparator is enabled as soon as the INSEL[2:0] bits are  | ||||
|   *         different from "000". | ||||
|   * @param  COMP_InitStruct: pointer to an COMP_InitTypeDef structure that contains  | ||||
|   *         the configuration information for the specified COMP peripheral.   | ||||
|   * @retval None | ||||
|   */ | ||||
| void COMP_Init(COMP_InitTypeDef* COMP_InitStruct) | ||||
| { | ||||
|   uint32_t tmpreg = 0; | ||||
|    | ||||
|   /* Check the parameters */ | ||||
|   assert_param(IS_COMP_INVERTING_INPUT(COMP_InitStruct->COMP_InvertingInput)); | ||||
|   assert_param(IS_COMP_OUTPUT(COMP_InitStruct->COMP_OutputSelect)); | ||||
|   assert_param(IS_COMP_SPEED(COMP_InitStruct->COMP_Speed)); | ||||
| 
 | ||||
|   /*!< Get the COMP CSR value */ | ||||
|   tmpreg = COMP->CSR; | ||||
| 
 | ||||
|   /*!< Clear the  INSEL[2:0], OUTSEL[1:0] and SPEED bits */  | ||||
|   tmpreg &= (uint32_t) (~(uint32_t) (COMP_CSR_OUTSEL | COMP_CSR_INSEL | COMP_CSR_SPEED)); | ||||
|    | ||||
|   /*!< Configure COMP: speed, inversion input selection and output redirection */ | ||||
|   /*!< Set SPEED bit according to COMP_InitStruct->COMP_Speed value */ | ||||
|   /*!< Set INSEL bits according to COMP_InitStruct->COMP_InvertingInput value */  | ||||
|   /*!< Set OUTSEL bits according to COMP_InitStruct->COMP_OutputSelect value */   | ||||
|   tmpreg |= (uint32_t)((COMP_InitStruct->COMP_Speed | COMP_InitStruct->COMP_InvertingInput  | ||||
|                         | COMP_InitStruct->COMP_OutputSelect)); | ||||
| 
 | ||||
|   /*!< The COMP2 comparator is enabled as soon as the INSEL[2:0] bits value are 
 | ||||
|      different from "000" */ | ||||
|   /*!< Write to COMP_CSR register */ | ||||
|   COMP->CSR = tmpreg;   | ||||
| } | ||||
| 
 | ||||
| /**
 | ||||
|   * @brief  Enable or disable the COMP1 peripheral. | ||||
|   * @note   After enabling COMP1, the following functions should be called to  | ||||
|   *         connect the selected GPIO input to COMP1 non inverting input: | ||||
|   * @note   Enable switch control mode using SYSCFG_RISwitchControlModeCmd() | ||||
|   * @note   Close VCOMP switch using SYSCFG_RIIOSwitchConfig() | ||||
|   * @note   Close the I/O switch number n corresponding to the I/O  | ||||
|   *         using SYSCFG_RIIOSwitchConfig() | ||||
|   * @param  NewState: new state of the COMP1 peripheral. | ||||
|   *         This parameter can be: ENABLE or DISABLE. | ||||
|   * @note   This function enables/disables only the COMP1. | ||||
|   * @retval None | ||||
|   */ | ||||
| void COMP_Cmd(FunctionalState NewState) | ||||
| { | ||||
|   /* Check the parameter */ | ||||
|   assert_param(IS_FUNCTIONAL_STATE(NewState)); | ||||
| 
 | ||||
|   if (NewState != DISABLE) | ||||
|   { | ||||
|     /* Enable the COMP1 */ | ||||
|     COMP->CSR |= (uint32_t) COMP_CSR_CMP1EN; | ||||
|   } | ||||
|   else | ||||
|   { | ||||
|     /* Disable the COMP1  */ | ||||
|     COMP->CSR &= (uint32_t)(~COMP_CSR_CMP1EN); | ||||
|   } | ||||
| } | ||||
| 
 | ||||
| /**
 | ||||
|   * @brief  Return the output level (high or low) of the selected comparator. | ||||
|   * @note   Comparator output is low when the noninverting input is at a lower | ||||
|   *         voltage than the inverting input. | ||||
|   * @note   Comparator output is high when the noninverting input is at a higher | ||||
|   *         voltage than the inverting input. | ||||
|   * @note   Comparators outputs aren't available on GPIO (outputs levels are  | ||||
|   *         only internal). The COMP1 and COMP2 outputs are connected internally  | ||||
|   *         to the EXTI Line 21 and Line 22 respectively. | ||||
|   * @param  COMP_Selection: the selected comparator. | ||||
|   *   This parameter can be one of the following values: | ||||
|   *     @arg COMP_Selection_COMP1: COMP1 selected | ||||
|   *     @arg COMP_Selection_COMP2: COMP2 selected | ||||
|   * @retval Returns the selected comparator output level. | ||||
|   */ | ||||
| uint8_t COMP_GetOutputLevel(uint32_t COMP_Selection) | ||||
| { | ||||
|   uint8_t compout = 0x0; | ||||
| 
 | ||||
|   /* Check the parameters */ | ||||
|   assert_param(IS_COMP_ALL_PERIPH(COMP_Selection)); | ||||
| 
 | ||||
|   /* Check if Comparator 1 is selected */ | ||||
|   if(COMP_Selection == COMP_Selection_COMP1) | ||||
|   { | ||||
|     /* Check if comparator 1 output level is high */ | ||||
|     if((COMP->CSR & COMP_CSR_CMP1OUT) != (uint8_t) RESET) | ||||
|     { | ||||
|       /* Get Comparator 1 output level */ | ||||
|       compout = (uint8_t) COMP_OutputLevel_High; | ||||
|     } | ||||
|     /* comparator 1 output level is low */ | ||||
|     else | ||||
|     { | ||||
|       /* Get Comparator 1 output level */ | ||||
|       compout = (uint8_t) COMP_OutputLevel_Low; | ||||
|     } | ||||
|   } | ||||
|   /* Comparator 2 is selected */ | ||||
|   else | ||||
|   { | ||||
|     /* Check if comparator 2 output level is high */ | ||||
|     if((COMP->CSR & COMP_CSR_CMP2OUT) != (uint8_t) RESET) | ||||
|     { | ||||
|       /* Get Comparator output level */ | ||||
|       compout = (uint8_t) COMP_OutputLevel_High; | ||||
|     } | ||||
|     /* comparator 2 output level is low */ | ||||
|     else | ||||
|     { | ||||
|       /* Get Comparator 2 output level */ | ||||
|       compout = (uint8_t) COMP_OutputLevel_Low; | ||||
|     } | ||||
|   } | ||||
|   /* Return the comparator output level */ | ||||
|   return (uint8_t)(compout); | ||||
| } | ||||
| 
 | ||||
| /**
 | ||||
|   * @brief  Close or Open the SW1 switch. | ||||
|   * @param  NewState: new state of the SW1 switch. | ||||
|   *         This parameter can be: ENABLE or DISABLE. | ||||
|   * @note   ENABLE to close the SW1 switch | ||||
|   * @note   DISABLE to open the SW1 switch | ||||
|   * @retval None. | ||||
|   */ | ||||
| void COMP_SW1SwitchConfig(FunctionalState NewState) | ||||
| { | ||||
|   /* Check the parameters */ | ||||
|   assert_param(IS_FUNCTIONAL_STATE(NewState)); | ||||
| 
 | ||||
|   if (NewState != DISABLE) | ||||
|   { | ||||
|     /* Close SW1 switch */ | ||||
|     COMP->CSR |= (uint32_t) COMP_CSR_SW1; | ||||
|   } | ||||
|   else | ||||
|   { | ||||
|     /* Open SW1 switch */ | ||||
|     COMP->CSR &= (uint32_t)(~COMP_CSR_SW1); | ||||
|   } | ||||
| } | ||||
| 
 | ||||
| /**
 | ||||
|   * @} | ||||
|   */ | ||||
| 
 | ||||
| /** @defgroup COMP_Group2 Window mode control function
 | ||||
|  *  @brief   Window mode control function. | ||||
|  * | ||||
| @verbatim | ||||
|  =============================================================================== | ||||
|                   ##### Window mode control function ##### | ||||
|  =============================================================================== | ||||
| 
 | ||||
| @endverbatim | ||||
|   * @{ | ||||
|   */ | ||||
| 
 | ||||
| /**
 | ||||
|   * @brief  Enables or disables the window mode. | ||||
|   *         In window mode: | ||||
|   * @note   COMP1 inverting input is fixed to VREFINT defining the first | ||||
|   *         threshold. | ||||
|   * @note   COMP2 inverting input is configurable (DAC_OUT1, DAC_OUT2, VREFINT | ||||
|   *         sub-multiples, PB3) defining the second threshold. | ||||
|   * @note   COMP1 and COMP2 non inverting inputs are connected together. | ||||
|   * @note   In window mode, only the Group 6 (PB4 or PB5) can be used as | ||||
|   *         noninverting inputs. | ||||
|   * @param   NewState: new state of the window mode.  | ||||
|   *   This parameter can be ENABLE or DISABLE. | ||||
|   * @retval None | ||||
|   */ | ||||
| void COMP_WindowCmd(FunctionalState NewState) | ||||
| { | ||||
|   /* Check the parameters */ | ||||
|   assert_param(IS_FUNCTIONAL_STATE(NewState)); | ||||
|    | ||||
|   if (NewState != DISABLE) | ||||
|   { | ||||
|     /* Enable the window mode */ | ||||
|     COMP->CSR |= (uint32_t) COMP_CSR_WNDWE; | ||||
|   } | ||||
|   else | ||||
|   { | ||||
|     /* Disable the window mode */ | ||||
|     COMP->CSR &= (uint32_t)(~COMP_CSR_WNDWE); | ||||
|   } | ||||
| } | ||||
| 
 | ||||
| /**
 | ||||
|   * @} | ||||
|   */ | ||||
| 
 | ||||
| /** @defgroup COMP_Group3 Internal Reference Voltage output function
 | ||||
|  *  @brief   Internal Reference Voltage (VREFINT) output function. | ||||
|  * | ||||
| @verbatim | ||||
|  =============================================================================== | ||||
|       ##### Internal Reference Voltage (VREFINT) output function ##### | ||||
|  =============================================================================== | ||||
| 
 | ||||
| @endverbatim | ||||
|   * @{ | ||||
|   */ | ||||
| 
 | ||||
| /**
 | ||||
|   * @brief  Enables or disables the output of internal reference voltage (VREFINT). | ||||
|   *         The VREFINT output can be routed to any I/O in group 3: CH8 (PB0) or | ||||
|   *         CH9 (PB1). | ||||
|   *         To correctly use this function, the SYSCFG_RIIOSwitchConfig() function | ||||
|   *         should be called after. | ||||
|   * @param  NewState: new state of the Vrefint output. | ||||
|   *         This parameter can be: ENABLE or DISABLE. | ||||
|   * @retval None | ||||
|   */ | ||||
| void COMP_VrefintOutputCmd(FunctionalState NewState) | ||||
| { | ||||
|   /* Check the parameters */ | ||||
|   assert_param(IS_FUNCTIONAL_STATE(NewState)); | ||||
| 
 | ||||
|   if (NewState != DISABLE) | ||||
|   { | ||||
|     /* Enable the output of internal reference voltage */ | ||||
|     COMP->CSR |= (uint32_t) COMP_CSR_VREFOUTEN; | ||||
|   } | ||||
|   else | ||||
|   { | ||||
|     /* Disable the output of internal reference voltage */ | ||||
|     COMP->CSR &= (uint32_t) (~COMP_CSR_VREFOUTEN); | ||||
|   } | ||||
| } | ||||
| 
 | ||||
| /**
 | ||||
|   * @} | ||||
|   */ | ||||
| 
 | ||||
| /**
 | ||||
|   * @} | ||||
|   */ | ||||
| 
 | ||||
| /**
 | ||||
|   * @} | ||||
|   */ | ||||
| 
 | ||||
| /**
 | ||||
|   * @} | ||||
|   */ | ||||
| 
 | ||||
| /************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE****/ | ||||
|  | @ -1,133 +0,0 @@ | |||
| /**
 | ||||
|   ****************************************************************************** | ||||
|   * @file    stm32l1xx_crc.c | ||||
|   * @author  MCD Application Team | ||||
|   * @version V1.1.1 | ||||
|   * @date    05-March-2012 | ||||
|   * @brief   This file provides all the CRC firmware functions. | ||||
|   ****************************************************************************** | ||||
|   * @attention | ||||
|   * | ||||
|   * <h2><center>© COPYRIGHT 2012 STMicroelectronics</center></h2> | ||||
|   * | ||||
|   * Licensed under MCD-ST Liberty SW License Agreement V2, (the "License"); | ||||
|   * You may not use this file except in compliance with the License. | ||||
|   * You may obtain a copy of the License at: | ||||
|   * | ||||
|   *        http://www.st.com/software_license_agreement_liberty_v2
 | ||||
|   * | ||||
|   * Unless required by applicable law or agreed to in writing, software  | ||||
|   * distributed under the License is distributed on an "AS IS" BASIS,  | ||||
|   * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. | ||||
|   * See the License for the specific language governing permissions and | ||||
|   * limitations under the License. | ||||
|   * | ||||
|   ****************************************************************************** | ||||
|   */ | ||||
| 
 | ||||
| /* Includes ------------------------------------------------------------------*/ | ||||
| #include "stm32l1xx_crc.h" | ||||
| 
 | ||||
| /** @addtogroup STM32L1xx_StdPeriph_Driver
 | ||||
|   * @{ | ||||
|   */ | ||||
| 
 | ||||
| /** @defgroup CRC 
 | ||||
|   * @brief CRC driver modules | ||||
|   * @{ | ||||
|   */ | ||||
| 
 | ||||
| /* Private typedef -----------------------------------------------------------*/ | ||||
| /* Private define ------------------------------------------------------------*/ | ||||
| /* Private macro -------------------------------------------------------------*/ | ||||
| /* Private variables ---------------------------------------------------------*/ | ||||
| /* Private function prototypes -----------------------------------------------*/ | ||||
| /* Private functions ---------------------------------------------------------*/ | ||||
| 
 | ||||
| /** @defgroup CRC_Private_Functions
 | ||||
|   * @{ | ||||
|   */ | ||||
| 
 | ||||
| /**
 | ||||
|   * @brief  Resets the CRC Data register (DR). | ||||
|   * @param  None | ||||
|   * @retval None | ||||
|   */ | ||||
| void CRC_ResetDR(void) | ||||
| { | ||||
|   /* Reset CRC generator */ | ||||
|   CRC->CR = CRC_CR_RESET; | ||||
| } | ||||
| 
 | ||||
| /**
 | ||||
|   * @brief  Computes the 32-bit CRC of a given data word(32-bit). | ||||
|   * @param  Data: data word(32-bit) to compute its CRC. | ||||
|   * @retval 32-bit CRC | ||||
|   */ | ||||
| uint32_t CRC_CalcCRC(uint32_t Data) | ||||
| { | ||||
|   CRC->DR = Data; | ||||
|    | ||||
|   return (CRC->DR); | ||||
| } | ||||
| 
 | ||||
| /**
 | ||||
|   * @brief  Computes the 32-bit CRC of a given buffer of data word(32-bit). | ||||
|   * @param  pBuffer: pointer to the buffer containing the data to be computed. | ||||
|   * @param  BufferLength: length of the buffer to be computed					 | ||||
|   * @retval 32-bit CRC | ||||
|   */ | ||||
| uint32_t CRC_CalcBlockCRC(uint32_t pBuffer[], uint32_t BufferLength) | ||||
| { | ||||
|   uint32_t index = 0; | ||||
|    | ||||
|   for(index = 0; index < BufferLength; index++) | ||||
|   { | ||||
|     CRC->DR = pBuffer[index]; | ||||
|   } | ||||
|   return (CRC->DR); | ||||
| } | ||||
| 
 | ||||
| /**
 | ||||
|   * @brief  Returns the current CRC value. | ||||
|   * @param  None | ||||
|   * @retval 32-bit CRC | ||||
|   */ | ||||
| uint32_t CRC_GetCRC(void) | ||||
| { | ||||
|   return (CRC->DR); | ||||
| } | ||||
| 
 | ||||
| /**
 | ||||
|   * @brief  Stores a 8-bit data in the Independent Data(ID) register. | ||||
|   * @param  IDValue: 8-bit value to be stored in the ID register 					 | ||||
|   * @retval None | ||||
|   */ | ||||
| void CRC_SetIDRegister(uint8_t IDValue) | ||||
| { | ||||
|   CRC->IDR = IDValue; | ||||
| } | ||||
| 
 | ||||
| /**
 | ||||
|   * @brief  Returns the 8-bit data stored in the Independent Data(ID) register. | ||||
|   * @param  None | ||||
|   * @retval 8-bit value of the ID register  | ||||
|   */ | ||||
| uint8_t CRC_GetIDRegister(void) | ||||
| { | ||||
|   return (CRC->IDR); | ||||
| } | ||||
| 
 | ||||
| /**
 | ||||
|   * @} | ||||
|   */ | ||||
| 
 | ||||
| /**
 | ||||
|   * @} | ||||
|   */ | ||||
| 
 | ||||
| /**
 | ||||
|   * @} | ||||
|   */ | ||||
| 
 | ||||
| /************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE****/ | ||||
|  | @ -1,687 +0,0 @@ | |||
| /**
 | ||||
|   ****************************************************************************** | ||||
|   * @file    stm32l1xx_dac.c | ||||
|   * @author  MCD Application Team | ||||
|   * @version V1.1.1 | ||||
|   * @date    05-March-2012 | ||||
|   * @brief   This file provides firmware functions to manage the following  | ||||
|   *          functionalities of the Digital-to-Analog Converter (DAC) peripheral:  | ||||
|   *          + DAC channels configuration: trigger, output buffer, data format | ||||
|   *          + DMA management       | ||||
|   *          + Interrupts and flags management | ||||
| 
 | ||||
|   * @verbatim       | ||||
|   *    | ||||
|  =============================================================================== | ||||
|                         ##### DAC Peripheral features ##### | ||||
|  =============================================================================== | ||||
|     [..] The device integrates two 12-bit Digital Analog Converters that can  | ||||
|          be used independently or simultaneously (dual mode): | ||||
|          (#) DAC channel1 with DAC_OUT1 (PA4) as output. | ||||
|          (#) DAC channel2 with DAC_OUT2 (PA5) as output. | ||||
|    | ||||
|     [..] Digital to Analog conversion can be non-triggered using DAC_Trigger_None | ||||
|          and DAC_OUT1/DAC_OUT2 is available once writing to DHRx register using  | ||||
|          DAC_SetChannel1Data()/DAC_SetChannel2Data. | ||||
|    | ||||
|     [..] Digital to Analog conversion can be triggered by: | ||||
|          (#) External event: EXTI Line 9 (any GPIOx_Pin9) using DAC_Trigger_Ext_IT9. | ||||
|              The used pin (GPIOx_Pin9) must be configured in input mode. | ||||
|          (#) Timers TRGO: TIM2, TIM4, TIM6, TIM7 and TIM9  | ||||
|              (DAC_Trigger_T2_TRGO, DAC_Trigger_T4_TRGO...). | ||||
|              The timer TRGO event should be selected using TIM_SelectOutputTrigger() | ||||
|          (#) Software using DAC_Trigger_Software. | ||||
|    | ||||
|     [..] Each DAC channel integrates an output buffer that can be used to  | ||||
|          reduce the output impedance, and to drive external loads directly | ||||
|          without having to add an external operational amplifier. | ||||
|          To enable, the output buffer use   | ||||
|          DAC_InitStructure.DAC_OutputBuffer = DAC_OutputBuffer_Enable; | ||||
|              | ||||
|     [..] Refer to the device datasheet for more details about output impedance | ||||
|          value with and without output buffer. | ||||
|    | ||||
|     [..] Both DAC channels can be used to generate: | ||||
|          (#) Noise wave using DAC_WaveGeneration_Noise | ||||
|          (#) Triangle wave using DAC_WaveGeneration_Triangle | ||||
|    | ||||
|     [..] Wave generation can be disabled using DAC_WaveGeneration_None. | ||||
|    | ||||
|     [..] The DAC data format can be: | ||||
|          (#) 8-bit right alignment using DAC_Align_8b_R | ||||
|          (#) 12-bit left alignment using DAC_Align_12b_L | ||||
|          (#) 12-bit right alignment using DAC_Align_12b_R | ||||
|    | ||||
|     [..] The analog output voltage on each DAC channel pin is determined | ||||
|          by the following equation: DAC_OUTx = VREF+ * DOR / 4095 | ||||
|          with  DOR is the Data Output Register. | ||||
|          VEF+ is the input voltage reference (refer to the device datasheet) | ||||
|          e.g. To set DAC_OUT1 to 0.7V, use | ||||
|          DAC_SetChannel1Data(DAC_Align_12b_R, 868); | ||||
|          Assuming that VREF+ = 3.3, DAC_OUT1 = (3.3 * 868) / 4095 = 0.7V. | ||||
|    | ||||
|     [..] A DMA1 request can be generated when an external trigger (but not | ||||
|          a software trigger) occurs if DMA1 requests are enabled using | ||||
|          DAC_DMACmd() | ||||
|     [..] DMA1 requests are mapped as following: | ||||
|          (#) DAC channel1 is mapped on DMA1 channel3 which must be already  | ||||
|              configured. | ||||
|          (#) DAC channel2 is mapped on DMA1 channel4 which must be already  | ||||
|              configured. | ||||
|    | ||||
|                       ##### How to use this driver ##### | ||||
|  =============================================================================== | ||||
|     [..] | ||||
|         (+) DAC APB clock must be enabled to get write access to DAC registers using | ||||
|             RCC_APB1PeriphClockCmd(RCC_APB1Periph_DAC, ENABLE) | ||||
|         (+) Configure DAC_OUTx (DAC_OUT1: PA4, DAC_OUT2: PA5) in analog mode. | ||||
|         (+) Configure the DAC channel using DAC_Init() | ||||
|         (+) Enable the DAC channel using DAC_Cmd() | ||||
| 
 | ||||
|    @endverbatim | ||||
|   *     | ||||
|   ****************************************************************************** | ||||
|   * @attention | ||||
|   * | ||||
|   * <h2><center>© COPYRIGHT 2012 STMicroelectronics</center></h2> | ||||
|   * | ||||
|   * Licensed under MCD-ST Liberty SW License Agreement V2, (the "License"); | ||||
|   * You may not use this file except in compliance with the License. | ||||
|   * You may obtain a copy of the License at: | ||||
|   * | ||||
|   *        http://www.st.com/software_license_agreement_liberty_v2
 | ||||
|   * | ||||
|   * Unless required by applicable law or agreed to in writing, software  | ||||
|   * distributed under the License is distributed on an "AS IS" BASIS,  | ||||
|   * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. | ||||
|   * See the License for the specific language governing permissions and | ||||
|   * limitations under the License. | ||||
|   * | ||||
|   ****************************************************************************** | ||||
|   */ | ||||
| 
 | ||||
| /* Includes ------------------------------------------------------------------*/ | ||||
| #include "stm32l1xx_dac.h" | ||||
| #include "stm32l1xx_rcc.h" | ||||
| 
 | ||||
| /** @addtogroup STM32L1xx_StdPeriph_Driver
 | ||||
|   * @{ | ||||
|   */ | ||||
| 
 | ||||
| /** @defgroup DAC 
 | ||||
|   * @brief DAC driver modules | ||||
|   * @{ | ||||
|   */  | ||||
| 
 | ||||
| /* Private typedef -----------------------------------------------------------*/ | ||||
| /* Private define ------------------------------------------------------------*/ | ||||
| /* CR register Mask */ | ||||
| #define CR_CLEAR_MASK              ((uint32_t)0x00000FFE) | ||||
| 
 | ||||
| /* DAC Dual Channels SWTRIG masks */ | ||||
| #define DUAL_SWTRIG_SET            ((uint32_t)0x00000003) | ||||
| #define DUAL_SWTRIG_RESET          ((uint32_t)0xFFFFFFFC) | ||||
| 
 | ||||
| /* DHR registers offsets */ | ||||
| #define DHR12R1_OFFSET             ((uint32_t)0x00000008) | ||||
| #define DHR12R2_OFFSET             ((uint32_t)0x00000014) | ||||
| #define DHR12RD_OFFSET             ((uint32_t)0x00000020) | ||||
| 
 | ||||
| /* DOR register offset */ | ||||
| #define DOR_OFFSET                 ((uint32_t)0x0000002C) | ||||
| 
 | ||||
| /* Private macro -------------------------------------------------------------*/ | ||||
| /* Private variables ---------------------------------------------------------*/ | ||||
| /* Private function prototypes -----------------------------------------------*/ | ||||
| /* Private functions ---------------------------------------------------------*/ | ||||
| 
 | ||||
| /** @defgroup DAC_Private_Functions
 | ||||
|   * @{ | ||||
|   */  | ||||
| 
 | ||||
| /** @defgroup DAC_Group1 DAC channels configuration
 | ||||
|  *  @brief   DAC channels configuration: trigger, output buffer, data format. | ||||
|  * | ||||
| @verbatim | ||||
|  =============================================================================== | ||||
|   ##### DAC channels configuration: trigger, output buffer, data format ##### | ||||
|  =============================================================================== | ||||
| 
 | ||||
| @endverbatim | ||||
|   * @{ | ||||
|   */ | ||||
| 
 | ||||
| /**
 | ||||
|   * @brief  Deinitializes the DAC peripheral registers to their default reset values. | ||||
|   * @param  None | ||||
|   * @retval None | ||||
|   */ | ||||
| void DAC_DeInit(void) | ||||
| { | ||||
|   /* Enable DAC reset state */ | ||||
|   RCC_APB1PeriphResetCmd(RCC_APB1Periph_DAC, ENABLE); | ||||
|   /* Release DAC from reset state */ | ||||
|   RCC_APB1PeriphResetCmd(RCC_APB1Periph_DAC, DISABLE); | ||||
| } | ||||
| 
 | ||||
| /**
 | ||||
|   * @brief  Initializes the DAC peripheral according to the specified  | ||||
|   *         parameters in the DAC_InitStruct. | ||||
|   * @param  DAC_Channel: the selected DAC channel. | ||||
|   *   This parameter can be one of the following values: | ||||
|   *     @arg DAC_Channel_1: DAC Channel1 selected. | ||||
|   *     @arg DAC_Channel_2: DAC Channel2 selected. | ||||
|   * @param  DAC_InitStruct: pointer to a DAC_InitTypeDef structure that | ||||
|   *         contains the configuration information for the specified DAC channel. | ||||
|   * @retval None | ||||
|   */ | ||||
| void DAC_Init(uint32_t DAC_Channel, DAC_InitTypeDef* DAC_InitStruct) | ||||
| { | ||||
|   uint32_t tmpreg1 = 0, tmpreg2 = 0; | ||||
| 
 | ||||
|   /* Check the DAC parameters */ | ||||
|   assert_param(IS_DAC_CHANNEL(DAC_Channel)); | ||||
|   assert_param(IS_DAC_TRIGGER(DAC_InitStruct->DAC_Trigger)); | ||||
|   assert_param(IS_DAC_GENERATE_WAVE(DAC_InitStruct->DAC_WaveGeneration)); | ||||
|   assert_param(IS_DAC_LFSR_UNMASK_TRIANGLE_AMPLITUDE(DAC_InitStruct->DAC_LFSRUnmask_TriangleAmplitude)); | ||||
|   assert_param(IS_DAC_OUTPUT_BUFFER_STATE(DAC_InitStruct->DAC_OutputBuffer)); | ||||
| 
 | ||||
| /*---------------------------- DAC CR Configuration --------------------------*/ | ||||
|   /* Get the DAC CR value */ | ||||
|   tmpreg1 = DAC->CR; | ||||
|   /* Clear BOFFx, TENx, TSELx, WAVEx and MAMPx bits */ | ||||
|   tmpreg1 &= ~(CR_CLEAR_MASK << DAC_Channel); | ||||
|   /* Configure for the selected DAC channel: buffer output, trigger, wave generation,
 | ||||
|      mask/amplitude for wave generation */ | ||||
|   /* Set TSELx and TENx bits according to DAC_Trigger value */ | ||||
|   /* Set WAVEx bits according to DAC_WaveGeneration value */ | ||||
|   /* Set MAMPx bits according to DAC_LFSRUnmask_TriangleAmplitude value */  | ||||
|   /* Set BOFFx bit according to DAC_OutputBuffer value */    | ||||
|   tmpreg2 = (DAC_InitStruct->DAC_Trigger | DAC_InitStruct->DAC_WaveGeneration | | ||||
|              DAC_InitStruct->DAC_LFSRUnmask_TriangleAmplitude | DAC_InitStruct->DAC_OutputBuffer); | ||||
|   /* Calculate CR register value depending on DAC_Channel */ | ||||
|   tmpreg1 |= tmpreg2 << DAC_Channel; | ||||
|   /* Write to DAC CR */ | ||||
|   DAC->CR = tmpreg1; | ||||
| } | ||||
| 
 | ||||
| /**
 | ||||
|   * @brief  Fills each DAC_InitStruct member with its default value. | ||||
|   * @param  DAC_InitStruct: pointer to a DAC_InitTypeDef structure which will  | ||||
|   *         be initialized. | ||||
|   * @retval None | ||||
|   */ | ||||
| void DAC_StructInit(DAC_InitTypeDef* DAC_InitStruct) | ||||
| { | ||||
| /*--------------- Reset DAC init structure parameters values -----------------*/ | ||||
|   /* Initialize the DAC_Trigger member */ | ||||
|   DAC_InitStruct->DAC_Trigger = DAC_Trigger_None; | ||||
|   /* Initialize the DAC_WaveGeneration member */ | ||||
|   DAC_InitStruct->DAC_WaveGeneration = DAC_WaveGeneration_None; | ||||
|   /* Initialize the DAC_LFSRUnmask_TriangleAmplitude member */ | ||||
|   DAC_InitStruct->DAC_LFSRUnmask_TriangleAmplitude = DAC_LFSRUnmask_Bit0; | ||||
|   /* Initialize the DAC_OutputBuffer member */ | ||||
|   DAC_InitStruct->DAC_OutputBuffer = DAC_OutputBuffer_Enable; | ||||
| } | ||||
| 
 | ||||
| /**
 | ||||
|   * @brief  Enables or disables the specified DAC channel. | ||||
|   * @param  DAC_Channel: The selected DAC channel.  | ||||
|   *   This parameter can be one of the following values: | ||||
|   *     @arg DAC_Channel_1: DAC Channel1 selected | ||||
|   *     @arg DAC_Channel_2: DAC Channel2 selected | ||||
|   * @param  NewState: new state of the DAC channel.  | ||||
|   *      This parameter can be: ENABLE or DISABLE. | ||||
|   * @note When the DAC channel is enabled the trigger source can no more | ||||
|   *       be modified. | ||||
|   * @retval None | ||||
|   */ | ||||
| void DAC_Cmd(uint32_t DAC_Channel, FunctionalState NewState) | ||||
| { | ||||
|   /* Check the parameters */ | ||||
|   assert_param(IS_DAC_CHANNEL(DAC_Channel)); | ||||
|   assert_param(IS_FUNCTIONAL_STATE(NewState)); | ||||
| 
 | ||||
|   if (NewState != DISABLE) | ||||
|   { | ||||
|     /* Enable the selected DAC channel */ | ||||
|     DAC->CR |= (DAC_CR_EN1 << DAC_Channel); | ||||
|   } | ||||
|   else | ||||
|   { | ||||
|     /* Disable the selected DAC channel */ | ||||
|     DAC->CR &= (~(DAC_CR_EN1 << DAC_Channel)); | ||||
|   } | ||||
| } | ||||
| 
 | ||||
| /**
 | ||||
|   * @brief  Enables or disables the selected DAC channel software trigger. | ||||
|   * @param  DAC_Channel: the selected DAC channel. | ||||
|   *   This parameter can be one of the following values: | ||||
|   *     @arg DAC_Channel_1: DAC Channel1 selected | ||||
|   *     @arg DAC_Channel_2: DAC Channel2 selected | ||||
|   * @param  NewState: new state of the selected DAC channel software trigger. | ||||
|   *   This parameter can be: ENABLE or DISABLE. | ||||
|   * @retval None | ||||
|   */ | ||||
| void DAC_SoftwareTriggerCmd(uint32_t DAC_Channel, FunctionalState NewState) | ||||
| { | ||||
|   /* Check the parameters */ | ||||
|   assert_param(IS_DAC_CHANNEL(DAC_Channel)); | ||||
|   assert_param(IS_FUNCTIONAL_STATE(NewState)); | ||||
| 
 | ||||
|   if (NewState != DISABLE) | ||||
|   { | ||||
|     /* Enable software trigger for the selected DAC channel */ | ||||
|     DAC->SWTRIGR |= (uint32_t)DAC_SWTRIGR_SWTRIG1 << (DAC_Channel >> 4); | ||||
|   } | ||||
|   else | ||||
|   { | ||||
|     /* Disable software trigger for the selected DAC channel */ | ||||
|     DAC->SWTRIGR &= ~((uint32_t)DAC_SWTRIGR_SWTRIG1 << (DAC_Channel >> 4)); | ||||
|   } | ||||
| } | ||||
| 
 | ||||
| /**
 | ||||
|   * @brief  Enables or disables simultaneously the two DAC channels software | ||||
|   *         triggers. | ||||
|   * @param  NewState: new state of the DAC channels software triggers. | ||||
|   *   This parameter can be: ENABLE or DISABLE. | ||||
|   * @retval None | ||||
|   */ | ||||
| void DAC_DualSoftwareTriggerCmd(FunctionalState NewState) | ||||
| { | ||||
|   /* Check the parameters */ | ||||
|   assert_param(IS_FUNCTIONAL_STATE(NewState)); | ||||
| 
 | ||||
|   if (NewState != DISABLE) | ||||
|   { | ||||
|     /* Enable software trigger for both DAC channels */ | ||||
|     DAC->SWTRIGR |= DUAL_SWTRIG_SET; | ||||
|   } | ||||
|   else | ||||
|   { | ||||
|     /* Disable software trigger for both DAC channels */ | ||||
|     DAC->SWTRIGR &= DUAL_SWTRIG_RESET; | ||||
|   } | ||||
| } | ||||
| 
 | ||||
| /**
 | ||||
|   * @brief  Enables or disables the selected DAC channel wave generation. | ||||
|   * @param  DAC_Channel: the selected DAC channel. | ||||
|   *   This parameter can be one of the following values: | ||||
|   *     @arg DAC_Channel_1: DAC Channel1 selected | ||||
|   *     @arg DAC_Channel_2: DAC Channel2 selected | ||||
|   * @param  DAC_Wave: Specifies the wave type to enable or disable. | ||||
|   *   This parameter can be one of the following values: | ||||
|   *     @arg DAC_Wave_Noise: noise wave generation | ||||
|   *     @arg DAC_Wave_Triangle: triangle wave generation | ||||
|   * @param  NewState: new state of the selected DAC channel wave generation. | ||||
|   *   This parameter can be: ENABLE or DISABLE. | ||||
|   * @note    | ||||
|   * @retval None | ||||
|   */ | ||||
| void DAC_WaveGenerationCmd(uint32_t DAC_Channel, uint32_t DAC_Wave, FunctionalState NewState) | ||||
| { | ||||
|   /* Check the parameters */ | ||||
|   assert_param(IS_DAC_CHANNEL(DAC_Channel)); | ||||
|   assert_param(IS_DAC_WAVE(DAC_Wave));  | ||||
|   assert_param(IS_FUNCTIONAL_STATE(NewState)); | ||||
| 
 | ||||
|   if (NewState != DISABLE) | ||||
|   { | ||||
|     /* Enable the selected wave generation for the selected DAC channel */ | ||||
|     DAC->CR |= DAC_Wave << DAC_Channel; | ||||
|   } | ||||
|   else | ||||
|   { | ||||
|     /* Disable the selected wave generation for the selected DAC channel */ | ||||
|     DAC->CR &= ~(DAC_Wave << DAC_Channel); | ||||
|   } | ||||
| } | ||||
| 
 | ||||
| /**
 | ||||
|   * @brief  Set the specified data holding register value for DAC channel1. | ||||
|   * @param  DAC_Align: Specifies the data alignment for DAC channel1. | ||||
|   *   This parameter can be one of the following values: | ||||
|   *     @arg DAC_Align_8b_R: 8bit right data alignment selected | ||||
|   *     @arg DAC_Align_12b_L: 12bit left data alignment selected | ||||
|   *     @arg DAC_Align_12b_R: 12bit right data alignment selected | ||||
|   * @param  Data : Data to be loaded in the selected data holding register. | ||||
|   * @retval None | ||||
|   */ | ||||
| void DAC_SetChannel1Data(uint32_t DAC_Align, uint16_t Data) | ||||
| {   | ||||
|   __IO uint32_t tmp = 0; | ||||
|    | ||||
|   /* Check the parameters */ | ||||
|   assert_param(IS_DAC_ALIGN(DAC_Align)); | ||||
|   assert_param(IS_DAC_DATA(Data)); | ||||
|    | ||||
|   tmp = (uint32_t)DAC_BASE;  | ||||
|   tmp += DHR12R1_OFFSET + DAC_Align; | ||||
| 
 | ||||
|   /* Set the DAC channel1 selected data holding register */ | ||||
|   *(__IO uint32_t *) tmp = Data; | ||||
| } | ||||
| 
 | ||||
| /**
 | ||||
|   * @brief  Set the specified data holding register value for DAC channel2. | ||||
|   * @param  DAC_Align: Specifies the data alignment for DAC channel2. | ||||
|   *   This parameter can be one of the following values: | ||||
|   *     @arg DAC_Align_8b_R: 8bit right data alignment selected | ||||
|   *     @arg DAC_Align_12b_L: 12bit left data alignment selected | ||||
|   *     @arg DAC_Align_12b_R: 12bit right data alignment selected | ||||
|   * @param  Data : Data to be loaded in the selected data holding register. | ||||
|   * @retval None | ||||
|   */ | ||||
| void DAC_SetChannel2Data(uint32_t DAC_Align, uint16_t Data) | ||||
| { | ||||
|   __IO uint32_t tmp = 0; | ||||
| 
 | ||||
|   /* Check the parameters */ | ||||
|   assert_param(IS_DAC_ALIGN(DAC_Align)); | ||||
|   assert_param(IS_DAC_DATA(Data)); | ||||
|    | ||||
|   tmp = (uint32_t)DAC_BASE; | ||||
|   tmp += DHR12R2_OFFSET + DAC_Align; | ||||
| 
 | ||||
|   /* Set the DAC channel2 selected data holding register */ | ||||
|   *(__IO uint32_t *)tmp = Data; | ||||
| } | ||||
| 
 | ||||
| /**
 | ||||
|   * @brief  Set the specified data holding register value for dual channel DAC. | ||||
|   * @param  DAC_Align: Specifies the data alignment for dual channel DAC. | ||||
|   *   This parameter can be one of the following values: | ||||
|   *     @arg DAC_Align_8b_R: 8bit right data alignment selected | ||||
|   *     @arg DAC_Align_12b_L: 12bit left data alignment selected | ||||
|   *     @arg DAC_Align_12b_R: 12bit right data alignment selected | ||||
|   * @param  Data2: Data for DAC Channel2 to be loaded in the selected data  | ||||
|   *         holding register. | ||||
|   * @param  Data1: Data for DAC Channel1 to be loaded in the selected data  | ||||
|   *         holding register. | ||||
|   * @note In dual mode, a unique register access is required to write in both | ||||
|   *       DAC channels at the same time. | ||||
|   * @retval None | ||||
|   */ | ||||
| void DAC_SetDualChannelData(uint32_t DAC_Align, uint16_t Data2, uint16_t Data1) | ||||
| { | ||||
|   uint32_t data = 0, tmp = 0; | ||||
|    | ||||
|   /* Check the parameters */ | ||||
|   assert_param(IS_DAC_ALIGN(DAC_Align)); | ||||
|   assert_param(IS_DAC_DATA(Data1)); | ||||
|   assert_param(IS_DAC_DATA(Data2)); | ||||
|    | ||||
|   /* Calculate and set dual DAC data holding register value */ | ||||
|   if (DAC_Align == DAC_Align_8b_R) | ||||
|   { | ||||
|     data = ((uint32_t)Data2 << 8) | Data1;  | ||||
|   } | ||||
|   else | ||||
|   { | ||||
|     data = ((uint32_t)Data2 << 16) | Data1; | ||||
|   } | ||||
|    | ||||
|   tmp = (uint32_t)DAC_BASE; | ||||
|   tmp += DHR12RD_OFFSET + DAC_Align; | ||||
| 
 | ||||
|   /* Set the dual DAC selected data holding register */ | ||||
|   *(__IO uint32_t *)tmp = data; | ||||
| } | ||||
| 
 | ||||
| /**
 | ||||
|   * @brief  Returns the last data output value of the selected DAC channel. | ||||
|   * @param  DAC_Channel: the selected DAC channel.  | ||||
|   *   This parameter can be one of the following values: | ||||
|   *     @arg DAC_Channel_1: DAC Channel1 selected | ||||
|   *     @arg DAC_Channel_2: DAC Channel2 selected | ||||
|   * @retval The selected DAC channel data output value. | ||||
|   */ | ||||
| uint16_t DAC_GetDataOutputValue(uint32_t DAC_Channel) | ||||
| { | ||||
|   __IO uint32_t tmp = 0; | ||||
|    | ||||
|   /* Check the parameters */ | ||||
|   assert_param(IS_DAC_CHANNEL(DAC_Channel)); | ||||
|    | ||||
|   tmp = (uint32_t) DAC_BASE ; | ||||
|   tmp += DOR_OFFSET + ((uint32_t)DAC_Channel >> 2); | ||||
|    | ||||
|   /* Returns the DAC channel data output register value */ | ||||
|   return (uint16_t) (*(__IO uint32_t*) tmp); | ||||
| } | ||||
| 
 | ||||
| /**
 | ||||
|   * @} | ||||
|   */ | ||||
| 
 | ||||
| /** @defgroup DAC_Group2 DMA management functions
 | ||||
|  *  @brief   DMA management functions | ||||
|  * | ||||
| @verbatim | ||||
|  =============================================================================== | ||||
|                     ##### DMA management functions ##### | ||||
|  =============================================================================== | ||||
| 
 | ||||
| @endverbatim | ||||
|   * @{ | ||||
|   */ | ||||
| 
 | ||||
| /**
 | ||||
|   * @brief  Enables or disables the specified DAC channel DMA request. | ||||
|   *         When enabled DMA1 is generated when an external trigger (EXTI Line9, | ||||
|   *         TIM2, TIM4, TIM6, TIM7 or TIM9  but not a software trigger) occurs. | ||||
|   * @param  DAC_Channel: the selected DAC channel. | ||||
|   *   This parameter can be one of the following values: | ||||
|   *     @arg DAC_Channel_1: DAC Channel1 selected | ||||
|   *     @arg DAC_Channel_2: DAC Channel2 selected | ||||
|   * @param  NewState: new state of the selected DAC channel DMA request. | ||||
|   *         This parameter can be: ENABLE or DISABLE. | ||||
|   * @note The DAC channel1 (channel2) is mapped on DMA1 channel3 (channel4) which  | ||||
|   *  must be already configured.  | ||||
|   * @retval None | ||||
|   */ | ||||
| void DAC_DMACmd(uint32_t DAC_Channel, FunctionalState NewState) | ||||
| { | ||||
|   /* Check the parameters */ | ||||
|   assert_param(IS_DAC_CHANNEL(DAC_Channel)); | ||||
|   assert_param(IS_FUNCTIONAL_STATE(NewState)); | ||||
| 
 | ||||
|   if (NewState != DISABLE) | ||||
|   { | ||||
|     /* Enable the selected DAC channel DMA request */ | ||||
|     DAC->CR |= (DAC_CR_DMAEN1 << DAC_Channel); | ||||
|   } | ||||
|   else | ||||
|   { | ||||
|     /* Disable the selected DAC channel DMA request */ | ||||
|     DAC->CR &= (~(DAC_CR_DMAEN1 << DAC_Channel)); | ||||
|   } | ||||
| } | ||||
| 
 | ||||
| /**
 | ||||
|   * @} | ||||
|   */ | ||||
| 
 | ||||
| /** @defgroup DAC_Group3 Interrupts and flags management functions
 | ||||
|  *  @brief   Interrupts and flags management functions | ||||
|  * | ||||
| @verbatim | ||||
|  =============================================================================== | ||||
|             ##### Interrupts and flags management functions ##### | ||||
|  =============================================================================== | ||||
| 
 | ||||
| @endverbatim | ||||
|   * @{ | ||||
|   */ | ||||
| 
 | ||||
| /**
 | ||||
|   * @brief  Enables or disables the specified DAC interrupts. | ||||
|   * @param  DAC_Channel: the selected DAC channel.  | ||||
|   *   This parameter can be one of the following values: | ||||
|   *     @arg DAC_Channel_1: DAC Channel1 selected | ||||
|   *     @arg DAC_Channel_2: DAC Channel2 selected | ||||
|   * @param  DAC_IT: specifies the DAC interrupt sources to be enabled or disabled.  | ||||
|   *   This parameter can be the following value: | ||||
|   *     @arg DAC_IT_DMAUDR: DMA underrun interrupt mask | ||||
|   * @note The DMA underrun occurs when a second external trigger arrives before | ||||
|   *       the acknowledgement for the first external trigger is received (first request). | ||||
|   * @param  NewState: new state of the specified DAC interrupts. | ||||
|   *         This parameter can be: ENABLE or DISABLE. | ||||
|   * @retval None | ||||
|   */  | ||||
| void DAC_ITConfig(uint32_t DAC_Channel, uint32_t DAC_IT, FunctionalState NewState)   | ||||
| { | ||||
|   /* Check the parameters */ | ||||
|   assert_param(IS_DAC_CHANNEL(DAC_Channel)); | ||||
|   assert_param(IS_FUNCTIONAL_STATE(NewState)); | ||||
|   assert_param(IS_DAC_IT(DAC_IT));  | ||||
| 
 | ||||
|   if (NewState != DISABLE) | ||||
|   { | ||||
|     /* Enable the selected DAC interrupts */ | ||||
|     DAC->CR |=  (DAC_IT << DAC_Channel); | ||||
|   } | ||||
|   else | ||||
|   { | ||||
|     /* Disable the selected DAC interrupts */ | ||||
|     DAC->CR &= (~(uint32_t)(DAC_IT << DAC_Channel)); | ||||
|   } | ||||
| } | ||||
| 
 | ||||
| /**
 | ||||
|   * @brief  Checks whether the specified DAC flag is set or not. | ||||
|   * @param  DAC_Channel: thee selected DAC channel.  | ||||
|   *   This parameter can be one of the following values: | ||||
|   *     @arg DAC_Channel_1: DAC Channel1 selected | ||||
|   *     @arg DAC_Channel_2: DAC Channel2 selected | ||||
|   * @param  DAC_FLAG: specifies the flag to check.  | ||||
|   *   This parameter can be only of the following value: | ||||
|   *     @arg DAC_FLAG_DMAUDR: DMA underrun flag | ||||
|   * @note The DMA underrun occurs when a second external trigger arrives before | ||||
|   *       the acknowledgement for the first external trigger is received (first request). | ||||
|   * @retval The new state of DAC_FLAG (SET or RESET). | ||||
|   */ | ||||
| FlagStatus DAC_GetFlagStatus(uint32_t DAC_Channel, uint32_t DAC_FLAG) | ||||
| { | ||||
|   FlagStatus bitstatus = RESET; | ||||
|   /* Check the parameters */ | ||||
|   assert_param(IS_DAC_CHANNEL(DAC_Channel)); | ||||
|   assert_param(IS_DAC_FLAG(DAC_FLAG)); | ||||
| 
 | ||||
|   /* Check the status of the specified DAC flag */ | ||||
|   if ((DAC->SR & (DAC_FLAG << DAC_Channel)) != (uint8_t)RESET) | ||||
|   { | ||||
|     /* DAC_FLAG is set */ | ||||
|     bitstatus = SET; | ||||
|   } | ||||
|   else | ||||
|   { | ||||
|     /* DAC_FLAG is reset */ | ||||
|     bitstatus = RESET; | ||||
|   } | ||||
|   /* Return the DAC_FLAG status */ | ||||
|   return  bitstatus; | ||||
| } | ||||
| 
 | ||||
| /**
 | ||||
|   * @brief  Clears the DAC channel's pending flags. | ||||
|   * @param  DAC_Channel: the selected DAC channel.  | ||||
|   *   This parameter can be one of the following values: | ||||
|   *     @arg DAC_Channel_1: DAC Channel1 selected | ||||
|   *     @arg DAC_Channel_2: DAC Channel2 selected | ||||
|   * @param  DAC_FLAG: specifies the flag to clear.  | ||||
|   *   This parameter can be the following value: | ||||
|   *     @arg DAC_FLAG_DMAUDR: DMA underrun flag | ||||
|   * @retval None | ||||
|   */ | ||||
| void DAC_ClearFlag(uint32_t DAC_Channel, uint32_t DAC_FLAG) | ||||
| { | ||||
|   /* Check the parameters */ | ||||
|   assert_param(IS_DAC_CHANNEL(DAC_Channel)); | ||||
|   assert_param(IS_DAC_FLAG(DAC_FLAG)); | ||||
| 
 | ||||
|   /* Clear the selected DAC flags */ | ||||
|   DAC->SR = (DAC_FLAG << DAC_Channel); | ||||
| } | ||||
| 
 | ||||
| /**
 | ||||
|   * @brief  Checks whether the specified DAC interrupt has occurred or not. | ||||
|   * @param  DAC_Channel: the selected DAC channel.  | ||||
|   *   This parameter can be one of the following values: | ||||
|   *     @arg DAC_Channel_1: DAC Channel1 selected | ||||
|   *     @arg DAC_Channel_2: DAC Channel2 selected | ||||
|   * @param  DAC_IT: specifies the DAC interrupt source to check.  | ||||
|   *   This parameter can be the following values: | ||||
|   *     @arg DAC_IT_DMAUDR: DMA underrun interrupt mask | ||||
|   * @note The DMA underrun occurs when a second external trigger arrives before | ||||
|   *       the acknowledgement for the first external trigger is received (first request). | ||||
|   * @retval The new state of DAC_IT (SET or RESET). | ||||
|   */ | ||||
| ITStatus DAC_GetITStatus(uint32_t DAC_Channel, uint32_t DAC_IT) | ||||
| { | ||||
|   ITStatus bitstatus = RESET; | ||||
|   uint32_t enablestatus = 0; | ||||
|    | ||||
|   /* Check the parameters */ | ||||
|   assert_param(IS_DAC_CHANNEL(DAC_Channel)); | ||||
|   assert_param(IS_DAC_IT(DAC_IT)); | ||||
| 
 | ||||
|   /* Get the DAC_IT enable bit status */ | ||||
|   enablestatus = (DAC->CR & (DAC_IT << DAC_Channel)) ; | ||||
|    | ||||
|   /* Check the status of the specified DAC interrupt */ | ||||
|   if (((DAC->SR & (DAC_IT << DAC_Channel)) != (uint32_t)RESET) && enablestatus) | ||||
|   { | ||||
|     /* DAC_IT is set */ | ||||
|     bitstatus = SET; | ||||
|   } | ||||
|   else | ||||
|   { | ||||
|     /* DAC_IT is reset */ | ||||
|     bitstatus = RESET; | ||||
|   } | ||||
|   /* Return the DAC_IT status */ | ||||
|   return  bitstatus; | ||||
| } | ||||
| 
 | ||||
| /**
 | ||||
|   * @brief  Clears the DAC channel's interrupt pending bits. | ||||
|   * @param  DAC_Channel: the selected DAC channel.  | ||||
|   *   This parameter can be one of the following values: | ||||
|   *     @arg DAC_Channel_1: DAC Channel1 selected | ||||
|   *     @arg DAC_Channel_2: DAC Channel2 selected | ||||
|   * @param  DAC_IT: specifies the DAC interrupt pending bit to clear. | ||||
|   *   This parameter can be the following values: | ||||
|   *     @arg DAC_IT_DMAUDR: DMA underrun interrupt mask | ||||
|   * @retval None | ||||
|   */ | ||||
| void DAC_ClearITPendingBit(uint32_t DAC_Channel, uint32_t DAC_IT) | ||||
| { | ||||
|   /* Check the parameters */ | ||||
|   assert_param(IS_DAC_CHANNEL(DAC_Channel)); | ||||
|   assert_param(IS_DAC_IT(DAC_IT));  | ||||
| 
 | ||||
|   /* Clear the selected DAC interrupt pending bits */ | ||||
|   DAC->SR = (DAC_IT << DAC_Channel); | ||||
| } | ||||
| 
 | ||||
| /**
 | ||||
|   * @} | ||||
|   */ | ||||
| 
 | ||||
| /**
 | ||||
|   * @} | ||||
|   */  | ||||
| 
 | ||||
| /**
 | ||||
|   * @} | ||||
|   */  | ||||
| 
 | ||||
| /**
 | ||||
|   * @} | ||||
|   */  | ||||
| 
 | ||||
| /************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE****/ | ||||
|  | @ -1,181 +0,0 @@ | |||
| /**
 | ||||
|   ****************************************************************************** | ||||
|   * @file    stm32l1xx_dbgmcu.c | ||||
|   * @author  MCD Application Team | ||||
|   * @version V1.1.1 | ||||
|   * @date    05-March-2012 | ||||
|   * @brief   This file provides all the DBGMCU firmware functions. | ||||
|   ****************************************************************************** | ||||
|   * @attention | ||||
|   * | ||||
|   * <h2><center>© COPYRIGHT 2012 STMicroelectronics</center></h2> | ||||
|   * | ||||
|   * Licensed under MCD-ST Liberty SW License Agreement V2, (the "License"); | ||||
|   * You may not use this file except in compliance with the License. | ||||
|   * You may obtain a copy of the License at: | ||||
|   * | ||||
|   *        http://www.st.com/software_license_agreement_liberty_v2
 | ||||
|   * | ||||
|   * Unless required by applicable law or agreed to in writing, software  | ||||
|   * distributed under the License is distributed on an "AS IS" BASIS,  | ||||
|   * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. | ||||
|   * See the License for the specific language governing permissions and | ||||
|   * limitations under the License. | ||||
|   * | ||||
|   ****************************************************************************** | ||||
|   */ | ||||
| 
 | ||||
| /* Includes ------------------------------------------------------------------*/ | ||||
| #include "stm32l1xx_dbgmcu.h" | ||||
| 
 | ||||
| /** @addtogroup STM32L1xx_StdPeriph_Driver
 | ||||
|   * @{ | ||||
|   */ | ||||
| 
 | ||||
| /** @defgroup DBGMCU 
 | ||||
|   * @brief DBGMCU driver modules | ||||
|   * @{ | ||||
|   */  | ||||
| 
 | ||||
| /* Private typedef -----------------------------------------------------------*/ | ||||
| /* Private define ------------------------------------------------------------*/ | ||||
| #define IDCODE_DEVID_MASK    ((uint32_t)0x00000FFF) | ||||
| 
 | ||||
| /* Private macro -------------------------------------------------------------*/ | ||||
| /* Private variables ---------------------------------------------------------*/ | ||||
| /* Private function prototypes -----------------------------------------------*/ | ||||
| /* Private functions ---------------------------------------------------------*/ | ||||
| 
 | ||||
| /** @defgroup DBGMCU_Private_Functions
 | ||||
|   * @{ | ||||
|   */ | ||||
| 
 | ||||
| /**
 | ||||
|   * @brief  Returns the device revision identifier. | ||||
|   * @param  None | ||||
|   * @retval Device revision identifier | ||||
|   */ | ||||
| uint32_t DBGMCU_GetREVID(void) | ||||
| { | ||||
|    return(DBGMCU->IDCODE >> 16); | ||||
| } | ||||
| 
 | ||||
| /**
 | ||||
|   * @brief  Returns the device identifier. | ||||
|   * @param  None | ||||
|   * @retval Device identifier | ||||
|   */ | ||||
| uint32_t DBGMCU_GetDEVID(void) | ||||
| { | ||||
|    return(DBGMCU->IDCODE & IDCODE_DEVID_MASK); | ||||
| } | ||||
| 
 | ||||
| /**
 | ||||
|   * @brief  Configures low power mode behavior when the MCU is in Debug mode. | ||||
|   * @param  DBGMCU_Periph: specifies the low power mode. | ||||
|   *   This parameter can be any combination of the following values: | ||||
|   *     @arg DBGMCU_SLEEP: Keep debugger connection during SLEEP mode | ||||
|   *     @arg DBGMCU_STOP: Keep debugger connection during STOP mode | ||||
|   *     @arg DBGMCU_STANDBY: Keep debugger connection during STANDBY mode | ||||
|   * @param  NewState: new state of the specified low power mode in Debug mode. | ||||
|   *   This parameter can be: ENABLE or DISABLE. | ||||
|   * @retval None | ||||
|   */ | ||||
| void DBGMCU_Config(uint32_t DBGMCU_Periph, FunctionalState NewState) | ||||
| { | ||||
|   /* Check the parameters */ | ||||
|   assert_param(IS_DBGMCU_PERIPH(DBGMCU_Periph)); | ||||
|   assert_param(IS_FUNCTIONAL_STATE(NewState)); | ||||
| 
 | ||||
|   if (NewState != DISABLE) | ||||
|   { | ||||
|     DBGMCU->CR |= DBGMCU_Periph; | ||||
|   } | ||||
|   else | ||||
|   { | ||||
|     DBGMCU->CR &= ~DBGMCU_Periph; | ||||
|   } | ||||
| } | ||||
| 
 | ||||
| 
 | ||||
| /**
 | ||||
|   * @brief  Configures APB1 peripheral behavior when the MCU is in Debug mode. | ||||
|   * @param  DBGMCU_Periph: specifies the APB1 peripheral. | ||||
|   *   This parameter can be any combination of the following values: | ||||
|   *     @arg DBGMCU_TIM2_STOP: TIM2 counter stopped when Core is halted | ||||
|   *     @arg DBGMCU_TIM3_STOP: TIM3 counter stopped when Core is halted | ||||
|   *     @arg DBGMCU_TIM4_STOP: TIM4 counter stopped when Core is halted | ||||
|   *     @arg DBGMCU_TIM5_STOP: TIM5 counter stopped when Core is halted   | ||||
|   *     @arg DBGMCU_TIM6_STOP: TIM6 counter stopped when Core is halted | ||||
|   *     @arg DBGMCU_TIM7_STOP: TIM7 counter stopped when Core is halted | ||||
|   *     @arg DBGMCU_RTC_STOP: | ||||
|   *       + On STM32L1xx Medium-density devices: RTC Wakeup counter stopped when  | ||||
|   *         Core is halted. | ||||
|   *       + On STM32L1xx High-density and Medium-density Plus devices: RTC Calendar  | ||||
|   *         and Wakeup counter stopped when Core is halted. | ||||
|   *     @arg DBGMCU_WWDG_STOP: Debug WWDG stopped when Core is halted | ||||
|   *     @arg DBGMCU_IWDG_STOP: Debug IWDG stopped when Core is halted | ||||
|   *     @arg DBGMCU_I2C1_SMBUS_TIMEOUT: I2C1 SMBUS timeout mode stopped when Core is  | ||||
|   *                                     halted | ||||
|   *     @arg DBGMCU_I2C2_SMBUS_TIMEOUT: I2C2 SMBUS timeout mode stopped when Core is  | ||||
|   *                                     halted | ||||
|   * @param  NewState: new state of the specified APB1 peripheral in Debug mode. | ||||
|   *   This parameter can be: ENABLE or DISABLE. | ||||
|   * @retval None | ||||
|   */ | ||||
| void DBGMCU_APB1PeriphConfig(uint32_t DBGMCU_Periph, FunctionalState NewState) | ||||
| { | ||||
|   /* Check the parameters */ | ||||
|   assert_param(IS_DBGMCU_APB1PERIPH(DBGMCU_Periph)); | ||||
|   assert_param(IS_FUNCTIONAL_STATE(NewState)); | ||||
| 
 | ||||
|   if (NewState != DISABLE) | ||||
|   { | ||||
|     DBGMCU->APB1FZ |= DBGMCU_Periph; | ||||
|   } | ||||
|   else | ||||
|   { | ||||
|     DBGMCU->APB1FZ &= ~DBGMCU_Periph; | ||||
|   } | ||||
| } | ||||
| 
 | ||||
| /**
 | ||||
|   * @brief  Configures APB2 peripheral behavior when the MCU is in Debug mode. | ||||
|   * @param  DBGMCU_Periph: specifies the APB2 peripheral. | ||||
|   *   This parameter can be any combination of the following values: | ||||
|   *     @arg DBGMCU_TIM9_STOP: TIM9 counter stopped when Core is halted | ||||
|   *     @arg DBGMCU_TIM10_STOP: TIM10 counter stopped when Core is halted | ||||
|   *     @arg DBGMCU_TIM11_STOP: TIM11 counter stopped when Core is halted | ||||
|   * @param  NewState: new state of the specified APB2 peripheral in Debug mode. | ||||
|   *   This parameter can be: ENABLE or DISABLE. | ||||
|   * @retval None | ||||
|   */ | ||||
| void DBGMCU_APB2PeriphConfig(uint32_t DBGMCU_Periph, FunctionalState NewState) | ||||
| { | ||||
|   /* Check the parameters */ | ||||
|   assert_param(IS_DBGMCU_APB2PERIPH(DBGMCU_Periph)); | ||||
|   assert_param(IS_FUNCTIONAL_STATE(NewState)); | ||||
| 
 | ||||
|   if (NewState != DISABLE) | ||||
|   { | ||||
|     DBGMCU->APB2FZ |= DBGMCU_Periph; | ||||
|   } | ||||
|   else | ||||
|   { | ||||
|     DBGMCU->APB2FZ &= ~DBGMCU_Periph; | ||||
|   } | ||||
| } | ||||
| 
 | ||||
| /**
 | ||||
|   * @} | ||||
|   */ | ||||
| 
 | ||||
| /**
 | ||||
|   * @} | ||||
|   */ | ||||
| 
 | ||||
| /**
 | ||||
|   * @} | ||||
|   */ | ||||
| 
 | ||||
| /************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE****/ | ||||
|  | @ -1,866 +0,0 @@ | |||
| /**
 | ||||
|   ****************************************************************************** | ||||
|   * @file    stm32l1xx_dma.c | ||||
|   * @author  MCD Application Team | ||||
|   * @version V1.1.1 | ||||
|   * @date    05-March-2012 | ||||
|   * @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 ##### | ||||
|   ============================================================================== | ||||
|     [..] | ||||
|     (#) 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. | ||||
|     (#) Enable and configure the peripheral to be connected to the DMA channel | ||||
|                (except for internal SRAM / FLASH memories: no initialization is  | ||||
|                necessary). | ||||
|     (#) 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. | ||||
|     (#) Enable the NVIC and the corresponding interrupt(s) using the function  | ||||
|         DMA_ITConfig() if you need to use DMA interrupts. | ||||
|     (#) Enable the DMA channel using the DMA_Cmd() function. | ||||
|     (#) 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). | ||||
|     (#) 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). | ||||
|     (#) To control DMA events you can use one of the following two methods: | ||||
|         (##) Check on DMA channel flags using the function DMA_GetFlagStatus(). | ||||
|         (##) 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 | ||||
|   * | ||||
|   * <h2><center>© COPYRIGHT 2012 STMicroelectronics</center></h2> | ||||
|   * | ||||
|   * Licensed under MCD-ST Liberty SW License Agreement V2, (the "License"); | ||||
|   * You may not use this file except in compliance with the License. | ||||
|   * You may obtain a copy of the License at: | ||||
|   * | ||||
|   *        http://www.st.com/software_license_agreement_liberty_v2
 | ||||
|   * | ||||
|   * Unless required by applicable law or agreed to in writing, software  | ||||
|   * distributed under the License is distributed on an "AS IS" BASIS,  | ||||
|   * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. | ||||
|   * See the License for the specific language governing permissions and | ||||
|   * limitations under the License. | ||||
|   * | ||||
|   ****************************************************************************** | ||||
|   */ | ||||
| 
 | ||||
| /* 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)) | ||||
| 
 | ||||
| /* DMA2 Channelx interrupt pending bit masks */ | ||||
| #define DMA2_CHANNEL1_IT_MASK    ((uint32_t)(DMA_ISR_GIF1 | DMA_ISR_TCIF1 | DMA_ISR_HTIF1 | DMA_ISR_TEIF1)) | ||||
| #define DMA2_CHANNEL2_IT_MASK    ((uint32_t)(DMA_ISR_GIF2 | DMA_ISR_TCIF2 | DMA_ISR_HTIF2 | DMA_ISR_TEIF2)) | ||||
| #define DMA2_CHANNEL3_IT_MASK    ((uint32_t)(DMA_ISR_GIF3 | DMA_ISR_TCIF3 | DMA_ISR_HTIF3 | DMA_ISR_TEIF3)) | ||||
| #define DMA2_CHANNEL4_IT_MASK    ((uint32_t)(DMA_ISR_GIF4 | DMA_ISR_TCIF4 | DMA_ISR_HTIF4 | DMA_ISR_TEIF4)) | ||||
| #define DMA2_CHANNEL5_IT_MASK    ((uint32_t)(DMA_ISR_GIF5 | DMA_ISR_TCIF5 | DMA_ISR_HTIF5 | DMA_ISR_TEIF5)) | ||||
| 
 | ||||
| /* 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 or 2 to select the DMA and x can be  | ||||
|   *         1 to 7 for DMA1 and 1 to 5 for DMA2 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; | ||||
|   } | ||||
|   else if (DMAy_Channelx == DMA2_Channel1) | ||||
|   { | ||||
|     /* Reset interrupt pending bits for DMA2 Channel1 */ | ||||
|     DMA2->IFCR |= DMA2_CHANNEL1_IT_MASK; | ||||
|   } | ||||
|   else if (DMAy_Channelx == DMA2_Channel2) | ||||
|   { | ||||
|     /* Reset interrupt pending bits for DMA2 Channel2 */ | ||||
|     DMA2->IFCR |= DMA2_CHANNEL2_IT_MASK; | ||||
|   } | ||||
|   else if (DMAy_Channelx == DMA2_Channel3) | ||||
|   { | ||||
|     /* Reset interrupt pending bits for DMA2 Channel3 */ | ||||
|     DMA2->IFCR |= DMA2_CHANNEL3_IT_MASK; | ||||
|   } | ||||
|   else if (DMAy_Channelx == DMA2_Channel4) | ||||
|   { | ||||
|     /* Reset interrupt pending bits for DMA2 Channel4 */ | ||||
|     DMA2->IFCR |= DMA2_CHANNEL4_IT_MASK; | ||||
|   } | ||||
|   else | ||||
|   {  | ||||
|     if (DMAy_Channelx == DMA2_Channel5) | ||||
|     { | ||||
|       /* Reset interrupt pending bits for DMA2 Channel5 */ | ||||
|       DMA2->IFCR |= DMA2_CHANNEL5_IT_MASK; | ||||
|     } | ||||
|   } | ||||
| } | ||||
| 
 | ||||
| /**
 | ||||
|   * @brief  Initializes the DMAy Channelx according to the specified | ||||
|   *         parameters in the DMA_InitStruct. | ||||
|   * @param  DMAy_Channelx: where y can be 1 or 2 to select the DMA and x can be  | ||||
|   *         1 to 7 for DMA1 and 1 to 5 for DMA2 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 */ | ||||
|   DMAy_Channelx->CNDTR = DMA_InitStruct->DMA_BufferSize; | ||||
| 
 | ||||
| /*--------------------------- DMAy Channelx CPAR Configuration ----------------*/ | ||||
|   /* Write to DMAy Channelx CPAR */ | ||||
|   DMAy_Channelx->CPAR = DMA_InitStruct->DMA_PeripheralBaseAddr; | ||||
| 
 | ||||
| /*--------------------------- DMAy Channelx CMAR Configuration ----------------*/ | ||||
|   /* Write to DMAy Channelx CMAR */ | ||||
|   DMAy_Channelx->CMAR = DMA_InitStruct->DMA_MemoryBaseAddr; | ||||
| } | ||||
| 
 | ||||
| /**
 | ||||
|   * @brief  Fills each DMA_InitStruct member with its default value. | ||||
|   * @param  DMA_InitStruct: pointer to a DMA_InitTypeDef structure which will | ||||
|   *         be initialized. | ||||
|   * @retval None | ||||
|   */ | ||||
| void DMA_StructInit(DMA_InitTypeDef* DMA_InitStruct) | ||||
| { | ||||
| /*-------------- Reset DMA init structure parameters values ------------------*/ | ||||
|   /* Initialize the DMA_PeripheralBaseAddr member */ | ||||
|   DMA_InitStruct->DMA_PeripheralBaseAddr = 0; | ||||
|   /* Initialize the DMA_MemoryBaseAddr member */ | ||||
|   DMA_InitStruct->DMA_MemoryBaseAddr = 0; | ||||
|   /* Initialize the DMA_DIR member */ | ||||
|   DMA_InitStruct->DMA_DIR = DMA_DIR_PeripheralSRC; | ||||
|   /* Initialize the DMA_BufferSize member */ | ||||
|   DMA_InitStruct->DMA_BufferSize = 0; | ||||
|   /* Initialize the DMA_PeripheralInc member */ | ||||
|   DMA_InitStruct->DMA_PeripheralInc = DMA_PeripheralInc_Disable; | ||||
|   /* Initialize the DMA_MemoryInc member */ | ||||
|   DMA_InitStruct->DMA_MemoryInc = DMA_MemoryInc_Disable; | ||||
|   /* Initialize the DMA_PeripheralDataSize member */ | ||||
|   DMA_InitStruct->DMA_PeripheralDataSize = DMA_PeripheralDataSize_Byte; | ||||
|   /* Initialize the DMA_MemoryDataSize member */ | ||||
|   DMA_InitStruct->DMA_MemoryDataSize = DMA_MemoryDataSize_Byte; | ||||
|   /* Initialize the DMA_Mode member */ | ||||
|   DMA_InitStruct->DMA_Mode = DMA_Mode_Normal; | ||||
|   /* Initialize the DMA_Priority member */ | ||||
|   DMA_InitStruct->DMA_Priority = DMA_Priority_Low; | ||||
|   /* Initialize the DMA_M2M member */ | ||||
|   DMA_InitStruct->DMA_M2M = DMA_M2M_Disable; | ||||
| } | ||||
| 
 | ||||
| /**
 | ||||
|   * @brief  Enables or disables the specified DMAy Channelx. | ||||
|   * @param  DMAy_Channelx: where y can be 1 or 2 to select the DMA and x can be  | ||||
|   *         1 to 7 for DMA1 and 1 to 5 for DMA2 to select the DMA Channel. | ||||
|   * @param  NewState: new state of the DMAy Channelx.  | ||||
|   *         This parameter can be: ENABLE or DISABLE. | ||||
|   * @retval None | ||||
|   */ | ||||
| void DMA_Cmd(DMA_Channel_TypeDef* DMAy_Channelx, FunctionalState NewState) | ||||
| { | ||||
|   /* Check the parameters */ | ||||
|   assert_param(IS_DMA_ALL_PERIPH(DMAy_Channelx)); | ||||
|   assert_param(IS_FUNCTIONAL_STATE(NewState)); | ||||
| 
 | ||||
|   if (NewState != DISABLE) | ||||
|   { | ||||
|     /* Enable the selected DMAy Channelx */ | ||||
|     DMAy_Channelx->CCR |= DMA_CCR1_EN; | ||||
|   } | ||||
|   else | ||||
|   { | ||||
|     /* Disable the selected DMAy Channelx */ | ||||
|     DMAy_Channelx->CCR &= (uint16_t)(~DMA_CCR1_EN); | ||||
|   } | ||||
| } | ||||
| 
 | ||||
| /**
 | ||||
|   * @} | ||||
|   */ | ||||
| 
 | ||||
| /** @defgroup DMA_Group2 Data Counter functions
 | ||||
|  *  @brief   Data Counter functions  | ||||
|  * | ||||
| @verbatim    | ||||
|  =============================================================================== | ||||
|                       ##### Data Counter functions ##### | ||||
|  =============================================================================== | ||||
|     [..] This subsection provides function allowing to configure and read the buffer  | ||||
|          size (number of data to be transferred).The DMA data counter can be written  | ||||
|          only when the DMA channel is disabled (ie. after transfer complete event). | ||||
|     [..] The following function can be used to write the Channel data counter value: | ||||
|          (+) void DMA_SetCurrDataCounter(DMA_Channel_TypeDef* DMAy_Channelx, uint16_t  | ||||
|              DataNumber). | ||||
|     -@- It is advised to use this function rather than DMA_Init() in situations  | ||||
|         where only the Data buffer needs to be reloaded. | ||||
|     [..] The DMA data counter can be read to indicate the number of remaining transfers  | ||||
|          for the relative DMA channel. This counter is decremented at the end of each  | ||||
|          data transfer and when the transfer is complete:  | ||||
|          (+) If Normal mode is selected: the counter is set to 0. | ||||
|          (+) If Circular mode is selected: the counter is reloaded with the initial  | ||||
|          value(configured before enabling the DMA channel). | ||||
|     [..] The following function can be used to read the Channel data counter value: | ||||
|          (+) uint16_t DMA_GetCurrDataCounter(DMA_Channel_TypeDef* DMAy_Channelx). | ||||
| 
 | ||||
| @endverbatim | ||||
|   * @{ | ||||
|   */ | ||||
| 
 | ||||
| /**
 | ||||
|   * @brief  Sets the number of data units in the current DMAy Channelx transfer. | ||||
|   * @param  DMAy_Channelx: where y can be 1 or 2 to select the DMA and x can be  | ||||
|   *         1 to 7 for DMA1 and 1 to 5 for DMA2 to select the DMA Channel. | ||||
|   * @param  DataNumber: The number of data units in the current DMAy Channelx | ||||
|   *         transfer. | ||||
|   * @note   This function can only be used when the DMAy_Channelx is disabled. | ||||
|   * @retval None. | ||||
|   */ | ||||
| void DMA_SetCurrDataCounter(DMA_Channel_TypeDef* DMAy_Channelx, uint16_t DataNumber) | ||||
| { | ||||
|   /* Check the parameters */ | ||||
|   assert_param(IS_DMA_ALL_PERIPH(DMAy_Channelx)); | ||||
|    | ||||
| /*--------------------------- DMAy Channelx CNDTR Configuration ---------------*/ | ||||
|   /* Write to DMAy Channelx CNDTR */ | ||||
|   DMAy_Channelx->CNDTR = DataNumber;   | ||||
| } | ||||
| 
 | ||||
| /**
 | ||||
|   * @brief  Returns the number of remaining data units in the current | ||||
|   *         DMAy Channelx transfer. | ||||
|   * @param  DMAy_Channelx: where y can be 1 or 2 to select the DMA and x can be  | ||||
|   *         1 to 7 for DMA1 and 1 to 5 for DMA2 to select the DMA Channel. | ||||
|   * @retval The number of remaining data units in the current DMAy Channelx | ||||
|   *         transfer. | ||||
|   */ | ||||
| uint16_t DMA_GetCurrDataCounter(DMA_Channel_TypeDef* DMAy_Channelx) | ||||
| { | ||||
|   /* Check the parameters */ | ||||
|   assert_param(IS_DMA_ALL_PERIPH(DMAy_Channelx)); | ||||
|   /* Return the number of remaining data units for DMAy Channelx */ | ||||
|   return ((uint16_t)(DMAy_Channelx->CNDTR)); | ||||
| } | ||||
| 
 | ||||
| /**
 | ||||
|   * @} | ||||
|   */ | ||||
| 
 | ||||
| /** @defgroup DMA_Group3 Interrupts and flags management functions
 | ||||
|  *  @brief   Interrupts and flags management functions  | ||||
|  * | ||||
| @verbatim    | ||||
|  =============================================================================== | ||||
|           ##### Interrupts and flags management functions ##### | ||||
|  =============================================================================== | ||||
|     [..] This subsection provides functions allowing to configure the DMA Interrupts  | ||||
|          sources and check or clear the flags or pending bits status. | ||||
|          The user should identify which mode will be used in his application to manage  | ||||
|          the DMA controller events: Polling mode or Interrupt mode.  | ||||
|   *** Polling Mode *** | ||||
|   ==================== | ||||
|     [..] Each DMA channel can be managed through 4 event Flags:(y : DMA Controller  | ||||
|          number  x : DMA channel number ). | ||||
|          (#) DMAy_FLAG_TCx : to indicate that a Transfer Complete event occurred. | ||||
|          (#) DMAy_FLAG_HTx : to indicate that a Half-Transfer Complete event occurred. | ||||
|          (#) DMAy_FLAG_TEx : to indicate that a Transfer Error occurred. | ||||
|          (#) DMAy_FLAG_GLx : to indicate that at least one of the events described  | ||||
|              above occurred. | ||||
|     -@- Clearing DMAy_FLAG_GLx results in clearing all other pending flags of the  | ||||
|         same channel (DMAy_FLAG_TCx, DMAy_FLAG_HTx and DMAy_FLAG_TEx). | ||||
|     [..]In this Mode it is advised to use the following functions: | ||||
|         (+) FlagStatus DMA_GetFlagStatus(uint32_t DMA_FLAG); | ||||
|         (+) void DMA_ClearFlag(uint32_t DMA_FLAG); | ||||
| 
 | ||||
|   *** Interrupt Mode *** | ||||
|   ====================== | ||||
|     [..] Each DMA channel can be managed through 4 Interrupts: | ||||
|     (+) Interrupt Source | ||||
|        (##) DMA_IT_TC: specifies the interrupt source for the Transfer Complete  | ||||
|             event. | ||||
|        (##) DMA_IT_HT : specifies the interrupt source for the Half-transfer Complete  | ||||
|             event. | ||||
|        (##) DMA_IT_TE : specifies the interrupt source for the transfer errors event. | ||||
|        (##) DMA_IT_GL : to indicate that at least one of the interrupts described  | ||||
|             above occurred. | ||||
|     -@@- Clearing DMA_IT_GL interrupt results in clearing all other interrupts of  | ||||
|         the same channel (DMA_IT_TCx, DMA_IT_HT and DMA_IT_TE). | ||||
|     [..]In this Mode it is advised to use the following functions: | ||||
|         (+) void DMA_ITConfig(DMA_Channel_TypeDef* DMAy_Channelx, uint32_t DMA_IT,  | ||||
|             FunctionalState NewState); | ||||
|         (+) ITStatus DMA_GetITStatus(uint32_t DMA_IT); | ||||
|         (+) void DMA_ClearITPendingBit(uint32_t DMA_IT); | ||||
| 
 | ||||
| @endverbatim | ||||
|   * @{ | ||||
|   */ | ||||
| 
 | ||||
| /**
 | ||||
|   * @brief  Enables or disables the specified DMAy Channelx interrupts. | ||||
|   * @param  DMAy_Channelx: where y can be 1 or 2 to select the DMA and x can be  | ||||
|   *         1 to 7 for DMA1 and 1 to 5 for DMA2 to select the DMA Channel. | ||||
|   * @param  DMA_IT: specifies the DMA interrupts sources to be enabled | ||||
|   *         or disabled.  | ||||
|   *   This parameter can be any combination of the following values: | ||||
|   *     @arg DMA_IT_TC: Transfer complete interrupt mask | ||||
|   *     @arg DMA_IT_HT: Half transfer interrupt mask | ||||
|   *     @arg DMA_IT_TE: Transfer error interrupt mask | ||||
|   * @param  NewState: new state of the specified DMA interrupts. | ||||
|   *         This parameter can be: ENABLE or DISABLE. | ||||
|   * @retval None | ||||
|   */ | ||||
| void DMA_ITConfig(DMA_Channel_TypeDef* DMAy_Channelx, uint32_t DMA_IT, FunctionalState NewState) | ||||
| { | ||||
|   /* Check the parameters */ | ||||
|   assert_param(IS_DMA_ALL_PERIPH(DMAy_Channelx)); | ||||
|   assert_param(IS_DMA_CONFIG_IT(DMA_IT)); | ||||
|   assert_param(IS_FUNCTIONAL_STATE(NewState)); | ||||
| 
 | ||||
|   if (NewState != DISABLE) | ||||
|   { | ||||
|     /* Enable the selected DMA interrupts */ | ||||
|     DMAy_Channelx->CCR |= DMA_IT; | ||||
|   } | ||||
|   else | ||||
|   { | ||||
|     /* Disable the selected DMA interrupts */ | ||||
|     DMAy_Channelx->CCR &= ~DMA_IT; | ||||
|   } | ||||
| } | ||||
| 
 | ||||
| /**
 | ||||
|   * @brief  Checks whether the specified DMAy Channelx flag is set or not. | ||||
|   * @param  DMAy_FLAG: specifies the flag to check. | ||||
|   *   This parameter can be one of the following values: | ||||
|   *     @arg DMA1_FLAG_GL1: DMA1 Channel1 global flag. | ||||
|   *     @arg DMA1_FLAG_TC1: DMA1 Channel1 transfer complete flag. | ||||
|   *     @arg DMA1_FLAG_HT1: DMA1 Channel1 half transfer flag. | ||||
|   *     @arg DMA1_FLAG_TE1: DMA1 Channel1 transfer error flag. | ||||
|   *     @arg DMA1_FLAG_GL2: DMA1 Channel2 global flag. | ||||
|   *     @arg DMA1_FLAG_TC2: DMA1 Channel2 transfer complete flag. | ||||
|   *     @arg DMA1_FLAG_HT2: DMA1 Channel2 half transfer flag. | ||||
|   *     @arg DMA1_FLAG_TE2: DMA1 Channel2 transfer error flag. | ||||
|   *     @arg DMA1_FLAG_GL3: DMA1 Channel3 global flag. | ||||
|   *     @arg DMA1_FLAG_TC3: DMA1 Channel3 transfer complete flag. | ||||
|   *     @arg DMA1_FLAG_HT3: DMA1 Channel3 half transfer flag. | ||||
|   *     @arg DMA1_FLAG_TE3: DMA1 Channel3 transfer error flag. | ||||
|   *     @arg DMA1_FLAG_GL4: DMA1 Channel4 global flag. | ||||
|   *     @arg DMA1_FLAG_TC4: DMA1 Channel4 transfer complete flag. | ||||
|   *     @arg DMA1_FLAG_HT4: DMA1 Channel4 half transfer flag. | ||||
|   *     @arg DMA1_FLAG_TE4: DMA1 Channel4 transfer error flag. | ||||
|   *     @arg DMA1_FLAG_GL5: DMA1 Channel5 global flag. | ||||
|   *     @arg DMA1_FLAG_TC5: DMA1 Channel5 transfer complete flag. | ||||
|   *     @arg DMA1_FLAG_HT5: DMA1 Channel5 half transfer flag. | ||||
|   *     @arg DMA1_FLAG_TE5: DMA1 Channel5 transfer error flag. | ||||
|   *     @arg DMA1_FLAG_GL6: DMA1 Channel6 global flag. | ||||
|   *     @arg DMA1_FLAG_TC6: DMA1 Channel6 transfer complete flag. | ||||
|   *     @arg DMA1_FLAG_HT6: DMA1 Channel6 half transfer flag. | ||||
|   *     @arg DMA1_FLAG_TE6: DMA1 Channel6 transfer error flag. | ||||
|   *     @arg DMA1_FLAG_GL7: DMA1 Channel7 global flag. | ||||
|   *     @arg DMA1_FLAG_TC7: DMA1 Channel7 transfer complete flag. | ||||
|   *     @arg DMA1_FLAG_HT7: DMA1 Channel7 half transfer flag. | ||||
|   *     @arg DMA1_FLAG_TE7: DMA1 Channel7 transfer error flag. | ||||
|   *     @arg DMA2_FLAG_GL1: DMA2 Channel1 global flag. | ||||
|   *     @arg DMA2_FLAG_TC1: DMA2 Channel1 transfer complete flag. | ||||
|   *     @arg DMA2_FLAG_HT1: DMA2 Channel1 half transfer flag. | ||||
|   *     @arg DMA2_FLAG_TE1: DMA2 Channel1 transfer error flag. | ||||
|   *     @arg DMA2_FLAG_GL2: DMA2 Channel2 global flag. | ||||
|   *     @arg DMA2_FLAG_TC2: DMA2 Channel2 transfer complete flag. | ||||
|   *     @arg DMA2_FLAG_HT2: DMA2 Channel2 half transfer flag. | ||||
|   *     @arg DMA2_FLAG_TE2: DMA2 Channel2 transfer error flag. | ||||
|   *     @arg DMA2_FLAG_GL3: DMA2 Channel3 global flag. | ||||
|   *     @arg DMA2_FLAG_TC3: DMA2 Channel3 transfer complete flag. | ||||
|   *     @arg DMA2_FLAG_HT3: DMA2 Channel3 half transfer flag. | ||||
|   *     @arg DMA2_FLAG_TE3: DMA2 Channel3 transfer error flag. | ||||
|   *     @arg DMA2_FLAG_GL4: DMA2 Channel4 global flag. | ||||
|   *     @arg DMA2_FLAG_TC4: DMA2 Channel4 transfer complete flag. | ||||
|   *     @arg DMA2_FLAG_HT4: DMA2 Channel4 half transfer flag. | ||||
|   *     @arg DMA2_FLAG_TE4: DMA2 Channel4 transfer error flag. | ||||
|   *     @arg DMA2_FLAG_GL5: DMA2 Channel5 global flag. | ||||
|   *     @arg DMA2_FLAG_TC5: DMA2 Channel5 transfer complete flag. | ||||
|   *     @arg DMA2_FLAG_HT5: DMA2 Channel5 half transfer flag. | ||||
|   *     @arg DMA2_FLAG_TE5: DMA2 Channel5 transfer error flag. | ||||
|   *      | ||||
|   * @note | ||||
|   *    The Global flag (DMAy_FLAG_GLx) is set whenever any of the other flags  | ||||
|   *    relative to the same channel is set (Transfer Complete, Half-transfer  | ||||
|   *    Complete or Transfer Error flags: DMAy_FLAG_TCx, DMAy_FLAG_HTx or  | ||||
|   *    DMAy_FLAG_TEx).  | ||||
|   *       | ||||
|   * @retval The new state of DMAy_FLAG (SET or RESET). | ||||
|   */ | ||||
| FlagStatus DMA_GetFlagStatus(uint32_t DMAy_FLAG) | ||||
| { | ||||
|   FlagStatus bitstatus = RESET; | ||||
|   uint32_t tmpreg = 0; | ||||
| 
 | ||||
|   /* Check the parameters */ | ||||
|   assert_param(IS_DMA_GET_FLAG(DMAy_FLAG)); | ||||
| 
 | ||||
|   /* Calculate the used DMAy */ | ||||
|   if ((DMAy_FLAG & FLAG_MASK) == (uint32_t)RESET) | ||||
|   { | ||||
|     /* Get DMA1 ISR register value */ | ||||
|     tmpreg = DMA1->ISR; | ||||
|   } | ||||
|   else | ||||
|   { | ||||
|     /* Get DMA2 ISR register value */ | ||||
|     tmpreg = DMA2->ISR; | ||||
|   } | ||||
| 
 | ||||
|   /* Check the status of the specified DMAy flag */ | ||||
|   if ((tmpreg & DMAy_FLAG) != (uint32_t)RESET) | ||||
|   { | ||||
|     /* DMAy_FLAG is set */ | ||||
|     bitstatus = SET; | ||||
|   } | ||||
|   else | ||||
|   { | ||||
|     /* DMAy_FLAG is reset */ | ||||
|     bitstatus = RESET; | ||||
|   } | ||||
|    | ||||
|   /* Return the DMAy_FLAG status */ | ||||
|   return  bitstatus; | ||||
| } | ||||
| 
 | ||||
| /**
 | ||||
|   * @brief  Clears the DMAy Channelx's pending flags. | ||||
|   * @param  DMAy_FLAG: specifies the flag to clear. | ||||
|   *   This parameter can be any combination (for the same DMA) of the following values: | ||||
|   *     @arg DMA1_FLAG_GL1: DMA1 Channel1 global flag. | ||||
|   *     @arg DMA1_FLAG_TC1: DMA1 Channel1 transfer complete flag. | ||||
|   *     @arg DMA1_FLAG_HT1: DMA1 Channel1 half transfer flag. | ||||
|   *     @arg DMA1_FLAG_TE1: DMA1 Channel1 transfer error flag. | ||||
|   *     @arg DMA1_FLAG_GL2: DMA1 Channel2 global flag. | ||||
|   *     @arg DMA1_FLAG_TC2: DMA1 Channel2 transfer complete flag. | ||||
|   *     @arg DMA1_FLAG_HT2: DMA1 Channel2 half transfer flag. | ||||
|   *     @arg DMA1_FLAG_TE2: DMA1 Channel2 transfer error flag. | ||||
|   *     @arg DMA1_FLAG_GL3: DMA1 Channel3 global flag. | ||||
|   *     @arg DMA1_FLAG_TC3: DMA1 Channel3 transfer complete flag. | ||||
|   *     @arg DMA1_FLAG_HT3: DMA1 Channel3 half transfer flag. | ||||
|   *     @arg DMA1_FLAG_TE3: DMA1 Channel3 transfer error flag. | ||||
|   *     @arg DMA1_FLAG_GL4: DMA1 Channel4 global flag. | ||||
|   *     @arg DMA1_FLAG_TC4: DMA1 Channel4 transfer complete flag. | ||||
|   *     @arg DMA1_FLAG_HT4: DMA1 Channel4 half transfer flag. | ||||
|   *     @arg DMA1_FLAG_TE4: DMA1 Channel4 transfer error flag. | ||||
|   *     @arg DMA1_FLAG_GL5: DMA1 Channel5 global flag. | ||||
|   *     @arg DMA1_FLAG_TC5: DMA1 Channel5 transfer complete flag. | ||||
|   *     @arg DMA1_FLAG_HT5: DMA1 Channel5 half transfer flag. | ||||
|   *     @arg DMA1_FLAG_TE5: DMA1 Channel5 transfer error flag. | ||||
|   *     @arg DMA1_FLAG_GL6: DMA1 Channel6 global flag. | ||||
|   *     @arg DMA1_FLAG_TC6: DMA1 Channel6 transfer complete flag. | ||||
|   *     @arg DMA1_FLAG_HT6: DMA1 Channel6 half transfer flag. | ||||
|   *     @arg DMA1_FLAG_TE6: DMA1 Channel6 transfer error flag. | ||||
|   *     @arg DMA1_FLAG_GL7: DMA1 Channel7 global flag. | ||||
|   *     @arg DMA1_FLAG_TC7: DMA1 Channel7 transfer complete flag. | ||||
|   *     @arg DMA1_FLAG_HT7: DMA1 Channel7 half transfer flag. | ||||
|   *     @arg DMA1_FLAG_TE7: DMA1 Channel7 transfer error flag. | ||||
|   *     @arg DMA2_FLAG_GL1: DMA2 Channel1 global flag. | ||||
|   *     @arg DMA2_FLAG_TC1: DMA2 Channel1 transfer complete flag. | ||||
|   *     @arg DMA2_FLAG_HT1: DMA2 Channel1 half transfer flag. | ||||
|   *     @arg DMA2_FLAG_TE1: DMA2 Channel1 transfer error flag. | ||||
|   *     @arg DMA2_FLAG_GL2: DMA2 Channel2 global flag. | ||||
|   *     @arg DMA2_FLAG_TC2: DMA2 Channel2 transfer complete flag. | ||||
|   *     @arg DMA2_FLAG_HT2: DMA2 Channel2 half transfer flag. | ||||
|   *     @arg DMA2_FLAG_TE2: DMA2 Channel2 transfer error flag. | ||||
|   *     @arg DMA2_FLAG_GL3: DMA2 Channel3 global flag. | ||||
|   *     @arg DMA2_FLAG_TC3: DMA2 Channel3 transfer complete flag. | ||||
|   *     @arg DMA2_FLAG_HT3: DMA2 Channel3 half transfer flag. | ||||
|   *     @arg DMA2_FLAG_TE3: DMA2 Channel3 transfer error flag. | ||||
|   *     @arg DMA2_FLAG_GL4: DMA2 Channel4 global flag. | ||||
|   *     @arg DMA2_FLAG_TC4: DMA2 Channel4 transfer complete flag. | ||||
|   *     @arg DMA2_FLAG_HT4: DMA2 Channel4 half transfer flag. | ||||
|   *     @arg DMA2_FLAG_TE4: DMA2 Channel4 transfer error flag. | ||||
|   *     @arg DMA2_FLAG_GL5: DMA2 Channel5 global flag. | ||||
|   *     @arg DMA2_FLAG_TC5: DMA2 Channel5 transfer complete flag. | ||||
|   *     @arg DMA2_FLAG_HT5: DMA2 Channel5 half transfer flag. | ||||
|   *     @arg DMA2_FLAG_TE5: DMA2 Channel5 transfer error flag.        | ||||
|   *      | ||||
|   * @note | ||||
|   *    Clearing the Global flag (DMAy_FLAG_GLx) results in clearing all other flags | ||||
|   *    relative to the same channel (Transfer Complete, Half-transfer Complete and  | ||||
|   *    Transfer Error flags: DMAy_FLAG_TCx, DMAy_FLAG_HTx and DMAy_FLAG_TEx).   | ||||
|   *       | ||||
|   * @retval None | ||||
|   */ | ||||
| void DMA_ClearFlag(uint32_t DMAy_FLAG) | ||||
| { | ||||
|   /* Check the parameters */ | ||||
|   assert_param(IS_DMA_CLEAR_FLAG(DMAy_FLAG)); | ||||
| 
 | ||||
|   if ((DMAy_FLAG & FLAG_MASK) == (uint32_t)RESET) | ||||
|   { | ||||
|     /* Clear the selected DMAy flags */ | ||||
|     DMA1->IFCR = DMAy_FLAG; | ||||
|   } | ||||
|   else | ||||
|   { | ||||
|     /* Clear the selected DMAy flags */ | ||||
|     DMA2->IFCR = DMAy_FLAG; | ||||
|   }   | ||||
| } | ||||
| 
 | ||||
| /**
 | ||||
|   * @brief  Checks whether the specified DMAy Channelx interrupt has occurred or not. | ||||
|   * @param  DMAy_IT: specifies the DMAy interrupt source to check.  | ||||
|   *   This parameter can be one of the following values: | ||||
|   *     @arg DMA1_IT_GL1: DMA1 Channel1 global interrupt. | ||||
|   *     @arg DMA1_IT_TC1: DMA1 Channel1 transfer complete interrupt. | ||||
|   *     @arg DMA1_IT_HT1: DMA1 Channel1 half transfer interrupt. | ||||
|   *     @arg DMA1_IT_TE1: DMA1 Channel1 transfer error interrupt. | ||||
|   *     @arg DMA1_IT_GL2: DMA1 Channel2 global interrupt. | ||||
|   *     @arg DMA1_IT_TC2: DMA1 Channel2 transfer complete interrupt. | ||||
|   *     @arg DMA1_IT_HT2: DMA1 Channel2 half transfer interrupt. | ||||
|   *     @arg DMA1_IT_TE2: DMA1 Channel2 transfer error interrupt. | ||||
|   *     @arg DMA1_IT_GL3: DMA1 Channel3 global interrupt. | ||||
|   *     @arg DMA1_IT_TC3: DMA1 Channel3 transfer complete interrupt. | ||||
|   *     @arg DMA1_IT_HT3: DMA1 Channel3 half transfer interrupt. | ||||
|   *     @arg DMA1_IT_TE3: DMA1 Channel3 transfer error interrupt. | ||||
|   *     @arg DMA1_IT_GL4: DMA1 Channel4 global interrupt. | ||||
|   *     @arg DMA1_IT_TC4: DMA1 Channel4 transfer complete interrupt. | ||||
|   *     @arg DMA1_IT_HT4: DMA1 Channel4 half transfer interrupt. | ||||
|   *     @arg DMA1_IT_TE4: DMA1 Channel4 transfer error interrupt. | ||||
|   *     @arg DMA1_IT_GL5: DMA1 Channel5 global interrupt. | ||||
|   *     @arg DMA1_IT_TC5: DMA1 Channel5 transfer complete interrupt. | ||||
|   *     @arg DMA1_IT_HT5: DMA1 Channel5 half transfer interrupt. | ||||
|   *     @arg DMA1_IT_TE5: DMA1 Channel5 transfer error interrupt. | ||||
|   *     @arg DMA1_IT_GL6: DMA1 Channel6 global interrupt. | ||||
|   *     @arg DMA1_IT_TC6: DMA1 Channel6 transfer complete interrupt. | ||||
|   *     @arg DMA1_IT_HT6: DMA1 Channel6 half transfer interrupt. | ||||
|   *     @arg DMA1_IT_TE6: DMA1 Channel6 transfer error interrupt. | ||||
|   *     @arg DMA1_IT_GL7: DMA1 Channel7 global interrupt. | ||||
|   *     @arg DMA1_IT_TC7: DMA1 Channel7 transfer complete interrupt. | ||||
|   *     @arg DMA1_IT_HT7: DMA1 Channel7 half transfer interrupt. | ||||
|   *     @arg DMA1_IT_TE7: DMA1 Channel7 transfer error interrupt. | ||||
|   *     @arg DMA2_IT_GL1: DMA2 Channel1 global interrupt. | ||||
|   *     @arg DMA2_IT_TC1: DMA2 Channel1 transfer complete interrupt. | ||||
|   *     @arg DMA2_IT_HT1: DMA2 Channel1 half transfer interrupt. | ||||
|   *     @arg DMA2_IT_TE1: DMA2 Channel1 transfer error interrupt. | ||||
|   *     @arg DMA2_IT_GL2: DMA2 Channel2 global interrupt. | ||||
|   *     @arg DMA2_IT_TC2: DMA2 Channel2 transfer complete interrupt. | ||||
|   *     @arg DMA2_IT_HT2: DMA2 Channel2 half transfer interrupt. | ||||
|   *     @arg DMA2_IT_TE2: DMA2 Channel2 transfer error interrupt. | ||||
|   *     @arg DMA2_IT_GL3: DMA2 Channel3 global interrupt. | ||||
|   *     @arg DMA2_IT_TC3: DMA2 Channel3 transfer complete interrupt. | ||||
|   *     @arg DMA2_IT_HT3: DMA2 Channel3 half transfer interrupt. | ||||
|   *     @arg DMA2_IT_TE3: DMA2 Channel3 transfer error interrupt. | ||||
|   *     @arg DMA2_IT_GL4: DMA2 Channel4 global interrupt. | ||||
|   *     @arg DMA2_IT_TC4: DMA2 Channel4 transfer complete interrupt. | ||||
|   *     @arg DMA2_IT_HT4: DMA2 Channel4 half transfer interrupt. | ||||
|   *     @arg DMA2_IT_TE4: DMA2 Channel4 transfer error interrupt. | ||||
|   *     @arg DMA2_IT_GL5: DMA2 Channel5 global interrupt. | ||||
|   *     @arg DMA2_IT_TC5: DMA2 Channel5 transfer complete interrupt. | ||||
|   *     @arg DMA2_IT_HT5: DMA2 Channel5 half transfer interrupt. | ||||
|   *     @arg DMA2_IT_TE5: DMA2 Channel5 transfer error interrupt.    | ||||
|   *      | ||||
|   * @note | ||||
|   *    The Global interrupt (DMAy_FLAG_GLx) is set whenever any of the other  | ||||
|   *    interrupts relative to the same channel is set (Transfer Complete,  | ||||
|   *    Half-transfer Complete or Transfer Error interrupts: DMAy_IT_TCx,  | ||||
|   *    DMAy_IT_HTx or DMAy_IT_TEx).  | ||||
|   *       | ||||
|   * @retval The new state of DMAy_IT (SET or RESET). | ||||
|   */ | ||||
| ITStatus DMA_GetITStatus(uint32_t DMAy_IT) | ||||
| { | ||||
|   ITStatus bitstatus = RESET; | ||||
|   uint32_t tmpreg = 0; | ||||
|   | ||||
|   /* Check the parameters */ | ||||
|   assert_param(IS_DMA_GET_IT(DMAy_IT)); | ||||
| 
 | ||||
|   /* Calculate the used DMAy */ | ||||
|   if ((DMAy_IT & FLAG_MASK) == (uint32_t)RESET) | ||||
|   { | ||||
|     /* Get DMA1 ISR register value */ | ||||
|     tmpreg = DMA1->ISR; | ||||
|   } | ||||
|   else | ||||
|   { | ||||
|     /* Get DMA2 ISR register value */ | ||||
|     tmpreg = DMA2->ISR; | ||||
|   } | ||||
|    | ||||
|   /* Check the status of the specified DMAy interrupt */ | ||||
|   if ((tmpreg & DMAy_IT) != (uint32_t)RESET) | ||||
|   { | ||||
|     /* DMAy_IT is set */ | ||||
|     bitstatus = SET; | ||||
|   } | ||||
|   else | ||||
|   { | ||||
|     /* DMAy_IT is reset */ | ||||
|     bitstatus = RESET; | ||||
|   } | ||||
|   /* Return the DMAy_IT status */ | ||||
|   return  bitstatus; | ||||
| } | ||||
| 
 | ||||
| /**
 | ||||
|   * @brief  Clears the DMAy Channelx's interrupt pending bits. | ||||
|   * @param  DMAy_IT: specifies the DMAy interrupt pending bit to clear. | ||||
|   *   This parameter can be any combination (for the same DMA) of the following values: | ||||
|   *     @arg DMA1_IT_GL1: DMA1 Channel1 global interrupt. | ||||
|   *     @arg DMA1_IT_TC1: DMA1 Channel1 transfer complete interrupt. | ||||
|   *     @arg DMA1_IT_HT1: DMA1 Channel1 half transfer interrupt. | ||||
|   *     @arg DMA1_IT_TE1: DMA1 Channel1 transfer error interrupt. | ||||
|   *     @arg DMA1_IT_GL2: DMA1 Channel2 global interrupt. | ||||
|   *     @arg DMA1_IT_TC2: DMA1 Channel2 transfer complete interrupt. | ||||
|   *     @arg DMA1_IT_HT2: DMA1 Channel2 half transfer interrupt. | ||||
|   *     @arg DMA1_IT_TE2: DMA1 Channel2 transfer error interrupt. | ||||
|   *     @arg DMA1_IT_GL3: DMA1 Channel3 global interrupt. | ||||
|   *     @arg DMA1_IT_TC3: DMA1 Channel3 transfer complete interrupt. | ||||
|   *     @arg DMA1_IT_HT3: DMA1 Channel3 half transfer interrupt. | ||||
|   *     @arg DMA1_IT_TE3: DMA1 Channel3 transfer error interrupt. | ||||
|   *     @arg DMA1_IT_GL4: DMA1 Channel4 global interrupt. | ||||
|   *     @arg DMA1_IT_TC4: DMA1 Channel4 transfer complete interrupt. | ||||
|   *     @arg DMA1_IT_HT4: DMA1 Channel4 half transfer interrupt. | ||||
|   *     @arg DMA1_IT_TE4: DMA1 Channel4 transfer error interrupt. | ||||
|   *     @arg DMA1_IT_GL5: DMA1 Channel5 global interrupt. | ||||
|   *     @arg DMA1_IT_TC5: DMA1 Channel5 transfer complete interrupt. | ||||
|   *     @arg DMA1_IT_HT5: DMA1 Channel5 half transfer interrupt. | ||||
|   *     @arg DMA1_IT_TE5: DMA1 Channel5 transfer error interrupt. | ||||
|   *     @arg DMA1_IT_GL6: DMA1 Channel6 global interrupt. | ||||
|   *     @arg DMA1_IT_TC6: DMA1 Channel6 transfer complete interrupt. | ||||
|   *     @arg DMA1_IT_HT6: DMA1 Channel6 half transfer interrupt. | ||||
|   *     @arg DMA1_IT_TE6: DMA1 Channel6 transfer error interrupt. | ||||
|   *     @arg DMA1_IT_GL7: DMA1 Channel7 global interrupt. | ||||
|   *     @arg DMA1_IT_TC7: DMA1 Channel7 transfer complete interrupt. | ||||
|   *     @arg DMA1_IT_HT7: DMA1 Channel7 half transfer interrupt. | ||||
|   *     @arg DMA1_IT_TE7: DMA1 Channel7 transfer error interrupt. | ||||
|   *     @arg DMA2_IT_GL1: DMA2 Channel1 global interrupt. | ||||
|   *     @arg DMA2_IT_TC1: DMA2 Channel1 transfer complete interrupt. | ||||
|   *     @arg DMA2_IT_HT1: DMA2 Channel1 half transfer interrupt. | ||||
|   *     @arg DMA2_IT_TE1: DMA2 Channel1 transfer error interrupt. | ||||
|   *     @arg DMA2_IT_GL2: DMA2 Channel2 global interrupt. | ||||
|   *     @arg DMA2_IT_TC2: DMA2 Channel2 transfer complete interrupt. | ||||
|   *     @arg DMA2_IT_HT2: DMA2 Channel2 half transfer interrupt. | ||||
|   *     @arg DMA2_IT_TE2: DMA2 Channel2 transfer error interrupt. | ||||
|   *     @arg DMA2_IT_GL3: DMA2 Channel3 global interrupt. | ||||
|   *     @arg DMA2_IT_TC3: DMA2 Channel3 transfer complete interrupt. | ||||
|   *     @arg DMA2_IT_HT3: DMA2 Channel3 half transfer interrupt. | ||||
|   *     @arg DMA2_IT_TE3: DMA2 Channel3 transfer error interrupt. | ||||
|   *     @arg DMA2_IT_GL4: DMA2 Channel4 global interrupt. | ||||
|   *     @arg DMA2_IT_TC4: DMA2 Channel4 transfer complete interrupt. | ||||
|   *     @arg DMA2_IT_HT4: DMA2 Channel4 half transfer interrupt. | ||||
|   *     @arg DMA2_IT_TE4: DMA2 Channel4 transfer error interrupt. | ||||
|   *     @arg DMA2_IT_GL5: DMA2 Channel5 global interrupt. | ||||
|   *     @arg DMA2_IT_TC5: DMA2 Channel5 transfer complete interrupt. | ||||
|   *     @arg DMA2_IT_HT5: DMA2 Channel5 half transfer interrupt. | ||||
|   *     @arg DMA2_IT_TE5: DMA2 Channel5 transfer error interrupt.    | ||||
|   *      | ||||
|   * @note | ||||
|   *    Clearing the Global interrupt (DMAy_IT_GLx) results in clearing all other  | ||||
|   *    interrupts relative to the same channel (Transfer Complete, Half-transfer  | ||||
|   *    Complete and Transfer Error interrupts: DMAy_IT_TCx, DMAy_IT_HTx and  | ||||
|   *    DMAy_IT_TEx).   | ||||
|   *         | ||||
|   * @retval None | ||||
|   */ | ||||
| void DMA_ClearITPendingBit(uint32_t DMAy_IT) | ||||
| { | ||||
|   /* Check the parameters */ | ||||
|   assert_param(IS_DMA_CLEAR_IT(DMAy_IT)); | ||||
| 
 | ||||
|   /* Calculate the used DMAy */ | ||||
|   if ((DMAy_IT & FLAG_MASK) == (uint32_t)RESET) | ||||
|   { | ||||
|     /* Clear the selected DMAy interrupt pending bits */ | ||||
|     DMA1->IFCR = DMAy_IT; | ||||
|   } | ||||
|   else | ||||
|   { | ||||
|     /* Clear the selected DMAy interrupt pending bits */ | ||||
|     DMA2->IFCR = DMAy_IT; | ||||
|   }   | ||||
| } | ||||
| 
 | ||||
| /**
 | ||||
|   * @} | ||||
|   */ | ||||
| 
 | ||||
| /**
 | ||||
|   * @} | ||||
|   */ | ||||
| 
 | ||||
| /**
 | ||||
|   * @} | ||||
|   */ | ||||
| 
 | ||||
| /**
 | ||||
|   * @} | ||||
|   */ | ||||
| 
 | ||||
| /************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE****/ | ||||
										
											
												File diff suppressed because it is too large
												Load diff
											
										
									
								
							|  | @ -1,553 +0,0 @@ | |||
| /**
 | ||||
|   ****************************************************************************** | ||||
|   * @file    stm32l1xx_flash_ramfunc.c | ||||
|   * @author  MCD Application Team | ||||
|   * @version V1.1.1 | ||||
|   * @date    05-March-2012 | ||||
|   * @brief   This file provides all the Flash firmware functions which should be | ||||
|   *          executed from the internal SRAM. This file should be placed in  | ||||
|   *          internal SRAM.  | ||||
|   *          Other FLASH memory functions that can be used from the FLASH are  | ||||
|   *          defined in the "stm32l1xx_flash.c" file.  | ||||
| @verbatim | ||||
| 
 | ||||
|     *** ARM Compiler *** | ||||
|     -------------------- | ||||
|     [..] RAM functions are defined using the toolchain options.  | ||||
|          Functions that are be executed in RAM should reside in a separate | ||||
|          source module. Using the 'Options for File' dialog you can simply change | ||||
|          the 'Code / Const' area of a module to a memory space in physical RAM. | ||||
|          Available memory areas are declared in the 'Target' tab of the  | ||||
|          Options for Target' dialog. | ||||
| 
 | ||||
|     *** ICCARM Compiler *** | ||||
|     ----------------------- | ||||
|     [..] RAM functions are defined using a specific toolchain keyword "__ramfunc". | ||||
| 
 | ||||
|     *** GNU Compiler *** | ||||
|     -------------------- | ||||
|     [..] RAM functions are defined using a specific toolchain attribute | ||||
|          "__attribute__((section(".data")))". | ||||
| 
 | ||||
|     *** TASKING Compiler *** | ||||
|     ------------------------ | ||||
|     [..] RAM functions are defined using a specific toolchain pragma. This  | ||||
|          pragma is defined inside this file. | ||||
| 
 | ||||
| @endverbatim | ||||
|   * | ||||
|   ****************************************************************************** | ||||
|   * @attention | ||||
|   * | ||||
|   * <h2><center>© COPYRIGHT 2012 STMicroelectronics</center></h2> | ||||
|   * | ||||
|   * Licensed under MCD-ST Liberty SW License Agreement V2, (the "License"); | ||||
|   * You may not use this file except in compliance with the License. | ||||
|   * You may obtain a copy of the License at: | ||||
|   * | ||||
|   *        http://www.st.com/software_license_agreement_liberty_v2
 | ||||
|   * | ||||
|   * Unless required by applicable law or agreed to in writing, software  | ||||
|   * distributed under the License is distributed on an "AS IS" BASIS,  | ||||
|   * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. | ||||
|   * See the License for the specific language governing permissions and | ||||
|   * limitations under the License. | ||||
|   * | ||||
|   ****************************************************************************** | ||||
|   */ | ||||
| 
 | ||||
| /* Includes ------------------------------------------------------------------*/ | ||||
| #include "stm32l1xx_flash.h" | ||||
| 
 | ||||
| /** @addtogroup STM32L1xx_StdPeriph_Driver
 | ||||
|   * @{ | ||||
|   */ | ||||
| 
 | ||||
| /** @defgroup FLASH 
 | ||||
|   * @brief FLASH driver modules | ||||
|   * @{ | ||||
|   */  | ||||
| 
 | ||||
| /* Private typedef -----------------------------------------------------------*/ | ||||
| /* Private define ------------------------------------------------------------*/ | ||||
| /* Private macro -------------------------------------------------------------*/ | ||||
| /* Private variables ---------------------------------------------------------*/ | ||||
| /* Private function prototypes -----------------------------------------------*/ | ||||
| static __RAM_FUNC GetStatus(void); | ||||
| static __RAM_FUNC WaitForLastOperation(uint32_t Timeout); | ||||
| 
 | ||||
| /* Private functions ---------------------------------------------------------*/ | ||||
|   | ||||
| /** @defgroup FLASH_Private_Functions
 | ||||
|   * @{ | ||||
|   */  | ||||
| 
 | ||||
| /** @addtogroup FLASH_Group1
 | ||||
|  * | ||||
| @verbatim   | ||||
| @endverbatim | ||||
|   * @{ | ||||
|   */   | ||||
| #if defined (  __TASKING__  ) | ||||
| #pragma section_code_init on | ||||
| #endif | ||||
| 
 | ||||
| /**
 | ||||
|   * @brief  Enable or disable the power down mode during RUN mode. | ||||
|   * @note  This function can be used only when the user code is running from Internal SRAM. | ||||
|   * @param  NewState: new state of the power down mode during RUN mode. | ||||
|   *   This parameter can be: ENABLE or DISABLE. | ||||
|   * @retval None | ||||
|   */ | ||||
| __RAM_FUNC FLASH_RUNPowerDownCmd(FunctionalState NewState) | ||||
| { | ||||
|   FLASH_Status status = FLASH_COMPLETE; | ||||
|   | ||||
|   if (NewState != DISABLE) | ||||
|   { | ||||
|      /* Unlock the RUN_PD bit */ | ||||
|      FLASH->PDKEYR = FLASH_PDKEY1; | ||||
|      FLASH->PDKEYR = FLASH_PDKEY2; | ||||
|       | ||||
|      /* Set the RUN_PD bit in  FLASH_ACR register to put Flash in power down mode */ | ||||
|      FLASH->ACR |= (uint32_t)FLASH_ACR_RUN_PD; | ||||
| 
 | ||||
|      if((FLASH->ACR & FLASH_ACR_RUN_PD) != FLASH_ACR_RUN_PD) | ||||
|      { | ||||
|        status = FLASH_ERROR_PROGRAM; | ||||
|      } | ||||
|   } | ||||
|   else | ||||
|   { | ||||
|     /* Clear the RUN_PD bit in  FLASH_ACR register to put Flash in idle  mode */ | ||||
|     FLASH->ACR &= (uint32_t)(~(uint32_t)FLASH_ACR_RUN_PD); | ||||
|   } | ||||
| 
 | ||||
|   /* Return the Write Status */ | ||||
|   return status;   | ||||
| } | ||||
| 
 | ||||
| /**
 | ||||
|   * @} | ||||
|   */ | ||||
| 
 | ||||
| /** @addtogroup FLASH_Group2
 | ||||
|  * | ||||
| @verbatim   | ||||
| @endverbatim | ||||
|   * @{ | ||||
|   */ | ||||
| 
 | ||||
| /**
 | ||||
|   * @brief  Erases a specified 2 page in program memory in parallel. | ||||
|   * @note   This function can be used only for STM32L1XX_HD density devices. | ||||
|   *         To correctly run this function, the FLASH_Unlock() function | ||||
|   *         must be called before. | ||||
|   *         Call the FLASH_Lock() to disable the flash memory access  | ||||
|   *        (recommended to protect the FLASH memory against possible unwanted operation). | ||||
|   * @param  Page_Address1: The page address in program memory to be erased in  | ||||
|   *         the first Bank (BANK1). This parameter should be between 0x08000000 | ||||
|   *         and 0x0802FF00. | ||||
|   * @param  Page_Address2: The page address in program memory to be erased in  | ||||
|   *         the second Bank (BANK2). This parameter should be between 0x08030000 | ||||
|   *         and 0x0805FF00. | ||||
|   * @note   A Page is erased in the Program memory only if the address to load  | ||||
|   *         is the start address of a page (multiple of 256 bytes). | ||||
|   * @retval FLASH Status: The returned value can be:  | ||||
|   *         FLASH_ERROR_PROGRAM, FLASH_ERROR_WRP, FLASH_COMPLETE or FLASH_TIMEOUT. | ||||
|   */ | ||||
| FLASH_Status FLASH_EraseParallelPage(uint32_t Page_Address1, uint32_t Page_Address2) | ||||
| { | ||||
|   FLASH_Status status = FLASH_COMPLETE; | ||||
| 
 | ||||
|   /* Wait for last operation to be completed */ | ||||
|   status = WaitForLastOperation(FLASH_ER_PRG_TIMEOUT); | ||||
|    | ||||
|   if(status == FLASH_COMPLETE) | ||||
|   { | ||||
|     /* If the previous operation is completed, proceed to erase the page */ | ||||
| 
 | ||||
|     /* Set the PARALLBANK bit */ | ||||
|     FLASH->PECR |= FLASH_PECR_PARALLBANK; | ||||
|      | ||||
|     /* Set the ERASE bit */ | ||||
|     FLASH->PECR |= FLASH_PECR_ERASE; | ||||
| 
 | ||||
|     /* Set PROG bit */ | ||||
|     FLASH->PECR |= FLASH_PECR_PROG; | ||||
|    | ||||
|     /* Write 00000000h to the first word of the first program page to erase */ | ||||
|     *(__IO uint32_t *)Page_Address1 = 0x00000000; | ||||
|     /* Write 00000000h to the first word of the second program page to erase */     | ||||
|     *(__IO uint32_t *)Page_Address2 = 0x00000000;     | ||||
|   | ||||
|     /* Wait for last operation to be completed */ | ||||
|     status = WaitForLastOperation(FLASH_ER_PRG_TIMEOUT); | ||||
| 
 | ||||
|     /* If the erase operation is completed, disable the ERASE, PROG and PARALLBANK bits */ | ||||
|     FLASH->PECR &= (uint32_t)(~FLASH_PECR_PROG); | ||||
|     FLASH->PECR &= (uint32_t)(~FLASH_PECR_ERASE); | ||||
|     FLASH->PECR &= (uint32_t)(~FLASH_PECR_PARALLBANK);    | ||||
|   }      | ||||
|   /* Return the Erase Status */ | ||||
|   return status; | ||||
| } | ||||
| 
 | ||||
| /**
 | ||||
|   * @brief  Programs a half page in program memory. | ||||
|   * @param  Address: specifies the address to be written. | ||||
|   * @param  pBuffer: pointer to the buffer  containing the data to be  written to  | ||||
|   *         the half page. | ||||
|   * @note   To correctly run this function, the FLASH_Unlock() function | ||||
|   *         must be called before. | ||||
|   *         Call the FLASH_Lock() to disable the flash memory access   | ||||
|   *         (recommended to protect the FLASH memory against possible unwanted operation) | ||||
|   * @note   Half page write is possible only from SRAM. | ||||
|   * @note   If there are more than 32 words to write, after 32 words another  | ||||
|   *         Half Page programming operation starts and has to be finished. | ||||
|   * @note   A half page is written to the program memory only if the first  | ||||
|   *         address to load is the start address of a half page (multiple of 128  | ||||
|   *         bytes) and the 31 remaining words to load are in the same half page. | ||||
|   * @note   During the Program memory half page write all read operations are  | ||||
|   *         forbidden (this includes DMA read operations and debugger read  | ||||
|   *         operations such as breakpoints, periodic updates, etc.). | ||||
|   * @note   If a PGAERR is set during a Program memory half page write, the  | ||||
|   *         complete write operation is aborted. Software should then reset the  | ||||
|   *         FPRG and PROG/DATA bits and restart the write operation from the  | ||||
|   *         beginning. | ||||
|   * @retval FLASH Status: The returned value can be:   | ||||
|   *   FLASH_ERROR_PROGRAM, FLASH_ERROR_WRP, FLASH_COMPLETE or FLASH_TIMEOUT.  | ||||
|   */ | ||||
| __RAM_FUNC FLASH_ProgramHalfPage(uint32_t Address, uint32_t* pBuffer) | ||||
| { | ||||
|   uint32_t count = 0;  | ||||
|     | ||||
|   FLASH_Status status = FLASH_COMPLETE; | ||||
| 
 | ||||
|   /* Set the DISMCYCINT[0] bit in the Auxillary Control Register (0xE000E008) 
 | ||||
|      This bit prevents the interruption of multicycle instructions and therefore  | ||||
|      will increase the interrupt latency. of Cortex-M3. */ | ||||
|   SCnSCB->ACTLR |= SCnSCB_ACTLR_DISMCYCINT_Msk; | ||||
|    | ||||
|   /* Wait for last operation to be completed */ | ||||
|   status = WaitForLastOperation(FLASH_ER_PRG_TIMEOUT); | ||||
|    | ||||
|   if(status == FLASH_COMPLETE) | ||||
|   { | ||||
|     /* if the previous operation is completed, proceed to program the new  
 | ||||
|     half page */ | ||||
|     FLASH->PECR |= FLASH_PECR_FPRG; | ||||
|     FLASH->PECR |= FLASH_PECR_PROG; | ||||
|      | ||||
|     /* Write one half page directly with 32 different words */ | ||||
|     while(count < 32) | ||||
|     { | ||||
|       *(__IO uint32_t*) (Address + (4 * count)) = *(pBuffer++); | ||||
|       count ++;   | ||||
|     } | ||||
|     /* Wait for last operation to be completed */ | ||||
|     status = WaitForLastOperation(FLASH_ER_PRG_TIMEOUT); | ||||
|   | ||||
|     /* if the write operation is completed, disable the PROG and FPRG bits */ | ||||
|     FLASH->PECR &= (uint32_t)(~FLASH_PECR_PROG); | ||||
|     FLASH->PECR &= (uint32_t)(~FLASH_PECR_FPRG); | ||||
|   } | ||||
| 
 | ||||
|   SCnSCB->ACTLR &= ~SCnSCB_ACTLR_DISMCYCINT_Msk; | ||||
|      | ||||
|   /* Return the Write Status */ | ||||
|   return status; | ||||
| } | ||||
| 
 | ||||
| /**
 | ||||
|   * @brief  Programs 2 half page in program memory in parallel. | ||||
|   * @param  Address1: specifies the first address to be written in the first bank  | ||||
|   *        (BANK1). This parameter should be between 0x08000000 and 0x0802FF80. | ||||
|   * @param  pBuffer1: pointer to the buffer  containing the data to be  written  | ||||
|   *         to the first half page in the first bank. | ||||
|   * @param  Address2: specifies the second address to be written in the second bank | ||||
|   *        (BANK2). This parameter should be between 0x08030000 and 0x0805FF80. | ||||
|   * @param  pBuffer2: pointer to the buffer containing the data to be  written  | ||||
|   *         to the second half page in the second bank. | ||||
|   * @note   This function can be used only for STM32L1XX_HD density devices. | ||||
|   * @note   To correctly run this function, the FLASH_Unlock() function | ||||
|   *         must be called before. | ||||
|   *         Call the FLASH_Lock() to disable the flash memory access   | ||||
|   *         (recommended to protect the FLASH memory against possible unwanted operation). | ||||
|   * @note   Half page write is possible only from SRAM. | ||||
|   * @note   If there are more than 32 words to write, after 32 words another  | ||||
|   *         Half Page programming operation starts and has to be finished. | ||||
|   * @note   A half page is written to the program memory only if the first  | ||||
|   *         address to load is the start address of a half page (multiple of 128  | ||||
|   *         bytes) and the 31 remaining words to load are in the same half page. | ||||
|   * @note   During the Program memory half page write all read operations are  | ||||
|   *         forbidden (this includes DMA read operations and debugger read  | ||||
|   *         operations such as breakpoints, periodic updates, etc.). | ||||
|   * @note   If a PGAERR is set during a Program memory half page write, the  | ||||
|   *         complete write operation is aborted. Software should then reset the  | ||||
|   *         FPRG and PROG/DATA bits and restart the write operation from the  | ||||
|   *         beginning. | ||||
|   * @retval FLASH Status: The returned value can be:   | ||||
|   *         FLASH_ERROR_PROGRAM, FLASH_ERROR_WRP, FLASH_COMPLETE or FLASH_TIMEOUT. | ||||
|   */ | ||||
| __RAM_FUNC FLASH_ProgramParallelHalfPage(uint32_t Address1, uint32_t* pBuffer1, uint32_t Address2, uint32_t* pBuffer2) | ||||
| { | ||||
|   uint32_t count = 0;  | ||||
|     | ||||
|   FLASH_Status status = FLASH_COMPLETE; | ||||
| 
 | ||||
|   /* Set the DISMCYCINT[0] bit in the Auxillary Control Register (0xE000E008) 
 | ||||
|      This bit prevents the interruption of multicycle instructions and therefore  | ||||
|      will increase the interrupt latency. of Cortex-M3. */ | ||||
|   SCnSCB->ACTLR |= SCnSCB_ACTLR_DISMCYCINT_Msk; | ||||
| 
 | ||||
|   /* Wait for last operation to be completed */ | ||||
|   status = WaitForLastOperation(FLASH_ER_PRG_TIMEOUT); | ||||
|    | ||||
|   if(status == FLASH_COMPLETE) | ||||
|   { | ||||
|     /* If the previous operation is completed, proceed to program the new  
 | ||||
|        half page */ | ||||
|     FLASH->PECR |= FLASH_PECR_PARALLBANK; | ||||
|     FLASH->PECR |= FLASH_PECR_FPRG; | ||||
|     FLASH->PECR |= FLASH_PECR_PROG; | ||||
|      | ||||
|     /* Write the first half page directly with 32 different words */ | ||||
|     while(count < 32) | ||||
|     { | ||||
|       *(__IO uint32_t*) (Address1 + (4 * count)) = *(pBuffer1++); | ||||
|       count ++;   | ||||
|     } | ||||
|     count = 0; | ||||
|     /* Write the second half page directly with 32 different words */ | ||||
|     while(count < 32) | ||||
|     { | ||||
|       *(__IO uint32_t*) (Address2 + (4 * count)) = *(pBuffer2++); | ||||
|       count ++;   | ||||
|     } | ||||
|     /* Wait for last operation to be completed */ | ||||
|     status = WaitForLastOperation(FLASH_ER_PRG_TIMEOUT); | ||||
|   | ||||
|     /* if the write operation is completed, disable the PROG, FPRG and PARALLBANK bits */ | ||||
|     FLASH->PECR &= (uint32_t)(~FLASH_PECR_PROG); | ||||
|     FLASH->PECR &= (uint32_t)(~FLASH_PECR_FPRG); | ||||
|     FLASH->PECR &= (uint32_t)(~FLASH_PECR_PARALLBANK); | ||||
|   } | ||||
| 
 | ||||
|   SCnSCB->ACTLR &= ~SCnSCB_ACTLR_DISMCYCINT_Msk; | ||||
|      | ||||
|   /* Return the Write Status */ | ||||
|   return status; | ||||
| } | ||||
| 
 | ||||
| /**
 | ||||
|   * @} | ||||
|   */ | ||||
| 
 | ||||
| /** @addtogroup FLASH_Group3
 | ||||
|  * | ||||
| @verbatim   | ||||
| @endverbatim | ||||
|   * @{ | ||||
|   */ | ||||
| 
 | ||||
| /**
 | ||||
|   * @brief  Erase a double word in data memory. | ||||
|   * @param  Address: specifies the address to be erased. | ||||
|   * @note   To correctly run this function, the DATA_EEPROM_Unlock() function | ||||
|   *         must be called before. | ||||
|   *         Call the DATA_EEPROM_Lock() to he data EEPROM access | ||||
|   *         and Flash program erase control register access(recommended to protect  | ||||
|   *         the DATA_EEPROM against possible unwanted operation). | ||||
|   * @note   Data memory double word erase is possible only from SRAM. | ||||
|   * @note   A double word is erased to the data memory only if the first address  | ||||
|   *         to load is the start address of a double word (multiple of 8 bytes). | ||||
|   * @note   During the Data memory double word erase, all read operations are  | ||||
|   *         forbidden (this includes DMA read operations and debugger read  | ||||
|   *         operations such as breakpoints, periodic updates, etc.). | ||||
|   * @retval FLASH Status: The returned value can be:  | ||||
|   *   FLASH_ERROR_PROGRAM, FLASH_ERROR_WRP, FLASH_COMPLETE or FLASH_TIMEOUT. | ||||
|   */ | ||||
| 
 | ||||
| __RAM_FUNC DATA_EEPROM_EraseDoubleWord(uint32_t Address) | ||||
| { | ||||
|   FLASH_Status status = FLASH_COMPLETE; | ||||
|    | ||||
|   /* Set the DISMCYCINT[0] bit in the Auxillary Control Register (0xE000E008) 
 | ||||
|      This bit prevents the interruption of multicycle instructions and therefore  | ||||
|      will increase the interrupt latency. of Cortex-M3. */ | ||||
|   SCnSCB->ACTLR |= SCnSCB_ACTLR_DISMCYCINT_Msk; | ||||
|      | ||||
|   /* Wait for last operation to be completed */ | ||||
|   status = WaitForLastOperation(FLASH_ER_PRG_TIMEOUT); | ||||
|    | ||||
|   if(status == FLASH_COMPLETE) | ||||
|   { | ||||
|     /* If the previous operation is completed, proceed to erase the next double word */ | ||||
|     /* Set the ERASE bit */ | ||||
|     FLASH->PECR |= FLASH_PECR_ERASE; | ||||
| 
 | ||||
|     /* Set DATA bit */ | ||||
|     FLASH->PECR |= FLASH_PECR_DATA; | ||||
|     | ||||
|     /* Write 00000000h to the 2 words to erase */ | ||||
|     *(__IO uint32_t *)Address = 0x00000000; | ||||
|     Address += 4; | ||||
|     *(__IO uint32_t *)Address = 0x00000000; | ||||
|     | ||||
|     /* Wait for last operation to be completed */ | ||||
|     status = WaitForLastOperation(FLASH_ER_PRG_TIMEOUT); | ||||
|      | ||||
|     /* If the erase operation is completed, disable the ERASE and DATA bits */ | ||||
|     FLASH->PECR &= (uint32_t)(~FLASH_PECR_ERASE); | ||||
|     FLASH->PECR &= (uint32_t)(~FLASH_PECR_DATA); | ||||
|   }   | ||||
|    | ||||
|   SCnSCB->ACTLR &= ~SCnSCB_ACTLR_DISMCYCINT_Msk; | ||||
|      | ||||
|   /* Return the erase status */ | ||||
|   return status; | ||||
| } | ||||
| 
 | ||||
| /**
 | ||||
|   * @brief  Write a double word in data memory without erase. | ||||
|   * @param  Address: specifies the address to be written. | ||||
|   * @param  Data: specifies the data to be written. | ||||
|   * @note   To correctly run this function, the DATA_EEPROM_Unlock() function | ||||
|   *         must be called before. | ||||
|   *         Call the DATA_EEPROM_Lock() to he data EEPROM access | ||||
|   *         and Flash program erase control register access(recommended to protect  | ||||
|   *         the DATA_EEPROM against possible unwanted operation). | ||||
|   * @note   Data memory double word write is possible only from SRAM. | ||||
|   * @note   A data memory double word is written to the data memory only if the  | ||||
|   *         first address to load is the start address of a double word (multiple  | ||||
|   *         of double word). | ||||
|   * @note   During the Data memory double word write, all read operations are  | ||||
|   *         forbidden (this includes DMA read operations and debugger read  | ||||
|   *         operations such as breakpoints, periodic updates, etc.). | ||||
|   * @retval FLASH Status: The returned value can be:  | ||||
|   *   FLASH_ERROR_PROGRAM, FLASH_ERROR_WRP, FLASH_COMPLETE or FLASH_TIMEOUT.  | ||||
|   */  | ||||
| __RAM_FUNC DATA_EEPROM_ProgramDoubleWord(uint32_t Address, uint64_t Data) | ||||
| { | ||||
|   FLASH_Status status = FLASH_COMPLETE; | ||||
| 
 | ||||
|   /* Set the DISMCYCINT[0] bit in the Auxillary Control Register (0xE000E008) 
 | ||||
|      This bit prevents the interruption of multicycle instructions and therefore  | ||||
|      will increase the interrupt latency. of Cortex-M3. */ | ||||
|   SCnSCB->ACTLR |= SCnSCB_ACTLR_DISMCYCINT_Msk; | ||||
|      | ||||
|   /* Wait for last operation to be completed */ | ||||
|   status = WaitForLastOperation(FLASH_ER_PRG_TIMEOUT); | ||||
|    | ||||
|   if(status == FLASH_COMPLETE) | ||||
|   { | ||||
|     /* If the previous operation is completed, proceed to program the new data*/ | ||||
|     FLASH->PECR |= FLASH_PECR_FPRG; | ||||
|     FLASH->PECR |= FLASH_PECR_DATA; | ||||
|      | ||||
|     /* Write the 2 words */   | ||||
|      *(__IO uint32_t *)Address = (uint32_t) Data; | ||||
|      Address += 4; | ||||
|      *(__IO uint32_t *)Address = (uint32_t) (Data >> 32); | ||||
|      | ||||
|     /* Wait for last operation to be completed */ | ||||
|     status = WaitForLastOperation(FLASH_ER_PRG_TIMEOUT); | ||||
|      | ||||
|     /* If the write operation is completed, disable the FPRG and DATA bits */ | ||||
|     FLASH->PECR &= (uint32_t)(~FLASH_PECR_FPRG); | ||||
|     FLASH->PECR &= (uint32_t)(~FLASH_PECR_DATA);      | ||||
|   } | ||||
|    | ||||
|   SCnSCB->ACTLR &= ~SCnSCB_ACTLR_DISMCYCINT_Msk; | ||||
|      | ||||
|   /* Return the Write Status */ | ||||
|   return status; | ||||
| } | ||||
| 
 | ||||
| /**
 | ||||
|   * @} | ||||
|   */ | ||||
| 
 | ||||
| /**
 | ||||
|   * @brief  Returns the FLASH Status. | ||||
|   * @param  None | ||||
|   * @retval FLASH Status: The returned value can be: FLASH_BUSY,  | ||||
|   *   FLASH_ERROR_PROGRAM, FLASH_ERROR_WRP or FLASH_COMPLETE | ||||
|   */ | ||||
| static __RAM_FUNC GetStatus(void) | ||||
| { | ||||
|   FLASH_Status FLASHstatus = FLASH_COMPLETE; | ||||
|    | ||||
|   if((FLASH->SR & FLASH_FLAG_BSY) == FLASH_FLAG_BSY)  | ||||
|   { | ||||
|     FLASHstatus = FLASH_BUSY; | ||||
|   } | ||||
|   else  | ||||
|   {   | ||||
|     if((FLASH->SR & (uint32_t)FLASH_FLAG_WRPERR)!= (uint32_t)0x00) | ||||
|     {  | ||||
|       FLASHstatus = FLASH_ERROR_WRP; | ||||
|     } | ||||
|     else  | ||||
|     { | ||||
|       if((FLASH->SR & (uint32_t)0x1E00) != (uint32_t)0x00) | ||||
|       { | ||||
|         FLASHstatus = FLASH_ERROR_PROGRAM;  | ||||
|       } | ||||
|       else | ||||
|       { | ||||
|         FLASHstatus = FLASH_COMPLETE; | ||||
|       } | ||||
|     } | ||||
|   } | ||||
|   /* Return the FLASH Status */ | ||||
|   return FLASHstatus; | ||||
| } | ||||
| 
 | ||||
| /**
 | ||||
|   * @brief  Waits for a FLASH operation to complete or a TIMEOUT to occur. | ||||
|   * @param  Timeout: FLASH programming Timeout | ||||
|   * @retval FLASH Status: The returned value can be: FLASH_BUSY,  | ||||
|   *   FLASH_ERROR_PROGRAM, FLASH_ERROR_WRP, FLASH_COMPLETE or  | ||||
|   *   FLASH_TIMEOUT. | ||||
|   */ | ||||
| static __RAM_FUNC  WaitForLastOperation(uint32_t Timeout) | ||||
| {  | ||||
|   __IO FLASH_Status status = FLASH_COMPLETE; | ||||
|     | ||||
|   /* Check for the FLASH Status */ | ||||
|   status = GetStatus(); | ||||
|    | ||||
|   /* Wait for a FLASH operation to complete or a TIMEOUT to occur */ | ||||
|   while((status == FLASH_BUSY) && (Timeout != 0x00)) | ||||
|   { | ||||
|     status = GetStatus(); | ||||
|     Timeout--; | ||||
|   } | ||||
|    | ||||
|   if(Timeout == 0x00 ) | ||||
|   { | ||||
|     status = FLASH_TIMEOUT; | ||||
|   } | ||||
|   /* Return the operation status */ | ||||
|   return status; | ||||
| } | ||||
| 
 | ||||
| #if defined (  __TASKING__  ) | ||||
| #pragma section_code_init restore | ||||
| #endif | ||||
| 
 | ||||
| /**
 | ||||
|   * @} | ||||
|   */ | ||||
|     | ||||
|   /**
 | ||||
|   * @} | ||||
|   */  | ||||
| 
 | ||||
| /**
 | ||||
|   * @} | ||||
|   */  | ||||
| 
 | ||||
| /************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE****/ | ||||
|  | @ -1,285 +0,0 @@ | |||
| /**
 | ||||
|   ****************************************************************************** | ||||
|   * @file    stm32l1xx_fsmc.c | ||||
|   * @author  MCD Application Team | ||||
|   * @version V1.1.1 | ||||
|   * @date    05-March-2012 | ||||
|   * @brief   This file provides firmware functions to manage the following  | ||||
|   *          functionalities of the FSMC peripheral: | ||||
|   *           + Initialization  | ||||
|   *           + Interrupts and flags management | ||||
|   * | ||||
|   ****************************************************************************** | ||||
|   * @attention | ||||
|   * | ||||
|   * <h2><center>© COPYRIGHT 2012 STMicroelectronics</center></h2> | ||||
|   * | ||||
|   * Licensed under MCD-ST Liberty SW License Agreement V2, (the "License"); | ||||
|   * You may not use this file except in compliance with the License. | ||||
|   * You may obtain a copy of the License at: | ||||
|   * | ||||
|   *        http://www.st.com/software_license_agreement_liberty_v2
 | ||||
|   * | ||||
|   * Unless required by applicable law or agreed to in writing, software  | ||||
|   * distributed under the License is distributed on an "AS IS" BASIS,  | ||||
|   * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. | ||||
|   * See the License for the specific language governing permissions and | ||||
|   * limitations under the License. | ||||
|   * | ||||
|   ****************************************************************************** | ||||
|   */ | ||||
| 
 | ||||
| /* Includes ------------------------------------------------------------------*/ | ||||
| #include "stm32l1xx_fsmc.h" | ||||
| #include "stm32l1xx_rcc.h" | ||||
| 
 | ||||
| /** @addtogroup STM32L1xx_StdPeriph_Driver
 | ||||
|   * @{ | ||||
|   */ | ||||
| 
 | ||||
| /** @defgroup FSMC 
 | ||||
|   * @brief FSMC driver modules | ||||
|   * @{ | ||||
|   */  | ||||
| 
 | ||||
| /* Private typedef -----------------------------------------------------------*/ | ||||
| /* Private define ------------------------------------------------------------*/ | ||||
| /* Private macro -------------------------------------------------------------*/ | ||||
| /* Private variables ---------------------------------------------------------*/ | ||||
| /* Private function prototypes -----------------------------------------------*/ | ||||
| /* Private functions ---------------------------------------------------------*/ | ||||
| 
 | ||||
| /** @defgroup FSMC_Private_Functions
 | ||||
|   * @{ | ||||
|   */ | ||||
| 
 | ||||
| /** @defgroup FSMC_Group1 NOR/SRAM Controller functions
 | ||||
|  *  @brief   NOR/SRAM Controller functions  | ||||
|  * | ||||
|   @verbatim | ||||
|   ============================================================================== | ||||
|                   ##### NOR-SRAM Controller functions ##### | ||||
|   ============================================================================== | ||||
|     [..] The following sequence should be followed to configure the FSMC to  | ||||
|          interface with SRAM, PSRAM, NOR or OneNAND memory connected to the  | ||||
|          NOR/SRAM Bank:  | ||||
|     (#) Enable the clock for the FSMC and associated GPIOs using the following  | ||||
|         functions:  | ||||
|         (++)RCC_AHBPeriphClockCmd(RCC_AHBPeriph_FSMC, ENABLE);  | ||||
|         (++)RCC_AHBPeriphClockCmd(RCC_AHBPeriph_GPIOx, ENABLE);  | ||||
|     (#) FSMC pins configuration   | ||||
|         (++) Connect the involved FSMC pins to AF12 using the following function   | ||||
|              GPIO_PinAFConfig(GPIOx, GPIO_PinSourcex, GPIO_AF_FSMC); | ||||
|         (++) Configure these FSMC pins in alternate function mode by calling the | ||||
|              function GPIO_Init(); | ||||
|     (#) Declare a FSMC_NORSRAMInitTypeDef structure, for example:  | ||||
|         FSMC_NORSRAMInitTypeDef  FSMC_NORSRAMInitStructure; and fill the  | ||||
|         FSMC_NORSRAMInitStructure variable with the allowed values of the  | ||||
|         structure member. | ||||
|     (#) Initialize the NOR/SRAM Controller by calling the function  | ||||
|         FSMC_NORSRAMInit(&FSMC_NORSRAMInitStructure);   | ||||
|     (#) Then enable the NOR/SRAM Bank, for example:  | ||||
|         FSMC_NORSRAMCmd(FSMC_Bank1_NORSRAM2, ENABLE);    | ||||
|     (#) At this stage you can read/write from/to the memory connected to the  | ||||
|         NOR/SRAM Bank. | ||||
|     | ||||
| @endverbatim | ||||
| 
 | ||||
|   * @{ | ||||
|   */ | ||||
| 
 | ||||
| /**
 | ||||
|   * @brief  Deinitializes the FSMC NOR/SRAM Banks registers to their default  | ||||
|   *   reset values. | ||||
|   * @param  FSMC_Bank: specifies the FSMC Bank to be used | ||||
|   *   This parameter can be one of the following values: | ||||
|   *     @arg FSMC_Bank1_NORSRAM1: FSMC Bank1 NOR/SRAM1   | ||||
|   *     @arg FSMC_Bank1_NORSRAM2: FSMC Bank1 NOR/SRAM2  | ||||
|   *     @arg FSMC_Bank1_NORSRAM3: FSMC Bank1 NOR/SRAM3  | ||||
|   *     @arg FSMC_Bank1_NORSRAM4: FSMC Bank1 NOR/SRAM4  | ||||
|   * @retval None | ||||
|   */ | ||||
| void FSMC_NORSRAMDeInit(uint32_t FSMC_Bank) | ||||
| { | ||||
|   /* Check the parameter */ | ||||
|   assert_param(IS_FSMC_NORSRAM_BANK(FSMC_Bank)); | ||||
|    | ||||
|   /* FSMC_Bank1_NORSRAM1 */ | ||||
|   if(FSMC_Bank == FSMC_Bank1_NORSRAM1) | ||||
|   { | ||||
|     FSMC_Bank1->BTCR[FSMC_Bank] = 0x000030DB;     | ||||
|   } | ||||
|   /* FSMC_Bank1_NORSRAM2,  FSMC_Bank1_NORSRAM3 or FSMC_Bank1_NORSRAM4 */ | ||||
|   else | ||||
|   {    | ||||
|     FSMC_Bank1->BTCR[FSMC_Bank] = 0x000030D2;  | ||||
|   } | ||||
|   FSMC_Bank1->BTCR[FSMC_Bank + 1] = 0x0FFFFFFF; | ||||
|   FSMC_Bank1E->BWTR[FSMC_Bank] = 0x0FFFFFFF;   | ||||
| } | ||||
| 
 | ||||
| /**
 | ||||
|   * @brief  Initializes the FSMC NOR/SRAM Banks according to the specified | ||||
|   *   parameters in the FSMC_NORSRAMInitStruct. | ||||
|   * @param  FSMC_NORSRAMInitStruct : pointer to a FSMC_NORSRAMInitTypeDef | ||||
|   *   structure that contains the configuration information for  | ||||
|   *   the FSMC NOR/SRAM specified Banks.                        | ||||
|   * @retval None | ||||
|   */ | ||||
| void FSMC_NORSRAMInit(FSMC_NORSRAMInitTypeDef* FSMC_NORSRAMInitStruct) | ||||
| {  | ||||
|   /* Check the parameters */ | ||||
|   assert_param(IS_FSMC_NORSRAM_BANK(FSMC_NORSRAMInitStruct->FSMC_Bank)); | ||||
|   assert_param(IS_FSMC_MUX(FSMC_NORSRAMInitStruct->FSMC_DataAddressMux)); | ||||
|   assert_param(IS_FSMC_MEMORY(FSMC_NORSRAMInitStruct->FSMC_MemoryType)); | ||||
|   assert_param(IS_FSMC_MEMORY_WIDTH(FSMC_NORSRAMInitStruct->FSMC_MemoryDataWidth)); | ||||
|   assert_param(IS_FSMC_BURSTMODE(FSMC_NORSRAMInitStruct->FSMC_BurstAccessMode)); | ||||
|   assert_param(IS_FSMC_ASYNWAIT(FSMC_NORSRAMInitStruct->FSMC_AsynchronousWait)); | ||||
|   assert_param(IS_FSMC_WAIT_POLARITY(FSMC_NORSRAMInitStruct->FSMC_WaitSignalPolarity)); | ||||
|   assert_param(IS_FSMC_WRAP_MODE(FSMC_NORSRAMInitStruct->FSMC_WrapMode)); | ||||
|   assert_param(IS_FSMC_WAIT_SIGNAL_ACTIVE(FSMC_NORSRAMInitStruct->FSMC_WaitSignalActive)); | ||||
|   assert_param(IS_FSMC_WRITE_OPERATION(FSMC_NORSRAMInitStruct->FSMC_WriteOperation)); | ||||
|   assert_param(IS_FSMC_WAITE_SIGNAL(FSMC_NORSRAMInitStruct->FSMC_WaitSignal)); | ||||
|   assert_param(IS_FSMC_EXTENDED_MODE(FSMC_NORSRAMInitStruct->FSMC_ExtendedMode)); | ||||
|   assert_param(IS_FSMC_WRITE_BURST(FSMC_NORSRAMInitStruct->FSMC_WriteBurst));   | ||||
|   assert_param(IS_FSMC_ADDRESS_SETUP_TIME(FSMC_NORSRAMInitStruct->FSMC_ReadWriteTimingStruct->FSMC_AddressSetupTime)); | ||||
|   assert_param(IS_FSMC_ADDRESS_HOLD_TIME(FSMC_NORSRAMInitStruct->FSMC_ReadWriteTimingStruct->FSMC_AddressHoldTime)); | ||||
|   assert_param(IS_FSMC_DATASETUP_TIME(FSMC_NORSRAMInitStruct->FSMC_ReadWriteTimingStruct->FSMC_DataSetupTime)); | ||||
|   assert_param(IS_FSMC_TURNAROUND_TIME(FSMC_NORSRAMInitStruct->FSMC_ReadWriteTimingStruct->FSMC_BusTurnAroundDuration)); | ||||
|   assert_param(IS_FSMC_CLK_DIV(FSMC_NORSRAMInitStruct->FSMC_ReadWriteTimingStruct->FSMC_CLKDivision)); | ||||
|   assert_param(IS_FSMC_DATA_LATENCY(FSMC_NORSRAMInitStruct->FSMC_ReadWriteTimingStruct->FSMC_DataLatency)); | ||||
|   assert_param(IS_FSMC_ACCESS_MODE(FSMC_NORSRAMInitStruct->FSMC_ReadWriteTimingStruct->FSMC_AccessMode));  | ||||
|    | ||||
|   /* Bank1 NOR/SRAM control register configuration */  | ||||
|   FSMC_Bank1->BTCR[FSMC_NORSRAMInitStruct->FSMC_Bank] =  | ||||
|             (uint32_t)FSMC_NORSRAMInitStruct->FSMC_DataAddressMux | | ||||
|             FSMC_NORSRAMInitStruct->FSMC_MemoryType | | ||||
|             FSMC_NORSRAMInitStruct->FSMC_MemoryDataWidth | | ||||
|             FSMC_NORSRAMInitStruct->FSMC_BurstAccessMode | | ||||
|             FSMC_NORSRAMInitStruct->FSMC_AsynchronousWait | | ||||
|             FSMC_NORSRAMInitStruct->FSMC_WaitSignalPolarity | | ||||
|             FSMC_NORSRAMInitStruct->FSMC_WrapMode | | ||||
|             FSMC_NORSRAMInitStruct->FSMC_WaitSignalActive | | ||||
|             FSMC_NORSRAMInitStruct->FSMC_WriteOperation | | ||||
|             FSMC_NORSRAMInitStruct->FSMC_WaitSignal | | ||||
|             FSMC_NORSRAMInitStruct->FSMC_ExtendedMode | | ||||
|             FSMC_NORSRAMInitStruct->FSMC_WriteBurst; | ||||
| 
 | ||||
|   if(FSMC_NORSRAMInitStruct->FSMC_MemoryType == FSMC_MemoryType_NOR) | ||||
|   { | ||||
|     FSMC_Bank1->BTCR[FSMC_NORSRAMInitStruct->FSMC_Bank] |= (uint32_t)FSMC_BCR1_FACCEN; | ||||
|   } | ||||
|    | ||||
|   /* Bank1 NOR/SRAM timing register configuration */ | ||||
|   FSMC_Bank1->BTCR[FSMC_NORSRAMInitStruct->FSMC_Bank+1] =  | ||||
|             (uint32_t)FSMC_NORSRAMInitStruct->FSMC_ReadWriteTimingStruct->FSMC_AddressSetupTime | | ||||
|             (FSMC_NORSRAMInitStruct->FSMC_ReadWriteTimingStruct->FSMC_AddressHoldTime << 4) | | ||||
|             (FSMC_NORSRAMInitStruct->FSMC_ReadWriteTimingStruct->FSMC_DataSetupTime << 8) | | ||||
|             (FSMC_NORSRAMInitStruct->FSMC_ReadWriteTimingStruct->FSMC_BusTurnAroundDuration << 16) | | ||||
|             (FSMC_NORSRAMInitStruct->FSMC_ReadWriteTimingStruct->FSMC_CLKDivision << 20) | | ||||
|             (FSMC_NORSRAMInitStruct->FSMC_ReadWriteTimingStruct->FSMC_DataLatency << 24) | | ||||
|              FSMC_NORSRAMInitStruct->FSMC_ReadWriteTimingStruct->FSMC_AccessMode; | ||||
|              | ||||
|      | ||||
|   /* Bank1 NOR/SRAM timing register for write configuration, if extended mode is used */ | ||||
|   if(FSMC_NORSRAMInitStruct->FSMC_ExtendedMode == FSMC_ExtendedMode_Enable) | ||||
|   { | ||||
|     assert_param(IS_FSMC_ADDRESS_SETUP_TIME(FSMC_NORSRAMInitStruct->FSMC_WriteTimingStruct->FSMC_AddressSetupTime)); | ||||
|     assert_param(IS_FSMC_ADDRESS_HOLD_TIME(FSMC_NORSRAMInitStruct->FSMC_WriteTimingStruct->FSMC_AddressHoldTime)); | ||||
|     assert_param(IS_FSMC_DATASETUP_TIME(FSMC_NORSRAMInitStruct->FSMC_WriteTimingStruct->FSMC_DataSetupTime)); | ||||
|     assert_param(IS_FSMC_CLK_DIV(FSMC_NORSRAMInitStruct->FSMC_WriteTimingStruct->FSMC_CLKDivision)); | ||||
|     assert_param(IS_FSMC_DATA_LATENCY(FSMC_NORSRAMInitStruct->FSMC_WriteTimingStruct->FSMC_DataLatency)); | ||||
|     assert_param(IS_FSMC_ACCESS_MODE(FSMC_NORSRAMInitStruct->FSMC_WriteTimingStruct->FSMC_AccessMode)); | ||||
|     FSMC_Bank1E->BWTR[FSMC_NORSRAMInitStruct->FSMC_Bank] =  | ||||
|               (uint32_t)FSMC_NORSRAMInitStruct->FSMC_WriteTimingStruct->FSMC_AddressSetupTime | | ||||
|               (FSMC_NORSRAMInitStruct->FSMC_WriteTimingStruct->FSMC_AddressHoldTime << 4 )| | ||||
|               (FSMC_NORSRAMInitStruct->FSMC_WriteTimingStruct->FSMC_DataSetupTime << 8) | | ||||
|               (FSMC_NORSRAMInitStruct->FSMC_WriteTimingStruct->FSMC_CLKDivision << 20) | | ||||
|               (FSMC_NORSRAMInitStruct->FSMC_WriteTimingStruct->FSMC_DataLatency << 24) | | ||||
|                FSMC_NORSRAMInitStruct->FSMC_WriteTimingStruct->FSMC_AccessMode; | ||||
|   } | ||||
|   else | ||||
|   { | ||||
|     FSMC_Bank1E->BWTR[FSMC_NORSRAMInitStruct->FSMC_Bank] = 0x0FFFFFFF; | ||||
|   } | ||||
| } | ||||
| 
 | ||||
| /**
 | ||||
|   * @brief  Fills each FSMC_NORSRAMInitStruct member with its default value. | ||||
|   * @param  FSMC_NORSRAMInitStruct: pointer to a FSMC_NORSRAMInitTypeDef  | ||||
|   *   structure which will be initialized. | ||||
|   * @retval None | ||||
|   */ | ||||
| void FSMC_NORSRAMStructInit(FSMC_NORSRAMInitTypeDef* FSMC_NORSRAMInitStruct) | ||||
| {   | ||||
|   /* Reset NOR/SRAM Init structure parameters values */ | ||||
|   FSMC_NORSRAMInitStruct->FSMC_Bank = FSMC_Bank1_NORSRAM1; | ||||
|   FSMC_NORSRAMInitStruct->FSMC_DataAddressMux = FSMC_DataAddressMux_Enable; | ||||
|   FSMC_NORSRAMInitStruct->FSMC_MemoryType = FSMC_MemoryType_SRAM; | ||||
|   FSMC_NORSRAMInitStruct->FSMC_MemoryDataWidth = FSMC_MemoryDataWidth_8b; | ||||
|   FSMC_NORSRAMInitStruct->FSMC_BurstAccessMode = FSMC_BurstAccessMode_Disable; | ||||
|   FSMC_NORSRAMInitStruct->FSMC_AsynchronousWait = FSMC_AsynchronousWait_Disable; | ||||
|   FSMC_NORSRAMInitStruct->FSMC_WaitSignalPolarity = FSMC_WaitSignalPolarity_Low; | ||||
|   FSMC_NORSRAMInitStruct->FSMC_WrapMode = FSMC_WrapMode_Disable; | ||||
|   FSMC_NORSRAMInitStruct->FSMC_WaitSignalActive = FSMC_WaitSignalActive_BeforeWaitState; | ||||
|   FSMC_NORSRAMInitStruct->FSMC_WriteOperation = FSMC_WriteOperation_Enable; | ||||
|   FSMC_NORSRAMInitStruct->FSMC_WaitSignal = FSMC_WaitSignal_Enable; | ||||
|   FSMC_NORSRAMInitStruct->FSMC_ExtendedMode = FSMC_ExtendedMode_Disable; | ||||
|   FSMC_NORSRAMInitStruct->FSMC_WriteBurst = FSMC_WriteBurst_Disable; | ||||
|   FSMC_NORSRAMInitStruct->FSMC_ReadWriteTimingStruct->FSMC_AddressSetupTime = 0xF; | ||||
|   FSMC_NORSRAMInitStruct->FSMC_ReadWriteTimingStruct->FSMC_AddressHoldTime = 0xF; | ||||
|   FSMC_NORSRAMInitStruct->FSMC_ReadWriteTimingStruct->FSMC_DataSetupTime = 0xFF; | ||||
|   FSMC_NORSRAMInitStruct->FSMC_ReadWriteTimingStruct->FSMC_BusTurnAroundDuration = 0xF; | ||||
|   FSMC_NORSRAMInitStruct->FSMC_ReadWriteTimingStruct->FSMC_CLKDivision = 0xF; | ||||
|   FSMC_NORSRAMInitStruct->FSMC_ReadWriteTimingStruct->FSMC_DataLatency = 0xF; | ||||
|   FSMC_NORSRAMInitStruct->FSMC_ReadWriteTimingStruct->FSMC_AccessMode = FSMC_AccessMode_A;  | ||||
|   FSMC_NORSRAMInitStruct->FSMC_WriteTimingStruct->FSMC_AddressSetupTime = 0xF; | ||||
|   FSMC_NORSRAMInitStruct->FSMC_WriteTimingStruct->FSMC_AddressHoldTime = 0xF; | ||||
|   FSMC_NORSRAMInitStruct->FSMC_WriteTimingStruct->FSMC_DataSetupTime = 0xFF; | ||||
|   FSMC_NORSRAMInitStruct->FSMC_WriteTimingStruct->FSMC_BusTurnAroundDuration = 0xF; | ||||
|   FSMC_NORSRAMInitStruct->FSMC_WriteTimingStruct->FSMC_CLKDivision = 0xF; | ||||
|   FSMC_NORSRAMInitStruct->FSMC_WriteTimingStruct->FSMC_DataLatency = 0xF; | ||||
|   FSMC_NORSRAMInitStruct->FSMC_WriteTimingStruct->FSMC_AccessMode = FSMC_AccessMode_A; | ||||
| } | ||||
| 
 | ||||
| /**
 | ||||
|   * @brief  Enables or disables the specified NOR/SRAM Memory Bank. | ||||
|   * @param  FSMC_Bank: specifies the FSMC Bank to be used | ||||
|   *   This parameter can be one of the following values: | ||||
|   *     @arg FSMC_Bank1_NORSRAM1: FSMC Bank1 NOR/SRAM1   | ||||
|   *     @arg FSMC_Bank1_NORSRAM2: FSMC Bank1 NOR/SRAM2  | ||||
|   *     @arg FSMC_Bank1_NORSRAM3: FSMC Bank1 NOR/SRAM3  | ||||
|   *     @arg FSMC_Bank1_NORSRAM4: FSMC Bank1 NOR/SRAM4  | ||||
|   * @param  NewState: new state of the FSMC_Bank. This parameter can be: ENABLE or DISABLE. | ||||
|   * @retval None | ||||
|   */ | ||||
| void FSMC_NORSRAMCmd(uint32_t FSMC_Bank, FunctionalState NewState) | ||||
| { | ||||
|   assert_param(IS_FSMC_NORSRAM_BANK(FSMC_Bank)); | ||||
|   assert_param(IS_FUNCTIONAL_STATE(NewState)); | ||||
|    | ||||
|   if (NewState != DISABLE) | ||||
|   { | ||||
|     /* Enable the selected NOR/SRAM Bank by setting the MBKEN bit in the BCRx register */ | ||||
|     FSMC_Bank1->BTCR[FSMC_Bank] |= FSMC_BCR1_MBKEN; | ||||
|   } | ||||
|   else | ||||
|   { | ||||
|     /* Disable the selected NOR/SRAM Bank by clearing the MBKEN bit in the BCRx register */ | ||||
|     FSMC_Bank1->BTCR[FSMC_Bank] &= (uint32_t)(~FSMC_BCR1_MBKEN); | ||||
|   } | ||||
| } | ||||
| 
 | ||||
| /**
 | ||||
|   * @} | ||||
|   */  | ||||
| 
 | ||||
| /**
 | ||||
|   * @} | ||||
|   */ | ||||
| 
 | ||||
| /**
 | ||||
|   * @} | ||||
|   */ | ||||
| 
 | ||||
| /************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE****/ | ||||
										
											
												File diff suppressed because it is too large
												Load diff
											
										
									
								
							|  | @ -1,266 +0,0 @@ | |||
| /**
 | ||||
|   ****************************************************************************** | ||||
|   * @file    stm32l1xx_iwdg.c | ||||
|   * @author  MCD Application Team | ||||
|   * @version V1.1.1 | ||||
|   * @date    05-March-2012 | ||||
|   * @brief   This file provides firmware functions to manage the following  | ||||
|   *          functionalities of the Independent watchdog (IWDG) peripheral:            | ||||
|   *           + Prescaler and Counter configuration | ||||
|   *           + IWDG activation | ||||
|   *           + Flag management | ||||
|   * | ||||
|   *  @verbatim   | ||||
|   *   | ||||
|   ==============================================================================  | ||||
|                           ##### IWDG features ##### | ||||
|   ==============================================================================  | ||||
|     [..] The IWDG can be started by either software or hardware (configurable | ||||
|          through option byte). | ||||
|               | ||||
|     [..] The IWDG is clocked by its own dedicated low-speed clock (LSI) and | ||||
|          thus stays active even if the main clock fails. | ||||
|          Once the IWDG is started, the LSI is forced ON and cannot be disabled | ||||
|          (LSI cannot be disabled too), and the counter starts counting down from  | ||||
|          the reset value of 0xFFF. When it reaches the end of count value (0x000) | ||||
|          a system reset is generated. | ||||
|          The IWDG counter should be reloaded at regular intervals to prevent | ||||
|          an MCU reset. | ||||
|                               | ||||
|     [..] The IWDG is implemented in the VDD voltage domain that is still functional | ||||
|          in STOP and STANDBY mode (IWDG reset can wake-up from STANDBY). | ||||
|                | ||||
|     [..] IWDGRST flag in RCC_CSR register can be used to inform when a IWDG | ||||
|          reset occurs. | ||||
|                | ||||
|     [..] Min-max timeout value @37KHz (LSI): ~108us / ~28.3s | ||||
|          The IWDG timeout may vary due to LSI frequency dispersion. STM32L1xx | ||||
|          devices provide the capability to measure the LSI frequency (LSI clock | ||||
|          connected internally to TIM10 CH1 input capture). The measured value | ||||
|          can be used to have an IWDG timeout with an acceptable accuracy.  | ||||
|          For more information, please refer to the STM32L1xx Reference manual. | ||||
|              | ||||
|                           ##### How to use this driver #####  | ||||
|   ==============================================================================  | ||||
|     [..] | ||||
|     (#) Enable write access to IWDG_PR and IWDG_RLR registers using | ||||
|         IWDG_WriteAccessCmd(IWDG_WriteAccess_Enable) function. | ||||
|     (#) Configure the IWDG prescaler using IWDG_SetPrescaler() function. | ||||
| 
 | ||||
|     (#) Configure the IWDG counter value using IWDG_SetReload() function. | ||||
|         This value will be loaded in the IWDG counter each time the counter | ||||
|         is reloaded, then the IWDG will start counting down from this value. | ||||
| 
 | ||||
|     (#) Start the IWDG using IWDG_Enable() function, when the IWDG is used | ||||
|         in software mode (no need to enable the LSI, it will be enabled | ||||
|         by hardware). | ||||
| 
 | ||||
|     (#) Then the application program must reload the IWDG counter at regular | ||||
|         intervals during normal operation to prevent an MCU reset, using | ||||
|         IWDG_ReloadCounter() function. | ||||
| 
 | ||||
|     @endverbatim | ||||
|   *     | ||||
|   ****************************************************************************** | ||||
|   * @attention | ||||
|   * | ||||
|   * <h2><center>© COPYRIGHT 2012 STMicroelectronics</center></h2> | ||||
|   * | ||||
|   * Licensed under MCD-ST Liberty SW License Agreement V2, (the "License"); | ||||
|   * You may not use this file except in compliance with the License. | ||||
|   * You may obtain a copy of the License at: | ||||
|   * | ||||
|   *        http://www.st.com/software_license_agreement_liberty_v2
 | ||||
|   * | ||||
|   * Unless required by applicable law or agreed to in writing, software  | ||||
|   * distributed under the License is distributed on an "AS IS" BASIS,  | ||||
|   * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. | ||||
|   * See the License for the specific language governing permissions and | ||||
|   * limitations under the License. | ||||
|   * | ||||
|   ****************************************************************************** | ||||
|   */ | ||||
| 
 | ||||
| /* Includes ------------------------------------------------------------------*/ | ||||
| #include "stm32l1xx_iwdg.h" | ||||
| 
 | ||||
| /** @addtogroup STM32L1xx_StdPeriph_Driver
 | ||||
|   * @{ | ||||
|   */ | ||||
| 
 | ||||
| /** @defgroup IWDG 
 | ||||
|   * @brief IWDG driver modules | ||||
|   * @{ | ||||
|   */  | ||||
| 
 | ||||
| /* Private typedef -----------------------------------------------------------*/ | ||||
| /* Private define ------------------------------------------------------------*/ | ||||
| /* ---------------------- IWDG registers bit mask ----------------------------*/ | ||||
| /* KR register bit mask */ | ||||
| #define KR_KEY_RELOAD    ((uint16_t)0xAAAA) | ||||
| #define KR_KEY_ENABLE    ((uint16_t)0xCCCC) | ||||
| 
 | ||||
| /* Private macro -------------------------------------------------------------*/ | ||||
| /* Private variables ---------------------------------------------------------*/ | ||||
| /* Private function prototypes -----------------------------------------------*/ | ||||
| /* Private functions ---------------------------------------------------------*/ | ||||
| 
 | ||||
| /** @defgroup IWDG_Private_Functions
 | ||||
|   * @{ | ||||
|   */ | ||||
| 
 | ||||
| /** @defgroup IWDG_Group1 Prescaler and Counter configuration functions
 | ||||
|  *  @brief   Prescaler and Counter configuration functions | ||||
|  * | ||||
| @verbatim    | ||||
|   ============================================================================== | ||||
|             ##### Prescaler and Counter configuration functions ##### | ||||
|   ==============================================================================   | ||||
| 
 | ||||
| @endverbatim | ||||
|   * @{ | ||||
|   */ | ||||
| 
 | ||||
| /**
 | ||||
|   * @brief  Enables or disables write access to IWDG_PR and IWDG_RLR registers. | ||||
|   * @param  IWDG_WriteAccess: new state of write access to IWDG_PR and IWDG_RLR registers. | ||||
|   *   This parameter can be one of the following values: | ||||
|   *     @arg IWDG_WriteAccess_Enable: Enable write access to IWDG_PR and IWDG_RLR registers | ||||
|   *     @arg IWDG_WriteAccess_Disable: Disable write access to IWDG_PR and IWDG_RLR registers | ||||
|   * @retval None | ||||
|   */ | ||||
| void IWDG_WriteAccessCmd(uint16_t IWDG_WriteAccess) | ||||
| { | ||||
|   /* Check the parameters */ | ||||
|   assert_param(IS_IWDG_WRITE_ACCESS(IWDG_WriteAccess)); | ||||
|   IWDG->KR = IWDG_WriteAccess; | ||||
| } | ||||
| 
 | ||||
| /**
 | ||||
|   * @brief  Sets IWDG Prescaler value. | ||||
|   * @param  IWDG_Prescaler: specifies the IWDG Prescaler value. | ||||
|   *   This parameter can be one of the following values: | ||||
|   *     @arg IWDG_Prescaler_4: IWDG prescaler set to 4 | ||||
|   *     @arg IWDG_Prescaler_8: IWDG prescaler set to 8 | ||||
|   *     @arg IWDG_Prescaler_16: IWDG prescaler set to 16 | ||||
|   *     @arg IWDG_Prescaler_32: IWDG prescaler set to 32 | ||||
|   *     @arg IWDG_Prescaler_64: IWDG prescaler set to 64 | ||||
|   *     @arg IWDG_Prescaler_128: IWDG prescaler set to 128 | ||||
|   *     @arg IWDG_Prescaler_256: IWDG prescaler set to 256 | ||||
|   * @retval None | ||||
|   */ | ||||
| void IWDG_SetPrescaler(uint8_t IWDG_Prescaler) | ||||
| { | ||||
|   /* Check the parameters */ | ||||
|   assert_param(IS_IWDG_PRESCALER(IWDG_Prescaler)); | ||||
|   IWDG->PR = IWDG_Prescaler; | ||||
| } | ||||
| 
 | ||||
| /**
 | ||||
|   * @brief  Sets IWDG Reload value. | ||||
|   * @param  Reload: specifies the IWDG Reload value. | ||||
|   *   This parameter must be a number between 0 and 0x0FFF. | ||||
|   * @retval None | ||||
|   */ | ||||
| void IWDG_SetReload(uint16_t Reload) | ||||
| { | ||||
|   /* Check the parameters */ | ||||
|   assert_param(IS_IWDG_RELOAD(Reload)); | ||||
|   IWDG->RLR = Reload; | ||||
| } | ||||
| 
 | ||||
| /**
 | ||||
|   * @brief  Reloads IWDG counter with value defined in the reload register | ||||
|   *   (write access to IWDG_PR and IWDG_RLR registers disabled). | ||||
|   * @param  None | ||||
|   * @retval None | ||||
|   */ | ||||
| void IWDG_ReloadCounter(void) | ||||
| { | ||||
|   IWDG->KR = KR_KEY_RELOAD; | ||||
| } | ||||
| 
 | ||||
| /**
 | ||||
|   * @} | ||||
|   */ | ||||
| 
 | ||||
| /** @defgroup IWDG_Group2 IWDG activation function
 | ||||
|  *  @brief   IWDG activation function  | ||||
|  * | ||||
| @verbatim    | ||||
|   ============================================================================== | ||||
|                           ##### IWDG activation function ##### | ||||
|   ==============================================================================   | ||||
| 
 | ||||
| @endverbatim | ||||
|   * @{ | ||||
|   */ | ||||
| 
 | ||||
| /**
 | ||||
|   * @brief  Enables IWDG (write access to IWDG_PR and IWDG_RLR registers disabled). | ||||
|   * @param  None. | ||||
|   * @retval None. | ||||
|   */ | ||||
| void IWDG_Enable(void) | ||||
| { | ||||
|   IWDG->KR = KR_KEY_ENABLE; | ||||
| } | ||||
| 
 | ||||
| /**
 | ||||
|   * @} | ||||
|   */ | ||||
| 
 | ||||
| /** @defgroup IWDG_Group3 Flag management function 
 | ||||
|  *  @brief  Flag management function   | ||||
|  * | ||||
| @verbatim    | ||||
|  =============================================================================== | ||||
|                       ##### Flag management function #####  | ||||
|  ===============================================================================   | ||||
| 
 | ||||
| @endverbatim | ||||
|   * @{ | ||||
|   */ | ||||
| 
 | ||||
| /**
 | ||||
|   * @brief  Checks whether the specified IWDG flag is set or not. | ||||
|   * @param  IWDG_FLAG: specifies the flag to check. | ||||
|   *   This parameter can be one of the following values: | ||||
|   *     @arg IWDG_FLAG_PVU: Prescaler Value Update on going | ||||
|   *     @arg IWDG_FLAG_RVU: Reload Value Update on going | ||||
|   * @retval The new state of IWDG_FLAG (SET or RESET). | ||||
|   */ | ||||
| FlagStatus IWDG_GetFlagStatus(uint16_t IWDG_FLAG) | ||||
| { | ||||
|   FlagStatus bitstatus = RESET; | ||||
|   /* Check the parameters */ | ||||
|   assert_param(IS_IWDG_FLAG(IWDG_FLAG)); | ||||
|   if ((IWDG->SR & IWDG_FLAG) != (uint32_t)RESET) | ||||
|   { | ||||
|     bitstatus = SET; | ||||
|   } | ||||
|   else | ||||
|   { | ||||
|     bitstatus = RESET; | ||||
|   } | ||||
|   /* Return the flag status */ | ||||
|   return bitstatus; | ||||
| } | ||||
| 
 | ||||
| /**
 | ||||
|   * @} | ||||
|   */ | ||||
| 
 | ||||
| /**
 | ||||
|   * @} | ||||
|   */ | ||||
| 
 | ||||
| /**
 | ||||
|   * @} | ||||
|   */ | ||||
| 
 | ||||
| /**
 | ||||
|   * @} | ||||
|   */ | ||||
| 
 | ||||
| /************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE****/ | ||||
|  | @ -1,557 +0,0 @@ | |||
| /**
 | ||||
|   ****************************************************************************** | ||||
|   * @file    stm32l1xx_opamp.c | ||||
|   * @author  MCD Application Team | ||||
|   * @version V1.1.1 | ||||
|   * @date    05-March-2012 | ||||
|   * @brief   This file provides firmware functions to manage the following | ||||
|   *          functionalities of the operational amplifiers (opamp) peripheral: | ||||
|   *           + Initialization and configuration | ||||
|   *           + Calibration management | ||||
|   *           | ||||
|   *  @verbatim | ||||
|   ============================================================================== | ||||
|                             ##### How to use this driver ##### | ||||
|   ============================================================================== | ||||
|     [..] The device integrates three independent rail-to-rail operational amplifiers | ||||
|          OPAMP1, OPAMP2 and OPAMP3: | ||||
|                (+) Internal connections to the ADC. | ||||
|                (+) Internal connections to the DAC. | ||||
|                (+) Internal connection to COMP1 (only OPAMP3). | ||||
|                (+) Internal connection for unity gain (voltage follower) configuration. | ||||
|                (+) Calibration capability. | ||||
|                (+) Selectable gain-bandwidth (2MHz in normal mode, 500KHz in low power mode). | ||||
|     [..]     | ||||
|          (#) COMP AHB clock must be enabled to get write access | ||||
|              to OPAMP registers using | ||||
|          (#) RCC_APB1PeriphClockCmd(RCC_APB1Periph_COMP, ENABLE) | ||||
|    | ||||
|          (#) Configure the corresponding GPIO to OPAMPx INP, OPAMPx_INN (if used) | ||||
|              and OPAMPx_OUT in analog mode. | ||||
|     | ||||
|          (#) Configure (close/open) the OPAMP switches using OPAMP_SwitchCmd() | ||||
| 
 | ||||
|          (#) Enable the OPAMP peripheral using OPAMP_Cmd() | ||||
| 
 | ||||
|          -@- In order to use OPAMP outputs as ADC inputs, the opamps must be enabled | ||||
|              and the ADC must use the OPAMP output channel number: | ||||
|              (+@) OPAMP1 output is connected to ADC channel 3. | ||||
|              (+@) OPAMP2 output is connected to ADC channel 8. | ||||
|              (+@) OPAMP3 output is connected to ADC channel 13 (SW1 switch must be closed). | ||||
| 
 | ||||
|   *  @endverbatim | ||||
|   * | ||||
|   ****************************************************************************** | ||||
|   * @attention | ||||
|   * | ||||
|   * <h2><center>© COPYRIGHT 2012 STMicroelectronics</center></h2> | ||||
|   * | ||||
|   * Licensed under MCD-ST Liberty SW License Agreement V2, (the "License"); | ||||
|   * You may not use this file except in compliance with the License. | ||||
|   * You may obtain a copy of the License at: | ||||
|   * | ||||
|   *        http://www.st.com/software_license_agreement_liberty_v2
 | ||||
|   * | ||||
|   * Unless required by applicable law or agreed to in writing, software  | ||||
|   * distributed under the License is distributed on an "AS IS" BASIS,  | ||||
|   * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. | ||||
|   * See the License for the specific language governing permissions and | ||||
|   * limitations under the License. | ||||
|   * | ||||
|   ****************************************************************************** | ||||
|   */ | ||||
| 
 | ||||
| /* Includes ------------------------------------------------------------------*/ | ||||
| #include "stm32l1xx_opamp.h" | ||||
| 
 | ||||
| 
 | ||||
| /** @addtogroup STM32L1xx_StdPeriph_Driver
 | ||||
|   * @{ | ||||
|   */ | ||||
| 
 | ||||
| /** @defgroup OPAMP 
 | ||||
|   * @brief OPAMP driver modules | ||||
|   * @{ | ||||
|   */  | ||||
| 
 | ||||
| /* Private typedef -----------------------------------------------------------*/ | ||||
| /* Private define ------------------------------------------------------------*/ | ||||
| /* Private macro -------------------------------------------------------------*/ | ||||
| /* Private variables ---------------------------------------------------------*/ | ||||
| /* Private function prototypes -----------------------------------------------*/ | ||||
| /* Private functions ---------------------------------------------------------*/ | ||||
| 
 | ||||
| /** @defgroup OPAMP_Private_Functions
 | ||||
|   * @{ | ||||
|   */ | ||||
| 
 | ||||
| /** @defgroup OPAMP_Group1 Initialization and configuration
 | ||||
|  *  @brief   Initialization and configuration | ||||
|  * | ||||
| @verbatim    | ||||
|  =============================================================================== | ||||
|                             ##### Initialization and configuration ##### | ||||
|  =============================================================================== | ||||
| 
 | ||||
| @endverbatim | ||||
|   * @{ | ||||
|   */   | ||||
| 
 | ||||
| /**
 | ||||
|   * @brief  Deinitialize the OPAMPs register to its default reset value. | ||||
|   * @note   At startup, OTR and LPOTR registers are set to factory programmed values. | ||||
|   * @param  None. | ||||
|   * @retval None. | ||||
|   */ | ||||
| void OPAMP_DeInit(void) | ||||
| { | ||||
|   /*!< Set OPAMP_CSR register to reset value */ | ||||
|   OPAMP->CSR = 0x00010101; | ||||
|   /*!< Set OPAMP_OTR register to reset value */ | ||||
|   OPAMP->OTR = (uint32_t)(* (uint32_t*)FLASH_R_BASE + 0x00000038); | ||||
|   /*!< Set OPAMP_LPOTR register to reset value */ | ||||
|   OPAMP->LPOTR = (uint32_t)(* (uint32_t*)FLASH_R_BASE + 0x0000003C); | ||||
| } | ||||
| 
 | ||||
| /**
 | ||||
|   * @brief  Close or Open the OPAMP switches. | ||||
|   * @param  OPAMP_OPAMPxSwitchy: selects the OPAMPx switch. | ||||
|   *   This parameter can be any combinations of the following values: | ||||
|   *     @arg OPAMP_OPAMP1Switch3: used to connect internally OPAMP1 output to  | ||||
|   *                               OPAMP1 negative input (internal follower) | ||||
|   *     @arg OPAMP_OPAMP1Switch4: used to connect PA2 to OPAMP1 negative input | ||||
|   *     @arg OPAMP_OPAMP1Switch5: used to connect PA1 to OPAMP1 positive input | ||||
|   *     @arg OPAMP_OPAMP1Switch6: used to connect DAC_OUT1 to OPAMP1 positive input | ||||
|   *     @arg OPAMP_OPAMP1SwitchANA: used to meet 1 nA input leakage | ||||
|   *     @arg OPAMP_OPAMP2Switch3: used to connect internally OPAMP2 output to  | ||||
|   *                               OPAMP2 negative input (internal follower) | ||||
|   *     @arg OPAMP_OPAMP2Switch4: used to connect PA7 to OPAMP2 negative input | ||||
|   *     @arg OPAMP_OPAMP2Switch5: used to connect PA6 to OPAMP2 positive input | ||||
|   *     @arg OPAMP_OPAMP2Switch6: used to connect DAC_OUT1 to OPAMP2 positive input | ||||
|   *     @arg OPAMP_OPAMP2Switch7: used to connect DAC_OUT2 to OPAMP2 positive input | ||||
|   *     @arg OPAMP_OPAMP2SwitchANA: used to meet 1 nA input leakage | ||||
|   *     @arg OPAMP_OPAMP3Switch3: used to connect internally OPAMP3 output to  | ||||
|   *                               OPAMP3 negative input (internal follower) | ||||
|   *     @arg OPAMP_OPAMP3Switch4: used to connect PC2 to OPAMP3 negative input | ||||
|   *     @arg OPAMP_OPAMP3Switch5: used to connect PC1 to OPAMP3 positive input | ||||
|   *     @arg OPAMP_OPAMP3Switch6: used to connect DAC_OUT1 to OPAMP3 positive input | ||||
|   *     @arg OPAMP_OPAMP3SwitchANA: used to meet 1 nA input leakage on negative input | ||||
|   * | ||||
|   * @param  NewState: New state of the OPAMP switch.  | ||||
|   *   This parameter can be: | ||||
|   *     ENABLE to close the OPAMP switch | ||||
|   *     or DISABLE to open the OPAMP switch | ||||
|   * @note OPAMP_OPAMP2Switch6 and OPAMP_OPAMP2Switch7 mustn't be closed together. | ||||
|   * @retval None | ||||
|   */ | ||||
| void OPAMP_SwitchCmd(uint32_t OPAMP_OPAMPxSwitchy, FunctionalState NewState) | ||||
| { | ||||
|   /* Check the parameter */ | ||||
|   assert_param(IS_OPAMP_SWITCH(OPAMP_OPAMPxSwitchy)); | ||||
|   assert_param(IS_FUNCTIONAL_STATE(NewState)); | ||||
| 
 | ||||
|   if (NewState != DISABLE) | ||||
|   { | ||||
|     /* Close the selected switches */ | ||||
|     OPAMP->CSR |= (uint32_t) OPAMP_OPAMPxSwitchy; | ||||
|   } | ||||
|   else | ||||
|   { | ||||
|     /* Open the selected switches */ | ||||
|     OPAMP->CSR &= (~(uint32_t)OPAMP_OPAMPxSwitchy); | ||||
|   } | ||||
| } | ||||
| 
 | ||||
| /**
 | ||||
|   * @brief  Enable or disable the OPAMP peripheral. | ||||
|   * @param  OPAMP_Selection: the selected OPAMP.  | ||||
|   *   This parameter can be one of the following values: | ||||
|   *     @arg OPAMP_Selection_OPAMP1: OPAMP1 is selected | ||||
|   *     @arg OPAMP_Selection_OPAMP2: OPAMP2 is selected | ||||
|   *     @arg OPAMP_Selection_OPAMP3: OPAMP3 is selected | ||||
|   * @param  NewState: new state of the selected OPAMP peripheral.  | ||||
|   *         This parameter can be: ENABLE or DISABLE. | ||||
|   * @retval None | ||||
|   */ | ||||
| void OPAMP_Cmd(uint32_t OPAMP_Selection, FunctionalState NewState) | ||||
| { | ||||
|   /* Check the parameter */ | ||||
|   assert_param(IS_OPAMP_ALL_PERIPH(OPAMP_Selection)); | ||||
|   assert_param(IS_FUNCTIONAL_STATE(NewState)); | ||||
| 
 | ||||
|   if (NewState != DISABLE) | ||||
|   { | ||||
|     /* Enable the selected OPAMP */ | ||||
|     OPAMP->CSR &= (~(uint32_t) OPAMP_Selection); | ||||
|   } | ||||
|   else | ||||
|   { | ||||
|     /* Disable the selected OPAMP */ | ||||
|     OPAMP->CSR |= (uint32_t) OPAMP_Selection; | ||||
|   } | ||||
| } | ||||
| 
 | ||||
| /**
 | ||||
|   * @brief  Enable or disable the low power mode for OPAMP peripheral. | ||||
|   * @param  OPAMP_Selection: the selected OPAMP.  | ||||
|   *   This parameter can be one of the following values: | ||||
|   *     @arg OPAMP_Selection_OPAMP1: OPAMP1 selected | ||||
|   *     @arg OPAMP_Selection_OPAMP2: OPAMP2 selected | ||||
|   *     @arg OPAMP_Selection_OPAMP3: OPAMP3 selected | ||||
|   * @param  NewState: new low power state of the selected OPAMP peripheral. | ||||
|   *         This parameter can be: ENABLE or DISABLE. | ||||
|   * @retval None | ||||
|   */ | ||||
| void OPAMP_LowPowerCmd(uint32_t OPAMP_Selection, FunctionalState NewState) | ||||
| { | ||||
|   /* Check the parameter */ | ||||
|   assert_param(IS_OPAMP_ALL_PERIPH(OPAMP_Selection)); | ||||
|   assert_param(IS_FUNCTIONAL_STATE(NewState)); | ||||
| 
 | ||||
|   if (NewState != DISABLE) | ||||
|   { | ||||
|     /* Set the selected OPAMP in low power mode */ | ||||
|     OPAMP->CSR |= (uint32_t) (OPAMP_Selection << 7); | ||||
|   } | ||||
|   else | ||||
|   { | ||||
|     /* Disable the low power mode for the selected OPAMP */ | ||||
|     OPAMP->CSR &= (~(uint32_t) (OPAMP_Selection << 7)); | ||||
|   } | ||||
| } | ||||
| 
 | ||||
| /**
 | ||||
|   * @brief  Select the OPAMP power range. | ||||
|   * @note   The OPAMP power range selection must be performed while OPAMPs are powered down. | ||||
|   * @param  OPAMP_Range: the selected OPAMP power range.  | ||||
|   *   This parameter can be one of the following values: | ||||
|   *     @arg OPAMP_PowerRange_Low: Low power range is selected (VDDA is lower than 2.4V). | ||||
|   *     @arg OPAMP_PowerRange_High: High power range is selected (VDDA is higher than 2.4V). | ||||
|   * @retval None | ||||
|   */ | ||||
| void OPAMP_PowerRangeSelect(uint32_t OPAMP_PowerRange) | ||||
| { | ||||
|   /* Check the parameter */ | ||||
|   assert_param(IS_OPAMP_RANGE(OPAMP_PowerRange)); | ||||
| 
 | ||||
|   /* Reset the OPAMP range bit */ | ||||
|   OPAMP->CSR &= (~(uint32_t) (OPAMP_CSR_AOP_RANGE)); | ||||
| 
 | ||||
|   /* Select the OPAMP power range */ | ||||
|   OPAMP->CSR |= OPAMP_PowerRange; | ||||
| } | ||||
| 
 | ||||
| /**
 | ||||
|   * @} | ||||
|   */ | ||||
| 
 | ||||
| /** @defgroup OPAMP_Group2 Calibration functions
 | ||||
|  *  @brief   Calibration functions | ||||
|  * | ||||
| @verbatim    | ||||
|  =============================================================================== | ||||
|                             ##### Calibration functions ##### | ||||
|  =============================================================================== | ||||
| 
 | ||||
| @endverbatim | ||||
|   * @{ | ||||
|   */ | ||||
| 
 | ||||
| /**
 | ||||
|   * @brief  Select the trimming mode. | ||||
|   * @param  OffsetTrimming: the selected offset trimming mode.  | ||||
|   *   This parameter  can be one of the following values: | ||||
|   *     @arg OffsetTrimming_Factory: factory trimming values are used for offset | ||||
|   *                                  calibration. | ||||
|   *     @arg OffsetTrimming_User: user trimming values are used for offset | ||||
|   *                               calibration. | ||||
|   * @note When OffsetTrimming_User is selected, use OPAMP_OffsetTrimConfig() | ||||
|   *       function or OPAMP_OffsetTrimLowPowerConfig() function to adjust  | ||||
|   *       trimming value. | ||||
|   * @retval None | ||||
|   */ | ||||
| void OPAMP_OffsetTrimmingModeSelect(uint32_t OPAMP_Trimming) | ||||
| { | ||||
|   /* Check the parameter */ | ||||
|   assert_param(IS_OPAMP_TRIMMING(OPAMP_Trimming)); | ||||
| 
 | ||||
|   /* Reset the OPAMP_OTR range bit */ | ||||
|   OPAMP->CSR &= (~(uint32_t) (OPAMP_OTR_OT_USER)); | ||||
| 
 | ||||
|   /* Select the OPAMP offset trimming  */ | ||||
|   OPAMP->CSR |= OPAMP_Trimming; | ||||
| 
 | ||||
| } | ||||
| 
 | ||||
| /**
 | ||||
|   * @brief  Configure the trimming value of OPAMPs in normal mode. | ||||
|   * @param  OPAMP_Selection: the selected OPAMP.  | ||||
|   *   This parameter can be one of the following values: | ||||
|   *         @arg OPAMP_Selection_OPAMP1: OPAMP1 is selected to configure the trimming value. | ||||
|   *         @arg OPAMP_Selection_OPAMP2: OPAMP2 is selected to configure the trimming value. | ||||
|   *         @arg OPAMP_Selection_OPAMP3: OPAMP3 is selected to configure the trimming value. | ||||
|   * @param  OPAMP_Input: the selected OPAMP input.  | ||||
|   *   This parameter can be one of the following values: | ||||
|   *         @arg OPAMP_Input_NMOS: NMOS input is selected to configure the trimming value. | ||||
|   *         @arg OPAMP_Input_PMOS: PMOS input is selected to configure the trimming value. | ||||
|   * @param  OPAMP_TrimValue: the trimming value. This parameter can be any value lower | ||||
|   *         or equal to 0x0000001F.  | ||||
|   * @retval None | ||||
|   */ | ||||
| void OPAMP_OffsetTrimConfig(uint32_t OPAMP_Selection, uint32_t OPAMP_Input, uint32_t OPAMP_TrimValue) | ||||
| { | ||||
|   uint32_t tmpreg = 0; | ||||
| 
 | ||||
|   /* Check the parameter */ | ||||
|   assert_param(IS_OPAMP_ALL_PERIPH(OPAMP_Selection)); | ||||
|   assert_param(IS_OPAMP_INPUT(OPAMP_Input)); | ||||
|   assert_param(IS_OPAMP_TRIMMINGVALUE(OPAMP_TrimValue)); | ||||
| 
 | ||||
|   /* Get the OPAMP_OTR value */ | ||||
|   tmpreg = OPAMP->OTR; | ||||
| 
 | ||||
|   if(OPAMP_Selection == OPAMP_Selection_OPAMP1) | ||||
|   { | ||||
|     /* Reset the OPAMP inputs selection */ | ||||
|     tmpreg &= (uint32_t)~(OPAMP_CSR_OPA1CAL_L | OPAMP_CSR_OPA1CAL_H); | ||||
|     /* Select the OPAMP input */ | ||||
|     tmpreg |= OPAMP_Input; | ||||
| 
 | ||||
|     if(OPAMP_Input == OPAMP_Input_PMOS) | ||||
|     { | ||||
|       /* Reset the trimming value corresponding to OPAMP1 PMOS input */ | ||||
|       tmpreg &= (0xFFFFFFE0); | ||||
|       /* Set the new trimming value corresponding to OPAMP1 PMOS input */ | ||||
|       tmpreg |= (OPAMP_TrimValue); | ||||
|     } | ||||
|     else | ||||
|     { | ||||
|       /* Reset the trimming value corresponding to OPAMP1 NMOS input */ | ||||
|       tmpreg &= (0xFFFFFC1F); | ||||
|       /* Set the new trimming value corresponding to OPAMP1 NMOS input */ | ||||
|       tmpreg |= (OPAMP_TrimValue<<5); | ||||
|     } | ||||
|   } | ||||
|   else if (OPAMP_Selection == OPAMP_Selection_OPAMP2) | ||||
|   { | ||||
|     /* Reset the OPAMP inputs selection */ | ||||
|     tmpreg &= (uint32_t)~(OPAMP_CSR_OPA2CAL_L | OPAMP_CSR_OPA2CAL_H); | ||||
|     /* Select the OPAMP input */ | ||||
|     tmpreg |= (uint32_t)(OPAMP_Input<<8); | ||||
| 
 | ||||
|     if(OPAMP_Input == OPAMP_Input_PMOS) | ||||
|     { | ||||
|       /* Reset the trimming value corresponding to OPAMP2 PMOS input */ | ||||
|       tmpreg &= (0xFFFF83FF); | ||||
|       /* Set the new trimming value corresponding to OPAMP2 PMOS input */ | ||||
|       tmpreg |= (OPAMP_TrimValue<<10); | ||||
|     } | ||||
|     else | ||||
|     { | ||||
|       /* Reset the trimming value corresponding to OPAMP2 NMOS input */ | ||||
|       tmpreg &= (0xFFF07FFF); | ||||
|       /* Set the new trimming value corresponding to OPAMP2 NMOS input */ | ||||
|       tmpreg |= (OPAMP_TrimValue<<15); | ||||
|     } | ||||
|   } | ||||
|   else | ||||
|   { | ||||
|     /* Reset the OPAMP inputs selection */ | ||||
|     tmpreg &= (uint32_t)~(OPAMP_CSR_OPA3CAL_L | OPAMP_CSR_OPA3CAL_H); | ||||
|     /* Select the OPAMP input */ | ||||
|     tmpreg |= (uint32_t)(OPAMP_Input<<16); | ||||
| 
 | ||||
|     if(OPAMP_Input == OPAMP_Input_PMOS) | ||||
|     { | ||||
|       /* Reset the trimming value corresponding to OPAMP3 PMOS input */ | ||||
|       tmpreg &= (0xFE0FFFFF); | ||||
|       /* Set the new trimming value corresponding to OPAMP3 PMOS input */ | ||||
|       tmpreg |= (OPAMP_TrimValue<<20); | ||||
|     } | ||||
|     else | ||||
|     { | ||||
|       /* Reset the trimming value corresponding to OPAMP3 NMOS input */ | ||||
|       tmpreg &= (0xC1FFFFFF); | ||||
|       /* Set the new trimming value corresponding to OPAMP3 NMOS input */ | ||||
|       tmpreg |= (OPAMP_TrimValue<<25); | ||||
|     } | ||||
|   } | ||||
| 
 | ||||
|   /* Set the OPAMP_OTR register */ | ||||
|   OPAMP->OTR = tmpreg; | ||||
| } | ||||
| 
 | ||||
| /**
 | ||||
|   * @brief  Configure the trimming value of OPAMPs in low power mode. | ||||
|   * @param  OPAMP_Selection: the selected OPAMP.  | ||||
|   *   This parameter can be one of the following values: | ||||
|   *         @arg OPAMP_Selection_OPAMP1: OPAMP1 is selected to configure the trimming value. | ||||
|   *         @arg OPAMP_Selection_OPAMP2: OPAMP2 is selected to configure the trimming value. | ||||
|   *         @arg OPAMP_Selection_OPAMP3: OPAMP3 is selected to configure the trimming value. | ||||
|   * @param  OPAMP_Input: the selected OPAMP input.  | ||||
|   *   This parameter can be one of the following values: | ||||
|   *         @arg OPAMP_Input_NMOS: NMOS input is selected to configure the trimming value. | ||||
|   *         @arg OPAMP_Input_PMOS: PMOS input is selected to configure the trimming value. | ||||
|   * @param  OPAMP_TrimValue: the trimming value.  | ||||
|   *    This parameter can be any value lower or equal to 0x0000001F.  | ||||
|   * @retval None | ||||
|   */ | ||||
| void OPAMP_OffsetTrimLowPowerConfig(uint32_t OPAMP_Selection, uint32_t OPAMP_Input, uint32_t OPAMP_TrimValue) | ||||
| { | ||||
|   uint32_t tmpreg = 0; | ||||
| 
 | ||||
|   /* Check the parameter */ | ||||
|   assert_param(IS_OPAMP_ALL_PERIPH(OPAMP_Selection)); | ||||
|   assert_param(IS_OPAMP_INPUT(OPAMP_Input)); | ||||
|   assert_param(IS_OPAMP_TRIMMINGVALUE(OPAMP_TrimValue)); | ||||
| 
 | ||||
|   /* Get the OPAMP_LPOTR value */ | ||||
|   tmpreg = OPAMP->LPOTR; | ||||
| 
 | ||||
|   if(OPAMP_Selection == OPAMP_Selection_OPAMP1) | ||||
|   { | ||||
|     /* Reset the OPAMP inputs selection */ | ||||
|     tmpreg &= (uint32_t)~(OPAMP_CSR_OPA1CAL_L | OPAMP_CSR_OPA1CAL_H); | ||||
|     /* Select the OPAMP input */ | ||||
|     tmpreg |= OPAMP_Input; | ||||
| 
 | ||||
|     if(OPAMP_Input == OPAMP_Input_PMOS) | ||||
|     { | ||||
|       /* Reset the trimming value corresponding to OPAMP1 PMOS input */ | ||||
|       tmpreg &= (0xFFFFFFE0); | ||||
|       /* Set the new trimming value corresponding to OPAMP1 PMOS input */ | ||||
|       tmpreg |= (OPAMP_TrimValue); | ||||
|     } | ||||
|     else | ||||
|     { | ||||
|       /* Reset the trimming value corresponding to OPAMP1 NMOS input */ | ||||
|       tmpreg &= (0xFFFFFC1F); | ||||
|       /* Set the new trimming value corresponding to OPAMP1 NMOS input */ | ||||
|       tmpreg |= (OPAMP_TrimValue<<5); | ||||
|     } | ||||
|   } | ||||
|   else if (OPAMP_Selection == OPAMP_Selection_OPAMP2) | ||||
|   { | ||||
|     /* Reset the OPAMP inputs selection */ | ||||
|     tmpreg &= (uint32_t)~(OPAMP_CSR_OPA2CAL_L | OPAMP_CSR_OPA2CAL_H); | ||||
|     /* Select the OPAMP input */ | ||||
|     tmpreg |= (uint32_t)(OPAMP_Input<<8); | ||||
| 
 | ||||
|     if(OPAMP_Input == OPAMP_Input_PMOS) | ||||
|     { | ||||
|       /* Reset the trimming value corresponding to OPAMP2 PMOS input */ | ||||
|       tmpreg &= (0xFFFF83FF); | ||||
|       /* Set the new trimming value corresponding to OPAMP2 PMOS input */ | ||||
|       tmpreg |= (OPAMP_TrimValue<<10); | ||||
|     } | ||||
|     else | ||||
|     { | ||||
|       /* Reset the trimming value corresponding to OPAMP2 NMOS input */ | ||||
|       tmpreg &= (0xFFF07FFF); | ||||
|       /* Set the new trimming value corresponding to OPAMP2 NMOS input */ | ||||
|       tmpreg |= (OPAMP_TrimValue<<15); | ||||
|     } | ||||
|   } | ||||
|   else | ||||
|   { | ||||
|     /* Reset the OPAMP inputs selection */ | ||||
|     tmpreg &= (uint32_t)~(OPAMP_CSR_OPA3CAL_L | OPAMP_CSR_OPA3CAL_H); | ||||
|     /* Select the OPAMP input */ | ||||
|     tmpreg |= (uint32_t)(OPAMP_Input<<16); | ||||
| 
 | ||||
|     if(OPAMP_Input == OPAMP_Input_PMOS) | ||||
|     { | ||||
|       /* Reset the trimming value corresponding to OPAMP3 PMOS input */ | ||||
|       tmpreg &= (0xFE0FFFFF); | ||||
|       /* Set the new trimming value corresponding to OPAMP3 PMOS input */ | ||||
|       tmpreg |= (OPAMP_TrimValue<<20); | ||||
|     } | ||||
|     else | ||||
|     { | ||||
|       /* Reset the trimming value corresponding to OPAMP3 NMOS input */ | ||||
|       tmpreg &= (0xC1FFFFFF); | ||||
|       /* Set the new trimming value corresponding to OPAMP3 NMOS input */ | ||||
|       tmpreg |= (OPAMP_TrimValue<<25); | ||||
|     } | ||||
|   } | ||||
| 
 | ||||
|   /* Set the OPAMP_LPOTR register */ | ||||
|   OPAMP->LPOTR = tmpreg; | ||||
| } | ||||
| 
 | ||||
| /**
 | ||||
|   * @brief  Checks whether the specified OPAMP calibration flag is set or not. | ||||
|   * @note   User should wait until calibration flag change the value when changing | ||||
|   *         the trimming value. | ||||
|   * @param  OPAMP_Selection: the selected OPAMP.  | ||||
|   *   This parameter can be one of the following values: | ||||
|   *     @arg OPAMP_Selection_OPAMP1: OPAMP1 is selected. | ||||
|   *     @arg OPAMP_Selection_OPAMP2: OPAMP2 is selected. | ||||
|   *     @arg OPAMP_Selection_OPAMP3: OPAMP3 is selected. | ||||
|   * @retval The new state of the OPAMP calibration flag (SET or RESET). | ||||
|   */ | ||||
| FlagStatus OPAMP_GetFlagStatus(uint32_t OPAMP_Selection) | ||||
| { | ||||
|   FlagStatus bitstatus = RESET; | ||||
|   uint32_t tmpreg = 0; | ||||
| 
 | ||||
|   /* Check the parameter */ | ||||
|   assert_param(IS_OPAMP_ALL_PERIPH(OPAMP_Selection)); | ||||
|    | ||||
|   /* Get the CSR register value */ | ||||
|   tmpreg = OPAMP->CSR; | ||||
| 
 | ||||
|   /* Check if OPAMP1 is selected */ | ||||
|   if(OPAMP_Selection == OPAMP_Selection_OPAMP1) | ||||
|   { | ||||
|     /* Check OPAMP1 CAL bit status */ | ||||
|     if ((tmpreg & OPAMP_CSR_OPA1CALOUT) != (uint32_t)RESET) | ||||
|     { | ||||
|       bitstatus = SET; | ||||
|     } | ||||
|     else | ||||
|     { | ||||
|       bitstatus = RESET; | ||||
|     } | ||||
|   } | ||||
|   /* Check if OPAMP2 is selected */ | ||||
|   else if(OPAMP_Selection == OPAMP_Selection_OPAMP2) | ||||
|   { | ||||
|     /* Check OPAMP2 CAL bit status */ | ||||
|     if ((tmpreg & OPAMP_CSR_OPA2CALOUT) != (uint32_t)RESET) | ||||
|     { | ||||
|       bitstatus = SET; | ||||
|     }  | ||||
|     else | ||||
|     { | ||||
|       bitstatus = RESET; | ||||
|     } | ||||
|   } | ||||
|   else | ||||
|   { | ||||
|     /* Check OPAMP3 CAL bit status */ | ||||
|     if ((tmpreg & OPAMP_CSR_OPA3CALOUT) != (uint32_t)RESET) | ||||
|     { | ||||
|       bitstatus = SET; | ||||
|     } | ||||
|     else | ||||
|     { | ||||
|       bitstatus = RESET; | ||||
|     } | ||||
|   } | ||||
|   return bitstatus; | ||||
| } | ||||
| 
 | ||||
| /**
 | ||||
|   * @} | ||||
|   */ | ||||
| 
 | ||||
| /**
 | ||||
|   * @} | ||||
|   */ | ||||
| 
 | ||||
| /**
 | ||||
|   * @} | ||||
|   */ | ||||
| 
 | ||||
| /************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE****/ | ||||
										
											
												File diff suppressed because it is too large
												Load diff
											
										
									
								
							|  | @ -1,984 +0,0 @@ | |||
| /**
 | ||||
|   ****************************************************************************** | ||||
|   * @file    stm32l1xx_sdio.c | ||||
|   * @author  MCD Application Team | ||||
|   * @version V1.1.1 | ||||
|   * @date    05-March-2012 | ||||
|   * @brief   This file provides firmware functions to manage the following  | ||||
|   *          functionalities of the SDIO peripheral: | ||||
|   *           + Initialization  | ||||
|   *           + Interrupts and flags management | ||||
|   * | ||||
|   *  @verbatim | ||||
|   ============================================================================== | ||||
|                          ##### How to use this driver ##### | ||||
|   ============================================================================== | ||||
|     [..] | ||||
|     (#) The SDIO clock (SDIOCLK = 48 MHz) is coming from a specific output of PLL | ||||
|        (PLLVCO) througth a fixed divider by 2. | ||||
|        Before to start working with SDIO peripheral make sure that the PLLVCO is  | ||||
|        well configured to 96MHz.  | ||||
|        The SDIO peripheral uses two clock signals:  | ||||
|        (++) SDIO adapter clock (SDIOCLK = 48 MHz). | ||||
|        (++) APB2 bus clock (PCLK2). | ||||
|             PCLK2 and SDIO_CK clock frequencies must respect the following  | ||||
|             condition: Frequenc(PCLK2) >= (3 / 8 x Frequency(SDIO_CK)). | ||||
|     (#) Enable peripheral clock using  | ||||
|         RCC_APB2PeriphClockCmd(RCC_APB2Periph_SDIO, ENABLE).  | ||||
|     (#) According to the SDIO mode, enable the GPIO clocks using | ||||
|         RCC_AHBPeriphClockCmd() function. | ||||
|         The I/O can be one of the following configurations:  | ||||
|         (++) 1-bit data length: SDIO_CMD, SDIO_CK and D0.  | ||||
|         (++) 4-bit data length: SDIO_CMD, SDIO_CK and D[3:0].  | ||||
|         (++) 8-bit data length: SDIO_CMD, SDIO_CK and D[7:0]. | ||||
| 
 | ||||
|     (#) Peripheral's alternate function:   | ||||
|         (++) Connect the pin to the desired peripherals' Alternate   | ||||
|              Function (AF) using GPIO_PinAFConfig() function. | ||||
|         (++) Configure the desired pin in alternate function by:  | ||||
|              GPIO_InitStruct->GPIO_Mode = GPIO_Mode_AF. | ||||
|         (++) Select the type, pull-up/pull-down and output speed via   | ||||
|              GPIO_PuPd, GPIO_OType and GPIO_Speed members. | ||||
|         (++) Call GPIO_Init() function. | ||||
| 
 | ||||
|     (#) Program the Clock Edge, Clock Bypass, Clock Power Save, Bus Wide,   | ||||
|         hardware, flow control and the Clock Divider using the SDIO_Init()  | ||||
|         function.  | ||||
|     (#) Enable the Power ON State using the SDIO_SetPowerState(SDIO_PowerState_ON)   | ||||
|         function.            | ||||
|     (#) Enable the clock using the SDIO_ClockCmd() function.  | ||||
|     (#) Enable the NVIC and the corresponding interrupt using the function   | ||||
|         SDIO_ITConfig() if you need to use interrupt mode.   | ||||
|     (#) When using the DMA mode | ||||
|         (++) Configure the DMA using DMA_Init() function. | ||||
|         (++) Active the needed channel Request using SDIO_DMACmd() function. | ||||
|     (#) Enable the DMA using the DMA_Cmd() function, when using DMA mode. | ||||
|     (#) To control the CPSM (Command Path State Machine) and send commands to the | ||||
|         card use the SDIO_SendCommand(), SDIO_GetCommandResponse() and  | ||||
|         SDIO_GetResponse() functions. First, user has to fill the command  | ||||
|         structure (pointer to SDIO_CmdInitTypeDef) according to the selected  | ||||
|         command to be sent. The parameters that should be filled are:  | ||||
|         (++) Command Argument. | ||||
|         (++) Command Index. | ||||
|         (++) Command Response type. | ||||
|         (++) Command Wait. | ||||
|         (++) CPSM Status (Enable or Disable). | ||||
|         To check if the command is well received, read the SDIO_CMDRESP register  | ||||
|         using the SDIO_GetCommandResponse(). The SDIO responses registers  | ||||
|         (SDIO_RESP1 to SDIO_RESP2), use the SDIO_GetResponse() function.  | ||||
|     (#) To control the DPSM (Data Path State Machine) and send/receive   | ||||
|         data to/from the card use the SDIO_DataConfig(), SDIO_GetDataCounter(), | ||||
|         SDIO_ReadData(), SDIO_WriteData() and SDIO_GetFIFOCount() functions. | ||||
| 
 | ||||
|     *** Read Operations ***  | ||||
|     -----------------------  | ||||
|       [..] | ||||
|       (#) First, user has to fill the data structure (pointer to  | ||||
|           SDIO_DataInitTypeDef) according to the selected data type to be received.  | ||||
|           The parameters that should be filled are: | ||||
|           (++) Data TimeOut. | ||||
|           (++) Data Length. | ||||
|           (++) Data Block size. | ||||
|           (++) Data Transfer direction: should be from card (To SDIO). | ||||
|           (++) Data Transfer mode. | ||||
|           (++) DPSM Status (Enable or Disable). | ||||
|       (#) Configure the SDIO resources to receive the data from the card  | ||||
|           according to selected transfer mode (Refer to Step 8, 9 and 10). | ||||
|       (#) Send the selected Read command (refer to step 11). | ||||
|       (#) Use the SDIO flags/interrupts to check the transfer status. | ||||
|   | ||||
|   *** Write Operations ***  | ||||
|   ------------------------  | ||||
|     [..] | ||||
|     (#) First, user has to fill the data structure (pointer to | ||||
|         SDIO_DataInitTypeDef) according to the selected data type to be received.  | ||||
|         The parameters that should be filled are:  | ||||
|         (++) Data TimeOut. | ||||
|         (++) Data Length. | ||||
|         (++) Data Block size. | ||||
|         (++) Data Transfer direction:  should be to card (To CARD). | ||||
|         (++) Data Transfer mode. | ||||
|         (++) DPSM Status (Enable or Disable). | ||||
|     (#) Configure the SDIO resources to send the data to the card  | ||||
|         according to selected transfer mode (Refer to Step 8, 9 and 10). | ||||
|     (#) Send the selected Write command (refer to step 11). | ||||
|     (#) Use the SDIO flags/interrupts to check the transfer status. | ||||
| 
 | ||||
|   @endverbatim | ||||
|   * | ||||
|   ****************************************************************************** | ||||
|   * @attention | ||||
|   * | ||||
|   * <h2><center>© COPYRIGHT 2012 STMicroelectronics</center></h2> | ||||
|   * | ||||
|   * Licensed under MCD-ST Liberty SW License Agreement V2, (the "License"); | ||||
|   * You may not use this file except in compliance with the License. | ||||
|   * You may obtain a copy of the License at: | ||||
|   * | ||||
|   *        http://www.st.com/software_license_agreement_liberty_v2
 | ||||
|   * | ||||
|   * Unless required by applicable law or agreed to in writing, software  | ||||
|   * distributed under the License is distributed on an "AS IS" BASIS,  | ||||
|   * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. | ||||
|   * See the License for the specific language governing permissions and | ||||
|   * limitations under the License. | ||||
|   * | ||||
|   ****************************************************************************** | ||||
|   */  | ||||
| 
 | ||||
| /* Includes ------------------------------------------------------------------*/ | ||||
| #include "stm32l1xx_sdio.h" | ||||
| #include "stm32l1xx_rcc.h" | ||||
| 
 | ||||
| /** @addtogroup STM32L1xx_StdPeriph_Driver
 | ||||
|   * @{ | ||||
|   */ | ||||
| 
 | ||||
| /** @defgroup SDIO 
 | ||||
|   * @brief SDIO driver modules | ||||
|   * @{ | ||||
|   */  | ||||
| 
 | ||||
| /* Private typedef -----------------------------------------------------------*/ | ||||
| /* Private define ------------------------------------------------------------*/  | ||||
| 
 | ||||
| /* ------------ 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         ((uint32_t)0xFFFF8100)  | ||||
| 
 | ||||
| /* --- PWRCTRL Register ---*/ | ||||
| 
 | ||||
| /* SDIO PWRCTRL Mask */ | ||||
| #define PWR_PWRCTRL_MASK         ((uint32_t)0xFFFFFFFC) | ||||
| 
 | ||||
| /* --- DCTRL Register ---*/ | ||||
| 
 | ||||
| /* SDIO DCTRL Clear Mask */ | ||||
| #define DCTRL_CLEAR_MASK         ((uint32_t)0xFFFFFF08) | ||||
| 
 | ||||
| /* --- CMD Register ---*/ | ||||
| 
 | ||||
| /* CMD Register clear mask */ | ||||
| #define CMD_CLEAR_MASK           ((uint32_t)0xFFFFF800) | ||||
| 
 | ||||
| /* SDIO RESP Registers Address */ | ||||
| #define SDIO_RESP_ADDR           ((uint32_t)(SDIO_BASE + 0x14)) | ||||
| 
 | ||||
| /* Private macro -------------------------------------------------------------*/ | ||||
| /* Private variables ---------------------------------------------------------*/ | ||||
| /* Private function prototypes -----------------------------------------------*/ | ||||
| /* Private functions ---------------------------------------------------------*/ | ||||
| 
 | ||||
| /** @defgroup SDIO_Private_Functions
 | ||||
|   * @{ | ||||
|   */ | ||||
| 
 | ||||
| /** @defgroup SDIO_Group1 Initialization and Configuration functions
 | ||||
|  *  @brief   Initialization and Configuration functions  | ||||
|  * | ||||
|  @verbatim | ||||
|   ============================================================================== | ||||
|               ##### Initialization and Configuration functions ##### | ||||
|   ============================================================================== | ||||
| 
 | ||||
| @endverbatim | ||||
|   * @{ | ||||
|   */ | ||||
| 
 | ||||
| /**
 | ||||
|   * @brief  Deinitializes the SDIO peripheral registers to their default reset values. | ||||
|   * @param  None | ||||
|   * @retval None | ||||
|   */ | ||||
| void SDIO_DeInit(void) | ||||
| { | ||||
|   RCC_APB2PeriphResetCmd(RCC_APB2Periph_SDIO, ENABLE); | ||||
|   RCC_APB2PeriphResetCmd(RCC_APB2Periph_SDIO, DISABLE);   | ||||
| } | ||||
| 
 | ||||
| /**
 | ||||
|   * @brief  Initializes the SDIO peripheral according to the specified  | ||||
|   *   parameters in the SDIO_InitStruct. | ||||
|   * @param  SDIO_InitStruct : pointer to a SDIO_InitTypeDef structure  | ||||
|   *   that contains the configuration information for the SDIO peripheral. | ||||
|   * @retval None | ||||
|   */ | ||||
| void SDIO_Init(SDIO_InitTypeDef* SDIO_InitStruct) | ||||
| { | ||||
|   uint32_t 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; | ||||
| } | ||||
| 
 | ||||
| /**
 | ||||
|   * @brief  Fills each SDIO_InitStruct member with its default value. | ||||
|   * @param  SDIO_InitStruct: pointer to an SDIO_InitTypeDef structure which  | ||||
|   *   will be initialized. | ||||
|   * @retval 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; | ||||
| } | ||||
| 
 | ||||
| /**
 | ||||
|   * @brief  Enables or disables the SDIO Clock. | ||||
|   * @param  NewState: new state of the SDIO Clock. This parameter can be: ENABLE or DISABLE. | ||||
|   * @retval None | ||||
|   */ | ||||
| void SDIO_ClockCmd(FunctionalState NewState) | ||||
| { | ||||
|   /* Check the parameters */ | ||||
|   assert_param(IS_FUNCTIONAL_STATE(NewState)); | ||||
|    | ||||
|   *(__IO uint32_t *) CLKCR_CLKEN_BB = (uint32_t)NewState; | ||||
| } | ||||
| 
 | ||||
| /**
 | ||||
|   * @brief  Sets the power status of the controller. | ||||
|   * @param  SDIO_PowerState: new state of the Power state.  | ||||
|   *   This parameter can be one of the following values: | ||||
|   *     @arg SDIO_PowerState_OFF: SDIO Power OFF. | ||||
|   *     @arg SDIO_PowerState_ON: SDIO Power ON. | ||||
|   * @retval None | ||||
|   */ | ||||
| void SDIO_SetPowerState(uint32_t SDIO_PowerState) | ||||
| { | ||||
|   /* Check the parameters */ | ||||
|   assert_param(IS_SDIO_POWER_STATE(SDIO_PowerState)); | ||||
| 
 | ||||
|   SDIO->POWER = SDIO_PowerState; | ||||
| } | ||||
| 
 | ||||
| /**
 | ||||
|   * @brief  Gets the power status of the controller. | ||||
|   * @param  None | ||||
|   * @retval Power status of the controller. The returned value can | ||||
|   *   be one of the following: | ||||
|   * - 0x00: Power OFF | ||||
|   * - 0x02: Power UP | ||||
|   * - 0x03: Power ON  | ||||
|   */ | ||||
| uint32_t SDIO_GetPowerState(void) | ||||
| { | ||||
|   return (SDIO->POWER & (~PWR_PWRCTRL_MASK)); | ||||
| } | ||||
| 
 | ||||
| /**
 | ||||
|   * @} | ||||
|   */ | ||||
| 
 | ||||
| /** @defgroup SDIO_Group2 DMA transfers management functions
 | ||||
|  *  @brief   DMA transfers management functions | ||||
|  * | ||||
|  @verbatim | ||||
|   ============================================================================== | ||||
|                   ##### DMA transfers management functions ##### | ||||
|   ============================================================================== | ||||
|     [..] This section provide functions allowing to program SDIO DMA transfer. | ||||
| 
 | ||||
| @endverbatim | ||||
|   * @{ | ||||
|   */ | ||||
| 
 | ||||
| /**
 | ||||
|   * @brief  Enables or disables the SDIO DMA request. | ||||
|   * @param  NewState: new state of the selected SDIO DMA request. | ||||
|   *   This parameter can be: ENABLE or DISABLE. | ||||
|   * @retval None | ||||
|   */ | ||||
| void SDIO_DMACmd(FunctionalState NewState) | ||||
| { | ||||
|   /* Check the parameters */ | ||||
|   assert_param(IS_FUNCTIONAL_STATE(NewState)); | ||||
|    | ||||
|   *(__IO uint32_t *) DCTRL_DMAEN_BB = (uint32_t)NewState; | ||||
| } | ||||
| 
 | ||||
| /**
 | ||||
|   * @} | ||||
|   */ | ||||
| 
 | ||||
| /** @defgroup SDIO_Group3 Command path state machine (CPSM) management functions
 | ||||
|  *  @brief   Command path state machine (CPSM) management functions  | ||||
|  * | ||||
|  @verbatim | ||||
|   ============================================================================== | ||||
|        ##### Command path state machine (CPSM) management functions ##### | ||||
|   ============================================================================== | ||||
|   [..] This section provide functions allowing to program and read the Command  | ||||
|        path state machine (CPSM). | ||||
| 
 | ||||
| @endverbatim | ||||
|   * @{ | ||||
|   */ | ||||
| 
 | ||||
| /**
 | ||||
|   * @brief  Initializes the SDIO Command according to the specified  | ||||
|   *   parameters in the SDIO_CmdInitStruct and send the command. | ||||
|   * @param  SDIO_CmdInitStruct : pointer to a SDIO_CmdInitTypeDef  | ||||
|   *   structure that contains the configuration information for the SDIO command. | ||||
|   * @retval None | ||||
|   */ | ||||
| void SDIO_SendCommand(SDIO_CmdInitTypeDef *SDIO_CmdInitStruct) | ||||
| { | ||||
|   uint32_t tmpreg = 0; | ||||
|    | ||||
|   /* Check the parameters */ | ||||
|   assert_param(IS_SDIO_CMD_INDEX(SDIO_CmdInitStruct->SDIO_CmdIndex)); | ||||
|   assert_param(IS_SDIO_RESPONSE(SDIO_CmdInitStruct->SDIO_Response)); | ||||
|   assert_param(IS_SDIO_WAIT(SDIO_CmdInitStruct->SDIO_Wait)); | ||||
|   assert_param(IS_SDIO_CPSM(SDIO_CmdInitStruct->SDIO_CPSM)); | ||||
|    | ||||
| /*---------------------------- SDIO ARG Configuration ------------------------*/ | ||||
|   /* Set the SDIO Argument value */ | ||||
|   SDIO->ARG = SDIO_CmdInitStruct->SDIO_Argument; | ||||
|    | ||||
| /*---------------------------- SDIO CMD Configuration ------------------------*/   | ||||
|   /* Get the SDIO CMD value */ | ||||
|   tmpreg = SDIO->CMD; | ||||
|   /* Clear CMDINDEX, WAITRESP, WAITINT, WAITPEND, CPSMEN bits */ | ||||
|   tmpreg &= CMD_CLEAR_MASK; | ||||
|   /* Set CMDINDEX bits according to SDIO_CmdIndex value */ | ||||
|   /* Set WAITRESP bits according to SDIO_Response value */ | ||||
|   /* Set WAITINT and WAITPEND bits according to SDIO_Wait value */ | ||||
|   /* Set CPSMEN bits according to SDIO_CPSM value */ | ||||
|   tmpreg |= (uint32_t)SDIO_CmdInitStruct->SDIO_CmdIndex | SDIO_CmdInitStruct->SDIO_Response | ||||
|            | SDIO_CmdInitStruct->SDIO_Wait | SDIO_CmdInitStruct->SDIO_CPSM; | ||||
|    | ||||
|   /* Write to SDIO CMD */ | ||||
|   SDIO->CMD = tmpreg; | ||||
| } | ||||
| 
 | ||||
| /**
 | ||||
|   * @brief  Fills each SDIO_CmdInitStruct member with its default value. | ||||
|   * @param  SDIO_CmdInitStruct: pointer to an SDIO_CmdInitTypeDef  | ||||
|   *   structure which will be initialized. | ||||
|   * @retval None | ||||
|   */ | ||||
| void SDIO_CmdStructInit(SDIO_CmdInitTypeDef* SDIO_CmdInitStruct) | ||||
| { | ||||
|   /* SDIO_CmdInitStruct members default value */ | ||||
|   SDIO_CmdInitStruct->SDIO_Argument = 0x00; | ||||
|   SDIO_CmdInitStruct->SDIO_CmdIndex = 0x00; | ||||
|   SDIO_CmdInitStruct->SDIO_Response = SDIO_Response_No; | ||||
|   SDIO_CmdInitStruct->SDIO_Wait = SDIO_Wait_No; | ||||
|   SDIO_CmdInitStruct->SDIO_CPSM = SDIO_CPSM_Disable; | ||||
| } | ||||
| 
 | ||||
| /**
 | ||||
|   * @brief  Returns command index of last command for which response received. | ||||
|   * @param  None | ||||
|   * @retval Returns the command index of the last command response received. | ||||
|   */ | ||||
| uint8_t SDIO_GetCommandResponse(void) | ||||
| { | ||||
|   return (uint8_t)(SDIO->RESPCMD); | ||||
| } | ||||
| 
 | ||||
| /**
 | ||||
|   * @brief  Returns response received from the card for the last command. | ||||
|   * @param  SDIO_RESP: Specifies the SDIO response register.  | ||||
|   *   This parameter can be one of the following values: | ||||
|   *     @arg SDIO_RESP1: Response Register 1. | ||||
|   *     @arg SDIO_RESP2: Response Register 2. | ||||
|   *     @arg SDIO_RESP3: Response Register 3. | ||||
|   *     @arg SDIO_RESP4: Response Register 4. | ||||
|   * @retval The Corresponding response register value. | ||||
|   */ | ||||
| uint32_t SDIO_GetResponse(uint32_t SDIO_RESP) | ||||
| { | ||||
|   __IO uint32_t tmp = 0; | ||||
| 
 | ||||
|   /* Check the parameters */ | ||||
|   assert_param(IS_SDIO_RESP(SDIO_RESP)); | ||||
| 
 | ||||
|   tmp = SDIO_RESP_ADDR + SDIO_RESP; | ||||
|    | ||||
|   return (*(__IO uint32_t *) tmp);  | ||||
| } | ||||
| 
 | ||||
| /**
 | ||||
|   * @} | ||||
|   */ | ||||
| 
 | ||||
| /** @defgroup SDIO_Group4 Data path state machine (DPSM) management functions
 | ||||
|  *  @brief   Data path state machine (DPSM) management functions | ||||
|  * | ||||
|  @verbatim | ||||
|   ============================================================================== | ||||
|         ##### Data path state machine (DPSM) management functions ##### | ||||
|   ============================================================================== | ||||
|   [..] This section provide functions allowing to program and read the Data path  | ||||
|        state machine (DPSM). | ||||
| 
 | ||||
| @endverbatim | ||||
|   * @{ | ||||
|   */ | ||||
| 
 | ||||
| /**
 | ||||
|   * @brief  Initializes the SDIO data path according to the specified  | ||||
|   *   parameters in the SDIO_DataInitStruct. | ||||
|   * @param  SDIO_DataInitStruct : pointer to a SDIO_DataInitTypeDef structure that | ||||
|   *   contains the configuration information for the SDIO command. | ||||
|   * @retval None | ||||
|   */ | ||||
| void SDIO_DataConfig(SDIO_DataInitTypeDef* SDIO_DataInitStruct) | ||||
| { | ||||
|   uint32_t tmpreg = 0; | ||||
|    | ||||
|   /* Check the parameters */ | ||||
|   assert_param(IS_SDIO_DATA_LENGTH(SDIO_DataInitStruct->SDIO_DataLength)); | ||||
|   assert_param(IS_SDIO_BLOCK_SIZE(SDIO_DataInitStruct->SDIO_DataBlockSize)); | ||||
|   assert_param(IS_SDIO_TRANSFER_DIR(SDIO_DataInitStruct->SDIO_TransferDir)); | ||||
|   assert_param(IS_SDIO_TRANSFER_MODE(SDIO_DataInitStruct->SDIO_TransferMode)); | ||||
|   assert_param(IS_SDIO_DPSM(SDIO_DataInitStruct->SDIO_DPSM)); | ||||
| 
 | ||||
| /*---------------------------- SDIO DTIMER Configuration ---------------------*/ | ||||
|   /* Set the SDIO Data TimeOut value */ | ||||
|   SDIO->DTIMER = SDIO_DataInitStruct->SDIO_DataTimeOut; | ||||
| 
 | ||||
| /*---------------------------- SDIO DLEN Configuration -----------------------*/ | ||||
|   /* Set the SDIO DataLength value */ | ||||
|   SDIO->DLEN = SDIO_DataInitStruct->SDIO_DataLength; | ||||
| 
 | ||||
| /*---------------------------- SDIO DCTRL Configuration ----------------------*/   | ||||
|   /* Get the SDIO DCTRL value */ | ||||
|   tmpreg = SDIO->DCTRL; | ||||
|   /* Clear DEN, DTMODE, DTDIR and DBCKSIZE bits */ | ||||
|   tmpreg &= DCTRL_CLEAR_MASK; | ||||
|   /* Set DEN bit according to SDIO_DPSM value */ | ||||
|   /* Set DTMODE bit according to SDIO_TransferMode value */ | ||||
|   /* Set DTDIR bit according to SDIO_TransferDir value */ | ||||
|   /* Set DBCKSIZE bits according to SDIO_DataBlockSize value */ | ||||
|   tmpreg |= (uint32_t)SDIO_DataInitStruct->SDIO_DataBlockSize | SDIO_DataInitStruct->SDIO_TransferDir | ||||
|            | SDIO_DataInitStruct->SDIO_TransferMode | SDIO_DataInitStruct->SDIO_DPSM; | ||||
| 
 | ||||
|   /* Write to SDIO DCTRL */ | ||||
|   SDIO->DCTRL = tmpreg; | ||||
| } | ||||
| 
 | ||||
| /**
 | ||||
|   * @brief  Fills each SDIO_DataInitStruct member with its default value. | ||||
|   * @param  SDIO_DataInitStruct: pointer to an SDIO_DataInitTypeDef structure which | ||||
|   *   will be initialized. | ||||
|   * @retval None | ||||
|   */ | ||||
| void SDIO_DataStructInit(SDIO_DataInitTypeDef* SDIO_DataInitStruct) | ||||
| { | ||||
|   /* SDIO_DataInitStruct members default value */ | ||||
|   SDIO_DataInitStruct->SDIO_DataTimeOut = 0xFFFFFFFF; | ||||
|   SDIO_DataInitStruct->SDIO_DataLength = 0x00; | ||||
|   SDIO_DataInitStruct->SDIO_DataBlockSize = SDIO_DataBlockSize_1b; | ||||
|   SDIO_DataInitStruct->SDIO_TransferDir = SDIO_TransferDir_ToCard; | ||||
|   SDIO_DataInitStruct->SDIO_TransferMode = SDIO_TransferMode_Block;   | ||||
|   SDIO_DataInitStruct->SDIO_DPSM = SDIO_DPSM_Disable; | ||||
| } | ||||
| 
 | ||||
| /**
 | ||||
|   * @brief  Returns number of remaining data bytes to be transferred. | ||||
|   * @param  None | ||||
|   * @retval Number of remaining data bytes to be transferred | ||||
|   */ | ||||
| uint32_t SDIO_GetDataCounter(void) | ||||
| {  | ||||
|   return SDIO->DCOUNT; | ||||
| } | ||||
| 
 | ||||
| /**
 | ||||
|   * @brief  Read one data word from Rx FIFO. | ||||
|   * @param  None | ||||
|   * @retval Data received | ||||
|   */ | ||||
| uint32_t SDIO_ReadData(void) | ||||
| {  | ||||
|   return SDIO->FIFO; | ||||
| } | ||||
| 
 | ||||
| /**
 | ||||
|   * @brief  Write one data word to Tx FIFO. | ||||
|   * @param  Data: 32-bit data word to write. | ||||
|   * @retval None | ||||
|   */ | ||||
| void SDIO_WriteData(uint32_t Data) | ||||
| {  | ||||
|   SDIO->FIFO = Data; | ||||
| } | ||||
| 
 | ||||
| /**
 | ||||
|   * @brief  Returns the number of words left to be written to or read from FIFO.	 | ||||
|   * @param  None | ||||
|   * @retval Remaining number of words. | ||||
|   */ | ||||
| uint32_t SDIO_GetFIFOCount(void) | ||||
| {  | ||||
|   return SDIO->FIFOCNT; | ||||
| } | ||||
| 
 | ||||
| /**
 | ||||
|   * @} | ||||
|   */ | ||||
| 
 | ||||
| /** @defgroup SDIO_Group5 SDIO IO Cards mode management functions
 | ||||
|  *  @brief   SDIO IO Cards mode management functions | ||||
|  * | ||||
|  @verbatim | ||||
|   ============================================================================== | ||||
|               ##### SDIO IO Cards mode management functions ##### | ||||
|   ============================================================================== | ||||
|   [..] This section provide functions allowing to program and read the SDIO IO  | ||||
|        Cards. | ||||
| 
 | ||||
| @endverbatim | ||||
|   * @{ | ||||
|   */ | ||||
| 
 | ||||
| /**
 | ||||
|   * @brief  Starts the SD I/O Read Wait operation.	 | ||||
|   * @param  NewState: new state of the Start SDIO Read Wait operation.  | ||||
|   *   This parameter can be: ENABLE or DISABLE. | ||||
|   * @retval None | ||||
|   */ | ||||
| void SDIO_StartSDIOReadWait(FunctionalState NewState) | ||||
| {  | ||||
|   /* Check the parameters */ | ||||
|   assert_param(IS_FUNCTIONAL_STATE(NewState)); | ||||
|    | ||||
|   *(__IO uint32_t *) DCTRL_RWSTART_BB = (uint32_t) NewState; | ||||
| } | ||||
| 
 | ||||
| /**
 | ||||
|   * @brief  Stops the SD I/O Read Wait operation.	 | ||||
|   * @param  NewState: new state of the Stop SDIO Read Wait operation.  | ||||
|   *   This parameter can be: ENABLE or DISABLE. | ||||
|   * @retval None | ||||
|   */ | ||||
| void SDIO_StopSDIOReadWait(FunctionalState NewState) | ||||
| {  | ||||
|   /* Check the parameters */ | ||||
|   assert_param(IS_FUNCTIONAL_STATE(NewState)); | ||||
|    | ||||
|   *(__IO uint32_t *) DCTRL_RWSTOP_BB = (uint32_t) NewState; | ||||
| } | ||||
| 
 | ||||
| /**
 | ||||
|   * @brief  Sets one of the two options of inserting read wait interval. | ||||
|   * @param  SDIO_ReadWaitMode: SD I/O Read Wait operation mode. | ||||
|   *   This parametre can be: | ||||
|   *     @arg SDIO_ReadWaitMode_CLK: Read Wait control by stopping SDIOCLK. | ||||
|   *     @arg SDIO_ReadWaitMode_DATA2: Read Wait control using SDIO_DATA2. | ||||
|   * @retval None | ||||
|   */ | ||||
| void SDIO_SetSDIOReadWaitMode(uint32_t SDIO_ReadWaitMode) | ||||
| { | ||||
|   /* Check the parameters */ | ||||
|   assert_param(IS_SDIO_READWAIT_MODE(SDIO_ReadWaitMode)); | ||||
|    | ||||
|   *(__IO uint32_t *) DCTRL_RWMOD_BB = SDIO_ReadWaitMode; | ||||
| } | ||||
| 
 | ||||
| /**
 | ||||
|   * @brief  Enables or disables the SD I/O Mode Operation. | ||||
|   * @param  NewState: new state of SDIO specific operation.  | ||||
|   *   This parameter can be: ENABLE or DISABLE. | ||||
|   * @retval None | ||||
|   */ | ||||
| void SDIO_SetSDIOOperation(FunctionalState NewState) | ||||
| {  | ||||
|   /* Check the parameters */ | ||||
|   assert_param(IS_FUNCTIONAL_STATE(NewState)); | ||||
|    | ||||
|   *(__IO uint32_t *) DCTRL_SDIOEN_BB = (uint32_t)NewState; | ||||
| } | ||||
| 
 | ||||
| /**
 | ||||
|   * @brief  Enables or disables the SD I/O Mode suspend command sending. | ||||
|   * @param  NewState: new state of the SD I/O Mode suspend command. | ||||
|   *   This parameter can be: ENABLE or DISABLE. | ||||
|   * @retval None | ||||
|   */ | ||||
| void SDIO_SendSDIOSuspendCmd(FunctionalState NewState) | ||||
| {  | ||||
|   /* Check the parameters */ | ||||
|   assert_param(IS_FUNCTIONAL_STATE(NewState)); | ||||
|    | ||||
|   *(__IO uint32_t *) CMD_SDIOSUSPEND_BB = (uint32_t)NewState; | ||||
| } | ||||
| 
 | ||||
| /**
 | ||||
|   * @} | ||||
|   */ | ||||
| 
 | ||||
| /** @defgroup SDIO_Group6 CE-ATA mode management functions
 | ||||
|  *  @brief   CE-ATA mode management functions | ||||
|  * | ||||
|  @verbatim | ||||
|   ============================================================================== | ||||
|                     ##### CE-ATA mode management functions ##### | ||||
|   ============================================================================== | ||||
|   [..] This section provide functions allowing to program and read the CE-ATA  | ||||
|        card. | ||||
| 
 | ||||
| @endverbatim | ||||
|   * @{ | ||||
|   */ | ||||
| 
 | ||||
| /**
 | ||||
|   * @brief  Enables or disables the command completion signal. | ||||
|   * @param  NewState: new state of command completion signal.  | ||||
|   *   This parameter can be: ENABLE or DISABLE. | ||||
|   * @retval None | ||||
|   */ | ||||
| void SDIO_CommandCompletionCmd(FunctionalState NewState) | ||||
| {  | ||||
|   /* Check the parameters */ | ||||
|   assert_param(IS_FUNCTIONAL_STATE(NewState)); | ||||
|    | ||||
|   *(__IO uint32_t *) CMD_ENCMDCOMPL_BB = (uint32_t)NewState; | ||||
| } | ||||
| 
 | ||||
| /**
 | ||||
|   * @brief  Enables or disables the CE-ATA interrupt. | ||||
|   * @param  NewState: new state of CE-ATA interrupt. This parameter can be: ENABLE or DISABLE. | ||||
|   * @retval None | ||||
|   */ | ||||
| void SDIO_CEATAITCmd(FunctionalState NewState) | ||||
| {  | ||||
|   /* Check the parameters */ | ||||
|   assert_param(IS_FUNCTIONAL_STATE(NewState)); | ||||
|    | ||||
|   *(__IO uint32_t *) CMD_NIEN_BB = (uint32_t)((~((uint32_t)NewState)) & ((uint32_t)0x1)); | ||||
| } | ||||
| 
 | ||||
| /**
 | ||||
|   * @brief  Sends CE-ATA command (CMD61). | ||||
|   * @param  NewState: new state of CE-ATA command. This parameter can be: ENABLE or DISABLE. | ||||
|   * @retval None | ||||
|   */ | ||||
| void SDIO_SendCEATACmd(FunctionalState NewState) | ||||
| {  | ||||
|   /* Check the parameters */ | ||||
|   assert_param(IS_FUNCTIONAL_STATE(NewState)); | ||||
|    | ||||
|   *(__IO uint32_t *) CMD_ATACMD_BB = (uint32_t)NewState; | ||||
| } | ||||
| 
 | ||||
| /**
 | ||||
|   * @} | ||||
|   */ | ||||
| 
 | ||||
| /** @defgroup SDIO_Group7 Interrupts and flags management functions
 | ||||
|  *  @brief   Interrupts and flags management functions   | ||||
| 
 | ||||
| 
 | ||||
|  @verbatim | ||||
|   ============================================================================== | ||||
|               ##### Interrupts and flags management functions ##### | ||||
|   ============================================================================== | ||||
| 
 | ||||
|  @endverbatim | ||||
|   * @{ | ||||
|   */ | ||||
| 
 | ||||
| /**
 | ||||
|   * @brief  Enables or disables the SDIO interrupts. | ||||
|   * @param  SDIO_IT: specifies the SDIO interrupt sources to be enabled or disabled. | ||||
|   *   This parameter can be one or a combination of the following values: | ||||
|   *     @arg SDIO_IT_CCRCFAIL: Command response received (CRC check failed) interrupt. | ||||
|   *     @arg SDIO_IT_DCRCFAIL: Data block sent/received (CRC check failed) interrupt. | ||||
|   *     @arg SDIO_IT_CTIMEOUT: Command response timeout interrupt. | ||||
|   *     @arg SDIO_IT_DTIMEOUT: Data timeout interrupt. | ||||
|   *     @arg SDIO_IT_TXUNDERR: Transmit FIFO underrun error interrupt. | ||||
|   *     @arg SDIO_IT_RXOVERR:  Received FIFO overrun error interrupt. | ||||
|   *     @arg SDIO_IT_CMDREND:  Command response received (CRC check passed) interrupt. | ||||
|   *     @arg SDIO_IT_CMDSENT:  Command sent (no response required) interrupt. | ||||
|   *     @arg SDIO_IT_DATAEND:  Data end (data counter, SDIDCOUNT, is zero) interrupt. | ||||
|   *     @arg SDIO_IT_STBITERR: Start bit not detected on all data signals in wide  | ||||
|   *                            bus mode interrupt. | ||||
|   *     @arg SDIO_IT_DBCKEND:  Data block sent/received (CRC check passed) interrupt. | ||||
|   *     @arg SDIO_IT_CMDACT:   Command transfer in progress interrupt. | ||||
|   *     @arg SDIO_IT_TXACT:    Data transmit in progress interrupt. | ||||
|   *     @arg SDIO_IT_RXACT:    Data receive in progress interrupt. | ||||
|   *     @arg SDIO_IT_TXFIFOHE: Transmit FIFO Half Empty interrupt. | ||||
|   *     @arg SDIO_IT_RXFIFOHF: Receive FIFO Half Full interrupt. | ||||
|   *     @arg SDIO_IT_TXFIFOF:  Transmit FIFO full interrupt. | ||||
|   *     @arg SDIO_IT_RXFIFOF:  Receive FIFO full interrupt. | ||||
|   *     @arg SDIO_IT_TXFIFOE:  Transmit FIFO empty interrupt. | ||||
|   *     @arg SDIO_IT_RXFIFOE:  Receive FIFO empty interrupt. | ||||
|   *     @arg SDIO_IT_TXDAVL:   Data available in transmit FIFO interrupt. | ||||
|   *     @arg SDIO_IT_RXDAVL:   Data available in receive FIFO interrupt. | ||||
|   *     @arg SDIO_IT_SDIOIT:   SD I/O interrupt received interrupt. | ||||
|   *     @arg SDIO_IT_CEATAEND: CE-ATA command completion signal received for CMD61 interrupt. | ||||
|   * @param  NewState: new state of the specified SDIO interrupts. | ||||
|   *   This parameter can be: ENABLE or DISABLE. | ||||
|   * @retval None  | ||||
|   */ | ||||
| void SDIO_ITConfig(uint32_t SDIO_IT, FunctionalState NewState) | ||||
| { | ||||
|   /* Check the parameters */ | ||||
|   assert_param(IS_SDIO_IT(SDIO_IT)); | ||||
|   assert_param(IS_FUNCTIONAL_STATE(NewState)); | ||||
|    | ||||
|   if (NewState != DISABLE) | ||||
|   { | ||||
|     /* Enable the SDIO interrupts */ | ||||
|     SDIO->MASK |= SDIO_IT; | ||||
|   } | ||||
|   else | ||||
|   { | ||||
|     /* Disable the SDIO interrupts */ | ||||
|     SDIO->MASK &= ~SDIO_IT; | ||||
|   }  | ||||
| } | ||||
| 
 | ||||
| /**
 | ||||
|   * @brief  Checks whether the specified SDIO flag is set or not. | ||||
|   * @param  SDIO_FLAG: specifies the flag to check.  | ||||
|   *   This parameter can be one of the following values: | ||||
|   *     @arg SDIO_FLAG_CCRCFAIL: Command response received (CRC check failed). | ||||
|   *     @arg SDIO_FLAG_DCRCFAIL: Data block sent/received (CRC check failed). | ||||
|   *     @arg SDIO_FLAG_CTIMEOUT: Command response timeout. | ||||
|   *     @arg SDIO_FLAG_DTIMEOUT: Data timeout. | ||||
|   *     @arg SDIO_FLAG_TXUNDERR: Transmit FIFO underrun error. | ||||
|   *     @arg SDIO_FLAG_RXOVERR:  Received FIFO overrun error. | ||||
|   *     @arg SDIO_FLAG_CMDREND:  Command response received (CRC check passed). | ||||
|   *     @arg SDIO_FLAG_CMDSENT:  Command sent (no response required). | ||||
|   *     @arg SDIO_FLAG_DATAEND:  Data end (data counter, SDIDCOUNT, is zero). | ||||
|   *     @arg SDIO_FLAG_STBITERR: Start bit not detected on all data signals in wide  | ||||
|   *                              bus mode. | ||||
|   *     @arg SDIO_FLAG_DBCKEND:  Data block sent/received (CRC check passed). | ||||
|   *     @arg SDIO_FLAG_CMDACT:   Command transfer in progress. | ||||
|   *     @arg SDIO_FLAG_TXACT:    Data transmit in progress. | ||||
|   *     @arg SDIO_FLAG_RXACT:    Data receive in progress. | ||||
|   *     @arg SDIO_FLAG_TXFIFOHE: Transmit FIFO Half Empty. | ||||
|   *     @arg SDIO_FLAG_RXFIFOHF: Receive FIFO Half Full. | ||||
|   *     @arg SDIO_FLAG_TXFIFOF:  Transmit FIFO full. | ||||
|   *     @arg SDIO_FLAG_RXFIFOF:  Receive FIFO full. | ||||
|   *     @arg SDIO_FLAG_TXFIFOE:  Transmit FIFO empty. | ||||
|   *     @arg SDIO_FLAG_RXFIFOE:  Receive FIFO empty. | ||||
|   *     @arg SDIO_FLAG_TXDAVL:   Data available in transmit FIFO. | ||||
|   *     @arg SDIO_FLAG_RXDAVL:   Data available in receive FIFO. | ||||
|   *     @arg SDIO_FLAG_SDIOIT:   SD I/O interrupt received. | ||||
|   *     @arg SDIO_FLAG_CEATAEND: CE-ATA command completion signal received for CMD61. | ||||
|   * @retval The new state of SDIO_FLAG (SET or RESET). | ||||
|   */ | ||||
| FlagStatus SDIO_GetFlagStatus(uint32_t SDIO_FLAG) | ||||
| {  | ||||
|   FlagStatus bitstatus = RESET; | ||||
|    | ||||
|   /* Check the parameters */ | ||||
|   assert_param(IS_SDIO_FLAG(SDIO_FLAG)); | ||||
|    | ||||
|   if ((SDIO->STA & SDIO_FLAG) != (uint32_t)RESET) | ||||
|   { | ||||
|     bitstatus = SET; | ||||
|   } | ||||
|   else | ||||
|   { | ||||
|     bitstatus = RESET; | ||||
|   } | ||||
|   return bitstatus; | ||||
| } | ||||
| 
 | ||||
| /**
 | ||||
|   * @brief  Clears the SDIO's pending flags. | ||||
|   * @param  SDIO_FLAG: specifies the flag to clear.   | ||||
|   *   This parameter can be one or a combination of the following values: | ||||
|   *     @arg SDIO_FLAG_CCRCFAIL: Command response received (CRC check failed). | ||||
|   *     @arg SDIO_FLAG_DCRCFAIL: Data block sent/received (CRC check failed). | ||||
|   *     @arg SDIO_FLAG_CTIMEOUT: Command response timeout. | ||||
|   *     @arg SDIO_FLAG_DTIMEOUT: Data timeout. | ||||
|   *     @arg SDIO_FLAG_TXUNDERR: Transmit FIFO underrun error. | ||||
|   *     @arg SDIO_FLAG_RXOVERR:  Received FIFO overrun error. | ||||
|   *     @arg SDIO_FLAG_CMDREND:  Command response received (CRC check passed). | ||||
|   *     @arg SDIO_FLAG_CMDSENT:  Command sent (no response required). | ||||
|   *     @arg SDIO_FLAG_DATAEND:  Data end (data counter, SDIDCOUNT, is zero). | ||||
|   *     @arg SDIO_FLAG_STBITERR: Start bit not detected on all data signals in wide  | ||||
|   *                              bus mode. | ||||
|   *     @arg SDIO_FLAG_DBCKEND:  Data block sent/received (CRC check passed). | ||||
|   *     @arg SDIO_FLAG_SDIOIT:   SD I/O interrupt received. | ||||
|   *     @arg SDIO_FLAG_CEATAEND: CE-ATA command completion signal received for CMD61. | ||||
|   * @retval None | ||||
|   */ | ||||
| void SDIO_ClearFlag(uint32_t SDIO_FLAG) | ||||
| {  | ||||
|   /* Check the parameters */ | ||||
|   assert_param(IS_SDIO_CLEAR_FLAG(SDIO_FLAG)); | ||||
|     | ||||
|   SDIO->ICR = SDIO_FLAG; | ||||
| } | ||||
| 
 | ||||
| /**
 | ||||
|   * @brief  Checks whether the specified SDIO interrupt has occurred or not. | ||||
|   * @param  SDIO_IT: specifies the SDIO interrupt source to check.  | ||||
|   *   This parameter can be one of the following values: | ||||
|   *     @arg SDIO_IT_CCRCFAIL: Command response received (CRC check failed) interrupt. | ||||
|   *     @arg SDIO_IT_DCRCFAIL: Data block sent/received (CRC check failed) interrupt. | ||||
|   *     @arg SDIO_IT_CTIMEOUT: Command response timeout interrupt. | ||||
|   *     @arg SDIO_IT_DTIMEOUT: Data timeout interrupt. | ||||
|   *     @arg SDIO_IT_TXUNDERR: Transmit FIFO underrun error interrupt. | ||||
|   *     @arg SDIO_IT_RXOVERR:  Received FIFO overrun error interrupt. | ||||
|   *     @arg SDIO_IT_CMDREND:  Command response received (CRC check passed) interrupt. | ||||
|   *     @arg SDIO_IT_CMDSENT:  Command sent (no response required) interrupt. | ||||
|   *     @arg SDIO_IT_DATAEND:  Data end (data counter, SDIDCOUNT, is zero) interrupt. | ||||
|   *     @arg SDIO_IT_STBITERR: Start bit not detected on all data signals in wide  | ||||
|   *                            bus mode interrupt. | ||||
|   *     @arg SDIO_IT_DBCKEND:  Data block sent/received (CRC check passed) interrupt. | ||||
|   *     @arg SDIO_IT_CMDACT:   Command transfer in progress interrupt. | ||||
|   *     @arg SDIO_IT_TXACT:    Data transmit in progress interrupt. | ||||
|   *     @arg SDIO_IT_RXACT:    Data receive in progress interrupt. | ||||
|   *     @arg SDIO_IT_TXFIFOHE: Transmit FIFO Half Empty interrupt. | ||||
|   *     @arg SDIO_IT_RXFIFOHF: Receive FIFO Half Full interrupt. | ||||
|   *     @arg SDIO_IT_TXFIFOF:  Transmit FIFO full interrupt. | ||||
|   *     @arg SDIO_IT_RXFIFOF:  Receive FIFO full interrupt. | ||||
|   *     @arg SDIO_IT_TXFIFOE:  Transmit FIFO empty interrupt. | ||||
|   *     @arg SDIO_IT_RXFIFOE:  Receive FIFO empty interrupt. | ||||
|   *     @arg SDIO_IT_TXDAVL:   Data available in transmit FIFO interrupt. | ||||
|   *     @arg SDIO_IT_RXDAVL:   Data available in receive FIFO interrupt. | ||||
|   *     @arg SDIO_IT_SDIOIT:   SD I/O interrupt received interrupt. | ||||
|   *     @arg SDIO_IT_CEATAEND: CE-ATA command completion signal received for CMD61 interrupt. | ||||
|   * @retval The new state of SDIO_IT (SET or RESET). | ||||
|   */ | ||||
| ITStatus SDIO_GetITStatus(uint32_t SDIO_IT) | ||||
| {  | ||||
|   ITStatus bitstatus = RESET; | ||||
|    | ||||
|   /* Check the parameters */ | ||||
|   assert_param(IS_SDIO_GET_IT(SDIO_IT)); | ||||
|   if ((SDIO->STA & SDIO_IT) != (uint32_t)RESET)   | ||||
|   { | ||||
|     bitstatus = SET; | ||||
|   } | ||||
|   else | ||||
|   { | ||||
|     bitstatus = RESET; | ||||
|   } | ||||
|   return bitstatus; | ||||
| } | ||||
| 
 | ||||
| /**
 | ||||
|   * @brief  Clears the SDIO's interrupt pending bits. | ||||
|   * @param  SDIO_IT: specifies the interrupt pending bit to clear.  | ||||
|   *   This parameter can be one or a combination of the following values: | ||||
|   *     @arg SDIO_IT_CCRCFAIL: Command response received (CRC check failed) interrupt. | ||||
|   *     @arg SDIO_IT_DCRCFAIL: Data block sent/received (CRC check failed) interrupt. | ||||
|   *     @arg SDIO_IT_CTIMEOUT: Command response timeout interrupt. | ||||
|   *     @arg SDIO_IT_DTIMEOUT: Data timeout interrupt. | ||||
|   *     @arg SDIO_IT_TXUNDERR: Transmit FIFO underrun error interrupt. | ||||
|   *     @arg SDIO_IT_RXOVERR:  Received FIFO overrun error interrupt. | ||||
|   *     @arg SDIO_IT_CMDREND:  Command response received (CRC check passed) interrupt. | ||||
|   *     @arg SDIO_IT_CMDSENT:  Command sent (no response required) interrupt. | ||||
|   *     @arg SDIO_IT_DATAEND:  Data end (data counter, SDIDCOUNT, is zero) interrupt. | ||||
|   *     @arg SDIO_IT_STBITERR: Start bit not detected on all data signals in wide  | ||||
|   *                            bus mode interrupt. | ||||
|   *     @arg SDIO_IT_SDIOIT:   SD I/O interrupt received interrupt. | ||||
|   *     @arg SDIO_IT_CEATAEND: CE-ATA command completion signal received for CMD61. | ||||
|   * @retval None | ||||
|   */ | ||||
| void SDIO_ClearITPendingBit(uint32_t SDIO_IT) | ||||
| {  | ||||
|   /* Check the parameters */ | ||||
|   assert_param(IS_SDIO_CLEAR_IT(SDIO_IT)); | ||||
|     | ||||
|   SDIO->ICR = SDIO_IT; | ||||
| } | ||||
| 
 | ||||
| /**
 | ||||
|   * @} | ||||
|   */ | ||||
| 
 | ||||
| /**
 | ||||
|   * @} | ||||
|   */ | ||||
| 
 | ||||
| /**
 | ||||
|   * @} | ||||
|   */ | ||||
| 
 | ||||
| /************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE****/ | ||||
										
											
												File diff suppressed because it is too large
												Load diff
											
										
									
								
							
										
											
												File diff suppressed because it is too large
												Load diff
											
										
									
								
							|  | @ -1,313 +0,0 @@ | |||
| /**
 | ||||
|   ****************************************************************************** | ||||
|   * @file    stm32l1xx_wwdg.c | ||||
|   * @author  MCD Application Team | ||||
|   * @version V1.1.1 | ||||
|   * @date    05-March-2012 | ||||
|   * @brief   This file provides firmware functions to manage the following  | ||||
|   *          functionalities of the Window watchdog (WWDG) peripheral:            | ||||
|   *           + Prescaler, Refresh window and Counter configuration | ||||
|   *           + WWDG activation | ||||
|   *           + Interrupts and flags management | ||||
|   *              | ||||
|   *  @verbatim | ||||
|   *     | ||||
|   ==============================================================================  | ||||
|                            ##### WWDG features #####  | ||||
|   ==============================================================================  | ||||
|     [..] Once enabled the WWDG generates a system reset on expiry of a programmed | ||||
|         time period, unless the program refreshes the counter (downcounter)  | ||||
|         before to reach 0x3F value (i.e. a reset is generated when the counter | ||||
|         value rolls over from 0x40 to 0x3F).  | ||||
|     [..] An MCU reset is also generated if the counter value is refreshed | ||||
|          before the counter has reached the refresh window value. This  | ||||
|          implies that the counter must be refreshed in a limited window. | ||||
| 
 | ||||
|     [..] Once enabled the WWDG cannot be disabled except by a system reset. | ||||
| 
 | ||||
|     [..] WWDGRST flag in RCC_CSR register can be used to inform when a WWDG | ||||
|          reset occurs. | ||||
| 
 | ||||
|     [..] The WWDG counter input clock is derived from the APB clock divided  | ||||
|          by a programmable prescaler. | ||||
| 
 | ||||
|     [..] WWDG counter clock = PCLK1 / Prescaler. | ||||
|     [..] WWDG timeout = (WWDG counter clock) * (counter value). | ||||
| 
 | ||||
|     [..] Min-max timeout value @32MHz (PCLK1): ~128us / ~65.6ms. | ||||
| 
 | ||||
|                        ##### How to use this driver #####  | ||||
|   ============================================================================== | ||||
|     [..] | ||||
|         (#) Enable WWDG clock using RCC_APB1PeriphClockCmd(RCC_APB1Periph_WWDG, ENABLE)  | ||||
|             function. | ||||
|                | ||||
|         (#) Configure the WWDG prescaler using WWDG_SetPrescaler() function. | ||||
|                               | ||||
|         (#) Configure the WWDG refresh window using WWDG_SetWindowValue() function. | ||||
|                | ||||
|         (#) Set the WWDG counter value and start it using WWDG_Enable() function. | ||||
|             When the WWDG is enabled the counter value should be configured to  | ||||
|             a value greater than 0x40 to prevent generating an immediate reset. | ||||
|                | ||||
|         (#) Optionally you can enable the Early wakeup interrupt which is  | ||||
|             generated when the counter reach 0x40. | ||||
|             Once enabled this interrupt cannot be disabled except by a system reset. | ||||
|                     | ||||
|         (#) Then the application program must refresh the WWDG counter at regular | ||||
|             intervals during normal operation to prevent an MCU reset, using | ||||
|             WWDG_SetCounter() function. This operation must occur only when | ||||
|             the counter value is lower than the refresh window value,  | ||||
|             programmed using WWDG_SetWindowValue(). | ||||
|    | ||||
|   *  @endverbatim   | ||||
|   *                              | ||||
|   ****************************************************************************** | ||||
|   * @attention | ||||
|   * | ||||
|   * <h2><center>© COPYRIGHT 2012 STMicroelectronics</center></h2> | ||||
|   * | ||||
|   * Licensed under MCD-ST Liberty SW License Agreement V2, (the "License"); | ||||
|   * You may not use this file except in compliance with the License. | ||||
|   * You may obtain a copy of the License at: | ||||
|   * | ||||
|   *        http://www.st.com/software_license_agreement_liberty_v2
 | ||||
|   * | ||||
|   * Unless required by applicable law or agreed to in writing, software  | ||||
|   * distributed under the License is distributed on an "AS IS" BASIS,  | ||||
|   * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. | ||||
|   * See the License for the specific language governing permissions and | ||||
|   * limitations under the License. | ||||
|   * | ||||
|   ****************************************************************************** | ||||
|   */ | ||||
| 
 | ||||
| /* Includes ------------------------------------------------------------------*/ | ||||
| #include "stm32l1xx_wwdg.h" | ||||
| #include "stm32l1xx_rcc.h" | ||||
| 
 | ||||
| /** @addtogroup STM32L1xx_StdPeriph_Driver
 | ||||
|   * @{ | ||||
|   */ | ||||
| 
 | ||||
| /** @defgroup WWDG 
 | ||||
|   * @brief WWDG driver modules | ||||
|   * @{ | ||||
|   */ | ||||
| 
 | ||||
| /* Private typedef -----------------------------------------------------------*/ | ||||
| /* Private define ------------------------------------------------------------*/ | ||||
| 
 | ||||
| /* ----------- WWDG registers bit address in the alias region ----------- */ | ||||
| #define WWDG_OFFSET       (WWDG_BASE - PERIPH_BASE) | ||||
| 
 | ||||
| /* Alias word address of EWI bit */ | ||||
| #define CFR_OFFSET        (WWDG_OFFSET + 0x04) | ||||
| #define EWI_BitNumber     0x09 | ||||
| #define CFR_EWI_BB        (PERIPH_BB_BASE + (CFR_OFFSET * 32) + (EWI_BitNumber * 4)) | ||||
| 
 | ||||
| /* --------------------- WWDG registers bit mask ------------------------ */ | ||||
| 
 | ||||
| /* CFR register bit mask */ | ||||
| #define CFR_WDGTB_MASK    ((uint32_t)0xFFFFFE7F) | ||||
| #define CFR_W_MASK        ((uint32_t)0xFFFFFF80) | ||||
| #define BIT_MASK          ((uint8_t)0x7F) | ||||
| 
 | ||||
| /* Private macro -------------------------------------------------------------*/ | ||||
| /* Private variables ---------------------------------------------------------*/ | ||||
| /* Private function prototypes -----------------------------------------------*/ | ||||
| /* Private functions ---------------------------------------------------------*/ | ||||
| 
 | ||||
| /** @defgroup WWDG_Private_Functions
 | ||||
|   * @{ | ||||
|   */ | ||||
| 
 | ||||
| /** @defgroup WWDG_Group1 Prescaler, Refresh window and Counter configuration functions
 | ||||
|  *  @brief   Prescaler, Refresh window and Counter configuration functions  | ||||
|  * | ||||
| @verbatim    | ||||
|   ============================================================================== | ||||
|     ##### Prescaler, Refresh window and Counter configuration functions ##### | ||||
|   ==============================================================================   | ||||
| 
 | ||||
| @endverbatim | ||||
|   * @{ | ||||
|   */ | ||||
| 
 | ||||
| /**
 | ||||
|   * @brief  Deinitializes the WWDG peripheral registers to their default reset values. | ||||
|   * @param  None | ||||
|   * @retval None | ||||
|   */ | ||||
| void WWDG_DeInit(void) | ||||
| { | ||||
|   RCC_APB1PeriphResetCmd(RCC_APB1Periph_WWDG, ENABLE); | ||||
|   RCC_APB1PeriphResetCmd(RCC_APB1Periph_WWDG, DISABLE); | ||||
| } | ||||
| 
 | ||||
| /**
 | ||||
|   * @brief  Sets the WWDG Prescaler. | ||||
|   * @param  WWDG_Prescaler: specifies the WWDG Prescaler. | ||||
|   *   This parameter can be one of the following values: | ||||
|   *     @arg WWDG_Prescaler_1: WWDG counter clock = (PCLK1/4096)/1 | ||||
|   *     @arg WWDG_Prescaler_2: WWDG counter clock = (PCLK1/4096)/2 | ||||
|   *     @arg WWDG_Prescaler_4: WWDG counter clock = (PCLK1/4096)/4 | ||||
|   *     @arg WWDG_Prescaler_8: WWDG counter clock = (PCLK1/4096)/8 | ||||
|   * @retval None | ||||
|   */ | ||||
| void WWDG_SetPrescaler(uint32_t WWDG_Prescaler) | ||||
| { | ||||
|   uint32_t tmpreg = 0; | ||||
|   /* Check the parameters */ | ||||
|   assert_param(IS_WWDG_PRESCALER(WWDG_Prescaler)); | ||||
|   /* Clear WDGTB[1:0] bits */ | ||||
|   tmpreg = WWDG->CFR & CFR_WDGTB_MASK; | ||||
|   /* Set WDGTB[1:0] bits according to WWDG_Prescaler value */ | ||||
|   tmpreg |= WWDG_Prescaler; | ||||
|   /* Store the new value */ | ||||
|   WWDG->CFR = tmpreg; | ||||
| } | ||||
| 
 | ||||
| /**
 | ||||
|   * @brief  Sets the WWDG window value. | ||||
|   * @param  WindowValue: specifies the window value to be compared to the downcounter. | ||||
|   *   This parameter value must be lower than 0x80. | ||||
|   * @retval None | ||||
|   */ | ||||
| void WWDG_SetWindowValue(uint8_t WindowValue) | ||||
| { | ||||
|   __IO uint32_t tmpreg = 0; | ||||
| 
 | ||||
|   /* Check the parameters */ | ||||
|   assert_param(IS_WWDG_WINDOW_VALUE(WindowValue)); | ||||
|   /* Clear W[6:0] bits */ | ||||
| 
 | ||||
|   tmpreg = WWDG->CFR & CFR_W_MASK; | ||||
| 
 | ||||
|   /* Set W[6:0] bits according to WindowValue value */ | ||||
|   tmpreg |= WindowValue & (uint32_t) BIT_MASK; | ||||
| 
 | ||||
|   /* Store the new value */ | ||||
|   WWDG->CFR = tmpreg; | ||||
| } | ||||
| 
 | ||||
| /**
 | ||||
|   * @brief  Enables the WWDG Early Wakeup interrupt(EWI). | ||||
|   * @note   Once enabled this interrupt cannot be disabled except by a system reset.  | ||||
|   * @param  None | ||||
|   * @retval None | ||||
|   */ | ||||
| void WWDG_EnableIT(void) | ||||
| { | ||||
|   *(__IO uint32_t *) CFR_EWI_BB = (uint32_t)ENABLE; | ||||
| } | ||||
| 
 | ||||
| /**
 | ||||
|   * @brief  Sets the WWDG counter value. | ||||
|   * @param  Counter: specifies the watchdog counter value. | ||||
|   *   This parameter must be a number between 0x40 and 0x7F (to prevent generating | ||||
|   *   an immediate reset). | ||||
|   * @retval None | ||||
|   */ | ||||
| void WWDG_SetCounter(uint8_t Counter) | ||||
| { | ||||
|   /* Check the parameters */ | ||||
|   assert_param(IS_WWDG_COUNTER(Counter)); | ||||
|   /* Write to T[6:0] bits to configure the counter value, no need to do
 | ||||
|      a read-modify-write; writing a 0 to WDGA bit does nothing */ | ||||
|   WWDG->CR = Counter & BIT_MASK; | ||||
| } | ||||
| 
 | ||||
| /**
 | ||||
|   * @} | ||||
|   */ | ||||
| 
 | ||||
| /** @defgroup WWDG_Group2 WWDG activation functions
 | ||||
|  *  @brief   WWDG activation functions  | ||||
|  * | ||||
| @verbatim    | ||||
|   ============================================================================== | ||||
|                      ##### WWDG activation function ##### | ||||
|   ==============================================================================   | ||||
| 
 | ||||
| @endverbatim | ||||
|   * @{ | ||||
|   */ | ||||
| 
 | ||||
| /**
 | ||||
|   * @brief  Enables WWDG and load the counter value.                   | ||||
|   * @param  Counter: specifies the watchdog counter value. | ||||
|   *   This parameter must be a number between 0x40 and 0x7F (to prevent generating | ||||
|   *   an immediate reset). | ||||
|   * @retval None | ||||
|   */ | ||||
| void WWDG_Enable(uint8_t Counter) | ||||
| { | ||||
|   /* Check the parameters */ | ||||
|   assert_param(IS_WWDG_COUNTER(Counter)); | ||||
|   WWDG->CR = WWDG_CR_WDGA | Counter; | ||||
| } | ||||
| 
 | ||||
| /**
 | ||||
|   * @} | ||||
|   */ | ||||
| 
 | ||||
| /** @defgroup WWDG_Group3 Interrupts and flags management functions
 | ||||
|  *  @brief   Interrupts and flags management functions  | ||||
|  * | ||||
| @verbatim    | ||||
|   ============================================================================== | ||||
|                 ##### Interrupts and flags management functions ##### | ||||
|   ==============================================================================   | ||||
| 
 | ||||
| @endverbatim | ||||
|   * @{ | ||||
|   */ | ||||
| 
 | ||||
| /**
 | ||||
|   * @brief  Checks whether the Early Wakeup interrupt flag is set or not. | ||||
|   * @param  None | ||||
|   * @retval The new state of the Early Wakeup interrupt flag (SET or RESET). | ||||
|   */ | ||||
| FlagStatus WWDG_GetFlagStatus(void) | ||||
| { | ||||
|   FlagStatus bitstatus = RESET; | ||||
|      | ||||
|   if ((WWDG->SR) != (uint32_t)RESET) | ||||
|   { | ||||
|     bitstatus = SET; | ||||
|   } | ||||
|   else | ||||
|   { | ||||
|     bitstatus = RESET; | ||||
|   } | ||||
|   return bitstatus; | ||||
| } | ||||
| 
 | ||||
| /**
 | ||||
|   * @brief  Clears Early Wakeup interrupt flag. | ||||
|   * @param  None | ||||
|   * @retval None | ||||
|   */ | ||||
| void WWDG_ClearFlag(void) | ||||
| { | ||||
|   WWDG->SR = (uint32_t)RESET; | ||||
| } | ||||
| 
 | ||||
| /**
 | ||||
|   * @} | ||||
|   */ | ||||
| 
 | ||||
| /**
 | ||||
|   * @} | ||||
|   */ | ||||
| 
 | ||||
| /**
 | ||||
|   * @} | ||||
|   */ | ||||
| 
 | ||||
| /**
 | ||||
|   * @} | ||||
|   */ | ||||
| 
 | ||||
| /************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE****/ | ||||
|  | @ -1,60 +0,0 @@ | |||
|  /**
 | ||||
|   ****************************************************************************** | ||||
|   * @file    discover_board.h | ||||
|   * @author  Microcontroller Division | ||||
|   * @version V1.0.3 | ||||
|   * @date    May-2013 | ||||
|   * @brief   Input/Output defines | ||||
|   ****************************************************************************** | ||||
|   * @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>© COPYRIGHT 2011 STMicroelectronics</center></h2> | ||||
|   */ | ||||
| 
 | ||||
| /* Define to prevent recursive inclusion -------------------------------------*/ | ||||
| 
 | ||||
| #ifndef __DISCOVER_BOARD_H | ||||
| #define __DISCOVER_BOARD_H | ||||
| 
 | ||||
| /* Includes ------------------------------------------------------------------*/ | ||||
| #include "stm32l1xx.h"   | ||||
| 
 | ||||
| #define bool _Bool | ||||
| #define FALSE 0 | ||||
| #define TRUE !FALSE | ||||
| 
 | ||||
| /* MACROs for SET, RESET or TOGGLE Output port */ | ||||
| 
 | ||||
| #define GPIO_HIGH(a,b) 		a->BSRRL = b | ||||
| #define GPIO_LOW(a,b)		a->BSRRH = b | ||||
| #define GPIO_TOGGLE(a,b) 	a->ODR ^= b  | ||||
| 
 | ||||
| #define USERBUTTON_GPIO_PORT	GPIOA | ||||
| #define USERBUTTON_GPIO_PIN     GPIO_Pin_0 | ||||
| #define USERBUTTON_GPIO_CLK     RCC_AHBPeriph_GPIOA | ||||
| 
 | ||||
| #define LD_GPIO_PORT 		GPIOB | ||||
| #define LD_GREEN_GPIO_PIN 		GPIO_Pin_7 | ||||
| #define LD_BLUE_GPIO_PIN             GPIO_Pin_6 | ||||
| #define LD_GPIO_PORT_CLK             RCC_AHBPeriph_GPIOB | ||||
| 
 | ||||
| #define CTN_GPIO_PORT           GPIOC | ||||
| #define CTN_CNTEN_GPIO_PIN      GPIO_Pin_13 | ||||
| #define CTN_GPIO_CLK            RCC_AHBPeriph_GPIOC | ||||
| 
 | ||||
| #define WAKEUP_GPIO_PORT        GPIOA | ||||
| 
 | ||||
| #define IDD_MEASURE_PORT	GPIOA | ||||
| #define IDD_MEASURE             GPIO_Pin_4 | ||||
| 
 | ||||
| #endif | ||||
| 
 | ||||
| 
 | ||||
| /******************* (C) COPYRIGHT 2011 STMicroelectronics *****END OF FILE****/ | ||||
|  | @ -1,611 +0,0 @@ | |||
| /**
 | ||||
|   ****************************************************************************** | ||||
|   * @file    stm32l_discovery_lcd.c | ||||
|   * @author  Microcontroller Division | ||||
|   * @version V1.0.3 | ||||
|   * @date    May-2013 | ||||
|   * @brief   This file includes driver for the glass LCD Module mounted on  | ||||
|   *          STM32l discovery board MB963 | ||||
|   ****************************************************************************** | ||||
|   * @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>© COPYRIGHT 2011 STMicroelectronics</center></h2> | ||||
|   */  | ||||
| 
 | ||||
| /* Includes ------------------------------------------------------------------*/ | ||||
| #include "stm32l_discovery_lcd.h" | ||||
| #include "discover_board.h" | ||||
| #include "stm32l1xx_lcd.h" | ||||
| #include "main.h" | ||||
| 
 | ||||
| /* this variable can be used for accelerate the scrolling exit when push user button */ | ||||
| volatile bool KeyPressed = FALSE;  | ||||
| 		 | ||||
| /* LCD BAR status: We don't write directly in LCD RAM for save the bar setting */ | ||||
| uint8_t t_bar[2]={0x0,0X0}; | ||||
| 		 | ||||
| /*  =========================================================================
 | ||||
|                                  LCD MAPPING | ||||
|     ========================================================================= | ||||
| 	    A | ||||
|      _  ---------- | ||||
| COL |_| |\   |J  /| | ||||
|        F| H  |  K |B | ||||
|      _  |  \ | /  | | ||||
| COL |_| --G-- --M-- | ||||
|         |   /| \  | | ||||
|        E|  Q |  N |C | ||||
|      _  | /  |P  \|    | ||||
| DP  |_| -----------   | ||||
| 	    D          | ||||
| 
 | ||||
|  An LCD character coding is based on the following matrix: | ||||
|       { E , D , P , N   } | ||||
|       { M , C , COL , DP} | ||||
|       { B , A , K , J   } | ||||
|       { G , F , Q , H   } | ||||
| 
 | ||||
|  The character 'A' for example is: | ||||
|   ------------------------------- | ||||
| LSB   { 1 , 0 , 0 , 0   } | ||||
|       { 1 , 1 , 0 , 0   } | ||||
|       { 1 , 1 , 0 , 0   } | ||||
| MSB   { 1 , 1 , 0 , 0   } | ||||
|       ------------------- | ||||
|   'A' =  F    E   0   0 hexa | ||||
| 
 | ||||
| */ | ||||
| 
 | ||||
| /* Constant table for cap characters 'A' --> 'Z' */ | ||||
| const uint16_t CapLetterMap[26]= | ||||
|     { | ||||
|         /* A      B      C      D      E      F      G      H      I  */ | ||||
|         0xFE00,0x6714,0x1d00,0x4714,0x9d00,0x9c00,0x3f00,0xfa00,0x0014, | ||||
|         /* J      K      L      M      N      O      P      Q      R  */ | ||||
|         0x5300,0x9841,0x1900,0x5a48,0x5a09,0x5f00,0xFC00,0x5F01,0xFC01, | ||||
|         /* S      T      U      V      W      X      Y      Z  */ | ||||
|         0xAF00,0x0414,0x5b00,0x18c0,0x5a81,0x00c9,0x0058,0x05c0 | ||||
|     }; | ||||
| 
 | ||||
| /* Constant table for number '0' --> '9' */ | ||||
| const uint16_t NumberMap[10]= | ||||
|     { | ||||
|         /* 0      1      2      3      4      5      6      7      8      9  */ | ||||
|         0x5F00,0x4200,0xF500,0x6700,0xEa00,0xAF00,0xBF00,0x04600,0xFF00,0xEF00 | ||||
|     }; | ||||
| 
 | ||||
| static void LCD_Conv_Char_Seg(uint8_t* c,bool point,bool column,uint8_t* digit); | ||||
| 
 | ||||
| /**
 | ||||
|   * @brief  Configures the LCD GLASS relative GPIO port IOs and LCD peripheral. | ||||
|   * @param  None | ||||
|   * @retval None | ||||
|   */ | ||||
| void LCD_GLASS_Init(void) | ||||
| { | ||||
|   LCD_InitTypeDef LCD_InitStruct; | ||||
| 
 | ||||
|   | ||||
|   LCD_InitStruct.LCD_Prescaler = LCD_Prescaler_1; | ||||
|   LCD_InitStruct.LCD_Divider = LCD_Divider_31; | ||||
|   LCD_InitStruct.LCD_Duty = LCD_Duty_1_4; | ||||
|   LCD_InitStruct.LCD_Bias = LCD_Bias_1_3; | ||||
|   LCD_InitStruct.LCD_VoltageSource = LCD_VoltageSource_Internal; | ||||
| 
 | ||||
|   | ||||
|   /* Initialize the LCD */ | ||||
|   LCD_Init(&LCD_InitStruct); | ||||
|    | ||||
|   LCD_MuxSegmentCmd(ENABLE); | ||||
|    | ||||
|   /* To set contrast to mean value */ | ||||
|   LCD_ContrastConfig(LCD_Contrast_Level_4); | ||||
|    | ||||
|   LCD_DeadTimeConfig(LCD_DeadTime_0); | ||||
|   LCD_PulseOnDurationConfig(LCD_PulseOnDuration_4); | ||||
| 
 | ||||
|   /* Wait Until the LCD FCR register is synchronized */ | ||||
|   LCD_WaitForSynchro(); | ||||
|    | ||||
|   /* Enable LCD peripheral */ | ||||
|   LCD_Cmd(ENABLE); | ||||
|    | ||||
|   /* Wait Until the LCD is enabled */ | ||||
|   while(LCD_GetFlagStatus(LCD_FLAG_ENS) == RESET) | ||||
|   { | ||||
|   } | ||||
|   /*!< Wait Until the LCD Booster is ready */   | ||||
|   while(LCD_GetFlagStatus(LCD_FLAG_RDY) == RESET) | ||||
|   { | ||||
|   }  | ||||
| 
 | ||||
|   LCD_BlinkConfig(LCD_BlinkMode_Off,LCD_BlinkFrequency_Div32);	   | ||||
|   LCD_GLASS_Clear(); | ||||
| } | ||||
| 
 | ||||
| /**
 | ||||
|   * @brief  To initialize the LCD pins | ||||
|   * @caller main | ||||
|   * @param None | ||||
|   * @retval None | ||||
|   */ | ||||
| 
 | ||||
| void LCD_GLASS_Configure_GPIO(void) | ||||
| { | ||||
|   GPIO_InitTypeDef GPIO_InitStructure; | ||||
|    | ||||
| /* Enable GPIOs clock */ 	 | ||||
|   RCC_AHBPeriphClockCmd(RCC_AHBPeriph_GPIOA | RCC_AHBPeriph_GPIOB | RCC_AHBPeriph_GPIOC | | ||||
|                         RCC_AHBPeriph_GPIOD | RCC_AHBPeriph_GPIOE | RCC_AHBPeriph_GPIOH, ENABLE); | ||||
| 
 | ||||
|    | ||||
| /* Configure Output for LCD */ | ||||
| /* Port A */ | ||||
|   GPIO_StructInit(&GPIO_InitStructure); | ||||
|   GPIO_InitStructure.GPIO_Pin = GPIO_Pin_1 | GPIO_Pin_2 | GPIO_Pin_3 | GPIO_Pin_8 | GPIO_Pin_9 |GPIO_Pin_10 |GPIO_Pin_15; | ||||
|   GPIO_InitStructure.GPIO_Mode = GPIO_Mode_AF; | ||||
|   GPIO_Init( GPIOA, &GPIO_InitStructure); | ||||
| 
 | ||||
|   GPIO_PinAFConfig(GPIOA, GPIO_PinSource1,GPIO_AF_LCD) ; | ||||
|   GPIO_PinAFConfig(GPIOA, GPIO_PinSource2,GPIO_AF_LCD) ; | ||||
|   GPIO_PinAFConfig(GPIOA, GPIO_PinSource3,GPIO_AF_LCD) ; | ||||
|   GPIO_PinAFConfig(GPIOA, GPIO_PinSource8,GPIO_AF_LCD) ; | ||||
|   GPIO_PinAFConfig(GPIOA, GPIO_PinSource9,GPIO_AF_LCD) ; | ||||
|   GPIO_PinAFConfig(GPIOA, GPIO_PinSource10,GPIO_AF_LCD) ; | ||||
|   GPIO_PinAFConfig(GPIOA, GPIO_PinSource15,GPIO_AF_LCD) ;   | ||||
|    | ||||
| /* Configure Output for LCD */ | ||||
| /* Port B */   | ||||
|   GPIO_InitStructure.GPIO_Pin = GPIO_Pin_3 | GPIO_Pin_4 | GPIO_Pin_5 | GPIO_Pin_8 | GPIO_Pin_9 \ | ||||
|                                  | GPIO_Pin_10 | GPIO_Pin_11 | GPIO_Pin_12 | GPIO_Pin_13 | GPIO_Pin_14 | GPIO_Pin_15;   | ||||
|   GPIO_InitStructure.GPIO_Mode = GPIO_Mode_AF; | ||||
|   GPIO_Init( GPIOB, &GPIO_InitStructure); | ||||
|    | ||||
|   GPIO_PinAFConfig(GPIOB, GPIO_PinSource3,GPIO_AF_LCD) ; | ||||
|   GPIO_PinAFConfig(GPIOB, GPIO_PinSource4,GPIO_AF_LCD) ; | ||||
|   GPIO_PinAFConfig(GPIOB, GPIO_PinSource5,GPIO_AF_LCD) ; | ||||
|   GPIO_PinAFConfig(GPIOB, GPIO_PinSource8,GPIO_AF_LCD) ; | ||||
|   GPIO_PinAFConfig(GPIOB, GPIO_PinSource9,GPIO_AF_LCD) ; | ||||
|   GPIO_PinAFConfig(GPIOB, GPIO_PinSource10,GPIO_AF_LCD) ; | ||||
|   GPIO_PinAFConfig(GPIOB, GPIO_PinSource11,GPIO_AF_LCD) ;   | ||||
|   GPIO_PinAFConfig(GPIOB, GPIO_PinSource12,GPIO_AF_LCD) ; | ||||
|   GPIO_PinAFConfig(GPIOB, GPIO_PinSource13,GPIO_AF_LCD) ;    | ||||
|   GPIO_PinAFConfig(GPIOB, GPIO_PinSource14,GPIO_AF_LCD) ; | ||||
|   GPIO_PinAFConfig(GPIOB, GPIO_PinSource15,GPIO_AF_LCD) ;    | ||||
|    | ||||
| /* Configure Output for LCD */ | ||||
| /* Port C*/   | ||||
|   GPIO_InitStructure.GPIO_Pin = GPIO_Pin_0 | GPIO_Pin_1 | GPIO_Pin_2 | GPIO_Pin_3 | GPIO_Pin_6 \ | ||||
|                                  | GPIO_Pin_7 | GPIO_Pin_8 | GPIO_Pin_9 | GPIO_Pin_10 |GPIO_Pin_11 ;                                | ||||
|   GPIO_InitStructure.GPIO_Mode = GPIO_Mode_AF; | ||||
|   GPIO_Init( GPIOC, &GPIO_InitStructure);   | ||||
|    | ||||
| 
 | ||||
|   GPIO_PinAFConfig(GPIOC, GPIO_PinSource0,GPIO_AF_LCD) ; | ||||
|   GPIO_PinAFConfig(GPIOC, GPIO_PinSource1,GPIO_AF_LCD) ;  | ||||
|   GPIO_PinAFConfig(GPIOC, GPIO_PinSource2,GPIO_AF_LCD) ; | ||||
|   GPIO_PinAFConfig(GPIOC, GPIO_PinSource3,GPIO_AF_LCD) ; | ||||
|   GPIO_PinAFConfig(GPIOC, GPIO_PinSource6,GPIO_AF_LCD) ; | ||||
|   GPIO_PinAFConfig(GPIOC, GPIO_PinSource7,GPIO_AF_LCD) ; | ||||
|   GPIO_PinAFConfig(GPIOC, GPIO_PinSource8,GPIO_AF_LCD) ; | ||||
|   GPIO_PinAFConfig(GPIOC, GPIO_PinSource9,GPIO_AF_LCD) ; | ||||
|   GPIO_PinAFConfig(GPIOC, GPIO_PinSource10,GPIO_AF_LCD) ;  | ||||
|   GPIO_PinAFConfig(GPIOC, GPIO_PinSource11,GPIO_AF_LCD) ;   | ||||
| 
 | ||||
| /* Disable GPIOs clock */ 	 | ||||
|   RCC_AHBPeriphClockCmd(RCC_AHBPeriph_GPIOA | RCC_AHBPeriph_GPIOB | RCC_AHBPeriph_GPIOC | | ||||
|                         RCC_AHBPeriph_GPIOD | RCC_AHBPeriph_GPIOE | RCC_AHBPeriph_GPIOH, DISABLE); | ||||
|    | ||||
| } | ||||
| 
 | ||||
| /**
 | ||||
|   * @brief  LCD contrast setting min-->max-->min by pressing user button | ||||
|   * @param  None | ||||
|   * @retval None | ||||
|   */ | ||||
| void LCD_contrast() | ||||
| { | ||||
|   uint32_t contrast ; | ||||
|    | ||||
|   /* To get the actual contrast value in register */ | ||||
|   contrast = LCD->FCR & LCD_Contrast_Level_7; | ||||
|    | ||||
|   while ((GPIOC->IDR & USERBUTTON_GPIO_PIN) == 0x0) | ||||
|   { | ||||
|     contrast += LCD_Contrast_Level_1;	 | ||||
|      | ||||
|     if (contrast > LCD_Contrast_Level_7) | ||||
|      contrast=LCD_Contrast_Level_0; | ||||
|    | ||||
|     LCD_ContrastConfig(contrast); | ||||
|     Delay(100); | ||||
|   } | ||||
| } | ||||
| 
 | ||||
| /**
 | ||||
|   * @brief  Setting bar on LCD, writes bar value in LCD frame buffer  | ||||
|   * @param  None | ||||
|   * @retval None | ||||
|   */ | ||||
| void LCD_bar() | ||||
| { | ||||
|          | ||||
|   LCD->RAM[LCD_RAMRegister_4] &= 0xffff5fff; | ||||
|   LCD->RAM[LCD_RAMRegister_6] &= 0xffff5fff; | ||||
| /* bar1 bar3 */ | ||||
|   LCD->RAM[LCD_RAMRegister_4] |= (uint32_t)(t_bar[0]<<12); | ||||
|    | ||||
| /*bar0 bar2 */ | ||||
|   LCD->RAM[LCD_RAMRegister_6] |= (uint32_t)(t_bar[1]<<12); | ||||
|   | ||||
| } | ||||
| 
 | ||||
| /**
 | ||||
|   * @brief  Converts an ascii char to the a LCD digit. | ||||
|   * @param  c: a char to display. | ||||
|   * @param  point: a point to add in front of char | ||||
|   *         This parameter can be: POINT_OFF or POINT_ON | ||||
|   * @param  column : flag indicating if a column has to be add in front | ||||
|   *         of displayed character. | ||||
|   *         This parameter can be: COLUMN_OFF or COLUMN_ON. | ||||
| 	* @param 	digit array with segment  | ||||
|   * @retval None | ||||
|   */ | ||||
| static void LCD_Conv_Char_Seg(uint8_t* c,bool point,bool column, uint8_t* digit) | ||||
| { | ||||
|   uint16_t ch = 0 ; | ||||
|   uint8_t i,j; | ||||
|    | ||||
|   switch (*c) | ||||
|     { | ||||
|     case ' ' :  | ||||
|       ch = 0x00; | ||||
|       break; | ||||
|      | ||||
|     case '*': | ||||
|       ch = star; | ||||
|       break; | ||||
|                    | ||||
|     case 'µ' : | ||||
|       ch = C_UMAP; | ||||
|       break; | ||||
|      | ||||
|     case 'm' : | ||||
|       ch = C_mMap; | ||||
|       break; | ||||
|                    | ||||
|     case 'n' : | ||||
|       ch = C_nMap; | ||||
|       break;					 | ||||
|                    | ||||
|     case '-' : | ||||
|       ch = C_minus; | ||||
|       break; | ||||
|        | ||||
|     case '/' : | ||||
|       ch = C_slatch; | ||||
|       break;   | ||||
|        | ||||
|     case '°' : | ||||
|       ch = C_percent_1; | ||||
|       break;   | ||||
|     case '%' : | ||||
|       ch = C_percent_2;  | ||||
|       break; | ||||
|     case 255 : | ||||
|       ch = C_full; | ||||
|       break ; | ||||
|      | ||||
|     case '0': | ||||
|     case '1': | ||||
|     case '2': | ||||
|     case '3': | ||||
|     case '4': | ||||
|     case '5': | ||||
|     case '6': | ||||
|     case '7': | ||||
|     case '8': | ||||
|     case '9':			 | ||||
|       ch = NumberMap[*c-0x30];		 | ||||
|       break; | ||||
|            | ||||
|     default: | ||||
|       /* The character c is one letter in upper case*/ | ||||
|       if ( (*c < 0x5b) && (*c > 0x40) ) | ||||
|       { | ||||
|         ch = CapLetterMap[*c-'A']; | ||||
|       } | ||||
|       /* The character c is one letter in lower case*/ | ||||
|       if ( (*c <0x7b) && ( *c> 0x60) ) | ||||
|       { | ||||
|         ch = CapLetterMap[*c-'a']; | ||||
|       } | ||||
|       break; | ||||
|   } | ||||
|         | ||||
|   /* Set the digital point can be displayed if the point is on */ | ||||
|   if (point) | ||||
|   { | ||||
|     ch |= 0x0002; | ||||
|   } | ||||
| 
 | ||||
|   /* Set the "COL" segment in the character that can be displayed if the column is on */ | ||||
|   if (column) | ||||
|   { | ||||
|     ch |= 0x0020; | ||||
|   }		 | ||||
| 
 | ||||
|   for (i = 12,j=0 ;j<4; i-=4,j++) | ||||
|   { | ||||
|     digit[j] = (ch >> i) & 0x0f; //To isolate the less signifiant dibit
 | ||||
|   } | ||||
| } | ||||
| 
 | ||||
| /**
 | ||||
|   * @brief  This function writes a char in the LCD frame buffer. | ||||
|   * @param  ch: the character to display. | ||||
|   * @param  point: a point to add in front of char | ||||
|   *         This parameter can be: POINT_OFF or POINT_ON | ||||
|   * @param  column: flag indicating if a column has to be add in front | ||||
|   *         of displayed character. | ||||
|   *         This parameter can be: COLUMN_OFF or COLUMN_ON.            | ||||
|   * @param  position: position in the LCD of the caracter to write [0:7] | ||||
|   * @retval None | ||||
|   * @par    Required preconditions: The LCD should be cleared before to start the | ||||
|   *         write operation.   | ||||
|   */ | ||||
| void LCD_GLASS_WriteChar(uint8_t* ch, bool point, bool column, uint8_t position) | ||||
| { | ||||
|   uint8_t digit[4];     /* Digit frame buffer */ | ||||
|     | ||||
| /* To convert displayed character in segment in array digit */ | ||||
|   LCD_Conv_Char_Seg(ch,point,column,digit); | ||||
| 
 | ||||
|   | ||||
|   switch (position) | ||||
|   { | ||||
|     /* Position 1 on LCD (Digit1)*/ | ||||
|     case 1: | ||||
|       LCD->RAM[LCD_RAMRegister_0] &= 0xcffffffc; | ||||
|       LCD->RAM[LCD_RAMRegister_2] &= 0xcffffffc; | ||||
|       LCD->RAM[LCD_RAMRegister_4] &= 0xcffffffc; | ||||
|       LCD->RAM[LCD_RAMRegister_6] &= 0xcffffffc; | ||||
| 
 | ||||
|       LCD->RAM[LCD_RAMRegister_0] |= ((digit[0]& 0x0c) << 26 ) | (digit[0]& 0x03) ; // 1G 1B 1M 1E	    
 | ||||
|       LCD->RAM[LCD_RAMRegister_2] |= ((digit[1]& 0x0c) << 26 ) | (digit[1]& 0x03) ; // 1F 1A 1C 1D 
 | ||||
|       LCD->RAM[LCD_RAMRegister_4] |= ((digit[2]& 0x0c) << 26 ) | (digit[2]& 0x03) ; // 1Q 1K 1Col 1P                                                                                                                                    
 | ||||
|       LCD->RAM[LCD_RAMRegister_6] |= ((digit[3]& 0x0c) << 26 ) | (digit[3]& 0x03) ; // 1H 1J 1DP 1N
 | ||||
| 
 | ||||
|       break; | ||||
|      | ||||
|     /* Position 2 on LCD (Digit2)*/ | ||||
|     case 2: | ||||
|       LCD->RAM[LCD_RAMRegister_0] &= 0xf3ffff03; | ||||
|       LCD->RAM[LCD_RAMRegister_2] &= 0xf3ffff03;       | ||||
|       LCD->RAM[LCD_RAMRegister_4] &= 0xf3ffff03; | ||||
|       LCD->RAM[LCD_RAMRegister_6] &= 0xf3ffff03; | ||||
|        | ||||
|       LCD->RAM[LCD_RAMRegister_0] |= ((digit[0]& 0x0c) << 24 )|((digit[0]& 0x02) << 6 )|((digit[0]& 0x01) << 2 ) ; // 2G 2B 2M 2E	  
 | ||||
|       LCD->RAM[LCD_RAMRegister_2] |= ((digit[1]& 0x0c) << 24 )|((digit[1]& 0x02) << 6 )|((digit[1]& 0x01) << 2 ) ; // 2F 2A 2C 2D
 | ||||
|       LCD->RAM[LCD_RAMRegister_4] |= ((digit[2]& 0x0c) << 24 )|((digit[2]& 0x02) << 6 )|((digit[2]& 0x01) << 2 ) ; // 2Q 2K 2Col 2P
 | ||||
|       LCD->RAM[LCD_RAMRegister_6] |= ((digit[3]& 0x0c) << 24 )|((digit[3]& 0x02) << 6 )|((digit[3]& 0x01) << 2 ) ; // 2H 2J 2DP 2N
 | ||||
|        | ||||
|       break; | ||||
|      | ||||
|     /* Position 3 on LCD (Digit3)*/ | ||||
|     case 3: | ||||
|       LCD->RAM[LCD_RAMRegister_0] &= 0xfcfffcff; | ||||
|       LCD->RAM[LCD_RAMRegister_2] &= 0xfcfffcff; | ||||
|       LCD->RAM[LCD_RAMRegister_4] &= 0xfcfffcff; | ||||
|       LCD->RAM[LCD_RAMRegister_6] &= 0xfcfffcff; | ||||
| 
 | ||||
|       LCD->RAM[LCD_RAMRegister_0] |= ((digit[0]& 0x0c) << 22 ) | ((digit[0]& 0x03) << 8 ) ; // 3G 3B 3M 3E	
 | ||||
|       LCD->RAM[LCD_RAMRegister_2] |= ((digit[1]& 0x0c) << 22 ) | ((digit[1]& 0x03) << 8 ) ; // 3F 3A 3C 3D
 | ||||
|       LCD->RAM[LCD_RAMRegister_4] |= ((digit[2]& 0x0c) << 22 ) | ((digit[2]& 0x03) << 8 ) ; // 3Q 3K 3Col 3P
 | ||||
|       LCD->RAM[LCD_RAMRegister_6] |= ((digit[3]& 0x0c) << 22 ) | ((digit[3]& 0x03) << 8 ) ; // 3H 3J 3DP 3N
 | ||||
|        | ||||
|       break; | ||||
|      | ||||
|     /* Position 4 on LCD (Digit4)*/ | ||||
|     case 4: | ||||
|       LCD->RAM[LCD_RAMRegister_0] &= 0xffcff3ff; | ||||
|       LCD->RAM[LCD_RAMRegister_2] &= 0xffcff3ff; | ||||
|       LCD->RAM[LCD_RAMRegister_4] &= 0xffcff3ff; | ||||
|       LCD->RAM[LCD_RAMRegister_6] &= 0xffcff3ff; | ||||
|        | ||||
|       LCD->RAM[LCD_RAMRegister_0] |= ((digit[0]& 0x0c) << 18 ) | ((digit[0]& 0x03) << 10 ) ; // 4G 4B 4M 4E	
 | ||||
|       LCD->RAM[LCD_RAMRegister_2] |= ((digit[1]& 0x0c) << 18 ) | ((digit[1]& 0x03) << 10 ) ; // 4F 4A 4C 4D
 | ||||
|       LCD->RAM[LCD_RAMRegister_4] |= ((digit[2]& 0x0c) << 18 ) | ((digit[2]& 0x03) << 10 ) ; // 4Q 4K 4Col 4P
 | ||||
|       LCD->RAM[LCD_RAMRegister_6] |= ((digit[3]& 0x0c) << 18 ) | ((digit[3]& 0x03) << 10 ) ; // 4H 4J 4DP 4N
 | ||||
|        | ||||
|       break; | ||||
|      | ||||
|     /* Position 5 on LCD (Digit5)*/ | ||||
|     case 5: | ||||
|       LCD->RAM[LCD_RAMRegister_0] &= 0xfff3cfff; | ||||
|       LCD->RAM[LCD_RAMRegister_2] &= 0xfff3cfff; | ||||
|       LCD->RAM[LCD_RAMRegister_4] &= 0xfff3efff; | ||||
|       LCD->RAM[LCD_RAMRegister_6] &= 0xfff3efff; | ||||
| 
 | ||||
|       LCD->RAM[LCD_RAMRegister_0] |= ((digit[0]& 0x0c) << 16 ) | ((digit[0]& 0x03) << 12 ) ; // 5G 5B 5M 5E	
 | ||||
|       LCD->RAM[LCD_RAMRegister_2] |= ((digit[1]& 0x0c) << 16 ) | ((digit[1]& 0x03) << 12 ) ; // 5F 5A 5C 5D
 | ||||
|       LCD->RAM[LCD_RAMRegister_4] |= ((digit[2]& 0x0c) << 16 ) | ((digit[2]& 0x01) << 12 ) ; // 5Q 5K   5P 
 | ||||
|       LCD->RAM[LCD_RAMRegister_6] |= ((digit[3]& 0x0c) << 16 ) | ((digit[3]& 0x01) << 12 ) ; // 5H 5J   5N
 | ||||
|        | ||||
|       break; | ||||
|      | ||||
|     /* Position 6 on LCD (Digit6)*/ | ||||
|     case 6: | ||||
|       LCD->RAM[LCD_RAMRegister_0] &= 0xfffc3fff; | ||||
|       LCD->RAM[LCD_RAMRegister_2] &= 0xfffc3fff; | ||||
|       LCD->RAM[LCD_RAMRegister_4] &= 0xfffc3fff; | ||||
|       LCD->RAM[LCD_RAMRegister_6] &= 0xfffc3fff; | ||||
| 
 | ||||
|       LCD->RAM[LCD_RAMRegister_0] |= ((digit[0]& 0x04) << 15 ) | ((digit[0]& 0x08) << 13 ) | ((digit[0]& 0x03) << 14 ) ; // 6B 6G 6M 6E	
 | ||||
|       LCD->RAM[LCD_RAMRegister_2] |= ((digit[1]& 0x04) << 15 ) | ((digit[1]& 0x08) << 13 ) | ((digit[1]& 0x03) << 14 ) ; // 6A 6F 6C 6D
 | ||||
|       LCD->RAM[LCD_RAMRegister_4] |= ((digit[2]& 0x04) << 15 ) | ((digit[2]& 0x08) << 13 ) | ((digit[2]& 0x01) << 14 ) ; // 6K 6Q    6P 
 | ||||
|       LCD->RAM[LCD_RAMRegister_6] |= ((digit[3]& 0x04) << 15 ) | ((digit[3]& 0x08) << 13 ) | ((digit[3]& 0x01) << 14 ) ; // 6J 6H   6N
 | ||||
|        | ||||
|       break; | ||||
|      | ||||
|      default: | ||||
|       break; | ||||
|   } | ||||
| 
 | ||||
| /* Refresh LCD  bar */ | ||||
|   LCD_bar(); | ||||
| 
 | ||||
| } | ||||
| 
 | ||||
| /**
 | ||||
|   * @brief  This function writes a char in the LCD RAM. | ||||
|   * @param  ptr: Pointer to string to display on the LCD Glass. | ||||
|   * @retval None | ||||
|   */ | ||||
| void LCD_GLASS_DisplayString(uint8_t* ptr) | ||||
| { | ||||
|   uint8_t i = 0x01; | ||||
| 
 | ||||
| 	/* wait for LCD Ready */   | ||||
|   while( LCD_GetFlagStatus (LCD_FLAG_UDR) != RESET) ; | ||||
| 	 | ||||
|   /* Send the string character by character on lCD */ | ||||
|   while ((*ptr != 0) & (i < 8)) | ||||
|   { | ||||
|     /* Display one character on LCD */ | ||||
|     LCD_GLASS_WriteChar(ptr, FALSE, FALSE, i); | ||||
| 
 | ||||
|     /* Point on the next character */ | ||||
|     ptr++; | ||||
| 
 | ||||
|     /* Increment the character counter */ | ||||
|     i++; | ||||
|   } | ||||
| 
 | ||||
| 	/* Update the LCD display */ | ||||
|   LCD_UpdateDisplayRequest(); | ||||
| } | ||||
| 
 | ||||
| /**
 | ||||
|   * @brief  This function writes a char in the LCD RAM. | ||||
|   * @param  ptr: Pointer to string to display on the LCD Glass. | ||||
|   * @retval None | ||||
|   * @par    Required preconditions: Char is ASCCI value "Ored" with decimal point or Column flag | ||||
|   */ | ||||
| void LCD_GLASS_DisplayStrDeci(uint16_t* ptr) | ||||
| { | ||||
|   uint8_t i = 0x01; | ||||
|   uint8_t char_tmp; | ||||
| 
 | ||||
| 	/* TO wait LCD Ready */   | ||||
|   while( LCD_GetFlagStatus (LCD_FLAG_UDR) != RESET) ; | ||||
|    | ||||
|   /* Send the string character by character on lCD */ | ||||
|   while ((*ptr != 0) & (i < 8)) | ||||
|   {			 | ||||
|     char_tmp = (*ptr) & 0x00ff; | ||||
|      | ||||
|     switch ((*ptr) & 0xf000) | ||||
|     { | ||||
|       case DOT: | ||||
|           /* Display one character on LCD with decimal point */ | ||||
|           LCD_GLASS_WriteChar(&char_tmp, POINT_ON, COLUMN_OFF, i); | ||||
|           break; | ||||
|       case DOUBLE_DOT: | ||||
|           /* Display one character on LCD with decimal point */ | ||||
|           LCD_GLASS_WriteChar(&char_tmp, POINT_OFF, COLUMN_ON, i); | ||||
|           break; | ||||
|       default: | ||||
|           LCD_GLASS_WriteChar(&char_tmp, POINT_OFF, COLUMN_OFF, i);		 | ||||
|           break; | ||||
|     }/* Point on the next character */ | ||||
|     ptr++; | ||||
|      | ||||
|     /* Increment the character counter */ | ||||
|     i++; | ||||
|   } | ||||
| 	/* Update the LCD display */ | ||||
|   LCD_UpdateDisplayRequest(); | ||||
| } | ||||
| 
 | ||||
| /**
 | ||||
|   * @brief  This function Clear the whole LCD RAM. | ||||
|   * @param  None | ||||
|   * @retval None | ||||
|   */ | ||||
| void LCD_GLASS_Clear(void) | ||||
| { | ||||
|   uint32_t counter = 0; | ||||
| 	 | ||||
|   /* TO wait LCD Ready */   | ||||
|   while( LCD_GetFlagStatus (LCD_FLAG_UDR) != RESET) ; | ||||
|    | ||||
|   for (counter = LCD_RAMRegister_0; counter <= LCD_RAMRegister_15; counter++) | ||||
|   { | ||||
|     LCD->RAM[counter] = 0; | ||||
|   } | ||||
| 
 | ||||
|   /* Update the LCD display */ | ||||
|   LCD_UpdateDisplayRequest(); | ||||
|    | ||||
| } | ||||
| 
 | ||||
| /**
 | ||||
|   * @brief  Display a string in scrolling mode | ||||
|   * @param  ptr: Pointer to string to display on the LCD Glass. | ||||
|   * @param  nScroll: Specifies how many time the message will be scrolled | ||||
|   * @param  ScrollSpeed : Speciifes the speed of the scroll, low value gives | ||||
|   *         higher speed  | ||||
|   * @retval None | ||||
|   * @par    Required preconditions: The LCD should be cleared before to start the | ||||
|   *         write operation. | ||||
|   */ | ||||
| void LCD_GLASS_ScrollSentence(uint8_t* ptr, uint16_t nScroll, uint16_t ScrollSpeed) | ||||
| { | ||||
|   uint8_t Repetition; | ||||
|   uint8_t Char_Nb; | ||||
|   uint8_t* ptr1; | ||||
|   uint8_t str[7]=""; | ||||
|   uint8_t Str_size; | ||||
|    | ||||
|   if (ptr == 0) return; | ||||
| 
 | ||||
| /* To calculate end of string */ | ||||
|   for (ptr1=ptr,Str_size = 0 ; *ptr1 != 0; Str_size++,ptr1++) ; | ||||
|    | ||||
|   ptr1 = ptr; | ||||
|    | ||||
|   LCD_GLASS_DisplayString(ptr); | ||||
|   Delay(ScrollSpeed); | ||||
|            | ||||
| /* To shift the string for scrolling display*/ | ||||
|   for (Repetition=0; Repetition<nScroll; Repetition++) | ||||
|   { | ||||
|     for (Char_Nb=0; Char_Nb<Str_size; Char_Nb++) | ||||
|     { | ||||
|       *(str) =* (ptr1+((Char_Nb+1)%Str_size)); | ||||
|       *(str+1) =* (ptr1+((Char_Nb+2)%Str_size)); | ||||
|       *(str+2) =* (ptr1+((Char_Nb+3)%Str_size)); | ||||
|       *(str+3) =* (ptr1+((Char_Nb+4)%Str_size)); | ||||
|       *(str+4) =* (ptr1+((Char_Nb+5)%Str_size)); | ||||
|       *(str+5) =* (ptr1+((Char_Nb+6)%Str_size)); | ||||
|       LCD_GLASS_Clear(); | ||||
|       LCD_GLASS_DisplayString(str); | ||||
|    | ||||
|   /* user button pressed stop the scrolling sentence */ | ||||
|       if (KeyPressed) | ||||
|               return;   		 | ||||
|       Delay(ScrollSpeed); | ||||
|     }	 | ||||
|   } | ||||
| 
 | ||||
| } | ||||
| 
 | ||||
| /******************* (C) COPYRIGHT 2011 STMicroelectronics *****END OF FILE****/ | ||||
|  | @ -1,127 +0,0 @@ | |||
|  /**
 | ||||
|   ****************************************************************************** | ||||
|   * @file    stm32l_discovery_lcd.h | ||||
|   * @author  Microcontroller Division | ||||
|   * @version V1.0.3 | ||||
|   * @date    May-2013 | ||||
|   * @brief   This file contains all the functions prototypes for the glass LCD | ||||
|   *          firmware driver. | ||||
|   ****************************************************************************** | ||||
|   * @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>© COPYRIGHT 2011 STMicroelectronics</center></h2> | ||||
|   */  | ||||
| 
 | ||||
| /* Define to prevent recursive inclusion -------------------------------------*/ | ||||
| #ifndef __stm32l_discovery_lcd | ||||
| #define __stm32l_discovery_lcd | ||||
| 
 | ||||
| /* Includes ------------------------------------------------------------------*/ | ||||
| #include "stm32l1xx.h"    | ||||
| #include "discover_board.h" | ||||
| 
 | ||||
| /* Define for scrolling sentences*/ | ||||
| #define SCROLL_SPEED  	75 | ||||
| #define SCROLL_SPEED_L  600 | ||||
| #define SCROLL_NUM    	1 | ||||
| 
 | ||||
| /* Define for character '.' */ | ||||
| #define  POINT_OFF FALSE | ||||
| #define  POINT_ON TRUE | ||||
| 
 | ||||
| /* Define for caracter ":" */ | ||||
| #define  COLUMN_OFF FALSE | ||||
| #define  COLUMN_ON TRUE | ||||
| 
 | ||||
| #define DOT 0x8000 /* for add decimal point in string */ | ||||
| #define DOUBLE_DOT 0x4000 /* for add decimal point in string */ | ||||
| 
 | ||||
| 
 | ||||
| /*  =========================================================================
 | ||||
|                                  LCD MAPPING | ||||
|     ========================================================================= | ||||
| 	    A | ||||
|      _  ---------- | ||||
| COL |_| |\   |J  /| | ||||
|        F| H  |  K |B | ||||
|      _  |  \ | /  | | ||||
| COL |_| --G-- --M-- | ||||
|         |   /| \  | | ||||
|        E|  Q |  N |C | ||||
|      _  | /  |P  \|    | ||||
| DP  |_| -----------   | ||||
| 	    D          | ||||
| 
 | ||||
|  An LCD character coding is based on the following matrix: | ||||
|       { E , D , P , N   } | ||||
|       { M , C , COL , DP} | ||||
|       { B , A , K , J   } | ||||
|       { G , F , Q , H   } | ||||
| 
 | ||||
|  The character 'A' for example is: | ||||
|   ------------------------------- | ||||
| LSB   { 1 , 0 , 0 , 0   } | ||||
|       { 1 , 1 , 0 , 0   } | ||||
|       { 1 , 1 , 0 , 0   } | ||||
| MSB   { 1 , 1 , 0 , 0   } | ||||
|       ------------------- | ||||
|   'A' =  F    E   0   0 hexa | ||||
| 
 | ||||
| */ | ||||
| /* Macros used for set/reset bar LCD bar */ | ||||
| #define BAR0_ON  t_bar[1] |= 8 | ||||
| #define BAR0_OFF t_bar[1] &= ~8 | ||||
| #define BAR1_ON  t_bar[0] |= 8 | ||||
| #define BAR1_OFF t_bar[0] &= ~8 | ||||
| #define BAR2_ON  t_bar[1] |= 2 | ||||
| #define BAR2_OFF t_bar[1] &= ~2 | ||||
| #define BAR3_ON t_bar[0]  |= 2  | ||||
| #define BAR3_OFF t_bar[0] &= ~2  | ||||
| 
 | ||||
| /* code for 'µ' character */ | ||||
| #define C_UMAP 0x6084 | ||||
| 
 | ||||
| /* code for 'm' character */ | ||||
| #define C_mMap 0xb210 | ||||
| 
 | ||||
| /* code for 'n' character */ | ||||
| #define C_nMap 0x2210 | ||||
| 
 | ||||
| /* constant code for '*' character */ | ||||
| #define star 0xA0DD | ||||
| 
 | ||||
| /* constant code for '-' character */ | ||||
| #define C_minus 0xA000 | ||||
| 
 | ||||
| /* constant code for '/' */ | ||||
| #define C_slatch  0x00c0 | ||||
| 
 | ||||
| /* constant code for ° */ | ||||
| #define C_percent_1 0xec00 | ||||
| 
 | ||||
| /* constant code  for small o */ | ||||
| #define C_percent_2 0xb300 | ||||
| 
 | ||||
| #define C_full 0xffdd | ||||
| 
 | ||||
| void LCD_bar(void); | ||||
| void LCD_GLASS_Init(void); | ||||
| void LCD_GLASS_WriteChar(uint8_t* ch, bool point, bool column,uint8_t position); | ||||
| void LCD_GLASS_DisplayString(uint8_t* ptr); | ||||
| void LCD_GLASS_DisplayStrDeci(uint16_t* ptr); | ||||
| void LCD_GLASS_ClearChar(uint8_t position); | ||||
| void LCD_GLASS_Clear(void); | ||||
| void LCD_GLASS_ScrollSentence(uint8_t* ptr, uint16_t nScroll, uint16_t ScrollSpeed); | ||||
| void LCD_GLASS_WriteTime(char a, uint8_t posi, bool column); | ||||
| void LCD_GLASS_Configure_GPIO(void); | ||||
| 
 | ||||
| #endif /* stm32l_discovery_lcd*/ | ||||
| 
 | ||||
| /******************* (C) COPYRIGHT 2011 STMicroelectronics *****END OF FILE****/ | ||||
|  | @ -1,683 +0,0 @@ | |||
|  /**
 | ||||
|  ****************************************************************************** | ||||
|  * @file    discover_functions.c | ||||
|  * @author  Microcontroller Division | ||||
|   * @version V1.0.3 | ||||
|   * @date    May-2013 | ||||
|  * @brief   Discover demo 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>© COPYRIGHT 2011 STMicroelectronics</center></h2> | ||||
|  */ | ||||
| 
 | ||||
| /* Includes ------------------------------------------------------------------*/ | ||||
| 
 | ||||
| /* stm32l1xxx std peripheral drivers headers*/  | ||||
| #include "stm32l1xx_exti.h" | ||||
| #include "misc.h" | ||||
| 
 | ||||
| /* touch sensing library headers*/  | ||||
| //#include "stm32_tsl_api.h" -- superseded
 | ||||
| //#include "stm32l15x_tsl_ct_acquisition.h" -- superseded
 | ||||
| #include "tsl.h" | ||||
| #include "tsl_user.h" | ||||
| /* discover application headers*/  | ||||
| #include "discover_board.h" | ||||
| #include "discover_functions.h" | ||||
| #include "stm32l_discovery_lcd.h" | ||||
| #include "icc_measure.h" | ||||
|    | ||||
| /*Variables placed in DataFlash */ | ||||
| 
 | ||||
| /* ADC converter value for Bias current value*/ | ||||
| #if   (defined ( __CC_ARM )) | ||||
| uint8_t Bias_Current __attribute__((at(0x08080000)));      | ||||
| #elif (defined (__ICCARM__)) | ||||
| uint8_t Bias_Current @ ".DataFlash" ;   | ||||
| #elif (defined (__GNUC__)) | ||||
| /* ADC converter value for Bias current value*/ | ||||
| uint8_t Bias_Current __attribute__((section(".DataFlash"))); | ||||
| #endif | ||||
| 
 | ||||
| /* Flag for autotest placed in Data Flash for return from RESET after STANDBY */ | ||||
| #if   (defined ( __CC_ARM )) | ||||
| bool self_test      __attribute__((at(0x08080004)));         | ||||
| #elif (defined (__ICCARM__)) | ||||
| bool self_test @ ".DataFlash" ; | ||||
| #elif (defined (__GNUC__)) | ||||
| /* Flag for autotest placed in Data Flash for return from RESET after STANDBY */ | ||||
| bool self_test      __attribute__((section(".DataFlash"))); | ||||
| #endif | ||||
| 
 | ||||
| extern float Current_STBY; | ||||
| extern uint8_t t_bar[2]; | ||||
| extern uint16_t Int_CurrentSTBY; | ||||
| 
 | ||||
| /* Used for indicate that the automatic test is ON (set in interrupt handler).*/ | ||||
| 
 | ||||
| /* To indicate if user button function is actived*/ | ||||
| bool UserButton ; | ||||
| /* Used for detect keypressed*/ | ||||
| extern volatile bool KeyPressed; | ||||
| 
 | ||||
| 
 | ||||
| /**
 | ||||
|   * @brief  automatic test for VDD  | ||||
|   * @caller auto_test | ||||
|   * @param None | ||||
|   * @retval None | ||||
|   */ | ||||
| void test_vdd(void) | ||||
| { | ||||
|   uint16_t vdd_test; | ||||
|   uint16_t Message[6]; | ||||
|    | ||||
|   /* Display test name*/ | ||||
|   LCD_GLASS_DisplayString(" VDD "); | ||||
|   DELAY; | ||||
|   /* get VDD voltage value */  | ||||
|   vdd_test = (int)Vref_measure(); | ||||
|   DELAY; | ||||
|   /* Check if value is correct */	 | ||||
|   if ((vdd_test>VCC_MAX) || (vdd_test<VCC_MIN)) | ||||
|   { | ||||
|     /* if not correct stay in following infinit loop -- Press reset for exit */ | ||||
|     while(1) | ||||
|     { | ||||
|       /* Display VDD ERROR message*/ | ||||
|       LCD_GLASS_ScrollSentence("VDD ERROR ",1,SCROLL_SPEED);  | ||||
|       DELAY; | ||||
|       /*convert vdd_test value in char and stor it into Message */ | ||||
|       convert_into_char (vdd_test, Message); | ||||
|       /* Add unit and decimal point to Message  */ | ||||
|       Message[5] = 'V'; | ||||
|       Message[4] = ' '; | ||||
|       Message[1] |= DOT;  | ||||
|       Message[0] = ' '; | ||||
|       /*Display Message*/    | ||||
|       LCD_GLASS_DisplayStrDeci(Message);       | ||||
|       DELAY; | ||||
|       DELAY;       | ||||
|     } | ||||
|   } | ||||
|   /* Display VDD OK message*/ | ||||
|   LCD_GLASS_DisplayString("VDD OK"); | ||||
|   DELAY ; | ||||
| } | ||||
| 
 | ||||
| /**
 | ||||
|   * @brief  Automatic test current in Run Mode  | ||||
|   * @caller auto_test | ||||
|   * @param None | ||||
|   * @retval None | ||||
|   */  | ||||
| void test_icc_Run(void) | ||||
| { | ||||
|   uint16_t icc_test; | ||||
|   uint16_t Message[6]; | ||||
|    | ||||
|   /* Display test name*/ | ||||
|   LCD_GLASS_DisplayString("RUN   "); | ||||
|   DELAY; | ||||
|    | ||||
|   /* get ICC current value in RUN mode*/  | ||||
|   icc_test = (int)Icc_RUN(); | ||||
|   DELAY; | ||||
|   /* Check if value is correct */	 | ||||
|   if ((icc_test>ICC_RUN_MAX) || (icc_test<ICC_RUN_MIN)) | ||||
|   { | ||||
|      /* if not correct stay in following infinit loop -- Press reset for exit */ | ||||
|     while (1) | ||||
|     { | ||||
|       KeyPressed = FALSE; | ||||
|       /* Display RUN ERROR message*/ | ||||
|       LCD_GLASS_ScrollSentence("RUN ERROR ",1,SCROLL_SPEED);  | ||||
|       DELAY; | ||||
|       /*convert icc_test value in char and stor it into tab */ | ||||
|       convert_into_char((uint32_t)(icc_test), Message); | ||||
|       /* Add unit and decimal point to Message  */ | ||||
|       Message[5] = 'A'; | ||||
|       Message[4] = 'm'; | ||||
|       Message[3] = ' '; | ||||
|       Message[0] |= DOT; | ||||
|        /*Display Message*/    | ||||
|       LCD_GLASS_DisplayStrDeci(Message); | ||||
|       DELAY; | ||||
|       DELAY; | ||||
|     } | ||||
|   } | ||||
|   /* Display RUN OK message*/ | ||||
|   LCD_GLASS_DisplayString("RUN OK"); | ||||
|   DELAY; | ||||
| } | ||||
| 
 | ||||
| /**
 | ||||
|   * @brief  Automatic test bias value | ||||
|   * @caller auto_test | ||||
|   * @param None | ||||
|   * @retval None | ||||
|   */  | ||||
| void test_Bias(void) | ||||
| { | ||||
|   float Current = 0; | ||||
|   /* Display test name*/ | ||||
|   LCD_GLASS_DisplayString("BIAS   "); | ||||
|   DELAY; | ||||
|   /* Get operational amplifier BIAS current value*/  | ||||
|   Current = Bias_Current * Vdd_appli()/ADC_CONV;  | ||||
|   Current *= 20L; | ||||
|   display_MuAmp((uint32_t)Current); | ||||
|   DELAY; | ||||
|    /* Check if value is correct */	 | ||||
|   if ((Bias_Current > ICC_BIAS_MAX) || (Bias_Current == 0 )) | ||||
|   { | ||||
|      /* if not correct stay in following infinit loop */ | ||||
|     while (1) | ||||
|     { | ||||
|       KeyPressed = FALSE; | ||||
|       /* Display BIAS ERROR message and BIAS current*/ | ||||
|       LCD_GLASS_ScrollSentence("BIAS ERROR ",1,SCROLL_SPEED); | ||||
|       DELAY; | ||||
|       display_MuAmp((uint32_t)Current); | ||||
|       DELAY; | ||||
|       DELAY; | ||||
|     } | ||||
|   } | ||||
|   /* Display BIAS OK message*/ | ||||
|   LCD_GLASS_DisplayString("BIASOK"); | ||||
|   DELAY; | ||||
| } | ||||
| 
 | ||||
| /**
 | ||||
|   * @brief  Automatic test current in STOP Mode | ||||
|   * @caller auto_test | ||||
|   * @param None | ||||
|   * @retval None | ||||
|   */ | ||||
| void test_icc_STOP(void) | ||||
| { | ||||
|   uint16_t icc_test; | ||||
|   /* Display test name*/ | ||||
|   LCD_GLASS_DisplayString("STOP  "); | ||||
|   DELAY; | ||||
|    | ||||
|   /* Get operational Icc current value in Stop mode no RTC*/	 | ||||
|   icc_test = (int)Icc_Stop_NoRTC(); | ||||
|     DELAY; | ||||
|   /* Test if value is correct */ | ||||
|     if ((icc_test>ICC_STOP_MAX) || (icc_test<ICC_STOP_MIN)) | ||||
|     { | ||||
|        /* if not correct stay in following infinite loop */ | ||||
|       while (1) | ||||
|       { | ||||
|         KeyPressed = FALSE; | ||||
|         /* Display ICC STOP ERROR message*/ | ||||
|         LCD_GLASS_ScrollSentence("ICC STOP ERROR ",1,SCROLL_SPEED); | ||||
|         DELAY; | ||||
|         /* Display ICC STOPvalue*/ | ||||
|         display_MuAmp((uint32_t)icc_test); | ||||
|         DELAY; | ||||
|         DELAY; | ||||
|       } | ||||
|     } | ||||
|   /* Display STOP OK message*/ | ||||
|   LCD_GLASS_DisplayString("STOPOK"); | ||||
|   DELAY; | ||||
| } | ||||
| 
 | ||||
| 
 | ||||
| /**
 | ||||
|   * @brief  Automatic test current in STBY Mode | ||||
|   * @caller auto_test | ||||
|   * @param None | ||||
|   * @retval None | ||||
|   */ | ||||
| void test_icc_STBY(void) | ||||
| { | ||||
|   /* Display test name*/ | ||||
|   LCD_GLASS_DisplayString("STBY  "); | ||||
|   DELAY; | ||||
|   /* Current value measured in Standby mode*/	 | ||||
|   ADC_Icc_Test(MCU_STBY); | ||||
|   /* No Return software reset performed in ADC_Icc_Test function */ | ||||
| } | ||||
| 
 | ||||
| /**
 | ||||
|   * @brief  Run auto test | ||||
|   * @caller main  | ||||
|   * @param None | ||||
|   * @retval None | ||||
|   */  | ||||
| void auto_test(void) | ||||
| { | ||||
|   uint16_t tab[6]={0x20,0x20,0x20,0x20,0x20,0x20}; | ||||
|    | ||||
|   AUTOTEST(TRUE) ; | ||||
| 	 | ||||
|   /* Switch off leds*/ | ||||
|   GPIO_LOW(LD_GPIO_PORT,LD_GREEN_GPIO_PIN);	 | ||||
|   GPIO_LOW(LD_GPIO_PORT,LD_BLUE_GPIO_PIN); | ||||
|    | ||||
|   /* reset LCD bar indicator*/ | ||||
|   BAR0_OFF; | ||||
|   BAR1_OFF; | ||||
|   BAR2_OFF; | ||||
|   BAR3_OFF; | ||||
|    | ||||
|   /* To display version */ | ||||
|   LCD_GLASS_DisplayString(" TEST "); | ||||
|   DELAY; | ||||
|   STR_VERSION; | ||||
|   LCD_GLASS_DisplayStrDeci(tab); | ||||
|   DELAY; | ||||
|   DELAY; | ||||
|    | ||||
|   /* And launch the tests*/ | ||||
|   test_vdd(); | ||||
|   test_icc_Run(); | ||||
|   test_Bias(); | ||||
|   test_icc_STOP(); | ||||
|   test_icc_STBY(); | ||||
|    | ||||
|   /* Infinite loop: Press reset button at the end of test for exit*/ | ||||
|   while (1) | ||||
|   { | ||||
|     LCD_GLASS_ScrollSentence("TEST OK ",1,SCROLL_SPEED); | ||||
|     KeyPressed = FALSE; | ||||
|   } | ||||
| } | ||||
| 
 | ||||
| /**
 | ||||
|   * @brief Second part of  Run auto test (run after sw reset) | ||||
|   * @caller main after RESET  | ||||
|   * @param None | ||||
|   * @retval None | ||||
|   */  | ||||
| void auto_test_part2(void) | ||||
| { | ||||
|   float Current_STBY; | ||||
|    | ||||
|   /* Substract operational amplifier bias current from mesured standby current*/ | ||||
|   if ( Int_CurrentSTBY > Bias_Current ) | ||||
|     Int_CurrentSTBY -= Bias_Current; | ||||
|   /* convert value in uA */  | ||||
|   Current_STBY = Int_CurrentSTBY * Vdd_appli()/ADC_CONV;   | ||||
|   Current_STBY *= 20L; | ||||
|   /*Display Standby Icc current value*/ | ||||
|   display_MuAmp((uint32_t)Current_STBY); | ||||
|   DELAY; | ||||
|  /* Test if value is correct */ | ||||
|     if ((Current_STBY > ICC_STBY_MAX) || (Current_STBY < ICC_STBY_MIN)) | ||||
|     { | ||||
|        /* if not correct stay in following infinite loop */ | ||||
|       while (1) | ||||
|       { | ||||
|         KeyPressed = FALSE; | ||||
|         /* Display ICC STBY error message */  | ||||
|         LCD_GLASS_ScrollSentence("ICC STBY ERROR ",1,SCROLL_SPEED);  | ||||
|         DELAY; | ||||
|         /* Display ICC STBY current */ | ||||
|         display_MuAmp((uint32_t)Current_STBY); | ||||
|         DELAY; | ||||
|         DELAY; | ||||
|       } | ||||
|     } | ||||
|   /* Display ICC STBY test OK*/   | ||||
|   LCD_GLASS_DisplayString("STBYOK"); | ||||
|   DELAY;     | ||||
|    | ||||
|    /* Infinite loop: Press reset button at the end of autotest to restart application*/ | ||||
|   while (1) | ||||
|   { | ||||
|     LCD_GLASS_ScrollSentence("TEST OK ",1,SCROLL_SPEED); | ||||
|     KeyPressed = FALSE; | ||||
|   } | ||||
| } | ||||
| /**
 | ||||
|   * @brief Measures the BIAS current PJ1 Must be on OFF position | ||||
|   * @caller main  | ||||
|   * @param None | ||||
|   * @retval None | ||||
|   */   | ||||
| void Bias_measurement(void) | ||||
| { | ||||
|   float Current; | ||||
|   uint16_t MeasurINT; | ||||
|   /* indicate that applicartion run in ** BIAS CURRENT ** mode */ | ||||
|   LCD_GLASS_ScrollSentence("      ** BIAS CURRENT ** JP1 OFF **",1,SCROLL_SPEED);	 | ||||
|    | ||||
|   /* Get operational amplifier Bias current value */ | ||||
|   MeasurINT = ADC_Icc_Test(MCU_STOP_NoRTC); | ||||
|    | ||||
|   /* convert mesured value in uA*/ | ||||
|   Current = MeasurINT * Vdd_appli()/ADC_CONV;  | ||||
|   Current *= 20L; | ||||
|    | ||||
|   /*display bias current value */ | ||||
|   display_MuAmp((uint32_t)Current); | ||||
| 
 | ||||
|   /* unlock E²Prom write access*/ | ||||
|   DATA_EEPROM_Unlock(); | ||||
|    | ||||
|   /* Store the value in E²Prom for application needs*/ | ||||
|   DATA_EEPROM_FastProgramByte((uint32_t)&Bias_Current, MeasurINT) ; | ||||
|    | ||||
|   /* Lock back E²PROM write access */ | ||||
|   DATA_EEPROM_Lock();	 | ||||
|    | ||||
|   /* Infinite loop: BIAS current display -- Press reset button in order to restart application*/ | ||||
|   while (1)   | ||||
|   {  | ||||
|     /* Get operational amplifier Bias current value */ | ||||
|     MeasurINT = ADC_Icc_Test(MCU_STOP_NoRTC); | ||||
|     /* convert mesured value in uA*/ | ||||
|     Current = MeasurINT * Vdd_appli()/ADC_CONV;  | ||||
|     Current *= 20L; | ||||
|     /*display bias current value */ | ||||
|     display_MuAmp((uint32_t)Current); | ||||
|     Delay(800) ; | ||||
|   } | ||||
| } | ||||
| 
 | ||||
| /**
 | ||||
|   * @brief converts a 32bit unsined int into ASCII  | ||||
|   * @caller several callers for display values | ||||
|   * @param Number digit to displays | ||||
|   *  p_tab values in array in ASCII    | ||||
|   * @retval None | ||||
|   */  | ||||
| void convert_into_char(uint32_t number, uint16_t *p_tab) | ||||
| { | ||||
|   uint16_t units=0, tens=0, hundreds=0, thousands=0, misc=0; | ||||
|    | ||||
|   units = (((number%10000)%1000)%100)%10; | ||||
|   tens = ((((number-units)/10)%1000)%100)%10; | ||||
|   hundreds = (((number-tens-units)/100))%100%10; | ||||
|   thousands = ((number-hundreds-tens-units)/1000)%10; | ||||
|   misc = ((number-thousands-hundreds-tens-units)/10000); | ||||
|    | ||||
|   *(p_tab+4) = units + 0x30; | ||||
|   *(p_tab+3) = tens + 0x30; | ||||
|   *(p_tab+2) = hundreds + 0x30; | ||||
|   *(p_tab+1) = thousands + 0x30; | ||||
|   *(p_tab) = misc + 0x30; | ||||
| 
 | ||||
| } | ||||
| 
 | ||||
| /**
 | ||||
|   * @brief Function to return the VDD measurement | ||||
|   * @caller All measurements: VDD display or Current | ||||
|   * | ||||
|   * Method for VDD measurement: | ||||
|   * The VREFINT is not stored in memory. | ||||
|   *   In this case: | ||||
|   *   Vdd_appli = (Theorical_Vref/Vref mesure) * ADC_Converter | ||||
|   *   Theorical_Vref = 1.224V | ||||
|   *   ADC_Converter 4096 | ||||
|   *   ---> LSBIdeal = VREF/4096 or VDA/4096 | ||||
|   * @param None    | ||||
|   * @retval VDD measurements | ||||
|   */ | ||||
| float Vdd_appli(void) | ||||
| { | ||||
|   uint16_t MeasurINT ; | ||||
| 
 | ||||
|   float f_Vdd_appli ; | ||||
|    | ||||
|   /*Read the BandGap value on ADC converter*/ | ||||
|   MeasurINT = ADC_Supply();	 | ||||
|    | ||||
|   /* We use the theorical value */ | ||||
|   f_Vdd_appli = (VREF/MeasurINT) * ADC_CONV; | ||||
| 
 | ||||
|   /* convert Vdd_appli into mV */   | ||||
|   f_Vdd_appli *= 1000L; | ||||
| 	 | ||||
|   return f_Vdd_appli; | ||||
| } | ||||
| 
 | ||||
| /**
 | ||||
|   * @brief Function to measure VDD | ||||
|   * @caller main | ||||
|   * @param None    | ||||
|   * @retval Vdd value in mV | ||||
|   */ | ||||
| uint16_t Vref_measure(void) | ||||
| { | ||||
|   uint16_t tab[6];	 | ||||
|   uint16_t Vdd_mV ; | ||||
|    | ||||
|   Vdd_mV = (uint16_t)Vdd_appli(); | ||||
| 
 | ||||
|   convert_into_char (Vdd_mV, tab); | ||||
| 	 | ||||
|   /* To add unit and decimal point  */ | ||||
|   tab[5] = 'V'; | ||||
|   tab[4] = ' '; | ||||
|   tab[1] |= DOT; /* To add decimal point for display in volt */ | ||||
|   tab[0] = ' '; | ||||
| 	 | ||||
|   LCD_GLASS_DisplayStrDeci(tab); | ||||
| 
 | ||||
|   return Vdd_mV; | ||||
| } | ||||
| 
 | ||||
| /**
 | ||||
|   * @brief funtion to display the current in µA | ||||
|   * @caller several funcions | ||||
|   * @param Current value. | ||||
|   * @retval none | ||||
|   */  | ||||
| void display_MuAmp (uint32_t Current) | ||||
| { | ||||
|   uint16_t tab[6]; | ||||
|            | ||||
|   convert_into_char(Current, tab); | ||||
|   tab[5] = 'A'; | ||||
|   tab[4] = 'µ'; | ||||
| 		 | ||||
| /* Test the significant digit for displays 3 or 4 digits*/ | ||||
|   if ( tab[0] != '0') | ||||
|   { | ||||
|     tab[1] |= DOT; /* To add decimal point */ | ||||
|   }  else  { | ||||
|     /* To shift for suppress '0' before decimal */ | ||||
|     tab[0] = tab[1] ;	 | ||||
|     tab[0] |= DOT ; | ||||
|     tab[1] = tab[2] ; | ||||
|     tab[2] = tab[3] ;		 | ||||
|     tab[3] = ' '; | ||||
|   } | ||||
| 	 | ||||
|   LCD_GLASS_DisplayStrDeci(tab); | ||||
| } | ||||
| 
 | ||||
| /**
 | ||||
|   * @brief funtion Current measurement in RUN mode | ||||
|   * @caller main and test_icc_RUN | ||||
|   * @param none | ||||
|   * @retval Current (mA) | ||||
|   */  | ||||
| float Icc_RUN(void) | ||||
| { | ||||
|   float Current; | ||||
|   uint16_t MeasurINT; | ||||
|   uint16_t tab[6];	 | ||||
|   /* Get Icc current value in Run mode*/	 | ||||
|   MeasurINT = ADC_Icc_Test(MCU_RUN); | ||||
|   /* Convert value in mA*/	 | ||||
|   Current = MeasurINT * Vdd_appli()/ADC_CONV; | ||||
|   Current *= 100L;  | ||||
|   /* Convert value in ASCII and store it into tab*/ | ||||
|   convert_into_char((uint32_t)(Current), tab); | ||||
|   /* Add unit and decimal point  */ | ||||
|   tab[5] = 'A'; | ||||
|   tab[4] = 'm'; | ||||
|   tab[3] = ' '; | ||||
|   tab[0] |= DOT;  | ||||
|   /* Display mesured value */ | ||||
|   LCD_GLASS_DisplayStrDeci(tab); | ||||
| 	 | ||||
|   return (Current); | ||||
| } | ||||
| 
 | ||||
| /**
 | ||||
|   * @brief funtion Current measurement in SLEEP mode | ||||
|   * @caller main | ||||
|   * @param none | ||||
|   * @retval Current (mA) | ||||
|   */  | ||||
| float Icc_SLEEP(void) | ||||
| { | ||||
|   float Current; | ||||
|   uint16_t MeasurINT; | ||||
|   uint16_t tab[6];	 | ||||
|    | ||||
|   /* Get Icc current value in Sleep mode*/	 | ||||
|   MeasurINT = ADC_Icc_Test(MCU_SLEEP); | ||||
|   /* Substract operational amplifier bias current from value*/ | ||||
|   Current = MeasurINT * Vdd_appli()/ADC_CONV;   | ||||
|   /* Convert value in mA*/	 | ||||
|   Current *= 100L; | ||||
|   /* Convert value in ASCII and store it into tab*/ | ||||
|   convert_into_char((uint32_t)(Current), tab); | ||||
|   /* Add unit and decimal point  */ | ||||
|   tab[5] = 'A'; | ||||
|   tab[4] = 'm'; | ||||
|   tab[3] = ' '; | ||||
|   tab[0] |= DOT;  | ||||
|   /*Display mesured value */ | ||||
|   LCD_GLASS_DisplayStrDeci(tab); | ||||
|   /* Return value in mA*/ | ||||
|   return(Current); | ||||
| } | ||||
| 
 | ||||
| /**
 | ||||
|   * @brief funtion Current measurement in Low power | ||||
|   * @caller main | ||||
|   * @param none | ||||
|   * @retval Current (uA) | ||||
|   */  | ||||
| float Icc_LPRUN(void) | ||||
| { | ||||
|   float Current; | ||||
|   uint16_t MeasurINT; | ||||
| 
 | ||||
|   /* Get Icc current value in Low power mode*/ | ||||
|   MeasurINT = ADC_Icc_Test(MCU_LP_RUN); | ||||
|   /* Substract operational amplifier bias current from value*/ | ||||
|   if ( MeasurINT > Bias_Current ) | ||||
|     MeasurINT -= Bias_Current; | ||||
|   /* Convert value in uA*/	 | ||||
|   Current = MeasurINT * Vdd_appli()/ADC_CONV;   | ||||
|   Current *= 20L; | ||||
|   /* Display mesured value */ | ||||
|   display_MuAmp((uint32_t)Current); | ||||
|   /* Return value in uA*/	 | ||||
|   return(Current); | ||||
| } | ||||
| 
 | ||||
| /**
 | ||||
|   * @brief funtion Current measurement in Low power | ||||
|   * @caller main | ||||
|   * @param none | ||||
|   * @retval Current (µA) | ||||
|   */  | ||||
| float Icc_LPSLEEP(void) | ||||
| { | ||||
|   float Current; | ||||
|   uint16_t MeasurINT; | ||||
|   /* Get Icc current value in Low power sleep mode*/ | ||||
|   MeasurINT = ADC_Icc_Test(MCU_LP_SLEEP); | ||||
|   /* Substract operational amplifier bias current from value*/ | ||||
|   if ( MeasurINT > Bias_Current ) | ||||
|     MeasurINT -= Bias_Current; | ||||
|   /* Convert value in uA*/ | ||||
|   Current = MeasurINT * Vdd_appli()/ADC_CONV;   | ||||
|   Current *= 20L; | ||||
|   /* Test if value is correct */ | ||||
|   if ((int) Current<MAX_CURRENT) | ||||
|   { | ||||
|     /* if correct : Display mesured value */ | ||||
|     display_MuAmp((uint32_t)Current); | ||||
|   } else{ | ||||
|     /* if not correct : Display ERROR */ | ||||
|     LCD_GLASS_Clear(); | ||||
|     LCD_GLASS_DisplayString("Error"); | ||||
|   } | ||||
|   /* Return value in uA*/ | ||||
|   return(Current); | ||||
| } | ||||
| 
 | ||||
| /**
 | ||||
|   * @brief funtion Current measurement in Stop mode with LCD ON | ||||
|   * @caller main and test_icc_LCD | ||||
|   * @param none | ||||
|   * @retval Current (µA) | ||||
|   */ | ||||
| float Icc_STOP(void) | ||||
| { | ||||
|   float Current; | ||||
|   uint16_t MeasurINT; | ||||
|    | ||||
|    /* Get Icc current value in STOP mode*/	 | ||||
|   MeasurINT = ADC_Icc_Test(MCU_STOP_RTC);  | ||||
|   /* Substract operational amplifier bias current from value*/ | ||||
|   if ( MeasurINT > Bias_Current ) | ||||
|       MeasurINT -= Bias_Current; | ||||
|   /* Convert value in uA*/ | ||||
|   Current = MeasurINT * Vdd_appli()/ADC_CONV;  | ||||
|   Current *= 20L;  | ||||
|   /* test if value is correct */ | ||||
|   if ((int) Current<MAX_CURRENT) | ||||
|   { | ||||
|     /* if correct : Display mesured value */ | ||||
|     display_MuAmp((uint32_t)Current); | ||||
|   } | ||||
|   else | ||||
|   { | ||||
|     /* if not correct : Display error if not in autotest */ | ||||
|     if (!self_test) | ||||
|     { | ||||
|       LCD_GLASS_Clear(); | ||||
|       LCD_GLASS_DisplayString("Error"); | ||||
|     } | ||||
|   } | ||||
|   /* Return value in uA*/ | ||||
|   return (Current); | ||||
| } | ||||
| 
 | ||||
| /**
 | ||||
|   * @brief funtion Current measurement in Stop mode with LCD OFF | ||||
|   * @caller main | ||||
|   * @param none | ||||
|   * @retval none | ||||
|   */ | ||||
| float Icc_Stop_NoRTC(void) | ||||
| { | ||||
|   float Current; | ||||
|   uint16_t MeasurINT; | ||||
| 	 | ||||
|   /* Get Icc current value in STOP mode with no RTC */	 | ||||
|   MeasurINT = ADC_Icc_Test(MCU_STOP_NoRTC); | ||||
|   /* Substract operational amplifier bias current from value*/ | ||||
|   if ( MeasurINT > Bias_Current ) | ||||
|     MeasurINT -=	Bias_Current; | ||||
|   /* Convert value in uA*/ | ||||
|   Current = MeasurINT * Vdd_appli()/ADC_CONV;  | ||||
|   Current *= 20L; | ||||
|   /* Display mesured value */   | ||||
|   display_MuAmp((uint32_t)Current); | ||||
|   /* Return value in uA*/ | ||||
|   return (Current); | ||||
| }	 | ||||
| 
 | ||||
| /******************* (C) COPYRIGHT 2011 STMicroelectronics *****END OF FILE****/ | ||||
|  | @ -89,7 +89,7 @@ assembler. */ | |||
| 
 | ||||
| /* Set configCREATE_LOW_POWER_DEMO to one to run the simple blinky low power
 | ||||
| demo, or 0 to run the more comprehensive test and demo application. */ | ||||
| #define configCREATE_LOW_POWER_DEMO			0 | ||||
| #define configCREATE_LOW_POWER_DEMO			1 | ||||
| 
 | ||||
| /* A few settings are dependent on the configCREATE_LOW_POWER_DEMO setting. */ | ||||
| #if configCREATE_LOW_POWER_DEMO == 1 | ||||
|  |  | |||
|  | @ -1,126 +0,0 @@ | |||
|  /**
 | ||||
|   ****************************************************************************** | ||||
|   * @file   discover_functions.h | ||||
|   * @author  Microcontroller Division | ||||
|   * @version V1.0.3 | ||||
|   * @date    May-2013 | ||||
|   * @brief   This file contains measurement values and board | ||||
|   ****************************************************************************** | ||||
|   * @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>© COPYRIGHT 2011 STMicroelectronics</center></h2> | ||||
|   */  | ||||
| 
 | ||||
| /* Define to prevent recursive inclusion -------------------------------------*/ | ||||
| #ifndef __DISCOVER_FUNCTIONS_H | ||||
| #define __DISCOVER_FUNCTIONS_H | ||||
| 
 | ||||
| /* Includes ------------------------------------------------------------------*/ | ||||
| #include "stm32l1xx.h"   | ||||
| 
 | ||||
| #define DELAY Delay(150) | ||||
| #define TEMPO if(!KeyPressed) DELAY | ||||
| 
 | ||||
| //#define SLIDER_DETECTED (sMCKeyInfo[0].Setting.b.DETECTED)
 | ||||
| //#define SLIDER_POSITION (sMCKeyInfo[0].UnScaledPosition)
 | ||||
| 
 | ||||
| #define enableGlobalInterrupts()   __set_PRIMASK(0); | ||||
| #define disableGlobalInterrupts()  __set_PRIMASK(1); | ||||
| 
 | ||||
| #define STR_VERSION     tab[1] = 'V';tab[2] = '2'|DOT; tab[3] = '0'|DOT; tab[4] = '4' | ||||
| 
 | ||||
| #define STATE_VREF	        0 | ||||
| #define STATE_SLIDER_VALUE 	1 | ||||
| #define STATE_SLIDER_BUTTON 	2 | ||||
| #define STATE_ICC_RUN 	        3 | ||||
| #define STATE_ICC_LP_RUN        4 | ||||
| #define STATE_ICC_STOP     	5 | ||||
| #define STATE_ICC_STBY  	6 | ||||
| 
 | ||||
| #define MAX_STATE 	        7 | ||||
| 
 | ||||
| 
 | ||||
| /* Theorically BandGAP 1.224volt */ | ||||
| #define VREF 		1.224L | ||||
| 
 | ||||
| 
 | ||||
| /*
 | ||||
| 	ADC Converter  | ||||
| 	LSBIdeal = VREF/4096 or VDA/4096 | ||||
| */ | ||||
| #define ADC_CONV 	4096 | ||||
| 
 | ||||
| /*
 | ||||
|  VDD Factory for VREFINT measurement  | ||||
| */ | ||||
| #define VDD_FACTORY 3.0L | ||||
| 
 | ||||
| #define MAX_CURRENT 	99999 | ||||
| 
 | ||||
| /* AUTO TEST VALUE */ | ||||
| 
 | ||||
| #define VCC_MIN 	2920  /* nominal Vcc/Vdd is 2.99V, allow 2.5% lower - Vref can be ~2% lower than 1.225 */ | ||||
| #define VCC_MAX 	3100 | ||||
| #define ICC_RUN_MIN 	6000 | ||||
| #define ICC_RUN_MAX 	11000 /* typical ICC_RUN is ~0.9mA */ | ||||
| #define ICC_STOP_MIN 	250 | ||||
| #define ICC_STOP_MAX 	800   /* typical ICC_STOP is 0.6uA */ | ||||
| #define ICC_BIAS_MAX    30    /* ! converter value in decimal ! --> 3.0volts/4036* 30 = 21 mV */ | ||||
| 
 | ||||
| #define ICC_STBY_MIN 	150   /* typical ICC_STAND BY is 0.3 uA */ | ||||
| #define ICC_STBY_MAX    450     | ||||
| 
 | ||||
| /* Exported constants --------------------------------------------------------*/ | ||||
| /* Exported macro ------------------------------------------------------------*/ | ||||
| 
 | ||||
| #define AUTOTEST(a) DATA_EEPROM_Unlock();   DATA_EEPROM_FastProgramByte((uint32_t)&self_test,a ) ;  DATA_EEPROM_Lock()	 | ||||
|    | ||||
| /* Exported functions ------------------------------------------------------- */ | ||||
| 
 | ||||
| 
 | ||||
| void  Init_Port (void); | ||||
| void convert_into_char(uint32_t number, uint16_t *p_tab); | ||||
| void LPR_init(void); | ||||
| void Halt_Init(void); | ||||
| uint16_t Vref_measure(void); | ||||
| void Icc_measure(void); | ||||
| float Icc_RUN(void); | ||||
| float Icc_SLEEP(void); | ||||
| float Icc_LPRUN(void); | ||||
| float Icc_LPSLEEP(void); | ||||
| float Icc_STOP(void); | ||||
| float Icc_Stop_NoRTC(void); | ||||
| void Icc_STBY(void); | ||||
| float Icc_STBY_NoRTC(void); | ||||
| void auto_test(void); | ||||
| void Bias_measurement(void); | ||||
| void test_vdd(void); | ||||
| void test_icc_Run(void); | ||||
| void test_icc_STOP(void); | ||||
| void test_icc_STBY(void); | ||||
| void display_MuAmp (uint32_t); | ||||
| void FLASH_ProgramBias(uint8_t) ; | ||||
| float Vdd_appli(void); | ||||
| uint16_t wake_up_measurement (void); | ||||
| void RCC_Configuration(void); | ||||
| void Init_clocks(void); | ||||
| void Init_GPIOs (void); | ||||
| void TimingDelay_Decrement(void); | ||||
| void Delay(uint32_t nTime); | ||||
| void ExtraCode_StateMachine(void); | ||||
| void Config_Systick(void); | ||||
| void Config_Systick_50ms(void);	 | ||||
| void Button_value(void); | ||||
| void Slider_value(void); | ||||
| void auto_test_part2(void); | ||||
| 
 | ||||
| #endif /* __DISCOVER_FUNCTIONS_H*/ | ||||
| 
 | ||||
| /******************* (C) COPYRIGHT 2011 STMicroelectronics *****END OF FILE****/ | ||||
|  | @ -1,6 +1,6 @@ | |||
| /**
 | ||||
|   ****************************************************************************** | ||||
|   * @file    Project/STM32L1xx_StdPeriph_Template/main.h  | ||||
|   * @file    Project/STM32L1xx_StdPeriph_Template/main.h | ||||
|   * @author  MCD Application Team | ||||
|   * @version V1.0.3 | ||||
|   * @date    May-2013 | ||||
|  | @ -17,8 +17,8 @@ | |||
|   * | ||||
|   * <h2><center>© COPYRIGHT 2010 STMicroelectronics</center></h2> | ||||
|   ****************************************************************************** | ||||
|   */  | ||||
|    | ||||
|   */ | ||||
| 
 | ||||
| /* Define to prevent recursive inclusion -------------------------------------*/ | ||||
| #ifndef __MAIN_H | ||||
| #define __MAIN_H | ||||
|  | @ -36,7 +36,6 @@ | |||
| /* discovery board and specific drivers headers*/ | ||||
| #include "discover_board.h" | ||||
| #include "icc_measure.h" | ||||
| #include "discover_functions.h" | ||||
| #include "stm32l_discovery_lcd.h" | ||||
| 
 | ||||
| 
 | ||||
|  |  | |||
|  | @ -1,6 +1,6 @@ | |||
| /**
 | ||||
|   ****************************************************************************** | ||||
|   * @file    Project/STM32L1xx_StdPeriph_Template/stm32l1xx_conf.h  | ||||
|   * @file    Project/STM32L1xx_StdPeriph_Template/stm32l1xx_conf.h | ||||
|   * @author  MCD Application Team | ||||
|   * @version V1.0.3 | ||||
|   * @date    May-2013 | ||||
|  | @ -17,7 +17,7 @@ | |||
|   * | ||||
|   * <h2><center>© COPYRIGHT 2010 STMicroelectronics</center></h2> | ||||
|   ****************************************************************************** | ||||
|   */  | ||||
|   */ | ||||
| 
 | ||||
| /* Define to prevent recursive inclusion -------------------------------------*/ | ||||
| #ifndef __STM32L1xx_CONF_H | ||||
|  | @ -25,31 +25,31 @@ | |||
| 
 | ||||
| /* Includes ------------------------------------------------------------------*/ | ||||
| /* Comment the line below to disable peripheral header file inclusion */ | ||||
| #include "stm32l1xx_adc.h" | ||||
| #include "stm32l1xx_crc.h" | ||||
| #include "stm32l1xx_comp.h" | ||||
| #include "stm32l1xx_dac.h" | ||||
| #include "stm32l1xx_dbgmcu.h" | ||||
| #include "stm32l1xx_dma.h" | ||||
| //#include "stm32l1xx_adc.h"
 | ||||
| //#include "stm32l1xx_crc.h"
 | ||||
| //#include "stm32l1xx_comp.h"
 | ||||
| //#include "stm32l1xx_dac.h"
 | ||||
| //#include "stm32l1xx_dbgmcu.h"
 | ||||
| //#include "stm32l1xx_dma.h"
 | ||||
| #include "stm32l1xx_exti.h" | ||||
| #include "stm32l1xx_flash.h" | ||||
| //#include "stm32l1xx_flash.h"
 | ||||
| #include "stm32l1xx_gpio.h" | ||||
| #include "stm32l1xx_syscfg.h" | ||||
| #include "stm32l1xx_i2c.h" | ||||
| #include "stm32l1xx_iwdg.h" | ||||
| //#include "stm32l1xx_i2c.h"
 | ||||
| //#include "stm32l1xx_iwdg.h"
 | ||||
| #include "stm32l1xx_lcd.h" | ||||
| #include "stm32l1xx_pwr.h" | ||||
| #include "stm32l1xx_rcc.h" | ||||
| #include "stm32l1xx_rtc.h" | ||||
| #include "stm32l1xx_spi.h" | ||||
| //#include "stm32l1xx_spi.h"
 | ||||
| #include "stm32l1xx_tim.h" | ||||
| #include "stm32l1xx_usart.h" | ||||
| #include "stm32l1xx_wwdg.h" | ||||
| //#include "stm32l1xx_usart.h"
 | ||||
| //#include "stm32l1xx_wwdg.h"
 | ||||
| #include "misc.h"  /* High level functions for NVIC and SysTick (add-on to CMSIS functions) */ | ||||
| 
 | ||||
| /* Exported types ------------------------------------------------------------*/ | ||||
| /* Exported constants --------------------------------------------------------*/ | ||||
| /* Uncomment the line below to expanse the "assert_param" macro in the 
 | ||||
| /* Uncomment the line below to expanse the "assert_param" macro in the
 | ||||
|    Standard Peripheral Library drivers code */ | ||||
| /* #define USE_FULL_ASSERT    1 */ | ||||
| 
 | ||||
|  | @ -58,8 +58,8 @@ | |||
| 
 | ||||
| /**
 | ||||
|   * @brief  The assert_param macro is used for function's parameters check. | ||||
|   * @param  expr: If expr is false, it calls assert_failed function which reports  | ||||
|   *         the name of the source file and the source line number of the call  | ||||
|   * @param  expr: If expr is false, it calls assert_failed function which reports | ||||
|   *         the name of the source file and the source line number of the call | ||||
|   *         that failed. If expr is true, it returns no value. | ||||
|   * @retval None | ||||
|   */ | ||||
|  |  | |||
|  | @ -83,7 +83,6 @@ | |||
| /* ST library functions. */ | ||||
| #include "stm32l1xx.h" | ||||
| #include "discover_board.h" | ||||
| #include "discover_functions.h" | ||||
| 
 | ||||
| /*-----------------------------------------------------------*/ | ||||
| 
 | ||||
|  |  | |||
|  | @ -122,7 +122,6 @@ | |||
| /* ST library functions. */ | ||||
| #include "stm32l1xx.h" | ||||
| #include "discover_board.h" | ||||
| #include "discover_functions.h" | ||||
| #include "stm32l_discovery_lcd.h" | ||||
| 
 | ||||
| /* Priorities for the demo application tasks. */ | ||||
|  | @ -150,12 +149,20 @@ in ticks using the portTICK_RATE_MS constant. */ | |||
|  */ | ||||
| static void prvCheckTimerCallback( xTimerHandle xTimer ); | ||||
| 
 | ||||
| /*
 | ||||
|  * Configure the LCD, then write welcome message. | ||||
|  */ | ||||
| static void prvConfigureLCD( void ); | ||||
| 
 | ||||
| /*-----------------------------------------------------------*/ | ||||
| 
 | ||||
| void main_full( void ) | ||||
| { | ||||
| xTimerHandle xCheckTimer = NULL; | ||||
| 
 | ||||
| 	/* The LCD is only used in the Full demo. */ | ||||
| 	prvConfigureLCD(); | ||||
| 
 | ||||
| 	/* Start all the other standard demo/test tasks.  They have not particular
 | ||||
| 	functionality, but do demonstrate how to use the FreeRTOS API and test the | ||||
| 	kernel port. */ | ||||
|  | @ -261,3 +268,68 @@ unsigned long ulErrorFound = pdFALSE; | |||
| } | ||||
| /*-----------------------------------------------------------*/ | ||||
| 
 | ||||
| static void prvConfigureLCD( void ) | ||||
| { | ||||
| GPIO_InitTypeDef GPIO_InitStructure; | ||||
| 
 | ||||
| 	/* Enable necessary clocks. */ | ||||
| 	RCC_AHBPeriphClockCmd( RCC_AHBPeriph_GPIOA | RCC_AHBPeriph_GPIOB | RCC_AHBPeriph_GPIOC, ENABLE ); | ||||
| 	RCC_APB1PeriphClockCmd( RCC_APB1Periph_LCD, ENABLE ); | ||||
| 	PWR_RTCAccessCmd( ENABLE ); | ||||
| 	RCC_LSEConfig( ENABLE ); | ||||
| 	RCC_RTCCLKConfig( RCC_RTCCLKSource_LSE ); | ||||
| 	RCC_RTCCLKCmd( ENABLE ); | ||||
| 
 | ||||
| 	/* Configure Port A LCD Output pins as alternate function. */ | ||||
| 	GPIO_InitStructure.GPIO_Pin = GPIO_Pin_1 | GPIO_Pin_2 | GPIO_Pin_3 | GPIO_Pin_8 | GPIO_Pin_9 |GPIO_Pin_10 |GPIO_Pin_15; | ||||
| 	GPIO_InitStructure.GPIO_Mode = GPIO_Mode_AF; | ||||
| 	GPIO_Init( GPIOA, &GPIO_InitStructure ); | ||||
| 
 | ||||
| 	/* Select LCD alternate function for Port A LCD Output pins. */ | ||||
| 	GPIO_PinAFConfig( GPIOA, GPIO_PinSource1, GPIO_AF_LCD ); | ||||
| 	GPIO_PinAFConfig( GPIOA, GPIO_PinSource2, GPIO_AF_LCD ); | ||||
| 	GPIO_PinAFConfig( GPIOA, GPIO_PinSource3, GPIO_AF_LCD ); | ||||
| 	GPIO_PinAFConfig( GPIOA, GPIO_PinSource8, GPIO_AF_LCD ); | ||||
| 	GPIO_PinAFConfig( GPIOA, GPIO_PinSource9, GPIO_AF_LCD ); | ||||
| 	GPIO_PinAFConfig( GPIOA, GPIO_PinSource10, GPIO_AF_LCD ); | ||||
| 	GPIO_PinAFConfig( GPIOA, GPIO_PinSource15, GPIO_AF_LCD ); | ||||
| 
 | ||||
| 	/* Configure Port B LCD Output pins as alternate function */ | ||||
| 	GPIO_InitStructure.GPIO_Pin = GPIO_Pin_3 | GPIO_Pin_4 | GPIO_Pin_5 | GPIO_Pin_8 | GPIO_Pin_9 | GPIO_Pin_10 | GPIO_Pin_11 | GPIO_Pin_12 | GPIO_Pin_13 | GPIO_Pin_14 | GPIO_Pin_15; | ||||
| 	GPIO_InitStructure.GPIO_Mode = GPIO_Mode_AF; | ||||
| 	GPIO_Init( GPIOB, &GPIO_InitStructure ); | ||||
| 
 | ||||
| 	/* Select LCD alternate function for Port B LCD Output pins */ | ||||
| 	GPIO_PinAFConfig( GPIOB, GPIO_PinSource3, GPIO_AF_LCD ); | ||||
| 	GPIO_PinAFConfig( GPIOB, GPIO_PinSource4, GPIO_AF_LCD ); | ||||
| 	GPIO_PinAFConfig( GPIOB, GPIO_PinSource5, GPIO_AF_LCD ); | ||||
| 	GPIO_PinAFConfig( GPIOB, GPIO_PinSource8, GPIO_AF_LCD ); | ||||
| 	GPIO_PinAFConfig( GPIOB, GPIO_PinSource9, GPIO_AF_LCD ); | ||||
| 	GPIO_PinAFConfig( GPIOB, GPIO_PinSource10, GPIO_AF_LCD ); | ||||
| 	GPIO_PinAFConfig( GPIOB, GPIO_PinSource11, GPIO_AF_LCD ); | ||||
| 	GPIO_PinAFConfig( GPIOB, GPIO_PinSource12, GPIO_AF_LCD ); | ||||
| 	GPIO_PinAFConfig( GPIOB, GPIO_PinSource13, GPIO_AF_LCD ); | ||||
| 	GPIO_PinAFConfig( GPIOB, GPIO_PinSource14, GPIO_AF_LCD ); | ||||
| 	GPIO_PinAFConfig( GPIOB, GPIO_PinSource15, GPIO_AF_LCD ); | ||||
| 
 | ||||
| 	/* Configure Port C LCD Output pins as alternate function */ | ||||
| 	GPIO_InitStructure.GPIO_Pin = GPIO_Pin_0 | GPIO_Pin_1 | GPIO_Pin_2 | GPIO_Pin_3 | GPIO_Pin_6 | GPIO_Pin_7 | GPIO_Pin_8 | GPIO_Pin_9 | GPIO_Pin_10 |GPIO_Pin_11 ; | ||||
| 	GPIO_InitStructure.GPIO_Mode = GPIO_Mode_AF; | ||||
| 	GPIO_Init( GPIOC, &GPIO_InitStructure ); | ||||
| 
 | ||||
| 	/* Select LCD alternate function for Port B LCD Output pins */ | ||||
| 	GPIO_PinAFConfig( GPIOC, GPIO_PinSource0, GPIO_AF_LCD ); | ||||
| 	GPIO_PinAFConfig( GPIOC, GPIO_PinSource1, GPIO_AF_LCD ); | ||||
| 	GPIO_PinAFConfig( GPIOC, GPIO_PinSource2, GPIO_AF_LCD ); | ||||
| 	GPIO_PinAFConfig( GPIOC, GPIO_PinSource3, GPIO_AF_LCD ); | ||||
| 	GPIO_PinAFConfig( GPIOC, GPIO_PinSource6, GPIO_AF_LCD ); | ||||
| 	GPIO_PinAFConfig( GPIOC, GPIO_PinSource7, GPIO_AF_LCD ); | ||||
| 	GPIO_PinAFConfig( GPIOC, GPIO_PinSource8, GPIO_AF_LCD ); | ||||
| 	GPIO_PinAFConfig( GPIOC, GPIO_PinSource9, GPIO_AF_LCD ); | ||||
| 	GPIO_PinAFConfig( GPIOC, GPIO_PinSource10, GPIO_AF_LCD ); | ||||
| 	GPIO_PinAFConfig( GPIOC, GPIO_PinSource11, GPIO_AF_LCD ); | ||||
| 
 | ||||
| 	LCD_GLASS_Init(); | ||||
| 	LCD_GLASS_DisplayString( "F'RTOS" ); | ||||
| } | ||||
| 
 | ||||
|  |  | |||
|  | @ -156,7 +156,6 @@ | |||
| /* ST library functions. */ | ||||
| #include "stm32l1xx.h" | ||||
| #include "discover_board.h" | ||||
| #include "discover_functions.h" | ||||
| #include "stm32l_discovery_lcd.h" | ||||
| 
 | ||||
| /* Priorities at which the Rx and Tx tasks are created. */ | ||||
|  |  | |||
|  | @ -24,7 +24,6 @@ | |||
| #include "stm32l1xx_it.h" | ||||
| #include "stm32l1xx_exti.h" | ||||
| #include "stm32l1xx_rtc.h" | ||||
| #include "discover_functions.h" | ||||
| #include "discover_board.h" | ||||
| #include "stm32l_discovery_lcd.h" | ||||
| #include "tsl.h" | ||||
|  |  | |||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue