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

操作系统内核与安全分析课程笔记【1】链表、汇编与makefile

文章目录

  • 链表
    • 循环双向链表
    • 哈希链表
    • 其他链表
  • 汇编
    • 内联汇编
    • 扩展内联汇编
  • makefile

链表

链表是linux内核中关键的数据结构。在第二次课中,重点介绍了循环双向链表哈希链表。这两种链表都在传统的双向链表的基础之上进行了针对效率的优化。(ps:这部分可以通过看插入链表、删除链表中节点的具体实现来加深理解)

循环双向链表

请添加图片描述
linux内核中的链表节点中只包含指针,数据被存在节点之外的空间,通过偏移来获取数据。(ps:在结构体之外再套一个结构体)

哈希链表

请添加图片描述
哈希链表是双向非循环链表,head和node的结构不同,head里有1个指针,node里面有2个指针,并且两个指针一个是一级指针(next),一个是二级指针(prev)。
请添加图片描述
这种设计的优点在于:

  1. 节省空间:head设计只有1个指针,空间使用减少一半
  2. 提高效率:判断是否为head节点,只需要查看pprev指针

其他链表

降序优先排序的双向链表: 二重索引请添加图片描述
无锁单链表
请添加图片描述

汇编

Linux大部分代码是c语言编写,但依旧有少量代码用汇编语言编写,原因是:

  1. 提高效率
  2. 与硬件交互
  3. 与cpu交互

用c语言写的代码可以通过3种方法看其汇编代码:

gcc -S [file_name].c # method 1gcc -c [file_name].c # method 2
objdump -d [file_name].o gdb + disassemble # method 3

汇编指令语法见:汇编语言–x86汇编指令集大全

内联汇编

内联汇编只可以对全局变量进行操作。


#include <stdio.h> // asm.cint a, b, c;
int main() {a = 1, b = 2;asm volatile ("movl a, %eax\n\t" // 将a放入eax寄存器"addl b, %eax\n\t" // 将b的值加到eax寄存器中"movl %eax, c\n\t" // 将eax寄存器的值加到c中);printf("c:%d\n",c);    
}

扩展内联汇编

扩展内联汇编可以对局部变量进行操作,其基本格式为:

asm volatile ("assembly code" : output operands /* optional */: input operands /* optional */: list of clobbered registers /* optional */
)
#include <stdio.h> //asm_2.cint main() {int a = 1, b = 2, c = 0;asm volatile ("movl %0, %%eax\n\t""movl %1, %%ebx\n\t""addl %%eax, %%ebx\n\t""movl %%ebx, %2\n\t":"+g"(a), "+g"(b) // input operand:"+g"(c) // output operand );printf("c:%d\n",c);printf("a:%d\n",a);printf("b:%d\n",b);return 0;
}

clobbered registers会影响最终结果:

#include<stdio.h>
int main() {int data1 = 10;int result = 20;asm ("movl %1, %%eax\n\t""addl %%eax, %0":"=r"(result):"r"(data1), "0"(result)// :"%eax" 此行不注释result=30,注释后result=20);printf("the result is:%d\n",result);return 0;
}

makefile

请添加图片描述
在软件开发中,Make 是一种构建自动化工具,它通过读取指定如何派生目标程序的称为 Makefile 的文件,从源代码自动构建可执行程序和库。 尽管集成开发环境和特定于语言的编译器功能也可用于管理构建过程,但 Make 仍被广泛使用,尤其是在 Unix 和类 Unix 操作系统中。

Make 可用于管理任何项目,除了构建程序之外,只要其他文件发生变化,某些文件需要从其他文件自动更新。

makefile包括4种语句:

  1. 规则
  2. 变量定义
  3. 其他元素

一个简单的makefile例子:项目包括2个c++文件:processing.cppgui.cpp文件,那么makefile可以写成:

gcc -c processing.cpp -o processing.o # 单独编译processing.cpp
gcc -c gui.cpp -o gui.o # 单独编译gui.cpp
gcc processing.o gui.o -o my_program # 联合编译processing.o和gui.o

可以发现编译一个2个文件的项目,已经涉及到了3行命令行来进行编译。可以预想的是,当项目规模扩大时,编译的指令也会变得异常复杂,并且一旦更新其中一个文件,需要重新编译的时候,所涉及到需要重新运行的编译指令所面临的情况也是千奇百怪。因此,我们需要makefile来对编译的指令进行一个封装,简化用户编译时的工作量。

to be continued

http://www.lryc.cn/news/37493.html

相关文章:

  • 华为OD机试题 - 九宫格按键输入(JavaScript)| 机考必刷
  • PMSM控制_foc 控制环路
  • Linux 练习七 (IPC 共享内存)
  • 【数据库原理复习】ch4 完整性约束 SQL定义
  • 【2023年的就业形势依旧严峻】
  • Linux下LED灯驱动模板详解
  • 【C++】你不得不爱的——继承
  • 数据库系统概论
  • 32位处理器AM6528BACDXEA、AM6548BACDXEAF基于Arm Cortex-A53内核【工业4.0嵌入式产品应用】
  • 多图片怎么转换成PDF?这招教你轻松转换
  • kali双网卡
  • 【wed前端初级课程】第一章 什么是HTML
  • sd卡格式化后数据恢复怎么操作
  • 论文阅读笔记|大规模多标签文本分类
  • 国际化翻译navigator.language与语种对照表
  • Matlab进阶绘图第6期—雷达图/蜘蛛图/星图
  • Javascript的ES6 class写法和ES5闭包写法性能对比
  • 探秘MySQL——全面了解索引、索引优化规则
  • 战斗力最强排行榜:10-30人团队任务管理工具
  • 2023-03-09干活小计
  • 基数排序算法
  • 项目实战典型案例24——xxljob控制台不打印日志排查
  • 旋转框目标检测mmrotate v1.0.0rc1 之RTMDet训练DOTA的官方问题解析整理(四)
  • 4个顶级的华为/小米/OPPO/Vivo手机屏幕解锁工具软件
  • 华为OD机试题 - 和最大子矩阵(JavaScript)| 机考必刷
  • 企业电子招标采购系统源码之项目说明和开发类型
  • Python高频面试题——装饰器(带大家理解装饰器的本质)
  • 全方位解读智能中控屏发展趋势!亚马逊Alexa语音+Matter能力成必备
  • JAVA练习74-括号生成
  • Java ORM开发 更全面的应用场景