亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? mmumacro.s

?? windows ce 50 drive program
?? S
?? 第 1 頁 / 共 3 頁
字號:
;
; Copyright (c) 2001. Samsung Electronics, co. ltd  All rights reserved.
;
;
; Use of this source code is subject to the terms of the Microsoft end-user
; license agreement (EULA) under which you licensed this SOFTWARE PRODUCT.
; If you did not accept the terms of the EULA, you are not authorized to use
; this source code. For a copy of the EULA, please see the LICENSE.RTF on your
; install media.
;
; -*-Asm-*-
;
; $Revision: 1.2 $
;   $Author: kwelton $
;     $Date: 1999/10/25 21:40:55 $
;
; Copyright (c) ARM Limited 1998, 1999.
; All Rights Reserved.
;
; mmumacro.s - Generic aliases for COPROCESSOR access macros for
;              ARM processors.
;
;	$Id: mmumacro.s,v 1.2 1999/10/25 21:40:55 kwelton Exp $
;

 IF :LNOT: :DEF: __mmumacros
__mmumacros             EQU     1

; Bit definitions are here
	INCLUDE	mmu_h.s

; Dummy macros for processors without MMU/MPU etc.
	INCLUDE	nommu.s

; NOTE: Most (all?) macros call the NO_* macro first. These macros must
;	be non-destructive on passed parameters, as one (or more) of
;	the processor-specific macros may be called next.

 IF FORCE_TGTCPU = "ARM7"
	INCLUDE	mmu7T.s
 ENDIF

 IF FORCE_TGTCPU = "ARM720"
	INCLUDE	mmu720T.s
 ENDIF

 IF FORCE_TGTCPU = "ARM740"
	INCLUDE	mmu740T.s
 ENDIF

 IF FORCE_TGTCPU = "ARM920"
	INCLUDE	mmu920T.s
 ENDIF

 IF FORCE_TGTCPU = "ARM940"
	INCLUDE	mmu940T.s
 ENDIF

 IF FORCE_TGTCPU = "SA110"
	INCLUDE	mmu110.s
 ENDIF

;------------------------------------------------------------------
;Macro to test that the given address has a 1-to-1 mapping between
;physical and virtual memory

	MACRO
	TEST_121MAP	$addr, $tmp1, $tmp2
	RDMMU_TTBase	$tmp1
	MOV	$tmp1, $tmp1, LSR #14		; Clear bottom 14 bits
	MOV	$tmp1, $tmp1, LSL #14
	ADD	$tmp2, $tmp1, $addr, LSR #(20-2)	; page table entry
	LDR	$tmp1, [$tmp2]			; read the entry
	MOV	$tmp2, $addr, LSR #20		; addr in MB
	SUBS	$tmp2, $tmp2, $tmp1, LSR #20	; entry in
	MEND

;------------------------------------------------------------------
; For executables which are linked for a different address to the
; physically executed address:
;
; Need to adjust from the linked address of the table to a relative
; offset from here. First, work out the offset from the RO$$Base,
; then find out how far we are from our actual start. Lastly, add
; the difference to the current pc.

	MACRO
	FIND_TABLEADDR	$tmp3, $tmp4, $addr
        LDR	$tmp4, =|Image$$RO$$Base| ; get linked location of code
	SUB	$addr, $addr, $tmp4	  ; A. table offset from start
        LDR	$tmp3, =%F79
	SUB	$tmp3, $tmp3, $tmp4	  ; B. Offset to next label
	SUB	$addr, $addr, $tmp3	  ; A-B
	; ----------------------------------------------------
	; Note: no more than 2 instructions between here and
	; the label.  Since pc is here + 8, add A-B to get
	; current table address
	MOV	$tmp3, pc
	ADD	$addr, $addr, $tmp3
79
	MEND

