X-Git-Url: http://git.rot13.org/?a=blobdiff_plain;f=include%2Fasm-x86%2Fdmi.h;h=1241e6ad1935b99c6273554eb8501f05833b28cb;hb=9135f1901ee6449dfe338adf6e40e9c2025b8150;hp=c9e4e8ebc2708611c18bf367ffe94cad1e64fed9;hpb=dd6d1844af33acb4edd0a40b1770d091a22c94be;p=powerpc.git diff --git a/include/asm-x86/dmi.h b/include/asm-x86/dmi.h index c9e4e8ebc2..1241e6ad19 100644 --- a/include/asm-x86/dmi.h +++ b/include/asm-x86/dmi.h @@ -1,5 +1,33 @@ +#ifndef _ASM_X86_DMI_H +#define _ASM_X86_DMI_H + +#include + #ifdef CONFIG_X86_32 -# include "dmi_32.h" -#else -# include "dmi_64.h" + +#define dmi_alloc alloc_bootmem + +#else /* CONFIG_X86_32 */ + +#define DMI_MAX_DATA 2048 + +extern int dmi_alloc_index; +extern char dmi_alloc_data[DMI_MAX_DATA]; + +/* This is so early that there is no good way to allocate dynamic memory. + Allocate data in an BSS array. */ +static inline void *dmi_alloc(unsigned len) +{ + int idx = dmi_alloc_index; + if ((dmi_alloc_index + len) > DMI_MAX_DATA) + return NULL; + dmi_alloc_index += len; + return dmi_alloc_data + idx; +} + +#endif + +#define dmi_ioremap early_ioremap +#define dmi_iounmap early_iounmap + #endif