ARMv8指令學(xué)習(xí)(1)
(1) TBNZ x0, #uimm6, label
本文引用地址:http://www.ex-cimer.com/article/201611/317218.htmTest and branch Not zero.
如果x0[uimm6]!=0 , then jump to label位置處執(zhí)行.
(2) TBZ x0, #uimm6, label
Test and branch Zero.
如果x0[uimm6]==0 , then jump to label位置處執(zhí)行.
(3) CBZ x0, label
Compare and Branch Zero
如果x0==0 , then jump to label位置處執(zhí)行
(4) CBNZ x0, label
Compare and branch Not zero.
如果x0 !=0 , then jump to label位置處執(zhí)行
2. LDUR / LDURB / LDURSB / LDURH / LDURSH / LDURSW / STUR / STURB / STURH
它們都屬于Load-Store Single Register(unscaledoffset)
unscaled offset : 指的是"Base addr + 一個(gè)立即數(shù)"
(1) ldur x0,[base,#simm9]
x0 = [base+simm9]指向的內(nèi)容
(2) ldurb w0,[base,#simm9]
從 [base+simm9]指向的內(nèi)容中:取出一個(gè)byte,賦給w0.
w0中的其它字節(jié):用0擴(kuò)展得到.
(3) ldursb w0,[base,#simm9]
從 [base+simm9]指向的內(nèi)容中:取出一個(gè)byte,賦給w0.
w0中的其它字節(jié):用此byte的符號位擴(kuò)展得到.
(4) ldurh
類似ldurb,不過:這次取halfword(2 bytes)
(5) ldursh
類似ldursb,不過:這次取halfword(2 bytes)
(6) ldursw
類似ldursb,不過:這次取word(4 bytes)
(7) stur x0,[base,#simm9]
把x0保存到[base+#simm9]指向的內(nèi)存位置
(8) sturb x0,[base,#simm9]
把x0中的一個(gè)byte,保存到[base+#simm9]指向的內(nèi)存位置
(9) sturh x0,[base,#simm9]
把x0中的一個(gè)half-word(2 bytes),保存到[base+#simm9]指向的內(nèi)存位置
評論