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

鴻蒙內核源碼分析(匯編匯總篇) | 鴻蒙所有的匯編代碼都在這里

開發
文章由鴻蒙社區產出,想要了解更多內容請前往:51CTO和華為官方戰略合作共建的鴻蒙技術社區https://harmonyos.51cto.com

[[387002]]

想了解更多內容,請訪問:

51CTO和華為官方合作共建的鴻蒙技術社區

https://harmonyos.51cto.com

匯編其實很可愛

● 絕大部分IT從業人員終生不用觸碰到的匯編,它聽著像上古時代遙遠的呼喚,總覺得遠卻又能聽到聲,匯編再往下就真的是01110011了,匯編指令基本是一一對應了機器指令.

● 所謂內核是對硬件的驅動,對驅動之后資源的良序管理,這里說的資源是CPU(單核/多核),內存,磁盤,i/o設備.層層封裝,步步遮蔽,到了應用層,不知有漢,無論魏晉才好.好是好,但有句話,其實哪有什么歲月靜好,只是有人替你負重前行.難道你真的不想知道別人是怎么替你負重前行的?

● 越高級的語言是越接近人思維模式的,越低級的語言就是越貼近邏輯與非門的高低電平的起伏.匯編是貼著硬件飛行的,要研究內核就繞不過匯編,覺得神秘是來源于不了解,恐懼是來自于沒接近.

● 其實當你深入分析內核源碼之后就會發現,匯編其實很可愛,很容易,比c/c++/java容易太多了,真的是很傻很單純.

鴻蒙內核源碼分析系列篇至少已經有五篇涉及到了匯編,請自行翻看,但還是遠遠不夠,要寫十五篇,徹底摸透,現在才剛剛開始,本篇先整理鴻蒙內核所有匯編文件和大概說明文件的作用,后續一塊一塊來剝,不把這些匯編剝個精光不罷休.

匯編目錄

鴻蒙所有匯編文件如下: 直接點擊可以查看注解源碼,有些站點會把鏈接去除,沒辦法,可直接去各大站點搜"鴻蒙內核源碼分析",找到源碼注解.

● \arch\arm\arm\src

◆ startup 啟動相關

◆ reset_vector_mp.S 多核CPU下啟動代碼,大文件

◆ reset_vector_up.S 單核CPU下啟動代碼,大文件

◆ armv7a

◆ cache.S 緩存相關的兩個函數

◆ los_dispatch.S 異常分發處理,大文件.

◆ los_hw_exc.S 硬件異常相關,大文件.

◆ los_hw_runstop.S OsSRSaveRegister 和 OsSRRestoreRegister 匯編實現

◆ jmp.S 兩個簡單的跳轉函數

◆ hw_user_get.S 拷貝用戶空間數據到內核空間

◆ hw_user_put.S 拷貝內核空間數據到用戶空間

hw_user_get.S

將用戶空間數據src 拷貝到內核空間 dst

  1. // errno_t _arm_get_user(void *dst, const void *src, size_t dstTypeLen, size_t srcTypeLen) 
  2. FUNCTION(_arm_get_user) 
  3.     stmdb   sp!, {r0, r1, r2, r3, lr} @四個參數入棧,保存LR 
  4.     cmp     r2, #0  @r2 和 0比較 
  5.     beq     .Lget_user_return @相等 跳到Lget_user_return 直接返回 
  6.     cmp     r2, r3  @r2 和 r3比較 
  7.     bne     .Lget_user_err  @不等,說明函數要返回錯誤 
  8.     cmp     r2, #1  @r2 和 1比較 
  9.     bhi     .Lget_user_half @if(dstTypeLen>1) 跳轉到Lget_user_half 
  10. .Lget_user_byte:         @按字節拷貝數據 
  11. 0:  ldrbt   r3, [r1], #0 @r3=*r1 
  12. 1:  strb    r3, [r0], #0 @*r0=r3 
  13.     b       .Lget_user_return  
  14. .Lget_user_half: 
  15.     cmp     r2, #2  @r2 和 2比較 
  16.     bhi     .Lget_user_word  @if(dstTypeLen>2) Lget_user_word 
  17. 2:  ldrht   r3, [r1], #0    @完成最后一個字節的拷貝 
  18. 3:  strh    r3, [r0], #0    @完成最后一個字節的拷貝 
  19.     b       .Lget_user_return 
  20. .Lget_user_word: 
  21.     cmp     r2, #4 @r2 和 4比較 
  22.     bhi     .Lget_user_err @if(dstTypeLen>4) 跳轉到Lget_user_err 
  23. 4:  ldrt   r3, [r1], #0 
  24. 5:  str    r3, [r0], #0 
  25. .Lget_user_return:  @返回錨點 
  26.     ldmia   sp!, {r0, r1, r2, r3, lr}   @保存的內容出棧,恢復各寄存器值 
  27.     mov     r0, 0   @r0保存返回值為0 
  28.     bx      lr  @跳回調用函數繼續執行,_arm_get_user到此結束! 
  29. .Lget_user_err: 
  30.     ldmia   sp!, {r0, r1, r2, r3, lr}   @保存的內容出棧,恢復各寄存器值 
  31.     mov     r0, #-14    @r0保存返回值為-14     
  32.     bx      lr  @跳回調用函數繼續執行,_arm_get_user到此結束! 
  33.  
  34. .pushsection __exc_table, "a" 
  35.     .long   0c,  .Lget_user_err 
  36.     .long   1c,  .Lget_user_err 
  37.     .long   2c,  .Lget_user_err 
  38.     .long   3c,  .Lget_user_err 
  39.     .long   4c,  .Lget_user_err 
  40.     .long   5c,  .Lget_user_err 
  41. .popsection 

