一步步编写操作系统 48 二进制程序的加载方式
接上節,程序頭可以自定義,只要我們按照自己定義的格式去解析就行。也許我光這么一說,很多同學還是不能徹底明白如何自定義文件頭,因為大多數同學都是用高級語言來寫程序,即使用了偏底層的c語言,不同平臺的c編譯器也會根據系統平臺自動添加文件頭,不給咱們親手體驗自定義程序頭的機會。匯編語言非常 靈活,所以用它來構建任意文件格式則是非常方便的。書看到這里,我估計您已經發現我是個非常體貼的人,哈哈,所以給大家呈上以下代碼來演示自定義文件頭,請見以下的匯編程序代碼:
[work@localhost book]$ cat -n header.S1 header:2 program_length dd program_end-program_start3 start_addr dd program_start4 ;;;;;;; 以上是文件頭,以下是文件體 ;;;;;;;5 body:6 program_start:7 mov ax, 0x12348 jmp $9 program_end:10 [work@localhost book]$以上測試代碼header.S,經編譯后生成的文件是header.bin,編譯命令是nams –o header.bin header.S,所以header.bin依然是純二進制文件。但此純二進制文件的程序入口并不是文件開頭,這和咱們的loader.bin很像,mbr是跳到loader.bin的中間某部分去執行。假設header.S是被調用的程序,調用方知道header.S的前8字節是程序頭,在這8字節中,前4字節用來標明程序尺寸大小,后4字節用來指明程序的入口地址,也就是該程序的第一條指令地址。從8字節后到文件結束為文件體。在調用方程序已經了解此文件格式后,它可以這樣做:
您看,被調用方header.bin被設計成這樣文件格式,調用方就可以自由處理啦。為了驗證文件格式,大家看下header.bin生成的二進制文件真實內容,前8字節用了兩個下劃線分別區分了兩個程序頭屬性,即program_length是0x00000005,start_addr是0x00000008。順序是反著的,小端字節序。B83412是mov ax,0x1234指令,EBFE則對應的是jmp $。
當然這僅僅是用來演示,目的是起到拋磚引玉的作用,說了這些是為了引出后面咱們要介紹的文件格式。
自己設計的文件頭自己當然認識,但這畢竟不通用,我們需要選擇一種流行的文件格式,咱們是在linux下用c語言編程,其編譯器gcc生成的是elf文件格式,咱們在下一節展開elf可執行文件格式的內容。
本內容摘自《操作系統真象還原》
總結
以上是生活随笔為你收集整理的一步步编写操作系统 48 二进制程序的加载方式的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 警惕!八成互联网电视系统存非法采集用户数
- 下一篇: QQ影音官网下架!视频播放器还有前途吗