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

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 综合教程 >内容正文

综合教程

Linux下时钟框架实践---一款芯片的时钟树配置

發布時間:2023/12/13 综合教程 34 生活家
生活随笔 收集整理的這篇文章主要介紹了 Linux下时钟框架实践---一款芯片的时钟树配置 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

關鍵詞:時鐘、PLL、Mux、Divider、Gate、clk_summary等。

時鐘和電源是各種設備的基礎設施,整個時鐘框架可以抽象為幾種基本的元器件:負責提供晶振

Linux內核提供了良好的CCF(Common Clock Framework),框架的兩端一個是provider,一個是consumer。

provider指的是提供時鐘模塊,包括晶振、PLL、Mux、Divider、Gate等,consumer指的是使用這些時鐘的模塊。

1. Linux時鐘框架基礎

相關文檔對時鐘框架做了詳細的介紹:《Linux common clock framework(1)_概述》、《Linux common clock framework(2)_clock provider》、《Linux common clock framework(3)_實現邏輯分析》以及《Common Clock Framework系統結構》。

這里簡單羅列一下相關知識。

1.1 編寫時鐘provider驅動

provider包含基本硬件元素:Oscillator/Crystal-提供時鐘晶振、PLL-倍頻、Mux-多路選擇、Divider-分頻器、Gate-控制開關,還有Fixed-Divider-固定分頻器。

這些硬件都可以抽象成一種類型的時鐘,所有類型的時鐘都可以通過struct clk_hw描述。

struct clk_hw {
    struct clk_core *core;
    struct clk *clk;
    const struct clk_init_data *init;
};

struct clk_core {
    const char        *name;
    const struct clk_ops    *ops;
    struct clk_hw        *hw;
    struct module        *owner;
    struct clk_core        *parent;
    const char        **parent_names;
    struct clk_core        **parents;
    u8            num_parents;
    u8            new_parent_index;
    unsigned long        rate;
    unsigned long        req_rate;
    unsigned long        new_rate;
    struct clk_core        *new_parent;
    struct clk_core        *new_child;
    unsigned long        flags;
    bool            orphan;
    unsigned int        enable_count;
    unsigned int        prepare_count;
    unsigned long        min_rate;
    unsigned long        max_rate;
    unsigned long        accuracy;
    int            phase;
    struct hlist_head    children;
    struct hlist_node    child_node;
    struct hlist_head    clks;
    unsigned int        notifier_count;
#ifdef CONFIG_DEBUG_FS
    struct dentry        *dentry;
    struct hlist_node    debug_node;
#endif
    struct kref        ref;
};
struct clk_init_data {
    const char        *name;
    const struct clk_ops    *ops;
    const char        * const *parent_names;
    u8            num_parents;
    unsigned long        flags;
};
struct clk_ops { int (*prepare)(struct clk_hw *hw); void (*unprepare)(struct clk_hw *hw); int (*is_prepared)(struct clk_hw *hw); void (*unprepare_unused)(struct clk_hw *hw); int (*enable)(struct clk_hw *hw); void (*disable)(struct clk_hw *hw); int (*is_enabled)(struct clk_hw *hw); void (*disable_unused)(struct clk_hw *hw); unsigned long (*recalc_rate)(struct clk_hw *hw, unsigned long parent_rate); long (*round_rate)(struct clk_hw *hw, unsigned long rate, unsigned long *parent_rate); int (*determine_rate)(struct clk_hw *hw, struct clk_rate_request *req); int (*set_parent)(struct clk_hw *hw, u8 index); u8 (*get_parent)(struct clk_hw *hw); int (*set_rate)(struct clk_hw *hw, unsigned long rate, unsigned long parent_rate); int (*set_rate_and_parent)(struct clk_hw *hw, unsigned long rate, unsigned long parent_rate, u8 index); unsigned long (*recalc_accuracy)(struct clk_hw *hw, unsigned long parent_accuracy); int (*get_phase)(struct clk_hw *hw); int (*set_phase)(struct clk_hw *hw, int degrees); void (*init)(struct clk_hw *hw); int (*debug_init)(struct clk_hw *hw, struct dentry *dentry); };

clk_register()將描述時鐘的struct clk_hw注冊,轉化成strcut clk變量。

但在實際使用中,對不同類型的時鐘往往調用其對應的封裝函數。

對于上面提到的硬件在下面都能找到對應的注冊函數,其中包括一個composite設備作為一個組合注冊。

struct clk *clk_register(struct device *dev, struct clk_hw *hw)

int clk_hw_register(struct device *dev, struct clk_hw *hw)
struct clk *clk_register_fixed_rate(struct device *dev, const char *name, const char *parent_name, unsigned long flags, unsigned long fixed_rate); struct clk *clk_register_gate(struct device *dev, const char *name, const char *parent_name, unsigned long flags, void __iomem *reg, u8 bit_idx, u8 clk_gate_flags, spinlock_t *lock); struct clk *clk_register_divider(struct device *dev, const char *name, const char *parent_name, unsigned long flags, void __iomem *reg, u8 shift, u8 width, u8 clk_divider_flags, spinlock_t *lock); struct clk *clk_register_mux(struct device *dev, const char *name, const char * const *parent_names, u8 num_parents, unsigned long flags, void __iomem *reg, u8 shift, u8 width, u8 clk_mux_flags, spinlock_t *lock); struct clk *clk_register_fixed_factor(struct device *dev, const char *name, const char *parent_name, unsigned long flags, unsigned int mult, unsigned int div); struct clk *clk_register_fractional_divider(struct device *dev, const char *name, const char *parent_name, unsigned long flags, void __iomem *reg, u8 mshift, u8 mwidth, u8 nshift, u8 nwidth, u8 clk_divider_flags, spinlock_t *lock); struct clk *clk_register_composite(struct device *dev, const char *name, const char * const *parent_names, int num_parents, struct clk_hw *mux_hw, const struct clk_ops *mux_ops, struct clk_hw *rate_hw, const struct clk_ops *rate_ops, struct clk_hw *gate_hw, const struct clk_ops *gate_ops, unsigned long flags);

最后調用of_clk_add_provider()將注冊的時鐘加入到OF框架中。

int of_clk_add_provider(struct device_node *np,
            struct clk *(*clk_src_get)(struct of_phandle_args *args,
                           void *data),
            void *data);

