您现在的位置是:课程

周哥教IT.C与ARM汇编

2023-06-30 22:05课程 人已围观

周哥简介 
周哥:男,真名周扬荣,毕业于中科院软件所。曾就职于阿里巴巴,奇虎360安全公司,SUN中国工程研究院,北大计算机研究所等,创办了“麦洛科菲”高端IT安全培训 。
 

在从事程序设计与开发期间,主要参与研发的产品包括:  
1.“火眼”Rootkit检测工具 
2.基于Linux内核开发的服务器双机热备 
3.Solaris内核声卡,显卡驱动 
4.Comodo Internet Security 中的Defense+/Sandbox内核驱动开发 
5.360安全卫士文件防火墙,桌面流氓图标智能防护 
6.拥有国家发明专利两项 
7.著有《程序员求职成功路:技术、求职技巧与软实力培养》,《电脑系统与数据安全防护》,《加密与解密-第4版》(作者之一)等书,在当当,京东360,CSDN等网站广获读者5星好评和推荐,并被包括北京大学,清华大学,中国科学技术大学在内的众多高校图书馆收藏。 

此外,曾亲临美国加州硅谷工作生活过一段时间,并在SUN公司总部做过Solaris内核开发的技术报告;还曾经作为海文学校计算机专业考研讲师,负责中科院计算机专业考研专业课的课程讲解。    

课程大纲 
ARM处理器是一种RISC架构,是当今移动应用的王者。ARM汇编是移动安全的基础,在逆向,调试,脱壳等方面离不开ARM汇编。如下所示,互联网名企招聘移动安全工程师都要求熟练掌握ARM汇编语言:








本课将深入介绍ARM汇编编程,包括开发环境搭建,调试,指令集,子程序,寻址方式,AArch64架构,详细分析了C函数调用、传参、语句与底层ARM汇编的实现,最后还结合Meltdown&Spectre漏洞讨论了CPU芯片安全相关问题。

1.序言
2.复杂指令集(CISC)和精简指令集(RISC)
3.ARM寄存器
4.基于IDE的ARM程序开发,调试
5.ARM指令集学习
    5.1ARM指令集概述
    5.2算术指令
    5.3减、乘、除指令底层的加法实现
    5.4逻辑运算与移位指令
    5.5比较、跳转、交换等指令,伪指令
    5.6Load/Store指令
    5.7MOV指令、ARM立即数定义与判断
    5.8THUMB指令
6.ARM子程序
    6.1ATPCS调用标准
    6.2汇编函数定义与调用,库函数调用
    6.3C程序调用汇编函数
7.ARM寻址方式
8.ARMv8 AArch64架构
    8.1A64架构概述
    8.2A64寄存器
    8.3A64异常级别
    8.4A64运行模式
9.C与底层ARM汇编
    9.1调用约定与ARM汇编
    9.2传参与ARM汇编
    9.3C语句与ARM汇编
10.CPU芯片安全概述
    10.1CPU流水线,分支预测,乱序执行
    10.2虚拟地址翻译理论:X86,X86 PAE,X64
    10.3虚拟地址翻译实验:X86 PAE
    10.4Meltdown与Spectre漏洞原理与修复分析
  
学员评价 
感谢麦洛克菲,讲得比大学老师好! 

错误更正:
第7节,ARM9种寻址方式,第4种和第5种,应该为:
ldr r0, [r1]
ldr r0, [r1, #-4]

即把原来的mov改为ldr,因为ARM基于load/store架构,是不允许MOV直接访问内存的。

勘误提示:如您在学习过程中发现任何“错误”,请通过email:zyr(at) mallocfree.com告知我们错误所在的课程名称和错误所在视频的时间起始位置。错误一经我们确认,我们将会在该门课程的“课程概述”里提供“错误更正”信息,并对您表示衷心的感谢。 
-->

站点信息

  • 文章统计篇文章