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

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

?? bbparamtype.c

?? IBE是一種非對稱密碼技術
?? C
?? 第 1 頁 / 共 3 頁
字號:
/* Copyright 2005-2006, Voltage Security, all rights reserved.
 */
#include "vibecrypto.h"
#include "environment.h"
#include "base.h"
#include "libctx.h"
#include "paramobj.h"
#include "ibe.h"
#include "ibecache.h"
#include "mpint.h"
#include "errorctx.h"

/* Gets the system parameters out of a parameter object.
 *
 * @param paramObj The object from which the params are to be extracted.
 * @param getInfo The address where the function will deposit the
 * pointer to the info.
 * @return an int, 0 if the function completed successfully or a
 * non-zero error code.
 */
static int VOLT_CALLING_CONV VoltParameterGetBBType1IBEParams VOLT_PROTO_LIST ((
   VtParameterObject object,
   Pointer *getInfo
));

/* Free the data fields of the coordinates of the point, memset
 * everything to 0.
 */
static void VOLT_CALLING_CONV FreePointData VOLT_PROTO_LIST ((
   VoltLibCtx *libCtx,
   VtBBType1IBEPoint *thePoint
));

/* Given a VtBBType1IBEPoint, copy it into the xCoord buffer. This will
 * copy into the xCoord as the prefix byte (y-coordinate bit) and the
 * x-coordinate data.
 * <p>If the point is infinity, error.
 * <p>If the x-coordinate (with extra byte) won't fit in the buffer
 * (bufferSize), error (not BUFFER_TOO_SMALL).
 * <p>If the point has no x-coordinate, place a fake value into xCoord
 * and set fake to 1 (true, yes).
 * <p>If the point copy works, set fake to 0.
 */
static int VOLT_CALLING_CONV CopyPointToXCoord VOLT_PROTO_LIST ((
   VoltLibCtx *libCtx,
   VtBBType1IBEPoint *point,
   unsigned char *xCoord,
   unsigned int bufferSize,
   unsigned int *xCoordLen,
   unsigned int *fake
));

int VtParameterParamBBType1IBEParams (
   VtParameterObject object,
   Pointer info,
   unsigned int flag
   )
{
  int status;
  VoltParameterObject *obj = (VoltParameterObject *)object;
  VtBBType1IBEParamInfo *paramInfo = (VtBBType1IBEParamInfo *)info;
  VOLT_DECLARE_ERROR_TYPE (errorType)
  VOLT_DECLARE_FNCT_LINE (fnctLine)

  do
  {
    if (flag == VOLT_PARAM_GET_TYPE_FLAG)
    {
      VOLT_SET_ERROR_TYPE (errorType, 0)
      VOLT_SET_FNCT_LINE (fnctLine)
      status = VoltParameterGetBBType1IBEParams (object, (Pointer *)info);
      break;
    }

    /* Check the flag, it should be VOLT_PARAM_SET_TYPE_FLAG.
     */
    VOLT_SET_ERROR_TYPE (errorType, VT_ERROR_TYPE_PRIMARY)
    VOLT_SET_FNCT_LINE (fnctLine)
    status = VT_ERROR_INVALID_TYPE;
    if (flag != VOLT_PARAM_SET_TYPE_FLAG)
      break;

    /* Check the paramData of the object. It should be empty.
     */
    VOLT_SET_FNCT_LINE (fnctLine)
    status = VT_ERROR_INVALID_SET;
    if (obj->paramData != (Pointer)0)
      break;

    /* The associated info should be a pointer to VtBBType1IBEParamInfo.
     */
    VOLT_SET_FNCT_LINE (fnctLine)
    status = VT_ERROR_INVALID_ASSOCIATED_INFO;
    if (info == (Pointer)0)
      break;

    /* If using this ParameterParam, the object must already have an
     * mpCtx loaded.
     */
    VOLT_SET_FNCT_LINE (fnctLine)
    status = VT_ERROR_INVALID_PARAM_OBJ;
    if (obj->mpCtx == (VoltMpIntCtx *)0)
      break;

    /* The Set function will check the params.
     */
    VOLT_SET_FNCT_LINE (fnctLine)
    status = VoltSetBBParams ((VtParameterObject)obj, paramInfo);

  } while (0);

  /* If everything worked, return 0.
   */
  if (status == 0)
    return (0);

  /* If something went wrong, indicate that this object is not usable.
   */
  obj->paramType = 0;

  VOLT_LOG_ERROR_INFO (
    0, object, status, 0, errorType,
    (char *)0, "VtParameterParamBBType1IBEParams", fnctLine, (char *)0)

  return (status);
}