hw_user_put.S

將內核空間數據src 拷貝到用戶空間 dst

  1. // errno_t _arm_put_user(void *dst, const void *src, size_t dstTypeLen, size_t srcTypeLen) 
  2. FUNCTION(_arm_put_user) 
  3.     stmdb   sp!, {r0, r1, r2, r3, lr} 
  4.     cmp     r2, #0 
  5.     beq     .Lget_user_return 
  6.     cmp     r2, r3 
  7.     bne     .Lget_user_err 
  8.     cmp     r2, #1 
  9.     bhi     .Lget_user_half 
  10. .Lget_user_byte: 
  11. 0:  ldrb    r3, [r1], #0 
  12. 1:  strbt   r3, [r0], #0 
  13.     b       .Lget_user_return 
  14. .Lget_user_half: 
  15.     cmp     r2, #2 
  16.     bhi     .Lget_user_word 
  17. 2:  ldrh    r3, [r1], #0 
  18. 3:  strht   r3, [r0], #0 
  19.     b       .Lget_user_return 
  20. .Lget_user_word: 
  21.     cmp     r2, #4 
  22.     bhi     .Lget_user_err 
  23. 4:  ldr    r3, [r1], #0 
  24. 5:  strt   r3, [r0], #0 
  25. .Lget_user_return: 
  26.     ldmia   sp!, {r0, r1, r2, r3, lr} 
  27.     mov     r0, 0 
  28.     bx      lr 
  29. .Lget_user_err: 
  30.     ldmia   sp!, {r0, r1, r2, r3, lr} 
  31.     mov     r0, #-14 
  32.     bx      lr 
  33.  
  34. .pushsection __exc_table, "a" 
  35.     .long   0c,  .Lget_user_err 
  36.     .long   1c,  .Lget_user_err 
  37.     .long   2c,  .Lget_user_err 
  38.     .long   3c,  .Lget_user_err 
  39.     .long   4c,  .Lget_user_err 
  40.     .long   5c,  .Lget_user_err 
  41. .popsection 

解讀

● 如果仔細對比一下發現這兩個函數的匯編代碼是一模一樣的,沒有區別.這就跟讓左右各一個美女陪你和左右各一個丑姑娘陪你的道理是一樣,都是1+1=2,算式加法的邏輯是一樣的,不會變.但給你的感覺能一樣嘛,美丑的含義是上層賦予的,到了這里美丑不重要,都變成了 r0,r1,r2,r3了, 跟咱東哥一樣臉盲分不清啦

● 用戶空間和內核空間的數據為什么需要拷貝? 這是個經典問題,看了網上的一些回答,沒毛病:

內核不能信任任何用戶空間的指針。必須對用戶空間的指針指向的數據進行驗證。如果只做驗證不做拷貝的話,那么在隨后的運行中要隨時受到其它進/線程可能修改用戶空間數據的威脅。所以必須做拷貝。

在內存系列篇中已經反復的說過,每個用戶進程都有自己獨立的用戶空間,但這個用戶空間是通過MMU映射出來的,是表面上繁花似錦,背后都共用著真正的物理內存,所以在高頻率的任務切換過程中,原有的用戶空間地址內容很容易被覆蓋掉.舉個例子說明下:

◊ 用戶A客戶有個美女放在萬聰酒店21號房說要獻給內核大佬,如果內核不直接把美女接回家,而僅僅是做個記錄,寫著美女在萬聰酒店21號房,內核立馬跑去過還好不會錯,但如果被其他事給耽擱了呢?

