2005-04-08 15:01:17 +00:00
|
|
|
#ifndef CONSOLE_H
|
|
|
|
#define CONSOLE_H
|
|
|
|
|
2006-04-24 15:42:49 +00:00
|
|
|
#include <gpxe/tables.h>
|
2005-04-08 15:01:17 +00:00
|
|
|
|
2005-05-20 10:24:11 +00:00
|
|
|
/** @file
|
|
|
|
*
|
|
|
|
* User interaction.
|
|
|
|
*
|
|
|
|
* Various console devices can be selected via the build options
|
|
|
|
* CONSOLE_FIRMWARE, CONSOLE_SERIAL etc. The console functions
|
|
|
|
* putchar(), getchar() and iskey() delegate to the individual console
|
|
|
|
* drivers.
|
|
|
|
*
|
2005-04-08 15:01:17 +00:00
|
|
|
*/
|
|
|
|
|
2005-05-20 10:24:11 +00:00
|
|
|
/**
|
|
|
|
* A console driver
|
|
|
|
*
|
|
|
|
* Defines the functions that implement a particular console type.
|
|
|
|
* Must be made part of the console drivers table by using
|
|
|
|
* #__console_driver.
|
|
|
|
*
|
2007-07-03 23:09:56 +01:00
|
|
|
* @note Consoles that cannot be used before their initialisation
|
|
|
|
* function has completed should set #disabled=1 initially. This
|
|
|
|
* allows other console devices to still be used to print out early
|
|
|
|
* debugging messages.
|
2005-05-20 10:24:11 +00:00
|
|
|
*
|
|
|
|
*/
|
2005-04-08 15:01:17 +00:00
|
|
|
struct console_driver {
|
2005-05-20 10:24:11 +00:00
|
|
|
/** Console is disabled.
|
|
|
|
*
|
2007-04-09 18:01:43 +00:00
|
|
|
* The console's putchar(), putline(), getchar() and iskey()
|
2007-07-03 23:09:56 +01:00
|
|
|
* methods will not be called while #disabled==1. Typically
|
|
|
|
* the console's initialisation functions will set #disabled=0
|
|
|
|
* upon completion.
|
2005-05-20 10:24:11 +00:00
|
|
|
*
|
|
|
|
*/
|
2005-04-08 15:01:17 +00:00
|
|
|
int disabled;
|
2005-05-20 10:24:11 +00:00
|
|
|
|
|
|
|
/** Write a character to the console.
|
|
|
|
*
|
|
|
|
* @v character Character to be written
|
2005-05-24 00:11:25 +00:00
|
|
|
* @ret None -
|
|
|
|
* @err None -
|
2005-05-20 10:24:11 +00:00
|
|
|
*
|
|
|
|
*/
|
2005-04-08 15:01:17 +00:00
|
|
|
void ( *putchar ) ( int character );
|
2005-05-20 10:24:11 +00:00
|
|
|
|
2007-04-09 18:01:43 +00:00
|
|
|
/** Write an entire line to the console.
|
|
|
|
* This is intended to be used by line-oriented output media,
|
|
|
|
* like system logging facilities or line printers.
|
|
|
|
* Line output will not contain non-printable characters.
|
|
|
|
*
|
|
|
|
* @v linebuffer Pointer to the \0-terminated line
|
|
|
|
* @ret None -
|
|
|
|
* @err None -
|
|
|
|
*/
|
|
|
|
void ( * putline ) ( unsigned char * linebuffer );
|
|
|
|
|
2005-05-20 10:24:11 +00:00
|
|
|
/** Read a character from the console.
|
|
|
|
*
|
2005-05-24 00:11:25 +00:00
|
|
|
* @v None -
|
2005-05-20 10:24:11 +00:00
|
|
|
* @ret character Character read
|
2005-05-24 00:11:25 +00:00
|
|
|
* @err None -
|
2005-05-20 10:24:11 +00:00
|
|
|
*
|
|
|
|
* If no character is available to be read, this method will
|
|
|
|
* block. The character read should not be echoed back to the
|
|
|
|
* console.
|
|
|
|
*
|
|
|
|
*/
|
2005-04-08 15:01:17 +00:00
|
|
|
int ( *getchar ) ( void );
|
2005-05-20 10:24:11 +00:00
|
|
|
|
|
|
|
/** Check for available input.
|
|
|
|
*
|
2005-05-24 00:11:25 +00:00
|
|
|
* @v None -
|
2005-05-20 10:24:11 +00:00
|
|
|
* @ret True Input is available
|
|
|
|
* @ret False Input is not available
|
2005-05-24 00:11:25 +00:00
|
|
|
* @err None -
|
2005-05-20 10:24:11 +00:00
|
|
|
*
|
|
|
|
* This should return True if a subsequent call to getchar()
|
|
|
|
* will not block.
|
|
|
|
*
|
|
|
|
*/
|
2005-04-08 15:01:17 +00:00
|
|
|
int ( *iskey ) ( void );
|
|
|
|
};
|
|
|
|
|
2005-05-20 10:24:11 +00:00
|
|
|
/**
|
|
|
|
* Mark a <tt> struct console_driver </tt> as being part of the
|
|
|
|
* console drivers table.
|
|
|
|
*
|
|
|
|
* Use as e.g.
|
|
|
|
*
|
|
|
|
* @code
|
|
|
|
*
|
|
|
|
* struct console_driver my_console __console_driver = {
|
|
|
|
* .putchar = my_putchar,
|
|
|
|
* .getchar = my_getchar,
|
|
|
|
* .iskey = my_iskey,
|
|
|
|
* };
|
|
|
|
*
|
|
|
|
* @endcode
|
|
|
|
*
|
|
|
|
*/
|
2007-01-10 04:22:09 +00:00
|
|
|
#define __console_driver __table ( struct console_driver, console, 01 )
|
2005-04-08 15:01:17 +00:00
|
|
|
|
|
|
|
/* Function prototypes */
|
|
|
|
|
|
|
|
extern void putchar ( int character );
|
|
|
|
extern int getchar ( void );
|
|
|
|
extern int iskey ( void );
|
2006-12-20 21:56:50 +00:00
|
|
|
extern int getkey ( void );
|
2005-04-08 15:01:17 +00:00
|
|
|
|
|
|
|
#endif /* CONSOLE_H */
|