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

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

?? cave_test_new.c

?? 在cdma2000移動通信系統中使用A-Key實現空中接口部分無線接入的身份驗證和加密密鑰的產生。
?? C
?? 第 1 頁 / 共 3 頁
字號:
#include <stdio.h>
//#include "cave.h" /* see Exhibit 2-2 */
//#include "ecmea.h" /* see Exhibit 2-29 */
/* NAM stored data */

#ifndef CAVE_H
#define CAVE_H
/* external header for CAVE and related procedures */
/* function declarations */
void CAVE( int number_of_rounds,
int *offset_1,
int *offset_2);
void A_Key_Checksum( char A_KEY_DIGITS[20],
char A_KEY_CHECKSUM[6]);
int A_Key_Verify( char A_KEY_DIGITS[26]);
void SSD_Generation( unsigned char RANDSSD[7]);
void SSD_Update(void);
unsigned long Auth_Signature( unsigned char RAND_CHALLENGE[4],
//const 
unsigned char AUTH_DATA[3],
//const 
unsigned char *SSD_AUTH,
//const
 int SAVE_REGISTERS);
void Key_VPM_Generation(void);
void CMEA(unsigned char *msg_buf,  int octet_count);
/* global variable definitions */
#ifdef CAVE_SOURCE_FILE
#define CAVE_GLOBAL
#else
#define CAVE_GLOBAL extern
#endif
/* externally available results */
//CAVE_GLOBAL
unsigned char cmeakey[8];
//CAVE_GLOBAL
unsigned char VPM[65];
//CAVE_GLOBAL
unsigned char SAVED_LFSR[4];
//CAVE_GLOBAL
int SAVED_OFFSET_1;
//CAVE_GLOBAL
int SAVED_OFFSET_2;
//CAVE_GLOBAL
unsigned char SAVED_RAND[4];
//CAVE_GLOBAL
unsigned char SAVED_DATA[3];



/* global constant definitions */
#ifndef CAVE_SOURCE_FILE
//CAVE_GLOBAL
unsigned char CaveTable[256];
//CAVE_GLOBAL
unsigned char ibox[256];
#endif // ifndef CAVE_SOURCE_FILE
#endif // ifndef CAVE_H
/* end of CAVE external header */
/********************************************************************/

/* internal header for CAVE, used by all cryptographic source files */




////////////////////////////////////////////////////////////////////////////////////

////////////////////////////////////////////////////////////////////////////////////


void ECMEA_Secret_Generation(void);
void Non_Financial_Seed_Key_Generation(void);
void Non_Financial_Secret_Generation(void);
void ECMEA(unsigned char *msg_buf,
const int octet_count,
const unsigned char sync[2],
const unsigned int decrypt,
const unsigned int data_type);
#ifndef ECMEA_SOURCE_FILE
//extern
unsigned char ecmea_key[8];
//extern
unsigned char ecmea_nf_key[8];
//extern
unsigned char offset_key[4];
//extern
unsigned char offset_nf_key[4];
//extern
unsigned char seed_nf_key[5];
#endif


////////////////////////////////////////////////////////////////////////////

/////////////////////////////////////////////////////////////////////////////



/////////////////////////////////////////////////////////////////////////////

/////////////////////////////////////////////////////////////////////////////

//#include "cave.h" /* see Exhibit 2-2 */

/* authentication algorithm version (fixed) */
#define AAV 0xC7
#define LOMASK 0x0F
#define HIMASK 0xF0
#define TRUE 1
#define FALSE 0
/* NAM stored data */
//extern
unsigned char ESN[4];
//extern
unsigned char A_key[8];
//extern
unsigned char SSD_A_NEW[8], SSD_A[8];
//extern
unsigned char SSD_B_NEW[8], SSD_B[8];
/* saved outputs */
//CAVE_GLOBAL
unsigned char LFSR[4];
#define LFSR_A LFSR[0]
#define LFSR_B LFSR[1]
#define LFSR_C LFSR[2]
#define LFSR_D LFSR[3]

//CAVE_GLOBAL
unsigned char Register[16];

#define CAVE_SOURCE_FILE


//#include "cavei.h" /* see Exhibit 2-3 */

