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

歡迎訪問 生活随笔!

生活随笔

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

linux

linux内核3.4基于wakeup_source的autosleep机制分析

發布時間:2025/4/16 linux 45 豆豆
生活随笔 收集整理的這篇文章主要介紹了 linux内核3.4基于wakeup_source的autosleep机制分析 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

點擊打開鏈接

一:wakeup_source簡介:

?? ?linux 3.4內核PM使用了wakeup_source來保持喚醒狀態,也就是keep awake。之前android一直是基于Linux加入了wake_lock機制來阻止系統休眠,后來Linux 3.4內核加入了wakeup_source來管理,安卓4.4跟著升級內核也就摒棄了自己的臃腫的wake_lock機制,在對上層接口并不改變,在內核wake_lock實現直接基于wakeup_source來實現的。當然也會帶來debug上的一些問題,比如以前的wake_lock自身帶有強大的debug信息,那么我們在調試的時候可以自己看見dmesg中默認打印active wake lock XXX,很直觀來辨別需要休眠的時候那個wake lock有問題阻止了休眠。這個需要我們自己來完善。個人認為改進很大,現在使用了autosleep機制,只要不存在任何active wakeup_source了,系統自動休眠,當有active wake_source自動block住,個人認為休眠更及時,非休眠時間在減少,同時不會消耗額外的資源。使用基于queue work與進程block來管理suspend。還有這里的wakeup_source個人覺得應該叫keepawake_source或者stayawake_souce,畢竟系統的喚醒也就是cpu的再次運行是由中斷喚醒的而不是wakeup_source。同時安卓4.4還有一個重大改變就是去除了early suspend機制改為fb event通知機制。那么現在就只有suspend與resume,runtime suspend與runtime resume了。


/**
?* struct wakeup_source - Representation of wakeup sources
?*
?* @total_time: Total time this wakeup source has been active.
?* @max_time: Maximum time this wakeup source has been continuously active.
?* @last_time: Monotonic clock when the wakeup source's was touched last time.
?* @prevent_sleep_time: Total time this source has been preventing autosleep.
?* @event_count: Number of signaled wakeup events.
?* @active_count: Number of times the wakeup sorce was activated.
?* @relax_count: Number of times the wakeup sorce was deactivated.
?* @expire_count: Number of times the wakeup source's timeout has expired.
?* @wakeup_count: Number of times the wakeup source might abort suspend.
?* @active: Status of the wakeup source.
?* @has_timeout: The wakeup source has been activated with a timeout.
?*/
struct wakeup_source {
?? ?const char ?? ??? ?*name;
?? ?struct list_head?? ?entry;
?? ?struct list_head?? ?list;
?? ?spinlock_t?? ??? ?lock;
?? ?struct timer_list?? ?timer;
?? ?unsigned long?? ??? ?timer_expires; //超時時間,也就是wake_lock_timeout()里面的時間參數,超時后會執行deactivate函數
?? ?ktime_t total_time;
?? ?ktime_t max_time;
?? ?ktime_t last_time;
?? ?ktime_t start_prevent_time;
?? ?ktime_t prevent_sleep_time;
?? ?unsigned long?? ??? ?event_count; //event計數
?? ?unsigned long?? ??? ?active_count;//active計數
?? ?unsigned long?? ??? ?relax_count;
?? ?unsigned long?? ??? ?expire_count;
?? ?unsigned long?? ??? ?wakeup_count;
?? ?bool?? ??? ??? ?active:1; //用于判斷是否是active狀態
?? ?bool?? ??? ??? ?autosleep_enabled:1;//這個變量是來標記active等時間的
};


//active任何wakeup_source都會執行該函數,標記active為true
/**
?* wakup_source_activate - Mark given wakeup source as active.
?* @ws: Wakeup source to handle.
?*
?* Update the @ws' statistics and, if @ws has just been activated, notify the PM
?* core of the event by incrementing the counter of of wakeup events being
?* processed.
?*/
static void wakeup_source_activate(struct wakeup_source *ws)
{
?? ?unsigned int cec;

?? ?ws->active = true;
?? ?ws->active_count++;
?? ?ws->last_time = ktime_get();
?? ?if (ws->autosleep_enabled)
?? ??? ?ws->start_prevent_time = ws->last_time;

?? ?/* Increment the counter of events in progress. */
?? ?cec = atomic_inc_return(&combined_event_count);

?? ?trace_wakeup_source_activate(ws->name, cec);
}


//deactivate任何wakeup_source都會執行該函數,標記active為false
/**
?* wakup_source_deactivate - Mark given wakeup source as inactive.
?* @ws: Wakeup source to handle.
?*
?* Update the @ws' statistics and notify the PM core that the wakeup source has
?* become inactive by decrementing the counter of wakeup events being processed
?* and incrementing the counter of registered wakeup events.
?*/
static void wakeup_source_deactivate(struct wakeup_source *ws)
{
?? ?unsigned int cnt, inpr, cec;
?? ?ktime_t duration;
?? ?ktime_t now;

?? ?ws->relax_count++;
?? ?/*
?? ? * __pm_relax() may be called directly or from a timer function.
?? ? * If it is called directly right after the timer function has been
?? ? * started, but before the timer function calls __pm_relax(), it is
?? ? * possible that __pm_stay_awake() will be called in the meantime and
?? ? * will set ws->active.? Then, ws->active may be cleared immediately
?? ? * by the __pm_relax() called from the timer function, but in such a
?? ? * case ws->relax_count will be different from ws->active_count.
?? ? */
?? ?if (ws->relax_count != ws->active_count) {
?? ??? ?ws->relax_count--;
?? ??? ?return;
?? ?}

?? ?ws->active = false;

?? ?now = ktime_get();
?? ?duration = ktime_sub(now, ws->last_time);
?? ?ws->total_time = ktime_add(ws->total_time, duration);
?? ?if (ktime_to_ns(duration) > ktime_to_ns(ws->max_time))
?? ??? ?ws->max_time = duration;

?? ?ws->last_time = now;
?? ?del_timer(&ws->timer);
?? ?ws->timer_expires = 0;

?? ?if (ws->autosleep_enabled)
?? ??? ?update_prevent_sleep_time(ws, now);

?? ?/*
?? ? * Increment the counter of registered wakeup events and decrement the
?? ? * couter of wakeup events in progress simultaneously.
?? ? */
?? ?cec = atomic_add_return(MAX_IN_PROGRESS, &combined_event_count);
?? ?trace_wakeup_source_deactivate(ws->name, cec);

?? ?split_counters(&cnt, &inpr);
?? ?
?? ?if (!inpr && waitqueue_active(&wakeup_count_wait_queue)){
?? ??? ?wake_up(&wakeup_count_wait_queue); //當不存在任何active wake_up source的時候喚醒try_to_suspend進程。
?? ?}
?? ?
}

wakup_source的申請與釋放:
1:使用安卓的wake_lock接口:wake_lock(),wake_lock_timeout(),wake_unlock();
2: 使用wakeup_source自帶的接口:pm_stay_awake(),pm_relax();這里的name就是device name。

二:autosleep分析:

sys接口:sys/power/autosleep

亮屏時libsuspend會寫入off,滅屏寫入mem


