历史上的今天
返回首页

历史上的今天

今天是:2025年05月14日(星期三)

正在发生

2018年05月14日 | stm32休眠 以及休眠中如何喂狗

2018-05-14 来源:eefocus

在STM32开发中经常会用到独立看门狗(IWDG)和低功耗模式,看门狗是为了检测和解决由软件错误引起的故障,低功耗模式是为了在CPU不需要继续运行时进入到休眠模式用以节省电能。其中独立看门狗的时钟由独立的RC振荡器(STM32F10x一般为40kHz)提供,即使在主时钟出现故障时,也仍然有效,因此可以在停止和待机模式下工作。而且独立看门狗一旦启动,除了系统复位,它不能再被停止。但这样引发的一个问题是当MCU进入到低功耗模式后由于CPU停止运行无法喂狗,会导致系统频繁复位。那如何解决这个问题呢,难道独立看门狗和低功耗模式没法同时使用?

一个很好的方式是在休眠模式下通过RTC定时唤醒来喂狗,喂完够在进入继续进入到休眠模式。比如看门狗复位的时间间隔为10s。那么在进入休眠模式前设置RTC闹钟中断时间为5s。这样每隔5s唤醒一次喂一次狗。便可以很好的解决这个问题。


while(1)  

  {  

    // 执行任务  

    Task1();  

    Task2();  

    // ..  

  

    // 喂狗  

    dev_iwdg_feed();  

  

    // 进入待机模式开关  

    if(m_bEnterStandByMode)  

    {     

        // 使能外部中断,GPIOB3,用以MCU从待机模式唤醒  

        dev_exti_enable(TRUE);  

ENTERSTOPMODE:    

        // 设置RTC闹钟,5秒钟产生一次RTC闹钟中断*/  

        dev_rtc_setAlarm(5);  

      

        // 进入停止模式(低功耗),直至外部中断触发时被唤醒  

        PWR_EnterSTOPMode(PWR_Regulator_LowPower, PWR_STOPEntry_WFI);  

      

        // 是否是RTC闹钟中断唤醒  

        if(dev_rtc_isAlarm())  

        {  

            // 喂狗  

            dev_iwdg_feed();  

            // 喂完狗继续进入停止模式  

            goto ENTERSTOPMODE;   

        }  

        // 禁止外部中断   

        dev_exti_enable(FALSE);  

        // 从停止模式唤醒后恢复系统时钟  

        dev_clk_restore();  

    }               

  }  

以下是完整的代码:


//**********************************************************************************************       

//  STM32F10x StopMode RTC Feed Dog   

//  compiler: Keil UV3       

//  2013-01-04 , By friehood       

//**********************************************************************************************    

#include "stm32f10x_lib.h"  

#include "platform_config.h"  

static Boolean g_bRTCAlarm = FALSE;  

  

/*******************************************************************************  

* Function Name  : RCC_Configuration  

* Description    : Configures the different system clocks.  

* Input          : None  

* Output         : None  

* Return         : None  

*******************************************************************************/  

void RCC_Configuration(void)  

