同一个软中断对应同一个中断处理函数
时间: 2024-04-04 21:21:19 浏览: 86
是的,同一个软中断对应同一个中断处理函数。在 Linux 内核中,软中断是通过 `do_softirq()` 函数来触发的,每个软中断都有一个唯一的编号,在注册软中断时需要指定其对应的中断处理函数。当软中断被触发时,内核会通过该编号查找对应的中断处理函数,并执行该函数来处理软中断。因此,同一个软中断编号对应同一个中断处理函数。
相关问题
写一个信号机制实验程序signal.c,由父进程创建两个子进程,通过终端输入Crtl+\组合键向父进程发送SIGQUIT软中断信号或由系统时钟产生SIGALRM软中断信号发送给父进程;父进程接收到这两个软中断的其中某一个后,向其两个子进程分别发送整数值为SIGUSR1 (10)和SIGUSR1 (12)软中断信号,子进程获得对应软中断信号后,分别输出“<进程PID> killed by <信号编号>”后,终止运行;父进程调用wait()函数等待两个子进程终止,然后自我终止。
下面是 signal.c 的代码实现:
```
#include <stdio.h>
#include <stdlib.h>
#include <signal.h>
#include <unistd.h>
#include <sys/wait.h>
void child_handler(int signo)
{
printf("%d killed by %d\n", getpid(), signo);
exit(0);
}
int main()
{
pid_t pid1, pid2;
int status;
if ((pid1 = fork()) == 0) {
signal(SIGUSR1, child_handler);
while (1) {}
} else if ((pid2 = fork()) == 0) {
signal(SIGUSR1, child_handler);
while (1) {}
} else {
signal(SIGQUIT, SIG_IGN);
signal(SIGALRM, SIG_IGN);
printf("Waiting for signal...\n");
pause();
if (kill(pid1, SIGUSR1) == -1) {
perror("kill");
exit(1);
}
if (kill(pid2, SIGUSR2) == -1) {
perror("kill");
exit(1);
}
wait(&status);
wait(&status);
printf("Parent process terminating...\n");
exit(0);
}
}
```
这个程序首先创建了两个子进程,然后父进程忽略了 SIGQUIT 和 SIGALRM 信号,并进入了 pause() 函数的等待状态。
当父进程接收到 SIGQUIT 或 SIGALRM 信号时,它会分别向两个子进程发送 SIGUSR1 和 SIGUSR2 信号。子进程在收到对应的信号后,会输出“<进程PID> killed by <信号编号>”,然后调用 exit() 函数终止运行。
父进程在发送信号后,调用 wait() 函数等待两个子进程终止,然后自我终止。
编制一段程序,实现软中断通信 使用系统调用fork()创建两个子进程,再用系统调用signal()让父进程捕捉键盘上来的中断信号,当父进程接受到这两个软中断的其中某一个后,父进程用系统调用kill()向两个子进程分别发送整数值为16和17软中断信号,子进程获得对应软中断信号后,分别输出下列信息后终止: Child process 1 i
下面是一个简单的C语言程序,实现软中断通信的功能:
```
#include <stdio.h>
#include <stdlib.h>
#include <unistd.h>
#include <signal.h>
void child1_handler(int sig) {
printf("Child process 1 is terminated.\n");
exit(0);
}
void child2_handler(int sig) {
printf("Child process 2 is terminated.\n");
exit(0);
}
int main() {
pid_t pid1, pid2;
int status;
pid1 = fork(); // 创建子进程1
if (pid1 < 0) {
printf("Failed to fork child process 1.\n");
exit(1);
} else if (pid1 == 0) {
// 子进程1
while(1) {
sleep(1);
}
exit(0);
} else {
pid2 = fork(); // 创建子进程2
if (pid2 < 0) {
printf("Failed to fork child process 2.\n");
exit(1);
} else if (pid2 == 0) {
// 子进程2
while(1) {
sleep(1);
}
exit(0);
} else {
// 父进程
signal(SIGINT, SIG_IGN); // 忽略SIGINT信号
signal(SIGQUIT, SIG_IGN); // 忽略SIGQUIT信号
// 捕捉软中断信号
signal(16, child1_handler);
signal(17, child2_handler);
while(1) {
pause(); // 等待软中断信号
}
}
}
return 0;
}
```
父进程在创建完两个子进程后,用signal()函数捕捉软中断信号。当接收到信号时,父进程会向子进程1和子进程2分别发送整数值为16和17的软中断信号。子进程在接收到对应的软中断信号后,输出相应的信息并终止。
阅读全文