日韩av黄I国产麻豆传媒I国产91av视频在线观看I日韩一区二区三区在线看I美女国产在线I麻豆视频国产在线观看I成人黄色短片

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 运维知识 > linux >内容正文

linux

linux 串口驱动(二)初始化 【转】

發(fā)布時間:2025/3/20 linux 58 豆豆
生活随笔 收集整理的這篇文章主要介紹了 linux 串口驱动(二)初始化 【转】 小編覺得挺不錯的,現(xiàn)在分享給大家,幫大家做個參考.

轉(zhuǎn)自:http://blog.chinaunix.net/uid-27717694-id-3493611.html

8250串口的初始化:

(1)定義uart_driver、uart_ops、uart_port等結構體的實例并在適當?shù)牡胤礁呔唧w的硬件驅(qū)動情況初始化他們,當然具體設備xxx的驅(qū)動可以將這些結構體套在新定義的xxx_uart_driver、xxx_uart_ops、xxx_uart_port之內(nèi)。

(2)在模塊初始化調(diào)用uart_register()和uart_add_one_port()以注冊UART驅(qū)動并添加端口,在模塊卸載時調(diào)用uart_unregister_driver()和uart_remove_one_port()以注銷UART驅(qū)動以移除端口。

(3)根據(jù)具體硬件的uart_ops中的成員函數(shù),這些函數(shù)的實現(xiàn)成為UART驅(qū)動的主體工作。
1.串口結構體,他們之間的關系如圖所示:


//(1)串口驅(qū)動結構體
struct uart_driver {??
??? struct module?? *owner; //模塊所有者???
??? const char? *driver_name;?? //驅(qū)動名???
??? const char? *dev_name;? //設備名???
??? int? major; //主設備號???
??? int? minor; //次設備號???
??? int? nr;??? //支持串口個數(shù)???
??? struct console? *cons;//控制臺設備???
??? struct uart_state?? *state; //串口狀態(tài)???
??? struct tty_driver?? *tty_driver; //tty設備???
};?

//(2)串口端口結構體
struct uart_port {??
??? spinlock_t? lock;??
??? unsigned long?? iobase; //io端口基地址???
??? unsigned char __iomem?? *membase; //內(nèi)存端口基地址???
??? unsigned int??? (*serial_in)(struct uart_port *, int); //串口讀函數(shù)?
??? void??? (*serial_out)(struct uart_port *, int, int); //串口寫方法
??? void??? (*set_termios)(struct uart_port *,struct ktermios *new,struct ktermios *old); //串口配置方法函數(shù)
??? void??? (*pm)(struct uart_port *, unsigned int state,unsigned int old);??
??? unsigned int??? irq;??? //中斷號???
??? unsigned long?? irqflags;?? //中斷標志???
??? unsigned int??? uartclk;?? //串口時鐘
??? unsigned int??? fifosize;?? //fifo大小???????
??? unsigned char?? x_char;??
??? unsigned char?? regshift;?? //寄存器偏移值???????
??? unsigned char?? iotype; //io訪問類型???
??? unsigned char?? unused1;??
??? unsigned int??? read_status_mask;??
??? unsigned int??? ignore_status_mask;??
??? struct uart_state?? *state; //uart_state結構體????
??? struct uart_icount? icount; //串口使用計數(shù)???
??? struct console? *cons;? //console控制臺???
#if defined(CONFIG_SERIAL_CORE_CONSOLE) || defined(SUPPORT_SYSRQ)???
??? unsigned long?? sysrq;??
#endif???
??? upf_t?? flags;??
??? unsigned int??? mctrl;??
??? unsigned int??? timeout;??
??? unsigned int??? type; //串口類型?
??? const struct uart_ops?? *ops;?? //串口操作函數(shù)集???
??? unsigned int??? custom_divisor;??
??? unsigned int??? line;?? //端口號???
??? resource_size_t mapbase; //串口寄存器基地址(物理地址)
??? struct device?? *dev;?? //設備文件???
??? unsigned char?? hub6;??
??? unsigned char?? suspended;??
??? unsigned char?? irq_wake;??
??? unsigned char?? unused[2];??
??? void??? *private_data;??
};?

//(3)操作函數(shù)集
struct uart_ops {??
??? unsigned int??? (*tx_empty)(struct uart_port *);??? //發(fā)送緩沖區(qū)為空???
??? void??? (*set_mctrl)(struct uart_port *, unsigned int mctrl);?? //設置串口modem控制模式???
??? unsigned int??? (*get_mctrl)(struct uart_port *);?? //獲取串口modem控制模式???
??? void??? (*stop_tx)(struct uart_port *); //停止發(fā)送???
??? void??? (*start_tx)(struct uart_port *);??? //開始發(fā)送???
??? void??? (*send_xchar)(struct uart_port *, char ch);??
??? void??? (*stop_rx)(struct uart_port *); //停止接收???
??? void??? (*enable_ms)(struct uart_port *);?? //使能modem狀態(tài)信息???
??? void??? (*break_ctl)(struct uart_port *, int ctl);??
??? int (*startup)(struct uart_port *); //打開串口???
??? void??? (*shutdown)(struct uart_port *);??? //關閉串口???
??? void??? (*flush_buffer)(struct uart_port *);??
??? void??? (*set_termios)(struct uart_port *, struct ktermios *new,struct ktermios *old);? //設置串口參數(shù)???
??? void??? (*set_ldisc)(struct uart_port *, int new);??
??? void??? (*pm)(struct uart_port *, unsigned int state,unsigned int oldstate);??
??? int (*set_wake)(struct uart_port *, unsigned int state);??
??? const char *(*type)(struct uart_port *);??
??? void??? (*release_port)(struct uart_port *);??? //釋放端口???
??? int (*request_port)(struct uart_port *);??? //請求端口???
??? void??? (*config_port)(struct uart_port *, int);??? //配置端口???
??? int (*verify_port)(struct uart_port *, struct serial_struct *); //校驗端口???
??? int (*ioctl)(struct uart_port *, unsigned int, unsigned long);? //控制???
#ifdef CONFIG_CONSOLE_POLL???
??? void??? (*poll_put_char)(struct uart_port *, unsigned char);??
??? int (*poll_get_char)(struct uart_port *);??
#endif???
};?


//(4)uart_state
struct uart_state {??
??? struct tty_port port;??
??? int???? pm_state;??
??? struct circ_buf xmit;??
??? struct tasklet_struct?? tlet;??
??? struct uart_port??? *uart_port;//指向?qū)拇诮Y構??
};?

2.串口初始化
static int __init serial8250_init(void)
{
?int ret;

?if (nr_uarts > UART_NR)//UART_NR =3
??nr_uarts = UART_NR;//串口數(shù)量最多設為3個

?printk(KERN_INFO "Serial: 8250/16550 driver, ""%d ports, IRQ sharing %sabled\n", nr_uarts,share_irqs ? "en" : "dis");

?serial8250_reg.nr = UART_NR;//串口數(shù)量
?/*
??static struct uart_driver serial8250_reg = {
??.owner???= THIS_MODULE,
??.driver_name??= "serial",
??.dev_name??= "ttyS",
??.major???= TTY_MAJOR,//主設備號是4
??.minor???= 64,
??.cons???= SERIAL8250_CONSOLE,//終端
?};
?
?#define SERIAL8250_CONSOLE?&serial8250_console
?
?static struct console serial8250_console = {
??.name??= "ttyS",
??.write??= serial8250_console_write,
??.device??= uart_console_device,
??.setup??= serial8250_console_setup,//設置串口波特率,也就是設置串口。很重要,里面涉及到平臺特性,波特率相關。
??.early_setup?= serial8250_console_early_setup,
??.flags??= CON_PRINTBUFFER | CON_ANYTIME,
??.index??= -1,
??.data??= &serial8250_reg,
?};
?*/
?//函數(shù)定義在serial_core.c中
?//注冊uart串口驅(qū)動,完善uart_driver結構serial8250_reg的uart_state成員及tty_driver成員,并注冊tty驅(qū)動
?ret = uart_register_driver(&serial8250_reg);
#endif
?if (ret)
??goto out;
?
?//創(chuàng)建一個platform_device結構:serial8250_isa_devs
?serial8250_isa_devs = platform_device_alloc("serial8250",PLAT8250_DEV_LEGACY);
?if (!serial8250_isa_devs) {
??ret = -ENOMEM;
??goto unreg_uart_drv;
?}
?
? //將該結構serial8250_isa_devs注冊到總線上
?ret = platform_device_add(serial8250_isa_devs);
?if (ret)
??goto put_dev;
??
?//對uart_8250_port結構serial8250_reg[]初始化,即對3個串口的uart_port結構初始化,并添加端口
?serial8250_register_ports(&serial8250_reg, &serial8250_isa_devs->dev);
?
?/*
?static struct platform_driver serial8250_isa_driver = {
??.probe??= serial8250_probe,
??.remove??= __devexit_p(serial8250_remove),
??.suspend?= serial8250_suspend,
??.resume??= serial8250_resume,
??.driver??= {
???.name?= "serial8250",
???.owner?= THIS_MODULE,
??},
?};
?*/
?//注冊設備,會調(diào)用serial8250_probe()。怎樣調(diào)用的serial8250_probe???????
?ret = platform_driver_register(&serial8250_isa_driver);
?if (ret == 0)
??goto out;

?platform_device_del(serial8250_isa_devs);
put_dev:
?platform_device_put(serial8250_isa_devs);
unreg_uart_drv:
#ifdef CONFIG_SPARC
?sunserial_unregister_minors(&serial8250_reg, UART_NR);
#else
?uart_unregister_driver(&serial8250_reg);
#endif
out:
?return ret;
}