{  

    /* RCC system reset(for debug purpose) */  

    RCC_DeInit();  

  

    /* Enable HSE */  

    RCC_HSEConfig(RCC_HSE_ON);  

  

    /* Wait till HSE is ready */  

    if(RCC_WaitForHSEStartUp() == SUCCESS)  

    {  

        /* Enable Prefetch Buffer */  

        FLASH_PrefetchBufferCmd(FLASH_PrefetchBuffer_Enable);  

  

        //FLASH时序控制   

        //推荐值:SYSCLK = 0~24MHz   Latency=0   

        //        SYSCLK = 24~48MHz  Latency=1   

        //        SYSCLK = 48~72MHz  Latency=2  

        //FLASH_SetLatency(FLASH_Latency_1);        //警告:修改为1会对DMA值有影响(如ADC采集值会错位)  

        FLASH_SetLatency(FLASH_Latency_2);  

  

        /* HCLK = SYSCLK */  

        RCC_HCLKConfig(RCC_SYSCLK_Div1);   

  

        /* PCLK2 = HCLK */  

        RCC_PCLK2Config(RCC_HCLK_Div1);   

  

        /* PCLK1 = HCLK/2 */  

        RCC_PCLK1Config(RCC_HCLK_Div2);  

  

        /* PLLCLK = 12MHz * 3 = 36 MHz */  

        RCC_PLLConfig(RCC_PLLSource_HSE_Div1, RCC_PLLMul_3);  

  

        /* Enable PLL */   

        RCC_PLLCmd(ENABLE);  

  

        /* Wait till PLL is ready */  

        while(RCC_GetFlagStatus(RCC_FLAG_PLLRDY) == RESET)  

        {  

        }  

  

        /* Select PLL as system clock source */  

        RCC_SYSCLKConfig(RCC_SYSCLKSource_PLLCLK);  

  

        /* Wait till PLL is used as system clock source */  

        while(RCC_GetSYSCLKSource() != 0x08)  

        {  

        }  

    }  

    /* Enable PWR and BKP clock */  

    RCC_APB1PeriphClockCmd(RCC_APB1Periph_PWR | RCC_APB1Periph_BKP, ENABLE);  

  

    /* Enable AFIO clock */  

    RCC_APB2PeriphClockCmd(RCC_APB2Periph_AFIO, ENABLE);  

}  

  

/******************************************************************************* 

* Function Name  : NVIC_Configuration 

* Description    : Configures the nested vectored interrupt controller. 

* 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  

  

  /* Configure one bit for preemption priority */  

  NVIC_PriorityGroupConfig(NVIC_PriorityGroup_1);  

}  

  

/******************************************************************************* 

* Function Name  : SysTick_Configuration 

* Description    : Configures the SysTick to generate an interrupt each 1 millisecond. 

* Input          : None 

* Output         : None 

* Return         : None 

*******************************************************************************/  

void SysTick_Configuration(void)  

{  

  /* Select AHB clock(HCLK) as SysTick clock source */  

  SysTick_CLKSourceConfig(SysTick_CLKSource_HCLK);  

  

  /* Set SysTick Priority to 3 */  

  NVIC_SystemHandlerPriorityConfig(SystemHandler_SysTick, 3, 0);  

     

  /* SysTick interrupt each 1ms with HCLK equal to 72MHz */  

  SysTick_SetReload(72000);  

  

  /* Enable the SysTick Interrupt */  

  SysTick_ITConfig(ENABLE);  

}  

  

/******************************************************************************* 

* Function Name  : Delay 

* Description    : Inserts a delay time. 

* Input          : nTime: specifies the delay time length, in milliseconds. 

* Output         : None 

* Return         : None 

*******************************************************************************/  

void Delay(u32 nTime)  

{  

  /* Enable the SysTick Counter */  

  SysTick_CounterCmd(SysTick_Counter_Enable);  

    

  TimingDelay = nTime;  

  

  while(TimingDelay != 0);  

  

  /* Disable the SysTick Counter */  

  SysTick_CounterCmd(SysTick_Counter_Disable);  

  /* Clear the SysTick Counter */  

  SysTick_CounterCmd(SysTick_Counter_Clear);  

}  

  

  

/******************************************************************************* 

* Function Name  : RTC_Configuration 

* Description    : Configures RTC clock source and prescaler. 

* Input          : None 

* Output         : None 

* Return         : None 

*******************************************************************************/  

void RTC_Configuration(void)  

