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

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

?? asm.c

?? This free cpu-ip! use verilog
?? C
?? 第 1 頁 / 共 2 頁
字號:
	}
	else if (isdigit(**pp)) {
		if (**pp == '0') {
			++*pp;
			if (**pp == 'x' || **pp == 'X') {
				while (isxdigit(*++*pp))
					;
				c = **pp;
				**pp = 0;
				t.type = CON;
				sscanf(p1, "%x", &t.u.con);
				**pp = c;
				return t;
			}
			--*pp;
		}

		while (isdigit(*++*pp))
			;
		c = **pp;
		**pp = 0;
		t.type = CON;
		t.u.con = atoi(p1);
		**pp = c;
	}
	else {
		t.type = **pp;
		++*pp;
	}

	return t;
}

Bool parse(char**p, ...)
{
	va_list va;
	Token t;
	Type expected;
	Bool ret = TRUE;

	va_start(va, p);

	while ((expected = va_arg(va, Type)) != 0) {
		t = lex(p);
		if (t.type != expected) {
			error("syntax error");
			ret = FALSE;
			break;
		}
		if (t.type == SYM || t.type == REG || t.type == CON) {
			Token* pt = va_arg(va, Token*);
			*pt = t;
		}
	}

	va_end(va);

	return ret;
}

enum { NSYMS = 10000 };
static int nsyms = 0;
static Symbol symtab[NSYMS];

/* Look-up symbol for string in current file's symbol table.
 * If found, return symbol.
 * If not, create new symbol and return that.
 *
 * Each source file has its own logical name space.
 * Global names (sym.file == 0) are visible across all files.
 */
Sym lookup(SZ sz)
{
	int i;

	for (i = 0; i < nsyms; i++)
		if ((symtab[i].file == 0 || symtab[i].file == file) &&
		    strncmp(symtab[i].id, sz, sizeof(symtab[i].id)-1) == 0)
			return &symtab[i];

	/* not found, add it */
	if (nsyms < NSYMS) {
		strncpy(symtab[i].id, sz, sizeof(symtab[i].id)-1);
		symtab[nsyms].addr = 0;
		symtab[nsyms].defined = FALSE;
		symtab[nsyms].file = file;
		return &symtab[nsyms++];
	}
	else
		return 0;
}

int cmpAddr(const void* pv1, const void* pv2)
{
	const Symbol* ps1 = pv1;
	const Symbol* ps2 = pv2;

	return ps1->addr - ps2->addr;
}

SZ szForAddr(char buf[], size_t cbbuf, Addr addr)
{
	static Bool sorted = FALSE;
	Symbol *p, *base = 0;

	if (!sorted) {
		qsort(symtab, nsyms, sizeof(symtab[0]), cmpAddr);
		sorted = TRUE;
	}

	/* find last symbol address <= addr
	 * 
	 * Takes advantage of the invariant that symbols are in order
	 * of increasing address.
	 */
	for (p = symtab; p < &symtab[nsyms] && p->addr <= addr; p++)
		if (p->id[0] != 'L') /* skip labels */
			base = p;

	if (base && !(strcmp(base->id, "end")==0 || strcmp(base->id, "__end")==0)) {
		if (addr == base->addr)
			_snprintf(buf, cbbuf, "%s", base->id);
		else
			_snprintf(buf, cbbuf, "%s+%d", base->id, addr - base->addr);
	} else
		_snprintf(buf, cbbuf, "%04X", addr);

	buf[cbbuf-1] = 0;

	return buf;
}


enum { cbMax = 65536 };
Byte rgb[cbMax];

unsigned cb = 0;

Addr here()
{
	return cb;
}

void label(Sym sym)
{
	sym->addr = cb;
	sym->defined = TRUE;
}

void global(Sym sym)
{
	sym->file = 0;
}

int lastDestReg()
{
	Insn insn = (rgb[cb-2] << 8) | rgb[cb-1];
	if (OP_ADD <= OP(insn) && OP(insn) < OP_SW)
		return RD(insn);
	else
		return 0;
}

void insn(unsigned in, unsigned w) {
	word(mpininsn[in] | w);
}