//注冊串口驅(qū)動
int uart_register_driver(struct uart_driver *drv)
{
?struct tty_driver *normal;
?int i, retval;

?BUG_ON(drv->state);

?//為串口的uart_driver結構分配要指向的uart_state結構的空間*串口數(shù)量
?drv->state = kzalloc(sizeof(struct uart_state) * drv->nr, GFP_KERNEL);
?if (!drv->state)
??goto out;
?
?//為uart_driver結構分配要指向的tty_driver結構的空間
?/*struct tty_driver *alloc_tty_driver(int lines)
?{
??struct tty_driver *driver;
?
??driver = kzalloc(sizeof(struct tty_driver), GFP_KERNEL);//分配空間
??if (driver) {
???kref_init(&driver->kref);
???driver->magic = TTY_DRIVER_MAGIC;//tty_driver的魔數(shù)
???driver->num = lines;//串口數(shù)量3個
??}
??return driver;
?}*/
?normal = alloc_tty_driver(drv->nr);
?if (!normal)
??goto out_kfree;

?drv->tty_driver = normal;//賦值給uart_driver結構的tty_driver成員
?//對tty_driver成員指向的結構初始化
?normal->owner??= drv->owner;//THIS_MODULE
?normal->driver_name?= drv->driver_name;//"serial"
?normal->name??= drv->dev_name;//"ttyS"
?normal->major??= drv->major;//主設備號:TTY_MAJOR=4
?normal->minor_start?= drv->minor;//次設備號:64
?normal->type??= TTY_DRIVER_TYPE_SERIAL;//#define TTY_DRIVER_TYPE_SERIAL 0x0003
?normal->subtype??= SERIAL_TYPE_NORMAL;//#define SERIAL_TYPE_NORMAL? 1(定義在include/linux/tty_driver.h)
?normal->init_termios?= tty_std_termios;//終端的標準配置(drivers/tty/tty_io.c)
?normal->init_termios.c_cflag = B9600 | CS8 | CREAD | HUPCL | CLOCAL;//配置c_cflag
?normal->init_termios.c_ispeed = normal->init_termios.c_ospeed = 9600;//波特率設為9600
?normal->flags??= TTY_DRIVER_REAL_RAW | TTY_DRIVER_DYNAMIC_DEV;
?normal->driver_state??? = drv;//指向相應的uart_driver
?tty_set_operations(normal, &uart_ops);//將tty_driver結構的normal操作指向uart_ops
?/*void tty_set_operations(struct tty_driver *driver,const struct tty_operations *op)
?{
??driver->ops = op;
?};
?static const struct tty_operations uart_ops = {
??.open??= uart_open,
??.close??= uart_close,
??.write??= uart_write,
??.put_char?= uart_put_char,
??.flush_chars?= uart_flush_chars,
??.write_room?= uart_write_room,
??.chars_in_buffer= uart_chars_in_buffer,
??.flush_buffer?= uart_flush_buffer,
??.ioctl??= uart_ioctl,
??.throttle?= uart_throttle,
??.unthrottle?= uart_unthrottle,
??.send_xchar?= uart_send_xchar,
??.set_termios?= uart_set_termios,
??.set_ldisc?= uart_set_ldisc,
??.stop??= uart_stop,
??.start??= uart_start,
??.hangup??= uart_hangup,
??.break_ctl?= uart_break_ctl,
??.wait_until_sent= uart_wait_until_sent,
?#ifdef CONFIG_PROC_FS
??.proc_fops?= &uart_proc_fops,
?#endif
??.tiocmget?= uart_tiocmget,
??.tiocmset?= uart_tiocmset,
??.get_icount?= uart_get_icount,
?#ifdef CONFIG_CONSOLE_POLL
??.poll_init?= uart_poll_init,
??.poll_get_char?= uart_poll_get_char,
??.poll_put_char?= uart_poll_put_char,
?#endif
?};
?*/

?for (i = 0; i < drv->nr; i++) {//根據(jù)串口數(shù)量依次掃描drv->nr=3
??struct uart_state *state = drv->state + i;//找到每個串口的uart_state地址
??struct tty_port *port = &state->port;//每個串口有一個tty_port結構
??
??//初始化每個串口的tty_port結構
??tty_port_init(port);
??port->ops = &uart_port_ops;
??port->close_delay???? = 500;?/* .5 seconds */
??port->closing_wait??? = 30000;?/* 30 seconds */
??tasklet_init(&state->tlet, uart_tasklet_action,(unsigned long)state);
?}
?
?//注冊tty驅(qū)動
?retval = tty_register_driver(normal);
?if (retval >= 0)
??return retval;

?put_tty_driver(normal);
out_kfree:
?kfree(drv->state);
out:
?return -ENOMEM;
}

//初始化串口的uart_port結構
static void __init serial8250_register_ports(struct uart_driver *drv, struct device *dev)
{
?int i;
?
?//對uart_8250_port結構的serial8250_ports進行初始化
?for (i = 0; i < nr_uarts; i++) {//共3個串口
??struct uart_8250_port *up = &serial8250_ports[i];
??up->cur_iotype = 0xFF;//先初始化為0xFF,在set_io_from_upio()會賦值成uart_port->iotype(即UPIO_MEM=2)
?}
?
?//對uart_8250_port結構的serial8250_ports[]接著進行初始化,主要是設置uart_port字段ops的操作
?//由于此函數(shù)在初始化console時被調(diào)用過,所以現(xiàn)在調(diào)用的話會直接返回。即串口的uart_port的ops字段已經(jīng)賦過值了
?serial8250_isa_init_ports();

?for (i = 0; i < nr_uarts; i++) {//共3個串口
??struct uart_8250_port *up = &serial8250_ports[i];

??up->port.dev = dev;//指向相應的struct device結構

??if (up->port.flags & UPF_FIXED_TYPE)//因為未進行serial8250_probe(),所以此標志未設置,不進入下邊函數(shù)
???serial8250_init_fixed_type_port(up, up->port.type);//設置串口type=PORT_AR7,即18
??
??//向設備添加端口,是在uart_driver增加一個port,在未進行serial8250_probe()之前,這個函數(shù)的串口配置操作會失敗
??//進行過serial8250_probe()后,還會再調(diào)用此函數(shù),那時就可以配置好串口。
??uart_add_one_port(drv, &up->port);
?}
}

static void __init serial8250_isa_init_ports(void)
{
?struct uart_8250_port *up;
?static int first = 1;
?int i, irqflag = 0;

?if (!first)//靜態(tài)變量,serial8250_console_init()第一次進入這個函數(shù),之后serial8250_init()再進入這個函數(shù)就會直接返回
??return;
?first = 0;
?
?//對三個串口的uart_8250_port結構serial8250_ports結構體進行初始化
?for (i = 0; i < nr_uarts; i++) {
??struct uart_8250_port *up = &serial8250_ports[i];

??up->port.line = i;//0代表串口0,1代表串口1
??spin_lock_init(&up->port.lock);

??init_timer(&up->timer);//初始化定時器
??up->timer.function = serial8250_timeout;//初始化定時器的超時函數(shù)

??//ALPHA_KLUDGE_MCR needs to be killed.
??up->mcr_mask = ~ALPHA_KLUDGE_MCR;
??up->mcr_force = ALPHA_KLUDGE_MCR;
??
??//初始化uart_8250_port指向的uart_port字段port的操作
??up->port.ops = &serial8250_pops;
??/*
??static struct uart_ops serial8250_pops = {
???.tx_empty?= serial8250_tx_empty,
???.set_mctrl?= serial8250_set_mctrl,
???.get_mctrl?= serial8250_get_mctrl,
???.stop_tx?= serial8250_stop_tx,
???.start_tx?= serial8250_start_tx,
???.stop_rx?= serial8250_stop_rx,
???.enable_ms?= serial8250_enable_ms,
???.break_ctl?= serial8250_break_ctl,
???.startup?= serial8250_startup,
???.shutdown?= serial8250_shutdown,
???.set_termios?= serial8250_set_termios,
???.set_ldisc?= serial8250_set_ldisc,
???.pm??= serial8250_pm,
???.type??= serial8250_type,
???.release_port?= serial8250_release_port,
???.request_port?= serial8250_request_port,
???.config_port?= serial8250_config_port,
???.verify_port?= serial8250_verify_port,
??#ifdef CONFIG_CONSOLE_POLL
???.poll_get_char = serial8250_get_poll_char,
???.poll_put_char = serial8250_put_poll_char,
??#endif
??};
??*/
?}

?if (share_irqs)//中斷是否共享(這里設置成不共享)
??irqflag = IRQF_SHARED;
?
?//條件不滿足,不會進來初始化
?for (i = 0, up = serial8250_ports;i < ARRAY_SIZE(old_serial_port) && i < nr_uarts;i++, up++) {
/*?up->port.iobase?? = old_serial_port[i].port;
??up->port.irq????? = irq_canonicalize(old_serial_port[i].irq);
??up->port.irqflags = old_serial_port[i].irqflags;
??up->port.uartclk? = old_serial_port[i].baud_base * 16;
??up->port.flags??? = old_serial_port[i].flags;
??up->port.hub6???? = old_serial_port[i].hub6;
??up->port.membase? = old_serial_port[i].iomem_base;
??up->port.iotype?? = old_serial_port[i].io_type;
??up->port.regshift = old_serial_port[i].iomem_reg_shift;
??set_io_from_upio(&up->port);
??up->port.irqflags |= irqflag;
??if (serial8250_isa_config != NULL)
???serial8250_isa_config(i, &up->port, &up->capabilities);
*/
?}
}

