国产毛片a精品毛-国产毛片黄片-国产毛片久久国产-国产毛片久久精品-青娱乐极品在线-青娱乐精品

如何使用STM32的PVD對電源的電壓進(jìn)行監(jiān)控

發(fā)布時間:2009-11-25 17:28    發(fā)布者:STM32
關(guān)鍵詞: PVD , 電壓 , 電源
用戶在使用STM32時,可以利用其內(nèi)部的PVD對VDD的電壓進(jìn)行監(jiān)控,通過電源控制寄存器(PWR_CR)中的PLS[2:0]位來設(shè)定監(jiān)控的電壓值。

PLS[2:0]位用于選擇PVD監(jiān)控電源的電壓閥值:

000:2.2V
001:2.3V
010:2.4V
011:2.5V
100:2.6V
101:2.7V
110:2.8V
111:2.9V

在電源控制/狀態(tài)寄存器(PWR_CSR)中的PVDO標(biāo)志用來表明VDD是高于還是低于PVD設(shè)定的電壓閥值。該事件連接到外部中斷的第16線,如果該中斷在外部中斷寄存器中被使能的,該事件就會產(chǎn)生中斷。當(dāng)VDD下降到PVD閥值以下和(或)當(dāng)VDD上升到PVD閥值之上時,根據(jù)外部中斷第16 線的上升/下降邊沿觸發(fā)設(shè)置,就會產(chǎn)生PVD中斷。這一特性可用于發(fā)現(xiàn)電壓出現(xiàn)異常時,執(zhí)行緊急關(guān)閉任務(wù)。

下面是用于測試PVD的代碼:

主程序的代碼:

