2 ******************************************************************************
\r
3 * @file stm32f10x_dbgmcu.c
\r
4 * @author MCD Application Team
\r
6 * @date 11-March-2011
\r
7 * @brief This file provides all the DBGMCU firmware functions.
\r
8 ******************************************************************************
\r
11 * THE PRESENT FIRMWARE WHICH IS FOR GUIDANCE ONLY AIMS AT PROVIDING CUSTOMERS
\r
12 * WITH CODING INFORMATION REGARDING THEIR PRODUCTS IN ORDER FOR THEM TO SAVE
\r
13 * TIME. AS A RESULT, STMICROELECTRONICS SHALL NOT BE HELD LIABLE FOR ANY
\r
14 * DIRECT, INDIRECT OR CONSEQUENTIAL DAMAGES WITH RESPECT TO ANY CLAIMS ARISING
\r
15 * FROM THE CONTENT OF SUCH FIRMWARE AND/OR THE USE MADE BY CUSTOMERS OF THE
\r
16 * CODING INFORMATION CONTAINED HEREIN IN CONNECTION WITH THEIR PRODUCTS.
\r
18 * <h2><center>© COPYRIGHT 2011 STMicroelectronics</center></h2>
\r
19 ******************************************************************************
\r
22 /* Includes ------------------------------------------------------------------*/
\r
23 #include "stm32f10x_dbgmcu.h"
\r
25 /** @addtogroup STM32F10x_StdPeriph_Driver
\r
29 /** @defgroup DBGMCU
\r
30 * @brief DBGMCU driver modules
\r
34 /** @defgroup DBGMCU_Private_TypesDefinitions
\r
42 /** @defgroup DBGMCU_Private_Defines
\r
46 #define IDCODE_DEVID_MASK ((uint32_t)0x00000FFF)
\r
51 /** @defgroup DBGMCU_Private_Macros
\r
59 /** @defgroup DBGMCU_Private_Variables
\r
67 /** @defgroup DBGMCU_Private_FunctionPrototypes
\r
75 /** @defgroup DBGMCU_Private_Functions
\r
80 * @brief Returns the device revision identifier.
\r
82 * @retval Device revision identifier
\r
84 uint32_t DBGMCU_GetREVID(void)
\r
86 return(DBGMCU->IDCODE >> 16);
\r
90 * @brief Returns the device identifier.
\r
92 * @retval Device identifier
\r
94 uint32_t DBGMCU_GetDEVID(void)
\r
96 return(DBGMCU->IDCODE & IDCODE_DEVID_MASK);
\r
100 * @brief Configures the specified peripheral and low power mode behavior
\r
101 * when the MCU under Debug mode.
\r
102 * @param DBGMCU_Periph: specifies the peripheral and low power mode.
\r
103 * This parameter can be any combination of the following values:
\r
104 * @arg DBGMCU_SLEEP: Keep debugger connection during SLEEP mode
\r
105 * @arg DBGMCU_STOP: Keep debugger connection during STOP mode
\r
106 * @arg DBGMCU_STANDBY: Keep debugger connection during STANDBY mode
\r
107 * @arg DBGMCU_IWDG_STOP: Debug IWDG stopped when Core is halted
\r
108 * @arg DBGMCU_WWDG_STOP: Debug WWDG stopped when Core is halted
\r
109 * @arg DBGMCU_TIM1_STOP: TIM1 counter stopped when Core is halted
\r
110 * @arg DBGMCU_TIM2_STOP: TIM2 counter stopped when Core is halted
\r
111 * @arg DBGMCU_TIM3_STOP: TIM3 counter stopped when Core is halted
\r
112 * @arg DBGMCU_TIM4_STOP: TIM4 counter stopped when Core is halted
\r
113 * @arg DBGMCU_CAN1_STOP: Debug CAN2 stopped when Core is halted
\r
114 * @arg DBGMCU_I2C1_SMBUS_TIMEOUT: I2C1 SMBUS timeout mode stopped when Core is halted
\r
115 * @arg DBGMCU_I2C2_SMBUS_TIMEOUT: I2C2 SMBUS timeout mode stopped when Core is halted
\r
116 * @arg DBGMCU_TIM5_STOP: TIM5 counter stopped when Core is halted
\r
117 * @arg DBGMCU_TIM6_STOP: TIM6 counter stopped when Core is halted
\r
118 * @arg DBGMCU_TIM7_STOP: TIM7 counter stopped when Core is halted
\r
119 * @arg DBGMCU_TIM8_STOP: TIM8 counter stopped when Core is halted
\r
120 * @arg DBGMCU_CAN2_STOP: Debug CAN2 stopped when Core is halted
\r
121 * @arg DBGMCU_TIM15_STOP: TIM15 counter stopped when Core is halted
\r
122 * @arg DBGMCU_TIM16_STOP: TIM16 counter stopped when Core is halted
\r
123 * @arg DBGMCU_TIM17_STOP: TIM17 counter stopped when Core is halted
\r
124 * @arg DBGMCU_TIM9_STOP: TIM9 counter stopped when Core is halted
\r
125 * @arg DBGMCU_TIM10_STOP: TIM10 counter stopped when Core is halted
\r
126 * @arg DBGMCU_TIM11_STOP: TIM11 counter stopped when Core is halted
\r
127 * @arg DBGMCU_TIM12_STOP: TIM12 counter stopped when Core is halted
\r
128 * @arg DBGMCU_TIM13_STOP: TIM13 counter stopped when Core is halted
\r
129 * @arg DBGMCU_TIM14_STOP: TIM14 counter stopped when Core is halted
\r
130 * @param NewState: new state of the specified peripheral in Debug mode.
\r
131 * This parameter can be: ENABLE or DISABLE.
\r
134 void DBGMCU_Config(uint32_t DBGMCU_Periph, FunctionalState NewState)
\r
136 /* Check the parameters */
\r
137 assert_param(IS_DBGMCU_PERIPH(DBGMCU_Periph));
\r
138 assert_param(IS_FUNCTIONAL_STATE(NewState));
\r
140 if (NewState != DISABLE)
\r
142 DBGMCU->CR |= DBGMCU_Periph;
\r
146 DBGMCU->CR &= ~DBGMCU_Periph;
\r
162 /******************* (C) COPYRIGHT 2011 STMicroelectronics *****END OF FILE****/
\r