void align(unsigned alignment) {
	while (cb % alignment != 0)
		byte(0);
}

void bss(unsigned c) {
	while (c--)
		byte(0);
}

void word(unsigned w) {
	align(2);
	byte(w >> 8);
	byte(w);
}

unsigned wordAt(Addr addr) {
	return (rgb[addr] << 8) | rgb[addr+1];
}

void byte(unsigned b) {
	if (cb < sizeof(rgb))
		rgb[cb++] = (Byte)b;
}

enum { NFIXUPS = 10000 };
Fixup fixups[NFIXUPS];
int cfixup = 0;

void fixup(FixupType type, Sym target, int disp)
{
	if (cfixup < NFIXUPS) {
		fixups[cfixup].type = type;
		fixups[cfixup].target = target;
		fixups[cfixup].addr = cb;
		fixups[cfixup].disp = disp;
		++cfixup;
	}
}

void applyFixups() {
	Fixup*	pfix;

	for (pfix = fixups; pfix < &fixups[cfixup]; pfix++) {
		int disp;
		unsigned abs;

		if (!pfix->target->defined && !pfix->target->error) {
			error("undefined symbol '%s'", pfix->target->id);
			pfix->target->error = TRUE;
			continue;
		}

		switch (pfix->type) {
		case FIX_ADDR:
			abs = pfix->target->addr + pfix->disp;
			rgb[pfix->addr  ] = abs >> 8;
			rgb[pfix->addr+1] = abs;
			break;
		case FIX_LDST: {
			Insn imm  = (rgb[pfix->addr]   << 8) | rgb[pfix->addr+1];
			Insn insn = (rgb[pfix->addr+2] << 8) | rgb[pfix->addr+3];
			Bool byte = (OP(insn) == OP_LB || OP(insn) == OP_SB || OP(insn) == OP_ADDI);
			Bool word = (OP(insn) == OP_LW || OP(insn) == OP_SW || OP(insn) == OP_JAL);

			abs = pfix->target->addr + pfix->disp;

			if (OP(imm) != OP_IMM || !(byte || word)) {
				error("ldst fixup error");
				break;
			}
			else if ((abs&1) && word) {
				error("ldst word fixup error target '%s' odd address %04X + %d", pfix->target->id, pfix->target->addr, pfix->disp);
				break;
			}

			imm = mpininsn[IMM] | IMM12(abs >> 4);
			insn = (insn & ~0xF) | INSN_I4(abs);

			rgb[pfix->addr  ] = imm >> 8;
			rgb[pfix->addr+1] = (Byte)imm;
			rgb[pfix->addr+2] = insn >> 8;
			rgb[pfix->addr+3] = (Byte)insn;
			break;
		}
		case FIX_BR:
			disp = ((int)pfix->target->addr - (int)pfix->addr)/2 - 2;
			if (-128 <= disp && disp < 128)
				rgb[pfix->addr+1] = (Byte)disp;
			else
				error("branch displacement overflow at %04X target '%s'", pfix->addr, pfix->target->id);
			break;
		case FIX_CALL:
			if ((pfix->target->addr & 0xF) == 0) {
				rgb[pfix->addr]   |= (pfix->target->addr >> 12) & 0x0F;
				rgb[pfix->addr+1] |= (pfix->target->addr >>  4) & 0xFF;
			}
			else
				error("call at %04X target '%s' is not 16-byte aligned", pfix->addr, pfix->target->id);
			break;
		default:
			error("unexpected fixup type");
			break;
		}
	}
}

void addListingLine(SZ line) {
	if (nlines < NLINES) {
		lines[nlines].addr = here();
		lines[nlines].szLine = _strdup(line);
		++nlines;
	}
}

