Commit 6bac468e authored by Andrew Morton's avatar Andrew Morton Committed by Linus Torvalds

[PATCH] sh: merge.

From: Paul Mundt <lethal@Linux-SH.ORG>

This merges the remaining sh changes, random bug fixes, added syscalls, cache
fixups, etc.  Nothing really eventful.
Signed-off-by: default avatarPaul Mundt <lethal@linux-sh.org>
Signed-off-by: default avatarAndrew Morton <akpm@osdl.org>
Signed-off-by: default avatarLinus Torvalds <torvalds@osdl.org>
parent cc8406d5
...@@ -188,13 +188,7 @@ adding a machine called vapor): ...@@ -188,13 +188,7 @@ adding a machine called vapor):
- add a new file include/asm-sh/vapor/io.h which contains prototypes for - add a new file include/asm-sh/vapor/io.h which contains prototypes for
any machine specific IO functions prefixed with the machine name, for any machine specific IO functions prefixed with the machine name, for
example vapor_inb. These will be needed when filling out the machine example vapor_inb. These will be needed when filling out the machine
vector. In addition, a section is required which defines what to do when vector.
building a machine specific version. For example:
#ifdef __WANT_IO_DEF
#define inb vapor_inb
...
#endif
This is the minimum that is required, however there are ample This is the minimum that is required, however there are ample
opportunities to optimise this. In particular, by making the prototypes opportunities to optimise this. In particular, by making the prototypes
......
...@@ -45,6 +45,12 @@ config SH_7751_SOLUTION_ENGINE ...@@ -45,6 +45,12 @@ config SH_7751_SOLUTION_ENGINE
Select 7751 SolutionEngine if configuring for a Hitachi SH7751 Select 7751 SolutionEngine if configuring for a Hitachi SH7751
evalutation board. evalutation board.
config SH_7300_SOLUTION_ENGINE
bool "SolutionEngine7300"
help
Select 7300 SolutionEngine if configuring for a Hitachi SH7300(SH-Mobile V)
evalutation board.
config SH_7751_SYSTEMH config SH_7751_SYSTEMH
bool "SystemH7751R" bool "SystemH7751R"
help help
...@@ -138,6 +144,18 @@ config SH_SECUREEDGE5410 ...@@ -138,6 +144,18 @@ config SH_SECUREEDGE5410
This includes both the OEM SecureEdge products as well as the This includes both the OEM SecureEdge products as well as the
SME product line. SME product line.
config SH_HS7751RVOIP
bool "HS7751RVOIP"
help
Select HS7751RVOIP if configuring for a Renesas Technology
Sales VoIP board.
config SH_RTS7751R2D
bool "RTS7751R2D"
help
Select RTS7751R2D if configuring for a Renesas Technology
Sales SH-Graphics board.
config SH_UNKNOWN config SH_UNKNOWN
bool "BareCPU" bool "BareCPU"
help help
...@@ -186,7 +204,11 @@ config CPU_SUBTYPE_SH7604 ...@@ -186,7 +204,11 @@ config CPU_SUBTYPE_SH7604
config CPU_SUBTYPE_SH7300 config CPU_SUBTYPE_SH7300
bool "SH7300" bool "SH7300"
depends on CPU_SH3 depends on CPU_SH3
config CPU_SUBTYPE_SH7705
bool "SH7705"
depends on CPU_SH3
config CPU_SUBTYPE_SH7707 config CPU_SUBTYPE_SH7707
bool "SH7707" bool "SH7707"
depends on CPU_SH3 depends on CPU_SH3
...@@ -224,10 +246,17 @@ config CPU_SUBTYPE_SH7760 ...@@ -224,10 +246,17 @@ config CPU_SUBTYPE_SH7760
depends on CPU_SH4 depends on CPU_SH4
config CPU_SUBTYPE_ST40STB1 config CPU_SUBTYPE_ST40STB1
bool "ST40STB1" bool "ST40STB1 / ST40RA"
depends on CPU_SH4 depends on CPU_SH4
help help
Select ST40STB1 if you have a ST40STB1 CPU. Select ST40STB1 if you have a ST40RA CPU.
This was previously called the ST40STB1, hence the option name.
config CPU_SUBTYPE_ST40GX1
bool "ST40GX1"
depends on CPU_SH4
help
Select ST40GX1 if you have a ST40GX1 CPU.
endchoice endchoice
...@@ -268,7 +297,7 @@ config CMDLINE ...@@ -268,7 +297,7 @@ config CMDLINE
config MEMORY_START config MEMORY_START
hex "Physical memory start address" if !MEMORY_SET || MEMORY_OVERRIDE hex "Physical memory start address" if !MEMORY_SET || MEMORY_OVERRIDE
default "0x08000000" if !MEMORY_SET || MEMORY_OVERRIDE || !MEMORY_OVERRIDE && SH_ADX || SH_MPC1211 || SH_SECUREEDGE5410 default "0x08000000" if !MEMORY_SET || MEMORY_OVERRIDE || !MEMORY_OVERRIDE && SH_ADX || SH_MPC1211 || SH_SECUREEDGE5410
default "0x0c000000" if !MEMORY_OVERRIDE && (SH_DREAMCAST || SH_HP600 || SH_BIGSUR || SH_SH2000 || SH_7751_SOLUTION_ENGINE || SH_SOLUTION_ENGINE) default "0x0c000000" if !MEMORY_OVERRIDE && (SH_DREAMCAST || SH_HP600 || SH_BIGSUR || SH_SH2000 || SH_7751_SOLUTION_ENGINE || SH_SOLUTION_ENGINE || SH_HS7751RVOIP || SH_RTS7751R2D)
---help--- ---help---
Computers built with Hitachi SuperH processors always Computers built with Hitachi SuperH processors always
map the ROM starting at address zero. But the processor map the ROM starting at address zero. But the processor
...@@ -287,7 +316,7 @@ config MEMORY_SIZE ...@@ -287,7 +316,7 @@ config MEMORY_SIZE
hex "Physical memory size" if !MEMORY_SET || MEMORY_OVERRIDE hex "Physical memory size" if !MEMORY_SET || MEMORY_OVERRIDE
default "0x00400000" if !MEMORY_SET || MEMORY_OVERRIDE || !MEMORY_OVERRIDE && SH_ADX || !MEMORY_OVERRIDE && (SH_HP600 || SH_BIGSUR || SH_SH2000) default "0x00400000" if !MEMORY_SET || MEMORY_OVERRIDE || !MEMORY_OVERRIDE && SH_ADX || !MEMORY_OVERRIDE && (SH_HP600 || SH_BIGSUR || SH_SH2000)
default "0x01000000" if !MEMORY_OVERRIDE && SH_DREAMCAST || SH_SECUREEDGE5410 default "0x01000000" if !MEMORY_OVERRIDE && SH_DREAMCAST || SH_SECUREEDGE5410
default "0x04000000" if !MEMORY_OVERRIDE && SH_7751_SOLUTION_ENGINE default "0x04000000" if !MEMORY_OVERRIDE && (SH_7751_SOLUTION_ENGINE || SH_HS7751RVOIP || SH_RTS7751R2D)
default "0x02000000" if !MEMORY_OVERRIDE && SH_SOLUTION_ENGINE default "0x02000000" if !MEMORY_OVERRIDE && SH_SOLUTION_ENGINE
default "0x08000000" if SH_MPC1211 default "0x08000000" if SH_MPC1211
help help
...@@ -299,7 +328,7 @@ config MEMORY_SIZE ...@@ -299,7 +328,7 @@ config MEMORY_SIZE
config MEMORY_SET config MEMORY_SET
bool bool
depends on !MEMORY_OVERRIDE && (SH_MPC1211 || SH_ADX || SH_DREAMCAST || SH_HP600 || SH_BIGSUR || SH_SH2000 || SH_7751_SOLUTION_ENGINE || SH_SOLUTION_ENGINE || SH_SECUREEDGE5410) depends on !MEMORY_OVERRIDE && (SH_MPC1211 || SH_ADX || SH_DREAMCAST || SH_HP600 || SH_BIGSUR || SH_SH2000 || SH_7751_SOLUTION_ENGINE || SH_SOLUTION_ENGINE || SH_SECUREEDGE5410 || SH_HS7751RVOIP || SH_RTS7751R2D)
default y default y
help help
This is an option about which you will never be asked a question. This is an option about which you will never be asked a question.
...@@ -358,7 +387,7 @@ config CF_BASE_ADDR ...@@ -358,7 +387,7 @@ config CF_BASE_ADDR
# The SH7750 RTC module is disabled in the Dreamcast # The SH7750 RTC module is disabled in the Dreamcast
config SH_RTC config SH_RTC
bool bool
depends on !SH_DREAMCAST && !SH_SATURN depends on !SH_DREAMCAST && !SH_SATURN && !SH_7300_SOLUTION_ENGINE
default y default y
help help
Selecting this option will allow the Linux kernel to emulate Selecting this option will allow the Linux kernel to emulate
...@@ -377,11 +406,26 @@ config SH_DSP ...@@ -377,11 +406,26 @@ config SH_DSP
This option must be set in order to enable the DSP. This option must be set in order to enable the DSP.
config SH_ADC
bool "ADC support"
depends on CPU_SH3
default y
help
Selecting this option will allow the Linux kernel to use SH3 on-chip
ADC module.
If unsure, say N.
config SH_HP600 config SH_HP600
bool bool
depends on SH_HP620 || SH_HP680 || SH_HP690 depends on SH_HP620 || SH_HP680 || SH_HP690
default y default y
config CPU_SUBTYPE_ST40
bool
depends on CPU_SUBTYPE_ST40STB1 || CPU_SUBTYPE_ST40GX1
default y
config DISCONTIGMEM config DISCONTIGMEM
bool bool
depends on SH_HP690 depends on SH_HP690
...@@ -514,10 +558,32 @@ config NR_CPUS ...@@ -514,10 +558,32 @@ config NR_CPUS
This is purely to save memory - each supported CPU adds This is purely to save memory - each supported CPU adds
approximately eight kilobytes to the kernel image. approximately eight kilobytes to the kernel image.
config HS7751RVOIP_CODEC
bool "Support VoIP Codec section"
depends on SH_HS7751RVOIP
help
Selecting this option will support CODEC section.
config RTS7751R2D_REV11
bool "RTS7751R2D Rev. 1.1 board support"
depends on SH_RTS7751R2D
help
Selecting this option will support version rev. 1.1.
config SH_PCLK_CALC
bool
default n if CPU_SUBTYPE_SH7300
default y
help
This option will cause the PCLK value to be probed at run-time. It
will display a notification if the probed value has greater than a
1% variance of the hardcoded CONFIG_SH_PCLK_FREQ.
config SH_PCLK_FREQ config SH_PCLK_FREQ
int "Peripheral clock frequency (in Hz)" int "Peripheral clock frequency (in Hz)"
default "49876504" if CPU_SUBTYPE_SH7750 default "49876504" if CPU_SUBTYPE_SH7750
default "60013568" if CPU_SUBTYPE_SH7751 default "60013568" if CPU_SUBTYPE_SH7751
default "33333333" if CPU_SUBTYPE_SH7300
default "1193182" default "1193182"
help help
This option is used to specify the peripheral clock frequency. This This option is used to specify the peripheral clock frequency. This
...@@ -570,12 +636,18 @@ source "arch/sh/cchips/Kconfig" ...@@ -570,12 +636,18 @@ source "arch/sh/cchips/Kconfig"
config HEARTBEAT config HEARTBEAT
bool "Heartbeat LED" bool "Heartbeat LED"
depends on SH_MPC1211 || SH_CAT68701 || SH_STB1_HARP || SH_STB1_OVERDRIVE || SH_BIGSUR || SH_7751_SOLUTION_ENGINE || SH_SOLUTION_ENGINE depends on SH_MPC1211 || SH_CAT68701 || SH_STB1_HARP || SH_STB1_OVERDRIVE || SH_BIGSUR || SH_7751_SOLUTION_ENGINE || SH_7300_SOLUTION_ENGINE || SH_SOLUTION_ENGINE || SH_RTS7751R2D
help help
Use the power-on LED on your machine as a load meter. The exact Use the power-on LED on your machine as a load meter. The exact
behavior is platform-dependent, but normally the flash frequency is behavior is platform-dependent, but normally the flash frequency is
a hyperbolic function of the 5-minute load average. a hyperbolic function of the 5-minute load average.
config RTC_9701JE
tristate "EPSON RTC-9701JE support"
depends on SH_RTS7751R2D
help
Selecting this option will support EPSON RTC-9701JE.
endmenu endmenu
...@@ -646,6 +718,24 @@ source "fs/Kconfig.binfmt" ...@@ -646,6 +718,24 @@ source "fs/Kconfig.binfmt"
endmenu endmenu
menu "SH initrd options"
depends on BLK_DEV_INITRD
config EMBEDDED_RAMDISK
bool "Embed root filesystem ramdisk into the kernel"
config EMBEDDED_RAMDISK_IMAGE
string "Filename of gziped ramdisk image"
depends on EMBEDDED_RAMDISK
default "ramdisk.gz"
help
This is the filename of the ramdisk image to be built into the
kernel. Relative pathnames are relative to arch/mips/ramdisk/.
The ramdisk image is not part of the kernel distribution; you must
provide one yourself.
endmenu
source "drivers/Kconfig" source "drivers/Kconfig"
source "fs/Kconfig" source "fs/Kconfig"
...@@ -675,6 +765,14 @@ config DEBUG_SPINLOCK ...@@ -675,6 +765,14 @@ config DEBUG_SPINLOCK
best used in conjunction with the NMI watchdog so that spinlock best used in conjunction with the NMI watchdog so that spinlock
deadlocks are also debuggable. deadlocks are also debuggable.
config DEBUG_INFO
bool "Compile the kernel with debug info"
help
If you say Y here the resulting kernel image will include
debugging info resulting in a larger kernel image.
Say Y here only if you plan to use gdb to debug the kernel.
If you don't debug the kernel, you can say N.
config SH_STANDARD_BIOS config SH_STANDARD_BIOS
bool "Use LinuxSH standard BIOS" bool "Use LinuxSH standard BIOS"
help help
...@@ -688,9 +786,13 @@ config SH_STANDARD_BIOS ...@@ -688,9 +786,13 @@ config SH_STANDARD_BIOS
mask ROM and no flash (WindowsCE machines fall in this category). mask ROM and no flash (WindowsCE machines fall in this category).
If unsure, say N. If unsure, say N.
config SH_EARLY_PRINTK config EARLY_SCIF_CONSOLE
bool "Use early SCIF console"
depends on CPU_SH4
config EARLY_PRINTK
bool "Early printk support" bool "Early printk support"
depends on SH_STANDARD_BIOS depends on SH_STANDARD_BIOS || EARLY_SCIF_CONSOLE
help help
Say Y here to redirect kernel printk messages to the serial port Say Y here to redirect kernel printk messages to the serial port
used by the SH-IPL bootloader, starting very early in the boot used by the SH-IPL bootloader, starting very early in the boot
......
# $Id: Makefile,v 1.34 2004/03/21 17:31:06 lethal Exp $ # $Id: Makefile,v 1.35 2004/04/15 03:39:20 sugioka Exp $
# #
# This file is subject to the terms and conditions of the GNU General Public # 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 # License. See the file "COPYING" in the main directory of this archive
# for more details. # for more details.
# #
# Copyright (C) 1999 Kaz Kojima # Copyright (C) 1999 Kaz Kojima
# Copyright (C) 2002, 2003 Paul Mundt # Copyright (C) 2002, 2003, 2004 Paul Mundt
# Copyright (C) 2002 M. R. Brown # Copyright (C) 2002 M. R. Brown
# #
# This file is included by the global makefile so that you can add your own # This file is included by the global makefile so that you can add your own
...@@ -64,10 +64,18 @@ LIBGCC := $(shell $(CC) $(CFLAGS) -print-libgcc-file-name) ...@@ -64,10 +64,18 @@ LIBGCC := $(shell $(CC) $(CFLAGS) -print-libgcc-file-name)
core-y += arch/sh/kernel/ arch/sh/mm/ core-y += arch/sh/kernel/ arch/sh/mm/
#
# ramdisk/initrd support
# You need a compressed ramdisk image, named
# CONFIG_EMBEDDED_RAMDISK_IMAGE. Relative pathnames
# are relative to arch/sh/ramdisk/.
#
core-$(CONFIG_EMBEDDED_RAMDISK) += arch/sh/ramdisk/
# Boards # Boards
machdir-$(CONFIG_SH_SOLUTION_ENGINE) := se/770x machdir-$(CONFIG_SH_SOLUTION_ENGINE) := se/770x
machdir-$(CONFIG_SH_7751_SOLUTION_ENGINE) := se/7751 machdir-$(CONFIG_SH_7751_SOLUTION_ENGINE) := se/7751
machdir-$(CONFIG_SH_7751_SYSTEMH) := systemh machdir-$(CONFIG_SH_7300_SOLUTION_ENGINE) := se/7300
machdir-$(CONFIG_SH_STB1_HARP) := harp machdir-$(CONFIG_SH_STB1_HARP) := harp
machdir-$(CONFIG_SH_STB1_OVERDRIVE) := overdrive machdir-$(CONFIG_SH_STB1_OVERDRIVE) := overdrive
machdir-$(CONFIG_SH_HP620) := hp6xx/hp620 machdir-$(CONFIG_SH_HP620) := hp6xx/hp620
...@@ -84,19 +92,24 @@ machdir-$(CONFIG_SH_SH2000) := sh2000 ...@@ -84,19 +92,24 @@ machdir-$(CONFIG_SH_SH2000) := sh2000
machdir-$(CONFIG_SH_ADX) := adx machdir-$(CONFIG_SH_ADX) := adx
machdir-$(CONFIG_SH_MPC1211) := mpc1211 machdir-$(CONFIG_SH_MPC1211) := mpc1211
machdir-$(CONFIG_SH_SECUREEDGE5410) := snapgear machdir-$(CONFIG_SH_SECUREEDGE5410) := snapgear
machdir-$(CONFIG_SH_HS7751RVOIP) := renesas/hs7751rvoip
machdir-$(CONFIG_SH_RTS7751R2D) := renesas/rts7751r2d
machdir-$(CONFIG_SH_7751_SYSTEMH) := renesas/systemh
machdir-$(CONFIG_SH_UNKNOWN) := unknown machdir-$(CONFIG_SH_UNKNOWN) := unknown
incdir-y := $(machdir-y) incdir-y := $(notdir $(machdir-y))
incdir-$(CONFIG_SH_SOLUTION_ENGINE) := se incdir-$(CONFIG_SH_SOLUTION_ENGINE) := se
incdir-$(CONFIG_SH_7751_SOLUTION_ENGINE) := se7751 incdir-$(CONFIG_SH_7751_SOLUTION_ENGINE) := se7751
incdir-$(CONFIG_SH_7300_SOLUTION_ENGINE) := se7300
incdir-$(CONFIG_SH_HP600) := hp6xx incdir-$(CONFIG_SH_HP600) := hp6xx
core-y += arch/sh/boards/$(machdir-y)/ core-y += arch/sh/boards/$(machdir-y)/
# Companion chips # Companion chips
core-$(CONFIG_HD64461) += arch/sh/cchips/hd6446x/hd64461/ core-$(CONFIG_HD64461) += arch/sh/cchips/hd6446x/hd64461/
core-$(CONFIG_HD64465) += arch/sh/cchips/hd6446x/hd64465/ core-$(CONFIG_HD64465) += arch/sh/cchips/hd6446x/hd64465/
core-$(CONFIG_VOYAGERGX) += arch/sh/cchips/voyagergx/
cpuincdir-$(CONFIG_CPU_SH2) := cpu-sh2 cpuincdir-$(CONFIG_CPU_SH2) := cpu-sh2
cpuincdir-$(CONFIG_CPU_SH3) := cpu-sh3 cpuincdir-$(CONFIG_CPU_SH3) := cpu-sh3
...@@ -114,6 +127,9 @@ AFLAGS_vmlinux.lds.o := -traditional ...@@ -114,6 +127,9 @@ AFLAGS_vmlinux.lds.o := -traditional
prepare: target_links prepare: target_links
.PHONY: target_links FORCE .PHONY: target_links FORCE
all: zImage
target_links: target_links:
@echo ' Making asm-sh/cpu -> asm-sh/$(cpuincdir-y) link' @echo ' Making asm-sh/cpu -> asm-sh/$(cpuincdir-y) link'
@rm -f include/asm-sh/cpu @rm -f include/asm-sh/cpu
......
...@@ -15,7 +15,11 @@ endif ...@@ -15,7 +15,11 @@ endif
# #
# IMAGE_OFFSET is the load offset of the compression loader # IMAGE_OFFSET is the load offset of the compression loader
# Assign dummy values if these 2 variables are not defined,
# in order to suppress error message.
# #
CONFIG_MEMORY_START ?= 0x0c000000
CONFIG_BOOT_LINK_OFFSET ?= 0x00800000
IMAGE_OFFSET := $(shell printf "0x%8x" $$[0x80000000+$(CONFIG_MEMORY_START)+$(CONFIG_BOOT_LINK_OFFSET)]) IMAGE_OFFSET := $(shell printf "0x%8x" $$[0x80000000+$(CONFIG_MEMORY_START)+$(CONFIG_BOOT_LINK_OFFSET)])
LDFLAGS_vmlinux := -Ttext $(IMAGE_OFFSET) -e startup -T $(obj)/../../kernel/vmlinux.lds.s LDFLAGS_vmlinux := -Ttext $(IMAGE_OFFSET) -e startup -T $(obj)/../../kernel/vmlinux.lds.s
......
/* /*
* arch/sh/boot/compressed/misc.c * arch/sh/boot/compressed/misc.c
* *
* This is a collection of several routines from gzip-1.0.3 * This is a collection of several routines from gzip-1.0.3
* adapted for Linux. * adapted for Linux.
* *
* malloc by Hannu Savolainen 1993 and Matthias Urlichs 1994 * malloc by Hannu Savolainen 1993 and Matthias Urlichs 1994
...@@ -52,7 +52,7 @@ static unsigned outcnt = 0; /* bytes in output buffer */ ...@@ -52,7 +52,7 @@ static unsigned outcnt = 0; /* bytes in output buffer */
#define RESERVED 0xC0 /* bit 6,7: reserved */ #define RESERVED 0xC0 /* bit 6,7: reserved */
#define get_byte() (inptr < insize ? inbuf[inptr++] : fill_inbuf()) #define get_byte() (inptr < insize ? inbuf[inptr++] : fill_inbuf())
/* Diagnostic functions */ /* Diagnostic functions */
#ifdef DEBUG #ifdef DEBUG
# define Assert(cond,msg) {if(!(cond)) error(msg);} # define Assert(cond,msg) {if(!(cond)) error(msg);}
...@@ -75,7 +75,7 @@ static void flush_window(void); ...@@ -75,7 +75,7 @@ static void flush_window(void);
static void error(char *m); static void error(char *m);
static void gzip_mark(void **); static void gzip_mark(void **);
static void gzip_release(void **); static void gzip_release(void **);
extern char input_data[]; extern char input_data[];
extern int input_len; extern int input_len;
...@@ -83,20 +83,19 @@ static long bytes_out = 0; ...@@ -83,20 +83,19 @@ static long bytes_out = 0;
static uch *output_data; static uch *output_data;
static unsigned long output_ptr = 0; static unsigned long output_ptr = 0;
static void *malloc(int size); static void *malloc(int size);
static void free(void *where); static void free(void *where);
static void error(char *m); static void error(char *m);
static void gzip_mark(void **); static void gzip_mark(void **);
static void gzip_release(void **); static void gzip_release(void **);
static void puts(const char *); int puts(const char *);
extern int _text; /* Defined in vmlinux.lds.S */ extern int _text; /* Defined in vmlinux.lds.S */
extern int _end; extern int _end;
static unsigned long free_mem_ptr; static unsigned long free_mem_ptr;
static unsigned long free_mem_end_ptr; static unsigned long free_mem_end_ptr;
#define HEAP_SIZE 0x10000 #define HEAP_SIZE 0x10000
#include "../../../../lib/inflate.c" #include "../../../../lib/inflate.c"
...@@ -134,7 +133,7 @@ static void gzip_release(void **ptr) ...@@ -134,7 +133,7 @@ static void gzip_release(void **ptr)
} }
#ifdef CONFIG_SH_STANDARD_BIOS #ifdef CONFIG_SH_STANDARD_BIOS
static int strlen(const char *s) size_t strlen(const char *s)
{ {
int i = 0; int i = 0;
...@@ -143,14 +142,17 @@ static int strlen(const char *s) ...@@ -143,14 +142,17 @@ static int strlen(const char *s)
return i; return i;
} }
void puts(const char *s) int puts(const char *s)
{ {
sh_bios_console_write(s, strlen(s)); int len = strlen(s);
sh_bios_console_write(s, len);
return len;
} }
#else #else
void puts(const char *s) int puts(const char *s)
{ {
/* This should be updated to use the sh-sci routines */ /* This should be updated to use the sh-sci routines */
return 0;
} }
#endif #endif
...@@ -198,9 +200,9 @@ static void flush_window(void) ...@@ -198,9 +200,9 @@ static void flush_window(void)
ulg c = crc; /* temporary variable */ ulg c = crc; /* temporary variable */
unsigned n; unsigned n;
uch *in, *out, ch; uch *in, *out, ch;
in = window; in = window;
out = &output_data[output_ptr]; out = &output_data[output_ptr];
for (n = 0; n < outcnt; n++) { for (n = 0; n < outcnt; n++) {
ch = *out++ = *in++; ch = *out++ = *in++;
c = crc_32_tab[((int)c ^ ch) & 0xff] ^ (c >> 8); c = crc_32_tab[((int)c ^ ch) & 0xff] ^ (c >> 8);
......
...@@ -2,7 +2,7 @@ ...@@ -2,7 +2,7 @@
# Makefile for the Linux/SuperH CPU-specifc backends. # Makefile for the Linux/SuperH CPU-specifc backends.
# #
obj-y := irq_ipr.o irq_imask.o init.o obj-y := irq_ipr.o irq_imask.o init.o bus.o
obj-$(CONFIG_CPU_SH2) += sh2/ obj-$(CONFIG_CPU_SH2) += sh2/
obj-$(CONFIG_CPU_SH3) += sh3/ obj-$(CONFIG_CPU_SH3) += sh3/
......
/*
* arch/sh/kernel/cpu/bus.c
*
* Virtual bus for SuperH.
*
* Copyright (C) 2004 Paul Mundt
*
* Shamelessly cloned from arch/arm/mach-omap/bus.c, which was written
* by:
*
* Copyright (C) 2003 - 2004 Nokia Corporation
* Written by Tony Lindgren <tony@atomide.com>
* Portions of code based on sa1111.c.
*
* 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; either version 2 of the License, or (at your
* option) any later version.
*/
#include <linux/kernel.h>
#include <linux/device.h>
#include <linux/init.h>
#include <linux/module.h>
#include <asm/bus-sh.h>
static int sh_bus_match(struct device *dev, struct device_driver *drv)
{
struct sh_driver *shdrv = to_sh_driver(drv);
struct sh_dev *shdev = to_sh_dev(dev);
return shdev->dev_id == shdrv->dev_id;
}
static int sh_bus_suspend(struct device *dev, u32 state)
{
struct sh_dev *shdev = to_sh_dev(dev);
struct sh_driver *shdrv = to_sh_driver(dev->driver);
if (shdrv && shdrv->suspend)
return shdrv->suspend(shdev, state);
return 0;
}
static int sh_bus_resume(struct device *dev)
{
struct sh_dev *shdev = to_sh_dev(dev);
struct sh_driver *shdrv = to_sh_driver(dev->driver);
if (shdrv && shdrv->resume)
return shdrv->resume(shdev);
return 0;
}
static struct device sh_bus_devices[SH_NR_BUSES] = {
{
.bus_id = SH_BUS_NAME_VIRT,
},
};
struct bus_type sh_bus_types[SH_NR_BUSES] = {
{
.name = SH_BUS_NAME_VIRT,
.match = sh_bus_match,
.suspend = sh_bus_suspend,
.resume = sh_bus_resume,
},
};
static int sh_device_probe(struct device *dev)
{
struct sh_dev *shdev = to_sh_dev(dev);
struct sh_driver *shdrv = to_sh_driver(dev->driver);
if (shdrv && shdrv->probe)
return shdrv->probe(shdev);
return -ENODEV;
}
static int sh_device_remove(struct device *dev)
{
struct sh_dev *shdev = to_sh_dev(dev);
struct sh_driver *shdrv = to_sh_driver(dev->driver);
if (shdrv && shdrv->remove)
return shdrv->remove(shdev);
return 0;
}
int sh_device_register(struct sh_dev *dev)
{
if (!dev)
return -EINVAL;
if (dev->bus_id < 0 || dev->bus_id >= SH_NR_BUSES) {
printk(KERN_ERR "%s: bus_id invalid: %s bus: %d\n",
__FUNCTION__, dev->name, dev->bus_id);
return -EINVAL;
}
dev->dev.parent = &sh_bus_devices[dev->bus_id];
dev->dev.bus = &sh_bus_types[dev->bus_id];
/* This is needed for USB OHCI to work */
if (dev->dma_mask)
dev->dev.dma_mask = dev->dma_mask;
snprintf(dev->dev.bus_id, BUS_ID_SIZE, "%s%u",
dev->name, dev->dev_id);
printk(KERN_INFO "Registering SH device '%s'. Parent at %s\n",
dev->dev.bus_id, dev->dev.parent->bus_id);
return device_register(&dev->dev);
}
void sh_device_unregister(struct sh_dev *dev)
{
device_unregister(&dev->dev);
}
int sh_driver_register(struct sh_driver *drv)
{
if (!drv)
return -EINVAL;
if (drv->bus_id < 0 || drv->bus_id >= SH_NR_BUSES) {
printk(KERN_ERR "%s: bus_id invalid: bus: %d device %d\n",
__FUNCTION__, drv->bus_id, drv->dev_id);
return -EINVAL;
}
drv->drv.probe = sh_device_probe;
drv->drv.remove = sh_device_remove;
drv->drv.bus = &sh_bus_types[drv->bus_id];
return driver_register(&drv->drv);
}
void sh_driver_unregister(struct sh_driver *drv)
{
driver_unregister(&drv->drv);
}
static int __init sh_bus_init(void)
{
int i, ret = 0;
for (i = 0; i < SH_NR_BUSES; i++) {
ret = device_register(&sh_bus_devices[i]);
if (ret != 0) {
printk(KERN_ERR "Unable to register bus device %s\n",
sh_bus_devices[i].bus_id);
continue;
}
ret = bus_register(&sh_bus_types[i]);
if (ret != 0) {
printk(KERN_ERR "Unable to register bus %s\n",
sh_bus_types[i].name);
device_unregister(&sh_bus_devices[i]);
}
}
printk(KERN_INFO "SH Virtual Bus initialized\n");
return ret;
}
static void __exit sh_bus_exit(void)
{
int i;
for (i = 0; i < SH_NR_BUSES; i++) {
bus_unregister(&sh_bus_types[i]);
device_unregister(&sh_bus_devices[i]);
}
}
module_init(sh_bus_init);
module_exit(sh_bus_exit);
MODULE_AUTHOR("Paul Mundt <lethal@linux-sh.org>");
MODULE_DESCRIPTION("SH Virtual Bus");
MODULE_LICENSE("GPL");
EXPORT_SYMBOL(sh_bus_types);
EXPORT_SYMBOL(sh_device_register);
EXPORT_SYMBOL(sh_device_unregister);
EXPORT_SYMBOL(sh_driver_register);
EXPORT_SYMBOL(sh_driver_unregister);
...@@ -42,7 +42,7 @@ onchip_setup(dsp); ...@@ -42,7 +42,7 @@ onchip_setup(dsp);
*/ */
static void __init cache_init(void) static void __init cache_init(void)
{ {
unsigned long ccr, flags = 0; unsigned long ccr, flags;
if (cpu_data->type == CPU_SH_NONE) if (cpu_data->type == CPU_SH_NONE)
panic("Unknown CPU"); panic("Unknown CPU");
...@@ -54,42 +54,50 @@ static void __init cache_init(void) ...@@ -54,42 +54,50 @@ static void __init cache_init(void)
* If the cache is already enabled .. flush it. * If the cache is already enabled .. flush it.
*/ */
if (ccr & CCR_CACHE_ENABLE) { if (ccr & CCR_CACHE_ENABLE) {
unsigned long entries, i, j; unsigned long ways, waysize, addrstart;
entries = cpu_data->dcache.sets; waysize = cpu_data->dcache.sets;
/* /*
* If the OC is already in RAM mode, we only have * If the OC is already in RAM mode, we only have
* half of the entries to flush.. * half of the entries to flush..
*/ */
if (ccr & CCR_CACHE_ORA) if (ccr & CCR_CACHE_ORA)
entries >>= 1; waysize >>= 1;
for (i = 0; i < entries; i++) { waysize <<= cpu_data->dcache.entry_shift;
for (j = 0; j < cpu_data->dcache.ways; j++) {
unsigned long data, addr;
addr = CACHE_OC_ADDRESS_ARRAY | #ifdef CCR_CACHE_EMODE
(j << cpu_data->dcache.way_shift) | /* If EMODE is not set, we only have 1 way to flush. */
(i << cpu_data->dcache.entry_shift); if (!(ccr & CCR_CACHE_EMODE))
ways = 1;
else
#endif
ways = cpu_data->dcache.ways;
data = ctrl_inl(addr); addrstart = CACHE_OC_ADDRESS_ARRAY;
do {
unsigned long addr;
if ((data & (SH_CACHE_UPDATED | SH_CACHE_VALID)) for (addr = addrstart;
== (SH_CACHE_UPDATED | SH_CACHE_VALID)) addr < addrstart + waysize;
ctrl_outl(data & ~SH_CACHE_UPDATED, addr); addr += cpu_data->dcache.linesz)
} ctrl_outl(0, addr);
}
addrstart += cpu_data->dcache.way_incr;
} while (--ways);
} }
/* /*
* Default CCR values .. enable the caches * Default CCR values .. enable the caches
* and flush them immediately.. * and invalidate them immediately..
*/ */
flags |= CCR_CACHE_ENABLE | CCR_CACHE_INVALIDATE; flags = CCR_CACHE_ENABLE | CCR_CACHE_INVALIDATE;
#ifdef CCR_CACHE_EMODE #ifdef CCR_CACHE_EMODE
flags |= (ccr & CCR_CACHE_EMODE); /* Force EMODE if possible */
if (cpu_data->dcache.ways > 1)
flags |= CCR_CACHE_EMODE;
#endif #endif
#ifdef CONFIG_SH_WRITETHROUGH #ifdef CONFIG_SH_WRITETHROUGH
...@@ -145,8 +153,8 @@ static void __init dsp_init(void) ...@@ -145,8 +153,8 @@ static void __init dsp_init(void)
/* If the DSP bit is still set, this CPU has a DSP */ /* If the DSP bit is still set, this CPU has a DSP */
if (sr & SR_DSP) if (sr & SR_DSP)
set_bit(CPU_HAS_DSP, &(cpu_data->flags)); cpu_data->flags |= CPU_HAS_DSP;
/* Now that we've determined the DSP status, clear the DSP bit. */ /* Now that we've determined the DSP status, clear the DSP bit. */
release_dsp(); release_dsp();
} }
...@@ -184,7 +192,7 @@ asmlinkage void __init sh_cpu_init(void) ...@@ -184,7 +192,7 @@ asmlinkage void __init sh_cpu_init(void)
} }
/* FPU initialization */ /* FPU initialization */
if (test_bit(CPU_HAS_FPU, &(cpu_data->flags))) { if ((cpu_data->flags & CPU_HAS_FPU)) {
clear_thread_flag(TIF_USEDFPU); clear_thread_flag(TIF_USEDFPU);
current->used_math = 0; current->used_math = 0;
} }
......
...@@ -1130,6 +1130,14 @@ ENTRY(sys_call_table) ...@@ -1130,6 +1130,14 @@ ENTRY(sys_call_table)
.long sys_utimes .long sys_utimes
.long sys_fadvise64_64_wrapper .long sys_fadvise64_64_wrapper
.long sys_ni_syscall /* Reserved for vserver */ .long sys_ni_syscall /* Reserved for vserver */
.long sys_ni_syscall .long sys_ni_syscall /* Reserved for mbind */
.long sys_ni_syscall /* 275 - get_mempolicy */
.long sys_ni_syscall /* set_mempolicy */
.long sys_mq_open
.long sys_mq_unlink
.long sys_mq_timedsend
.long sys_mq_timedreceive /* 280 */
.long sys_mq_notify
.long sys_mq_getsetattr
/* End of entry.S */ /* End of entry.S */
/* $Id: io_generic.c,v 1.1.1.1.4.2.2.1 2003/01/10 17:26:56 lethal Exp $ /* $Id: io_generic.c,v 1.2 2003/05/04 19:29:53 lethal Exp $
* *
* linux/arch/sh/kernel/io_generic.c * linux/arch/sh/kernel/io_generic.c
* *
...@@ -71,16 +71,32 @@ unsigned int generic_inl_p(unsigned long port) ...@@ -71,16 +71,32 @@ unsigned int generic_inl_p(unsigned long port)
return v; return v;
} }
/*
* insb/w/l all read a series of bytes/words/longs from a fixed port
* address. However as the port address doesn't change we only need to
* convert the port address to real address once.
*/
void generic_insb(unsigned long port, void *buffer, unsigned long count) void generic_insb(unsigned long port, void *buffer, unsigned long count)
{ {
volatile unsigned char *port_addr;
unsigned char *buf=buffer; unsigned char *buf=buffer;
while(count--) *buf++=inb(port);
port_addr = (volatile unsigned char *)PORT2ADDR(port);
while(count--)
*buf++ = *port_addr;
} }
void generic_insw(unsigned long port, void *buffer, unsigned long count) void generic_insw(unsigned long port, void *buffer, unsigned long count)
{ {
volatile unsigned short *port_addr;
unsigned short *buf=buffer; unsigned short *buf=buffer;
while(count--) *buf++=inw(port);
port_addr = (volatile unsigned short *)PORT2ADDR(port);
while(count--)
*buf++ = *port_addr;
#ifdef SH3_PCMCIA_BUG_WORKAROUND #ifdef SH3_PCMCIA_BUG_WORKAROUND
ctrl_inb (DUMMY_READ_AREA6); ctrl_inb (DUMMY_READ_AREA6);
#endif #endif
...@@ -88,8 +104,13 @@ void generic_insw(unsigned long port, void *buffer, unsigned long count) ...@@ -88,8 +104,13 @@ void generic_insw(unsigned long port, void *buffer, unsigned long count)
void generic_insl(unsigned long port, void *buffer, unsigned long count) void generic_insl(unsigned long port, void *buffer, unsigned long count)
{ {
volatile unsigned long *port_addr;
unsigned long *buf=buffer; unsigned long *buf=buffer;
while(count--) *buf++=inl(port);
port_addr = (volatile unsigned long *)PORT2ADDR(port);
while(count--)
*buf++ = *port_addr;
#ifdef SH3_PCMCIA_BUG_WORKAROUND #ifdef SH3_PCMCIA_BUG_WORKAROUND
ctrl_inb (DUMMY_READ_AREA6); ctrl_inb (DUMMY_READ_AREA6);
#endif #endif
...@@ -128,16 +149,33 @@ void generic_outl_p(unsigned int b, unsigned long port) ...@@ -128,16 +149,33 @@ void generic_outl_p(unsigned int b, unsigned long port)
delay(); delay();
} }
/*
* outsb/w/l all write a series of bytes/words/longs to a fixed port
* address. However as the port address doesn't change we only need to
* convert the port address to real address once.
*/
void generic_outsb(unsigned long port, const void *buffer, unsigned long count) void generic_outsb(unsigned long port, const void *buffer, unsigned long count)
{ {
volatile unsigned char *port_addr;
const unsigned char *buf=buffer; const unsigned char *buf=buffer;
while(count--) outb(*buf++, port);
port_addr = (volatile unsigned char *)PORT2ADDR(port);
while(count--)
*port_addr = *buf++;
} }
void generic_outsw(unsigned long port, const void *buffer, unsigned long count) void generic_outsw(unsigned long port, const void *buffer, unsigned long count)
{ {
volatile unsigned short *port_addr;
const unsigned short *buf=buffer; const unsigned short *buf=buffer;
while(count--) outw(*buf++, port);
port_addr = (volatile unsigned short *)PORT2ADDR(port);
while(count--)
*port_addr = *buf++;
#ifdef SH3_PCMCIA_BUG_WORKAROUND #ifdef SH3_PCMCIA_BUG_WORKAROUND
ctrl_inb (DUMMY_READ_AREA6); ctrl_inb (DUMMY_READ_AREA6);
#endif #endif
...@@ -145,8 +183,14 @@ void generic_outsw(unsigned long port, const void *buffer, unsigned long count) ...@@ -145,8 +183,14 @@ void generic_outsw(unsigned long port, const void *buffer, unsigned long count)
void generic_outsl(unsigned long port, const void *buffer, unsigned long count) void generic_outsl(unsigned long port, const void *buffer, unsigned long count)
{ {
volatile unsigned long *port_addr;
const unsigned long *buf=buffer; const unsigned long *buf=buffer;
while(count--) outl(*buf++, port);
port_addr = (volatile unsigned long *)PORT2ADDR(port);
while(count--)
*port_addr = *buf++;
#ifdef SH3_PCMCIA_BUG_WORKAROUND #ifdef SH3_PCMCIA_BUG_WORKAROUND
ctrl_inb (DUMMY_READ_AREA6); ctrl_inb (DUMMY_READ_AREA6);
#endif #endif
......
...@@ -575,6 +575,49 @@ unsigned long probe_irq_on(void) ...@@ -575,6 +575,49 @@ unsigned long probe_irq_on(void)
EXPORT_SYMBOL(probe_irq_on); EXPORT_SYMBOL(probe_irq_on);
/* Return a mask of triggered interrupts (this
* can handle only legacy ISA interrupts).
*/
/*
* probe_irq_mask - scan a bitmap of interrupt lines
* @val: mask of interrupts to consider
*
* Scan the ISA bus interrupt lines and return a bitmap of
* active interrupts. The interrupt probe logic state is then
* returned to its previous value.
*
* Note: we need to scan all the irq's even though we will
* only return ISA irq numbers - just so that we reset them
* all to a known state.
*/
unsigned int probe_irq_mask(unsigned long val)
{
int i;
unsigned int mask;
mask = 0;
for (i = 0; i < NR_IRQS; i++) {
irq_desc_t *desc = irq_desc + i;
unsigned int status;
spin_lock_irq(&desc->lock);
status = desc->status;
if (status & IRQ_AUTODETECT) {
if (i < 16 && !(status & IRQ_WAITING))
mask |= 1 << i;
desc->status = status & ~IRQ_AUTODETECT;
desc->handler->shutdown(i);
}
spin_unlock_irq(&desc->lock);
}
up(&probe_sem);
return mask & val;
}
int probe_irq_off(unsigned long val) int probe_irq_off(unsigned long val)
{ {
int i, irq_found, nr_irqs; int i, irq_found, nr_irqs;
......
/* $Id: process.c,v 1.26 2004/02/06 14:14:14 kkojima Exp $ /* $Id: process.c,v 1.28 2004/05/05 16:54:23 lethal Exp $
* *
* linux/arch/sh/kernel/process.c * linux/arch/sh/kernel/process.c
* *
...@@ -25,6 +25,11 @@ ...@@ -25,6 +25,11 @@
#include <asm/uaccess.h> #include <asm/uaccess.h>
#include <asm/mmu_context.h> #include <asm/mmu_context.h>
#include <asm/elf.h> #include <asm/elf.h>
#if defined(CONFIG_SH_HS7751RVOIP)
#include <asm/hs7751rvoip/hs7751rvoip.h>
#elif defined(CONFIG_SH_RTS7751R2D)
#include <asm/rts7751r2d/rts7751r2d.h>
#endif
static int hlt_counter=0; static int hlt_counter=0;
...@@ -50,8 +55,14 @@ void default_idle(void) ...@@ -50,8 +55,14 @@ void default_idle(void)
{ {
/* endless idle loop with no priority at all */ /* endless idle loop with no priority at all */
while (1) { while (1) {
while (!need_resched()) if (hlt_counter) {
cpu_relax(); while (1)
if (need_resched())
break;
} else {
while (!need_resched())
cpu_sleep();
}
schedule(); schedule();
} }
...@@ -73,14 +84,30 @@ EXPORT_SYMBOL(machine_restart); ...@@ -73,14 +84,30 @@ EXPORT_SYMBOL(machine_restart);
void machine_halt(void) void machine_halt(void)
{ {
#if defined(CONFIG_SH_HS7751RVOIP)
unsigned short value;
value = ctrl_inw(PA_OUTPORTR);
ctrl_outw((value & 0xffdf), PA_OUTPORTR);
#elif defined(CONFIG_SH_RTS7751R2D)
ctrl_outw(0x0001, PA_POWOFF);
#endif
while (1) while (1)
cpu_relax(); cpu_sleep();
} }
EXPORT_SYMBOL(machine_halt); EXPORT_SYMBOL(machine_halt);
void machine_power_off(void) void machine_power_off(void)
{ {
#if defined(CONFIG_SH_HS7751RVOIP)
unsigned short value;
value = ctrl_inw(PA_OUTPORTR);
ctrl_outw((value & 0xffdf), PA_OUTPORTR);
#elif defined(CONFIG_SH_RTS7751R2D)
ctrl_outw(0x0001, PA_POWOFF);
#endif
} }
EXPORT_SYMBOL(machine_power_off); EXPORT_SYMBOL(machine_power_off);
......
/* $Id: ptrace.c,v 1.14 2003/11/28 23:05:43 kkojima Exp $ /* $Id: ptrace.c,v 1.15 2004/05/07 05:32:05 sugioka Exp $
* *
* linux/arch/sh/kernel/ptrace.c * linux/arch/sh/kernel/ptrace.c
* *
...@@ -255,13 +255,6 @@ asmlinkage int sys_ptrace(long request, long pid, long addr, long data) ...@@ -255,13 +255,6 @@ asmlinkage int sys_ptrace(long request, long pid, long addr, long data)
ret = ptrace_detach(child, data); ret = ptrace_detach(child, data);
break; break;
case PTRACE_SETOPTIONS:
if (data & PTRACE_O_TRACESYSGOOD)
child->ptrace |= PT_TRACESYSGOOD;
else
child->ptrace &= ~PT_TRACESYSGOOD;
ret = 0;
break;
#ifdef CONFIG_SH_DSP #ifdef CONFIG_SH_DSP
case PTRACE_GETDSPREGS: { case PTRACE_GETDSPREGS: {
unsigned long dp; unsigned long dp;
......
...@@ -25,15 +25,12 @@ ...@@ -25,15 +25,12 @@
#include <asm/io_generic.h> #include <asm/io_generic.h>
#include <asm/sections.h> #include <asm/sections.h>
#include <asm/irq.h> #include <asm/irq.h>
#ifdef CONFIG_SH_EARLY_PRINTK
#include <asm/sh_bios.h>
#endif
#ifdef CONFIG_SH_KGDB #ifdef CONFIG_SH_KGDB
#include <asm/kgdb.h> #include <asm/kgdb.h>
static int kgdb_parse_options(char *options); static int kgdb_parse_options(char *options);
#endif #endif
extern void * __rd_start, * __rd_end;
/* /*
* Machine setup.. * Machine setup..
*/ */
...@@ -118,130 +115,6 @@ static struct resource ram_resources[] = { ...@@ -118,130 +115,6 @@ static struct resource ram_resources[] = {
unsigned long memory_start, memory_end; unsigned long memory_start, memory_end;
/* XXX: MRB-remove - blatant hack */
#if 1
#define SCIF_REG 0xffe80000
static void scif_sercon_putc(int c)
{
while (!(ctrl_inw(SCIF_REG + 0x10) & 0x20)) ;
ctrl_outb(c, SCIF_REG + 12);
ctrl_outw((ctrl_inw(SCIF_REG + 0x10) & 0x9f), SCIF_REG + 0x10);
if (c == '\n')
scif_sercon_putc('\r');
}
static void scif_sercon_flush(void)
{
ctrl_outw((ctrl_inw(SCIF_REG + 0x10) & 0xbf), SCIF_REG + 0x10);
while (!(ctrl_inw(SCIF_REG + 0x10) & 0x40)) ;
ctrl_outw((ctrl_inw(SCIF_REG + 0x10) & 0xbf), SCIF_REG + 0x10);
}
static void scif_sercon_write(struct console *con, const char *s, unsigned count)
{
while (count-- > 0)
scif_sercon_putc(*s++);
scif_sercon_flush();
}
static int __init scif_sercon_setup(struct console *con, char *options)
{
con->cflag = CREAD | HUPCL | CLOCAL | B57600 | CS8;
return 0;
}
static struct console scif_sercon = {
.name = "sercon",
.write = scif_sercon_write,
.setup = scif_sercon_setup,
.flags = CON_PRINTBUFFER,
.index = -1,
};
void scif_sercon_init(int baud)
{
ctrl_outw(0, SCIF_REG + 8);
ctrl_outw(0, SCIF_REG);
/* Set baud rate */
ctrl_outb((50000000 / (32 * baud)) - 1, SCIF_REG + 4);
ctrl_outw(12, SCIF_REG + 24);
ctrl_outw(8, SCIF_REG + 24);
ctrl_outw(0, SCIF_REG + 32);
ctrl_outw(0x60, SCIF_REG + 16);
ctrl_outw(0, SCIF_REG + 36);
ctrl_outw(0x30, SCIF_REG + 8);
register_console(&scif_sercon);
}
void scif_sercon_unregister(void)
{
unregister_console(&scif_sercon);
}
#endif
#ifdef CONFIG_SH_EARLY_PRINTK
/*
* Print a string through the BIOS
*/
static void sh_console_write(struct console *co, const char *s,
unsigned count)
{
sh_bios_console_write(s, count);
}
/*
* Setup initial baud/bits/parity. We do two things here:
* - construct a cflag setting for the first rs_open()
* - initialize the serial port
* Return non-zero if we didn't find a serial port.
*/
static int __init sh_console_setup(struct console *co, char *options)
{
int cflag = CREAD | HUPCL | CLOCAL;
/*
* Now construct a cflag setting.
* TODO: this is a totally bogus cflag, as we have
* no idea what serial settings the BIOS is using, or
* even if its using the serial port at all.
*/
cflag |= B115200 | CS8 | /*no parity*/0;
co->cflag = cflag;
return 0;
}
static struct console sh_console = {
.name = "bios",
.write = sh_console_write,
.setup = sh_console_setup,
.flags = CON_PRINTBUFFER,
.index = -1,
};
void sh_console_init(void)
{
register_console(&sh_console);
}
void sh_console_unregister(void)
{
unregister_console(&sh_console);
}
#endif
static inline void parse_cmdline (char ** cmdline_p, char mv_name[MV_NAME_SIZE], static inline void parse_cmdline (char ** cmdline_p, char mv_name[MV_NAME_SIZE],
struct sh_machine_vector** mvp, struct sh_machine_vector** mvp,
unsigned long *mv_io_base, unsigned long *mv_io_base,
...@@ -323,10 +196,6 @@ static int __init sh_mv_setup(char **cmdline_p) ...@@ -323,10 +196,6 @@ static int __init sh_mv_setup(char **cmdline_p)
parse_cmdline(cmdline_p, mv_name, &mv, &mv_io_base, &mv_mmio_enable); parse_cmdline(cmdline_p, mv_name, &mv, &mv_io_base, &mv_mmio_enable);
#ifdef CONFIG_CMDLINE_BOOL
sprintf(*cmdline_p, CONFIG_CMDLINE);
#endif
#ifdef CONFIG_SH_GENERIC #ifdef CONFIG_SH_GENERIC
if (mv == NULL) { if (mv == NULL) {
mv = &mv_unknown; mv = &mv_unknown;
...@@ -380,14 +249,15 @@ void __init setup_arch(char **cmdline_p) ...@@ -380,14 +249,15 @@ void __init setup_arch(char **cmdline_p)
unsigned long bootmap_size; unsigned long bootmap_size;
unsigned long start_pfn, max_pfn, max_low_pfn; unsigned long start_pfn, max_pfn, max_low_pfn;
/* XXX: MRB-remove */ #ifdef CONFIG_EARLY_PRINTK
#if 0 extern void enable_early_printk(void);
scif_sercon_init(57600);
enable_early_printk();
#endif #endif
#ifdef CONFIG_SH_EARLY_PRINTK #ifdef CONFIG_CMDLINE_BOOL
sh_console_init(); strcpy(COMMAND_LINE, CONFIG_CMDLINE);
#endif #endif
ROOT_DEV = old_decode_dev(ORIG_ROOT_DEV); ROOT_DEV = old_decode_dev(ORIG_ROOT_DEV);
#ifdef CONFIG_BLK_DEV_RAM #ifdef CONFIG_BLK_DEV_RAM
...@@ -490,6 +360,13 @@ void __init setup_arch(char **cmdline_p) ...@@ -490,6 +360,13 @@ void __init setup_arch(char **cmdline_p)
reserve_bootmem_node(NODE_DATA(0), __MEMORY_START, PAGE_SIZE); reserve_bootmem_node(NODE_DATA(0), __MEMORY_START, PAGE_SIZE);
#ifdef CONFIG_BLK_DEV_INITRD #ifdef CONFIG_BLK_DEV_INITRD
ROOT_DEV = MKDEV(RAMDISK_MAJOR, 0);
if (&__rd_start != &__rd_end) {
LOADER_TYPE = 1;
INITRD_START = PHYSADDR((unsigned long)&__rd_start) - __MEMORY_START;
INITRD_SIZE = (unsigned long)&__rd_end - (unsigned long)&__rd_start;
}
if (LOADER_TYPE && INITRD_START) { if (LOADER_TYPE && INITRD_START) {
if (INITRD_START + INITRD_SIZE <= (max_low_pfn << PAGE_SHIFT)) { if (INITRD_START + INITRD_SIZE <= (max_low_pfn << PAGE_SHIFT)) {
reserve_bootmem_node(NODE_DATA(0), INITRD_START+__MEMORY_START, INITRD_SIZE); reserve_bootmem_node(NODE_DATA(0), INITRD_START+__MEMORY_START, INITRD_SIZE);
...@@ -555,8 +432,10 @@ subsys_initcall(topology_init); ...@@ -555,8 +432,10 @@ subsys_initcall(topology_init);
static const char *cpu_name[] = { static const char *cpu_name[] = {
[CPU_SH7604] = "SH7604", [CPU_SH7604] = "SH7604",
[CPU_SH7705] = "SH7705",
[CPU_SH7708] = "SH7708", [CPU_SH7708] = "SH7708",
[CPU_SH7729] = "SH7729", [CPU_SH7729] = "SH7729",
[CPU_SH7300] = "SH7300",
[CPU_SH7750] = "SH7750", [CPU_SH7750] = "SH7750",
[CPU_SH7750S] = "SH7750S", [CPU_SH7750S] = "SH7750S",
[CPU_SH7750R] = "SH7750R", [CPU_SH7750R] = "SH7750R",
...@@ -593,8 +472,8 @@ static void show_cpuflags(struct seq_file *m) ...@@ -593,8 +472,8 @@ static void show_cpuflags(struct seq_file *m)
for (i = 0; i < cpu_data->flags; i++) for (i = 0; i < cpu_data->flags; i++)
if ((cpu_data->flags & (1 << i))) if ((cpu_data->flags & (1 << i)))
seq_printf(m, " %s", cpu_flags[i]); seq_printf(m, " %s", cpu_flags[i+1]);
seq_printf(m, "\n"); seq_printf(m, "\n");
} }
......
...@@ -33,6 +33,7 @@ EXPORT_SYMBOL(dump_fpu); ...@@ -33,6 +33,7 @@ EXPORT_SYMBOL(dump_fpu);
EXPORT_SYMBOL(iounmap); EXPORT_SYMBOL(iounmap);
EXPORT_SYMBOL(enable_irq); EXPORT_SYMBOL(enable_irq);
EXPORT_SYMBOL(disable_irq); EXPORT_SYMBOL(disable_irq);
EXPORT_SYMBOL(probe_irq_mask);
EXPORT_SYMBOL(kernel_thread); EXPORT_SYMBOL(kernel_thread);
EXPORT_SYMBOL(disable_irq_nosync); EXPORT_SYMBOL(disable_irq_nosync);
EXPORT_SYMBOL(irq_desc); EXPORT_SYMBOL(irq_desc);
...@@ -83,6 +84,7 @@ EXPORT_SYMBOL(__down); ...@@ -83,6 +84,7 @@ EXPORT_SYMBOL(__down);
EXPORT_SYMBOL(__down_interruptible); EXPORT_SYMBOL(__down_interruptible);
EXPORT_SYMBOL(__udelay); EXPORT_SYMBOL(__udelay);
EXPORT_SYMBOL(__ndelay);
EXPORT_SYMBOL(__const_udelay); EXPORT_SYMBOL(__const_udelay);
#define DECLARE_EXPORT(name) extern void name(void);EXPORT_SYMBOL_NOVERS(name) #define DECLARE_EXPORT(name) extern void name(void);EXPORT_SYMBOL_NOVERS(name)
...@@ -100,6 +102,7 @@ DECLARE_EXPORT(__movstr); ...@@ -100,6 +102,7 @@ DECLARE_EXPORT(__movstr);
DECLARE_EXPORT(__movstr_i4_even); DECLARE_EXPORT(__movstr_i4_even);
DECLARE_EXPORT(__movstr_i4_odd); DECLARE_EXPORT(__movstr_i4_odd);
DECLARE_EXPORT(__movstrSI12_i4);
/* needed by some modules */ /* needed by some modules */
EXPORT_SYMBOL(flush_cache_all); EXPORT_SYMBOL(flush_cache_all);
...@@ -115,3 +118,4 @@ EXPORT_SYMBOL(synchronize_irq); ...@@ -115,3 +118,4 @@ EXPORT_SYMBOL(synchronize_irq);
#endif #endif
EXPORT_SYMBOL(csum_partial); EXPORT_SYMBOL(csum_partial);
EXPORT_SYMBOL(consistent_sync);
/* $Id: traps.c,v 1.16 2004/03/16 00:10:54 lethal Exp $ /* $Id: traps.c,v 1.17 2004/05/02 01:46:30 sugioka Exp $
* *
* linux/arch/sh/traps.c * linux/arch/sh/traps.c
* *
...@@ -559,7 +559,7 @@ int is_dsp_inst(struct pt_regs *regs) ...@@ -559,7 +559,7 @@ int is_dsp_inst(struct pt_regs *regs)
* Safe guard if DSP mode is already enabled or we're lacking * Safe guard if DSP mode is already enabled or we're lacking
* the DSP altogether. * the DSP altogether.
*/ */
if (!test_bit(CPU_HAS_DSP, &(cpu_data->flags)) || (regs->sr & SR_DSP)) if (!(cpu_data->flags & CPU_HAS_DSP) || (regs->sr & SR_DSP))
return 0; return 0;
get_user(inst, ((unsigned short *) regs->pc)); get_user(inst, ((unsigned short *) regs->pc));
...@@ -636,7 +636,7 @@ void __init trap_init(void) ...@@ -636,7 +636,7 @@ void __init trap_init(void)
= (void *)do_illegal_slot_inst; = (void *)do_illegal_slot_inst;
#ifdef CONFIG_CPU_SH4 #ifdef CONFIG_CPU_SH4
if (!test_bit(CPU_HAS_FPU, &(cpu_data->flags))) { if (!(cpu_data->flags & CPU_HAS_FPU)) {
/* For SH-4 lacking an FPU, treat floating point instructions /* For SH-4 lacking an FPU, treat floating point instructions
as reserved. */ as reserved. */
/* entry 64 corresponds to EXPEVT=0x800 */ /* entry 64 corresponds to EXPEVT=0x800 */
......
...@@ -38,6 +38,14 @@ SECTIONS ...@@ -38,6 +38,14 @@ SECTIONS
.data : { /* Data */ .data : { /* Data */
*(.data) *(.data)
/* Align the initial ramdisk image (INITRD) on page boundaries. */
. = ALIGN(4096);
__rd_start = .;
*(.initrd)
. = ALIGN(4096);
__rd_end = .;
CONSTRUCTORS CONSTRUCTORS
} }
......
...@@ -33,3 +33,9 @@ void __udelay(unsigned long usecs) ...@@ -33,3 +33,9 @@ void __udelay(unsigned long usecs)
{ {
__const_udelay(usecs * 0x000010c6); /* 2**32 / 1000000 */ __const_udelay(usecs * 0x000010c6); /* 2**32 / 1000000 */
} }
void __ndelay(unsigned long nsecs)
{
__const_udelay(nsecs * 0x00000005);
}
/* $Id: cache-sh3.c,v 1.8 2004/02/01 16:26:27 lethal Exp $ /* $Id: cache-sh3.c,v 1.9 2004/05/02 01:46:30 sugioka Exp $
* *
* linux/arch/sh/mm/cache-sh3.c * linux/arch/sh/mm/cache-sh3.c
* *
...@@ -65,14 +65,14 @@ int __init detect_cpu_and_cache_system(void) ...@@ -65,14 +65,14 @@ int __init detect_cpu_and_cache_system(void)
* 2K(direct) 7702 is not supported (yet) * 2K(direct) 7702 is not supported (yet)
*/ */
if (data0 == data1 && data2 == data3) { /* Shadow */ if (data0 == data1 && data2 == data3) { /* Shadow */
cpu_data->dcache.way_shift = 11; cpu_data->dcache.way_incr = (1 << 11);
cpu_data->dcache.entry_mask = 0x7f0; cpu_data->dcache.entry_mask = 0x7f0;
cpu_data->dcache.sets = 128; cpu_data->dcache.sets = 128;
cpu_data->type = CPU_SH7708; cpu_data->type = CPU_SH7708;
set_bit(CPU_HAS_MMU_PAGE_ASSOC, &(cpu_data->flags)); cpu_data->flags |= CPU_HAS_MMU_PAGE_ASSOC;
} else { /* 7709A or 7729 */ } else { /* 7709A or 7729 */
cpu_data->dcache.way_shift = 12; cpu_data->dcache.way_incr = (1 << 12);
cpu_data->dcache.entry_mask = 0xff0; cpu_data->dcache.entry_mask = 0xff0;
cpu_data->dcache.sets = 256; cpu_data->dcache.sets = 256;
cpu_data->type = CPU_SH7729; cpu_data->type = CPU_SH7729;
...@@ -108,13 +108,12 @@ void __flush_wback_region(void *start, int size) ...@@ -108,13 +108,12 @@ void __flush_wback_region(void *start, int size)
& ~(L1_CACHE_BYTES-1); & ~(L1_CACHE_BYTES-1);
for (v = begin; v < end; v+=L1_CACHE_BYTES) { for (v = begin; v < end; v+=L1_CACHE_BYTES) {
unsigned long addrstart = CACHE_OC_ADDRESS_ARRAY;
for (j = 0; j < cpu_data->dcache.ways; j++) { for (j = 0; j < cpu_data->dcache.ways; j++) {
unsigned long data, addr, p; unsigned long data, addr, p;
p = __pa(v); p = __pa(v);
addr = CACHE_OC_ADDRESS_ARRAY | addr = addrstart | (v & cpu_data->dcache.entry_mask);
(j << cpu_data->dcache.way_shift)|
(v & cpu_data->dcache.entry_mask);
local_irq_save(flags); local_irq_save(flags);
data = ctrl_inl(addr); data = ctrl_inl(addr);
...@@ -126,6 +125,7 @@ void __flush_wback_region(void *start, int size) ...@@ -126,6 +125,7 @@ void __flush_wback_region(void *start, int size)
break; break;
} }
local_irq_restore(flags); local_irq_restore(flags);
addrstart += cpu_data->dcache.way_incr;
} }
} }
} }
......
...@@ -30,7 +30,7 @@ static void __flush_dcache_all_ex(void); ...@@ -30,7 +30,7 @@ static void __flush_dcache_all_ex(void);
int __init detect_cpu_and_cache_system(void) int __init detect_cpu_and_cache_system(void)
{ {
unsigned long pvr, prr, ccr, cvr; unsigned long pvr, prr, cvr;
unsigned long size; unsigned long size;
static unsigned long sizes[16] = { static unsigned long sizes[16] = {
...@@ -48,7 +48,7 @@ int __init detect_cpu_and_cache_system(void) ...@@ -48,7 +48,7 @@ int __init detect_cpu_and_cache_system(void)
/* /*
* Setup some sane SH-4 defaults for the icache * Setup some sane SH-4 defaults for the icache
*/ */
cpu_data->icache.way_shift = 13; cpu_data->icache.way_incr = (1 << 13);
cpu_data->icache.entry_shift = 5; cpu_data->icache.entry_shift = 5;
cpu_data->icache.entry_mask = 0x1fe0; cpu_data->icache.entry_mask = 0x1fe0;
cpu_data->icache.sets = 256; cpu_data->icache.sets = 256;
...@@ -58,7 +58,7 @@ int __init detect_cpu_and_cache_system(void) ...@@ -58,7 +58,7 @@ int __init detect_cpu_and_cache_system(void)
/* /*
* And again for the dcache .. * And again for the dcache ..
*/ */
cpu_data->dcache.way_shift = 14; cpu_data->dcache.way_incr = (1 << 14);
cpu_data->dcache.entry_shift = 5; cpu_data->dcache.entry_shift = 5;
cpu_data->dcache.entry_mask = 0x3fe0; cpu_data->dcache.entry_mask = 0x3fe0;
cpu_data->dcache.sets = 512; cpu_data->dcache.sets = 512;
...@@ -66,7 +66,7 @@ int __init detect_cpu_and_cache_system(void) ...@@ -66,7 +66,7 @@ int __init detect_cpu_and_cache_system(void)
cpu_data->dcache.linesz = L1_CACHE_BYTES; cpu_data->dcache.linesz = L1_CACHE_BYTES;
/* Set the FPU flag, virtually all SH-4's have one */ /* Set the FPU flag, virtually all SH-4's have one */
set_bit(CPU_HAS_FPU, &(cpu_data->flags)); cpu_data->flags |= CPU_HAS_FPU;
/* /*
* Probe the underlying processor version/revision and * Probe the underlying processor version/revision and
...@@ -75,7 +75,7 @@ int __init detect_cpu_and_cache_system(void) ...@@ -75,7 +75,7 @@ int __init detect_cpu_and_cache_system(void)
switch (pvr) { switch (pvr) {
case 0x205: case 0x205:
cpu_data->type = CPU_SH7750; cpu_data->type = CPU_SH7750;
set_bit(CPU_HAS_P2_FLUSH_BUG, &(cpu_data->flags)); cpu_data->flags |= CPU_HAS_P2_FLUSH_BUG;
break; break;
case 0x206: case 0x206:
cpu_data->type = CPU_SH7750S; cpu_data->type = CPU_SH7750S;
...@@ -84,7 +84,7 @@ int __init detect_cpu_and_cache_system(void) ...@@ -84,7 +84,7 @@ int __init detect_cpu_and_cache_system(void)
* FIXME: This is needed for 7750, but do we need it for the * FIXME: This is needed for 7750, but do we need it for the
* 7750S too? For now, assume we do.. -- PFM * 7750S too? For now, assume we do.. -- PFM
*/ */
set_bit(CPU_HAS_P2_FLUSH_BUG, &(cpu_data->flags)); cpu_data->flags |= CPU_HAS_P2_FLUSH_BUG;
break; break;
case 0x1100: case 0x1100:
...@@ -102,7 +102,7 @@ int __init detect_cpu_and_cache_system(void) ...@@ -102,7 +102,7 @@ int __init detect_cpu_and_cache_system(void)
cpu_data->dcache.ways = 2; cpu_data->dcache.ways = 2;
/* No FPU on the SH4-500 series.. */ /* No FPU on the SH4-500 series.. */
clear_bit(CPU_HAS_FPU, &(cpu_data->flags)); cpu_data->flags &= ~CPU_HAS_FPU;
break; break;
case 0x600: case 0x600:
cpu_data->type = CPU_SH4_202; cpu_data->type = CPU_SH4_202;
...@@ -129,27 +129,20 @@ int __init detect_cpu_and_cache_system(void) ...@@ -129,27 +129,20 @@ int __init detect_cpu_and_cache_system(void)
* On anything that's not a direct-mapped cache, look to the CVR * On anything that's not a direct-mapped cache, look to the CVR
* for I/D-cache specifics. * for I/D-cache specifics.
*/ */
if (cpu_data->dcache.ways > 1) { if (cpu_data->icache.ways > 1) {
jump_to_P2();
ccr = ctrl_inl(CCR);
/* Force EMODE */
if (!(ccr & CCR_CACHE_EMODE)) {
ccr |= CCR_CACHE_EMODE;
ctrl_outl(ccr, CCR);
}
back_to_P1();
size = sizes[(cvr >> 20) & 0xf]; size = sizes[(cvr >> 20) & 0xf];
cpu_data->icache.way_shift = (size >> 1); cpu_data->icache.way_incr = size / cpu_data->icache.ways;
cpu_data->icache.entry_mask = ((size >> 2) - (1 << 5)); cpu_data->icache.sets = (size >> 6);
cpu_data->icache.sets = (size >> 6); cpu_data->icache.entry_mask =
((size / cpu_data->icache.ways) - (1 << 5));
}
if (cpu_data->dcache.ways > 1) {
size = sizes[(cvr >> 16) & 0xf]; size = sizes[(cvr >> 16) & 0xf];
cpu_data->dcache.way_shift = (size >> 1); cpu_data->dcache.way_incr = size / cpu_data->dcache.ways;
cpu_data->dcache.entry_mask = ((size >> 2) - (1 << 5)); cpu_data->dcache.sets = (size >> 6);
cpu_data->dcache.sets = (size >> 6); cpu_data->dcache.entry_mask =
((size / cpu_data->dcache.ways) - (1 << 5));
} }
return 0; return 0;
...@@ -250,7 +243,7 @@ static void __flush_cache_4096_all_ex(unsigned long start) ...@@ -250,7 +243,7 @@ static void __flush_cache_4096_all_ex(unsigned long start)
int i; int i;
entry_offset = 1 << cpu_data->dcache.entry_shift; entry_offset = 1 << cpu_data->dcache.entry_shift;
for (i = 0; i < cpu_data->dcache.ways; i++, start += (1 << cpu_data->dcache.way_shift)) { for (i = 0; i < cpu_data->dcache.ways; i++, start += cpu_data->dcache.way_incr) {
for (addr = CACHE_OC_ADDRESS_ARRAY + start; for (addr = CACHE_OC_ADDRESS_ARRAY + start;
addr < CACHE_OC_ADDRESS_ARRAY + 4096 + start; addr < CACHE_OC_ADDRESS_ARRAY + 4096 + start;
addr += entry_offset) { addr += entry_offset) {
...@@ -297,7 +290,7 @@ void flush_cache_sigtramp(unsigned long addr) ...@@ -297,7 +290,7 @@ void flush_cache_sigtramp(unsigned long addr)
local_irq_save(flags); local_irq_save(flags);
jump_to_P2(); jump_to_P2();
for(i = 0; i < cpu_data->icache.ways; i++, index += (1 << cpu_data->icache.way_shift)) for(i = 0; i < cpu_data->icache.ways; i++, index += cpu_data->icache.way_incr)
ctrl_outl(0, index); /* Clear out Valid-bit */ ctrl_outl(0, index); /* Clear out Valid-bit */
back_to_P1(); back_to_P1();
local_irq_restore(flags); local_irq_restore(flags);
...@@ -313,12 +306,13 @@ static inline void flush_cache_4096(unsigned long start, ...@@ -313,12 +306,13 @@ static inline void flush_cache_4096(unsigned long start,
* SH7751, SH7751R, and ST40 have no restriction to handle cache. * SH7751, SH7751R, and ST40 have no restriction to handle cache.
* (While SH7750 must do that at P2 area.) * (While SH7750 must do that at P2 area.)
*/ */
if (test_bit(CPU_HAS_P2_FLUSH_BUG, &(cpu_data->flags))) { if ((cpu_data->flags & CPU_HAS_P2_FLUSH_BUG)
|| start < CACHE_OC_ADDRESS_ARRAY) {
local_irq_save(flags); local_irq_save(flags);
__flush_cache_4096(start | SH_CACHE_ASSOC, phys | 0x80000000, 0x20000000); __flush_cache_4096(start | SH_CACHE_ASSOC, P1SEGADDR(phys), 0x20000000);
local_irq_restore(flags); local_irq_restore(flags);
} else if (start >= CACHE_OC_ADDRESS_ARRAY) { } else {
__flush_cache_4096(start | SH_CACHE_ASSOC, phys | 0x80000000, 0); __flush_cache_4096(start | SH_CACHE_ASSOC, P1SEGADDR(phys), 0);
} }
} }
......
...@@ -72,7 +72,7 @@ void __flush_tlb_page(unsigned long asid, unsigned long page) ...@@ -72,7 +72,7 @@ void __flush_tlb_page(unsigned long asid, unsigned long page)
addr = MMU_TLB_ADDRESS_ARRAY | (page & 0x1F000); addr = MMU_TLB_ADDRESS_ARRAY | (page & 0x1F000);
data = (page & 0xfffe0000) | asid; /* VALID bit is off */ data = (page & 0xfffe0000) | asid; /* VALID bit is off */
if (test_bit(CPU_HAS_MMU_PAGE_ASSOC, &(cpu_data->flags))) { if ((cpu_data->flags & CPU_HAS_MMU_PAGE_ASSOC)) {
addr |= MMU_PAGE_ASSOC_BIT; addr |= MMU_PAGE_ASSOC_BIT;
ways = 1; /* we already know the way .. */ ways = 1; /* we already know the way .. */
} }
......
#
# Makefile for a ramdisk image
#
obj-y += ramdisk.o
O_FORMAT = $(shell $(OBJDUMP) -i | head -n 2 | grep elf32)
img := $(subst ",,$(CONFIG_EMBEDDED_RAMDISK_IMAGE))
# add $(src) when $(img) is relative
img := $(subst $(src)//,/,$(src)/$(img))
quiet_cmd_ramdisk = LD $@
define cmd_ramdisk
$(LD) -T $(src)/ld.script -b binary --oformat $(O_FORMAT) -o $@ $(img)
endef
$(obj)/ramdisk.o: $(img) $(src)/ld.script
$(call cmd,ramdisk)
OUTPUT_ARCH(sh)
SECTIONS
{
.initrd :
{
*(.data)
}
}
...@@ -7,6 +7,7 @@ ...@@ -7,6 +7,7 @@
# #
SE SH_SOLUTION_ENGINE SE SH_SOLUTION_ENGINE
7751SE SH_7751_SOLUTION_ENGINE 7751SE SH_7751_SOLUTION_ENGINE
7300SE SH_7300_SOLUTION_ENGINE
7751SYSTEMH SH_7751_SYSTEMH 7751SYSTEMH SH_7751_SYSTEMH
HP600 SH_HP600 HP600 SH_HP600
HP620 SH_HP620 HP620 SH_HP620
...@@ -21,4 +22,6 @@ BIGSUR SH_BIGSUR ...@@ -21,4 +22,6 @@ BIGSUR SH_BIGSUR
ADX SH_ADX ADX SH_ADX
MPC1211 SH_MPC1211 MPC1211 SH_MPC1211
SNAPGEAR SH_SECUREEDGE5410 SNAPGEAR SH_SECUREEDGE5410
HS7751RVOIP SH_HS7751RVOIP
RTS7751R2D SH_RTS7751R2D
/*
* include/asm-sh/bus-sh.h
*
* Copyright (C) 2004 Paul Mundt
*
* 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.
*/
#ifndef __ASM_SH_BUS_SH_H
#define __ASM_SH_BUS_SH_H
extern struct bus_type sh_bus_types[];
struct sh_dev {
struct device dev;
char *name;
unsigned int dev_id;
unsigned int bus_id;
struct resource res;
void *mapbase;
unsigned int irq[6];
u64 *dma_mask;
};
#define to_sh_dev(d) container_of((d), struct sh_dev, dev)
#define sh_get_drvdata(d) dev_get_drvdata(&(d)->dev)
#define sh_set_drvdata(d,p) dev_set_drvdata(&(d)->dev, (p))
struct sh_driver {
struct device_driver drv;
unsigned int dev_id;
unsigned int bus_id;
int (*probe)(struct sh_dev *);
int (*remove)(struct sh_dev *);
int (*suspend)(struct sh_dev *, u32);
int (*resume)(struct sh_dev *);
};
#define to_sh_driver(d) container_of((d), struct sh_driver, drv)
#define sh_name(d) ((d)->dev.driver->name)
/*
* Device ID numbers for bus types
*/
enum {
SH_DEV_ID_USB_OHCI,
};
#define SH_NR_BUSES 1
#define SH_BUS_NAME_VIRT "shbus"
enum {
SH_BUS_VIRT,
};
/* arch/sh/kernel/cpu/bus.c */
extern int sh_device_register(struct sh_dev *dev);
extern void sh_device_unregister(struct sh_dev *dev);
extern int sh_driver_register(struct sh_driver *drv);
extern void sh_driver_unregister(struct sh_driver *drv);
#endif /* __ASM_SH_BUS_SH_H */
...@@ -28,7 +28,8 @@ struct cache_info { ...@@ -28,7 +28,8 @@ struct cache_info {
unsigned int sets; unsigned int sets;
unsigned int linesz; unsigned int linesz;
unsigned int way_shift; unsigned int way_incr;
unsigned int entry_shift; unsigned int entry_shift;
unsigned int entry_mask; unsigned int entry_mask;
......
#ifndef __ASM_SH_DAC_H #ifndef __ASM_CPU_SH3_DAC_H
#define __ASM_SH_DAC_H #define __ASM_CPU_SH3_DAC_H
/* /*
* Copyright (C) 2003 Andriy Skulysh * Copyright (C) 2003 Andriy Skulysh
...@@ -38,5 +38,4 @@ static __inline__ void sh_dac_output(u8 value, int channel) ...@@ -38,5 +38,4 @@ static __inline__ void sh_dac_output(u8 value, int channel)
else ctrl_outb(value,DADR0); else ctrl_outb(value,DADR0);
} }
#endif /* __ASM_SH_DAC_H */ #endif /* __ASM_CPU_SH3_DAC_H */
...@@ -271,6 +271,7 @@ extern unsigned long get_wchan(struct task_struct *p); ...@@ -271,6 +271,7 @@ extern unsigned long get_wchan(struct task_struct *p);
#define KSTK_EIP(tsk) ((tsk)->thread.pc) #define KSTK_EIP(tsk) ((tsk)->thread.pc)
#define KSTK_ESP(tsk) ((tsk)->thread.sp) #define KSTK_ESP(tsk) ((tsk)->thread.sp)
#define cpu_relax() __asm__ __volatile__ ("sleep" : : : "memory") #define cpu_sleep() __asm__ __volatile__ ("sleep" : : : "memory")
#define cpu_relax() do { } while (0)
#endif /* __ASM_SH_PROCESSOR_H */ #endif /* __ASM_SH_PROCESSOR_H */
...@@ -44,8 +44,5 @@ ...@@ -44,8 +44,5 @@
#define SERIAL_PORT_DFNS STD_SERIAL_PORT_DEFNS #define SERIAL_PORT_DFNS STD_SERIAL_PORT_DEFNS
/* XXX: This should be moved ino irq.h */
#define irq_canonicalize(x) (x)
#endif #endif
#endif /* _ASM_SERIAL_H */ #endif /* _ASM_SERIAL_H */
#ifndef __ASM_SH_SIGCONTEXT_H #ifndef __ASM_SH_SIGCONTEXT_H
#define __ASM_SH_SIGCONTEXT_H #define __ASM_SH_SIGCONTEXT_H
#include <asm/cpu/sigcontext.h> struct sigcontext {
unsigned long oldmask;
/* CPU registers */
unsigned long sc_regs[16];
unsigned long sc_pc;
unsigned long sc_pr;
unsigned long sc_sr;
unsigned long sc_gbr;
unsigned long sc_mach;
unsigned long sc_macl;
#if defined(__SH4__) || defined(CONFIG_CPU_SH4)
/* FPU registers */
unsigned long sc_fpregs[16];
unsigned long sc_xfpregs[16];
unsigned int sc_fpscr;
unsigned int sc_fpul;
unsigned int sc_ownedfp;
#endif
};
#endif /* __ASM_SH_SIGCONTEXT_H */ #endif /* __ASM_SH_SIGCONTEXT_H */
...@@ -281,8 +281,17 @@ ...@@ -281,8 +281,17 @@
#define __NR_utimes 271 #define __NR_utimes 271
#define __NR_fadvise64_64 272 #define __NR_fadvise64_64 272
#define __NR_vserver 273 #define __NR_vserver 273
#define __NR_mbind 274
#define __NR_get_mempolicy 275
#define __NR_set_mempolicy 276
#define __NR_mq_open 277
#define __NR_mq_unlink (__NR_mq_open+1)
#define __NR_mq_timedsend (__NR_mq_open+2)
#define __NR_mq_timedreceive (__NR_mq_open+3)
#define __NR_mq_notify (__NR_mq_open+4)
#define __NR_mq_getsetattr (__NR_mq_open+5)
#define NR_syscalls 274 #define NR_syscalls 283
/* user-visible error numbers are in the range -1 - -124: see <asm-sh/errno.h> */ /* user-visible error numbers are in the range -1 - -124: see <asm-sh/errno.h> */
...@@ -429,6 +438,7 @@ __syscall_return(type,__sc0); \ ...@@ -429,6 +438,7 @@ __syscall_return(type,__sc0); \
#include <linux/compiler.h> #include <linux/compiler.h>
#include <linux/types.h> #include <linux/types.h>
#include <linux/linkage.h>
#include <asm/ptrace.h> #include <asm/ptrace.h>
/* /*
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment