run real mode code under unreal mode and A20 enable

Question about which tools to use, bugs, the best way to implement a function, etc should go here. Don't forget to see if your question is answered in the wiki first! When in doubt post here.
Post Reply
zq
Posts: 9
Joined: Wed May 10, 2017 7:00 pm
Libera.chat IRC: si

run real mode code under unreal mode and A20 enable

Post by zq »

As the title stated, will it be safe to run real mode code under unreal mode(large mode) and A20 line enable.
Because I need to R/W memory at high address and using some BIOS interupt function, will such config crash in BIOS call?
User avatar
Geri
Member
Member
Posts: 442
Joined: Sun Jul 14, 2013 6:01 pm

Re: run real mode code under unreal mode and A20 enable

Post by Geri »

it will not crash. bios interrupts will work properly in unreal mode. nowdays most of the intel configs will boot in unreal mode by default, but older intels, and all amd-s will require to set unreal mode.
Operating system for SUBLEQ cpu architecture:
http://users.atw.hu/gerigeri/DawnOS/download.html
User avatar
Brendan
Member
Member
Posts: 8561
Joined: Sat Jan 15, 2005 12:00 am
Location: At his keyboard!
Contact:

Re: run real mode code under unreal mode and A20 enable

Post by Brendan »

Hi,
zq wrote:As the title stated, will it be safe to run real mode code under unreal mode(large mode) and A20 line enable.
Because I need to R/W memory at high address and using some BIOS interupt function, will such config crash in BIOS call?
It's mostly safe, but (depending on which BIOS functions you use and a few other things) there's a (relatively small) chance that the BIOS will use protected mode and disable unreal mode (restore 64 KiB segment limits) when you're not expecting it. Note: This is most often a problem caused by network cards, RAID controllers and SCSI controllers that don't use (slow) IO ports; where the device's ROM has to enable protected mode to access the device's memory mapped registers.

To guard against that it's a nice idea to hook the BIOS "interrupt 0x0D" handler, where your code would:
  • Check if the interrupt's "return CS:IP" points to the area your code is in, and jump to the original BIOS interrupt handler if it's not
  • Check if the master PIC chip sent an "IRQ5" (by reading the PIC chip's "In Service Register" and checking bit 5), and if IRQ5 is in service jump to the original BIOS interrupt handler
  • Otherwise (if your code was interrupted and it's not an IRQ) assume the interrupt was caused by a general protection fault (which was caused by your code using unreal mode when segment limits have been restored unexpectedly), and re-enable unreal mode and return to the instruction that cause the general protection fault
That way, if anything ever does restore real mode segment limits your "interrupt 0x0D hook" will auto-fix the problem and continue as if nothing happened.


Cheers,

Brendan
For all things; perfection is, and will always remain, impossible to achieve in practice. However; by striving for perfection we create things that are as perfect as practically possible. Let the pursuit of perfection be our guide.
alexfru
Member
Member
Posts: 1112
Joined: Tue Mar 04, 2014 5:27 am

Re: run real mode code under unreal mode and A20 enable

Post by alexfru »

Brendan wrote: It's mostly safe, but (depending on which BIOS functions you use and a few other things) there's a (relatively small) chance that the BIOS will use protected mode and disable unreal mode (restore 64 KiB segment limits) when you're not expecting it. Note: This is most often a problem caused by network cards, RAID controllers and SCSI controllers that don't use (slow) IO ports; where the device's ROM has to enable protected mode to access the device's memory mapped registers.

To guard against that it's a nice idea to hook the BIOS "interrupt 0x0D" handler, where your code would:
  • Check if the interrupt's "return CS:IP" points to the area your code is in, and jump to the original BIOS interrupt handler if it's not
  • Check if the master PIC chip sent an "IRQ5" (by reading the PIC chip's "In Service Register" and checking bit 5), and if IRQ5 is in service jump to the original BIOS interrupt handler
  • Otherwise (if your code was interrupted and it's not an IRQ) assume the interrupt was caused by a general protection fault (which was caused by your code using unreal mode when segment limits have been restored unexpectedly), and re-enable unreal mode and return to the instruction that cause the general protection fault
That way, if anything ever does restore real mode segment limits your "interrupt 0x0D hook" will auto-fix the problem and continue as if nothing happened.
That's very much what I do in Smaller C's unreal mode. Except, I don't check CS:IP to belong to my code in #GP/IRQ5 handler. And I allow for nested #GP/IRQ5 handling. On the first invocation of the #GP/IRQ5 handler I check the IRQ5 ISR bit in the PIC. If it's set, I then call my custom handler which may do something or nothing and request the original handler to be invoked. If IRQ5 ISR is not set, it must be a #GP. On more deeply nested invocations (in reality, just one or we're screwed), I assume it's a #GP (triggered by the IRQ5 handler). This lets me use unreal mode code in all ISRs as well, including the IRQ5 ISR.
zq
Posts: 9
Joined: Wed May 10, 2017 7:00 pm
Libera.chat IRC: si

Re: run real mode code under unreal mode and A20 enable

Post by zq »

Brendan wrote:Hi,
zq wrote:As the title stated, will it be safe to run real mode code under unreal mode(large mode) and A20 line enable.
Because I need to R/W memory at high address and using some BIOS interupt function, will such config crash in BIOS call?
It's mostly safe, but (depending on which BIOS functions you use and a few other things) there's a (relatively small) chance that the BIOS will use protected mode and disable unreal mode (restore 64 KiB segment limits) when you're not expecting it. Note: This is most often a problem caused by network cards, RAID controllers and SCSI controllers that don't use (slow) IO ports; where the device's ROM has to enable protected mode to access the device's memory mapped registers.

To guard against that it's a nice idea to hook the BIOS "interrupt 0x0D" handler, where your code would:
  • Check if the interrupt's "return CS:IP" points to the area your code is in, and jump to the original BIOS interrupt handler if it's not
  • Check if the master PIC chip sent an "IRQ5" (by reading the PIC chip's "In Service Register" and checking bit 5), and if IRQ5 is in service jump to the original BIOS interrupt handler
  • Otherwise (if your code was interrupted and it's not an IRQ) assume the interrupt was caused by a general protection fault (which was caused by your code using unreal mode when segment limits have been restored unexpectedly), and re-enable unreal mode and return to the instruction that cause the general protection fault
That way, if anything ever does restore real mode segment limits your "interrupt 0x0D hook" will auto-fix the problem and continue as if nothing happened.


Cheers,

Brendan
You're right, there is also that occassion that BIOS will also use unreal mode and also restore the ds(or es) back to the limit 0xffff, so it is nessasary to do like you've stated.
User avatar
bluemoon
Member
Member
Posts: 1761
Joined: Wed Dec 01, 2010 3:41 am
Location: Hong Kong

Re: run real mode code under unreal mode and A20 enable

Post by bluemoon »

zq wrote:As the title stated, will it be safe to run real mode code under unreal mode(large mode) and A20 line enable.
Because I need to R/W memory at high address and using some BIOS interupt function, will such config crash in BIOS call?
For A20, it's designed for backward compatibility for those ancient software abusing wrapping at the end.
So if your real mode code rely on that, it's not safe. AFAIK BIOS should not rely on that, but BIOS can always surprise you.
Post Reply