int uart_add_one_port(struct uart_driver *drv, struct uart_port *uport)
{
?struct uart_state *state;
?struct tty_port *port;
?int ret = 0;
?struct device *tty_dev;

?BUG_ON(in_interrupt());//不能在中斷中調(diào)用
?
?//Uart_port->line就是對uart設備文件序號.它對應的也就是uart_driver->state數(shù)組中的uart_port->line項.
?if (uport->line >= drv->nr)//在serial8250_isa_init_ports()已經(jīng)初始化過,代表端口號,0代表串口0。
??return -EINVAL;
?
?//根據(jù)串口號找到每個串口對應的uart_state結構
?state = drv->state + uport->line;
?port = &state->port;//通過uart_state結構找到每個串口的tty_port結構

?mutex_lock(&port_mutex);
?mutex_lock(&port->mutex);
?if (state->uart_port) {
??ret = -EINVAL;
??goto out;
?}
?
?//將uart_state和uart_port結構相關聯(lián)起來
?state->uart_port = uport;?
?state->pm_state = -1;

?uport->cons = drv->cons;//將uart_driver的serial8250_console成員賦值給uart_port成員
?uport->state = state;//uart_port的state成員指向相應的uart_state

? //If this port is a console, then the spinlock is already initialised.
? //檢查這個串口是否就是終端,并且此終端是否已經(jīng)注冊完畢
?if (!(uart_console(uport) && (uport->cons->flags & CON_ENABLED))) {
??spin_lock_init(&uport->lock);
??lockdep_set_class(&uport->lock, &port_lock_key);
?}
?
?//進行port的自動配置,在未進行serial8250_probe(),串口的port->iobase、port->mapbase、port->membase都為空,所以函數(shù)進去會立即返回,即未配置成功。
?//當進行完serial8250_probe()函數(shù)時,還會調(diào)用uart_add_one_port(),再到這個函數(shù)配置時就會配置成功
?uart_configure_port(drv, state, uport);

? //然后注冊tty_device.如果用戶空間運行了udev或者已經(jīng)配置好了hotplug.就會在/dev下自動生成設備文件了.
?tty_dev = tty_register_device(drv->tty_driver, uport->line, uport->dev);
?if (likely(!IS_ERR(tty_dev))) {//設置設備的喚醒狀態(tài)
??device_init_wakeup(tty_dev, 1);
??device_set_wakeup_enable(tty_dev, 0);
?} else
??printk(KERN_ERR "Cannot register tty device on line %d\n",uport->line);

? //Ensure UPF_DEAD is not set.
?uport->flags &= ~UPF_DEAD;

?out:
?mutex_unlock(&port->mutex);
?mutex_unlock(&port_mutex);

?return ret;
}

static void uart_configure_port(struct uart_driver *drv, struct uart_state *state,struct uart_port *port)
{
?unsigned int flags;

?if (!port->iobase && !port->mapbase && !port->membase)//未調(diào)用serial8250_probe()之前,會從這里直接返回。
??return;
?
?//調(diào)用serial8250_probe()之后,會接著往下進行
?flags = 0;
?if (port->flags & UPF_AUTO_IRQ)//未設置此標志
??flags |= UART_CONFIG_IRQ;
??
?if (port->flags & UPF_BOOT_AUTOCONF) {//經(jīng)過probe()函數(shù),此標志已配置
??if (!(port->flags & UPF_FIXED_TYPE)) {//已設置該標志,下邊的不會進入
???port->type = PORT_UNKNOWN;//不會進入
???flags |= UART_CONFIG_TYPE;
??}
??port->ops->config_port(port, flags);//調(diào)用設備的自動配置函數(shù),即serial8250_config_port()
?}

?if (port->type != PORT_UNKNOWN) {
??unsigned long flags;
??
??//打印串口的信息
??uart_report_port(drv, port);

??/* Power up port for set_mctrl() */
??uart_change_pm(state, 0);改變端口的電源狀態(tài),上電

??spin_lock_irqsave(&port->lock, flags);
??port->ops->set_mctrl(port, port->mctrl & TIOCM_DTR);設置串口modem控制,調(diào)用serial8250_set_mctrl()
??spin_unlock_irqrestore(&port->lock, flags);

?? //注冊終端,配置終端的信息,若此端口有cons字段,并且console的注冊不成功。注冊成功CON_ENABLED標志為1
??if (port->cons && !(port->cons->flags & CON_ENABLED))
??{
???/*serial8250_console_init()函數(shù)會比serial8250_probe()先調(diào)用,所以調(diào)用register_console的時候,port還沒有初始化,所以當
????register_console調(diào)用serial8250_console_setup()設置buad,parity bits的時候,
????serial8250_console_setup()會檢測port->iobase和port->membase是否是有效值,如果不是就返回,
????放棄初始化console,所以實際上,console不是在serial8250_console_init()里邊初始化。
????
????當serial8250_probe()調(diào)用uart_add_one_port->uart_configure_port:又會調(diào)用register_console(),
????在這里會將真正的console注冊掉。
????該函數(shù)會檢查console有沒有初始化,如果沒有初始化,則調(diào)用register_console來初始化.
????所以console放在這里初始化也是比較好一些.
???*/
???register_console(port->cons);//將該console注冊到console_drivers鏈表上,最后調(diào)用release_console_sem,將printk緩沖的數(shù)據(jù)打印到ttyS2上
??}

??//檢查此串口是否是終端,除了我們使用作為console的串口,其余的進行斷電
??if (!uart_console(port))//#define uart_console(port)?((port)->cons && (port)->cons->index == (port)->line)
???uart_change_pm(state, 3);//除了我們使用的console,其余的進行斷電
?}
}

//注冊設備serial8250_isa_driver時,會調(diào)用此函數(shù)
static int __devinit serial8250_probe(struct platform_device *dev)
{
?//傳入的參數(shù)就是da8xx_serial_device
?/*struct platform_device da8xx_serial_device = {//platform_device就描述了設備對象。
??.name?= "serial8250",
??.id?= PLAT8250_DEV_PLATFORM,
??.dev?= {
???.platform_data?= da8xx_serial_pdata,//這個platform_device對象的私有數(shù)據(jù)指成員向一個plat_serial8250_port類型的數(shù)組。在這里該數(shù)組描述了三個串口接口的基本信息。
?????????????????????//當8250驅(qū)動檢測到這個platform_device對象后,就分析該對象的私有數(shù)據(jù)成員指向的那個plat_serial8250_port類型的數(shù)組。
?????????????????????//然后根據(jù)該數(shù)組的每個成員描述的信息生成一個串口對象設備。
??},
?};
?
?static struct plat_serial8250_port da8xx_serial_pdata[] = {
??{
???.mapbase?= DA8XX_UART0_BASE,//串口接口寄存器物理地址的基地址,#define DAVINCI_UART0_BASE?(IO_PHYS + 0x20000)(見/arch/arm/mach-davinci/include/mach/serial.h)
???.irq??= IRQ_DA8XX_UARTINT0,//該串口接口使用的中斷號, #define IRQ_DA8XX_UARTINT0? 25,(在/arch/arm/mach-davinci/include/mach/irqs.h)
???.flags??= UPF_BOOT_AUTOCONF | UPF_SKIP_TEST | UPF_IOREMAP | UPF_FIXED_TYPE,
???.type??= PORT_AR7,//串口0類型
???.iotype??= UPIO_MEM,//成員表示該串口接口寄存器的地址類型,8位的內(nèi)存地址?
???.regshift?= 2,//在訪問該串口接口的某個寄存器時,需把該寄存器的號左移多少位然后加基地址(不管是物理或虛擬地址)才能得能到這個寄存器的址址
??},
??{
???.mapbase?= DA8XX_UART1_BASE, //DAVINCI_UART1_BASE?(IO_PHYS + 0x20400)
???.irq??= IRQ_DA8XX_UARTINT1, //中斷號是53
???.flags??= UPF_BOOT_AUTOCONF | UPF_SKIP_TEST |UPF_IOREMAP | UPF_FIXED_TYPE,
???.type??= PORT_AR7,
???.iotype??= UPIO_MEM,
???.regshift?= 2,
??},
??{
???.mapbase?= DA8XX_UART2_BASE, //#define DAVINCI_UART2_BASE?(IO_PHYS + 0x20800)
???.irq??= IRQ_DA8XX_UARTINT2, //中斷號是61
???.flags??= UPF_BOOT_AUTOCONF | UPF_SKIP_TEST |UPF_IOREMAP | UPF_FIXED_TYPE,
???.type??= PORT_AR7,
???.iotype??= UPIO_MEM,
???.regshift?= 2,
??},
??{
???.flags?= 0,
??},
?};*/
?struct plat_serial8250_port *p = dev->dev.platform_data;
?struct uart_port port;
?int ret, i, irqflag = 0;

?memset(&port, 0, sizeof(struct uart_port));

?if (share_irqs)
??irqflag = IRQF_SHARED;
??
?// 會 將 dev->dev.platform_data 所代表的 port 添加到 uart_driver 中
?for (i = 0; p && p->flags != 0; p++, i++) {//遍歷三個串口
??port.iobase??= p->iobase;
??port.membase??= p->membase;
??port.irq??= p->irq;//中斷號
??port.irqflags??= p->irqflags;
??port.uartclk??= p->uartclk;//時鐘
??port.regshift??= p->regshift;//寄存器偏移量 2
??port.iotype??= p->iotype;//IO類型
??port.flags??= p->flags;//標志
??port.mapbase??= p->mapbase;//串口接口寄存器物理地址的基地址
??port.hub6??= p->hub6;
??port.private_data?= p->private_data;
??port.type??= p->type;//PORT_AR7,串口類型
??port.serial_in??= p->serial_in;
??port.serial_out??= p->serial_out;
??port.set_termios?= p->set_termios;
??port.pm???= p->pm;
??port.dev??= &dev->dev;
??port.irqflags??|= irqflag;
??if (p->clk)
???serial8250_ports[i].clk = p->clk;
??
??//再重新注冊串口
??ret = serial8250_register_port(&port);
??if (ret < 0) {
???dev_err(&dev->dev, "unable to register port at index %d ""(IO%lx MEM%llx IRQ%d): %d\n", i,p->iobase, (unsigned long long)p->mapbase,p->irq, ret);
??}
?}
?return 0;//到這里串口的初始化就結束!!!!
}