static ssize_t autosleep_show(struct kobject *kobj,
?? ??? ??? ?????? struct kobj_attribute *attr,
?? ??? ??? ?????? char *buf)
{
?? ?suspend_state_t state = pm_autosleep_state();

?? ?if (state == PM_SUSPEND_ON)
?? ??? ?return sprintf(buf, "off\n");

#ifdef CONFIG_SUSPEND
?? ?if (state < PM_SUSPEND_MAX)
?? ??? ?return sprintf(buf, "%s\n", valid_state(state) ?
?? ??? ??? ??? ??? ??? ?pm_states[state] : "error");
#endif
#ifdef CONFIG_HIBERNATION
?? ?return sprintf(buf, "disk\n");
#else
?? ?return sprintf(buf, "error");
#endif
}

static ssize_t autosleep_store(struct kobject *kobj,
?? ??? ??? ??????? struct kobj_attribute *attr,
?? ??? ??? ??????? const char *buf, size_t n)
{
?? ?suspend_state_t state = decode_state(buf, n);
?? ?int error;

?? ?if (state == PM_SUSPEND_ON
?? ???? && strcmp(buf, "off") && strcmp(buf, "off\n"))
?? ??? ?return -EINVAL;

?? ?error = pm_autosleep_set_state(state);
?? ?return error ? error : n;
}

power_attr(autosleep);


int pm_autosleep_set_state(suspend_state_t state)
{

#ifndef CONFIG_HIBERNATION
?? ?if (state >= PM_SUSPEND_MAX)
?? ??? ?return -EINVAL;
#endif

?? ?__pm_stay_awake(autosleep_ws); //防止系統休眠?

?? ?mutex_lock(&autosleep_lock);

?? ?autosleep_state = state;

?? ?__pm_relax(autosleep_ws); //釋放上面的wake up source

?? ?if (state > PM_SUSPEND_ON) {
?? ??? ?pm_wakep_autosleep_enabled(true); //設置所有wake up source里面的autosleep_enabled為真,這個變量不會對休眠有影響,但是會標記active的時間,使用debugfs可以看見
?? ??? ?queue_up_suspend_work();//調度工作隊列,會執行try_to_suspend(),其實state mem執行try_to_suspend(),一次就可以了,后面再分析。
?? ?} else {
?? ??? ?pm_wakep_autosleep_enabled(false);//設置所有wake up source里面的autosleep_enabled為假
?? ?}

?? ?mutex_unlock(&autosleep_lock);
?? ?return 0;
}


重頭戲:try_to_suspend

static void try_to_suspend(struct work_struct *work)
{
?? ?unsigned int initial_count, final_count;

?? ?if (!pm_get_wakeup_count(&initial_count, true)) //獲取initial_count,這個函數會block住,當存在active wakeup source的時候,直到wakeup source為detative狀態
?? ??? ?goto out;

?? ?mutex_lock(&autosleep_lock);

?? ?if (!pm_save_wakeup_count(initial_count)) {//保存initial_count,不會block,當然也會檢查是否有active wakeup source,當有active存在再次queue work。
?? ??? ?mutex_unlock(&autosleep_lock);
?? ??? ?goto out;
?? ?}

?? ?if (autosleep_state == PM_SUSPEND_ON) {//當為ON狀態時,return。//在睡眠期間跟了很久沒有遇見過這種情況
?? ??? ?mutex_unlock(&autosleep_lock);
?? ??? ?return;
?? ?}
?? ?if (autosleep_state >= PM_SUSPEND_MAX)
?? ??? ?hibernate();????????????????? //hibernate高通平臺目前不支持
?? ?else
?? ??? ?pm_suspend(autosleep_state); //進入pm_suspend,dmesg會有PM: suspend entry 與PM: suspend exit來標記,這里面會執行freeze task,suspend與resume,disable cpu的操作。內核PM最重要的函數。

?? ?mutex_unlock(&autosleep_lock);

?? ?if (!pm_get_wakeup_count(&final_count, false))//獲取final_count,非block,當然也會檢查是否有active wakeup source,當有active存在再次queue work
?? ??? ?goto out;

?? ?/*
?? ? * If the wakeup occured for an unknown reason, wait to prevent the
?? ? * system from trying to suspend and waking up in a tight loop.
?? ? */
?? ?if (final_count == initial_count)???????????? //這里遇見未知原因,initial_count與final_count相等,超時500ms后繼續往下執行。這種現象我也是跟了許久沒有遇見過。
?? ??? ?schedule_timeout_uninterruptible(HZ / 2);

?out:
?? ?queue_up_suspend_work(); //調度queue work會再次執行該函數,實際上只要一次echo mem > sys/power/autosleep后這個進程一直會在auto_sleep cycle。
}


pm_get_wakeup_count原型,個人感覺這個是仿__wait_event_interruptible()而寫的。

bool pm_get_wakeup_count(unsigned int *count, bool block)
{
?? ?unsigned int cnt, inpr;

?? ?if (block) { //當block為真時,該進程可能會block住
?? ??? ?DEFINE_WAIT(wait);

?? ??? ?for (;;) {
?? ??? ??? ?prepare_to_wait(&wakeup_count_wait_queue, &wait,
?? ??? ??? ??? ??? ?TASK_INTERRUPTIBLE);
?? ??? ??? ?split_counters(&cnt, &inpr); //有active的wakeup_source存在就是block住,否則block
?? ??? ??? ?if (inpr == 0 || signal_pending(current))
?? ??? ??? ??? ?break;
?? ??? ??? ?
?? ??? ??? ?schedule();//在這里面block住,直到最后一個active的wakeup_source deactivate時會喚醒該進程,之后會break出來。
?? ??? ?}
?? ??? ?finish_wait(&wakeup_count_wait_queue, &wait);
?? ?}

?? ?split_counters(&cnt, &inpr);
?? ?*count = cnt;
?? ?return !inpr;
}

那么有2個問題,按power鍵喚醒系統是退出try_to_suspend了嗎?
?????? 首先系統是如何被喚醒的?這個是由硬件中斷喚醒的,比如我們這里的power鍵,還有其他的比如alarm等其他硬件中斷,只要我們在中斷申請時enbale_irq_wake(), 那么睡眠期間,只要觸發該中斷就可以喚醒系統。那么在try_to_suspend里面喚醒后pm_suspend()執行完resume后會退出來,接著會獲取final_count,在這里是存在active ? wake_up source的(在out之前加添的打印active wakeup_source,下面的dmesg證明了存在的wakeup_source),之后執行out,后調度工作隊列,再次進入try_to_suspend(),在第一次獲取initial_count后便會遇見active wakeup_source,這里面更多的是系統上層加的wakeup_source,那么try_to_suspend()會一直block在pm_get_wakeup_count()里面直到滅屏和所有wakeup_source deactivate時會再次進入pm_suspend()休眠。
?????? 這里也就解釋了為什么只要執行一次ehco mem > sys/power/autosleep后自動可以休眠了的原因。

