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