/* Includes ------------------------------------------------------------------*/
#include "stm32f10x_lib.h"
/* Private typedef -----------------------------------------------------------*/
typedef enum {FAILED = 0, PASSED = !FAILED} TestStatus;
/* Private define ------------------------------------------------------------*/
/* Private macro -------------------------------------------------------------*/
/* Private variables ---------------------------------------------------------*/
ErrorStatus HSEStartUpStatus;
/* Private function prototypes -----------------------------------------------*/
void RCC_Configuration(void);
void GPIO_Configuration(void);
void EXTI_Configuration(void);
void NVIC_Configuration(void);
/* Private functions ---------------------------------------------------------*/
STM32 中文應(yīng)用文檔
/*****************************************************************************
* Function Name : main
* Description : Main program
* Input : None
* Output : None
* Return : None
******************************************************************************/
int main(void)
{
RCC_Configuration(); /* System Clocks Configuration */
GPIO_Configuration(); /* Configure the GPIO ports */
NVIC_Configuration(); /* NVIC configuration */
EXTI_Configuration();
PWR_PVDLevelConfig(PWR_PVDLevel_2V8);
PWR_PVDCmd(ENABLE);
while(1) {}
}
/*******************************************************************
* Function Name : RCC_Configuration
* Description : Configures the different system clocks.
* Input : None
* Output : None
* Return : None
********************************************************************/
void RCC_Configuration(void)
{
RCC_DeInit(); // RCC system reset(for debug purpose)
RCC_HSEConfig(RCC_HSE_ON); // Enable HSE
HSEStartUpStatus = RCC_WaitForHSEStartUp(); // Wait till HSE is ready
if(HSEStartUpStatus == SUCCESS) {
RCC_HCLKConfig(RCC_SYSCLK_Div1); // HCLK = SYSCLK
RCC_PCLK2Config(RCC_HCLK_Div1); // PCLK2 = HCLK
RCC_PCLK1Config(RCC_HCLK_Div1); // PCLK1 = HCLK/2
FLASH_SetLatency(FLASH_Latency_2); // Flash 2 wait state
FLASH_PrefetchBufferCmd(FLASH_PrefetchBuffer_Enable); // Enable Prefetch Buffer
RCC_PLLConfig(RCC_PLLSource_HSE_Div1, RCC_PLLMul_9); // PLLCLK = 8MHz * 9 = 72 MHz
RCC_PLLCmd(ENABLE); // Enable PLL
while(RCC_GetFlagStatus(RCC_FLAG_PLLRDY) == RESET) {} // Wait till PLL is ready
RCC_SYSCLKConfig(RCC_SYSCLKSource_PLLCLK); // Select PLL as system clock source
while(RCC_GetSYSCLKSource() != 0x08) {} // Wait till PLL is used as system clock source
}
RCC_APB2PeriphClockCmd(RCC_APB2Periph_GPIOB, ENABLE);
RCC_APB1PeriphClockCmd(RCC_APB1Periph_PWR, ENABLE);
}
STM32 中文應(yīng)用文檔
/****************************************************************
* Function Name : GPIO_Configuration
* Description : Configures the different GPIO ports.
* Input : None
* Output : None
* Return : None
****************************************************************/
void GPIO_Configuration(void)
{
GPIO_InitTypeDef GPIO_InitStructure;
GPIO_InitStructure.GPIO_Pin = GPIO_Pin_5|GPIO_Pin_6|GPIO_Pin_7|GPIO_Pin_8;
GPIO_InitStructure.GPIO_Speed = GPIO_Speed_50MHz;
GPIO_InitStructure.GPIO_Mode = GPIO_Mode_OUT_PP;
GPIO_Init(GPIOB, &GPIO_InitStructure); //GPIO B
}
/*******************************************************************
* Function Name : EXTI_Configuration
* Description : Configures .
* Input : None
* Output : None
* Return : None
********************************************************************/
void EXTI_Configuration(void)
{
EXTI_InitTypeDef EXTI_InitStructure;
EXTI_DeInit();
EXTI_StructInit(&EXTI_InitStructure);
EXTI_InitStructure.EXTI_Line = EXTI_Line16;
EXTI_InitStructure.EXTI_Mode = EXTI_Mode_Interrupt;
EXTI_InitStructure.EXTI_Trigger = EXTI_Trigger_Rising_Falling;
EXTI_InitStructure.EXTI_LineCmd = ENABLE;
EXTI_Init(&EXTI_InitStructure); // Configure EXTI Line16 to generate an interrupt
}
/***************************************************************************
* Function Name : NVIC_Configuration
* Description : Configures Vector Table base location.
* Input : None
* Output : None
* Return : None
**************************************************************************/
void NVIC_Configuration(void)
{
NVIC_InitTypeDef NVIC_InitStructure;
#ifdef VECT_TAB_RAM
/* Set the Vector Table base location at 0x20000000 */
NVIC_SetVectorTable(NVIC_VectTab_RAM, 0x0);
#else /* VECT_TAB_FLASH */
/* Set the Vector Table base location at 0x08000000 */
NVIC_SetVectorTable(NVIC_VectTab_FLASH, 0x0);
#endif
STM32 中文應(yīng)用文檔
NVIC_PriorityGroupConfig(NVIC_PriorityGroup_1); // Configure one bit for preemption priority
NVIC_InitStructure.NVIC_IRQChannel = PVD_IRQChannel;
NVIC_InitStructure.NVIC_IRQChannelPreemptionPriority = 2;
NVIC_InitStructure.NVIC_IRQChannelSubPriority = 0;
NVIC_InitStructure.NVIC_IRQChannelCmd = ENABLE;
NVIC_Init(&NVIC_InitStructure); // Enable the PVD Interrupt
}
中斷程序:
/**************************************************************************
* Function Name : PVD_IRQHandler
* Description : This function handles PVD interrupt request.
* Input : None
* Output : None
* Return : None
***************************************************************************/
void PVD_IRQHandler(void)
{
if (PWR_GetFlagStatus(PWR_FLAG_PVDO))
GPIO_WriteBit(GPIOB, 1 << 5, Bit_SET);
else
GPIO_WriteBit(GPIOB, 1 << 5, Bit_RESET);
}

