跟着李述铜学习x86操作系统之前置课---加载自己写的c文件到内存 001

.s和.c文件一起编译后会存放到磁盘上  由于程序只加载主引导扇区 不会主动加载剩余的磁盘上内容 为了让我们自己写的.c文件能加载到内存中 需要写汇编代码 读写磁盘 将.c文件加载到内存

 

/**
 * 功能:16位与32位的启动混合代码
 *
 *创建时间:2022年8月31日
 *作者:李述铜
 *联系邮箱: 527676163@qq.com
 *相关信息:此工程为《从0写x86 Linux操作系统》的前置课程,用于帮助预先建立对32位x86体系结构的理解。整体代码量不到200行(不算注释)
 *课程请见:https://study.163.com/course/introduction.htm?courseId=1212765805&_trace_c_p_k2_=0bdf1e7edda543a8b9a0ad73b5100990
 */
    #include "os.h"

    // 声明本地以下符号是全局的,在其它源文件中可以访问
    .global _start

    // 指定以下的代码生成16位的机器指令,这样才能在启动时的实模式下运行
      .code16

    // 以下是代码区
     .text
_start: 

    mov $0, %ax
    mov %ax, %ds
    mov %ax, %es
    mov %ax, %ss
    mov %ax, %fs
    mov %ax, %gs
    mov $_start, %esp

read_self_all:  //将主引导扇区以外的磁盘加载到内存
    mov $0x7e00, %bx //设定要将磁盘内容加载到内存的位置
    mov $0x02, %cx // 设定读取的扇区号
    mov $0x240, %ax //设定 2 是读指令 存在ah 40是十六进制 表示读取的扇区数量存在al
    mov $0x80, %dx //80表示第一个磁盘
    int $0x13 //0x13号软中断 该中断里面有读磁盘的对应历程
    jc read_self_all //jmp的判断指令
    

    .org 0x1fe  //org伪指令  0x1fe =510 表示后面的数据 距文件起始位置偏移多少开始存放 510和511字节存放 0x55 0xaa
    .byte 0x55, 0xaa

.fill 64*1024, 1, 0x35 //伪指令fill 表示填充 .fill 反复次数 字节  填充内容

  

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 2
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值