| David Brown | 56e2d8a | 2011-08-04 02:01:02 -0700 | [diff] [blame] | 1 | /* Copyright (c) 2010, 2011, Code Aurora Forum. All rights reserved. | 
| Steve Muckle | a55df6e | 2010-01-07 12:43:24 -0800 | [diff] [blame] | 2 | * | 
|  | 3 | * This program is free software; you can redistribute it and/or modify | 
|  | 4 | * it under the terms of the GNU General Public License version 2 and | 
|  | 5 | * only version 2 as published by the Free Software Foundation. | 
|  | 6 | * | 
|  | 7 | * This program is distributed in the hope that it will be useful, | 
|  | 8 | * but WITHOUT ANY WARRANTY; without even the implied warranty of | 
|  | 9 | * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the | 
|  | 10 | * GNU General Public License for more details. | 
| Steve Muckle | a55df6e | 2010-01-07 12:43:24 -0800 | [diff] [blame] | 11 | */ | 
|  | 12 |  | 
|  | 13 | #include <linux/kernel.h> | 
|  | 14 | #include <linux/platform_device.h> | 
|  | 15 | #include <linux/io.h> | 
| Steve Muckle | 9161d30 | 2010-02-11 11:50:40 -0800 | [diff] [blame] | 16 | #include <linux/irq.h> | 
| David Brown | 56e2d8a | 2011-08-04 02:01:02 -0700 | [diff] [blame] | 17 | #include <linux/irqdomain.h> | 
|  | 18 | #include <linux/of.h> | 
|  | 19 | #include <linux/of_address.h> | 
|  | 20 | #include <linux/of_platform.h> | 
| Stephen Boyd | 9e775ad | 2011-08-12 00:14:28 +0100 | [diff] [blame] | 21 | #include <linux/memblock.h> | 
| Steve Muckle | a55df6e | 2010-01-07 12:43:24 -0800 | [diff] [blame] | 22 |  | 
|  | 23 | #include <asm/mach-types.h> | 
|  | 24 | #include <asm/mach/arch.h> | 
|  | 25 | #include <asm/hardware/gic.h> | 
| Stephen Boyd | 9e775ad | 2011-08-12 00:14:28 +0100 | [diff] [blame] | 26 | #include <asm/setup.h> | 
| Steve Muckle | a55df6e | 2010-01-07 12:43:24 -0800 | [diff] [blame] | 27 |  | 
|  | 28 | #include <mach/board.h> | 
|  | 29 | #include <mach/msm_iomap.h> | 
|  | 30 |  | 
| Stephen Boyd | 47a6770 | 2011-10-25 09:35:19 -0700 | [diff] [blame] | 31 | static void __init msm8x60_fixup(struct tag *tag, char **cmdline, | 
|  | 32 | struct meminfo *mi) | 
| Stephen Boyd | 9e775ad | 2011-08-12 00:14:28 +0100 | [diff] [blame] | 33 | { | 
|  | 34 | for (; tag->hdr.size; tag = tag_next(tag)) | 
|  | 35 | if (tag->hdr.tag == ATAG_MEM && | 
|  | 36 | tag->u.mem.start == 0x40200000) { | 
|  | 37 | tag->u.mem.start = 0x40000000; | 
|  | 38 | tag->u.mem.size += SZ_2M; | 
|  | 39 | } | 
|  | 40 | } | 
|  | 41 |  | 
|  | 42 | static void __init msm8x60_reserve(void) | 
|  | 43 | { | 
|  | 44 | memblock_remove(0x40000000, SZ_2M); | 
|  | 45 | } | 
| Steve Muckle | a55df6e | 2010-01-07 12:43:24 -0800 | [diff] [blame] | 46 |  | 
|  | 47 | static void __init msm8x60_map_io(void) | 
|  | 48 | { | 
|  | 49 | msm_map_msm8x60_io(); | 
|  | 50 | } | 
|  | 51 |  | 
|  | 52 | static void __init msm8x60_init_irq(void) | 
|  | 53 | { | 
| Russell King | ff2e27a | 2010-12-04 16:13:29 +0000 | [diff] [blame] | 54 | gic_init(0, GIC_PPI_START, MSM_QGIC_DIST_BASE, | 
|  | 55 | (void *)MSM_QGIC_CPU_BASE); | 
| Steve Muckle | 9161d30 | 2010-02-11 11:50:40 -0800 | [diff] [blame] | 56 |  | 
|  | 57 | /* Edge trigger PPIs except AVS_SVICINT and AVS_SVICINTSWDONE */ | 
|  | 58 | writel(0xFFFFD7FF, MSM_QGIC_DIST_BASE + GIC_DIST_CONFIG + 4); | 
|  | 59 |  | 
|  | 60 | /* RUMI does not adhere to GIC spec by enabling STIs by default. | 
|  | 61 | * Enable/clear is supposed to be RO for STIs, but is RW on RUMI. | 
|  | 62 | */ | 
| Steve Muckle | 57bbf1c | 2010-01-07 12:51:10 -0800 | [diff] [blame] | 63 | if (!machine_is_msm8x60_sim()) | 
|  | 64 | writel(0x0000FFFF, MSM_QGIC_DIST_BASE + GIC_DIST_ENABLE_SET); | 
| Steve Muckle | a55df6e | 2010-01-07 12:43:24 -0800 | [diff] [blame] | 65 | } | 
|  | 66 |  | 
|  | 67 | static void __init msm8x60_init(void) | 
|  | 68 | { | 
|  | 69 | } | 
|  | 70 |  | 
| David Brown | 56e2d8a | 2011-08-04 02:01:02 -0700 | [diff] [blame] | 71 | #ifdef CONFIG_OF | 
|  | 72 | static struct of_dev_auxdata msm_auxdata_lookup[] __initdata = { | 
|  | 73 | {} | 
|  | 74 | }; | 
|  | 75 |  | 
|  | 76 | static struct of_device_id msm_dt_gic_match[] __initdata = { | 
|  | 77 | { .compatible = "qcom,msm-8660-qgic", }, | 
|  | 78 | {} | 
|  | 79 | }; | 
|  | 80 |  | 
|  | 81 | static void __init msm8x60_dt_init(void) | 
|  | 82 | { | 
|  | 83 | struct device_node *node; | 
|  | 84 |  | 
|  | 85 | node = of_find_matching_node_by_address(NULL, msm_dt_gic_match, | 
|  | 86 | MSM8X60_QGIC_DIST_PHYS); | 
|  | 87 | if (node) | 
|  | 88 | irq_domain_add_simple(node, GIC_SPI_START); | 
|  | 89 |  | 
|  | 90 | if (of_machine_is_compatible("qcom,msm8660-surf")) { | 
|  | 91 | printk(KERN_INFO "Init surf UART registers\n"); | 
|  | 92 | msm8x60_init_uart12dm(); | 
|  | 93 | } | 
|  | 94 |  | 
|  | 95 | of_platform_populate(NULL, of_default_bus_match_table, | 
|  | 96 | msm_auxdata_lookup, NULL); | 
|  | 97 | } | 
|  | 98 |  | 
|  | 99 | static const char *msm8x60_fluid_match[] __initdata = { | 
|  | 100 | "qcom,msm8660-fluid", | 
|  | 101 | "qcom,msm8660-surf", | 
|  | 102 | NULL | 
|  | 103 | }; | 
|  | 104 | #endif /* CONFIG_OF */ | 
|  | 105 |  | 
| Steve Muckle | a55df6e | 2010-01-07 12:43:24 -0800 | [diff] [blame] | 106 | MACHINE_START(MSM8X60_RUMI3, "QCT MSM8X60 RUMI3") | 
| Stephen Boyd | 9e775ad | 2011-08-12 00:14:28 +0100 | [diff] [blame] | 107 | .fixup = msm8x60_fixup, | 
|  | 108 | .reserve = msm8x60_reserve, | 
| Steve Muckle | a55df6e | 2010-01-07 12:43:24 -0800 | [diff] [blame] | 109 | .map_io = msm8x60_map_io, | 
|  | 110 | .init_irq = msm8x60_init_irq, | 
| Marc Zyngier | 041f777 | 2011-09-06 10:23:45 +0100 | [diff] [blame] | 111 | .handle_irq = gic_handle_irq, | 
| Steve Muckle | a55df6e | 2010-01-07 12:43:24 -0800 | [diff] [blame] | 112 | .init_machine = msm8x60_init, | 
|  | 113 | .timer = &msm_timer, | 
|  | 114 | MACHINE_END | 
| Steve Muckle | 49b76f7 | 2010-03-19 17:00:08 -0700 | [diff] [blame] | 115 |  | 
|  | 116 | MACHINE_START(MSM8X60_SURF, "QCT MSM8X60 SURF") | 
| Stephen Boyd | 9e775ad | 2011-08-12 00:14:28 +0100 | [diff] [blame] | 117 | .fixup = msm8x60_fixup, | 
|  | 118 | .reserve = msm8x60_reserve, | 
| Steve Muckle | 49b76f7 | 2010-03-19 17:00:08 -0700 | [diff] [blame] | 119 | .map_io = msm8x60_map_io, | 
|  | 120 | .init_irq = msm8x60_init_irq, | 
| Marc Zyngier | 041f777 | 2011-09-06 10:23:45 +0100 | [diff] [blame] | 121 | .handle_irq = gic_handle_irq, | 
| Steve Muckle | 49b76f7 | 2010-03-19 17:00:08 -0700 | [diff] [blame] | 122 | .init_machine = msm8x60_init, | 
|  | 123 | .timer = &msm_timer, | 
|  | 124 | MACHINE_END | 
| Steve Muckle | 57bbf1c | 2010-01-07 12:51:10 -0800 | [diff] [blame] | 125 |  | 
|  | 126 | MACHINE_START(MSM8X60_SIM, "QCT MSM8X60 SIMULATOR") | 
| Stephen Boyd | 9e775ad | 2011-08-12 00:14:28 +0100 | [diff] [blame] | 127 | .fixup = msm8x60_fixup, | 
|  | 128 | .reserve = msm8x60_reserve, | 
| Steve Muckle | 57bbf1c | 2010-01-07 12:51:10 -0800 | [diff] [blame] | 129 | .map_io = msm8x60_map_io, | 
|  | 130 | .init_irq = msm8x60_init_irq, | 
| Marc Zyngier | 041f777 | 2011-09-06 10:23:45 +0100 | [diff] [blame] | 131 | .handle_irq = gic_handle_irq, | 
| Steve Muckle | 57bbf1c | 2010-01-07 12:51:10 -0800 | [diff] [blame] | 132 | .init_machine = msm8x60_init, | 
|  | 133 | .timer = &msm_timer, | 
|  | 134 | MACHINE_END | 
| Gregory Bean | 69b7f6f | 2010-04-04 22:29:02 -0700 | [diff] [blame] | 135 |  | 
|  | 136 | MACHINE_START(MSM8X60_FFA, "QCT MSM8X60 FFA") | 
| Stephen Boyd | 9e775ad | 2011-08-12 00:14:28 +0100 | [diff] [blame] | 137 | .fixup = msm8x60_fixup, | 
|  | 138 | .reserve = msm8x60_reserve, | 
| Gregory Bean | 69b7f6f | 2010-04-04 22:29:02 -0700 | [diff] [blame] | 139 | .map_io = msm8x60_map_io, | 
|  | 140 | .init_irq = msm8x60_init_irq, | 
| Marc Zyngier | 041f777 | 2011-09-06 10:23:45 +0100 | [diff] [blame] | 141 | .handle_irq = gic_handle_irq, | 
| Gregory Bean | 69b7f6f | 2010-04-04 22:29:02 -0700 | [diff] [blame] | 142 | .init_machine = msm8x60_init, | 
|  | 143 | .timer = &msm_timer, | 
|  | 144 | MACHINE_END | 
| David Brown | 56e2d8a | 2011-08-04 02:01:02 -0700 | [diff] [blame] | 145 |  | 
|  | 146 | #ifdef CONFIG_OF | 
|  | 147 | /* TODO: General device tree support for all MSM. */ | 
|  | 148 | DT_MACHINE_START(MSM_DT, "Qualcomm MSM (Flattened Device Tree)") | 
|  | 149 | .map_io = msm8x60_map_io, | 
|  | 150 | .init_irq = msm8x60_init_irq, | 
|  | 151 | .init_machine = msm8x60_dt_init, | 
|  | 152 | .timer = &msm_timer, | 
|  | 153 | .dt_compat = msm8x60_fluid_match, | 
|  | 154 | MACHINE_END | 
|  | 155 | #endif /* CONFIG_OF */ |