arm中的饱和指令
来源:互联网 发布:达人如何挂淘宝 编辑:程序博客网 时间:2024/04/27 18:35
转自--- http://www.cnblogs.com/c6000/archive/2010/11/08/1872223.html
ARMv6 及更高版本中推出了饱和指令:SSAT 和 USAT, SSAT16 和 USAT16
有符号饱和到任何位位置和无符号饱和到任何位位置,可选择在饱和前进行移位。
SSAT
可将有符号值饱和到有符号范围内。
USAT
可将有符号值饱和到无符号范围内。
语法
op
{cond
}Rd
, #sat
,Rm
{,shift
}
其中:
op
是
SSAT
或USAT
。cond
是一个可选的条件代码(请参阅条件执行)。
Rd
是目标寄存器。
不能为 r15。Rd
sat
指定要饱和到的位位置,
SSAT
的范围在 1 到 32 之间,USAT
的范围在 0 到 31 之间。Rm
是包含操作数的寄存器。
不能为 r15。Rm
shift
是一个可选的移位。 必须为下列项之一:
ASR #
n
其中,
的范围为 1-32 (ARM) 或 1-31 (Thumb-2)n
LSL #
n
其中,
的范围为 0-31。n
操作
SSAT
指令会先进行指定的移位,然后将结果饱和到有符号范围 –2sat–1 ≤ x
≤ 2sat–1 –1。
USAT
指令会先进行指定的移位,然后将结果饱和到无符号范围 0 ≤ x
≤ 2sat – 1。
条件标记
如果发生饱和,则这些指令设置 Q 标记。 若要读取 Q 标记的状态,请使用 MRS
指令(请参阅MRS)。
体系结构
这些 ARM 指令可用于 ARMv6 及更高版本。
这些 32 位 Thumb 指令可用于 ARMv6T2 及更高版本。
这些指令均无 16 位 Thumb 版本。
示例
SSAT r7, #16, r7, LSL #4 USATNE r0, #7, r5
并行半字饱和指令。
SSAT16
可将有符号值饱和到有符号范围内。
USAT16
可将有符号值饱和到无符号范围内。
语法
op
{cond
}Rd
, #sat
,Rn
其中:
op
是下列项之一:
SSAT16
有符号饱和。
USAT16
无符号饱和。
cond
是一个可选的条件代码(请参阅条件执行)。
Rd
是目标寄存器。
sat
指定要饱和到的位位置,
SSAT16
的范围在 1 到 16 之间,USAT16
的范围在 0 到 15 之间。Rn
是存放操作数的寄存器。
不要将 r15 用作
或 Rd
。Rn
操作
有符号和无符号半字饱和任何位位置。
SSAT16
指令可将每个有符号半字饱和到有符号范围 –2sat–1 ≤ x
≤ 2sat–1 –1 内。
USAT16
指令可将每个有符号半字饱和到无符号范围 0 ≤ x
≤ 2sat –1 内。
条件标记
只要有半字发生饱和,这些指令就会设置 Q 标记。 若要读取 Q 标记的状态,请使用 MRS
指令(请参阅MRS)。
体系结构
这些 ARM 指令可用于 ARMv6 及更高版本。
这些 32 位 Thumb 指令可用于 ARMv6T2 及更高版本(ARMv7-M 架构除外)。
这些指令均无 16 位 Thumb 版本。
示例
SSAT16 r7, #12, r7 USAT16 r0, #7, r5
不正确的示例
SSAT16 r1, #16, r2, LSL #4 ; shifts not permitted with halfword saturations
- arm中的饱和指令
- ARM中的MOV指令
- ARM中的MOV指令
- ARM中的---汇编指令
- ARM中的---汇编指令
- ARM中的常用指令
- ARM中的---汇编指令
- ARM中的---汇编指令
- ARM中的---汇编指令
- ARM中的---汇编指令
- ARM中的---汇编指令
- ARM中的常用指令
- arm中的汇编语言之ARM指令集
- ARM中的B指令和BL指令
- ARM中的条件执行指令 (IT指令)
- arm汇编中的跳转指令
- ARM中的STM/LDM指令
- arm指令中的伪操作
- VS开发Windows应用程序建错工程后的几种解决方案
- 理解变量字符的截取功能
- 12款精美的免费 HTML 网站模板下载
- ie6 不支持 z-index:0 (z-index 为 0)
- hadoop公平调度其Fair Scheduler运行错误
- arm中的饱和指令
- [.net]记录一些自己写代码时的总结(持续更新)
- windows socket 函数
- 还是徒步香山,每周一次
- 什么是glibc
- css位置
- Android核心分析(24)----Android GDI之显示缓冲管理
- ByteArrayOutputStream和ByteArrayInputStream详解 &&&管道流
- 关于Java的return continue break语句的讲解