hjr-DSP:汇编运算与段的理解

DSP编程语言是汇编和C

先说下汇编基础,这是几种常见运算

 

MOVE 传送,ADD 加法,SUB减法,MPYM乘法,MACM乘加(MACM a,b,c    =》 c=a*b+c)

移位:移出位丢弃,空位补零,左移n位相当于乘以2的n次方,右移n位相当于除以2的n次方

 

对于程序,主要由数据与代码组成,数据又分为初始化的数据和未初始化的数据,比如你int a;这就是未初始化,int a = 1;这就是初始化

汇编语言把程序空间分段,存放数据与代码,注意只有变量可能未初始化,代码一定是初始化的

为什么要分段呢,为了管理方便,比如未初始化的变量会统一赋值0

未初始化段:

.bss:存放系统保留的未初始化的全局变量,比如int,long,位数是系统定的

.usect:存放用户自己定义的未初始化的全局变量,比如定义一个abc类型设置成100位长度

初始化段:

.data:存放系统保留的初始化的全局变量

.sect:存放用户自己定义的初始化的全局变量

.text:存放你的程序代码

比如 .bss h,3

就是把名为h位长为3的变量汇编到.bss段

下面看一段代码

 

	.mmregs
	.def start
	.text
start:   MOV #0X000A,AC0
	 AMOV #0X018001,XAR2
	 AMOV #0X018002,XAR3
	 MOV #0X0005,*AR2
	 MOV #0X0002,*AR3
	 MACM *AR2,*AR3,AC0
HERE:    B HERE;
	.end

上面的.text就是告诉汇编器把下面的代码汇编到程序空间的代码段
注意寄存器的几个规则

 

带X的说明是辅助寄存器

MACM是累乘,上面的代码汇编后AC0的值是

A+2*5=20

20用16进制表示,满10进1就是14

然后AC0是40位寄存器,所以0X0000000014,1那个是高位,4是低位,低位满了高位进1,转化成值就是1*16+4=20

如果遇到小数乘法,看是定点DSP还是浮点DSP,定点便宜,不准,速度快,功耗低,浮点相反

定点计算公式,Xq = X*2的Q次幂   Q是定标数

比如Q=8,编写0.3*5的程序

写程序时,0.3需要转换成0.3*2的8次幂即0.3*256,然后用转换后的值进行运算

 

 

 

  • 1
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
以下是一个简单的 HTML 代码示例,可以用来制作类似于 iPhone 的网页: ```html <!DOCTYPE html> <html> <head> <title>iPhone 网页示例</title> <meta name="viewport" content="width=device-width, initial-scale=1"> <style> body { background-color: #f2f2f2; font-family: Arial, Helvetica, sans-serif; } .container { margin: 20px auto; max-width: 400px; background-color: #fff; border-radius: 10px; padding: 20px; box-shadow: 0px 0px 10px rgba(0,0,0,0.2); } .header { display: flex; align-items: center; justify-content: space-between; margin-bottom: 20px; } .header img { height: 30px; } .navbar { display: flex; background-color: #eee; border-radius: 5px; overflow: hidden; margin-bottom: 20px; } .navbar a { display: block; padding: 10px; text-align: center; flex: 1; text-decoration: none; color: #555; font-weight: bold; } .navbar a.active { background-color: #007aff; color: #fff; } .content { text-align: center; margin-bottom: 20px; } .content img { max-width: 100%; height: auto; margin-bottom: 10px; } .footer { text-align: center; font-size: 12px; color: #aaa; } </style> </head> <body> <div class="container"> <div class="header"> <img src="https://i.imgur.com/6f8yvRP.png" alt="iPhone" /> <button>搜索</button> </div> <div class="navbar"> <a href="#" class="active">主页</a> <a href="#">新闻</a> <a href="#">社交</a> <a href="#">设置</a> </div> <div class="content"> <img src="https://i.imgur.com/4a74HJr.jpg" alt="iPhone" /> <h2>欢迎来到 iPhone 网页示例</h2> <p>这是一个简单的 HTML 示例,用于展示如何制作类似于 iPhone 的网页。</p> </div> <div class="footer"> <p>©2021 iPhone 网页示例</p> </div> </div> </body> </html> ``` 在浏览器中打开该 HTML 文件,即可看到类似于 iPhone 的网页效果。可以根据需要进行修改和调整。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

架构师小侯

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值