162306a36Sopenharmony_ci// SPDX-License-Identifier: GPL-2.0
262306a36Sopenharmony_ci/*
362306a36Sopenharmony_ci * Renesas Technology Europe RSK+ 7203 Support.
462306a36Sopenharmony_ci *
562306a36Sopenharmony_ci * Copyright (C) 2008 - 2010  Paul Mundt
662306a36Sopenharmony_ci */
762306a36Sopenharmony_ci#include <linux/init.h>
862306a36Sopenharmony_ci#include <linux/types.h>
962306a36Sopenharmony_ci#include <linux/platform_device.h>
1062306a36Sopenharmony_ci#include <linux/interrupt.h>
1162306a36Sopenharmony_ci#include <linux/smsc911x.h>
1262306a36Sopenharmony_ci#include <linux/input.h>
1362306a36Sopenharmony_ci#include <linux/gpio.h>
1462306a36Sopenharmony_ci#include <linux/gpio_keys.h>
1562306a36Sopenharmony_ci#include <linux/leds.h>
1662306a36Sopenharmony_ci#include <asm/machvec.h>
1762306a36Sopenharmony_ci#include <asm/io.h>
1862306a36Sopenharmony_ci#include <cpu/sh7203.h>
1962306a36Sopenharmony_ci
2062306a36Sopenharmony_cistatic struct smsc911x_platform_config smsc911x_config = {
2162306a36Sopenharmony_ci	.phy_interface	= PHY_INTERFACE_MODE_MII,
2262306a36Sopenharmony_ci	.irq_polarity	= SMSC911X_IRQ_POLARITY_ACTIVE_LOW,
2362306a36Sopenharmony_ci	.irq_type	= SMSC911X_IRQ_TYPE_OPEN_DRAIN,
2462306a36Sopenharmony_ci	.flags		= SMSC911X_USE_32BIT | SMSC911X_SWAP_FIFO,
2562306a36Sopenharmony_ci};
2662306a36Sopenharmony_ci
2762306a36Sopenharmony_cistatic struct resource smsc911x_resources[] = {
2862306a36Sopenharmony_ci	[0] = {
2962306a36Sopenharmony_ci		.start		= 0x24000000,
3062306a36Sopenharmony_ci		.end		= 0x240000ff,
3162306a36Sopenharmony_ci		.flags		= IORESOURCE_MEM,
3262306a36Sopenharmony_ci	},
3362306a36Sopenharmony_ci	[1] = {
3462306a36Sopenharmony_ci		.start		= 64,
3562306a36Sopenharmony_ci		.end		= 64,
3662306a36Sopenharmony_ci		.flags		= IORESOURCE_IRQ,
3762306a36Sopenharmony_ci	},
3862306a36Sopenharmony_ci};
3962306a36Sopenharmony_ci
4062306a36Sopenharmony_cistatic struct platform_device smsc911x_device = {
4162306a36Sopenharmony_ci	.name		= "smsc911x",
4262306a36Sopenharmony_ci	.id		= -1,
4362306a36Sopenharmony_ci	.num_resources	= ARRAY_SIZE(smsc911x_resources),
4462306a36Sopenharmony_ci	.resource	= smsc911x_resources,
4562306a36Sopenharmony_ci	.dev		= {
4662306a36Sopenharmony_ci		.platform_data = &smsc911x_config,
4762306a36Sopenharmony_ci	},
4862306a36Sopenharmony_ci};
4962306a36Sopenharmony_ci
5062306a36Sopenharmony_cistatic struct gpio_led rsk7203_gpio_leds[] = {
5162306a36Sopenharmony_ci	{
5262306a36Sopenharmony_ci		.name			= "green",
5362306a36Sopenharmony_ci		.gpio			= GPIO_PE10,
5462306a36Sopenharmony_ci		.active_low		= 1,
5562306a36Sopenharmony_ci	}, {
5662306a36Sopenharmony_ci		.name			= "orange",
5762306a36Sopenharmony_ci		.default_trigger	= "nand-disk",
5862306a36Sopenharmony_ci		.gpio			= GPIO_PE12,
5962306a36Sopenharmony_ci		.active_low		= 1,
6062306a36Sopenharmony_ci	}, {
6162306a36Sopenharmony_ci		.name			= "red:timer",
6262306a36Sopenharmony_ci		.default_trigger	= "timer",
6362306a36Sopenharmony_ci		.gpio			= GPIO_PC14,
6462306a36Sopenharmony_ci		.active_low		= 1,
6562306a36Sopenharmony_ci	}, {
6662306a36Sopenharmony_ci		.name			= "red:heartbeat",
6762306a36Sopenharmony_ci		.default_trigger	= "heartbeat",
6862306a36Sopenharmony_ci		.gpio			= GPIO_PE11,
6962306a36Sopenharmony_ci		.active_low		= 1,
7062306a36Sopenharmony_ci	},
7162306a36Sopenharmony_ci};
7262306a36Sopenharmony_ci
7362306a36Sopenharmony_cistatic struct gpio_led_platform_data rsk7203_gpio_leds_info = {
7462306a36Sopenharmony_ci	.leds		= rsk7203_gpio_leds,
7562306a36Sopenharmony_ci	.num_leds	= ARRAY_SIZE(rsk7203_gpio_leds),
7662306a36Sopenharmony_ci};
7762306a36Sopenharmony_ci
7862306a36Sopenharmony_cistatic struct platform_device led_device = {
7962306a36Sopenharmony_ci	.name		= "leds-gpio",
8062306a36Sopenharmony_ci	.id		= -1,
8162306a36Sopenharmony_ci	.dev		= {
8262306a36Sopenharmony_ci		.platform_data	= &rsk7203_gpio_leds_info,
8362306a36Sopenharmony_ci	},
8462306a36Sopenharmony_ci};
8562306a36Sopenharmony_ci
8662306a36Sopenharmony_cistatic struct gpio_keys_button rsk7203_gpio_keys_table[] = {
8762306a36Sopenharmony_ci	{
8862306a36Sopenharmony_ci		.code		= BTN_0,
8962306a36Sopenharmony_ci		.gpio		= GPIO_PB0,
9062306a36Sopenharmony_ci		.active_low	= 1,
9162306a36Sopenharmony_ci		.desc		= "SW1",
9262306a36Sopenharmony_ci	}, {
9362306a36Sopenharmony_ci		.code		= BTN_1,
9462306a36Sopenharmony_ci		.gpio		= GPIO_PB1,
9562306a36Sopenharmony_ci		.active_low	= 1,
9662306a36Sopenharmony_ci		.desc		= "SW2",
9762306a36Sopenharmony_ci	}, {
9862306a36Sopenharmony_ci		.code		= BTN_2,
9962306a36Sopenharmony_ci		.gpio		= GPIO_PB2,
10062306a36Sopenharmony_ci		.active_low	= 1,
10162306a36Sopenharmony_ci		.desc		= "SW3",
10262306a36Sopenharmony_ci	},
10362306a36Sopenharmony_ci};
10462306a36Sopenharmony_ci
10562306a36Sopenharmony_cistatic struct gpio_keys_platform_data rsk7203_gpio_keys_info = {
10662306a36Sopenharmony_ci	.buttons	= rsk7203_gpio_keys_table,
10762306a36Sopenharmony_ci	.nbuttons	= ARRAY_SIZE(rsk7203_gpio_keys_table),
10862306a36Sopenharmony_ci	.poll_interval	= 50, /* default to 50ms */
10962306a36Sopenharmony_ci};
11062306a36Sopenharmony_ci
11162306a36Sopenharmony_cistatic struct platform_device keys_device = {
11262306a36Sopenharmony_ci	.name		= "gpio-keys-polled",
11362306a36Sopenharmony_ci	.dev		= {
11462306a36Sopenharmony_ci		.platform_data	= &rsk7203_gpio_keys_info,
11562306a36Sopenharmony_ci	},
11662306a36Sopenharmony_ci};
11762306a36Sopenharmony_ci
11862306a36Sopenharmony_cistatic struct platform_device *rsk7203_devices[] __initdata = {
11962306a36Sopenharmony_ci	&smsc911x_device,
12062306a36Sopenharmony_ci	&led_device,
12162306a36Sopenharmony_ci	&keys_device,
12262306a36Sopenharmony_ci};
12362306a36Sopenharmony_ci
12462306a36Sopenharmony_cistatic int __init rsk7203_devices_setup(void)
12562306a36Sopenharmony_ci{
12662306a36Sopenharmony_ci	/* Select pins for SCIF0 */
12762306a36Sopenharmony_ci	gpio_request(GPIO_FN_TXD0, NULL);
12862306a36Sopenharmony_ci	gpio_request(GPIO_FN_RXD0, NULL);
12962306a36Sopenharmony_ci
13062306a36Sopenharmony_ci	/* Setup LAN9118: CS1 in 16-bit Big Endian Mode, IRQ0 at Port B */
13162306a36Sopenharmony_ci	__raw_writel(0x36db0400, 0xfffc0008); /* CS1BCR */
13262306a36Sopenharmony_ci	gpio_request(GPIO_FN_IRQ0_PB, NULL);
13362306a36Sopenharmony_ci
13462306a36Sopenharmony_ci	return platform_add_devices(rsk7203_devices,
13562306a36Sopenharmony_ci				    ARRAY_SIZE(rsk7203_devices));
13662306a36Sopenharmony_ci}
13762306a36Sopenharmony_cidevice_initcall(rsk7203_devices_setup);
138