日韩av黄I国产麻豆传媒I国产91av视频在线观看I日韩一区二区三区在线看I美女国产在线I麻豆视频国产在线观看I成人黄色短片

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

ARM指令寻址方式之: 内存访问指令寻址

發布時間:2024/4/20 编程问答 53 豆豆
生活随笔 收集整理的這篇文章主要介紹了 ARM指令寻址方式之: 内存访问指令寻址 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

4.2? 內存訪問指令尋址

根據內存訪問指令的分類,內存訪問指令的尋址方式可以分為以下幾種。

① 字及無符號字節的Load/Store指令的尋址方式。

② 雜類Load/Store指令的尋址方式。

③ 批量Load/Store指令的尋址方式。

④ 協處理器Load/Store指令的尋址方式。

?

4.2.1? 字及無符號字節的Load/Store指令的尋址方式

字及無符號字節的Load/Store指令語法格式如下:

?

LDR|STR{<cond>}{B}{T}? <Rd>,<addressing_mode>

?

其中<addressing_mode>共有9種尋址方式,如表4.2所示。

表4.2?? 字及無符合字節的Load/Store指令的尋址方式

?

格??? 式

模??? 式

1

[Rn,#±<offset_12>]

立即數偏移尋址

(Immediate offset)

2

[Rn,±Rm]

寄存器偏移尋址

(Register offset)

3

[Rn,Rm,<shift>#< offset_12>]

帶移位的寄存器偏移尋址

(Scaled register offset)

4

[Rn,#±< offset_12>]!

立即數前索引尋址

(Immediate pre-indexed)

5

[Rn,±Rm]!

寄存器前索引尋址

(Register post-indexed)

6

[Rn,Rm,<shift>#< offset_12>]!

帶移位的寄存器前索引尋址

(Scaled register pre-indexed)

7

[Rn],#±< offset_12>

立即數后索引尋址

(Immediate post-indeded)

8

[Rn],±<Rm>

寄存器后索引尋址

(Register post-indexed)

9

[Rn],±<Rm>,<shift>#< offset_12>

帶移位的寄存器后索引尋址

(Scaled register post-indexed)

?

字及無符號字節的Load/Store指令的解碼格式如圖4.13所示。

圖4.13? 字及無符號字節的Load/Store指令的解碼格式

?

編碼格式中各位的含義如表4.3所示。

表4.3?????????? 字和無符號半字Load/Store指令編碼格式各位含義

位? 標? 識

取??? 值

含??? 義

P

P=0

使用后索引尋址

P=1

使用偏移地址或前索引尋址(由W位決定)

U

U=0

訪問的地址=基址寄存器的值-偏移量(offset)

U=1

訪問的地址=基址寄存器的值+偏移量(offset)

B

B=0

字訪問Load/Store

B=1

無符號字節訪問Load/Store

W

W=0

如果P=0,該指令為LDR、LDRB、STR或STRB指令,且內存訪問指令為正常訪問指令;如果P=1,指令執行不更新基地址

W=1

如果P=0,該指令為LDRBT、LDRT、STRBT或STRT,且指令為非特權(用戶模式)訪問指令;如果P=1,計算內存地址并更新基地址

L

L=0

Store指令

L=1

Load指令

?

1.[Rn,#±<offset_12>]

(1)編碼格式

指令的編碼格式如圖4.14所示。

圖4.14? 內存訪問指令——立即數偏移尋址編碼格式

?

內存訪問地址為基址寄存器Rn的值加(或減)立即數offset_12。

?

編程中,在訪問結構體或記錄(record)類型的變量時,這些內存的操作指令是十分有效的。另外,在子程序中也常用這些指令訪問本地變量和堆棧。

?

(2)語法格式

?

LDR|STR{<cond>}{B}{T}? <Rd>,[<Rn>,#±<offset_12>]

?

其中:

·? Rn為基址寄存器,該寄存器包含內存訪問的基地址;

·? <offset_12>為12位立即數,內存訪問地址偏移量。

?

(3)操作偽代碼

?

If? U = = 1? then

???? Address = Rn + offset_12

Else

???? Address = Rn – offset_12

?

(4)說明

① 如果指令中沒有指定立即數,使用[<Rn>],編譯器按[<Rn>,#0]形式編碼。

② 如果Rn被指定為程序計數器r15,其值為當前指令地址加8。

?

2.[Rn,±Rm]

(1)編碼格式

指令的編碼格式如圖4.15所示。

圖4.15? 內存訪問指令——寄存器偏移尋址編碼格式

?

內存訪問地址為基址寄存器Rn的值加(或減)偏移寄存器Rm的值。

該尋址方式適合使用指針訪問字節數組中的數據成員。

?

(2)語法格式

?

LDR|STR{<cond>}{B}{T}? <Rd>,[<Rn>,±<Rm>]

?

其中:

·? Rn為基址寄存器,該寄存器包含內存訪問的基地址;

·? <Rm>為偏移地址寄存器,包含內存訪問地址偏移量。

?

(3)操作偽代碼

?

If? U = = 1? then

???? Address = Rn + Rm

Else

???? Address = Rn – Rm

?

(4)說明

如果Rn被指定為程序計數器r15,其值為當前指令地址加8;如果r15被用作偏移地址寄存器Rm的值,指令的執行結果不可預知。

?

3.[Rn,Rm,<shift>#< offset_12>]

(1)編碼格式

指令的編碼格式如圖4.16所示。

圖4.16? 內存訪問指令——帶移位的寄存器偏移尋址編碼格式

?

內存地址為Rn的值加/減通過移位操作后的Rm的值。

當數組中的成員長度大于1個字節時,使用該尋址方式可高效率地訪問數組成員。

?

(2)語法格式

語法格式有以下5種。

?

LDR|STR{<cond>}{B}{T}? <Rd>,[<Rn>,±<Rm>,LSL #< offset_12>]

LDR|STR{<cond>}{B}{T}? <Rd>,[<Rn>,±<Rm>,LSR #< offset_12>]

LDR|STR{<cond>}{B}{T}? <Rd>,[<Rn>,±<Rm>,ASR #< offset_12>]

LDR|STR{<cond>}{B}{T}? <Rd>,[<Rn>,±<Rm>,ROR #< offset_12>]

LDR|STR{<cond>}{B}{T}? <Rd>,[<Rn>,±<Rm>,RRX]

?

其中:

·? Rn為基址寄存器,該寄存器包含內存訪問的基地址;

·? <Rm>為偏移地址寄存器,包含內存訪問地址偏移量;

·? LSL表示邏輯左移操作;

·? LSR表示邏輯右移操作;

·? ASR表示算術右移操作;

·? ROR表示循環右移操作;

·? RRX表示擴展的循環右移。

·? <shift_imm>為移位立即數。

?

(3)操作偽代碼

?

Case? shift? of

???? 0b00? /*LSL*/

???? ??????Index = Rm logic_shift_left? shift_imm

???? 0b01? /*LSR*/

?????????? If? shift_imm = = 0? then /*LSR? #32*/

??????????????? Index = 0

?????????? Else

??????????????? Index = Rm logical_shift_right? shift_imm

???? 0b10? /*ASR*/

?????????? If? shift_imm = = 0 then /*ASR? #32*/

??????????????? If? Rm[31] = = 1 then

???????????????????? Index = 0xffffffff

??????????????? Else

???????????????????? Index = 0

?????????? Else

??????????????? Index = Rm? Arithmetic_shift_Right? shift_imm

???? 0b11? /* ROR or RRX*/

?????????? If? shift_imm = = 0 then /*RRX*/

??????????????? Index = (C flag Logical_shift_left 31) OR

????????????????????????? (Rm logical_shift_Right 1)

?????????? Else /*ROR*/

??????????????? Index = Rm Rotate_Right shift_imm

Endcase

If? U = = 1 then

???? Address = Rn + index

Else /*U = = 0*/

???? Address = Rn – index

?

(4)說明

如果Rn被指定為程序計數器r15,其值為當前指令地址加8;如果r15被用作偏移地址寄存器Rm的值,指令的執行結果不可預知。

?

4.[Rn,#±< offset_12>]!

(1)編碼格式

指令的編碼格式如圖4.17所示。

圖4.17? 內存訪問指令——前索引立即數偏移尋址編碼格式

?

內存地址為基址寄存器Rn加/減立即數offset_8的值。當指令執行的條件<cc>滿足時,生成的地址寫回基址寄存器Rn中。

該尋址方式適合訪問數組自動進行數組下標的更新。

?

(2)語法格式

?

LDR|STR{<cond>}{B}{T}? <Rd>,[<Rn>,±<offset_12>] !

?

其中:

·? Rn為基址寄存器,該寄存器包含內存訪問的基地址;

·? <offset_12>為12位立即數,內存訪問地址偏移量;

·? !設置指令編碼中的W位,更新指令基址寄存器。

?

(3)操作偽代碼

?

If? U == 1? then

???? Address = Rn + offset_12

Else

???? Address = Rn – offset_12

If? ConditionPassed{cond}? then

???? Rn = address

?

(4)說明

① 如果指令中沒有指定立即數,使用[<Rn>],編譯器按[<Rn>,#0] ! 形式編碼。

② 如果Rn被指定為程序計數器r15,指令的執行結果不可預知。

?

5.[Rn,±Rm]!

(1)編碼格式

指令的編碼格式如圖4.18所示。

圖4.18? 內存訪問指令——前索引寄存器偏移尋址編碼格式

?

內存訪問地址為基址寄存器Rn的值加(或減)偏移寄存器Rm的值。當指令的執行條件<cc>滿足時,生成地地址將寫回基址寄存器。

?

(2)語法格式

?

LDR|STR{<cond>}{B}{T}? <Rd>,[<Rn>,±<Rm>]

?

其中:

·? Rn為基址寄存器,該寄存器包含內存訪問的基地址;

·? <Rm>為偏移地址寄存器,包含內存訪問地址偏移量;

·? !設置指令編碼中的W位,更新指令基址寄存器。

?

(3)操作偽代碼

?

If? U = = 1? then

???? Address = Rn + Rm

Else

???? Address = Rn – Rm

If? ConditionPassed{cond}? then

???? Rn = address

?

(4)說明

如果Rn和Rm指定為同一寄存器,指令的執行結果不可預知。

?

6.[Rn,±Rm,<shift>#< offset_12>]!

(1)編碼格式

指令的編碼格式如圖4.19所示。

圖4.19? 內存訪問指令——帶移位的前索引寄存器偏移尋址編碼格式

?

內存地址為Rn的值加/減通過移位操作后的Rm的值。當指令的執行條件<cc>滿足時,生成地地址將寫回基址寄存器。

?

(2)語法格式

語法格式有以下5種。

?

LDR|STR{<cond>}{B}{T}? <Rd>,[<Rn>,±<Rm>,LSL #< offset_12>] !

LDR|STR{<cond>}{B}{T}? <Rd>,[<Rn>,±<Rm>,LSR #< offset_12>] !

LDR|STR{<cond>}{B}{T}? <Rd>,[<Rn>,±<Rm>,ASR #< offset_12>] !

LDR|STR{<cond>}{B}{T}? <Rd>,[<Rn>,±<Rm>,ROR #< offset_12>] !

LDR|STR{<cond>}{B}{T}? <Rd>,[<Rn>,±<Rm>,RRX] !

?

其中:

·? Rn為基址寄存器,該寄存器包含內存訪問的基地址;

·? <Rm>為偏移地址寄存器,包含內存訪問地址偏移量;

·? LSL表示邏輯左移操作;

·? LSR表示邏輯右移操作;

·? ASR表示算術右移操作;

·? ROR表示循環右移操作;

·? RRX表示擴展的循環右移。

·? <shift_imm>為移位立即數。

·? !設置指令編碼中的W位,更新指令基址寄存器。

?

(3)操作偽代碼

?

Case? shift? of

???? 0b00? /*LSL*/

?????????? Index = Rm logic_shift_left? shift_imm

???? 0b01? /*LSR*/

?????????? If? shift_imm = = 0? then /*LSR? #32*/

??????????????? Index = 0

?????????? Else

??????????????? Index = Rm logical_shift_right? shift_imm

???? 0b10? /*ASR*/

?????????? If? shift_imm = = 0 then /*ASR? #32*/

??????????????? If? Rm[31] = = 1 then

???????????????????? Index = 0xffffffff

??????????????? Else

???????????????????? Index = 0

?????????? Else

??????????????? Index = Rm? Arithmetic_shift_Right? shift_imm

???? 0b11? /* ROR or RRX*/

?????????? If? shift_imm = = 0 then /*RRX*/

??????????????? Index = (C flag Logical_shift_left 31) OR

????????????????????????? (Rm logical_shift_Right 1)

?????????? Else /*ROR*/

??????????????? Index = Rm Rotate_Right shift_imm

Endcase

If? U = = 1 then

???? Address = Rn + index

Else /*U = = 0*/

???? Address = Rn – index

If? ConditionPassed{cond}? then

???? Rn = address

(4)說明

① 當PC用作基址寄存器Rn或Rm時,指令執行結果不可預知。

② 當Rn和Rm是同一個寄存器時,指令的執行結果不可預知。

?

7.[Rn],#±< offset_12>

(1)編碼格式

指令的編碼格式如圖4.20所示。

圖4.20? 內存訪問指令——后索引立即數偏移尋址編碼格式

?

指令使用基址寄存器Rn的值作為實際內存訪問地址。當指令的執行條件滿足時,將基址寄存器的值加/減偏移量產生新的地址值回寫到Rn寄存器中。

?

(2)語法格式

?

LDR|STR{<cond>}{B}{T}? <Rd>,[<Rn>],±<offset_12>

?

其中:

·? Rn為基址寄存器,該寄存器包含內存訪問的基地址;

·? <offset_12>為12位立即數,內存訪問地址偏移量。

?

(3)操作偽代碼

?

Address = Rn

If? conditionPassed{cond}? then

???? If? U = = 1 then

????????? Rn = Rn + offset_12

???? Else

????????? Rn = Rn – offset_12

?

(4)說明

① LDRBT、LDRT、STRBT和STRT指令只支持后索引尋址。

② 如果Rn被指定為程序計數器r15,指令的執行結果不可預知。

?

8.[Rn],±<Rm>

(1)編碼格式

指令的編碼格式如圖4.21所示。

圖4.21? 內存訪問指令——后索引寄存器偏移尋址編碼格式

?

指令訪問地址為實際的基址寄存器的值。當指令的執行條件滿足時,將基址寄存器的值加/減索引寄存器Rm的值回寫到Rn基址寄存器。

(2)語法格式

?

LDR|STR{<cond>}{B}{T}? <Rd>,[Rn],±<Rm>

?

其中:

·? Rn為基址寄存器,該寄存器包含內存訪問的基地址;

·? <Rm>為偏移地址寄存器,包含內存訪問地址偏移量。

(3)操作偽代碼

?

Address = Rn

If ?conditionPassed{cond}? then

???? If? U = = 1? then

????????? Rn = Rn + Rm

???? Else

????????? Rn = Rn – Rm

?

(4)說明

① LDRBT、LDRT、STRBT和STRT指令只支持后索引尋址。

② 如果Rm和Rn指定為同一寄存器,指令的執行結果不可預知。

?

9.[Rn],±Rm,<shift>#< offset_12>]

(1)編碼格式

指令的編碼格式如圖4.22所示。

圖4.22? 內存訪問指令——帶移位的后索引寄存器偏移尋址編碼格式

?

實際的內存訪問地址為寄存器Rn的值。當指令的執行條件滿足時,將基址寄存器值加/減一個地址偏移量產生新的地址值。

?

(2)語法格式

語法格式有以下5種。

?

LDR|STR{<cond>}{B}{T}? <Rd>,[<Rn>],±<Rm>,LSL #< offset_12>

LDR|STR{<cond>}{B}{T}? <Rd>,[<Rn>],±<Rm>,LSR #< offset_12>

LDR|STR{<cond>}{B}{T}? <Rd>,[<Rn>],±<Rm>,ASR #< offset_12>

LDR|STR{<cond>}{B}{T}? <Rd>,[<Rn>],±<Rm>,ROR #< offset_12>

LDR|STR{<cond>}{B}{T}? <Rd>,[<Rn>],±<Rm>,RRX

?

其中:

·? Rn為基址寄存器,該寄存器包含內存訪問的基地址;

·? <Rm>為偏移地址寄存器,包含內存訪問地址偏移量;

·? LSL表示邏輯左移操作;

·? LSR表示邏輯右移操作;

·? ASR表示算術右移操作;

·? ROR表示循環右移操作;

·? RRX表示擴展的循環右移。

·? <shift_imm>為移位立即數。

?

(3)操作偽代碼

?

Address = Rn

Case? shift? of

???? 0b00? /*LSL*/

?????????? Index = Rm logic_shift_left? shift_imm

???? 0b01? /*LSR*/

?????????? If? shift_imm = = 0? then /*LSR? #32*/

??????????????? Index = 0

?????????? Else

??????????????? Index = Rm logical_shift_right? shift_imm

???? 0b10? /*ASR*/

?????????? If? shift_imm = = 0 then /*ASR? #32*/

??????????????? If? Rm[31] = = 1 then

???????????????????? Index = 0xffffffff

??????????????? Else

???????????????????? Index = 0

?????????? Else

??????????????? Index = Rm? Arithmetic_shift_Right? shift_imm

???? 0b11? /* ROR or RRX*/

?????????? If? shift_imm = = 0 then /*RRX*/

??????????????? Index = (C flag Logical_shift_left 31) OR

????????????????????????? (Rm logical_shift_Right 1)

?????????? Else /*ROR*/

??????????????? Index = Rm Rotate_Right shift_imm

Endcase

If? ConditionPassed{cond}? then

??? If? U = = 1 then

???????? Rn = Rn + index

??? Else /*U = = 0*/

???????? Rn = Rn – index

?

(4)說明

① LDRBT、LDRT、STRBT和STRT指令只支持后索引尋址。

② 當PC用作基址寄存器Rn或Rm時,指令執行結果不可預知。

③ 當Rn和Rm是同一個寄存器時,指令的執行結果不可預知。

?

4.2.2? 雜類Load/Store指令的尋址方式

使用該類尋址方式的指令的語法格式如下。

?

LDR|STR{<cond>}H|SH|SB|D? <Rd>,<addressing_mode>

?

使用該類尋址方式的指令包括:(有符號/無符號)半字Load/Store指令、有符號字節Load/Store指令和雙字Load/Store指令。

?

該類尋址方式分為6種類型,如表4.4所示。

表4.4?? 雜類Load/Store指令的尋址方式

?

格??? 式

模??? 式

1

[Rn,#±<offset_8>]

立即數偏移尋址

(Immediate offset)

2

[Rn,±Rm]

寄存器偏移尋址

(Register offset)

3

[Rn,#±< offset_8>]!

立即數前索引尋址

(Immediate pre-indexed)

4

[Rn,±Rm]!

寄存器前索引尋址

(Register post-indexed)

5

[Rn],#±< offset_8>

立即數后索引尋址

(Immediate post-indeded)

6

[Rn],±<Rm>

寄存器后索引尋址

(Register post-indexed)

?

雜類Load/Store指令的解碼格式如圖4.23所示。

圖4.23? 雜類Load/Store指令解碼格式

?

編碼格式中各標志位的含義如表4.5所示。

表4.5??????? 雜類Load/Store指令編碼格式各標志位含義

位? 標? 識

取??? 值

含??? 義

P

P=0

使用后索引尋址

P=1

使用偏移地址或前索引尋址(由W位決定)

續表

位? 標? 識

取??? 值

含??? 義

U

U=0

訪問的地址=基址寄存器的值-偏移量(offset)

U=1

訪問的地址=基址寄存器的值+偏移量(offset)

W

W=0

如果P=0,使用后索引尋址;P=1,指令不改變基址寄存器的值

W=1

如果P=0,未定義指令;如果P=1,將計算的內存訪問地址回寫到基址寄存器

L

L=0

Store指令

L=1

Load指令

S

S=0

無符號半字內存訪問

S=1

有符號半字內存訪問

H

H=0

字節訪問

H=1

半字訪問

?

注意

當S=0并且H=0時,并非無符號的字節內存訪問指令。無符號的內存訪問指令不使用該種尋址方式,詳見本章上一節。

當S=1并且L=0時,并非是有符號的存儲指令,而是未定義指令。ARM指令并未區分有符號和無符號的字節和半字存儲。

?

1.[Rn,#±<offset_8>]

(1)編碼格式

指令的編碼格式如圖4.24所示。

圖4.24? 雜項內存訪問指令——立即數偏移尋址編碼格式

?

內存訪問地址為基址寄存器Rn的值加(或減)立即數offset_8。

編程中,在訪問結構體或記錄(record)類型的變量時,這些內存的操作指令是十分有效的。另外,在子程序中,也常用這些指令訪問本地變量和堆棧。當offset_8=0時,內存訪問地址即基址寄存器Rn的值。

?

(2)語法格式

?

LDR|STR{<cond>}H|SH|SB|D? <Rd>,[<Rn>,#±<offset_12>]

?

其中:

·? Rn為基址寄存器,該寄存器包含內存訪問的基地址。

·? <offset_8>為8位立即數,內存訪問地址偏移量。

?

(3)操作偽代碼

?

offset_8 = (immedH << 4) OR immedL

If? U = = 1? then

???? Address = Rn + offset_8

Else

???? Address = Rn – offset_8

?

(4)說明

① 如果指令中沒有指定立即數,使用[<Rn>],編譯器按[<Rn>,#0]形式編碼。

② 如果Rn被指定為程序計數器r15,其值為當前指令地址加8。

?

2.[Rn,±Rm]

(1)編碼格式

指令的編碼格式如圖4.25所示。

圖4.25? 雜項內存訪問指令——寄存器偏移尋址編碼格式

?

內存訪問地址為基址寄存器Rn的值加(或減)偏移寄存器Rm的值。

該尋址方式適合使用指針訪問數組中的單個數據成員。

?

(2)語法格式

?

LDR|STR{<cond>}H|SH|SB|D? <Rd>,[<Rn>,±<Rm>]

?

其中:

·? Rn為基址寄存器,該寄存器包含內存訪問的基地址;

·? <Rm>為偏移地址寄存器,包含內存訪問地址偏移量。

?

(3)操作偽代碼

?

If? U = = 1? then

???? Address = Rn + Rm

Else

???? Address = Rn – Rm

?

(4)說明

如果Rn被指定為程序計數器r15,其值為當前指令地址加8;如果r15被用作偏移地址寄存器Rm的值,指令的執行結果不可預知。

?

3.[Rn,#±< offset_8>]!

(1)編碼格式

指令的編碼格式如圖4.26所示。

圖4.26? 雜類內存訪問指令——前索引立即數偏移尋址編碼格式

?

內存地址為基址寄存器Rn加/減立即數offset_8的值。當指令執行的條件<cc>滿足時,生成的地址寫回基址寄存器Rn中。

?

該尋址方式適合訪問數組自動進行數組下標的更新。

?

(2)語法格式

?

LDR|STR{<cond>}H|SH|SB|D? <Rd>,[<Rn>,±<offset_8>] !

?

其中:

·? Rn為基址寄存器,該寄存器包含內存訪問的基地址;

·? <offset_8>為8位立即數,內存訪問地址偏移量,在指令編碼格式中被拆為immedH和immedL兩部分;

·? !設置指令編碼中的W位,更新指令基址寄存器。

?

(3)操作偽代碼

?

offset_8 = (immedH) << 4 OR immedL

If? U == 1? then

???? Address = Rn + offset_8

Else

???? Address = Rn – offset_8

If? ConditionPassed{cond}? then

???? Rn = address

?

(4)說明

① 如果指令中沒有指定立即數,使用[<Rn>],編譯器按[<Rn>,#0] ! 形式編碼。

② 如果Rn被指定為程序計數器r15,指令的執行結果不可預知。

?

4.[Rn,±Rm] !

(1)編碼格式

指令的編碼格式如圖4.27所示。

圖4.27? 雜項內存訪問指令——前索引寄存器偏移尋址編碼格式

?

內存訪問地址為基址寄存器Rn的值加(或減)偏移寄存器Rm的值。當指令的執行條件<cc>滿足時,生成地地址將寫回基址寄存器。

?

(2)語法格式

?

LDR|STR{<cond>}H|SH|SB|D? <Rd>,[<Rn>,±<Rm>]

?

其中:

·? Rn為基址寄存器,該寄存器包含內存訪問的基地址;

·? <Rm>為偏移地址寄存器,包含內存訪問地址偏移量;

·? !設置指令編碼中的W位,更新指令基址寄存器。

?

(3)操作偽代碼

?

If? U = = 1? then

???? Address = Rn + Rm

Else

???? Address = Rn – Rm

If? ConditionPassed{cond}? then

???? Rn = address

?

(4)說明

① 如果Rn和Rm指定為同一寄存器,指令的執行結果不可預知。

② 如果程序計數器r15被用作Rm或Rn,則指令的執行結果不可預知。

?

5.[Rn],#±< offset_8>

(1)編碼格式

指令的編碼格式如圖4.28所示。

圖4.28? 雜項內存訪問指令——后索引立即數偏移尋址編碼格式

?

指令使用基址寄存器Rn的值作為實際內存訪問地址。當指令的執行條件滿足時,將基址寄存器的值加/減偏移量生產新的地址值回寫到Rn寄存器中。

?

(2)語法格式

?

LDR|STR{<cond>}H|SH|SB|D? <Rd>,[<Rn>],±<offset_8>

?

其中:

·? Rn為基址寄存器,該寄存器包含內存訪問的基地址;

·? <offset_8>為8位立即數,內存訪問地址偏移量。

?

(3)操作偽代碼

?

Address = Rn

Offset_8 = (immedH << 4) OR immedL

If? conditionPassed{cond}? then

???? If? U = = 1 then

????????? Rn = Rn + offset_8

???? Else

????????? Rn = Rn – offset_8

?

(4)說明

① 當指令中沒有指定立即數時,匯編器按“[<Rn>],#0”編碼。

② 如果Rn被指定為程序計數器r15,指令的執行結果不可預知。

?

6.[Rn],±<Rm>

(1)編碼格式

指令的編碼格式如圖4.29所示。

圖4.29? 雜項內存訪問指令——后索引寄存器偏移尋址編碼格式

?

指令訪問地址為實際的基址寄存器的值。當指令的執行條件滿足時,將基址寄存器的值加/減索引寄存器Rm的值回寫到Rn基址寄存器。

?

(2)語法格式

?

LDR|STR{<cond>}H|SH|SB|D? <Rd>,[Rn],±<Rm>

?

其中:

·? Rn為基址寄存器,該寄存器包含內存訪問的基地址;

·? <Rm>為偏移地址寄存器,包含內存訪問地址偏移量。

?

(3)操作偽代碼

?

Address = Rn

If ?conditionPassed{cond}? then

???? If? U = = 1? then

????????? Rn = Rn + Rm

???? Else

????????? Rn = Rn – Rm

?

(4)說明

① 程序寄存器r15被指定為Rm或Rn,指令的執行結果不可預知。

② 如果Rm和Rn指定為同一寄存器,指令的執行結果不可預知。

?

4.2.3? 批量Load/Store指令尋址方式

批量Load/Store指令將一片連續內存單元的數據加載到通用寄存器組中或將一組通用寄存器的數據存儲到內存單元中。

?

批量Load/Store指令的尋址模式產生一個內存單元的地址范圍,指令寄存器和內存單元的對應關系滿足這樣的規則,即編號低的寄存器對應于內存中低地址單元,編號高的寄存器對應于內存中的高地址單元。

?

指令的語法格式如下。

?

LDM|STM{<cond>}<addressing_mode>? <Rn>{!},<registers><^>

?

指令的尋址方式如表4.6所示。

表4.6????? 批量Load/Store指令的尋址方式

?

格??? 式

模??? 式

1

IA(Increment After)

后遞增方式

2

IB(Increment Before)

先遞增方式

3

DA(Decrement After)

后遞減方式

4

DB(Decrement Before)

先遞減方式

?

指令的編碼格式如圖4.30所示。

圖4.30? 批量Load/Store指令編碼格式

?

編碼格式中各標志位的含義如表4.7所示。

表4.7??????? 批量Load/Store指令編碼格式各標志位含義

位標識

取??? 值

含??? 義

P

P=0

Rn包含的地址,是所要訪問的內存塊的高地址(U=0)還是低地址(U=1)

P=1

標識Rn所指向的內存單元是否被訪問

U

U=0

Rn所指內存單元為所要訪問的內存單元塊的高地址

U=1

Rn所指內存單元為所要訪問的內存單元塊的低地址

S

S=0

當程序計數器PC作為要加載的寄存器之一時,S標識是否將spsr內容拷貝到cpsr;對于不加載PC的load指令和所有store指令,S標識特權模式下,使用用戶模式寄存器組代替當前模式下寄存器組

S=1

W

W=0

數據傳送完畢,更新地址寄存器內容

W=1

L

L=0

Store指令

L=1

Load指令

?

1.IA尋址

(1)編碼格式

指令的編碼格式如圖4.31所示。

?

該尋址方式指定一片連續的內存地址空間,地址空間的大小<address_length>等于寄存器列表中寄存器數目的4倍。內存地址范圍起始地址<start_address>等于基址寄存器Rn的值。結束地址<end_address>等于起始地址<start_address>加上地址空間大小<address_length>。

?

圖4.31? 批量Load/Store指令——后增加尋址

?

地址空間中的每個內存單元對應寄存器列表中的一個寄存器。編號低的寄存器對應于內存中低地址單元,編號高的寄存器對應于內存中的高地址單元。

?

當指令執行條件滿足并且指令編碼格式中W位置位,基址寄存器Rn的值等于內存地址范圍結束地址<end_address>加4。

?

(2)語法格式

?

LDM|STM{<cond>}IA? <Rn>{!},<registers><^>

?

其中:

·? IA標識指令使用“后增加”尋址方式;

·? Rn為基址寄存器,包含內存訪問的基地址;

·? <registers>為指令操作的寄存器列表;

·? <^>表示如果寄存器列表中包含程序計數器PC,是否將spsr拷貝到cpsr。

?

(3)操作偽代碼

?

Start_address = Rn

End_address = Rn + (Number_of_Set_Bits_In(register_list)*4) – 4

If? conditionPassed(cond) and W = = 1 then

???? Rn = Rn + (Number_of_Set_Bits_In(register_list)*4)

?

2.DA尋址

(1)編碼格式

?

指令的編碼格式如圖4.32所示。

圖4.32? 批量Load/Store指令——后遞減尋址

?

該尋址方式指定一片連續的內存地址空間,地址空間的大小<address_length>等于寄存器列表中寄存器數目的4倍。內存地址范圍起始地址<start_address>等于基址寄存器Rn的值減去地址空間大小<address_length>并加4。結束地址<end_address>等于基址寄存器的值。

?

地址空間中的每個內存單元對應寄存器列表中的一個寄存器。編號低的寄存器對應于內存中低地址單元,編號高的寄存器對應于內存中的高地址單元。

?

當指令執行條件滿足并且指令編碼格式中W位置位時,基址寄存器Rn的值等于內存地址范圍起始地址<start_address>減4。

?

(2)語法格式

?

LDM|STM{<cond>}IA? <Rn>{!},<registers><^>

?

其中:

·? DA標識指令使用“后遞減”尋址方式;

·? Rn為基址寄存器,包含內存訪問的基地址;

·? <registers>為指令操作的寄存器列表;

·? <^>表示如果寄存器列表中包含程序計數器PC,是否將spsr拷貝到cpsr。

?

(3)操作偽代碼

?

Start_address = Rn – (Number_of_Set_Bits_In(register_list)*4) + 4

End_address = Rn

If? conditionPassed(cond) and W = = 1 then

Rn = Rn - (Number_of_Set_Bits_In(register_list)*4)

?

3.IB尋址

(1)編碼格式

?

指令的編碼格式如圖4.33所示。

圖4.33? 批量Load/Store指令——前增加尋址

?

該尋址方式指定一片連續的內存地址空間,地址空間的大小<address_length>等于寄存器列表中寄存器數目的4倍。內存地址范圍起始地址<start_address>等于基址寄存器Rn的值加4。結束地址<end_address>等于起始地址<start_address>加上地址空間大小<address_length>。

?

地址空間中的每個內存單元對應寄存器列表中的一個寄存器。編號低的寄存器對應于內存中低地址單元,編號高的寄存器對應于內存中的高地址單元。

?

當指令執行條件滿足并且指令編碼格式中W位置位,基址寄存器Rn的值等于內存地址范圍結束地址<end_address>。

?

(2)語法格式

?

LDM|STM{<cond>}IB? <Rn>{!},<registers><^>

?

其中:

·? IB標識指令使用“前增加”尋址方式;

·? Rn為基址寄存器,包含內存訪問的基地址;

·? <registers>為指令操作的寄存器列表;

·? <^>表示如果寄存器列表中包含程序計數器PC,是否將spsr拷貝到cpsr。

?

(3)操作偽代碼

?

Start_address = Rn + 4

End_address = Rn + (Number_of_Set_Bits_In(register_list)*4)

If? ConditionPassed(cond) and W= = 1? then

???? Rn = Rn + (Number_Of_Set_Bits_In(register_list)*4)

?

4.DB尋址

(1)編碼格式

?

指令的編碼格式如圖4.34所示。

圖4.34? 批量Load/Store指令——前遞減尋址

?

該尋址方式指定一片連續的內存地址空間,地址空間的大小<address_length>等于寄存器列表中寄存器數目的4倍。內存地址范圍起始地址<start_address>等于基址寄存器Rn的值減地址空間的大小<address_length>。結束地址<end_address>等于基址寄存器的值減4。

?

地址空間中的每個內存單元對應寄存器列表中的一個寄存器。編號低的寄存器對應于內存中低地址單元,編號高的寄存器對應于內存中的高地址單元。

?

當指令執行條件滿足并且指令編碼格式中W位置位,基址寄存器Rn的值等于內存地址范圍起始地址<address_address>。

?

(2)語法格式

?

LDM|STM{<cond>}DB? <Rn>{!},<registers><^>

?

其中:

·? DB標識指令使用“前遞減”尋址方式;

·? Rn為基址寄存器,包含內存訪問的基地址;

·? <registers>為指令操作的寄存器列表;

·? <^>表示如果寄存器列表中包含程序計數器PC,是否將spsr拷貝到cpsr。

?

(3)操作偽代碼

?

Start_address = Rn - (Number_Of_Set_Bits_In(register_list)*4)

End_address = Rn - 4

If? ConditionPassed(cond) and W = = 1? then

???? Rn = Rn – (Number_Of_Set_Bits_In(register_list)*4)

?

4.2.4? 堆棧操作尋址方式

堆棧操作尋址方式和批量Load/Store指令尋址方式十分類似。但對于堆棧的操作,數據寫入內存和從內存中讀出要使用不同的尋址模式,因為進棧操作(pop)和出棧操作(push)要在不同的方向上調整堆棧。

?

下面詳細討論如何使用合適的尋址方式實現數據的堆棧操作。

?

根據不同的尋址方式,將堆棧分為以下4種。

① Full棧:堆棧指針指向棧頂元素(last used location)。

② Empty棧:堆棧指針指向第一個可用元素(the first unused location)。

③ 遞減棧:堆棧向內存地址減小的方向生長。

④ 遞增棧:堆棧向內存地址增加的方向生長。

?

根據堆棧的不同種類,將其尋址方式分為以下4種。

① 滿遞減FD(Full Descending)。

② 空遞減ED(Empty Descending)。

③ 滿遞增FA(Full Ascending)。

④ 空遞增EA(Empty Ascending)。

?

注意

如果程序中有對協處理器數據的進棧/出棧操作,最好使用FD或EA類型堆棧。這樣可以使用一條STC或LDC指令將數據進棧或出棧。

?

表4.8顯示了堆棧的尋址方式和批量Load/Store指令尋址方式的對應關系。

表4.8???? 堆棧尋址方式和批量Load/Store指令尋址方式對應關系

批量數據尋址方式

堆棧尋址方式

L位

P位

U位

LDMDA

LDMFA

1

0

0

LDMIA

LDMFD

1

0

1

LDMDB

LDMEA

1

1

0

LDMIB

LDMED

1

1

1

STMDA

STMED

0

0

0

STMIA

STMEA

0

0

1

STMDB

STMFD

0

1

0

STMIB

STMFA

0

1

1

?

4.2.5? 協處理器Load/Store尋址方式

協處理器Load/Store指令的語法格式如下。

?

<opcode>{<cond>}{L}? <coproc>,<CRd>,<addressing_mode>

?

表4.9顯示了該類指令的尋址方式。

表4.9?? 協處理器Load/Store指令尋址方式

?

格??? 式

說??? 明

1

[<Rn>,#±<offset_8>*4]

立即數偏移尋址

2

[<Rn>,#±<offset_8>*4]!

前索引立即數偏移尋址

3

[<Rn>],#±<offset_8>*4

后索引立即數偏移尋址

4

[<Rn>], <option>

直接尋址

?

協處理器Load/Store指令的編碼方式如圖4.35所示。

編碼格式中各標志位的含義如表4.10所示。

圖4.35? 協處理器Load/Store指令編碼格式

?

表4.10???? 協處理器Load/Store指令編碼格式各標志位含義

位? 標? 識

取??? 值

含??? 義

P

P=0

標識使用偏移尋址還是前索引尋址(由W位決定)

P=1

標識使用后索引尋址還是直接尋址(由W位決定)

U

U=0

從基地址中減去偏移量offset

U=1

從基地址中加上偏移量offset

N

N=0

和具體使用的協處理器相關

N=1

W

W=0

指令執行結束,不改變基址寄存器的值

W=1

訪問的內存地址回寫到基址寄存器

L

L=0

Store指令

L=1

Load指令

?

1.[<Rn>,#±<offset_8>*4]

(1)編碼格式

指令的編碼格式如圖4.36所示。

圖4.36? 協處理器Load/Store指令——立即數尋址

?

該尋址方式指定一片連續的內存地址空間。訪問內存單元的第一個地址<first_addressing>等于基址寄存器<Rn>的值加上/減去指令中寄存器值的4倍。接下來的內存訪問地址是前一個訪問地址加4。當協處理器發出傳輸中止信號時,數據傳送結束。

?

這種尋址方式的數據傳輸數目由協處理器決定。

?

注意

這種尋址方式最多允許傳輸16的字。

?

(2)語法格式

?

<opcode>{<cond>}{L}? <coproc>,<CRd>,[<Rn>,#±<offset_8>*4]

?

其中:

·? <Rn>為基址寄存器,包含尋址操作的基地址;

·? <offset_8>為8位立即數,該值的4倍為地址偏移量。

?

(3)操作偽代碼

?

If? ConditionPassed(cond)? then

???? If? U = = 1 then

????????? Address = Rn + offset_8 * 4

???? Else? /*U = = 0*/

????????? Address = Rn – offset_8 * 4

???? Start_address = address

???? While (NotFinished(coprocessor[cp_num]))

????????? Address = address +4

???? End_address = address

?

(4)說明

如果基址寄存器指定為程序計數器r15,則基地址為當前執行指令地址加8。

?

2.[<Rn>,#±<offset_8>*4]!

(1)編碼格式

指令的編碼格式如圖4.37所示。

圖4.37? 協處理器Load/Store指令——前索引立即數尋址

?

該尋址方式指定一片連續的內存地址空間。訪問內存單元的第一個地址<first_addressing>等于基址寄存器<Rn>的值加上/減去指令中寄存器值的4倍。如果指令的條件域滿足,產生的<first_addressing>回寫到基址寄存器Rn中。接下來的內存訪問地址是前一個訪問地址加4。當協處理器發出傳輸中止信號時,數據傳送結束。

?

這種尋址方式的數據傳輸數目由協處理器決定。

?

注意

這種尋址方式最多允許傳輸16的字。

?

(2)語法格式

?

<opcode>{<cond>}{L}? <coproc>,<CRd>,[<Rn>,#±<offset_8>*4]!

?

其中:

·? <Rn>為基址寄存器,包含尋址操作的基地址;

·? <offset_8>為8位立即數,該值的4倍為地址偏移量;

·? !設置指令編碼中的W位,更新指令基地址。

?

(3)操作偽代碼

?

If? ConditionPassed(cond)? then

???? If? U = = 1 then

????????? Rn = Rn + offset_8 * 4

???? Else? /*U = = 0*/

????????? Rn = Rn – offset_8 * 4

???? Start_address = Rn

???? Address = start_address

???? While (NotFinished(coprocessor[cp_num]))

????????? Address = address +4

???? End_address = address

?

(4)說明

如果基址寄存器指定為程序計數器r15,則指令的執行結果不可預知。

?

3.[<Rn>],#±<Offset_8>*4

(1)編碼格式

指令的編碼格式如圖4.38所示。

圖4.38? 協處理器Load/Store指令——后索引立即數尋址

?

該尋址方式指定一片連續的內存地址空間。訪問內存單元的第一個地址<first_addressing>等于基址寄存器<Rn>的值。接下來的內存訪問地址是前一個訪問地址加4。當協處理器發出傳輸中止信號時,數據傳送結束。如果指令的條件域滿足,Rn基址寄存器的值更新為Rn的值加上/減去8位立即數的4倍。

?

這種尋址方式的數據傳輸數目由協處理器決定。

?

注意

這種尋址方式最多允許傳輸16的字。

?

(2)語法格式

?

<opcode>{<cond>}{L}? <coproc>,<CRd>,[<Rn>],#±<offset_8>*4

?

其中:

·? <Rn>為基址寄存器,包含尋址操作的基地址;

·? <offset_8>為8位立即數,該值的4倍為地址偏移量。

?

(3)操作偽代碼

?

If? ConditionPassed(cond)? then

???? Start_address = Rn

???? If? U = = 1 then

????????? Rn = Rn + offset_8 * 4

???? Else? /*U = = 0*/

????????? Rn = Rn – offset_8 * 4

???? Address = start_address

???? While (NotFinished(coprocessor[cp_num]))

????????? Address = address +4

???? End_address = address

?

(4)說明

如果基址寄存器指定為程序計數器r15,則指令的執行結果不可預知。

?

4.[<Rn>], <Option>

(1)編碼格式

?

指令的編碼格式如圖4.39所示。

圖4.39? 協處理器Load/Store指令——直接尋址

?

該尋址方式指定一片連續的內存地址空間。訪問內存單元的第一個地址<first_addressing>等于基址寄存器<Rn>的值。接下來的內存訪問地址是前一個訪問地址加4。當協處理器發出傳輸中止信號時,數據傳送結束。

?

指令不更新基址寄存器的值。指令編碼格式中bits[7:0]保留,所以可以將空閑位用作協處理器指令擴展。

?

這種尋址方式的數據傳輸數目由協處理器決定,最多可以傳輸16字。

?

(2)語法格式

?

<opcode>{<cond>}{L}? <coproc>,<CRd>,[<Rn>],<Option>

?

其中:

·? <Rn>為基址寄存器,包含尋址操作的基地址;

·? <option>用作協處理器指令擴展。

?

(3)操作偽代碼

?

If? ConditionPassed(cond)? then

???? Start_address = Rn

???? Address = start_address

???? While (NotFinished(coprocessor[cp_num]))

????????? Address = address +4

???? End_address = address

?

(4)說明

如果基址寄存器指定為程序計數器r15,則尋址基地址為當前指令地址加8。


參考網址:http://www.eefocus.com/embedded/322869/r0

總結

以上是生活随笔為你收集整理的ARM指令寻址方式之: 内存访问指令寻址的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。

日韩在线播放视频 | 免费亚洲片 | 欧美男女爱爱视频 | 国产高清不卡一区二区三区 | 精品在线免费视频 | 激情综合网五月 | 中文字幕在线成人 | 91黄色在线观看 | 国产精品黑丝在线观看 | 日韩精品久久中文字幕 | 亚洲黑丝少妇 | 91在线视频观看免费 | 亚洲视频在线观看免费 | 人人爽人人片 | 五月天综合网站 | 美女搞黄国产视频网站 | 国产亚洲一区二区在线观看 | 欧美在线视频免费 | 欧美黄污视频 | 99 久久久久| 人人干人人干人人干 | 夜夜操网 | 久久综合久久88 | 精品久久一区二区三区 | 日韩免费视频 | 88av色| 色之综合网 | 天天色天天操天天爽 | 久久免费观看少妇a级毛片 久久久久成人免费 | 欧美一区二区三区在线看 | a级免费观看 | 国产视频18 | 色黄久久久久久 | 六月丁香激情综合色啪小说 | 在线观看视频一区二区三区 | 俺要去色综合狠狠 | 成人黄视频 | 九九视频热 | 日韩高清一区二区 | 在线国产高清 | 亚洲日韩中文字幕 | 国产一级性生活 | 久久亚洲欧美日韩精品专区 | 国产精品色婷婷视频 | 国产精品露脸在线 | 麻豆国产精品视频 | 免费视频黄色 | 国产精品欧美久久久久天天影视 | 精品久久久久久久久久久久久久久久 | 日日摸日日碰 | 日韩精品在线播放 | 午夜精品一区二区三区在线观看 | 成年人黄色在线观看 | 中文在线最新版天堂 | 久久国产欧美日韩 | 一级性视频 | 中文在线www | 顶级bbw搡bbbb搡bbbb | 国产麻豆视频在线观看 | 狠狠干狠狠久久 | 精品免费一区 | 一级成人免费 | 精品在线观看一区二区 | 日韩精品中文字幕有码 | 高清在线观看av | 狠狠天天 | 四虎国产精品成人免费4hu | 久久黄色成人 | 欧美成人久久 | 亚洲狠狠干| 激情五月av| 狠狠操综合 | 99在线播放 | 午夜少妇 | 一区二区视频电影在线观看 | 狠狠色免费 | 黄色av电影免费观看 | 日韩高清在线不卡 | 日韩精品久久一区二区三区 | 日韩久久激情 | 91视频免费看 | 成人中文字幕av | 欧美精品在线观看 | 日韩av美女 | 免费看的黄色的网站 | 亚洲激情一区二区三区 | 天天干,天天射,天天操,天天摸 | av免费片| 日日爱夜夜爱 | 亚洲 欧洲av | 夜夜操狠狠干 | 91久久国产露脸精品国产闺蜜 | 三级黄在线 | av免费看在线 | 国产精品99爱 | 国产伦理剧 | 啪啪资源 | 日本夜夜草视频网站 | 久久精品视频3 | 4438全国亚洲精品在线观看视频 | 国产第一福利 | 中文字幕精 | 日日夜夜天天综合 | 免费在线观看成年人视频 | 激情丁香婷婷 | 久久黄色免费 | 六月激情 | 91视频91蝌蚪 | 黄色一级免费 | 欧美成人91 | 狠狠干狠狠色 | 91激情视频在线 | 亚洲爱视频 | www.69xx| 欧美日韩国产在线精品 | 日韩一级片网址 | 国产麻豆精品免费视频 | 曰本免费av | 亚洲精品啊啊啊 | 99超碰在线观看 | 三上悠亚一区二区在线观看 | 久久成人精品 | 激情大尺度视频 | 人人舔人人爱 | 91毛片在线 | 少妇高潮流白浆在线观看 | 亚洲狠狠婷婷综合久久久 | 久久人人97超碰精品888 | 国产精品21区 | 精品国产一区二区三区男人吃奶 | 国产免码va在线观看免费 | 九九视频这里只有精品 | 国产在线国偷精品产拍 | 99视频精品全国免费 | 久久久www成人免费精品张筱雨 | 91人人爽久久涩噜噜噜 | 黄色中文字幕 | 久久综合视频网 | 成人国产精品 | 91精品夜夜 | 九九久久影视 | 手机av电影在线观看 | 国产日韩精品久久 | 亚洲精品人人 | 亚洲成人第一区 | 成年人视频在线免费播放 | 色婷婷97 | av在线之家电影网站 | 日韩在线视 | 亚州精品天堂中文字幕 | 亚洲精品777| 中文字幕日本在线观看 | 99久久久国产精品免费99 | 黄色视屏在线免费观看 | 欧美一级乱黄 | 丁香一区二区 | 国产成人免费高清 | ,午夜性刺激免费看视频 | 超碰在线观看av.com | 激情六月婷婷久久 | 国产一二三精品 | 国产在线精品一区二区不卡了 | 夜夜爽www | 日韩精品中文字幕在线观看 | 四虎影视精品成人 | 久久国产精品一国产精品 | 四虎成人精品永久免费av | 国产精品久久久av久久久 | 天天综合网~永久入口 | 国产精品大片免费观看 | 美女在线免费视频 | 亚洲欧洲成人精品av97 | 成人免费91 | 国产精品手机在线 | 中文字幕色综合网 | 亚洲日日夜夜 | 中文日韩在线 | 蜜臀aⅴ国产精品久久久国产 | 美女黄视频免费 | 亚洲激情在线观看 | 中文在线www | 亚洲最新av在线网址 | www操操操 | 美女av免费看 | 欧美日韩一二三四区 | 色综合久久88色综合天天 | www黄在线 | 高清av影院 | 国产一区av在线 | 欧美日韩精品免费观看视频 | 911精品视频 | 丁香六月综合网 | 在线中文字幕视频 | 午夜精品一区二区三区视频免费看 | 精品国产一区二区三区不卡 | 久久免费看毛片 | 日韩大片在线免费观看 | 天天操天天射天天爽 | 国产精品免费成人 | 日韩系列在线观看 | 天天色天天搞 | 亚洲黑丝少妇 | 在线国产欧美 | 7777精品伊人久久久大香线蕉 | 久久伊人综合 | 国产精品一区二区电影 | 中文亚洲欧美日韩 | 国产一区二区在线影院 | 少妇超碰在线 | 国产黄色片久久久 | 色a在线观看 | 波多野结衣在线观看一区二区三区 | 国产精品色婷婷视频 | 久久黄色片子 | 黄色99视频 | 国产亚洲精品久久久久动 | 欧美一级淫片videoshd | 国产一二三精品 | 国产色视频网站 | 五月天丁香亚洲 | 日本99久久 | 欧美在线视频免费 | 久久亚洲福利视频 | 国产精品久久久久婷婷二区次 | 欧美小视频在线 | 欧美高清成人 | 成人aⅴ视频 | 99精品在线免费 | 亚洲播放一区 | 免费三级黄色片 | 六月色播| 国产精品九色 | 在线免费高清视频 | 五月婷婷在线视频 | 日韩av一区二区在线 | 亚洲一区网站 | 一区二区三区国产欧美 | 欧美色操 | 婷婷伊人五月 | 亚洲精品免费播放 | 国产精品嫩草影院99网站 | 97夜夜澡人人双人人人喊 | 欧美日韩一区二区三区视频 | 国产经典三级 | 一区二区三区精品久久久 | 精品亚洲免a | 91大片网站 | 99久久久成人国产精品 | 99re国产| 国产精品一级在线 | 亚洲天天在线日亚洲洲精 | 丁香av| 欧美精品三级 | 在线涩涩| 国产又粗又猛又色 | 狠狠狠色丁香综合久久天下网 | 国产精品一区免费看8c0m | 超碰97在线人人 | 午夜精品麻豆 | 天天射天天干天天 | 国产精品视频免费观看 | 欧美大香线蕉线伊人久久 | 国产精品亚 | 色婷婷久久| 亚洲激情在线播放 | 亚洲视频99| 国产在线一区二区 | 日韩二区三区在线观看 | 国产一级片视频 | 国产小视频在线 | 草樱av| 99视频+国产日韩欧美 | 男女视频久久久 | 亚洲精品在线电影 | 久久观看免费视频 | 福利网址在线观看 | 91av视频免费在线观看 | 亚洲播放一区 | 欧美成人在线免费 | 欧美日韩久久 | 超碰在线9 | 一区二区三区四区在线 | 91人人爱 | 91av社区| 丁香婷婷久久久综合精品国产 | 国产九色在线播放九色 | 狠狠色狠狠色综合日日92 | 中文字幕免费观看全部电影 | 婷婷亚洲五月色综合 | 探花视频在线观看免费 | 国产免费久久精品 | 久久久国产成人 | 2024国产精品视频 | 久久人视频 | 999免费视频 | 中文字幕 成人 | 午夜视频一区二区三区 | 天天操天天怕 | 夜夜爽88888免费视频4848 | 中文字幕高清 | 三级视频片 | 手机看片福利 | 日韩精品免费一线在线观看 | 97色综合| 国产一卡久久电影永久 | 欧美淫aaa免费观看 日韩激情免费视频 | 色老板在线视频 | 国产99re| 日韩午夜在线观看 | 日韩精品久久中文字幕 | 久久综合亚洲鲁鲁五月久久 | 瑞典xxxx性hd极品 | 中文字幕成人一区 | 69热国产视频 | 日韩精品久久久久久 | 国产精品九九久久99视频 | 婷五月天激情 | 狠狠躁夜夜av | 中文字幕在线观看视频一区二区三区 | 日日夜夜天天人人 | 久久精品人人做人人综合老师 | 国产中文字幕在线视频 | 中文字幕av网站 | 日韩专区在线观看 | 日韩精品视频免费专区在线播放 | 96久久精品| 亚洲午夜久久久久久久久 | 干干夜夜 | 色wwww| 精品国产一区二区三区久久久蜜臀 | 探花视频网站 | 欧美视频99 | 欧美在线日韩在线 | 日日草av | 亚洲人片在线观看 | 香蕉影院在线 | 天天插天天干天天操 | 亚洲成人高清在线 | 精品久久久久久综合日本 | 亚洲精品456在线播放乱码 | 国产精品久久久久久久久久久免费看 | 亚洲国产精品99久久久久久久久 | 欧美日韩午夜 | 亚洲成人免费在线 | 国产理论片在线观看 | 九色91在线 | 国产91在| av国产网站 | 中文字幕视频网站 | 亚洲va综合va国产va中文 | 久久国产免费看 | 免费看国产精品 | 二区中文字幕 | 色资源中文字幕 | 人人爽人人爽人人爽 | 久久99视频免费观看 | 欧美午夜性生活 | 免费日韩一区二区三区 | 午夜.dj高清免费观看视频 | 日韩在线观看中文 | 亚洲免费在线观看视频 | 日日夜夜狠狠 | 日本黄区免费视频观看 | 在线观看国产福利片 | 亚洲视频免费在线看 | 欧美污污网站 | 亚洲一区二区三区四区在线视频 | 久久人人97超碰精品888 | 久久久国产影院 | 欧美日韩18| av电影免费| 久久综合九色综合久99 | 欧美精品生活片 | 日韩精品中文字幕在线 | 91大神dom调教在线观看 | 青青草华人在线视频 | 欧美日韩国产区 | 亚洲激情综合 | 天天色天天草天天射 | aav在线 | 免费中午字幕无吗 | 中文字幕欧美日韩va免费视频 | 91九色国产在线 | 日韩精品视频久久 | 精品国产一区二区三区在线观看 | 中文字幕 在线看 | 91精品国产欧美一区二区成人 | 99精品久久久久 | 婷婷六月中文字幕 | 亚州av免费 | 日韩大陆欧美高清视频区 | 国产视频精品久久 | 国产亚洲va综合人人澡精品 | 成年人在线观看免费视频 | 97在线资源| 伊人色综合久久天天网 | 天堂黄色片 | 成年人毛片在线观看 | 日日操天天爽 | 免费看一级黄色 | 最新av免费在线 | 91精品人成在线观看 | 三级av中文字幕 | 久久久网 | 丁香五香天综合情 | 免费精品 | 一本色道久久精品 | 亚洲免费在线视频 | 婷婷久久综合九色综合 | 亚洲va天堂va欧美ⅴa在线 | av手机版 | 久久成人免费视频 | 91亚·色| 国产色资源 | 91香蕉视频好色先生 | 美女在线免费观看视频 | 国产一区二区在线免费播放 | 亚洲高清视频在线观看免费 | 一区二精品 | 国产成人av在线影院 | 香蕉蜜桃视频 | 国产精品九色 | 精品电影一区 | 久久久久久久国产精品 | 久久久久久久网站 | 91精品久久久久久久久 | 香蕉影院在线 | 麻豆视频在线 | 91激情视频在线观看 | 久久国产剧场电影 | 一本之道乱码区 | 曰韩在线| 亚洲国产中文字幕在线观看 | 成人av直播 | 中文字幕婷婷 | 亚洲专区在线视频 | 久久久视频在线 | 欧美成年网站 | 日韩 精品 一区 国产 麻豆 | a√天堂中文在线 | 欧美射射射| 国产福利一区二区三区视频 | 久久久免费国产 | 成年人免费av | 久久久久免费精品视频 | 欧美成人精品三级在线观看播放 | 欧美 日韩 久久 | 国产精品午夜免费福利视频 | www.97视频| av福利网址导航 | 国产精品毛片久久久久久 | 国产视频资源在线观看 | 国产精品久久久久久电影 | 91精品人成在线观看 | 99久久er热在这里只有精品66 | 久久视频网址 | 久久久午夜精品理论片中文字幕 | 国产视频精品在线 | 中文字幕日韩高清 | 欧美a在线看 | 天天噜天天色 | 综合久久久久 | 日本久久免费视频 | 欧美日韩精品在线播放 | 日韩激情免费视频 | 久草在线视频免费资源观看 | 五月婷婷丁香色 | 免费看国产视频 | 五月激情天 | 欧美日韩一区二区三区在线观看视频 | 日韩午夜av电影 | 久久久久久在线观看 | 五月的婷婷| av在线h | 日韩丝袜视频 | 99精彩视频在线观看免费 | 国产高清免费观看 | 又黄又爽又刺激 | 精品久久久精品 | 一区二区三区四区五区六区 | 亚洲精品小视频 | 四虎国产精品免费 | 免费黄色a网站 | 日本黄色大片儿 | 视频 天天草 | 日韩在线免费电影 | 91超级碰 | 伊人婷婷色 | 欧美日韩高清在线 | 精品电影一区二区 | 亚洲闷骚少妇在线观看网站 | 四虎影院在线观看av | 天天干,夜夜操 | 99久e精品热线免费 99国产精品久久久久久久久久 | 国产毛片在线 | 久久久久一区 | 久久老司机精品视频 | 久草在线免费资源 | 日韩区欧美久久久无人区 | 日韩av成人免费看 | 日本精品一区二区 | 91网页版在线观看 | 日日夜精品 | 久色伊人| 播五月综合 | 久久99网| 国内视频在线观看 | av久久久| 亚洲日日日 | 国产在线精品播放 | www.五月天婷婷.com | 丁香激情五月婷婷 | 国产精品1区 | 成人毛片久久 | 中文字幕在线国产精品 | 亚洲国产网站 | 521色香蕉网站在线观看 | 日日干激情五月 | 中文字幕亚洲精品在线观看 | 日韩午夜在线 | 欧美久久久久久久久久久 | 成人av观看| 欧美日韩中文国产一区发布 | 亚洲区另类春色综合小说校园片 | 日韩精品久久中文字幕 | 日韩黄色软件 | 91久久爱热色涩涩 | 久久免费av电影 | 国产91精品一区二区绿帽 | 久久福利小视频 | 亚洲最新在线视频 | 四虎在线观看精品视频 | 色香天天 | 亚洲精品黄网站 | 亚洲91网站 | 人人狠狠综合久久亚洲 | 日韩中文在线播放 | caobi视频 | 人人人爽 | 又黄又爽的视频在线观看网站 | 国产999视频在线观看 | 日本精品一区二区在线观看 | 久久一线 | 国产精品视频免费 | 久久欧美精品 | 午夜视频播放 | www.com.日本一级 | 久99精品 | 亚洲免费婷婷 | 免费在线观看av网站 | 国产黄色片免费 | 欧美国产日韩一区 | 射久久 | 久久国产热视频 | 国产精品影音先锋 | www久久九 | 国产精品手机在线观看 | 午夜av在线免费 | 久草在线高清视频 | 国产中文自拍 | 久久久精品国产免费观看一区二区 | 久久免费视频99 | 亚州国产精品久久久 | 国内精品久久久久久久久久 | 992tv在线| 粉嫩av一区二区三区四区 | 免费热情视频 | 狠狠干狠狠插 | 深夜福利视频在线观看 | 久久男人免费视频 | 久久成人亚洲欧美电影 | 五月婷丁香网 | 欧美极品少妇xxxxⅹ欧美极品少妇xxxx亚洲精品 | 久草在线免费资源 | 日韩欧美精品在线观看 | 精品婷婷| 97色婷婷 | 五月天天在线 | 久久久久国产成人免费精品免费 | 天天人人综合 | 一区二区三区四区影院 | 亚洲视频免费在线 | 丁香色综合 | 91女神的呻吟细腰翘臀美女 | 欧美性色黄大片在线观看 | 久久久精品99 | 国产精品av久久久久久无 | 99久久99久久| 蜜桃av人人夜夜澡人人爽 | av电影在线观看完整版一区二区 | 国产精品系列在线播放 | 奇米777777| 国产精品欧美久久 | 日韩欧美视频在线播放 | 欧美少妇的秘密 | 中文在线a∨在线 | 久久草草热国产精品直播 | 国产高清免费av | 亚洲国产欧美在线人成大黄瓜 | 九九视频网站 | 国产精品日韩久久久久 | 77国产精品 | 国产精品久久久久久久久久久免费看 | 欧美日韩精品网站 | 精品久久久网 | 丝袜制服综合网 | 99精品免费网 | 97视频在线免费 | 在线观看v片 | 亚洲丁香久久久 | 又湿又紧又大又爽a视频国产 | 久草在线视频免费资源观看 | 精品国产aⅴ一区二区三区 在线直播av | 国产免费久久av | 人人精品久久 | 国产一区二区综合 | 亚洲做受高潮欧美裸体 | 婷婷av在线 | 91丨九色丨高潮丰满 | 99爱在线观看 | 免费av试看| 国产亚洲精品久久久久久移动网络 | 精品一区电影 | 久久精品免视看 | 亚洲作爱视频 | 国产精品成人自产拍在线观看 | 国产特级毛片aaaaaa毛片 | 久久av影院 | 有码中文字幕 | 人人澡人人草 | 成人动漫一区二区三区 | 911香蕉视频| www.天天射.com| 看片黄网站 | 黄色动态图xx| 亚洲欧洲xxxx | 色综合天天综合网国产成人网 | 久久婷婷精品视频 | 欧美高清视频不卡网 | 午夜精品导航 | a视频免费| 亚洲黄色在线免费观看 | 99久久激情视频 | 黄色中文字幕在线 | 婷婷丁香导航 | 中文字幕 国产专区 | 亚洲经典在线 | 日韩在线观看a | 日韩中文字幕91 | 国产手机在线播放 | 国产一区二区高清 | 天天爱天天操 | 色婷婷狠狠五月综合天色拍 | 日韩黄色在线 | 国产精品久久久免费 | 欧洲色吧 | 国产精品人成电影在线观看 | 日韩欧美视频在线观看免费 | 91在线视频免费观看 | 在线精品观看国产 | 日韩免费大片 | 亚洲精品乱码白浆高清久久久久久 | 久久99在线视频 | 一级性视频 | 国内视频在线观看 | 99视频黄 | 在线免费观看国产黄色 | 国产精品久久久久av免费 | 精品亚洲免费 | 亚洲精品久久激情国产片 | 日韩av一区二区三区四区 | 久久精品99国产精品亚洲最刺激 | 激情婷婷久久 | 黄色看片 | 精品一区中文字幕 | 500部大龄熟乱视频使用方法 | 激情视频免费在线观看 | 久久精品视频网站 | 久久私人影院 | 久久久av免费 | 久久久久久久久久久福利 | 视频在线观看亚洲 | 中文字幕黄色av | 天天综合天天做天天综合 | 在线中文字幕一区二区 | 国内精品国产三级国产aⅴ久 | 日韩欧美高清视频在线观看 | 久久国产热视频 | 日韩一区二区久久 | 久久你懂得 | 久久久国产精华液 | 久久国产91 | 国产小视频你懂的在线 | 久久99久久99精品免视看婷婷 | 四虎在线观看精品视频 | 91精品国产入口 | 国产五码一区 | 超级碰碰碰碰 | 国产乱对白刺激视频在线观看女王 | 一二三久久久 | 成人香蕉视频 | 丁香激情视频 | 久久精品成人 | 日韩精品一区二区在线视频 | 日本三级吹潮在线 | 色婷婷综合视频在线观看 | 色网av| 久久国产网 | 久久国产精品免费 | 国产成人无码AⅤ片在线观 日韩av不卡在线 | 国产免费久久精品 | av免费高清观看 | 欧美日韩国产一区二区三区 | 99久久夜色精品国产亚洲96 | 色哟哟国产精品 | 日韩av在线看 | 97国产在线视频 | 久久经典视频 | 久草青青在线观看 | 91精品专区| 色婷婷电影网 | 九九九九九精品 | 黄色大全在线观看 | 日韩在线观看网址 | 一区中文字幕在线观看 | 一区二区视频在线播放 | 久久尤物电影视频在线观看 | 日本超碰在线 | 久久久久免费电影 | 蜜臀久久99精品久久久无需会员 | bbb搡bbb爽爽爽| 日韩欧美网址 | 操综合| 三级黄色在线 | 成人黄色电影在线播放 | 亚洲一级黄色av | 丁香六月婷 | 亚洲第一久久久 | 日韩久久精品一区二区 | 亚洲日本在线视频观看 | 米奇狠狠狠888 | 日韩深夜在线观看 | 国产一区在线免费观看视频 | 国产无区一区二区三麻豆 | 免费av 在线 | 成人在线网站观看 | 久久久久久久久久电影 | 亚洲久在线 | 九九涩涩av台湾日本热热 | 日韩国产欧美视频 | 日韩av在线高清 | 久久久精品日本 | 久草在线免费播放 | 在线观看你懂的网站 | 色婷婷狠狠操 | 国产精品观看视频 | 国产91在线观看 | 精品成人在线 | 亚洲欧洲精品一区二区精品久久久 | 国产精品成人av电影 | 黄色小说在线观看视频 | 免费观看v片在线观看 | 国产精品va在线观看入 | 99精品热视频 | 久草在线免费资源 | 麻豆视频在线免费观看 | 成人播放器 | 欧美日韩在线看 | 国产自在线 | 91av手机在线观看 | 久久久久久国产精品999 | bbbbb女女女女女bbbbb国产 | 成人免费在线播放 | 日韩精品中文字幕av | 丁香婷婷射 | 少妇搡bbb | 在线不卡的av | 国产麻豆精品一区二区 | 国产精品毛片网 | 91在线日本| 久久精品视 | 国产五月婷| 在线电影av | 日韩午夜电影院 | 狠狠狠色丁香婷婷综合久久88 | 在线观看久 | 中文字幕在线视频网站 | 国产精品免费观看视频 | 91在线亚洲 | 夜夜骑首页 | 国产高清不卡 | 91av在线电影| 在线播放91| 黄色精品一区 | 免费视频99| a视频免费在线观看 | 黄av资源| 国产精品9区 | 亚洲最新av| japanese黑人亚洲人4k | 天天综合日日夜夜 | 国产69熟 | 亚洲精品在线国产 | 在线观看 亚洲 | 亚洲一级特黄 | 最近中文字幕 | 最新av在线网址 | 精品久久久久久国产 | 美女网站色在线观看 | 狠狠干.com | 三级性生活视频 | 婷婷播播网 | 一级黄色片毛片 | 日本精品中文字幕在线观看 | 在线香蕉视频 | 亚洲国产精品日韩 | 爱av在线网| 日韩精品极品视频 | 久久久久国产精品免费网站 | 亚洲欧美日韩在线一区二区 | 97人人澡人人添人人爽超碰 | 香蕉视频在线免费 | 久久免费播放 | www.狠狠插.com| 日韩一区二区免费播放 | 91亚洲欧美 | 黄色av一区二区 | 国产精品久久久久久久久久妇女 | 欧洲高潮三级做爰 | 在线天堂v | 玖玖999 | 中文字幕在线免费看 | 国产一及片 | 最近中文国产在线视频 | 毛片无卡免费无播放器 | 国产一级h| 日韩av一区二区三区在线观看 | 久久观看免费视频 | 午夜精品久久久久久99热明星 | 91成熟丰满女人少妇 | 99热这里有精品 | 51久久成人国产精品麻豆 | 日日干av | 亚洲精品999| 天天干天天拍天天操天天拍 | 天天草av | 国产黄在线 | 久久精品久久国产 | 欧美午夜寂寞影院 | 在线观看视频你懂的 | 国产啊v在线 | 国产色视频123区 | 天天操天天射天天 | 天天操天天综合网 | 91社区国产高清 | 日韩日韩日韩日韩 | 三级av免费看 | 97色se| 久久精品视频在线观看 | 亚州精品视频 | 最近中文字幕在线播放 | 毛片99 | 99久久久国产精品美女 | 九九热在线视频免费观看 | 国产人成精品一区二区三 | 久久久三级视频 | 在线免费观看视频一区 | 少妇做爰k8经典 | 超碰97国产精品人人cao | 中文字幕第一页在线vr | 草莓视频在线观看免费观看 | 国产三级香港三韩国三级 | 日韩在线欧美在线 | 欧美坐爱视频 | 天天干天天操天天入 | 婷婷色伊人 | 色五婷婷 | www久| 在线观看日韩 | 中文字幕中文字幕在线中文字幕三区 | 久久爱资源网 | 人人爱天天操 | 欧美日韩一区二区三区免费视频 | 我要色综合天天 | 麻豆国产网站入口 | 91黄色小网站 | 色丁香综合 | 91免费视频国产 | 国产日韩在线播放 | 日韩高清片 | 999成人网| a视频免费在线观看 | 我爱av激情网 | 国产精品理论视频 | 亚洲精品视频在线免费 | 免费视频a | 免费在线色电影 | 日韩三级中文字幕 | 一区二区三区高清 | 极品美女被弄高潮视频网站 | 综合天天 | 日韩视频在线不卡 | 91精品视频免费观看 | 国产亚洲aⅴaaaaaa毛片 | 日本成人免费在线观看 | 99精品在线视频播放 | 在线看av网址 | 视频在线观看入口黄最新永久免费国产 | 久久99亚洲精品 | 在线免费观看av网站 | 亚洲婷婷丁香 | 人人射人人插 | 尤物一区二区三区 | 久久久久久久久久久久久影院 | 久久一区二区三区日韩 | 久久久久久国产精品免费 | 欧美天堂久久 | 国产日韩欧美在线一区 | 午夜影院一级片 | 中文字幕在线资源 | 国产精品va最新国产精品视频 | 国产视频不卡 | 国产香蕉视频在线观看 | 西西大胆啪啪 | 精品国产人成亚洲区 | 日本护士撒尿xxxx18 | 久久不射电影网 | 97香蕉久久超级碰碰高清版 | 日韩欧美国产成人 | 一区二区三区在线播放 | av在线超碰 | 天堂在线视频免费观看 | 黄色www免费 | 欧美精品久久久久久久久久久 | 久久久私人影院 | 国内精品久久久久 | 欧美在线aaa | 欧美va电影| 久久久久黄色 | 91精品在线麻豆 | 麻花传媒mv免费观看 | 五月天激情婷婷 | 一级片色播影院 | 日韩三级视频在线看 | 97精品国产一二三产区 | 西西444www高清大胆 | 国产对白av| 9草在线 | 91人人澡 | 国产精品五月天 | 国产精品普通话 | 狠狠躁夜夜躁人人爽超碰97香蕉 | 久久久久在线 | 99久久国产免费免费 | 波多野结衣一区 | 四虎影视精品永久在线观看 | 欧美片一区二区三区 | 久久这里只有精品视频99 | 亚洲国产美女精品久久久久∴ | 久久精品8 | 97国产人人| 性日韩欧美在线视频 | 日韩久久午夜一级啪啪 | 久久久久久久久影院 | 日韩三级精品 | 国产黄色大片 | 欧美久久久久久久久中文字幕 | 国产精品久久久久久麻豆一区 | 在线看日韩 | 天天天天射 | 国内外成人在线视频 | 香蕉视频最新网址 | 亚洲精品字幕 | 精品国产1区二区 | 日韩黄色免费 | 国产精品欧美久久久久天天影视 | 欧美精品色 | 亚洲无吗视频在线 | 久久精品4 | 成人亚洲精品国产www | 五月婷久久 | 久久综合一本 | 成人国产精品一区二区 | 国产精品视频观看 | 麻豆视频免费入口 | 91正在播放 | 亚洲精品影院在线观看 | 91精品999 | 91少妇精拍在线播放 | 国产精品一区二区久久精品爱涩 | 日本视频精品 | 国产精品欧美久久久久三级 | 成人禁用看黄a在线 | 日韩精品一区二区不卡 | 免费特级黄色片 | 97香蕉久久超级碰碰高清版 | 国产原创在线观看 | 天天射天天射天天射 |