/* * Copyright (c) 2007, Kohsuke Ohtani * All rights reserved. * * Redistribution and use in source and binary forms, with or without * modification, are permitted provided that the following conditions * are met: * 1. Redistributions of source code must retain the above copyright * notice, this list of conditions and the following disclaimer. * 2. Redistributions in binary form must reproduce the above copyright * notice, this list of conditions and the following disclaimer in the * documentation and/or other materials provided with the distribution. * 3. Neither the name of the author nor the names of any co-contributors * may be used to endorse or promote products derived from this software * without specific prior written permission. * * THIS SOFTWARE IS PROVIDED BY THE AUTHOR AND CONTRIBUTORS ``AS IS'' AND * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE * ARE DISCLAIMED. IN NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS BE LIABLE * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF * SUCH DAMAGE. */ #ifndef _PC_PLATFORM_H #define _PC_PLATFORM_H /* * Memory location */ #ifdef CONFIG_MMU #define PAGE_OFFSET 0x80000000 #else #define PAGE_OFFSET 0x00000000 #endif #define KERNEL_BASE PAGE_OFFSET #define KERNEL_MAX 0xffffffff #define USER_BASE 0x00000000 #define USER_MAX 0x80000000 #define BOOT_PTE0 0x00001000 #define INT_STACK 0x00001000 #define BOOT_INFO 0x00002000 #define BOOT_STACK 0x00002800 #define KERNEL_PGD 0x00003000 #ifdef CONFIG_MMU #define RESERVED_BASE 0x00000000 #define RESERVED_MAX 0x00004000 #else #define RESERVED_BASE 0x00000000 #define RESERVED_MAX 0x00003000 #endif #ifndef __ASSEMBLY__ /* * Page mapping */ #define phys_to_virt(pa) (void *)((paddr_t)(pa) + PAGE_OFFSET) #define virt_to_phys(va) (void *)((vaddr_t)(va) - PAGE_OFFSET) /* * Kernel/User Locations */ #if KERNEL_BASE == 0 #define kern_area(addr) 1 #else #define kern_area(addr) ((vaddr_t)(addr) >= (vaddr_t)KERNEL_BASE) #endif #define user_area(addr) ((vaddr_t)(addr) < (vaddr_t)USER_MAX) /* * Interrupt */ #define NIRQS 16 /* number of interrupt vectors */ extern void interrupt_enable(void); extern void interrupt_disable(void); extern void interrupt_save(int *); extern void interrupt_restore(int); extern void interrupt_mask(int); extern void interrupt_unmask(int, int); extern void interrupt_setup(int, int); extern void interrupt_handler(struct cpu_regs *); extern void interrupt_init(void); /* Interrupt mode for interrupt_setup() */ #define IMODE_EDGE 0 /* edge trigger */ #define IMODE_LEVEL 1 /* level trigger */ extern void clock_init(void); extern void diag_init(void); extern void diag_print(char *); extern void machine_reset(void); extern void machine_init(void); extern void machine_idle(void); #endif /* !__ASSEMBLY__ */ #endif /* !_PC_PLATFORM_H */