Page 4 of 5

Re: IRQ Firing Bug

Posted: Wed Jul 27, 2016 3:15 pm
by BrightLight
SpyderTL wrote:Any time you see repeated three stacked horizontal lines followed by an S, you are printing your 16-bit Interrupt Table to the screen. This is likely because you are passing a null to a draw string function, so it is drawing everything from RAM address zero until it finds a null value.
Which is why we use paging to prevent this. ;)

Re: IRQ Firing Bug

Posted: Thu Jul 28, 2016 12:09 pm
by Octacone
Ch4ozz wrote:Your drawstring function probably draws a string but your passing single characters to it which simply wont work.
Either code a proper printf function and you can use

Code: Select all

printf("%c", kbdus[keycode]);
or you find another solution.
Damn, that is not good.
How my PrintString functions works:
1. PrintString gets called: PrintString("abc123");
2. PrintString has a loop, foreach char inside that loop it calls another function called PrintCharacter.
3. PrintCharacter prints given char with wanted color using 0xB8000

Re: IRQ Firing Bug

Posted: Thu Jul 28, 2016 12:15 pm
by Octacone
SpyderTL wrote:
thehardcoreOS wrote:Should I use SendEOI Inside my kbd and timer handlers?
Yes. You should notify the master PIC any time it signals an IRQ (0-7), and notify both the master and slave PIC when the slave PIC signals an IRQ (8-15). Any IRQs that you have unmasked should have valid interrupt handlers that will notify the proper PICs installed before you unmask them.
thehardcoreOS wrote:When I enable while(1) loop I can use my timer and my keyboard. But I get these weird glyphs:
Any time you see repeated three stacked horizontal lines followed by an S, you are printing your 16-bit Interrupt Table to the screen. This is likely because you are passing a null to a draw string function, so it is drawing everything from RAM address zero until it finds a null value.

That's my guess.

(I get this a lot, by the way.. :))

I see you get this a lot. You seem to be interrupts expert. 8)

Hmm, about that slave master EOI sending etc, I already have that function inside my IRQ_Handler that does the same exact thing, to just copy paste it inside my Keyboard_Handler and Timer_Handler? :?

What do you mean by it prints 16bit interrupt table? I don't think so, because it prints only what I tell it to print. Little bit confused in there. :?: :?: :?: Drawing from RAM??? I don't have any kind of memory management set up and I don't interact with RAM as fair as I know, or maybe I do? :?:

Re: IRQ Firing Bug

Posted: Thu Jul 28, 2016 12:18 pm
by Octacone
omarrx024 wrote:
SpyderTL wrote:Any time you see repeated three stacked horizontal lines followed by an S, you are printing your 16-bit Interrupt Table to the screen. This is likely because you are passing a null to a draw string function, so it is drawing everything from RAM address zero until it finds a null value.
Which is why we use paging to prevent this. ;)
It is sad that I still don't have any kind of memory management. Paging is my next big thing on the list.
Also I already know that: string paging; paging = "hell". :oops: :D

Re: IRQ Firing Bug

Posted: Fri Jul 29, 2016 1:34 am
by BrightLight
thehardcoreOS wrote:It is sad that I still don't have any kind of memory management. Paging is my next big thing on the list.
Also I already know that: string paging; paging = "hell". :oops: :D
Paging is actually very easy; but beginners to it seem to think it's difficult and I thought so myself. :P

Re: IRQ Firing Bug

Posted: Fri Jul 29, 2016 6:30 am
by SpyderTL
thehardcoreOS wrote:Hmm, about that slave master EOI sending etc, I already have that function inside my IRQ_Handler that does the same exact thing, to just copy paste it inside my Keyboard_Handler and Timer_Handler? :?

What do you mean by it prints 16bit interrupt table? I don't think so, because it prints only what I tell it to print. Little bit confused in there. :?: :?: :?: Drawing from RAM??? I don't have any kind of memory management set up and I don't interact with RAM as fair as I know, or maybe I do? :?:
What I meant to say is that whenever I see that pattern on the screen, with three horizontal lines and an S, it looks like what you would see if you copied the bytes starting at RAM address zero to the screen.

RAM address 0000:0000 is where the interrupt handler table is located when the machine first boots. My guess is that you are (accidentally) passing the wrong address to your print string function, and from the looks of the screen, I'm guessing that your print string function is attempting to draw whatever string is sitting at memory address zero.

Maybe that is a hint to help you track down the actual problem, but I could be wrong.
Hmm, about that slave master EOI sending etc, I already have that function inside my IRQ_Handler that does the same exact thing, to just copy paste it inside my Keyboard_Handler and Timer_Handler?
No, you only have to send the EOI once per interrupt (for each PIC, of course). Your original code looks like you were sending it twice per interrupt. I'm assuming that's fixed now.

Re: IRQ Firing Bug

Posted: Fri Jul 29, 2016 6:44 am
by onlyonemac
SpyderTL wrote:What I meant to say is that whenever I see that pattern on the screen, with three horizontal lines and an S, it looks like what you would see if you copied the bytes starting at RAM address zero to the screen.
Oh, so that's why I always get an S when I pass a NULL pointer to a string output function in my kernel, I never realised that. Not that it's a problem, just fascinating.

