0%

msleepmdelay都是内核的延时函数,原型如下:

1
2
void mdelay(unsigned long msecs);
void msleep(unsigned int millisecs);

区别

mdelay是忙等待函数,会占用CPU资源,延迟时间是准确的。

msleep是休眠函数,不占用CPU资源,延迟时间通常高于给定值。

阅读全文 »

运行环境

Linux debian 4.19.0-10-amd64

编译内核模块

0. 准备编译所需的内核头文件

系统默认内核头文件路径在/lib/modules/`uname -r`,先确认该路径是否存在:

1
ls /lib/modules/`uname -r`/build

如路径不存在,需要先安装内核头文件,方法如下:

阅读全文 »

问题描述

打开office软件失败,提示无法找到应用程序的许可证。

原因

Software Protection服务启动失败,可以通过services.msc查看该服务的启动状态

解决方法

修改注册表,将如下文本复制到文件,文件名改为software prtection服务.reg, 双击该文件即可。

阅读全文 »

实验介绍

本实验中,我们需要利用缓冲区溢出漏洞,来修改一个二进制可执行文件的运行时行为。

预备知识

  • 缓冲区溢出的原理,参考《CSAPP原书第3版》3.10小节

  • gdbobjdump使用

  • x86_64下的汇编

阅读全文 »

从官网安装指定版本, 以3.12.1版本为例:

1
2
3
4
5
6
wget https://cmake.org/files/v3.12/cmake-3.12.1.tar.gz
tar -zxvf cmake-3.12.1.tar.gz
cd cmake-3.12.1
./bootstrap
make -j8
make install
阅读全文 »

实验简介

二进制炸弹是一个作为目标代码提供的程序。运行时提示用户输入6个不同的字符串,如其中一个字符串不正确,炸弹会引爆并打印一条错误信息。需要通过反汇编确定输入的6个字符串,从而拆除炸弹。

知识点

  • 汇编语言基础
  • GDB和OBJDUMP工具的使用
阅读全文 »