blob: 8ef8ac4ab4ac13c7b5c4763b53c18798c5c2ed91 [file] [log] [blame]
Thomas Gleixnerd2912cb2019-06-04 10:11:33 +02001// SPDX-License-Identifier: GPL-2.0-only
Kristoffer Ericson49ea26d02008-10-02 20:15:35 +01002/*
3 * linux/arch/arm/mach-pxa/mp900.c
4 *
5 * Support for the NEC MobilePro900/C platform
6 *
7 * Based on mach-pxa/gumstix.c
8 *
9 * 2007, 2008 Kristoffer Ericson <kristoffer.ericson@gmail.com>
10 * 2007, 2008 Michael Petchkovsky <mkpetch@internode.on.net>
Kristoffer Ericson49ea26d02008-10-02 20:15:35 +010011 */
12
13#include <linux/init.h>
14#include <linux/device.h>
15#include <linux/platform_device.h>
16#include <linux/types.h>
17#include <linux/usb/isp116x.h>
18
Kristoffer Ericson49ea26d02008-10-02 20:15:35 +010019#include <asm/mach-types.h>
20#include <asm/mach/arch.h>
Eric Miao51c62982009-01-02 23:17:22 +080021
Arnd Bergmann4c25c5d2015-01-30 10:45:33 +010022#include "pxa25x.h"
Kristoffer Ericson49ea26d02008-10-02 20:15:35 +010023#include "generic.h"
24
25static void isp116x_pfm_delay(struct device *dev, int delay)
26{
27
Russell King6a53bc72015-05-14 16:18:46 +010028 /* 400MHz PXA2 = 2.5ns / instruction */
Kristoffer Ericson49ea26d02008-10-02 20:15:35 +010029
30 int cyc = delay / 10;
31
32 /* 4 Instructions = 4 x 2.5ns = 10ns */
33 __asm__ volatile ("0:\n"
34 "subs %0, %1, #1\n"
35 "bge 0b\n"
36 :"=r" (cyc)
37 :"0"(cyc)
38 );
39}
40
41static struct isp116x_platform_data isp116x_pfm_data = {
42 .remote_wakeup_enable = 1,
43 .delay = isp116x_pfm_delay,
44};
45
46static struct resource isp116x_pfm_resources[] = {
47 [0] = {
48 .start = 0x0d000000,
49 .end = 0x0d000000 + 1,
50 .flags = IORESOURCE_MEM,
51 },
52 [1] = {
53 .start = 0x0d000000 + 4,
54 .end = 0x0d000000 + 5,
55 .flags = IORESOURCE_MEM,
56 },
57 [2] = {
58 .start = 61,
59 .end = 61,
60 .flags = IORESOURCE_IRQ,
61 },
62};
63
64static struct platform_device mp900c_dummy_device = {
65 .name = "mp900c_dummy",
66 .id = -1,
67};
68
69static struct platform_device mp900c_usb = {
70 .name = "isp116x-hcd",
71 .num_resources = ARRAY_SIZE(isp116x_pfm_resources),
72 .resource = isp116x_pfm_resources,
73 .dev.platform_data = &isp116x_pfm_data,
74};
75
76static struct platform_device *devices[] __initdata = {
77 &mp900c_dummy_device,
78 &mp900c_usb,
79};
80
81static void __init mp900c_init(void)
82{
83 printk(KERN_INFO "MobilePro 900/C machine init\n");
Russell Kingcc155c62009-11-09 13:34:08 +080084 pxa_set_ffuart_info(NULL);
85 pxa_set_btuart_info(NULL);
86 pxa_set_stuart_info(NULL);
Kristoffer Ericson49ea26d02008-10-02 20:15:35 +010087 platform_add_devices(devices, ARRAY_SIZE(devices));
88}
89
90/* Maintainer - Michael Petchkovsky <mkpetch@internode.on.net> */
91MACHINE_START(NEC_MP900, "MobilePro900/C")
Nicolas Pitre7375aba2011-07-05 22:38:15 -040092 .atag_offset = 0x220100,
Stephen Warren6bb27d72012-11-08 12:40:59 -070093 .init_time = pxa_timer_init,
Marek Vasut851982c2010-10-11 02:20:19 +020094 .map_io = pxa25x_map_io,
Rob Herring4e611092012-01-03 16:53:48 -060095 .nr_irqs = PXA_NR_IRQS,
Kristoffer Ericson49ea26d02008-10-02 20:15:35 +010096 .init_irq = pxa25x_init_irq,
Eric Miao8a97ae22011-05-18 21:30:04 +080097 .handle_irq = pxa25x_handle_irq,
Kristoffer Ericson49ea26d02008-10-02 20:15:35 +010098 .init_machine = mp900c_init,
Russell King271a74f2011-11-04 14:15:53 +000099 .restart = pxa_restart,
Kristoffer Ericson49ea26d02008-10-02 20:15:35 +0100100MACHINE_END
101