×

ARM汇编编译器的使用

消耗积分:1 | 格式:rar | 大小:0.3 MB | 2017-10-19

分享资料个

10.4 ARM汇编编译器的使用
  armasm是ARM汇编语言的交叉编译器,本节将详细介绍它的使用方法。
  armasm命令行语法格式如下。
  armasm options inputfile
  在armasm命令中,除了文件名区分大小写之外,其他的参数都不区分大小写。option可是汇编器规定选项中的一个或多个的组合,多个选项用空格分开。下面详细介绍armasm的各参数。
  · --16:告诉汇编器当前程序是Thumb指令程序,使用旧的Thumb语法,与在源程序开头使用伪操作CODE16意义相同。使用--thumb选项指定当前程序是使用ARM语法的Thumb或Thumb-2源程序。
  · --32:告诉汇编器所处理的源程序是ARM指令的程序。此选项为汇编器的默认选项。
  · --apcs [qualifiers]:该选项告诉汇编器是否使用AAPCS标准编译源程序。详见AAPCS一节。
  · --arm:同--32选项。
  · --bigend:告诉汇编器将源程序按大端模式编译。汇编器默认为小端模式(littleend)。
  · --brief_diagnostics:控制输出诊断信息。详见控制诊断信息输出一节。
  · --littleend:告诉编译器将源程序按小端模式编译。这是汇编器的默认选项。
  · --checkreglist:告诉汇编器检测RLIST、LDM、STM指令的寄存器列表是否按升序排列。使用此选项后,如果源程序中寄存器没有按升序排列,汇编器将给出警告信息。
  · --cpu name:告诉汇编器允许程序所使用的CPU型号,详见CPU名一节。
  · --debug:告诉编译器编译时产生DWARF格式的调试信息表。
  · --depend dependfile:告诉编译器将程序的依赖关系列表输出到指定的dependfile文件中。当使用makefile文件对程序进行编译时,该选项十分有用。
  · --diag_[error | remark | warning | suppress | style]:详见控制诊断信息输出一节。
  · --dllexport_all:告诉编译器产生全局变量的动态可见列表(dynamic visibility),在将源程序编译成DLL文件时使用该选项。
  · --dwarf2:和--debug选项配合使用。告诉编译器编译时产生DWARF2格式的调试信息表,当使用了--debug选项时,该选项为默认选项。
  · --dwarf3:和--debug选项配合使用。告诉编译器编译时产生DWARF3格式的调试信息表。
  · -m:告诉编译器将源文件的依赖关系列表输出到标准输出设备上。
  · --md:告诉编译器将源文件的依赖关系列表输出到inputfile.d文件中。
  · --errors errorfile:告诉编译器将编译的错误信息输出到errorfile文件中。
  · --exceptions:详见指示编译器产生异常向量表一节。
  · --exceptions_unwind:详见指示编译器产生anwind异常向量表一节。
  · --fpmode model:详见10.4.3。
  · --fpu name:选择指定目标系统中浮点运算单元的体系结构。
  · -i dir [,dir]…:为源文件搜索增加路径,如果要搜索的源文件路径已被此选项指定,那么在使用伪操作GET、INCLUDE、INCBIN包含源文件时,将不必指定搜索路径。
  · --keep:指定汇编器将局部符号保留在目标文件的符号表中,供调试器进行调试时使用。
  · --list [listingfile]:告诉汇编器将汇编过程中产生的汇编程序列表保存到列表文件listingfile文件中。
  · --maxcache n:指定最大的源程序cache大小,默认为8MB。
  · --memaccess attributes:确定目标系统的内存属性。详见内存访问属性一节。
  · --no_cache:禁止源程序cache。默认情况下源程序cache是打开的。
  · --no_esc:禁止C风格的特殊符号,如“\n”、“\t”。
  · --no_exceptions:详见异常向量表产生一节。
  · --no_exceptions_unwind:详见异常向量表产生一节。
  · --no_hide_all:控制符号的可见性。
  · --no_regs:告诉编译器不使用汇编器预定义的寄存器名。
  · --no_warn:禁止警告信息。
  · -o filename:给输出的目标文件命名。
  · --predefine“directive”:告诉编译器预执行SET伪操作。详见预执行SET伪操作一节。
  · --split_ldm:详见LDM和STM指令。
  · --thumb:告诉编译器将源文件编译为符合ARM语法的Thumb指令。此编译选项和在源文件头使用THUMB伪操作效果相同。
  · --unsafe:降低汇编器的警告级别。详见控制针对信息输出一节。
  · --via file:指示汇编器从指定文件file中读取各选项信息。
  · inputfile:为输入的源程序,必须是ARM或Thumb汇编源程序。
  下面各节详细介绍以上选项中常用到的选项。
  10.4.1 选项说明列表
  在命令行输入下面的汇编命令,可使汇编器输出所有可用选项类别。
  armasm –help
  10.4.2 过程调用标准AAPCS
  为了使不同编译器编译的程序之间能够相互调用,必须为子程序间的调用规定一定的规则。AAPCS就是这样一个标准。所谓AAPCS,其英文全称为Procedure Call Standard for the ARM Architecture (AAPCS),即ARM体系结构过程调用标准。它是ABI(Application Binary Interface (ABI) for the ARM Architecture (base standard) [BSABI])标准的一部分。
  可以使用“--apcs”选项告诉编译器将源代码编译成符号AAPCS调用标准的目标代码。
  注意使用“--apcs”选项并不影响代码的产生,编译器只是在各段中放置相应的属性,标识用户选定的AAPCS属性。
  与AAPCS相关的编译/汇编选项有以下几种。
  · none:指定输入文件不使用AAPCS规则。
  · /interwork:指定输入文件符合ARM/Thumb交互标准。
  · /nointerwork:指定输入文件不能使用ARM/Thumb交互。这是编译器默认选项。
  · /ropi:指定输入文件是位置无关只读文件。
  · /noropi:指定输入文件是非位置无关只读文件。这是编译器默认选项。
  · /pic:同/ropi。
  · /nopic:同/noropi。
  · /rwpi:指定输入文件是位置无关可读可写文件。
  · /norwpi:指定输入文件是非位置无关可读可写文件。
  · /pid:同/rwpi。
  · /nopid:同/norwpi。
  · /fpic:指定输入文件编译成位置无关只读代码。代码中地址是FPIC地址。
  · /swstackcheck:编译过程中对输入文件使用堆栈检测。
  · /noswstackcheck:编译过程中对输入文件不使用堆栈检测。这是编译器默认选项。
  · /swstna:如果汇编程序对于是否进行数据栈检查无所谓,而与该汇编程序连接的其他程序指定了选项/swst或选项/noswst,这时该汇编程序使用选项/swstna。
  10.4.3 浮点模式选项
  “--fpmode model”选项指定所选的浮点模式。可使用的浮点模式有以下几种。
  · ieee_full:所有的浮点操作符号IEEE标准,其中包括单精度浮点操作和双精度浮点操作。浮点模式可以在使用时动态选择。使用该选项,编译器将使用下面的预定义符号。
  __FP_IEEE;
  __FP_FENV_EXCEPTIONS;
  __FP_FENV_ROUNDING;
  __FP_INEXACT_EXCEPTION。
  · ieee_fixed:符合IEEE标准的浮点运算异常处理规则。使用该选项,编译器将使用下面的预定义符号。
  __FP_IEEE;
  __FP_FENV_EXCEPTIONS。
  · ieee_no_fenv:和JAVA兼容的浮点运算算法选择。预定义的符号为__FP_IEEE。
  · std:和C和C++兼容的浮点运算算法选择。这是编译器默认选项。
  · fast:快速浮点运算选项。使用该选项将影响浮点运算的精度。
  10.4.4 为CPU命名选项
  使用“--cpu name”选项为目标程序使用的CPU命名。其中name的取值为4T、5TE或6T2。编译器的默认值为ARM7TDMI。
  下面的选项使编译器列出所有当前可使用的CPU名。
  armasm --cpu list
  10.4.5 为FPU命名选项
  选项“--FPU”指定所使用的浮点运算单元的结构。
 