{  

    EXTI_InitTypeDef EXTI_InitStructure;  

    NVIC_InitTypeDef NVIC_InitStructure;  

      

    /* RTC clock source configuration ------------------------------------------*/  

    /* Allow access to BKP Domain */  

    PWR_BackupAccessCmd(ENABLE);  

  

    /* Reset Backup Domain */  

    BKP_DeInit();  

  

    /* Enable the LSI OSC */  

    RCC_LSICmd(ENABLE);  

  

    /* Wait till LSI is ready */  

    while (RCC_GetFlagStatus(RCC_FLAG_LSIRDY) == RESET){}  

      

    /* Select the RTC Clock Source */  

    RCC_RTCCLKConfig(RCC_RTCCLKSource_LSI);  

  

    /* Enable the RTC Clock */  

    RCC_RTCCLKCmd(ENABLE);  

  

    /* RTC configuration -------------------------------------------------------*/  

    /* Wait for RTC APB registers synchronisation */  

    RTC_WaitForSynchro();  

  

    /* Set RTC prescaler: set RTC period to 1sec */  

    RTC_SetPrescaler(40000);  

      

    /* Wait until last write operation on RTC registers has finished */  

    RTC_WaitForLastTask();  

  

    /* Enable the RTC Alarm interrupt */  

    RTC_ITConfig(RTC_IT_ALR, ENABLE);  

      

    /* Wait until last write operation on RTC registers has finished */  

    RTC_WaitForLastTask();  

  

    /* Configure EXTI Line17(RTC Alarm) to generate an interrupt on rising edge */  

    EXTI_ClearITPendingBit(EXTI_Line17);  

    EXTI_InitStructure.EXTI_Line = EXTI_Line17;  

    EXTI_InitStructure.EXTI_Mode = EXTI_Mode_Interrupt;  

    EXTI_InitStructure.EXTI_Trigger = EXTI_Trigger_Rising;  

    EXTI_InitStructure.EXTI_LineCmd = ENABLE;  

    EXTI_Init(&EXTI_InitStructure);  

  

    /* Enable the RTC Interrupt */  

    NVIC_InitStructure.NVIC_IRQChannel = RTCAlarm_IRQChannel;  

    NVIC_InitStructure.NVIC_IRQChannelPreemptionPriority = 0;  

    NVIC_InitStructure.NVIC_IRQChannelSubPriority = 0;  

    NVIC_InitStructure.NVIC_IRQChannelCmd = ENABLE;  

    NVIC_Init(&NVIC_InitStructure);  

}  

  

/******************************************************************************* 

* Function Name  : RTCAlarm_IRQHandler 

* Description    : This function handles RTC Alarm interrupt request. 

* Input          : None 

* Output         : None 

* Return         : None 

*******************************************************************************/  

void RTCAlarm_IRQHandler(void)  

{  

    if(RTC_GetITStatus(RTC_IT_ALR) != RESET)  

    {  

        /* Set the RTC alarm flag */  

        g_bRTCAlarm = TRUE;  

  

        /* Clear EXTI line17 pending bit */  

        EXTI_ClearITPendingBit(EXTI_Line17);  

  

        /* Check if the Wake-Up flag is set */  

        if(PWR_GetFlagStatus(PWR_FLAG_WU) != RESET)  

        {  

            /* Clear Wake Up flag */  

            PWR_ClearFlag(PWR_FLAG_WU);  

        }                                                                         

                                                           

        /* Wait until last write operation on RTC registers has finished */  

        RTC_WaitForLastTask();     

        /* Clear RTC Alarm interrupt pending bit */  

        RTC_ClearITPendingBit(RTC_IT_ALR);  

        /* Wait until last write operation on RTC registers has finished */  

        RTC_WaitForLastTask();  

    }  

}  

  

/******************************************************************************* 

* Function Name  : dev_rtc_setAlarm 

* Description    : 设置RTC闹钟. 

* Input          : 闹钟时间 

* Output         : None 

* Return         : None 

*******************************************************************************/  

void dev_rtc_setAlarm(u32 AlarmValue)  