int VoltParameterGetBBType1IBEParams (
   VtParameterObject object,
   Pointer *getInfo
   )
{
  int status;
  VoltParameterObject *obj = (VoltParameterObject *)object;
  VOLT_DECLARE_ERROR_TYPE (errorType)
  VOLT_DECLARE_FNCT_LINE (fnctLine)

  do
  {
    /* Check the paramType in the object, it should contain
     * VOLT_PARAM_TYPE_PARAMS and VOLT_PARAM_ALG_BB_TYPE_1.
     */
    VOLT_SET_ERROR_TYPE (errorType, VT_ERROR_TYPE_PRIMARY)
    VOLT_SET_FNCT_LINE (fnctLine)
    status = VT_ERROR_GET_INFO_UNAVAILABLE;
    if (obj->paramType == 0)
      break;

    VOLT_SET_FNCT_LINE (fnctLine)
    if ((obj->paramType & VOLT_PARAM_TYPE_MASK_ALG) !=
        VOLT_PARAM_ALG_BB_TYPE_1)
      break;
    if ((obj->paramType & VOLT_PARAM_TYPE_PARAMS) == 0)
      break;

    /* Are the parameters in data format? If so, we're done. (Set the
     * return values.)
     */
    *getInfo = obj->paramData;
    status = 0;
    if ((obj->paramType & VOLT_PARAM_TYPE_MASK_DATA) == VOLT_PARAM_TYPE_DATA)
      break;

    /* The data is not available, does the object have a GetData
     * function?
     */
    VOLT_SET_FNCT_LINE (fnctLine)
    *getInfo = (Pointer)0;
    status = VT_ERROR_INVALID_GET;
    if (obj->GetParamData == (VGetParamData)0)
      break;

    /* Call the Get function.
     */
    VOLT_SET_ERROR_TYPE (errorType, 0)
    VOLT_SET_FNCT_LINE (fnctLine)
    status = obj->GetParamData ((VtParameterObject)obj, getInfo);

  } while (0);

  VOLT_LOG_ERROR_INFO_COMPARE (
    status, 0, object, status, 0, errorType,
    (char *)0, "VoltParameterGetBBType1IBEParams", fnctLine, (char *)0)

  return (status);
}

