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

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

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

seL4微內(nèi)核入門-代碼下載運(yùn)行及資料

? 來源:OS與AUTOSAR研究 ? 作者:OS與AUTOSAR研究 ? 2022-11-12 15:42 ? 次閱讀

不廢話,老一套:編譯環(huán)境準(zhǔn)備,代碼下載,代碼編譯,qemu代碼運(yùn)行。本文介紹的內(nèi)容都是好東西,提供全方位的微內(nèi)核入門指導(dǎo),就看毅力怎么樣了,就像那句話:笨鳥先飛。

1. sel4簡介

sel4是微內(nèi)核操作系統(tǒng),號稱世界上最安全,最高效的微內(nèi)核。提供非posix兼容的編程接口,它只提供了少量的服務(wù),創(chuàng)建和管理虛擬地址空間、線程以及進(jìn)程間通信(IPC)。亮點是capability機(jī)制,管理每個進(jìn)程所擁有的資源。這個機(jī)制的引入也導(dǎo)致了sel4較難理解和應(yīng)用開發(fā)。關(guān)于微內(nèi)核的介紹參考上一篇:

2. Turorial練習(xí)

從官網(wǎng)提供的學(xué)習(xí)教程hello world開始練習(xí),
df669de2-3df3-11ed-9e49-dac502259ad0.png

2.1 環(huán)境準(zhǔn)備

這里同樣,采用的開發(fā)方式為VitrualBox+Ubuntu,下載VitrualBox和Ubuntu鏡像(版本>= 20.04),安裝虛擬機(jī),具體不再描述。

df9622b0-3df3-11ed-9e49-dac502259ad0.png

環(huán)境搭建是否正常,以能運(yùn)行第一個helloworld工程為準(zhǔn),詳細(xì)步驟為:

1)repo工具安裝

mkdir~/binPATH=~/bin:$PATH curl  https://storage.googleapis.com/git-repo-downloads/repo > ~/bin/repochmod a+x ~/bin/repo
2)lib依賴庫和編譯工具安裝

#ThebasicbuildpackageonUbuntuisthe build-essentialpackage.Toinstallrun:sudo apt-get updatesudo apt-get install build-essential #AdditionalbasedependenciesforbuildingseL4 projectsonUbuntuincludeinstalling:sudo apt-get install cmake ccache ninja-build cmake-curses-guisudo apt-get install libxml2-utils ncurses-devsudo apt-get install curl git doxygen device-tree-compilersudo apt-get install u-boot-toolssudoapt-getinstallpython3-dev python3-pippython-is-python3sudoapt-getinstallprotobuf-compiler python3-protobuf sudoapt-getinstallqemu-system-arm qemu-system-x86qemu-system-miscsudoapt-getinstallgcc-arm-linux-gnueabi g++-arm-linux-gnueabisudoapt-getinstallgcc-aarch64-linux-gnu g++-aarch64-linux-gnu
3)Python 依賴庫

pip3 install--user setuptoolspip3 install--user sel4-deps# Currently we duplicate  dependencies for python2 and python3 as a python3 upgrade is in processpip install--user setuptoolspip install--user sel4-deps
4) 編譯庫依賴

sudo apt-get install clang gdbsudo apt-get install libssl-dev libclang-dev libcunit1-dev libsqlite3-devsudo apt-get install qemu-kvm
5)證明依賴

sudo apt-get installpython3 python3-pippython3-devgcc-arm-none-eabi build-essentiallibxml2-utilsccachencurses-dev librsvg2-bindevice-tree-compilercmakeninja-build curlzlib1g-devtexlive-fonts-recommendedtexlive-latex-extra texlive-metapost texlive-bibtex-extra mlton-compiler haskell-stack

2.2 下載代碼 下載代碼前安裝python依賴用于編譯教程

pipinstall--useraenumpip install --user pyelftools
下載代碼前配置repo郵箱信息

gitconfig --globaluser.email"you@example.com"gitconfig--globaluser.name "Your Name"
下載代碼(這里使用sel4官方的代碼進(jìn)行練習(xí),從github上下載)?

mkdirsel4-tutorials-manifestcd sel4-tutorials-manifestrepo init -u  https://github.com/seL4/sel4-tutorials-manifestrepo sync
2.3 Hello World應(yīng)用生成 初始化hello-world文件夾?

