色哟哟视频在线观看-色哟哟视频在线-色哟哟欧美15最新在线-色哟哟免费在线观看-国产l精品国产亚洲区在线观看-国产l精品国产亚洲区久久

0
  • 聊天消息
  • 系統(tǒng)消息
  • 評論與回復(fù)
登錄后你可以
  • 下載海量資料
  • 學(xué)習(xí)在線課程
  • 觀看技術(shù)視頻
  • 寫文章/發(fā)帖/加入社區(qū)
會員中心
創(chuàng)作中心

完善資料讓更多小伙伴認識你,還能領(lǐng)取20積分哦,立即完善>

3天內(nèi)不再提示

微內(nèi)核中的電源管理

yzcdx ? 來源:OS與AUTOSAR研究 ? 2023-11-29 09:33 ? 次閱讀

之前介紹的電源管理機制基本都是在Linux中實現(xiàn)的,可以看到很復(fù)雜,各種框架,明明一個操作非要轉(zhuǎn)來轉(zhuǎn)去,而且在內(nèi)核里面實現(xiàn),跟內(nèi)核的各種框架又糾纏不清,什么consumer、Framework、provider框架亂亂的

就不能搞成最簡單的CS構(gòu)架,一個Client和一個Server就搞定了,不需要什么框架,也不需要跟各種程序混到一塊去,就像上圖的一個問題:去飯店吃飯是客戶端還是服務(wù)端

72f5d0e4-8e40-11ee-939d-92fbcf53809c.png

這里重點以QNX為例,介紹下微內(nèi)核中的電源管理的特點:

電源管理作為一個Server在用戶層,算一個APP

電源管理服務(wù)的對象Client:電源敏感APP、驅(qū)動APP、電源監(jiān)控APP

Client和Server之間通過IPC通信,約定好通信的報文

1. QNX電源管理框架

73135402-8e40-11ee-939d-92fbcf53809c.png

電源管理服務(wù)可以:

可以控制各個設(shè)備包括CPU的電源狀態(tài)

一組電源管理服務(wù),用于實現(xiàn)電源管理策略,可以管理應(yīng)用APP即設(shè)備硬件驅(qū)動APP、電源敏感APP、電源監(jiān)控APP

7332c3e6-8e40-11ee-939d-92fbcf53809c.png

電源管理架構(gòu)的主要組件是:

實施系統(tǒng)電源管理策略的電源管理服務(wù)

與電源管理器交互以根據(jù)系統(tǒng)策略調(diào)整功率級別的設(shè)備驅(qū)動程序

電源監(jiān)控應(yīng)用程序——可以提供電源管理策略使用的輸入事件或數(shù)據(jù)

功率敏感應(yīng)用程序——可能會收到電源模式更改的通知。

7349a6d8-8e40-11ee-939d-92fbcf53809c.png

QNX中一切都是文件,設(shè)備也是組織為文件層級,對設(shè)備的電源管理操作就是操作文件節(jié)點,例如上圖中。

電源管理狀態(tài):

735ee2d2-8e40-11ee-939d-92fbcf53809c.png

對于設(shè)備只定義了四種,簡單好管理。

Active:表示從用戶的角度來看實體是可操作的。

Idle:表示實體部分供電;并非所有功能都可操作。從用戶的角度來看,實體是可操作的,并在使用時轉(zhuǎn)換為*活動*模式。

Standby:表示實體部分供電;只有有限的功能是可操作的,例如實現(xiàn)喚醒事件。從用戶的角度來看,該實體是不可操作的。

Off:指示實體已斷電且不可操作。

73881346-8e40-11ee-939d-92fbcf53809c.png

對于系統(tǒng)可以多定義一些電源層級,用來進入不同級別的節(jié)電狀態(tài),從而滿足多種需要。例如上圖中的車載遠程信息處理系統(tǒng)的不同電源模式

上圖顯示電源管理策略通過在空閑、待機(睡眠)或關(guān)機狀態(tài)之間轉(zhuǎn)換來逐步關(guān)閉設(shè)備。這用于限制從電池汲取的待機電流在點火裝置關(guān)閉時逐漸下降。該系統(tǒng)還可以隨時準備在短時間內(nèi)啟動。例如,實時時鐘 (RTC) 可用于定時喚醒 CPU 休眠模式。

當汽車熄火后,像CPU、SDRAMRF、RTC等設(shè)備不能立即斷電,因為CPU、SDRAM是保持系統(tǒng)處于一個運行狀態(tài),而RF、RTC是系統(tǒng)喚醒源