/********************************************************************/
/* table0 is the 4 lsbs of the array,
table1 is the 4 msbs of the array */
unsigned char CaveTable[256] =
{ 0xd9, 0x23, 0x5f, 0xe6, 0xca, 0x68, 0x97, 0xb0,
0x7b, 0xf2, 0x0c, 0x34, 0x11, 0xa5, 0x8d, 0x4e,
0x0a, 0x46, 0x77, 0x8d, 0x10, 0x9f, 0x5e, 0x62,
0xf1, 0x34, 0xec, 0xa5, 0xc9, 0xb3, 0xd8, 0x2b,
0x59, 0x47, 0xe3, 0xd2, 0xff, 0xae, 0x64, 0xca,
0x15, 0x8b, 0x7d, 0x38, 0x21, 0xbc, 0x96, 0x00,
0x49, 0x56, 0x23, 0x15, 0x97, 0xe4, 0xcb, 0x6f,
0xf2, 0x70, 0x3c, 0x88, 0xba, 0xd1, 0x0d, 0xae,
0xe2, 0x38, 0xba, 0x44, 0x9f, 0x83, 0x5d, 0x1c,
0xde, 0xab, 0xc7, 0x65, 0xf1, 0x76, 0x09, 0x20,
0x86, 0xbd, 0x0a, 0xf1, 0x3c, 0xa7, 0x29, 0x93,
0xcb, 0x45, 0x5f, 0xe8, 0x10, 0x74, 0x62, 0xde,
0xb8, 0x77, 0x80, 0xd1, 0x12, 0x26, 0xac, 0x6d,
0xe9, 0xcf, 0xf3, 0x54, 0x3a, 0x0b, 0x95, 0x4e,
0xb1, 0x30, 0xa4, 0x96, 0xf8, 0x57, 0x49, 0x8e,
0x05, 0x1f, 0x62, 0x7c, 0xc3, 0x2b, 0xda, 0xed,
0xbb, 0x86, 0x0d, 0x7a, 0x97, 0x13, 0x6c, 0x4e,
0x51, 0x30, 0xe5, 0xf2, 0x2f, 0xd8, 0xc4, 0xa9,
0x91, 0x76, 0xf0, 0x17, 0x43, 0x38, 0x29, 0x84,
0xa2, 0xdb, 0xef, 0x65, 0x5e, 0xca, 0x0d, 0xbc,
0xe7, 0xfa, 0xd8, 0x81, 0x6f, 0x00, 0x14, 0x42,
0x25, 0x7c, 0x5d, 0xc9, 0x9e, 0xb6, 0x33, 0xab,
0x5a, 0x6f, 0x9b, 0xd9, 0xfe, 0x71, 0x44, 0xc5,
0x37, 0xa2, 0x88, 0x2d, 0x00, 0xb6, 0x13, 0xec,
0x4e, 0x96, 0xa8, 0x5a, 0xb5, 0xd7, 0xc3, 0x8d,
0x3f, 0xf2, 0xec, 0x04, 0x60, 0x71, 0x1b, 0x29,
0x04, 0x79, 0xe3, 0xc7, 0x1b, 0x66, 0x81, 0x4a,
0x25, 0x9d, 0xdc, 0x5f, 0x3e, 0xb0, 0xf8, 0xa2,
0x91, 0x34, 0xf6, 0x5c, 0x67, 0x89, 0x73, 0x05,
0x22, 0xaa, 0xcb, 0xee, 0xbf, 0x18, 0xd0, 0x4d,
0xf5, 0x36, 0xae, 0x01, 0x2f, 0x94, 0xc3, 0x49,
0x8b, 0xbd, 0x58, 0x12, 0xe0, 0x77, 0x6c, 0xda };

