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

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

?? pxa2xx_lcd.c

?? QEMU 0.91 source code, supports ARM processor including S3C24xx series
?? C
?? 第 1 頁 / 共 2 頁
字號:
/* * Intel XScale PXA255/270 LCDC emulation. * * Copyright (c) 2006 Openedhand Ltd. * Written by Andrzej Zaborowski <balrog@zabor.org> * * This code is licensed under the GPLv2. */#include "hw.h"#include "console.h"#include "pxa.h"#include "pixel_ops.h"/* FIXME: For graphic_rotate. Should probably be done in common code.  */#include "sysemu.h"typedef void (*drawfn)(uint32_t *, uint8_t *, const uint8_t *, int, int);struct pxa2xx_lcdc_s {    target_phys_addr_t base;    qemu_irq irq;    int irqlevel;    int invalidated;    DisplayState *ds;    drawfn *line_fn[2];    int dest_width;    int xres, yres;    int pal_for;    int transp;    enum {        pxa_lcdc_2bpp = 1,        pxa_lcdc_4bpp = 2,        pxa_lcdc_8bpp = 3,        pxa_lcdc_16bpp = 4,        pxa_lcdc_18bpp = 5,        pxa_lcdc_18pbpp = 6,        pxa_lcdc_19bpp = 7,        pxa_lcdc_19pbpp = 8,        pxa_lcdc_24bpp = 9,        pxa_lcdc_25bpp = 10,    } bpp;    uint32_t control[6];    uint32_t status[2];    uint32_t ovl1c[2];    uint32_t ovl2c[2];    uint32_t ccr;    uint32_t cmdcr;    uint32_t trgbr;    uint32_t tcr;    uint32_t liidr;    uint8_t bscntr;    struct {        target_phys_addr_t branch;        int up;        uint8_t palette[1024];        uint8_t pbuffer[1024];        void (*redraw)(struct pxa2xx_lcdc_s *s, uint8_t *fb,                        int *miny, int *maxy);        target_phys_addr_t descriptor;        target_phys_addr_t source;        uint32_t id;        uint32_t command;    } dma_ch[7];    qemu_irq vsync_cb;    int orientation;};struct __attribute__ ((__packed__)) pxa_frame_descriptor_s {    uint32_t fdaddr;    uint32_t fsaddr;    uint32_t fidr;    uint32_t ldcmd;};#define LCCR0	0x000	/* LCD Controller Control register 0 */#define LCCR1	0x004	/* LCD Controller Control register 1 */#define LCCR2	0x008	/* LCD Controller Control register 2 */#define LCCR3	0x00c	/* LCD Controller Control register 3 */#define LCCR4	0x010	/* LCD Controller Control register 4 */#define LCCR5	0x014	/* LCD Controller Control register 5 */#define FBR0	0x020	/* DMA Channel 0 Frame Branch register */#define FBR1	0x024	/* DMA Channel 1 Frame Branch register */#define FBR2	0x028	/* DMA Channel 2 Frame Branch register */#define FBR3	0x02c	/* DMA Channel 3 Frame Branch register */#define FBR4	0x030	/* DMA Channel 4 Frame Branch register */#define FBR5	0x110	/* DMA Channel 5 Frame Branch register */#define FBR6	0x114	/* DMA Channel 6 Frame Branch register */#define LCSR1	0x034	/* LCD Controller Status register 1 */#define LCSR0	0x038	/* LCD Controller Status register 0 */#define LIIDR	0x03c	/* LCD Controller Interrupt ID register */#define TRGBR	0x040	/* TMED RGB Seed register */#define TCR	0x044	/* TMED Control register */#define OVL1C1	0x050	/* Overlay 1 Control register 1 */#define OVL1C2	0x060	/* Overlay 1 Control register 2 */#define OVL2C1	0x070	/* Overlay 2 Control register 1 */#define OVL2C2	0x080	/* Overlay 2 Control register 2 */#define CCR	0x090	/* Cursor Control register */#define CMDCR	0x100	/* Command Control register */#define PRSR	0x104	/* Panel Read Status register */#define PXA_LCDDMA_CHANS	7#define DMA_FDADR		0x00	/* Frame Descriptor Address register */#define DMA_FSADR		0x04	/* Frame Source Address register */#define DMA_FIDR		0x08	/* Frame ID register */#define DMA_LDCMD		0x0c	/* Command register *//* LCD Buffer Strength Control register */#define BSCNTR	0x04000054/* Bitfield masks */#define LCCR0_ENB	(1 << 0)#define LCCR0_CMS	(1 << 1)#define LCCR0_SDS	(1 << 2)#define LCCR0_LDM	(1 << 3)#define LCCR0_SOFM0	(1 << 4)#define LCCR0_IUM	(1 << 5)#define LCCR0_EOFM0	(1 << 6)#define LCCR0_PAS	(1 << 7)#define LCCR0_DPD	(1 << 9)#define LCCR0_DIS	(1 << 10)#define LCCR0_QDM	(1 << 11)#define LCCR0_PDD	(0xff << 12)#define LCCR0_BSM0	(1 << 20)#define LCCR0_OUM	(1 << 21)#define LCCR0_LCDT	(1 << 22)#define LCCR0_RDSTM	(1 << 23)#define LCCR0_CMDIM	(1 << 24)#define LCCR0_OUC	(1 << 25)#define LCCR0_LDDALT	(1 << 26)#define LCCR1_PPL(x)	((x) & 0x3ff)#define LCCR2_LPP(x)	((x) & 0x3ff)#define LCCR3_API	(15 << 16)#define LCCR3_BPP(x)	((((x) >> 24) & 7) | (((x) >> 26) & 8))#define LCCR3_PDFOR(x)	(((x) >> 30) & 3)#define LCCR4_K1(x)	(((x) >> 0) & 7)#define LCCR4_K2(x)	(((x) >> 3) & 7)#define LCCR4_K3(x)	(((x) >> 6) & 7)#define LCCR4_PALFOR(x)	(((x) >> 15) & 3)#define LCCR5_SOFM(ch)	(1 << (ch - 1))#define LCCR5_EOFM(ch)	(1 << (ch + 7))#define LCCR5_BSM(ch)	(1 << (ch + 15))#define LCCR5_IUM(ch)	(1 << (ch + 23))#define OVLC1_EN	(1 << 31)#define CCR_CEN		(1 << 31)#define FBR_BRA		(1 << 0)#define FBR_BINT	(1 << 1)#define FBR_SRCADDR	(0xfffffff << 4)#define LCSR0_LDD	(1 << 0)#define LCSR0_SOF0	(1 << 1)#define LCSR0_BER	(1 << 2)#define LCSR0_ABC	(1 << 3)#define LCSR0_IU0	(1 << 4)#define LCSR0_IU1	(1 << 5)#define LCSR0_OU	(1 << 6)#define LCSR0_QD	(1 << 7)#define LCSR0_EOF0	(1 << 8)#define LCSR0_BS0	(1 << 9)#define LCSR0_SINT	(1 << 10)#define LCSR0_RDST	(1 << 11)#define LCSR0_CMDINT	(1 << 12)#define LCSR0_BERCH(x)	(((x) & 7) << 28)#define LCSR1_SOF(ch)	(1 << (ch - 1))#define LCSR1_EOF(ch)	(1 << (ch + 7))#define LCSR1_BS(ch)	(1 << (ch + 15))#define LCSR1_IU(ch)	(1 << (ch + 23))#define LDCMD_LENGTH(x)	((x) & 0x001ffffc)#define LDCMD_EOFINT	(1 << 21)#define LDCMD_SOFINT	(1 << 22)#define LDCMD_PAL	(1 << 26)/* Route internal interrupt lines to the global IC */static void pxa2xx_lcdc_int_update(struct pxa2xx_lcdc_s *s){    int level = 0;    level |= (s->status[0] & LCSR0_LDD)    && !(s->control[0] & LCCR0_LDM);    level |= (s->status[0] & LCSR0_SOF0)   && !(s->control[0] & LCCR0_SOFM0);    level |= (s->status[0] & LCSR0_IU0)    && !(s->control[0] & LCCR0_IUM);    level |= (s->status[0] & LCSR0_IU1)    && !(s->control[5] & LCCR5_IUM(1));    level |= (s->status[0] & LCSR0_OU)     && !(s->control[0] & LCCR0_OUM);    level |= (s->status[0] & LCSR0_QD)     && !(s->control[0] & LCCR0_QDM);    level |= (s->status[0] & LCSR0_EOF0)   && !(s->control[0] & LCCR0_EOFM0);    level |= (s->status[0] & LCSR0_BS0)    && !(s->control[0] & LCCR0_BSM0);    level |= (s->status[0] & LCSR0_RDST)   && !(s->control[0] & LCCR0_RDSTM);    level |= (s->status[0] & LCSR0_CMDINT) && !(s->control[0] & LCCR0_CMDIM);    level |= (s->status[1] & ~s->control[5]);    qemu_set_irq(s->irq, !!level);    s->irqlevel = level;}/* Set Branch Status interrupt high and poke associated registers */static inline void pxa2xx_dma_bs_set(struct pxa2xx_lcdc_s *s, int ch){    int unmasked;    if (ch == 0) {        s->status[0] |= LCSR0_BS0;        unmasked = !(s->control[0] & LCCR0_BSM0);    } else {        s->status[1] |= LCSR1_BS(ch);        unmasked = !(s->control[5] & LCCR5_BSM(ch));    }    if (unmasked) {        if (s->irqlevel)            s->status[0] |= LCSR0_SINT;        else            s->liidr = s->dma_ch[ch].id;    }}/* Set Start Of Frame Status interrupt high and poke associated registers */static inline void pxa2xx_dma_sof_set(struct pxa2xx_lcdc_s *s, int ch){    int unmasked;    if (!(s->dma_ch[ch].command & LDCMD_SOFINT))        return;    if (ch == 0) {        s->status[0] |= LCSR0_SOF0;        unmasked = !(s->control[0] & LCCR0_SOFM0);    } else {        s->status[1] |= LCSR1_SOF(ch);        unmasked = !(s->control[5] & LCCR5_SOFM(ch));    }    if (unmasked) {        if (s->irqlevel)            s->status[0] |= LCSR0_SINT;        else            s->liidr = s->dma_ch[ch].id;    }}/* Set End Of Frame Status interrupt high and poke associated registers */static inline void pxa2xx_dma_eof_set(struct pxa2xx_lcdc_s *s, int ch){    int unmasked;    if (!(s->dma_ch[ch].command & LDCMD_EOFINT))        return;    if (ch == 0) {        s->status[0] |= LCSR0_EOF0;        unmasked = !(s->control[0] & LCCR0_EOFM0);    } else {        s->status[1] |= LCSR1_EOF(ch);        unmasked = !(s->control[5] & LCCR5_EOFM(ch));    }    if (unmasked) {        if (s->irqlevel)            s->status[0] |= LCSR0_SINT;        else            s->liidr = s->dma_ch[ch].id;    }}/* Set Bus Error Status interrupt high and poke associated registers */static inline void pxa2xx_dma_ber_set(struct pxa2xx_lcdc_s *s, int ch){    s->status[0] |= LCSR0_BERCH(ch) | LCSR0_BER;    if (s->irqlevel)        s->status[0] |= LCSR0_SINT;    else        s->liidr = s->dma_ch[ch].id;}/* Set Read Status interrupt high and poke associated registers */static inline void pxa2xx_dma_rdst_set(struct pxa2xx_lcdc_s *s){    s->status[0] |= LCSR0_RDST;    if (s->irqlevel && !(s->control[0] & LCCR0_RDSTM))        s->status[0] |= LCSR0_SINT;}/* Load new Frame Descriptors from DMA */static void pxa2xx_descriptor_load(struct pxa2xx_lcdc_s *s){    struct pxa_frame_descriptor_s *desc[PXA_LCDDMA_CHANS];    target_phys_addr_t descptr;    int i;    for (i = 0; i < PXA_LCDDMA_CHANS; i ++) {        desc[i] = 0;        s->dma_ch[i].source = 0;        if (!s->dma_ch[i].up)            continue;        if (s->dma_ch[i].branch & FBR_BRA) {            descptr = s->dma_ch[i].branch & FBR_SRCADDR;            if (s->dma_ch[i].branch & FBR_BINT)                pxa2xx_dma_bs_set(s, i);            s->dma_ch[i].branch &= ~FBR_BRA;        } else            descptr = s->dma_ch[i].descriptor;        if (!(descptr >= PXA2XX_SDRAM_BASE && descptr +                    sizeof(*desc[i]) <= PXA2XX_SDRAM_BASE + phys_ram_size))            continue;        descptr -= PXA2XX_SDRAM_BASE;        desc[i] = (struct pxa_frame_descriptor_s *) (phys_ram_base + descptr);        s->dma_ch[i].descriptor = desc[i]->fdaddr;        s->dma_ch[i].source = desc[i]->fsaddr;        s->dma_ch[i].id = desc[i]->fidr;        s->dma_ch[i].command = desc[i]->ldcmd;    }}static uint32_t pxa2xx_lcdc_read(void *opaque, target_phys_addr_t offset){    struct pxa2xx_lcdc_s *s = (struct pxa2xx_lcdc_s *) opaque;    int ch;    offset -= s->base;    switch (offset) {    case LCCR0:        return s->control[0];    case LCCR1:        return s->control[1];    case LCCR2:        return s->control[2];    case LCCR3:        return s->control[3];    case LCCR4:        return s->control[4];    case LCCR5:        return s->control[5];    case OVL1C1:        return s->ovl1c[0];    case OVL1C2:        return s->ovl1c[1];    case OVL2C1:        return s->ovl2c[0];    case OVL2C2:        return s->ovl2c[1];    case CCR:        return s->ccr;    case CMDCR:        return s->cmdcr;    case TRGBR:        return s->trgbr;    case TCR:        return s->tcr;    case 0x200 ... 0x1000:	/* DMA per-channel registers */        ch = (offset - 0x200) >> 4;        if (!(ch >= 0 && ch < PXA_LCDDMA_CHANS))            goto fail;        switch (offset & 0xf) {        case DMA_FDADR:            return s->dma_ch[ch].descriptor;        case DMA_FSADR:            return s->dma_ch[ch].source;        case DMA_FIDR:            return s->dma_ch[ch].id;        case DMA_LDCMD:            return s->dma_ch[ch].command;        default:            goto fail;        }    case FBR0:        return s->dma_ch[0].branch;    case FBR1:        return s->dma_ch[1].branch;    case FBR2:        return s->dma_ch[2].branch;    case FBR3:        return s->dma_ch[3].branch;    case FBR4:        return s->dma_ch[4].branch;    case FBR5:        return s->dma_ch[5].branch;    case FBR6:        return s->dma_ch[6].branch;    case BSCNTR:        return s->bscntr;    case PRSR:        return 0;    case LCSR0:        return s->status[0];    case LCSR1:        return s->status[1];    case LIIDR:        return s->liidr;    default:    fail:        cpu_abort(cpu_single_env,                "%s: Bad offset " REG_FMT "\n", __FUNCTION__, offset);    }    return 0;}static void pxa2xx_lcdc_write(void *opaque,                target_phys_addr_t offset, uint32_t value){    struct pxa2xx_lcdc_s *s = (struct pxa2xx_lcdc_s *) opaque;    int ch;    offset -= s->base;    switch (offset) {    case LCCR0:        /* ACK Quick Disable done */        if ((s->control[0] & LCCR0_ENB) && !(value & LCCR0_ENB))            s->status[0] |= LCSR0_QD;        if (!(s->control[0] & LCCR0_LCDT) && (value & LCCR0_LCDT))            printf("%s: internal frame buffer unsupported\n", __FUNCTION__);        if ((s->control[3] & LCCR3_API) &&                (value & LCCR0_ENB) && !(value & LCCR0_LCDT))            s->status[0] |= LCSR0_ABC;        s->control[0] = value & 0x07ffffff;        pxa2xx_lcdc_int_update(s);        s->dma_ch[0].up = !!(value & LCCR0_ENB);        s->dma_ch[1].up = (s->ovl1c[0] & OVLC1_EN) || (value & LCCR0_SDS);        break;    case LCCR1:        s->control[1] = value;        break;    case LCCR2:        s->control[2] = value;        break;    case LCCR3:        s->control[3] = value & 0xefffffff;        s->bpp = LCCR3_BPP(value);        break;    case LCCR4:        s->control[4] = value & 0x83ff81ff;        break;    case LCCR5:        s->control[5] = value & 0x3f3f3f3f;        break;    case OVL1C1:        if (!(s->ovl1c[0] & OVLC1_EN) && (value & OVLC1_EN))            printf("%s: Overlay 1 not supported\n", __FUNCTION__);        s->ovl1c[0] = value & 0x80ffffff;        s->dma_ch[1].up = (value & OVLC1_EN) || (s->control[0] & LCCR0_SDS);        break;    case OVL1C2:        s->ovl1c[1] = value & 0x000fffff;        break;    case OVL2C1:        if (!(s->ovl2c[0] & OVLC1_EN) && (value & OVLC1_EN))            printf("%s: Overlay 2 not supported\n", __FUNCTION__);        s->ovl2c[0] = value & 0x80ffffff;        s->dma_ch[2].up = !!(value & OVLC1_EN);        s->dma_ch[3].up = !!(value & OVLC1_EN);        s->dma_ch[4].up = !!(value & OVLC1_EN);        break;    case OVL2C2:        s->ovl2c[1] = value & 0x007fffff;        break;    case CCR:        if (!(s->ccr & CCR_CEN) && (value & CCR_CEN))            printf("%s: Hardware cursor unimplemented\n", __FUNCTION__);        s->ccr = value & 0x81ffffe7;        s->dma_ch[5].up = !!(value & CCR_CEN);        break;    case CMDCR:        s->cmdcr = value & 0xff;        break;    case TRGBR:        s->trgbr = value & 0x00ffffff;        break;    case TCR:        s->tcr = value & 0x7fff;        break;    case 0x200 ... 0x1000:	/* DMA per-channel registers */        ch = (offset - 0x200) >> 4;        if (!(ch >= 0 && ch < PXA_LCDDMA_CHANS))            goto fail;        switch (offset & 0xf) {        case DMA_FDADR:            s->dma_ch[ch].descriptor = value & 0xfffffff0;            break;        default:            goto fail;        }        break;    case FBR0:        s->dma_ch[0].branch = value & 0xfffffff3;        break;

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
在线观看免费亚洲| 色呦呦一区二区三区| 国产精品高潮久久久久无| 91免费国产在线| 国产一区美女在线| 亚洲国产你懂的| 国产精品网站在线观看| 日韩欧美一卡二卡| 一本久道久久综合中文字幕| 国产一区欧美日韩| 日本不卡的三区四区五区| 亚洲天堂成人网| 亚洲国产电影在线观看| 欧美本精品男人aⅴ天堂| 欧美在线一二三| 不卡av在线网| 成人自拍视频在线| 国内外精品视频| 男男gaygay亚洲| 污片在线观看一区二区| 亚洲美女在线一区| 国产精品久久久久久久蜜臀| 欧美xxxx在线观看| 欧美成人一区二区三区片免费| 在线观看视频91| 91丨porny丨中文| 精品一区二区三区香蕉蜜桃 | 狠狠色丁香久久婷婷综合_中| 亚洲欧美国产77777| 国产精品日韩成人| 国产视频在线观看一区二区三区 | 91精品欧美综合在线观看最新| 99久久综合国产精品| 成人午夜看片网址| 国产福利精品一区| 国产成人av一区二区| 国产一区二区在线观看免费 | 色天天综合色天天久久| 成人午夜在线免费| 不卡的av在线播放| 91小宝寻花一区二区三区| 92精品国产成人观看免费| 99久久免费国产| 91亚洲国产成人精品一区二三| 成人精品免费网站| 91免费版在线| 欧美视频一区二区| 欧美日韩国产美女| 日韩视频一区在线观看| 日韩精品一区二区三区三区免费 | 91精品在线一区二区| 制服丝袜一区二区三区| 91麻豆精品国产自产在线观看一区| 欧美精品在线观看一区二区| 56国语精品自产拍在线观看| 91精品国产91久久久久久一区二区| 91麻豆精品国产91久久久资源速度 | 国产亚洲欧美在线| 国产清纯白嫩初高生在线观看91| 欧美激情在线一区二区三区| 亚洲免费av观看| 日韩电影免费一区| 国产精品99久久久久久似苏梦涵| 国产成人免费视频| 在线免费观看日本欧美| 欧美精品在线一区二区| 久久天天做天天爱综合色| 中文字幕精品—区二区四季| 一区二区三区在线影院| 婷婷一区二区三区| 国产成人av电影在线播放| 91女厕偷拍女厕偷拍高清| 欧美日韩国产一二三| 精品国产免费视频| 亚洲图片你懂的| 麻豆国产精品官网| 99久久免费精品| 日韩一区二区在线观看视频| 中日韩免费视频中文字幕| 亚洲亚洲人成综合网络| 国产一本一道久久香蕉| 色悠悠亚洲一区二区| 精品毛片乱码1区2区3区 | 日韩和欧美的一区| 成人小视频在线| 欧美精品高清视频| 欧美韩国日本一区| 美女视频网站黄色亚洲| 色综合久久久久| 久久人人超碰精品| 天涯成人国产亚洲精品一区av| 国产精品18久久久久久久久久久久| 91福利资源站| 欧美国产综合色视频| 全国精品久久少妇| 色婷婷一区二区三区四区| 欧美精品一区二区三区久久久| 一区二区三区日韩欧美精品| 国产乱人伦精品一区二区在线观看| 91福利在线导航| 国产精品美女久久久久久久久| 日韩av不卡在线观看| 色狠狠一区二区三区香蕉| 久久久久久久久久久久久女国产乱| 亚洲最快最全在线视频| 成人听书哪个软件好| 精品国产电影一区二区| 午夜不卡av免费| 91电影在线观看| 欧美高清在线一区二区| 精品在线播放免费| 在线不卡a资源高清| 一区二区三区四区中文字幕| 成人一二三区视频| 精品久久久久久亚洲综合网| 午夜亚洲国产au精品一区二区 | 日韩欧美一级片| 午夜天堂影视香蕉久久| 色8久久精品久久久久久蜜 | 男人操女人的视频在线观看欧美| 欧洲精品在线观看| 亚洲精品视频在线观看网站| 国产福利一区二区三区| 久久影音资源网| 久久精品国产久精国产爱| 欧美色视频在线观看| 亚洲一区二区三区中文字幕 | 午夜精品久久久久久不卡8050| 一本一道久久a久久精品| 中文字幕在线视频一区| 成人国产精品免费观看视频| 国产欧美一区二区精品秋霞影院| 国产一区二区三区最好精华液| 日韩精品一区二区三区中文不卡 | 国产精品一区二区在线播放 | 91香蕉视频在线| 亚洲女子a中天字幕| 99精品视频一区二区| 国产精品欧美综合在线| 波多野结衣中文字幕一区| 国产精品久久久爽爽爽麻豆色哟哟 | 麻豆91在线播放免费| 日韩一区二区精品在线观看| 久久国产三级精品| 精品国产乱子伦一区| 久久国产尿小便嘘嘘尿| 国产午夜精品一区二区三区视频 | 亚洲久本草在线中文字幕| 日本道在线观看一区二区| 亚洲综合激情网| 欧美精品一卡两卡| 久久草av在线| 久久久亚洲欧洲日产国码αv| 国产成人综合亚洲网站| 亚洲欧洲日产国产综合网| 91一区在线观看| 亚洲va韩国va欧美va精品| 日韩免费成人网| 国产成人免费在线| 亚洲激情图片小说视频| 欧美精品 日韩| 国产在线国偷精品免费看| 国产精品欧美久久久久一区二区| 91社区在线播放| 丝袜亚洲另类丝袜在线| 精品剧情v国产在线观看在线| 国产乱一区二区| 亚洲欧美色图小说| 欧美老年两性高潮| 国产精品一二三| 亚洲精品老司机| 日韩一区二区电影网| 视频精品一区二区| 91精品婷婷国产综合久久| wwwwww.欧美系列| av在线不卡免费看| 日韩不卡免费视频| 国产女同性恋一区二区| 欧美色综合网站| 国产精品资源在线| 一区二区三区欧美亚洲| 欧美xxxx老人做受| 欧洲国产伦久久久久久久| 老司机精品视频导航| 国产精品天美传媒| 欧美一级高清片| 91精品办公室少妇高潮对白| 久久精品国产精品亚洲红杏| 日韩理论片一区二区| 精品久久国产老人久久综合| 91黄视频在线观看| 国产精品一二二区| 日本亚洲电影天堂| 亚洲精品va在线观看| 久久久99精品免费观看不卡| 欧美精品日韩一本| 91蜜桃免费观看视频| 国产一区二区电影| 秋霞午夜鲁丝一区二区老狼| 日韩毛片在线免费观看|