www.久久久久|狼友网站av天堂|精品国产无码a片|一级av色欲av|91在线播放视频|亚洲无码主播在线|国产精品草久在线|明星AV网站在线|污污内射久久一区|婷婷综合视频网站

當前位置:首頁 > 芯聞號 > 充電吧
[導讀]接上篇的內(nèi)容,分析下ServiceManager的實現(xiàn)。??????? ServiceManager的實現(xiàn)位于:??????? 4.2:/frameworks/base/cmds/serviceman

接上篇的內(nèi)容,分析下ServiceManager的實現(xiàn)。

??????? ServiceManager的實現(xiàn)位于:

??????? 4.2:/frameworks/base/cmds/servicemanager/

??????? 4.3:frameworks/native/cmds/servicemanager/

ServiceManager的啟動 ? ? ? ? ServiceManager的的啟動由init進程根據(jù)init.rc文件的配置執(zhí)行,從時間順序上來說,ServiceManager的啟動優(yōu)先于Zygote進程

service?servicemanager?/system/bin/servicemanager
????class?core????????????//core類服務
????user?system???????????//用戶名
????group?system??????????//用戶組
????critical??????????????//重要service,?如果4分鐘內(nèi)crush4次以上,則重啟系統(tǒng)并進入recovery
????onrestart?restart?zygote??????????//servicemanager重啟以后,自動重啟zygote
????onrestart?restart?media???????????//同上
????onrestart?restart?surfaceflinger??//同上
????onrestart?restart?drm?????????????//同上

? ? ? ? ServiceManager是一個可執(zhí)行文件,所以,我們從main函數(shù)看起(frameworks/base/cmds/servicemanager/servicemanager.c):

int?main(int?argc,?char?**argv)
{
????struct?binder_state?*bs;
????void?*svcmgr?=?BINDER_SERVICE_MANAGER;

????bs?=?binder_open(128*1024);

????if?(binder_become_context_manager(bs))?{
????????ALOGE("cannot?become?context?manager?(%s)n",?strerror(errno));
????????return?-1;
????}

????svcmgr_handle?=?svcmgr;
????binder_loop(bs,?svcmgr_handler);//svcmgr_handle為具體的請求處理邏輯
????return?0;
}

? ? ? ? 簡單來說,ServiceManager的啟動分為三個步驟: 打開dev/binder,并創(chuàng)建binder緩沖區(qū)注冊當前進程為上下文管理者(ServiceManager)進入處理循環(huán),等待Service/Client的請求 步驟一 ? ? ? ? 步驟一,由binder_open函數(shù)實現(xiàn)(frameworks/base/cmds/servicemanager/binder.c):

struct?binder_state?*binder_open(unsigned?mapsize)
{
????struct?binder_state?*bs;

????bs?=?malloc(sizeof(*bs));
????if?(!bs)?{
????????errno?=?ENOMEM;
????????return?0;
????}

????bs->fd?=?open("/dev/binder",?O_RDWR);//上一節(jié)講過,這里會轉入內(nèi)核態(tài),執(zhí)行binder_open,創(chuàng)建binder_proc
????if?(bs->fd?<?0)?{
????????fprintf(stderr,"binder:?cannot?open?device?(%s)n",
????????????????strerror(errno));
????????goto?fail_open;
????}

????bs->mapsize?=?mapsize;//mapsize?=?128KB
????bs->mapped?=?mmap(NULL,?mapsize,?PROT_READ,?MAP_PRIVATE,?bs->fd,?0);//上一節(jié)講過,這里會轉入內(nèi)核態(tài),執(zhí)行binder_mmap
????????????????????????????????????????????????????????????????????????//在內(nèi)核態(tài)創(chuàng)建相同size的緩沖區(qū),并分配第一個物理頁面,計算內(nèi)核緩沖區(qū)地址和用戶緩沖區(qū)地址的偏移量
????if?(bs->mapped?==?MAP_FAILED)?{
????????fprintf(stderr,"binder:?cannot?map?device?(%s)n",
????????????????strerror(errno));
????????goto?fail_map;
????}

????????/*?TODO:?check?version?*/

????return?bs;

fail_map:
????close(bs->fd);
fail_open:
????free(bs);
????return?0;
}

