mirror of
https://mirrors.bfsu.edu.cn/git/linux.git
synced 2024-12-23 02:54:32 +08:00
e6449c9b2d
The missing NULL terminator can cause a panic on PPC405 boards during boot: Linux/PowerPC load: console=ttyS0,115200 root=/dev/mtdblock1 rootfstype=squashfs,jffs2 noinitrd init=/etc/preinit Finalizing device tree... flat tree at 0x6a5160 bootconsole [udbg0] enabled Page fault in user mode with in_atomic() = 1 mm = (null) NIP = c0275f50 MSR = fffffffe Oops: Weird page fault, sig: 11 [#1] PowerPC 40x Platform Modules linked in: NIP: c0275f50 LR: c0275f60 CTR: c0280000 REGS: c0275eb0 TRAP: 636f7265 Not tainted (3.7.1) MSR: fffffffe <VEC,VSX,EE,PR,FP,ME,SE,BE,IR,DR,PMM,RI> CR: c06a6190 XER: 00000001 TASK = c02662a8[0] 'swapper' THREAD: c0274000 GPR00: c0275ec0 c000c658 c027c4bf 00000000 c0275ee0c000a0ec
c020a1a8 c020a1f0 GPR08: c020f631 c020f404 c025f078 c025f080 c0275f10 Call Trace: ---[ end trace 31fd0ba7d8756001 ]--- Kernel panic - not syncing: Attempted to kill the idle task! The panic happens since commit9597abe00c
(sections: fix section conflicts in arch/powerpc), however the root cause of this is that the NULL terminator were not added in commita4f740cf33
(of/flattree: Add of_flat_dt_match() helper function). Cc: Grant Likely <grant.likely@secretlab.ca> Cc: <stable@vger.kernel.org> Signed-off-by: Gabor Juhos <juhosg@openwrt.org> Signed-off-by: Benjamin Herrenschmidt <benh@kernel.crashing.org>
83 lines
2.2 KiB
C
83 lines
2.2 KiB
C
/*
|
|
* Generic PowerPC 40x platform support
|
|
*
|
|
* Copyright 2008 IBM Corporation
|
|
*
|
|
* This program is free software; you can redistribute it and/or modify it
|
|
* under the terms of the GNU General Public License as published by the
|
|
* Free Software Foundation; version 2 of the License.
|
|
*
|
|
* This implements simple platform support for PowerPC 44x chips. This is
|
|
* mostly used for eval boards or other simple and "generic" 44x boards. If
|
|
* your board has custom functions or hardware, then you will likely want to
|
|
* implement your own board.c file to accommodate it.
|
|
*/
|
|
|
|
#include <asm/machdep.h>
|
|
#include <asm/pci-bridge.h>
|
|
#include <asm/ppc4xx.h>
|
|
#include <asm/prom.h>
|
|
#include <asm/time.h>
|
|
#include <asm/udbg.h>
|
|
#include <asm/uic.h>
|
|
|
|
#include <linux/init.h>
|
|
#include <linux/of_platform.h>
|
|
|
|
static __initdata struct of_device_id ppc40x_of_bus[] = {
|
|
{ .compatible = "ibm,plb3", },
|
|
{ .compatible = "ibm,plb4", },
|
|
{ .compatible = "ibm,opb", },
|
|
{ .compatible = "ibm,ebc", },
|
|
{ .compatible = "simple-bus", },
|
|
{},
|
|
};
|
|
|
|
static int __init ppc40x_device_probe(void)
|
|
{
|
|
of_platform_bus_probe(NULL, ppc40x_of_bus, NULL);
|
|
|
|
return 0;
|
|
}
|
|
machine_device_initcall(ppc40x_simple, ppc40x_device_probe);
|
|
|
|
/* This is the list of boards that can be supported by this simple
|
|
* platform code. This does _not_ mean the boards are compatible,
|
|
* as they most certainly are not from a device tree perspective.
|
|
* However, their differences are handled by the device tree and the
|
|
* drivers and therefore they don't need custom board support files.
|
|
*
|
|
* Again, if your board needs to do things differently then create a
|
|
* board.c file for it rather than adding it to this list.
|
|
*/
|
|
static const char * const board[] __initconst = {
|
|
"amcc,acadia",
|
|
"amcc,haleakala",
|
|
"amcc,kilauea",
|
|
"amcc,makalu",
|
|
"apm,klondike",
|
|
"est,hotfoot",
|
|
"plathome,obs600",
|
|
NULL
|
|
};
|
|
|
|
static int __init ppc40x_probe(void)
|
|
{
|
|
if (of_flat_dt_match(of_get_flat_dt_root(), board)) {
|
|
pci_set_flags(PCI_REASSIGN_ALL_RSRC);
|
|
return 1;
|
|
}
|
|
|
|
return 0;
|
|
}
|
|
|
|
define_machine(ppc40x_simple) {
|
|
.name = "PowerPC 40x Platform",
|
|
.probe = ppc40x_probe,
|
|
.progress = udbg_progress,
|
|
.init_IRQ = uic_init_tree,
|
|
.get_irq = uic_get_irq,
|
|
.restart = ppc4xx_reset_system,
|
|
.calibrate_decr = generic_calibrate_decr,
|
|
};
|