/sys/power/state
state 是 sysfs 中一個文件,為 Generic PM
的核心接口,在“kernel/power/main.c”中實現(xiàn),用于將系統(tǒng)置于指定的 Power State。
讀取該文件,返回當前系統(tǒng)支持的 Power State,形式為字符串。在內(nèi)核中,有兩種類型的 Power
State,一種是 Hibernate
相關的,名稱為“disk”,除“disk”之外,內(nèi)核在"/kernel/power/suspend.c"中通過數(shù)組的形式定義了另外 3 個
state,如下:
const char *const pm_states[PM_SUSPEND_MAX] = {
[PM_SUSPEND_FREEZE] = "freeze",
[PM_SUSPEND_STANDBY] = "standby",
[PM_SUSPEND_MEM] = "mem",
};
這些 Power State 的解釋如下:
- freeze:不涉及具體的
Hardware 或 Driver,只是凍結(jié)所有的進程,包括用戶空間進程及內(nèi)核線程 - standby
- mem,即通常所講的 Sleep
功能,STR,Suspend to RAM。 - disk,即
Hibernate 功能,STD,Suspend to Disk。
寫入特定的 Power State 字符串,將會把系統(tǒng)置為該模式。
/sys/power/wakeup_count
該接口只和 Sleep 功能有關,因此由“CONFIG_PM_SLEEP”宏定義控制。它的存在,是為了解決
Sleep 和 Wakeup 之間的同步問題。
系統(tǒng)睡眠后,可以通過保留的 Wakeup source 喚醒系統(tǒng)。而在 CPU 體系中,喚醒系統(tǒng)就是喚醒
CPU,而喚醒 CPU 的唯一途徑,就是 Wakeup source 產(chǎn)生中斷(內(nèi)核稱作 Wakeup event)。而內(nèi)核要保證在多種狀態(tài)下,Sleep/Wakeup
的行為都能正常,如下:
▆ 系統(tǒng)處于 sleep 狀態(tài)時,產(chǎn)生了 Wakeup event。此時應該直接喚醒系統(tǒng)。這沒有問題。
▆ 系統(tǒng)在進入 sleep 的過程中,產(chǎn)生了
Wakeup event。此時應該放棄進入 sleep。
這一點就不那么容易做到了。例如,當 Wakeup event
發(fā)生在“/sys/power/state”被寫之后、內(nèi)核執(zhí)行 freeze 操作之前。此時用戶空間程序依舊可以處理 Wakeup
event,或者只是部分處理。而內(nèi)核卻以為該 Event 已經(jīng)被處理,因此并不會放棄此次 sleep 動作。
這就會造成,Wakeup event 發(fā)生后,用戶空間程序已經(jīng)后悔了,不想睡了,但最終還是睡下去了。直到下一個
Wakeup event 到來。
為了解決上面的問題,內(nèi)核提供 wakeup_count 機制,配合“/sys/power/state”,以實現(xiàn)
Sleep 過程中的同步。該機制的操作行為如下:
▆ wakeup_count 是內(nèi)核用來保存當前
wakeup event 發(fā)生的計數(shù)。
▆ 用戶空間程序在寫入
state 切換狀態(tài)之前,應先讀取 wakeup_count 并把獲得的 count 寫回給 wakeup_count。
▆ 內(nèi)核會比對寫回的 count 和當前的 count 是否一致,如果不一致,說明在讀取/寫回操作之間,產(chǎn)生了新的的
wakeup event,內(nèi)核就會返回錯誤。
▆ 用戶空間程序檢測到寫入錯誤之后,不能繼續(xù)后的動作,需要處理響應的 event 并伺機再次讀取/寫回
wakeup_count。
▆ 如果內(nèi)核比對一致,會記錄 write wakeup_count 成功時的 event 快照,后面繼續(xù)
suspend 動作時,會檢查是否和快照相符,如果不符,會終止 suspend。
▆ 用戶空間程序檢測到寫入正確后,可以繼續(xù)對 state 的寫入,以便發(fā)起一次狀態(tài)切換。而此時是安全的。
-
嵌入式
+關注
關注
5095文章
19189瀏覽量
307987 -
接口
+關注
關注
33文章
8717瀏覽量
152018 -
Linux
+關注
關注
87文章
11351瀏覽量
210505
發(fā)布評論請先 登錄
相關推薦
Linux用戶空間與內(nèi)核空間的區(qū)別?
USB接口怎么實現(xiàn)間接的數(shù)據(jù)讀寫?
用戶空間與內(nèi)核通信方式是什么
用戶空間如何訪問內(nèi)核空間?
空間數(shù)據(jù)插件技術研究
過程計算系統(tǒng)和技術過程之間接口的說明 GB12058-89
模塊間接口設計不匹配問題
用戶空間和內(nèi)核空間通訊-Netlink 上
需要了解linux內(nèi)核空間和用戶空間的基本原理
Linux用戶空間與內(nèi)核空間
![Linux<b class='flag-5'>用戶</b><b class='flag-5'>空間</b>與內(nèi)核<b class='flag-5'>空間</b>](https://file.elecfans.com/web1/M00/BC/8D/o4YBAF7DmvOAKMm0AABuoDxbbeM080.png)
什么是futex?Futex用戶和內(nèi)核空間接口API是什么?
![什么是futex?Futex<b class='flag-5'>用戶</b>和內(nèi)核<b class='flag-5'>空間接口</b>API是什么?](https://file1.elecfans.com/web2/M00/88/7D/wKgZomRoi8qAI34qAAAOfiaIvVw672.png)
Suspend是什么意思 過程概述
![Suspend是什么意思 過程概述](https://file1.elecfans.com/web2/M00/A2/7C/wKgZomT-yVeAUEi5AABg2ozmIvg203.jpg)
評論