unsigned char ibox[256] =
{ 0xdd, 0xf3, 0xf7, 0x90, 0x0b, 0xf5, 0x1a, 0x48,
0x20, 0x3c, 0x84, 0x04, 0x19, 0x16, 0x22, 0x47,
0x6d, 0xa8, 0x8e, 0xc8, 0x9f, 0x8d, 0x0d, 0xb5,
0xc2, 0x0c, 0x06, 0x2f, 0x43, 0x60, 0xf0, 0xa4,
0x08, 0x99, 0x0e, 0x36, 0x98, 0x3d, 0x2e, 0x81,
0xcb, 0xab, 0x5c, 0xd5, 0x3f, 0xee, 0x26, 0x1b,
0x94, 0xd9, 0xfc, 0x68, 0xde, 0xcd, 0x23, 0xed,
0x96, 0xc5, 0xdc, 0x45, 0x09, 0x25, 0x4f, 0x2c,
0x62, 0x53, 0xbf, 0x1c, 0x95, 0x3b, 0x89, 0x0f,
0x07, 0x56, 0x7f, 0xbd, 0xaa, 0xb7, 0xff, 0x3e,
0x86, 0x77, 0x54, 0x41, 0x52, 0xd4, 0x49, 0xb8,
0xc7, 0x9e, 0x82, 0x71, 0x2a, 0xd0, 0x78, 0x9c,
0x1d, 0x6a, 0x40, 0xae, 0xf4, 0xaf, 0xf2, 0xe9,
0x33, 0x80, 0x61, 0xb4, 0xc0, 0x10, 0xa7, 0xbb,
0xb6, 0x5b, 0x73, 0x72, 0x79, 0x7c, 0x8c, 0x51,
0x5e, 0x74, 0xfb, 0xe6, 0x75, 0xd6, 0xef, 0x4a,
0x69, 0x27, 0x5a, 0xb3, 0x0a, 0xe8, 0x50, 0xa0,
0xca, 0x46, 0xc3, 0xea, 0x76, 0x15, 0x12, 0xc6,
0x03, 0x97, 0xa3, 0xd1, 0x30, 0x44, 0x38, 0x91,
0x24, 0x21, 0xc1, 0xdb, 0x5f, 0xe3, 0x59, 0x14,
0x87, 0xa2, 0xa1, 0x92, 0x1f, 0xe2, 0xbc, 0x6e,
0x11, 0xbe, 0x4c, 0x29, 0xe4, 0xc9, 0x63, 0x65,
0xcc, 0xfa, 0xf1, 0x83, 0x6b, 0x17, 0x70, 0x4d,
0x57, 0xd3, 0xfe, 0x6f, 0xa6, 0x4b, 0xa9, 0x42,
0x6c, 0x9a, 0x18, 0x8a, 0xd2, 0x39, 0x8f, 0x58,
0x13, 0xad, 0x88, 0x28, 0xb0, 0x35, 0xd7, 0xe1,
0x5d, 0x93, 0xc4, 0xb9, 0x55, 0x2b, 0x7d, 0xce,
0xe0, 0x31, 0xfd, 0x9b, 0x3a, 0x00, 0x34, 0xe5,
0xd8, 0xcf, 0xa5, 0x9d, 0xac, 0xdf, 0x7b, 0xf9,
0x85, 0x67, 0x8b, 0xf6, 0xf8, 0x37, 0x2d, 0x7e,
0x1e, 0xb2, 0x66, 0x01, 0x64, 0x05, 0xeb, 0x02,
0xec, 0xe7, 0xb1, 0x7a, 0x32, 0xda, 0xba, 0x4e };


/* CAVE local functions */
static unsigned char bit_val(const unsigned char octet, const int bit)
{
return((octet << (7 - bit)) & 0x80);
}
static void LFSR_cycle(void)
{
unsigned char temp;
int i;
temp = bit_val(LFSR_B,6);
temp ^= bit_val(LFSR_D,2);
temp ^= bit_val(LFSR_D,1);
temp ^= bit_val(LFSR_D,0);
/* Shift right LFSR, Discard LFSR_D[0] bit */
for (i = 3; i > 0; i--)
{
LFSR[i] >>= 1;
if (LFSR[i-1] & 0x01)
LFSR[i] |= 0x80;
}
LFSR[0] >>= 1;
LFSR_A |= temp;
}

static void Rotate_right_registers(void)
{
unsigned int temp_reg;
int i;
temp_reg = Register[15]; /* save lsb */
for (i = 15; i > 0; i--)
{
Register[i] >>= 1;
if (Register[i-1] & 0x01)
Register[i] |= 0x80;
}
Register[0] >>= 1;
if (temp_reg & 0x01)
Register[0] |= 0x80;
}