int serial8250_register_port(struct uart_port *port)
{
?struct uart_8250_port *uart;
?int ret = -ENOSPC;

?if (port->uartclk == 0)
??return -EINVAL;

?mutex_lock(&serial_mutex);
?
?//查找在serial8250_ports[]數(shù)組中是否已有記錄
?uart = serial8250_find_match_or_unused(port);
?if (uart) {//都會查到有記錄
??uart_remove_one_port(&serial8250_reg, &uart->port);//把原來的串口移除掉,再重新添加
??
??//串口的uart_port再賦值
??uart->port.iobase?????? = port->iobase;
??uart->port.membase????? = port->membase;
??uart->port.irq????????? = port->irq;
??uart->port.irqflags???? = port->irqflags;
??uart->port.uartclk????? = port->uartclk;
??uart->port.fifosize???? = port->fifosize;
??uart->port.regshift???? = port->regshift;
??uart->port.iotype?????? = port->iotype;
??uart->port.flags??????? = port->flags | UPF_BOOT_AUTOCONF;
??uart->port.mapbase????? = port->mapbase;
??uart->port.private_data = port->private_data;
??if (port->dev)
???uart->port.dev = port->dev;

??if (port->flags & UPF_FIXED_TYPE)//probe()進行時,此標志已設置
???serial8250_init_fixed_type_port(uart, port->type);//設置串口type=PORT_AR7,即18

??set_io_from_upio(&uart->port);//設置串口的讀寫函數(shù)
??
??//如果傳進來的參數(shù)此成員有值,用原來的。實際時原來此成員變量為空,da8xx_serial_pdata變量中未賦值
??if (port->serial_in)
???uart->port.serial_in = port->serial_in;
??if (port->serial_out)
???uart->port.serial_out = port->serial_out;
??if (port->set_termios)
???uart->port.set_termios = port->set_termios;
??if (port->pm)
???uart->port.pm = port->pm;

??if (serial8250_isa_config != NULL)
???serial8250_isa_config(0, &uart->port,&uart->capabilities);
??
??//再重新添加串口,這時配置串口就能成功
??ret = uart_add_one_port(&serial8250_reg, &uart->port);
??if (ret == 0)
???ret = uart->port.line;

??ret = serial8250_cpufreq_register(uart);
??if (ret < 0)
???printk(KERN_ERR "Failed to add cpufreq notifier\n");
?}
?mutex_unlock(&serial_mutex);

?return ret;
}

static void serial8250_config_port(struct uart_port *port, int flags)
{
?struct uart_8250_port *up = (struct uart_8250_port *)port;
?int probeflags = PROBE_ANY;
?int ret;

?if (cpu_is_davinci_da850())//是否為達芬奇平臺
??up->bugs |= UART_BUG_NOMSR;

?ret = serial8250_request_std_resource(up);//分配內(nèi)存資源,IO資源
?if (ret < 0)
??return;

?ret = serial8250_request_rsa_resource(up);//會返回失敗
?if (ret < 0)
??probeflags &= ~PROBE_RSA;//清除PROBE_RSA標志
?
?//up->cur_iotype在serial8250_register_ports()設置成0xFF,
?//而up->port.iotype在serial8250_isa_init_ports()被設置為UPIO_MEM,即2
?if (up->port.iotype != up->cur_iotype)
??set_io_from_upio(port);//設置uart_port結構的serial_in函數(shù)和serial_out函數(shù)

?if (flags & UART_CONFIG_TYPE)//此標志沒有被設置
??autoconfig(up, probeflags);//不會調(diào)用

?if (up->port.type == PORT_16550A && up->port.iotype == UPIO_AU)
??up->bugs |= UART_BUG_NOMSR;

?if (up->port.type != PORT_UNKNOWN && flags & UART_CONFIG_IRQ)//此標志UART_CONFIG_IRQ未設置
??autoconfig_irq(up);//不會調(diào)用
?
?//以下不會調(diào)用
?if (up->port.type != PORT_RSA && probeflags & PROBE_RSA)
??serial8250_release_rsa_resource(up);
?if (up->port.type == PORT_UNKNOWN)
??serial8250_release_std_resource(up);
}

static int serial8250_request_std_resource(struct uart_8250_port *up)
{
?unsigned int size = serial8250_port_size(up);
?int ret = 0;

?switch (up->port.iotype) {//up->port.iotype == UPIO_MEM
?case UPIO_AU:
?case UPIO_TSI:
?case UPIO_MEM32:
?case UPIO_MEM:
?case UPIO_DWAPB:
??if (!up->port.mapbase)
???break;

??if (!request_mem_region(up->port.mapbase, size, "serial")) {
???ret = -EBUSY;
???break;
??}

??if (up->port.flags & UPF_IOREMAP) {//如果前邊映射過了,UPF_IOREMAP被清零了,這里就不需再映射了
???up->port.membase = ioremap_nocache(up->port.mapbase,size);
???if (!up->port.membase) {
????release_mem_region(up->port.mapbase, size);
????ret = -ENOMEM;
???}
??}
??break;

?case UPIO_HUB6:
?case UPIO_PORT:
??if (!request_region(up->port.iobase, size, "serial"))
???ret = -EBUSY;
??break;
?}
?return ret;
}

static void set_io_from_upio(struct uart_port *p)
{
?struct uart_8250_port *up = (struct uart_8250_port *)p;
?switch (p->iotype) {
?case UPIO_HUB6:
??p->serial_in = hub6_serial_in;
??p->serial_out = hub6_serial_out;
??break;

?case UPIO_MEM://p->iotype=2,采用這里的讀寫函數(shù)
??p->serial_in = mem_serial_in;
??p->serial_out = mem_serial_out;
??break;

?case UPIO_RM9000:
?case UPIO_MEM32:
??p->serial_in = mem32_serial_in;
??p->serial_out = mem32_serial_out;
??break;

?case UPIO_AU:
??p->serial_in = au_serial_in;
??p->serial_out = au_serial_out;
??break;

?case UPIO_TSI:
??p->serial_in = tsi_serial_in;
??p->serial_out = tsi_serial_out;
??break;

?case UPIO_DWAPB:
??p->serial_in = mem_serial_in;
??p->serial_out = dwapb_serial_out;
??break;

?default:
??p->serial_in = io_serial_in;
??p->serial_out = io_serial_out;
??break;
?}
?/* Remember loaded iotype */
?up->cur_iotype = p->iotype;//注意要賦值
}

static inline void uart_report_port(struct uart_driver *drv, struct uart_port *port)
{
?char address[64];

?switch (port->iotype) {//port->iotype == UPIO_MEM
?case UPIO_PORT:
??snprintf(address, sizeof(address), "I/O 0x%lx", port->iobase);
??break;
?case UPIO_HUB6:
??snprintf(address, sizeof(address),"I/O 0x%lx offset 0x%x", port->iobase, port->hub6);
??break;
?case UPIO_MEM:
?case UPIO_MEM32:
?case UPIO_AU:
?case UPIO_TSI:
?case UPIO_DWAPB:
??snprintf(address, sizeof(address), "MMIO 0x%llx", (unsigned long long)port->mapbase);
??break;
?default:
??strlcpy(address, "*unknown*", sizeof(address));
??break;
?}
?/*打印出的信息如下:
?serial8250.0: ttyS0 at MMIO 0x1c42000 (irq = 25) is a AR7
?serial8250.0: ttyS1 at MMIO 0x1d0c000 (irq = 53) is a AR7
?serial8250.0: ttyS2 at MMIO 0x1d0d000 (irq = 61) is a AR7
?*/
?printk(KERN_INFO "%s%s%s%d at %s (irq = %d) is a %s\n",
??????? port->dev ? dev_name(port->dev) : "",
??????? port->dev ? ": " : "",
??????? drv->dev_name,
??????? drv->tty_driver->name_base + port->line,
??????? address, port->irq, uart_type(port));
}