1.2 consumer使用時鐘

其他設備需要使用時鐘,可以再驅動中后去時鐘也可以在設備DTS中引用時鐘。

struct clk *clk_get(struct device *dev, const char *id);
struct clk *devm_clk_get(struct device *dev, const char *id);
int clk_enable(struct clk *clk);
void clk_disable(struct clk *clk);
unsigned long clk_get_rate(struct clk *clk);
void clk_put(struct clk *clk);
void devm_clk_put(struct device *dev, struct clk *clk);
long clk_round_rate(struct clk *clk, unsigned long rate);
int clk_set_rate(struct clk *clk, unsigned long rate);
bool clk_has_parent(struct clk *clk, struct clk *parent);
int clk_set_rate_range(struct clk *clk, unsigned long min, unsigned long max);
int clk_set_min_rate(struct clk *clk, unsigned long rate);
int clk_set_max_rate(struct clk *clk, unsigned long rate);
int clk_set_parent(struct clk *clk, struct clk *parent);
struct clk *clk_get_parent(struct clk *clk);
struct clk *clk_get_sys(const char *dev_id, const char *con_id);

int clk_prepare(struct clk *clk);
void clk_unprepare(struct clk *clk);
static inline int clk_prepare_enable(struct clk *clk)
static inline void clk_disable_unprepare(struct clk *clk)
struct clk *of_clk_get(struct device_node *np, int index); struct clk *of_clk_get_by_name(struct device_node *np, const char *name); struct clk *of_clk_get_from_provider(struct of_phandle_args *clkspec);

2. 如何實現一款芯片的時鐘框架

對一款芯片配置時鐘框架,首先拿到時鐘框架圖,上面會有詳細的Mux關系、是否有Divider、是否是Fixed Divider、是否有gate等等。

將這些器件找到對應的Linux時鐘框架抽象,將整張時鐘框架圖抽象成Linux時鐘框架識別的屬性結構。

然后還需要每一個器件的寄存器解釋。

在有了這些準備工作之后,工作氛圍兩部分:編寫器件抽象驅動,比如Fixed clock、Gate、Divider等;按照時鐘框架圖編寫DTS文件,寄存器參照規格書,compatible和驅動對應。

2.1 編寫類型時鐘驅動

首先通過CLK_OF_DECLARE()將字符串和xx2000_divider_setup()進行關聯,然后在xx2000_divider_setup進行時鐘的注冊。