看下面的dmesg:
<6>[? 928.536418] CPU0: msm_cpu_pm_enter_sleep mode 000000,00000000,00000000,00000000,00000000,00000020,00000000,00000000,00000000,00000000,00000000,00000000,00000000,00000000
<6>[? 928.543066] PM: noirq resume of devices complete after 6.020 msecs
<6>[? 928.548512] PM: early resume of devices complete after 2.598 msecs
<6>[? 928.650793] PM: resume of devices complete after 102.266 msecs
<6>[? 928.660290] Restarting tasks ... done.
<6>[? 928.681208] PM: suspend exit 1970-01-05 05:23:32.206389881 UTC
<6>[? 928.681229] active wake lock KeyEvents
<6>[? 928.681267] active wake lock qpnp_soc_wake
<6>[? 928.681284] active wake lock alarm, time left 486
<6>[? 928.681342] active wake lock KeyEvents
<6>[? 928.681584] active wake lock qpnp_soc_wake
<6>[? 928.681600] active wake lock alarm, time left 486
<6>[? 928.696345] request_suspend_state: wakeup at 928691792356 (1970-01-05 05:23:32.221521704 UTC)
<6>[? 928.708608] mdss_dsi_panel_power on=1



還有一個與wakeup source無關的問題,為什么suspend后就一直停留在那里不動了?
?????? 這個是cpu停止運轉了,下面再分析下代碼。
?????? 核心函數suspend_devices_and_enter():

/**
?* suspend_devices_and_enter - Suspend devices and enter system sleep state.
?* @state: System sleep state to enter.
?*/
int suspend_devices_and_enter(suspend_state_t state)
{
?? ?int error;
?? ?bool wakeup = false;

?? ?if (!suspend_ops)
?? ??? ?return -ENOSYS;

?? ?trace_machine_suspend(state);
?? ?if (suspend_ops->begin) {
?? ??? ?error = suspend_ops->begin(state);
?? ??? ?if (error)
?? ??? ??? ?goto Close;
?? ?}
?? ?suspend_console();
?? ?suspend_test_start();
?? ?error = dpm_suspend_start(PMSG_SUSPEND);//這里會執行所有driver的suspend函數,suspend里面有active wakeup_source或者return 為真的話,suspend會報錯
?? ?if (error) {
?? ??? ?printk(KERN_ERR "PM: Some devices failed to suspend\n");
?? ??? ?goto Recover_platform;
?? ?}
?? ?suspend_test_finish("suspend devices");
?? ?if (suspend_test(TEST_DEVICES))
?? ??? ?goto Recover_platform;

?? ?do {
?? ??? ?error = suspend_enter(state, &wakeup);//這里會diable cpu
?? ?} while (!error && !wakeup
?? ??? ?&& suspend_ops->suspend_again && suspend_ops->suspend_again());

?Resume_devices:
?? ?suspend_test_start();
?? ?dpm_resume_end(PMSG_RESUME);
?? ?suspend_test_finish("resume devices");
?? ?resume_console();
?Close:
?? ?if (suspend_ops->end)
?? ??? ?suspend_ops->end();
?? ?trace_machine_suspend(PWR_EVENT_EXIT);
?? ?return error;

?Recover_platform:
?? ?if (suspend_ops->recover)
?? ??? ?suspend_ops->recover();
?? ?goto Resume_devices;
}


static int suspend_enter(suspend_state_t state, bool *wakeup)
{
?? ?int error;

?? ?if (suspend_ops->prepare) {
?? ??? ?error = suspend_ops->prepare();
?? ??? ?if (error)
?? ??? ??? ?goto Platform_finish;
?? ?}

?? ?error = dpm_suspend_end(PMSG_SUSPEND);
?? ?if (error) {
?? ??? ?printk(KERN_ERR "PM: Some devices failed to power down\n");
?? ??? ?goto Platform_finish;
?? ?}

?? ?if (suspend_ops->prepare_late) {
?? ??? ?error = suspend_ops->prepare_late();
?? ??? ?if (error)
?? ??? ??? ?goto Platform_wake;
?? ?}

?? ?if (suspend_test(TEST_PLATFORM))
?? ??? ?goto Platform_wake;

?? ?error = disable_nonboot_cpus();? //disable nonboot cpu注意還有cpu需要下面disable的
?? ?if (error || suspend_test(TEST_CPUS))
?? ??? ?goto Enable_cpus;

?? ?arch_suspend_disable_irqs();
?? ?BUG_ON(!irqs_disabled());

?? ?error = syscore_suspend();
?? ?if (!error) {
?? ??? ?*wakeup = pm_wakeup_pending();
?? ??? ?if (!(suspend_test(TEST_CORE) || *wakeup)) {
?? ??? ??? ?error = suspend_ops->enter(state); //在這里cpu會停止運行,直到中斷喚醒
//下面的全部是喚醒的操作了
?? ??? ??? ?events_check_enabled = false;
?? ??? ?}
?? ??? ?syscore_resume();
?? ?}

?? ?arch_suspend_enable_irqs();
?? ?BUG_ON(irqs_disabled());

?Enable_cpus:
?? ?enable_nonboot_cpus();

?Platform_wake:
?? ?if (suspend_ops->wake)
?? ??? ?suspend_ops->wake();

?? ?dpm_resume_start(PMSG_RESUME);

?Platform_finish:
?? ?if (suspend_ops->finish)
?? ??? ?suspend_ops->finish();

?? ?return error;
}

平臺賦值,這里debug平臺是基于msm8974的:
static const struct platform_suspend_ops lpm_suspend_ops = {
?? ?.enter = lpm_suspend_enter,//在這里面disbale cpu,停止運行程序
?? ?.valid = suspend_valid_only_mem,
?? ?.prepare_late = lpm_suspend_prepare,
?? ?.wake = lpm_suspend_wake,
};