//下邊再次調(diào)用register_console()注冊serial8250_console真正的console終端
void register_console(struct console *newcon)
{
?int i;
?unsigned long flags;
?struct console *bcon = NULL;
?/*
?現(xiàn)在是注冊一個serial8250_console,即
?static struct console serial8250_console = {
??.name??= "ttyS",
??.write??= serial8250_console_write,//寫方法
??.device??= uart_console_device,//tty驅(qū)動
??.setup??= serial8250_console_setup,//設置串口波特率,也就是設置串口。很重要,里面涉及到平臺特性,波特率相關。
??.early_setup?= serial8250_console_early_setup,
??.flags??= CON_PRINTBUFFER | CON_ANYTIME,
??.index??= -1,
??.data??= &serial8250_reg,
?};
?*/
?if (console_drivers && newcon->flags & CON_BOOT) {//注冊的是serial8250_console,CON_BOOT沒有置位,不是引導控制臺。下邊不會進去遍歷
??for_each_console(bcon) {遍歷全局console_drivers數(shù)組???
???if (!(bcon->flags & CON_BOOT)) {//判斷是否已經(jīng)有引導控制臺了,有了的話就直接退出
????printk(KERN_INFO "Too late to register bootconsole %s%d\n",newcon->name, newcon->index);
????return;
???}
??}
?}
?
?if (console_drivers && console_drivers->flags & CON_BOOT)//如果注冊的是引導控制臺,serial8250_console不是引導控制臺
??bcon = console_drivers;//這里不執(zhí)行

?if (preferred_console < 0 || bcon || !console_drivers)
??preferred_console = selected_console;//設置preferred_console為uboot命令選擇的selected_console(即在Uboot傳入的參數(shù)“console=ttyS2,115200n8”在console_cmdline[]數(shù)組中的索引)???
???????????????????? //這里preferred_console =0
?if (newcon->early_setup)//serial8250_console初始化early_setup字段
??newcon->early_setup();//調(diào)用serial8250_console_early_setup()


?if (preferred_console < 0) {//由于preferred_console =0,不會進入下邊
??if (newcon->index < 0)
???newcon->index = 0;
??if (newcon->setup == NULL ||newcon->setup(newcon, NULL) == 0) {
???newcon->flags |= CON_ENABLED;
???if (newcon->device) {
????newcon->flags |= CON_CONSDEV;
????preferred_console = 0;
???}
??}
?}

? //傳給內(nèi)核參數(shù):
? //Kernel command line: console=ttyS2,115200n8 rw root=/dev/ram0 initrd=0xc2000000,20M mem=128M ip=192.168.1.220::192.168.1.1:255.255.255.0::eth0:off
? //所以這里將根據(jù)傳參console=ttyS2,115200來配置作為console的ttyS2串口
?for (i = 0; i < MAX_CMDLINECONSOLES && console_cmdline[i].name[0];i++) {//遍歷全局console_cmdline找到匹配的,i=0就是匹配的“ttyS2”
??if (strcmp(console_cmdline[i].name, newcon->name) != 0)//比較終端名稱“ttyS”
???continue;
??if (newcon->index >= 0 &&newcon->index != console_cmdline[i].index)//console_cmdline[i].index=2。//比較次設備號??
???continue;
??if (newcon->index < 0)
???newcon->index = console_cmdline[i].index;//將終端號賦值給serial8250_console->index,這里是2
???
??//console_cmdline[i].options = "115200n8",對于serial8250_console而言setup字段已初始化
??if (newcon->setup && newcon->setup(newcon, console_cmdline[i].options) != 0)//調(diào)用serial8250_console_setup()對終端進行配置,未probe()前調(diào)用不成功,probe()后調(diào)用成功。
???break;
??//在這里注冊serial8250_console時,調(diào)用serial8250_console_setup()由于port->iobase和port->membase不是有效值,
??//故返回錯誤,這樣下邊的操作不會執(zhí)行,直接break跳出,從flag1出跳出函數(shù)。即在這里serial8250_console沒有注冊成功
??//由于內(nèi)核在下邊的操作隊串口進行初始化時,還會調(diào)用register_console()來注冊serial8250_console,在那時注冊就會成功
??
??newcon->flags |= CON_ENABLED; //設置標志為CON_ENABLE,表示console使能(這個在printk調(diào)用中使用到)?
??newcon->index = console_cmdline[i].index;//設置索引號???
??if (i == selected_console) { //索引號和uboot指定的console的一樣?
???newcon->flags |= CON_CONSDEV;//設置標志CON_CONSDEV(全局console_drivers鏈表中靠前)?
???preferred_console = selected_console;
??}
??break;
?}//for循環(huán)作用大致是查看注冊的console是否是uboot知道的引導console,是則設置相關標志和preferred_console

? //flag1:
?if (!(newcon->flags & CON_ENABLED))//若前邊沒有設置CON_ENABLED標志,就退出。若進行過probe(),CON_ENABLED置位,這里就往下接著注冊console
??return;

?if (bcon && ((newcon->flags & (CON_CONSDEV | CON_BOOT)) == CON_CONSDEV))//防止重復打印???
??newcon->flags &= ~CON_PRINTBUFFER;

?acquire_console_sem();
?if ((newcon->flags & CON_CONSDEV) || console_drivers == NULL) {//如果是preferred控制臺,此標志CON_CONSDEV在前邊已設置過
??newcon->next = console_drivers;
??console_drivers = newcon;//添加進全局console_drivers鏈表前面位置(printk中會遍歷該表調(diào)用合適的console的write方法打印信息)
??if (newcon->next)
???newcon->next->flags &= ~CON_CONSDEV;
?} else {//如果不是preferred控制臺?
??newcon->next = console_drivers->next;
??console_drivers->next = newcon; //添加進全局console_drivers鏈表后面位置
?}
?
?//主冊console主要是刷選preferred_console放置在全局console_drivers鏈表前面,剩下的console放置鏈表靠后的位置,并設置相應的flags,
?//console_drivers最終會在printk函數(shù)的層層調(diào)用中遍歷到,并調(diào)用console的write方法將信息打印出來

?if (newcon->flags & CON_PRINTBUFFER) {
??spin_lock_irqsave(&logbuf_lock, flags);
??con_start = log_start;
??spin_unlock_irqrestore(&logbuf_lock, flags);
?}
?release_console_sem();

?if (bcon && ((newcon->flags & (CON_CONSDEV | CON_BOOT)) == CON_CONSDEV)) {
??printk(KERN_INFO "console [%s%d] enabled, bootconsole disabled\n",newcon->name, newcon->index);
??for_each_console(bcon)
???if (bcon->flags & CON_BOOT)
????unregister_console(bcon);
?} else {//調(diào)用這里
??printk(KERN_INFO "%sconsole [%s%d] enabled\n",(newcon->flags & CON_BOOT) ? "boot" : "" ,newcon->name, newcon->index);
?}
}

//serial8250_console_early_setup()-->serial8250_find_port_for_earlycon()
int serial8250_find_port_for_earlycon(void)
{
?struct early_serial8250_device *device = &early_device;//early console初始化時對early_device結構的初始化
?struct uart_port *port = &device->port;
?int line;
?int ret;

?if (!device->port.membase && !device->port.iobase)//early_device結構初始化時已經(jīng)配置好
??return -ENODEV;
?//early console注冊時不會調(diào)用此函數(shù)。
?//當真正的console初始化時,會調(diào)用此函數(shù)。
?//真正的console初始化時,會查找early console注冊時用的是哪一個串口號,從serial8250_ports[]中根據(jù)uart_port->mapbase地址來比對
?line = serial8250_find_port(port);//根據(jù)uart_port結構找到串口號,比對沒有找到串口號,line返回負值
?if (line < 0)
??return -ENODEV;//從這里返回,下邊的不再執(zhí)行
?
?//若找到early console用的串口號,更新當初傳入內(nèi)核參數(shù)使用的console_cmdline[i],名稱改成ttyS。。。。
?ret = update_console_cmdline("uart", 8250, "ttyS", line, device->options);
?if (ret < 0)
??ret = update_console_cmdline("uart", 0,"ttyS", line, device->options);

?return ret;
}

static int __init serial8250_console_setup(struct console *co, char *options)
{
?struct uart_port *port;
?int baud = 9600;
?int bits = 8;
?int parity = 'n';
?int flow = 'n';

?if (co->index >= nr_uarts)//console的索引,這里是2,即ttyS2
??co->index = 0;
?port = &serial8250_ports[co->index].port;//找到對應的ttyS2的uart_port結構
?
?//由于console_init在注冊serial8250_console時調(diào)用的register_console()函數(shù)調(diào)用serial8250_console_setup()
?//進入這個函數(shù)時,由于ttyS2的uart_port結構沒有初始化,port->iobase 和port->membase值都未設置,所以直接從下邊返回
?//當進行串口初始化時,還會回來注冊serial8250_console,再調(diào)用到這里,由于設置了ttyS2的uart_port結構,所以下邊的配置就會成功
?if (!port->iobase && !port->membase)//第一次注冊時,由于未設置,從這里直接返回
??return -ENODEV;

?if (options)//如果options不為空,就將options里的數(shù)值寫給baud, &parity, &bits, &flow
??uart_parse_options(options, &baud, &parity, &bits, &flow);
?//沒有配置options,則使用缺省值,否則使用傳下來的的參數(shù)options里的串口配置
?return uart_set_options(port, co, baud, parity, bits, flow);
}

void uart_parse_options(char *options, int *baud, int *parity, int *bits, int *flow)
{
?char *s = options;

?*baud = simple_strtoul(s, NULL, 10);
?while (*s >= '0' && *s <= '9')
??s++;
?if (*s)
??*parity = *s++;
?if (*s)
??*bits = *s++ - '0';
?if (*s)
??*flow = *s;
}

int uart_set_options(struct uart_port *port, struct console *co,int baud, int parity, int bits, int flow)
{
?struct ktermios termios;
?static struct ktermios dummy;
?int i;

?//Ensure that the serial console lock is initialised early.
?spin_lock_init(&port->lock);
?lockdep_set_class(&port->lock, &port_lock_key);

?memset(&termios, 0, sizeof(struct ktermios));
?termios.c_cflag = CREAD | HUPCL | CLOCAL;

?//Construct a cflag setting.
?for (i = 0; baud_rates[i].rate; i++)
??if (baud_rates[i].rate <= baud)
???break;

?termios.c_cflag |= baud_rates[i].cflag;

?if (bits == 7)
??termios.c_cflag |= CS7;
?else
??termios.c_cflag |= CS8;

?switch (parity) {
?case 'o': case 'O':
??termios.c_cflag |= PARODD;
??/*fall through*/
?case 'e': case 'E':
??termios.c_cflag |= PARENB;
??break;
?}

?if (flow == 'r')
??termios.c_cflag |= CRTSCTS;

?/*
? * some uarts on other side don't support no flow control.
? * So we set * DTR in host uart to make them happy
? */
?port->mctrl |= TIOCM_DTR;

?port->ops->set_termios(port, &termios, &dummy);//調(diào)用serial8250_set_termios()對串口進行配置

?//Allow the setting of the UART parameters with a NULL console too:
?if (co)
??co->cflag = termios.c_cflag;

?return 0;
}

struct device *tty_register_device(struct tty_driver *driver, unsigned index,struct device *device)
{
?char name[64];
?dev_t dev = MKDEV(driver->major, driver->minor_start) + index;//得到設備號

?if (index >= driver->num) {
??printk(KERN_ERR "Attempt to register invalid tty line number "" (%d).\n", index);
??return ERR_PTR(-EINVAL);
?}

?if (driver->type == TTY_DRIVER_TYPE_PTY)
??pty_line_name(driver, index, name);
?else
??tty_line_name(driver, index, name);//得到串口設備名稱ttyS0,ttyS1,ttyS2
?
?return device_create(tty_class, device, dev, NULL, name);//在/dev下創(chuàng)建設備文件
}

?

總結

以上是生活随笔為你收集整理的linux 串口驱动(二)初始化 【转】的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網(wǎng)站內(nèi)容還不錯,歡迎將生活随笔推薦給好友。