; Macro to read the MPU MappingTable and build the region, cache, buffer
; and permissions before setting up the MPU as required
;
	MACRO
	SETUP_MPU	$tmp1, $size, $tmp2, $tmp3, $tmp4, $addr, $offset

 IF :LNOT: :DEF: MPUMaptab
	IMPORT	MPUMaptab
 ENDIF

	; Flush MPU Map to invalid
	LDR	$tmp2, =MPUMaptab
	ADD	$tmp1, $tmp2, $offset	; Real address of Level1 TTB
	MOV	$tmp3, #0		; Invalid
	LDR	$tmp4, =MPU_TABLE_ENTRIES
70
	STR	$tmp3, [$tmp1], #4
	SUBS	$tmp4, $tmp4, #1	; decrement loop count
	BNE	%B70

	; If not executing from linked address, adjust $addr
	FIND_TABLEADDR	$tmp3, $tmp4, $addr

	ADD	$tmp1, $tmp2, $offset	; Real address of Mapping Table
71
	LDR	$offset, [$addr], #4	; Read the region
	LDR	$tmp2, [$addr], #4	; Base address
	LDR	$tmp3, [$addr], #4	; Area size

	CMP	$tmp3, #0		; All done if size is zero
	BEQ	%F74

	; Make sure address is correctly aligned (a multiple of size)
	MOV	$tmp4, #2
	MOV	$tmp4, $tmp4, LSL $tmp3
	SUB	$tmp4, $tmp4, #1
	ANDS	$tmp4, $tmp2, $tmp4
	BNE	%F80			; Failed, stop.

	; Build the region value, strip bottom 12 bits
	MOV	$tmp3, $tmp3, LSL #1	; Size is used x 2
	MOV	$tmp2, $tmp2, LSR #12
	MOV	$tmp2, $tmp2, LSL #12
	ADD	$tmp2, $tmp2, $tmp3	; Add in size
	ADD	$tmp2, $tmp2, #1	; Enable this region
	MOV	$tmp3, $offset, LSL #2	; Sotre in region * 4
	STR	$tmp2, [$tmp1, $tmp3]	; Save the region base address

	; Now add in access permissions for cache etc.
	LDR	$tmp4, [$addr], #4	; Access permissions
	MOV	$tmp4, $tmp4, LSR #2	; Access >> 2
	AND	$tmp3, $tmp4, #1
	MOV	$tmp2, $tmp3, LSL $offset
	LDR	$tmp3, [$tmp1, #MPU_BUFFER_OFFSET]
	ORR	$tmp2, $tmp2, $tmp3
	STR	$tmp2, [$tmp1, #MPU_BUFFER_OFFSET]
	MOV	$tmp4, $tmp4, LSR #1	; Access >> 3
	AND	$tmp3, $tmp4, #1
	MOV	$tmp2, $tmp3, LSL $offset
	LDR	$tmp3, [$tmp1, #MPU_CACHE_OFFSET]
	ORR	$tmp2, $tmp2, $tmp3
	STR	$tmp2, [$tmp1, #MPU_CACHE_OFFSET]
	MOV	$tmp4, $tmp4, LSR #7	; Access >> 10
	AND	$tmp3, $tmp4, #3
	MOV	$tmp3, $tmp3, LSL $offset
	MOV	$tmp2, $tmp3, LSL $offset	; region x 2
	LDR	$tmp3, [$tmp1, #MPU_ACCESS_OFFSET]
	ORR	$tmp2, $tmp2, $tmp3
	STR	$tmp2, [$tmp1, #MPU_ACCESS_OFFSET]

	B	%B71			; Next..

72	; MPU Mapping Table failure..
	B	.

74
	; The table is built, so now write the values to the MPU
	LDR	$tmp2, [$tmp1], #4
	WRMPU_Region	0, $tmp2
	LDR	$tmp2, [$tmp1], #4
	WRMPU_Region	1, $tmp2
	LDR	$tmp2, [$tmp1], #4
	WRMPU_Region	2, $tmp2
	LDR	$tmp2, [$tmp1], #4
	WRMPU_Region	3, $tmp2
	LDR	$tmp2, [$tmp1], #4
	WRMPU_Region	4, $tmp2
	LDR	$tmp2, [$tmp1], #4
	WRMPU_Region	5, $tmp2
	LDR	$tmp2, [$tmp1], #4
	WRMPU_Region	6, $tmp2
	LDR	$tmp2, [$tmp1], #4
	WRMPU_Region	7, $tmp2

	LDR	$tmp2, [$tmp1], #4
	WRMPU_CacheBits	$tmp2
	LDR	$tmp2, [$tmp1], #4
	WRMPU_BufferBits	$tmp2
	LDR	$tmp2, [$tmp1]
	WRMPU_AccessBits	$tmp2

	MEND
	
; Simple macro to clear all page table entries.
;
	MACRO
$label  INIT_PGTABLE	$count, $val, $ptr, $offset
	LDR	$ptr, =Level2tab_ROM
	ADD	$ptr, $ptr, $offset	; Real address of Level2 TTB
	LDR	$count, =L2_TABLE_ENTRIES
	CMP	$count, #0		; Check for no Level2 table
	BEQ	%F77

	LDR	$val, =L2_ENTRY_SIZE
	MUL	$count, $val, $count
	MOV	$val, #0		; Invalid
76
	STR	$val, [$ptr], #4
	SUBS	$count, $count, #1	; decrement loop count
	BGE	%B76
77
	LDR	$ptr, =Level1tab
	ADD	$ptr, $ptr, $offset	; Real address of Level1 TTB
	MOV	$val, #0		; Invalid
	LDR	$count, =L1_TABLE_ENTRIES
78
	STR	$val, [$ptr], #4
	SUBS	$count, $count, #1	; decrement loop count
	BGE	%B78

	MEND

; Build a page table from the supplied address map table.
;
; $tmp2		size of memory If this platform supports auto-memory sizing
; $addr		pointer to memory map table
; $offset	offset between physical addr & virtual addr of TTBs
;
	MACRO
$label  BUILD_PGTABLE	$tmp1, $tmp2, $tmp3, $tmp4, $tmp5, $addr, $offset

	; ----------------------------------------------------
	; First clear all TT entries - FAULT
	; ----------------------------------------------------
	INIT_PGTABLE	$tmp3, $tmp4, $tmp5, $offset

	; If not executing from linked address, adjust $addr
	FIND_TABLEADDR	$tmp3, $tmp4, $addr

	; ----------------------------------------------------
	; Check $size parameter.
	; If non-zero, size of first memory area is taken from
	; target-specific memory sizing code rather than $size
	CMP	$tmp2, #0
	BEQ	%F81		; Not autosizing, read all params

	; ----------------------------------------------------
	; Make sure given memory size is a multiple of 1MB
	; tmp3 is no. of 1MB segments
	MOV	$tmp3, $tmp2, LSR #20
	MOV	$tmp4, $tmp3, LSL #20
	CMP	$tmp4, $tmp2
	ADDNE	$tmp3, $tmp3, #1

	; Read 1st Entry from MMU table seperately to allow
	; memory sizing.
	; NOTE: 1st entry cannot abort & can't be Level2 !!
	LDR	$tmp4, =Level1tab
	ADD	$tmp4, $tmp4, $offset

	; Virtual base address -> Level1 offset in tmp2
	LDR	$tmp5, [$addr], #4
	ADD	$tmp2, $tmp4, $tmp5, LSR #(20-2)

	; Physical base address -> tmp4
	LDR	$tmp1, [$addr], #4
	; Access permissions etc -> tmp3 (NOTE: Size is skipped!)
	LDR	$tmp5, [$addr], #8

	CMP	$tmp5, #0
	BEQ	%F80			; Halt if access is zero

	TST	$tmp1, #PT_PAGE
	BNE	%F80			; Halt if Level2 table

	ADD	$tmp1, $tmp1, $tmp5	; Level1 Table Entry

	; Registers set, so build 1st entry & rest of TLB.
	B	%F83

	; All causes for error end up here
80	
 IF FORCE_TGTCPU = "ARM7"
	B	%F90			; No Page Table if no MMU
 ENDIF
	B	.

81
	LDR	$tmp4, =Level1tab
	ADD	$tmp4, $tmp4, $offset
82
	; Calculate offset to virtual base address entry -> tmp2
	LDR	$tmp1, [$addr], #4	; Virtual address
	ADD	$tmp2, $tmp4, $tmp1, LSR #(20-2)

	; Physical base address -> tmp1
	LDR	$tmp1, [$addr], #4
	; Access permissions etc -> tmp3
	LDR	$tmp3, [$addr], #4
	CMP	$tmp3, #0		; All done if access is zero
	BEQ	%F90

	TST	$tmp1, #PT_PAGE		; Check for Level2 table
	BNE	%F84			; Yes, do it

	; ----------------------------------------------------
	; Level 1 Entries, calculate size & fill table
	; ----------------------------------------------------
	ADD	$tmp1, $tmp1, $tmp3	; Level1 Table Entry
	LDR	$tmp3, [$addr], #4	; area size
	MOV	$tmp3, $tmp3, LSR #20	; no. of 1MB segments
83
	STR	$tmp1, [$tmp2], #4	; store Table Entry
	ADD	$tmp1, $tmp1, #SZ_1M	; add section number field
	SUBS	$tmp3, $tmp3, #1	; decrement loop count
	BGT	%B83
	B	%B82			; Repeat until done

84
	; Convert logical addresses to real addresses
	ADD	$tmp1, $tmp1, $offset	; Pointer to Level2 table

	; ----------------------------------------------------
	; Check for Fine table and process seperately
	; ----------------------------------------------------
	TST	$tmp3, #(PT_FINE - PT_PAGE)
	; Read size!
	LDR	$tmp5, [$addr], #4
	BIC	$tmp4, $tmp1, #0x0ff
	BNE	%F87

	; ----------------------------------------------------
	; Large Level2: Strip address of Level2 Table -> tmp4
	; ----------------------------------------------------
	BIC	$tmp4, $tmp4, #0x0300

	MOV	$tmp5, $tmp5, LSR #16	; no. of 64KB segments
	MOV	$tmp5, $tmp5, LSL #4	; no. of 4KB aliases
85
	STR	$tmp1, [$tmp2], #4	; Level1 points to Level2 entry
86
	; Add each entry aliased 16 times (64KB/4KB, so $tmp3 & 0xF == 0)
	STR	$tmp3, [$tmp4], #4	; store large L2 TT entry
	SUB	$tmp5, $tmp5, #1	; decrement page count
	TST	$tmp5, #0xF
	BNE	%B86			; upto 16 L2 entries

	; Add 16 L2 entries per L1 entry  (1MB/64KB, so $tmp3 & 0xF0 == 0)
	ADD	$tmp3, $tmp3, #SZ_64K	; next page field
	TST	$tmp5, #0xf0
	BNE	%B86			; upto 16 L2 entries

	CMP	$tmp5, #0		; All done?
	ADD	$tmp1, $tmp1, #0x400	; Next 1MB is 256 entries further down
	BNE	%B85			; No, do another L1 entry.
	B	%B81
87
	; ----------------------------------------------------
	; Fine Level2: Strip address of Level2 Table -> tmp4
	; ----------------------------------------------------
	BIC	$tmp4, $tmp4, #0x0f00

	MOV	$tmp5, $tmp5, LSR #16	; no. of 64KB segments
	MOVEQ	$tmp5, $tmp5, LSL #8	; no. of 1KB aliases
	MOVNE	$tmp5, $tmp5, LSL #4	; no. of 4KB aliases
88
	STR	$tmp1, [$tmp2], #4	; Level1 points to Level2 entry
89
	STR	$tmp3, [$tmp4], #4	; store fine L2 TT entry
	SUBS	$tmp5, $tmp5, #1	; decrement page count
	ADD	$tmp3, $tmp3, #SZ_1K	; next page field
	TST	$tmp5, #0x0ff
	BNE	%B89			; 4 x 256 L2 entries
	TST	$tmp5, #0x300
	BNE	%B89			; 3ff won't fit inside an instruction

	CMP	$tmp5, #0		; All done?
	ADD	$tmp1, $tmp1, #0x4000	; Next 1MB is 1K entries further down
	BNE	%B88			; No, do another L1 entry.
	B	%B81
90
	MEND
;------------------------------------------------------------------
;	Compulsory Macros:
;
; These are the macros which must be defined, even for processors
; without any memory management capabilities.
;
; CHECK_FOR_MMU	- return TRUE if CPU has an MMU
; CHECK_FOR_MPU	- return TRUE if CPU has an MPU
; CHECK_CACHE	- return TRUE if CPU has a Cache
; CHECK_UNIFIED	- return TRUE if CPU has a Unified Cache
; CHECK_CPUID	- return TRUE if CPU matches the expected ID
; CHECK_VENDOR	- return TRUE if CPU matches the expected Vendor ID

	MACRO
	CHECK_FOR_MMU	$reg
	NO_CHECK_FOR_MMU	$reg
 IF FORCE_TGTCPU = "ARM7"
	CHECK_FOR_MMU_7T	$reg
 ENDIF
 IF FORCE_TGTCPU = "ARM720"
	CHECK_FOR_MMU_720T	$reg
 ENDIF
 IF FORCE_TGTCPU = "ARM740"
	CHECK_FOR_MMU_740T	$reg
 ENDIF
 IF FORCE_TGTCPU = "ARM920"
	CHECK_FOR_MMU_920T	$reg
 ENDIF
 IF FORCE_TGTCPU = "ARM940"
	CHECK_FOR_MMU_940T	$reg
 ENDIF
 IF FORCE_TGTCPU = "SA110"
	CHECK_FOR_MMU_110	$reg
 ENDIF
	MEND

;Macro to signal if this processor has an MPU
;
	MACRO
	CHECK_FOR_MPU	$reg
	NO_CHECK_FOR_MPU	$reg
 IF FORCE_TGTCPU = "ARM7"
	CHECK_FOR_MPU_7T	$reg
 ENDIF
 IF FORCE_TGTCPU = "ARM720"
	CHECK_FOR_MPU_720T	$reg
 ENDIF
 IF FORCE_TGTCPU = "ARM740"
	CHECK_FOR_MPU_740T	$reg
 ENDIF
 IF FORCE_TGTCPU = "ARM920"
	CHECK_FOR_MPU_920T	$reg
 ENDIF
 IF FORCE_TGTCPU = "ARM940"
	CHECK_FOR_MPU_940T	$reg
 ENDIF
 IF FORCE_TGTCPU = "SA110"
	CHECK_FOR_MPU_110	$reg
 ENDIF
	MEND

;Macro to signal if this processor has a Cache
;
	MACRO
	CHECK_CACHE	$reg
	NO_CHECK_CACHE	$reg
 IF FORCE_TGTCPU = "ARM7"
	CHECK_CACHE_7T	$reg
 ENDIF
 IF FORCE_TGTCPU = "ARM720"
	CHECK_CACHE_720T	$reg
 ENDIF
 IF FORCE_TGTCPU = "ARM740"
	CHECK_CACHE_740T	$reg
 ENDIF
 IF FORCE_TGTCPU = "ARM920"
	CHECK_CACHE_920T	$reg
 ENDIF
 IF FORCE_TGTCPU = "ARM940"
	CHECK_CACHE_940T	$reg
 ENDIF
 IF FORCE_TGTCPU = "SA110"
	CHECK_CACHE_110	$reg
 ENDIF
	MEND

;Macro to signal if this processor has a unified cache
;
	MACRO
	CHECK_UNIFIED	$reg
	NO_CHECK_UNIFIED	$reg
 IF FORCE_TGTCPU = "ARM7"
	CHECK_UNIFIED_7T	$reg
 ENDIF
 IF FORCE_TGTCPU = "ARM720"
	CHECK_UNIFIED_720T	$reg
 ENDIF
 IF FORCE_TGTCPU = "ARM740"
	CHECK_UNIFIED_740T	$reg
 ENDIF
 IF FORCE_TGTCPU = "ARM920"
	CHECK_UNIFIED_920T	$reg
 ENDIF
 IF FORCE_TGTCPU = "ARM940"
	CHECK_UNIFIED_940T	$reg
 ENDIF

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
2021中文字幕一区亚洲| 精品国产露脸精彩对白| 国产高清不卡二三区| 青青草原综合久久大伊人精品优势| 亚洲蜜臀av乱码久久精品蜜桃| 国产欧美va欧美不卡在线| 久久天天做天天爱综合色| 久久精品人人做| 中文字幕一区二区三区在线观看| 国产精品久久久久影院老司| 亚洲欧洲在线观看av| 一区二区三区高清不卡| 亚洲成av人片一区二区梦乃| 天堂va蜜桃一区二区三区漫画版 | 欧美精品一区二区三区四区| 制服丝袜成人动漫| 欧美成人a视频| 国产亚洲一本大道中文在线| 国产精品网站在线观看| 亚洲人妖av一区二区| 一卡二卡三卡日韩欧美| 首页欧美精品中文字幕| 久久99精品国产.久久久久 | 99精品一区二区| 色嗨嗨av一区二区三区| 3atv在线一区二区三区| 337p日本欧洲亚洲大胆精品| 国产精品美女久久久久久久| 亚洲高清久久久| 国产一区二区在线观看视频| 成人免费黄色大片| 欧美精选午夜久久久乱码6080| 精品国产三级电影在线观看| 国产精品美女久久久久aⅴ国产馆| 亚洲精品国产品国语在线app| 日韩高清在线观看| 成人久久18免费网站麻豆 | 欧美国产日韩亚洲一区| 一区二区三区中文在线| 麻豆91免费观看| 日本韩国欧美一区二区三区| 日韩欧美国产综合| 亚洲天堂2016| 久草在线在线精品观看| 欧美影院一区二区| 国产午夜精品久久久久久久 | 国产精品免费视频观看| 婷婷中文字幕一区三区| 国内偷窥港台综合视频在线播放| 欧美怡红院视频| 中文字幕亚洲在| 激情图区综合网| 欧美日韩专区在线| 国产精品久久久久久福利一牛影视| 日韩高清在线一区| 欧美性受xxxx黑人xyx性爽| 国产亚洲一本大道中文在线| 美女诱惑一区二区| 在线观看日产精品| 国产精品久久久久久久久免费桃花| 另类小说色综合网站| 欧美日本国产视频| 亚洲最新在线观看| 99国产精品国产精品毛片| 国产欧美日韩视频在线观看| 免费欧美在线视频| 欧美一级在线视频| 天天影视色香欲综合网老头| 在线国产亚洲欧美| 亚洲天堂网中文字| jlzzjlzz国产精品久久| 国产欧美精品一区二区色综合朱莉| 久久精品国产99久久6| 在线成人免费观看| 日韩二区三区在线观看| 在线不卡免费欧美| 日本不卡一区二区三区高清视频| 欧美日韩亚洲综合在线| 亚洲综合激情网| 欧美在线高清视频| 亚洲va国产va欧美va观看| 欧美日韩一区三区| 午夜伦欧美伦电影理论片| 欧美精品v国产精品v日韩精品| 图片区小说区区亚洲影院| 欧美一区二区视频网站| 蜜臀av一区二区| 久久精品综合网| 成人免费视频国产在线观看| 中文字幕一区免费在线观看| 91视频在线看| 婷婷六月综合亚洲| 日韩免费一区二区| 国产成人激情av| 亚洲丝袜精品丝袜在线| 欧美色综合久久| 麻豆成人91精品二区三区| 国产亚洲欧美日韩日本| 成人福利视频网站| 亚洲福利视频一区| 2020国产精品久久精品美国| 成人激情免费视频| 亚洲电影在线免费观看| 久久亚洲精华国产精华液| 成人av片在线观看| 天天综合日日夜夜精品| 久久新电视剧免费观看| 91无套直看片红桃| 热久久一区二区| 国产精品入口麻豆九色| 欧美视频中文字幕| 成人性生交大合| 天天射综合影视| 国产精品网站导航| 欧美一区二区免费视频| 国产精品99久久久久久久女警| 亚洲欧美另类在线| 精品成人一区二区三区| 91麻豆精品一区二区三区| 免费在线观看一区二区三区| 国产精品伦理在线| 精品奇米国产一区二区三区| 色婷婷久久久久swag精品 | 亚洲一区二区三区爽爽爽爽爽| 欧美成人一区二区三区在线观看| av一二三不卡影片| 国产在线一区二区| 日韩专区在线视频| 亚洲欧美二区三区| 国产欧美日韩不卡免费| 欧美va在线播放| 5月丁香婷婷综合| 色偷偷久久人人79超碰人人澡| 精品在线亚洲视频| 亚洲成精国产精品女| 亚洲欧洲日韩av| 国产丝袜欧美中文另类| 欧美一区二区三区精品| 欧美性受xxxx黑人xyx性爽| av中文字幕亚洲| 国产成人免费视频一区| 精品一区二区三区香蕉蜜桃| 日韩中文字幕一区二区三区| 亚洲国产综合色| 亚洲乱码国产乱码精品精可以看| 欧美国产综合一区二区| 久久久久久免费网| 精品久久免费看| 日韩欧美在线观看一区二区三区| 欧美日韩大陆在线| 欧美日韩国产精品成人| 欧美日韩aaaaa| 欧美日韩五月天| 欧美精品一二三| 日韩欧美高清一区| 日韩欧美国产系列| 精品久久一区二区三区| 久久伊99综合婷婷久久伊| 欧美精品一区二区在线播放| 久久精品一区四区| 国产精品久久久爽爽爽麻豆色哟哟| 久久精品一区蜜桃臀影院| 欧美国产精品v| 一色屋精品亚洲香蕉网站| 亚洲三级久久久| 亚洲网友自拍偷拍| 蜜桃在线一区二区三区| 美国十次综合导航| 国产在线精品免费av| 国产黄人亚洲片| 91在线看国产| 欧美日韩一区二区三区在线| 欧美一区二区日韩| 精品sm在线观看| 国产精品久99| 亚洲成人手机在线| 国产真实乱子伦精品视频| 不卡一区二区中文字幕| 欧美色倩网站大全免费| 欧美tickling挠脚心丨vk| 国产精品婷婷午夜在线观看| 一区二区三区蜜桃| 欧美aa在线视频| 成人免费观看av| 91精品欧美久久久久久动漫 | 久久精品国产亚洲高清剧情介绍| 卡一卡二国产精品| 99国产精品久久久久久久久久久| 欧美午夜片在线看| 久久人人超碰精品| 夜夜亚洲天天久久| 国产乱理伦片在线观看夜一区| 色婷婷综合五月| 国产日韩欧美一区二区三区乱码 | 久久免费看少妇高潮| 亚洲天堂福利av| 国产乱子伦视频一区二区三区| 色八戒一区二区三区| 2020国产精品| 日韩精品欧美精品|