[PATCH] sh: Move CPU subtype configuration to its own Kconfig
Currently the CPU subtype options are cluttering up arch/sh/Kconfig somewhat. Given that, this moves all of that in to its own arch/sh/mm/Kconfig. Things like cache configuration are also moved to this new location. This also adds support for strict CPU tuning on newer cores, which requires the addition of as-option. Signed-off-by: Paul Mundt <lethal@linux-sh.org> Signed-off-by: Andrew Morton <akpm@osdl.org> Signed-off-by: Linus Torvalds <torvalds@osdl.org>
This commit is contained in:
parent
aa01666df3
commit
cad8244840
7
Makefile
7
Makefile
@ -263,6 +263,13 @@ export quiet Q KBUILD_VERBOSE
|
|||||||
# cc support functions to be used (only) in arch/$(ARCH)/Makefile
|
# cc support functions to be used (only) in arch/$(ARCH)/Makefile
|
||||||
# See documentation in Documentation/kbuild/makefiles.txt
|
# See documentation in Documentation/kbuild/makefiles.txt
|
||||||
|
|
||||||
|
# as-option
|
||||||
|
# Usage: cflags-y += $(call as-option, -Wa$(comma)-isa=foo,)
|
||||||
|
|
||||||
|
as-option = $(shell if $(CC) $(CFLAGS) $(1) -Wa,-Z -c -o /dev/null \
|
||||||
|
-xassembler /dev/null > /dev/null 2>&1; then echo "$(1)"; \
|
||||||
|
else echo "$(2)"; fi ;)
|
||||||
|
|
||||||
# cc-option
|
# cc-option
|
||||||
# Usage: cflags-y += $(call cc-option, -march=winchip-c6, -march=i586)
|
# Usage: cflags-y += $(call cc-option, -march=winchip-c6, -march=i586)
|
||||||
|
|
||||||
|
581
arch/sh/Kconfig
581
arch/sh/Kconfig
@ -33,9 +33,11 @@ config GENERIC_CALIBRATE_DELAY
|
|||||||
bool
|
bool
|
||||||
default y
|
default y
|
||||||
|
|
||||||
|
config GENERIC_IOMAP
|
||||||
|
bool
|
||||||
|
|
||||||
config ARCH_MAY_HAVE_PC_FDC
|
config ARCH_MAY_HAVE_PC_FDC
|
||||||
bool
|
bool
|
||||||
default y
|
|
||||||
|
|
||||||
source "init/Kconfig"
|
source "init/Kconfig"
|
||||||
|
|
||||||
@ -53,24 +55,28 @@ config SH_SOLUTION_ENGINE
|
|||||||
|
|
||||||
config SH_7751_SOLUTION_ENGINE
|
config SH_7751_SOLUTION_ENGINE
|
||||||
bool "SolutionEngine7751"
|
bool "SolutionEngine7751"
|
||||||
|
select CPU_SUBTYPE_SH7751
|
||||||
help
|
help
|
||||||
Select 7751 SolutionEngine if configuring for a Hitachi SH7751
|
Select 7751 SolutionEngine if configuring for a Hitachi SH7751
|
||||||
evaluation board.
|
evaluation board.
|
||||||
|
|
||||||
config SH_7300_SOLUTION_ENGINE
|
config SH_7300_SOLUTION_ENGINE
|
||||||
bool "SolutionEngine7300"
|
bool "SolutionEngine7300"
|
||||||
|
select CPU_SUBTYPE_SH7300
|
||||||
help
|
help
|
||||||
Select 7300 SolutionEngine if configuring for a Hitachi SH7300(SH-Mobile V)
|
Select 7300 SolutionEngine if configuring for a Hitachi SH7300(SH-Mobile V)
|
||||||
evaluation board.
|
evaluation board.
|
||||||
|
|
||||||
config SH_73180_SOLUTION_ENGINE
|
config SH_73180_SOLUTION_ENGINE
|
||||||
bool "SolutionEngine73180"
|
bool "SolutionEngine73180"
|
||||||
|
select CPU_SUBTYPE_SH73180
|
||||||
help
|
help
|
||||||
Select 73180 SolutionEngine if configuring for a Hitachi SH73180(SH-Mobile 3)
|
Select 73180 SolutionEngine if configuring for a Hitachi SH73180(SH-Mobile 3)
|
||||||
evaluation board.
|
evaluation board.
|
||||||
|
|
||||||
config SH_7751_SYSTEMH
|
config SH_7751_SYSTEMH
|
||||||
bool "SystemH7751R"
|
bool "SystemH7751R"
|
||||||
|
select CPU_SUBTYPE_SH7751R
|
||||||
help
|
help
|
||||||
Select SystemH if you are configuring for a Renesas SystemH
|
Select SystemH if you are configuring for a Renesas SystemH
|
||||||
7751R evaluation board.
|
7751R evaluation board.
|
||||||
@ -81,27 +87,13 @@ config SH_STB1_HARP
|
|||||||
config SH_STB1_OVERDRIVE
|
config SH_STB1_OVERDRIVE
|
||||||
bool "STB1_Overdrive"
|
bool "STB1_Overdrive"
|
||||||
|
|
||||||
config SH_HP620
|
config SH_HP6XX
|
||||||
bool "HP620"
|
bool "HP6XX"
|
||||||
help
|
help
|
||||||
Select HP620 if configuring for a HP jornada HP620.
|
Select HP6XX if configuring for a HP jornada HP6xx.
|
||||||
More information (hardware only) at
|
More information (hardware only) at
|
||||||
<http://www.hp.com/jornada/>.
|
<http://www.hp.com/jornada/>.
|
||||||
|
|
||||||
config SH_HP680
|
|
||||||
bool "HP680"
|
|
||||||
help
|
|
||||||
Select HP680 if configuring for a HP Jornada HP680.
|
|
||||||
More information (hardware only) at
|
|
||||||
<http://www.hp.com/jornada/products/680/>.
|
|
||||||
|
|
||||||
config SH_HP690
|
|
||||||
bool "HP690"
|
|
||||||
help
|
|
||||||
Select HP690 if configuring for a HP Jornada HP690.
|
|
||||||
More information (hardware only)
|
|
||||||
at <http://www.hp.com/jornada/products/680/>.
|
|
||||||
|
|
||||||
config SH_CQREEK
|
config SH_CQREEK
|
||||||
bool "CqREEK"
|
bool "CqREEK"
|
||||||
help
|
help
|
||||||
@ -123,11 +115,13 @@ config SH_EC3104
|
|||||||
|
|
||||||
config SH_SATURN
|
config SH_SATURN
|
||||||
bool "Saturn"
|
bool "Saturn"
|
||||||
|
select CPU_SUBTYPE_SH7604
|
||||||
help
|
help
|
||||||
Select Saturn if configuring for a SEGA Saturn.
|
Select Saturn if configuring for a SEGA Saturn.
|
||||||
|
|
||||||
config SH_DREAMCAST
|
config SH_DREAMCAST
|
||||||
bool "Dreamcast"
|
bool "Dreamcast"
|
||||||
|
select CPU_SUBTYPE_SH7091
|
||||||
help
|
help
|
||||||
Select Dreamcast if configuring for a SEGA Dreamcast.
|
Select Dreamcast if configuring for a SEGA Dreamcast.
|
||||||
More information at
|
More information at
|
||||||
@ -142,6 +136,7 @@ config SH_BIGSUR
|
|||||||
|
|
||||||
config SH_SH2000
|
config SH_SH2000
|
||||||
bool "SH2000"
|
bool "SH2000"
|
||||||
|
select CPU_SUBTYPE_SH7709
|
||||||
help
|
help
|
||||||
SH-2000 is a single-board computer based around SH7709A chip
|
SH-2000 is a single-board computer based around SH7709A chip
|
||||||
intended for embedded applications.
|
intended for embedded applications.
|
||||||
@ -153,20 +148,22 @@ config SH_ADX
|
|||||||
bool "ADX"
|
bool "ADX"
|
||||||
|
|
||||||
config SH_MPC1211
|
config SH_MPC1211
|
||||||
bool "MPC1211"
|
bool "Interface MPC1211"
|
||||||
|
help
|
||||||
|
CTP/PCI-SH02 is a CPU module computer that is produced
|
||||||
|
by Interface Corporation.
|
||||||
|
More information at <http://www.interface.co.jp>
|
||||||
|
|
||||||
config SH_SH03
|
config SH_SH03
|
||||||
bool "SH03"
|
bool "Interface CTP/PCI-SH03"
|
||||||
help
|
help
|
||||||
CTP/PCI-SH03 is a CPU module computer that produced
|
CTP/PCI-SH03 is a CPU module computer that is produced
|
||||||
by Interface Corporation.
|
by Interface Corporation.
|
||||||
It is compact and excellent in durability.
|
|
||||||
It will play an active part in your factory or laboratory
|
|
||||||
as a FA computer.
|
|
||||||
More information at <http://www.interface.co.jp>
|
More information at <http://www.interface.co.jp>
|
||||||
|
|
||||||
config SH_SECUREEDGE5410
|
config SH_SECUREEDGE5410
|
||||||
bool "SecureEdge5410"
|
bool "SecureEdge5410"
|
||||||
|
select CPU_SUBTYPE_SH7751R
|
||||||
help
|
help
|
||||||
Select SecureEdge5410 if configuring for a SnapGear SH board.
|
Select SecureEdge5410 if configuring for a SnapGear SH board.
|
||||||
This includes both the OEM SecureEdge products as well as the
|
This includes both the OEM SecureEdge products as well as the
|
||||||
@ -174,25 +171,49 @@ config SH_SECUREEDGE5410
|
|||||||
|
|
||||||
config SH_HS7751RVOIP
|
config SH_HS7751RVOIP
|
||||||
bool "HS7751RVOIP"
|
bool "HS7751RVOIP"
|
||||||
|
select CPU_SUBTYPE_SH7751R
|
||||||
help
|
help
|
||||||
Select HS7751RVOIP if configuring for a Renesas Technology
|
Select HS7751RVOIP if configuring for a Renesas Technology
|
||||||
Sales VoIP board.
|
Sales VoIP board.
|
||||||
|
|
||||||
config SH_RTS7751R2D
|
config SH_RTS7751R2D
|
||||||
bool "RTS7751R2D"
|
bool "RTS7751R2D"
|
||||||
|
select CPU_SUBTYPE_SH7751R
|
||||||
help
|
help
|
||||||
Select RTS7751R2D if configuring for a Renesas Technology
|
Select RTS7751R2D if configuring for a Renesas Technology
|
||||||
Sales SH-Graphics board.
|
Sales SH-Graphics board.
|
||||||
|
|
||||||
|
config SH_R7780RP
|
||||||
|
bool "R7780RP-1"
|
||||||
|
select CPU_SUBTYPE_SH7780
|
||||||
|
help
|
||||||
|
Select R7780RP-1 if configuring for a Renesas Solutions
|
||||||
|
HIGHLANDER board.
|
||||||
|
|
||||||
config SH_EDOSK7705
|
config SH_EDOSK7705
|
||||||
bool "EDOSK7705"
|
bool "EDOSK7705"
|
||||||
|
select CPU_SUBTYPE_SH7705
|
||||||
|
|
||||||
config SH_SH4202_MICRODEV
|
config SH_SH4202_MICRODEV
|
||||||
bool "SH4-202 MicroDev"
|
bool "SH4-202 MicroDev"
|
||||||
|
select CPU_SUBTYPE_SH4_202
|
||||||
help
|
help
|
||||||
Select SH4-202 MicroDev if configuring for a SuperH MicroDev board
|
Select SH4-202 MicroDev if configuring for a SuperH MicroDev board
|
||||||
with an SH4-202 CPU.
|
with an SH4-202 CPU.
|
||||||
|
|
||||||
|
config SH_LANDISK
|
||||||
|
bool "LANDISK"
|
||||||
|
select CPU_SUBTYPE_SH7751R
|
||||||
|
help
|
||||||
|
I-O DATA DEVICE, INC. "LANDISK Series" support.
|
||||||
|
|
||||||
|
config SH_TITAN
|
||||||
|
bool "TITAN"
|
||||||
|
select CPU_SUBTYPE_SH7751R
|
||||||
|
help
|
||||||
|
Select Titan if you are configuring for a Nimble Microsystems
|
||||||
|
NetEngine NP51R.
|
||||||
|
|
||||||
config SH_UNKNOWN
|
config SH_UNKNOWN
|
||||||
bool "BareCPU"
|
bool "BareCPU"
|
||||||
help
|
help
|
||||||
@ -207,168 +228,27 @@ config SH_UNKNOWN
|
|||||||
|
|
||||||
endchoice
|
endchoice
|
||||||
|
|
||||||
choice
|
source "arch/sh/mm/Kconfig"
|
||||||
prompt "Processor family"
|
|
||||||
default CPU_SH4
|
|
||||||
help
|
|
||||||
This option determines the CPU family to compile for. Supported
|
|
||||||
targets are SH-2, SH-3, and SH-4. These options are independent of
|
|
||||||
CPU functionality. As such, SH-DSP users will still want to select
|
|
||||||
their respective processor family in addition to the DSP support
|
|
||||||
option.
|
|
||||||
|
|
||||||
config CPU_SH2
|
|
||||||
bool "SH-2"
|
|
||||||
select SH_WRITETHROUGH
|
|
||||||
|
|
||||||
config CPU_SH3
|
|
||||||
bool "SH-3"
|
|
||||||
|
|
||||||
config CPU_SH4
|
|
||||||
bool "SH-4"
|
|
||||||
|
|
||||||
endchoice
|
|
||||||
|
|
||||||
choice
|
|
||||||
prompt "Processor subtype"
|
|
||||||
|
|
||||||
config CPU_SUBTYPE_SH7604
|
|
||||||
bool "SH7604"
|
|
||||||
depends on CPU_SH2
|
|
||||||
help
|
|
||||||
Select SH7604 if you have SH7604
|
|
||||||
|
|
||||||
config CPU_SUBTYPE_SH7300
|
|
||||||
bool "SH7300"
|
|
||||||
depends on CPU_SH3
|
|
||||||
|
|
||||||
config CPU_SUBTYPE_SH7705
|
|
||||||
bool "SH7705"
|
|
||||||
depends on CPU_SH3
|
|
||||||
|
|
||||||
config CPU_SUBTYPE_SH7707
|
|
||||||
bool "SH7707"
|
|
||||||
depends on CPU_SH3
|
|
||||||
help
|
|
||||||
Select SH7707 if you have a 60 Mhz SH-3 HD6417707 CPU.
|
|
||||||
|
|
||||||
config CPU_SUBTYPE_SH7708
|
|
||||||
bool "SH7708"
|
|
||||||
depends on CPU_SH3
|
|
||||||
help
|
|
||||||
Select SH7708 if you have a 60 Mhz SH-3 HD6417708S or
|
|
||||||
if you have a 100 Mhz SH-3 HD6417708R CPU.
|
|
||||||
|
|
||||||
config CPU_SUBTYPE_SH7709
|
|
||||||
bool "SH7709"
|
|
||||||
depends on CPU_SH3
|
|
||||||
help
|
|
||||||
Select SH7709 if you have a 80 Mhz SH-3 HD6417709 CPU.
|
|
||||||
|
|
||||||
config CPU_SUBTYPE_SH7750
|
|
||||||
bool "SH7750"
|
|
||||||
depends on CPU_SH4
|
|
||||||
help
|
|
||||||
Select SH7750 if you have a 200 Mhz SH-4 HD6417750 CPU.
|
|
||||||
|
|
||||||
config CPU_SUBTYPE_SH7751
|
|
||||||
bool "SH7751/SH7751R"
|
|
||||||
depends on CPU_SH4
|
|
||||||
help
|
|
||||||
Select SH7751 if you have a 166 Mhz SH-4 HD6417751 CPU,
|
|
||||||
or if you have a HD6417751R CPU.
|
|
||||||
|
|
||||||
config CPU_SUBTYPE_SH7760
|
|
||||||
bool "SH7760"
|
|
||||||
depends on CPU_SH4
|
|
||||||
|
|
||||||
config CPU_SUBTYPE_SH73180
|
|
||||||
bool "SH73180"
|
|
||||||
depends on CPU_SH4
|
|
||||||
|
|
||||||
config CPU_SUBTYPE_ST40STB1
|
|
||||||
bool "ST40STB1 / ST40RA"
|
|
||||||
depends on CPU_SH4
|
|
||||||
help
|
|
||||||
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.
|
|
||||||
|
|
||||||
config CPU_SUBTYPE_SH4_202
|
|
||||||
bool "SH4-202"
|
|
||||||
depends on CPU_SH4
|
|
||||||
|
|
||||||
endchoice
|
|
||||||
|
|
||||||
config SH7705_CACHE_32KB
|
|
||||||
bool "Enable 32KB cache size for SH7705"
|
|
||||||
depends on CPU_SUBTYPE_SH7705
|
|
||||||
default y
|
|
||||||
|
|
||||||
config MMU
|
|
||||||
bool "Support for memory management hardware"
|
|
||||||
depends on !CPU_SH2
|
|
||||||
default y
|
|
||||||
help
|
|
||||||
Early SH processors (such as the SH7604) lack an MMU. In order to
|
|
||||||
boot on these systems, this option must not be set.
|
|
||||||
|
|
||||||
On other systems (such as the SH-3 and 4) where an MMU exists,
|
|
||||||
turning this off will boot the kernel on these machines with the
|
|
||||||
MMU implicitly switched off.
|
|
||||||
|
|
||||||
choice
|
|
||||||
prompt "HugeTLB page size"
|
|
||||||
depends on HUGETLB_PAGE && CPU_SH4 && MMU
|
|
||||||
default HUGETLB_PAGE_SIZE_64K
|
|
||||||
|
|
||||||
config HUGETLB_PAGE_SIZE_64K
|
|
||||||
bool "64K"
|
|
||||||
|
|
||||||
config HUGETLB_PAGE_SIZE_1MB
|
|
||||||
bool "1MB"
|
|
||||||
|
|
||||||
endchoice
|
|
||||||
|
|
||||||
config CMDLINE_BOOL
|
|
||||||
bool "Default bootloader kernel arguments"
|
|
||||||
|
|
||||||
config CMDLINE
|
|
||||||
string "Initial kernel command string"
|
|
||||||
depends on CMDLINE_BOOL
|
|
||||||
default "console=ttySC1,115200"
|
|
||||||
|
|
||||||
# Platform-specific memory start and size definitions
|
|
||||||
config MEMORY_START
|
config MEMORY_START
|
||||||
hex "Physical memory start address" if !MEMORY_SET || MEMORY_OVERRIDE
|
hex "Physical memory start address"
|
||||||
default "0x08000000" if !MEMORY_SET || MEMORY_OVERRIDE || !MEMORY_OVERRIDE && SH_ADX || SH_MPC1211 || SH_SH03 || SH_SECUREEDGE5410 || SH_SH4202_MICRODEV
|
default "0x08000000"
|
||||||
default "0x0c000000" if !MEMORY_OVERRIDE && (SH_DREAMCAST || SH_HP600 || SH_BIGSUR || SH_SH2000 || SH_73180_SOLUTION_ENGINE || SH_7300_SOLUTION_ENGINE || SH_7751_SOLUTION_ENGINE || SH_SOLUTION_ENGINE || SH_HS7751RVOIP || SH_RTS7751R2D || SH_EDOSK7705)
|
|
||||||
---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
|
||||||
does not specify the range that RAM takes.
|
does not specify the range that RAM takes.
|
||||||
|
|
||||||
The physical memory (RAM) start address will be automatically
|
The physical memory (RAM) start address will be automatically
|
||||||
set to 08000000, unless you selected one of the following
|
set to 08000000. Other platforms, such as the Solution Engine
|
||||||
processor types: SolutionEngine, Overdrive, HP620, HP680, HP690,
|
boards typically map RAM at 0C000000.
|
||||||
in which case the start address will be set to 0c000000.
|
|
||||||
|
|
||||||
Tweak this only when porting to a new machine which is not already
|
Tweak this only when porting to a new machine which does not
|
||||||
known by the config system. Changing it from the known correct
|
already have a defconfig. Changing it from the known correct
|
||||||
value on any of the known systems will only lead to disaster.
|
value on any of the known systems will only lead to disaster.
|
||||||
|
|
||||||
config MEMORY_SIZE
|
config MEMORY_SIZE
|
||||||
hex "Physical memory size" if !MEMORY_SET || MEMORY_OVERRIDE
|
hex "Physical memory size"
|
||||||
default "0x00400000" if !MEMORY_SET || MEMORY_OVERRIDE || !MEMORY_OVERRIDE && SH_ADX || !MEMORY_OVERRIDE && (SH_HP600 || SH_BIGSUR || SH_SH2000)
|
default "0x00400000"
|
||||||
default "0x01000000" if !MEMORY_OVERRIDE && SH_DREAMCAST || SH_SECUREEDGE5410 || SH_EDOSK7705
|
|
||||||
default "0x02000000" if !MEMORY_OVERRIDE && (SH_73180_SOLUTION_ENGINE || SH_SOLUTION_ENGINE)
|
|
||||||
default "0x04000000" if !MEMORY_OVERRIDE && (SH_7300_SOLUTION_ENGINE || SH_7751_SOLUTION_ENGINE || SH_HS7751RVOIP || SH_RTS7751R2D || SH_SH4202_MICRODEV)
|
|
||||||
default "0x08000000" if SH_MPC1211 || SH_SH03
|
|
||||||
help
|
help
|
||||||
This sets the default memory size assumed by your SH kernel. It can
|
This sets the default memory size assumed by your SH kernel. It can
|
||||||
be overridden as normal by the 'mem=' argument on the kernel command
|
be overridden as normal by the 'mem=' argument on the kernel command
|
||||||
@ -376,21 +256,6 @@ config MEMORY_SIZE
|
|||||||
as 0x00400000 which was the default value before this became
|
as 0x00400000 which was the default value before this became
|
||||||
configurable.
|
configurable.
|
||||||
|
|
||||||
config MEMORY_SET
|
|
||||||
bool
|
|
||||||
depends on !MEMORY_OVERRIDE && (SH_MPC1211 || SH_SH03 || SH_ADX || SH_DREAMCAST || SH_HP600 || SH_BIGSUR || SH_SH2000 || SH_7751_SOLUTION_ENGINE || SH_SOLUTION_ENGINE || SH_SECUREEDGE5410 || SH_HS7751RVOIP || SH_RTS7751R2D || SH_SH4202_MICRODEV || SH_EDOSK7705)
|
|
||||||
default y
|
|
||||||
help
|
|
||||||
This is an option about which you will never be asked a question.
|
|
||||||
Therefore, I conclude that you do not exist - go away.
|
|
||||||
|
|
||||||
There is a grue here.
|
|
||||||
|
|
||||||
# If none of the above have set memory start/size, ask the user.
|
|
||||||
config MEMORY_OVERRIDE
|
|
||||||
bool "Override default load address and memory size"
|
|
||||||
|
|
||||||
# XXX: break these out into the board-specific configs below
|
|
||||||
config CF_ENABLER
|
config CF_ENABLER
|
||||||
bool "Compact Flash Enabler support"
|
bool "Compact Flash Enabler support"
|
||||||
depends on SH_ADX || SH_SOLUTION_ENGINE || SH_UNKNOWN || SH_CAT68701 || SH_SH03
|
depends on SH_ADX || SH_SOLUTION_ENGINE || SH_UNKNOWN || SH_CAT68701 || SH_SH03
|
||||||
@ -434,10 +299,21 @@ config CF_BASE_ADDR
|
|||||||
default "0xb8000000" if CF_AREA6
|
default "0xb8000000" if CF_AREA6
|
||||||
default "0xb4000000" if CF_AREA5
|
default "0xb4000000" if CF_AREA5
|
||||||
|
|
||||||
|
menu "Processor features"
|
||||||
|
|
||||||
|
config CPU_LITTLE_ENDIAN
|
||||||
|
bool "Little Endian"
|
||||||
|
help
|
||||||
|
Some SuperH machines can be configured for either little or big
|
||||||
|
endian byte order. These modes require different kernels. Say Y if
|
||||||
|
your machine is little endian, N if it's a big endian machine.
|
||||||
|
|
||||||
# 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 && !SH_7300_SOLUTION_ENGINE && !SH_73180_SOLUTION_ENGINE
|
depends on !SH_DREAMCAST && !SH_SATURN && !SH_7300_SOLUTION_ENGINE && \
|
||||||
|
!SH_73180_SOLUTION_ENGINE && !SH_LANDISK && \
|
||||||
|
!SH_R7780RP
|
||||||
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
|
||||||
@ -476,98 +352,6 @@ config SH_ADC
|
|||||||
|
|
||||||
If unsure, say N.
|
If unsure, say N.
|
||||||
|
|
||||||
config SH_HP600
|
|
||||||
bool
|
|
||||||
depends on SH_HP620 || SH_HP680 || SH_HP690
|
|
||||||
default y
|
|
||||||
|
|
||||||
config CPU_SUBTYPE_ST40
|
|
||||||
bool
|
|
||||||
depends on CPU_SUBTYPE_ST40STB1 || CPU_SUBTYPE_ST40GX1
|
|
||||||
default y
|
|
||||||
|
|
||||||
source "mm/Kconfig"
|
|
||||||
|
|
||||||
config ZERO_PAGE_OFFSET
|
|
||||||
hex "Zero page offset"
|
|
||||||
default "0x00001000" if !(SH_MPC1211 || SH_SH03)
|
|
||||||
default "0x00004000" if SH_MPC1211 || SH_SH03
|
|
||||||
help
|
|
||||||
This sets the default offset of zero page.
|
|
||||||
|
|
||||||
# XXX: needs to lose subtype for system type
|
|
||||||
config ST40_LMI_MEMORY
|
|
||||||
bool "Memory on LMI"
|
|
||||||
depends on CPU_SUBTYPE_ST40STB1
|
|
||||||
|
|
||||||
config MEMORY_START
|
|
||||||
hex
|
|
||||||
depends on CPU_SUBTYPE_ST40STB1 && ST40_LMI_MEMORY
|
|
||||||
default "0x08000000"
|
|
||||||
|
|
||||||
config MEMORY_SIZE
|
|
||||||
hex
|
|
||||||
depends on CPU_SUBTYPE_ST40STB1 && ST40_LMI_MEMORY
|
|
||||||
default "0x00400000"
|
|
||||||
|
|
||||||
config MEMORY_SET
|
|
||||||
bool
|
|
||||||
depends on CPU_SUBTYPE_ST40STB1 && ST40_LMI_MEMORY
|
|
||||||
default y
|
|
||||||
|
|
||||||
config BOOT_LINK_OFFSET
|
|
||||||
hex "Link address offset for booting"
|
|
||||||
default "0x00800000"
|
|
||||||
help
|
|
||||||
This option allows you to set the link address offset of the zImage.
|
|
||||||
This can be useful if you are on a board which has a small amount of
|
|
||||||
memory.
|
|
||||||
|
|
||||||
config CPU_LITTLE_ENDIAN
|
|
||||||
bool "Little Endian"
|
|
||||||
help
|
|
||||||
Some SuperH machines can be configured for either little or big
|
|
||||||
endian byte order. These modes require different kernels. Say Y if
|
|
||||||
your machine is little endian, N if it's a big endian machine.
|
|
||||||
|
|
||||||
config PREEMPT
|
|
||||||
bool "Preemptible Kernel (EXPERIMENTAL)"
|
|
||||||
depends on EXPERIMENTAL
|
|
||||||
|
|
||||||
config UBC_WAKEUP
|
|
||||||
bool "Wakeup UBC on startup"
|
|
||||||
help
|
|
||||||
Selecting this option will wakeup the User Break Controller (UBC) on
|
|
||||||
startup. Although the UBC is left in an awake state when the processor
|
|
||||||
comes up, some boot loaders misbehave by putting the UBC to sleep in a
|
|
||||||
power saving state, which causes issues with things like ptrace().
|
|
||||||
|
|
||||||
If unsure, say N.
|
|
||||||
|
|
||||||
config SH_WRITETHROUGH
|
|
||||||
bool "Use write-through caching"
|
|
||||||
default y if CPU_SH2
|
|
||||||
help
|
|
||||||
Selecting this option will configure the caches in write-through
|
|
||||||
mode, as opposed to the default write-back configuration.
|
|
||||||
|
|
||||||
Since there's sill some aliasing issues on SH-4, this option will
|
|
||||||
unfortunately still require the majority of flushing functions to
|
|
||||||
be implemented to deal with aliasing.
|
|
||||||
|
|
||||||
If unsure, say N.
|
|
||||||
|
|
||||||
config SH_OCRAM
|
|
||||||
bool "Operand Cache RAM (OCRAM) support"
|
|
||||||
help
|
|
||||||
Selecting this option will automatically tear down the number of
|
|
||||||
sets in the dcache by half, which in turn exposes a memory range.
|
|
||||||
|
|
||||||
The addresses for the OC RAM base will vary according to the
|
|
||||||
processor version. Consult vendor documentation for specifics.
|
|
||||||
|
|
||||||
If unsure, say N.
|
|
||||||
|
|
||||||
config SH_STORE_QUEUES
|
config SH_STORE_QUEUES
|
||||||
bool "Support for Store Queues"
|
bool "Support for Store Queues"
|
||||||
depends on CPU_SH4
|
depends on CPU_SH4
|
||||||
@ -575,6 +359,125 @@ config SH_STORE_QUEUES
|
|||||||
Selecting this option will enable an in-kernel API for manipulating
|
Selecting this option will enable an in-kernel API for manipulating
|
||||||
the store queues integrated in the SH-4 processors.
|
the store queues integrated in the SH-4 processors.
|
||||||
|
|
||||||
|
config CPU_HAS_INTEVT
|
||||||
|
bool
|
||||||
|
|
||||||
|
config CPU_HAS_PINT_IRQ
|
||||||
|
bool
|
||||||
|
|
||||||
|
config CPU_HAS_INTC2_IRQ
|
||||||
|
bool
|
||||||
|
|
||||||
|
config CPU_HAS_SR_RB
|
||||||
|
bool "CPU has SR.RB"
|
||||||
|
depends on CPU_SH3 || CPU_SH4
|
||||||
|
default y
|
||||||
|
help
|
||||||
|
This will enable the use of SR.RB register bank usage. Processors
|
||||||
|
that are lacking this bit must have another method in place for
|
||||||
|
accomplishing what is taken care of by the banked registers.
|
||||||
|
|
||||||
|
See <file:Documentation/sh/register-banks.txt> for further
|
||||||
|
information on SR.RB and register banking in the kernel in general.
|
||||||
|
|
||||||
|
endmenu
|
||||||
|
|
||||||
|
menu "Timer support"
|
||||||
|
|
||||||
|
config SH_TMU
|
||||||
|
bool "TMU timer support"
|
||||||
|
default y
|
||||||
|
help
|
||||||
|
This enables the use of the TMU as the system timer.
|
||||||
|
|
||||||
|
endmenu
|
||||||
|
|
||||||
|
source "arch/sh/boards/renesas/hs7751rvoip/Kconfig"
|
||||||
|
|
||||||
|
source "arch/sh/boards/renesas/rts7751r2d/Kconfig"
|
||||||
|
|
||||||
|
config SH_PCLK_FREQ_BOOL
|
||||||
|
bool "Set default pclk frequency"
|
||||||
|
default y if !SH_RTC
|
||||||
|
default n
|
||||||
|
|
||||||
|
config SH_PCLK_FREQ
|
||||||
|
int "Peripheral clock frequency (in Hz)"
|
||||||
|
depends on SH_PCLK_FREQ_BOOL
|
||||||
|
default "50000000" if CPU_SUBTYPE_SH7750 || CPU_SUBTYPE_SH7780
|
||||||
|
default "60000000" if CPU_SUBTYPE_SH7751
|
||||||
|
default "33333333" if CPU_SUBTYPE_SH7300 || CPU_SUBTYPE_SH7770 || CPU_SUBTYPE_SH7760
|
||||||
|
default "27000000" if CPU_SUBTYPE_SH73180
|
||||||
|
default "66000000" if CPU_SUBTYPE_SH4_202
|
||||||
|
help
|
||||||
|
This option is used to specify the peripheral clock frequency.
|
||||||
|
This is necessary for determining the reference clock value on
|
||||||
|
platforms lacking an RTC.
|
||||||
|
|
||||||
|
menu "CPU Frequency scaling"
|
||||||
|
|
||||||
|
source "drivers/cpufreq/Kconfig"
|
||||||
|
|
||||||
|
config SH_CPU_FREQ
|
||||||
|
tristate "SuperH CPU Frequency driver"
|
||||||
|
depends on CPU_FREQ
|
||||||
|
select CPU_FREQ_TABLE
|
||||||
|
help
|
||||||
|
This adds the cpufreq driver for SuperH. At present, only
|
||||||
|
the SH-4 is supported.
|
||||||
|
|
||||||
|
For details, take a look at <file:Documentation/cpu-freq>.
|
||||||
|
|
||||||
|
If unsure, say N.
|
||||||
|
|
||||||
|
endmenu
|
||||||
|
|
||||||
|
source "arch/sh/drivers/dma/Kconfig"
|
||||||
|
|
||||||
|
source "arch/sh/cchips/Kconfig"
|
||||||
|
|
||||||
|
config HEARTBEAT
|
||||||
|
bool "Heartbeat LED"
|
||||||
|
depends on SH_MPC1211 || SH_SH03 || SH_CAT68701 || \
|
||||||
|
SH_STB1_HARP || SH_STB1_OVERDRIVE || SH_BIGSUR || \
|
||||||
|
SH_7751_SOLUTION_ENGINE || SH_7300_SOLUTION_ENGINE || \
|
||||||
|
SH_73180_SOLUTION_ENGINE || SH_SOLUTION_ENGINE || \
|
||||||
|
SH_RTS7751R2D || SH_SH4202_MICRODEV || SH_LANDISK
|
||||||
|
help
|
||||||
|
Use the power-on LED on your machine as a load meter. The exact
|
||||||
|
behavior is platform-dependent, but normally the flash frequency is
|
||||||
|
a hyperbolic function of the 5-minute load average.
|
||||||
|
|
||||||
|
endmenu
|
||||||
|
|
||||||
|
config ISA_DMA_API
|
||||||
|
bool
|
||||||
|
depends on MPC1211
|
||||||
|
default y
|
||||||
|
|
||||||
|
menu "Kernel features"
|
||||||
|
|
||||||
|
config KEXEC
|
||||||
|
bool "kexec system call (EXPERIMENTAL)"
|
||||||
|
depends on EXPERIMENTAL
|
||||||
|
help
|
||||||
|
kexec is a system call that implements the ability to shutdown your
|
||||||
|
current kernel, and to start another kernel. It is like a reboot
|
||||||
|
but it is indepedent of the system firmware. And like a reboot
|
||||||
|
you can start any kernel with it, not just Linux.
|
||||||
|
|
||||||
|
The name comes from the similiarity to the exec system call.
|
||||||
|
|
||||||
|
It is an ongoing process to be certain the hardware in a machine
|
||||||
|
is properly shutdown, so do not be surprised if this code does not
|
||||||
|
initially work for you. It may help to enable device hotplugging
|
||||||
|
support. As of this writing the exact hardware interface is
|
||||||
|
strongly in flux, so no good recommendation can be made.
|
||||||
|
|
||||||
|
config PREEMPT
|
||||||
|
bool "Preemptible Kernel (EXPERIMENTAL)"
|
||||||
|
depends on EXPERIMENTAL
|
||||||
|
|
||||||
config SMP
|
config SMP
|
||||||
bool "Symmetric multi-processing support"
|
bool "Symmetric multi-processing support"
|
||||||
---help---
|
---help---
|
||||||
@ -610,87 +513,58 @@ 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
|
config CPU_HAS_SR_RB
|
||||||
bool "Support VoIP Codec section"
|
bool "CPU has SR.RB"
|
||||||
depends on SH_HS7751RVOIP
|
depends on CPU_SH3 || CPU_SH4
|
||||||
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 || CPU_SUBTYPE_SH73180
|
|
||||||
default y
|
default y
|
||||||
help
|
help
|
||||||
This option will cause the PCLK value to be probed at run-time. It
|
This will enable the use of SR.RB register bank usage. Processors
|
||||||
will display a notification if the probed value has greater than a
|
that are lacking this bit must have another method in place for
|
||||||
1% variance of the hardcoded CONFIG_SH_PCLK_FREQ.
|
accomplishing what is taken care of by the banked registers.
|
||||||
|
|
||||||
config SH_PCLK_FREQ
|
See <file:Documentation/sh/register-banks.txt> for further
|
||||||
int "Peripheral clock frequency (in Hz)"
|
information on SR.RB and register banking in the kernel in general.
|
||||||
default "50000000" if CPU_SUBTYPE_SH7750
|
|
||||||
default "60000000" if CPU_SUBTYPE_SH7751
|
endmenu
|
||||||
default "33333333" if CPU_SUBTYPE_SH7300
|
|
||||||
default "27000000" if CPU_SUBTYPE_SH73180
|
menu "Boot options"
|
||||||
default "66000000" if CPU_SUBTYPE_SH4_202
|
|
||||||
default "1193182"
|
config ZERO_PAGE_OFFSET
|
||||||
|
hex "Zero page offset"
|
||||||
|
default "0x00004000" if SH_MPC1211 || SH_SH03
|
||||||
|
default "0x00001000"
|
||||||
help
|
help
|
||||||
This option is used to specify the peripheral clock frequency. This
|
This sets the default offset of zero page.
|
||||||
option must be set for each processor in order for the kernel to
|
|
||||||
function reliably. If no sane default exists, we use a default from
|
|
||||||
the legacy i8254. Any discrepancies will be reported on boot time
|
|
||||||
with an auto-probed frequency which should be considered the proper
|
|
||||||
value for your hardware.
|
|
||||||
|
|
||||||
menu "CPU Frequency scaling"
|
config BOOT_LINK_OFFSET
|
||||||
|
hex "Link address offset for booting"
|
||||||
source "drivers/cpufreq/Kconfig"
|
default "0x00800000"
|
||||||
|
|
||||||
config SH_CPU_FREQ
|
|
||||||
tristate "SuperH CPU Frequency driver"
|
|
||||||
depends on CPU_FREQ
|
|
||||||
select CPU_FREQ_TABLE
|
|
||||||
help
|
help
|
||||||
This adds the cpufreq driver for SuperH. At present, only
|
This option allows you to set the link address offset of the zImage.
|
||||||
the SH-4 is supported.
|
This can be useful if you are on a board which has a small amount of
|
||||||
|
memory.
|
||||||
|
|
||||||
For details, take a look at <file:Documentation/cpu-freq>.
|
config UBC_WAKEUP
|
||||||
|
bool "Wakeup UBC on startup"
|
||||||
|
help
|
||||||
|
Selecting this option will wakeup the User Break Controller (UBC) on
|
||||||
|
startup. Although the UBC is left in an awake state when the processor
|
||||||
|
comes up, some boot loaders misbehave by putting the UBC to sleep in a
|
||||||
|
power saving state, which causes issues with things like ptrace().
|
||||||
|
|
||||||
If unsure, say N.
|
If unsure, say N.
|
||||||
|
|
||||||
endmenu
|
config CMDLINE_BOOL
|
||||||
|
bool "Default bootloader kernel arguments"
|
||||||
|
|
||||||
source "arch/sh/drivers/dma/Kconfig"
|
config CMDLINE
|
||||||
|
string "Initial kernel command string"
|
||||||
source "arch/sh/cchips/Kconfig"
|
depends on CMDLINE_BOOL
|
||||||
|
default "console=ttySC1,115200"
|
||||||
config HEARTBEAT
|
|
||||||
bool "Heartbeat LED"
|
|
||||||
depends on SH_MPC1211 || SH_SH03 || SH_CAT68701 || SH_STB1_HARP || SH_STB1_OVERDRIVE || SH_BIGSUR || SH_7751_SOLUTION_ENGINE || SH_7300_SOLUTION_ENGINE || SH_73180_SOLUTION_ENGINE || SH_SOLUTION_ENGINE || SH_RTS7751R2D || SH_SH4202_MICRODEV
|
|
||||||
help
|
|
||||||
Use the power-on LED on your machine as a load meter. The exact
|
|
||||||
behavior is platform-dependent, but normally the flash frequency is
|
|
||||||
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
|
||||||
|
|
||||||
config ISA_DMA_API
|
menu "Bus options"
|
||||||
bool
|
|
||||||
depends on MPC1211
|
|
||||||
default y
|
|
||||||
|
|
||||||
menu "Bus options (PCI, PCMCIA, EISA, MCA, ISA)"
|
|
||||||
|
|
||||||
# Even on SuperH devices which don't have an ISA bus,
|
# Even on SuperH devices which don't have an ISA bus,
|
||||||
# this variable helps the PCMCIA modules handle
|
# this variable helps the PCMCIA modules handle
|
||||||
@ -701,7 +575,7 @@ menu "Bus options (PCI, PCMCIA, EISA, MCA, ISA)"
|
|||||||
# PCMCIA outright. -- PFM.
|
# PCMCIA outright. -- PFM.
|
||||||
config ISA
|
config ISA
|
||||||
bool
|
bool
|
||||||
default y if PCMCIA || SMC91X
|
default y if PCMCIA
|
||||||
help
|
help
|
||||||
Find out whether you have ISA slots on your motherboard. ISA is the
|
Find out whether you have ISA slots on your motherboard. ISA is the
|
||||||
name of a bus system, i.e. the way the CPU talks to the other stuff
|
name of a bus system, i.e. the way the CPU talks to the other stuff
|
||||||
@ -735,10 +609,9 @@ config MCA
|
|||||||
config SBUS
|
config SBUS
|
||||||
bool
|
bool
|
||||||
|
|
||||||
config MAPLE
|
config SUPERHYWAY
|
||||||
tristate "Maple Bus support"
|
tristate "SuperHyway Bus support"
|
||||||
depends on SH_DREAMCAST
|
depends on CPU_SUBTYPE_SH4_202
|
||||||
default y
|
|
||||||
|
|
||||||
source "arch/sh/drivers/pci/Kconfig"
|
source "arch/sh/drivers/pci/Kconfig"
|
||||||
|
|
||||||
|
@ -17,7 +17,7 @@ config SH_STANDARD_BIOS
|
|||||||
|
|
||||||
config EARLY_SCIF_CONSOLE
|
config EARLY_SCIF_CONSOLE
|
||||||
bool "Use early SCIF console"
|
bool "Use early SCIF console"
|
||||||
depends on CPU_SH4
|
depends on CPU_SH4 || CPU_SH2A && !SH_STANDARD_BIOS
|
||||||
|
|
||||||
config EARLY_PRINTK
|
config EARLY_PRINTK
|
||||||
bool "Early printk support"
|
bool "Early printk support"
|
||||||
|
@ -17,10 +17,30 @@
|
|||||||
cflags-y := -mb
|
cflags-y := -mb
|
||||||
cflags-$(CONFIG_CPU_LITTLE_ENDIAN) := -ml
|
cflags-$(CONFIG_CPU_LITTLE_ENDIAN) := -ml
|
||||||
|
|
||||||
|
isa-y := any
|
||||||
|
isa-$(CONFIG_CPU_SH2) := sh2
|
||||||
|
isa-$(CONFIG_CPU_SH3) := sh3
|
||||||
|
isa-$(CONFIG_CPU_SH4) := sh4
|
||||||
|
isa-$(CONFIG_CPU_SH4A) := sh4a
|
||||||
|
isa-$(CONFIG_CPU_SH2A) := sh2a
|
||||||
|
|
||||||
|
isa-$(CONFIG_SH_DSP) := $(isa-y)-dsp
|
||||||
|
|
||||||
|
ifndef CONFIG_MMU
|
||||||
|
isa-y := $(isa-y)-nommu
|
||||||
|
endif
|
||||||
|
|
||||||
|
ifndef CONFIG_SH_FPU
|
||||||
|
isa-y := $(isa-y)-nofpu
|
||||||
|
endif
|
||||||
|
|
||||||
|
cflags-y += $(call as-option,-Wa$(comma)-isa=$(isa-y),)
|
||||||
|
|
||||||
cflags-$(CONFIG_CPU_SH2) += -m2
|
cflags-$(CONFIG_CPU_SH2) += -m2
|
||||||
cflags-$(CONFIG_CPU_SH3) += -m3
|
cflags-$(CONFIG_CPU_SH3) += -m3
|
||||||
cflags-$(CONFIG_CPU_SH4) += -m4 \
|
cflags-$(CONFIG_CPU_SH4) += -m4 \
|
||||||
$(call cc-option,-mno-implicit-fp,-m4-nofpu)
|
$(call cc-option,-mno-implicit-fp,-m4-nofpu)
|
||||||
|
cflags-$(CONFIG_CPU_SH4A) += $(call cc-option,-m4a-nofpu,)
|
||||||
|
|
||||||
cflags-$(CONFIG_SH_DSP) += -Wa,-dsp
|
cflags-$(CONFIG_SH_DSP) += -Wa,-dsp
|
||||||
cflags-$(CONFIG_SH_KGDB) += -g
|
cflags-$(CONFIG_SH_KGDB) += -g
|
||||||
@ -67,9 +87,7 @@ machdir-$(CONFIG_SH_7300_SOLUTION_ENGINE) := se/7300
|
|||||||
machdir-$(CONFIG_SH_73180_SOLUTION_ENGINE) := se/73180
|
machdir-$(CONFIG_SH_73180_SOLUTION_ENGINE) := se/73180
|
||||||
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_HP6XX) := hp6xx
|
||||||
machdir-$(CONFIG_SH_HP680) := hp6xx/hp680
|
|
||||||
machdir-$(CONFIG_SH_HP690) := hp6xx/hp690
|
|
||||||
machdir-$(CONFIG_SH_CQREEK) := cqreek
|
machdir-$(CONFIG_SH_CQREEK) := cqreek
|
||||||
machdir-$(CONFIG_SH_DMIDA) := dmida
|
machdir-$(CONFIG_SH_DMIDA) := dmida
|
||||||
machdir-$(CONFIG_SH_EC3104) := ec3104
|
machdir-$(CONFIG_SH_EC3104) := ec3104
|
||||||
@ -119,31 +137,39 @@ boot := arch/sh/boot
|
|||||||
|
|
||||||
CPPFLAGS_vmlinux.lds := -traditional
|
CPPFLAGS_vmlinux.lds := -traditional
|
||||||
|
|
||||||
|
ifneq ($(KBUILD_SRC),)
|
||||||
|
incdir-prefix := $(srctree)/include/asm-sh/
|
||||||
|
else
|
||||||
|
incdir-prefix :=
|
||||||
|
endif
|
||||||
|
|
||||||
# Update machine arch and proc symlinks if something which affects
|
# Update machine arch and proc symlinks if something which affects
|
||||||
# them changed. We use .arch and .mach to indicate when they were
|
# them changed. We use .arch and .mach to indicate when they were
|
||||||
# updated last, otherwise make uses the target directory mtime.
|
# updated last, otherwise make uses the target directory mtime.
|
||||||
|
|
||||||
include/asm-sh/.cpu: $(wildcard include/config/cpu/*.h) include/config/MARKER
|
include/asm-sh/.cpu: $(wildcard include/config/cpu/*.h) include/config/MARKER
|
||||||
@echo ' SYMLINK include/asm-sh/cpu -> include/asm-sh/$(cpuincdir-y)'
|
@echo ' SYMLINK include/asm-sh/cpu -> include/asm-sh/$(cpuincdir-y)'
|
||||||
ifneq ($(KBUILD_SRC),)
|
$(Q)if [ ! -d include/asm-sh ]; then mkdir -p include/asm-sh; fi
|
||||||
$(Q)mkdir -p include/asm-sh
|
$(Q)ln -fsn $(incdir-prefix)$(cpuincdir-y) include/asm-sh/cpu
|
||||||
$(Q)ln -fsn $(srctree)/include/asm-sh/$(cpuincdir-y) include/asm-sh/cpu
|
|
||||||
else
|
|
||||||
$(Q)ln -fsn $(cpuincdir-y) include/asm-sh/cpu
|
|
||||||
endif
|
|
||||||
@touch $@
|
@touch $@
|
||||||
|
|
||||||
|
# Most boards have their own mach directories. For the ones that
|
||||||
|
# don't, just reference the parent directory so the semantics are
|
||||||
|
# kept roughly the same.
|
||||||
|
|
||||||
include/asm-sh/.mach: $(wildcard include/config/sh/*.h) include/config/MARKER
|
include/asm-sh/.mach: $(wildcard include/config/sh/*.h) include/config/MARKER
|
||||||
@echo ' SYMLINK include/asm-sh/mach -> include/asm-sh/$(incdir-y)'
|
@echo -n ' SYMLINK include/asm-sh/mach -> '
|
||||||
ifneq ($(KBUILD_SRC),)
|
$(Q)if [ ! -d include/asm-sh ]; then mkdir -p include/asm-sh; fi
|
||||||
$(Q)mkdir -p include/asm-sh
|
$(Q)if [ -d $(incdir-prefix)$(incdir-y) ]; then \
|
||||||
$(Q)ln -fsn $(srctree)/include/asm-sh/$(incdir-y) include/asm-sh/mach
|
echo -e 'include/asm-sh/$(incdir-y)'; \
|
||||||
else
|
ln -fsn $(incdir-prefix)$(incdir-y) \
|
||||||
$(Q)ln -fsn $(incdir-y) include/asm-sh/mach
|
include/asm-sh/mach; \
|
||||||
endif
|
else \
|
||||||
|
echo -e 'include/asm-sh'; \
|
||||||
|
ln -fsn $(incdir-prefix) include/asm-sh/mach; \
|
||||||
|
fi
|
||||||
@touch $@
|
@touch $@
|
||||||
|
|
||||||
|
|
||||||
archprepare: maketools include/asm-sh/.cpu include/asm-sh/.mach
|
archprepare: maketools include/asm-sh/.cpu include/asm-sh/.mach
|
||||||
|
|
||||||
.PHONY: maketools FORCE
|
.PHONY: maketools FORCE
|
||||||
|
233
arch/sh/mm/Kconfig
Normal file
233
arch/sh/mm/Kconfig
Normal file
@ -0,0 +1,233 @@
|
|||||||
|
menu "Processor selection"
|
||||||
|
|
||||||
|
#
|
||||||
|
# Processor families
|
||||||
|
#
|
||||||
|
config CPU_SH2
|
||||||
|
bool
|
||||||
|
select SH_WRITETHROUGH
|
||||||
|
|
||||||
|
config CPU_SH3
|
||||||
|
bool
|
||||||
|
select CPU_HAS_INTEVT
|
||||||
|
select CPU_HAS_SR_RB
|
||||||
|
|
||||||
|
config CPU_SH4
|
||||||
|
bool
|
||||||
|
select CPU_HAS_INTEVT
|
||||||
|
select CPU_HAS_SR_RB
|
||||||
|
|
||||||
|
config CPU_SH4A
|
||||||
|
bool
|
||||||
|
select CPU_SH4
|
||||||
|
select CPU_HAS_INTC2_IRQ
|
||||||
|
|
||||||
|
config CPU_SUBTYPE_ST40
|
||||||
|
bool
|
||||||
|
select CPU_SH4
|
||||||
|
select CPU_HAS_INTC2_IRQ
|
||||||
|
|
||||||
|
#
|
||||||
|
# Processor subtypes
|
||||||
|
#
|
||||||
|
|
||||||
|
comment "SH-2 Processor Support"
|
||||||
|
|
||||||
|
config CPU_SUBTYPE_SH7604
|
||||||
|
bool "Support SH7604 processor"
|
||||||
|
select CPU_SH2
|
||||||
|
|
||||||
|
comment "SH-3 Processor Support"
|
||||||
|
|
||||||
|
config CPU_SUBTYPE_SH7300
|
||||||
|
bool "Support SH7300 processor"
|
||||||
|
select CPU_SH3
|
||||||
|
|
||||||
|
config CPU_SUBTYPE_SH7705
|
||||||
|
bool "Support SH7705 processor"
|
||||||
|
select CPU_SH3
|
||||||
|
select CPU_HAS_PINT_IRQ
|
||||||
|
|
||||||
|
config CPU_SUBTYPE_SH7707
|
||||||
|
bool "Support SH7707 processor"
|
||||||
|
select CPU_SH3
|
||||||
|
select CPU_HAS_PINT_IRQ
|
||||||
|
help
|
||||||
|
Select SH7707 if you have a 60 Mhz SH-3 HD6417707 CPU.
|
||||||
|
|
||||||
|
config CPU_SUBTYPE_SH7708
|
||||||
|
bool "Support SH7708 processor"
|
||||||
|
select CPU_SH3
|
||||||
|
help
|
||||||
|
Select SH7708 if you have a 60 Mhz SH-3 HD6417708S or
|
||||||
|
if you have a 100 Mhz SH-3 HD6417708R CPU.
|
||||||
|
|
||||||
|
config CPU_SUBTYPE_SH7709
|
||||||
|
bool "Support SH7709 processor"
|
||||||
|
select CPU_SH3
|
||||||
|
select CPU_HAS_PINT_IRQ
|
||||||
|
help
|
||||||
|
Select SH7709 if you have a 80 Mhz SH-3 HD6417709 CPU.
|
||||||
|
|
||||||
|
comment "SH-4 Processor Support"
|
||||||
|
|
||||||
|
config CPU_SUBTYPE_SH7750
|
||||||
|
bool "Support SH7750 processor"
|
||||||
|
select CPU_SH4
|
||||||
|
help
|
||||||
|
Select SH7750 if you have a 200 Mhz SH-4 HD6417750 CPU.
|
||||||
|
|
||||||
|
config CPU_SUBTYPE_SH7091
|
||||||
|
bool "Support SH7091 processor"
|
||||||
|
select CPU_SH4
|
||||||
|
select CPU_SUBTYPE_SH7750
|
||||||
|
help
|
||||||
|
Select SH7091 if you have an SH-4 based Sega device (such as
|
||||||
|
the Dreamcast, Naomi, and Naomi 2).
|
||||||
|
|
||||||
|
config CPU_SUBTYPE_SH7750R
|
||||||
|
bool "Support SH7750R processor"
|
||||||
|
select CPU_SH4
|
||||||
|
select CPU_SUBTYPE_SH7750
|
||||||
|
|
||||||
|
config CPU_SUBTYPE_SH7750S
|
||||||
|
bool "Support SH7750S processor"
|
||||||
|
select CPU_SH4
|
||||||
|
select CPU_SUBTYPE_SH7750
|
||||||
|
|
||||||
|
config CPU_SUBTYPE_SH7751
|
||||||
|
bool "Support SH7751 processor"
|
||||||
|
select CPU_SH4
|
||||||
|
help
|
||||||
|
Select SH7751 if you have a 166 Mhz SH-4 HD6417751 CPU,
|
||||||
|
or if you have a HD6417751R CPU.
|
||||||
|
|
||||||
|
config CPU_SUBTYPE_SH7751R
|
||||||
|
bool "Support SH7751R processor"
|
||||||
|
select CPU_SH4
|
||||||
|
select CPU_SUBTYPE_SH7751
|
||||||
|
|
||||||
|
config CPU_SUBTYPE_SH7760
|
||||||
|
bool "Support SH7760 processor"
|
||||||
|
select CPU_SH4
|
||||||
|
select CPU_HAS_INTC2_IRQ
|
||||||
|
|
||||||
|
config CPU_SUBTYPE_SH4_202
|
||||||
|
bool "Support SH4-202 processor"
|
||||||
|
select CPU_SH4
|
||||||
|
|
||||||
|
comment "ST40 Processor Support"
|
||||||
|
|
||||||
|
config CPU_SUBTYPE_ST40STB1
|
||||||
|
bool "Support ST40STB1/ST40RA processors"
|
||||||
|
select CPU_SUBTYPE_ST40
|
||||||
|
help
|
||||||
|
Select ST40STB1 if you have a ST40RA CPU.
|
||||||
|
This was previously called the ST40STB1, hence the option name.
|
||||||
|
|
||||||
|
config CPU_SUBTYPE_ST40GX1
|
||||||
|
bool "Support ST40GX1 processor"
|
||||||
|
select CPU_SUBTYPE_ST40
|
||||||
|
help
|
||||||
|
Select ST40GX1 if you have a ST40GX1 CPU.
|
||||||
|
|
||||||
|
comment "SH-4A Processor Support"
|
||||||
|
|
||||||
|
config CPU_SUBTYPE_SH73180
|
||||||
|
bool "Support SH73180 processor"
|
||||||
|
select CPU_SH4A
|
||||||
|
|
||||||
|
config CPU_SUBTYPE_SH7770
|
||||||
|
bool "Support SH7770 processor"
|
||||||
|
select CPU_SH4A
|
||||||
|
|
||||||
|
config CPU_SUBTYPE_SH7780
|
||||||
|
bool "Support SH7780 processor"
|
||||||
|
select CPU_SH4A
|
||||||
|
|
||||||
|
endmenu
|
||||||
|
|
||||||
|
menu "Memory management options"
|
||||||
|
|
||||||
|
config MMU
|
||||||
|
bool "Support for memory management hardware"
|
||||||
|
depends on !CPU_SH2
|
||||||
|
default y
|
||||||
|
help
|
||||||
|
Some SH processors (such as SH-2/SH-2A) lack an MMU. In order to
|
||||||
|
boot on these systems, this option must not be set.
|
||||||
|
|
||||||
|
On other systems (such as the SH-3 and 4) where an MMU exists,
|
||||||
|
turning this off will boot the kernel on these machines with the
|
||||||
|
MMU implicitly switched off.
|
||||||
|
|
||||||
|
config 32BIT
|
||||||
|
bool "Support 32-bit physical addressing through PMB"
|
||||||
|
depends on CPU_SH4A
|
||||||
|
default y
|
||||||
|
help
|
||||||
|
If you say Y here, physical addressing will be extended to
|
||||||
|
32-bits through the SH-4A PMB. If this is not set, legacy
|
||||||
|
29-bit physical addressing will be used.
|
||||||
|
|
||||||
|
choice
|
||||||
|
prompt "HugeTLB page size"
|
||||||
|
depends on HUGETLB_PAGE && CPU_SH4 && MMU
|
||||||
|
default HUGETLB_PAGE_SIZE_64K
|
||||||
|
|
||||||
|
config HUGETLB_PAGE_SIZE_64K
|
||||||
|
bool "64K"
|
||||||
|
|
||||||
|
config HUGETLB_PAGE_SIZE_1MB
|
||||||
|
bool "1MB"
|
||||||
|
|
||||||
|
endchoice
|
||||||
|
|
||||||
|
source "mm/Kconfig"
|
||||||
|
|
||||||
|
endmenu
|
||||||
|
|
||||||
|
menu "Cache configuration"
|
||||||
|
|
||||||
|
config SH7705_CACHE_32KB
|
||||||
|
bool "Enable 32KB cache size for SH7705"
|
||||||
|
depends on CPU_SUBTYPE_SH7705
|
||||||
|
default y
|
||||||
|
|
||||||
|
config SH_DIRECT_MAPPED
|
||||||
|
bool "Use direct-mapped caching"
|
||||||
|
default n
|
||||||
|
help
|
||||||
|
Selecting this option will configure the caches to be direct-mapped,
|
||||||
|
even if the cache supports a 2 or 4-way mode. This is useful primarily
|
||||||
|
for debugging on platforms with 2 and 4-way caches (SH7750R/SH7751R,
|
||||||
|
SH4-202, SH4-501, etc.)
|
||||||
|
|
||||||
|
Turn this option off for platforms that do not have a direct-mapped
|
||||||
|
cache, and you have no need to run the caches in such a configuration.
|
||||||
|
|
||||||
|
config SH_WRITETHROUGH
|
||||||
|
bool "Use write-through caching"
|
||||||
|
default y if CPU_SH2
|
||||||
|
help
|
||||||
|
Selecting this option will configure the caches in write-through
|
||||||
|
mode, as opposed to the default write-back configuration.
|
||||||
|
|
||||||
|
Since there's sill some aliasing issues on SH-4, this option will
|
||||||
|
unfortunately still require the majority of flushing functions to
|
||||||
|
be implemented to deal with aliasing.
|
||||||
|
|
||||||
|
If unsure, say N.
|
||||||
|
|
||||||
|
config SH_OCRAM
|
||||||
|
bool "Operand Cache RAM (OCRAM) support"
|
||||||
|
help
|
||||||
|
Selecting this option will automatically tear down the number of
|
||||||
|
sets in the dcache by half, which in turn exposes a memory range.
|
||||||
|
|
||||||
|
The addresses for the OC RAM base will vary according to the
|
||||||
|
processor version. Consult vendor documentation for specifics.
|
||||||
|
|
||||||
|
If unsure, say N.
|
||||||
|
|
||||||
|
endmenu
|
Loading…
Reference in New Issue
Block a user