成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

詳解Linux內核在arm上的啟動過程

系統 Linux
本文詳細介紹了Linux內核在arm上的啟動過程,一起來看看吧。

 [[426411]]

Linux內核加載過程

通常,Linux內核都是經過gzip加載過之后的映像文件。

  •  bootloader復制壓縮內核到內存空間。
  •  內核自解壓。
  •  運行內核。

編譯完成的Linux內核存放在哪里?

  •  ./vmlinux     elf格式未壓縮內核。
  •  arch/arm/boot/compressed/vmlinux    壓縮以后的elf格式內核。
  •  arch/arm/boot/zImage    壓縮內核。

壓縮內核(zImage)的入口

  •  /arch/arm/boot/compressed/vmlinux.lds    該文件為編譯器指定link順序。
  •  ENTRY(_start)    壓縮內核從.start段開始執行。
  •  在/arch/arm/boot/compressed/head.S中執行以下愛操作:

        (1)檢測系統空間。

        (2)初始化C代碼空間。

        (3)跳轉到C代碼decompress_kernel,

                 arch/arm/boot/compressed/misc.c中。

解壓之前的串口輸出

  •  include/asm-arm/arch-s3c2410/uncompress.h    中定義了puts作為串口輸出函數。
  •  解壓結束之后,程序跳轉到r5:解壓之后內核的起始地址。

開始真正的Linux內核

1、入口在arch/arm/kernel/head-armv.S

2、查找處理器類型

  •  __lookup_processor_type
  •  __lookup_architecture_type

3、初始化頁表:__creat_page_tables

4、初始化C代碼空間

5、跳轉到C代碼中,start_kernel

ARM的MMU單元

MMU:內存管理單元

作用:

  •  虛擬地址到物理地址的映射
  •  存儲器訪問權限
  •  控制Cache

通過MMU的訪存

  •  MMU會先查找TLB中的虛擬地址表
  •  如果TLB中沒有虛擬地址的入口,硬件從主存儲器中的轉換表中獲取轉換與訪問權限。

ARM的MMU訪存原理

ARM的MMU頁表格式

MMU支持基于節或者頁的存儲器訪問。

  •  節:1MB的存儲器塊
  •  大頁:64KB的存儲器塊
  •  小頁:4KB的存儲器塊
  •  微頁:1KB的存儲器塊

頁表的級別

存在主存儲器內的轉換頁表有兩個級別:

  •  第一級表:存儲節轉換表與指向第二級表的指針
  •  第二級表:

        (1)存儲大頁和小頁的轉換表。

        (2)存儲微頁的轉換表。

一級頁表的地址

第一級表占用空間16KB,必須16KB對齊

第一級描述符

一級表每個入口描述了它所關聯的1MB虛擬地址是如何映射的。

節描述符

  •  Bits[1:0] 描述符類型(10b 表示節描述符)
  •  Bits[3:2] 高速緩存(cache)和緩沖位(buffer)
  •  Bits[4] 由具體實現定義
  •  Bits[8:5] 控制的節的16 種域之一
  •  Bits[9] 現在沒有使用,應該為零
  •  Bits[11:10] 訪問控制(AP)
  •  Bits[19:12] 現在沒有使用,應該為零
  •  Bits[31:20] 節基址,形成物理地址的高12 位

節的轉換過程

臨時內核頁表的創建 __create_page_tables 

  1. __create_page_tables:  
  2. pgtbl r4 @ page table address 0x30008000-0x4000  
  3. mov r0, r4 @r0=0x30004000  
  4. mov r3, #0  
  5. add r2, r0, #0x4000  
  6. 1: str r3, [r0], #4  
  7. str r3, [r0], #4  
  8. str r3, [r0], #4  
  9. str r3, [r0], #4  
  10. teq r0, r2  
  11. bne 1b 

把一級頁表0x30004000-0xa0080000清空 

  1. krnladr r2, r4 @ start of kernel 

r4=0xa0004000,r2 = 內核起始地址所在1MB對齊空間,0x30000000 

  1. add r3, r8, r2 @ flags + kernel base 

r8 為從處理器信息中得到的MMU 頁表標志,r8=0xc0e, r3=0x30000c0e 

  1. str r3, [r4, r2, lsr #18]@ identity mapping 

地址:0x300068000, value:0x30000c0e 

  1. add r0, r4, #(TEXTADDR & 0xff000000) >> 18   
  2. @ start of kernel  
  3. bic r2, r3, #0x00f00000  
  4. str r2, [r0] @ PAGE_OFFSET + 0MB  
  5. add r0, r0, #(TEXTADDR & 0x00f00000) >> 18  
  6. str r3, [r0], #4 @ KERNEL + 0MB  
  7. ...... 

映射表內容

映射結果

進入C代碼

init/main.c中的start_kernel函數,進入到了Linux內核代碼中。

  •  printk函數
  •  重新初始化頁表
  •  初始化中斷,trap_init
  •  設置系統定時器、控制臺…
  •  創建內核進程init 

 

責任編輯:龐桂玉 來源: 良許Linux
相關推薦

2011-06-28 13:27:13

ARM Linux

2011-09-05 17:35:18

MTK啟動過程RTOS

2009-12-03 10:00:46

Linux系統啟動

2018-03-13 13:00:03

Linux運維啟動分析

2009-08-11 09:03:45

Windows 7系統啟動

2018-10-18 14:06:15

Linux系統過程

2011-07-28 10:34:38

Cocoa 程序 啟動

2014-06-23 10:31:09

Android啟動過程

2025-06-18 09:01:27

Linux系統啟動系統

2021-07-02 06:34:53

Go語言sysmon

2010-07-05 17:38:39

IIS 7.0 FTP

2011-06-29 10:18:20

LINUX QT ARM

2019-05-10 08:00:00

UKUUUbuntuLinux

2012-02-20 14:47:08

JavaPlay

2012-08-16 09:07:57

Erlang

2009-06-11 10:57:11

netbeans li安裝

2024-09-11 09:25:03

Tomcat組件PREP

2010-05-06 14:05:15

Unix系統

2009-10-16 09:45:41

Linux內核操作系統

2020-03-19 08:59:15

SpringMVC啟動過程
點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 国产免费黄网 | 一区二区三区久久久 | 国产成人精品久久二区二区 | 国产乱码精品一区二区三区中文 | 成人免费在线小视频 | 亚洲aⅴ| 国产精品不卡视频 | 国产亚洲成av人在线观看导航 | 亚洲高清在线 | 国产精品国产三级国产aⅴ无密码 | 亚洲综合二区 | 成人av一区 | 亚洲精品乱码久久久久v最新版 | 欧美精品v | 国产高清在线精品一区二区三区 | 亚洲日本欧美日韩高观看 | 久久精品国产久精国产 | 日本天堂一区二区 | 国产视频一二三区 | 亚洲欧美日韩精品久久亚洲区 | 欧美一级黑人aaaaaaa做受 | 国产成人99久久亚洲综合精品 | 色爱区综合 | 国产成人精品一区二区三区四区 | 久久国产精品一区二区三区 | 蜜月aⅴ免费一区二区三区 99re在线视频 | 欧美成人精品 | 伊人超碰在线 | 久久久青草 | 在线欧美视频 | 91成人午夜性a一级毛片 | 欧美日一区 | 日韩不卡一区二区 | 久久网站免费视频 | 九九免费 | 日韩一级电影免费观看 | 欧美日韩专区 | 欧美福利| 精品国产一区二区三区久久久久久 | 亚洲高清在线 | 一级毛片免费 |