2005-04-17 05:20:36 +07:00
|
|
|
/*
|
|
|
|
* fixmap.h: compile-time virtual memory allocation
|
|
|
|
*
|
|
|
|
* This file is subject to the terms and conditions of the GNU General Public
|
|
|
|
* License. See the file "COPYING" in the main directory of this archive
|
|
|
|
* for more details.
|
|
|
|
*
|
|
|
|
* Copyright (C) 1998 Ingo Molnar
|
|
|
|
*/
|
|
|
|
|
2008-04-25 23:25:25 +07:00
|
|
|
#ifndef _ASM_FIXMAP_64_H
|
|
|
|
#define _ASM_FIXMAP_64_H
|
2005-04-17 05:20:36 +07:00
|
|
|
|
|
|
|
#include <linux/kernel.h>
|
|
|
|
#include <asm/apicdef.h>
|
|
|
|
#include <asm/page.h>
|
|
|
|
#include <asm/vsyscall.h>
|
2008-01-30 19:31:19 +07:00
|
|
|
#include <asm/efi.h>
|
2005-04-17 05:20:36 +07:00
|
|
|
|
|
|
|
/*
|
|
|
|
* Here we define all the compile-time 'special' virtual
|
|
|
|
* addresses. The point is to have a constant address at
|
|
|
|
* compile time, but to set the physical address only
|
|
|
|
* in the boot process.
|
|
|
|
*
|
2007-07-21 22:11:21 +07:00
|
|
|
* These 'compile-time allocated' memory buffers are
|
|
|
|
* fixed-size 4k pages (or larger if used with an increment
|
|
|
|
* higher than 1). Use set_fixmap(idx,phys) to associate
|
2005-04-17 05:20:36 +07:00
|
|
|
* physical memory with fixmap indices.
|
|
|
|
*
|
|
|
|
* TLB entries of such buffers will not be flushed across
|
|
|
|
* task switches.
|
|
|
|
*/
|
|
|
|
|
|
|
|
enum fixed_addresses {
|
|
|
|
VSYSCALL_LAST_PAGE,
|
2008-03-23 15:02:10 +07:00
|
|
|
VSYSCALL_FIRST_PAGE = VSYSCALL_LAST_PAGE
|
|
|
|
+ ((VSYSCALL_END-VSYSCALL_START) >> PAGE_SHIFT) - 1,
|
2005-04-17 05:20:36 +07:00
|
|
|
VSYSCALL_HPET,
|
serial: convert early_uart to earlycon for 8250
Beacuse SERIAL_PORT_DFNS is removed from include/asm-i386/serial.h and
include/asm-x86_64/serial.h. the serial8250_ports need to be probed late in
serial initializing stage. the console_init=>serial8250_console_init=>
register_console=>serial8250_console_setup will return -ENDEV, and console
ttyS0 can not be enabled at that time. need to wait till uart_add_one_port in
drivers/serial/serial_core.c to call register_console to get console ttyS0.
that is too late.
Make early_uart to use early_param, so uart console can be used earlier. Make
it to be bootconsole with CON_BOOT flag, so can use console handover feature.
and it will switch to corresponding normal serial console automatically.
new command line will be:
console=uart8250,io,0x3f8,9600n8
console=uart8250,mmio,0xff5e0000,115200n8
or
earlycon=uart8250,io,0x3f8,9600n8
earlycon=uart8250,mmio,0xff5e0000,115200n8
it will print in very early stage:
Early serial console at I/O port 0x3f8 (options '9600n8')
console [uart0] enabled
later for console it will print:
console handover: boot [uart0] -> real [ttyS0]
Signed-off-by: <yinghai.lu@sun.com>
Cc: Andi Kleen <ak@suse.de>
Cc: Bjorn Helgaas <bjorn.helgaas@hp.com>
Cc: Russell King <rmk@arm.linux.org.uk>
Cc: Gerd Hoffmann <kraxel@suse.de>
Signed-off-by: Andrew Morton <akpm@linux-foundation.org>
Signed-off-by: Linus Torvalds <torvalds@linux-foundation.org>
2007-07-16 13:37:59 +07:00
|
|
|
FIX_DBGP_BASE,
|
|
|
|
FIX_EARLYCON_MEM_BASE,
|
2005-04-17 05:20:36 +07:00
|
|
|
FIX_HPET_BASE,
|
|
|
|
FIX_APIC_BASE, /* local (CPU) APIC) -- required for SMP or not */
|
|
|
|
FIX_IO_APIC_BASE_0,
|
2008-03-23 15:02:10 +07:00
|
|
|
FIX_IO_APIC_BASE_END = FIX_IO_APIC_BASE_0 + MAX_IO_APICS - 1,
|
2008-01-30 19:31:19 +07:00
|
|
|
FIX_EFI_IO_MAP_LAST_PAGE,
|
2008-03-23 15:02:10 +07:00
|
|
|
FIX_EFI_IO_MAP_FIRST_PAGE = FIX_EFI_IO_MAP_LAST_PAGE
|
|
|
|
+ MAX_EFI_IO_PAGES - 1,
|
x86: early boot debugging via FireWire (ohci1394_dma=early)
This patch adds a new configuration option, which adds support for a new
early_param which gets checked in arch/x86/kernel/setup_{32,64}.c:setup_arch()
to decide wether OHCI-1394 FireWire controllers should be initialized and
enabled for physical DMA access to allow remote debugging of early problems
like issues ACPI or other subsystems which are executed very early.
If the config option is not enabled, no code is changed, and if the boot
paramenter is not given, no new code is executed, and independent of that,
all new code is freed after boot, so the config option can be even enabled
in standard, non-debug kernels.
With specialized tools, it is then possible to get debugging information
from machines which have no serial ports (notebooks) such as the printk
buffer contents, or any data which can be referenced from global pointers,
if it is stored below the 4GB limit and even memory dumps of of the physical
RAM region below the 4GB limit can be taken without any cooperation from the
CPU of the host, so the machine can be crashed early, it does not matter.
In the extreme, even kernel debuggers can be accessed in this way. I wrote
a small kgdb module and an accompanying gdb stub for FireWire which allows
to gdb to talk to kgdb using remote remory reads and writes over FireWire.
An version of the gdb stub fore FireWire is able to read all global data
from a system which is running a a normal kernel without any kernel debugger,
without any interruption or support of the system's CPU. That way, e.g. the
task struct and so on can be read and even manipulated when the physical DMA
access is granted.
A HOWTO is included in this patch, in Documentation/debugging-via-ohci1394.txt
and I've put a copy online at
ftp://ftp.suse.de/private/bk/firewire/docs/debugging-via-ohci1394.txt
It also has links to all the tools which are available to make use of it
another copy of it is online at:
ftp://ftp.suse.de/private/bk/firewire/kernel/ohci1394_dma_early-v2.diff
Signed-Off-By: Bernhard Kaindl <bk@suse.de>
Tested-By: Thomas Renninger <trenn@suse.de>
Signed-off-by: Ingo Molnar <mingo@elte.hu>
Signed-off-by: Thomas Gleixner <tglx@linutronix.de>
2008-01-30 19:34:11 +07:00
|
|
|
#ifdef CONFIG_PROVIDE_OHCI1394_DMA_INIT
|
|
|
|
FIX_OHCI1394_BASE,
|
|
|
|
#endif
|
2005-04-17 05:20:36 +07:00
|
|
|
__end_of_fixed_addresses
|
|
|
|
};
|
|
|
|
|
2008-03-23 15:02:10 +07:00
|
|
|
extern void __set_fixmap(enum fixed_addresses idx,
|
|
|
|
unsigned long phys, pgprot_t flags);
|
2005-04-17 05:20:36 +07:00
|
|
|
|
2008-03-23 15:02:10 +07:00
|
|
|
#define set_fixmap(idx, phys) \
|
|
|
|
__set_fixmap(idx, phys, PAGE_KERNEL)
|
2005-04-17 05:20:36 +07:00
|
|
|
/*
|
|
|
|
* Some hardware wants to get fixmapped without caching.
|
|
|
|
*/
|
2008-03-23 15:02:10 +07:00
|
|
|
#define set_fixmap_nocache(idx, phys) \
|
|
|
|
__set_fixmap(idx, phys, PAGE_KERNEL_NOCACHE)
|
2005-04-17 05:20:36 +07:00
|
|
|
|
|
|
|
#define FIXADDR_TOP (VSYSCALL_END-PAGE_SIZE)
|
|
|
|
#define FIXADDR_SIZE (__end_of_fixed_addresses << PAGE_SHIFT)
|
|
|
|
#define FIXADDR_START (FIXADDR_TOP - FIXADDR_SIZE)
|
|
|
|
|
|
|
|
/* Only covers 32bit vsyscalls currently. Need another set for 64bit. */
|
|
|
|
#define FIXADDR_USER_START ((unsigned long)VSYSCALL32_VSYSCALL)
|
|
|
|
#define FIXADDR_USER_END (FIXADDR_USER_START + PAGE_SIZE)
|
|
|
|
|
|
|
|
#define __fix_to_virt(x) (FIXADDR_TOP - ((x) << PAGE_SHIFT))
|
|
|
|
|
|
|
|
extern void __this_fixmap_does_not_exist(void);
|
|
|
|
|
|
|
|
/*
|
|
|
|
* 'index to address' translation. If anyone tries to use the idx
|
|
|
|
* directly without translation, we catch the bug with a NULL-deference
|
|
|
|
* kernel oops. Illegal ranges of incoming indices are caught too.
|
|
|
|
*/
|
2006-01-15 04:21:30 +07:00
|
|
|
static __always_inline unsigned long fix_to_virt(const unsigned int idx)
|
2005-04-17 05:20:36 +07:00
|
|
|
{
|
|
|
|
/*
|
|
|
|
* this branch gets completely eliminated after inlining,
|
|
|
|
* except when someone tries to use fixaddr indices in an
|
|
|
|
* illegal way. (such as mixing up address types or using
|
|
|
|
* out-of-range indices).
|
|
|
|
*
|
|
|
|
* If it doesn't get removed, the linker will complain
|
|
|
|
* loudly with a reasonably clear error message..
|
|
|
|
*/
|
|
|
|
if (idx >= __end_of_fixed_addresses)
|
|
|
|
__this_fixmap_does_not_exist();
|
|
|
|
|
serial: convert early_uart to earlycon for 8250
Beacuse SERIAL_PORT_DFNS is removed from include/asm-i386/serial.h and
include/asm-x86_64/serial.h. the serial8250_ports need to be probed late in
serial initializing stage. the console_init=>serial8250_console_init=>
register_console=>serial8250_console_setup will return -ENDEV, and console
ttyS0 can not be enabled at that time. need to wait till uart_add_one_port in
drivers/serial/serial_core.c to call register_console to get console ttyS0.
that is too late.
Make early_uart to use early_param, so uart console can be used earlier. Make
it to be bootconsole with CON_BOOT flag, so can use console handover feature.
and it will switch to corresponding normal serial console automatically.
new command line will be:
console=uart8250,io,0x3f8,9600n8
console=uart8250,mmio,0xff5e0000,115200n8
or
earlycon=uart8250,io,0x3f8,9600n8
earlycon=uart8250,mmio,0xff5e0000,115200n8
it will print in very early stage:
Early serial console at I/O port 0x3f8 (options '9600n8')
console [uart0] enabled
later for console it will print:
console handover: boot [uart0] -> real [ttyS0]
Signed-off-by: <yinghai.lu@sun.com>
Cc: Andi Kleen <ak@suse.de>
Cc: Bjorn Helgaas <bjorn.helgaas@hp.com>
Cc: Russell King <rmk@arm.linux.org.uk>
Cc: Gerd Hoffmann <kraxel@suse.de>
Signed-off-by: Andrew Morton <akpm@linux-foundation.org>
Signed-off-by: Linus Torvalds <torvalds@linux-foundation.org>
2007-07-16 13:37:59 +07:00
|
|
|
return __fix_to_virt(idx);
|
2005-04-17 05:20:36 +07:00
|
|
|
}
|
|
|
|
|
|
|
|
#endif
|