{  

    /* Clear the RTC SEC flag */  

    RTC_ClearFlag(RTC_FLAG_SEC);  

    /* Wait clear RTC flag sccess */  

    while(RTC_GetFlagStatus(RTC_FLAG_SEC) == RESET);  

    /* Wait until last write operation on RTC registers has finished */  

    RTC_WaitForLastTask();   

  

    /* Sets the RTC alarm value */  

    RTC_SetAlarm(RTC_GetCounter() + AlarmValue);  

    /* Wait until last write operation on RTC registers has finished */  

    RTC_WaitForLastTask();   

}  

  

/******************************************************************************* 

* Function Name  : dev_rtc_isAlarm 

* Description    : RTC闹钟是否触发 

* Input          : None 

* Output         : None 

* Return         : TRUE:已触发,FALSE,未触发 

*******************************************************************************/  

Boolean dev_rtc_isAlarm(void)  

{  

    if(g_bRTCAlarm)  

    {  

        /* Clear the RTC alarm flag */  

        g_bRTCAlarm = FALSE;  

        return TRUE;  

    }  

    return FALSE;             

}  

  

void dev_iwdg_init(void)  

{  

    /* Enable write access to IWDG_PR and IWDG_RLR registers */  

    IWDG_WriteAccessCmd(IWDG_WriteAccess_Enable);  

    /* IWDG counter clock: 40KHz(LSI) / 256 = 0.15625 KHz */  

    IWDG_SetPrescaler(IWDG_Prescaler_256);  

    /* Set counter reload value to 1562 */  

    IWDG_SetReload(1562);   // 10s  

    /* Reload IWDG counter */  

    IWDG_ReloadCounter();  

    /* Enable IWDG (the LSI oscillator will be enabled by hardware) */  

    IWDG_Enable();  

}  

  

void dev_iwdg_feed(void)  

{  

    IWDG_ReloadCounter();  

}  

  

/******************************************************************************* 

* Function Name  : dev_clk_restore 

* Description    : Restore system clock after wake-up from STOP: enable HSE, PLL 

*                  and select PLL as system clock source. 

* Input          : None 

* Output         : None 

* Return         : None 

*******************************************************************************/  

void dev_clk_restore(void)  

{  

  /* Enable HSE */  

  RCC_HSEConfig(RCC_HSE_ON);  

  

  /* Wait till HSE is ready */  

  HSEStartUpStatus = RCC_WaitForHSEStartUp();  

  

  if(HSEStartUpStatus == SUCCESS)  

  {  

    /* Enable PLL */   

    RCC_PLLCmd(ENABLE);  

  

    /* Wait till PLL is ready */  

    while(RCC_GetFlagStatus(RCC_FLAG_PLLRDY) == RESET)  

    {  

    }  

  

    /* Select PLL as system clock source */  

    RCC_SYSCLKConfig(RCC_SYSCLKSource_PLLCLK);  

  

    /* Wait till PLL is used as system clock source */  

    while(RCC_GetSYSCLKSource() != 0x08)  

    {  

    }  

  }  

}  

  

/******************************************************************************* 

* Function Name  : EXTI_Configuration 

* Description    : Configures EXTI Line3. 

* Input          : None 

* Output         : None 

* Return         : None 

*******************************************************************************/  

void EXIT_Configuration(void)  

{  

    EXTI_InitTypeDef EXTI_InitStructure;  

  

    GPIO_EXTILineConfig(GPIO_PortSourceGPIOB,GPIO_PinSource3);  

    EXTI_ClearITPendingBit(EXTI_Line3);  

    EXTI_InitStructure.EXTI_Line = EXTI_Line3;  

    EXTI_InitStructure.EXTI_Mode = EXTI_Mode_Interrupt;                                         

    EXTI_InitStructure.EXTI_Trigger = EXTI_Trigger_Falling;   

    EXTI_InitStructure.EXTI_LineCmd = ENABLE;  

    EXTI_Init(&EXTI_InitStructure);  

}  

  

