首页 > 其他分享 > 20211325 2023-2024-1 《信息安全系统设计与实现(上)》第九周学习笔记

20211325 2023-2024-1 《信息安全系统设计与实现(上)》第九周学习笔记

时间:2023-11-10 19:45:16浏览次数:48  
标签:函数 int printf 2024 中断 信号 2023 进程 20211325

 20211325 2023-2024-1 《信息安全系统设计与实现(上)》第九周学习笔记

一、任务要求

自学教材第6章,提交学习笔记(10分),评分标准如下 1. 知识点归纳以及自己最有收获的内容,选择至少2个知识点利用chatgpt等工具进行苏格拉底挑战,并提交过程截图,提示过程参考下面内容 (4分) “我在学***X知识点,请你以苏格拉底的方式对我进行提问,一次一个问题” 核心是要求GPT:“请你以苏格拉底的方式对我进行提问” 然后GPT就会给你提问,如果不知道问题的答案,可以反问AI:“你的理解(回答)是什么?” 如果你觉得差不多了,可以先问问GPT:“针对我XXX知识点,我理解了吗?” GPT会给出它的判断,如果你也觉得自己想清楚了,可以最后问GPT:“我的回答结束了,请对我的回答进行评价总结”,让它帮你总结一下。

2. 问题与解决思路,遇到问题最先使用chatgpt等AI工具解决,并提供过程截图(3分)

3. 实践过程截图,代码链接(2分)

4. 其他(知识的结构化,知识的完整性等,提交markdown文档,使用openeuler系统等)(1分)

二、课本内容总结

(1)信号和中断

中断,英文名为Interrupt,计算机的世界里处处都有中断,任何工作都离不开中断,可以说整个计算机系统就是由中断来驱动的。

“中断”是从I/O设备或协处理器发送到CPU的外部请求,他将CPU从正常执行转移到中断处理。

简单总结:中断即CPU停下当前的工作任务,去处理其他事情,处理完后回来继续执行刚才的任务

  • 首先,我们将进程的概念概括为:一个"进程"(引号中)就是一系列活动。广义的"进程"包括
    • 从事日常事务的人。
    • 在用户模式或内核模式下运行的 Unix/Linux 进程
    • 执行机器指令的CPU。

根据来源 中断可分为三类

1.人员中断:
来自硬件的中断:大楼着火,闹钟响了等
来自其他人的中断:电话响了,有人敲门等。
自己造成的中断:切到手指,吃得太多等。
按照紧急程度,中断可分为以下几类:
    不可屏蔽(NMI):大楼着火!
    可屏蔽:有人敲门等。