./init--tuthello-world--solution
hello-world是示例名字,練習(xí)其他示例更換這個名字就可以,命令加 --solution后綴,可以補(bǔ)全代碼??梢钥吹缴闪讼旅娴膆ello-world文件夾,里面有c代碼。

dfbb7376-3df3-11ed-9e49-dac502259ad0.png

2.4 代碼編譯

cdhello-world_buildninja
編譯成功后顯示:

dfe74c4e-3df3-11ed-9e49-dac502259ad0.png

2.5 代碼運(yùn)行

# In build directory, hello-world_build./simulate
成功后顯示:

e00930f2-3df3-11ed-9e49-dac502259ad0.png

運(yùn)行后Ctrl-A, X退出qemu模擬工具。

3. Hello World代碼分析

編譯的時候,我們使用了ninja這個命令,Ninja 是Google的一名程序員推出的注重速度的構(gòu)建工具,一般在Unix/Linux上的程序通過make/makefile來構(gòu)建編譯,而Ninja通過將編譯任務(wù)并行組織,大大提高了構(gòu)建速度。

可見ninja跟makefile同級別的都是構(gòu)建工具,生成編譯器使用的規(guī)則。

在sel4-tutorials-manifest/hello-world_build/build.ninja文件中可以看到

e048cd34-3df3-11ed-9e49-dac502259ad0.png

執(zhí)行ninja命令就會通過這個build.ninja進(jìn)行編譯,會找到hello-world的代碼

dfbb7376-3df3-11ed-9e49-dac502259ad0.png

cmake是makefile之上的一層封裝。

CMakeLists.txt – cmake使用的腳本,將根任務(wù)合并到更廣泛的 seL4 構(gòu)建系統(tǒng)中的文件。

src/main.c - 初始任務(wù)的單個源文件。
hello-world.md - 為教程生成的自述文件。

