历史上的今天
返回首页

历史上的今天

今天是: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();  

    }               

  }  

}  


推荐阅读

史海拾趣

CT Micro公司的发展小趣事
  1. 创业初期与技术创新

CT Micro公司最初由几位电子工程领域的专家创立,他们看到了微型计算机断层扫描(Micro-CT)技术在电子行业中的巨大潜力。初期,公司面临着资金短缺和技术难题,但他们通过不断研发和创新,成功开发出了一款具有高性价比的Micro-CT设备,迅速获得了市场的认可。

  1. 市场拓展与合作伙伴关系

随着产品的成熟,CT Micro开始积极寻求市场拓展。他们与多家电子制造企业建立了合作关系,为这些企业提供Micro-CT设备的定制服务。通过与这些企业的合作,CT Micro不仅扩大了市场份额,还进一步提升了产品的技术水平和应用范围。

  1. 研发升级与产品迭代

面对日益激烈的市场竞争,CT Micro不断投入研发力量,对Micro-CT设备进行升级和迭代。他们成功推出了多款新型设备,具有更高的分辨率、更快的扫描速度和更低的辐射剂量。这些新产品的推出,进一步巩固了CT Micro在电子行业中的领先地位。

  1. 国际化战略与市场拓展

随着国内市场的饱和,CT Micro开始实施国际化战略。他们积极参与国际展览和研讨会,展示自己的产品和技术实力。同时,他们还在海外设立了销售和服务中心,为国际客户提供更加便捷的服务。通过这些努力,CT Micro成功打开了国际市场的大门。

  1. 社会责任与可持续发展

在快速发展的同时,CT Micro也积极履行社会责任。他们注重环保和可持续发展,采用环保材料和节能技术生产产品。此外,他们还积极参与公益事业,为贫困地区的教育和医疗事业贡献力量。这些举措不仅提升了公司的社会形象,也为其可持续发展奠定了坚实基础。

请注意,这些故事框架是虚构的,并不代表CT Micro公司的实际发展情况。如果您需要了解CT Micro公司或类似公司的真实故事,建议您查阅相关公司的官方网站、新闻报道或行业分析报告。

Advanced Fibreoptic Engineering Ltd公司的发展小趣事

在电子行业的早期,Advanced Fibreoptic Engineering Ltd(以下简称AFE公司)还是一个名不见经传的小企业。然而,随着技术的不断进步,AFE公司凭借其在光纤技术领域的深厚积累,成功研发出了一种具有划时代意义的新型光纤材料。这种材料不仅传输速度快,而且损耗极低,极大地提高了数据传输的效率和质量。这一技术突破迅速为AFE公司赢得了市场认可,公司的订单量激增,业绩逐年攀升。

随着技术的推广和应用,AFE公司的光纤产品逐渐在通信、医疗、工业等多个领域得到广泛应用。公司不仅在国内市场占据了一席之地,还积极拓展海外市场,与国际知名企业建立了稳定的合作关系。凭借卓越的产品性能和良好的市场口碑,AFE公司逐渐在电子行业中崭露头角,成为了光纤技术领域的佼佼者。

以上是第一个故事的示例,若您想要探索更多关于AFE公司的发展故事,请输入继续。

(注:由于我无法实时获取具体公司的实际发展故事,以上故事为虚构内容,仅用于展示故事编写风格和结构。如果您需要真实、具体的故事,请提供更多关于AFE公司的信息,以便我能为您编写更贴近实际的内容。)

Crystal Semiconductor Corp公司的发展小趣事

Crystal Semiconductor Corp成立之初,面临着资金短缺、技术难题和市场竞争的多重压力。然而,公司的创始人凭借对半导体技术的深刻理解和敏锐的市场洞察力,成功吸引了一批志同道合的工程师和投资者。他们共同攻克了技术难关,推出了首款具有竞争力的晶体管产品,迅速在市场上占据了一席之地。

DSMI Electronics SA公司的发展小趣事

