当前位置: 首页 > news >正文

昆山建设局网站首页河北seo平台

昆山建设局网站首页,河北seo平台,游戏网站策划,建设单位发包许可证网站1. 前言 限于作者能力水平#xff0c;本文可能存在谬误#xff0c;因此而给读者带来的损失#xff0c;作者不做任何承诺。 2. 背景 本文分析基于 ARM32 架构#xff0c;Linux-4.14 内核代码。 3. 问题分析 3.1 测试范例 void main(void) {*(int *)0 8; }运行程序会 …1. 前言 限于作者能力水平本文可能存在谬误因此而给读者带来的损失作者不做任何承诺。 2. 背景 本文分析基于 ARM32 架构Linux-4.14 内核代码。 3. 问题分析 3.1 测试范例 void main(void) {*(int *)0 8; }运行程序会 coredump 。 3.2 分析 3.2.1 ARM32 3级页表(PAE使能) 上图看起有点复杂我们简化一下Linux 下内存的访问的过程大概是这样的 MMU页表 虚拟地址 -------- 物理地址3.2.2 生成 coredump 每当发生内存访问时如果从虚拟地址到物理地址的转换路径中不管是哪级页表没有就绪ARM32系统都会产生缺页中断因此我们分析的起点就是缺页中断的入口。先看看中断向量表 arch/arm/kernel/entry-armv.Svector_stub dabt, ABT_MODE, 8.long __dabt_usr 0 (USR_26 / USR_32).long __dabt_invalid 1 (FIQ_26 / FIQ_32).long __dabt_invalid 2 (IRQ_26 / IRQ_32).long __dabt_svc 3 (SVC_26 / SVC_32).long __dabt_invalid 4.long __dabt_invalid 5.long __dabt_invalid 6.long __dabt_invalid 7.long __dabt_invalid 8.long __dabt_invalid 9.long __dabt_invalid a.long __dabt_invalid b.long __dabt_invalid c.long __dabt_invalid d.long __dabt_invalid e.long __dabt_invalid f.globl vector_fiq/* 各个CPU模式下的中断向量表指针 */.section .vectors, ax, %progbits .L__vectors_start:W(b) vector_rstW(b) vector_undW(ldr) pc, .L__vectors_start 0x1000W(b) vector_pabtW(b) vector_dabt /* DataAbort模式的中断向量表指针 */W(b) vector_addrexcptnW(b) vector_irqW(b) vector_fiq/* 缺页(DataAbort)中断可产生于[SVC、用户]两种模式下 */ __dabt_usr: /* 用户模式缺页中断 */...dabt_helper // bl CPU_DABORT_HANDLER - bl v7_early_abort....align 5 __dabt_svc: /* SVC模式缺页中断 */...dabt_helper // bl CPU_DABORT_HANDLER - bl v7_early_abort...arch/arm/mm/abort-ev7.S.align 5 ENTRY(v7_early_abort)mrc p15, 0, r1, c5, c0, 0 get FSRmrc p15, 0, r0, c6, c0, 0 get FARuaccess_disable ip disable userspace access...b do_DataAbort ENDPROC(v7_early_abort)/** 以3级页表举例。* arch/arm/mm/fsr-3level.c */ static struct fsr_info fsr_info[] {.../* 缺页中断处理接口 */{ do_translation_fault, SIGSEGV, SEGV_MAPERR, level 1 translation fault }, /* 1级页目录转换接口 */{ do_translation_fault, SIGSEGV, SEGV_MAPERR, level 2 translation fault }, /* 2级页目录转换接口 */{ do_page_fault, SIGSEGV, SEGV_MAPERR, level 3 translation fault }, /* 3级页表项转换接口 */... };/** arch/arm/mm/fault.c */ asmlinkage void __exception do_DataAbort(unsigned long addr, unsigned int fsr, struct pt_regs *regs) {const struct fsr_info *inf fsr_info fsr_fs(fsr);struct siginfo info;/* 调用具体类型缺页中断的入口: do_translation_fault() 或 do_page_fault() */if (!inf-fn(addr, fsr ~FSR_LNX_PF, regs))return;... }如果第 1,2 级别页表导致的缺页中断会进入 do_translation_fault() static int __kprobes do_translation_fault(unsigned long addr, unsigned int fsr,struct pt_regs *regs) {if (addr TASK_SIZE) /* 用户空间地址 */return do_page_fault(addr, fsr, regs);... }第3级页表导致的缺页中断进入 do_page_fault() 这和第1,2级页表导致缺页中断的情形殊途同归。来看 do_page_fault() static int __kprobes do_page_fault(unsigned long addr, unsigned int fsr, struct pt_regs *regs) {struct task_struct *tsk;...unsigned int flags FAULT_FLAG_ALLOW_RETRY | FAULT_FLAG_KILLABLE;...tsk current;...fault __do_page_fault(mm, addr, fsr, flags, tsk);... }static int __kprobes __do_page_fault(struct mm_struct *mm, unsigned long addr, unsigned int fsr,unsigned int flags, struct task_struct *tsk) {/** 查看addr是否存在对应的 vma ? * 如果没有的话意味着非法地址访问.*/vma find_vma(mm, addr);fault VM_FAULT_BADMAP;if (unlikely(!vma))goto out;...out:return fault; }从 __do_page_fault() 返回 do_page_fault() static int __kprobes do_page_fault(unsigned long addr, unsigned int fsr, struct pt_regs *regs) {struct task_struct *tsk;...unsigned int flags FAULT_FLAG_ALLOW_RETRY | FAULT_FLAG_KILLABLE;...tsk current;...fault __do_page_fault(mm, addr, fsr, flags, tsk);...if (!(fault VM_FAULT_ERROR) flags FAULT_FLAG_ALLOW_RETRY) {if (fault VM_FAULT_MAJOR) {tsk-maj_flt;...} else {tsk-min_flt;...}...}...if (fault VM_FAULT_SIGBUS) {...} else { /* 测试代码场景走这里 *//** Something tried to access memory that* isnt in our memory map..*/sig SIGSEGV;code fault VM_FAULT_BADACCESS ?SEGV_ACCERR : SEGV_MAPERR;}__do_user_fault(tsk, addr, fsr, sig, code, regs);return 0;... }static void __do_user_fault(struct task_struct *tsk, unsigned long addr,unsigned int fsr, unsigned int sig, int code,struct pt_regs *regs) {struct siginfo si;...#ifdef CONFIG_DEBUG_USERif (((user_debug UDBG_SEGV) (sig SIGSEGV)) ||((user_debug UDBG_BUS) (sig SIGBUS))) {printk(KERN_DEBUG %s: unhandled page fault (%d) at 0x%08lx, code 0x%03x\n,tsk-comm, sig, addr, fsr);show_pte(tsk-mm, addr);show_regs(regs);} #endiftsk-thread.address addr;tsk-thread.error_code fsr;tsk-thread.trap_no 14;si.si_signo sig;si.si_errno 0;si.si_code code;si.si_addr (void __user *)addr;force_sig_info(sig, si, tsk); /* 给出错进程发送 SIGSEGV 信号 */ }出错进程处理 SIGSEGV 信号 asmlinkage int do_work_pending(struct pt_regs *regs, unsigned int thread_flags, int syscall) {...do {if (likely(thread_flags _TIF_NEED_RESCHED)) {...} else {if (unlikely(!user_mode(regs)))return 0;if (thread_flags _TIF_SIGPENDING) {int restart do_signal(regs, syscall); /* 信号处理 */...} else if (thread_flags _TIF_UPROBE) {...} else {...}}...} while (thread_flags _TIF_WORK_MASK);return 0; }static int do_signal(struct pt_regs *regs, int syscall) {...if (get_signal(ksig)) {...} else {...}return 0; }int get_signal(struct ksignal *ksig) {...for (;;) {...signr dequeue_synchronous_signal(ksig-info);if (!signr)signr dequeue_signal(current, current-blocked, ksig-info);if (!signr)break; /* will return 0 */...if (ka-sa.sa_handler ! SIG_DFL) {/* Run the handler. */ksig-ka *ka;if (ka-sa.sa_flags SA_ONESHOT)ka-sa.sa_handler SIG_DFL;break; /* will return non-zero signr value */}...}fatal:if (sig_kernel_coredump(signr)) {if (print_fatal_signals)print_fatal_signal(ksig-info.si_signo);...do_coredump(ksig-info); /* 产生 coredump 文件 */}... }4. 调试 coredump 问题 产生的 coredump 文件可用 gdb 进行调试 。 5. 后记 本文涉及到信号处理更多信号处理细节可参考 Linux信号处理简析 。本文没有对程序的 coredump 细节进行展开它有点复杂留待后续有机会再进行述说。
http://www.hkea.cn/news/14301262/