總結(jié)如下:

Power Manager Server初始化先調(diào)用power manager server的init()初始化命名空間,及power manager server提供的resource manager接口;調(diào)用start()初始化處理client請求的thread;觸發(fā)各個device driver or service啟動;啟動其他client:system monitoring apps, Power sensitive apps;

各個device driver or service啟動過程中會向power manager server注冊

System monitoring apps 中的關(guān)火檢測線程檢測到關(guān)火事件,則將當前的點火系統(tǒng)為off的狀態(tài)作為屬性發(fā)送給power manager;Power manager得知system monitor app 匯報了點火系統(tǒng)關(guān)閉的,會執(zhí)行相應(yīng)的電源管理策略切換當前電源模式;將Active1 Idle; 切換電源模式具體操作:對Audio、Video設(shè)備執(zhí)行電源模式切換,此操作為異步操作。

Audio、Video設(shè)備驅(qū)動內(nèi)部執(zhí)行電源模式切換:Active->Shutdown, 當執(zhí)行完畢后向Power manager發(fā)送設(shè)備電源模式切換完成的event;同時會觸發(fā)對設(shè)備及系統(tǒng)電源模式切換關(guān)心的app即Power sensitive apps發(fā)送event

設(shè)備及系統(tǒng)電源模式切換關(guān)心的Power sensitive apps執(zhí)行相應(yīng)的處理。

2. QNX客戶端API

驅(qū)動程序API:

客戶端庫提供了允許驅(qū)動程序和電源管理服務(wù)之間雙向通信的基本服務(wù):

驅(qū)動程序初始化時需要向電源管理服務(wù)進行注冊,這樣系統(tǒng)電源狀態(tài)更改才去通知這個驅(qū)動

電源管理服務(wù)根據(jù)系統(tǒng)電源模式策略通知驅(qū)動程序更改電源模式。

驅(qū)動程序向電源管理服務(wù)報告其電源模式狀態(tài)。

驅(qū)動程序可以選擇向電源管理服務(wù)請求自主電源模式更改。

739ec154-8e40-11ee-939d-92fbcf53809c.png

功耗敏感程序API:

功耗敏感程序要想電源管理服務(wù)注冊感興趣的系統(tǒng)電源狀態(tài)或者某個設(shè)備的電源狀態(tài)

接收電源模式更改的通知

查詢特定服務(wù)或驅(qū)動程序的電源模式

請求更改特定服務(wù)或驅(qū)動程序的電源模式。

系統(tǒng)監(jiān)控應(yīng)用程序的API:

系統(tǒng)監(jiān)控程序需要給電源管理服務(wù)上報各種參數(shù),例如電量、溫度等。

管理與電源管理器對象關(guān)聯(lián)的屬性。這些屬性可以包括由產(chǎn)品特定系統(tǒng)電源管理策略處理的任意數(shù)據(jù),以確定最合適的電源模式

根據(jù)自己的評估標準請求特定服務(wù)或驅(qū)動程序的電源模式更改。

例如查詢設(shè)備自己的電源模式

pm_power_attr_t attr;

if (pm_getattr(hdl, &attr) == -1) {
   error...
}