int VoltSetBBParams (
   VtParameterObject paramObj,
   VtBBType1IBEParamInfo *paramInfo
   )
{
  int status;
  unsigned int bufferSize, offset;
  VoltParameterObject *obj = (VoltParameterObject *)paramObj;
  VoltLibCtx *libCtx = (VoltLibCtx *)(obj->voltObject.libraryCtx);
  unsigned char *buffer = (unsigned char *)0;
  VoltBBType1IBEParams *theParams;
  VtBBType1IBEParamInfo newParamInfo;
  VOLT_DECLARE_ERROR_TYPE (errorType)
  VOLT_DECLARE_FNCT_LINE (fnctLine)

  Z2Memset (&newParamInfo, 0, sizeof (newParamInfo));

  do
  {
    /* Copy each of the points.
     */
    VOLT_SET_ERROR_TYPE (errorType, 0)
    VOLT_SET_FNCT_LINE (fnctLine)
    status = VoltBBCopyPoint (
      libCtx, obj->mpCtx, paramInfo, &(paramInfo->basePointG),
      &(newParamInfo.basePointG));
    if (status != 0)
      break;

    VOLT_SET_FNCT_LINE (fnctLine)
    status = VoltBBCopyPoint (
      libCtx, obj->mpCtx, paramInfo, &(paramInfo->pubPointAlpha),
      &(newParamInfo.pubPointAlpha));
    if (status != 0)
      break;

    VOLT_SET_FNCT_LINE (fnctLine)
    status = VoltBBCopyPoint (
      libCtx, obj->mpCtx, paramInfo, &(paramInfo->pubPointBeta),
      &(newParamInfo.pubPointBeta));
    if (status != 0)
      break;

    VOLT_SET_FNCT_LINE (fnctLine)
    status = VoltBBCopyPoint (
      libCtx, obj->mpCtx, paramInfo, &(paramInfo->pubPointGamma),
      &(newParamInfo.pubPointGamma));
    if (status != 0)
      break;

    /* Copy references to the prime and subprime.
     */
    newParamInfo.primeP.data = paramInfo->primeP.data;
    newParamInfo.primeP.len = paramInfo->primeP.len;
    newParamInfo.subprimeQ.data = paramInfo->subprimeQ.data;
    newParamInfo.subprimeQ.len = paramInfo->subprimeQ.len;

    /* Allocate space to hold the param struct, the prime, subprime,
     * base point and pub points. After the struct, all the data is byte
     * arrays, so there's no need to worry about alignment.
     */
    VOLT_SET_ERROR_TYPE (errorType, VT_ERROR_TYPE_PRIMARY)
    VOLT_SET_FNCT_LINE (fnctLine)
    status = VT_ERROR_MEMORY;
    bufferSize =
      sizeof (VoltBBType1IBEParams) + newParamInfo.primeP.len +
      newParamInfo.subprimeQ.len +
      newParamInfo.basePointG.xCoord.len +
      newParamInfo.basePointG.yCoord.len +
      newParamInfo.pubPointAlpha.xCoord.len +
      newParamInfo.pubPointAlpha.yCoord.len +
      newParamInfo.pubPointBeta.xCoord.len +
      newParamInfo.pubPointBeta.yCoord.len +
      newParamInfo.pubPointGamma.xCoord.len +
      newParamInfo.pubPointGamma.yCoord.len;
    buffer = (unsigned char *)Z2Malloc (bufferSize, VOLT_MEMORY_SENSITIVE);
    if (buffer == (unsigned char *)0)
      break;
    Z2Memset (buffer, 0, bufferSize);

    /* Locate the structs and data.
     */
    theParams = (VoltBBType1IBEParams *)buffer;
    offset = sizeof (VoltBBType1IBEParams);
    theParams->paramInfo.primeP.data = buffer + offset;
    offset += newParamInfo.primeP.len;
    theParams->paramInfo.subprimeQ.data = buffer + offset;
    offset += newParamInfo.subprimeQ.len;
    theParams->paramInfo.basePointG.xCoord.data =  buffer + offset;
    offset += newParamInfo.basePointG.xCoord.len;
    theParams->paramInfo.basePointG.yCoord.data =  buffer + offset;
    offset += newParamInfo.basePointG.yCoord.len;
    theParams->paramInfo.pubPointAlpha.xCoord.data = buffer + offset;
    offset += newParamInfo.pubPointAlpha.xCoord.len;
    theParams->paramInfo.pubPointAlpha.yCoord.data = buffer + offset;
    offset += newParamInfo.pubPointAlpha.yCoord.len;
    theParams->paramInfo.pubPointBeta.xCoord.data = buffer + offset;
    offset += newParamInfo.pubPointBeta.xCoord.len;
    theParams->paramInfo.pubPointBeta.yCoord.data = buffer + offset;
    offset += newParamInfo.pubPointBeta.yCoord.len;
    theParams->paramInfo.pubPointGamma.xCoord.data = buffer + offset;
    offset += newParamInfo.pubPointGamma.xCoord.len;
    theParams->paramInfo.pubPointGamma.yCoord.data = buffer + offset;
    offset += newParamInfo.pubPointGamma.yCoord.len;

    /* Fill in fields and copy data.
     */
    Z2Memcpy (
      theParams->paramInfo.primeP.data, newParamInfo.primeP.data,
      newParamInfo.primeP.len);
    theParams->paramInfo.primeP.len = newParamInfo.primeP.len;

    Z2Memcpy (
      theParams->paramInfo.subprimeQ.data, newParamInfo.subprimeQ.data,
      newParamInfo.subprimeQ.len);
    theParams->paramInfo.subprimeQ.len = newParamInfo.subprimeQ.len;

    theParams->paramInfo.basePointG.isInfinity =
      newParamInfo.basePointG.isInfinity;

    Z2Memcpy (
      theParams->paramInfo.basePointG.xCoord.data,
      newParamInfo.basePointG.xCoord.data,
      newParamInfo.basePointG.xCoord.len);
    theParams->paramInfo.basePointG.xCoord.len =
      newParamInfo.basePointG.xCoord.len;

    Z2Memcpy (
      theParams->paramInfo.basePointG.yCoord.data,
      newParamInfo.basePointG.yCoord.data,
      newParamInfo.basePointG.yCoord.len);
    theParams->paramInfo.basePointG.yCoord.len =
      newParamInfo.basePointG.yCoord.len;

    theParams->paramInfo.pubPointAlpha.isInfinity =
      newParamInfo.pubPointAlpha.isInfinity;

    Z2Memcpy (
      theParams->paramInfo.pubPointAlpha.xCoord.data,
      newParamInfo.pubPointAlpha.xCoord.data,
      newParamInfo.pubPointAlpha.xCoord.len);
    theParams->paramInfo.pubPointAlpha.xCoord.len =
      newParamInfo.pubPointAlpha.xCoord.len;

    Z2Memcpy (
      theParams->paramInfo.pubPointAlpha.yCoord.data,
      newParamInfo.pubPointAlpha.yCoord.data,
      newParamInfo.pubPointAlpha.yCoord.len);
    theParams->paramInfo.pubPointAlpha.yCoord.len =
      newParamInfo.pubPointAlpha.yCoord.len;

    theParams->paramInfo.pubPointBeta.isInfinity =
      newParamInfo.pubPointBeta.isInfinity;

    Z2Memcpy (
      theParams->paramInfo.pubPointBeta.xCoord.data,
      newParamInfo.pubPointBeta.xCoord.data,
      newParamInfo.pubPointBeta.xCoord.len);
    theParams->paramInfo.pubPointBeta.xCoord.len =
      newParamInfo.pubPointBeta.xCoord.len;

    Z2Memcpy (
      theParams->paramInfo.pubPointBeta.yCoord.data,
      newParamInfo.pubPointBeta.yCoord.data,
      newParamInfo.pubPointBeta.yCoord.len);
    theParams->paramInfo.pubPointBeta.yCoord.len =
      newParamInfo.pubPointBeta.yCoord.len;

    theParams->paramInfo.pubPointGamma.isInfinity =
      newParamInfo.pubPointGamma.isInfinity;

    Z2Memcpy (
      theParams->paramInfo.pubPointGamma.xCoord.data,
      newParamInfo.pubPointGamma.xCoord.data,
      newParamInfo.pubPointGamma.xCoord.len);
    theParams->paramInfo.pubPointGamma.xCoord.len =
      newParamInfo.pubPointGamma.xCoord.len;

    Z2Memcpy (
      theParams->paramInfo.pubPointGamma.yCoord.data,
      newParamInfo.pubPointGamma.yCoord.data,
      newParamInfo.pubPointGamma.yCoord.len);
    theParams->paramInfo.pubPointGamma.yCoord.len =
      newParamInfo.pubPointGamma.yCoord.len;

    /* Set these values "early" so we have the destructor in place if
     * something goes wrong.
     */
    obj->paramType =
      VOLT_PARAM_ALG_BB_TYPE_1 | VOLT_PARAM_TYPE_PARAMS |
      VOLT_PARAM_TYPE_CONTENTS | VOLT_PARAM_TYPE_DATA;
    obj->paramData = (Pointer)theParams;
    obj->CopyParams = BBType1IBECopyParams;
    obj->ParamDataDestroy = BBType1IBEParamDataDestroy;

    /* Now get the bbCtx.
     */
    VOLT_SET_ERROR_TYPE (errorType, 0)
    VOLT_SET_FNCT_LINE (fnctLine)
    status = VoltGetBbCtxFromIBEParams (
      libCtx, (VtMpIntCtx)(obj->mpCtx), &(theParams->paramInfo),
      0, (unsigned char *)0,  (unsigned char *)0,  (unsigned char *)0,
      &(theParams->bbCtx));

  } while (0);

  FreePointData (libCtx, &(newParamInfo.basePointG));
  FreePointData (libCtx, &(newParamInfo.pubPointAlpha));
  FreePointData (libCtx, &(newParamInfo.pubPointBeta));
  FreePointData (libCtx, &(newParamInfo.pubPointGamma));

  /* If everything worked, return 0.
   */
  if (status == 0)
    return (0);

  /* If something went wrong indicate that this object is not usable.
   */
  obj->paramType = 0;

  VOLT_LOG_ERROR_INFO (
    0, paramObj, status, 0, errorType,
    (char *)0, "VoltSetBBParams", fnctLine, (char *)0)

  return (status);
}