相关文章:

  • wordpress中文破解主题seo网站建设视频
  • 黄页名录网站开发网站设计与网页制作岗位招聘信息
  • 单位门户网站是什么合肥高端网站建设公司哪家好
  • 建设的网站打开速度很慢任县网站建设设计
  • 网站 html 作用WordPress禁止英文评论插件
  • wordpress大型网站短链接生成器下载
  • 免费企业网站做a爱片网站
  • 网站备案号被注销什么原因wordpress 代码编写
  • 南通仿站定制模板建站wordpress 图片命名
  • 信息化建设网站范本原神移动端
  • 网站策划书范文模板可以下载app的软件
  • 北京seo学校北京推广优化经理
  • 如何做网站卖商品的网站实验教学网站建设策划方案
  • 网站开发 产品经理简洁商城网站模板
  • 做产品网站多少钱沧州市网站建设价格
  • 网站建设 中企动力西安靓号网站开发
  • 深圳的seo网站排名优化网页美工培训哪里好
  • 网站做支付需要准备什么东西域名转移 网站访问
  • 建设通网站是什么网站网站建设的流程及步骤
  • 海南哪家公司做网站做的好合肥大型网站设计公司
  • 湛江建站程序开发一个跑腿app需要多少钱
  • 有关学校网站建设的建议互动企业展厅设计公司
  • 包头建设厅官方网站想自己开发一款软件
  • 网站建设多少钱哪个济南兴田德润有活动吗个人网站的设计及实现
  • 四川移动网站建设报价网站建设专业输入法
  • 东莞网站托管公司安阳网络平台
  • 南宁做网站设计方案wordpress网页没法评论
  • 江苏建设网官方网站龙华营销型网站建设公司
  • 广州建设水务局网站建设企业网站企业网银
  • 上海网站制作是什么营销推广48个方法