void CAVE(const int number_of_rounds,
int *offset_1,
int *offset_2)
{
unsigned char temp_reg0;
unsigned char lowNibble;
unsigned char hiNibble;
unsigned char temp;
int round_index;
int R_index;
int fail_count;
unsigned char T[16];
for (round_index = number_of_rounds - 1;
round_index >= 0;
round_index--)
{
/* save R0 for reuse later */
temp_reg0 = Register[0];
for (R_index = 0; R_index < 16; R_index++)
{
fail_count = 0;
while(1)
{
*offset_1 += (LFSR_A ^ Register[R_index]);
/* will overflow; mask to prevent */
*offset_1 &= 0xff;
lowNibble = CaveTable[*offset_1] & LOMASK;
if (lowNibble == (Register[R_index] & LOMASK))
{
LFSR_cycle();
fail_count++;
if (fail_count == 32)
{
LFSR_D++; /* no carry to LFSR_C */
break;
}
}
else break;
}

fail_count = 0;
while(1)
{
*offset_2 += (LFSR_B ^ Register[R_index]);
/* will overflow; mask to prevent */
*offset_2 &= 0xff;
hiNibble = CaveTable[*offset_2] & HIMASK;
if (hiNibble == (Register[R_index] & HIMASK))
{
LFSR_cycle();
fail_count++;
if (fail_count == 32)
{
LFSR_D++; /* no carry to LFSR_C */
break;
}
}
else
break;
}
temp = lowNibble | hiNibble;
if (R_index == 15)
Register[R_index] = temp_reg0 ^ temp;
else
Register[R_index] = Register[R_index+1] ^ temp;
LFSR_cycle();
}
Rotate_right_registers();
/* shuffle the mixing registers */
for (R_index = 0; R_index < 16; R_index++)
{
temp = CaveTable[16*round_index + R_index] & LOMASK;
T[temp] = Register[R_index];
}
for (R_index = 0; R_index < 16; R_index++)
Register[R_index] = T[R_index];
}
}

/* A_Key_Checksum has the same header as CAVE (see Exhibit 2-4) */
static void mul10(unsigned char i64[8], unsigned int carry)
{
int i;
unsigned int temp;
for (i = 7; i >= 0; i--)
{
temp = ((unsigned int)(i64[i]) * 10) + carry;
i64[i] = temp & 0xFF;
carry = temp >> 8;
}
}

////////////////////////////////////////////////////////////////////////////////////

////////////////////////////////////////////////////////////////////////////////////
static unsigned long Calc_Checksum(const unsigned char A_key[8])
{
int i,offset_1,offset_2;
unsigned long A_key_checksum;
/* see if 32 MSB are zero */
if ((A_key[0] | A_key[1] | A_key[2] | A_key[3]) != 0)
{
/* put 32 MSB into LFSR */
for (i = 0; i < 4; i++)
LFSR[i] = A_key[i];
}
else
{
/* put ESN into LFSR */
for (i = 0; i < 4; i++)
LFSR[i] = ESN[i];
}

/* put A_key into r0-r7 */
for (i = 0; i < 8; i++)
Register[i] = A_key[i];
Register[8] = AAV;
/* put ls 24 bits of A_key into r9-r11 */
for (i = 9; i < 12; i++)
Register[i] = A_key[5+i-9];
/* put ESN into r12-r15 */
for (i = 12; i < 16; i++)
Register[i] = ESN[i-12];
offset_1 = offset_2 = 128;
CAVE(8, &offset_1, &offset_2);


A_key_checksum =
( ((unsigned long)(Register[0] ^ Register[13]) << 16) +
((unsigned long)(Register[1] ^ Register[14]) << 8) +
((unsigned long)(Register[2] ^ Register[15]) )) & 0x3ffff;


////////////////////////////////////////////////////////////////////////////
 printf("A_key_checksum(Calc_Checksum(temp_A_key)的計算結果)=");//后加的
 printf("%x\n",A_key_checksum);//后加的
//////////////////////////////////////////////////////
return (A_key_checksum);
}

////////////////////////////////////////////////////////////////////////////////////

////////////////////////////////////////////////////////////////////////////////////


/* A_KEY_DIGITS contains the ASCII digits in the order to be entered */
void A_Key_Checksum(const char A_KEY_DIGITS[20],char A_KEY_CHECKSUM[6])
{
int i;
unsigned char temp_A_key[8];
unsigned long A_key_checksum;
/* convert digits to 64-bit representation in temp_A_key */
for (i = 0; i < 8; i++)
temp_A_key[i] = 0;
for (i = 0; i < 20; i++)
{
mul10(temp_A_key,(unsigned int)(A_KEY_DIGITS[i] - '0'));
}
A_key_checksum = Calc_Checksum(temp_A_key);
/* convert checksum to decimal digits */
for (i = 0; i < 6; i++)
{
A_KEY_CHECKSUM[5-i] = '0' + (char)(A_key_checksum % 10);
A_key_checksum /= 10;
}
}

////////////////////////////////////////////////////////////////////////////////////

////////////////////////////////////////////////////////////////////////////////////