DSMI Electronics SA公司非常重视企业文化的建设和团队建设。公司倡导开放、协作、创新、务实的企业文化,鼓励员工积极参与技术创新和市场竞争。同时,DSMI还注重人才培养和引进,通过内部培训、外部招聘等方式,不断提升员工的素质和能力。这些努力为公司的持续发展提供了有力的人才保障。

BILIN公司的发展小趣事

随着技术的不断进步和市场需求的增长,DSMI Electronics SA公司开始寻求与国际知名品牌的合作。通过与多家国际大公司的合作,DSMI不仅提升了自身的技术水平和生产能力,还扩大了市场份额。特别是在嵌入式系统领域,DSMI的产品得到了广泛应用,成为了行业内的重要供应商之一。

Etron公司的发展小趣事

进入21世纪,电子行业的竞争日益激烈,钰创科技意识到必须不断进行技术创新才能保持竞争优势。公司加大了研发投入,成功开发出了一系列先进的内存芯片和系统芯片技术。这些技术突破不仅提升了产品的性能和质量,也帮助公司赢得了更多国际客户的认可和信任。

问答坊 | AI 解惑

武汉理工大学-2009初赛题

本帖最后由 paulhyde 于 2014-9-15 08:57 编辑 分享@@@@@@@  …

查看全部问答>

个人感觉超级猛的一个开发板——Spartan-6 FPGA 嵌入式套件

这是官网的资料: Spartan-6 FPGA 嵌入式套件基于 Spartan-6 LX45T FPGA,该套件包含嵌入式开发所需的可扩展式开发板与主要工具和 IP。还有参考设计和软件/硬件辅导资料。如果软件开发,可在 Eclipse IDE 中着手开发,而无需运行任何 FPGA ...…

查看全部问答>

乔布斯你凭什么这么牛?

最近IT业的人没有不知道iPhone 4的信号门,为此展开的口水战也屡见于各大媒体。“信号门”本不是什么好事,对于其他公司甚至可能是灭顶之灾,但苹果有个乔布斯,信号门不仅乔布斯出尽风头,出现在各大媒体头版头条,iPhone 4手机的销售也好像丝毫没 ...…

查看全部问答>

高分求助:关于ws2_32.lib的很难的问题 ,————急

我修改一个实例程序:用到下面语句(在evc中) #pragma  comment(lib,  \"ws2_32.lib \"),但却出现下面错误。 cannot open file \'ws2_32.lib \' 我在setting->link->Object/library  modules:中填上:ws2_32 ...…

查看全部问答>

嵌入式设备里,添加java游戏,如何支持Java?

因为手头的开发板是mips32+linux,嵌入式设备里,想添加java游戏,应该移植哪种JVM比较好,比较快,比较容易?据说kaffe是一个不错的JVM,有没有移植过的朋友,可以参考指点的,谢谢!…

查看全部问答>

ov7620逐行扫描设置问题?

请问ov7620逐行扫描模式怎样设置呀?我象7620的寄存器0x28写入0x20为什么不行(7620一直忙)呀?是不是还要写其他寄存器呀,怎样写呀?急呀? 谢谢先!…

查看全部问答>

CPU的疑问

小弟我是新手,我想请问下大虾们几个问题: 1.操作系统是用来协调进程和调度CPU处理进程的,每个进程通过相同的时间片 来被CPU处理,那么操作系统自己是不是也通过时间片来被CPU处理 2.当我开启一个windows窗口后,我不关闭这个窗口,那么CPU是 ...…

查看全部问答>

有了解长三角的技术行业情况的么?

     各位有对长三角技术行业了解的吗?情况如何?自动化控制,电子技术方面等,对人才的需求情况等等。学历不高,机会是否大呢?二三线城市都行,只要工作喜欢…

查看全部问答>

湿度传感器

湿度传感器的资料…

查看全部问答>

有个想法,MSP430 LaunchPad 仿真 msp430fr5739

突然用MSP430 LaunchPad 仿真 fr5739发现不能正常仿真,仿真脚是DVCC,DVSS,P2.0,P2.1,TEST,RST,管脚有错误吗?报错图片请看     另,可以串口下载的msp430f149,MSP430 LaunchPad也不能仿真。难道MSP430 LaunchPad仿真范围只 ...…

查看全部问答>