void dev_exti_enable(Boolean bEnable)  

{  

    NVIC_InitTypeDef NVIC_InitStructure;  

  

    /* Clear the Key Button EXTI line pending bit */  

    EXTI_ClearITPendingBit(EXTI_Line3);  

  

    NVIC_ClearIRQChannelPendingBit(EXTI3_IRQChannel);  

    NVIC_InitStructure.NVIC_IRQChannel = EXTI3_IRQChannel;  

    NVIC_InitStructure.NVIC_IRQChannelPreemptionPriority = 0;  

    NVIC_InitStructure.NVIC_IRQChannelSubPriority = 0;  

    NVIC_InitStructure.NVIC_IRQChannelCmd = bEnable ? ENABLE : DISABLE;  

    NVIC_Init(&NVIC_InitStructure);   

}  

  

/******************************************************************************* 

* Function Name  : main 

* Description    : Main program. 

* Input          : None 

* Output         : None 

* Return         : None 

*******************************************************************************/  

int main(void)  

{  

  /* System Clocks Configuration */  

  RCC_Configuration();  

  

  /* NVIC configuration */  

  NVIC_Configuration();  

  

  /* Configure RTC clock source and prescaler */  

  RTC_Configuration();  

  

  /* Configure the SysTick to generate an interrupt each 1 millisecond */  

  SysTick_Configuration();  

  

  /* Configures EXTI Line3 */  

  EXIT_Configuration();  

  

  /* IWDG initialize*/  

  dev_iwdg_init();  

  

  while(1)  

  {  

    // 执行任务  

    Task1();  

    Task2();  

    // ..  

  

    // 喂狗  

    dev_iwdg_feed();  

  

    // 进入待机模式开关  

    if(m_bEnterStandByMode)  

    {     

        // 使能外部中断,GPIOB3,用以MCU从待机模式唤醒  

        dev_exti_enable(TRUE);  

ENTERSTOPMODE:    

        // 设置RTC闹钟,5秒钟产生一次RTC闹钟中断*/  

        dev_rtc_setAlarm(5);  

      

        // 进入停止模式(低功耗),直至外部中断触发时被唤醒  

        PWR_EnterSTOPMode(PWR_Regulator_LowPower, PWR_STOPEntry_WFI);  

      

        // 是否是RTC闹钟中断唤醒  

        if(dev_rtc_isAlarm())  

        {  

            // 喂狗  

            dev_iwdg_feed();  

            // 喂完狗继续进入停止模式  

            goto ENTERSTOPMODE;   

        }  

        // 禁止外部中断   

        dev_exti_enable(FALSE);  

        // 从停止模式唤醒后恢复系统时钟  

        dev_clk_restore();  

    }               

  }  

}  


推荐阅读

史海拾趣

Hirel Systems Ltd公司的发展小趣事

对于四通道红外遥控器接收器电路,网友可能提出的问题涉及多个方面,以下是一些可能的问题及回答:

一、技术原理类问题

  1. 问题:四通道红外遥控器接收器电路是如何工作的?
    回答:四通道红外遥控器接收器电路主要通过光电二极管接收遥控器发射的红外信号,经过放大、解码等处理,最终识别出不同的按键指令,并控制相应的设备执行操作。具体来说,当遥控器发射出特定频率的红外光信号时,光电二极管将光信号转换为电信号,经过放大电路放大后,送入解码器进行解码,解码器根据解码结果输出相应的控制信号,控制设备执行相应的操作。

  2. 问题:接收器电路中的关键元件有哪些?
    回答:接收器电路中的关键元件包括光电二极管(用于接收红外光信号)、放大器(用于放大微弱的电信号)、解码器(用于解码信号并输出控制信号)以及可能的滤波电路(用于滤除噪声干扰)等。这些元件共同协作,实现红外信号的接收和处理。

