完善资料让更多小伙伴认识你,还能领取20积分哦, 立即完善>
大家好!
我是DSP产品的新手。最近在看DSP程序例程上有一段语句是这样的: _ISR_Run: ;(13 cycles to get to here from ISR trigger) ;CONTEXT_SAVE PUSH AR1H:AR0H ; 32-bit PUSH XAR2 ; 32-bit PUSH XAR3 ; 32-bit PUSH XAR4 ; 32-bit ;---------------------------------------- PUSH XT ; 32-bit NOP ;--------------------------------------------------------- ;--------------------------------------------------------- MOVW DP,#ADCST>>6 ; 我看SPRU里写应当是让DP指向含有ADCST的页,那么右移6位是什么意思呢? MOV AL,@ADCST ; AND AL,#0x0004 ; B ADC_Conv, NEQ ; 能不能请哪位朋友帮我解释一下高亮部分是什么意思啊? 我查了SPRU513D,没有发现DP寻址方式里有这种 MOVW DP, #xx 再加右移的方式啊? 另外,能不能请帮我看一下下面的语句,我把我的理解加了高亮,能不能请各位帮我看看我是不是理解对了啊?谢谢各位 MOVL XAR4,#(_dlog) ; 把变量dlog的地址给XAR4,即把XAR4当指针用 MOV ACC,*XAR5 ;把XAR5的内容赋给ACC(即把XAR5当指针用) MOV *+XAR5[2],#0 ; 把0给XAR5[2],????, XARn也可以当数组用吗? MOVL XAR7,*XAR4++ ; 先把XAR4的内容给XAR7,然后XAR4加1。即XAR4当指针用,XAR7不当指针用? MOV @ADCTRL2,#0x4100 ; 把0X4100写入ADCTRL2寄存器 谢谢 |
|
相关推荐
8 个讨论
|
|
Emily1225 发表于 2018-8-19 07:54 谢谢你。这是源于TI的例程。但似乎例程在运行上没有什么问题啊?是不是我挪去这个>>也是OK的呢? 源程序这里是用汇编处理ADC采样结果,全段如下。但似乎这种MOVW DP #xx >>6 使用了很多次。有没有可能是通用的呢?谢谢哦 _ISR_Run: ;(13 cycles to get to here from ISR trigger) ;CONTEXT_SAVE PUSH AR1H:AR0H ; 32-bit PUSH XAR2 ; 32-bit PUSH XAR3 ; 32-bit PUSH XAR4 ; 32-bit ;---------------------------------------- PUSH XT ; 32-bit NOP ;--------------------------------------------------------- MOVW DP,#ADCST>>6 ; Make sure ADC conversion has completed ADC_Conv: MOV AL,@ADCST ; check seq1 busy bit AND AL,#0x0004 ; This code may not be needed with proper timing B ADC_Conv, NEQ ; and buffer code that doesn't use the ADC result and ; runs from the start of the ISR till the completion of ADC conversion ADC_NchDRV 3 ; 3 Channel, (i.e. N=3) ADC_Reset: MOVW DP,#ADCTRL2>>6 ; Reset ADC SEQ MOV @ADCTRL2,#0x4100 ; RST_SEQ1=1, SOCA-SEQ1=1 ; ADC Sample Point Calculation MOVW DP,#TBPHS3>>6 MOV AL,@TBPHS3 ; TBPHS3 ADD AL,@TBPRD3 ; TBPRD3 LSR AL,#1 ; ACC = (TBPRD3 + TBPHS3)/2 MOV @CMPB3, AL ; CMPB3 = (TBPRD3 + TBPHS3)/2 ;--------------------------------------------------------- ; Datalog to store and plot upto four variables in the control flow MOVW DP,#dlog_cntr INC @dlog_cntr CMP @dlog_cntr,#4 B EXIT_ISR, LT ; Execute this module 4x slower MOV @dlog_cntr,#0 ; Reset loop counter DLOG_4CH_update EXIT_ISR: ;=================================== MOVW DP,#PIEACK>>6 ; Acknowledge PIE interrupt Group 3 MOV @PIEACK,#PIEACK_GROUP3 .endif ; EPWMn_ISR .if(ADC_ISR) ; Case where ISR is triggered by ADC MOVW DP,#ADCST>>6 MOV @ADCST,#0x010 ; Clear INT SEQ1 Int flag MOVW DP,#PIEACK>>6 ; Acknowledge PIE interrupt Group 1 MOV @PIEACK,#PIEACK_GROUP1 .endif ; ADC_ISR ; Restore context & return POP XT ;----------------------------------- POP XAR4 POP XAR3 POP XAR2 POP AR1H:AR0H IRET |
|
|
|
|
|
60user144 发表于 2018-8-19 08:37 如下面的图所示,当用.set定义时,编译器并不认为地址所以编译器没有自动进行6位移位,需要程序员写>>6. 另一种形式的定义,编译器自动进行6位移位,需要程序员无需写>>6。 楼主可以看到,ADCST的地址定义为07119h,DP应该是1C4h。res_3的地址是0X7A0,DP应为0x1E |
|
|
|
|
|
只有小组成员才能发言,加入小组>>
TMS320F28377D:新做了以377d为芯片的板子,上电后芯片复位引脚出现方波请问如何解决?
1888 浏览 0 评论
TPS55340通电后输入端保险丝烧断,芯片输入和GND之间短路
3641 浏览 4 评论
5027 浏览 0 评论
请问如何用DM368对RGB格式的图片数据进行编码生成JPEG格式图片?
1732 浏览 1 评论
9353 浏览 8 评论
CC3100BOOST使用CC3200lunchXL进行烧录
664浏览 2评论
707浏览 1评论
TMS320F28034: 利用C2prog通过SCI给TMS320F28034烧录程序,出现错误提示:Bootloading... failed (invalid echo)!
668浏览 1评论
1186浏览 1评论
求DLPC350 Programmer’s Guide User's Guide 中文版说明书
1189浏览 1评论
小黑屋| 手机版| Archiver| 电子发烧友 ( 湘ICP备2023018690号 )
GMT+8, 2024-4-19 21:10 , Processed in 0.697396 second(s), Total 57, Slave 47 queries .
Powered by 电子发烧友网
© 2015 bbs.elecfans.com
关注我们的微信
下载发烧友APP
电子发烧友观察
版权所有 © 湖南华秋数字科技有限公司
电子发烧友 (电路图) 湘公网安备 43011202000918 号 电信与信息服务业务经营许可证:合字B2-20210191 工商网监 湘ICP备2023018690号