static void xx2000_divider_setup(struct device_node *node)
{
    void __iomem *reg;
    struct resource res;
    struct clk *clk;
    unsigned int bit_shift = 0, bit_width = 0;
    const char *clk_name = NULL;
    const char *parent_name;
    int ret = 0;

    if(!node)
        return;

    reg = of_io_request_and_map(node, 0, of_node_full_name(node));-----------------------------------將寄存器映射,后續對divider的設置以及讀取都需要此寄存器。
    if(IS_ERR(reg)) {
        pr_err("%s <%s> must have a reg property.
", __func__, node->name);
        return;
    }

    if(of_property_read_u32(node, "bit-shift", &bit_shift)) {----------------------------------------操作divider需要知道配置divider的位偏移及位寬。然后根據頻率選擇divider的值,設置到寄存器中。獲取時鐘頻率也通過讀取寄存器值進行計算。
        pr_err("%s <%s> must have a bit-shift property.
", __func__, node->name);
        goto err_unmap;
    }
    if(of_property_read_u32(node, "bit-width", &bit_width)) {
        pr_err("%s <%s> must have a bit-width property.
", __func__, node->name);
        goto err_unmap;
    }

    parent_name = of_clk_get_parent_name(node, 0);----------------------------------------------------獲取父時鐘名稱。
    if(!parent_name)
    {
        pr_err("%s <%s> must have a parent.
", __func__, node->name);
        goto err_unmap;
    }

    of_property_read_string(node, "clock-output-names", &clk_name);

    clk = clk_register_divider(NULL, clk_name, parent_name, 0, reg, bit_shift, bit_width, 0, NULL);---注冊divider時鐘,必須要有的參數有reg、bit_shift、bit_width,以及本身的名稱。
    if(IS_ERR(clk))
    {
        pr_err("%s Failed to register <%s>.
", __func__, node->name);
        goto err_unmap;
    }

    ret = of_clk_add_provider(node, of_clk_src_simple_get, clk);--------------------------------------將注冊的時鐘加入到OF框架。
    if(ret)
    {
        pr_err("%s Failed to add <%s>.
", __func__, node->name);
        goto err_unregister;
    }

    return;
    
    err_unregister:
        clk_unregister_divider(clk);

    err_unmap:
        iounmap(reg);
        of_address_to_resource(node, 0, &res);
        release_mem_region(res.start, resource_size(&res));
    return;
}

CLK_OF_DECLARE(xx2000_clk_divider, "xx2000,clk-divider", xx2000_divider_setup);

2.2 編寫DTS文件

有了上面的時鐘框架圖、時鐘寄存器規格書和驅動,就可以按部就班的按照時鐘框架圖一步一步編寫DTS。

編寫fixed clock的晶振、PLL等;
編寫多路復用Mux和分頻器Divider,需要配置寄存器以及寄存器的bit-shift和bit-width。

具體的DTS配置,參考如下:

            cpu_core_clk: cpu-core-clk {---------------------------------cpu_core_clk是在其他設備中clocks指向的名稱。
                #clock-cells = <0>;--------------------------------------0表示只有一個輸出,1表示多余一個輸出。
                compatible = "xx2000,clk-divider";-----------------------如果有特殊需求,還需要編寫自己的驅動。這里通過此字符串進行匹配。
                reg = <CPU_CLK_DIV 0x4>;---------------------------------配置此事中的寄存器地址以及大小。
                bit-shift = <0>;-----------------------------------------對于divider類型需要知道配置bit在寄存器中的偏移以及bit位寬。
                bit-width = <5>;
                clocks = <&cpu_mux 0>;-----------------------------------clocks指向父時鐘。
                clock-output-names = "cpu_core_clk";---------------------本時鐘輸出名稱,在consumer時鐘中可以使用此名稱來獲得該時鐘的struct clk結構體。
            };

3. 對時鐘框架進行驗證

3.1 clk_summary驗證時鐘樹

通過讀取/sys/kernel/debug/clk/clk_summary信息,和時鐘框圖對照,可以驗證DTS配置正確與否。

   clock                             enable  prepare_cnt        rate   accuracy   phase
---------------------------------------------------------------------------------------- ddr_pll                                  0            0  1200000000          0 0  
 nn_pll                                   0            0   750000000          0 0  
 video_pll                                0            0  1100000000          0 0  
    sdio0_mux                             0            0  1100000000          0 0  
       sdio0_cclk_divider                 0            0    39285715          0 0  
          sdio0_cclk                      0            0    39285715          0 0...
 cpu_pll                                  0            0  1000000000          0 0  
    cpu_mux                               0            0  1000000000          0 0  
       cpu_core_clk                       0            0  1000000000          0 0  
          cpu_bus_clk                     0            0   500000000          0 0  
             cpu_apb_clk                  0            0   250000000          0 0  
             ddr_cpu_port_clk             0            0   500000000          0 0  
 rtc_clk                                  0            0       32768          0 0  
    tsen_mux                              0            0       32768          0 0  
       tsen_clk                           0            0       32768          0 0  
 ref_clk                                  0            0    24000000          0 0  
    wdt_clk                               0            0    24000000          0 0  
    timer3_clk                            0            0    24000000          0 0  
    timer2_clk                            0            0    24000000          0 0  
    timer1_clk                            0            0    24000000          0 0  
    timer0_clk                            0            0    24000000          0 0  
    ref_clk_750_fixed_factor              0            0       32000          0 0  
       usb_suspend_clk                    0            0       32000          0 0  

3.2 驗證時鐘實際輸出

在/sys/kernel/debug/clk目錄下,每個時鐘都有自己的目錄。

在clk_debug_create_one()函數中,對divider和gate類型時鐘創建相應的節點用于控制硬件。

 static int clk_debug_create_one(struct clk_core *core, struct dentry *pdentry)
 {
        struct dentry *d;
@@ -2182,6 +2290,7 @@ static int clk_debug_create_one(struct clk_core *core, struct dentry *pdentry)
                if (ret)
                        goto err_out;
        }
+    xx2000_clk_create(core);
 
        ret = 0;
        goto out;

下面根據struct clk_core所對應的struct clk_ops來判斷時鐘的類型,gate創建xx2000_gate,divider創建xx2000_rate節點。

static ssize_t xx2000_gate_read(struct file *filp, char __user *buffer,
                    size_t count, loff_t *ppos)
{
    struct clk_core *pdata = filp->private_data;
    unsigned int value;
    char tmp[32];
    size_t size;

    value = __clk_is_enabled(pdata->hw->clk);
    size = sprintf(tmp, "%u
", value);
    printk("%s value=%u
", __func__, value);

    return simple_read_from_buffer(buffer, count, ppos, tmp, size);
}

static ssize_t xx2000_gate_write(struct file *filp,
                     const char __user *buffer,
                     size_t count, loff_t *ppos)
{
    struct clk_core *pdata = filp->private_data;
    unsigned int value;
    int ret = 0;

    ret = kstrtouint_from_user(buffer, count, 0, &value);
    if (ret)
        return -EFAULT;

    printk("%s name=%s value=%u
", __func__, pdata->name, value);

    if(value)
        clk_prepare_enable(pdata->hw->clk);
    else
        clk_disable_unprepare(pdata->hw->clk);
    return count;
}

static const struct file_operations xx2000_gate_ops = {
    .owner = THIS_MODULE,
    .open = simple_open,
    .read = xx2000_gate_read,
    .write = xx2000_gate_write,
    .release = single_release,
};

static ssize_t xx2000_rate_read(struct file *filp, char __user *buffer,
                    size_t count, loff_t *ppos)
{
    struct clk_core *pdata = filp->private_data;
    unsigned long rate;
    char tmp[32];
    size_t size;

    rate = clk_get_rate(pdata->hw->clk);
    size = sprintf(tmp, "%lu
", rate);
    printk("%s value=%lu
", __func__, rate);

    return simple_read_from_buffer(buffer, count, ppos, tmp, size);
}

static ssize_t xx2000_rate_write(struct file *filp,
                     const char __user *buffer,
                     size_t count, loff_t *ppos)
{
    struct clk_core *pdata = filp->private_data;
    unsigned int rate;
    int ret = 0;

    ret = kstrtouint_from_user(buffer, count, 0, &rate);
    if (ret)
        return -EFAULT;

    printk("%s value=%u
", __func__, rate);

    if(rate)
        clk_set_rate(pdata->hw->clk, rate);
    return count;
}

static const struct file_operations xx2000_rate_ops = {
    .owner = THIS_MODULE,
    .open = simple_open,
    .read = xx2000_rate_read,
    .write = xx2000_rate_write,
    .release = single_release,
};

void xx2000_clk_create(struct clk_core *core)
{
    const struct clk_ops *clk_ops = core->ops;

    //printk("%s %s %p %p %p %p
", __func__, core->name ,clk_ops, &clk_gate_ops, &clk_mux_ops, &clk_divider_ops);
    if(clk_ops == &clk_gate_ops)
    {
        debugfs_create_file("xx2000_gate", S_IRUSR | S_IWUSR, core->dentry, core, &xx2000_gate_ops);
    }
    else if(clk_ops == &clk_mux_ops)
    {
//        debugfs_create_file("xx2000_mux", S_IRUSR | S_IWUSR, core->dentry, core, &xx2000_mux_ops);
    }
    else if(clk_ops == &clk_divider_ops)
    {
        debugfs_create_file("xx2000_rate", S_IRUSR | S_IWUSR, core->dentry, core, &xx2000_rate_ops);
    }
}

選擇合適的clk輸出pin,對上面的不同時鐘進行開關、頻率選擇。

可以通過clk_summary查看結果;還可以通過測量pin輸出波形驗證結果是否正確。

4. 小結

Linux提供了良好的時鐘框架,wowotech.net對其進行了詳細的總結。

在實際應用中,通過時鐘框架圖對時鐘樹進行抽象,結合時鐘規格書配置時鐘樹;編寫時鐘驅動。

然后查看clk_summary,并進行驗證;最后在相應的設備驅動中使用時鐘。

總結

以上是生活随笔為你收集整理的Linux下时钟框架实践---一款芯片的时钟树配置的全部內容,希望文章能夠幫你解決所遇到的問題。

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

久久久一本精品99久久精品66 | 欧美一区二区三区在线观看 | 91人人澡人人爽人人精品 | 五月婷婷丁香综合 | 成人免费在线观看入口 | 久久久久久综合网天天 | 午夜国产成人 | 国产成人精品女人久久久 | 国产黄色资源 | 天天干夜夜爱 | 国产精品一区一区三区 | 最新成人av | 91精品视频免费 | 亚洲精品国产免费 | 一区二区理论片 | 亚洲成人第一区 | 97在线视| 在线va网站 | 91av原创| 国产麻豆精品久久一二三 | 99久久99久国产黄毛片 | 国产精品麻豆视频 | 91精品色 | 国产精品一区二区在线免费观看 | 亚洲伊人成综合网 | av线上免费看 | 欧美日韩中文在线视频 | 三级视频片 | 国产精品一区专区欧美日韩 | 成人网页在线免费观看 | 国产精品视频内 | 久久高清国产 | 日韩精品在线观看av | 特级西西444www高清大视频 | 欧美五月婷婷 | 日韩,精品电影 | 亚洲精品在线二区 | 免费在线观看av电影 | 又湿又紧又大又爽a视频国产 | 91成人网在线播放 | 日韩a在线 | 日韩国产高清在线 | 久久国产女人 | 久久艹久久 | 国产精品麻豆三级一区视频 | 五月天婷婷免费视频 | 在线观看黄网站 | 免费精品在线视频 | 超碰97av在线| 四虎影视精品永久在线观看 | 亚洲人成人在线 | 日韩在线播放欧美字幕 | 亚洲干视频在线观看 | 天天躁日日躁狠狠躁 | 中文字幕在线观看第二页 | 操久 | 国产精品欧美久久久久天天影视 | 亚洲精品国产精品乱码在线观看 | 久久草在线视频国产 | 成人一区在线观看 | 欧美日韩另类在线 | 日韩视频一区二区三区 | 五月天国产 | 毛片视频电影 | 国产探花 | 久久九九网站 | 欧美黄网站 | 天天综合91 | 91精品国产乱码久久 | 操操操天天操 | 97在线影院 | 99精品在线视频观看 | 国产国产人免费人成免费视频 | 国产精品麻豆一区二区三区 | 久久看看| 国产亚洲精品成人 | 日韩欧美视频在线观看免费 | 97久久精品午夜一区二区 | 色偷偷97| 成人毛片一区二区三区 | 欧美一区二区三区不卡 | 黄色成人av | 成年人视频在线免费播放 | 欧美日韩aa | 久久av在线播放 | 在线免费视频你懂的 | 色香网| 日韩欧美电影网 | 99久久影院 | 国产精品久久久久久婷婷天堂 | 精品99在线| 亚洲国产丝袜在线观看 | 黄色大全免费观看 | 成人中文字幕在线观看 | 成人91在线 | 国产精品97| 国产黄色高清 | 香蕉视频国产在线 | 在线精品观看国产 | 91香蕉视频 | 成人黄色大片网站 | 久久草草影视免费网 | 九九九在线观看视频 | 成人在线观看日韩 | 在线黄色国产 | 亚洲精品美女在线观看 | 国产精品亚洲a | 国产黄色一级大片 | 91视频xxxx| 国产精品女主播一区二区三区 | 欧美亚洲国产日韩 | 天天插狠狠插 | 国产精品12| 日日操操操 | 2022国产精品视频 | 国产成人精品久久二区二区 | 亚洲美女免费精品视频在线观看 | 久久综合视频网 | www.久热| 亚洲综合小说 | 一个色综合网站 | 国产精品久久久久久麻豆一区 | 亚洲三级在线免费观看 | 伊人网综合在线观看 | 午夜精品久久久99热福利 | 国产中文字幕在线看 | 国产欧美三级 | 国产一区二区三区免费观看视频 | 国产视 | 人成免费网站 | 中文字幕一区二区三区在线观看 | 中文字幕电影高清在线观看 | 国产精品久久久久久久久久久久久 | 亚洲一区天堂 | 免费在线观看av不卡 | 国产在线播放一区二区 | 久久综合久久综合久久综合 | 麻豆久久精品 | 天天干天天操天天干 | 在线亚洲人成电影网站色www | 日韩午夜精品福利 | 97爱 | 日韩高清在线一区二区 | 黄色91在线| 亚洲精品久久在线 | 免费日韩 精品中文字幕视频在线 | 精品在线观看一区二区 | 日日爽夜夜爽 | 51精品国自产在线 | 黄色视屏av | 国产精品日韩在线 | 久久久久亚洲精品成人网小说 | 精品国产乱子伦一区二区 | 蜜臀av性久久久久蜜臀aⅴ四虎 | 狠狠色丁香久久婷婷综合五月 | 久久综合九色综合网站 | 午夜精品一区二区三区四区 | 中文字幕日韩无 | 天天撸夜夜操 | 国产精品福利视频 | 欧美精品久久久久久 | 精品国产一区二区三区久久影院 | 夜夜躁狠狠躁日日躁 | 久久精品99久久 | 国产亚洲精品久久网站 | 波多野结衣视频一区二区三区 | 国产精品伦一区二区三区视频 | 亚洲国内精品在线 | 天天干,天天射,天天操,天天摸 | 免费精品在线 | 日韩午夜大片 | 91精品久久久久久久久久入口 | 亚洲精品www | 亚洲 成人 欧美 | 色综合激情久久 | 精品一区在线 | 免费人成在线观看 | 国产精品久久久久久久久久久免费看 | 丁香婷婷深情五月亚洲 | 国产精品久久久久久久久久久久久久 | 日韩 精品 一区 国产 麻豆 | 亚洲精品在线观看的 | 日韩久久精品一区二区三区下载 | 日韩黄色免费电影 | 99久热在线精品 | 亚洲精品成人av在线 | 成人精品视频久久久久 | 国产亚洲精品久久久久久无几年桃 | 亚洲欧美日韩中文在线 | 国产婷婷在线观看 | 99九九视频| 99久久日韩精品免费热麻豆美女 | 中文字幕免费 | 狠狠色丁香婷婷综合久久片 | 亚洲在线精品 | 久久美女高清视频 | 在线免费av观看 | 精品久久网站 | 韩日成人av | 在线观看色网 | 亚洲一级片在线观看 | 婷婷六月天综合 | 日本中出在线观看 | 久久欧美视频 | 最新精品视频在线 | 三上悠亚在线免费 | 婷婷网五月天 | 国产精品18久久久久vr手机版特色 | 亚洲五月综合 | 国产精品99久久免费观看 | 91污污| 久久视频99 | 欧美片网站yy | 精品伦理一区二区三区 | 中文字幕最新精品 | 天天操网站 | 三级黄色在线 | 免费久久99精品国产婷婷六月 | 一区二区三区在线电影 | 亚洲国产av精品毛片鲁大师 | 久碰视频在线观看 | 激情综合网五月 | 国产伦理久久精品久久久久_ | 国产精品中文字幕在线 | 国产午夜视频在线观看 | 国产精品一区二区三区99 | 天堂av在线| 免费视频 三区 | 亚洲禁18久人片 | 久久99精品国产91久久来源 | 色综合天天综合网国产成人网 | 亚洲精欧美一区二区精品 | 国产精品一区二区果冻传媒 | 国产精品黑丝在线观看 | 免费美女av| 精品在线看 | 精品视频中文字幕 | 日韩免费av网址 | 色婷婷精品大在线视频 | 久久精品国产一区二区 | 三日本三级少妇三级99 | 久久精品之 | 久久婷婷一区二区三区 | 国产女v资源在线观看 | 国产精品嫩草影院9 | 欧美色图亚洲图片 | 国产精品毛片一区二区 | 黄a在线看 | av成人免费网站 | 黄色小说在线观看视频 | 美女视频永久黄网站免费观看国产 | 天天操夜夜看 | 天堂视频一区 | 福利一区二区 | 欧美日韩中字 | 国产视频久久久 | 日韩一区二区三区免费视频 | 黄色成人av网址 | 国产精品夜夜夜一区二区三区尤 | 在线观看日韩精品 | www.av小说 | 国产精品久久一区二区三区不卡 | 国产精品久久久久久久久久久久久 | 欧美日韩在线视频一区 | 97超视频 | 中文字幕影视 | 久久人人爽视频 | 久久免费视频7 | 特黄特黄的视频 | 国产区精品视频 | 成人免费在线视频观看 | 欧美日韩国产一区二 | www.超碰| 久久伊人五月天 | 激情五月激情综合网 | 久久久久久久久久久久久久免费看 | 色国产精品一区在线观看 | 国产不卡在线观看 | 国产精品久久久久久妇 | 五月婷婷丁香在线观看 | 一区二区毛片 | www九九热 | 黄色免费观看视频 | 国产午夜精品一区二区三区四区 | 黄色软件视频大全免费下载 | www.激情五月.com | 一级黄视频 | 91伊人| 亚洲区另类春色综合小说校园片 | 天天干亚洲 | 另类老妇性bbwbbw高清 | 色在线网| 日韩在线视频不卡 | 毛片网在线观看 | 久久免费在线观看 | 久久免费国产精品 | 精品国产不卡 | 国产精品九九视频 | 超碰在线免费97 | 久久精品免费 | 日韩免费电影一区二区三区 | 日日夜夜干 | 97免费中文视频在线观看 | 国色天香第二季 | 亚洲精品国产区 | 日日干 天天干 | 美女网色| 久久久影院一区二区三区 | 日韩高清三区 | 久久久999精品视频 国产美女免费观看 | 在线观看免费视频你懂的 | 精品国产伦一区二区三区观看说明 | 欧美精品做受xxx性少妇 | 日韩在线观看的 | 国产啊v在线 | 亚洲激情五月 | 国产精品99在线播放 | www免费看 | 99r在线播放 | 狠狠色丁香婷婷综合久小说久 | 婷婷成人在线 | 久草在线资源观看 | 人人澡人人爽欧一区 | 国产网站av | 久久国产精品影视 | 99精品在线观看 | 国产99久久精品一区二区300 | 欧美另类xxxxx | 在线色视频小说 | 国产五月色婷婷六月丁香视频 | a在线观看视频 | 在线观看精品一区 | 日韩二区三区在线观看 | 欧美色图东方 | 精品国产乱码久久久久久三级人 | 狠狠色丁香婷综合久久 | 狠狠操.com| 91在线观看视频 | 一区二区三区在线视频观看58 | 91在线视频在线观看 | 久久久国产一区二区 | 高清色免费 | 996久久国产精品线观看 | 精品视频国产一区 | 亚洲视频免费 | 日本久久久久久久久久久 | av在线中文| 500部大龄熟乱视频使用方法 | 久久99国产综合精品免费 | 人人网av| 中文国产在线观看 | 一级欧美日韩 | 国产在线精品一区二区三区 | 国产精品99久久久精品免费观看 | 中文字幕在线字幕中文 | 亚洲黄色免费观看 | 开心色停停| 夜又临在线观看 | 国产a高清 | 国产精品av免费在线观看 | 午夜精品一区二区三区免费视频 | 中文在线中文资源 | 久久久免费av | 伊人看片 | 天天操天天爽天天干 | 99热这里只有精品国产首页 | 亚洲精品五月天 | 久草精品免费 | 美女网站一区 | 久久99久久久久 | 久久免费的视频 | 高清有码中文字幕 | 中文字幕在线观看的网站 | 91九色国产在线 | 五月婷婷一区二区三区 | 国产精品国产三级国产不产一地 | 久久久久国产a免费观看rela | 国产黄色美女 | 欧美xxxxx在线视频 | 911在线 | 成人av免费看| 欧美韩日精品 | 不卡的av电影在线观看 | 大荫蒂欧美视频另类xxxx | 久久精品中文字幕一区二区三区 | 99热国产在线观看 | 日本爱爱免费 | 久久国产精品小视频 | 国产一区二区精 | 女人18毛片90分钟 | 五月婷婷一区 | 国产69精品久久久久99尤 | 视频国产在线观看18 | 国产操在线 | 一级做a爱片性色毛片www | 亚洲综合激情小说 | 国产亚洲精品成人av久久ww | 久久视奸| av7777777| 欧美日韩国产免费视频 | 久久久久高清毛片一级 | 波多野结衣在线观看一区 | 日日爽天天操 | 国产白浆在线观看 | 亚洲免费一级 | 亚洲精品中文字幕在线 | 久久福利小视频 | 久久人人爽人人人人片 | 久久九九久久 | 国产不卡免费 | 黄色软件在线观看 | 色婷婷丁香 | 免费在线观看日韩视频 | 国产经典av| 日韩视频在线观看视频 | 久久成人国产精品免费软件 | 国产亚洲欧美在线视频 | 日本性生活免费看 | 国产专区日韩专区 | 欧美日韩国产一二 | 色五婷婷 | 国产99一区视频免费 | 日韩欧美综合视频 | 日本激情中文字幕 | 亚洲成人精品av | 人人射av | 成人黄色资源 | 午夜精品久久久久久久99 | 成人午夜在线观看 | 国产精品专区h在线观看 | 97超碰在线久草超碰在线观看 | 中文字幕最新精品 | 999久久国产精品免费观看网站 | 97国产在线 | 婷婷在线视频 | 国产高h视频 | 国产精品美女久久久久久 | 玖玖999 | 国产不卡av在线 | 91在线www| 高清av在线| 96久久久 | 国产一区二区精品在线 | 久久精品国产精品亚洲 | 日本精品一 | 国产又黄又爽又猛视频日本 | 国产偷v国产偷∨精品视频 在线草 | 天天射天天操天天干 | 日韩动漫免费观看高清完整版在线观看 | 国产成人三级在线播放 | 黄色av一区二区 | 久久国产亚洲视频 | 亚洲国产精品电影 | 美女视频一区二区 | 国产成人精品免费在线观看 | 免费久久99精品国产婷婷六月 | 亚洲激情| 免费a v观看| 欧美精品久久天天躁 | 欧美国产日韩一区二区三区 | 俺要去色综合狠狠 | 992tv在线观看网站 | 亚洲天天在线日亚洲洲精 | 色婷婷激情电影 | 国产一区在线视频 | 日韩中文字幕亚洲一区二区va在线 | 国产成人精品av久久 | 日韩av在线不卡 | 973理论片235影院9 | 国产成人精品一区二区在线 | 看v片 | 一本一本久久a久久精品牛牛影视 | 在线一二区 | 欧美精品久久 | 婷婷久久一区 | 97人人澡人人添人人爽超碰 | 中文国产在线观看 | 玖玖在线资源 | 国产精品女人久久久久久 | 国产午夜三级一区二区三桃花影视 | www.狠狠| 日日摸日日 | 精品在线99| 99视频国产精品免费观看 | 天天色婷婷| 在线免费av网站 | 天天久久综合 | 麻豆传媒视频在线播放 | 久久99久久99精品免观看软件 | 婷婷综合导航 | 免费视频一二三区 | 久久婷亚洲五月一区天天躁 | 久久久综合 | 蜜臀精品久久久久久蜜臀 | 九九九热精品免费视频观看网站 | 色婷婷狠狠五月综合天色拍 | 久久在线看 | 99久久www | 一区二区三区四区免费视频 | 久草在线费播放视频 | 国产系列 在线观看 | 深爱婷婷网 | 国产 日韩 在线 亚洲 字幕 中文 | 欧美日韩中文国产一区发布 | 99精品在线视频观看 | 成年人黄色免费网站 | 在线观看视频国产 | 欧美日韩在线视频一区 | 久久精品久久久久 | 97精品国自产拍在线观看 | 丁香激情综合国产 | 手机在线小视频 | 欧美色就是色 | 黄色片网站免费 | 久久免费av电影 | 在线免费视频你懂的 | 人人爽人人澡 | 国产高清在线视频 | 久久综合给合久久狠狠色 | 极品久久久久久久 | 欧美亚洲另类在线视频 | 97超碰免费| 久久久国际精品 | 国产 中文 日韩 欧美 | 五月婷婷久久综合 | 福利电影久久 | 91亚洲精品久久久蜜桃借种 | 一区二区三区在线视频111 | 国内久久久久 | 国产精品一区二区三区99 | 久久免费在线观看视频 | 日韩久久精品一区二区三区下载 | 成人av片免费观看app下载 | 国产无套一区二区三区久久 | 久久国产电影 | av资源在线观看 | 在线观看免费观看在线91 | 日韩精品一区在线观看 | 国产99一区视频免费 | 久久国产精品久久国产精品 | 少妇高潮流白浆在线观看 | 456成人精品影院 | 亚洲 综合 专区 | 九九九视频在线 | www.五月天婷婷 | 精品高清美女精品国产区 | 国产亚洲欧美精品久久久久久 | 懂色av懂色av粉嫩av分享吧 | 久久精品一区二区三区视频 | 亚洲精品国偷拍自产在线观看 | 免费国产一区二区视频 | 最近免费中文字幕 | 91丨九色丨国产女 | a级国产毛片 | 国产精美视频 | 国产一区二区免费 | 9色在线视频 | 日韩一二三区不卡 | 亚洲最快最全在线视频 | 欧美 激情 国产 91 在线 | 久草在线观看资源 | 午夜精品久久久久久久99 | 久在线观看视频 | 免费高清在线视频一区· | 中文字幕黄色 | 国产91精品一区二区 | 爱爱av网 | 日韩精品免费在线视频 | 99热在线观看 | 日本一区二区高清不卡 | 在线免费91 | 一区二区中文字幕在线播放 | 日韩在线观看中文字幕 | 欧美久久综合 | 黄色片软件网站 | 国产中文字幕在线看 | 国产小视频网站 | 婷婷综合成人 | 欧美天堂久久 | 色婷婷成人 | 日韩欧美有码在线 | 精品伊人久久久 | 欧美一级黄大片 | 亚洲 成人 欧美 | 国产精品久久久久久久99 | 国产精品久久久亚洲 | 日韩av看片 | 久久精品99国产精品 | 中文字幕人成不卡一区 | 欧美极品少妇xxxx | 免费观看国产精品视频 | 国产精品va在线观看入 | 中文字幕在线专区 | 欧美男女爱爱视频 | 国产亚洲va综合人人澡精品 | 日韩欧美精品免费 | 99久久久久免费精品国产 | 国产精品一区二区精品视频免费看 | 曰韩在线 | 国产精品一区二区在线看 | 五月天婷婷在线视频 | 国产91综合一区在线观看 | 久久久久综合精品福利啪啪 | 在线观看免费 | 久久电影色 | 狠狠狠干 | 日韩大片在线免费观看 | 99视频偷窥在线精品国自产拍 | 国产不卡在线观看视频 | 国产精品免费在线观看视频 | 免费成人av | 久草免费色站 | 深爱五月激情五月 | 韩国av永久免费 | av三级在线看 | 久久公开视频 | 丁香综合av | 91麻豆视频网站 | 日韩三级视频在线观看 | 综合影视 | 天天干天天操人体 | 欧美激情视频一区二区三区 | 婷婷九月丁香 | 国产麻豆果冻传媒在线观看 | 手机看片福利 | 日本一区二区三区免费看 | 亚洲成人黄色在线 | 日韩区欠美精品av视频 | 婷婷电影在线观看 | 91视频麻豆视频 | 亚洲理论在线观看电影 | 高潮久久久久久久久 | 福利一区二区三区四区 | 丁香在线观看完整电影视频 | 中文字幕在线视频一区二区三区 | 欧美一区二区三区在线播放 | 国产亚洲精品久久久久久大师 | 黄色网址a | 国产精品va | 一本—道久久a久久精品蜜桃 | 欧美日在线观看 | 久久久免费观看 | 国产精品一区二区三区99 | 福利区在线观看 | 亚洲精品久久久久999中文字幕 | 日本中文字幕电影在线免费观看 | 成全免费观看视频 | 久久久久久久久久久网站 | www.亚洲精品在线 | 精品国产诱惑 | 亚洲免费精品一区二区 | 精品国产一区二区三区日日嗨 | 久久草在线视频国产 | 五月婷婷激情综合 | 国产伦精品一区二区三区照片91 | 成人午夜电影网 | 九九九热 | 国产精品毛片 | 91成人在线视频观看 | 亚洲成av人片在线观看 | 日批在线观看 | 美女网站色在线观看 | 日日综合| 狠狠色伊人亚洲综合网站野外 | 欧美视频国产视频 | 国产日韩精品久久 | 国产视频久 | 99精品偷拍视频一区二区三区 | 亚洲精品99久久久久久 | 五月婷婷在线视频观看 | 国产福利精品在线观看 | 国产精品美女视频 | 欧美大片第1页 | av先锋中文字幕 | 日批网站免费观看 | 91尤物国产尤物福利在线播放 | 国产一区二区久久久 | 亚洲国产精品电影 | 一级黄毛片 | 亚洲精品免费在线播放 | 国产精品久久久久久久久久久久午 | 国产中文在线播放 | 在线中文字幕网站 | 国产一区二区免费 | 日韩专区在线 | 91亚洲精品国产 | 久久撸在线视频 | 久久无码av一区二区三区电影网 | 美国三级黄色大片 | 亚洲综合情 | 日批网站在线观看 | 91免费看黄色 | 2019久久精品 | 五月婷av| 91日韩精品视频 | 丁香在线视频 | 婷婷色综合网 | 国产亚洲精品美女 | 超碰精品在线 | 国产精品美女久久久久久久 | 国产在线观看你懂得 | 五月天中文字幕 | 麻豆系列在线观看 | 午夜精品一区二区三区在线视频 | 在线观看精品一区 | 日韩中文字幕免费 | 国产不卡片 | 成人免费观看视频网站 | 日本久热| 国产色综合天天综合网 | 激情自拍av | 在线观看免费视频 | 少妇bbbb搡bbbb搡bbbb | 欧美特一级| 精精国产xxxx视频在线播放 | av在线小说| 国产小视频免费在线观看 | 欧美精品被| 玖玖视频在线 | 中国一级片在线播放 | 丁香视频免费观看 | 亚洲一区二区三区在线看 | 日韩免费三级 | 中文av不卡 | 日日干天天爽 | 国产成人三级在线 | 国产婷婷久久 | 丁香六月av | 国产裸体视频bbbbb | 精品国产99国产精品 | 99国产精品视频免费观看一公开 | 久久看片 | 日日夜夜网| 国产原创av片 | 91精品一区二区三区蜜臀 | 色婷婷婷| 99视频网站 | 伊人国产在线播放 | 免费不卡中文字幕视频 | 福利久久 | 91在线超碰| 日韩视频免费在线 | 国产精品欧美一区二区三区不卡 | 亚洲视频电影在线 | 97成人在线免费视频 | 午夜av剧场| 一区二区在线影院 | 高清中文字幕av | 色婷婷丁香 | 高清在线一区二区 | 久草网站 | 日韩视频一区二区在线 | 四虎在线观看视频 | a视频在线看| 丝袜少妇在线 | 久久精视频 | 日韩精品在线视频 | 久草在线免费在线观看 | av一级在线观看 | 在线视频一二三 | 97成人精品区在线播放 | 国产一级一片免费播放放a 一区二区三区国产欧美 | 成人av在线播放网站 | 国产精品18毛片一区二区 | 中文字幕 国产视频 | 色偷偷88888欧美精品久久 | 在线观看麻豆av | 国产黄色精品视频 | 成人黄大片 | 天天操天天射天天舔 | 色九九影院 | 久久激情婷婷 | 五月天中文字幕 | 一区三区视频在线观看 | 国内精品久久久久久久久久清纯 | 精品视频久久 | 国产一区视频免费在线观看 | 香蕉在线视频播放网站 | 免费看黄色大全 | 久久久久久草 | 91插插插免费视频 | 亚洲激情 在线 | 日日夜夜狠狠操 | 国产成人一区二区三区久久精品 | 色综合小说| 久草在线观看视频免费 | 国产原厂视频在线观看 | 国产成人久久av977小说 | 免费成人短视频 | 99 久久久久 | 国产精品 999 | 黄色av电影在线观看 | 婷婷色网站 | 日韩色区 | 国产高清久久久久 | 久久久av电影 | av大片免费在线观看 | 国产91精品久久久久久 | 亚洲日本激情 | 韩国三级av在线 | 久久久噜噜噜久久久 | 国产在线观看你懂得 | 欧美性生活小视频 | 色综合久久88色综合天天6 | 中文字幕在线视频一区二区三区 | 国产裸体视频bbbbb | 色窝资源| 亚洲天堂网站 | 在线观看免费视频 | 男女啪啪免费网站 | 亚州性色 | 日韩大片在线看 | 久草精品视频 | 五月婷婷六月综合 | 国产精品私人影院 | 五月天综合激情 | 99r在线播放| 99热最新精品 | 黄a网| 国产精品永久久久久久久久久 | 国产美女视频免费观看的网站 | 中文一区在线 | 99r在线播放 | 青青草视频精品 | 久草剧场| 在线观看一区 | 亚洲欧美激情精品一区二区 | 青青河边草免费直播 | 国产视频 久久久 | 麻豆va一区二区三区久久浪 | 狠狠久久 | av电影在线观看完整版一区二区 | 麻豆视频免费在线 | 在线亚洲成人 | 亚洲欧美日本A∨在线观看 青青河边草观看完整版高清 | av资源免费看 | av韩国在线 | 99热精品国产一区二区在线观看 | 欧美精品二区 | 国产精品第10页 | 亚洲第一久久久 | 久久免费在线观看视频 | 玖玖在线精品 | 亚洲特级毛片 | 免费亚洲黄色 | 操操操操网 | 九九综合久久 | 激情婷婷丁香 | 激情 一区二区 | 久久黄色免费 | 欧美日本一二三 | 91精品影视 | 国产精品99久久久久久宅男 | 免费一级特黄录像 | 精品一区二区电影 | 久久尤物电影视频在线观看 | 免费在线观看日韩视频 | 亚洲女同videos | 色综合小说 | 欧美精品久久久久久久久久丰满 | 麻豆视频www | 精品美女在线视频 | 欧美激情第一区 | 99久视频 | 99久久一区| 天天草天天爽 | 婷婷视频导航 | 一本一本久久aa综合精品 | 97香蕉超级碰碰久久免费软件 | 国际精品网 | 日韩在线高清 | 日韩午夜视频在线观看 | 99热精品视 | av黄色影院 | 亚洲精品一区中文字幕乱码 | 欧美一级片免费观看 | 亚洲精品综合一二三区在线观看 | 国内偷拍精品视频 | 国产原创中文在线 | 日韩欧美国产激情在线播放 | 欧美性黑人 | 九色91福利 | 人人添人人澡人人澡人人人爽 | 在线观看日本高清mv视频 | 久久任你操 | 伊人国产女 | 久久99精品久久久久久 | 97国产大学生情侣酒店的特点 | 久久久久久久久久久久久9999 | 亚洲高清激情 | 欧美一级小视频 | 成人免费av电影 | 深爱激情五月综合 | 欧美日韩中文国产 | av在线精品 | 五月天激情婷婷 | 国产精品一区二区免费在线观看 | 国产精品伦一区二区三区视频 | 九九视频网站 | 美女免费视频一区二区 | japanese黑人亚洲人4k | 亚洲 欧洲av | 又黄又爽又无遮挡的视频 | 久久久久日本精品一区二区三区 | 91精品国产自产老师啪 | 婷婷在线免费视频 | 日韩91在线 | 久久精品国产亚洲精品2020 | 国产日韩在线看 | 成人永久在线 | 国产精品美女免费 | 99热在线精品观看 | 国产成人精品不卡 | 成人午夜免费剧场 | 久久久久久久久久久黄色 | 激情动态 | 91爱在线 | 激情欧美日韩一区二区 | 国产成人一区二区三区 | 久久久久久99精品 | 亚洲最新精品 | 国产精品国产三级国产aⅴ无密码 | 91中文字幕在线视频 | 深夜免费小视频 | 免费在线观看成年人视频 | av在线在线| 久久99精品一区二区三区三区 | 久久国产一区二区三区 | 碰超在线 | 久久久久久国产精品亚洲78 | 狠狠干夜夜爱 | 亚洲天天看 | 亚洲精选99 | 久久久在线免费观看 | 深爱婷婷久久综合 | www.五月天| 日韩高清无线码2023 | 国产区精品视频 | 夜夜视频资源 | 亚洲成人国产 | 日韩精品免费一区二区三区 | 国产精品嫩草影视久久久 | 丁香婷婷综合网 | 国产色在线观看 | 中文字幕 影院 | 久久精品美女视频网站 | 人人干天天射 | 婷婷丁香狠狠爱 | 麻豆视频在线免费 | 久久综合精品一区 | 婷婷午夜天 | 亚洲人毛片 | 久久综合狠狠综合久久狠狠色综合 | 蜜臀久久99静品久久久久久 | 中文字幕一区在线观看视频 | 久久久久综合精品福利啪啪 | 久久综合色一综合色88 | 亚洲乱码在线 | 热99在线视频 | 在线视频 一区二区 | 99精品在线视频观看 | 天天综合网在线观看 | 中文字幕视频免费观看 | 亚洲 欧美 变态 国产 另类 | 日本韩国在线不卡 | 毛片一级免费一级 | 精品国产乱码一区二 | 日韩欧美精品一区二区三区经典 | 女女av在线 | 亚洲精品免费在线观看 | 日韩另类在线 | 一二三区高清 | av丝袜美腿 | 久久夜色精品国产欧美乱 | 色综合久久久久综合 | 国产污视频在线观看 | 久亚洲 | 久久综合色播五月 | 五月婷婷久久综合 | 日韩va欧美va亚洲va久久 | 麻豆一区在线观看 | 亚洲国产黄色 | 国产中文欧美日韩在线 | 色激情五月 | 一区在线免费观看 | 久久久噜噜噜久久久 | 亚洲天堂在线观看完整版 | 成人四虎| 国产精品久久久一区二区 | 国产精品久久久久久久久久久久 | 中文字幕在线观看第一页 | 精品国产成人av | 国内综合精品午夜久久资源 | 亚洲精品系列 | 天天操天天操天天操天天操天天操 | 国产精品一区二区无线 | 国产一在线精品一区在线观看 | 69欧美视频|