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

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

?? cmd_nand_mba24x0.c.svn-base

?? u-boot loader common files, like cpu, clock, environment...etc...
?? SVN-BASE
?? 第 1 頁 / 共 2 頁
字號:
/* * 2005 modified by Embedded Biz. Division, AIJI system * * (C) Samsung Electronics  *       SW.LEE <hitchcar@samsung.com> *       - add  nandE, 16Bit NAND *       - delete dummy code for S3C2440A * (C) Samsung Electrocnis *       getfree  * * Driver for NAND support, Rick Bronson * borrowed heavily from: * (c) 1999 Machine Vision Holdings, Inc. * (c) 1999, 2000 David Woodhouse <dwmw2@infradead.org> */#include <common.h>#include <command.h>#include <malloc.h>#include <asm/io.h>#if CONFIG_S3C2410#include <s3c2410.h>#elif CONFIG_S3C2440#include <s3c2440.h>#elif CONFIG_S3C2443#include <s3c2443.h>#endif#if (CONFIG_COMMANDS & CFG_CMD_NAND)#include <linux/mtd/nand.h>#include <linux/mtd/nand_ids.h>#if CONFIG_S3C2443    /**** This is not final DO MODIFY  ***/#define		NAND_LED		(*(volatile unsigned *)(S3C24X0_GPIO_BASE+0x54))   #else#define		NAND_LED		(*(volatile unsigned *)(S3C24X0_GPIO_BASE+0x54))#endif#define		WR_STATUS		1#define		RD_STATUS		2extern u16 	NF_CheckId(void);static int	NF_Write(u8 *src_addr, u8 *start_nand_addr, u32 size);extern int	NF_WriteBlock(u8 *src_addr, u32 blk_num);static int 	NF_WritePage(u32 block, u32 page, u8 *buffer);extern int 	NF_EraseBlock(u32 blockNum);static int	NF_Read(u8 *dst_addr, u8 *start_nand_addr, u32 size);extern int	NF_ReadBlock(u8 *dst_addr, u32 blk_num);static int	NF_ReadPage(u32 block, u32 page, u8 *buffer);static int 	NF_IsBadBlock(u32 block);static int 	NF_MarkBadBlock(u32 block);static void NF_Reset(void);static void NF_Init(void);extern void nand_init(void);static void LED_blink(int status);//static int 	NF_WriteOob(u32 block, u32 page, u8 *buffer, int yaffs_option);static int nand_mem_size = 0;static int nand_blk_count = 0;void nand_init(void){	unsigned char manuf_id, model_id;	unsigned short id = 0;	int i;		NF_Init();	id = NF_CheckId();		manuf_id = (id >> 8) & 0xff;	model_id = id & 0xff;	for(i=0; nand_flash_ids[i].name != NULL;i++){		if(manuf_id == nand_flash_ids[i].manufacture_id){			if(model_id == nand_flash_ids[i].model_id){				nand_mem_size = nand_flash_ids[i].memsize;				nand_blk_count = nand_mem_size/NAND_BLOCK_SIZE;				printf("%s  mem size<%dMB>, Block count<%d>\n",					nand_flash_ids[i].name, nand_mem_size>>20, nand_blk_count);			}		}	}	if(nand_mem_size == 0)   printf("[NAND flash is not detected..]");	return;}/*int do_nandyw    (cmd_tbl_t *cmdtp, int flag, int argc, char *argv[]){    ulong   startblk,size,memadr;    int ecc_option;    if (argc !=  5) {        printf ("Usage:\n%s\n", cmdtp->usage);        return 1;    }    startblk = simple_strtoul(argv[1], NULL, 16);    size  = simple_strtoul(argv[2], NULL, 16);    memadr = simple_strtoul(argv[3], NULL, 16);    ecc_option = (argv[4][0] == 'y') ? NF_USE_ECC : NF_USE_MTD_ECC;    // yaffs image don't use 1st block    startblk++;    NF_Init();    s3c24x0_nand_write(startblk, size, memadr, NF_RW_YAFFS, ecc_option );    return 0;}*/int do_nandw    (cmd_tbl_t *cmdtp, int flag, int argc, char *argv[]){	ulong blk_num, page_num, src_addr, size, mem_addr;		if ((argc <  4) || (argc > 5)){		printf ("inadquate argument count\n%s\n", cmdtp->help);		return -1;	}	NF_Init();		mem_addr = simple_strtoul(argv[2], NULL, 16);		if(strcmp(argv[1], "b") == 0){		blk_num  = simple_strtoul(argv[3], NULL, 10);		printf("write block[%d].. read from memory address 0x%x, size is 0x%x\n"			, blk_num, mem_addr, NAND_BLOCK_SIZE);		NF_EraseBlock(blk_num);		if(NF_WriteBlock((u8 *)mem_addr, blk_num) != 0)	return -1;		printf("\nWriting block is Completed\n\n");	}else if(strcmp(argv[1], "p") == 0){		blk_num  = simple_strtoul(argv[3], NULL, 10);		page_num = simple_strtoul(argv[4], NULL, 10);		printf("write page[block:%d, page:%d].. read from memory address 0x%x, size is 0x%x\n"			, blk_num, page_num, mem_addr, NAND_PAGE_SIZE);		NF_EraseBlock(blk_num);		if(NF_WritePage(blk_num, page_num, (u8 *)mem_addr) != 0)			return -1;	}else if(strcmp(argv[1], "t") == 0){		src_addr = simple_strtoul(argv[3], NULL, 16);		size	 = simple_strtoul(argv[4], NULL, 16);		if(NF_Write((u8 *)mem_addr, (u8 *)src_addr, size) != 0)	return -1;	}else{		printf("unknown option.. 'b' or 'p' or 't' \n");		return -1;	}		return 0;}int do_nandr    (cmd_tbl_t *cmdtp, int flag, int argc, char *argv[]){	ulong blk_num, page_num, dst_addr, size, mem_addr;		if ((argc <  4) || (argc > 5)){		printf ("inadquate argument count\n%s\n", cmdtp->help);		return -1;	}		NF_Init();		mem_addr = simple_strtoul(argv[2], NULL, 16);	if(strcmp(argv[1], "b") == 0){		blk_num  = simple_strtoul(argv[3], NULL, 10);		printf("read block[%d].. copy to memory address 0x%x, size is 0x%x\n"			, blk_num, mem_addr, NAND_BLOCK_SIZE);		if(NF_ReadBlock((u8 *)mem_addr, blk_num) != 0)	return -1;		printf("\nReading block is Completed\n\n");	}else if(strcmp(argv[1], "p") == 0){		blk_num  = simple_strtoul(argv[3], NULL, 10);		page_num = simple_strtoul(argv[4], NULL, 10);		printf("read page[block:%d, page:%d].. copy to memory address 0x%x, size is 0x%x\n"			, blk_num, page_num, mem_addr, NAND_PAGE_SIZE);		if(NF_ReadPage(blk_num, page_num, (u8 *)mem_addr) != 0)			return -1;	}else if(strcmp(argv[1], "t") == 0){		dst_addr = simple_strtoul(argv[3], NULL, 16);		size	 = simple_strtoul(argv[4], NULL, 16);		if(NF_Read((u8 *)mem_addr, (u8 *)dst_addr, size) != 0)	return -1;	}else{		printf("unknown option.. 'b' or 'p' or 't' \n");		return -1;	}	return 0;}int do_nande    (cmd_tbl_t *cmdtp, int flag, int argc, char *argv[]){	int startblock, endblock, i;	if ((argc <  2) || (argc > 3)){		printf ("inadquate argument count\nUsage:\n%s\n", cmdtp->help);		return -1;	}		NF_Init();		if(argc == 2){		if(strcmp(argv[1], "all") == 0){			startblock = 0;			endblock = nand_blk_count-1;			printf("erase all blocks [0 ~ %d]\n", endblock);		}else{			startblock = simple_strtoul(argv[1], NULL, 10);			endblock = startblock;			printf("erase block [%d]\n", startblock);		}	}else{ //argc == 3		startblock = simple_strtoul(argv[1], NULL, 10);		endblock = simple_strtoul(argv[2], NULL, 10);		printf("erase block [%d ~ %d]\n", startblock, endblock);	}	printf("Erasing block ...");	for( i=startblock ; i <= endblock;  i++){		if(NF_EraseBlock(i)  == 1)	spin_wheel();		else{			printf("\n[ERASE_ERROR: bad block[ %4d]\n", i);			printf("Erasing block ... ");		}//		NF_CheckBadNande(i);//		printf("%4d  ", i);//		if(i%16 == 15)	printf("\n");	}	printf("\nComplete erasing block\n\n\n");	return 0;}int do_nandb    (cmd_tbl_t *cmdtp, int flag, int argc, char *argv[]){	int startblock, endblock, i, chk_blk_cnt;	if ((argc <  2) || (argc > 3)){		printf ("inadquate argument count\nUsage:\n%s\n", cmdtp->help);		return -1;	}		NF_Init();		if(argc == 2){		if(strcmp(argv[1], "all") == 0){			startblock = 0;			endblock = nand_blk_count-1;			printf("check all blocks [0 ~ %d]\n", endblock);		}else{			startblock = simple_strtoul(argv[1], NULL, 10);			endblock = startblock;			printf("check block number [%d]\n", startblock);		}	}else{ //argc == 3		startblock = simple_strtoul(argv[1], NULL, 10);		endblock = simple_strtoul(argv[2], NULL, 10);		printf("erase block [%d ~ %d]\n", startblock, endblock);	}	printf("Display block status :");	chk_blk_cnt = 0;	for( i=startblock ; i <= endblock;  i++){		if(NF_IsBadBlock(i) == 1){			if(chk_blk_cnt%8 == 0)  printf("\n");			printf("%4d(bad) ", i);			chk_blk_cnt++;		}else{//			printf("%4d(o) ", i);		}	}	if(chk_blk_cnt == 0){		if(argc == 2){			if(startblock == endblock)  printf("\nblock[%4d] is OK..", startblock);			else                        printf("\nAll block is OK..");		}else			printf("block[%4d] ~ block[%4d] OK..", startblock, endblock);	}	printf("\n\n\n");	return 0;}/*U_BOOT_CMD(	nandyw, 5,  1,  do_nandyw,	"nandyw - HEX: targetblock targetsize mem_addr ecc_option(y/m)\n",	"\n  - MBA2410 NAND Flash Write Command for Yaffs\n"        \	"nandyw targetblock 0~0xfff(4095), targetsize memory addr \n"    \	"       ecc_option : [y] : use yaffs ecc / [m] : use mtd ecc  \n"  \);*/U_BOOT_CMD(	nandw,	5,	1,	do_nandw,	"nandw   - MBA2410 NAND Flash Write program : write from memory to NAND flash\n",	" - MBA2410 NAND Flash Write Program : write from NAND\n"	\	"nandw [b/p/t] [src_mem_addr] [targetblock/src_addr] [targetpage/size]\n" \	"    option b - read block, p - read page, t - read address you wanna write\n"	\	"    nandw b source_memory_addr(hex) targetblock(0~4095)\n"	\	"    nandw p source_memory_addr(hex) targetblock(0~4095) targetpage(0~31)\n"	\	"    nandw t source_memory_addr(hex) target_addr[hex]    size[hex]\n"	\	"            The limits of target_addr must be from 0x0 to 0x4000000\n"	\	"            target_addr must be the multiple of page size 0x200\n"	\);U_BOOT_CMD(	nandr,	5,	1,	do_nandr,	"nandr   - MBA2410 NAND Flash Read program : read and copy to memory \n",	" - MBA2410 NAND Flash Read program : read and copy to memory \n"	\	"nandr [b/p/t] [dst_mem_addr] [targetblock/src_addr] [targetpage/size]\n" \	"    option b - read block, p - read page, t - read address you wanna read\n"	\	"    nandr b destination_memory_addr(hex) targetblock(0~4095)\n"	\	"    nandr p destination_memory_addr(hex) targetblock(0~4095) targetpage(0~31)\n"	\	"    nandr t destination_memory_addr(hex) target_addr[hex]    size[hex]\n"	\	"            The limits of target_addr must be from 0x0 to 0x4000000\n"	\	"            target_addr must be the multiple of page size 0x200\n"	\);U_BOOT_CMD(	nande,	3,	1,	do_nande,	"nande   - MBA2410 NAND Flash Erase program : erase blocks\n",	" - MBA2410 NAND Flash Erase program : erase only blocks\n"	\	"    nande startblock(0~4095) endblock(0~4095)\n"	\	"    nande blocknumber(0~4095)  - erase one block you select\n"	\	"    nande all                  - erase all blocks\n"	\);U_BOOT_CMD(	nandb,	3,	1,	do_nandb,	"nandb   - MBA2410 NAND Flash Bad block check program\n",	" - MBA2410 NAND Flash Bad block check program\n"	\	"    nandb startblock(0~4095) endblock(0~4095)\n"	\	"    nande blocknumber(0~4095)  - check one block you select\n"	\	"    nande all                  - check all blocks\n"	\);#define NF_CMD(cmd)		{NFCMD   =  cmd;}#define NF_ADDR(addr)		{NFADDR  =  addr;}#define NF_RDDATA() 		(NFDATA)#define NF_WRDATA(data) 	{NFDATA  =  data;}#if CONFIG_S3C2410#define NF_nFCE_L()			{NFCONF &= ~(1<<11);}#define NF_nFCE_H()			{NFCONF |=  (1<<11);}#define NF_RSTECC()			{NFCONF |=  (1<<12);}#define NF_DETECT_RB()		{while(!(NFSTAT & (1<<0)));}#define NF_CLEAR_RB()		{NFSTAT |= (1<<2);} // Have write '1' to clear this bit.#define TACLS           0       // 1-clk(0ns) #define TWRPH0          3       // 3-clk(25ns)#define TWRPH1          0       // 1-clk(10ns)  //TACLS+TWRPH0+TWRPH1>=50ns#elif CONFIG_S3C2440#define NF_SOFT_UnLock()    {NFCONT&=~(1<<12);}#define NF_MECC_UnLock()    {NFCONT&=~(1<<5);}#define NF_MECC_Lock()      {NFCONT|=(1<<5);}#define NF_SECC_UnLock()    {NFCONT&=~(1<<6);}#define NF_SECC_Lock()      {NFCONT|=(1<<6);}#define NF_nFCE_L()         {NFCONT&=~(1<<1);}#define NF_nFCE_H()         {NFCONT|=(1<<1);}#define NF_RSTECC()         {NFCONT|=(1<<4);}#define NF_RDDATA8()        (NFDATA8)#define NF_WRDATA8(data)    {NFDATA8=data;}// RnB Signal#define NF_DETECT_RB()      {while(!(NFSTAT&(1<<2)));}#define NF_CLEAR_RB()		{NFSTAT |= (1<<2);} // Have write '1' to clear this bit.#define TACLS               1#define TWRPH0              5#define TWRPH1              0static u32 se16Buf[32/2]={        0xffffffff,0xffffffff,0xffffffff,0xffffffff,        0xffffffff,0xffffffff,0xffffffff,0xffffffff,        0xffffffff,0xffffffff,0xffffffff,0xffffffff,        0xffffffff,0xffffffff,0xffffffff,0xffffffff};#elif CONFIG_S3C2443#define NF_SOFT_UnLock()    {NFCONT&=~(1<<16);}#define NF_MECC_UnLock()    {NFCONT&=~(1<<7);}#define NF_MECC_Lock()      {NFCONT|=(1<<7);}#define NF_SECC_UnLock()    {NFCONT&=~(1<<6);}#define NF_SECC_Lock()      {NFCONT|=(1<<6);}#define NF_nFCE_L()         {NFCONT&=~(1<<1);}#define NF_nFCE_H()         {NFCONT|=(1<<1);}#define NF_RSTECC()         {NFCONT|=(1<<4);}#define NF_RDDATA8()        (NFDATA8)#define NF_WRDATA8(data)    {NFDATA8=data;}// RnB Signal#define NF_DETECT_RB()      {while(!(NFSTAT & (1<<4)));}#define NF_CLEAR_RB()		{NFSTAT |= (1<<4);} // Have write '1' to clear this bit.#define TACLS               1#define TWRPH0              5#define TWRPH1              0static u32 se16Buf[32/2]={        0xffffffff,0xffffffff,0xffffffff,0xffffffff,        0xffffffff,0xffffffff,0xffffffff,0xffffffff,        0xffffffff,0xffffffff,0xffffffff,0xffffffff,        0xffffffff,0xffffffff,0xffffffff,0xffffffff};#endifstatic u8 seBuf[16]={0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff};int	NF_Write(u8 *src_addr, u8 *start_nand_addr, u32 size){	u32 s_blk_num, s_pg_num;	u32 e_blk_num, e_pg_num;	u8 * buf = src_addr;	int i, j;		if((start_nand_addr<0) || (start_nand_addr>=nand_mem_size)){		printf("target_addr must be within the range of 0x0 ~ 0x%x\n", nand_mem_size-1);		return -1;	}		if(((u32)src_addr<CFG_MEMTEST_START) || ((u32)src_addr>=CFG_MEMTEST_END)){		printf("source_memory_addr must be within the range of 0x%x ~ 0x%x\n", 			CFG_MEMTEST_START, CFG_MEMTEST_END);		return -1;	}		s_blk_num = (u32)start_nand_addr / (u32)NAND_BLOCK_SIZE;	s_pg_num  = ((u32)start_nand_addr&(NAND_BLOCK_SIZE -1)) / (u32)NAND_PAGE_SIZE;		e_blk_num = ((size / (u32)NAND_BLOCK_SIZE)) + s_blk_num;	e_pg_num  = ((size&(NAND_BLOCK_SIZE -1)) / (u32)NAND_PAGE_SIZE) + s_pg_num;		printf("Write start point : block[%d] page[%d] size = 0x%x\n", 		s_blk_num, s_pg_num, size);	printf("Writing data ... ");	for(i=s_blk_num; i<=e_blk_num; i++){		if(NF_EraseBlock(i) == 0){			printf("\nBlock[%d] is bad block. Write next block\n", i);			e_blk_num++;			printf("Writing data ... ");			continue;		}		if((i==s_blk_num) && (s_pg_num != 0)){			for(j=s_pg_num; j<NAND_PAGES_IN_BLOCK; j++){				NF_WritePage(i, j, buf);				spin_wheel();				buf += NAND_PAGE_SIZE;			}		}else if((i==e_blk_num) && (e_pg_num != 0)){			for(j=0; j<e_pg_num; j++){				NF_WritePage(i, j, buf);				spin_wheel();				buf += NAND_PAGE_SIZE;			}		}else if((i==e_blk_num) && (e_pg_num == 0)){			break;		}else{			NF_WriteBlock(buf, i);			buf += NAND_BLOCK_SIZE;		}	}		printf("\nWrite compelete(0x%x): from 0x%x SDRAM to 0x%x(%d) NAND flash\n",		size, (u32)src_addr, start_nand_addr, s_blk_num);	return 0;	}int	NF_WriteBlock(u8 *src_addr, u32 blk_num){	char *buf = src_addr;	int i;		for (i = 0; i < NAND_PAGES_IN_BLOCK; i++) {		NF_WritePage(blk_num, i, buf);		spin_wheel();		buf += NAND_PAGE_SIZE;	}	LED_blink(WR_STATUS);	return 0;}int NF_WritePage(u32 block,u32 page,u8 *buffer){	int i;	u32 blockPage = (block * NAND_PAGES_IN_BLOCK) + (page & 0x1f);	u8 *ptr = buffer;#if CONFIG_S3C2440 || CONFIG_S3C2443  //added by maddy220109	u32 mecc, secc;#endif#if CONFIG_S3C2440 || CONFIG_S3C2443 	//added by maddy220109	NF_SOFT_UnLock();#endif	NF_RSTECC();#if CONFIG_S3C2440 || CONFIG_S3C2443   //added by maddy220109 		NF_MECC_UnLock();#endif	NF_nFCE_L();	NF_CLEAR_RB();    NF_CMD(NAND_CMD_READ0);			//??????    NF_CMD(NAND_CMD_SEQIN);			// Write 1st command    NF_ADDR(0);						// Column 0    NF_ADDR(blockPage&0xff);	    //    NF_ADDR((blockPage>>8)&0xff);   // Block & page num.    NF_ADDR((blockPage>>16)&0xff);  //    	// Write one page to NFM from buffer#if CONFIG_S3C2410

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
一区二区三区不卡视频在线观看| 26uuu国产日韩综合| 亚洲成人黄色影院| 欧美亚洲丝袜传媒另类| 亚洲国产乱码最新视频| 欧美一区午夜视频在线观看| 免费看日韩a级影片| 久久久久99精品国产片| jiyouzz国产精品久久| 一区二区三区丝袜| 欧美一区二区三区四区五区| 激情综合网激情| 中文字幕一区二区在线播放| 日本高清不卡一区| 精一区二区三区| 亚洲色图一区二区| 正在播放一区二区| 色悠悠久久综合| 免费观看在线综合| 亚洲日本一区二区三区| 欧美日韩亚洲综合一区| 国产麻豆精品久久一二三| 一区二区三区中文字幕电影 | 亚洲一区二区三区中文字幕| 欧美丰满高潮xxxx喷水动漫| 国产精品18久久久| 午夜精品视频一区| 中文字幕精品一区二区三区精品| 欧美系列日韩一区| 成人在线视频一区| 美女视频网站黄色亚洲| 亚洲三级在线看| 久久久国际精品| 欧美人伦禁忌dvd放荡欲情| 成人高清免费在线播放| 久久福利视频一区二区| 亚洲在线一区二区三区| 亚洲图片激情小说| 中文在线资源观看网站视频免费不卡 | 亚洲国产综合在线| 国产精品蜜臀av| 久久久综合激的五月天| 欧美一区国产二区| 欧美精品久久久久久久多人混战| 99精品视频免费在线观看| 国产成人在线视频网址| 九一九一国产精品| 日本特黄久久久高潮| 精品一区二区国语对白| 丝袜亚洲精品中文字幕一区| 亚洲精品视频在线| 一区二区三区自拍| 一区二区三区在线播| 亚洲一级二级三级| 亚洲一区视频在线| 亚洲成av人片一区二区三区| 亚洲宅男天堂在线观看无病毒| 亚洲天堂免费在线观看视频| 亚洲欧美日韩国产成人精品影院| 亚洲视频电影在线| 久久久噜噜噜久噜久久综合| 精品久久久久久久久久久院品网| 欧美大片在线观看一区二区| 日韩小视频在线观看专区| 精品国产乱码久久| 国产亚洲欧洲997久久综合| 中文字幕不卡一区| 一区二区三区中文字幕电影 | 91精品国产日韩91久久久久久| 欧美一区二区三区四区在线观看| 欧美一级黄色录像| 久久久99久久精品欧美| 亚洲欧洲在线观看av| 亚洲国产日产av| 激情综合色播激情啊| 国产成人免费视频| 91官网在线免费观看| 日韩一本二本av| 国产欧美日韩卡一| 日韩专区欧美专区| 国产黄色精品网站| 欧美性大战久久| 国产日韩欧美精品电影三级在线| 亚洲视频在线观看一区| 蜜臀91精品一区二区三区| 成人高清在线视频| 亚洲精品一线二线三线无人区| 亚洲精品视频在线观看网站| 国产尤物一区二区| 欧美日韩国产另类不卡| 国产精品国产三级国产三级人妇| 丝袜美腿亚洲一区二区图片| 成人午夜免费视频| 久久亚洲精精品中文字幕早川悠里| 亚洲天堂网中文字| 粉嫩高潮美女一区二区三区| 日韩欧美在线观看一区二区三区| 国产精品的网站| 麻豆免费看一区二区三区| 国产成人综合在线| 91精品国产综合久久久久久漫画 | 在线观看一区二区视频| 欧美一区二区在线播放| 亚洲欧洲精品成人久久奇米网| 日韩理论片中文av| 国产成人aaa| 欧美一级生活片| 夜夜夜精品看看| 成人av在线播放网站| 欧美va亚洲va| 免费久久99精品国产| 欧美午夜一区二区三区免费大片| 欧美国产丝袜视频| 国产一区二区日韩精品| 日韩一级精品视频在线观看| 亚洲欧美另类综合偷拍| 成人高清免费观看| 久久精品夜色噜噜亚洲a∨ | 欧美日韩国产精品自在自线| 国产精品天干天干在观线| 国产制服丝袜一区| 精品国产精品网麻豆系列| 91小视频免费看| 国产99久久久久久免费看农村| 国产在线精品一区二区夜色 | 99精品视频在线播放观看| 久久嫩草精品久久久精品| 麻豆91精品91久久久的内涵| 欧美三级电影在线观看| 国产精品欧美一级免费| 成人激情黄色小说| 亚洲精品老司机| 欧美在线免费播放| 日韩精品一级中文字幕精品视频免费观看| 91福利在线观看| 亚洲va国产天堂va久久en| 日本韩国精品在线| 午夜精品爽啪视频| 精品福利av导航| 99久免费精品视频在线观看| 亚洲日穴在线视频| 欧美精品v国产精品v日韩精品| 欧美aaa在线| 91精品国产麻豆国产自产在线| 精品午夜久久福利影院| 亚洲国产精品成人久久综合一区| 99视频国产精品| 青青草精品视频| 中文字幕中文字幕在线一区 | 久久综合国产精品| 国产精品自拍在线| 亚洲专区一二三| 欧美日韩国产片| 国产高清不卡一区二区| 一区二区三区在线观看网站| 欧美日韩国产小视频在线观看| 国产一二精品视频| 亚洲大片精品永久免费| 国产婷婷一区二区| 欧美精品123区| 色婷婷综合在线| 韩国成人福利片在线播放| 亚洲精品成人精品456| 精品欧美一区二区三区精品久久| 国产不卡视频一区二区三区| 日韩av一区二区三区四区| 亚洲视频一二区| 国产三级精品在线| 欧美tickling网站挠脚心| 日本道精品一区二区三区| 国产盗摄一区二区三区| 蜜桃视频在线观看一区二区| 一区二区在线观看免费视频播放| 国产亚洲综合在线| 日韩无一区二区| 欧美日韩久久一区二区| 成人高清视频在线观看| 精品综合免费视频观看| 亚洲成人综合在线| 亚洲在线视频免费观看| 国产欧美精品一区二区色综合| 26uuu成人网一区二区三区| 日本道在线观看一区二区| 91在线视频播放地址| 捆绑调教一区二区三区| 日韩激情视频网站| 午夜精品久久久| 美腿丝袜一区二区三区| 久久国产剧场电影| 精油按摩中文字幕久久| 国产麻豆成人精品| 国产福利一区在线| 99在线精品视频| 色999日韩国产欧美一区二区| 91在线精品一区二区| 91极品美女在线| 日韩一区二区三免费高清| 欧美精品一区二区三区蜜桃视频| 久久你懂得1024| 亚洲人妖av一区二区|