完善资料让更多小伙伴认识你,还能领取20积分哦, 立即完善>
原本设想是ulp执行一次唤醒主mcu一次,然后mcu打印完之后在进入深度睡眠。然后这样不断的循环。
实际测试出来的结果是ulp执行2次才唤醒主mcu一次,这是为什么。 下面虚线之后的这段代码是协处理器ulp执行完任务后,会执行的唤醒主CPU操作,但每次都会先执行一次exit分支,然后ulp重启后在执行完一次任务之后,才在跳转到wake_up分支。 想看看RTC_CNTL_STATE0_REG寄存器是干什么的: #define DR_REG_RTCCNTL_BASE 0x3ff48000 #define RTC_CNTL_LOW_POWER_ST_REG (DR_REG_RTCCNTL_BASE + 0xc0) #define RTC_CNTL_DIAG0_REG RTC_CNTL_LOW_POWER_ST_REG READ_RTC_REG(RTC_CNTL_DIAG0_REG, 19, 1) 也就是说,实际是判断0x3ff480C0这个寄存器的第19位是否为1,如果为1才能重启主MCU,否则则重启ulp。 在数据手册里查看0x3ff480C0这个寄存器,他是RTC_CNTL_STOREn_REG系统保留的寄存器,也不知道它是干什么的,手册没有说明。 jump wake_up /* Get ULP back to sleep */ .global exit exit: /* Stop the wakeup timer so it does not restart ULP */ WRITE_RTC_FIELD(RTC_CNTL_STATE0_REG, RTC_CNTL_ULP_CP_SLP_TIMER_EN, 0) halt .global wake_up wake_up: /* Check if the SoC can be woken up */ READ_RTC_REG(RTC_CNTL_DIAG0_REG, 19, 1) and r0, r0, 1 jump exit, eq /* Wake up the SoC and stop ULP program */ wake /* Stop the wakeup timer so it does not restart ULP */ WRITE_RTC_FIELD(RTC_CNTL_STATE0_REG, RTC_CNTL_ULP_CP_SLP_TIMER_EN, 0) halt |
|
相关推荐
|
|
只有小组成员才能发言,加入小组>>
528浏览 6评论
438浏览 5评论
有没有办法在不使用混杂模式的情况下实现Wifi驱动程序接收缓冲区访问中断呢?
425浏览 5评论
423浏览 4评论
399浏览 4评论
小黑屋| 手机版| Archiver| 电子发烧友 ( 湘ICP备2023018690号 )
GMT+8, 2024-11-9 09:47 , Processed in 0.587625 second(s), Total 46, Slave 39 queries .
Powered by 电子发烧友网
© 2015 bbs.elecfans.com
关注我们的微信
下载发烧友APP
电子发烧友观察
版权所有 © 湖南华秋数字科技有限公司
电子发烧友 (电路图) 湘公网安备 43011202000918 号 电信与信息服务业务经营许可证:合字B2-20210191 工商网监 湘ICP备2023018690号