- 1、本文档共37页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
Assemble汇编语言设计技术
最近,我帮助朋友编写一个使用Assemble汇编语言的程序,接触了一些Assemble行业的开发工作者以及行业管理人员,在与他们合作和交流过程中发现,我国Assemble汇编语言设计技术根本性的变化,没有一个飞跃性的发展,Assemble汇编设计技术仍然处于落后的、不发达的国家。当然,我可能言过其实,Assemble汇编设计的工作者他们使用Assemble汇编语言设计了很多的产品,在各个领域运用Assemble汇编技术创造出辉煌的成绩,我们必须认可的,并向他们表示衷心问候。但是,当我完成这一篇文章,让我们从事Assemble汇编语言设计的朋友们阅读后,我们可以讨论我所表达的意思是否正确。我已经20年没有再深入地讨论过Assemble汇编语言设计问题了,非常有信心的相信我国的Assemble汇编设计技术这一方面发展应当进入世界同等水平发展,而且有层出不穷的更新的设计技术出现,可是当我再回头接触时,令人只有伤感。
概述
通常,我们知道计算机是由电子元器件组合而成的,主要是逻辑电路组成,因此计算机中真正可以处理的只是由“0”、“1” 组成的二进制这种指令代码易由于依赖于机器,使用极不方便于是人们发明“指令的助记符”,用几个字母(往往就是其含义的英文单词或缩写)代替某条指令,如加法用ADD表示,这种符号系统的扩大就是汇编语言。使用汇编语言编程,可直接对硬件内部进行控制缺点与机器的体系结构的依赖关系。ATmega8 / ATmega48/88/168 / ATmega8515 / ATmega8535 / AT90PWM2/3 Instruction Set
The Assembler accepts mnemonic instructions from the instruction set. A summary of the instruction set mnemonics and their parameters is given here. For a detailed description of the Instruction set, refer to the AVR Data Book.
Arithmetic and Logic Instructions
Mnemonic Operands Description Operation Flags Cycles ADD? Rd,Rr? Add without Carry? Rd = Rd + Rr? Z,C,N,V,H,S? 1 ADC Rd,Rr Add with Carry Rd = Rd + Rr + C Z,C,N,V,H,S 1 ADIW Rd, K Add Immediate To Word Rd+1:Rd,K Z,C,N,V,S 2 SUB Rd,Rr Subtract without Carry Rd = Rd - Rr Z,C,N,V,H,S 1 SUBI Rd,K8 Subtract Immediate Rd = Rd - K8 Z,C,N,V,H,S 1 SBC Rd,Rr Subtract with Carry Rd = Rd - Rr - C Z,C,N,V,H,S 1 SBCI Rd,K8 Subtract with Carry Immedtiate Rd = Rd - K8 - C Z,C,N,V,H,S 1 AND Rd,Rr Logical AND Rd = Rd · Rr Z,N,V,S? 1 ANDI Rd,K8 Logical AND with Immediate Rd = Rd · K8 Z,N,V,S 1 OR Rd,Rr Logical OR Rd = Rd V Rr Z,N,V,S 1 ORI Rd,K8 Logical OR with Immediate Rd = Rd V K8 Z,N,V,S 1 EOR Rd,Rr Logical Exclusive OR Rd = Rd EOR Rr Z,N,V,S 1 COM Rd Ones Complement Rd = $FF - Rd Z,C,N,V,S 1 NEG Rd Twos Complement Rd = $00 - Rd Z,C,N,V,H,S 1 SBR Rd,K8 Set Bit(s) in Register Rd = Rd V K8 Z,C,N,V,S 1 CBR Rd,K8 Clear Bit(s) in Register Rd = Rd · ($FF - K8) Z,C,N,V,S 1 INC Rd Increment Register Rd = Rd + 1 Z,N,V,S 1
文档评论(0)