◊ 耽擱的這回功夫,調度算法把萬聰酒店21號房給了B客戶使用,當然B客戶用之前酒店管理人員會把美女置換個地方(以至于A客戶再回到酒店時,原來的東西該怎樣還咋樣). 等21號房空出來了,B肯定不知道原來的房間是A在用,而且里面還有個美女,更不可能曉得美女獻給內核大佬了.因為B的業務需要,很可能往21號房整了個東施進來.

◊ 此時如果內核大佬事忙完了,想起A客戶獻美女的事了,是時候了.因為只記錄了地址,直接去萬聰酒店21號房抓人,那抓出來可是東施呀.這可不把事給搞砸啦.

◊ 所以需要拷貝,直接把美女接回家找個地方關起來先.

reset_vector_mp.S 和 reset_vector_up.S

鴻蒙開機代碼根據 CPU多核還是單核分成了兩個獨立文件處理. mp就是多處理器(multiprocessing)的意思: 多CPU核的操作系統3種處理模式(SMP+AMP+BMP) 鴻蒙實現的是 SMP 的方式

● 非對稱多處理(Asymmetric multiprocessing,AMP)每個CPU內核 運行一個獨立的操作系統或同一操作系統的獨立實例(instantiation)。

● 對稱多處理(Symmetric multiprocessing,SMP)一個操作系統的實例 可以同時管理所有CPU內核,且應用并不綁定某一個內核。

● 混合多處理(Bound multiprocessing,BMP)一個操作系統的實例可以 同時管理所有CPU內核,但每個應用被鎖定于某個指定的核心。

up(unit processing )的意思,單個CPU,雖然沒mp的復雜,但文件也很大 500行匯編,一小節講不完,需要單獨的一篇專講 reset_vector

這里只列出up情況下的開機代碼

  1. reset_vector: @鴻蒙單核cpu 開機代碼 
  2.     /* do some early cpu setup: i/d cache disable, mmu disabled */ 
  3.     mrc     p15, 0, r0, c1, c0, 0 
  4.     bic     r0, #(1<<12) 
  5.     bic     r0, #(1<<2 | 1<<0) 
  6.     mcr     p15, 0, r0, c1, c0, 0 
  7.  
  8.     /* r11: delta of physical address and virtual address */ 
  9.     adr     r11, pa_va_offset 
  10.     ldr     r0, [r11] 
  11.     sub     r11, r11, r0 
  12.  
  13.     /* if we need to relocate to proper location or not */ 
  14.     adr     r4, __exception_handlers            /* r4: base of load address */ 
  15.     ldr     r5, =SYS_MEM_BASE                   /* r5: base of physical address */ 
  16.     subs    r12, r4, r5                         /* r12: delta of load address and physical address */ 
  17.     beq     reloc_img_to_bottom_done            /* if we load image at the bottom of physical address */ 
  18.  
  19.     /* we need to relocate image at the bottom of physical address */ 
  20.     ldr     r7, =__exception_handlers           /* r7: base of linked address (or vm address) */ 
  21.     ldr     r6, =__bss_start                    /* r6: end of linked address (or vm address) */ 
  22.     sub     r6, r7                              /* r6: delta of linked address (or vm address) */ 
  23.     add     r6, r4                              /* r6: end of load address */ 

los_dispatch.S 和 los_hw_exc.S

異常模式處理入口和統一分發現實,之前也有提到過,很復雜,1000多行,后續單獨細說實現過程.

jmp.S

兩個簡單的函數longjmp setjmp 的實現,加注解部分請前往 鴻蒙內核源碼注解分析 查看

  1. FUNCTION(longjmp) 
  2.         ldmfd   r0,{r4-r12} 
  3.         add     r0,#(4 * 9) 
  4.         ldr     r13,[r0] 
  5.         add     r0,#4 
  6.         ldr     r14,[r0] 
  7.         cmp     r1,#0 
  8.         moveq   r1,#1 
  9.         mov     r0,r1 
  10.         mov     pc,lr 
  11.  
  12. FUNCTION(setjmp) 
  13.         stmea   r0,{r4-r12} 
  14.         add     r0,#(4 * 9) 
  15.         str     r13,[r0] 
  16.         add     r0,#4 
  17.         str     r14,[r0] 
  18.         mov     r0,#0 
  19.         mov     pc,lr 

los_hw_runstop.S

  1. .global  OsSRSaveRegister 
  2.  .global  OsSRRestoreRegister 

兩個函數的匯編現實,有點復雜,后續單獨說明.

cache.S