printf("Current mode is %d
", attr.cur_mode);
if (attr.new_mode != attr.cur_mode)
   printf("Device is changing modes to %d
", attr.new_mode);
if (attr.nxt_mode != attr.new_mode)
   printf("Pending mode change to %d
", attr.nxt_mode);

改變電源模式:

int status;

// attempt to change mode, subject to the power manager policy
if (pm_setmode(hdl, mode, 0) == -1) {
   if (errno == EACCES) {
      // force the power mode to change
      pm_setmode(hdl, mode, PM_MODE_FORCE);
   } else {
      error...
   }
}

3. QNX代碼分析

這里以關(guān)機為例shutdown:關(guān)機或重啟之前會正確地中止進程及服務(wù),代碼路徑:utilssshutdownmain.c

先對命令參數(shù)進行解析:-b是重啟 -S r是重啟

調(diào)用庫函數(shù)shutdown_system()進行重啟

庫函數(shù)shutdown_system(),代碼路徑:libshutdownshutdown.c

提高進程優(yōu)先級

根據(jù)"/proc"目錄下進程,構(gòu)建所有正在運行的進程的列表,申請內(nèi)存空間pidvec存放

按進程的class值排序,然后順序發(fā)送SIGTERM來關(guān)閉進程,kill(pip->pid, SIGTERM)

等待一段時間直到進程被殺死為止,如果時間到了還沒殺死且class <= CLASS_APP則發(fā)送SIGKILL信號

此時,所有非顯示過程都已關(guān)閉。調(diào)用shutdown_done()函數(shù)做顯示更新

如果是重啟,則調(diào)用sysmgr_reboot

釋放pidvec內(nèi)存空間

sysmgr_reboot()函數(shù),代碼中位置:libcservicessysmgr_reboot.c

int sysmgr_reboot(void) {
    sys_cmd_t                   msg;

    msg.i.type = _SYS_CMD;
    msg.i.cmd = _SYS_CMD_REBOOT;
    
    return MsgSendnc(SYSMGR_COID, &msg.i, sizeof msg.i, 0, 0);
}

servicessystemkerminiproc_start.c中do_miniproc()函數(shù)進行處理

case _SYS_CMD_REBOOT:
    RebootSystem(0);
    break;

之后執(zhí)行servicessystemkerkerext_reboot.c中reboot()函數(shù)

static void
reboot(void *abnormal) {
    lock_kernel();
    cpu_reboot();
    calloutptr->reboot(_syspage_ptr, (int)abnormal);
}

屏蔽內(nèi)核中斷

執(zhí)行cpu重啟

回調(diào)calloutptr->reboot函數(shù)

4. Fuchsia中的電源管理

73ae59ac-8e40-11ee-939d-92fbcf53809c.png

初始化:

src/power/power-manager/src/main.rs中找到main函數(shù)

async fn main() -> Result<(), Error> {
    // Setup logging
    fuchsia_syslog::init()?;
    log::info!("started");

    // Setup tracing
    fuchsia_trace_provider::trace_provider_create_with_fdio();

    // Set up the PowerManager
    let mut pm = PowerManager::new();

    // This future should never complete
    let result = pm.run().await;
    log::error!("Unexpected exit with result: {:?}", result);
    result
}

run函數(shù)在模塊PowerManager中

/// Perform the node initialization and begin running the PowerManager.
pub async fn run(&mut self) -> Result<(), Error> {
    // Create a new ServiceFs to handle incoming service requests for the various services that the PowerManager hosts.
    let mut fs = ServiceFs::new_local();

    // Allow our services to be discovered.
    fs.take_and_serve_directory_handle()?;

    // Required call to serve the inspect tree
    let inspector = component::inspector();
    inspect_runtime::serve(inspector, &mut fs)?;

    // Create the nodes according to the config file
    let node_futures = FuturesUnordered::new();
    self.create_nodes_from_config(&mut fs, &node_futures).await?;

    // Run the ServiceFs (handles incoming request streams) and node futures. This future never completes.
    futures::select(fs, node_futures).collect::<()>().await;

    Ok(())
}

SystemPowerModeHandler

這里有很多種type,例如電源模式"SystemPowerModeHandler",主要執(zhí)行了new_from_json和build這兩個函數(shù)

SystemShutdownHandler

每個類型的Handler調(diào)用new_from_json函數(shù)將json文件中的配置賦給handler結(jié)構(gòu)體,然后調(diào)用build方法,初始化handler實例,啟動服務(wù)線程。

這里不詳細說明了,大家可以自己去看代碼。

5. Minix中的電源管理

73c2392c-8e40-11ee-939d-92fbcf53809c.png

Minix也是一個微內(nèi)核,介紹見之前的文章:MINIX3入門-簡介及代碼編譯運行,有興趣自己看看代碼。

6. Harmony OS中的電源管理

Harmony OS也是一個微內(nèi)核

電源管理服務(wù)組件提供如下功能:

重啟系統(tǒng)。

管理休眠運行鎖。

系統(tǒng)電源狀態(tài)查詢。

73d84d5c-8e40-11ee-939d-92fbcf53809c.png73f15f7c-8e40-11ee-939d-92fbcf53809c.png

后記:

微內(nèi)核中電源管理各種驅(qū)動都被實現(xiàn)為APP,各種應(yīng)用APP一般之前是根據(jù)Linux開發(fā)的,也不可能在微內(nèi)核上重新開發(fā)一遍,那這些應(yīng)用APP是符合UNIX編程函數(shù)規(guī)范的,也就是符合POSIX規(guī)范,一個最大的特點就是其規(guī)定了一系列的系統(tǒng)調(diào)用支持這些應(yīng)用APP。那么在微內(nèi)核中需要再加一個殼子來提供這些POSIX接口,從而擴展微內(nèi)核支持的系統(tǒng)調(diào)用,不在微內(nèi)核中的電源管理和驅(qū)動等需要跟這個殼子交互來對應(yīng)用提供服務(wù),或者直接跟電源管理和驅(qū)動的server APP交互(這時需要重寫應(yīng)用APP的代碼接口)。






審核編輯:劉清

聲明:本文內(nèi)容及配圖由入駐作者撰寫或者入駐合作網(wǎng)站授權(quán)轉(zhuǎn)載。文章觀點僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場。文章及其配圖僅供工程師學(xué)習(xí)之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問題,請聯(lián)系本站處理。 舉報投訴
  • SDRAM
    +關(guān)注

    關(guān)注

    7

    文章

    423

    瀏覽量

    55205
  • 電源管理
    +關(guān)注

    關(guān)注

    115

    文章

    6180

    瀏覽量

    144452
  • 實時時鐘
    +關(guān)注

    關(guān)注

    4

    文章

    245

    瀏覽量

    65767
  • RTC
    RTC
    +關(guān)注

    關(guān)注

    2

    文章

    538

    瀏覽量

    66471

原文標題:電源管理入門-19 微內(nèi)核中的電源管理

文章出處:【微信號:OS與AUTOSAR研究,微信公眾號:OS與AUTOSAR研究】歡迎添加關(guān)注!文章轉(zhuǎn)載請注明出處。

收藏 人收藏

    評論

    相關(guān)推薦

    ESP-IDF內(nèi)核的內(nèi)存管理如何驗證?

    請教一下,ESP-IDF 內(nèi)核的內(nèi)存管理如何驗證
    發(fā)表于 06-19 06:30

    Linux 2.6 內(nèi)核的最新電源管理技術(shù)綜述

    (包括 kernel、middleware 以及各種用戶態(tài) utility)如何添加對這些創(chuàng)新的節(jié)能技術(shù)的支持這一角度,為讀者介紹 Linux 操作系統(tǒng)近幾年來在電源管理方面所取得的長足進步以及未來
    發(fā)表于 09-28 14:15

    RTOS的實時內(nèi)核內(nèi)核解析

    什么功能以及實現(xiàn)什么結(jié)構(gòu),不同的操作系統(tǒng)設(shè)計者有不同的回答。 與內(nèi)核相對的是宏內(nèi)核的概念。 宏內(nèi)核把本來在
    發(fā)表于 02-19 06:36

    Linux內(nèi)核電源管理的整體架構(gòu)介紹

    Linux電源管理非常復(fù)雜,牽扯到系統(tǒng)級的待機、頻率電壓變換、系統(tǒng)空閑時的處理以及每個設(shè)備驅(qū)動對于系統(tǒng)待機的支持和每個設(shè)備的運行時電源管理,可以說和系統(tǒng)
    發(fā)表于 07-05 07:00

    什么是內(nèi)核

    什么是內(nèi)核內(nèi)核的發(fā)展歷史內(nèi)核的優(yōu)缺點
    發(fā)表于 03-07 06:36

    內(nèi)核與大內(nèi)核的相關(guān)資料下載

    內(nèi)核與大內(nèi)核是操作系統(tǒng)設(shè)計的兩種不同的思想,這與 CPU 的設(shè)計 RISC 和 CISC 構(gòu)架類似。其中,
    發(fā)表于 12-20 07:11

    用于收獲設(shè)計的電源管理集成電路

    捕集,或從環(huán)境清除環(huán)境的能量,為在各種嵌入式應(yīng)用驅(qū)動電路提供了新的機會。然而,對于工程師來說,能源供應(yīng)的高可變性決定了需要滿足有效電源
    發(fā)表于 07-13 10:34 ?5次下載
    用于<b class='flag-5'>微</b>收獲設(shè)計的<b class='flag-5'>電源</b><b class='flag-5'>管理</b>集成電路

    內(nèi)核RTOS的核外中斷管理

    ARTs-OS是一個基于內(nèi)核的嵌入式實時操作系統(tǒng)。ARTs-OS的中斷管理應(yīng)該提供的基本功能包括:管理中斷處理設(shè)備、中斷服務(wù)例程的
    發(fā)表于 11-01 10:59 ?0次下載

    什么是內(nèi)核_內(nèi)核的發(fā)展歷史

    內(nèi)核設(shè)計的基本思想是簡化內(nèi)核功能,在內(nèi)核之外的用戶態(tài)盡可能多地實現(xiàn)系統(tǒng)服務(wù),同時加入相互之間的安全保護。內(nèi)核只提供最基礎(chǔ)的服務(wù),比如多進程
    的頭像 發(fā)表于 08-14 17:20 ?1.2w次閱讀
    什么是<b class='flag-5'>微</b><b class='flag-5'>內(nèi)核</b>_<b class='flag-5'>微</b><b class='flag-5'>內(nèi)核</b>的發(fā)展歷史

    淺談鴻蒙操作系統(tǒng)的內(nèi)核

    獲取用戶所有權(quán)限的做法,在安全性上大大提升。 什么是內(nèi)核呢? 內(nèi)核結(jié)構(gòu)由一個非常簡單的硬件抽象層和一組比較關(guān)鍵的原語或系統(tǒng)調(diào)用組成;這些原語,僅僅包括了建立一個系統(tǒng)必需的幾個部分;
    的頭像 發(fā)表于 10-13 12:36 ?6156次閱讀

    內(nèi)核與宏內(nèi)核的比較與分析

    混合內(nèi)核實質(zhì)上也是內(nèi)核,而外內(nèi)核是一種比較極端的設(shè)計方法,目前還處于研究階段,所以我們就著重討論宏內(nèi)核
    發(fā)表于 03-17 16:05 ?11次下載
    <b class='flag-5'>微</b><b class='flag-5'>內(nèi)核</b>與宏<b class='flag-5'>內(nèi)核</b>的比較與分析

    微軟內(nèi)核構(gòu)架之Cache管理

    微軟內(nèi)核構(gòu)架之Cache管理器(實用電源技術(shù)手冊磁性元器件分冊pdf)-微軟內(nèi)核構(gòu)架之Cache管理器? ? ? ? ? ? ? ? ? ?
    發(fā)表于 08-31 16:39 ?10次下載
    微軟<b class='flag-5'>內(nèi)核</b>構(gòu)架之Cache<b class='flag-5'>管理</b>器

    LINUX電源管理

    Linux的系統(tǒng)suspend和resumeLinux內(nèi)核 runtime_PM 框架Linux內(nèi)核電源管理綜述
    發(fā)表于 11-07 19:36 ?8次下載
    LINUX<b class='flag-5'>電源</b><b class='flag-5'>管理</b>

    基于Android的Linux內(nèi)核電源管理:概述

    1.電源管理的狀態(tài)Android的Linux內(nèi)核為系統(tǒng)提供了4種電源狀態(tài),內(nèi)核的源代碼為其中的3種定義了名字和對應(yīng)的宏定義,名字定義在ker
    發(fā)表于 01-07 11:14 ?6次下載
    基于Android的Linux<b class='flag-5'>內(nèi)核</b>的<b class='flag-5'>電源</b><b class='flag-5'>管理</b>:概述

    10個關(guān)于內(nèi)核的問題

    如果有個一個不得不用內(nèi)核的理由,那一定是安全。實時上疫情這幾年,汽車和云的實踐表明,內(nèi)核幾乎肯定會應(yīng)用加速。我們提煉了10個關(guān)于
    的頭像 發(fā)表于 12-13 09:55 ?764次閱讀
    主站蜘蛛池模板: 最近中文字幕mv手机免费高清| 国产成人综合在线观看| 久久影院午夜理论片无码| 亚洲国产在线精品国偷产拍| 国产精品玖玖玖影院| 无码区国产区在线播放| 国产精品香蕉视频在线| 无套内谢大学生A片| 国产在线精彩亚洲久久| 亚洲欧美一级久久精品| 久久vs国产| 久久精品国产久精国产果冻传媒| 午夜射精日本三级| 精品久久久无码21P发布| 亚洲中文 字幕 国产 综合| 久久最新地址获取| old胖老太fat bbw青年| 相声flash| 狂躁美女BBBBBB视频| wwwzzz日本| 香蕉免费高清完整| 久久综合香蕉久久久久久久| brazzers欧美最新版视频| 天天综合亚洲综合网站| 黄梅戏mp3大全| 91伊人久久大香线蕉| 三级黄色在线看| 黄色a一级视频| FREE另类老女人| 亚洲成 人a影院青久在线观看| 麻豆蜜桃国语精品无码视频| 成人国产在线观看| 亚洲中文久久精品AV无码| 欧美亚洲高清国产| 娇女的呻吟亲女禁忌h16| 99热这里只有精品6| 亚洲精品美女久久777777| 男人桶女人j的视频在线观看| 国产精片久久久久久婷婷| 永久免费的污视频网站| 色99蜜臀AV无码|