Following the baby steps tutorial, why does this code work?

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
handuel
Posts: 9
Joined: Thu Jul 05, 2012 10:44 am

Following the baby steps tutorial, why does this code work?

Post by handuel »

Hi, another noob here, so sorry if I'm not to quick to grasp some stuff, (don't worry I know some basic OS theory though, I'm not coming here from nothing). Anyway, I've been following the babystep tutorials on the wiki (which are very good by the way, thankyou whoever wrote them), and have reached number 4. The code inside it is pretty basic, and I understand most of it, however there are a few lines in the printreg16 "function" that I don't understand. Here is the code for people to look at: http://wiki.osdev.org/Babystep4
I could just copy and paste the lines in, but I somehow doubt that will help me learn. The lines are these

rol ax, 4
mov bx, ax
and bx, 0x0f
mov bl, [si + bx]
mov [di], bl

this is part of a loop that loops for 4 times (1 for each character, as 16 bit registers have 4 digits when written in hex) and the register we are attempting to print's higher byte is the color attribute, and it's lower byte is the character.

My question is, too get the hex value of the character, why does the lines that I have pasted work. I know what each individual instruction does, but I can't seem to figure why that would find the hex value of the character. Can anyone tell me why.
User avatar
Brendan
Member
Member
Posts: 8561
Joined: Sat Jan 15, 2005 12:00 am
Location: At his keyboard!
Contact:

Re: Following the baby steps tutorial, why does this code wo

Post by Brendan »

Hi,
handuel wrote:My question is, too get the hex value of the character, why does the lines that I have pasted work.
I'd assume that DS:SI points to an array of 16 characters (e.g. "0123456789ABCDEF"); and the line "mov bl, [si + bx]" fetches a character from this array.

The only other slightly tricky part is "rol ax, 4", which rotates the value so that the highest 4 bits become the new lowest 4 bits. The equivalent in C would be "value = (value << 4) | (value >> 28);".


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.
handuel
Posts: 9
Joined: Thu Jul 05, 2012 10:44 am

Re: Following the baby steps tutorial, why does this code wo

Post by handuel »

Thankyou very much, I've worked it out know, and you explaining about the array helped me a lot. Thanks for the quick reply :D
Post Reply