? ? ? ? 如果上一節(jié)binder driver部分的內(nèi)容有比較好的理解的話,這邊的代碼應該比較好理解的,順便看看binder_state的實現(xiàn):

struct?binder_state
{
????int?fd;
????void?*mapped;
????unsigned?mapsize;
};

步驟二 ? ? ? ? 步驟二,由binder_become_context_manager函數(shù)實現(xiàn):

int?binder_become_context_manager(struct?binder_state?*bs)
{
????return?ioctl(bs->fd,?BINDER_SET_CONTEXT_MGR,?0);
}

? ? ? ? 灰常簡單的實現(xiàn),有木有? 讓我們來回憶一下,上一節(jié)的內(nèi)容,ioctl的調用會轉入到binder driver的binder_ioctl函數(shù)來處理BINDER_SET_CONTEXT_MGR:

????????case?BINDER_SET_CONTEXT_MGR:
		if?(binder_context_mgr_node?!=?NULL)?{
			printk(KERN_ERR?"binder:?BINDER_SET_CONTEXT_MGR?already?setn");
			ret?=?-EBUSY;
			goto?err;
		}
		ret?=?security_binder_set_context_mgr(proc->tsk);
		if?(ret?<?0)
			goto?err;
		if?(binder_context_mgr_uid?!=?-1)?{
			if?(binder_context_mgr_uid?!=?current->cred->euid)?{
				printk(KERN_ERR?"binder:?BINDER_SET_"
				???????"CONTEXT_MGR?bad?uid?%d?!=?%dn",
				???????current->cred->euid,
				???????binder_context_mgr_uid);
				ret?=?-EPERM;
				goto?err;
			}
		}?else
			binder_context_mgr_uid?=?current->cred->euid;
		binder_context_mgr_node?=?binder_new_node(proc,?NULL,?NULL);//binder_context_mgr_node->proc?=?servicemanager
		if?(binder_context_mgr_node?==?NULL)?{
			ret?=?-ENOMEM;
			goto?err;
		}
		binder_context_mgr_node->local_weak_refs++;
		binder_context_mgr_node->local_strong_refs++;
		binder_context_mgr_node->has_strong_ref?=?1;
		binder_context_mgr_node->has_weak_ref?=?1;
		break;

? ? ? ? 忽略安全檢查等代碼,上面的代碼就是設定了全局變量binder_context_mgr_node,并增加引用計數(shù)。 步驟三 ? ? ? ? 處理循環(huán)的實現(xiàn)在binder_loop函數(shù)中:

void?binder_loop(struct?binder_state?*bs,?binder_handler?func)
{
????int?res;
????struct?binder_write_read?bwr;
????unsigned?readbuf[32];

????bwr.write_size?=?0;
????bwr.write_consumed?=?0;
????bwr.write_buffer?=?0;
????
????readbuf[0]?=?BC_ENTER_LOOPER;
????binder_write(bs,?readbuf,?sizeof(unsigned));//binder?driver會通過binder_thread_write函數(shù)處理BC_ENTER_LOOPER指令

????for?(;;)?{
????????bwr.read_size?=?sizeof(readbuf);
????????bwr.read_consumed?=?0;
????????bwr.read_buffer?=?(unsigned)?readbuf;

????????res?=?ioctl(bs->fd,?BINDER_WRITE_READ,?&bwr);//讀取client/service的請求

????????if?(res?<?0)?{
????????????ALOGE("binder_loop:?ioctl?failed?(%s)n",?strerror(errno));
????????????break;
????????}

????????res?=?binder_parse(bs,?0,?readbuf,?bwr.read_consumed,?func);//處理請求
????????if?(res?==?0)?{
????????????ALOGE("binder_loop:?unexpected?reply?!n");
????????????break;
????????}
????????if?(res?<?0)?{
????????????ALOGE("binder_loop:?io?error?%d?%sn",?res,?strerror(errno));
????????????break;
????????}
????}
}

