久久久精品视频在线_免费在线a视频_在线看的黄色网址_懂色av粉嫩av浪潮av_艳妇乳肉豪妇荡乳av_国产午夜大地久久_国产在线观看免费播放_天堂视频免费看_久久精品女同亚洲女同13_各处沟厕大尺度偷拍女厕嘘嘘

當前位置: 首頁 >綜合 > 正文

世界實時:Linux內核加載ELF文件源碼分析,你學會了嗎?

2023-05-08 08:10:28 來源:FreeBuf.COM
一、源碼版本

1)版本:V6.3-rc7,x862)elf文件加載源碼:fs/binfmt_elf.c

二、Linux可執行文件注冊

Linux支持多種不同格式的可執行程序,這些可執行 程序的加載方式由linux\binfmts.h文件中的linux_binfmt結構體進行定義:


(資料圖片僅供參考)

struct linux_binfmt { struct list_head lh; struct module *module; int (*load_binary)(struct linux_binprm *); int (*load_shlib)(struct file *);#ifdef CONFIG_COREDUMP int (*core_dump)(struct coredump_params *cprm); unsigned long min_coredump; /* minimal dump size */#endif} __randomize_layout;

結構體定義了可執行程序的3中不同的加載模式:

加載模式

備注

load_binary

讀取可執行文件內容并加載當前進程建立新的執行環境

load_shlib

動態加載共享庫到已有進程

core_dump

存放當前進程的執行上下文到core文件中

每一種系統支持的可執行文件都對應一個linux_binfmt對象,統一注冊在一個鏈表中,通過register_binfmt和unregister_binfmt函數編輯鏈表。在執行可執行程序時,內核通過list_for_each_enrty遍歷鏈表中注冊的linux_binfmt對象,使用正確的加載方式進行加載。elf文件的linux_binfmt對象結構如下,該結構體定義了elf文件由load_elf_binary函數加載:

static struct linux_binfmt elf_format = { .module = THIS_MODULE, .load_binary = load_elf_binary, .load_shlib = load_elf_library,#ifdef CONFIG_COREDUMP .core_dump = elf_core_dump, .min_coredump = ELF_EXEC_PAGESIZE,#endif};三、load_elf_binary函數分析1、文件格式校驗

struct elfhdr *elf_ex = (struct elfhdr *)bprm->buf; retval = -ENOEXEC;/* First of all, some simple consistency checks */if (memcmp(elf_ex->e_ident, ELFMAG, SELFMAG) != 0) goto out; if (elf_ex->e_type != ET_EXEC && elf_ex->e_type != ET_DYN) goto out; if (!elf_check_arch(elf_ex)) goto out; if (elf_check_fdpic(elf_ex)) goto out; if (!bprm->file->f_op->mmap) goto out;

程序首先讀取了e_ident中的魔數并進行了校驗,elf_ident是ELF文件最頭部的一個長度為16字節的數組,不區分架構和系統位數。e_ident起始的4個字節固定為\0x7fELF,通過校驗該位可以確定是否為elf文件。然后識別文件是否為可執行文件或動態鏈接文件,ELF文件當前主要有4種格式,分別為可重定位文件(ET_REL)、可執行文件(ET_EXEC)、共享目標文件(ET_DYN)和core文件(ET_CORE)。load_elf_binary函數只負責解析exec和dyn文件。最后還解析了文件依賴的系統架構等必要項。

2、讀取程序頭

static struct elf_phdr *load_elf_phdrs(const struct elfhdr *elf_ex, struct file *elf_file){ struct elf_phdr *elf_phdata = NULL; int retval = -1; unsigned int size; /* * If the size of this structure has changed, then punt, since * we will be doing the wrong thing. */ if (elf_ex->e_phentsize != sizeof(struct elf_phdr)) goto out; /* Sanity check the number of program headers... */ /* ...and their total size. */ size = sizeof(struct elf_phdr) * elf_ex->e_phnum; if (size == 0 || size > 65536 || size > ELF_MIN_ALIGN) goto out; elf_phdata = kmalloc(size, GFP_KERNEL); if (!elf_phdata) goto out; /* Read in the program headers */ retval = elf_read(elf_file, elf_phdata, size, elf_ex->e_phoff); out: if (retval) { kfree(elf_phdata); elf_phdata = NULL; } return elf_phdata;}

程序頭是描述與程序執行直接相關的目標文件結構信息,用于在文件中定位各個段的映像,同時包含其他一些用來為程序創建進程映像所必須的信息。

3、讀取解釋器段

elf_ppnt = elf_phdata; for (i = 0; i < elf_ex->e_phnum; i++, elf_ppnt++) { char *elf_interpreter; if (elf_ppnt->p_type == PT_GNU_PROPERTY) { elf_property_phdata = elf_ppnt; continue; } if (elf_ppnt->p_type != PT_INTERP) continue; /* * This is the program interpreter used for shared libraries - * for now assume that this is an a.out format binary. */ retval = -ENOEXEC; if (elf_ppnt->p_filesz > PATH_MAX || elf_ppnt->p_filesz < 2) goto out_free_ph; retval = -ENOMEM; elf_interpreter = kmalloc(elf_ppnt->p_filesz, GFP_KERNEL); if (!elf_interpreter) goto out_free_ph; retval = elf_read(bprm->file, elf_interpreter, elf_ppnt->p_filesz, elf_ppnt->p_offset); if (retval < 0) goto out_free_interp; /* make sure path is NULL terminated */ retval = -ENOEXEC; if (elf_interpreter[elf_ppnt->p_filesz - 1] != "\0") goto out_free_interp; interpreter = open_exec(elf_interpreter); kfree(elf_interpreter); retval = PTR_ERR(interpreter); if (IS_ERR(interpreter)) goto out_free_ph; /* * If the binary is not readable then enforce mm->dumpable = 0 * regardless of the interpreter"s permissions. */ would_dump(bprm, interpreter); interp_elf_ex = kmalloc(sizeof(*interp_elf_ex), GFP_KERNEL); if (!interp_elf_ex) { retval = -ENOMEM; goto out_free_file; } /* Get the exec headers */ retval = elf_read(interpreter, interp_elf_ex, sizeof(*interp_elf_ex), 0); if (retval < 0) goto out_free_dentry; break; out_free_interp: kfree(elf_interpreter); goto out_free_ph; }

如果程序需要動態鏈接,則需要加載解釋器段(PT_INTERP),程序遍歷所有的程序頭,識別到解釋器段后,讀取該段的內容。解釋器段實際上是標明解釋器程序文件路徑的字符串,內核根據字符串指向的文件,使用open_exec函數打開解釋器。

4、棧可執行屬性及其他定制信息獲取

elf_ppnt = elf_phdata; for (i = 0; i < elf_ex->e_phnum; i++, elf_ppnt++) switch (elf_ppnt->p_type) { case PT_GNU_STACK: if (elf_ppnt->p_flags & PF_X) executable_stack = EXSTACK_ENABLE_X; else executable_stack = EXSTACK_DISABLE_X; break; case PT_LOPROC ... PT_HIPROC: retval = arch_elf_pt_proc(elf_ex, elf_ppnt, bprm->file, false, &arch_state); if (retval) goto out_free_dentry; break; }

同樣通過for循環遍歷,如果識別到棧屬性段(PT_GNU_STACK),根據程序頭中的p_flags標志位判定棧的可執行屬性。如果識別到處理器專用語義段(PT_LOPROC至PT_HIPROC之間),則調用arch_elf_pt_proc函數完成相應的配置。

5、讀取解釋器

if (interpreter) { retval = -ELIBBAD; /* Not an ELF interpreter */ if (memcmp(interp_elf_ex->e_ident, ELFMAG, SELFMAG) != 0) goto out_free_dentry; /* Verify the interpreter has a valid arch */ if (!elf_check_arch(interp_elf_ex) || elf_check_fdpic(interp_elf_ex)) goto out_free_dentry; /* Load the interpreter program headers */ interp_elf_phdata = load_elf_phdrs(interp_elf_ex, interpreter); if (!interp_elf_phdata) goto out_free_dentry;

解釋器也是一個elf文件,這里讀取解釋器以便于后續操作

6、加載程序段

for(i = 0, elf_ppnt = elf_phdata; i < elf_ex->e_phnum; i++, elf_ppnt++) { int elf_prot, elf_flags; unsigned long k, vaddr; unsigned long total_size = 0; unsigned long alignment; if (elf_ppnt->p_type != PT_LOAD) continue;

加載所有類型為PT_LOAD的段,當處理第1個PT_LOAD段時,如果文件為dyn類型,還需要對其進行地址隨機化。隨機化時還需要區分解釋器或者其他普通so文件,對于解釋器,為避免程序發生沖突,程序固定從ELF_ET_DYN_BASE開始計算偏移進行加載。

if (!first_pt_load) { elf_flags |= MAP_FIXED;} else if (elf_ex->e_type == ET_EXEC) { elf_flags |= MAP_FIXED_NOREPLACE;} else if (elf_ex->e_type == ET_DYN) { if (interpreter) { load_bias = ELF_ET_DYN_BASE; if (current->flags & PF_RANDOMIZE) load_bias += arch_mmap_rnd(); alignment = maximum_alignment(elf_phdata, elf_ex->e_phnum); if (alignment) load_bias &= ~(alignment - 1); elf_flags |= MAP_FIXED_NOREPLACE; } else load_bias = 0; load_bias = ELF_PAGESTART(load_bias - vaddr); total_size = total_mapping_size(elf_phdata, elf_ex->e_phnum); if (!total_size) { retval = -EINVAL; goto out_free_dentry; }}

一切就緒后,通過elf_map函數建立用戶空間虛擬地址空間與目標映像文件中段的映射

error = elf_map(bprm->file, load_bias + vaddr, elf_ppnt, elf_prot, elf_flags, total_size);7、裝載程序入口地址

if (interpreter) { elf_entry = load_elf_interp(interp_elf_ex, interpreter, load_bias, interp_elf_phdata, &arch_state); if (!IS_ERR_VALUE(elf_entry)) { /* * load_elf_interp() returns relocation * adjustment */ interp_load_addr = elf_entry; elf_entry += interp_elf_ex->e_entry; } if (BAD_ADDR(elf_entry)) { retval = IS_ERR_VALUE(elf_entry) ? (int)elf_entry : -EINVAL; goto out_free_dentry; } reloc_func_desc = interp_load_addr; allow_write_access(interpreter); fput(interpreter); kfree(interp_elf_ex); kfree(interp_elf_phdata); } else { elf_entry = e_entry; if (BAD_ADDR(elf_entry)) { retval = -EINVAL; goto out_free_dentry; } }

對于需要解釋器的程序,需要先通過load_elf_interp函數裝入解釋器的映像,并將程序入口點設置為解釋器的入口地址,對于不需要解釋器的文件,直接讀取elf_header中的入口點虛擬地址即可。

8、添加參數和環境變量等配置信息

retval = create_elf_tables(bprm, elf_ex, interp_load_addr, e_entry, phdr_addr);if (retval < 0) goto out; mm = current->mm;mm->end_code = end_code;mm->start_code = start_code;mm->start_data = start_data;

本文作者:jixiaokui,轉載請注明來自

標簽:

返回頂部
国产高潮呻吟久久| 亚洲熟妇无码一区二区三区导航| 国产午夜大地久久| 一级黄色片播放| 91精品国产高清一区二区三密臀| 亚洲av成人精品日韩在线播放| 99久久精品久久亚洲精品| 色婷婷狠狠18| 亚洲精品一区二区三区蜜桃| 老司机成人免费视频| 久久久久久久中文字幕| 9.1在线观看免费| 国产第一页视频| 国产黄色一区二区| 欧美中日韩在线| 91在线视频国产| 超碰成人在线免费观看| av中文在线播放| 林心如三级全黄裸体| 免费在线观看国产精品| xxxwww国产| 亚洲一级免费在线观看| 中国黄色片一级| 稀缺呦国内精品呦| 日本黄色的视频| 亚洲av无码一区二区三区网址 | 中文字幕永久有效| 91视频在线免费| 九九视频免费观看| 精品亚洲aⅴ无码一区二区三区| 精品人妻在线播放| 日韩在线视频网址| 亚洲永久精品视频| 免费av观看网址| 天堂国产一区二区三区| 蜜臀av免费观看| 中文字幕高清视频| 伊人在线视频观看| 国产精品欧美久久久久天天影视| 69av视频在线| 精品人妻一区二区三区浪潮在线 | 无码人妻精品一区二区蜜桃色欲| 成人在线观看小视频| 一卡二卡三卡在线| 日韩一区二区高清视频| 深爱五月激情五月| 国产在线成人精品午夜| 日韩成人午夜影院| 天天干视频在线| 国产极品美女高潮无套嗷嗷叫酒店| 中国1级黄色片| 精品黑人一区二区三区国语馆| 成人在线观看a| 69视频免费看| xxx国产在线观看| 亚洲天堂精品一区| 蜜桃av中文字幕| 久久草视频在线| 久久国产精品网| 熟女少妇内射日韩亚洲| 性欧美8khd高清极品| 国产午夜福利一区二区| 国产www免费| 国产精品20p| 日本xxxxwww| 亚洲自拍一区在线观看| 激情内射人妻1区2区3区 | 黄色a级片在线观看| 国产吃瓜黑料一区二区| 中文字幕av网站| 欧美极品视频在线观看| 欧美中日韩在线| 性欧美13一14内谢| 欧洲av在线播放| 波多野结衣人妻| 久久无码精品丰满人妻| a√天堂在线观看| 欧美亚洲视频一区| 在线观看日本网站| 蜜桃视频一区二区在线观看| bt天堂新版中文在线地址| 精品人妻无码一区二区三区换脸 | 久久久久无码精品国产sm果冻| 欧美特黄一级视频| h片在线免费看| 无码免费一区二区三区| 北条麻妃亚洲一区| 国产wwwxx| 久久久久久久久久久免费视频| 裸体裸乳免费看| 日本视频在线免费| 蜜桃精品成人影片| 中国一级特黄录像播放| 丰满人妻一区二区三区大胸| xxxx国产精品| 国产裸体永久免费无遮挡| 销魂美女一区二区| 青娱乐在线免费视频| 免费在线不卡视频| 五月天婷婷综合网| 亚洲另类欧美日韩| 成人精品免费在线观看| 欧美国产日韩在线视频| 污污动漫在线观看| 性欧美在线视频| 欧美三级免费看| 国产精品.www| 中文字幕日韩免费| 国产乱色精品成人免费视频| 国产毛片毛片毛片毛片| 免费看av毛片| 91九色蝌蚪porny| 久久久久久久久免费看无码 | 国产黄色一级大片| 日本r级电影在线观看| 日韩有码第一页| 不卡的一区二区| 中文在线永久免费观看| 人妻少妇无码精品视频区| 少妇av片在线观看| 午夜av入18在线| 免费看一级大黄情大片| 国产无遮挡猛进猛出免费软件| 久久久久成人网站| 成年人视频免费| 成人精品在线播放| 制服丝袜第一页在线观看| 国产又粗又长免费视频| 国产精品久久久影院| 国产理论在线播放| 日韩人妻精品中文字幕| 午夜精品久久久久久久99老熟妇| 日韩在线视频观看免费| 亚洲色偷偷色噜噜狠狠99网| 黄大色黄女片18免费| www.成年人视频| 91大神免费观看| 国产又粗又猛视频| 第四色在线视频| 黄色a级在线观看| 看欧美ab黄色大片视频免费| 日韩成人在线免费视频| 性生活黄色大片| 欧美日韩国产黄色| 久久九九国产视频| 最近日韩免费视频| 久久久久亚洲AV成人无码国产| 四虎影院一区二区| 青娱乐国产盛宴| 黄色小视频免费观看| 中国1级黄色片| 孩娇小videos精品| 亚洲第一色网站| 亚洲天堂网av在线| 91插插插影院| 亚洲欧美激情在线观看| 国产一区二区视频在线观看免费| 三上悠亚在线一区| www.蜜臀av.com| 日本中文在线视频| av资源吧首页| 西西大胆午夜视频| 无码无遮挡又大又爽又黄的视频| 在线观看中文字幕码| 精品人妻一区二区三区日产乱码卜| 国产 欧美 日本| 亚洲国产av一区二区三区| 亚洲人人夜夜澡人人爽| 最近免费中文字幕中文高清百度| 99在线精品视频免费观看软件 | 男操女免费网站| 免费高清视频在线观看| 女人天堂av手机在线| 精品国产伦一区二区三区| 日韩video| 国产麻豆精品一区| 一二三在线视频| 亚洲无码精品在线播放| 波多野结衣激情| 国产欧美久久久| 国产一级不卡视频| 亚洲精品成人区在线观看| 久色视频在线播放| 天堂av手机版| 欧美特级aaa| 漂亮人妻被黑人久久精品| 精品国产乱码久久久久久1区二区| 国产精品久久久久久亚洲色| 性色av蜜臀av色欲av| 久久久久亚洲av片无码下载蜜桃| 久久久久无码精品国产sm果冻| 五月天婷婷网站| 国产精品三区在线观看| av中文字幕在线免费观看| 青娱乐自拍偷拍| 日本女人黄色片| 最新免费av网址| 女人十八毛片嫩草av| 无码人妻精品一区二区三区蜜桃91| 一区中文字幕在线观看| 精品国自产在线观看| 日韩精品一区中文字幕| 国产又黄又粗又猛又爽的视频 | 国产精品自拍视频一区| 男女裸体影院高潮| 国产伦理在线观看| 日本亚洲色大成网站www久久| 国产福利片一区二区| 天堂在线观看免费视频| 国产一级大片在线观看| 亚洲国产一二三精品无码| 午夜视频在线免费播放| 日本一区二区不卡在线| 今天免费高清在线观看国语| 天天操天天爱天天干| 中国一级特黄毛片| 国产a视频免费观看| 亚洲女同二女同志奶水| 欧美 日韩 综合| 91精品国产乱码在线观看| 玩弄中年熟妇正在播放| 黄色三级生活片| 亚洲精品一级片| 国产九色在线播放九色| 精品久久久噜噜噜噜久久图片| 在线观看黄网址| 亚洲午夜久久久久久久久| 中文在线a天堂| 国产一级特黄a高潮片| 免费欧美一级视频| 性欧美18一19内谢| b站大片免费直播| 久久久国产精品久久久| 一级黄色a视频| 国产无套粉嫩白浆内谢| 国产野外作爱视频播放| 美脚丝袜脚交一区二区| 国产视频精品免费| 国产精品成人一区二区三区电影毛片| 亚洲精品.www| 999免费视频| 怡红院男人天堂| 精品人妻无码一区二区性色| 亚洲精品午夜在线观看| 国产极品尤物在线| 性一交一乱一伧国产女士spa| 操她视频在线观看| 日本爱爱爱视频| 国产精品无码久久久久一区二区| 亚洲欧洲成人在线| 俄罗斯嫩小性bbwbbw| 国产又粗又长又黄| 国产又粗又猛又爽又| 欧美三级午夜理伦| 日本中文字幕网| 久久久精品91| 黄色小说在线观看视频| 久久综合成人网| 久久无码精品丰满人妻| 久操免费在线视频| 精品无码人妻一区二区三区品| 久久综合在线观看| 无套内谢丰满少妇中文字幕| 久久久久久福利| 国产午夜性春猛交ⅹxxx| 日韩欧美一级视频| 无码人妻一区二区三区线 | 中文字幕丰满乱子伦无码专区| 高潮毛片无遮挡| 欧美一级特黄高清视频| 国产中文字幕久久| 亚洲自拍偷拍一区二区三区| 国产 国语对白 露脸| 欧洲精品一区二区三区久久| 久久国产亚洲精品无码| 少妇激情一区二区三区| 污视频在线观看免费网站| 国产乱码久久久久久| 欧美国产一级片| 亚洲毛片在线播放| 日韩综合第一页| 久久久久久久久福利| 538任你躁在线精品视频网站| 肉大捧一出免费观看网站在线播放| 国产精品免费入口| 麻豆一区二区三区精品视频| 成年人免费高清视频| 国产三级精品在线观看| 亚洲av成人片无码| 日本成人精品视频| 久久精品.com| 久久免费激情视频| 午夜精品久久久久久久96蜜桃| 亚洲男人在线天堂| 欧美a级黄色大片| 欧美特黄aaa| 一级黄色大片免费| 免费观看av网站| 国产freexxxx性播放麻豆| 天天久久综合网| jlzzjlzz亚洲女人18| 亚洲成人网在线播放| 国产精品第157页| 麻豆chinese极品少妇| 精品国产av一区二区| 永久免费av无码网站性色av| 丁香花在线影院观看在线播放| 久久久久成人网站| 好男人www在线视频| 在线观看亚洲黄色| 人妻丰满熟妇aⅴ无码| 四虎精品一区二区三区| 国产奶头好大揉着好爽视频| 在线黄色免费看| 国产三级第一页| 小早川怜子一区二区的演员表| 粉色视频免费看| 亚洲AV无码乱码国产精品牛牛| 在线免费看av网站| 日产亚洲一区二区三区| 国产chinese中国hdxxxx| 免费看又黄又无码的网站| 最新中文字幕免费| 人妻熟人中文字幕一区二区| 成年人在线观看视频免费| 国产麻豆精品一区| 特色特色大片在线| 人妻中文字幕一区二区三区| 污污视频网站在线免费观看| 欧美精品色视频| 免费的av网站| 久久人人爽人人片| 网站免费在线观看| 欧美精品色哟哟| 国产黄片一区二区三区| 久久高清无码视频| 中文字幕人妻一区二区| 色婷婷综合在线观看| 天天躁日日躁狠狠躁av麻豆男男| 免费黄色一级网站| 国产成人精品一区二区在线小狼| 男人日女人下面视频| 亚洲国产成人一区二区| 人妻熟妇乱又伦精品视频| 亚洲免费成人在线| 亚洲中文字幕久久精品无码喷水| 天堂在线观看av| 久热精品在线播放| 极品粉嫩小仙女高潮喷水久久| 污污视频网站在线| 亚洲天堂网一区二区| 国产精品18p| www.毛片com| 91久久精品无码一区二区| 国产高清av在线播放| 国产在线观看免费播放| 久久精品亚洲天堂| 91香蕉视频在线播放| 国产毛片毛片毛片毛片| 免费在线激情视频| 插我舔内射18免费视频| 黄色成人免费看| 一级欧美一级日韩片| 国产无码精品久久久| 影音先锋成人资源网站| 国产有码在线观看| 青青草精品视频在线观看| 亚洲AV无码国产成人久久| 日韩视频在线观看一区| 欧美一级片免费播放| 亚洲av成人片无码| 中文人妻av久久人妻18| 野外做受又硬又粗又大视频√| 亚洲 精品 综合 精品 自拍| 久久久福利影院| 99国产精品白浆在线观看免费| 亚洲国产剧情在线观看| 久久久久亚洲av成人片| 欧美精品一区二区性色a+v| 亚洲三级在线视频| 日本少妇全体裸体洗澡| 日韩中文字幕在线免费| 国产又粗又猛又色| 在线观看xxxx| 伊人网在线综合| 国产探花在线播放| 肉丝美足丝袜一区二区三区四| 久久久久久久极品| 免费无码av片在线观看| av激情在线观看| 人妻 日韩 欧美 综合 制服| 中日韩在线观看视频| 天堂av.com| 国产91对白刺激露脸在线观看| 制服丨自拍丨欧美丨动漫丨| 亚洲精品国产精| www.com亚洲| 中文字幕亚洲影院| 久久精品网站视频| 国产又黄又爽又无遮挡|