14. x86编程模型(2)

本文介绍了在x86编程模型中,如何初始化cs、es、ss、ds寄存器为0以实现平坦模型,特别讨论了cs寄存器的特殊性以及使用jmp指令的技巧。同时,遇到调试时栈空间设置后出现报错的情况,虽然F11可以继续执行,但发现在汇编文件(.S)中无法设置断点,而在C文件中则可以。
摘要由CSDN通过智能技术生成

1 设置 cs ,es, ss ,ds 寄存器初始化为0,因为采用的是平坦模型

2 cs 寄存器, 无法直接 mov 的方式设置为0

3 jmp $0,  offset,   这种模式就相当于 jmp cs:ip 方式。

4 设置栈空间,esp 到栈顶。

_start: 
	jmp $0, $offset   // 用于设置cs寄存器, cs:ip  不支持这种语法
offset:
	mov $0, %ax
	mov %ax, %ds
	mov %ax, %ss
	mov %ax, %es
	mov %ax, %gs
	mov %ax, %fs

	mov $offset, %esp    // 设置了栈顶指针



	jmp .
	.org 0x1fe   //从510的地方开始
	.byte 0x55, 0xaa

结果: 调试报错

但是按 F11 却可以继续执行下去

发现: 在.c文件中可以 打断点,但是在 .S 文件中无法打断点。

暂时 先这样吧。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值