void listing(SZ lstfile) {
	FILE*	lst;
	Addr	addr;
	Insn	insn;
	time_t	now;
	struct tm* ptmNow;
	char	szInsn[20];
	static char rev[] = "$Revision: 3 $";

	if ((lst = fopen(lstfile, "w")) == 0) {
		error("cannot open '%s' (%s)", lstfile, strerror(errno));
		return;
	}

	time(&now);
	ptmNow = localtime(&now);
	rev[strlen(rev)-2] = 0;
	fprintf(lst, "# generated by xr16 rev.%s on %s\n", rev+11, asctime(ptmNow));
	fprintf(lst, "addr code  disassembly       source\n");
	fprintf(lst, "---- ----  -----------       ------\n");
	line = 0;
	for (addr = 0; addr < cb; addr += sizeof(Insn)) {
		while (line+1 < nlines && lines[line].addr <= addr && lines[line+1].addr <= addr)
			fprintf(lst, "%-28s %s\n", "", lines[line++].szLine);

		insn = wordAt(addr);
		szForInsn(szInsn, sizeof szInsn, addr, insn);
		fprintf(lst, "%04X %04X  %-18s", addr, insn, szInsn);

		if (line < nlines && lines[line].addr <= addr)
			fprintf(lst, "%s\n", lines[line++].szLine);
		else
			fprintf(lst, "\n");
	}
	for ( ; line < nlines; ++line)
		fprintf(lst, "%-28s %s\n", "", lines[line].szLine);

	if (ferror(lst) || fclose(lst))
		error("error writing '%s' (%s)", lstfile, strerror(errno));
}

void emit(SZ hexfile) {
	FILE*	hex;
	Addr	addr;

	if ((hex = fopen(hexfile, "w")) == 0) {
		error("cannot open '%s' (%s)", hexfile, strerror(errno));
		return;
	}

	for (addr = 0; addr < cb; addr++) {
		if (addr % 16 == 0)
			fprintf(hex, "- %02X %04X", __min(0x10, cb - addr), addr);
		fprintf(hex, " %02X", rgb[addr]);
		if (addr % 16 == 15 || addr == cb-1)
			fprintf(hex, "\n");
	}

	if (ferror(hex) || fclose(hex))
		error("error writing '%s' (%s)", hexfile, strerror(errno));
}

static SZ mprnsz[16] = {
	"r0", "r1", "r2", "r3",
	"r4", "r5", "r6", "r7",
	"r8", "r9", "r10", "r11",
	"r12", "r13", "sp", "r15"
};

static SZ mpopsz[16] = {
	"add  %s,%s,%s",
	"sub  %s,%s,%s",
	"addi %s,%s,%d",
	0,
	0,
	"lw   %s,%d(%s)",
	"lb   %s,%d(%s)",
	0,
	"sw   %s,%d(%s)",
	"sb   %s,%d(%s)",
	"jal  %s,%d(%s)",
	0,
	"call %04X",
	"imm  %04X",
	0,
	"trap %d"
};

static SZ mpfnszRR[16] = {
	"and  %s,%s",
	"or   %s,%s",
	"xor  %s,%s",
	"andn %s,%s",
	"adc  %s,%s",
	"sbc  %s,%s"
};

static SZ mpfnszRI[16] = {
	"andi %s,%d",
	"ori  %s,%d",
	"xori %s,%d",
	"andni %s,%d",
	"adci %s,%d",
	"sbci %s,%d",
	"srli %s,%d",
	"srai %s,%d",
	"slli %s,%d",
	"srxi %s,%d",
	"slxi %s,%d",
};

SZ mpcondszBR[16] = {
	"br   %04X",
	"brn",
	"beq  %04X",
	"bne  %04X",
	"bc   %04X",
	"bnc  %04X",
	"bv   %04X",
	"bnv  %04X",
	"blt  %04X",
	"bge  %04X",
	"ble  %04X",
	"bgt  %04X",
	"bltu %04X",
	"bgeu %04X",
	"bleu %04X",
	"bgtu %04X"
};