亚洲国产高清在线观看视频 | 国产亚洲精品免费 | 久久爱www.| 97视频播放 | 日韩成人免费观看 | 91av综合| 国产美女网 | 超碰人人射| 91字幕 | 毛片www| 国产精品一区二 | 成x99人av在线www | av黄免费看| 91精品国产电影 | 国产伦理久久精品久久久久_ | 久久深夜 | 亚洲成av人影院 | av福利在线看 | 天天综合区 | www国产亚洲 | 国产精品久久久久久久久毛片 | 日韩免费小视频 | 狠狠色丁香久久综合网 | 99免费国产 | 久久久久久久久久亚洲精品 | 日本特黄特色aaa大片免费 | 成人午夜精品久久久久久久3d | 91最新视频在线观看 | 人人爽人人爽人人爽 | 欧美日韩国产一区二区三区在线观看 | 国产高清无av久久 | 开心婷婷色 | 国产精品综合在线观看 | 久久中文精品视频 | 精品国产精品一区二区夜夜嗨 | 国产精品久久久久久久久久久久久久 | 97精品在线观看 | a久久久久久 | 久久精品99国产 | 中文字幕久久精品亚洲乱码 | 亚洲国产中文字幕 | 欧美在线视频a | 黄色亚洲精品 | 日韩视频一区二区在线观看 | 最近中文字幕高清字幕在线视频 | 久草精品免费 | 99视频免费| 在线亚洲成人 | 久久久久久久久久久网 | 亚洲精品福利在线 | av一级网站| 波多野结依在线观看 | 亚洲五月综合 | 91人人澡人人爽人人精品 | 日韩免费视频观看 | 丁香六月婷婷激情 | 91精品国产三级a在线观看 | 欧美日韩国产欧美 | 亚洲一级影院 | 搡bbbb搡bbb视频 | 欧美va在线观看 | 国产成人久久精品 | 美女在线免费视频 | 在线观看不卡的av | 福利视频入口 | 国产午夜影院 | 国产美女精品视频 | 日韩丝袜视频 | 99久久精品电影 | 国产成人一区二区三区久久精品 | 91精品在线播放 | 青草视频在线播放 | 激情视频网页 | 黄色软件在线观看免费 | www久| 欧美影片 | 亚洲影视九九影院在线观看 | 久久精品中文字幕少妇 | 国产在线观看91 | 日韩理论电影网 | 最近中文字幕免费视频 | 国产精品成人aaaaa网站 | 成人久久18免费 | 黄色av网站在线观看免费 | 亚洲最新视频在线播放 | 狠狠干成人综合网 | 日本大尺码专区mv | 99r在线播放 | 国产日韩精品一区二区在线观看播放 | 久久久久免费电影 | 国产黑丝一区二区三区 | 久久精品99国产精品酒店日本 | 99自拍视频在线观看 | 久久艹精品 | 国产专区日韩专区 | 日韩精品一区二区免费 | 成人免费在线看片 | 五月天综合网 | 天天色天天上天天操 | 国产精选在线 | 免费国产ww | 国产精品99久久久久的智能播放 | 精品久久久久久国产偷窥 | 成人免费在线视频观看 | 7777xxxx | 久久久男人的天堂 | 午夜精品剧场 | www成人av | 在线亚洲精品 | 99热国产在线观看 | 欧美成人精品三级在线观看播放 | 色婷婷狠狠干 | 开心激情网五月天 | 骄小bbw搡bbbb揉bbbb | 精品免费久久久久 | 97免费在线观看视频 | 成人 国产 在线 | 九九欧美视频 | 国产女人18毛片水真多18精品 | 国产成人a亚洲精品 | 久久新视频 | 奇米影视8888在线观看大全免费 | 不卡av在线 | av在线电影网站 | 国产a精品| 亚洲a在线观看 | 国产精品久久久久久婷婷天堂 | www.狠狠色 | 日韩免费小视频 | 免费久久久久久久 | 免费91在线| 最近最新中文字幕视频 | 五月天婷婷在线观看视频 | 免费看毛片网站 | 日韩成人高清在线 | 国产在线播放不卡 | www色网站| 久久免费a| 色多视频在线观看 | 午夜天使| 天天天色综合a | 日本深夜福利视频 | 一级黄色大片 | 国产网红在线观看 | 久久精品国产v日韩v亚洲 | 激情伊人 | 国产精品久久久久久久久久直播 | 国产裸体bbb视频 | 国产视频精品久久 | 国产精品麻豆视频 | 99久久久久久 | 嫩草av在线 | 天天色综合三 | 美女视频黄频大全免费 | 国产视频导航 | 精品一区 在线 | 日韩av电影免费在线观看 | 日韩动态视频 | 婷婷六月综合亚洲 | 天天艹天天干天天 | 亚洲网久久 | 一区二区视频网站 | 国产小视频福利在线 | 日韩欧美视频免费看 | 成人观看视频 | 国产精品一区二区在线看 | 成人欧美日韩国产 | 国产高清中文字幕 | 2024av在线播放| 日韩精品大片 | 国产亚洲综合精品 | 有码中文字幕在线观看 | 美腿丝袜av| 久久精品国产第一区二区三区 | 日日干天天 | 免费观看成年人视频 | 91精品国产综合久久福利不卡 | 亚洲视频1 | 欧美视频一区二 | 日本乱码在线 | 91桃色免费观看 | a天堂最新版中文在线地址 久久99久久精品国产 | 免费人做人爱www的视 | 9999精品视频 | 国精产品满18岁在线 | 欧美成人免费在线 | 五月色婷| 成人毛片a| 美女视频国产 | 亚洲天堂网视频 | 午夜精品福利影院 | 久久天天躁夜夜躁狠狠躁2022 | 日韩av在线免费看 | 免费观看一级成人毛片 | 婷色在线 | 狠狠干在线 | 人人干人人做 | 国产高清绿奴videos | 激情综合亚洲精品 | 久草视频在线免费播放 | 96精品视频 | 99热精品在线观看 | 久久国产精品区 | 亚洲精品99久久久久中文字幕 | 91大神电影 | 中文字幕亚洲欧美日韩2019 | av大全免费在线观看 | 91精品国产91久久久久久三级 | 国产一区二区视频在线 | 亚洲开心色 | 国产亚洲精品久久久久久久久久 | 国产精品系列在线观看 | 亚洲第一伊人 | 蜜桃视频色 | 91精品欧美 | 日韩高清在线一区 | 国产一级91| 久久免费观看视频 | 精品亚洲视频在线观看 | 亚洲精品在线观看的 | 狠狠操夜夜操 | 在线a人片免费观看视频 | 精品久久美女 | 中文字幕一区二区三区视频 | 国产精品入口麻豆www | 中文字幕区 | 麻豆传媒在线免费看 | 黄色大片中国 | 久久99最新地址 | 日韩免费电影网 | 久久五月天婷婷 | 成年人黄色免费视频 | 国产aaa毛片 | 国产精品国产三级国产aⅴ无密码 | 99在线观看免费视频精品观看 | 亚洲理论电影网 | 久久精品第一页 | 丁香视频免费观看 | 久久久高清视频 | 久久久久亚洲天堂 | 久久精彩免费视频 | 国产成人精品一区二区三区在线 | 美女国产精品 | 亚洲精品免费看 | 国产精品免费观看在线 | 999热视频 | 亚洲理论在线观看 | japanesefreesex中国少妇 | 一区二区三区免费在线观看视频 | 国产麻豆精品传媒av国产下载 | 久久精品xxx | 日韩国产精品毛片 | 日韩精品一区二区三区不卡 | 国产视频欧美视频 | 三级av网 | 欧美99热| av中文字幕电影 | 色婷婷激情四射 | 欧美男男激情videos | 欧美一级xxxx | 超碰大片 | 久久久久久美女 | 曰韩精品 | 国产亚洲精品v | 日韩激情第一页 | 国产专区视频在线 | 成年人视频免费在线播放 | 激情欧美日韩一区二区 | 成人av资源在线 | 欧美激情操 | 国内成人精品2018免费看 | 黄色片网站av | 色噜噜在线观看 | 欧美日韩精品久久久 | 91在线超碰| 高清国产一区 | 狠狠干狠狠操 | 欧美日韩久久不卡 | 国产精品尤物视频 | 国产在线综合视频 | 人人爽人人片 | 中字幕视频在线永久在线观看免费 | 国产在线播放一区二区三区 | 91在线操| 成人av网址大全 | 亚洲做受高潮欧美裸体 | 91在线视频播放 | 国产精品成人一区二区三区吃奶 | 香蕉一区 | 99视频在线精品国自产拍免费观看 | 亚洲视频在线免费观看 | 九九视频免费 | 国产色妞影院wwwxxx | 日韩极品视频在线观看 | 在线中文字幕播放 | 国产精品久久久久999 | 亚洲va欧美 | 色噜噜狠狠狠狠色综合久不 | 开心色插 | 在线精品观看国产 | 日韩激情片在线观看 | 黄污污网站 | 久草久草在线观看 | 一本一本久久aa综合精品 | 亚洲日本va中文字幕 | 久久久污 | 亚洲欧美日韩精品久久奇米一区 | 天天干天天操天天操 | 在线网址你懂得 | 久久免费观看少妇a级毛片 久久久久成人免费 | 99精品视频一区二区 | 久草爱| 91福利社区在线观看 | 丁香电影小说免费视频观看 | 欧美日韩精品影院 | 国产精品理论视频 | 婷婷.com| 日韩av电影一区 | 欧美精品在线观看一区 | 日韩视频一区二区在线 | 久久久久亚洲国产精品 | 久草免费新视频 | 精品少妇一区二区三区在线 | 婷婷综合伊人 | 国产一区二区三区免费在线观看 | 99久久日韩精品视频免费在线观看 | 国产日本亚洲高清 | 国产精品av久久久久久无 | 波多野结衣一区二区三区中文字幕 | 国产日产亚洲精华av | 色婷婷av国产精品 | 特级西西www44高清大胆图片 | 国产精品久久久久久久久久三级 | 免费黄色小网站 | 国产香蕉在线 | 99国产精品免费网站 | 久久免费av电影 | 亚洲伊人色 | 国产一级黄色片免费看 | 91人人澡人人爽人人精品 | 精久久久久 | 天堂在线一区二区 | 99久久精品免费看国产一区二区三区 | 成年人在线电影 | 黄色亚洲大片免费在线观看 | 国产一级性生活 | 麻豆观看 | 成人精品一区二区三区电影免费 | 国产最顶级的黄色片在线免费观看 | 亚洲综合在线五月天 | 激情欧美丁香 | 亚洲男男gaygay无套 | 亚洲成年片 | 久久久久亚洲精品 | 精品一二三区 | 国产成人精品一区二区三区网站观看 | 狠狠天天 | 婷婷丁香激情五月 | 成人国产精品一区 | 成人免费观看电影 | 免费一级片在线 | 久久久久久久久久久网 | 99精品免费在线 | 国产一区二区视频在线 | 亚洲精品99久久久久久 | 亚洲男女精品 | 天天爱av导航 | 欧美影院久久 | 在线免费视频一区 | 国产欧美在线一区 | 天天射天天干天天 | 狠狠色丁香久久婷婷综 | 国产中文字幕视频在线观看 | 亚洲在线网址 | 日本乱视频 | 久久精品一区二区三区国产主播 | 欧美日韩国产精品一区 | 精品久久久久久亚洲综合网站 | 日韩亚洲在线视频 | 91插插插免费视频 | 成人在线播放av | 美女网站视频久久 | 免费在线激情视频 | 亚洲国产欧美在线看片xxoo | 91最新视频在线观看 | 国产精品麻豆三级一区视频 | 免费婷婷 | 国产视频日韩 | 一区二区三区电影在线播 | 9久久精品 | 国产精品18久久久久久久久久久久 | 欧美久久久久久久久久久 | 亚洲精品动漫成人3d无尽在线 | 天天天天天操 | 国产淫片免费看 | 色成人亚洲网 | 亚洲视频精品 | 二区三区毛片 | 日韩免 | 亚洲免费av电影 | av在线免费不卡 | 天天爽网站 | 精品久久网 | 亚洲少妇天堂 | 久久再线视频 | 成人免费视频播放 | 欧美一级片免费播放 | 亚洲高清网站 | 91精品视频免费在线观看 | 久久99热精品这里久久精品 | 国内精品小视频 | 国产成人精品福利 | a在线免费观看视频 | 四虎欧美 | 天天插天天 | 在线看国产一区 | 国产欧美在线一区二区三区 | 日韩高清 一区 | 九九视频在线 | 国产精品专区在线观看 | 黄色一集片 | 亚洲天堂网在线观看视频 | 99超碰在线播放 | 99九九99九九九视频精品 | av视屏在线播放 | 麻豆系列在线观看 | 97夜夜澡人人双人人人喊 | 日本精品二区 | 国产91探花 | 天天干天天在线 | 一级大片在线观看 | 超碰公开在线观看 | 成年人网站免费在线观看 | 手机看片99 | 国产精品一区二区在线免费观看 | 中文字幕色在线 | 婷婷综合激情 | 国产亚洲小视频 | 97精品国产97久久久久久春色 | 色资源二区在线视频 | 就要干b | 深夜男人影院 | 日日操操操 | 国产精品专区h在线观看 | 久草视频免费在线播放 | 亚洲一级片在线看 | 探花视频免费观看高清视频 | 五月婷婷一区二区三区 | 在线a亚洲视频播放在线观看 | 17videosex性欧美 | 中文字幕免费观看视频 | 丁香婷婷射 | 久久久久久久久国产 | 国产1区2区3区精品美女 | 午夜精品视频免费在线观看 | 久久夜av | 国产精品亚洲人在线观看 | 免费高清在线观看电视网站 | 夜夜爽88888免费视频4848 | 亚洲影院色 | 日韩av播放在线 | 91日本在线播放 | 一区二区三区四区五区六区 | 97超级碰 | 国产精品成人国产乱 | 国产色视频一区 | 夜夜看av| 久久久电影 | 日本中文字幕在线电影 | 国产视频一级 | 欧美成人xxx| 日韩久久精品一区二区三区下载 | 亚洲va韩国va欧美va精四季 | 狠狠色丁香婷婷综合最新地址 | 久久tv| 99热在线免费观看 | 99精品亚洲 | 成人综合婷婷国产精品久久免费 | 91av在线视频免费观看 | 97在线观看视频 | 伊人手机在线 | 精品国产乱码久久久久久浪潮 | 国产99久久精品 | 中文字幕在线观看网站 | 最近中文字幕 | 久久久久久久久久久黄色 | 日韩av一区二区在线影视 | 97av超碰| 国产视频九色蝌蚪 | 夜夜操天天操 | 婷婷色五 | 天天干天天插 | 日本久久成人中文字幕电影 | 日韩激情精品 | 国产亚洲综合精品 | 国产精品破处视频 | 九九九九热精品免费视频点播观看 | 人人爱人人添 | 91中文在线 | 综合在线观看色 | 国产区精品在线 | www国产精品com | 亚洲人成在线电影 | 一级黄色片网站 | 精品一区二区三区香蕉蜜桃 | 91自拍视频在线观看 | 国产精品亚洲视频 | 国产精品国内免费一区二区三区 | 正在播放一区二区 | 91大神电影| www.av免费观看 | av天天草| 网址你懂的在线观看 | 久久精品久久久久 | 日本视频高清 | 天天干,天天射,天天操,天天摸 | 欧美成人h版在线观看 | 国产成人免费在线 | 五月天欧美精品 | 亚洲精品1234区 | 草樱av| 国产精品一区二区在线 | 久久国产精品免费一区二区三区 | 超碰激情在线 | 亚洲最新av在线网址 | 国产一级二级视频 | 91人人揉日日捏人人看 | 黄a在线看| 天天曰天天射 | 天天综合网在线观看 | av中文在线播放 | 九九九九精品九九九九 | 国产又粗又猛又爽 | 天天干天天操天天 | 天天干天天拍天天操天天拍 | 日韩精选在线 | 天堂av观看 | 久久久精品久久 | 亚洲情感电影大片 | 自拍超碰在线 | 最近高清中文在线字幕在线观看 | 三级毛片视频 | 日本大片免费观看在线 | 国产精品视频免费看 | 色av男人的天堂免费在线 | 免费视频a | 一级做a视频 | 欧美精选一区二区三区 | 五月激情亚洲 | 日日日日 | 91亚洲在线 | 天天操天天操天天操 | 在线成人看片 | 午夜视频一区二区三区 | 精品亚洲va在线va天堂资源站 | 91污视频在线观看 | 久久美女视频 | 免费十分钟 | 超级av在线 | 日韩亚洲国产中文字幕 | 99久久精品日本一区二区免费 | 亚洲精品大片www | 国产精品久久久久久爽爽爽 | 日韩色一区二区三区 | 欧美日本中文字幕 | 久久人人97超碰com | 亚洲国产成人久久综合 | 亚洲精品国精品久久99热一 | 精品国产电影 | 日韩av手机在线观看 | 天天久久综合 | 亚洲成av人电影 | 激情婷婷av| 天天射,天天干 | 欧美韩国日本在线观看 | 久久亚洲精品国产亚洲老地址 | 成人国产精品电影 | 欧美一区二视频在线免费观看 | 麻豆一二三精选视频 | 91在线国内视频 | 日本性生活一级片 | 黄色免费观看网址 | 草免费视频 | 激情网五月天 | 六月丁香综合网 | 97福利| 国产性xxxx| 深爱开心激情网 | 日韩精品一区二区三区在线播放 | 国产高清视频在线播放一区 | 99久久久久久 | 在线免费观看黄色小说 | 国产无套精品久久久久久 | 在线v片免费观看视频 | 天天干天天摸天天操 | 夜夜骑日日操 | 欧美精品国产综合久久 | 日本一区二区不卡高清 | 九九九九精品九九九九 | 国产在线精品区 | 久久在线看 | 国产一区二区不卡视频 | 亚洲国产精品激情在线观看 | 久久精品香蕉 | 亚洲三级网 | 国产精品福利午夜在线观看 | 国产欧美日韩精品一区二区免费 | 亚洲精品毛片一级91精品 | 玖玖视频免费在线 | 久久精品99视频 | 免费人做人爱www的视 | 午夜电影av | 97香蕉久久国产在线观看 | av3级在线 | 日韩激情免费视频 | 久久久久国产成人免费精品免费 | 狠狠色丁香 | 91视频 - 114av | 免费看黄的视频 | 久久精品人人做人人综合老师 | 伊色综合久久之综合久久 | 8090yy亚洲精品久久 | 特级西西人体444是什么意思 | 日韩中文字幕免费视频 | 97精品在线观看 | 青青久草在线视频 | 久久精品视频2 | 中文字幕永久 | 色综久久 | 伊人狠狠色丁香婷婷综合 | 精品a视频 | 成人黄色小视频 | 不卡视频一区二区三区 | 射射射av| 字幕网av | 91精品视频一区二区三区 | 亚洲精选视频免费看 | 色中文字幕在线观看 | 99热手机在线观看 | 日韩视频一区二区在线观看 | 91系列在线观看 | 婷婷在线精品视频 | 久久精品视频在线观看免费 | 最近免费中文字幕大全高清10 | 久久av福利 | 激情婷婷欧美 | 一区二区三区精品久久久 | 国产视频网站在线观看 | 久久免费在线观看视频 | 久久久亚洲麻豆日韩精品一区三区 | 国产一区二区在线免费播放 | 国产成人免费av电影 | 超碰久热 | 国产一级一片免费播放放a 一区二区三区国产欧美 | 欧美日韩精品区 | 久久黄视频 | 在线观看免费视频你懂的 | 久久综合狠狠综合 | 又污又黄网站 | 欧美精品一区二区蜜臀亚洲 | 日本高清久久久 | 香蕉成人在线视频 | 久久福利 | 国产综合久久 | 国产精品一区在线观看你懂的 | 久久久久国产精品午夜一区 | 狠狠躁夜夜a产精品视频 | 婷婷草| 午夜黄色一级片 | 天堂va欧美va亚洲va老司机 | 国产精品第三页 | 91视频在线免费观看 | 手机在线欧美 | 99久久精品国产毛片 | 色婷婷丁香 | 在线精品视频免费播放 | 久久亚洲福利视频 | 日日夜夜爱 | 国产综合在线观看视频 | 少妇性bbb搡bbb爽爽爽欧美 | 亚洲国产免费 | 免费裸体视频网 | 久久99热精品这里久久精品 | 久久久久免费 | 久久国产精品网站 | 精品国产成人av在线免 | 亚洲日本中文字幕在线观看 | 九草视频在线观看 | 国产一区欧美一区 | 玖玖精品在线 | 中文av免费 | 成年人网站免费在线观看 | 狠狠色狠狠色综合日日92 | 日韩欧美国产成人 | 日韩久久久久久久 | 国产黄网在线 | 最新动作电影 | 在线观看免费视频你懂的 | 天天射综合网视频 | 狠狠网| 在线激情av电影 | 探花视频网站 | av电影一区 | www.久久视频 | 精品国产欧美一区二区三区不卡 | 欧美人人爱 | 日韩国产精品久久久久久亚洲 | 亚洲午夜精品在线观看 | 一区二区三区国产精品 | 欧洲成人av | 久久久久久久久久久久久久av | 中文字幕中文字幕中文字幕 | 午夜精品电影 | 波多野结衣网址 | 三级黄色在线观看 | 久久精品小视频 | 日韩在线观看网站 | 久久精品系列 | 久久乱码卡一卡2卡三卡四 五月婷婷久 | 亚洲乱码在线 | 日韩大片在线免费观看 | 国产成人精品女人久久久 | 欧美在线观看小视频 | 国产婷婷精品av在线 | 992tv人人网tv亚洲精品 | 久久精品黄 | 国产91在线播放 | 91视频91蝌蚪 | 日韩三级视频在线观看 | 久久久免费精品国产一区二区 | 国产精品99久久久久久小说 | 中文字幕欧美日韩va免费视频 | 高清有码中文字幕 | 成人在线一区二区三区 | 日韩欧美视频在线免费观看 | 在线观看亚洲电影 | 婷婷精品| 国产福利网站 | 婷婷激情网站 | 成人三级av| 又爽又黄又刺激的视频 | 91麻豆文化传媒在线观看 | 日韩欧美高清视频在线观看 | 国产九九热 | 麻豆视频在线播放 | 亚洲一二区视频 | 国产91在线 | 美洲 | 欧美一区日韩精品 | 久久久99精品免费观看乱色 | 91丨porny丨九色 | 91高清视频 | 色在线观看网站 | 日韩在线首页 | 亚洲国产精品免费 | 久久久久久毛片精品免费不卡 | 深夜免费福利网站 | 欧美日韩一区二区在线观看 | 韩国av一区二区三区在线观看 | 婷婷久久综合网 | 热久久最新地址 | 91一区二区三区在线观看 | 国产亚洲精品久久网站 | 蜜臀久久99精品久久久无需会员 | 中文字幕在线观看网站 | 国产精品mm | 国产午夜精品一区二区三区在线观看 | 91一区在线观看 | 99久久婷婷国产一区二区三区 | 美女视频黄免费 | 久久久久久久久国产 | 国产精品第十页 | 欧美色图亚洲图片 | 色在线视频 | 日韩中文字幕免费 | 国产最顶级的黄色片在线免费观看 | 一级片免费在线 | 六月丁香激情网 | 午夜精品av在线 | 久久99日韩 | 久久夜靖品 | 日韩欧美国产激情在线播放 | 蜜臀av性久久久久av蜜臀妖精 | 激情综合一区 | 96国产在线 | 韩国精品福利一区二区三区 | 午夜精品一二三区 | 亚洲人成在线电影 | 四虎国产精 | 亚洲人成综合 | 91亚洲欧美 | 日韩在线电影观看 | 国产视频在线观看一区 | 国产福利91精品一区二区三区 | 国产资源 | 日韩在线视 | 亚洲国产日韩在线 | 精品国产综合区久久久久久 | 日日夜夜亚洲 | 日韩在线免费小视频 | 久久伦理 | 国产手机精品视频 | 国产色视频网站 | 日韩高清在线一区二区三区 | 久久久精品免费看 | 69精品久久| 超碰日韩在线 | 国产精品wwwwww | 久久综合狠狠综合久久综合88 | 91在线观看视频 | 美女网站视频免费都是黄 | 看毛片的网址 | 亚洲视频免费在线观看 | 黄色毛片视频免费 | 99色免费| 国产精品永久免费 | 91精品国自产在线偷拍蜜桃 | 中文字幕亚洲国产 | 91色蜜桃 | 欧美黄色成人 | 超碰公开在线观看 | 日日干美女 | www.夜夜操 | 黄色av一级 | 精品美女视频 | 免费看污在线观看 | 在线观看av网 | 奇米影视在线99精品 | 亚洲成人第一区 | 成人av在线影视 | 国产96av| 亚洲另类xxxx | 免费在线国产视频 | 精品一区电影 | 午夜精品99久久免费 | 亚洲成人黄色网址 | 国产热re99久久6国产精品 | 欧美性成人 | 国产精品久久久av久久久 | 国产精品一区二区久久久久 | 一区二区三区免费在线观看 | 国产一区电影在线观看 | 成人观看视频 | 在线观看岛国片 | 日韩中文字幕a | 日韩三级一区 | 日韩av资源在线观看 | 国产成人精品久久久久 | 欧美色图亚洲图片 | 一区二区三区日韩在线 | 欧美日韩中文在线视频 | 国产一区在线视频 | 999成人免费视频 | 99精品欧美一区二区蜜桃免费 | 四虎8848免费高清在线观看 | .精品久久久麻豆国产精品 亚洲va欧美 | 国产精品国产三级国产专区53 | 日韩免费在线观看视频 | 欧美在线一级片 | 国产做aⅴ在线视频播放 | 久久99精品久久久久婷婷 | 91亚洲视频在线观看 | 超碰在线人人 | 久久综合综合久久综合 | 九九热只有精品 | 一区二区三区国产精品 | 久久99精品视频 | 欧美一级免费片 | 欧美 高跟鞋交 xxxxhd | 亚洲精品在线视频播放 | 超碰97国产精品人人cao | 成人动漫精品一区二区 | 亚洲国产中文在线观看 | 久久国产精品色婷婷 | 欧美极品一区二区三区 | 色久综合 | 人人要人人澡人人爽人人dvd | 久久在线精品视频 | 国产亚洲精品久久久久久大师 | 久草在线中文888 | 97视频在线 | 国产精品资源网 | 亚洲成人精品影院 | 国产精品久久久久久久久免费看 | 99久久久国产精品免费观看 | 亚洲成人一区 | 黄色av成人在线观看 | 亚洲91中文字幕无线码三区 | 国产精品一区二区无线 | 欧美看片 | 黄色一级动作片 | 天天射天天爽 | 免费看的黄网站 | 黄色的网站在线 | 福利电影久久 | 欧美激情精品久久久久久变态 | 国产精品 国产精品 | 日韩99热 | 亚洲色图27p| 国产精品国产三级国产不产一地 | 成人亚洲欧美 | 欧美日产一区 | 亚洲综合视频在线观看 | 91成人看片 | 免费在线观看日韩视频 | 国产视频日本 | 免费久久久久久 | 亚洲国产中文字幕在线观看 | 就要干b | 精品国产视频一区 | 天天伊人网 | 91九色最新地址 | 国产精品一区在线观看你懂的 | 人人看人人 | 免费看一级特黄a大片 | 手机看片久久 | 久久久久高清 | 欧美日韩国产色综合一二三四 | 亚洲色图激情文学 | 天天摸天天弄 | 韩国一区二区在线观看 | 在线播放亚洲 | 色中色综合| 91在线区| 国产午夜精品理论片在线 | 久久久久久久久久国产精品 | 色噜噜日韩精品一区二区三区视频 | zzijzzij日本成熟少妇 | 免费三级网| 精品久久精品久久 | 婷婷久久国产 | 东方av在线免费观看 | 操操操干干干 | 狠日日 | 国产99久久久欧美黑人 | 国产精品久久久777 成人手机在线视频 | 在线观看的黄色 | 欧美在线一 | 日韩欧美高清 | 欧美福利视频一区 | 亚洲国产欧美在线人成大黄瓜 | 天天射综合 | av看片在线观看 | 91精品在线免费视频 | 色七七亚洲影院 | 九九热精品视频在线观看 | 福利视频第一页 | 五月婷色 | 国产高清免费在线观看 | 黄av免费在线观看 | 久久精品高清视频 | 久久久久久久久久久久电影 | 久久国产精品一国产精品 | 91色国产在线 | 久久精品视频网址 | 亚洲综合视频在线播放 | 成x99人av在线www | 天天要夜夜操 | 亚洲成人黄色 | 亚洲理论在线观看 | 草久中文字幕 | 久草电影在线观看 | 国产精品99久久久精品免费观看 | 波多野结衣精品在线 | 亚洲电影第一页av | 激情久久久久久久久久久久久久久久 | 99久久久国产精品美女 | 91黄色小网站 | 国产精品美女久久久久久网站 | 亚洲激情在线视频 | 久久精品a | 亚洲国产成人av网 | 精品国产伦一区二区三区观看说明 | 国产精品久久久久免费观看 | www免费网站在线观看 | 97av视频在线观看 | 在线视频免费观看 | 最新日韩在线观看 | 亚洲精品综合在线观看 | 狠狠躁18三区二区一区ai明星 | 亚洲国产成人在线观看 | 成年人视频在线免费观看 | 色婷婷狠狠五月综合天色拍 | 麻豆 91 在线 | 亚洲一级国产 | 久久免费精品 | 国产成人精品一区二区三区福利 | 国产精品久久久久久久婷婷 | 超碰在线中文字幕 | 天天激情天天干 | 999视频网 | 日韩激情第一页 | 中文字幕在线观看视频网站 | 夜夜骑日日| 色视频在线观看免费 | 开心激情五月婷婷 | 在线观看视频中文字幕 | 国产精品资源在线 | 中文字幕高清免费日韩视频在线 |