Chinaunix

标题: 请教boot0.s [打印本页]

作者: wellbye    时间: 2006-04-06 11:24
标题: 请教boot0.s
  1. start:                cld                                # String ops inc
  2.                 xorw %ax,%ax                        # Zero
  3.                 movw %ax,%es                        # Address
  4.                 movw %ax,%ds                        #  data
  5.                 movw %ax,%ss                        # Set up
  6.                 movw $LOAD,%sp                        #  stack
  7.        
  8. #
  9. # Copy this code to the address it was linked for
  10. #
  11.                 movw %sp,%si                        # Source
  12.                 movw $start,%di                        # Destination
  13.                 movw $0x100,%cx                        # Word count
  14.                 rep                                # Relocate
  15.                 movsw                                #  code
复制代码


这实在是没懂啊,大家看这个$start,它不就是0吗?难道这个代码的意思是把整个程序从$LOAD处移到地址0去吗??
地址0上面不是bios中断吗,要是把这个覆盖了以后还怎么做事啊,这这这这这这,还是请高手指点吧。。。
我以前也看过linux的代码,它是把自己移到0x9000上去了,可是这bsd,实在太诡异了吧。。
作者: 雨丝风片    时间: 2006-04-06 11:51
原帖由 wellbye 于 2006-4-6 11:24 发表
这实在是没懂啊,大家看这个$start,它不就是0吗?难道这个代码的意思是把整个程序从$LOAD处移到地址0去吗??
地址0上面不是bios中断吗,要是把这个覆盖了以后还怎么做事啊,这这这这这这,还是请高手指点吧。。。
我以前也看过linux的代码,它是把自己移到0x9000上去了,可是这bsd,实在太诡异了吧。。  ...


请参见下面这个链接:

【FreeBSD 5.2.1 boot0(启动扇区代码分析)】
作者: wellbye    时间: 2006-04-06 12:16
多谢指点!但是那文中有句话:
“把位于0:7c00处的代码搬移到0:0x600处。注意,此时由于代码连接的重定向,$start=0x600。”
这个代码连接重定向是谁做的呢?
作者: gvim    时间: 2006-04-06 19:51
编译的时候,有一句是这样的

cc -O2 ... -DFLAG=0x8f -DTICKS=0xb6 ... -e start -Ttext 0x600 ... -o boot0 boot0.o

具体可以在sys/boot/i386/boot0/Makefile 里面找到




欢迎光临 Chinaunix (http://bbs.chinaunix.net/) Powered by Discuz! X3.2