SZ szForInsn(char buf[], size_t cbbuf, Addr addr, Insn insn) {
	strcpy(buf, "<reserved>");

	buf[--cbbuf] = 0;

	switch (OP(insn)) {
	case OP_ADD:
	case OP_SUB:
		_snprintf(buf, cbbuf, mpopsz[OP(insn)], mprnsz[RD(insn)], mprnsz[RA(insn)], mprnsz[RB(insn)]);
		break;
	case OP_ADDI:
		_snprintf(buf, cbbuf, mpopsz[OP(insn)], mprnsz[RD(insn)], mprnsz[RA(insn)], IMM_SEXT(insn));
		break;
	case OP_RR:
		if (mpfnszRR[FN(insn)])
			_snprintf(buf, cbbuf, mpfnszRR[FN(insn)], mprnsz[RD(insn)], mprnsz[RB(insn)]);
		break;
	case OP_RI:
		if (mpfnszRI[FN(insn)])
			_snprintf(buf, cbbuf, mpfnszRI[FN(insn)], mprnsz[RD(insn)], IMM_SEXT(insn));
		break;
	case OP_LW:
	case OP_SW:
	case OP_JAL:
		_snprintf(buf, cbbuf, mpopsz[OP(insn)], mprnsz[RD(insn)], (((IMM(insn)>>1)<<1)|((IMM(insn)&1)<<4)), mprnsz[RA(insn)]);
		break;
	case OP_LB:
	case OP_SB:
		_snprintf(buf, cbbuf, mpopsz[OP(insn)], mprnsz[RD(insn)], IMM(insn), mprnsz[RA(insn)]);
		break;
	case OP_BR:
		if (mpcondszBR[COND(insn)])
			_snprintf(buf, cbbuf, mpcondszBR[COND(insn)], addr + (DISP(insn) + 2)*sizeof(Insn));
		break;
	case OP_CALL:
	case OP_IMM:
		_snprintf(buf, cbbuf, mpopsz[OP(insn)], IMM12(insn) << 4);
		break;
	case OP_TRAP:
		_snprintf(buf, cbbuf, mpopsz[OP(insn)], IMM12(insn));
		break;
	}
	buf[cbbuf] = 0;

	return buf;
}

SZ mpinsz[] = {
	"and", "sub", "addi",
	"and", "or", "xor", "andn", "adc", "sbc",
	"andi", "ori", "xori", "andni", "adci", "sbci", "srli", "srai", "slli", "srxi", "slxi",
	"lw", "lb", 0, "sw", "sb", "jal",
	"br", "brn", "beq", "bne", "bc", "bnc", "bv", "bnv",
	"blt", "bge", "ble", "bgt", "bltu", "bgeu", "bleu", "bgtu",
	"call", "imm", 0
};

Insn mpininsn[] = {
	INSN_OP(OP_ADD),
	INSN_OP(OP_SUB),
	INSN_OP(OP_ADDI),
	INSN_OPFN(OP_RR, FN_AND),
	INSN_OPFN(OP_RR, FN_OR),
	INSN_OPFN(OP_RR, FN_XOR),
	INSN_OPFN(OP_RR, FN_ANDN),
	INSN_OPFN(OP_RR, FN_ADC),
	INSN_OPFN(OP_RR, FN_SBC),
	INSN_OPFN(OP_RI, FN_AND),
	INSN_OPFN(OP_RI, FN_OR),
	INSN_OPFN(OP_RI, FN_XOR),
	INSN_OPFN(OP_RI, FN_ANDN),
	INSN_OPFN(OP_RI, FN_ADC),
	INSN_OPFN(OP_RI, FN_SBC),
	INSN_OPFN(OP_RI, FN_SRL),
	INSN_OPFN(OP_RI, FN_SRA),
	INSN_OPFN(OP_RI, FN_SLL),
	INSN_OPFN(OP_RI, FN_SRX),
	INSN_OPFN(OP_RI, FN_SLX),
	INSN_OP(OP_LW),
	INSN_OP(OP_LB),
	INSN_OP(OP_SW),
	INSN_OP(OP_SB),
	INSN_OP(OP_JAL),
	INSN_BR(BR_BR),
	INSN_BR(BR_BRN),
	INSN_BR(BR_BEQ),
	INSN_BR(BR_BNE),
	INSN_BR(BR_BC),
	INSN_BR(BR_BNC),
	INSN_BR(BR_BV),
	INSN_BR(BR_BNV),
	INSN_BR(BR_BLT),
	INSN_BR(BR_BGE),
	INSN_BR(BR_BLE),
	INSN_BR(BR_BGT),
	INSN_BR(BR_BLTU),
	INSN_BR(BR_BGEU),
	INSN_BR(BR_BLEU),
	INSN_BR(BR_BGTU), 
	INSN_OP(OP_CALL),
	INSN_OP(OP_IMM),
	INSN_OP(OP_TRAP),
};

