LINUX内核及应用程序移植工作】的更多相关文章

1. 添加工作用户 [root@localhost ~]#useradd -G root -g root -d/home/arm arm 2. 建立工作目录 [arm@localhost arm]$mkdir dev_home [arm@localhost arm]$cd dev_home [arm@localhost arm]$mkdir bootldr btools debug doc images kernel localapps \ rootfs sysapps tmp tools [a…
在编译Linux内核中增加程序需要完成以下3项工作: 将编写的源代码拷入Linux内核源代码的相应目录. 在目录的Kconfig文件中增加关于新源代码对应项目的编译配置选项 在目录的Makefile文件中增加对新源代码的编译条目 下面给出在内核中新增驱动代码目录和子目录的实例 假设我们要在内核源代码drivers目录下为ARM体系结构新增如下用于 test driver的树形目录: |--test       |-- test.c         在内核中增加目录和子目录,我们需要为相应的新增目…
Linux内核设计第二周 ——操作系统工作原理 作者:宋宸宁(20135315) 一.实验过程 图1 执行效果 从图中可以看出,每执行my_ start_ kernel函数两次或一次,my_ time_ hander函数执行一次. 图2 mymain.c文件关键代码部分 图3 myinterrupt.c文件关键代码部分 二.分析分析进程的启动和进程的切换机制(分析见注释) 1.myinterrupt.c /* * linux/mykernel/myinterrupt.c * * Kernel i…
万子惠 + 原创作品转载请注明出处 + <Linux内核分析>MOOC课程http://mooc.study.163.com/course/USTC-1000029000 " 实验部分(反汇编简单的C程序) 代码: int g(int x) { return x + 6; } int f(int x) { return g(x); } int main(void) { return f(4) + 8; } 最后结果应为18 在Code下新建main.c 进行编译和反编译 反编译结果如…
万子惠 + 原创作品转载请注明出处 + <Linux内核分析> 实验部分 使用实验楼的虚拟机打开shell 然后cd mykernel 您可以看到qemu窗口输出的内容的代码mymain.c和myinterrupt.c my_time_handler(调用printk //实际时会做一些中断处理) my_start_kernel(进行硬件初始化的工作) 总结部分 来自老师的计算机是如何工作的总结--三个法宝 存储程序计算机工作模型,计算机系统最最基础性的逻辑结构: 函数调用堆栈,高级语言得以运…
mykernel实验指导(操作系统是如何工作的) 实验要求 运行并分析一个精简的操作系统内核,理解操作系统是如何工作的 使用实验楼的虚拟机打开shell cd LinuxKernel/linux-3.9.4 qemu -kernel arch/x86/boot/bzImage 然后cd mykernel 您可以看到qemu窗口输出的内容的代码mymain.c和myinterrupt.c 实验截图 首先是 然后是 之后是 要建立一个简单的时间片轮转多道程序,按照实验楼给的链接,找到了几个源代码,如…
实验部分 使用gcc -S -o main.s main.c -m32命令将源代码编译成汇编代码. 源代码如下: int g(int x) { return x + 9; } int f(int x) { return g(x); } int main(void) { return f(18) + 11; } 编译后的代码如下: g: pushl %ebp movl %esp, %ebp movl 8(%ebp), %eax addl $9, %eax popl %ebp ret f: push…
一个简单的时间片轮转多道程序 操作系统的"两把剑":中断上下文(保存现场和恢复现场)和进程上下文的切换 源代码的分析 *使用的源代码为视频中所使用的精简内核的源代码 首先分析mypcd.h struct Thread { unsigned long ip;//point to cpu run address unsigned long sp;//point to the thread stack's top address //todo add other attrubte of sy…
实验部分 (以下命令为实验楼64位Linux虚拟机环境下适用,32位Linux环境可能会稍有不同) 使用 gcc –S –o main.s main.c -m32 命令编译成汇编代码, int g(int x) { return x + 6; } int f(int x) { return g(x); } int main(void) { return f(13) +2; } 1. 实验截图 复制代码到实验楼 编译,打开main.s(打开前忘记截图,改完后截的图) 删完冗余部分,剩下的汇编代码…
1.冯诺依曼体系结构:也就是指存储程序计算机 硬件(存储程序计算机工作模式): 软件(程序员角度): 2.API:程序员与计算机的接口界面 ABI:程序与CPU的接口界面 3.X86的实现: 4.X86 CPU的寄存器: 所有E开头的寄存器一般来说都是32位的. EBP:堆栈基址指针 ESP:堆栈顶指针 32位通用寄存器: 5.CPU在实际取指令时根据cs:eip来准确定位一个指令 6.EFLAGS register标志寄存器 7.X86的32位寄存器和64位寄存器在核心机制上差别不大,前面带R…