Moving from real mode to protected mode

Programming, for all ages and all languages.
Post Reply
User avatar
hometue
Member
Member
Posts: 100
Joined: Thu Dec 19, 2013 1:40 am
Location: Asia, Singapore

Moving from real mode to protected mode

Post by hometue »

Hi guys, I am now programming my code and what I am doing now is I am going to switch to protected mode (yeah, I know, if you check my OS its been a lotta commits yet I am still on real mode #-o ...moving on :arrow: ). However, before I do so, I want to know how different it is coding for real mode and coding for protected mode (I heard data access is different but how is it different in C, also any other things I need to take note of? :?: ) Thanks :)
CookieOS. Want a cookie? Its only black and white for now though, probably as bad as my baking skills.
User avatar
Love4Boobies
Member
Member
Posts: 2111
Joined: Fri Mar 07, 2008 5:36 pm
Location: Bucharest, Romania

Re: Moving from real mode to protected mode

Post by Love4Boobies »

The point of using abstract machines, like C, is that they have their own rules which implementations map to the underlying environment (this mapping is called an ABI). In other words, your code should look the same regardless of which mode your CPU is in. It's just that your compiler will need to target whatever environment you wish to run your code under. However, any assembly code will obviously be different.
"Computers in the future may weigh no more than 1.5 tons.", Popular Mechanics (1949)
[ Project UDI ]
User avatar
hometue
Member
Member
Posts: 100
Joined: Thu Dec 19, 2013 1:40 am
Location: Asia, Singapore

Re: Moving from real mode to protected mode

Post by hometue »

Ah...I see. Btw, to switch to protected mode is it fine to just put it in inline assembly(since I know C compiler will change it slightly so will this affect the result?). Also is there a way to check if the change went successfully (any address in the bios data area or any register to check). Thanks so much (since it seems to me that it is really important to switch to protected mode) :D .
CookieOS. Want a cookie? Its only black and white for now though, probably as bad as my baking skills.
User avatar
Love4Boobies
Member
Member
Posts: 2111
Joined: Fri Mar 07, 2008 5:36 pm
Location: Bucharest, Romania

Re: Moving from real mode to protected mode

Post by Love4Boobies »

hometue wrote:Ah...I see. Btw, to switch to protected mode is it fine to just put it in inline assembly(since I know C compiler will change it slightly so will this affect the result?).
I would recommend separate files for your assembly code for a couple of reasons. First, your source code will be easier to maintain if and when you decide to support multiple architectures. Secondly, it will give you the opportunity to use various C compilers (since the "asm" keyboard is a non-standard extension, it's often implemented in incompatible ways). Regarding the compiler modifying your assembly, some do others don't so be sure to check its documentation.
hometue wrote:Also is there a way to check if the change went successfully (any address in the bios data area or any register to check).
Why do you assume this is something that can fail, provided you write your code correctly? If it does fail, you'll probably be in enough trouble that you won't be able to check anything. And even if you won't, you'd need to have a pretty unusual setup in order for your protected mode code to have the same meaning as it would in real mode. You'd need to run the same code in both cases, right?

Also, the BIOS will probaby be unaware you changed to protected mode.
"Computers in the future may weigh no more than 1.5 tons.", Popular Mechanics (1949)
[ Project UDI ]
Post Reply