ServiceManager客戶端代理 ? ? ? ? ServiceManager運行在自己的進程中,為了向Client/Service進程提供服務,ServiceManager為自己準備了客戶端代理,方便Client/Service調用。 IServiceManager和BpServiceManager ? ? ? ? IServiceManager是ServiceManager在native層的接口(framework/native/include/binder/IServiceManager.h):

class?IServiceManager?:?public?IInterface
{
public:
????DECLARE_META_INTERFACE(ServiceManager);


????/**
?????*?Retrieve?an?existing?service,?blocking?for?a?few?seconds
?????*?if?it?doesn't?yet?exist.
?????*/
????virtual?spgetService(?const?String16&?name)?const?=?0;


????/**
?????*?Retrieve?an?existing?service,?non-blocking.
?????*/
????virtual?spcheckService(?const?String16&?name)?const?=?0;


????/**
?????*?Register?a?service.
?????*/
????virtual?status_t????????????addService(?const?String16&?name,
????????????????????????????????????????????const?sp&?service,
????????????????????????????????????????????bool?allowIsolated?=?false)?=?0;


????/**
?????*?Return?list?of?all?existing?services.
?????*/
????virtual?VectorlistServices()?=?0;


????enum?{
????????GET_SERVICE_TRANSACTION?=?IBinder::FIRST_CALL_TRANSACTION,
????????CHECK_SERVICE_TRANSACTION,
????????ADD_SERVICE_TRANSACTION,
????????LIST_SERVICES_TRANSACTION,
????};
};

? ? ? ? 從接口中,我們看到SeviceManager提供了4個功能: getService,同checkServicecheckService,供Client獲取Service的binderaddService, 供Service注冊binderlistService,用于枚舉所有已經(jīng)注冊的binder ? ? ? ? 而BpServiceManager是IServiceManager的一個子類,提供了IServiceManager的實現(xiàn)(frameworks/native/libs/binder/IServiceManager.cpp):

class?BpServiceManager?:?public?BpInterface{
public:
????BpServiceManager(const?sp&?impl)
????????:?BpInterface(impl)
????{
????}

????virtual?spgetService(const?String16&?name)?const
????{
??????????......?//實現(xiàn)啥的,我們后面再看
????}

????virtual?spcheckService(?const?String16&?name)?const
????{
??????????......
????}

????virtual?status_t?addService(const?String16&?name,?const?sp&?service,
????????????bool?allowIsolated)
????{
??????????......
????}

????virtual?VectorlistServices()
????{
??????????......
????}
};

? ? ? ? 前綴Bp可以理解為Binder Proxy,即BpServiceManager實際上是ServiceManager在客戶進程中的一個代理,所以BpServiceManager并不負責實現(xiàn)真正的功能,而是通過Binder通信發(fā)送請求到前面啟動的ServiceManager進程。上一節(jié)中我們講到過,Binder通信的前提是客戶端進程需要有BpBinder,那么BpBinder從何而來呢? defaultServiceManager ? ? ? ? 作為一個特殊的“Service”,Android系統(tǒng)為ServiceManager準備了“快捷方式”,這個快捷方式就是defaultServiceManager(frameworks/native/libs/binder/IServiceManager.cpp):

spdefaultServiceManager()
{
????if?(gDefaultServiceManager?!=?NULL)?return?gDefaultServiceManager;//單例模式
????
????{
????????AutoMutex?_l(gDefaultServiceManagerLock);
????????if?(gDefaultServiceManager?==?NULL)?{
????????????gDefaultServiceManager?=?interface_cast(
????????????????ProcessState::self()->getContextObject(NULL));
????????}
????}
????
????return?gDefaultServiceManager;
}

