1 /* 2 * (C) Copyright 2002 3 * Daniel Engström, Omicron Ceti AB, daniel@omicron.se. 4 * 5 * See file CREDITS for list of people who contributed to this 6 * project. 7 * 8 * This program is free software; you can redistribute it and/or 9 * modify it under the terms of the GNU General Public License as 10 * published by the Free Software Foundation; either version 2 of 11 * the License, or (at your option) any later version. 12 * 13 * This program is distributed in the hope that it will be useful, 14 * but WITHOUT ANY WARRANTY; without even the implied warranty of 15 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the 16 * GNU General Public License for more details. 17 * 18 * You should have received a copy of the GNU General Public License 19 * along with this program; if not, write to the Free Software 20 * Foundation, Inc., 59 Temple Place, Suite 330, Boston, 21 * MA 02111-1307 USA 22 */ 23 24 #ifndef _U_BOOT_I386_H_ 25 #define _U_BOOT_I386_H_ 1 26 27 /* Exports from the Linker Script */ 28 extern ulong __text_start; 29 extern ulong __data_end; 30 extern ulong __rel_dyn_start; 31 extern ulong __rel_dyn_end; 32 extern ulong __bss_start; 33 extern ulong __bss_end; 34 extern ulong _end; 35 36 /* cpu/.../cpu.c */ 37 int x86_cpu_init_r(void); 38 int cpu_init_r(void); 39 int x86_cpu_init_f(void); 40 int cpu_init_f(void); 41 void init_gd(gd_t *id, u64 *gdt_addr); 42 void setup_gdt(gd_t *id, u64 *gdt_addr); 43 int init_cache(void); 44 int cleanup_before_linux(void); 45 46 /* cpu/.../timer.c */ 47 void timer_isr(void *); 48 typedef void (timer_fnc_t) (void); 49 int register_timer_isr (timer_fnc_t *isr_func); 50 51 /* Architecture specific - can be in arch/x86/cpu/, arch/x86/lib/, or $(BOARD)/ */ 52 int dram_init_f(void); 53 54 /* cpu/.../interrupts.c */ 55 int cpu_init_interrupts(void); 56 57 /* board/.../... */ 58 int dram_init(void); 59 60 void setup_pcat_compatibility(void); 61 62 void isa_unmap_rom(u32 addr); 63 u32 isa_map_rom(u32 bus_addr, int size); 64 65 /* arch/x86/lib/... */ 66 int video_bios_init(void); 67 68 void board_init_f_r_trampoline(ulong) __attribute__ ((noreturn)); 69 void board_init_f_r(void) __attribute__ ((noreturn)); 70 71 /* Read the time stamp counter */ 72 static inline uint64_t rdtsc(void) 73 { 74 uint32_t high, low; 75 __asm__ __volatile__("rdtsc" : "=a" (low), "=d" (high)); 76 return (((uint64_t)high) << 32) | low; 77 } 78 79 /* board/... */ 80 void timer_set_tsc_base(uint64_t new_base); 81 uint64_t timer_get_tsc(void); 82 83 #endif /* _U_BOOT_I386_H_ */ 84