162306a36Sopenharmony_ci// SPDX-License-Identifier: GPL-2.0
262306a36Sopenharmony_ci/*
362306a36Sopenharmony_ci * June 2006 Steve Glendinning <steve.glendinning@shawell.net>
462306a36Sopenharmony_ci *
562306a36Sopenharmony_ci * Polaris-specific resource declaration
662306a36Sopenharmony_ci *
762306a36Sopenharmony_ci */
862306a36Sopenharmony_ci
962306a36Sopenharmony_ci#include <linux/init.h>
1062306a36Sopenharmony_ci#include <linux/interrupt.h>
1162306a36Sopenharmony_ci#include <linux/irq.h>
1262306a36Sopenharmony_ci#include <linux/platform_device.h>
1362306a36Sopenharmony_ci#include <linux/regulator/fixed.h>
1462306a36Sopenharmony_ci#include <linux/regulator/machine.h>
1562306a36Sopenharmony_ci#include <linux/smsc911x.h>
1662306a36Sopenharmony_ci#include <linux/io.h>
1762306a36Sopenharmony_ci#include <asm/irq.h>
1862306a36Sopenharmony_ci#include <asm/machvec.h>
1962306a36Sopenharmony_ci#include <asm/heartbeat.h>
2062306a36Sopenharmony_ci#include <cpu/gpio.h>
2162306a36Sopenharmony_ci#include <mach-se/mach/se.h>
2262306a36Sopenharmony_ci
2362306a36Sopenharmony_ci#define BCR2		(0xFFFFFF62)
2462306a36Sopenharmony_ci#define WCR2		(0xFFFFFF66)
2562306a36Sopenharmony_ci#define AREA5_WAIT_CTRL	(0x1C00)
2662306a36Sopenharmony_ci#define WAIT_STATES_10	(0x7)
2762306a36Sopenharmony_ci
2862306a36Sopenharmony_ci/* Dummy supplies, where voltage doesn't matter */
2962306a36Sopenharmony_cistatic struct regulator_consumer_supply dummy_supplies[] = {
3062306a36Sopenharmony_ci	REGULATOR_SUPPLY("vddvario", "smsc911x.0"),
3162306a36Sopenharmony_ci	REGULATOR_SUPPLY("vdd33a", "smsc911x.0"),
3262306a36Sopenharmony_ci};
3362306a36Sopenharmony_ci
3462306a36Sopenharmony_cistatic struct resource smsc911x_resources[] = {
3562306a36Sopenharmony_ci	[0] = {
3662306a36Sopenharmony_ci		.name		= "smsc911x-memory",
3762306a36Sopenharmony_ci		.start		= PA_EXT5,
3862306a36Sopenharmony_ci		.end		= PA_EXT5 + 0x1fff,
3962306a36Sopenharmony_ci		.flags		= IORESOURCE_MEM,
4062306a36Sopenharmony_ci	},
4162306a36Sopenharmony_ci	[1] = {
4262306a36Sopenharmony_ci		.name		= "smsc911x-irq",
4362306a36Sopenharmony_ci		.start		= IRQ0_IRQ,
4462306a36Sopenharmony_ci		.end		= IRQ0_IRQ,
4562306a36Sopenharmony_ci		.flags		= IORESOURCE_IRQ,
4662306a36Sopenharmony_ci	},
4762306a36Sopenharmony_ci};
4862306a36Sopenharmony_ci
4962306a36Sopenharmony_cistatic struct smsc911x_platform_config smsc911x_config = {
5062306a36Sopenharmony_ci	.irq_polarity	= SMSC911X_IRQ_POLARITY_ACTIVE_LOW,
5162306a36Sopenharmony_ci	.irq_type	= SMSC911X_IRQ_TYPE_OPEN_DRAIN,
5262306a36Sopenharmony_ci	.flags		= SMSC911X_USE_32BIT,
5362306a36Sopenharmony_ci	.phy_interface	= PHY_INTERFACE_MODE_MII,
5462306a36Sopenharmony_ci};
5562306a36Sopenharmony_ci
5662306a36Sopenharmony_cistatic struct platform_device smsc911x_device = {
5762306a36Sopenharmony_ci	.name		= "smsc911x",
5862306a36Sopenharmony_ci	.id		= 0,
5962306a36Sopenharmony_ci	.num_resources	= ARRAY_SIZE(smsc911x_resources),
6062306a36Sopenharmony_ci	.resource	= smsc911x_resources,
6162306a36Sopenharmony_ci	.dev = {
6262306a36Sopenharmony_ci		.platform_data = &smsc911x_config,
6362306a36Sopenharmony_ci	},
6462306a36Sopenharmony_ci};
6562306a36Sopenharmony_ci
6662306a36Sopenharmony_cistatic unsigned char heartbeat_bit_pos[] = { 0, 1, 2, 3 };
6762306a36Sopenharmony_ci
6862306a36Sopenharmony_cistatic struct heartbeat_data heartbeat_data = {
6962306a36Sopenharmony_ci	.bit_pos	= heartbeat_bit_pos,
7062306a36Sopenharmony_ci	.nr_bits	= ARRAY_SIZE(heartbeat_bit_pos),
7162306a36Sopenharmony_ci};
7262306a36Sopenharmony_ci
7362306a36Sopenharmony_cistatic struct resource heartbeat_resource = {
7462306a36Sopenharmony_ci	.start	= PORT_PCDR,
7562306a36Sopenharmony_ci	.end	= PORT_PCDR,
7662306a36Sopenharmony_ci	.flags	= IORESOURCE_MEM | IORESOURCE_MEM_8BIT,
7762306a36Sopenharmony_ci};
7862306a36Sopenharmony_ci
7962306a36Sopenharmony_cistatic struct platform_device heartbeat_device = {
8062306a36Sopenharmony_ci	.name		= "heartbeat",
8162306a36Sopenharmony_ci	.id		= -1,
8262306a36Sopenharmony_ci	.dev	= {
8362306a36Sopenharmony_ci		.platform_data	= &heartbeat_data,
8462306a36Sopenharmony_ci	},
8562306a36Sopenharmony_ci	.num_resources	= 1,
8662306a36Sopenharmony_ci	.resource	= &heartbeat_resource,
8762306a36Sopenharmony_ci};
8862306a36Sopenharmony_ci
8962306a36Sopenharmony_cistatic struct platform_device *polaris_devices[] __initdata = {
9062306a36Sopenharmony_ci	&smsc911x_device,
9162306a36Sopenharmony_ci	&heartbeat_device,
9262306a36Sopenharmony_ci};
9362306a36Sopenharmony_ci
9462306a36Sopenharmony_cistatic int __init polaris_initialise(void)
9562306a36Sopenharmony_ci{
9662306a36Sopenharmony_ci	u16 wcr, bcr_mask;
9762306a36Sopenharmony_ci
9862306a36Sopenharmony_ci	printk(KERN_INFO "Configuring Polaris external bus\n");
9962306a36Sopenharmony_ci
10062306a36Sopenharmony_ci	regulator_register_fixed(0, dummy_supplies, ARRAY_SIZE(dummy_supplies));
10162306a36Sopenharmony_ci
10262306a36Sopenharmony_ci	/* Configure area 5 with 2 wait states */
10362306a36Sopenharmony_ci	wcr = __raw_readw(WCR2);
10462306a36Sopenharmony_ci	wcr &= (~AREA5_WAIT_CTRL);
10562306a36Sopenharmony_ci	wcr |= (WAIT_STATES_10 << 10);
10662306a36Sopenharmony_ci	__raw_writew(wcr, WCR2);
10762306a36Sopenharmony_ci
10862306a36Sopenharmony_ci	/* Configure area 5 for 32-bit access */
10962306a36Sopenharmony_ci	bcr_mask = __raw_readw(BCR2);
11062306a36Sopenharmony_ci	bcr_mask |= 1 << 10;
11162306a36Sopenharmony_ci	__raw_writew(bcr_mask, BCR2);
11262306a36Sopenharmony_ci
11362306a36Sopenharmony_ci	return platform_add_devices(polaris_devices,
11462306a36Sopenharmony_ci				    ARRAY_SIZE(polaris_devices));
11562306a36Sopenharmony_ci}
11662306a36Sopenharmony_ciarch_initcall(polaris_initialise);
11762306a36Sopenharmony_ci
11862306a36Sopenharmony_cistatic struct ipr_data ipr_irq_table[] = {
11962306a36Sopenharmony_ci	/* External IRQs */
12062306a36Sopenharmony_ci	{ IRQ0_IRQ, 0,  0,  1, },	/* IRQ0 */
12162306a36Sopenharmony_ci	{ IRQ1_IRQ, 0,  4,  1, },	/* IRQ1 */
12262306a36Sopenharmony_ci};
12362306a36Sopenharmony_ci
12462306a36Sopenharmony_cistatic unsigned long ipr_offsets[] = {
12562306a36Sopenharmony_ci	INTC_IPRC
12662306a36Sopenharmony_ci};
12762306a36Sopenharmony_ci
12862306a36Sopenharmony_cistatic struct ipr_desc ipr_irq_desc = {
12962306a36Sopenharmony_ci	.ipr_offsets	= ipr_offsets,
13062306a36Sopenharmony_ci	.nr_offsets	= ARRAY_SIZE(ipr_offsets),
13162306a36Sopenharmony_ci
13262306a36Sopenharmony_ci	.ipr_data	= ipr_irq_table,
13362306a36Sopenharmony_ci	.nr_irqs	= ARRAY_SIZE(ipr_irq_table),
13462306a36Sopenharmony_ci	.chip = {
13562306a36Sopenharmony_ci		.name	= "sh7709-ext",
13662306a36Sopenharmony_ci	},
13762306a36Sopenharmony_ci};
13862306a36Sopenharmony_ci
13962306a36Sopenharmony_cistatic void __init init_polaris_irq(void)
14062306a36Sopenharmony_ci{
14162306a36Sopenharmony_ci	/* Disable all interrupts */
14262306a36Sopenharmony_ci	__raw_writew(0, BCR_ILCRA);
14362306a36Sopenharmony_ci	__raw_writew(0, BCR_ILCRB);
14462306a36Sopenharmony_ci	__raw_writew(0, BCR_ILCRC);
14562306a36Sopenharmony_ci	__raw_writew(0, BCR_ILCRD);
14662306a36Sopenharmony_ci	__raw_writew(0, BCR_ILCRE);
14762306a36Sopenharmony_ci	__raw_writew(0, BCR_ILCRF);
14862306a36Sopenharmony_ci	__raw_writew(0, BCR_ILCRG);
14962306a36Sopenharmony_ci
15062306a36Sopenharmony_ci	register_ipr_controller(&ipr_irq_desc);
15162306a36Sopenharmony_ci}
15262306a36Sopenharmony_ci
15362306a36Sopenharmony_cistatic struct sh_machine_vector mv_polaris __initmv = {
15462306a36Sopenharmony_ci	.mv_name		= "Polaris",
15562306a36Sopenharmony_ci	.mv_init_irq		= init_polaris_irq,
15662306a36Sopenharmony_ci};
157