162306a36Sopenharmony_ci// SPDX-License-Identifier: GPL-2.0
262306a36Sopenharmony_ci/*
362306a36Sopenharmony_ci * SH-2007 board support.
462306a36Sopenharmony_ci *
562306a36Sopenharmony_ci * Copyright (C) 2003, 2004  SUGIOKA Toshinobu
662306a36Sopenharmony_ci * Copyright (C) 2010  Hitoshi Mitake <mitake@dcl.info.waseda.ac.jp>
762306a36Sopenharmony_ci */
862306a36Sopenharmony_ci#include <linux/init.h>
962306a36Sopenharmony_ci#include <linux/irq.h>
1062306a36Sopenharmony_ci#include <linux/regulator/fixed.h>
1162306a36Sopenharmony_ci#include <linux/regulator/machine.h>
1262306a36Sopenharmony_ci#include <linux/smsc911x.h>
1362306a36Sopenharmony_ci#include <linux/platform_device.h>
1462306a36Sopenharmony_ci#include <linux/ata_platform.h>
1562306a36Sopenharmony_ci#include <linux/io.h>
1662306a36Sopenharmony_ci#include <asm/machvec.h>
1762306a36Sopenharmony_ci#include <mach/sh2007.h>
1862306a36Sopenharmony_ci
1962306a36Sopenharmony_ci/* Dummy supplies, where voltage doesn't matter */
2062306a36Sopenharmony_cistatic struct regulator_consumer_supply dummy_supplies[] = {
2162306a36Sopenharmony_ci	REGULATOR_SUPPLY("vddvario", "smsc911x.0"),
2262306a36Sopenharmony_ci	REGULATOR_SUPPLY("vdd33a", "smsc911x.0"),
2362306a36Sopenharmony_ci	REGULATOR_SUPPLY("vddvario", "smsc911x.1"),
2462306a36Sopenharmony_ci	REGULATOR_SUPPLY("vdd33a", "smsc911x.1"),
2562306a36Sopenharmony_ci};
2662306a36Sopenharmony_ci
2762306a36Sopenharmony_cistruct smsc911x_platform_config smc911x_info = {
2862306a36Sopenharmony_ci	.flags		= SMSC911X_USE_32BIT,
2962306a36Sopenharmony_ci	.irq_polarity	= SMSC911X_IRQ_POLARITY_ACTIVE_LOW,
3062306a36Sopenharmony_ci	.irq_type	= SMSC911X_IRQ_TYPE_PUSH_PULL,
3162306a36Sopenharmony_ci};
3262306a36Sopenharmony_ci
3362306a36Sopenharmony_cistatic struct resource smsc9118_0_resources[] = {
3462306a36Sopenharmony_ci	[0] = {
3562306a36Sopenharmony_ci		.start	= SMC0_BASE,
3662306a36Sopenharmony_ci		.end	= SMC0_BASE + 0xff,
3762306a36Sopenharmony_ci		.flags	= IORESOURCE_MEM,
3862306a36Sopenharmony_ci	},
3962306a36Sopenharmony_ci	[1] = {
4062306a36Sopenharmony_ci		.start	= evt2irq(0x240),
4162306a36Sopenharmony_ci		.end	= evt2irq(0x240),
4262306a36Sopenharmony_ci		.flags	= IORESOURCE_IRQ,
4362306a36Sopenharmony_ci	}
4462306a36Sopenharmony_ci};
4562306a36Sopenharmony_ci
4662306a36Sopenharmony_cistatic struct resource smsc9118_1_resources[] = {
4762306a36Sopenharmony_ci	[0] = {
4862306a36Sopenharmony_ci		.start	= SMC1_BASE,
4962306a36Sopenharmony_ci		.end	= SMC1_BASE + 0xff,
5062306a36Sopenharmony_ci		.flags	= IORESOURCE_MEM,
5162306a36Sopenharmony_ci	},
5262306a36Sopenharmony_ci	[1] = {
5362306a36Sopenharmony_ci		.start	= evt2irq(0x280),
5462306a36Sopenharmony_ci		.end	= evt2irq(0x280),
5562306a36Sopenharmony_ci		.flags	= IORESOURCE_IRQ,
5662306a36Sopenharmony_ci	}
5762306a36Sopenharmony_ci};
5862306a36Sopenharmony_ci
5962306a36Sopenharmony_cistatic struct platform_device smsc9118_0_device = {
6062306a36Sopenharmony_ci	.name		= "smsc911x",
6162306a36Sopenharmony_ci	.id		= 0,
6262306a36Sopenharmony_ci	.num_resources	= ARRAY_SIZE(smsc9118_0_resources),
6362306a36Sopenharmony_ci	.resource	= smsc9118_0_resources,
6462306a36Sopenharmony_ci	.dev = {
6562306a36Sopenharmony_ci		.platform_data = &smc911x_info,
6662306a36Sopenharmony_ci	},
6762306a36Sopenharmony_ci};
6862306a36Sopenharmony_ci
6962306a36Sopenharmony_cistatic struct platform_device smsc9118_1_device = {
7062306a36Sopenharmony_ci	.name		= "smsc911x",
7162306a36Sopenharmony_ci	.id		= 1,
7262306a36Sopenharmony_ci	.num_resources	= ARRAY_SIZE(smsc9118_1_resources),
7362306a36Sopenharmony_ci	.resource	= smsc9118_1_resources,
7462306a36Sopenharmony_ci	.dev = {
7562306a36Sopenharmony_ci		.platform_data = &smc911x_info,
7662306a36Sopenharmony_ci	},
7762306a36Sopenharmony_ci};
7862306a36Sopenharmony_ci
7962306a36Sopenharmony_cistatic struct resource cf_resources[] = {
8062306a36Sopenharmony_ci	[0] = {
8162306a36Sopenharmony_ci		.start	= CF_BASE + CF_OFFSET,
8262306a36Sopenharmony_ci		.end	= CF_BASE + CF_OFFSET + 0x0f,
8362306a36Sopenharmony_ci		.flags	= IORESOURCE_MEM,
8462306a36Sopenharmony_ci	},
8562306a36Sopenharmony_ci	[1] = {
8662306a36Sopenharmony_ci		.start	= CF_BASE + CF_OFFSET + 0x206,
8762306a36Sopenharmony_ci		.end	= CF_BASE + CF_OFFSET + 0x20f,
8862306a36Sopenharmony_ci		.flags	= IORESOURCE_MEM,
8962306a36Sopenharmony_ci	},
9062306a36Sopenharmony_ci	[2] = {
9162306a36Sopenharmony_ci		.start	= evt2irq(0x2c0),
9262306a36Sopenharmony_ci		.end	= evt2irq(0x2c0),
9362306a36Sopenharmony_ci		.flags	= IORESOURCE_IRQ,
9462306a36Sopenharmony_ci	},
9562306a36Sopenharmony_ci};
9662306a36Sopenharmony_ci
9762306a36Sopenharmony_cistatic struct platform_device cf_device  = {
9862306a36Sopenharmony_ci	.name		= "pata_platform",
9962306a36Sopenharmony_ci	.id		= 0,
10062306a36Sopenharmony_ci	.num_resources	= ARRAY_SIZE(cf_resources),
10162306a36Sopenharmony_ci	.resource	= cf_resources,
10262306a36Sopenharmony_ci};
10362306a36Sopenharmony_ci
10462306a36Sopenharmony_cistatic struct platform_device *sh2007_devices[] __initdata = {
10562306a36Sopenharmony_ci	&smsc9118_0_device,
10662306a36Sopenharmony_ci	&smsc9118_1_device,
10762306a36Sopenharmony_ci	&cf_device,
10862306a36Sopenharmony_ci};
10962306a36Sopenharmony_ci
11062306a36Sopenharmony_cistatic int __init sh2007_io_init(void)
11162306a36Sopenharmony_ci{
11262306a36Sopenharmony_ci	regulator_register_fixed(0, dummy_supplies, ARRAY_SIZE(dummy_supplies));
11362306a36Sopenharmony_ci
11462306a36Sopenharmony_ci	platform_add_devices(sh2007_devices, ARRAY_SIZE(sh2007_devices));
11562306a36Sopenharmony_ci	return 0;
11662306a36Sopenharmony_ci}
11762306a36Sopenharmony_cisubsys_initcall(sh2007_io_init);
11862306a36Sopenharmony_ci
11962306a36Sopenharmony_cistatic void __init sh2007_init_irq(void)
12062306a36Sopenharmony_ci{
12162306a36Sopenharmony_ci	plat_irq_setup_pins(IRQ_MODE_IRQ);
12262306a36Sopenharmony_ci}
12362306a36Sopenharmony_ci
12462306a36Sopenharmony_ci/*
12562306a36Sopenharmony_ci * Initialize the board
12662306a36Sopenharmony_ci */
12762306a36Sopenharmony_cistatic void __init sh2007_setup(char **cmdline_p)
12862306a36Sopenharmony_ci{
12962306a36Sopenharmony_ci	pr_info("SH-2007 Setup...");
13062306a36Sopenharmony_ci
13162306a36Sopenharmony_ci	/* setup wait control registers for area 5 */
13262306a36Sopenharmony_ci	__raw_writel(CS5BCR_D, CS5BCR);
13362306a36Sopenharmony_ci	__raw_writel(CS5WCR_D, CS5WCR);
13462306a36Sopenharmony_ci	__raw_writel(CS5PCR_D, CS5PCR);
13562306a36Sopenharmony_ci
13662306a36Sopenharmony_ci	pr_cont(" done.\n");
13762306a36Sopenharmony_ci}
13862306a36Sopenharmony_ci
13962306a36Sopenharmony_ci/*
14062306a36Sopenharmony_ci * The Machine Vector
14162306a36Sopenharmony_ci */
14262306a36Sopenharmony_cistruct sh_machine_vector mv_sh2007 __initmv = {
14362306a36Sopenharmony_ci	.mv_setup		= sh2007_setup,
14462306a36Sopenharmony_ci	.mv_name		= "sh2007",
14562306a36Sopenharmony_ci	.mv_init_irq		= sh2007_init_irq,
14662306a36Sopenharmony_ci};
147