提交 4ae04acb 编写于 作者: M Magnus Damm 提交者: Paul Mundt

ARM: mach-shmobile: early console support using earlyprintk

Add support for early console to the SH-Mobile boards.

Simply perform an early platform probe for "earlyprintk"
to trigger the early serial console code in sh-sci.c.
Signed-off-by: NMagnus Damm <damm@opensource.se>
Signed-off-by: NPaul Mundt <lethal@linux-sh.org>
上级 62f60d6a
...@@ -322,7 +322,7 @@ CONFIG_ALIGNMENT_TRAP=y ...@@ -322,7 +322,7 @@ CONFIG_ALIGNMENT_TRAP=y
# #
CONFIG_ZBOOT_ROM_TEXT=0x0 CONFIG_ZBOOT_ROM_TEXT=0x0
CONFIG_ZBOOT_ROM_BSS=0x0 CONFIG_ZBOOT_ROM_BSS=0x0
CONFIG_CMDLINE="console=ttySC0,115200" CONFIG_CMDLINE="console=ttySC0,115200 earlyprintk=sh-sci.0,115200"
# CONFIG_XIP_KERNEL is not set # CONFIG_XIP_KERNEL is not set
CONFIG_KEXEC=y CONFIG_KEXEC=y
CONFIG_ATAGS_PROC=y CONFIG_ATAGS_PROC=y
......
...@@ -317,7 +317,7 @@ CONFIG_ALIGNMENT_TRAP=y ...@@ -317,7 +317,7 @@ CONFIG_ALIGNMENT_TRAP=y
# #
CONFIG_ZBOOT_ROM_TEXT=0x0 CONFIG_ZBOOT_ROM_TEXT=0x0
CONFIG_ZBOOT_ROM_BSS=0x0 CONFIG_ZBOOT_ROM_BSS=0x0
CONFIG_CMDLINE="console=ttySC1,115200" CONFIG_CMDLINE="console=ttySC1,115200 earlyprintk=sh-sci.1,115200"
# CONFIG_XIP_KERNEL is not set # CONFIG_XIP_KERNEL is not set
CONFIG_KEXEC=y CONFIG_KEXEC=y
CONFIG_ATAGS_PROC=y CONFIG_ATAGS_PROC=y
......
...@@ -322,7 +322,7 @@ CONFIG_ALIGNMENT_TRAP=y ...@@ -322,7 +322,7 @@ CONFIG_ALIGNMENT_TRAP=y
# #
CONFIG_ZBOOT_ROM_TEXT=0x0 CONFIG_ZBOOT_ROM_TEXT=0x0
CONFIG_ZBOOT_ROM_BSS=0x0 CONFIG_ZBOOT_ROM_BSS=0x0
CONFIG_CMDLINE="console=ttySC4,115200" CONFIG_CMDLINE="console=ttySC4,115200 earlyprintk=sh-sci.4,115200"
# CONFIG_XIP_KERNEL is not set # CONFIG_XIP_KERNEL is not set
CONFIG_KEXEC=y CONFIG_KEXEC=y
CONFIG_ATAGS_PROC=y CONFIG_ATAGS_PROC=y
......
...@@ -3,7 +3,7 @@ ...@@ -3,7 +3,7 @@
# #
# Common objects # Common objects
obj-y := timer.o obj-y := timer.o console.o
# CPU objects # CPU objects
obj-$(CONFIG_ARCH_SH7367) += setup-sh7367.o clock-sh7367.o obj-$(CONFIG_ARCH_SH7367) += setup-sh7367.o clock-sh7367.o
......
...@@ -105,9 +105,10 @@ static void __init ap4evb_map_io(void) ...@@ -105,9 +105,10 @@ static void __init ap4evb_map_io(void)
{ {
iotable_init(ap4evb_io_desc, ARRAY_SIZE(ap4evb_io_desc)); iotable_init(ap4evb_io_desc, ARRAY_SIZE(ap4evb_io_desc));
/* setup early devices and clocks here as well */ /* setup early devices, clocks and console here as well */
sh7372_add_early_devices(); sh7372_add_early_devices();
sh7367_clock_init(); /* use g3 clocks for now */ sh7367_clock_init(); /* use g3 clocks for now */
shmobile_setup_console();
} }
static void __init ap4evb_init(void) static void __init ap4evb_init(void)
......
...@@ -105,9 +105,10 @@ static void __init g3evm_map_io(void) ...@@ -105,9 +105,10 @@ static void __init g3evm_map_io(void)
{ {
iotable_init(g3evm_io_desc, ARRAY_SIZE(g3evm_io_desc)); iotable_init(g3evm_io_desc, ARRAY_SIZE(g3evm_io_desc));
/* setup early devices and clocks here as well */ /* setup early devices, clocks and console here as well */
sh7367_add_early_devices(); sh7367_add_early_devices();
sh7367_clock_init(); sh7367_clock_init();
shmobile_setup_console();
} }
static void __init g3evm_init(void) static void __init g3evm_init(void)
......
...@@ -105,9 +105,10 @@ static void __init g4evm_map_io(void) ...@@ -105,9 +105,10 @@ static void __init g4evm_map_io(void)
{ {
iotable_init(g4evm_io_desc, ARRAY_SIZE(g4evm_io_desc)); iotable_init(g4evm_io_desc, ARRAY_SIZE(g4evm_io_desc));
/* setup early devices and clocks here as well */ /* setup early devices, clocks and console here as well */
sh7377_add_early_devices(); sh7377_add_early_devices();
sh7367_clock_init(); /* use g3 clocks for now */ sh7367_clock_init(); /* use g3 clocks for now */
shmobile_setup_console();
} }
static void __init g4evm_init(void) static void __init g4evm_init(void)
......
/*
* SH-Mobile Console
*
* Copyright (C) 2010 Magnus Damm
*
* 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 program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
*
* You should have received a copy of the GNU General Public License
* along with this program; if not, write to the Free Software
* Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
*/
#include <linux/kernel.h>
#include <linux/init.h>
#include <linux/platform_device.h>
#include <mach/common.h>
#include <asm/mach/map.h>
void __init shmobile_setup_console(void)
{
parse_early_param();
/* Let earlyprintk output early console messages */
early_platform_driver_probe("earlyprintk", 1, 1);
}
...@@ -2,6 +2,7 @@ ...@@ -2,6 +2,7 @@
#define __ARCH_MACH_COMMON_H #define __ARCH_MACH_COMMON_H
extern struct sys_timer shmobile_timer; extern struct sys_timer shmobile_timer;
extern void shmobile_setup_console(void);
extern void sh7367_init_irq(void); extern void sh7367_init_irq(void);
extern void sh7367_add_early_devices(void); extern void sh7367_add_early_devices(void);
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册