2.进程中断:
这类中断是发送给进程的中断。当某进程正在执行时,可能会收到来自3个不同来源的中断:
来自硬件的中断:终端、间隔定时器的“Ctrl+C”组合键等。
来自其他进程的中断:kill(pid,SIG#), death_of_child等。
自己造成的中断:除以0、无效地址等。
每个进程中断都被转换为一个唯一ID号,发送给进程。与多种类的人员中断不同,我们始终可限制在一个进程中的中断的数量。Unix/Linux中的进程中断称为信号,编号为1到31。进程的PROC结构体中有对应每个信号的动作函数,进程可在收到信号后执行该动作函数。与人员类似,进程也可屏蔽某些类型的信号,以推迟处理。必要时,进程还可能会修改信号动作函数。

3.硬件中断:
这类中断是发送给处理器或CPU的信号。它们也有三个可能的来源:
来自硬件的中断:定时器、1/O设备等
来自其他处理器的中断:FFP、DMA、多处理器系统中的其他CPU
自己造成的中断:除以О、保护错误、INT指令。
每个中断都有唯一的中断向量号。动作函数是中断向量表中的中断处理程序。
进程的陷阱错误
进程可能会自己造成中断。这些中断是由被CPU识别为异常的错误引起的,例如除以0、无效地址、非法指令、越权等。

(2)Unix/Linux信号示例

  • 按“Ctrl+C”组合键通常会导致当前运行的进程终止。原因如下:

    “Ctr1+C”组合键会生成一个键盘硬件中断。键盘中断处理程序将“Ctrl+C”组合键转换为SIGINT(2)信号,发送给终端上的所有进程,并唤醒等待键盘输人的进程。

  • 用户可使用nohup a.out &命令在后台运行一个程序。即使在用户退出后,进程仍将继续运行。nobup命令会使sh像往常一样复刻子进程来执行程序,但是子进程会忽略SIGHuP(1)信号。当用户退出时,sh会向与终端有关的所有进程发送一个SIGHUP信号。

实例:使用 nohup 命令 将一个jar包在后台运行,即使关闭中断仍不会导致进程死亡。

 

  • 用户可以使用sh命令kill pid (orkill-s9pia)杀死该程。

    方法如下。执行杀死的进程向pid标识的目标进程发送一个SIGTERM ( 15 )信号,请求它死亡。目标进程将会遵从请求并终止。

Unix/Linux中的信号处理

  • Unix/Linux支持31种不同的信号,每种信号在 signal.h文件中都有定义。

(下图例为 OpenEuler 20.03 LTS 操作系统)

使用kill -l命令可以列出该系统所支持的所有信号的列表:

信号值在32 之前的则有不同的名称,而信号值在32 以后的都是用“SIGRTMIN”或“SIGRTMAX”开头的,这就是两类..型的信号。前者是从UNIX 系统中继承下来的信号,为不可靠信号(也称为非实时信号);后者是为了解决前面“不可靠信号”的问题而进行了更改和扩充的信号,称为“可靠信号”(也称为实时信号)。

(3)信号的来源

  • 来自硬件中断的信号
  • 来自异常的信号
  • 来自其他进程的信号

(4)信号处理函数&信号捕捉函数

每个进程PROC 都有一个信号处理数组 int sig[32]。Sig[32]数组的每个条目都指定了如何处理相应的信号,其中0表示 DEFault(默认).1表示 IGNore(忽略).其他非零值表示用户模式下预先安装的信号捕捉(处理)函数。

  • 使用signal()函数处理时,只需要指出要处理的信号和处理函数即可。它主要是用于前32种非实时信号的处理,不支持信号传递信息,但是由于使用简单、易于理解,因此也受到很多程序员的欢迎。

Linux还支持一个更健壮、更新的信号处理函数sigaction(),推荐使用该函数。

typedef void (*sighandler_t)(int);
sighandler_t signal(int signum, sighandler_t handler);

第一个参数signum:指明了所要处理的信号类型,它可以取除了SIGKILL和SIGSTOP外的任何一种信号。  

第二个参数handler:描述了与信号关联的动作,它可以取以下三种值:

  • SIG_IGN:忽略该信号
  • SIG_DFL:恢复对信号的系统默认处理
  • sighandler_t类型的函数指针:用户自定义的处理函数。

在 实践环境下查看 sigaction 使用方法

  • 信号集函数组

我们可以通过信号来终止进程,也可以通过信号来在进程间进行通信,程序也可以通过指定信号的关联处理函数来改变信号的默认处理方式,也可以屏蔽某些信号,使其不能传递给进程。那么我们应该如何设定我们需要处理的信号,我们不需要处理哪些信号等问题呢?信号集函数就是帮助我们解决这些问题的。

int sigemptyset(sigset_t *set);
//该函数的作用是将信号集初始化为空。

int sigfillset(sigset_t *set);
//该函数的作用是把信号集初始化包含所有已定义的信号。

int sigaddset(sigset_t *set, int signo);
//该函数的作用是把信号signo添加到信号集set中,成功时返回0,失败时返回-1。

int sigdelset(sigset_t *set, int signo);
//该函数的作用是把信号signo从信号集set中删除,成功时返回0,失败时返回-1.

int sigismember(sigset_t *set, int signo);
//该函数的作用是判断给定的信号signo是否是信号集中的一个成员,如果是返回1,如果不是,返回0,如果给定的信号无效,返回-1;

int sigpromask(int how, const sigset_t *set, sigset_t *oset);
//该函数可以根据参数指定的方法修改进程的信号屏蔽字。新的信号屏蔽字由参数set(非空)指定,而原先的信号屏蔽字将保存在oset(非空)中。如果set为空,则how没有意义,但此时调用该函数,如果oset不为空,则把当前信号屏蔽字保存到oset中。

int sigpending(sigset_t *set);
//该函数的作用是将被阻塞的信号中停留在待处理状态的一组信号写到参数set指向的信号集中,成功调用返回0,否则返回-1,并设置errno表明错误原因。

int sigsuspend(const sigset_t *sigmask);
//该函数通过将进程的屏蔽字替换为由参数sigmask给出的信号集,然后挂起进程的执行。注意操作的先后顺序,是先替换再挂起程序的执行。程序将在信号处理函数执行完毕后继续执行。如果接收到信号终止了程序,sigsuspend()就不会返回,如果接收到的信号没有终止程序,sigsuspend()就返回-1,并将errno设置为EINTR。

(4)sigaction实践

#include <stdio.h>
#include <unistd.h>
#include <signal.h>
#include <string.h>

void handler(int sig,siginfo_t *siginfo,void *context){
printf("handler:sig=%d from PID=%d UID=%d\n",sig,siginfo->si_pid,siginfo->si_uid);
}

int main(int argc,char *argv[]){
struct sigaction act;
memset(&act,0,sizeof(act));
act.sa_sigaction = &handler;
act.sa_flags = SA_SIGINFO;
sigaction(SIGTERM,&act, NULL);
printf("proc PID=%d looping\n");
printf("enter Kill PID to send SIGTERM signal to it\n",getpid());
while(1){
sleep(10);
}
}

运行结果:

(5)信号处理步骤

  • 当某进程处于内核模式时,会检查信号并处理未完成的信号。如果某信号有用户安装的捕捉函数,该进程会先清除信号,获取捕捉函数地址,对于大多数陷阱信号,则将已安装的捕捉函数重置为 DEFault。然后,它会在用户模式下返回,以执行捕捉函数,以这种方式篡改返回路径。当捕捉函数结束时,它会返回到最初的中断点,即它最后进入内核模式的地方。

  • 重置用户安装的信号捕捉函数:用户安装的陷阱相关信号捕捉函数用于处理用户代码中的陷阱错误。由于捕捉函数也在用户模式下执行,因此可能会再次出现同样的错误。如果是这样,该进程最终会陷入无限循环,一直在用户模式和内核模式之间跳跃。为了防止这种情况,Unix 内核通常会在允许进程执行捕捉函数之前先将处理函数重置为 DEFault。这意味着用户安装的捕捉函数只对首次出现的信号有效。

  • 信号和唤醒:在Unix/Linux,内核中有两种 SLEEP进程;深度休眠进程和浅度休眠进程。前一种进程不可中断,而后一种进程可由信号中断。如果某进程处于不可中断的SLEEP 状态,到达的信号(必须来自硬件中断或其他进程)不会唤醒进程。如果它处于可中断的SLEEP状态,到达的信号将会唤醒它。

(6)信号与异常

Unix信号最初设计用于以下用途:

  • 作为进程异常的统一处理方法;
  • 让进城通过预先安装的信号捕捉函数用户模式下的程序错误;
  • 在特殊情况下,它会让某一个进程通过信号杀死另一个进程。

(7)信号用做IPC

实践:段错误捕捉函数

#include <stdio.h>
#include <stdlib.h>
#include <unistd.h>
#include <signal.h>
#include <setjmp.h>
#include <string.h>
jmp_buf env;
int count = 0;
void handler(int sig,siginfo_t *siginfo,void *context)
{
printf("handler:sig=&d from PID=%d UID=%d count=%d\n",sig,siginfo->si_pid,siginfo->si_uid,++count);
if (count>=4)
longjmp(env,1234);
}

int BAD()
{
int *ip=0;
printf("in BAD():try to dereference NULL pointer\n");
*ip=123;
printf("should not see this line\n");
}

int main(int argc,char *argv[])
{
int r;
struct sigaction act;
memset (&act,0,sizeof(act));
act.sa_sigaction = &handler;
act.sa_flags=SA_SIGINFO;
sigaction(SIGSEGV, &act,NULL);
if((r=setjmp(env))==0)
BAD();
else
printf("proc %d survived SEGMENTATION FAULT:r=%d\n",getpid(),r);
printf("proc %d looping\n");
while(1);
}

运行结果:

 

(8)管道和FIFO

管道的主要用途是连接一对管道写进程和读进程。管道写进程可将数据写入管道,读进程可从管道中读取数据。管道控制机制要对管道读写操作进行同步控制。未命名管道供相关进程使用。

在建立了管道之后,两个进程就可以把它当作普通文件一样进行读写操作,使用非常方便。不过值得注意的是,FIFO是严格地遵循先进先出规则的,对管道及FIFO的读总是从开始处返回数据,对它们的写则把数据添加到末尾,它们不支持如lseek()等文件定位操作。

(9)信号

进程可使用 kill 系统调用向其他进程发送信号,其他进程使用信号捕捉函数处理信号。将信号用作IPC的一个主要缺点是信号只是用作通知,不含任何信息内容

(10)线程同步机制

Linux 不区分进程和线程。在 Linux中,进程是共享某些公共资源的线程。如果是使用有共享地址空间的clone(系统调用创建的进程,它们可使用互斥量和条件变量通过共享内存进行同步通信。另外,常规进程可添加到共享内存,使它们可作为线程进行同步。

(11)编程实践:实现一个消息IPC

#include<stdio.h>
#include<signal.h>
#include<string.h>
#define LEN 64

int ppipe[2];
int pid;
char line[LEN];

int parent(){
printf("parent %d running\n",getpid());
close(ppipe[0]);
while(1){
printf("parent %d: input a line : \n",getpid());
fgets(line,LEN,stdin);
line[strlen(line)-1]=0;
printf("parent %d write to pipe\n",getpid());
write(ppipe[1],line,LEN);
printf("parent %d send signal 10 to %d\n",getpid(),pid);
kill(pid,SIGUSR1);
}
}

void chandler(int sig){
printf("\nchild %d got an interrupt sig=%d\n",getpid(),sig);
read(ppipe[0],line,LEN);
printf("child %d get a message = %s\n",getpid(),line);
}

int child(){
char msg[LEN];
int parent = getppid();
printf("child %d running\n",getpid());
close(ppipe[1]);
signal(SIGUSR1,chandler);
while(1);
}

int main(){
pipe(ppipe);
pid=fork();
if(pid)
parent();
else
child();
}

运行结果:

 三、课堂代码

 

四、苏格拉底挑战

(1)信号处理与应用

 

 

 

(2)信号用作IPC

标签:函数,int,printf,2024,中断,信号,2023,进程,20211325
From: https://www.cnblogs.com/Garden-of-Avalon/p/17824892.html

相关文章

  • 支撑企业数字化经营,《2023指标平台白皮书》正式发布
    导语随着宏观经济步入新常态和市场不确定性加剧,我国企业的经营环境正在发生深刻变化。为了更好地应对挑战,企业需转向高质量发展,通过精细化管理等手段优化业务结构、提高运营效率和创新能力。在数字经济时代,借助数字化手段实现数字化经营成为驱动企业高质量发展的关键途径。指标体系......
  • 20231110打卡
    早上,我按照计划开始了新一轮的学习。我花了一些时间复习之前学过的算法知识,并解决了一些算法练习题。通过不断思考和练习,我巩固了自己对算法的理解,并且提升了解决问题的能力。下午,由于天气很冷,我和一些同学相约去打球放松一下。尽管天气寒冷,但是打球的过程中我们感到温暖和快乐。......
  • 亚数受邀参加第六届进博会配套论坛,获评“2023年度上海重点产业提升国际竞争力示范案例
    11月8日,由上海市商务委指导,上海社科院和临港集团主办,上海社科院应用经济研究所、徐汇虹梅街道和上海市漕河泾新兴技术开发区开发总公司联合承办,长三角产业国际竞争力联盟协办的第六届中国国际进口博览会提升上海产业国际竞争力工作会议暨漕河泾开发区开放合作活动在沪举行。活动重......
  • 喜讯|ShowMeBug 入围2023 “超新星” 榜单
    11月9日,2023中国(广州)未来资本峰会暨2023“超新星”榜单颁奖典礼在广州越秀国际会议中心隆重举办,ShowMeBug有幸入围此次“超新星”榜单。本届论坛云集了政界领袖、行业专家、各领域学者与和企业代表,围绕新兴创投力量与创投趋势,以“新裂变∞新潜能”为主题,进行交流与探讨。本次......
  • 喜报!华为云金融PaaS3.0荣获“2023年应用现代化典型案例”称号
    中国软件行业协会近期启动了2023“应用现代化产业实践”优秀案例征集活动,旨在加快推动应用现代化发展与推广应用,形成行业应用带动和示范作用,打造应用现代化软件名企、名品,凝聚行业资源,助力我国行业应用现代化高质量发展,为建设制造强国、数字中国提供坚强支撑。近日,中国软件行业协会......
  • CINEMA 4D 2024:三维创意,设计未来 mac/win版
    CINEMA4D是一款由Maxon公司开发的3D建模、动画和渲染软件,广泛应用于影视、工业设计等领域。CINEMA4D以其强大的功能和高效的性能而备受设计师和艺术家们的青睐。→→↓↓载CINEMA4D2024mac/win版CINEMA4D2024是该软件的最新版本,它在继承了以往版本优秀功能的基础上,新增......
  • NeurIPS 2023 Spotlight | 半监督与扩散模型结合,实现少标签下可控生成
    前言 本文从模型结构到训练策略,以及实验结果出发,详解了DeepMind之前提出的不需要归一化的深度学习模型NFNet。本文转载自PaperWeekly作者:游泽彬单位:中国人民大学仅用于学术分享,若侵权请联系删除欢迎关注公众号CV技术指南,专注于计算机视觉的技术总结、最新技术跟踪、经典论文......
  • 2023年11月10日阅读笔记
    《黑客与画家》 为什么我会去阅读这本书籍呢?因为我最近在学习用java编写网络时感到枯燥和乏味,突发奇想去学习网络安全有关的知识。最初的自己还设想能成为一名黑客,因为他们似乎是高冷、神秘、聪明、无所不能的名词代表。而在阅读《黑客与画家》这本书的第一章内容后我对于黑客,......
  • 2023-11-10 习题选讲
    XLKCSP-S2023A给定一个\(01\)矩阵\(a\)。\(a_{x,y}=1\)则\((x,y)\)有点。求有多少个大小为\(4\)的点集,满足点集中的点刚好为一个正方形的四个顶点。\(n\le500\)发现\(O(n^3)\)不好做,直接bitset压位,\(O(\frac{n^4}{w})\)可以通过。constintN=5e2+......
  • 静态代码分析工具Helix QAC 2023.3:将100%覆盖MISRA C++2023规则
    静态代码分析工具HelixQAC2023.3:将100%覆盖MISRAC++:2023®规则 HelixQAC2023.3预计将于2023年第四季度发布的新MISRAC++®指南,将100%覆盖MISRAC++:2023®规则。 此外,此版本扩展了对C++20语言支持,并改进了PerforceValidate平台和HelixQAC与Validate的集成,包括其他......