這是緩存部分的兩個函數實現,此處沒有加注解,試著看明白這兩個函數的實現.加注解部分請前往 鴻蒙內核源碼注解分析 查看

  1. .macro  DCACHE_LINE_SIZE, reg, tmp 
  2.     mrc     p15, 0, \tmp, c0, c0, 1 
  3.     lsr     \tmp, \tmp, #16 
  4.     and     \tmp, \tmp, #0xf 
  5.     mov     \reg, #4 
  6.     mov     \reg, \reg, lsl \tmp 
  7. .endm 
  8.  
  9.  
  10. FUNCTION(arm_inv_cache_range) 
  11.     push    {r2, r3} 
  12.     DCACHE_LINE_SIZE r2, r3 
  13.     sub    r3, r2, #1 
  14.     tst    r0, r3 
  15.     bic    r0, r0, r3 
  16.  
  17.     mcrne  p15, 0, r0, c7, c14, 1 
  18.  
  19.     tst    r1, r3 
  20.     bic    r1, r1, r3 
  21.     mcrne  p15, 0, r1, c7, c14, 1 
  22. 1: 
  23.     mcr    p15, 0,  r0, c7, c6, 1 
  24.     add    r0,  r0, r2 
  25.     cmp    r0,  r1 
  26.     blo    1b 
  27.     dsb 
  28.     pop    {r2, r3} 
  29.     mov    pc, lr 
  30.  
  31. FUNCTION(arm_clean_cache_range) 
  32.     push   {r2, r3} 
  33.     DCACHE_LINE_SIZE r2, r3 
  34.     sub    r3, r2, #1 
  35.     bic    r0, r0, r3 
  36.  
  37. 1: 
  38.     mcr    p15, 0,  r0, c7, c10, 1 
  39.     add    r0,  r0, r2 
  40.     cmp    r0,  r1 
  41.     blo    1b 
  42.     dsb 
  43.     pop    {r2, r3} 
  44.     mov    pc, lr 

參與貢獻

● 訪問注解倉庫地址

● Fork 本倉庫 >> 新建 Feat_xxx 分支 >> 提交代碼注解 >> 新建 Pull Request

● 新建 Issue

想了解更多內容,請訪問:

51CTO和華為官方合作共建的鴻蒙技術社區

https://harmonyos.51cto.com

 

責任編輯:jianghua 來源: 鴻蒙社區
相關推薦

2017-09-19 14:55:27

Android字體修改

2023-09-11 08:51:23

LinkedList雙向鏈表線程

2016-05-20 11:26:54

客戶端優化 直播推流

2016-05-20 11:14:55

內容緩存 傳輸策略優

2016-05-16 12:08:08

UCloud 直播云

2016-05-16 14:00:39

UCloud 直播云

2019-11-04 09:07:48

DevOps互聯網IT

2021-10-06 16:21:32

類型對象Typescript

2023-12-11 21:59:01

時序分析深度學習自回歸模型

2017-08-28 16:40:07

Region切分觸發策略

2017-12-08 10:42:49

HBase切分細節

2025-05-16 09:34:10

2021-03-24 17:18:41

鴻蒙HarmonyOS應用開發

2018-03-19 14:43:28

2017-10-24 14:57:58

AI人工智能機器學習

2021-07-01 09:00:00

安全數字化轉型滲透

2018-04-26 16:15:02

數據庫MySQLMySQL 8.0

2024-07-02 11:16:21

2021-02-23 09:28:48

大數據數據分析

2016-05-12 14:54:39

UCloud
點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 麻豆精品一区二区三区在线观看 | 久久成人免费视频 | 久久久久久国产精品 | 久国久产久精永久网页 | 91精品国产乱码久久久久久久久 | 色爱区综合 | 欧美一区二区三区精品免费 | 色在线看 | 成人二区 | 免费h视频 | 亚洲精品国产电影 | 欧美一级淫片007 | 一级久久久久久 | 日韩中文一区二区三区 | 亚洲国产精品91 | 麻豆va| 日韩高清在线观看 | 一级毛片在线播放 | 一级毛片免费看 | 久久69精品久久久久久久电影好 | 黄色欧美 | 综合久久亚洲 | 小h片免费观看久久久久 | 亚洲国产视频一区二区 | 亚洲欧美另类在线观看 | 日日夜夜精品视频 | 国产精品久久国产愉拍 | 亚欧精品一区 | 99亚洲精品| 欧美视频三级 | 欧美日韩大陆 | 亚洲免费在线观看 | 91精品国产美女在线观看 | 一区二区三区国产 | 成人片免费看 | 91电影| 久久这里只有精品首页 | 国产日韩免费观看 | 日韩福利在线观看 | 精品国产一区二区国模嫣然 | 麻豆91精品91久久久 |