資料介紹
5.2 MVN指令
1.指令編碼格式
MVN是反相傳送(Move Negative)指令。它將操作數的反碼傳送到目的寄存器。
MVN指令多用于向寄存器傳送一個負數或生成位掩碼。
指令的編碼格式如圖5.2所示。
圖5.2 MVN指令編碼格式
MVN指令將《shifter_operand》表示的數據的反碼傳送到目的寄存器Rd。并根據操作的結果更新CPSR中相應的條件標志位。
2.指令的語法格式
MNV{《cond》}{S} 《Rd》,《shifter_operand》
① 《cond》
為指令編碼中的條件域。它指示MVN指令在什么條件下執行。當《cond》忽略時,指令為無條件執行(cond=AL(Alway))。
② S(bit[20])
如果S=1,MVN指令更新CPSR中條件標志位的值;如果S=0,MVN指令不更新CPSR中條件標志位的值。當更新狀態寄存器CPSR中的條件標志位時,有兩種情況。
· 如果指令中的目標寄存器《Rd》不是為r15,指令根據傳送的數值設置CPSR中的N位和Z位(如果數據在傳送前需要移位,則根據移位后的數值設置),并根據移位器的進位值設置CPSR的C位。標志位V和其他位不受影響。
· 如果指令中的目標寄存器《Rd》為r15,則當前處理器模式對應的SPSR的值復制到CPSR寄存器中,對于用戶模式和系統模式,由于沒有相應的SPSR,指令執行的結果不可預知。
③ 《Rd》
確定目標寄存器。
④ 《shifter_operand》
確定操作數,為目標寄存器傳送數據。
3.指令操作的偽代碼
指令操作的偽代碼如下面程序段所示。
If ConditionPassed{cond} then
Rd = NOT(shifter_operand)
If S==1 and Rd==r15 then
CPSR = SPSR
Else if S==1 then
N Flag = Rd[31]
Z Flag = If Rd==0 then 1 else 0
C Flag = shifter_carry_out
V Flag = unaggected
4.指令舉例
【例5.2】MVN指令
MVN指令和MOV指令相同也可以把一個數N送到目標寄存器Rd,其中N可以是立即數,也可以是寄存器。
注意這是邏輯非操作而不是算術操作,這個取反的值加 1 才是它的取負的值。
MVN R0, #4 ; R0 = -5
MVN R0, #0 ; R0 = -1
5.指令的使用
MVN指令主要完成以下功能。
· 向寄存器中傳送一個負數。
· 生成位掩碼(bit mask)。
· 求一個數的反碼。
?
1.指令編碼格式
MVN是反相傳送(Move Negative)指令。它將操作數的反碼傳送到目的寄存器。
MVN指令多用于向寄存器傳送一個負數或生成位掩碼。
指令的編碼格式如圖5.2所示。
圖5.2 MVN指令編碼格式
MVN指令將《shifter_operand》表示的數據的反碼傳送到目的寄存器Rd。并根據操作的結果更新CPSR中相應的條件標志位。
2.指令的語法格式
MNV{《cond》}{S} 《Rd》,《shifter_operand》
① 《cond》
為指令編碼中的條件域。它指示MVN指令在什么條件下執行。當《cond》忽略時,指令為無條件執行(cond=AL(Alway))。
② S(bit[20])
如果S=1,MVN指令更新CPSR中條件標志位的值;如果S=0,MVN指令不更新CPSR中條件標志位的值。當更新狀態寄存器CPSR中的條件標志位時,有兩種情況。
· 如果指令中的目標寄存器《Rd》不是為r15,指令根據傳送的數值設置CPSR中的N位和Z位(如果數據在傳送前需要移位,則根據移位后的數值設置),并根據移位器的進位值設置CPSR的C位。標志位V和其他位不受影響。
· 如果指令中的目標寄存器《Rd》為r15,則當前處理器模式對應的SPSR的值復制到CPSR寄存器中,對于用戶模式和系統模式,由于沒有相應的SPSR,指令執行的結果不可預知。
③ 《Rd》
確定目標寄存器。
④ 《shifter_operand》
確定操作數,為目標寄存器傳送數據。
3.指令操作的偽代碼
指令操作的偽代碼如下面程序段所示。
If ConditionPassed{cond} then
Rd = NOT(shifter_operand)
If S==1 and Rd==r15 then
CPSR = SPSR
Else if S==1 then
N Flag = Rd[31]
Z Flag = If Rd==0 then 1 else 0
C Flag = shifter_carry_out
V Flag = unaggected
4.指令舉例
【例5.2】MVN指令
MVN指令和MOV指令相同也可以把一個數N送到目標寄存器Rd,其中N可以是立即數,也可以是寄存器。
注意這是邏輯非操作而不是算術操作,這個取反的值加 1 才是它的取負的值。
MVN R0, #4 ; R0 = -5
MVN R0, #0 ; R0 = -1
5.指令的使用
MVN指令主要完成以下功能。
· 向寄存器中傳送一個負數。
· 生成位掩碼(bit mask)。
· 求一個數的反碼。
?
下載該資料的人也在下載
下載該資料的人還在閱讀
更多 >
- 51單片機數據傳送指令
- 51單片機之系統指令
- 使用51單片機實現數據傳送指令的資料免費下載
- 51單片機的數據傳遞類和控制轉移類指令的詳細資料說明
- 51單片機的數據傳送指令詳細資料說明
- 單片機程序設計案例教程之數據傳送指令的詳細資料說明
- 80X86指令系統-傳送指令講解的詳細資料課件免費下載 0次下載
- 淺談單寄存器數據傳送指令 1次下載
- Thumb指令集之多寄存器數據傳送指令解析 0次下載
- 數據傳送指令之程序狀態寄存器指令簡述 1次下載
- 數據傳送指令之單數據交換指令 1次下載
- 數據處理指令之SUB減操作指令分析 1次下載
- 數據傳送指令之MOV指令 4次下載
- 4.3 數據傳送指令 0次下載
- MCS-51系列單片機指令系統表數據傳送類指令
- 三菱PLC數據傳送指令介紹 4112次閱讀
- 三菱PLC傳送指令的用法 4449次閱讀
- 電路塊ANB指令與ORB指令操作 6577次閱讀
- PLC傳送與比較指令用法 6487次閱讀
- 三菱PLC的塊傳送和多點傳送指令 4434次閱讀
- MCS-51單片機的指令系統和尋址方式有哪些 6017次閱讀
- 89C51單片機16位數據傳送指令的執行過程 5341次閱讀
- 基于51單片機查表指令的應用 3739次閱讀
- 指令和偽指令分得清嗎? 6961次閱讀
- PLC傳送與比較指令用法與PLC硬件的實現 6520次閱讀
- 關于單片機89C51指令匯集 2653次閱讀
- 基于AT89S51數據傳送類指令程序 2808次閱讀
- 協處理器的三大類數據傳送指令 2182次閱讀
- 單片機控制系統中實現DMA數據傳送方法介紹 1.1w次閱讀
- thumb指令集是什么_thumb指令集與arm指令集的區別 1.8w次閱讀
下載排行
本周
- 1AN158 GD32VW553 Wi-Fi開發指南
- 1.51MB | 2次下載 | 免費
- 2嵌入式軟件開發符合ISO 26262 功能安全標準
- 1.61 MB | 1次下載 | 免費
- 3AN148 GD32VW553射頻硬件開發指南
- 2.07MB | 1次下載 | 免費
- 4PZT驅動開關電路
- 0.09 MB | 1次下載 | 免費
- 5模擬電路仿真實現
- 2.94MB | 1次下載 | 免費
- 6PCB繪制基礎知識
- 2.44MB | 1次下載 | 免費
- 7EE-38:ADSP-2181 IDMA端口-周期竊取時序
- 75.0KB | 次下載 | 免費
- 8EE-82:使用ADSP-2181 DSP的IO空間對另一個ADSP-2181進行IDMA引導
- 86.86KB | 次下載 | 免費
本月
- 1ADI高性能電源管理解決方案
- 2.43 MB | 452次下載 | 免費
- 2免費開源CC3D飛控資料(電路圖&PCB源文件、BOM、
- 5.67 MB | 139次下載 | 1 積分
- 3基于STM32單片機智能手環心率計步器體溫顯示設計
- 0.10 MB | 132次下載 | 免費
- 4美的電磁爐維修手冊大全
- 1.56 MB | 24次下載 | 5 積分
- 5如何正確測試電源的紋波
- 0.36 MB | 19次下載 | 免費
- 6感應筆電路圖
- 0.06 MB | 10次下載 | 免費
- 7LZC3106G高性能諧振控制器中文手冊
- 1.29 MB | 9次下載 | 1 積分
- 8萬用表UT58A原理圖
- 0.09 MB | 9次下載 | 5 積分
總榜
- 1matlab軟件下載入口
- 未知 | 935121次下載 | 10 積分
- 2開源硬件-PMP21529.1-4 開關降壓/升壓雙向直流/直流轉換器 PCB layout 設計
- 1.48MB | 420062次下載 | 10 積分
- 3Altium DXP2002下載入口
- 未知 | 233088次下載 | 10 積分
- 4電路仿真軟件multisim 10.0免費下載
- 340992 | 191367次下載 | 10 積分
- 5十天學會AVR單片機與C語言視頻教程 下載
- 158M | 183335次下載 | 10 積分
- 6labview8.5下載
- 未知 | 81581次下載 | 10 積分
- 7Keil工具MDK-Arm免費下載
- 0.02 MB | 73810次下載 | 10 積分
- 8LabVIEW 8.6下載
- 未知 | 65988次下載 | 10 積分
評論
查看更多