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,AC0AMOV #0X018001,XAR2AMOV #0X018002,XAR3MOV #0X0005,*AR2MOV #0X0002,*AR3MACM *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,然后用转换后的值进行运算
hjr-DSP:汇编运算与段的理解相关推荐
- 汇编实现时钟设置代码理解
汇编实现时钟设置代码理解 下面的笔记是我在看<朱老师物联网大讲堂>(www.zhulaoshi.org)之后所做的笔记,只是大概根据自己看了视频与朱老师上课做的笔记而有的理解记录下来. 写 ...
- 【STM32F429的DSP教程】第25章 DSP变换运算-快速傅里叶变换原理(FFT)
完整版教程下载地址:http://www.armbbs.cn/forum.php?mod=viewthread&tid=94547 第25章 DSP变换运算-快速傅里叶变换原理(F ...
- 【STM32F407的DSP教程】第24章 DSP变换运算-傅里叶变换
完整版教程下载地址:http://www.armbbs.cn/forum.php?mod=viewthread&tid=94547 第24章 DSP变换运算-傅里叶变换 本章节开始 ...
- 【STM32F407的DSP教程】第25章 DSP变换运算-快速傅里叶变换原理(FFT)
完整版教程下载地址:http://www.armbbs.cn/forum.php?mod=viewthread&tid=94547 第25章 DSP变换运算-快速傅里叶变换原理(F ...
- 目标码格式解析之DSP目标码Cinit段
目标码格式解析之DSP目标码Cinit段 什么是DSP 什么是DSP程序 什么是段信息 Cinit段数据分析 Loader操作 结尾 什么是DSP 一般来说DSP就是数字信号处理器,简单来说就是一块芯 ...
- 通过分析一个C程序的汇编指令执行过程,理解计算机的工作。
郑德伦 原创作品转载请注明出处 <Linux内核分析>MOOC课程 http://mooc.study.163.com/course/USTC-1000029000 首先创建一个C程序的文 ...
- DSP DSP汇编伪指令汇总
段定义伪指令: 把汇编程序的各个部分与适当的段(数据块或程序块)联系起来 段定义伪指令 .asect "段名" , 地址 汇编到一以绝对地址为起始的段中 作用类似于.sect,但多 ...
- ARM汇编——PC和LR寄存器理解
0.前言 既然学C/C++,不了解一下嵌入式有点不合适,了解嵌入式之前看了一点汇编,那些寄存器太特么有意思了.讲真的,硬件确实比软件要复杂一些. 对了,先推荐一首歌,<New Boy>-- ...
- 【 c语言中无符号和有符号的加法运算】【深入理解】--【sky原创】
第一题 #include<stdio.h> int main() { unsigned int a=6; int b=-20; printf("%d\n" ...
最新文章
- ACMNO.17C语言-筛法求素数 用筛法求之N内的素数。
- 复数3+4i在python中的表达方式是_i(x+yi)=3+4i xy属于R,则复数x+yi的模是为什么xi-y=3+4......
- Echange配置企业邮件收发策略
- 强烈推荐Spring Web Flow权威指南
- 设计模式理解:策略模式
- ios fixed定位后内容不显示_HTMLCSS学习笔记(七)-- 定位与锚点
- Mysql循环查询结果并设置排序编号
- 动态规划dp算法经典包子凑数java
- 音频编码(PCM、G711A、G711U、AAC)理解
- Conmi的正确答案——米家第一个ReactNative程序开发记录
- Centos7安装ElasticSearch6.4
- LPC1768 IAR环境下使用完整64K内存的方法_整理
- 大学python考试题及答案_中国大学慕课mooc用Python玩转数据期末考试大全答案
- 【阅读笔记】Towards Personalized Federated Learning个性化联邦综述
- docker: error pulling image configuration:timeout
- 比江小白杜蕾斯还要清新,这些文案,可能这就是青春吧!
- 史上最浅显易懂的Git学习指南
- 泪目!曾风靡全国的国产网游,宣布停运!
- 小学计算机室工作总结范文,小学信息技术教研组的工作总结范文
- 得了选择恐惧症?这款APP能解救你