int VoltBBCopyPoint (
   VoltLibCtx *libCtx,
   VoltMpIntCtx *mpCtx,
   VtBBType1IBEParamInfo *paramInfo,
   VtBBType1IBEPoint *oldPoint,
   VtBBType1IBEPoint *newPoint
   )
{
  int status;
  unsigned int primeLen, theXLen;
  unsigned char *theX;
  VOLT_DECLARE_ERROR_TYPE (errorType)
  VOLT_DECLARE_FNCT_LINE (fnctLine)

  do
  {
    primeLen = paramInfo->primeP.len;

    /* Because the x-coordinate might contain an extra byte, copy the
     * pointer to a variable we can adjust.
     */
    theX = oldPoint->xCoord.data;
    theXLen = oldPoint->xCoord.len;

    /* This function rejects infinity.
     */
    VOLT_SET_ERROR_TYPE (errorType, VT_ERROR_TYPE_PRIMARY)
    VOLT_SET_FNCT_LINE (fnctLine)
    status = VT_ERROR_INVALID_ASSOCIATED_INFO;
    if (oldPoint->isInfinity != 0)
      break;

    /* Allocate space to hold the computed or copied x and y.
     */
    VOLT_SET_FNCT_LINE (fnctLine)
    status = VT_ERROR_MEMORY;
    newPoint->yCoord.data = (unsigned char *)Z2Malloc (
      primeLen, VOLT_MEMORY_SENSITIVE);
    if (newPoint->yCoord.data == (unsigned char *)0)
      break;

    VOLT_SET_FNCT_LINE (fnctLine)
    newPoint->xCoord.data = (unsigned char *)Z2Malloc (
      primeLen, VOLT_MEMORY_SENSITIVE);
    if (newPoint->xCoord.data == (unsigned char *)0)
      break;

    /* If there is no y-coordinate, compute it.
     */
    if (oldPoint->yCoord.data == (unsigned char *)0)
    {
      /* We can't compute y without the x. And it must be in the
       * appropriate format.
       */
      VOLT_SET_FNCT_LINE (fnctLine)

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
99re视频这里只有精品| 日韩在线观看一区二区| 日韩欧美中文字幕公布| 欧美激情艳妇裸体舞| 天涯成人国产亚洲精品一区av| 国产酒店精品激情| 欧美日韩免费视频| 综合久久久久久| 丰满岳乱妇一区二区三区| 91精品国产综合久久久久久久久久| 亚洲图片激情小说| 国产激情视频一区二区在线观看 | 在线免费av一区| 久久精品亚洲一区二区三区浴池| 日韩成人午夜电影| 欧美午夜精品一区| 亚洲精品免费看| 波多野结衣中文字幕一区| 精品福利视频一区二区三区| 性做久久久久久久免费看| av在线不卡电影| 国产精品乱人伦中文| 国产高清在线观看免费不卡| 欧美成人国产一区二区| 麻豆91在线观看| 欧美另类变人与禽xxxxx| 一区二区三区自拍| 92精品国产成人观看免费 | 国产精品亚洲а∨天堂免在线| 9191成人精品久久| 亚洲国产精品一区二区久久| aaa亚洲精品| 日本一区二区三区四区在线视频| 黄页网站大全一区二区| 日韩一级完整毛片| 麻豆成人在线观看| xf在线a精品一区二区视频网站| 久久99久久久久久久久久久| 精品久久久久久无| 久久精品国产一区二区三区免费看 | 国产二区国产一区在线观看| 久久久久久久久久久久久久久99| 国产一区二区免费视频| 国产午夜精品久久久久久久| 欧美天天综合网| 成人a免费在线看| 91成人免费在线| 午夜久久福利影院| 制服.丝袜.亚洲.另类.中文| 精品午夜久久福利影院| 精品国产露脸精彩对白| 国产精品一区二区三区网站| 国产精品少妇自拍| 欧美亚洲一区三区| 日本不卡视频一二三区| 久久久91精品国产一区二区精品| 99精品视频中文字幕| 亚洲一级不卡视频| 久久综合九色综合欧美98| 懂色av一区二区夜夜嗨| 国产精品久久免费看| 欧美日韩国产综合一区二区| 久久超碰97中文字幕| 国产精品天美传媒| 欧美日韩dvd在线观看| 久久国产精品免费| 亚洲欧美福利一区二区| 精品久久久久99| 色综合色综合色综合色综合色综合| 亚洲18影院在线观看| 国产色产综合产在线视频| 欧美在线观看一区| 国内不卡的二区三区中文字幕| 亚洲三级在线免费观看| 欧美电影免费观看高清完整版在线观看| 国产美女av一区二区三区| 亚洲自拍偷拍网站| 2020国产成人综合网| 色狠狠色狠狠综合| 国产成人精品免费看| 亚洲第一在线综合网站| 国产丝袜美腿一区二区三区| 欧美福利一区二区| 成人免费不卡视频| 久久精品av麻豆的观看方式| 一区二区三区免费看视频| 久久精品网站免费观看| 欧美巨大另类极品videosbest| 成人国产在线观看| 国产主播一区二区| 日韩一区精品字幕| 一区二区三区欧美视频| 国产精品久久久久久一区二区三区| 日韩精品自拍偷拍| 色94色欧美sute亚洲13| 波多野结衣一区二区三区| 韩国成人在线视频| 男人的天堂亚洲一区| 日韩精品福利网| 亚洲美女偷拍久久| 国产精品精品国产色婷婷| 国产视频一区二区在线观看| 欧美一区二区三区影视| 色域天天综合网| 岛国av在线一区| 国产乱码精品一区二区三区忘忧草| 秋霞电影一区二区| 亚洲高清视频中文字幕| 一区二区国产盗摄色噜噜| 亚洲激情自拍偷拍| 一区二区国产视频| 亚洲精品成人精品456| 一区二区免费在线播放| 亚洲六月丁香色婷婷综合久久| 一色屋精品亚洲香蕉网站| 亚洲欧美在线高清| 亚洲女同ⅹxx女同tv| 亚洲欧美电影院| 亚洲专区一二三| 亚洲v精品v日韩v欧美v专区| 午夜私人影院久久久久| 调教+趴+乳夹+国产+精品| 日韩**一区毛片| 欧亚洲嫩模精品一区三区| 欧美日韩国产一级片| 在线成人av网站| 亚洲私人黄色宅男| 欧美猛男男办公室激情| 在线观看91av| 久久综合给合久久狠狠狠97色69| 久久日韩粉嫩一区二区三区| 国产日韩欧美一区二区三区乱码| 国产精品三级电影| 亚洲激情网站免费观看| 亚洲国产乱码最新视频 | 激情六月婷婷久久| 成人久久视频在线观看| 一本到不卡免费一区二区| 欧美在线免费观看亚洲| 日韩女优av电影在线观看| 国产欧美一区二区三区鸳鸯浴| 国产精品私人影院| 亚洲国产精品久久不卡毛片 | 日韩一区二区免费在线观看| www一区二区| 亚洲美女视频在线| 日韩高清在线观看| 在线观看国产91| 欧美aaaaaa午夜精品| 成人理论电影网| 欧美猛男超大videosgay| 欧美精品一区二区三区久久久| 欧美高清在线精品一区| 亚洲综合视频在线| 久久国产精品72免费观看| 99精品黄色片免费大全| 欧美老年两性高潮| 国产精品初高中害羞小美女文| 亚洲va欧美va人人爽| 国产麻豆日韩欧美久久| 在线中文字幕不卡| 26uuuu精品一区二区| 亚洲v日本v欧美v久久精品| 国产福利电影一区二区三区| 色哟哟精品一区| 久久精品人人做人人综合 | 国产亚洲婷婷免费| 亚洲成人激情av| 成人av一区二区三区| 欧美v国产在线一区二区三区| 一区二区三区加勒比av| 国产成人午夜电影网| 91精品久久久久久蜜臀| 中文字幕字幕中文在线中不卡视频| 麻豆精品视频在线观看免费 | 精品成人一区二区三区四区| 亚洲香蕉伊在人在线观| 国产成人aaa| 欧美xfplay| 日韩中文字幕区一区有砖一区| 99久久国产综合精品女不卡| 久久久久久久久久看片| 久久精品久久精品| 91精品婷婷国产综合久久性色| 亚洲最大成人网4388xx| 成人黄色大片在线观看| 欧美国产精品一区二区| 国产毛片精品视频| 久久只精品国产| 国产一区在线不卡| 日韩小视频在线观看专区| 图片区小说区国产精品视频| 欧美在线观看一二区| 一区二区三区加勒比av| 在线中文字幕一区| 亚洲午夜一区二区| 欧美三级在线看| 午夜电影久久久| 日韩一区二区三区在线视频| 日韩中文字幕区一区有砖一区|