添加顯示wake_lock的dmesg:
<6>[?? 90.964850] CPU0: msm_cpu_pm_enter_sleep mode 000000,00000000,00000000,00000000,00000000,00000020,00000000,00000000,00000000,00000000,00000000,00000000,00000000,00000000
<6>[?? 90.965302] Enabling non-boot CPUs ...
<6>[?? 90.968303] CPU3 is up
<6>[?? 90.970699] PM: noirq resume of devices complete after 2.382 msecs
<6>[?? 90.973460] PM: early resume of devices complete after 1.443 msecs
<6>[?? 91.097369] PM: resume of devices complete after 123.888 msecs
<6>[?? 91.112858] Restarting tasks ... done.
<6>[?? 91.141699] PM: suspend exit 1970-01-05 03:59:28.158266979 UTC
<6>[?? 91.141776] PM: suspend entry 1970-01-05 03:59:28.158347917 UTC
<6>[?? 91.141801] PM: Syncing filesystems ... done.
<6>[?? 91.222299] Freezing user space processes ... (elapsed 0.03 seconds) done.
<6>[?? 91.258126] Freezing remaining freezable tasks ... (elapsed 0.02 seconds) done.
<6>[?? 91.278279] Suspending console(s) (use no_console_suspend to debug)
<6>[?? 91.384933] PM: suspend of devices complete after 95.062 msecs
<6>[?? 91.397910] PM: late suspend of devices complete after 12.934 msecs
<6>[?? 91.413019] PM: noirq suspend of devices complete after 15.064 msecs
<6>[?? 91.413059] Disabling non-boot CPUs ...
<6>[?? 91.424477] CPU0: msm_cpu_pm_enter_sleep mode 000000,00000000,00000000,00000000,00000000,00000020,00000000,00000000,00000000,00000000,00000000,00000000,00000000,00000000//這里cpu停止運行直到中斷喚醒
<6>[?? 91.425144] Enabling non-boot CPUs ...
<6>[?? 91.432354] CPU3 is up
<6>[?? 91.444416] PM: noirq resume of devices complete after 11.997 msecs
<6>[?? 91.460948] PM: early resume of devices complete after 10.458 msecs
<6>[?? 91.577213] PM: resume of devices complete after 116.231 msecs
<6>[?? 91.584876] Restarting tasks ... done.
<6>[?? 91.614571] PM: suspend exit 1970-01-05 03:59:35.550203849 UTC
<6>[?? 91.614639] active wake lock rmt_storage_-1220268312
<6>[?? 91.689912] PM: suspend entry 1970-01-05 03:59:35.625550620 UTC
<6>[?? 91.689921] PM: Syncing filesystems ... done.
<6>[?? 91.700706] Freezing user space processes ...?
<3>[?? 91.712870] Freezing of user space? aborted
<6>[?? 91.712898]?
<6>[?? 91.712903] Restarting tasks ... done.
<6>[?? 91.720540] PM: suspend exit 1970-01-05 03:59:35.656175256 UTC
<6>[?? 91.720574] PM: suspend entry 1970-01-05 03:59:35.656214579 UTC
<6>[?? 91.720586] PM: Syncing filesystems ... done.
<6>[?? 91.801097] Freezing user space processes ...?
<3>[?? 91.815050] Freezing of user space? aborted
<6>[?? 91.815075]?
<6>[?? 91.815083] Restarting tasks ... done.
<6>[?? 91.823603] PM: suspend exit 1970-01-05 03:59:35.759241558 UTC
<6>[?? 91.823633] PM: suspend entry 1970-01-05 03:59:35.759272964 UTC
<6>[?? 91.823643] PM: Syncing filesystems ... done.
<6>[?? 91.911985] Freezing user space processes ... (elapsed 0.03 seconds) done.
<6>[?? 91.949378] Freezing remaining freezable tasks ... (elapsed 0.01 seconds) done.
<6>[?? 91.969089] Suspending console(s) (use no_console_suspend to debug)
<6>[?? 92.085594] PM: suspend of devices complete after 98.499 msecs
<6>[?? 92.098615] PM: late suspend of devices complete after 12.975 msecs
<6>[?? 92.113909] PM: noirq suspend of devices complete after 15.249 msecs
<6>[?? 92.113951] Disabling non-boot CPUs ...
<6>[?? 92.147320] CPU0: msm_cpu_pm_enter_sleep mode 000000,00000000,00000000,00000000,00000000,00000020,00000000,00000000,00000000,00000000,00000000,00000000,00000000,00000000
<6>[?? 92.148265] Enabling non-boot CPUs ...
<6>[?? 92.155121] CPU1 is up
<6>[?? 92.163797] CPU2 is up
<6>[?? 92.174144] CPU3 is up
<6>[?? 92.186556] PM: noirq resume of devices complete after 12.344 msecs
<6>[?? 92.199945] PM: early resume of devices complete after 10.020 msecs
<6>[?? 92.317528] PM: resume of devices complete after 117.548 msecs
<6>[?? 92.326254] Restarting tasks ... done.
<6>[?? 92.342025] PM: suspend exit 1970-01-05 04:00:48.122436614 UTC
<6>[?? 92.342337] active wake lock qpnp-vadc-f611ac00
<6>[?? 92.342357] active wake lock alarm, time left 481

<6>[?? 92.411428] PM: suspend entry 1970-01-05 04:00:48.191838905 UTC
<6>[?? 92.411451] PM: Syncing filesystems ... done.
<6>[?? 92.419086] Freezing user space processes ...?
<3>[?? 92.431173] Freezing of user space? aborted
<6>[?? 92.431213]?
<6>[?? 92.431225] Restarting tasks ... done.
<6>[?? 92.441575] PM: suspend exit 1970-01-05 04:00:48.221987864 UTC
<6>[?? 92.441709] active wake lock qpnp-vadc-f611ac00
<6>[?? 92.445004] PM: suspend entry 1970-01-05 04:00:48.225417551 UTC
<6>[?? 92.445026] PM: Syncing filesystems ... done.
<6>[?? 92.525764] Freezing user space processes ...?
<3>[?? 92.541465] Freezing of user space? aborted
<6>[?? 92.541523]?
<6>[?? 92.541545] Restarting tasks ... done.
<6>[?? 92.558768] PM: suspend exit 1970-01-05 04:00:48.339166145 UTC
<6>[?? 92.558865] PM: suspend entry 1970-01-05 04:00:48.339268645 UTC
<6>[?? 92.558898] PM: Syncing filesystems ... done.
<6>[?? 92.656122] Freezing user space processes ... (elapsed 0.04 seconds) done.
<6>[?? 92.699091] Freezing remaining freezable tasks ... (elapsed 0.01 seconds) done.
<6>[?? 92.718891] Suspending console(s) (use no_console_suspend to debug)
<6>[?? 92.832084] PM: suspend of devices complete after 97.905 msecs
<6>[?? 92.845099] PM: late suspend of devices complete after 12.971 msecs
<6>[?? 92.860407] PM: noirq suspend of devices complete after 15.264 msecs
<6>[?? 92.860447] Disabling non-boot CPUs ...
<6>[?? 92.895114] CPU0: msm_cpu_pm_enter_sleep mode 000000,00000000,00000000,00000000,00000000,00000020,00000000,00000000,00000000,00000000,00000000,00000000,00000000,00000000

總結

以上是生活随笔為你收集整理的linux内核3.4基于wakeup_source的autosleep机制分析的全部內容,希望文章能夠幫你解決所遇到的問題。

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

