-
Notifications
You must be signed in to change notification settings - Fork 0
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Add support for Renesas Technology Europe SDK7780 board. Signed-off-by: Nicholas Beck <nbeck@mpc-data.co.uk> Signed-off-by: Paul Mundt <lethal@linux-sh.org>
- Loading branch information
Nicholas Beck
authored and
Paul Mundt
committed
Jan 28, 2008
1 parent
773c7bd
commit 4862ec0
Showing
11 changed files
with
1,801 additions
and
0 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,23 @@ | ||
if SH_SDK7780 | ||
|
||
choice | ||
prompt "SDK7780 options" | ||
default SH_SDK7780_BASE | ||
|
||
config SH_SDK7780_STANDALONE | ||
bool "SDK7780 board support" | ||
depends on CPU_SUBTYPE_SH7780 | ||
help | ||
Selecting this option will enable support for the | ||
standalone version of the SDK7780. If in doubt, say Y. | ||
|
||
config SH_SDK7780_BASE | ||
bool "SDK7780 with base-board support" | ||
depends on CPU_SUBTYPE_SH7780 | ||
help | ||
Selecting this option will enable support for the expansion | ||
baseboard devices. If in doubt, say Y. | ||
|
||
endchoice | ||
|
||
endif |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,5 @@ | ||
# | ||
# Makefile for the SDK7780 specific parts of the kernel | ||
# | ||
obj-y := setup.o irq.o | ||
|
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,46 @@ | ||
/* | ||
* linux/arch/sh/boards/renesas/sdk7780/irq.c | ||
* | ||
* Renesas Technology Europe SDK7780 Support. | ||
* | ||
* Copyright (C) 2008 Nicholas Beck <nbeck@mpc-data.co.uk> | ||
* | ||
* 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. | ||
*/ | ||
#include <linux/init.h> | ||
#include <linux/irq.h> | ||
#include <linux/io.h> | ||
#include <asm/sdk7780.h> | ||
|
||
enum { | ||
UNUSED = 0, | ||
/* board specific interrupt sources */ | ||
SMC91C111, /* Ethernet controller */ | ||
}; | ||
|
||
static struct intc_vect fpga_vectors[] __initdata = { | ||
INTC_IRQ(SMC91C111, IRQ_ETHERNET), | ||
}; | ||
|
||
static struct intc_mask_reg fpga_mask_registers[] __initdata = { | ||
{ 0, FPGA_IRQ0MR, 16, | ||
{ 0, 0, 0, 0, 0, 0, 0, 0, | ||
0, 0, 0, SMC91C111, 0, 0, 0, 0 } }, | ||
}; | ||
|
||
static DECLARE_INTC_DESC(fpga_intc_desc, "sdk7780-irq", fpga_vectors, | ||
NULL, fpga_mask_registers, NULL, NULL); | ||
|
||
void __init init_sdk7780_IRQ(void) | ||
{ | ||
printk(KERN_INFO "Using SDK7780 interrupt controller.\n"); | ||
|
||
ctrl_outw(0xFFFF, FPGA_IRQ0MR); | ||
/* Setup IRL 0-3 */ | ||
ctrl_outw(0x0003, FPGA_IMSR); | ||
plat_irq_setup_pins(IRQ_MODE_IRL3210); | ||
|
||
register_intc_controller(&fpga_intc_desc); | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,109 @@ | ||
/* | ||
* arch/sh/boards/renesas/sdk7780/setup.c | ||
* | ||
* Renesas Solutions SH7780 SDK Support | ||
* Copyright (C) 2008 Nicholas Beck <nbeck@mpc-data.co.uk> | ||
* | ||
* 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. | ||
*/ | ||
#include <linux/init.h> | ||
#include <linux/types.h> | ||
#include <linux/platform_device.h> | ||
#include <linux/pata_platform.h> | ||
#include <asm/machvec.h> | ||
#include <asm/sdk7780.h> | ||
#include <asm/heartbeat.h> | ||
#include <asm/io.h> | ||
#include <asm/addrspace.h> | ||
|
||
#define GPIO_PECR 0xFFEA0008 | ||
|
||
//* Heartbeat */ | ||
static struct heartbeat_data heartbeat_data = { | ||
.regsize = 16, | ||
}; | ||
|
||
static struct resource heartbeat_resources[] = { | ||
[0] = { | ||
.start = PA_LED, | ||
.end = PA_LED, | ||
.flags = IORESOURCE_MEM, | ||
}, | ||
}; | ||
|
||
static struct platform_device heartbeat_device = { | ||
.name = "heartbeat", | ||
.id = -1, | ||
.dev = { | ||
.platform_data = &heartbeat_data, | ||
}, | ||
.num_resources = ARRAY_SIZE(heartbeat_resources), | ||
.resource = heartbeat_resources, | ||
}; | ||
|
||
/* SMC91x */ | ||
static struct resource smc91x_eth_resources[] = { | ||
[0] = { | ||
.name = "smc91x-regs" , | ||
.start = PA_LAN + 0x300, | ||
.end = PA_LAN + 0x300 + 0x10 , | ||
.flags = IORESOURCE_MEM, | ||
}, | ||
[1] = { | ||
.start = IRQ_ETHERNET, | ||
.end = IRQ_ETHERNET, | ||
.flags = IORESOURCE_IRQ, | ||
}, | ||
}; | ||
|
||
static struct platform_device smc91x_eth_device = { | ||
.name = "smc91x", | ||
.id = 0, | ||
.dev = { | ||
.dma_mask = NULL, /* don't use dma */ | ||
.coherent_dma_mask = 0xffffffff, | ||
}, | ||
.num_resources = ARRAY_SIZE(smc91x_eth_resources), | ||
.resource = smc91x_eth_resources, | ||
}; | ||
|
||
static struct platform_device *sdk7780_devices[] __initdata = { | ||
&heartbeat_device, | ||
&smc91x_eth_device, | ||
}; | ||
|
||
static int __init sdk7780_devices_setup(void) | ||
{ | ||
return platform_add_devices(sdk7780_devices, | ||
ARRAY_SIZE(sdk7780_devices)); | ||
} | ||
device_initcall(sdk7780_devices_setup); | ||
|
||
static void __init sdk7780_setup(char **cmdline_p) | ||
{ | ||
u16 ver = ctrl_inw(FPGA_FPVERR); | ||
u16 dateStamp = ctrl_inw(FPGA_FPDATER); | ||
|
||
printk(KERN_INFO "Renesas Technology Europe SDK7780 support.\n"); | ||
printk(KERN_INFO "Board version: %d (revision %d), " | ||
"FPGA version: %d (revision %d), datestamp : %d\n", | ||
(ver >> 12) & 0xf, (ver >> 8) & 0xf, | ||
(ver >> 4) & 0xf, ver & 0xf, | ||
dateStamp); | ||
|
||
/* Setup pin mux'ing for PCIC */ | ||
ctrl_outw(0x0000, GPIO_PECR); | ||
} | ||
|
||
/* | ||
* The Machine Vector | ||
*/ | ||
static struct sh_machine_vector mv_se7780 __initmv = { | ||
.mv_name = "Renesas SDK7780-R3" , | ||
.mv_setup = sdk7780_setup, | ||
.mv_nr_irqs = 111, | ||
.mv_init_irq = init_sdk7780_IRQ, | ||
}; | ||
|
Oops, something went wrong.