Linux下扬声器汇编程序设计.docVIP

  1. 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
  2. 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  3. 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  4. 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  5. 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  6. 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  7. 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
Linux下扬声器汇编程序设计

Linux下扬声器汇编程序设计   Linux是目前最常用的操作系统之一,同微软的Windows系列操作系统相比,它具有速度快、安全性、稳定性好、源代码开放且免费等优点。我国Linux的发展也处于蓬勃发展的局面,据权威预测,中国Linux人才的需求将突破120万。对于大多数只熟悉DOS/Windows程序设计的国内程序员来说,了解和掌握Linux下的程序设计大有裨益。这里介绍在Linux 下进行扬声器汇编程序设计。      ATT 汇编指令      同DOS/Windows 下使用的Intel 风格的汇编语言不同,在Linux 系统中,更多的是采用ATT 格式。两者的汇编指令名类似,但在语法格式上有着较大的不同。   1.在ATT汇编中,寄存器名要加%前缀;而在Intel汇编中,寄存器名不需要加前缀。   2.在ATT汇编中,用$前缀表示一个立即数;在Intel 汇编中,立即数不用任何前缀。   3.在 ATT 汇编格式中,目标操作数在源操作数的右边;而在 Intel 汇编中,顺序相反。指令举例如下:   ATT 格式:addl $0x80, %eax    Intel 格式: add eax, 80h   4.在 ATT 汇编格式中,操作数的字长由操作符的最后一个字母决定,后缀b、w、l分别表示操作数为字节(byte,8 bit)、字(word,16 bit)和长字(long,32 bit);而在 Intel 汇编格式中,操作数的字长是用 byte ptr 和 word ptr 等前缀来表示的。例如:   ATT格式: movb $0x32, %al   Intel格式: mov al, byte ptr 32h   5.在 ATT 汇编格式中,绝对转移和调用指令(jump/call)的操作数前要加上$作为前缀,而在 Intel 格式中则不需要。 远程转移指令和远程子调用指令的操作码,在 ATT 汇编格式中为 ljump 和 lcall,而在 Intel 汇编格式中则为 jmp far 和 call far,即:   ATT格式:ljump $section, $offset   Intel格式:jmp far section:offset   与之相应的远程返回指令则为:   ATT格式: lret $stack_adjust   Intel格式:ret far stack_adjust   6.在 ATT 汇编格式中,内存操作数的寻址方式是:section:disp(base, index, scale) 而在 Intel 汇编格式中,内存操作数的寻址方式为: section:[base + index*scale + disp]   7.由于 Linux 工作在保护模式下,用的是 32 位线性地址,所以在计算地址时不用考虑段基址和偏移量,其地址计算方法为:disp + base + index * scale。两种格式对比举例如下:      扬声器汇编程序开发      Linux 是一个运行在保护模式下的 32 位操作系统,采用 flat memory 模式,目前最常用到的是 ELF 格式的二进制代码。一个 ELF 格式的可执行程序通常划分为如下几个部分:.text、.data 和 .bss,其中 .text 是只读的代码区,.data 是可读可写的数据区,而 .bss 则是可读可写且没有初始化的数据区。代码区和数据区在 ELF 中统称为 section,根据实际需要你可以使用其它标准的 section,也可以添加自定义 section,但一个 ELF 可执行程序至少应该有一个 .text 部分。   扬声器发声程序主要是通过I/O端口的数据读写完成的,由于Linux 是一个运行在保护模式下的32 位操作系统,系统默认情况下不能直接对I/O端口进行读写。在程序进行I/O端口读写前,首先要请求Linux系统开放(允许读写)相应的I/O端口,同时还应该注意在程序结束前提请系统关闭开放的I/O端口。对I/O端口的开放/关闭操作可以使用Linux系统功能调用(0x80号中断)的101号功能。开发ATT 汇编语言程序包括编辑源程序、汇编、连接、调试运行等步骤。      ● 编辑汇编源程序   启动Linux下的文本编辑器,编辑输入ATT 汇编语言源程序。这里介绍的扬声器汇编源程序如下,需要注意的是,在ATT 汇编语言源程序中用“#”标记注释,也可以C语言一样用“/* */”作为注释标识符。   data #以下定义数据区数据   # frequency 存储的为1,2,3,4,5,6,7七个音符(中音)和高音1的频率,0为结束标志   frequency

文档评论(0)

3471161553 + 关注
实名认证
文档贡献者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档