SzToken tokens[] = {
	{ "add",	{ IN, ADD } },
	{ "sub",	{ IN, SUB } },
	{ "addi",	{ IN, ADDI } },
	{ "and",	{ IN, AND } },
	{ "or",		{ IN, OR } },
	{ "xor",	{ IN, XOR } },
	{ "andn",	{ IN, ANDN } },
	{ "adc",	{ IN, ADC } },
	{ "sbc",	{ IN, SBC } },
	{ "andi",	{ IN, ANDI } },
	{ "ori",	{ IN, ORI } },
	{ "xori",	{ IN, XORI } },
	{ "andni",	{ IN, ANDNI } },
	{ "adci",	{ IN, ADCI } },
	{ "sbci",	{ IN, SBCI } },
	{ "srli",	{ IN, SRLI } },
	{ "srai",	{ IN, SRAI } },
	{ "slli",	{ IN, SLLI } },
	{ "srxi",	{ IN, SRXI } },
	{ "slxi",	{ IN, SLXI } },
	{ "lw",		{ IN, LW } },
	{ "lb",		{ IN, LB } },
	{ "sw",		{ IN, SW } },
	{ "sb",		{ IN, SB } },
	{ "jal",	{ IN, JAL } },
	{ "br",		{ IN, BR } },
	{ "brn",	{ IN, BRN } },
	{ "beq",	{ IN, BEQ } },
	{ "bne",	{ IN, BNE } },
	{ "bc",		{ IN, BC } },
	{ "bnc",	{ IN, BNC } },
	{ "bv",		{ IN, BV } },
	{ "bnv",	{ IN, BNV } },
	{ "blt",	{ IN, BLT } },
	{ "bge",	{ IN, BGE } },
	{ "ble",	{ IN, BLE } },
	{ "bgt",	{ IN, BGT } },
	{ "bltu",	{ IN, BLTU } },
	{ "bgeu",	{ IN, BGEU } },
	{ "bleu",	{ IN, BLEU } },
	{ "bgtu",	{ IN, BGTU,  } },
	{ "call",	{ IN, CALL } },
	{ "imm",	{ IN, IMM } },

	{ "trap",	{ IN, TRAP } },

	{ "nop",	{ IN, NOP } },
	{ "mov",	{ IN, MOV } },
	{ "subi",	{ IN, SUBI } },
	{ "cmp",	{ IN, CMP } },
	{ "cmpi",	{ IN, CMPI } },
	{ "lea",	{ IN, LEA } },
	{ "j",		{ IN, J } },
	{ "ret",	{ IN, RET } },
	{ "reti",	{ IN, RETI } },
	{ "sext",	{ IN, SEXT } },
	{ "zext",	{ IN, ZEXT } },
	{ "lbs",	{ IN, LBS } },

	{ "addl",	{ IN, ADDL } },
	{ "subl",	{ IN, SUBL } },
	{ "andl",	{ IN, ANDL } },
	{ "orl",	{ IN, ORL } },
	{ "xorl",	{ IN, XORL } },
	{ "andnl",	{ IN, ANDNL } },
	{ "movl",	{ IN, MOVL } },
	{ "cmpl",	{ IN, CMPL } },
	{ "ll",		{ IN, LL } },
	{ "sl",		{ IN, SL } },

	{ "global",	{ IN, GLOBAL } },
	{ "align",	{ IN, ALIGN } },
	{ "byte",	{ IN, BYTE_ } },
	{ "word",	{ IN, WORD_ } },
	{ "bss",	{ IN, BSS } },

	{ "r0",		{ REG, 0 } },
	{ "r1",		{ REG, 1 } },
	{ "r2",		{ REG, 2 } },
	{ "r3",		{ REG, 3 } },
	{ "r4",		{ REG, 4 } },
	{ "r5",		{ REG, 5 } },
	{ "r6",		{ REG, 6 } },
	{ "r7",		{ REG, 7 } },
	{ "r8",		{ REG, 8 } },
	{ "r9",		{ REG, 9 } },
	{ "r10",	{ REG, 10 } },
	{ "r11",	{ REG, 11 } },
	{ "r12",	{ REG, 12 } },
	{ "r13",	{ REG, 13 } },
	{ "r14",	{ REG, 14 } },
	{ "r15",	{ REG, 15 } },
	{ "sp",		{ REG, 13 } },
	{ 0 }
};
 
