完善资料让更多小伙伴认识你,还能领取20积分哦, 立即完善>
嗨,
今天我有一个非常特别的问题: 我在编程手册中读到,DIV和DIVW的指令是可中断的。 当计算处于活动状态时发生中断时会发生什么 - 使用寄存器(A,X,Y)和 - 如何在IRET后继续计算??? 谁能回答? tiA, WoRo #divw #div 以上来自于谷歌翻译 以下为原文 Hi, today I have a very special question: I read in the programming manual, that the instructions DIV an DIVW are interruptible. What exactly happens, when an interrupt occurs while calculating is active - with the registers (A, X, Y) and - how does calculating continue after IRET??? Who can answer? TIA, WoRo #divw #div |
|
相关推荐
2个回答
|
|
你好WoRo!
我不知道STM8核如何实现DIV / DIVW指令。 STM8勘误表文档提供了一些见解,因为在ISR中始终存在“意外的DIV / DIVW指令”子部分。 当中断执行DIV / DIVW指令而另一个事件中断IRET指令时,会发生此错误。 似乎未使用的CC位在DIV / DIVW执行中起一定作用。 在我看来,专用硬件单元处理DIV / DIVW指令,当其结果准备好时,所涉及的寄存器被更新。这些更新可能由这些未使用的位之一(通常为空)强制执行,但只有STM8核心设计人员才知道会发生什么。 我认为ISR应该避免这些指令,但它可能过于保守...... EtaPhi 以上来自于谷歌翻译 以下为原文 Hello WoRo! I don't know how STM8 core implements DIV/DIVW instructions. STM8 errata documents provide some insight, as there is always an ''Unexpected DIV/DIVW instruction in ISR'' sub-section. This error happens when an interrupt executes a DIV/DIVW instruction and another event interrupts the IRET instruction. It seems that unused CC bits play some role in DIV/DIVW execution. In my opinion, a dedicated hardware unit processes DIV/DIVW instructions and when its result is ready, the involved registers are updated. This update may be forced by one of these unused bits (which are usually null), but only the STM8 core designers know what happens. I think that ISRs should avoid these instructions, but it may be too much conservative... EtaPhi |
|
|
|
我通过模拟中断堆栈帧尝试运行IRET指令失败了。
无论要恢复的CC值是什么,输出都是相同的:没有意外的X或Y寄存器值。 CC的第6位(未定义)似乎对IRET执行没有影响。 出于这个原因,我认为DIV / DIVW指令使用影子寄存器,用户代码无法访问,以及对用户也隐藏的触发器。 对不起,您的问题似乎没有答案。 问候, EtaPhi 以上来自于谷歌翻译 以下为原文 I unsuccessfully tried to exercise IRET instruction by simulating an interrupt stack frame. Whatever the CC value to restore is, the output is the same: no unexpected X or Y register value. It seems that bit 6 of CC, which is undefined, has no effect on IRET execution. For this reason, I suppose that DIV/DIVW instructions use shadow registers, which user code can't access, and a flip/flop which is hidden to the user too. Sorry, it seems that there is no answer to your question. Regards, EtaPhi |
|
|
|
只有小组成员才能发言,加入小组>>
请教:在使用UDE STK时,单片机使用SPC560D30L1,在配置文件怎么设置或选择?里面只有SPC560D40的选项
2801 浏览 1 评论
3258 浏览 1 评论
请问是否有通过UART连接的两个微处理器之间实现双向值交换的方法?
1832 浏览 1 评论
3684 浏览 6 评论
6081 浏览 21 评论
对H747I-DISCO写程序时将CN2的st-link复用为usart1,再次烧录时无法检测到stlink怎么解决?
384浏览 2评论
STM32G474RE芯片只是串口发个数据就发烫严重是怎么回事?
474浏览 2评论
STM32处理增量式编码器Z信号如何判断中断是正转的还是反向转的?
303浏览 2评论
使用STM32F407VET6的USB2.0功能,发现ctl后芯片无数据返回,是什么原因可能导致的呢?
222浏览 2评论
用STM32G431开发工程,1.50版本的Package包文件无法输出项目工程
328浏览 2评论
小黑屋| 手机版| Archiver| 电子发烧友 ( 湘ICP备2023018690号 )
GMT+8, 2025-1-24 16:25 , Processed in 1.162770 second(s), Total 79, Slave 63 queries .
Powered by 电子发烧友网
© 2015 bbs.elecfans.com
关注我们的微信
下载发烧友APP
电子发烧友观察
版权所有 © 湖南华秋数字科技有限公司
电子发烧友 (电路图) 湘公网安备 43011202000918 号 电信与信息服务业务经营许可证:合字B2-20210191 工商网监 湘ICP备2023018690号