2005-03-08 18:53:11 +00:00
|
|
|
/* Etherboot routines for PCBIOS firmware.
|
|
|
|
*
|
|
|
|
* Body of routines taken from old pcbios.S
|
|
|
|
*/
|
|
|
|
|
2006-05-13 11:43:07 +00:00
|
|
|
#include <stdint.h>
|
|
|
|
#include <realmode.h>
|
|
|
|
#include <bios.h>
|
2005-03-08 18:53:11 +00:00
|
|
|
|
|
|
|
#define CF ( 1 << 0 )
|
|
|
|
|
|
|
|
/**************************************************************************
|
|
|
|
CURRTICKS - Get Time
|
|
|
|
Use direct memory access to BIOS variables, longword 0040:006C (ticks
|
|
|
|
today) and byte 0040:0070 (midnight crossover flag) instead of calling
|
|
|
|
timeofday BIOS interrupt.
|
|
|
|
**************************************************************************/
|
|
|
|
#if defined(CONFIG_TSC_CURRTICKS)
|
|
|
|
#undef CONFIG_BIOS_CURRTICKS
|
|
|
|
#else
|
|
|
|
#define CONFIG_BIOS_CURRTICKS 1
|
|
|
|
#endif
|
|
|
|
#if defined(CONFIG_BIOS_CURRTICKS)
|
2005-04-08 15:01:17 +00:00
|
|
|
unsigned long currticks ( void ) {
|
2005-03-08 18:53:11 +00:00
|
|
|
static uint32_t days = 0;
|
2005-04-08 15:01:17 +00:00
|
|
|
uint32_t ticks;
|
|
|
|
uint8_t midnight;
|
2005-03-08 18:53:11 +00:00
|
|
|
|
|
|
|
/* Re-enable interrupts so that the timer interrupt can occur
|
|
|
|
*/
|
2005-04-08 15:01:17 +00:00
|
|
|
REAL_EXEC ( rm_currticks,
|
|
|
|
"sti\n\t"
|
|
|
|
"nop\n\t"
|
|
|
|
"nop\n\t"
|
|
|
|
"cli\n\t",
|
|
|
|
0,
|
|
|
|
OUT_CONSTRAINTS (),
|
|
|
|
IN_CONSTRAINTS (),
|
|
|
|
CLOBBER ( "eax" ) ); /* can't have an empty clobber list */
|
|
|
|
|
2006-05-13 11:43:07 +00:00
|
|
|
get_real ( ticks, BDA_SEG, 0x006c );
|
|
|
|
get_real ( midnight, BDA_SEG, 0x0070 );
|
2005-04-08 15:01:17 +00:00
|
|
|
|
|
|
|
if ( midnight ) {
|
|
|
|
midnight = 0;
|
2006-05-13 11:43:07 +00:00
|
|
|
put_real ( midnight, BDA_SEG, 0x0070 );
|
2005-03-08 18:53:11 +00:00
|
|
|
days += 0x1800b0;
|
|
|
|
}
|
2005-04-08 15:01:17 +00:00
|
|
|
return ( days + ticks );
|
2005-03-08 18:53:11 +00:00
|
|
|
}
|
|
|
|
#endif /* CONFIG_BIOS_CURRTICKS */
|
|
|
|
|
|
|
|
/**************************************************************************
|
|
|
|
CPU_NAP - Save power by halting the CPU until the next interrupt
|
|
|
|
**************************************************************************/
|
2005-04-08 15:01:17 +00:00
|
|
|
void cpu_nap ( void ) {
|
|
|
|
REAL_EXEC ( rm_cpu_nap,
|
|
|
|
"sti\n\t"
|
|
|
|
"hlt\n\t"
|
|
|
|
"cli\n\t",
|
|
|
|
0,
|
|
|
|
OUT_CONSTRAINTS (),
|
|
|
|
IN_CONSTRAINTS (),
|
|
|
|
CLOBBER ( "eax" ) ); /* can't have an empty clobber list */
|
2005-03-08 18:53:11 +00:00
|
|
|
}
|