二、故障排查与维修类问题

  1. 问题:接收器无法接收到信号,可能的原因有哪些?
    回答:接收器无法接收到信号的可能原因包括:

    • 光电二极管损坏或老化,导致无法有效接收红外光信号。
    • 接收器电路中的连接线松动或接触不良,导致信号传输中断。
    • 放大器或解码器故障,无法对接收到的信号进行正常放大或解码。
    • 接收器受到外界干扰(如光线、电磁干扰等),影响信号的接收和处理。

    针对以上问题,可以逐一检查光电二极管、连接线、放大器、解码器等元件的状态,并采取相应的维修或更换措施。同时,注意避免将接收器放置在易受干扰的环境中。

  2. 问题:如何排查和解决接收器响应延迟或误动作的问题?
    回答:排查和解决接收器响应延迟或误动作的问题可以从以下几个方面入手:

    • 检查遥控器发射的红外信号是否正常,包括信号的频率、强度等是否符合接收器的要求。
    • 检查接收器电路中的滤波电路是否设置得当,以避免噪声干扰导致误动作。
    • 检查解码器的解码逻辑是否正确,以确保能够准确识别出遥控器发射的指令。
    • 如果以上均正常,可以考虑检查接收器的电源系统是否稳定,以及是否有其他电路元件故障导致的影响。

    针对具体问题,可以采取相应的调整或维修措施来解决。

三、应用与拓展类问题

  1. 问题:四通道红外遥控器接收器电路可以应用于哪些场景?
    回答:四通道红外遥控器接收器电路可以广泛应用于各种需要遥控控制的设备中,如智能家居系统(如电视、空调、灯光等的遥控控制)、工业自动化控制(如电机、阀门等的远程控制)、安防监控系统(如摄像头、报警器的遥控操作)等。通过扩展通道数量和增加控制逻辑,还可以实现更复杂的控制功能。

  2. 问题:如何对四通道红外遥控器接收器电路进行升级或改造?
    回答:对四通道红外遥控器接收器电路进行升级或改造时,可以考虑以下几个方面:

    • 升级光电二极管或放大器等关键元件的性能,以提高接收灵敏度和信号处理能力。
    • 增加滤波电路或改进解码算法,以减少噪声干扰和提高解码准确性。
    • 扩展通道数量或增加控制逻辑,以实现更复杂的控制功能。
    • 引入无线通信模块(如Wi-Fi、蓝牙等),将红外遥控与无线控制相结合,提高控制的灵活性和便捷性。

    在进行升级或改造时,需要根据具体的应用需求和技术条件进行选择和设计。

EMC [ELAN Microelectronics Corp]公司的发展小趣事

义隆电子股份有限公司于1994年5月在台湾创立,以亚太区著名的IC设计公司为目标。公司初始阶段就明确了以研发和销售集成电路(IC)产品为核心业务的战略方向。在创立初期,义隆电子积极引进高素质的研发人才,建立了强大的研发团队,并投入大量资金用于新产品的研发。凭借卓越的技术实力和敏锐的市场洞察力,义隆电子在消费性芯片、通讯类芯片等领域迅速取得了突破。

场效应半导体(Cmos)公司的发展小趣事

高通(Qualcomm)在移动通信领域的迅猛发展也离不开CMOS技术的支持。高通在CMOS技术研发方面投入了大量资源,成功地将CMOS技术应用于其移动通信芯片产品中。这些芯片产品以其卓越的性能和出色的功耗控制而广受手机制造商的青睐。随着移动通信技术的不断进步,高通在CMOS技术方面的创新也不断推动着移动通信产业的发展。

Global Components & Controls公司的发展小趣事
将挡住光线的纸拿开,观察灯光亮度的变化。如果灯光稍有变化但趋于稳定,说明RP2的调节已到位;如果亮度变化很大,则需要进一步调节RP2使灯光稍有下降直至稳定。
Forge Europa Ltd公司的发展小趣事