注:在void EXTI_Configuration(void)中,對于EXTI_InitStructure.EXTI_Trigger = EXTI_Trigger_Rising_Falling; 中的初始化值,根據(jù)你的需要進(jìn)行修改,具體細(xì)節(jié)如下:

EXTI_Trigger_Rising --- 表示電壓從高電壓下降到低于設(shè)定的電壓閥值產(chǎn)生中斷;
EXTI_Trigger_Falling --- 表示電壓從低電壓上升到高于設(shè)定的電壓閥值產(chǎn)生中斷;
EXTI_Trigger_Rising_Falling --- 表示電壓從高電壓下降到低于設(shè)定的電壓閥值、或從低電壓上升到高于設(shè)定的電壓閥值產(chǎn)生中斷。

本文PDF格式: 1.pdf (66.5 KB)

最初發(fā)表日期:2008-7-16
本文地址:http://m.qingdxww.cn/thread-5765-1-1.html     【打印本頁】

本站部分文章為轉(zhuǎn)載或網(wǎng)友發(fā)布,目的在于傳遞和分享信息,并不代表本網(wǎng)贊同其觀點(diǎn)和對其真實(shí)性負(fù)責(zé);文章版權(quán)歸原作者及原出處所有,如涉及作品內(nèi)容、版權(quán)和其它問題,我們將根據(jù)著作權(quán)人的要求,第一時間更正或刪除。
您需要登錄后才可以發(fā)表評論 登錄 | 立即注冊

廠商推薦

  • Microchip視頻專區(qū)
  • 使用SAM-IoT Wx v2開發(fā)板演示AWS IoT Core應(yīng)用程序
  • 使用Harmony3加速TCP/IP應(yīng)用的開發(fā)培訓(xùn)教程
  • 集成高級模擬外設(shè)的PIC18F-Q71家族介紹培訓(xùn)教程
  • 探索PIC16F13145 MCU系列——快速概覽
  • 貿(mào)澤電子(Mouser)專區(qū)

相關(guān)在線工具

相關(guān)視頻

關(guān)于我們  -  服務(wù)條款  -  使用指南  -  站點(diǎn)地圖  -  友情鏈接  -  聯(lián)系我們
電子工程網(wǎng) © 版權(quán)所有   京ICP備16069177號 | 京公網(wǎng)安備11010502021702
快速回復(fù) 返回頂部 返回列表
主站蜘蛛池模板: 日本视频免费高清一本18 | 成品人app软件大全免费下载 | 亚洲欧美天堂网 | 欧美亚洲综合另类 | 色成人综合网 | 国产一区二区精品久久91 | 欧美卡1卡2卡三卡网站入口 | 爱爱喷水 | 福利网站污 | 欧美三级视频在线播放 | 97免费视频在线观看 | 亚洲欧洲日韩在线 | 中文字幕一区二区在线视频 | 香蕉视频一区二区三区 | 日本免费无遮挡吸乳视频中文 | 免费一级特黄3大片视频 | 国产精品1区2区3区在线播放 | 久久综合九色欧美综合狠狠 | 日韩欧美亚洲国产高清在线 | 久久精品影院一区二区三区 | 欧美手机手机在线视频一区 | 亚洲午夜久久久久久91 | 亚洲最大在线 | 国内外成人免费在线视频 | 日韩在线视频一区二区三区 | 日韩精品成人在线 | 久久久久久久国产a∨ | 自拍偷拍2019 | 蜜臀首页 | 久久精品国产亚洲综合色 | 一区二区三区四区精品视频 | 玖玖精品在线观看 | 成年女人18毛片毛片免费 | 久久99国产精品免费观看 | 精品欧美一区二区三区在线观看 | 亚洲国产亚洲片在线观看播放 | 四虎影院最新地址 | 国产精品欧美在线不卡 | 久久99蜜桃精品久久久久小说 | 中文字幕一区二区在线观看 | 国产福利在线观看一区二区 |