Linux 0.11 源码阅读 1 -- syscall的调用实现

本文详细介绍了Linux 0.11操作系统中系统调用的实现过程,从_syscall0宏的展开到int 0x80中断的触发,再到system_call汇编代码和sys_call_table的作用。通过对源码的分析,揭示了系统调用如何通过全局符号表进行函数跳转,为理解早期Linux内核工作原理提供了基础。
摘要由CSDN通过智能技术生成

前言

        在main.c函数中,存在两个函数 fork.c pause.c,当我们尝试单步跟进去之后,却发现失败了,我们来分析其原因。

void main(void)		/* This really IS void, no error here. */
{			
    ....
	if (!fork()) {		/* we count on this going ok */
		init();
	}

	for(;;) pause();
}

    

_syscall0(type,name) 宏的实现

        我们在main函数中存在下面这些定义,我们现在尝试分析一下。

static inline _syscall0(int,fork)
static inline _syscall0(int,pause)
static inline _syscall1(int,setup,void *,BIOS)
static inline _syscall0(int,sync)

        其_syscall0(type,name)定义如下,我们尝试对此展开一下。

#define _syscall0(type,name) \
  type name(void) \
{ \
long __res; \
__asm__ volatile ("int $0x80" \
	: "=a" (__res) \
	: "0" (__NR_##name)); \
if (__res >= 0) \
	return (type) __res; \
errno = -__res; \
return -1; \
}

          我们现在对pause( )展开,内容如下,就是调用 int 0x80,然后eax来传

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值