/* A_Key_Verify has the same header as CAVE (see Exhibit 2-4) */
/* A_KEY_DIGITS contains the ASCII digits in the order entered */
int A_Key_Verify(const char A_KEY_DIGITS[26])
{
int i;
unsigned char temp_A_key[8];
unsigned long entered_checksum;
/* convert first 20 digits to 64-bit representation in temp_A_key */
for (i = 0; i < 8; i++)
temp_A_key[i] = 0;
for (i = 0; i < 20; i++)
{
mul10(temp_A_key,(unsigned int)(A_KEY_DIGITS[i] - '0'));
}
/////以下為后補充的////////////////
////////////////////////////////
printf("A_key=  ");
for(i=0;i<8;i++)
  printf("%3x", temp_A_key[i]);
printf("\n");
 
//////////////////////////////////////
/* convert last 6 digits to entered checksum */
entered_checksum = 0;
for (i = 20; i < 26; i++)
{
entered_checksum = (entered_checksum * 10)
+ (A_KEY_DIGITS[i] - '0');
}
if(Calc_Checksum(temp_A_key) == entered_checksum)
{
for (i = 0; i < 8; i++)
{
A_key[i] = temp_A_key[i];
SSD_A[i] = SSD_B[i] = 0;
}
return TRUE;
}
else
{
return FALSE;
}
}


////////////////////////////////////////////////////////////////////////////////////

////////////////////////////////////////////////////////////////////////////////////


/* SSD_Generation has the same header as CAVE (see Exhibit 2-4) */
void SSD_Generation(const unsigned char RANDSSD[7])
{
int i,offset_1,offset_2;
for (i = 0; i < 4; i++)
{
LFSR[i] = RANDSSD[i+3] ^ A_key[i] ^ A_key[i+4];
}
if ((LFSR[0] | LFSR[1] | LFSR[2] | LFSR[3]) == 0)
{
for (i = 0; i < 4; i++)
LFSR[i] = RANDSSD[i+3];
}
for (i = 0; i < 8; i++)
Register[i] = A_key[i];
Register[8] = AAV;
for (i = 9; i < 12; i++)
Register[i] = RANDSSD[i-9];
for (i = 12; i < 16; i++)
Register[i] = ESN[i-12];
offset_1 = offset_2 = 128;
CAVE(8, &offset_1, &offset_2);
for (i = 0; i < 8; i++)
{
SSD_A_NEW[i] = Register[i];
SSD_B_NEW[i] = Register[i+8];
}
}

