Skip site navigation (1)Skip section navigation (2)
Date:      Fri, 4 Aug 2000 15:37:23 -0700 (PDT)
From:      John Baldwin <jhb@FreeBSD.org>
To:        cvs-committers@FreeBSD.org, cvs-all@FreeBSD.org
Subject:   cvs commit: src/sys/boot/i386/boot0 boot0.s
Message-ID:  <200008042237.PAA36603@freefall.freebsd.org>

next in thread | raw e-mail | index | archive | help
jhb         2000/08/04 15:37:23 PDT

  Modified files:
    sys/boot/i386/boot0  boot0.s 
  Log:
  Argh!  Fix a brainfart of mine.  In the old boot0, we relocated ourself
  to 0x600 via a 'rep movsw'.  Once that was done, %cx was zero, so we could
  simply use 'movb' to update the lower byte of %cx in preparation for
  zeroing out the fake partition entry used to boot to other drives via F5.
  Well, in the new boot0, we don't actually relocate ourselves, instead it
  is easier to create the fake partition entry first and then just use it to
  get the BIOS to load all of boot0 into memory at 0x600.  However, since we
  aren't doing the relocate code anymore, we don't know that %cx == 0 when
  we hit the 'movb' to setup %cx for clearning the fake partition entry.
  Thus, if %ch != 0 when the BIOS started boot0, then it would end up zeroing
  a lot more memory than just 8 words.  The solution is to do a word move of
  $8 into %cx.
  
  Debugging help from:	David Wolfskill <dhw@whistle.com>
  
  Revision  Changes    Path
  1.20      +2 -2      src/sys/boot/i386/boot0/boot0.s



To Unsubscribe: send mail to majordomo@FreeBSD.org
with "unsubscribe cvs-all" in the body of the message




Want to link to this message? Use this URL: <https://mail-archive.FreeBSD.org/cgi/mid.cgi?200008042237.PAA36603>