intmain(intargc,char*argv[]){     printf("Hello, World!
");      printf("Second hello
");    return  0;}
如果修改了應(yīng)用的源碼,重新運(yùn)行重建項目:

Bash# In build directory, hello-world_buildninja
然后再運(yùn)行simulator:

# In build directory, hello-world_build./simulate
4. 學(xué)習(xí)資料

sel4原理熟悉,主要從兩條路進(jìn)行學(xué)習(xí):

一邊是sel4的參考手冊,另一邊就是基于Tutorials教程開始一步一步的做實驗,這樣可以做到理論和實踐結(jié)合。

(turorials中camkes相關(guān)的例子可以先不學(xué)習(xí))

e076385a-3df3-11ed-9e49-dac502259ad0.png

輔助庫介紹:

tutorials工程中,其他輔助庫的介紹,除了sel4微內(nèi)核之外,還需要提供一些庫,才能讓你的應(yīng)用程序運(yùn)行起來。

sel4內(nèi)核:首先是sel4內(nèi)核。單單的一個內(nèi)核運(yùn)行起來,是沒法運(yùn)行一個例如hello world這樣的程序的,因為這個程序需要鏈接其他的庫,比如stdio中的printf,而且該程序和內(nèi)核交互,就需要知道內(nèi)核提供的標(biāo)準(zhǔn)API有哪些。

libsel4:sel4內(nèi)核提供的api都用內(nèi)核源碼工程里面的libsel4這個庫來描述。里面是sel4內(nèi)核支持的標(biāo)準(zhǔn)api。


sel4_libs:當(dāng)一個程序連接了這個libsel4之后,就可以使用sel4內(nèi)核的標(biāo)準(zhǔn)api了,這個和Linux內(nèi)核提供的標(biāo)準(zhǔn)api類似,是和操作系統(tǒng)密切關(guān)聯(lián)的。非posix標(biāo)準(zhǔn)的。另外這個libsel4庫不是很好用,因此在這之上又堆疊了一個sel4_libs庫,這個庫是對sel4標(biāo)準(zhǔn)api的進(jìn)一步功能性的封裝,比如分配一個cap對象,調(diào)用者無需知道更下層的sel4標(biāo)準(zhǔn)api調(diào)用的細(xì)節(jié)。

musllibc:這個是開源的一個libc庫,和sel4是沒有直接關(guān)系的。用到這個工程里面來,主要是提供標(biāo)準(zhǔn)的符合posix標(biāo)準(zhǔn)的api,其他的操作系統(tǒng)也是可以使用的。因此應(yīng)用程序可以直接使用libsel4中的函數(shù),也可以使用sel4_libs中的函數(shù),比較標(biāo)準(zhǔn)的功能就可以使用muscllibc中的功能了。為了打通muslibc和sel4_libs,sel4_libs中提供了一個libsel4muslcsys這樣的一個庫,muslibc中的一些功能通過sys call的方式調(diào)用到libsel4muslcsys這個接口庫中,這個接口庫就會調(diào)用sel4_libs中的相應(yīng)函數(shù)。當(dāng)然muslibc中的有些函數(shù)可能會直接調(diào)用libsel4的函數(shù)接口(目前還沒有看到muslibc中或者libsel4中有對這兩個庫的對接口的實現(xiàn),可能這個猜測不對)

sel4runtime:一般程序里面都有一個main函數(shù),作為該程序的入口位置,但是,這個程序的運(yùn)行并不是從main開始的,在運(yùn)行main之前,其實還做了其他的一些工作,比如堆棧指針的設(shè)置,環(huán)境變量的獲取,其他的一些準(zhǔn)備工作等等。一般編譯器,比如gcc編譯器編譯一個比如hello world這樣的一個代碼的時候,會指定該程序的入口地址是 _start, 就是會找尋源碼,把 _start開始的代碼放在該程序代碼段的最開始位置,hello_world.c源碼中并沒有 _start這個函數(shù)或者標(biāo)號,所以這個標(biāo)號是其他地方的,且是會被hello_world.c鏈接進(jìn)來的源碼,在sel4 tutorial工程里,我們用sel4runtime(里面是源碼)和lshello_world.c一起編譯,鏈接。這個sel4runtime工程里面提供了各個架構(gòu)的 _start入口標(biāo)號,該標(biāo)號緊跟著的是該架構(gòu)的一些匯編語言,處理堆棧等等,之后跳轉(zhuǎn)到一個簡單的c函數(shù)處,該c函數(shù)收集環(huán)境變量,傳入參數(shù)等,并最終調(diào)用main函數(shù)。


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

    關(guān)注

    37

    文章

    6609

    瀏覽量

    123029
  • 微內(nèi)核
    +關(guān)注

    關(guān)注

    0

    文章

    57

    瀏覽量

    13408

原文標(biāo)題:seL4微內(nèi)核入門-代碼下載運(yùn)行及資料

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

收藏 人收藏

    評論

    相關(guān)推薦

    最近寫了一個lcd的驅(qū)動,每次下載運(yùn)行的結(jié)果

    同樣的程序,每次下載運(yùn)行的結(jié)果不一樣,是代碼的問題嗎?
    發(fā)表于 11-09 23:41

    seL4移植到Xilinx Zynq UltraScale + MPSoC,以實現(xiàn)極高的硬件安全性

    seL4是經(jīng)過正式驗證的內(nèi)核,考慮到安全性和性能而構(gòu)建。對于具有嚴(yán)格安全性和/或安全性要求的項目,它是一種非常有吸引力的軟件解決方案。盡管seL4是一個不錯的選擇,但缺點之一是,與其
    發(fā)表于 08-20 19:23

    HarmonyOS學(xué)習(xí)之十:HarmonyOS內(nèi)核技術(shù)

    ,第三代內(nèi)核蓬勃發(fā)展,許許多多內(nèi)核都被開發(fā)出來,主要代表有:seL4、Fiasco.OC、NOVA 等。 本來第一代
    發(fā)表于 11-30 13:55

    RK3399(內(nèi)核入門篇)通過sysfs清楚了解設(shè)備的系統(tǒng)狀況

    RK3399平臺開發(fā)系列講解(內(nèi)核入門篇)1.1、通過sysfs清楚了解設(shè)備的系統(tǒng)狀況 sys目錄
    發(fā)表于 12-16 08:00

    ide界面為什么找不到選擇從Flash上傳至ILM的下載運(yùn)行模式?

    ide界面找不到選擇從Flash 上傳至ILM 的下載運(yùn)行模式 下冊第12章運(yùn)行gpio實驗 ide界面找不到選擇從Flash 上傳至ILM 的下載運(yùn)行模式
    發(fā)表于 08-12 07:28

    AT32 MCU Cortex M4內(nèi)核入門指南

    AT32 MCU Cortex M4內(nèi)核入門指南主要介紹了AT32 M4 內(nèi)核系統(tǒng)架構(gòu),并針對M4 內(nèi)核
    發(fā)表于 10-25 08:08

    基于內(nèi)核入侵的木馬設(shè)計與實現(xiàn)

             通過內(nèi)核入侵是木馬入侵 Linux 系統(tǒng)的一種重要形式,其原理是利用Linux 內(nèi)核提供的機(jī)制來實現(xiàn)木馬的各種功能,主要是通過內(nèi)核
    發(fā)表于 09-05 08:32 ?9次下載

    OK Labs推出可供下載的移動安全內(nèi)核OKL4 Verified

    Open Kernel Labs (OK Labs)日前推出了可供下載的OKL4 Verified(項目名稱為seL4
    發(fā)表于 01-28 08:47 ?1077次閱讀

    linux內(nèi)核入門教材之linux內(nèi)核設(shè)計與實現(xiàn)第二版中文版免費(fèi)下載

    此書是當(dāng)今首屈一指的linux內(nèi)核入門最佳圖書。作者是為2.6內(nèi)核加入了搶占的人,對調(diào)度部分非常精通,而調(diào)度是整個系統(tǒng)的核心,因此本書是很權(quán)威的。這本書講解淺顯易懂,全書沒有列舉一條匯編語句,但是
    發(fā)表于 10-15 18:20 ?0次下載
    linux<b class='flag-5'>內(nèi)核入門</b>教材之linux<b class='flag-5'>內(nèi)核</b>設(shè)計與實現(xiàn)第二版中文版免費(fèi)<b class='flag-5'>下載</b>

    SEL-SPC5 SEL-SPC5智能選擇32位Power架構(gòu)產(chǎn)品

    電子發(fā)燒友網(wǎng)為你提供(ti)SEL-SPC5相關(guān)產(chǎn)品參數(shù)、數(shù)據(jù)手冊,更有SEL-SPC5的引腳圖、接線圖、封裝手冊、中文資料、英文資料,SEL
    發(fā)表于 05-20 12:05

    鑒釋宣布加入RISC-V基金會、Linux基金會、seL4基金會與ioXt聯(lián)盟,旨在實現(xiàn)靜態(tài)代碼分析服務(wù)的全方位賦能

    靜態(tài)代碼工具開發(fā)商鑒釋科技(下文簡稱:鑒釋)宣布其加入RISC-V基金會、Linux基金會、seL4基金會,以及ioXt聯(lián)盟四大國際非盈利組織。
    的頭像 發(fā)表于 07-27 14:29 ?8752次閱讀

    seL4內(nèi)核參考?冊中?翻譯版

    內(nèi)核操作系統(tǒng)SEL4的簡介、功能描述
    發(fā)表于 01-21 09:33 ?0次下載

    seL4操作系統(tǒng)內(nèi)核

    seL4.zip
    發(fā)表于 04-18 10:13 ?6次下載
    <b class='flag-5'>seL4</b>操作系統(tǒng)<b class='flag-5'>內(nèi)核</b>

    谷歌在官博上又發(fā)布了一款全新的操作系統(tǒng)——KataOS

    目前的GitHub版本,已經(jīng)涵蓋了大部分KataOS的核心部分,包括用于Rust的框架(如sel4-sys crate,用于讓seL4系統(tǒng)調(diào)用API),一個用Rust編寫的備用根服務(wù)器(用于全系統(tǒng)的動態(tài)內(nèi)存管理),以及對seL4
    的頭像 發(fā)表于 10-28 11:54 ?895次閱讀

    什么叫變壓器的空載運(yùn)行、負(fù)載運(yùn)行及超負(fù)荷運(yùn)行

    什么叫變壓器的空載運(yùn)行、負(fù)載運(yùn)行及超負(fù)荷運(yùn)行? 變壓器的空載運(yùn)行、負(fù)載運(yùn)行及超負(fù)荷運(yùn)行是變壓器工
    的頭像 發(fā)表于 01-26 16:59 ?4073次閱讀