/* SSD_Update has the same header as CAVE (see Exhibit 2-4) */

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
色综合中文字幕| 全国精品久久少妇| 成人小视频在线| 国产精品国产三级国产aⅴ中文| 成人免费va视频| 亚洲在线视频一区| 欧美一区二区三区在线看| 精品制服美女丁香| 中文字幕av一区二区三区高| 91女厕偷拍女厕偷拍高清| 亚洲国产精品嫩草影院| 欧美一区二区三区四区久久| 精品亚洲国内自在自线福利| 国产精品网站导航| 欧美午夜精品久久久久久孕妇| 天天综合天天综合色| 久久在线观看免费| 91麻豆免费在线观看| 日本中文字幕不卡| 中文字幕二三区不卡| 欧美在线三级电影| 国产曰批免费观看久久久| 亚洲人成影院在线观看| 欧美精品在线一区二区三区| 国产一区二区三区| 亚洲国产一区二区三区| 欧美第一区第二区| 一本色道久久综合亚洲精品按摩| 美女www一区二区| ㊣最新国产の精品bt伙计久久| 欧美性生活大片视频| 国产一区二区三区视频在线播放 | 欧美精品久久99| 久久99国产精品久久99| 国产精品护士白丝一区av| 欧美久久高跟鞋激| 色综合中文字幕国产| 视频在线在亚洲| 自拍视频在线观看一区二区| 精品精品欲导航| 欧美三级电影在线看| 成人在线视频一区二区| 老司机精品视频线观看86| 一区二区不卡在线播放| 中文幕一区二区三区久久蜜桃| 884aa四虎影成人精品一区| 99国产精品久久| 国产剧情一区二区| 日本成人中文字幕| 一区二区三区蜜桃| 欧美国产日韩一二三区| 精品久久久久久久久久久久久久久久久 | 亚洲码国产岛国毛片在线| 精品少妇一区二区三区在线视频| 91电影在线观看| 99久久综合狠狠综合久久| 国产麻豆精品在线观看| 久久国产尿小便嘘嘘尿| 偷拍亚洲欧洲综合| 亚洲午夜免费福利视频| 亚洲图片另类小说| 国产精品青草久久| 久久综合九色综合欧美就去吻| 91超碰这里只有精品国产| 欧美亚洲综合网| 欧美最猛黑人xxxxx猛交| av在线这里只有精品| 成人精品免费看| 成人免费三级在线| 成人精品鲁一区一区二区| 国产999精品久久久久久| 国产精品一级片| 国产成人av电影| 成人黄色电影在线| 成人av网址在线观看| 99久久国产免费看| 91蜜桃在线观看| 欧美在线一区二区| 欧美日韩一区三区四区| 欧美视频在线一区二区三区 | 欧美精品日韩精品| 777久久久精品| 日韩欧美精品在线| 久久免费偷拍视频| 国产欧美1区2区3区| 国产精品日韩精品欧美在线| 中日韩av电影| 亚洲色图欧洲色图婷婷| 1000部国产精品成人观看| 亚洲激情欧美激情| 亚洲成人综合网站| 日韩精品电影一区亚洲| 蜜桃视频一区二区| 成人精品免费看| 欧美专区日韩专区| 欧美成人乱码一区二区三区| 精品久久国产老人久久综合| 国产精品萝li| 午夜久久久影院| 国产一区91精品张津瑜| 成人福利视频网站| 欧美日韩亚州综合| 精品国产一区二区三区不卡| 中文久久乱码一区二区| 亚洲成人免费av| 极品美女销魂一区二区三区免费| jlzzjlzz欧美大全| 欧美蜜桃一区二区三区| 国产亚洲成aⅴ人片在线观看| 国产精品网站在线观看| 五月婷婷激情综合| 国产成人av资源| 欧美三级日韩三级| 欧美激情综合五月色丁香小说| 一卡二卡三卡日韩欧美| 国产一区在线看| 欧美视频在线观看一区| 久久先锋影音av鲁色资源网| 亚洲美女淫视频| 国产精品自拍av| 欧美另类高清zo欧美| 国产精品高潮呻吟| 久久精品国产澳门| 在线欧美一区二区| 国产亲近乱来精品视频| 日本在线不卡一区| 一本一本大道香蕉久在线精品| 精品国产乱码久久久久久影片| 亚洲狠狠丁香婷婷综合久久久| 理论电影国产精品| 欧美性感一区二区三区| 欧美国产日韩在线观看| 捆绑变态av一区二区三区| 在线精品视频免费播放| 国产精品全国免费观看高清| 另类综合日韩欧美亚洲| 精品视频在线免费看| 中文字幕制服丝袜一区二区三区| 蜜桃精品在线观看| 欧美精品色一区二区三区| 亚洲精品欧美在线| 91在线精品秘密一区二区| 国产婷婷色一区二区三区在线| 日本伊人色综合网| 欧美日韩三级一区| 亚洲日本在线a| 成人av资源下载| 久久久亚洲国产美女国产盗摄| 免费看欧美美女黄的网站| 欧美日韩一区二区三区在线看 | 亚洲午夜视频在线观看| 91香蕉视频污在线| 国产精品久久久久久久久免费樱桃 | 欧美一区二区三区视频免费播放| 亚洲精品国产高清久久伦理二区| 高清国产一区二区| 久久久精品免费网站| 韩国欧美国产一区| 日韩欧美电影在线| 日本少妇一区二区| 91精品视频网| 日本午夜精品视频在线观看| 欧美精品1区2区| 日韩av一区二区三区| 欧美一区二区三区四区在线观看 | 在线观看网站黄不卡| 一区二区三区中文在线观看| 一本大道久久a久久精品综合| 国产精品成人在线观看| 99久久精品久久久久久清纯| 综合激情网...| 欧美亚洲一区三区| 亚洲成人黄色小说| 欧美理论电影在线| 精品在线一区二区| 国产欧美日韩视频在线观看| 成人avav在线| 一区二区三区成人| 欧美高清视频www夜色资源网| 日韩经典一区二区| 欧美精品一区二区三区一线天视频| 精品一区二区三区在线视频| 久久久www免费人成精品| 成人av小说网| 亚洲一级电影视频| 精品国精品国产尤物美女| 国产另类ts人妖一区二区| 专区另类欧美日韩| 欧美在线免费播放| 美国十次综合导航| 国产精品久久久久久久久免费丝袜| 99国产欧美另类久久久精品| 亚洲二区在线视频| 久久免费视频一区| 色94色欧美sute亚洲13| 日韩国产欧美在线观看| 国产亚洲女人久久久久毛片| 91免费看视频| 蜜臀av国产精品久久久久 | 欧美精品一区二区在线观看|