? ? ? ? 這里可以把defaultServiceManager分解為三個步驟: ProcessState::self()ProcessState->getContextObject(NULL)interface_cast

本站聲明: 本文章由作者或相關機構授權發(fā)布,目的在于傳遞更多信息,并不代表本站贊同其觀點,本站亦不保證或承諾內(nèi)容真實性等。需要轉載請聯(lián)系該專欄作者,如若文章內(nèi)容侵犯您的權益,請及時聯(lián)系本站刪除。
換一批
延伸閱讀

9月2日消息,不造車的華為或將催生出更大的獨角獸公司,隨著阿維塔和賽力斯的入局,華為引望愈發(fā)顯得引人矚目。

關鍵字: 阿維塔 塞力斯 華為

加利福尼亞州圣克拉拉縣2024年8月30日 /美通社/ -- 數(shù)字化轉型技術解決方案公司Trianz今天宣布,該公司與Amazon Web Services (AWS)簽訂了...

關鍵字: AWS AN BSP 數(shù)字化

倫敦2024年8月29日 /美通社/ -- 英國汽車技術公司SODA.Auto推出其旗艦產(chǎn)品SODA V,這是全球首款涵蓋汽車工程師從創(chuàng)意到認證的所有需求的工具,可用于創(chuàng)建軟件定義汽車。 SODA V工具的開發(fā)耗時1.5...

關鍵字: 汽車 人工智能 智能驅動 BSP

北京2024年8月28日 /美通社/ -- 越來越多用戶希望企業(yè)業(yè)務能7×24不間斷運行,同時企業(yè)卻面臨越來越多業(yè)務中斷的風險,如企業(yè)系統(tǒng)復雜性的增加,頻繁的功能更新和發(fā)布等。如何確保業(yè)務連續(xù)性,提升韌性,成...

關鍵字: 亞馬遜 解密 控制平面 BSP

8月30日消息,據(jù)媒體報道,騰訊和網(wǎng)易近期正在縮減他們對日本游戲市場的投資。

關鍵字: 騰訊 編碼器 CPU

8月28日消息,今天上午,2024中國國際大數(shù)據(jù)產(chǎn)業(yè)博覽會開幕式在貴陽舉行,華為董事、質量流程IT總裁陶景文發(fā)表了演講。

關鍵字: 華為 12nm EDA 半導體

8月28日消息,在2024中國國際大數(shù)據(jù)產(chǎn)業(yè)博覽會上,華為常務董事、華為云CEO張平安發(fā)表演講稱,數(shù)字世界的話語權最終是由生態(tài)的繁榮決定的。

關鍵字: 華為 12nm 手機 衛(wèi)星通信

要點: 有效應對環(huán)境變化,經(jīng)營業(yè)績穩(wěn)中有升 落實提質增效舉措,毛利潤率延續(xù)升勢 戰(zhàn)略布局成效顯著,戰(zhàn)新業(yè)務引領增長 以科技創(chuàng)新為引領,提升企業(yè)核心競爭力 堅持高質量發(fā)展策略,塑強核心競爭優(yōu)勢...

關鍵字: 通信 BSP 電信運營商 數(shù)字經(jīng)濟

北京2024年8月27日 /美通社/ -- 8月21日,由中央廣播電視總臺與中國電影電視技術學會聯(lián)合牽頭組建的NVI技術創(chuàng)新聯(lián)盟在BIRTV2024超高清全產(chǎn)業(yè)鏈發(fā)展研討會上宣布正式成立。 活動現(xiàn)場 NVI技術創(chuàng)新聯(lián)...

關鍵字: VI 傳輸協(xié)議 音頻 BSP

北京2024年8月27日 /美通社/ -- 在8月23日舉辦的2024年長三角生態(tài)綠色一體化發(fā)展示范區(qū)聯(lián)合招商會上,軟通動力信息技術(集團)股份有限公司(以下簡稱"軟通動力")與長三角投資(上海)有限...

關鍵字: BSP 信息技術
關閉
關閉