Re: IRQ Firing Bug

Posted: Fri Jul 29, 2016 7:02 am
by Octacone
onlyonemac wrote:
SpyderTL wrote:What I meant to say is that whenever I see that pattern on the screen, with three horizontal lines and an S, it looks like what you would see if you copied the bytes starting at RAM address zero to the screen.
Oh, so that's why I always get an S when I pass a NULL pointer to a string output function in my kernel, I never realised that. Not that it's a problem, just fascinating.
lol, never tried printing an empty string. :| fascinating yeah :shock:

Re: IRQ Firing Bug

Posted: Fri Jul 29, 2016 8:10 am
by SpyderTL
There is a difference between passing a null address and passing an address to an empty string. If I had to guess, I'd say that your code is passing a null address.

Re: IRQ Firing Bug

Posted: Fri Jul 29, 2016 12:32 pm
by Octacone
SpyderTL wrote:There is a difference between passing a null address and passing an address to an empty string. If I had to guess, I'd say that your code is passing a null address.
No worries, I fixed it.
For all future generations reading this: don't be stupid like me and instead of PrintStringFunction use PrintCharacterFunction and everything should be just fine. ;)

Re: IRQ Firing Bug

Posted: Fri Jul 29, 2016 2:21 pm
by Ch4ozz
thehardcoreOS wrote:
SpyderTL wrote:There is a difference between passing a null address and passing an address to an empty string. If I had to guess, I'd say that your code is passing a null address.
No worries, I fixed it.
For all future generations reading this: don't be stupid like me and instead of PrintStringFunction use PrintCharacterFunction and everything should be just fine. ;)
Thats what I told you before didnt I? :D

Re: IRQ Firing Bug

Posted: Fri Jul 29, 2016 3:53 pm
by Octacone
omarrx024 wrote:
thehardcoreOS wrote:It is sad that I still don't have any kind of memory management. Paging is my next big thing on the list.
Also I already know that: string paging; paging = "hell". :oops: :D
Paging is actually very easy; but beginners to it seem to think it's difficult and I thought so myself. :P
ROFL, paging is easy. We shall see. :D :P

Re: IRQ Firing Bug

Posted: Fri Jul 29, 2016 3:54 pm
by Octacone
Ch4ozz wrote:
thehardcoreOS wrote:
SpyderTL wrote:There is a difference between passing a null address and passing an address to an empty string. If I had to guess, I'd say that your code is passing a null address.
No worries, I fixed it.
For all future generations reading this: don't be stupid like me and instead of PrintStringFunction use PrintCharacterFunction and everything should be just fine. ;)
Thats what I told you before didnt I? :D
Hmm... Did you? :D Lol, I forgot. oops :oops:

Re: IRQ Firing Bug

Posted: Fri Jul 29, 2016 3:57 pm
by Octacone
SpyderTL wrote:
thehardcoreOS wrote:Hmm, about that slave master EOI sending etc, I already have that function inside my IRQ_Handler that does the same exact thing, to just copy paste it inside my Keyboard_Handler and Timer_Handler? :?

What do you mean by it prints 16bit interrupt table? I don't think so, because it prints only what I tell it to print. Little bit confused in there. :?: :?: :?: Drawing from RAM??? I don't have any kind of memory management set up and I don't interact with RAM as fair as I know, or maybe I do? :?:
What I meant to say is that whenever I see that pattern on the screen, with three horizontal lines and an S, it looks like what you would see if you copied the bytes starting at RAM address zero to the screen.

RAM address 0000:0000 is where the interrupt handler table is located when the machine first boots. My guess is that you are (accidentally) passing the wrong address to your print string function, and from the looks of the screen, I'm guessing that your print string function is attempting to draw whatever string is sitting at memory address zero.

Maybe that is a hint to help you track down the actual problem, but I could be wrong.
Hmm, about that slave master EOI sending etc, I already have that function inside my IRQ_Handler that does the same exact thing, to just copy paste it inside my Keyboard_Handler and Timer_Handler?
No, you only have to send the EOI once per interrupt (for each PIC, of course). Your original code looks like you were sending it twice per interrupt. I'm assuming that's fixed now.
Now, I get it. Thanks for explaining. I send EOI only once per interrupts as supposed to, everything works just okay. ;)

Re: IRQ Firing Bug

Posted: Mon Aug 01, 2016 6:49 am
by ajxs
omarrx024 wrote:

Code: Select all

void ps2_wait_write()
{
	while(inb(0x64) & 2 == 0);
}

void ps2_wait_read()
{
	while(inb(0x64) & 1 == 0);
}
Are you positive this works as intended?
Shouldn't this be:

Code: Select all

void ps2_wait_write()
{
	while((inb(0x64) & 2) != 0);
}

void ps2_wait_read()
{
	while((inb(0x64) & 1) != 0);
}
You'll need to add the extra set of (...) brackets, since ==/!= operators have a higher precedence than bitwise operators, so the condition for the while loop in your wait functions won't ever be satisfied. ( depending on how your compiler interprets this. gcc actually generates a warning from your code with -Wall )