久久精品国产精品国产精品污,男人扒开添女人下部免费视频,一级国产69式性姿势免费视频,夜鲁夜鲁很鲁在线视频 视频,欧美丰满少妇一区二区三区,国产偷国产偷亚洲高清人乐享,中文 在线 日韩 亚洲 欧美,熟妇人妻无乱码中文字幕真矢织江,一区二区三区人妻制服国产

歡迎訪問 生活随笔!

生活随笔

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

linux

【嵌入式Linux学习七步曲之第五篇 Linux内核及驱动编程】PowerPC + Linux2.6.25平台下的I2C驱动架构分析

發布時間:2024/9/21 linux 30 豆豆
生活随笔 收集整理的這篇文章主要介紹了 【嵌入式Linux学习七步曲之第五篇 Linux内核及驱动编程】PowerPC + Linux2.6.25平台下的I2C驱动架构分析 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

PowerPC + Linux2.6.25平臺下的I2C驅動架構分析

Sailor_forever? sailing_9806#163.com


(本原創文章發表于Sailor_forever 的個人blog,未經本人許可,不得用于商業用途。任何個人、媒體、其他網站不得私自抄襲;網絡媒體轉載請注明出處,增加原文鏈接,否則屬于侵權行為。如 有任何問題,請留言或者發郵件給sailing_9806#163.com)
http://blog.csdn.net/sailor_8318/archive/2010/09/25/5905988.aspx

?

【摘要】本文以PowerPC+Linux 2.6.25 平臺為例,詳細分析了I2C總線的驅動架構。首先介紹了I2C的總體架構,從用戶的角度將其分為三個層面,不同的開發者只需要關注相應的層面即可。然后分析了主要數據結構及其之間的相互關系,接著分析了不同層的具體實現,最后以一款EEPEOM為例講述了如何在用戶空間訪問I2C驅動。對于ARM + Linux平臺,只有平臺依賴層即總線適配器驅動有差異。

【關鍵字】PowerPC, I2C, i2c-core, adapter , i2c_algorithm, RTC, EEPROM

目錄

1??? I2C概述??? 3
2??? I2C總體架構??? 3
2.1??? 硬件抽象層??? 3
2.2??? 平臺依賴層??? 3
2.3??? 用戶接口層??? 3
3??? 主要的數據結構??? 4
3.1??? Adapter??? 4
3.2??? I2c_algorithm??? 5
3.3??? i2c_driver??? 5
3.4??? Client??? 6
4??? 平臺依賴層-總線適配器驅動??? 7
4.1??? platform device??? 7
4.2??? platform driver??? 9
4.3??? Adapter及algorithm??? 12
5??? 硬件抽象層-I2C core??? 13
5.1??? 總線初始化??? 13
5.2??? Adapter注冊??? 15
5.3??? 驅動注冊??? 16
5.4??? 數據傳輸??? 17
6??? 用戶接口層-I2C設備驅動??? 18
6.1??? 統一的設備模型??? 18
6.1.1??? 關鍵數據結構??? 18
6.1.2??? 初始化??? 19
6.1.3??? Open及release??? 21
6.1.4??? 數據收發??? 22
6.2??? 特定的設備驅動??? 26
6.2.1??? 關鍵數據結構??? 26
6.2.2??? 初始化??? 27
6.2.3??? 數據收發??? 29
7??? 驅動訪問示例??? 29
7.1.1??? 寫操作??? 29
7.1.2??? 讀操作??? 31
8??? 參考鳴謝??? 33

1??? I2C概述
I2C只有兩條線,一條串行數據線:SDA,一條是時鐘線SCL。I2C是一種多主機控制總線,同一總線上可允許多個master,即總線上的設備都有主動發起數據傳輸的可能,依靠線與邏輯來實現無損仲裁。但通常情況是總線上有個帶CPU的master,其他設備被master訪問。


2??? I2C總體架構
在2.6的Linux內核中,I2C的驅動架構分為如下三個層次:硬件抽象層、平臺依賴層和用戶接口層。
2.1??? 硬件抽象層
i2c-core.h和i2c-core.c為其主體框架代碼,提供了核心數據結構的定義、i2c適配器驅動和設備驅動的注冊、注銷管理等API。其為硬件平臺無關層,向下屏蔽了物理總線適配器的差異,定義了統一的訪問策略和接口;其向上提供了統一的接口,以便I2C設備驅動通過總線適配器進行數據收發。
2.2??? 平臺依賴層
i2c總線適配器(adapter)就是一條i2c總線的控制器(所謂控制是相對于本CPU來說的),在物理上連接若干i2c設備。在Linux驅動中,每種處理器平臺有自己的適配器驅動,屬于平臺移植相關層。每一個特定的硬件平臺在i2c/busses/目錄下都有一個adapter的實現,對于PowerPC平臺來說,其是i2c-mpc.c。其按照核心層定義的接口實現了i2c_adapter,提供了具體的訪問方式i2c_algorithm。
2.3??? 用戶接口層
設備驅動層為用戶接口層,其為用戶提供了通過I2C總線訪問具體設備的接口。

??????????????????????
?

3??? 主要的數據結構
3.1??? Adapter
Adapter是對某一條I2C總線的抽象,是特定總線的相關屬性的集合。
http://lxr.linux.no/#linux+v2.6.25/include/linux/i2c.h#L312?
312struct i2c_adapter {
?313??????? struct module *owner;
?314??????? unsigned int id;
?315??????? unsigned int class;
?316??????? const struct i2c_algorithm *algo; /* the algorithm to access the bus */
?317??????? void *algo_data;
?318
?319??????? /* --- administration stuff. */
?320??????? int (*client_register)(struct i2c_client *);
?321??????? int (*client_unregister)(struct i2c_client *);
?322
?323??????? /* data fields that are valid for all devices?? */
?324??????? u8 level;?????????????????????? /* nesting level for lockdep */
?325??????? struct mutex bus_lock;? //
?326??????? struct mutex clist_lock;
?327
?328??????? int timeout;
?329??????? int retries;
?330??????? struct device dev;????????????? /* the adapter device */
?331
?332??????? int nr;? /*該成員描述了總線號*/??
?333??????? struct list_head clients;?????? /* i2c_client結構鏈表,該結構包含device,driver和 adapter結構*/??
?334??????? char name[48];
?335??????? struct completion dev_released;
?336};?

Algo是和底層硬件的接口,標識了具體的物理總線傳輸的實現。
Clients為使用該總線的client鏈表。
Nr為該適配器也就是某條I2C總線占據的全局編號。
bus_lock總線的互斥鎖,防止總線沖突。

3.2??? I2c_algorithm

http://lxr.linux.no/#linux+v2.6.25/include/linux/i2c.h#L291
291struct i2c_algorithm {
?292??????? /* If an adapter algorithm can't do I2C-level access, set master_xfer
?293?????????? to NULL. If an adapter algorithm can do SMBus access, set
?294?????????? smbus_xfer. If set to NULL, the SMBus protocol is simulated
?295?????????? using common I2C messages */
?296??????? /* master_xfer should return the number of messages successfully
?297?????????? processed, or a negative value on error */
?298??????? int (*master_xfer)(struct i2c_adapter *adap,struct i2c_msg *msgs,
?299?????????????????????????? int num);
?300??????? int (*smbus_xfer) (struct i2c_adapter *adap, u16 addr,
?301?????????????????????????? unsigned short flags, char read_write,
?302?????????????????????????? u8 command, int size, union i2c_smbus_data * data);
?303
?304??????? /* To determine what the adapter supports */
?305??????? u32 (*functionality) (struct i2c_adapter *);
?306};
主要就是master_xfer方法,其和具體的總線控制器相關,不同的CPU在實現上可能有差異。

3.3??? i2c_driver
http://lxr.linux.no/#linux+v2.6.25/include/linux/i2c.h#L105
105struct i2c_driver {
?106??????? int id;
?107??????? unsigned int class;
?108
?109??????? /* Notifies the driver that a new bus has appeared. This routine
?110???????? * can be used by the driver to test if the bus meets its conditions
?111???????? * & seek for the presence of the chip(s) it supports. If found, it
?112???????? * registers the client(s) that are on the bus to the i2c admin. via
?113???????? * i2c_attach_client.? (LEGACY I2C DRIVERS ONLY)
?114???????? */
?115??????? int (*attach_adapter)(struct i2c_adapter *);
?116??????? int (*detach_adapter)(struct i2c_adapter *);
?117
?118??????? /* tells the driver that a client is about to be deleted & gives it
?119???????? * the chance to remove its private data. Also, if the client struct
?120???????? * has been dynamically allocated by the driver in the function above,
?121???????? * it must be freed here.? (LEGACY I2C DRIVERS ONLY)
?122???????? */
?123??????? int (*detach_client)(struct i2c_client *);
?124
?125??????? /* Standard driver model interfaces, for "new style" i2c drivers.
?126???????? * With the driver model, device enumeration is NEVER done by drivers;
?127???????? * it's done by infrastructure.? (NEW STYLE DRIVERS ONLY)
?128???????? */
?129??????? int (*probe)(struct i2c_client *);
?130??????? int (*remove)(struct i2c_client *);
?131
?132??????? /* driver model interfaces that don't relate to enumeration? */
?133??????? void (*shutdown)(struct i2c_client *);
?134??????? int (*suspend)(struct i2c_client *, pm_message_t mesg);
?135??????? int (*resume)(struct i2c_client *);
?136
?137??????? /* a ioctl like command that can be used to perform specific functions
?138???????? * with the device.
?139???????? */
?140??????? int (*command)(struct i2c_client *client,unsigned int cmd, void *arg);
?141
?142??????? struct device_driver driver;
?143};

Driver是為device服務的,i2c_driver注冊時會掃描i2c bus上的設備,進行驅動和設備的綁定。主要有兩種接口attach_adapter和probe,二者分別針對舊的和新式的驅動。
3.4??? Client
http://lxr.linux.no/#linux+v2.6.25/include/linux/i2c.h#L168
168struct i2c_client {
?169??????? unsigned short flags;?????????? /* div., see below????????????? */
?170??????? unsigned short addr;??????????? /* chip address - NOTE: 7bit??? */
?171??????????????????????????????????????? /* addresses are stored in the? */
?172??????????????????????????????????????? /* _LOWER_ 7 bits?????????????? */
?173??????? char name[I2C_NAME_SIZE];
?174??????? struct i2c_adapter *adapter;??? /* the adapter we sit on??????? */
?175??????? struct i2c_driver *driver;????? /* and our access routines????? */
?176??????? struct device dev;????????????? /* the device structure???????? */
?177??????? int irq;??????????????????????? /* irq issued by device (or -1) */
?178??????? char driver_name[KOBJ_NAME_LEN];
?179??????? struct list_head list;????????? /* DEPRECATED */
?180??????? struct completion released;
?181};

通常來說i2c_client對應著I2C總線上某個特定的slave或者是user space的某個用戶對應,而此時的slave可以動態變化。
4??? 平臺依賴層-總線適配器驅動
總線適配器驅動,本質上就是實現了具體的總線傳輸算法并向核心層注冊了適配器。主要分為三個層面,platform device,platform driver及與I2C core的接口層。

Linux內核的所有適配器驅動程序都在driver/i2c/busses/目錄下, MPC8xxx驅動是i2c-mpc.c。
4.1??? platform device
2.6內核中硬件資源的注冊都采用了platform device的機制。對于PowerPC來說,其硬件資源是通過DTS來描述的。
i2c@3000 {
??? #address-cells = <1>;
??? #size-cells = <0>;
??? cell-index = <0>;
??? compatible = "fsl-i2c";
??? reg = <0x3000 0x100>;
??? interrupts = <14 0x8>;
??? interrupt-parent = <&ipic>;
??? dfsrr;
};

i2c@3100 {
??? #address-cells = <1>;
??? #size-cells = <0>;
??? cell-index = <1>;
??? compatible = "fsl-i2c";
??? reg = <0x3100 0x100>;
??? interrupts = <15 0x8>;
??? interrupt-parent = <&ipic>;
??? dfsrr;
??? rtc@51 {? //legacy I2C device,靜態定義
??????????????????????? device_type = "rtc";
??????????????????????? compatible = "Philips,8563"; //設備類型
??????????????????????? reg = <0x51>;? //I2C地址
??????????????? };
};
中斷號及寄存器的基地址等信息會在設備樹中描述了,此后只需利用platform_get_resource等標準接口自動獲取即可,實現了驅動和資源的分離。cell-index標識了總線編號,也就是adapter的編號。

隨后在系統啟動階段會解析DTB文件,將相關資源注冊到Platform bus上。
http://lxr.linux.no/#linux+v2.6.25/arch/powerpc/sysdev/fsl_soc.c#L454

458static int __init fsl_i2c_of_init(void)
?501??????????????? of_register_i2c_devices(np, i++);
?429static void __init of_register_i2c_devices(struct device_node *adap_node,
?430?????????????????????????????????????????? int bus_num)
?431{
?432??????? struct device_node *node = NULL;
?433
?434??????? while ((node = of_get_next_child(adap_node, node))) {
?435??????????????? struct i2c_board_info info = {};
?436??????????????? const u32 *addr;
?437??????????????? int len;
?438
?439??????????????? addr = of_get_property(node, "reg", &len);
?440??????????????? if (!addr || len < sizeof(int) || *addr > (1 << 10) - 1) {
?441??????????????????????? printk(KERN_WARNING "fsl_soc.c: invalid i2c device entry/n");
?442??????????????????????? continue;
?443??????????????? }
?444
?445??????????????? info.irq = irq_of_parse_and_map(node, 0);
?446??????????????? if (info.irq == NO_IRQ)
?447??????????????????????? info.irq = -1;
?448
?449??????????????? if (of_find_i2c_driver(node, &info) < 0)
?450??????????????????????? continue;
?451
?452??????????????? info.addr = *addr;
?453
?454??????????????? i2c_register_board_info(bus_num, &info, 1);
?455??????? }
?456}
?397static struct i2c_driver_device i2c_devices[] __initdata = {
?398??????? {"ricoh,rs5c372a", "rtc-rs5c372", "rs5c372a",},
?399??????? {"ricoh,rs5c372b", "rtc-rs5c372", "rs5c372b",},
?400??????? {"ricoh,rv5c386",? "rtc-rs5c372", "rv5c386",},
?401??????? {"ricoh,rv5c387a", "rtc-rs5c372", "rv5c387a",},
?402??????? {"dallas,ds1307",? "rtc-ds1307",? "ds1307",},
?403??????? {"dallas,ds1337",? "rtc-ds1307",? "ds1337",},
?404??????? {"dallas,ds1338",? "rtc-ds1307",? "ds1338",},
?405??????? {"dallas,ds1339",? "rtc-ds1307",? "ds1339",},
?406??????? {"dallas,ds1340",? "rtc-ds1307",? "ds1340",},
?407??????? {"stm,m41t00",???? "rtc-ds1307",? "m41t00"},
?408??????? {"dallas,ds1374",? "rtc-ds1374",? "rtc-ds1374",},
?409};
?410
在i2c_devices列表里描述了那些采用傳統的I2C驅動的設備列表。同時DTS文件中也需要描述,二者會利用of_find_i2c_driver進行匹配。

?411static int __init of_find_i2c_driver(struct device_node *node,
?412???????????????????????????????????? struct i2c_board_info *info)
?413{
?414??????? int i;
?415
?416??????? for (i = 0; i < ARRAY_SIZE(i2c_devices); i++) {
?417??????????????? if (!of_device_is_compatible(node, i2c_devices[i].of_device))
?418??????????????????????? continue;
?419??????????????? if (strlcpy(info->driver_name, i2c_devices[i].i2c_driver,
?420??????????????????????????? KOBJ_NAME_LEN) >= KOBJ_NAME_LEN ||
?421??????????????????? strlcpy(info->type, i2c_devices[i].i2c_type,
?422??????????????????????????? I2C_NAME_SIZE) >= I2C_NAME_SIZE)
?423??????????????????????? return -ENOMEM;
?424??????????????? return 0;
?425??????? }
?426??????? return -ENODEV;
?427}

4.2??? platform driver
394
?395/* Structure for a device driver */
?396static struct platform_driver fsl_i2c_driver = {
?397??????? .probe = fsl_i2c_probe,
?398??????? .remove = fsl_i2c_remove,
?399??????? .driver = {
?400??????????????? .owner = THIS_MODULE,
?401??????????????? .name = "fsl-i2c",? //匹配因子
?402??????? },
?403};
?404
?405static int __init fsl_i2c_init(void)
?406{
?407??????? return platform_driver_register(&fsl_i2c_driver);
?408}
?409
?410static void __exit fsl_i2c_exit(void)
?411{
?412??????? platform_driver_unregister(&fsl_i2c_driver);
?413}
?414
?415module_init(fsl_i2c_init);
?416module_exit(fsl_i2c_exit);

fsl_i2c_driver注冊時會掃描platform bus上的所有設備,匹配因子是fsl-i2c,匹配成功后調用fsl_i2c_probe將設備和驅動綁定起來,具體過程參加《詳解Linux2.6內核中基于platform機制的驅動模型》,隨后向系統注冊一個adapter。
http://blog.csdn.net/sailor_8318/archive/2010/01/29/5267698.aspx

318static int fsl_i2c_probe(struct platform_device *pdev)
?319{
?320??????? int result = 0;
?321??????? struct mpc_i2c *i2c;
?322??????? struct fsl_i2c_platform_data *pdata;
?323??????? struct resource *r = platform_get_resource(pdev, IORESOURCE_MEM, 0);
?324
?325??????? pdata = (struct fsl_i2c_platform_data *) pdev->dev.platform_data;
?326
?327??????? i2c = kzalloc(sizeof(*i2c), GFP_KERNEL);
?328??????? if (!i2c)
?329??????????????? return -ENOMEM;
?330
?331??????? i2c->irq = platform_get_irq(pdev, 0);
?332??????? if (i2c->irq < 0) {
?333??????????????? result = -ENXIO;
?334??????????????? goto fail_get_irq;
?335??????? }
?336??????? i2c->flags = pdata->device_flags;
?337??????? init_waitqueue_head(&i2c->queue);
?338
?339??????? i2c->base = ioremap((phys_addr_t)r->start, MPC_I2C_REGION);
?340
?341??????? if (!i2c->base) {
?342??????????????? printk(KERN_ERR "i2c-mpc - failed to map controller/n");
?343??????????????? result = -ENOMEM;
?344??????????????? goto fail_map;
?345??????? }
?346
?347??????? if (i2c->irq != 0)
?348??????????????? if ((result = request_irq(i2c->irq, mpc_i2c_isr,
?349????????????????????????????????????????? IRQF_SHARED, "i2c-mpc", i2c)) < 0) {
?350??????????????????????? printk(KERN_ERR
?351?????????????????????????????? "i2c-mpc - failed to attach interrupt/n");
?352??????????????????????? goto fail_irq;
?353??????????????? }
?354
?355??????? mpc_i2c_setclock(i2c);
?356??????? platform_set_drvdata(pdev, i2c);
?357
?358??????? i2c->adap = mpc_ops;
?359??????? i2c->adap.nr = pdev->id;
?360??????? i2c_set_adapdata(&i2c->adap, i2c);
?361??????? i2c->adap.dev.parent = &pdev->dev;
?362??????? if ((result = i2c_add_numbered_adapter(&i2c->adap)) < 0) {
?363??????????????? printk(KERN_ERR "i2c-mpc - failed to add adapter/n");
?364??????????????? goto fail_add;
?365??????? }
?366
?367??????? return result;
?368
?369????? fail_add:
?370??????? if (i2c->irq != 0)
?371??????????????? free_irq(i2c->irq, i2c);
?372????? fail_irq:
?373??????? iounmap(i2c->base);
?374????? fail_map:
?375????? fail_get_irq:
?376??????? kfree(i2c);
?377??????? return result;
?378};
?379
?380static int fsl_i2c_remove(struct platform_device *pdev)
?381{
?382??????? struct mpc_i2c *i2c = platform_get_drvdata(pdev);
?383
?384??????? i2c_del_adapter(&i2c->adap);
?385??????? platform_set_drvdata(pdev, NULL);
?386
?387??????? if (i2c->irq != 0)
?388??????????????? free_irq(i2c->irq, i2c);
?389
?390??????? iounmap(i2c->base);
?391??????? kfree(i2c);
?392??????? return 0;
?393};
pdev->id為platform data中的devid,為I2C的總線編號,其在設備樹文件中描述。

PowerPC的adapter驅動使用了i2c_add_numbered_adapter()注冊,總線號最初保存在 platform_data中。

4.3??? Adapter及algorithm
這一層主要是定義了關鍵的數據結構adapter和algorithm。

http://lxr.linux.no/#linux+v2.6.25/drivers/i2c/busses/i2c-mpc.c#L309
309static struct i2c_adapter mpc_ops = {
?310??????? .owner = THIS_MODULE,
?311??????? .name = "MPC adapter",
?312??????? .id = I2C_HW_MPC107,
?313??????? .algo = &mpc_algo,
?314??????? .class = I2C_CLASS_HWMON,
?315??????? .timeout = 1,
?316};

304static const struct i2c_algorithm mpc_algo = {
?305??????? .master_xfer = mpc_xfer,
?306??????? .functionality = mpc_functionality,
?307};
?308

http://lxr.linux.no/#linux+v2.6.25/drivers/i2c/busses/i2c-mpc.c#L256
256static int mpc_xfer(struct i2c_adapter *adap, struct i2c_msg *msgs, int num)
?257{
?258??????? struct i2c_msg *pmsg;
?259??????? int i;
?260??????? int ret = 0;
?261??????? unsigned long orig_jiffies = jiffies;
?262??????? struct mpc_i2c *i2c = i2c_get_adapdata(adap);
?263
?264??????? mpc_i2c_start(i2c);
?265
?266??????? /* Allow bus up to 1s to become not busy */? //一定程度上避免總線沖突,收發數據前先查詢總線狀態
?267??????? while (readb(i2c->base + MPC_I2C_SR) & CSR_MBB) {
?268??????????????? if (signal_pending(current)) {
?269??????????????????????? pr_debug("I2C: Interrupted/n");
?270??????????????????????? writeccr(i2c, 0);
?271??????????????????????? return -EINTR;
?272??????????????? }
?273??????????????? if (time_after(jiffies, orig_jiffies + HZ)) {
?274??????????????????????? pr_debug("I2C: timeout/n");
?275??????????????????????? if (readb(i2c->base + MPC_I2C_SR) ==
?276??????????????????????????? (CSR_MCF | CSR_MBB | CSR_RXAK))
?277??????????????????????????????? mpc_i2c_fixup(i2c);
?278??????????????????????? return -EIO;
?279??????????????? }
?280??????????????? schedule();
?281??????? }
?282
?283??????? for (i = 0; ret >= 0 && i < num; i++) {
?284??????????????? pmsg = &msgs[i];
?285??????????????? pr_debug("Doing %s %d bytes to 0x%02x - %d of %d messages/n",
?286???????????????????????? pmsg->flags & I2C_M_RD ? "read" : "write",
?287???????????????????????? pmsg->len, pmsg->addr, i + 1, num);
?288??????????????? if (pmsg->flags & I2C_M_RD)
?289??????????????????????? ret =
?290??????????????????????????? mpc_read(i2c, pmsg->addr, pmsg->buf, pmsg->len, i);
?291??????????????? else
?292??????????????????????? ret =
?293??????????????????????????? mpc_write(i2c, pmsg->addr, pmsg->buf, pmsg->len, i);
?294??????? }
?295??????? mpc_i2c_stop(i2c);
?296??????? return (ret < 0) ? ret : num;
?297}


5??? 硬件抽象層-I2C core
5.1??? 總線初始化?
http://lxr.linux.no/#linux+v2.6.25/drivers/i2c/i2c-core.c#L914
?885static int __init i2c_init(void)
?886{
?887??????? int retval;
?888
?889??????? retval = bus_register(&i2c_bus_type);
?890??????? if (retval)
?891??????????????? return retval;
?892??????? retval = class_register(&i2c_adapter_class);
?893??????? if (retval)
?894??????????????? goto bus_err;
?895??????? retval = i2c_add_driver(&dummy_driver);
?896??????? if (retval)
?897??????????????? goto class_err;
?898??????? return 0;
?899
?900class_err:
?901??????? class_unregister(&i2c_adapter_class);
?902bus_err:
?903??????? bus_unregister(&i2c_bus_type);
?904??????? return retval;
?905}
?906
?907static void __exit i2c_exit(void)
?908{
?909??????? i2c_del_driver(&dummy_driver);
?910??????? class_unregister(&i2c_adapter_class);
?911??????? bus_unregister(&i2c_bus_type);
?912}
?913
?914subsys_initcall(i2c_init);
?915module_exit(i2c_exit);

關于被subsys_initcall修飾的i2c_init何時初始化,請參考下文《詳解Linux2.6內核中基于platform機制的驅動模型》
http://blog.csdn.net/sailor_8318/archive/2010/01/29/5267698.aspx
此時platform bus及platform device已經注冊完畢,因此I2C控制器的相關資源已經就緒。

該過程主要完成了sysfs總線結構,最終形成如下結構:
/sys/bus/i2c/
|-- devices
|-- drivers
|?? |-- dummy
|????? |-- bind
|????? |-- uevent
|????? `-- unbind
|-- drivers_autoprobe
|-- drivers_probe
`-- uevent

/sys/class/i2c-adapter/
dummy_driver 僅僅是注冊了一個空的設備驅動,注冊驅動時會遍歷加載/sys/class/i2c-adapter/中的所有設備,該過程在初始化總線過程中完成, /sys/class/i2c-adapter/基本為空,所以我認為這里的驅動注冊只是驗證i2c總線結構的完整性考慮的。

5.2??? Adapter注冊
在 kernel中提供了兩個adapter注冊接口,分別為i2c_add_adapter()和i2c_add_numbered_adapter()。 由于在系統中可能存在多個adapter,因此每一條I2C總線對應一個編號,下文中稱為I2C總線號。對于i2c_add_adapter()而言, 它使用的是動態總線號,即由系統給其分配一個總線號,而i2c_add_numbered_adapter()則是自己指定總線號,如果這個總線號非法或者是被占用,就會注冊失敗。

http://lxr.linux.no/#linux+v2.6.25/drivers/i2c/i2c-core.c#L403

403static int i2c_register_adapter(struct i2c_adapter *adap)
?404{
?405??????? int res = 0, dummy;
?406
?407??????? mutex_init(&adap->bus_lock);
?408??????? mutex_init(&adap->clist_lock);
?409??????? INIT_LIST_HEAD(&adap->clients);
?410
?411??????? mutex_lock(&core_lock);
?412
?413??????? /* Add the adapter to the driver core.
?414???????? * If the parent pointer is not set up,
?415???????? * we add this adapter to the host bus.
?416???????? */
?417??????? if (adap->dev.parent == NULL) {
?418??????????????? adap->dev.parent = &platform_bus;
?419??????????????? pr_debug("I2C adapter driver [%s] forgot to specify "
?420???????????????????????? "physical device/n", adap->name);
?421??????? }
?422??????? sprintf(adap->dev.bus_id, "i2c-%d", adap->nr);
?423??????? adap->dev.release = &i2c_adapter_dev_release;
?424??????? adap->dev.class = &i2c_adapter_class;
?425??????? res = device_register(&adap->dev);
?426??????? if (res)
?427??????????????? goto out_list;
?428
?429??????? dev_dbg(&adap->dev, "adapter [%s] registered/n", adap->name);
?430
?431??????? /* create pre-declared device nodes for new-style drivers */
?432??????? if (adap->nr < __i2c_first_dynamic_bus_num)
?433??????????????? i2c_scan_static_board_info(adap); //完成靜態定義的I2C設備的掃描,將設備和adapter掛上鉤,即將設備掛在總線上
?434
?435??????? /* let legacy drivers scan this bus for matching devices */
?436??????? dummy = bus_for_each_drv(&i2c_bus_type, NULL, adap,
?437???????????????????????????????? i2c_do_add_adapter); /*探測總線上的所有i2c設備驅動,如果匹配則完成client、driver、device、adapter的綁定*/??
?438
?439out_unlock:
?440??????? mutex_unlock(&core_lock);
?441??????? return res;
?442
?443out_list:
?444??????? idr_remove(&i2c_adapter_idr, adap->nr);
?445??????? goto out_unlock;
?446}

5.3??? 驅動注冊
http://lxr.linux.no/#linux+v2.6.25/drivers/i2c/i2c-core.c#L635
635int i2c_register_driver(struct module *owner, struct i2c_driver *driver)
?636{
?637??????? int res;
?638
?639??????? /* new style driver methods can't mix with legacy ones */
?640??????? if (is_newstyle_driver(driver)) {
?641??????????????? if (driver->attach_adapter || driver->detach_adapter
?642??????????????????????????????? || driver->detach_client) {
?643??????????????????????? printk(KERN_WARNING
?644??????????????????????????????????????? "i2c-core: driver [%s] is confused/n",
?645??????????????????????????????????????? driver->driver.name);
?646??????????????????????? return -EINVAL;
?647??????????????? }
?648??????? }
?649
?650??????? /* add the driver to the list of i2c drivers in the driver core */
?651??????? driver->driver.owner = owner;
?652??????? driver->driver.bus = &i2c_bus_type;
?653
?654??????? /* for new style drivers, when registration returns the driver core
?655???????? * will have called probe() for all matching-but-unbound devices.
?656???????? */
?657??????? res = driver_register(&driver->driver);
?658??????? if (res)
?659??????????????? return res;
?660
?661??????? mutex_lock(&core_lock);
?662
?663??????? pr_debug("i2c-core: driver [%s] registered/n", driver->driver.name);
?664
?665??????? /* legacy drivers scan i2c busses directly */
?666??????? if (driver->attach_adapter) {
?667??????????????? struct i2c_adapter *adapter;
?668
?669??????????????? down(&i2c_adapter_class.sem);
?670??????????????? list_for_each_entry(adapter, &i2c_adapter_class.devices,
?671??????????????????????????????????? dev.node) {
?672??????????????????????? driver->attach_adapter(adapter);
?673??????????????? }
?674??????????????? up(&i2c_adapter_class.sem);
?675??????? }
?676
?677??????? mutex_unlock(&core_lock);
?678??????? return 0;
?679}
?680EXPORT_SYMBOL(i2c_register_driver);

兩種注冊方式。對于new style驅動,將采用內核通用的驅動模型,其流程和platform driver的注冊過程類似,請請參考下文《詳解Linux2.6內核中基于platform機制的驅動模型》
http://blog.csdn.net/sailor_8318/archive/2010/01/29/5267698.aspx

而對于legacy driver,是如何匹配注冊的呢?TBD

5.4??? 數據傳輸
917/* ----------------------------------------------------
?918 * the functional interface to the i2c busses.
?919 * ----------------------------------------------------
?920 */
?921
?922int i2c_transfer(struct i2c_adapter * adap, struct i2c_msg *msgs, int num)
?923{
?924??????? int ret;
?925
?926??????? if (adap->algo->master_xfer) {
?927#ifdef DEBUG
?928??????????????? for (ret = 0; ret < num; ret++) {
?929??????????????????????? dev_dbg(&adap->dev, "master_xfer[%d] %c, addr=0x%02x, "
?930??????????????????????????????? "len=%d%s/n", ret, (msgs[ret].flags & I2C_M_RD)
?931??????????????????????????????? ? 'R' : 'W', msgs[ret].addr, msgs[ret].len,
?932??????????????????????????????? (msgs[ret].flags & I2C_M_RECV_LEN) ? "+" : "");
?933??????????????? }
?934#endif
?935
?936??????????????? if (in_atomic() || irqs_disabled()) { //原子上下文或者中斷禁止時不能獲取自旋鎖,防止休眠死鎖,只能試探鎖
?937??????????????????????? ret = mutex_trylock(&adap->bus_lock);
?938??????????????????????? if (!ret)
?939??????????????????????????????? /* I2C activity is ongoing. */
?940??????????????????????????????? return -EAGAIN;
?941??????????????? } else {
?942??????????????????????? mutex_lock_nested(&adap->bus_lock, adap->level);
?943??????????????? }
?944
?945??????????????? ret = adap->algo->master_xfer(adap,msgs,num);
?946??????????????? mutex_unlock(&adap->bus_lock);
?947
?948??????????????? return ret;
?949??????? } else {
?950??????????????? dev_dbg(&adap->dev, "I2C level transfers not supported/n");
?951??????????????? return -ENOSYS;
?952??????? }
?953}
?954EXPORT_SYMBOL(i2c_transfer);

核心層提供的通用數據收發接口,屏蔽了底層差異。利用adapter進行數據傳輸前先獲得互斥鎖,因此保證只有一個調用者占用總線,這樣數據傳輸才是原子的。多個msgs可以一次傳輸完畢,因此對于讀操作,兩次I2C總線的訪問(先寫后讀)需要在一個io ctrl中處理完畢

6??? 用戶接口層-I2C設備驅動
6.1??? 統一的設備模型
此驅動模型是針對I2C控制器的,因為對I2C slave的尋址是通過報文的內容來實現的,而對于I2C控制器來說,slave的地址僅僅是某個具體的報文而已,對控制器來說是透明的,因此用戶空間訪問的設備本質上就是I2C控制器。
6.1.1??? 關鍵數據結構
550static struct i2c_driver i2cdev_driver = {
?551??????? .driver = {
?552??????????????? .name?? = "dev_driver",
?553??????? },
?554??????? .id???????????? = I2C_DRIVERID_I2CDEV,
?555??????? .attach_adapter = i2cdev_attach_adapter,
?556??????? .detach_adapter = i2cdev_detach_adapter,
?557??????? .detach_client? = i2cdev_detach_client,
?558};
定義了一個標準的i2c_driver。

? 41/*
? 42 * An i2c_dev represents an i2c_adapter ... an I2C or SMBus master, not a
? 43 * slave (i2c_client) with which messages will be exchanged.? It's coupled
? 44 * with a character special file which is accessed by user mode drivers.
? 45 *
? 46 * The list of i2c_dev structures is parallel to the i2c_adapter lists
? 47 * maintained by the driver model, and is updated using notifications
? 48 * delivered to the i2cdev_driver.
? 49 */
? 50struct i2c_dev {
? 51??????? struct list_head list;
? 52??????? struct i2c_adapter *adap;
? 53??????? struct device *dev;
? 54};
? 55
? 56#define I2C_MINORS????? 256
? 57static LIST_HEAD(i2c_dev_list);
? 58static DEFINE_SPINLOCK(i2c_dev_list_lock);
定義了一個i2c_dev列表,每個adapter對應一個i2c_dev。

478static const struct file_operations i2cdev_fops = {
?479??????? .owner????????? = THIS_MODULE,
?480??????? .llseek???????? = no_llseek,
?481??????? .read?????????? = i2cdev_read,
?482??????? .write????????? = i2cdev_write,
?483??????? .ioctl????????? = i2cdev_ioctl,
?484??????? .open?????????? = i2cdev_open,
?485??????? .release??????? = i2cdev_release,
?486};
?487
任意一個需要和用戶空間通信的驅動必備的數據結構,其定義了具體的讀寫操作方法。

6.1.2??? 初始化
http://lxr.linux.no/#linux+v2.6.25/drivers/i2c/i2c-dev.c#L607
566static int __init i2c_dev_init(void)
?567{
?568??????? int res;
?569
?570??????? printk(KERN_INFO "i2c /dev entries driver/n");
?571
?572??????? res = register_chrdev(I2C_MAJOR, "i2c", &i2cdev_fops);
?573??????? if (res)
?574??????????????? goto out;
?575
?576??????? i2c_dev_class = class_create(THIS_MODULE, "i2c-dev");
?577??????? if (IS_ERR(i2c_dev_class))
?578??????????????? goto out_unreg_chrdev;
?579
?580??????? res = i2c_add_driver(&i2cdev_driver);
?581??????? if (res)
?582??????????????? goto out_unreg_class;
?583
?584??????? return 0;
?585
?586out_unreg_class:
?587??????? class_destroy(i2c_dev_class);
?588out_unreg_chrdev:
?589??????? unregister_chrdev(I2C_MAJOR, "i2c");
?590out:
?591??????? printk(KERN_ERR "%s: Driver Initialisation failed/n", __FILE__);
?592??????? return res;
?593}
?594
?595static void __exit i2c_dev_exit(void)
?596{
?597??????? i2c_del_driver(&i2cdev_driver);
?598??????? class_destroy(i2c_dev_class);
?599??????? unregister_chrdev(I2C_MAJOR,"i2c");
?600}
首先注冊了一個字符型設備驅動,然后注冊i2c_driver,將驅動和adapter綁定起來,匹配成功后將調用i2c_driver 的attach_adapter 方法,即i2cdev_attach_adapter, 建立dev設備節點,并維護了一個i2c_dev鏈表保存設備節點和adapter的關系。


http://lxr.linux.no/#linux+v2.6.25/drivers/i2c/i2c-dev.c#L498
498static int i2cdev_attach_adapter(struct i2c_adapter *adap)
?499{
?500??????? struct i2c_dev *i2c_dev;
?501??????? int res;
?502
?503??????? i2c_dev = get_free_i2c_dev(adap);? //添加一個adapter到i2c_dev列表中
?504??????? if (IS_ERR(i2c_dev))
?505??????????????? return PTR_ERR(i2c_dev);
?506
?507??????? /* register this i2c device with the driver core */
?508??????? i2c_dev->dev = device_create(i2c_dev_class, &adap->dev,
?509???????????????????????????????????? MKDEV(I2C_MAJOR, adap->nr),
?510???????????????????????????????????? "i2c-%d", adap->nr);
?511??????? if (IS_ERR(i2c_dev->dev)) {
?512??????????????? res = PTR_ERR(i2c_dev->dev);
?513??????????????? goto error;
?514??????? }
?515??????? res = device_create_file(i2c_dev->dev, &dev_attr_name);
?516??????? if (res)
?517??????????????? goto error_destroy;
?518
?519??????? pr_debug("i2c-dev: adapter [%s] registered as minor %d/n",
?520???????????????? adap->name, adap->nr);
?521??????? return 0;
?522error_destroy:
?523??????? device_destroy(i2c_dev_class, MKDEV(I2C_MAJOR, adap->nr));
?524error:
?525??????? return_i2c_dev(i2c_dev);
?526??????? return res;
?527}
以I2C_MAJOR和adap->nr為主從設備號注冊設備節點,如果系統有udev或者是hotplug,那么就么在/dev下自動創建相關的設備節點了

6.1.3??? Open及release
431static int i2cdev_open(struct inode *inode, struct file *file)
?432{
?433??????? unsigned int minor = iminor(inode);
?434??????? struct i2c_client *client;
?435??????? struct i2c_adapter *adap;
?436??????? struct i2c_dev *i2c_dev;
?437
?438??????? i2c_dev = i2c_dev_get_by_minor(minor); //由次設備號獲得i2c_dev即可獲得對應的adapter
?439??????? if (!i2c_dev)
?440??????????????? return -ENODEV;
?441
?442??????? adap = i2c_get_adapter(i2c_dev->adap->nr);? //對module引用進行計數
?443??????? if (!adap)
?444??????????????? return -ENODEV;
?445
?446??????? /* This creates an anonymous i2c_client, which may later be
?447???????? * pointed to some address using I2C_SLAVE or I2C_SLAVE_FORCE.
?448???????? *
?449???????? * This client is ** NEVER REGISTERED ** with the driver model
?450???????? * or I2C core code!!? It just holds private copies of addressing
?451???????? * information and maybe a PEC flag.
?452???????? */
?453??????? client = kzalloc(sizeof(*client), GFP_KERNEL);
?454??????? if (!client) {
?455??????????????? i2c_put_adapter(adap);
?456??????????????? return -ENOMEM;
?457??????? }
?458??????? snprintf(client->name, I2C_NAME_SIZE, "i2c-dev %d", adap->nr);
?459??????? client->driver = &i2cdev_driver;
?460
?461??????? client->adapter = adap;
?462??????? file->private_data = client;
?463
?464??????? return 0;
?465}

Open操作是用戶空間程序和內核驅動交換的第一步,最終返回給用戶空間的就是struct file結構體。對于I2C 驅動來說,用戶空間所獲得的就是client這個關鍵信息,在其中可以找到所有有關的信息如client所在的adapter及i2c_driver。此i2c_client并沒有遵循設備模型的方式注冊進系統,在sys下面沒有任何信息。
6.1.4??? 數據收發
對于I2C驅動來說,數據收發有兩種途徑,read/write或者ioctl方式。
對于read/write方式來說,必須先通過ioctl的I2C_SLAVE設置從設備的地址。隨后再通過read/write對相應的slave直接進行數據收發。

117/*
?118 * After opening an instance of this character special file, a file
?119 * descriptor starts out associated only with an i2c_adapter (and bus).
?120 *
?121 * Using the I2C_RDWR ioctl(), you can then *immediately* issue i2c_msg
?122 * traffic to any devices on the bus used by that adapter.? That's because
?123 * the i2c_msg vectors embed all the addressing information they need, and
?124 * are submitted directly to an i2c_adapter.? However, SMBus-only adapters
?125 * don't support that interface.
?126 *
?127 * To use read()/write() system calls on that file descriptor, or to use
?128 * SMBus interfaces (and work with SMBus-only hosts!), you must first issue
?129 * an I2C_SLAVE (or I2C_SLAVE_FORCE) ioctl.? That configures an anonymous
?130 * (never registered) i2c_client so it holds the addressing information
?131 * needed by those system calls and by this SMBus interface.
?132 */
?133
?134static ssize_t i2cdev_read (struct file *file, char __user *buf, size_t count,
?135??????????????????????????? loff_t *offset)
?136{

read/write與用戶空間的接口是buf和count,為收發的相應數據指針和數據長度。
SMBus只能利用read/write方式和用戶空間通信??

對于ioctl方式,相關的cmd是I2C_RDWR

203static int i2cdev_ioctl(struct inode *inode, struct file *file,
?204??????????????? unsigned int cmd, unsigned long arg)
?205{
?206??????? struct i2c_client *client = (struct i2c_client *)file->private_data;
?207??????? struct i2c_rdwr_ioctl_data rdwr_arg;
?208??????? struct i2c_smbus_ioctl_data data_arg;
?209??????? union i2c_smbus_data temp;
?210??????? struct i2c_msg *rdwr_pa;
?211??????? u8 __user **data_ptrs;
?212??????? int i,datasize,res;
?213??????? unsigned long funcs;

255??????? case I2C_RDWR:
?256??????????????? if (copy_from_user(&rdwr_arg,
?257?????????????????????????????????? (struct i2c_rdwr_ioctl_data __user *)arg,
?258?????????????????????????????????? sizeof(rdwr_arg)))
?259??????????????????????? return -EFAULT;
?260
?261??????????????? /* Put an arbitrary limit on the number of messages that can
?262???????????????? * be sent at once */
?263??????????????? if (rdwr_arg.nmsgs > I2C_RDRW_IOCTL_MAX_MSGS)
?264??????????????????????? return -EINVAL;
?265
?266??????????????? rdwr_pa = (struct i2c_msg *)
?267??????????????????????? kmalloc(rdwr_arg.nmsgs * sizeof(struct i2c_msg),
?268??????????????????????? GFP_KERNEL);
?269
?270??????????????? if (rdwr_pa == NULL) return -ENOMEM;
?271
?272??????????????? if (copy_from_user(rdwr_pa, rdwr_arg.msgs,
?273?????????????????????????????????? rdwr_arg.nmsgs * sizeof(struct i2c_msg))) {
?274??????????????????????? kfree(rdwr_pa);
?275??????????????????????? return -EFAULT;
?276??????????????? }
?277
?278??????????????? data_ptrs = kmalloc(rdwr_arg.nmsgs * sizeof(u8 __user *), GFP_KERNEL);
?279??????????????? if (data_ptrs == NULL) {
?280??????????????????????? kfree(rdwr_pa);
?281??????????????????????? return -ENOMEM;
?282??????????????? }
?283
?284??????????????? res = 0;
?285??????????????? for( i=0; i<rdwr_arg.nmsgs; i++ ) {
?286??????????????????????? /* Limit the size of the message to a sane amount;
?287???????????????????????? * and don't let length change either. */
?288??????????????????????? if ((rdwr_pa[i].len > 8192) ||
?289??????????????????????????? (rdwr_pa[i].flags & I2C_M_RECV_LEN)) {
?290??????????????????????????????? res = -EINVAL;
?291??????????????????????????????? break;
?292??????????????????????? }
?293??????????????????????? data_ptrs[i] = (u8 __user *)rdwr_pa[i].buf;
?294??????????????????????? rdwr_pa[i].buf = kmalloc(rdwr_pa[i].len, GFP_KERNEL);
?295??????????????????????? if(rdwr_pa[i].buf == NULL) {
?296??????????????????????????????? res = -ENOMEM;
?297??????????????????????????????? break;
?298??????????????????????? }
?299??????????????????????? if(copy_from_user(rdwr_pa[i].buf,
?300??????????????????????????????? data_ptrs[i],
?301??????????????????????????????? rdwr_pa[i].len)) {
?302??????????????????????????????????????? ++i; /* Needs to be kfreed too */
?303??????????????????????????????????????? res = -EFAULT;
?304??????????????????????????????? break;
?305??????????????????????? }
?306??????????????? }
?307??????????????? if (res < 0) {
?308??????????????????????? int j;
?309??????????????????????? for (j = 0; j < i; ++j)
?310??????????????????????????????? kfree(rdwr_pa[j].buf);
?311??????????????????????? kfree(data_ptrs);
?312??????????????????????? kfree(rdwr_pa);
?313??????????????????????? return res;
?314??????????????? }
?315
//上述所有操作就是將用戶空間的數據拷貝到內核空間。組織成以rdwr_pa為首地址的nmsgs個msg
?316??????????????? res = i2c_transfer(client->adapter,
?317??????????????????????? rdwr_pa,
?318??????????????????????? rdwr_arg.nmsgs);
?319??????????????? while(i-- > 0) {
?320??????????????????????? if( res>=0 && (rdwr_pa[i].flags & I2C_M_RD)) {
?321??????????????????????????????? if(copy_to_user(? //如果是讀操作,再將內核空間中緩存的數據拷貝到用戶空間
?322??????????????????????????????????????? data_ptrs[i],
?323??????????????????????????????????????? rdwr_pa[i].buf,
?324??????????????????????????????????????? rdwr_pa[i].len)) {
?325??????????????????????????????????????? res = -EFAULT;
?326??????????????????????????????? }
?327??????????????????????? }
?328??????????????????????? kfree(rdwr_pa[i].buf);
?329??????????????? }
?330??????????????? kfree(data_ptrs);
?331??????????????? kfree(rdwr_pa);
?332??????????????? return res;

與用戶空間的接口是i2c_rdwr_ioctl_data
/* This is the structure as used in the I2C_RDWR ioctl call */
struct i2c_rdwr_ioctl_data {
??? struct i2c_msg __user *msgs;??? /* pointers to i2c_msgs */
??? __u32 nmsgs;??? ??? ??? /* number of i2c_msgs */
};
所有待收發的數據都已經由用戶空間組織好了

/**
?* struct i2c_msg - an I2C transaction segment beginning with START
?* @addr: Slave address, either seven or ten bits.? When this is a ten
?*??? bit address, I2C_M_TEN must be set in @flags and the adapter
?*??? must support I2C_FUNC_10BIT_ADDR.
?* @flags: I2C_M_RD is handled by all adapters.? No other flags may be
?*??? provided unless the adapter exported the relevant I2C_FUNC_*
?*??? flags through i2c_check_functionality().
?* @len: Number of data bytes in @buf being read from or written to the
?*??? I2C slave address.? For read transactions where I2C_M_RECV_LEN
?*??? is set, the caller guarantees that this buffer can hold up to
?*??? 32 bytes in addition to the initial length byte sent by the
?*??? slave (plus, if used, the SMBus PEC); and this value will be
?*??? incremented by the number of block data bytes received.
?* @buf: The buffer into which data is read, or from which it's written.
?*
?* An i2c_msg is the low level representation of one segment of an I2C
?* transaction.? It is visible to drivers in the @i2c_transfer() procedure,
?* to userspace from i2c-dev, and to I2C adapter drivers through the
?* @i2c_adapter.@master_xfer() method.
?*
?* Except when I2C "protocol mangling" is used, all I2C adapters implement
?* the standard rules for I2C transactions.? Each transaction begins with a
?* START.? That is followed by the slave address, and a bit encoding read
?* versus write.? Then follow all the data bytes, possibly including a byte
?* with SMBus PEC.? The transfer terminates with a NAK, or when all those
?* bytes have been transferred and ACKed.? If this is the last message in a
?* group, it is followed by a STOP.? Otherwise it is followed by the next
?* @i2c_msg transaction segment, beginning with a (repeated) START.
?*
?* Alternatively, when the adapter supports I2C_FUNC_PROTOCOL_MANGLING then
?* passing certain @flags may have changed those standard protocol behaviors.
?* Those flags are only for use with broken/nonconforming slaves, and with
?* adapters which are known to support the specific mangling options they
?* need (one or more of IGNORE_NAK, NO_RD_ACK, NOSTART, and REV_DIR_ADDR).
?*/
struct i2c_msg {
??? __u16 addr;??? /* slave address??? ??? ??? */
??? __u16 flags;
#define I2C_M_TEN??? ??? 0x0010??? /* this is a ten bit chip address */
#define I2C_M_RD??? ??? 0x0001??? /* read data, from slave to master */
。。。
#define I2C_M_RECV_LEN??? ??? 0x0400??? /* length will be first received byte */
??? __u16 len;??? ??? /* msg length??? ??? ??? ??? */
??? __u8 *buf;??? ??? /* pointer to msg data??? ??? ??? */
};

6.2??? 特定的設備驅動
原則上所有的I2C從設備的方法都可以通過上述統一的設備模型I2c-dev來訪問,但I2c-dev上傳輸的是透明的數據,而對于某些I2C從設備,其數據傳輸遵循一定的格式,如果用I2c-dev來訪問,則用戶需要組織好所有的i2c_msg,對一般用戶來說可能比較復雜。為了提供更加user friendly的接口,可以對特定I2C從設備的訪問進行再次封裝。

如I2C的RTC,其數據的轉換較為復雜,為了減少用戶空間的轉換,提供了專用的RTC驅動供用戶程序訪問,其向上屏蔽了具體RTC芯片的差異。

下面以drivers/rtc/rtc-pcf8563.c為例來進行講述。
6.2.1??? 關鍵數據結構
struct pcf8563 {
??? struct i2c_client client;
??? /*
??? ?* The meaning of MO_C bit varies by the chip type.
??? ?* From PCF8563 datasheet: this bit is toggled when the years
??? ?* register overflows from 99 to 00
??? ?*?? 0 indicates the century is 20xx
??? ?*?? 1 indicates the century is 19xx
??? ?* From RTC8564 datasheet: this bit indicates change of
??? ?* century. When the year digit data overflows from 99 to 00,
??? ?* this bit is set. By presetting it to 0 while still in the
??? ?* 20th century, it will be set in year 2000, ...
??? ?* There seems no reliable way to know how the system use this
??? ?* bit.? So let's do it heuristically, assuming we are live in
??? ?* 1970...2069.
??? ?*/
??? int c_polarity;??? /* 0: MO_C=1 means 19xx, otherwise MO_C=1 means 20xx */
};
pcf8563關鍵信息的全局表示。

static struct i2c_driver pcf8563_driver = {
??? .driver??? ??? = {
??? ??? .name??? = "pcf8563",
??? },
??? .id??? ??? = I2C_DRIVERID_PCF8563,
??? .attach_adapter = &pcf8563_attach,
??? .detach_client??? = &pcf8563_detach,
};
特定的pcf8563_driver,有自己特定的pcf8563_attach方法。

static const struct rtc_class_ops pcf8563_rtc_ops = {
??? .read_time??? = pcf8563_rtc_read_time,
??? .set_time??? = pcf8563_rtc_set_time,
};
向RTC子系統注冊的讀寫方法。
6.2.2??? 初始化
static int __init pcf8563_init(void)
{
??? return i2c_add_driver(&pcf8563_driver);
}

static void __exit pcf8563_exit(void)
{
??? i2c_del_driver(&pcf8563_driver);
}

調用i2c_add_driver向I2C總線上注冊pcf8563_driver的I2C驅動,根據pcf8563這個driver的name進行匹配,匹配成功后將自動調用pcf8563_attach。

static int pcf8563_probe(struct i2c_adapter *adapter, int address, int kind)
{
??? struct pcf8563 *pcf8563;
??? struct i2c_client *client;
??? struct rtc_device *rtc;

??? int err = 0;

??? dev_dbg(&adapter->dev, "%s/n", __FUNCTION__);

??? if (!i2c_check_functionality(adapter, I2C_FUNC_I2C)) {
??? ??? err = -ENODEV;
??? ??? goto exit;
??? }

??? if (!(pcf8563 = kzalloc(sizeof(struct pcf8563), GFP_KERNEL))) {
??? ??? err = -ENOMEM;
??? ??? goto exit;
??? }

??? client = &pcf8563->client;
??? client->addr = address;? //此address即為該slave的I2C設備地址
??? client->driver = &pcf8563_driver;
??? client->adapter??? = adapter;
//上述幾步和統一的I2C設備模型的client一樣

??? strlcpy(client->name, pcf8563_driver.driver.name, I2C_NAME_SIZE);

??? /* Verify the chip is really an PCF8563 */
??? if (kind < 0) {
??? ??? if (pcf8563_validate_client(client) < 0) {? //探測相關slave是否存在,簡單的收發數據進行驗證
??? ??? ??? err = -ENODEV;
??? ??? ??? goto exit_kfree;
??? ??? }
??? }

??? /* Inform the i2c layer */
??? if ((err = i2c_attach_client(client)))? //將本client掛接到依附的adapter上??? ??? goto exit_kfree;

??? dev_info(&client->dev, "chip found, driver version " DRV_VERSION "/n");

??? rtc = rtc_device_register(pcf8563_driver.driver.name, &client->dev,
??? ??? ??? ??? &pcf8563_rtc_ops, THIS_MODULE);
//向RTC子系統注冊pcf8563設備

??? if (IS_ERR(rtc)) {
??? ??? err = PTR_ERR(rtc);
??? ??? goto exit_detach;
??? }

??? i2c_set_clientdata(client, rtc);

??? return 0;

exit_detach:
??? i2c_detach_client(client);

exit_kfree:
??? kfree(pcf8563);

exit:
??? return err;
}

6.2.3??? 數據收發
RTC設備的數據收發是通過drivers/rtc/rtc-dev.c進行的。
static const struct file_operations rtc_dev_fops = {
??? .owner??? ??? = THIS_MODULE,
??? .llseek??? ??? = no_llseek,
??? .read??? ??? = rtc_dev_read,
??? .poll??? ??? = rtc_dev_poll,
??? .ioctl??? ??? = rtc_dev_ioctl,
??? .open??? ??? = rtc_dev_open,
??? .release??? = rtc_dev_release,
??? .fasync??? ??? = rtc_dev_fasync,
};
該file_operations向用戶空間提供了統一接口。

7??? 驅動訪問示例
下面以一款EEPOM AT24C64AN為例來講述用戶空間如何訪問I2C設備。
7.1.1??? 寫操作
I2C總線的寫操作通常比較簡單,分為byte write和page write
?
但兩種方式對于SW來說沒有區別,SW只需要指定發送的數據長度即可。
/**********
i2cBus為總線編號,也就是adapter編號,應該是本I2C設備所掛接的I2C總線
devAddr,為待訪問的I2C設備地址
bTwoByteAddr,為待訪問的從設備內部寄存器偏移量地址的寬度,即8位或16位,對應1或2個字節
offAddr,為待訪問的從設備內部寄存器偏移量起始地址
byteLen,待寫的數據長度,不包括總線協議上的dev addr及word address
i2cBuff1,待發送到有效數據即DATA
********/
int i2c_write(BYTE i2cBus, BYTE devAddr, BOOL bTwoByteAddr,
?????????????????????????? WORD offAddr, WORD byteLen, BYTE* i2cBuff1)
{
? char?? fileName[20];
? BYTE?? i2cBuff0[256];?? /* buffer to send offset address & data*/
? int??? file, iRealDataStart;
??
? sprintf(fileName, "/dev/i2c-%d", i2cBus);? //打開相應的I2C總線設備
??
? file = open(fileName, O_RDWR);
? if (file < 0)
? {
??? fprintf(stderr, "Fail: Could not open file `/dev/i2c-%d': %s/n", /
??? i2cBus, strerror(ENOENT));
??? return -1;
? }
??
? if(!bTwoByteAddr)
? {
??? i2cBuff0[0] = (BYTE)(offAddr & 0x00FF);
??? iRealDataStart = 1;
? }
? else
? {
??? i2cBuff0[0] = (BYTE)((offAddr & 0xFF00)>>8);
??? i2cBuff0[1] = (BYTE)(offAddr & 0x00FF);
??? iRealDataStart = 2;
? }
??
? /* Build write buffer */
? memcpy(&i2cBuff0[iRealDataStart], i2cBuff1, byteLen);? //構造i2c_msg中的buf
??
? sI2ccMessages[0].addr = devAddr;
? sI2ccMessages[0].flags = 0; /* Write flag = 0 */
? sI2ccMessages[0].len = byteLen + iRealDataStart;? //此長度為DATA和WORD ADDRESS
? sI2ccMessages[0].buf = i2cBuff0;
??
? sI2ccIoctData.msgs = sI2ccMessages;
? sI2ccIoctData.nmsgs = 1;
??
? if (ioctl(file, I2C_RDWR, &sI2ccIoctData) < 0)
? {
??? fprintf(stderr, "Fail: fails to write to I2C device 0x%x at address 0x%x/n", devAddr, offAddr);
??? close(file);
??? return -1;
? }
??
? close(file);
??
? return 0;
}

7.1.2??? 讀操作
I2C設備的讀操作較復雜,需要先寫待讀的內部寄存器地址,然后再發起總線的讀操作。時序如下:
?
因此需要在總線上連續進行兩次數據傳輸,即兩個i2c_msg。

/**********
i2cBus為總線編號,也就是adapter編號,應該是本I2C設備所掛接的I2C總線
devAddr,為待訪問的I2C設備地址
bTwoByteAddr,為待訪問的從設備內部寄存器偏移量地址的寬度,即8位或16位,對應1或2個字節
offAddr,為待訪問的從設備內部寄存器偏移量起始地址
byteLen,待讀的數據長度
i2cBuff1,待讀的有效數據即DATA
********/

int i2c_read(BYTE i2cBus, BYTE devAddr, BOOL bTwoByteAddr,
?????????????????????????? WORD offAddr, WORD byteLen, BYTE* i2cBuff1)
{
? char?? fileName[20];
? BYTE?? i2cBuff0[2];???? /* buffer to send offset address */
? int??? file= 0;
??
? sprintf(fileName, "/dev/i2c-%d", i2cBus);
??
? file = open(fileName, O_RDWR);
? if (file < 0)
? {
??? fprintf(stderr, "Fail: Could not open file `/dev/i2c-%d': %s/n", /
??????????? i2cBus, strerror(ENOENT));
????
??? return -1;
? }
??
? sI2ccMessages[0].addr = devAddr;
? sI2ccMessages[0].flags = 0; /* write flag = 0 */
??
? if(!bTwoByteAddr)
? {
??? i2cBuff0[0] = (BYTE)(offAddr & 0x00FF);
??? sI2ccMessages[0].len = 1;??
? }
? else
? {
??? i2cBuff0[0] = (BYTE)((offAddr& 0xFF00)>>8);
??? i2cBuff0[1] = (BYTE)(offAddr& 0x00FF);
??? sI2ccMessages[0].len = 2;
? }
? sI2ccMessages[0].buf = i2cBuff0;? //第一個msg只是一個默認的寫操作
??
? sI2ccMessages[1].addr = devAddr;
? sI2ccMessages[1].flags = I2C_M_RD; /* read flag */
? sI2ccMessages[1].len = byteLen;
? sI2ccMessages[1].buf = i2cBuff1;? //此僅僅為DATA域
??
? sI2ccIoctData.msgs = sI2ccMessages;
? sI2ccIoctData.nmsgs = 2;
??
? if (ioctl(file, I2C_RDWR, &sI2ccIoctData) < 0)? //一個ioctl必須連續發送兩個msg
? {
??? fprintf(stderr, "Fail: fails to read from I2C device 0x%x at address 0x%x/n", /
??????????? devAddr, offAddr);
??? close(file);
??? return -1;
? }
??
? close(file);
? return 0;
}

8??? 參考鳴謝

http://blog.chinaunix.net/u1/51562/showart_1403925.html
http://blog.csdn.net/tjd0227/archive/2010/07/21/5753606.aspx

總結

以上是生活随笔為你收集整理的【嵌入式Linux学习七步曲之第五篇 Linux内核及驱动编程】PowerPC + Linux2.6.25平台下的I2C驱动架构分析的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。

久久久精品成人免费观看 | 国产午夜手机精彩视频 | 天天做天天爱天天爽综合网 | 欧美喷潮久久久xxxxx | 成熟女人特级毛片www免费 | 5858s亚洲色大成网站www | 国产高清不卡无码视频 | 99精品久久毛片a片 | 中文字幕无码视频专区 | 久久久久久a亚洲欧洲av冫 | 白嫩日本少妇做爰 | 九九热爱视频精品 | 人妻少妇精品视频专区 | 午夜精品久久久内射近拍高清 | 久久精品99久久香蕉国产色戒 | 日产精品高潮呻吟av久久 | 大色综合色综合网站 | 狂野欧美性猛xxxx乱大交 | 天堂а√在线地址中文在线 | 国产亚洲视频中文字幕97精品 | 中文字幕人成乱码熟女app | 爽爽影院免费观看 | 国产精品va在线观看无码 | 在线成人www免费观看视频 | 成人精品视频一区二区 | 亚洲精品国产a久久久久久 | 扒开双腿吃奶呻吟做受视频 | 中文字幕乱妇无码av在线 | 色欲人妻aaaaaaa无码 | 帮老师解开蕾丝奶罩吸乳网站 | 亚洲人成人无码网www国产 | 国产无遮挡又黄又爽免费视频 | 亚洲一区二区三区在线观看网站 | 人妻少妇被猛烈进入中文字幕 | 欧美性猛交内射兽交老熟妇 | 亚洲区小说区激情区图片区 | 性欧美videos高清精品 | 精品人人妻人人澡人人爽人人 | 天天摸天天透天天添 | 久久www免费人成人片 | 内射白嫩少妇超碰 | 国产明星裸体无码xxxx视频 | 欧美午夜特黄aaaaaa片 | 乱人伦中文视频在线观看 | 免费视频欧美无人区码 | 欧美三级不卡在线观看 | 亚洲精品国产第一综合99久久 | 特级做a爰片毛片免费69 | 久久成人a毛片免费观看网站 | 免费网站看v片在线18禁无码 | 国内少妇偷人精品视频 | 亚洲精品综合五月久久小说 | 久久www免费人成人片 | 国产九九九九九九九a片 | 爆乳一区二区三区无码 | 影音先锋中文字幕无码 | 99久久精品午夜一区二区 | 蜜桃视频插满18在线观看 | 欧美日韩视频无码一区二区三 | 国产午夜无码视频在线观看 | 日日麻批免费40分钟无码 | 亚洲 a v无 码免 费 成 人 a v | 欧洲精品码一区二区三区免费看 | 沈阳熟女露脸对白视频 | 国产日产欧产精品精品app | 在线精品国产一区二区三区 | 九一九色国产 | 国内揄拍国内精品少妇国语 | 亚洲成av人综合在线观看 | 欧美肥老太牲交大战 | 无套内谢的新婚少妇国语播放 | 丁香啪啪综合成人亚洲 | 国产在热线精品视频 | 性欧美熟妇videofreesex | 天天做天天爱天天爽综合网 | av无码久久久久不卡免费网站 | 强开小婷嫩苞又嫩又紧视频 | 国产无遮挡又黄又爽又色 | 国产三级久久久精品麻豆三级 | av小次郎收藏 | 久久人人97超碰a片精品 | 精品国精品国产自在久国产87 | 97无码免费人妻超级碰碰夜夜 | 香港三级日本三级妇三级 | 欧美大屁股xxxxhd黑色 | 76少妇精品导航 | 国产乱码精品一品二品 | 免费观看又污又黄的网站 | 狂野欧美性猛交免费视频 | 麻花豆传媒剧国产免费mv在线 | 亚洲欧美国产精品专区久久 | 国产精品亚洲一区二区三区喷水 | 天堂亚洲2017在线观看 | 人妻少妇被猛烈进入中文字幕 | 18精品久久久无码午夜福利 | 国产精品亚洲五月天高清 | 日日摸日日碰夜夜爽av | 久久99精品国产麻豆 | 婷婷综合久久中文字幕蜜桃三电影 | 欧美成人免费全部网站 | 久久zyz资源站无码中文动漫 | 国产真实乱对白精彩久久 | 性生交片免费无码看人 | 女人被男人躁得好爽免费视频 | 亚洲国产欧美在线成人 | 妺妺窝人体色www在线小说 | 5858s亚洲色大成网站www | 国产亚洲精品久久久久久大师 | 精品成在人线av无码免费看 | 一本加勒比波多野结衣 | 亚洲a无码综合a国产av中文 | 亚洲の无码国产の无码影院 | 亚洲爆乳大丰满无码专区 | 国产精品无码一区二区桃花视频 | 天天做天天爱天天爽综合网 | 亚洲午夜久久久影院 | 亚洲日韩av片在线观看 | 夜先锋av资源网站 | 亚洲成a人片在线观看无码3d | 久久www免费人成人片 | 一个人看的www免费视频在线观看 | 久久99热只有频精品8 | 久久久久久久人妻无码中文字幕爆 | 欧洲熟妇色 欧美 | 88国产精品欧美一区二区三区 | 扒开双腿疯狂进出爽爽爽视频 | www成人国产高清内射 | 领导边摸边吃奶边做爽在线观看 | 国产尤物精品视频 | 国色天香社区在线视频 | 国产另类ts人妖一区二区 | 乱人伦中文视频在线观看 | 丰满人妻翻云覆雨呻吟视频 | 在线观看免费人成视频 | av小次郎收藏 | 蜜臀av在线播放 久久综合激激的五月天 | 熟女俱乐部五十路六十路av | 国产亚洲欧美在线专区 | 日日摸夜夜摸狠狠摸婷婷 | aa片在线观看视频在线播放 | 99精品无人区乱码1区2区3区 | 两性色午夜免费视频 | 久久精品国产亚洲精品 | 欧美人与牲动交xxxx | 久久亚洲中文字幕精品一区 | 性欧美熟妇videofreesex | 国产高潮视频在线观看 | 少妇高潮一区二区三区99 | 国产精品久久久久久亚洲毛片 | 99精品国产综合久久久久五月天 | 久久97精品久久久久久久不卡 | 色情久久久av熟女人妻网站 | 亚洲中文字幕无码中字 | 99久久无码一区人妻 | 国产成人av免费观看 | 久久亚洲国产成人精品性色 | 欧美精品无码一区二区三区 | 国产卡一卡二卡三 | 亚洲日本一区二区三区在线 | 中文字幕无码乱人伦 | 亚洲va中文字幕无码久久不卡 | 国产亚洲欧美日韩亚洲中文色 | 成人免费视频在线观看 | 国产亚洲精品精品国产亚洲综合 | 欧美日韩久久久精品a片 | 亚洲欧美国产精品专区久久 | 99riav国产精品视频 | 国产精品亚洲五月天高清 | 成人精品视频一区二区三区尤物 | 蜜桃视频韩日免费播放 | 精品无人国产偷自产在线 | 久久久久人妻一区精品色欧美 | 人妻少妇被猛烈进入中文字幕 | 骚片av蜜桃精品一区 | 日产国产精品亚洲系列 | 日本熟妇人妻xxxxx人hd | 国产人妻精品午夜福利免费 | 亚洲gv猛男gv无码男同 | 熟妇人妻无乱码中文字幕 | 国产成人一区二区三区别 | 国产成人午夜福利在线播放 | 狠狠色欧美亚洲狠狠色www | 亚洲精品久久久久久一区二区 | 久久久久久九九精品久 | 国产成人无码午夜视频在线观看 | 乱人伦人妻中文字幕无码久久网 | 亚洲国产高清在线观看视频 | 亚洲乱码日产精品bd | 成 人 网 站国产免费观看 | 夜精品a片一区二区三区无码白浆 | 亚洲国产av精品一区二区蜜芽 | 天天摸天天碰天天添 | 国产小呦泬泬99精品 | 亚洲欧美国产精品久久 | 青青草原综合久久大伊人精品 | 内射后入在线观看一区 | 中文字幕无码av波多野吉衣 | 日本大香伊一区二区三区 | 狂野欧美激情性xxxx | 国产成人无码专区 | 成人欧美一区二区三区黑人免费 | 无码任你躁久久久久久久 | 夫妻免费无码v看片 | 99国产精品白浆在线观看免费 | 天下第一社区视频www日本 | 人妻无码αv中文字幕久久琪琪布 | 久久人人爽人人人人片 | 国产黄在线观看免费观看不卡 | 亚洲国产成人av在线观看 | 综合激情五月综合激情五月激情1 | 四虎永久在线精品免费网址 | 水蜜桃色314在线观看 | 18黄暴禁片在线观看 | 国产真实夫妇视频 | 亚洲熟女一区二区三区 | 天海翼激烈高潮到腰振不止 | 久久国产精品萌白酱免费 | 国内揄拍国内精品人妻 | 动漫av一区二区在线观看 | 国产精华av午夜在线观看 | 久久国语露脸国产精品电影 | 丰满少妇熟乱xxxxx视频 | 欧美黑人性暴力猛交喷水 | 欧美freesex黑人又粗又大 | 精品国产一区av天美传媒 | 性欧美牲交xxxxx视频 | 高清无码午夜福利视频 | 永久免费精品精品永久-夜色 | 欧美日韩综合一区二区三区 | www成人国产高清内射 | 无码人妻精品一区二区三区下载 | 国产xxx69麻豆国语对白 | 天堂一区人妻无码 | 天干天干啦夜天干天2017 | 日本乱人伦片中文三区 | 牲欲强的熟妇农村老妇女视频 | 日本精品少妇一区二区三区 | 国产无遮挡又黄又爽免费视频 | 亚洲国产成人a精品不卡在线 | 国产成人精品视频ⅴa片软件竹菊 | 亚洲男人av香蕉爽爽爽爽 | 久久99精品久久久久久 | 乱人伦人妻中文字幕无码 | 欧美黑人巨大xxxxx | 美女扒开屁股让男人桶 | 曰韩少妇内射免费播放 | 亚洲欧美日韩国产精品一区二区 | 成人aaa片一区国产精品 | 中文字幕无码免费久久99 | 内射巨臀欧美在线视频 | 国产精品亚洲专区无码不卡 | 亚洲乱亚洲乱妇50p | 久久综合香蕉国产蜜臀av | 熟妇人妻无乱码中文字幕 | 无码福利日韩神码福利片 | 亚洲欧美精品伊人久久 | 丰满诱人的人妻3 | av无码久久久久不卡免费网站 | 亚洲理论电影在线观看 | 青青青爽视频在线观看 | 国内精品人妻无码久久久影院 | 麻豆国产97在线 | 欧洲 | а√天堂www在线天堂小说 | 国产精品久久国产精品99 | 日韩少妇内射免费播放 | 对白脏话肉麻粗话av | 精品熟女少妇av免费观看 | 免费看少妇作爱视频 | 欧美精品免费观看二区 | 精品偷拍一区二区三区在线看 | 国产精品怡红院永久免费 | 国产精品久久久久久亚洲影视内衣 | 岛国片人妻三上悠亚 | 日本熟妇大屁股人妻 | 成人无码视频免费播放 | 国产一区二区不卡老阿姨 | 亚洲中文字幕在线无码一区二区 | 丝袜美腿亚洲一区二区 | 激情国产av做激情国产爱 | 天天摸天天碰天天添 | 内射欧美老妇wbb | 激情内射日本一区二区三区 | 国产精品无码永久免费888 | 国产精品视频免费播放 | 国产亚洲美女精品久久久2020 | 国内精品一区二区三区不卡 | 男人的天堂2018无码 | 婷婷综合久久中文字幕蜜桃三电影 | 人妻无码αv中文字幕久久琪琪布 | 成人女人看片免费视频放人 | 亚洲国产精品毛片av不卡在线 | 久在线观看福利视频 | 精品偷自拍另类在线观看 | 伊人久久大香线蕉亚洲 | 国产麻豆精品一区二区三区v视界 | 亚洲人成人无码网www国产 | 国产精品久久精品三级 | 国产av一区二区三区最新精品 | 国产精品福利视频导航 | 欧美高清在线精品一区 | 日日摸天天摸爽爽狠狠97 | 精品aⅴ一区二区三区 | 思思久久99热只有频精品66 | 午夜免费福利小电影 | 水蜜桃亚洲一二三四在线 | 亚洲精品久久久久久久久久久 | 久久综合狠狠综合久久综合88 | 精品国偷自产在线视频 | 无套内谢的新婚少妇国语播放 | 中文字幕久久久久人妻 | 窝窝午夜理论片影院 | 久久久久久av无码免费看大片 | 久久精品无码一区二区三区 | www成人国产高清内射 | 国产乱码精品一品二品 | 中文字幕乱码人妻二区三区 | 人妻少妇精品无码专区动漫 | 欧美成人高清在线播放 | 国产黄在线观看免费观看不卡 | 中文字幕av日韩精品一区二区 | 激情国产av做激情国产爱 | 18禁止看的免费污网站 | 97无码免费人妻超级碰碰夜夜 | 日本丰满熟妇videos | 曰本女人与公拘交酡免费视频 | 国产两女互慰高潮视频在线观看 | 精品久久久久香蕉网 | 亚洲 欧美 激情 小说 另类 | 久久久久av无码免费网 | 国产亚洲人成在线播放 | 玩弄少妇高潮ⅹxxxyw | 色婷婷香蕉在线一区二区 | 久久视频在线观看精品 | 女人被男人躁得好爽免费视频 | 天堂在线观看www | 国产av久久久久精东av | 东京热无码av男人的天堂 | 国产精品高潮呻吟av久久 | 日本丰满熟妇videos | 99久久精品日本一区二区免费 | 老子影院午夜伦不卡 | 日本一卡2卡3卡4卡无卡免费网站 国产一区二区三区影院 | 日韩人妻系列无码专区 | 亚洲欧洲中文日韩av乱码 | 男女爱爱好爽视频免费看 | 国语自产偷拍精品视频偷 | 狠狠色噜噜狠狠狠狠7777米奇 | 色五月丁香五月综合五月 | 国产亲子乱弄免费视频 | 国产午夜福利亚洲第一 | 给我免费的视频在线观看 | 乱人伦人妻中文字幕无码久久网 | 老子影院午夜伦不卡 | 精品国产av色一区二区深夜久久 | 黑人巨大精品欧美一区二区 | 成人免费无码大片a毛片 | 成人影院yy111111在线观看 | 国产激情艳情在线看视频 | 内射巨臀欧美在线视频 | 国内丰满熟女出轨videos | 国内少妇偷人精品视频免费 | 国产精品久久久久影院嫩草 | 国产人妻精品一区二区三区 | 东京热无码av男人的天堂 | 日本熟妇乱子伦xxxx | 精品人妻av区 | 18无码粉嫩小泬无套在线观看 | 国产精品高潮呻吟av久久 | 日本乱人伦片中文三区 | 亚洲国产精品无码一区二区三区 | 鲁一鲁av2019在线 | 精品欧洲av无码一区二区三区 | 妺妺窝人体色www婷婷 | 初尝人妻少妇中文字幕 | 亚洲精品一区二区三区在线观看 | 狠狠亚洲超碰狼人久久 | 亚洲色欲久久久综合网东京热 | 国产精品亚洲а∨无码播放麻豆 | 99国产精品白浆在线观看免费 | 麻豆国产人妻欲求不满 | 白嫩日本少妇做爰 | 人人妻人人澡人人爽精品欧美 | 大色综合色综合网站 | 国产9 9在线 | 中文 | 九九热爱视频精品 | 国产乱子伦视频在线播放 | 乱人伦中文视频在线观看 | 国内少妇偷人精品视频免费 | 3d动漫精品啪啪一区二区中 | 日本丰满熟妇videos | 欧美熟妇另类久久久久久不卡 | 欧美精品免费观看二区 | 欧美精品无码一区二区三区 | 国产精华av午夜在线观看 | 成熟人妻av无码专区 | 日韩av激情在线观看 | 中文字幕 亚洲精品 第1页 | 天堂久久天堂av色综合 | 日日夜夜撸啊撸 | 亚洲精品一区三区三区在线观看 | 日本精品人妻无码免费大全 | 精品国偷自产在线视频 | 人人爽人人爽人人片av亚洲 | 特黄特色大片免费播放器图片 | 白嫩日本少妇做爰 | 精品无码av一区二区三区 | 日本精品人妻无码77777 天堂一区人妻无码 | 亚洲娇小与黑人巨大交 | 亚洲国产精品一区二区第一页 | 老熟女重囗味hdxx69 | 成人精品视频一区二区 | 亚洲天堂2017无码 | 成人毛片一区二区 | 国产精品人妻一区二区三区四 | 99视频精品全部免费免费观看 | 亚洲色偷偷偷综合网 | 精品无码成人片一区二区98 | 色一情一乱一伦一视频免费看 | 亚洲gv猛男gv无码男同 | 在线观看国产午夜福利片 | 亚洲第一网站男人都懂 | 国产精品成人av在线观看 | 无码中文字幕色专区 | 蜜臀av无码人妻精品 | 成年女人永久免费看片 | 男女爱爱好爽视频免费看 | 久久久久成人片免费观看蜜芽 | 久久99精品久久久久婷婷 | 亚洲大尺度无码无码专区 | 2019nv天堂香蕉在线观看 | 无码纯肉视频在线观看 | 日本www一道久久久免费榴莲 | 国产人妖乱国产精品人妖 | 男人的天堂av网站 | 国产麻豆精品精东影业av网站 | 欧美肥老太牲交大战 | 国产又粗又硬又大爽黄老大爷视 | 青青草原综合久久大伊人精品 | 小sao货水好多真紧h无码视频 | 日本大香伊一区二区三区 | 成人影院yy111111在线观看 | 国产猛烈高潮尖叫视频免费 | 亚洲欧美色中文字幕在线 | 日本精品人妻无码免费大全 | 人妻夜夜爽天天爽三区 | 欧美性猛交内射兽交老熟妇 | 久激情内射婷内射蜜桃人妖 | 亚洲综合无码久久精品综合 | 亚洲另类伦春色综合小说 | 亚洲乱亚洲乱妇50p | 亚洲成a人片在线观看日本 | 国产精品高潮呻吟av久久4虎 | 久久99国产综合精品 | 婷婷色婷婷开心五月四房播播 | 最新国产麻豆aⅴ精品无码 | 久久熟妇人妻午夜寂寞影院 | 日日噜噜噜噜夜夜爽亚洲精品 | 牛和人交xxxx欧美 | 桃花色综合影院 | 中文久久乱码一区二区 | 亚洲啪av永久无码精品放毛片 | 亚洲综合在线一区二区三区 | 少妇人妻偷人精品无码视频 | 无码纯肉视频在线观看 | 国产一区二区三区日韩精品 | 少妇久久久久久人妻无码 | 成在人线av无码免观看麻豆 | 亚洲国产精品无码一区二区三区 | 初尝人妻少妇中文字幕 | 成人无码精品1区2区3区免费看 | 国产成人无码av一区二区 | 亚洲色无码一区二区三区 | 青青久在线视频免费观看 | 欧美三级a做爰在线观看 | 极品尤物被啪到呻吟喷水 | 婷婷丁香五月天综合东京热 | 国产精品无码成人午夜电影 | 久久亚洲中文字幕精品一区 | 国产后入清纯学生妹 | 欧美性猛交内射兽交老熟妇 | 理论片87福利理论电影 | 国产免费观看黄av片 | 伊在人天堂亚洲香蕉精品区 | 免费无码一区二区三区蜜桃大 | 狂野欧美激情性xxxx | 中文字幕精品av一区二区五区 | 亚洲人成网站免费播放 | 一区二区三区乱码在线 | 欧洲 | 日产精品高潮呻吟av久久 | 久久午夜夜伦鲁鲁片无码免费 | 亚洲中文字幕乱码av波多ji | 国产疯狂伦交大片 | 欧美成人午夜精品久久久 | 日欧一片内射va在线影院 | 激情内射日本一区二区三区 | 荫蒂添的好舒服视频囗交 | 免费观看黄网站 | 免费无码一区二区三区蜜桃大 | 高中生自慰www网站 | 大肉大捧一进一出视频出来呀 | 国产成人综合色在线观看网站 | 熟女俱乐部五十路六十路av | 国产亲子乱弄免费视频 | 亚洲小说春色综合另类 | 色欲久久久天天天综合网精品 | 亚洲乱亚洲乱妇50p | 国产色视频一区二区三区 | 牛和人交xxxx欧美 | 国产精品内射视频免费 | 色一情一乱一伦一区二区三欧美 | 成人影院yy111111在线观看 | 国产欧美亚洲精品a | 国产婷婷色一区二区三区在线 | 四虎4hu永久免费 | 又紧又大又爽精品一区二区 | 国产精品久久福利网站 | 日韩人妻少妇一区二区三区 | 老熟女重囗味hdxx69 | 丰满少妇弄高潮了www | 欧美日韩亚洲国产精品 | 欧美日韩视频无码一区二区三 | 成 人 网 站国产免费观看 | 国产成人精品必看 | 自拍偷自拍亚洲精品被多人伦好爽 | 国产精品人妻一区二区三区四 | 国产精品第一国产精品 | 中文字幕日韩精品一区二区三区 | 永久黄网站色视频免费直播 | 99精品视频在线观看免费 | 中文无码精品a∨在线观看不卡 | 丝袜 中出 制服 人妻 美腿 | 在线播放无码字幕亚洲 | 亚洲色偷偷男人的天堂 | 亚洲日韩精品欧美一区二区 | 一本色道久久综合狠狠躁 | 97夜夜澡人人双人人人喊 | 在线亚洲高清揄拍自拍一品区 | 国产亲子乱弄免费视频 | 宝宝好涨水快流出来免费视频 | 老太婆性杂交欧美肥老太 | 国产成人精品久久亚洲高清不卡 | 国产精品无套呻吟在线 | 亚洲精品国产a久久久久久 | 国产亚洲日韩欧美另类第八页 | 国产黑色丝袜在线播放 | 国产在线aaa片一区二区99 | 成人无码精品一区二区三区 | 日韩精品无码一区二区中文字幕 | 国产精品久久久一区二区三区 | 麻豆国产97在线 | 欧洲 | 未满小14洗澡无码视频网站 | 国产乱码精品一品二品 | 日韩无码专区 | 国产午夜手机精彩视频 | 乱码午夜-极国产极内射 | 国产97人人超碰caoprom | 青青青爽视频在线观看 | 中文字幕无码av波多野吉衣 | 亚洲国产精品久久人人爱 | а√资源新版在线天堂 | 国产在线一区二区三区四区五区 | 欧美日本精品一区二区三区 | 131美女爱做视频 | 色 综合 欧美 亚洲 国产 | 玩弄少妇高潮ⅹxxxyw | 日韩欧美中文字幕在线三区 | 在线a亚洲视频播放在线观看 | 久久久久国色av免费观看性色 | 亚洲欧洲中文日韩av乱码 | 久久99热只有频精品8 | 国产精品怡红院永久免费 | 亚洲色欲色欲欲www在线 | 一本久久a久久精品亚洲 | 无码播放一区二区三区 | 中文字幕乱妇无码av在线 | av人摸人人人澡人人超碰下载 | 2020久久香蕉国产线看观看 | 日韩精品久久久肉伦网站 | 中文字幕+乱码+中文字幕一区 | 377p欧洲日本亚洲大胆 | 伊在人天堂亚洲香蕉精品区 | 成人性做爰aaa片免费看不忠 | 99精品久久毛片a片 | 中文字幕乱码人妻无码久久 | 久久午夜夜伦鲁鲁片无码免费 | 国产精品久久久久无码av色戒 | 欧美高清在线精品一区 | 无码av中文字幕免费放 | 天下第一社区视频www日本 | 精品国产av色一区二区深夜久久 | 曰韩无码二三区中文字幕 | 亚洲国产欧美国产综合一区 | 妺妺窝人体色www婷婷 | 大肉大捧一进一出好爽视频 | 一本色道久久综合狠狠躁 | 久久aⅴ免费观看 | 97无码免费人妻超级碰碰夜夜 | 中文字幕无码热在线视频 | 97色伦图片97综合影院 | 亚洲色成人中文字幕网站 | 国产美女精品一区二区三区 | 九月婷婷人人澡人人添人人爽 | 日本乱人伦片中文三区 | 天堂无码人妻精品一区二区三区 | 国产福利视频一区二区 | 国内揄拍国内精品少妇国语 | 国产成人精品一区二区在线小狼 | 成人无码视频在线观看网站 | 无遮挡啪啪摇乳动态图 | 爆乳一区二区三区无码 | 无人区乱码一区二区三区 | 极品尤物被啪到呻吟喷水 | 国产国产精品人在线视 | 奇米影视888欧美在线观看 | 荫蒂添的好舒服视频囗交 | 亚洲小说图区综合在线 | 国产免费久久精品国产传媒 | 亚洲码国产精品高潮在线 | 国产特级毛片aaaaaaa高清 | 久久久国产精品无码免费专区 | 亚洲国产综合无码一区 | 色老头在线一区二区三区 | 国产一区二区三区影院 | 国产亚洲视频中文字幕97精品 | 久久精品国产一区二区三区 | 麻花豆传媒剧国产免费mv在线 | a在线观看免费网站大全 | 亚洲男人av香蕉爽爽爽爽 | 精品偷拍一区二区三区在线看 | 蜜臀av无码人妻精品 | 国产真人无遮挡作爱免费视频 | 国精品人妻无码一区二区三区蜜柚 | 极品嫩模高潮叫床 | 国产精品无码mv在线观看 | 色一情一乱一伦 | 伊人久久大香线蕉av一区二区 | 欧美人与牲动交xxxx | 2019午夜福利不卡片在线 | 亚洲国产精品一区二区美利坚 | 久久亚洲精品成人无码 | 欧美人与牲动交xxxx | 日日碰狠狠躁久久躁蜜桃 | 国产亲子乱弄免费视频 | 久久午夜无码鲁丝片 | 亚洲色无码一区二区三区 | 亚洲春色在线视频 | 奇米影视7777久久精品人人爽 | 四虎4hu永久免费 | 日日干夜夜干 | 亚洲国产精品无码一区二区三区 | 久久久精品成人免费观看 | 久久精品视频在线看15 | 国精产品一区二区三区 | 99久久婷婷国产综合精品青草免费 | 国产肉丝袜在线观看 | 大胆欧美熟妇xx | 99精品国产综合久久久久五月天 | 国内精品一区二区三区不卡 | 色诱久久久久综合网ywww | 国产精品国产三级国产专播 | 无码人妻精品一区二区三区不卡 | 欧美日韩久久久精品a片 | 日本一卡2卡3卡四卡精品网站 | 四虎影视成人永久免费观看视频 | 国产亚洲精品久久久闺蜜 | 国内综合精品午夜久久资源 | 99久久婷婷国产综合精品青草免费 | 免费男性肉肉影院 | 亚洲va中文字幕无码久久不卡 | 国产真实夫妇视频 | 性色av无码免费一区二区三区 | 国产人妻人伦精品 | 国产内射老熟女aaaa | 性生交大片免费看l | 骚片av蜜桃精品一区 | 午夜福利一区二区三区在线观看 | 激情人妻另类人妻伦 | 亚洲大尺度无码无码专区 | 亚洲国产成人a精品不卡在线 | 玩弄中年熟妇正在播放 | 欧美日韩一区二区三区自拍 | 人人妻人人澡人人爽欧美精品 | 爽爽影院免费观看 | 日韩精品乱码av一区二区 | 久久久久久九九精品久 | 亚洲精品国产精品乱码视色 | 女人被男人爽到呻吟的视频 | 性色欲网站人妻丰满中文久久不卡 | 伊人久久大香线蕉午夜 | 色婷婷综合激情综在线播放 | 色婷婷av一区二区三区之红樱桃 | 十八禁视频网站在线观看 | 欧美日韩色另类综合 | 国产香蕉尹人综合在线观看 | 亚洲日本va中文字幕 | 国产成人一区二区三区别 | 荫蒂添的好舒服视频囗交 | 久久99精品国产麻豆 | 亚洲精品一区三区三区在线观看 | 亚洲精品久久久久avwww潮水 | 亚洲七七久久桃花影院 | 色综合久久久久综合一本到桃花网 | 爱做久久久久久 | 无遮无挡爽爽免费视频 | 九一九色国产 | 亚洲欧洲中文日韩av乱码 | 少妇的肉体aa片免费 | 精品国产av色一区二区深夜久久 | 性色av无码免费一区二区三区 | 欧洲精品码一区二区三区免费看 | 久激情内射婷内射蜜桃人妖 | 欧美日本免费一区二区三区 | 国产精品无码一区二区三区不卡 | 99麻豆久久久国产精品免费 | 九九综合va免费看 | 欧美精品一区二区精品久久 | 国产肉丝袜在线观看 | 中文字幕无码av波多野吉衣 | 中文精品久久久久人妻不卡 | 国产精品无码永久免费888 | 亚洲 高清 成人 动漫 | 精品无码成人片一区二区98 | 亚洲日韩av一区二区三区中文 | 成人欧美一区二区三区黑人 | 麻豆精产国品 | 亚洲码国产精品高潮在线 | 亚洲国产精品毛片av不卡在线 | 我要看www免费看插插视频 | 99久久亚洲精品无码毛片 | 午夜福利不卡在线视频 | 又黄又爽又色的视频 | 免费无码av一区二区 | 精品国产一区av天美传媒 | 国产美女精品一区二区三区 | 中文字幕av日韩精品一区二区 | 国产真实夫妇视频 | 国产xxx69麻豆国语对白 | 中文字幕人妻丝袜二区 | 国产成人无码一二三区视频 | 毛片内射-百度 | 色五月丁香五月综合五月 | 巨爆乳无码视频在线观看 | 国产激情艳情在线看视频 | 国产午夜精品一区二区三区嫩草 | 国产一区二区三区影院 | 亚洲区欧美区综合区自拍区 | 亚洲va欧美va天堂v国产综合 | 学生妹亚洲一区二区 | 国产精品无码mv在线观看 | 久在线观看福利视频 | 国产精品成人av在线观看 | 国产成人无码区免费内射一片色欲 | 青草视频在线播放 | 午夜福利试看120秒体验区 | 国产精品办公室沙发 | 99久久人妻精品免费一区 | 久久久久99精品成人片 | 精品熟女少妇av免费观看 | 国产成人无码av片在线观看不卡 | 色窝窝无码一区二区三区色欲 | 久久成人a毛片免费观看网站 | 无码一区二区三区在线 | 色婷婷综合激情综在线播放 | 粉嫩少妇内射浓精videos | 久久久久久av无码免费看大片 | 亚拍精品一区二区三区探花 | 国产真人无遮挡作爱免费视频 | 亚洲 a v无 码免 费 成 人 a v | 久久综合色之久久综合 | 亚洲 a v无 码免 费 成 人 a v | 亚洲成av人综合在线观看 | 亚洲国产精品毛片av不卡在线 | 俺去俺来也在线www色官网 | 爆乳一区二区三区无码 | 5858s亚洲色大成网站www | а√资源新版在线天堂 | 国语自产偷拍精品视频偷 | 熟妇女人妻丰满少妇中文字幕 | 成人亚洲精品久久久久 | 十八禁视频网站在线观看 | 强开小婷嫩苞又嫩又紧视频 | 亚洲国产高清在线观看视频 | 福利一区二区三区视频在线观看 | www成人国产高清内射 | 久久国产精品偷任你爽任你 | 国产精品人人妻人人爽 | 国产无遮挡又黄又爽又色 | 日韩精品a片一区二区三区妖精 | 一个人看的www免费视频在线观看 | 四虎影视成人永久免费观看视频 | 丰满少妇熟乱xxxxx视频 | 成人无码影片精品久久久 | 爱做久久久久久 | 纯爱无遮挡h肉动漫在线播放 | 久久婷婷五月综合色国产香蕉 | 精品久久久久久人妻无码中文字幕 | 精品国产乱码久久久久乱码 | 欧洲vodafone精品性 | 小鲜肉自慰网站xnxx | 色婷婷久久一区二区三区麻豆 | 娇妻被黑人粗大高潮白浆 | 最新版天堂资源中文官网 | 亚洲精品国产品国语在线观看 | 久久国产自偷自偷免费一区调 | 男人扒开女人内裤强吻桶进去 | 久久精品女人的天堂av | 成年美女黄网站色大免费视频 | 亚洲精品成a人在线观看 | 国产免费久久精品国产传媒 | 狠狠躁日日躁夜夜躁2020 | 久久久久av无码免费网 | 亚洲欧美国产精品久久 | 欧美丰满熟妇xxxx | 18黄暴禁片在线观看 | 成熟妇人a片免费看网站 | 一本精品99久久精品77 | 岛国片人妻三上悠亚 | 天堂无码人妻精品一区二区三区 | 三级4级全黄60分钟 | 蜜桃臀无码内射一区二区三区 | 熟妇人妻无乱码中文字幕 | 乌克兰少妇性做爰 | 激情内射日本一区二区三区 | 精品国产一区av天美传媒 | 给我免费的视频在线观看 | 欧美xxxx黑人又粗又长 | 性欧美videos高清精品 | 成人无码精品一区二区三区 | 一区二区三区乱码在线 | 欧洲 | 国内精品久久毛片一区二区 | 精品久久久久久亚洲精品 | 久久国语露脸国产精品电影 | 日韩精品成人一区二区三区 | 免费播放一区二区三区 | 四虎永久在线精品免费网址 | 欧美乱妇无乱码大黄a片 | 亚洲热妇无码av在线播放 | 欧美freesex黑人又粗又大 | 亚洲中文字幕乱码av波多ji | 国产网红无码精品视频 | 女人被爽到呻吟gif动态图视看 | 国产精品人人爽人人做我的可爱 | 亚洲熟妇色xxxxx欧美老妇 | 亚洲国产午夜精品理论片 | 久久99精品久久久久久动态图 | 亚洲国产精品无码一区二区三区 | 强奷人妻日本中文字幕 | 女高中生第一次破苞av | 成人试看120秒体验区 | 欧美午夜特黄aaaaaa片 | 亚洲人交乣女bbw | 亚洲综合伊人久久大杳蕉 | 欧美丰满熟妇xxxx性ppx人交 | 亚洲中文字幕在线观看 | 人妻少妇精品无码专区动漫 | 免费观看的无遮挡av | 日韩精品成人一区二区三区 | 奇米综合四色77777久久 东京无码熟妇人妻av在线网址 | 国产黑色丝袜在线播放 | 丰满肥臀大屁股熟妇激情视频 | 久久五月精品中文字幕 | 欧美熟妇另类久久久久久多毛 | 装睡被陌生人摸出水好爽 | 国产人妻大战黑人第1集 | 国产亚洲精品久久久ai换 | 久久精品视频在线看15 | 日韩精品无码一区二区中文字幕 | 伊人久久大香线蕉av一区二区 | 久久亚洲中文字幕无码 | 午夜理论片yy44880影院 | 国产精品亚洲综合色区韩国 | 亚洲欧美精品伊人久久 | 自拍偷自拍亚洲精品10p | 国产亚洲tv在线观看 | 久久久久久亚洲精品a片成人 | 97久久超碰中文字幕 | 樱花草在线播放免费中文 | 在线观看欧美一区二区三区 | 色五月五月丁香亚洲综合网 | 中文字幕人妻无码一区二区三区 | 亚洲精品一区二区三区在线观看 | 一个人看的www免费视频在线观看 | 欧美怡红院免费全部视频 | 久久久成人毛片无码 | 免费无码的av片在线观看 | 99久久精品午夜一区二区 | 欧美日韩在线亚洲综合国产人 | 亚洲熟悉妇女xxx妇女av | 亚洲熟妇色xxxxx欧美老妇 | 亚洲 日韩 欧美 成人 在线观看 | 97久久国产亚洲精品超碰热 | 无码国产激情在线观看 | 亚洲区小说区激情区图片区 | 国产片av国语在线观看 | 精品国产aⅴ无码一区二区 | 欧洲精品码一区二区三区免费看 | 国产精品丝袜黑色高跟鞋 | 欧美黑人巨大xxxxx | 亚洲成色www久久网站 | 成年女人永久免费看片 | 色欲av亚洲一区无码少妇 | 日韩欧美中文字幕在线三区 | 国内老熟妇对白xxxxhd | 亚洲国产精品一区二区第一页 | 人人妻人人澡人人爽人人精品浪潮 | 搡女人真爽免费视频大全 | 樱花草在线播放免费中文 | 国产午夜福利亚洲第一 | 亚洲欧美日韩国产精品一区二区 | 在线а√天堂中文官网 | 国产极品美女高潮无套在线观看 | 国产精品丝袜黑色高跟鞋 | 色婷婷香蕉在线一区二区 | 亚洲娇小与黑人巨大交 | aⅴ亚洲 日韩 色 图网站 播放 | aⅴ在线视频男人的天堂 | 亚洲va欧美va天堂v国产综合 | 国产人妻精品一区二区三区 | 牲交欧美兽交欧美 | 亚洲日韩av一区二区三区四区 | 人人妻人人澡人人爽欧美一区九九 | 日本一卡2卡3卡四卡精品网站 | 日韩精品无码免费一区二区三区 | 亚洲人成网站免费播放 | 国产熟妇高潮叫床视频播放 | 一二三四社区在线中文视频 | 国产亚洲美女精品久久久2020 | 成人欧美一区二区三区黑人 | 男女爱爱好爽视频免费看 | 亚洲娇小与黑人巨大交 | 一本加勒比波多野结衣 | 国产无遮挡又黄又爽免费视频 | 亚洲欧洲无卡二区视頻 | 丝袜足控一区二区三区 | 国产黄在线观看免费观看不卡 | 国产手机在线αⅴ片无码观看 | 在线视频网站www色 | 免费国产成人高清在线观看网站 | 青青草原综合久久大伊人精品 | 久精品国产欧美亚洲色aⅴ大片 | 亚洲色大成网站www | 国产精品99久久精品爆乳 | 亚洲精品一区二区三区四区五区 | 久久精品人人做人人综合 | 人妻少妇精品无码专区动漫 | 色欲人妻aaaaaaa无码 | www国产亚洲精品久久网站 | 亚洲乱亚洲乱妇50p | 亚洲中文字幕va福利 | 国产精品久久久久久无码 | 欧美日本日韩 | 三上悠亚人妻中文字幕在线 | 未满小14洗澡无码视频网站 | 欧美性猛交xxxx富婆 | 天堂а√在线中文在线 | 亚洲高清偷拍一区二区三区 | 国产av一区二区三区最新精品 | 久久久久久久人妻无码中文字幕爆 | 中文字幕人妻丝袜二区 | 乱人伦中文视频在线观看 | 大乳丰满人妻中文字幕日本 | 牲欲强的熟妇农村老妇女视频 | 久久国产精品_国产精品 | 暴力强奷在线播放无码 | 97久久超碰中文字幕 | 国产亚洲美女精品久久久2020 | av香港经典三级级 在线 | 久久久久久久人妻无码中文字幕爆 | 天天躁日日躁狠狠躁免费麻豆 | 亚洲成av人片在线观看无码不卡 | 一本色道久久综合亚洲精品不卡 | 日韩欧美中文字幕在线三区 | 欧美人与善在线com | a在线亚洲男人的天堂 | 精品国产一区二区三区四区 | 成熟妇人a片免费看网站 | 99久久婷婷国产综合精品青草免费 | 亚洲成av人在线观看网址 | 未满成年国产在线观看 | 无码任你躁久久久久久久 | 亚洲第一网站男人都懂 | 妺妺窝人体色www婷婷 | 十八禁真人啪啪免费网站 | 又粗又大又硬毛片免费看 | 2020最新国产自产精品 | 精品国产一区av天美传媒 | 无码一区二区三区在线观看 | 国产在线精品一区二区高清不卡 | 久久久国产精品无码免费专区 | 亚洲精品一区二区三区在线观看 | 亚洲大尺度无码无码专区 | 一本久道久久综合婷婷五月 | 久久精品99久久香蕉国产色戒 | 久久熟妇人妻午夜寂寞影院 | 精品人人妻人人澡人人爽人人 | 久久aⅴ免费观看 | 国产精品国产三级国产专播 | 麻花豆传媒剧国产免费mv在线 | 成人无码视频在线观看网站 | 欧美精品在线观看 | 国产97色在线 | 免 | yw尤物av无码国产在线观看 | 日韩少妇白浆无码系列 | 午夜精品久久久久久久久 | 亚洲 欧美 激情 小说 另类 | 国产精品内射视频免费 | 亚洲国产一区二区三区在线观看 | 久久久国产精品无码免费专区 | 欧洲精品码一区二区三区免费看 | 亚洲爆乳精品无码一区二区三区 | 欧美老人巨大xxxx做受 | 免费无码av一区二区 | 国产精品第一国产精品 | 亚洲娇小与黑人巨大交 | 国产精品沙发午睡系列 | 亚洲日本va午夜在线电影 | 久久精品视频在线看15 | 亚洲啪av永久无码精品放毛片 | 久久人妻内射无码一区三区 | 亚洲乱亚洲乱妇50p | 丰满岳乱妇在线观看中字无码 | 无码任你躁久久久久久久 | 无码国产激情在线观看 | 色一情一乱一伦一区二区三欧美 | 鲁鲁鲁爽爽爽在线视频观看 | 亚洲毛片av日韩av无码 | 丰满人妻精品国产99aⅴ | 亚洲小说图区综合在线 | 色欲人妻aaaaaaa无码 | 丰满少妇人妻久久久久久 | 精品国产精品久久一区免费式 | 成人免费视频在线观看 | 国产免费久久久久久无码 | 人妻无码αv中文字幕久久琪琪布 | 亚洲熟妇自偷自拍另类 | 色婷婷久久一区二区三区麻豆 | 亚洲中文字幕乱码av波多ji | 野狼第一精品社区 | 国产xxx69麻豆国语对白 | 国产黑色丝袜在线播放 | 男人的天堂av网站 | 国产熟妇另类久久久久 | 久久国语露脸国产精品电影 | 高清无码午夜福利视频 | 日本一卡二卡不卡视频查询 | 无码人妻av免费一区二区三区 | 人妻少妇精品无码专区动漫 | 奇米影视888欧美在线观看 | 无套内谢的新婚少妇国语播放 | 波多野结衣高清一区二区三区 | 亚洲精品国产第一综合99久久 | 一个人看的视频www在线 | 成人精品一区二区三区中文字幕 | 国产麻豆精品一区二区三区v视界 | 久久国产36精品色熟妇 | 久久五月精品中文字幕 | 午夜嘿嘿嘿影院 | 免费视频欧美无人区码 | 成人免费视频视频在线观看 免费 | 中文亚洲成a人片在线观看 | 国产人妻久久精品二区三区老狼 | 丝袜人妻一区二区三区 | 熟妇女人妻丰满少妇中文字幕 | 2020久久香蕉国产线看观看 | 九九综合va免费看 | 久久久久免费看成人影片 | 波多野结衣av一区二区全免费观看 | 中文字幕av伊人av无码av | 国产成人人人97超碰超爽8 | 亚洲欧美日韩国产精品一区二区 | 国产精品第一国产精品 | 国产精品美女久久久 | 欧美阿v高清资源不卡在线播放 | 亚洲一区二区三区香蕉 | 天天燥日日燥 | 国产精品无码一区二区桃花视频 | 国产精品多人p群无码 | 中文字幕色婷婷在线视频 | 红桃av一区二区三区在线无码av | 精品午夜福利在线观看 | 成人精品视频一区二区三区尤物 | 亚洲一区二区三区无码久久 | 无码帝国www无码专区色综合 | 国产国产精品人在线视 | 水蜜桃色314在线观看 | 久久婷婷五月综合色国产香蕉 | 丰满诱人的人妻3 | 亚洲 欧美 激情 小说 另类 | 天干天干啦夜天干天2017 | 国产手机在线αⅴ片无码观看 | 欧洲精品码一区二区三区免费看 | 久久久av男人的天堂 | 岛国片人妻三上悠亚 | 夫妻免费无码v看片 | 国产成人精品必看 | 牛和人交xxxx欧美 | 男人和女人高潮免费网站 | 国模大胆一区二区三区 | 特级做a爰片毛片免费69 | 国产免费久久久久久无码 | 久久久精品456亚洲影院 | 欧美真人作爱免费视频 | 欧美日韩一区二区免费视频 | 狂野欧美性猛xxxx乱大交 | 特黄特色大片免费播放器图片 | 国产一区二区三区四区五区加勒比 | 无码av免费一区二区三区试看 | 扒开双腿吃奶呻吟做受视频 | 欧美国产日韩久久mv | 国产精品a成v人在线播放 | 久久久无码中文字幕久... | 日韩人妻系列无码专区 | 亚洲色欲色欲天天天www | 亚洲色欲色欲天天天www | 丰满少妇人妻久久久久久 | 亚洲精品中文字幕久久久久 | 天天爽夜夜爽夜夜爽 | 国产乱人伦app精品久久 国产在线无码精品电影网 国产国产精品人在线视 | 欧美亚洲日韩国产人成在线播放 | 99久久人妻精品免费一区 | 国产精品va在线播放 | aa片在线观看视频在线播放 | av无码电影一区二区三区 | 国产精品视频免费播放 | 久久97精品久久久久久久不卡 | 大乳丰满人妻中文字幕日本 | 久久精品中文字幕一区 | 色 综合 欧美 亚洲 国产 | 人人妻人人澡人人爽欧美一区 | 真人与拘做受免费视频 | 粗大的内捧猛烈进出视频 | 激情内射日本一区二区三区 | 最新国产麻豆aⅴ精品无码 | 夜夜高潮次次欢爽av女 | 日本护士xxxxhd少妇 | 在线观看国产午夜福利片 | 99久久精品国产一区二区蜜芽 | 亚洲精品国产a久久久久久 | 色妞www精品免费视频 | 亚洲 另类 在线 欧美 制服 | 麻豆蜜桃av蜜臀av色欲av | 欧美色就是色 | 亚洲第一无码av无码专区 | 国产在线无码精品电影网 | 国产激情一区二区三区 | 久久精品99久久香蕉国产色戒 | 国产亚洲精品久久久久久大师 | 牲欲强的熟妇农村老妇女视频 | 日韩精品成人一区二区三区 | 免费国产黄网站在线观看 | 无码国产乱人伦偷精品视频 | 久久99精品国产.久久久久 | 亚洲国产精品久久久久久 | 国产熟妇高潮叫床视频播放 | 丰满少妇高潮惨叫视频 | 蜜桃无码一区二区三区 | 狠狠亚洲超碰狼人久久 | 四虎永久在线精品免费网址 | 免费国产成人高清在线观看网站 | 中文字幕无码乱人伦 | 人妻体内射精一区二区三四 | 日日碰狠狠躁久久躁蜜桃 | 蜜臀av在线观看 在线欧美精品一区二区三区 | 亚洲日本va午夜在线电影 | 丰满妇女强制高潮18xxxx | 狠狠色丁香久久婷婷综合五月 | √天堂资源地址中文在线 | 中文字幕人妻无码一区二区三区 | 一本大道伊人av久久综合 | 亚洲国产精华液网站w | 午夜嘿嘿嘿影院 | 欧美肥老太牲交大战 | 亚洲国产午夜精品理论片 | 永久免费观看国产裸体美女 | 国产精品办公室沙发 | 免费国产成人高清在线观看网站 | 丰满人妻精品国产99aⅴ | 国产成人一区二区三区在线观看 | 日本在线高清不卡免费播放 | 欧美日本精品一区二区三区 | 伊人久久大香线蕉av一区二区 | 亚洲欧美综合区丁香五月小说 | 狠狠色欧美亚洲狠狠色www | 丰满岳乱妇在线观看中字无码 | 欧美日韩综合一区二区三区 | 亚洲 a v无 码免 费 成 人 a v | 内射后入在线观看一区 | 日本精品少妇一区二区三区 | 精品国产一区二区三区四区 | 一本久久a久久精品亚洲 | 日本一本二本三区免费 | 日韩欧美中文字幕公布 | 欧美激情综合亚洲一二区 | 中文字幕色婷婷在线视频 | 国产av人人夜夜澡人人爽麻豆 | 国产精品.xx视频.xxtv | 图片区 小说区 区 亚洲五月 | 免费中文字幕日韩欧美 | 999久久久国产精品消防器材 | 久久99国产综合精品 | 久久天天躁狠狠躁夜夜免费观看 | 蜜桃臀无码内射一区二区三区 | 国产一区二区不卡老阿姨 | 亚洲综合在线一区二区三区 | 无人区乱码一区二区三区 | 老子影院午夜伦不卡 | 久久久久久av无码免费看大片 | 性啪啪chinese东北女人 | 无人区乱码一区二区三区 | 日本精品高清一区二区 | 亚洲精品一区二区三区四区五区 | 色一情一乱一伦一区二区三欧美 | 午夜福利电影 | 日韩欧美成人免费观看 | 日日橹狠狠爱欧美视频 | 中文字幕乱码亚洲无线三区 | 久久综合网欧美色妞网 | 偷窥村妇洗澡毛毛多 | 疯狂三人交性欧美 | 青青青手机频在线观看 | 久久99精品国产麻豆蜜芽 | 国产激情艳情在线看视频 | 性生交大片免费看l | 麻豆果冻传媒2021精品传媒一区下载 | 亚洲精品国偷拍自产在线观看蜜桃 | 国产精品人人爽人人做我的可爱 | 亚洲热妇无码av在线播放 | 久久久成人毛片无码 | 国产真人无遮挡作爱免费视频 | 国产一区二区三区日韩精品 | 窝窝午夜理论片影院 | 97无码免费人妻超级碰碰夜夜 | 亚洲欧美日韩综合久久久 | 亚洲精品鲁一鲁一区二区三区 | 婷婷丁香六月激情综合啪 | 国产精品二区一区二区aⅴ污介绍 | 2019nv天堂香蕉在线观看 | 国产精品久久久久久久9999 | www一区二区www免费 | 在线天堂新版最新版在线8 | 久久久久99精品国产片 | 日韩精品无码一本二本三本色 | 波多野结衣 黑人 | 乱人伦人妻中文字幕无码 | 亚洲综合无码一区二区三区 | 亚洲爆乳精品无码一区二区三区 | 久久亚洲国产成人精品性色 | 国产精品无码成人午夜电影 | 亚洲精品一区国产 | 最近的中文字幕在线看视频 | 亚洲欧美色中文字幕在线 | www成人国产高清内射 | 蜜桃臀无码内射一区二区三区 | 中文字幕乱码人妻无码久久 | 日日麻批免费40分钟无码 | 久久人妻内射无码一区三区 | 中文字幕av无码一区二区三区电影 | 久久婷婷五月综合色国产香蕉 | 亚洲一区二区三区在线观看网站 | 免费观看又污又黄的网站 | 国产高清不卡无码视频 | 性生交片免费无码看人 | 亚洲中文无码av永久不收费 | 日本护士xxxxhd少妇 | 欧美xxxxx精品 | 亚洲中文字幕在线观看 | 亚洲一区二区三区在线观看网站 | 一区二区三区高清视频一 | 国产av无码专区亚洲a∨毛片 | 国产乱人偷精品人妻a片 | 2019午夜福利不卡片在线 | 亚洲国产av美女网站 | 国产精品二区一区二区aⅴ污介绍 | 欧美精品在线观看 | 成人免费无码大片a毛片 | 黑人大群体交免费视频 | 亚洲国产精品无码久久久久高潮 | 欧美精品在线观看 | 免费国产黄网站在线观看 | 国产色精品久久人妻 | 一个人免费观看的www视频 | 亚洲一区二区三区含羞草 | 成人亚洲精品久久久久软件 | 国产莉萝无码av在线播放 | 色五月丁香五月综合五月 | 国产深夜福利视频在线 | 日本护士毛茸茸高潮 | 精品国产成人一区二区三区 | 内射老妇bbwx0c0ck | 成人性做爰aaa片免费看 | 扒开双腿疯狂进出爽爽爽视频 | 久久精品国产一区二区三区肥胖 | 性生交大片免费看女人按摩摩 | 国产精品99爱免费视频 | 成人无码精品1区2区3区免费看 | 一二三四社区在线中文视频 | 国产明星裸体无码xxxx视频 | 日日橹狠狠爱欧美视频 | 国产后入清纯学生妹 | 精品国产av色一区二区深夜久久 | 无码人妻久久一区二区三区不卡 | 亚洲综合无码久久精品综合 | 免费视频欧美无人区码 | 人妻天天爽夜夜爽一区二区 | 亚洲人成影院在线无码按摩店 | 国产精品免费大片 | 无码国产色欲xxxxx视频 | 在线欧美精品一区二区三区 | 露脸叫床粗话东北少妇 | 中文字幕人成乱码熟女app | 少妇人妻偷人精品无码视频 | 性欧美熟妇videofreesex | 欧美精品无码一区二区三区 | 亚洲欧美精品aaaaaa片 | 午夜肉伦伦影院 | 欧美野外疯狂做受xxxx高潮 | 日韩在线不卡免费视频一区 | 中文字幕无码人妻少妇免费 | 国内精品久久毛片一区二区 | 人妻体内射精一区二区三四 | 色婷婷香蕉在线一区二区 | 国产精品亚洲五月天高清 | 最近的中文字幕在线看视频 | 一本色道久久综合亚洲精品不卡 | 奇米影视888欧美在线观看 | 国产午夜亚洲精品不卡下载 | 国产精品无套呻吟在线 | 白嫩日本少妇做爰 | 久久午夜夜伦鲁鲁片无码免费 | 无码福利日韩神码福利片 | 亚洲大尺度无码无码专区 | 中文字幕无码av激情不卡 | 噜噜噜亚洲色成人网站 | 日韩精品无码一区二区中文字幕 | 特黄特色大片免费播放器图片 | 国产精品欧美成人 | 国产精品嫩草久久久久 | 亚洲精品欧美二区三区中文字幕 | 国内少妇偷人精品视频免费 | 亚洲国产日韩a在线播放 | 搡女人真爽免费视频大全 | 精品乱子伦一区二区三区 | 色婷婷综合激情综在线播放 | 久久天天躁狠狠躁夜夜免费观看 | 国模大胆一区二区三区 | 国内揄拍国内精品少妇国语 | 国产成人人人97超碰超爽8 | 97精品国产97久久久久久免费 | 少妇久久久久久人妻无码 | 在线播放亚洲第一字幕 | 伊在人天堂亚洲香蕉精品区 | 一本久道高清无码视频 | 久久 国产 尿 小便 嘘嘘 | 亚洲狠狠婷婷综合久久 | av人摸人人人澡人人超碰下载 | 老司机亚洲精品影院 | 中文字幕无码av波多野吉衣 | 在线精品国产一区二区三区 | 无码吃奶揉捏奶头高潮视频 | 国产女主播喷水视频在线观看 | 人妻天天爽夜夜爽一区二区 | 国产在线aaa片一区二区99 | 久久亚洲国产成人精品性色 | 亚洲中文字幕无码中文字在线 | 精品少妇爆乳无码av无码专区 | 天下第一社区视频www日本 | 国产精品人人爽人人做我的可爱 | 欧美人与牲动交xxxx | 国产成人综合在线女婷五月99播放 | 又黄又爽又色的视频 | 99精品国产综合久久久久五月天 | 婷婷丁香五月天综合东京热 | 性色av无码免费一区二区三区 | 天下第一社区视频www日本 | 久久亚洲中文字幕精品一区 | 丰满少妇女裸体bbw | 日本一卡二卡不卡视频查询 | 高潮喷水的毛片 | 免费观看又污又黄的网站 | 99麻豆久久久国产精品免费 | 扒开双腿吃奶呻吟做受视频 | 久久精品国产一区二区三区肥胖 | 日本丰满护士爆乳xxxx | 久久99精品久久久久久动态图 | 久久www免费人成人片 | 午夜性刺激在线视频免费 | 人人爽人人澡人人高潮 | 久久久久国色av免费观看性色 | 好屌草这里只有精品 | 狠狠噜狠狠狠狠丁香五月 | 国产日产欧产精品精品app | 国产精品久久精品三级 | 日本xxxx色视频在线观看免费 | 色噜噜亚洲男人的天堂 | 兔费看少妇性l交大片免费 | 国产人妻精品一区二区三区不卡 | 欧美高清在线精品一区 | 免费人成网站视频在线观看 | 丰满少妇弄高潮了www | 国产真实夫妇视频 | 思思久久99热只有频精品66 | 国产精品无码永久免费888 | 欧美高清在线精品一区 | 久久婷婷五月综合色国产香蕉 | 色婷婷欧美在线播放内射 | 亚洲理论电影在线观看 | 九月婷婷人人澡人人添人人爽 | 一本加勒比波多野结衣 | 亚洲成a人片在线观看无码3d | 久久综合色之久久综合 | 久久久精品欧美一区二区免费 | 熟女俱乐部五十路六十路av | 国产情侣作爱视频免费观看 | 国产精品无码一区二区桃花视频 | 丰满岳乱妇在线观看中字无码 | 午夜精品久久久内射近拍高清 | 亚洲毛片av日韩av无码 | 一本加勒比波多野结衣 | a在线亚洲男人的天堂 | 日韩人妻无码中文字幕视频 | 中文字幕av日韩精品一区二区 | 狠狠亚洲超碰狼人久久 | 在线观看免费人成视频 | 亚洲欧美日韩国产精品一区二区 | 在线播放免费人成毛片乱码 | 国产精品a成v人在线播放 | 野外少妇愉情中文字幕 | 欧美一区二区三区视频在线观看 | 国产sm调教视频在线观看 | 国产偷抇久久精品a片69 | 亚洲一区二区三区无码久久 | 欧美精品无码一区二区三区 | 波多野结衣一区二区三区av免费 | 午夜福利不卡在线视频 | 亚洲人成网站色7799 | 久久综合久久自在自线精品自 | 亚洲精品国产品国语在线观看 | 国产乡下妇女做爰 | 伊人久久婷婷五月综合97色 | 好屌草这里只有精品 | 亚洲乱码国产乱码精品精 | 国产乱人伦av在线无码 | 久久久av男人的天堂 | 一本久道久久综合狠狠爱 | 国产欧美精品一区二区三区 | 99视频精品全部免费免费观看 | 婷婷丁香六月激情综合啪 | 久久精品国产99精品亚洲 | 国产高潮视频在线观看 | 欧美老妇交乱视频在线观看 | 亚洲精品国偷拍自产在线观看蜜桃 | 国产国语老龄妇女a片 | 成人亚洲精品久久久久软件 | 久久zyz资源站无码中文动漫 | 亚洲日韩中文字幕在线播放 | 美女黄网站人色视频免费国产 | 日本精品人妻无码77777 天堂一区人妻无码 | 三上悠亚人妻中文字幕在线 | 久久亚洲国产成人精品性色 | 一本色道久久综合狠狠躁 | 漂亮人妻洗澡被公强 日日躁 | 成人免费无码大片a毛片 | √天堂资源地址中文在线 | 青青青爽视频在线观看 | 欧美熟妇另类久久久久久多毛 | 中文字幕无线码免费人妻 | 亚洲一区二区观看播放 | 国产一区二区三区影院 | 又湿又紧又大又爽a视频国产 | 国产精品免费大片 | 九九综合va免费看 | 熟女少妇人妻中文字幕 | 日本又色又爽又黄的a片18禁 | 亚洲国产精品毛片av不卡在线 | 蜜臀aⅴ国产精品久久久国产老师 | 玩弄少妇高潮ⅹxxxyw | 婷婷色婷婷开心五月四房播播 | 欧美人与禽猛交狂配 | 亚洲gv猛男gv无码男同 | 国产亚洲精品精品国产亚洲综合 | 97夜夜澡人人爽人人喊中国片 | 亚洲午夜无码久久 | 日韩 欧美 动漫 国产 制服 | 亚洲 日韩 欧美 成人 在线观看 | 精品国产一区二区三区av 性色 | 中文无码成人免费视频在线观看 | 精品国产精品久久一区免费式 | 无人区乱码一区二区三区 | 日日麻批免费40分钟无码 | 国产精品亚洲专区无码不卡 | 精品无人国产偷自产在线 | 无码人妻丰满熟妇区五十路百度 | 99riav国产精品视频 | 白嫩日本少妇做爰 | 国产色在线 | 国产 | 又大又硬又爽免费视频 | 国产人妻精品午夜福利免费 | 中文字幕乱码人妻二区三区 | 成人aaa片一区国产精品 | 国产明星裸体无码xxxx视频 | 熟妇人妻无码xxx视频 | 国产特级毛片aaaaaa高潮流水 | 亚洲熟悉妇女xxx妇女av | 亚洲乱亚洲乱妇50p | 国产真实夫妇视频 | 国产两女互慰高潮视频在线观看 | 成年女人永久免费看片 | 丝袜人妻一区二区三区 | 99精品视频在线观看免费 | 97夜夜澡人人爽人人喊中国片 | 无码午夜成人1000部免费视频 | 成人试看120秒体验区 | 夜精品a片一区二区三区无码白浆 | 老头边吃奶边弄进去呻吟 | 无码一区二区三区在线观看 | 九月婷婷人人澡人人添人人爽 | 乱人伦人妻中文字幕无码久久网 | 在线a亚洲视频播放在线观看 | 99视频精品全部免费免费观看 | 精品一二三区久久aaa片 | 鲁一鲁av2019在线 | 欧美激情内射喷水高潮 | 欧美人与动性行为视频 | 午夜无码人妻av大片色欲 | 久久久久久a亚洲欧洲av冫 | 国产真实伦对白全集 | aⅴ亚洲 日韩 色 图网站 播放 | 国产一精品一av一免费 | 日韩av无码一区二区三区不卡 | 扒开双腿吃奶呻吟做受视频 | 97人妻精品一区二区三区 | 日韩成人一区二区三区在线观看 | 日韩欧美群交p片內射中文 | 任你躁在线精品免费 | 男女性色大片免费网站 | 欧美性生交活xxxxxdddd | 妺妺窝人体色www婷婷 | 午夜福利试看120秒体验区 | 欧美性生交xxxxx久久久 | 免费无码av一区二区 | 双乳奶水饱满少妇呻吟 | 色婷婷香蕉在线一区二区 | 日日摸夜夜摸狠狠摸婷婷 | 欧美一区二区三区视频在线观看 | 少妇无套内谢久久久久 | 少妇高潮喷潮久久久影院 | 久久国产自偷自偷免费一区调 | 亚洲s码欧洲m码国产av | 国产午夜精品一区二区三区嫩草 | 性生交大片免费看l | 亚洲s码欧洲m码国产av | 131美女爱做视频 | 性生交片免费无码看人 | 中文字幕中文有码在线 | 欧美日韩精品 | 中文字幕人成乱码熟女app | 国产精品香蕉在线观看 | 曰韩少妇内射免费播放 | 国产超碰人人爽人人做人人添 | 99久久久无码国产精品免费 | 久久精品中文字幕一区 | 女人高潮内射99精品 | 国内精品久久毛片一区二区 | 黑森林福利视频导航 | 九九久久精品国产免费看小说 | 日本精品久久久久中文字幕 | 成人免费视频在线观看 | 久久精品国产日本波多野结衣 | 99精品国产综合久久久久五月天 | 亚洲a无码综合a国产av中文 | 无码精品国产va在线观看dvd | 午夜精品久久久内射近拍高清 | 日本熟妇人妻xxxxx人hd | 一本色道久久综合亚洲精品不卡 | 久久伊人色av天堂九九小黄鸭 | 三上悠亚人妻中文字幕在线 | 亚洲人亚洲人成电影网站色 | 久久综合给合久久狠狠狠97色 | 日韩人妻无码一区二区三区久久99 | 国产亚洲精品久久久ai换 | 人妻少妇精品无码专区动漫 | 精品久久久无码人妻字幂 | 成人无码视频在线观看网站 | 99久久99久久免费精品蜜桃 | 黑人大群体交免费视频 | 内射欧美老妇wbb | 免费中文字幕日韩欧美 | 九九久久精品国产免费看小说 | 无码人妻av免费一区二区三区 | 久久久久国色av免费观看性色 | 在线播放免费人成毛片乱码 | 在线精品国产一区二区三区 | 国产精品无码久久av | 国产性生大片免费观看性 | 亚欧洲精品在线视频免费观看 | 久久 国产 尿 小便 嘘嘘 | 一区二区传媒有限公司 | 日韩无码专区 | 国产精品美女久久久网av | 国产内射爽爽大片视频社区在线 | 丰满诱人的人妻3 | 国内揄拍国内精品人妻 | 呦交小u女精品视频 | 思思久久99热只有频精品66 | 亚洲综合色区中文字幕 | 女人被男人躁得好爽免费视频 | 无遮挡啪啪摇乳动态图 | 亚洲精品久久久久中文第一幕 | 久久久久久久久蜜桃 | 日本护士xxxxhd少妇 | 久久久精品456亚洲影院 | 亚洲爆乳大丰满无码专区 | 亚洲国产精品一区二区美利坚 | 色五月五月丁香亚洲综合网 | 国产在线无码精品电影网 | 1000部啪啪未满十八勿入下载 | 国产午夜亚洲精品不卡 | 亚洲中文字幕无码中字 | 少妇人妻偷人精品无码视频 | 一本久久伊人热热精品中文字幕 | 国产精品无码成人午夜电影 | 伊人久久大香线蕉午夜 | 人人爽人人爽人人片av亚洲 | 日本免费一区二区三区最新 | 欧美freesex黑人又粗又大 | 老太婆性杂交欧美肥老太 | 麻豆国产人妻欲求不满 | 麻豆精品国产精华精华液好用吗 | 人人妻人人澡人人爽欧美精品 | 色综合天天综合狠狠爱 | 少妇无码av无码专区在线观看 | 成人欧美一区二区三区黑人 | 国产99久久精品一区二区 | 亚洲中文无码av永久不收费 | 精品无码av一区二区三区 | 亚洲精品美女久久久久久久 | 亚洲午夜久久久影院 | 学生妹亚洲一区二区 | 精品人妻中文字幕有码在线 | 欧美黑人乱大交 | 4hu四虎永久在线观看 | 亚洲精品一区三区三区在线观看 | 亚洲另类伦春色综合小说 | 色综合久久88色综合天天 | 亚洲自偷自偷在线制服 | 粗大的内捧猛烈进出视频 | 亚洲精品国偷拍自产在线麻豆 | 欧美性生交活xxxxxdddd | 精品无码国产一区二区三区av | 永久黄网站色视频免费直播 | 亚洲色欲久久久综合网东京热 | 四虎国产精品免费久久 | 国产国语老龄妇女a片 | 久久zyz资源站无码中文动漫 | 精品国产麻豆免费人成网站 | 成 人影片 免费观看 | 精品午夜福利在线观看 | 人人妻人人澡人人爽欧美一区九九 | 亚洲精品国产精品乱码不卡 | 精品无码国产自产拍在线观看蜜 | 在线观看欧美一区二区三区 | 成熟女人特级毛片www免费 | 老头边吃奶边弄进去呻吟 | 久久久无码中文字幕久... | 天干天干啦夜天干天2017 | 欧美兽交xxxx×视频 | 中文字幕亚洲情99在线 | 一本无码人妻在中文字幕免费 | 人妻体内射精一区二区三四 | 中文字幕无码av激情不卡 | 高清国产亚洲精品自在久久 | 国产精品人妻一区二区三区四 | 伊人久久大香线蕉亚洲 | 青青久在线视频免费观看 | 性做久久久久久久免费看 | 国产国产精品人在线视 |