extern SZ szProgram;
extern int errors;

int error(SZ szError, ...) {
	va_list va;
	char error[BUFSIZ], prefix[BUFSIZ], listing[BUFSIZ];

	++errors;

	va_start(va, szError);
	_vsnprintf(error, sizeof error, szError, va);
	va_end(va);
	error[sizeof(error)-1] = 0;

	if (szCurrentFile) {
		if (line)
			_snprintf(prefix, sizeof prefix, "%s(%d): %s", szCurrentFile, line, error);
		else
			_snprintf(prefix, sizeof prefix, "%s: %s", szCurrentFile, error);
	}
	else
		_snprintf(prefix, sizeof prefix, "%s", error);
	prefix[sizeof(prefix)-1] = 0;

	if (szProgram)
		fprintf(stderr, "%s: ", szProgram);
	fprintf(stderr, "%s\n", prefix);
	fflush(stderr);

	_snprintf(listing, sizeof listing, "# error %s", prefix);
	listing[sizeof(listing)-1] = 0;
	addListingLine(listing);

	return 1;
}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
麻豆国产精品一区二区三区| jizz一区二区| 成人激情免费网站| 欧美日韩中文国产| 日本一区二区三区四区在线视频 | 欧美激情中文不卡| 午夜欧美在线一二页| 成人免费va视频| 欧美一区二区三区不卡| 亚洲人吸女人奶水| 成人一区二区三区视频在线观看| 欧美人伦禁忌dvd放荡欲情| 椎名由奈av一区二区三区| 久久99久久久久| 欧美少妇一区二区| 亚洲视频综合在线| 成人性视频免费网站| 日韩一区二区视频| 日韩国产精品久久久| 欧洲精品一区二区| 亚洲人123区| 97久久精品人人做人人爽| 国产日韩欧美高清在线| 91蜜桃免费观看视频| 久久九九久精品国产免费直播| 免费人成精品欧美精品| 欧美日韩aaaaaa| 亚洲高清视频在线| 在线影院国内精品| 亚洲香肠在线观看| 欧美日韩一级视频| 午夜不卡在线视频| 亚洲精品中文字幕在线观看| 成人黄色小视频| 亚洲欧洲国产专区| 91污片在线观看| 一区二区三区中文字幕电影| 91亚洲资源网| 亚洲一区二区三区四区不卡| 色婷婷激情一区二区三区| 一二三区精品福利视频| 欧美性猛交xxxx黑人交| 亚洲18女电影在线观看| 91精品欧美一区二区三区综合在| 日韩精品三区四区| 精品国产青草久久久久福利| 精品亚洲porn| 国产精品丝袜在线| 91老司机福利 在线| 亚洲综合免费观看高清完整版在线| 欧洲精品一区二区| 久久精品久久综合| 久久久久成人黄色影片| zzijzzij亚洲日本少妇熟睡| 亚洲乱码日产精品bd| 欧美日本在线视频| 国产精品综合视频| 亚洲女人的天堂| 欧美日韩日日夜夜| 韩国av一区二区三区四区| 亚洲国产高清在线观看视频| 色老汉一区二区三区| 日韩精品视频网站| 亚洲国产成人私人影院tom| 色屁屁一区二区| 麻豆久久久久久久| 国产精品盗摄一区二区三区| 欧美日韩国产高清一区二区| 国产在线一区二区综合免费视频| **欧美大码日韩| 日韩一区二区中文字幕| 成人免费看片app下载| 亚洲综合免费观看高清完整版| 欧美tickle裸体挠脚心vk| 99国产精品视频免费观看| 午夜在线成人av| 国产精品伦一区| 91麻豆精品国产91久久久久久| 高清成人在线观看| 天堂在线一区二区| 亚洲色图第一区| 欧美精品一区二区高清在线观看| 色婷婷久久久综合中文字幕 | 精品视频一区 二区 三区| 国产精品18久久久| 亚洲.国产.中文慕字在线| 国产日韩欧美一区二区三区综合| 欧美三级日韩三级| 成人va在线观看| 国产乱淫av一区二区三区| 一区二区三区精品视频| 国产精品久久久久久久久果冻传媒 | 青青青爽久久午夜综合久久午夜| 国产精品国产三级国产aⅴ中文| 欧美一区二区黄| 国产亚洲污的网站| 欧美三级电影一区| 一本一道久久a久久精品| 国产精品1区二区.| 免费在线观看成人| 亚洲国产美女搞黄色| 亚洲天堂免费看| 中文字幕巨乱亚洲| 国产色一区二区| 久久婷婷一区二区三区| 91精品国产综合久久福利| 欧美在线观看一区| 在线免费一区三区| 91行情网站电视在线观看高清版| gogo大胆日本视频一区| 国产精品一区二区黑丝| 久久99久久久久久久久久久| 美女视频黄 久久| 免费欧美高清视频| 久久99久久久久| 国内精品久久久久影院薰衣草 | 日韩天堂在线观看| 日韩视频一区在线观看| 欧美一区二区在线观看| 日韩欧美电影一区| 精品国一区二区三区| 日韩一区二区三区电影在线观看| 欧美精品tushy高清| 67194成人在线观看| 日韩三级高清在线| 亚洲精品一区二区三区精华液| 久久久一区二区三区| 国产欧美一区二区三区沐欲| 国产精品美女久久久久久2018 | 久久久无码精品亚洲日韩按摩| 日韩三级视频中文字幕| 久久久午夜精品| 亚洲免费观看高清完整版在线观看熊| 亚洲精品一二三| 午夜天堂影视香蕉久久| 免费不卡在线视频| 国产传媒日韩欧美成人| caoporm超碰国产精品| 在线视频综合导航| 欧美一区二区三区在| 久久精品视频一区| 亚洲欧美激情视频在线观看一区二区三区 | 亚洲精品国产一区二区三区四区在线| 亚洲精品乱码久久久久久| 日韩精品三区四区| 国产激情一区二区三区| 色综合天天狠狠| 日韩欧美精品三级| 国产精品久久久久精k8 | 国产精品传媒在线| 日本伊人精品一区二区三区观看方式| 欧美三区免费完整视频在线观看| 欧美肥妇bbw| 国产精品妹子av| 日韩成人免费电影| 成人免费毛片app| 91精品久久久久久久99蜜桃| 欧美激情一二三区| 天堂蜜桃91精品| 99综合电影在线视频| 日韩一区二区在线播放| 亚洲欧美日韩国产中文在线| 麻豆成人综合网| 色狠狠色噜噜噜综合网| 久久蜜桃一区二区| 日本三级亚洲精品| 一本色道**综合亚洲精品蜜桃冫| 精品欧美一区二区久久| 一区二区三区四区乱视频| 国产一区 二区| 欧美视频在线观看一区| 国产精品每日更新在线播放网址| 日韩**一区毛片| 91国产视频在线观看| 中文字幕高清不卡| 乱中年女人伦av一区二区| 欧美在线free| 亚洲色图清纯唯美| 国产99久久精品| 26uuu亚洲| 天天亚洲美女在线视频| 色综合久久久久综合| 亚洲国产精品二十页| 国内精品自线一区二区三区视频| 欧美电影在线免费观看| 一区二区高清免费观看影视大全 | 国产色一区二区| 激情图区综合网| 日韩欧美在线影院| 日韩激情一区二区| 欧美视频一区二区三区在线观看 | 国产三级精品视频| 国产一区二区主播在线| 91麻豆精品国产91久久久| 亚洲午夜久久久久久久久久久 | 亚洲丝袜美腿综合| 97se亚洲国产综合自在线观| 国产精品国产a| 99精品欧美一区二区三区小说 | 丝袜诱惑亚洲看片|