2008-10-23 13:26:29 +08:00
|
|
|
#ifndef _ASM_X86_BIOS_EBDA_H
|
|
|
|
#define _ASM_X86_BIOS_EBDA_H
|
2005-04-17 06:20:36 +08:00
|
|
|
|
2008-04-19 22:55:18 +08:00
|
|
|
#include <asm/io.h>
|
|
|
|
|
2005-04-17 06:20:36 +08:00
|
|
|
/*
|
|
|
|
* there is a real-mode segmented pointer pointing to the
|
|
|
|
* 4K EBDA area at 0x40E.
|
|
|
|
*/
|
|
|
|
static inline unsigned int get_bios_ebda(void)
|
|
|
|
{
|
|
|
|
unsigned int address = *(unsigned short *)phys_to_virt(0x40E);
|
|
|
|
address <<= 4;
|
|
|
|
return address; /* 0 means none */
|
|
|
|
}
|
|
|
|
|
2011-03-15 14:58:45 +08:00
|
|
|
/*
|
|
|
|
* Return the sanitized length of the EBDA in bytes, if it exists.
|
|
|
|
*/
|
|
|
|
static inline unsigned int get_bios_ebda_length(void)
|
|
|
|
{
|
|
|
|
unsigned int address;
|
|
|
|
unsigned int length;
|
|
|
|
|
|
|
|
address = get_bios_ebda();
|
|
|
|
if (!address)
|
|
|
|
return 0;
|
|
|
|
|
|
|
|
/* EBDA length is byte 0 of the EBDA (stored in KiB) */
|
|
|
|
length = *(unsigned char *)phys_to_virt(address);
|
|
|
|
length <<= 10;
|
|
|
|
|
|
|
|
/* Trim the length if it extends beyond 640KiB */
|
|
|
|
length = min_t(unsigned int, (640 * 1024) - address, length);
|
|
|
|
return length;
|
|
|
|
}
|
|
|
|
|
2008-06-02 14:26:23 +08:00
|
|
|
void reserve_ebda_region(void);
|
|
|
|
|
2008-10-12 21:06:29 +08:00
|
|
|
#ifdef CONFIG_X86_CHECK_BIOS_CORRUPTION
|
|
|
|
/*
|
|
|
|
* This is obviously not a great place for this, but we want to be
|
|
|
|
* able to scatter it around anywhere in the kernel.
|
|
|
|
*/
|
|
|
|
void check_for_bios_corruption(void);
|
|
|
|
void start_periodic_check_for_corruption(void);
|
|
|
|
#else
|
|
|
|
static inline void check_for_bios_corruption(void)
|
|
|
|
{
|
|
|
|
}
|
|
|
|
|
|
|
|
static inline void start_periodic_check_for_corruption(void)
|
|
|
|
{
|
|
|
|
}
|
|
|
|
#endif
|
|
|
|
|
2008-10-23 13:26:29 +08:00
|
|
|
#endif /* _ASM_X86_BIOS_EBDA_H */
|