国产69精品久久99的直播节目 | 欧美精品亚洲精品 | 天天干天天碰 | 久久人人爽人人爽人人片av免费 | 欧美精品亚洲精品日韩精品 | 91亚洲国产成人久久精品网站 | 人人爽人人爽人人爽 | 午夜精品久久久久久久久久久 | 91精品在线观看入口 | 日韩视频在线一区 | 国产在线精品一区二区三区 | 激情视频91 | 久久久国产精品亚洲一区 | 国产精品女人久久久久久 | 狠狠网站| 亚洲小视频在线观看 | 国产成人一区二区精品非洲 | 91一区啪爱嗯打偷拍欧美 | 91大神精品视频在线观看 | 国产精品99精品久久免费 | 国产一级视屏 | 亚洲欧美日本一区二区三区 | av一区二区三区在线播放 | 国产精品久久久久久麻豆一区 | 免费一级片在线 | 欧美日韩精品在线视频 | 在线成人免费av | 亚洲精品一区二区三区新线路 | 操高跟美女 | 国产一级二级三级视频 | 国产精品视频 | 国产资源精品在线观看 | 国产精品久久网站 | 黄色软件视频大全免费下载 | 国产专区精品视频 | 国产精品乱码久久久久久1区2区 | 麻豆久久久久 | 青青河边草免费直播 | 四虎精品成人免费网站 | av电影免费在线播放 | 国产精品一区二区在线免费观看 | 久久怡红院 | 九九久久影视 | 久久99深爱久久99精品 | 欧美精品一区二区三区四区在线 | 午夜色场 | 亚洲传媒在线 | 一区二区三区久久 | 成人av一区二区在线观看 | 在线观看黄 | 午夜国产福利视频 | 超碰在线日韩 | 欧美精品在线观看 | 免费观看一区二区三区视频 | 黄色www | 日韩中文字幕视频在线 | 中文国产字幕在线观看 | 超碰免费av | 国产精品久久久视频 | 亚洲毛片在线观看. | 国产大片免费久久 | 日韩中文在线观看 | 国产破处精品 | 欧美做受xxx | 久av在线| 色婷婷狠狠五月综合天色拍 | 精品一区二区三区电影 | 免费观看完整版无人区 | 男女激情免费网站 | 中文字幕亚洲精品在线观看 | 亚洲精品在线视频播放 | 亚洲尺码电影av久久 | 免费在线观看一区 | 国产精品一区二区在线 | 亚洲国产中文字幕在线观看 | 国产成人综 | 1000部18岁以下禁看视频 | 五月天精品视频 | 日韩欧美在线综合网 | 天天综合网久久 | 天天爽夜夜爽人人爽曰av | 色婷婷国产精品 | 黄色福利网 | 婷婷综合久久 | 国产综合视频在线观看 | 欧美一级视频在线观看 | 最新国产福利 | 国产精品久久精品 | 又大又硬又黄又爽视频在线观看 | 婷婷丁香av | 久久激情视频网 | 亚洲精品高清在线观看 | 色吊丝在线永久观看最新版本 | 在线观看视频中文字幕 | 国产系列在线观看 | 在线观看日韩av | 九九免费观看视频 | 日本中文字幕视频 | 日本中文字幕在线一区 | 黄色电影在线免费观看 | 久久久免费毛片 | 国产精品网红福利 | 色小说av| 免费看一及片 | 国产精品久久久久永久免费观看 | 青青色影院 | 国产精品久久久久国产a级 激情综合中文娱乐网 | 日韩精品久久久久久久电影竹菊 | 国产字幕av| 国产精品黄色 | 在线观看一 | 国产精品视频区 | 国产视频2区 | 91视频免费 | 九色精品 | 国产伦精品一区二区三区高清 | 国产黄色免费看 | www.狠狠色 | 天天性天天草 | 91免费视频网站在线观看 | 成人性生爱a∨ | av在线看片| 超碰97.com | 欧美韩国日本在线观看 | 麻花天美星空视频 | 久久精品99精品国产香蕉 | 久久夜色精品国产亚洲aⅴ 91chinesexxx | 亚洲色影爱久久精品 | 久久精品视频观看 | 国内揄拍国产精品 | 久久在草 | 久久精品一级片 | a黄在线观看 | 精产嫩模国品一二三区 | 日韩精品高清不卡 | 久久综合狠狠综合 | 懂色av懂色av粉嫩av分享吧 | 午夜精品久久久久久久久久 | 能在线观看的日韩av | 免费手机黄色网址 | 日本在线观看一区 | 日韩久久久久久久久久 | 欧美与欧洲交xxxx免费观看 | 国产免费一区二区三区最新6 | 日韩av伦理片 | av中文字幕免费在线观看 | 国产精品综合久久 | 国产精品久久久久aaaa九色 | 亚洲少妇久久 | 亚洲综合婷婷 | 久久国产网 | 日日夜夜网站 | 日本午夜免费福利视频 | 日韩一区二区三区高清在线观看 | 日日夜夜精品免费 | 午夜成人影视 | 黄色网www| 欧美日韩在线精品一区二区 | 91毛片在线| av电影亚洲 | 精品久久久久久久久久岛国gif | av免费观看高清 | 人人爽人人看 | 日韩mv欧美mv国产精品 | 成人黄大片视频在线观看 | 久久久久综合精品福利啪啪 | 成人在线观看资源 | 人人干狠狠干 | 国产九九九精品视频 | 在线免费av电影 | 六月激情久久 | 成人免费大片黄在线播放 | 欧美成人精品三级在线观看播放 | 日韩精品短视频 | 欧美视频日韩视频 | 国产精品美女视频网站 | 国产一二三四在线视频 | 在线观看免费中文字幕 | 黄色大片入口 | 国产精品av免费 | 色狠狠久久av五月综合 | 99久久精品国 | 精品福利国产 | 四虎海外影库www4hu | 国产色婷婷精品综合在线手机播放 | 日日干夜夜爱 | 久久夜色精品亚洲噜噜国4 午夜视频在线观看欧美 | 特级毛片网站 | 日日夜日日干 | 在线观看av免费观看 | 免费亚洲黄色 | 国产黄色美女 | 超级碰碰免费视频 | 2018好看的中文在线观看 | 亚洲精品影院在线观看 | 超碰国产在线播放 | 91九色视频在线播放 | 国精产品999国精产品视频 | 日韩偷拍精品 | 69精品久久久 | 91久久国产综合精品女同国语 | 亚洲欧洲一级 | 免费在线观看黄网站 | 伊人激情网 | 中文字幕av专区 | 久艹在线观看视频 | 开心丁香婷婷深爱五月 | 日韩黄在线观看 | 97香蕉久久国产在线观看 | 成人夜晚看av| 久久国色夜色精品国产 | 国产日韩欧美在线观看视频 | 91看毛片| 网站免费黄 | 欧美日韩中文在线 | 丝袜制服综合网 | 日韩精品免费一区二区 | 日韩高清在线不卡 | 国产91精品一区二区麻豆网站 | 国产精品一区二区三区四区在线观看 | 欧美精品一区在线发布 | 中文字幕日韩精品有码视频 | 网站免费黄色 | 黄色av免费 | 在线精品视频免费观看 | 99久久99久久综合 | 免费在线精品视频 | 91福利影院在线观看 | 国产一区电影在线观看 | 久草在| 日韩精品不卡在线 | 国产免费精彩视频 | 午夜免费电影院 | 国内精品在线一区 | 国内一级片在线观看 | 欧美一级视频在线观看 | 亚洲国产影院av久久久久 | 国产视频在线观看一区 | 免费h精品视频在线播放 | 久草在线视频免费资源观看 | 深夜免费网站 | 99久久激情视频 | 黄色软件在线观看视频 | 99久久久久久国产精品 | 玖玖在线精品 | 97综合在线 | 蜜臀av性久久久久蜜臀av | 国产日韩欧美在线免费观看 | 亚洲成人频道 | 在线观看中文字幕 | 久久激情视频 | 一本一本久久aa综合精品 | 成年人网站免费观看 | 成人久久 | 久久激情小视频 | 日韩伦理片一区二区三区 | 中文字幕国产 | 九九热国产 | 国产一级高清视频 | 国产成人精品亚洲精品 | 国产精品永久免费在线 | 精品久久久久久久久中文字幕 | 欧洲色吧 | 欧美精品中文字幕亚洲专区 | 国产又粗又猛又爽又黄的视频免费 | 在线免费看黄色 | 开心丁香婷婷深爱五月 | 欧美精品三级在线观看 | 亚洲国产三级 | 亚洲成a人片77777kkkk1在线观看 | av在线电影网站 | 精品欧美在线视频 | 亚洲在线视频网站 | 日本99久久| 亚洲精品视频第一页 | 久久这里有 | 欧美日本国产在线观看 | 在线观看日本韩国电影 | 视频一区二区在线 | 伊人资源视频在线 | 亚洲视频每日更新 | 久久视频这里有精品 | 日韩一区二区三区免费视频 | 天天爽夜夜爽精品视频婷婷 | 黄色av一级片| 92国产精品久久久久首页 | 欧美中文字幕久久 | 特级片免费看 | 天堂av免费观看 | 欧美日韩国产精品爽爽 | 中文字幕免费国产精品 | 激情五月婷婷综合 | 国产手机在线视频 | 婷婷激情久久 | 深夜激情影院 | 国内偷拍精品视频 | 亚洲黄色在线观看 | 日韩在线观看视频中文字幕 | 中文在线www | 国产久草在线 | 在线а√天堂中文官网 | 激情欧美在线观看 | 欧美日韩一区久久 | 成人在线观看日韩 | 日韩欧美91 | 日韩在线网 | 久久黄色免费 | 中文字幕亚洲综合久久五月天色无吗'' | av在线网站大全 | 日韩在线播放视频 | 亚洲少妇xxxx| 麻豆一二三精选视频 | 国产精美视频 | 97色狠狠 | 成人一级片免费看 | 国产精品入口麻豆www | 二区三区av| www色com | 超碰国产在线播放 | 亚洲精品高清视频 | www.福利 | 免费精品在线观看 | 欧美日韩视频免费 | 狠狠色伊人亚洲综合成人 | 国产资源免费在线观看 | 亚洲在线视频观看 | 日韩狠狠操| 伊人看片| 青春草视频在线播放 | 午夜性生活片 | 91在线精品一区二区 | 成人av视屏 | www五月天| 精品免费 | 国产精品一区二区av日韩在线 | 精品在线播放视频 | 伊人网综合在线观看 | 狠狠狠干 | 免费看片在线观看 | 五月婷婷综合久久 | 国产精品av免费观看 | 国产亚洲欧美精品久久久久久 | 亚洲成av人片在线观看香蕉 | 中文av在线免费观看 | 午夜av大片 | 日韩电影一区二区在线 | 狠狠干网址 | 99免费在线观看 | 久草99| 婷婷日日 | 国产三级香港三韩国三级 | 中文字幕国内精品 | 91在线观| 91九色视频在线 | 一本一本久久a久久精品牛牛影视 | 日本在线观看中文字幕无线观看 | 韩国精品福利一区二区三区 | 97免费在线观看视频 | 国产在线不卡精品 | 国产福利a | 久久人人爽人人爽 | 黄色成人91| 久久久高清| 视频一区二区三区视频 | 欧美激情视频一区 | 91人人干 | 色综合天天天天做夜夜夜夜做 | 精品国产伦一区二区三区 | 亚洲国产精品一区二区久久,亚洲午夜 | 99看视频在线观看 | 久久99久久99 | se婷婷 | 日韩欧美精品在线 | 99热99re6国产在线播放 | 97精品久久 | 天无日天天操天天干 | 91精品国自产在线观看 | 日韩在线不卡av | 五月天激情电影 | 久久伊人精品天天 | 免费视频久久久久 | 亚洲精品久久视频 | 日韩欧美视频在线免费观看 | 婷婷五综合 | 九色精品免费永久在线 | 日本三级人妇 | 国产一二三区av | 色在线亚洲 | 日韩欧美高清不卡 | 狠狠躁18三区二区一区ai明星 | 久久精品国产免费 | 色婷婷狠狠18 | 黄色网址a | 国产亚洲精品中文字幕 | 国产精品h在线观看 | 黄色高清视频在线观看 | 视频一区二区免费 | 色婷婷午夜 | 六月丁香在线视频 | 国产精品毛片久久久久久 | 人人草天天草 | 亚洲专区欧美专区 | 91丨九色丨国产在线 | 日韩免费高清在线 | 国产打女人屁股调教97 | 国产精品精品国产色婷婷 | 欧美日韩在线精品一区二区 | 日韩一级成人av | 日本久久不卡视频 | 中文字幕一区二区三区久久蜜桃 | 欧美另类交人妖 | 国产一区播放 | 日韩精品一二三 | 手机av资源 | 色偷偷男人的天堂av | 97在线观视频免费观看 | 久久伊人热 | 久久久九色精品国产一区二区三区 | 国外调教视频网站 | 这里只有精品视频在线观看 | 超碰免费av | 西西44人体做爰大胆视频 | 一区二区观看 | 成人在线播放免费观看 | a精品视频 | 久久综合国产伦精品免费 | av一区二区三区在线播放 | av三级在线看 | 久青草影院 | 日韩视频在线一区 | 99精品视频免费观看视频 | 日韩精品在线免费观看 | 黄色网址在线播放 | 成人黄色国产 | 五月婷婷综| 欧美一级片 | 亚洲天堂在线观看完整版 | 婷婷久久国产 | 99久久毛片 | 九九九免费视频 | 超碰在线中文字幕 | 久久久久久久久爱 | 国产1区2| 中文字幕.av.在线 | 激情综合一区 | 激情综合五月网 | 久久精品电影院 | 亚洲黄色一级大片 | 国产一级片免费视频 | 999久久久| 亚洲亚洲精品在线观看 | 日韩av快播电影网 | 91亚洲在线 | 夜夜操天天干 | 99综合电影在线视频 | 欧美激情视频一区二区三区 | 婷婷免费在线视频 | 97视频资源 | 午夜久久影视 | 91人人在线 | 9在线观看免费高清完整版在线观看明 | 国产又粗又硬又爽视频 | 久久久蜜桃 | 特级aaa毛片| 成人黄色一级视频 | 黄色av网站在线免费观看 | 成年人视频在线免费播放 | 亚洲高清视频在线观看 | 国产最新在线视频 | 亚洲精品久 | 五月婷婷在线观看视频 | 播五月婷婷 | 日本最新一区二区三区 | 少妇视频在线播放 | 精品视频免费观看 | 黄色免费观看视频 | 成年人三级网站 | 久久久国产电影 | 色综合天| 欧美性大胆 | 啪啪免费试看 | 九草视频在线观看 | 国产日本亚洲高清 | 欧美一级高清片 | 超碰在线97国产 | 特黄一级毛片 | 亚洲免费精品视频 | 亚洲国产免费 | av片中文 | 青青久草在线视频 | 奇米影视777四色米奇影院 | 人人狠狠综合久久亚洲婷 | 在线看的毛片 | 综合网婷婷 | 日韩中文字幕免费看 | 91视频午夜 | 天天综合网天天综合色 | 久久久久国产精品免费免费搜索 | 日韩免费一区二区在线观看 | av在线亚洲天堂 | 色综合久久精品 | 天天操狠狠操 | 久久久久久久久久久免费 | 天天色成人 | 国产特级毛片 | 精品国产一区二区三区久久 | 三级午夜片 | 色999视频 | av片中文| 久久国产精品久久国产精品 | 高清精品久久 | 欧亚久久 | 成人免费亚洲 | 在线观看黄网站 | 日韩免费不卡视频 | 色狠狠干 | 96av视频| 天天射天| 国内精品久久久久影院一蜜桃 | 欧美日韩调教 | 日韩中文字幕在线看 | 免费高清在线观看成人 | 在线观看色视频 | 久久黄色免费 | 白丝av免费观看 | 国产精品免费在线播放 | 99热在线观看 | 97电影院在线观看 | 日本精品一区二区三区在线观看 | 91福利免费 | 综合色中文| 婷婷精品国产一区二区三区日韩 | 国产99久久精品一区二区300 | 久久区二区 | 欧美在线观看小视频 | 国产91国语对白在线 | 亚洲精品五月 | 久久精品亚洲一区二区三区观看模式 | 九九在线视频免费观看 | 免费看三级黄色片 | 亚洲国产成人精品电影在线观看 | 日韩美女黄色片 | 国产亚洲精品久久久久久久久久 | 国产精品va在线播放 | 亚洲成av人片在线观看无 | 日日爱视频 | 美女搞黄国产视频网站 | 蜜臀久久99精品久久久无需会员 | 中文字幕 婷婷 | 国产亚州av| 久久在线精品 | 日b黄色片 | 伊人www22综合色 | 一级黄色在线视频 | 免费色视频网址 | 亚洲精品一区二区三区四区高清 | 亚洲高清在线视频 | 青青河边草免费观看 | 99精品视频99 | 91亚洲网| 丁香婷婷电影 | 91成人网在线 | 91精品视频网站 | 国产一区二区高清 | 国产高清视频色在线www | 日韩成片 | 日韩一二三区不卡 | 日韩夜夜爽 | 香蕉蜜桃视频 | 天天综合天天做 | 日韩精品一卡 | 亚洲国产精品999 | 国产精品久久久久久久午夜 | 亚洲一区二区观看 | 鲁一鲁影院 | aaawww| 久久综合久久综合久久综合 | 91完整版在线观看 | 91免费的视频在线播放 | 国产一级在线 | 亚洲人视频在线 | 国产精品九九久久久久久久 | 日韩a级黄色 | av夜夜操| 国产视频18| 欧美久久九九 | 中文字幕av免费 | 久久午夜精品 | 久久视屏网| 久久久久久久久电影 | 久草精品视频 | 日韩av一卡二卡三卡 | 天天干天天拍天天操天天拍 | av激情五月 | 狠狠色狠狠色综合日日92 | 日本成人中文字幕在线观看 | 91污视频在线观看 | 免费成人av在线 | 日韩h在线观看 | 综合铜03| 成人99免费视频 | 色资源在线观看 | 国产剧情亚洲 | 国产精品九九久久久久久久 | 国产精品一区二区久久 | 欧美精品首页 | 中文在线a天堂 | 色老板在线视频 | 国产视频一 | 91精品一区国产高清在线gif | 特级xxxxx欧美 | 日韩在线免费 | 99视频播放 | 国产日韩中文在线 | 国产精品久久久久久久久久免费 | 亚洲欧美日韩中文在线 | 久久激情视频免费观看 | caobi视频 | 日韩电影在线一区二区 | 国产裸体视频网站 | 精品嫩模福利一区二区蜜臀 | 欧美成人一区二区 | 国产成人一区二区三区在线观看 | 男女全黄一级一级高潮免费看 | av高清一区二区三区 | 成人精品视频久久久久 | 中文字幕免费久久 | 亚洲精品一区二区18漫画 | 欧美成亚洲 | 天天操天天摸天天射 | 天天色综合三 | 欧美吞精| 亚洲视频观看 | 在线观看黄| 久久人人爽av | 久久久久免费精品国产 | 欧美在线观看视频一区二区三区 | 亚洲精品乱码久久久久久蜜桃91 | 婷婷综合导航 | 天天干天天看 | 99免费精品视频 | 99精品免费| 成人av一区二区兰花在线播放 | 黄色小说免费在线观看 | 亚洲黄色大片 | 黄色日本免费 | 天天综合婷婷 | 天天草视频| 国产69精品久久久久99尤 | www色,com| 国产在线高清视频 | 欧美日韩后| 91夫妻自拍 | 97超碰人人看 | 五月婷婷丁香色 | 欧美日韩视频一区二区 | 久久精品国产一区二区三区 | 亚洲爽爽网 | 免费一级特黄录像 | 欧美成人黄色 | 免费99精品国产自在在线 | 91亚洲精品在线观看 | 久久成人午夜 | 精品国产伦一区二区三区观看说明 | 国产白浆在线观看 | 久草资源在线观看 | 色综合天天综合 | 免费在线看成人av | 521色香蕉网站在线观看 | 天天色天天操天天爽 | 国产在线观看不卡 | 亚洲精品乱码久久久久久蜜桃动漫 | 高清国产午夜精品久久久久久 | 成年人在线免费看片 | 狠狠色狠狠色综合日日92 | 精品日韩视频 | 91精品视屏 | 91片黄在线观看 | 国产精品一区二区三区久久久 | 国产精品久久久久久99 | 四川bbb搡bbb爽爽视频 | 91免费在线看片 | 国产精品免费成人 | 制服丝袜在线91 | 国产一级特黄毛片在线毛片 | 人人爽人人澡 | 三级黄色a| 亚洲精品视频播放 | 日日夜夜狠狠 | 日韩欧美一二三 | 91桃色在线播放 | 在线三级av| 中文字幕制服丝袜av久久 | 亚洲精品一区二区在线观看 | 日韩av一区二区三区四区 | 激情狠狠干 | 在线亚洲观看 | 精品久久国产 | 综合久久久久久久 | 成人91在线 | 一区二区三区在线免费播放 | 伊人中文网 | 亚洲理论影院 | 欧美激情精品久久久久久 | 黄色毛片视频免费 | 狠狠色丁香婷婷综合久久片 | 日韩欧美国产精品 | 国产无吗一区二区三区在线欢 | 日韩精品一区二区电影 | www四虎影院 | 男女啪啪视屏 | 中文字幕成人网 | 黄色小视频在线观看免费 | 亚洲国产精品影院 | 国产理论一区二区三区 | www黄色com | 天堂黄色片 | 国产一级免费在线 | 国产精品亚洲综合久久 | 国产美女在线免费观看 | 精品视频在线播放 | 亚洲天天综合网 | 中文字幕成人在线观看 | 色资源在线 | 国产在线观看中文字幕 | 亚洲午夜久久久久久久久电影网 | 高清免费av在线 | 国产午夜精品一区二区三区 | a电影免费看| 成人h在线播放 | 成人小视频在线观看免费 | 婷婷丁香在线 | www.久艹| 一区二区三区在线观看免费 | 久久久精品久久日韩一区综合 | 超碰97在线看 | av官网在线 | 91尤物在线播放 | 欧美日韩在线观看一区二区三区 | 欧美精品网站 | 在线观看免费福利 | 玖玖精品在线 | 人人爽人人 | 色综合综合 | 97碰在线视频 | 免费在线国产精品 | 久久国产精品99久久久久久丝袜 | 精品夜夜嗨av一区二区三区 | 久草在线最新 | 免费观看视频的网站 | 国产精品理论片 | 91九色视频在线观看 | 日韩啪啪小视频 | 日本一区二区三区免费观看 | 色婷婷激婷婷情综天天 | 日韩专区在线 | 免费国产视频 | 色99导航 | 亚洲伊人天堂 | 免费观看的黄色片 | 99在线国产 | 91精品一区二区三区蜜桃 | 国产一区二区免费看 | 国产日韩精品一区二区在线观看播放 | 亚洲午夜久久久久久久久电影网 | 国产在线观看你懂得 | 开心婷婷色 | 国产区精品视频 | 中文字幕麻豆 | 国内揄拍国产精品 | 亚洲激情| 日韩经典一区二区三区 | www.天堂av | 全久久久久久久久久久电影 | 天天干天天拍天天操天天拍 | 国产精品一区二区三区免费看 | 色综合久久五月 | 丁香资源影视免费观看 | 一本一本久久aa综合精品 | 91亚色视频在线观看 | 久久国产精品色av免费看 | 欧美日韩精品二区第二页 | 国产拍揄自揄精品视频麻豆 | 永久免费在线 | 狠狠干.com | 久草久热| 久久国产福利 | 欧美色图一区 | 国产精品久久久久久一区二区 | 久久久综合九色合综国产精品 | av动图| 久久这里只有精品视频99 | 免费成人结看片 | 黄色一级大片在线免费看产 | 国产一区二区三精品久久久无广告 | 久久精品久久久久久久 | 成人91av | 国产99久久九九精品 | 国产视频精品视频 | 日韩精品在线视频免费观看 | 97超碰成人在线 | 日韩欧美91| 成人免费看视频 | 欧美一区免费观看 | 国产资源在线观看 | 久久久影院一区二区三区 | 久久污视频| 国产又粗又猛又色又黄网站 | 97精品国产97久久久久久 | 一区二区在线电影 | 九草视频在线观看 | 欧美a级在线免费观看 | 成人免费在线播放 | 美女av免费看 | 探花视频在线观看免费版 | 国产资源网 | 天天干天天上 | 国产精品自产拍在线观看中文 | 成人久久18免费 | 色婷婷av国产精品 | 国产视频欧美视频 | 免费一级特黄录像 | 国产精品第二页 | 欧美日本在线观看视频 | 中文字幕一区二区三区乱码在线 | 久久久99久久 | 一级黄色在线免费观看 | 福利视频在线看 | 91人人爱 | 伊人天天狠天天添日日拍 | 日韩精品久久中文字幕 | 欧美精品一区在线 | 午夜一级免费电影 | 91av中文| 日日操狠狠干 | 伊人久久精品久久亚洲一区 | 成人av片免费观看app下载 | 国产精品正在播放 | 国产中文字幕网 | 91欧美视频网站 | 国产精品不卡av | 欧美最新大片在线看 | 一区二区三区高清在线 | 亚洲欧美日韩一二三区 | 色a网| 国产成人亚洲在线观看 | 日本久久免费电影 | 伊人狠狠 | 免费一级日韩欧美性大片 | 九九爱免费视频在线观看 | 日韩美女一级片 | 特片网久久 | 久久精品毛片基地 | 97av在线视频免费播放 | 天天色天天色 | 天天做天天爱夜夜爽 | 青青啪 | 欧美欧美 | 欧美日韩视频在线播放 | 免费观看性生活大片 | 91九色最新地址 | 亚洲国产99| 亚洲精色 | 手机在线小视频 | 91污视频在线观看 | 毛片在线网 | av资源在线观看 | 99中文视频在线 | 人人澡人人爱 | 人人爽人人澡人人添人人人人 | 亚洲综合色播 | 国产精品免费视频网站 | 毛片网站在线观看 | 成人免费观看大片 | 亚洲天堂精品视频在线观看 | 日本中文字幕在线播放 | 亚洲综合激情 | 综合久久久久久久久 | www.亚洲精品视频 | 国产 欧美 日产久久 | 亚洲国产激情 | 亚洲婷婷综合色高清在线 | 婷婷六月综合亚洲 | 国产欧美日韩精品一区二区免费 | 人人插人人看 | 色婷婷综合在线 | 午夜精品一区二区三区在线播放 | 国产一级片免费视频 | 这里只有精彩视频 | 色婷婷综合视频在线观看 | 天天天综合网 | 国产美女精品久久久 | 日韩电影在线一区二区 | 日韩精品影视 | www.黄色 | 久久91久久久久麻豆精品 | 在线观看日韩中文字幕 | 亚洲成人资源 | 午夜色婷婷| 9草在线 | 精品国产免费看 | 亚洲综合五月天 | 天天插天天干 | 国产精品久久久久久久久久99 | 日韩电影中文字幕在线 | 热久久影视 | 深夜视频久久 | 一区 在线 影院 | 免费人人干 | 天天操夜夜操夜夜操 | 天天舔夜夜操 | 成人h电影 | 婷婷免费在线视频 | 五月开心六月婷婷 | 欧美aaa视频 | 欧美韩国日本在线 | 欧美日韩中文在线 | 少妇bbb| 国产精品一区二区三区在线看 | av在线免费不卡 | 亚洲国产精品视频在线观看 | 激情综合网在线观看 | 麻豆国产网站入口 | 久久国产精品一区二区 | 亚洲精品久久久蜜臀下载官网 | 国产成人精品久久亚洲高清不卡 | 97福利| 六月丁香综合网 | 中文字幕在线观看第一页 | 99免费在线观看 | 丁香六月综合网 | 国产又粗又猛又爽又黄的视频先 | 精品亚洲二区 | 亚洲黑丝少妇 | 国产在线久久久 | 久久精品欧美视频 | 亚洲成年人在线播放 | 日本公妇色中文字幕 | 久久久久这里只有精品 | 国产精品每日更新 | 婷婷丁香色 | 超碰97人人干| 国产精品99久久久久久宅男 | 久久久99国产精品免费 | 亚洲国产精品一区二区尤物区 | 一级大片在线观看 | 国产自在线观看 | 成年人app网址 | 日韩三级不卡 | 婷婷丁香狠狠爱 | 97在线视频免费 | 毛片一级免费一级 | 亚洲精品一区二区三区高潮 | 亚洲国产精品激情在线观看 | 成年人视频免费在线播放 | avlulu久久精品 | 国产精品夜夜夜一区二区三区尤 | 亚洲成av人片在线观看无 | 日韩一区二区免费视频 | 欧美精品久久久久 | 久久三级毛片 | 99精品国产一区二区三区麻豆 | 99视频免费看 | av性在线| 国产一级视频在线 | 久草在线播放视频 | 精品一区二区三区香蕉蜜桃 | 欧美一区二区日韩一区二区 | 亚洲综合色丁香婷婷六月图片 | 天天干,天天射,天天操,天天摸 | 午夜精品久久久久 | 日韩av中文字幕在线免费观看 | 黄网站免费看 | 亚洲成av人影片在线观看 | 在线观看国产永久免费视频 | 国产一区二区视频在线 | 免费色网站 | 久久精品一二三 | 美国三级黄色大片 | 激情中文字幕 | 久久九九影视 | 免费看片亚洲 | 在线日本看片免费人成视久网 | 亚一亚二国产专区 | 99热精品国产一区二区在线观看 | 亚洲欧美va | 国产精品久久久久久久久久久久久久 | 亚洲综合成人专区片 | 一区二区三区国产精品 | 日本女人逼 | 国产亚洲在线 | av成人在线网站 | 综合网中文字幕 | 在线观看www. | 在线成人免费电影 | 超碰大片 | 欧美综合干 | 亚洲免费一级电影 |