Page 1 of 1

keyboard buffer

Posted: Tue Mar 04, 2003 7:46 pm
by elias
i had a thought when reading about keyboard programming. if whenever a keystroke occurs, its translated to ASCII by the driver and stored in the keyboard buffer, and the keyboard buffer is circular, this means that if a program dosnt read from the kbd(the buffer in this case), the data is lost because it will be overwritten from too many keystrokes. is there any way around this? how big is the kbd buffer in most OSes?

Re:keyboard buffer

Posted: Tue Mar 04, 2003 10:41 pm
by stonedzealot
Well, the best way to handle this, in my opinion, is to give the character to the program that the user is typing into. For example, at the OS's command line, you'd pass the char to the command line handler, who'd then print the character to the screen (next to the command line) and then add the char onto the string/array of chars that holds the part of the command that has been typed so far.

Re:keyboard buffer

Posted: Wed Mar 05, 2003 2:58 am
by DarylD
Yes, just use events or messages to send the keyboard command.

In my OS I have a RequestFocus module call which will tell the keyboard driver where to send the keystrokes.

Daryl.

Re:keyboard buffer

Posted: Wed Mar 05, 2003 5:24 am
by Rico Sanchez
When a keyboard interrupt occurs. Do you all the keyboard handling, such as converting the keystroke to an ASCII character and sending it to the right program, in the ISR. Or do you only put the keystroke in a buffer as the ISR and that another part of the system (kernel or keyboard task) futher handles the keyboard handling. It seems to me that keeping the ISRs as short as possible is the best sollution so that other interrupts can be handled faster (at the ISR level), or would this be too much overhead?

Re:keyboard buffer

Posted: Wed Mar 05, 2003 8:30 am
by distantvoices
I have my keyboard Interrupt service routine put scancodes into a circular buffer, and from this buffer, another function which is called kbd_read, fetches the codes, translates them to characters or metakeys, and hands the characters over to the function which has requested them. Thus, I keep the ISR neat, short and simple.

I have learned to do it this way from tanenbaums os book.

stay safe

Re:keyboard buffer

Posted: Wed Mar 05, 2003 5:24 pm
by elias
this was what im planning to do too. but how big is your circular buffer? and my only prob is, wat happens if it overwrites itself?