声明:本文内容及配图由入驻作者撰写或者入驻合作网站授权转载。文章观点仅代表作者本人,不代表电子发烧友网立场。文章及其配图仅供工程师学习之用,如有内容侵权或者其他违规问题,请联系本站处理。 举报投诉

评论(0)
发评论

下载排行榜

全部0条评论

快来发表一下你的评论吧 !

'+ '

'+ '

'+ ''+ '
'+ ''+ ''+ '
'+ ''+ '' ); $.get('/article/vipdownload/aid/'+webid,function(data){ if(data.code ==5){ $(pop_this).attr('href',"/login/index.html"); return false } if(data.code == 2){ //跳转到VIP升级页面 window.location.href="//m.obk20.com/vip/index?aid=" + webid return false } //是会员 if (data.code > 0) { $('body').append(htmlSetNormalDownload); var getWidth=$("#poplayer").width(); $("#poplayer").css("margin-left","-"+getWidth/2+"px"); $('#tips').html(data.msg) $('.download_confirm').click(function(){ $('#dialog').remove(); }) } else { var down_url = $('#vipdownload').attr('data-url'); isBindAnalysisForm(pop_this, down_url, 1) } }); }); //是否开通VIP $.get('/article/vipdownload/aid/'+webid,function(data){ if(data.code == 2 || data.code ==5){ //跳转到VIP升级页面 $('#vipdownload>span').text("开通VIP 免费下载") return false }else{ // 待续费 if(data.code == 3) { vipExpiredInfo.ifVipExpired = true vipExpiredInfo.vipExpiredDate = data.data.endoftime } $('#vipdownload .icon-vip-tips').remove() $('#vipdownload>span').text("VIP免积分下载") } }); }).on("click",".download_cancel",function(){ $('#dialog').remove(); }) var setWeixinShare={};//定义默认的微信分享信息,页面如果要自定义分享,直接更改此变量即可 if(window.navigator.userAgent.toLowerCase().match(/MicroMessenger/i) == 'micromessenger'){ var d={ title:'ARM汇编编译器的使用',//标题 desc:$('[name=description]').attr("content"), //描述 imgUrl:'https://'+location.host+'/static/images/ele-logo.png',// 分享图标,默认是logo link:'',//链接 type:'',// 分享类型,music、video或link,不填默认为link dataUrl:'',//如果type是music或video,则要提供数据链接,默认为空 success:'', // 用户确认分享后执行的回调函数 cancel:''// 用户取消分享后执行的回调函数 } setWeixinShare=$.extend(d,setWeixinShare); $.ajax({ url:"//www.obk20.com/app/wechat/index.php?s=Home/ShareConfig/index", data:"share_url="+encodeURIComponent(location.href)+"&format=jsonp&domain=m", type:'get', dataType:'jsonp', success:function(res){ if(res.status!="successed"){ return false; } $.getScript('https://res.wx.qq.com/open/js/jweixin-1.0.0.js',function(result,status){ if(status!="success"){ return false; } var getWxCfg=res.data; wx.config({ //debug: true, // 开启调试模式,调用的所有api的返回值会在客户端alert出来,若要查看传入的参数,可以在pc端打开,参数信息会通过log打出,仅在pc端时才会打印。 appId:getWxCfg.appId, // 必填,公众号的唯一标识 timestamp:getWxCfg.timestamp, // 必填,生成签名的时间戳 nonceStr:getWxCfg.nonceStr, // 必填,生成签名的随机串 signature:getWxCfg.signature,// 必填,签名,见附录1 jsApiList:['onMenuShareTimeline','onMenuShareAppMessage','onMenuShareQQ','onMenuShareWeibo','onMenuShareQZone'] // 必填,需要使用的JS接口列表,所有JS接口列表见附录2 }); wx.ready(function(){ //获取“分享到朋友圈”按钮点击状态及自定义分享内容接口 wx.onMenuShareTimeline({ title: setWeixinShare.title, // 分享标题 link: setWeixinShare.link, // 分享链接 imgUrl: setWeixinShare.imgUrl, // 分享图标 success: function () { setWeixinShare.success; // 用户确认分享后执行的回调函数 }, cancel: function () { setWeixinShare.cancel; // 用户取消分享后执行的回调函数 } }); //获取“分享给朋友”按钮点击状态及自定义分享内容接口 wx.onMenuShareAppMessage({ title: setWeixinShare.title, // 分享标题 desc: setWeixinShare.desc, // 分享描述 link: setWeixinShare.link, // 分享链接 imgUrl: setWeixinShare.imgUrl, // 分享图标 type: setWeixinShare.type, // 分享类型,music、video或link,不填默认为link dataUrl: setWeixinShare.dataUrl, // 如果type是music或video,则要提供数据链接,默认为空 success: function () { setWeixinShare.success; // 用户确认分享后执行的回调函数 }, cancel: function () { setWeixinShare.cancel; // 用户取消分享后执行的回调函数 } }); //获取“分享到QQ”按钮点击状态及自定义分享内容接口 wx.onMenuShareQQ({ title: setWeixinShare.title, // 分享标题 desc: setWeixinShare.desc, // 分享描述 link: setWeixinShare.link, // 分享链接 imgUrl: setWeixinShare.imgUrl, // 分享图标 success: function () { setWeixinShare.success; // 用户确认分享后执行的回调函数 }, cancel: function () { setWeixinShare.cancel; // 用户取消分享后执行的回调函数 } }); //获取“分享到腾讯微博”按钮点击状态及自定义分享内容接口 wx.onMenuShareWeibo({ title: setWeixinShare.title, // 分享标题 desc: setWeixinShare.desc, // 分享描述 link: setWeixinShare.link, // 分享链接 imgUrl: setWeixinShare.imgUrl, // 分享图标 success: function () { setWeixinShare.success; // 用户确认分享后执行的回调函数 }, cancel: function () { setWeixinShare.cancel; // 用户取消分享后执行的回调函数 } }); //获取“分享到QQ空间”按钮点击状态及自定义分享内容接口 wx.onMenuShareQZone({ title: setWeixinShare.title, // 分享标题 desc: setWeixinShare.desc, // 分享描述 link: setWeixinShare.link, // 分享链接 imgUrl: setWeixinShare.imgUrl, // 分享图标 success: function () { setWeixinShare.success; // 用户确认分享后执行的回调函数 }, cancel: function () { setWeixinShare.cancel; // 用户取消分享后执行的回调函数 } }); }); }); } }); } function openX_ad(posterid, htmlid, width, height) { if ($(htmlid).length > 0) { var randomnumber = Math.random(); var now_url = encodeURIComponent(window.location.href); var ga = document.createElement('iframe'); ga.src = 'https://www1.elecfans.com/www/delivery/myafr.php?target=_blank&cb=' + randomnumber + '&zoneid=' + posterid+'&prefer='+now_url; ga.width = width; ga.height = height; ga.frameBorder = 0; ga.scrolling = 'no'; var s = $(htmlid).append(ga); } } openX_ad(828, '#berry-300', 300, 250);