在快速发展的过程中,Forge Europa Ltd公司始终注重品牌与文化的塑造。公司秉承“创新、品质、服务”的企业精神,致力于为客户提供优质的产品和服务。同时,公司还注重员工的培养和发展,建立了完善的培训体系和激励机制,激发了员工的创造力和工作热情。通过这些努力,Forge Europa不仅塑造了一个具有行业影响力的品牌形象,还形成了独特的企业文化,为企业的长远发展奠定了坚实的基础。

FINISAR公司的发展小趣事

FINISAR公司(前身为Finisar Corporation)成立于1987年(另有资料称成立于1988年),总部位于美国加利福尼亚州的硅谷地区。公司自创立之初便专注于光通信技术的研发与应用,致力于设计、制造和销售高性能的光模块和光网络设备。在成立初期,FINISAR凭借其创新的技术和高质量的产品,在光通信市场上逐渐崭露头角,为后续的快速发展奠定了坚实基础。

问答坊 | AI 解惑

学习rfid必须知道的六个问题

  问题一:RFID是什么?RFID是Radio Frequency Identification的缩写,即射频识别,俗称电子标签。  问题二:什么是RFID技术?  RFID射频识别是一种非接触式的自动识别技术,它通过射频信号自动识别目标对象并获取相关数据,识别工作无须人工 ...…

查看全部问答>

想要学习FPGA,希望推荐款合适的学习板

大家好,我想学习FPGA,对它很感兴趣。 所以想买一块学习板,请大家推荐一款比较适合初学者的。价格的话在800以内就行。 如果可以的话,推荐几本经典的书就更好了。 小弟在此先谢过了 …

查看全部问答>

WINCE中同一个flash显示两个flash文件夹?

在WINCE显示设备里出现连个flash设备:Nandflash,Nandflash2,而两个FLASH文件夹都是指向同一个flash。查了下注册表,里 面就有一个FLASH项。请问这是哪里设置不对造成的?…

查看全部问答>

C8051F版数字湿度计调试3---硬件SMbus与SHT21通信

硬件SMbus与SHT21通信     [ 本帖最后由 sdjntl 于 2010-8-18 16:43 编辑 ]…

查看全部问答>

无线数据传输测试仪器

请教诸位大侠:搞短距离无线数据传输,需要哪些测试方面的仪器设备?有些什么要求?…

查看全部问答>

50HZ交流转直流,直流电压随交流幅值变

大神们 求帮帮忙吧,   把50hz左右交流转成直流,AD给单片机测其电压,交流幅值变换在0到15v左右吧,直流电压最好就是交流有效值,要有比例关系。要精确点的,大家给点意见吧,最好是以前做过的。…

查看全部问答>

AM335X的Arduino开发板不知道大家敢不感兴趣

助力电子爱好者开发更小型、更友好、更低成本解决方案 信用卡大小的开发板支持便捷硬件扩展、通过单线缆以及 10 秒钟 Linux 启动便可实现快速开发 北京2011年11月2日电  -- 日前,BeagleBoard.org 高兴地宣布推出其深受青睐产品系列中 ...…

查看全部问答>

关于团购到MSP430之后的难题。。。

我表示找不到那个什么CCS和IAR,都是要钱的?我们买板没有送许可证?…

查看全部问答>

【TI资料下载】UCD3028 数字电源软件设计说明

摘 要 UCD3028 数字电源功能丰富,可以完成两个独立功率支路的控制;软件配置灵活,可以实现多种功能包括多种故障的检测和处理。本文基于一款1/8 砖模块产品对UCD3028 的软件设计进行了详细说明,内容包括外界模拟信号的采集与转换,副边电流的采 ...…

查看全部问答>

STM32F10x_StdPeriph_Driver_3.5.0.chm

STM32F10x_StdPeriph_Driver_3.5.0.chm [ 本帖最后由 zqjqq88 于 2013-5-25 19:30 编辑 ]…

查看全部问答>