diff options
396 files changed, 5354 insertions, 3063 deletions
diff --git a/Documentation/feature-removal-schedule.txt b/Documentation/feature-removal-schedule.txt index c268783bc4e7..1571c0c83dba 100644 --- a/Documentation/feature-removal-schedule.txt +++ b/Documentation/feature-removal-schedule.txt | |||
| @@ -647,3 +647,10 @@ Who: Stefan Richter <stefanr@s5r6.in-berlin.de> | |||
| 647 | 647 | ||
| 648 | ---------------------------- | 648 | ---------------------------- |
| 649 | 649 | ||
| 650 | What: The acpi_sleep=s4_nonvs command line option | ||
| 651 | When: 2.6.37 | ||
| 652 | Files: arch/x86/kernel/acpi/sleep.c | ||
| 653 | Why: superseded by acpi_sleep=nonvs | ||
| 654 | Who: Rafael J. Wysocki <rjw@sisk.pl> | ||
| 655 | |||
| 656 | ---------------------------- | ||
diff --git a/Documentation/kernel-parameters.txt b/Documentation/kernel-parameters.txt index 4ddb58df081e..2b2407d9a6d0 100644 --- a/Documentation/kernel-parameters.txt +++ b/Documentation/kernel-parameters.txt | |||
| @@ -254,8 +254,8 @@ and is between 256 and 4096 characters. It is defined in the file | |||
| 254 | control method, with respect to putting devices into | 254 | control method, with respect to putting devices into |
| 255 | low power states, to be enforced (the ACPI 2.0 ordering | 255 | low power states, to be enforced (the ACPI 2.0 ordering |
| 256 | of _PTS is used by default). | 256 | of _PTS is used by default). |
| 257 | s4_nonvs prevents the kernel from saving/restoring the | 257 | nonvs prevents the kernel from saving/restoring the |
| 258 | ACPI NVS memory during hibernation. | 258 | ACPI NVS memory during suspend/hibernation and resume. |
| 259 | sci_force_enable causes the kernel to set SCI_EN directly | 259 | sci_force_enable causes the kernel to set SCI_EN directly |
| 260 | on resume from S1/S3 (which is against the ACPI spec, | 260 | on resume from S1/S3 (which is against the ACPI spec, |
| 261 | but some broken systems don't work without it). | 261 | but some broken systems don't work without it). |
| @@ -1,7 +1,7 @@ | |||
| 1 | VERSION = 2 | 1 | VERSION = 2 |
| 2 | PATCHLEVEL = 6 | 2 | PATCHLEVEL = 6 |
| 3 | SUBLEVEL = 35 | 3 | SUBLEVEL = 35 |
| 4 | EXTRAVERSION = -rc5 | 4 | EXTRAVERSION = -rc6 |
| 5 | NAME = Sheep on Meth | 5 | NAME = Sheep on Meth |
| 6 | 6 | ||
| 7 | # *DOCUMENTATION* | 7 | # *DOCUMENTATION* |
diff --git a/arch/arm/Kconfig b/arch/arm/Kconfig index 98922f7d2d12..4047f5724da3 100644 --- a/arch/arm/Kconfig +++ b/arch/arm/Kconfig | |||
| @@ -10,6 +10,7 @@ config ARM | |||
| 10 | default y | 10 | default y |
| 11 | select HAVE_AOUT | 11 | select HAVE_AOUT |
| 12 | select HAVE_IDE | 12 | select HAVE_IDE |
| 13 | select HAVE_MEMBLOCK | ||
| 13 | select RTC_LIB | 14 | select RTC_LIB |
| 14 | select SYS_SUPPORTS_APM_EMULATION | 15 | select SYS_SUPPORTS_APM_EMULATION |
| 15 | select GENERIC_ATOMIC64 if (!CPU_32v6K) | 16 | select GENERIC_ATOMIC64 if (!CPU_32v6K) |
| @@ -24,6 +25,7 @@ config ARM | |||
| 24 | select HAVE_KERNEL_LZMA | 25 | select HAVE_KERNEL_LZMA |
| 25 | select HAVE_PERF_EVENTS | 26 | select HAVE_PERF_EVENTS |
| 26 | select PERF_USE_VMALLOC | 27 | select PERF_USE_VMALLOC |
| 28 | select HAVE_REGS_AND_STACK_ACCESS_API | ||
| 27 | help | 29 | help |
| 28 | The ARM series is a line of low-power-consumption RISC chip designs | 30 | The ARM series is a line of low-power-consumption RISC chip designs |
| 29 | licensed by ARM Ltd and targeted at embedded applications and | 31 | licensed by ARM Ltd and targeted at embedded applications and |
| @@ -439,21 +441,6 @@ config ARCH_IXP4XX | |||
| 439 | help | 441 | help |
| 440 | Support for Intel's IXP4XX (XScale) family of processors. | 442 | Support for Intel's IXP4XX (XScale) family of processors. |
| 441 | 443 | ||
| 442 | config ARCH_L7200 | ||
| 443 | bool "LinkUp-L7200" | ||
| 444 | select CPU_ARM720T | ||
| 445 | select FIQ | ||
| 446 | select ARCH_USES_GETTIMEOFFSET | ||
| 447 | help | ||
| 448 | Say Y here if you intend to run this kernel on a LinkUp Systems | ||
| 449 | L7200 Software Development Board which uses an ARM720T processor. | ||
| 450 | Information on this board can be obtained at: | ||
| 451 | |||
| 452 | <http://www.linkupsys.com/> | ||
| 453 | |||
| 454 | If you have any questions or comments about the Linux kernel port | ||
| 455 | to this board, send e-mail to <sjhill@cotw.com>. | ||
| 456 | |||
| 457 | config ARCH_DOVE | 444 | config ARCH_DOVE |
| 458 | bool "Marvell Dove" | 445 | bool "Marvell Dove" |
| 459 | select PCI | 446 | select PCI |
| @@ -719,7 +706,6 @@ config ARCH_SHARK | |||
| 719 | config ARCH_LH7A40X | 706 | config ARCH_LH7A40X |
| 720 | bool "Sharp LH7A40X" | 707 | bool "Sharp LH7A40X" |
| 721 | select CPU_ARM922T | 708 | select CPU_ARM922T |
| 722 | select ARCH_DISCONTIGMEM_ENABLE if !LH7A40X_CONTIGMEM | ||
| 723 | select ARCH_SPARSEMEM_ENABLE if !LH7A40X_CONTIGMEM | 709 | select ARCH_SPARSEMEM_ENABLE if !LH7A40X_CONTIGMEM |
| 724 | select ARCH_USES_GETTIMEOFFSET | 710 | select ARCH_USES_GETTIMEOFFSET |
| 725 | help | 711 | help |
| @@ -1031,11 +1017,6 @@ endmenu | |||
| 1031 | 1017 | ||
| 1032 | source "arch/arm/common/Kconfig" | 1018 | source "arch/arm/common/Kconfig" |
| 1033 | 1019 | ||
| 1034 | config FORCE_MAX_ZONEORDER | ||
| 1035 | int | ||
| 1036 | depends on SA1111 | ||
| 1037 | default "9" | ||
| 1038 | |||
| 1039 | menu "Bus support" | 1020 | menu "Bus support" |
| 1040 | 1021 | ||
| 1041 | config ARM_AMBA | 1022 | config ARM_AMBA |
| @@ -1172,9 +1153,10 @@ config HOTPLUG_CPU | |||
| 1172 | config LOCAL_TIMERS | 1153 | config LOCAL_TIMERS |
| 1173 | bool "Use local timer interrupts" | 1154 | bool "Use local timer interrupts" |
| 1174 | depends on SMP && (REALVIEW_EB_ARM11MP || MACH_REALVIEW_PB11MP || \ | 1155 | depends on SMP && (REALVIEW_EB_ARM11MP || MACH_REALVIEW_PB11MP || \ |
| 1175 | REALVIEW_EB_A9MP || MACH_REALVIEW_PBX || ARCH_OMAP4 || ARCH_U8500) | 1156 | REALVIEW_EB_A9MP || MACH_REALVIEW_PBX || ARCH_OMAP4 || \ |
| 1157 | ARCH_U8500 || ARCH_VEXPRESS_CA9X4) | ||
| 1176 | default y | 1158 | default y |
| 1177 | select HAVE_ARM_TWD if (ARCH_REALVIEW || ARCH_OMAP4 || ARCH_U8500) | 1159 | select HAVE_ARM_TWD if (ARCH_REALVIEW || ARCH_VEXPRESS || ARCH_OMAP4 || ARCH_U8500) |
| 1178 | help | 1160 | help |
| 1179 | Enable support for local timers on SMP platforms, rather then the | 1161 | Enable support for local timers on SMP platforms, rather then the |
| 1180 | legacy IPI broadcast method. Local timers allows the system | 1162 | legacy IPI broadcast method. Local timers allows the system |
| @@ -1185,10 +1167,10 @@ source kernel/Kconfig.preempt | |||
| 1185 | 1167 | ||
| 1186 | config HZ | 1168 | config HZ |
| 1187 | int | 1169 | int |
| 1188 | default 128 if ARCH_L7200 | ||
| 1189 | default 200 if ARCH_EBSA110 || ARCH_S3C2410 || ARCH_S5P6440 || ARCH_S5P6442 || ARCH_S5PV210 | 1170 | default 200 if ARCH_EBSA110 || ARCH_S3C2410 || ARCH_S5P6440 || ARCH_S5P6442 || ARCH_S5PV210 |
| 1190 | default OMAP_32K_TIMER_HZ if ARCH_OMAP && OMAP_32K_TIMER | 1171 | default OMAP_32K_TIMER_HZ if ARCH_OMAP && OMAP_32K_TIMER |
| 1191 | default AT91_TIMER_HZ if ARCH_AT91 | 1172 | default AT91_TIMER_HZ if ARCH_AT91 |
| 1173 | default SHMOBILE_TIMER_HZ if ARCH_SHMOBILE | ||
| 1192 | default 100 | 1174 | default 100 |
| 1193 | 1175 | ||
| 1194 | config THUMB2_KERNEL | 1176 | config THUMB2_KERNEL |
| @@ -1241,10 +1223,6 @@ config OABI_COMPAT | |||
| 1241 | config ARCH_HAS_HOLES_MEMORYMODEL | 1223 | config ARCH_HAS_HOLES_MEMORYMODEL |
| 1242 | bool | 1224 | bool |
| 1243 | 1225 | ||
| 1244 | # Discontigmem is deprecated | ||
| 1245 | config ARCH_DISCONTIGMEM_ENABLE | ||
| 1246 | bool | ||
| 1247 | |||
| 1248 | config ARCH_SPARSEMEM_ENABLE | 1226 | config ARCH_SPARSEMEM_ENABLE |
| 1249 | bool | 1227 | bool |
| 1250 | 1228 | ||
| @@ -1252,13 +1230,7 @@ config ARCH_SPARSEMEM_DEFAULT | |||
| 1252 | def_bool ARCH_SPARSEMEM_ENABLE | 1230 | def_bool ARCH_SPARSEMEM_ENABLE |
| 1253 | 1231 | ||
| 1254 | config ARCH_SELECT_MEMORY_MODEL | 1232 | config ARCH_SELECT_MEMORY_MODEL |
| 1255 | def_bool ARCH_DISCONTIGMEM_ENABLE && ARCH_SPARSEMEM_ENABLE | 1233 | def_bool ARCH_SPARSEMEM_ENABLE |
| 1256 | |||
| 1257 | config NODES_SHIFT | ||
| 1258 | int | ||
| 1259 | default "4" if ARCH_LH7A40X | ||
| 1260 | default "2" | ||
| 1261 | depends on NEED_MULTIPLE_NODES | ||
| 1262 | 1234 | ||
| 1263 | config HIGHMEM | 1235 | config HIGHMEM |
| 1264 | bool "High Memory Support (EXPERIMENTAL)" | 1236 | bool "High Memory Support (EXPERIMENTAL)" |
| @@ -1290,8 +1262,36 @@ config HW_PERF_EVENTS | |||
| 1290 | Enable hardware performance counter support for perf events. If | 1262 | Enable hardware performance counter support for perf events. If |
| 1291 | disabled, perf events will use software events only. | 1263 | disabled, perf events will use software events only. |
| 1292 | 1264 | ||
| 1265 | config SPARSE_IRQ | ||
| 1266 | bool "Support sparse irq numbering" | ||
| 1267 | depends on EXPERIMENTAL | ||
| 1268 | help | ||
| 1269 | This enables support for sparse irqs. This is useful in general | ||
| 1270 | as most CPUs have a fairly sparse array of IRQ vectors, which | ||
| 1271 | the irq_desc then maps directly on to. Systems with a high | ||
| 1272 | number of off-chip IRQs will want to treat this as | ||
| 1273 | experimental until they have been independently verified. | ||
| 1274 | |||
| 1275 | If you don't know what to do here, say N. | ||
| 1276 | |||
| 1293 | source "mm/Kconfig" | 1277 | source "mm/Kconfig" |
| 1294 | 1278 | ||
| 1279 | config FORCE_MAX_ZONEORDER | ||
| 1280 | int "Maximum zone order" if ARCH_SHMOBILE | ||
| 1281 | range 11 64 if ARCH_SHMOBILE | ||
| 1282 | default "9" if SA1111 | ||
| 1283 | default "11" | ||
| 1284 | help | ||
| 1285 | The kernel memory allocator divides physically contiguous memory | ||
| 1286 | blocks into "zones", where each zone is a power of two number of | ||
| 1287 | pages. This option selects the largest power of two that the kernel | ||
| 1288 | keeps in the memory allocator. If you need to allocate very large | ||
| 1289 | blocks of physically contiguous memory, then you may need to | ||
| 1290 | increase this value. | ||
| 1291 | |||
| 1292 | This config option is actually maximum order plus one. For example, | ||
| 1293 | a value of 11 means that the largest free memory block is 2^10 pages. | ||
| 1294 | |||
| 1295 | config LEDS | 1295 | config LEDS |
| 1296 | bool "Timer and CPU usage LEDs" | 1296 | bool "Timer and CPU usage LEDs" |
| 1297 | depends on ARCH_CDB89712 || ARCH_EBSA110 || \ | 1297 | depends on ARCH_CDB89712 || ARCH_EBSA110 || \ |
diff --git a/arch/arm/Makefile b/arch/arm/Makefile index 64ba313724d2..bea37a2512e7 100644 --- a/arch/arm/Makefile +++ b/arch/arm/Makefile | |||
| @@ -139,7 +139,6 @@ machine-$(CONFIG_ARCH_IXP23XX) := ixp23xx | |||
| 139 | machine-$(CONFIG_ARCH_IXP4XX) := ixp4xx | 139 | machine-$(CONFIG_ARCH_IXP4XX) := ixp4xx |
| 140 | machine-$(CONFIG_ARCH_KIRKWOOD) := kirkwood | 140 | machine-$(CONFIG_ARCH_KIRKWOOD) := kirkwood |
| 141 | machine-$(CONFIG_ARCH_KS8695) := ks8695 | 141 | machine-$(CONFIG_ARCH_KS8695) := ks8695 |
| 142 | machine-$(CONFIG_ARCH_L7200) := l7200 | ||
| 143 | machine-$(CONFIG_ARCH_LH7A40X) := lh7a40x | 142 | machine-$(CONFIG_ARCH_LH7A40X) := lh7a40x |
| 144 | machine-$(CONFIG_ARCH_LOKI) := loki | 143 | machine-$(CONFIG_ARCH_LOKI) := loki |
| 145 | machine-$(CONFIG_ARCH_MMP) := mmp | 144 | machine-$(CONFIG_ARCH_MMP) := mmp |
diff --git a/arch/arm/boot/compressed/Makefile b/arch/arm/boot/compressed/Makefile index 53faa9063a03..7a29301d516b 100644 --- a/arch/arm/boot/compressed/Makefile +++ b/arch/arm/boot/compressed/Makefile | |||
| @@ -19,10 +19,6 @@ ifeq ($(CONFIG_ARCH_SHARK),y) | |||
| 19 | OBJS += head-shark.o ofw-shark.o | 19 | OBJS += head-shark.o ofw-shark.o |
| 20 | endif | 20 | endif |
| 21 | 21 | ||
| 22 | ifeq ($(CONFIG_ARCH_L7200),y) | ||
| 23 | OBJS += head-l7200.o | ||
| 24 | endif | ||
| 25 | |||
| 26 | ifeq ($(CONFIG_ARCH_P720T),y) | 22 | ifeq ($(CONFIG_ARCH_P720T),y) |
| 27 | # Borrow this code from SA1100 | 23 | # Borrow this code from SA1100 |
| 28 | OBJS += head-sa1100.o | 24 | OBJS += head-sa1100.o |
diff --git a/arch/arm/boot/compressed/head-l7200.S b/arch/arm/boot/compressed/head-l7200.S deleted file mode 100644 index d0e3b20856cd..000000000000 --- a/arch/arm/boot/compressed/head-l7200.S +++ /dev/null | |||
| @@ -1,29 +0,0 @@ | |||
| 1 | /* | ||
| 2 | * linux/arch/arm/boot/compressed/head-l7200.S | ||
| 3 | * | ||
| 4 | * Copyright (C) 2000 Steve Hill <sjhill@cotw.com> | ||
| 5 | * | ||
| 6 | * Some code borrowed from Nicolas Pitre's 'head-sa1100.S' file. This | ||
| 7 | * is merged with head.S by the linker. | ||
| 8 | */ | ||
| 9 | |||
| 10 | #include <asm/mach-types.h> | ||
| 11 | |||
| 12 | #ifndef CONFIG_ARCH_L7200 | ||
| 13 | #error What am I doing here... | ||
| 14 | #endif | ||
| 15 | |||
| 16 | .section ".start", "ax" | ||
| 17 | |||
| 18 | __L7200_start: | ||
| 19 | mov r0, #0x00100000 @ FLASH address of initrd | ||
| 20 | mov r2, #0xf1000000 @ RAM address of initrd | ||
| 21 | add r3, r2, #0x00700000 @ Size of initrd | ||
| 22 | 1: | ||
| 23 | ldmia r0!, {r4, r5, r6, r7} | ||
| 24 | stmia r2!, {r4, r5, r6, r7} | ||
| 25 | cmp r2, r3 | ||
| 26 | ble 1b | ||
| 27 | |||
| 28 | mov r8, #0 @ Zero it out | ||
| 29 | mov r7, #MACH_TYPE_L7200 @ Set architecture ID | ||
diff --git a/arch/arm/common/gic.c b/arch/arm/common/gic.c index 337741f734ac..7dfa9a85bc0c 100644 --- a/arch/arm/common/gic.c +++ b/arch/arm/common/gic.c | |||
| @@ -108,6 +108,51 @@ static void gic_unmask_irq(unsigned int irq) | |||
| 108 | spin_unlock(&irq_controller_lock); | 108 | spin_unlock(&irq_controller_lock); |
| 109 | } | 109 | } |
| 110 | 110 | ||
| 111 | static int gic_set_type(unsigned int irq, unsigned int type) | ||
| 112 | { | ||
| 113 | void __iomem *base = gic_dist_base(irq); | ||
| 114 | unsigned int gicirq = gic_irq(irq); | ||
| 115 | u32 enablemask = 1 << (gicirq % 32); | ||
| 116 | u32 enableoff = (gicirq / 32) * 4; | ||
| 117 | u32 confmask = 0x2 << ((gicirq % 16) * 2); | ||
| 118 | u32 confoff = (gicirq / 16) * 4; | ||
| 119 | bool enabled = false; | ||
| 120 | u32 val; | ||
| 121 | |||
| 122 | /* Interrupt configuration for SGIs can't be changed */ | ||
| 123 | if (gicirq < 16) | ||
| 124 | return -EINVAL; | ||
| 125 | |||
| 126 | if (type != IRQ_TYPE_LEVEL_HIGH && type != IRQ_TYPE_EDGE_RISING) | ||
| 127 | return -EINVAL; | ||
| 128 | |||
| 129 | spin_lock(&irq_controller_lock); | ||
| 130 | |||
| 131 | val = readl(base + GIC_DIST_CONFIG + confoff); | ||
| 132 | if (type == IRQ_TYPE_LEVEL_HIGH) | ||
| 133 | val &= ~confmask; | ||
| 134 | else if (type == IRQ_TYPE_EDGE_RISING) | ||
| 135 | val |= confmask; | ||
| 136 | |||
| 137 | /* | ||
| 138 | * As recommended by the spec, disable the interrupt before changing | ||
| 139 | * the configuration | ||
| 140 | */ | ||
| 141 | if (readl(base + GIC_DIST_ENABLE_SET + enableoff) & enablemask) { | ||
| 142 | writel(enablemask, base + GIC_DIST_ENABLE_CLEAR + enableoff); | ||
| 143 | enabled = true; | ||
| 144 | } | ||
| 145 | |||
| 146 | writel(val, base + GIC_DIST_CONFIG + confoff); | ||
| 147 | |||
| 148 | if (enabled) | ||
| 149 | writel(enablemask, base + GIC_DIST_ENABLE_SET + enableoff); | ||
| 150 | |||
| 151 | spin_unlock(&irq_controller_lock); | ||
| 152 | |||
| 153 | return 0; | ||
| 154 | } | ||
| 155 | |||
| 111 | #ifdef CONFIG_SMP | 156 | #ifdef CONFIG_SMP |
| 112 | static int gic_set_cpu(unsigned int irq, const struct cpumask *mask_val) | 157 | static int gic_set_cpu(unsigned int irq, const struct cpumask *mask_val) |
| 113 | { | 158 | { |
| @@ -161,6 +206,7 @@ static struct irq_chip gic_chip = { | |||
| 161 | .ack = gic_ack_irq, | 206 | .ack = gic_ack_irq, |
| 162 | .mask = gic_mask_irq, | 207 | .mask = gic_mask_irq, |
| 163 | .unmask = gic_unmask_irq, | 208 | .unmask = gic_unmask_irq, |
| 209 | .set_type = gic_set_type, | ||
| 164 | #ifdef CONFIG_SMP | 210 | #ifdef CONFIG_SMP |
| 165 | .set_affinity = gic_set_cpu, | 211 | .set_affinity = gic_set_cpu, |
| 166 | #endif | 212 | #endif |
diff --git a/arch/arm/common/sa1111.c b/arch/arm/common/sa1111.c index 6f80665f477e..ac2fd440652e 100644 --- a/arch/arm/common/sa1111.c +++ b/arch/arm/common/sa1111.c | |||
| @@ -185,13 +185,10 @@ static struct sa1111_dev_info sa1111_devices[] = { | |||
| 185 | }, | 185 | }, |
| 186 | }; | 186 | }; |
| 187 | 187 | ||
| 188 | void __init sa1111_adjust_zones(int node, unsigned long *size, unsigned long *holes) | 188 | void __init sa1111_adjust_zones(unsigned long *size, unsigned long *holes) |
| 189 | { | 189 | { |
| 190 | unsigned int sz = SZ_1M >> PAGE_SHIFT; | 190 | unsigned int sz = SZ_1M >> PAGE_SHIFT; |
| 191 | 191 | ||
| 192 | if (node != 0) | ||
| 193 | sz = 0; | ||
| 194 | |||
| 195 | size[1] = size[0] - sz; | 192 | size[1] = size[0] - sz; |
| 196 | size[0] = sz; | 193 | size[0] = sz; |
| 197 | } | 194 | } |
diff --git a/arch/arm/configs/lusl7200_defconfig b/arch/arm/configs/lusl7200_defconfig deleted file mode 100644 index 816fc42884c9..000000000000 --- a/arch/arm/configs/lusl7200_defconfig +++ /dev/null | |||
| @@ -1,23 +0,0 @@ | |||
| 1 | CONFIG_EXPERIMENTAL=y | ||
| 2 | CONFIG_SYSVIPC=y | ||
| 3 | CONFIG_BSD_PROCESS_ACCT=y | ||
| 4 | CONFIG_LOG_BUF_SHIFT=14 | ||
| 5 | CONFIG_BLK_DEV_INITRD=y | ||
| 6 | CONFIG_EMBEDDED=y | ||
| 7 | # CONFIG_HOTPLUG is not set | ||
| 8 | CONFIG_MODULES=y | ||
| 9 | CONFIG_ARCH_L7200=y | ||
| 10 | # CONFIG_ARM_THUMB is not set | ||
| 11 | CONFIG_ZBOOT_ROM_TEXT=0x00010000 | ||
| 12 | CONFIG_ZBOOT_ROM_BSS=0xf03e0000 | ||
| 13 | CONFIG_ZBOOT_ROM=y | ||
| 14 | CONFIG_CMDLINE="console=tty0 console=ttyLU1,115200 root=/dev/ram initrd=0xf1000000,0x005dac7b mem=32M" | ||
| 15 | CONFIG_BINFMT_AOUT=y | ||
| 16 | CONFIG_BLK_DEV_RAM=y | ||
| 17 | # CONFIG_INPUT is not set | ||
| 18 | # CONFIG_SERIO_SERPORT is not set | ||
| 19 | # CONFIG_VT is not set | ||
| 20 | CONFIG_SERIAL_NONSTANDARD=y | ||
| 21 | CONFIG_EXT2_FS=y | ||
| 22 | CONFIG_DEBUG_USER=y | ||
| 23 | # CONFIG_CRC32 is not set | ||
diff --git a/arch/arm/include/asm/hwcap.h b/arch/arm/include/asm/hwcap.h index f7bd52b1c365..c1062c317103 100644 --- a/arch/arm/include/asm/hwcap.h +++ b/arch/arm/include/asm/hwcap.h | |||
| @@ -19,6 +19,7 @@ | |||
| 19 | #define HWCAP_NEON 4096 | 19 | #define HWCAP_NEON 4096 |
| 20 | #define HWCAP_VFPv3 8192 | 20 | #define HWCAP_VFPv3 8192 |
| 21 | #define HWCAP_VFPv3D16 16384 | 21 | #define HWCAP_VFPv3D16 16384 |
| 22 | #define HWCAP_TLS 32768 | ||
| 22 | 23 | ||
| 23 | #if defined(__KERNEL__) && !defined(__ASSEMBLY__) | 24 | #if defined(__KERNEL__) && !defined(__ASSEMBLY__) |
| 24 | /* | 25 | /* |
diff --git a/arch/arm/include/asm/irq.h b/arch/arm/include/asm/irq.h index 237282f7c762..2721a5814cb9 100644 --- a/arch/arm/include/asm/irq.h +++ b/arch/arm/include/asm/irq.h | |||
| @@ -7,6 +7,8 @@ | |||
| 7 | #define irq_canonicalize(i) (i) | 7 | #define irq_canonicalize(i) (i) |
| 8 | #endif | 8 | #endif |
| 9 | 9 | ||
| 10 | #define NR_IRQS_LEGACY 16 | ||
| 11 | |||
| 10 | /* | 12 | /* |
| 11 | * Use this value to indicate lack of interrupt | 13 | * Use this value to indicate lack of interrupt |
| 12 | * capability | 14 | * capability |
diff --git a/arch/arm/include/asm/kexec.h b/arch/arm/include/asm/kexec.h index df15a0dc228e..8ec9ef5c3c7b 100644 --- a/arch/arm/include/asm/kexec.h +++ b/arch/arm/include/asm/kexec.h | |||
| @@ -19,10 +19,26 @@ | |||
| 19 | 19 | ||
| 20 | #ifndef __ASSEMBLY__ | 20 | #ifndef __ASSEMBLY__ |
| 21 | 21 | ||
| 22 | struct kimage; | 22 | /** |
| 23 | /* Provide a dummy definition to avoid build failures. */ | 23 | * crash_setup_regs() - save registers for the panic kernel |
| 24 | * @newregs: registers are saved here | ||
| 25 | * @oldregs: registers to be saved (may be %NULL) | ||
| 26 | * | ||
| 27 | * Function copies machine registers from @oldregs to @newregs. If @oldregs is | ||
| 28 | * %NULL then current registers are stored there. | ||
| 29 | */ | ||
| 24 | static inline void crash_setup_regs(struct pt_regs *newregs, | 30 | static inline void crash_setup_regs(struct pt_regs *newregs, |
| 25 | struct pt_regs *oldregs) { } | 31 | struct pt_regs *oldregs) |
| 32 | { | ||
| 33 | if (oldregs) { | ||
| 34 | memcpy(newregs, oldregs, sizeof(*newregs)); | ||
| 35 | } else { | ||
| 36 | __asm__ __volatile__ ("stmia %0, {r0 - r15}" | ||
| 37 | : : "r" (&newregs->ARM_r0)); | ||
| 38 | __asm__ __volatile__ ("mrs %0, cpsr" | ||
| 39 | : "=r" (newregs->ARM_cpsr)); | ||
| 40 | } | ||
| 41 | } | ||
| 26 | 42 | ||
| 27 | #endif /* __ASSEMBLY__ */ | 43 | #endif /* __ASSEMBLY__ */ |
| 28 | 44 | ||
diff --git a/arch/arm/include/asm/mach/arch.h b/arch/arm/include/asm/mach/arch.h index c59842dc7cb8..8a0dd18ba642 100644 --- a/arch/arm/include/asm/mach/arch.h +++ b/arch/arm/include/asm/mach/arch.h | |||
| @@ -20,6 +20,7 @@ struct machine_desc { | |||
| 20 | * by assembler code in head.S, head-common.S | 20 | * by assembler code in head.S, head-common.S |
| 21 | */ | 21 | */ |
| 22 | unsigned int nr; /* architecture number */ | 22 | unsigned int nr; /* architecture number */ |
| 23 | unsigned int nr_irqs; /* number of IRQs */ | ||
| 23 | unsigned int phys_io; /* start of physical io */ | 24 | unsigned int phys_io; /* start of physical io */ |
| 24 | unsigned int io_pg_offst; /* byte offset for io | 25 | unsigned int io_pg_offst; /* byte offset for io |
| 25 | * page tabe entry */ | 26 | * page tabe entry */ |
| @@ -37,6 +38,7 @@ struct machine_desc { | |||
| 37 | void (*fixup)(struct machine_desc *, | 38 | void (*fixup)(struct machine_desc *, |
| 38 | struct tag *, char **, | 39 | struct tag *, char **, |
| 39 | struct meminfo *); | 40 | struct meminfo *); |
| 41 | void (*reserve)(void);/* reserve mem blocks */ | ||
| 40 | void (*map_io)(void);/* IO mapping function */ | 42 | void (*map_io)(void);/* IO mapping function */ |
| 41 | void (*init_irq)(void); | 43 | void (*init_irq)(void); |
| 42 | struct sys_timer *timer; /* system tick timer */ | 44 | struct sys_timer *timer; /* system tick timer */ |
diff --git a/arch/arm/include/asm/mach/irq.h b/arch/arm/include/asm/mach/irq.h index 8920b2d6e3b8..ce3eee9fe26c 100644 --- a/arch/arm/include/asm/mach/irq.h +++ b/arch/arm/include/asm/mach/irq.h | |||
| @@ -17,6 +17,7 @@ struct seq_file; | |||
| 17 | /* | 17 | /* |
| 18 | * This is internal. Do not use it. | 18 | * This is internal. Do not use it. |
| 19 | */ | 19 | */ |
| 20 | extern unsigned int arch_nr_irqs; | ||
| 20 | extern void (*init_arch_irq)(void); | 21 | extern void (*init_arch_irq)(void); |
| 21 | extern void init_FIQ(void); | 22 | extern void init_FIQ(void); |
| 22 | extern int show_fiq_list(struct seq_file *, void *); | 23 | extern int show_fiq_list(struct seq_file *, void *); |
diff --git a/arch/arm/include/asm/memblock.h b/arch/arm/include/asm/memblock.h new file mode 100644 index 000000000000..fdbc43b2e6c0 --- /dev/null +++ b/arch/arm/include/asm/memblock.h | |||
| @@ -0,0 +1,16 @@ | |||
| 1 | #ifndef _ASM_ARM_MEMBLOCK_H | ||
| 2 | #define _ASM_ARM_MEMBLOCK_H | ||
| 3 | |||
| 4 | #ifdef CONFIG_MMU | ||
| 5 | extern phys_addr_t lowmem_end_addr; | ||
| 6 | #define MEMBLOCK_REAL_LIMIT lowmem_end_addr | ||
| 7 | #else | ||
| 8 | #define MEMBLOCK_REAL_LIMIT 0 | ||
| 9 | #endif | ||
| 10 | |||
| 11 | struct meminfo; | ||
| 12 | struct machine_desc; | ||
| 13 | |||
| 14 | extern void arm_memblock_init(struct meminfo *, struct machine_desc *); | ||
| 15 | |||
| 16 | #endif | ||
diff --git a/arch/arm/include/asm/memory.h b/arch/arm/include/asm/memory.h index 4312ee5e3d0b..82df0ae71bb4 100644 --- a/arch/arm/include/asm/memory.h +++ b/arch/arm/include/asm/memory.h | |||
| @@ -158,7 +158,7 @@ | |||
| 158 | #endif | 158 | #endif |
| 159 | 159 | ||
| 160 | #ifndef arch_adjust_zones | 160 | #ifndef arch_adjust_zones |
| 161 | #define arch_adjust_zones(node,size,holes) do { } while (0) | 161 | #define arch_adjust_zones(size,holes) do { } while (0) |
| 162 | #elif !defined(CONFIG_ZONE_DMA) | 162 | #elif !defined(CONFIG_ZONE_DMA) |
| 163 | #error "custom arch_adjust_zones() requires CONFIG_ZONE_DMA" | 163 | #error "custom arch_adjust_zones() requires CONFIG_ZONE_DMA" |
| 164 | #endif | 164 | #endif |
| @@ -234,76 +234,11 @@ static inline __deprecated void *bus_to_virt(unsigned long x) | |||
| 234 | * virt_to_page(k) convert a _valid_ virtual address to struct page * | 234 | * virt_to_page(k) convert a _valid_ virtual address to struct page * |
| 235 | * virt_addr_valid(k) indicates whether a virtual address is valid | 235 | * virt_addr_valid(k) indicates whether a virtual address is valid |
| 236 | */ | 236 | */ |
| 237 | #ifndef CONFIG_DISCONTIGMEM | ||
| 238 | |||
| 239 | #define ARCH_PFN_OFFSET PHYS_PFN_OFFSET | 237 | #define ARCH_PFN_OFFSET PHYS_PFN_OFFSET |
| 240 | 238 | ||
| 241 | #define virt_to_page(kaddr) pfn_to_page(__pa(kaddr) >> PAGE_SHIFT) | 239 | #define virt_to_page(kaddr) pfn_to_page(__pa(kaddr) >> PAGE_SHIFT) |
| 242 | #define virt_addr_valid(kaddr) ((unsigned long)(kaddr) >= PAGE_OFFSET && (unsigned long)(kaddr) < (unsigned long)high_memory) | 240 | #define virt_addr_valid(kaddr) ((unsigned long)(kaddr) >= PAGE_OFFSET && (unsigned long)(kaddr) < (unsigned long)high_memory) |
| 243 | 241 | ||
| 244 | #define PHYS_TO_NID(addr) (0) | ||
| 245 | |||
| 246 | #else /* CONFIG_DISCONTIGMEM */ | ||
| 247 | |||
| 248 | /* | ||
| 249 | * This is more complex. We have a set of mem_map arrays spread | ||
| 250 | * around in memory. | ||
| 251 | */ | ||
| 252 | #include <linux/numa.h> | ||
| 253 | |||
| 254 | #define arch_pfn_to_nid(pfn) PFN_TO_NID(pfn) | ||
| 255 | #define arch_local_page_offset(pfn, nid) LOCAL_MAP_NR((pfn) << PAGE_SHIFT) | ||
| 256 | |||
| 257 | #define virt_to_page(kaddr) \ | ||
| 258 | (ADDR_TO_MAPBASE(kaddr) + LOCAL_MAP_NR(kaddr)) | ||
| 259 | |||
| 260 | #define virt_addr_valid(kaddr) (KVADDR_TO_NID(kaddr) < MAX_NUMNODES) | ||
| 261 | |||
| 262 | /* | ||
| 263 | * Common discontigmem stuff. | ||
| 264 | * PHYS_TO_NID is used by the ARM kernel/setup.c | ||
| 265 | */ | ||
| 266 | #define PHYS_TO_NID(addr) PFN_TO_NID((addr) >> PAGE_SHIFT) | ||
| 267 | |||
| 268 | /* | ||
| 269 | * Given a kaddr, ADDR_TO_MAPBASE finds the owning node of the memory | ||
| 270 | * and returns the mem_map of that node. | ||
| 271 | */ | ||
| 272 | #define ADDR_TO_MAPBASE(kaddr) NODE_MEM_MAP(KVADDR_TO_NID(kaddr)) | ||
| 273 | |||
| 274 | /* | ||
| 275 | * Given a page frame number, find the owning node of the memory | ||
| 276 | * and returns the mem_map of that node. | ||
| 277 | */ | ||
| 278 | #define PFN_TO_MAPBASE(pfn) NODE_MEM_MAP(PFN_TO_NID(pfn)) | ||
| 279 | |||
| 280 | #ifdef NODE_MEM_SIZE_BITS | ||
| 281 | #define NODE_MEM_SIZE_MASK ((1 << NODE_MEM_SIZE_BITS) - 1) | ||
| 282 | |||
| 283 | /* | ||
| 284 | * Given a kernel address, find the home node of the underlying memory. | ||
| 285 | */ | ||
| 286 | #define KVADDR_TO_NID(addr) \ | ||
| 287 | (((unsigned long)(addr) - PAGE_OFFSET) >> NODE_MEM_SIZE_BITS) | ||
| 288 | |||
| 289 | /* | ||
| 290 | * Given a page frame number, convert it to a node id. | ||
| 291 | */ | ||
| 292 | #define PFN_TO_NID(pfn) \ | ||
| 293 | (((pfn) - PHYS_PFN_OFFSET) >> (NODE_MEM_SIZE_BITS - PAGE_SHIFT)) | ||
| 294 | |||
| 295 | /* | ||
| 296 | * Given a kaddr, LOCAL_MEM_MAP finds the owning node of the memory | ||
| 297 | * and returns the index corresponding to the appropriate page in the | ||
| 298 | * node's mem_map. | ||
| 299 | */ | ||
| 300 | #define LOCAL_MAP_NR(addr) \ | ||
| 301 | (((unsigned long)(addr) & NODE_MEM_SIZE_MASK) >> PAGE_SHIFT) | ||
| 302 | |||
| 303 | #endif /* NODE_MEM_SIZE_BITS */ | ||
| 304 | |||
| 305 | #endif /* !CONFIG_DISCONTIGMEM */ | ||
| 306 | |||
| 307 | /* | 242 | /* |
| 308 | * Optional coherency support. Currently used only by selected | 243 | * Optional coherency support. Currently used only by selected |
| 309 | * Intel XSC3-based systems. | 244 | * Intel XSC3-based systems. |
diff --git a/arch/arm/include/asm/mmzone.h b/arch/arm/include/asm/mmzone.h deleted file mode 100644 index ae63a4fd28c8..000000000000 --- a/arch/arm/include/asm/mmzone.h +++ /dev/null | |||
| @@ -1,30 +0,0 @@ | |||
| 1 | /* | ||
| 2 | * arch/arm/include/asm/mmzone.h | ||
| 3 | * | ||
| 4 | * 1999-12-29 Nicolas Pitre Created | ||
| 5 | * | ||
| 6 | * This program is free software; you can redistribute it and/or modify | ||
| 7 | * it under the terms of the GNU General Public License version 2 as | ||
| 8 | * published by the Free Software Foundation. | ||
| 9 | */ | ||
| 10 | #ifndef __ASM_MMZONE_H | ||
| 11 | #define __ASM_MMZONE_H | ||
| 12 | |||
| 13 | /* | ||
| 14 | * Currently defined in arch/arm/mm/discontig.c | ||
| 15 | */ | ||
| 16 | extern pg_data_t discontig_node_data[]; | ||
| 17 | |||
| 18 | /* | ||
| 19 | * Return a pointer to the node data for node n. | ||
| 20 | */ | ||
| 21 | #define NODE_DATA(nid) (&discontig_node_data[nid]) | ||
| 22 | |||
| 23 | /* | ||
| 24 | * NODE_MEM_MAP gives the kaddr for the mem_map of the node. | ||
| 25 | */ | ||
| 26 | #define NODE_MEM_MAP(nid) (NODE_DATA(nid)->node_mem_map) | ||
| 27 | |||
| 28 | #include <mach/memory.h> | ||
| 29 | |||
| 30 | #endif | ||
diff --git a/arch/arm/include/asm/ptrace.h b/arch/arm/include/asm/ptrace.h index 9dcb11e59026..c974be8913a7 100644 --- a/arch/arm/include/asm/ptrace.h +++ b/arch/arm/include/asm/ptrace.h | |||
| @@ -184,6 +184,42 @@ extern unsigned long profile_pc(struct pt_regs *regs); | |||
| 184 | #define predicate(x) ((x) & 0xf0000000) | 184 | #define predicate(x) ((x) & 0xf0000000) |
| 185 | #define PREDICATE_ALWAYS 0xe0000000 | 185 | #define PREDICATE_ALWAYS 0xe0000000 |
| 186 | 186 | ||
| 187 | /* | ||
| 188 | * kprobe-based event tracer support | ||
| 189 | */ | ||
| 190 | #include <linux/stddef.h> | ||
| 191 | #include <linux/types.h> | ||
| 192 | #define MAX_REG_OFFSET (offsetof(struct pt_regs, ARM_ORIG_r0)) | ||
| 193 | |||
| 194 | extern int regs_query_register_offset(const char *name); | ||
| 195 | extern const char *regs_query_register_name(unsigned int offset); | ||
| 196 | extern bool regs_within_kernel_stack(struct pt_regs *regs, unsigned long addr); | ||
| 197 | extern unsigned long regs_get_kernel_stack_nth(struct pt_regs *regs, | ||
| 198 | unsigned int n); | ||
| 199 | |||
| 200 | /** | ||
| 201 | * regs_get_register() - get register value from its offset | ||
| 202 | * @regs: pt_regs from which register value is gotten | ||
| 203 | * @offset: offset number of the register. | ||
| 204 | * | ||
| 205 | * regs_get_register returns the value of a register whose offset from @regs. | ||
| 206 | * The @offset is the offset of the register in struct pt_regs. | ||
| 207 | * If @offset is bigger than MAX_REG_OFFSET, this returns 0. | ||
| 208 | */ | ||
| 209 | static inline unsigned long regs_get_register(struct pt_regs *regs, | ||
| 210 | unsigned int offset) | ||
| 211 | { | ||
| 212 | if (unlikely(offset > MAX_REG_OFFSET)) | ||
| 213 | return 0; | ||
| 214 | return *(unsigned long *)((unsigned long)regs + offset); | ||
| 215 | } | ||
| 216 | |||
| 217 | /* Valid only for Kernel mode traps. */ | ||
| 218 | static inline unsigned long kernel_stack_pointer(struct pt_regs *regs) | ||
| 219 | { | ||
| 220 | return regs->ARM_sp; | ||
| 221 | } | ||
| 222 | |||
| 187 | #endif /* __KERNEL__ */ | 223 | #endif /* __KERNEL__ */ |
| 188 | 224 | ||
| 189 | #endif /* __ASSEMBLY__ */ | 225 | #endif /* __ASSEMBLY__ */ |
diff --git a/arch/arm/include/asm/setup.h b/arch/arm/include/asm/setup.h index f392fb4437af..f1e5a9bca249 100644 --- a/arch/arm/include/asm/setup.h +++ b/arch/arm/include/asm/setup.h | |||
| @@ -201,8 +201,7 @@ static struct tagtable __tagtable_##fn __tag = { tag, fn } | |||
| 201 | struct membank { | 201 | struct membank { |
| 202 | unsigned long start; | 202 | unsigned long start; |
| 203 | unsigned long size; | 203 | unsigned long size; |
| 204 | unsigned short node; | 204 | unsigned int highmem; |
| 205 | unsigned short highmem; | ||
| 206 | }; | 205 | }; |
| 207 | 206 | ||
| 208 | struct meminfo { | 207 | struct meminfo { |
| @@ -212,9 +211,8 @@ struct meminfo { | |||
| 212 | 211 | ||
| 213 | extern struct meminfo meminfo; | 212 | extern struct meminfo meminfo; |
| 214 | 213 | ||
| 215 | #define for_each_nodebank(iter,mi,no) \ | 214 | #define for_each_bank(iter,mi) \ |
| 216 | for (iter = 0; iter < (mi)->nr_banks; iter++) \ | 215 | for (iter = 0; iter < (mi)->nr_banks; iter++) |
| 217 | if ((mi)->bank[iter].node == no) | ||
| 218 | 216 | ||
| 219 | #define bank_pfn_start(bank) __phys_to_pfn((bank)->start) | 217 | #define bank_pfn_start(bank) __phys_to_pfn((bank)->start) |
| 220 | #define bank_pfn_end(bank) __phys_to_pfn((bank)->start + (bank)->size) | 218 | #define bank_pfn_end(bank) __phys_to_pfn((bank)->start + (bank)->size) |
diff --git a/arch/arm/include/asm/tls.h b/arch/arm/include/asm/tls.h new file mode 100644 index 000000000000..e71d6ff8d104 --- /dev/null +++ b/arch/arm/include/asm/tls.h | |||
| @@ -0,0 +1,46 @@ | |||
| 1 | #ifndef __ASMARM_TLS_H | ||
| 2 | #define __ASMARM_TLS_H | ||
| 3 | |||
| 4 | #ifdef __ASSEMBLY__ | ||
| 5 | .macro set_tls_none, tp, tmp1, tmp2 | ||
| 6 | .endm | ||
| 7 | |||
| 8 | .macro set_tls_v6k, tp, tmp1, tmp2 | ||
| 9 | mcr p15, 0, \tp, c13, c0, 3 @ set TLS register | ||
| 10 | .endm | ||
| 11 | |||
| 12 | .macro set_tls_v6, tp, tmp1, tmp2 | ||
| 13 | ldr \tmp1, =elf_hwcap | ||
| 14 | ldr \tmp1, [\tmp1, #0] | ||
| 15 | mov \tmp2, #0xffff0fff | ||
| 16 | tst \tmp1, #HWCAP_TLS @ hardware TLS available? | ||
| 17 | mcrne p15, 0, \tp, c13, c0, 3 @ yes, set TLS register | ||
| 18 | streq \tp, [\tmp2, #-15] @ set TLS value at 0xffff0ff0 | ||
| 19 | .endm | ||
| 20 | |||
| 21 | .macro set_tls_software, tp, tmp1, tmp2 | ||
| 22 | mov \tmp1, #0xffff0fff | ||
| 23 | str \tp, [\tmp1, #-15] @ set TLS value at 0xffff0ff0 | ||
| 24 | .endm | ||
| 25 | #endif | ||
| 26 | |||
| 27 | #ifdef CONFIG_TLS_REG_EMUL | ||
| 28 | #define tls_emu 1 | ||
| 29 | #define has_tls_reg 1 | ||
| 30 | #define set_tls set_tls_none | ||
| 31 | #elif __LINUX_ARM_ARCH__ >= 7 || \ | ||
| 32 | (__LINUX_ARM_ARCH__ == 6 && defined(CONFIG_CPU_32v6K)) | ||
| 33 | #define tls_emu 0 | ||
| 34 | #define has_tls_reg 1 | ||
| 35 | #define set_tls set_tls_v6k | ||
| 36 | #elif __LINUX_ARM_ARCH__ == 6 | ||
| 37 | #define tls_emu 0 | ||
| 38 | #define has_tls_reg (elf_hwcap & HWCAP_TLS) | ||
| 39 | #define set_tls set_tls_v6 | ||
| 40 | #else | ||
| 41 | #define tls_emu 0 | ||
| 42 | #define has_tls_reg 0 | ||
| 43 | #define set_tls set_tls_software | ||
| 44 | #endif | ||
| 45 | |||
| 46 | #endif /* __ASMARM_TLS_H */ | ||
diff --git a/arch/arm/include/asm/vfpmacros.h b/arch/arm/include/asm/vfpmacros.h index 422f3cc204a2..3d5fc41ae8d3 100644 --- a/arch/arm/include/asm/vfpmacros.h +++ b/arch/arm/include/asm/vfpmacros.h | |||
| @@ -3,6 +3,8 @@ | |||
| 3 | * | 3 | * |
| 4 | * Assembler-only file containing VFP macros and register definitions. | 4 | * Assembler-only file containing VFP macros and register definitions. |
| 5 | */ | 5 | */ |
| 6 | #include <asm/hwcap.h> | ||
| 7 | |||
| 6 | #include "vfp.h" | 8 | #include "vfp.h" |
| 7 | 9 | ||
| 8 | @ Macros to allow building with old toolkits (with no VFP support) | 10 | @ Macros to allow building with old toolkits (with no VFP support) |
| @@ -22,12 +24,20 @@ | |||
| 22 | LDC p11, cr0, [\base],#32*4 @ FLDMIAD \base!, {d0-d15} | 24 | LDC p11, cr0, [\base],#32*4 @ FLDMIAD \base!, {d0-d15} |
| 23 | #endif | 25 | #endif |
| 24 | #ifdef CONFIG_VFPv3 | 26 | #ifdef CONFIG_VFPv3 |
| 27 | #if __LINUX_ARM_ARCH__ <= 6 | ||
| 28 | ldr \tmp, =elf_hwcap @ may not have MVFR regs | ||
| 29 | ldr \tmp, [\tmp, #0] | ||
| 30 | tst \tmp, #HWCAP_VFPv3D16 | ||
| 31 | ldceq p11, cr0, [\base],#32*4 @ FLDMIAD \base!, {d16-d31} | ||
| 32 | addne \base, \base, #32*4 @ step over unused register space | ||
| 33 | #else | ||
| 25 | VFPFMRX \tmp, MVFR0 @ Media and VFP Feature Register 0 | 34 | VFPFMRX \tmp, MVFR0 @ Media and VFP Feature Register 0 |
| 26 | and \tmp, \tmp, #MVFR0_A_SIMD_MASK @ A_SIMD field | 35 | and \tmp, \tmp, #MVFR0_A_SIMD_MASK @ A_SIMD field |
| 27 | cmp \tmp, #2 @ 32 x 64bit registers? | 36 | cmp \tmp, #2 @ 32 x 64bit registers? |
| 28 | ldceql p11, cr0, [\base],#32*4 @ FLDMIAD \base!, {d16-d31} | 37 | ldceql p11, cr0, [\base],#32*4 @ FLDMIAD \base!, {d16-d31} |
| 29 | addne \base, \base, #32*4 @ step over unused register space | 38 | addne \base, \base, #32*4 @ step over unused register space |
| 30 | #endif | 39 | #endif |
| 40 | #endif | ||
| 31 | .endm | 41 | .endm |
| 32 | 42 | ||
| 33 | @ write all the working registers out of the VFP | 43 | @ write all the working registers out of the VFP |
| @@ -38,10 +48,18 @@ | |||
| 38 | STC p11, cr0, [\base],#32*4 @ FSTMIAD \base!, {d0-d15} | 48 | STC p11, cr0, [\base],#32*4 @ FSTMIAD \base!, {d0-d15} |
| 39 | #endif | 49 | #endif |
| 40 | #ifdef CONFIG_VFPv3 | 50 | #ifdef CONFIG_VFPv3 |
| 51 | #if __LINUX_ARM_ARCH__ <= 6 | ||
| 52 | ldr \tmp, =elf_hwcap @ may not have MVFR regs | ||
| 53 | ldr \tmp, [\tmp, #0] | ||
| 54 | tst \tmp, #HWCAP_VFPv3D16 | ||
| 55 | stceq p11, cr0, [\base],#32*4 @ FSTMIAD \base!, {d16-d31} | ||
| 56 | addne \base, \base, #32*4 @ step over unused register space | ||
| 57 | #else | ||
| 41 | VFPFMRX \tmp, MVFR0 @ Media and VFP Feature Register 0 | 58 | VFPFMRX \tmp, MVFR0 @ Media and VFP Feature Register 0 |
| 42 | and \tmp, \tmp, #MVFR0_A_SIMD_MASK @ A_SIMD field | 59 | and \tmp, \tmp, #MVFR0_A_SIMD_MASK @ A_SIMD field |
| 43 | cmp \tmp, #2 @ 32 x 64bit registers? | 60 | cmp \tmp, #2 @ 32 x 64bit registers? |
| 44 | stceql p11, cr0, [\base],#32*4 @ FSTMIAD \base!, {d16-d31} | 61 | stceql p11, cr0, [\base],#32*4 @ FSTMIAD \base!, {d16-d31} |
| 45 | addne \base, \base, #32*4 @ step over unused register space | 62 | addne \base, \base, #32*4 @ step over unused register space |
| 46 | #endif | 63 | #endif |
| 64 | #endif | ||
| 47 | .endm | 65 | .endm |
diff --git a/arch/arm/kernel/Makefile b/arch/arm/kernel/Makefile index 26d302c28e13..ea023c6aa31e 100644 --- a/arch/arm/kernel/Makefile +++ b/arch/arm/kernel/Makefile | |||
| @@ -39,6 +39,7 @@ obj-$(CONFIG_ARM_THUMBEE) += thumbee.o | |||
| 39 | obj-$(CONFIG_KGDB) += kgdb.o | 39 | obj-$(CONFIG_KGDB) += kgdb.o |
| 40 | obj-$(CONFIG_ARM_UNWIND) += unwind.o | 40 | obj-$(CONFIG_ARM_UNWIND) += unwind.o |
| 41 | obj-$(CONFIG_HAVE_TCM) += tcm.o | 41 | obj-$(CONFIG_HAVE_TCM) += tcm.o |
| 42 | obj-$(CONFIG_CRASH_DUMP) += crash_dump.o | ||
| 42 | 43 | ||
| 43 | obj-$(CONFIG_CRUNCH) += crunch.o crunch-bits.o | 44 | obj-$(CONFIG_CRUNCH) += crunch.o crunch-bits.o |
| 44 | AFLAGS_crunch-bits.o := -Wa,-mcpu=ep9312 | 45 | AFLAGS_crunch-bits.o := -Wa,-mcpu=ep9312 |
diff --git a/arch/arm/kernel/crash_dump.c b/arch/arm/kernel/crash_dump.c new file mode 100644 index 000000000000..cd3b853a8a6d --- /dev/null +++ b/arch/arm/kernel/crash_dump.c | |||
| @@ -0,0 +1,60 @@ | |||
| 1 | /* | ||
| 2 | * arch/arm/kernel/crash_dump.c | ||
| 3 | * | ||
| 4 | * Copyright (C) 2010 Nokia Corporation. | ||
| 5 | * Author: Mika Westerberg | ||
| 6 | * | ||
| 7 | * This code is taken from arch/x86/kernel/crash_dump_64.c | ||
| 8 | * Created by: Hariprasad Nellitheertha (hari@in.ibm.com) | ||
| 9 | * Copyright (C) IBM Corporation, 2004. All rights reserved | ||
| 10 | * | ||
| 11 | * This program is free software; you can redistribute it and/or modify | ||
| 12 | * it under the terms of the GNU General Public License version 2 as | ||
| 13 | * published by the Free Software Foundation. | ||
| 14 | */ | ||
| 15 | |||
| 16 | #include <linux/errno.h> | ||
| 17 | #include <linux/crash_dump.h> | ||
| 18 | #include <linux/uaccess.h> | ||
| 19 | #include <linux/io.h> | ||
| 20 | |||
| 21 | /* stores the physical address of elf header of crash image */ | ||
| 22 | unsigned long long elfcorehdr_addr = ELFCORE_ADDR_MAX; | ||
| 23 | |||
| 24 | /** | ||
| 25 | * copy_oldmem_page() - copy one page from old kernel memory | ||
| 26 | * @pfn: page frame number to be copied | ||
| 27 | * @buf: buffer where the copied page is placed | ||
| 28 | * @csize: number of bytes to copy | ||
| 29 | * @offset: offset in bytes into the page | ||
| 30 | * @userbuf: if set, @buf is int he user address space | ||
| 31 | * | ||
| 32 | * This function copies one page from old kernel memory into buffer pointed by | ||
| 33 | * @buf. If @buf is in userspace, set @userbuf to %1. Returns number of bytes | ||
| 34 | * copied or negative error in case of failure. | ||
| 35 | */ | ||
| 36 | ssize_t copy_oldmem_page(unsigned long pfn, char *buf, | ||
| 37 | size_t csize, unsigned long offset, | ||
| 38 | int userbuf) | ||
| 39 | { | ||
| 40 | void *vaddr; | ||
| 41 | |||
| 42 | if (!csize) | ||
| 43 | return 0; | ||
| 44 | |||
| 45 | vaddr = ioremap(pfn << PAGE_SHIFT, PAGE_SIZE); | ||
| 46 | if (!vaddr) | ||
| 47 | return -ENOMEM; | ||
| 48 | |||
| 49 | if (userbuf) { | ||
| 50 | if (copy_to_user(buf, vaddr + offset, csize)) { | ||
| 51 | iounmap(vaddr); | ||
| 52 | return -EFAULT; | ||
| 53 | } | ||
| 54 | } else { | ||
| 55 | memcpy(buf, vaddr + offset, csize); | ||
| 56 | } | ||
| 57 | |||
| 58 | iounmap(vaddr); | ||
| 59 | return csize; | ||
| 60 | } | ||
diff --git a/arch/arm/kernel/entry-armv.S b/arch/arm/kernel/entry-armv.S index 3fd7861de4d1..e864e482118a 100644 --- a/arch/arm/kernel/entry-armv.S +++ b/arch/arm/kernel/entry-armv.S | |||
| @@ -22,6 +22,7 @@ | |||
| 22 | #include <asm/thread_notify.h> | 22 | #include <asm/thread_notify.h> |
| 23 | #include <asm/unwind.h> | 23 | #include <asm/unwind.h> |
| 24 | #include <asm/unistd.h> | 24 | #include <asm/unistd.h> |
| 25 | #include <asm/tls.h> | ||
| 25 | 26 | ||
| 26 | #include "entry-header.S" | 27 | #include "entry-header.S" |
| 27 | 28 | ||
| @@ -735,12 +736,7 @@ ENTRY(__switch_to) | |||
| 735 | #ifdef CONFIG_MMU | 736 | #ifdef CONFIG_MMU |
| 736 | ldr r6, [r2, #TI_CPU_DOMAIN] | 737 | ldr r6, [r2, #TI_CPU_DOMAIN] |
| 737 | #endif | 738 | #endif |
| 738 | #if defined(CONFIG_HAS_TLS_REG) | 739 | set_tls r3, r4, r5 |
| 739 | mcr p15, 0, r3, c13, c0, 3 @ set TLS register | ||
| 740 | #elif !defined(CONFIG_TLS_REG_EMUL) | ||
| 741 | mov r4, #0xffff0fff | ||
| 742 | str r3, [r4, #-15] @ TLS val at 0xffff0ff0 | ||
| 743 | #endif | ||
| 744 | #ifdef CONFIG_MMU | 740 | #ifdef CONFIG_MMU |
| 745 | mcr p15, 0, r6, c3, c0, 0 @ Set domain register | 741 | mcr p15, 0, r6, c3, c0, 0 @ Set domain register |
| 746 | #endif | 742 | #endif |
| @@ -1005,17 +1001,12 @@ kuser_cmpxchg_fixup: | |||
| 1005 | */ | 1001 | */ |
| 1006 | 1002 | ||
| 1007 | __kuser_get_tls: @ 0xffff0fe0 | 1003 | __kuser_get_tls: @ 0xffff0fe0 |
| 1008 | 1004 | ldr r0, [pc, #(16 - 8)] @ read TLS, set in kuser_get_tls_init | |
| 1009 | #if !defined(CONFIG_HAS_TLS_REG) && !defined(CONFIG_TLS_REG_EMUL) | ||
| 1010 | ldr r0, [pc, #(16 - 8)] @ TLS stored at 0xffff0ff0 | ||
| 1011 | #else | ||
| 1012 | mrc p15, 0, r0, c13, c0, 3 @ read TLS register | ||
| 1013 | #endif | ||
| 1014 | usr_ret lr | 1005 | usr_ret lr |
| 1015 | 1006 | mrc p15, 0, r0, c13, c0, 3 @ 0xffff0fe8 hardware TLS code | |
| 1016 | .rep 5 | 1007 | .rep 4 |
| 1017 | .word 0 @ pad up to __kuser_helper_version | 1008 | .word 0 @ 0xffff0ff0 software TLS value, then |
| 1018 | .endr | 1009 | .endr @ pad up to __kuser_helper_version |
| 1019 | 1010 | ||
| 1020 | /* | 1011 | /* |
| 1021 | * Reference declaration: | 1012 | * Reference declaration: |
diff --git a/arch/arm/kernel/irq.c b/arch/arm/kernel/irq.c index 3b3d2c80509c..c0d5c3b3a760 100644 --- a/arch/arm/kernel/irq.c +++ b/arch/arm/kernel/irq.c | |||
| @@ -47,12 +47,14 @@ | |||
| 47 | #define irq_finish(irq) do { } while (0) | 47 | #define irq_finish(irq) do { } while (0) |
| 48 | #endif | 48 | #endif |
| 49 | 49 | ||
| 50 | unsigned int arch_nr_irqs; | ||
| 50 | void (*init_arch_irq)(void) __initdata = NULL; | 51 | void (*init_arch_irq)(void) __initdata = NULL; |
| 51 | unsigned long irq_err_count; | 52 | unsigned long irq_err_count; |
| 52 | 53 | ||
| 53 | int show_interrupts(struct seq_file *p, void *v) | 54 | int show_interrupts(struct seq_file *p, void *v) |
| 54 | { | 55 | { |
| 55 | int i = *(loff_t *) v, cpu; | 56 | int i = *(loff_t *) v, cpu; |
| 57 | struct irq_desc *desc; | ||
| 56 | struct irqaction * action; | 58 | struct irqaction * action; |
| 57 | unsigned long flags; | 59 | unsigned long flags; |
| 58 | 60 | ||
| @@ -67,24 +69,25 @@ int show_interrupts(struct seq_file *p, void *v) | |||
| 67 | seq_putc(p, '\n'); | 69 | seq_putc(p, '\n'); |
| 68 | } | 70 | } |
| 69 | 71 | ||
| 70 | if (i < NR_IRQS) { | 72 | if (i < nr_irqs) { |
| 71 | raw_spin_lock_irqsave(&irq_desc[i].lock, flags); | 73 | desc = irq_to_desc(i); |
| 72 | action = irq_desc[i].action; | 74 | raw_spin_lock_irqsave(&desc->lock, flags); |
| 75 | action = desc->action; | ||
| 73 | if (!action) | 76 | if (!action) |
| 74 | goto unlock; | 77 | goto unlock; |
| 75 | 78 | ||
| 76 | seq_printf(p, "%3d: ", i); | 79 | seq_printf(p, "%3d: ", i); |
| 77 | for_each_present_cpu(cpu) | 80 | for_each_present_cpu(cpu) |
| 78 | seq_printf(p, "%10u ", kstat_irqs_cpu(i, cpu)); | 81 | seq_printf(p, "%10u ", kstat_irqs_cpu(i, cpu)); |
| 79 | seq_printf(p, " %10s", irq_desc[i].chip->name ? : "-"); | 82 | seq_printf(p, " %10s", desc->chip->name ? : "-"); |
| 80 | seq_printf(p, " %s", action->name); | 83 | seq_printf(p, " %s", action->name); |
| 81 | for (action = action->next; action; action = action->next) | 84 | for (action = action->next; action; action = action->next) |
| 82 | seq_printf(p, ", %s", action->name); | 85 | seq_printf(p, ", %s", action->name); |
| 83 | 86 | ||
| 84 | seq_putc(p, '\n'); | 87 | seq_putc(p, '\n'); |
| 85 | unlock: | 88 | unlock: |
| 86 | raw_spin_unlock_irqrestore(&irq_desc[i].lock, flags); | 89 | raw_spin_unlock_irqrestore(&desc->lock, flags); |
| 87 | } else if (i == NR_IRQS) { | 90 | } else if (i == nr_irqs) { |
| 88 | #ifdef CONFIG_FIQ | 91 | #ifdef CONFIG_FIQ |
| 89 | show_fiq_list(p, v); | 92 | show_fiq_list(p, v); |
| 90 | #endif | 93 | #endif |
| @@ -112,7 +115,7 @@ asmlinkage void __exception asm_do_IRQ(unsigned int irq, struct pt_regs *regs) | |||
| 112 | * Some hardware gives randomly wrong interrupts. Rather | 115 | * Some hardware gives randomly wrong interrupts. Rather |
| 113 | * than crashing, do something sensible. | 116 | * than crashing, do something sensible. |
| 114 | */ | 117 | */ |
| 115 | if (unlikely(irq >= NR_IRQS)) { | 118 | if (unlikely(irq >= nr_irqs)) { |
| 116 | if (printk_ratelimit()) | 119 | if (printk_ratelimit()) |
| 117 | printk(KERN_WARNING "Bad IRQ%u\n", irq); | 120 | printk(KERN_WARNING "Bad IRQ%u\n", irq); |
| 118 | ack_bad_irq(irq); | 121 | ack_bad_irq(irq); |
| @@ -132,12 +135,12 @@ void set_irq_flags(unsigned int irq, unsigned int iflags) | |||
| 132 | struct irq_desc *desc; | 135 | struct irq_desc *desc; |
| 133 | unsigned long flags; | 136 | unsigned long flags; |
| 134 | 137 | ||
| 135 | if (irq >= NR_IRQS) { | 138 | if (irq >= nr_irqs) { |
| 136 | printk(KERN_ERR "Trying to set irq flags for IRQ%d\n", irq); | 139 | printk(KERN_ERR "Trying to set irq flags for IRQ%d\n", irq); |
| 137 | return; | 140 | return; |
| 138 | } | 141 | } |
| 139 | 142 | ||
| 140 | desc = irq_desc + irq; | 143 | desc = irq_to_desc(irq); |
| 141 | raw_spin_lock_irqsave(&desc->lock, flags); | 144 | raw_spin_lock_irqsave(&desc->lock, flags); |
| 142 | desc->status |= IRQ_NOREQUEST | IRQ_NOPROBE | IRQ_NOAUTOEN; | 145 | desc->status |= IRQ_NOREQUEST | IRQ_NOPROBE | IRQ_NOAUTOEN; |
| 143 | if (iflags & IRQF_VALID) | 146 | if (iflags & IRQF_VALID) |
| @@ -151,14 +154,25 @@ void set_irq_flags(unsigned int irq, unsigned int iflags) | |||
| 151 | 154 | ||
| 152 | void __init init_IRQ(void) | 155 | void __init init_IRQ(void) |
| 153 | { | 156 | { |
| 157 | struct irq_desc *desc; | ||
| 154 | int irq; | 158 | int irq; |
| 155 | 159 | ||
| 156 | for (irq = 0; irq < NR_IRQS; irq++) | 160 | for (irq = 0; irq < nr_irqs; irq++) { |
| 157 | irq_desc[irq].status |= IRQ_NOREQUEST | IRQ_NOPROBE; | 161 | desc = irq_to_desc_alloc_node(irq, 0); |
| 162 | desc->status |= IRQ_NOREQUEST | IRQ_NOPROBE; | ||
| 163 | } | ||
| 158 | 164 | ||
| 159 | init_arch_irq(); | 165 | init_arch_irq(); |
| 160 | } | 166 | } |
| 161 | 167 | ||
| 168 | #ifdef CONFIG_SPARSE_IRQ | ||
| 169 | int __init arch_probe_nr_irqs(void) | ||
| 170 | { | ||
| 171 | nr_irqs = arch_nr_irqs ? arch_nr_irqs : NR_IRQS; | ||
| 172 | return 0; | ||
| 173 | } | ||
| 174 | #endif | ||
| 175 | |||
| 162 | #ifdef CONFIG_HOTPLUG_CPU | 176 | #ifdef CONFIG_HOTPLUG_CPU |
| 163 | 177 | ||
| 164 | static void route_irq(struct irq_desc *desc, unsigned int irq, unsigned int cpu) | 178 | static void route_irq(struct irq_desc *desc, unsigned int irq, unsigned int cpu) |
| @@ -178,10 +192,9 @@ static void route_irq(struct irq_desc *desc, unsigned int irq, unsigned int cpu) | |||
| 178 | void migrate_irqs(void) | 192 | void migrate_irqs(void) |
| 179 | { | 193 | { |
| 180 | unsigned int i, cpu = smp_processor_id(); | 194 | unsigned int i, cpu = smp_processor_id(); |
| 195 | struct irq_desc *desc; | ||
| 181 | 196 | ||
| 182 | for (i = 0; i < NR_IRQS; i++) { | 197 | for_each_irq_desc(i, desc) { |
| 183 | struct irq_desc *desc = irq_desc + i; | ||
| 184 | |||
| 185 | if (desc->node == cpu) { | 198 | if (desc->node == cpu) { |
| 186 | unsigned int newcpu = cpumask_any_and(desc->affinity, | 199 | unsigned int newcpu = cpumask_any_and(desc->affinity, |
| 187 | cpu_online_mask); | 200 | cpu_online_mask); |
diff --git a/arch/arm/kernel/machine_kexec.c b/arch/arm/kernel/machine_kexec.c index 598ca61e7bca..81e989858d42 100644 --- a/arch/arm/kernel/machine_kexec.c +++ b/arch/arm/kernel/machine_kexec.c | |||
| @@ -43,6 +43,10 @@ void machine_shutdown(void) | |||
| 43 | 43 | ||
| 44 | void machine_crash_shutdown(struct pt_regs *regs) | 44 | void machine_crash_shutdown(struct pt_regs *regs) |
| 45 | { | 45 | { |
| 46 | local_irq_disable(); | ||
| 47 | crash_save_cpu(regs, smp_processor_id()); | ||
| 48 | |||
| 49 | printk(KERN_INFO "Loading crashdump kernel...\n"); | ||
| 46 | } | 50 | } |
| 47 | 51 | ||
| 48 | void machine_kexec(struct kimage *image) | 52 | void machine_kexec(struct kimage *image) |
diff --git a/arch/arm/kernel/ptrace.c b/arch/arm/kernel/ptrace.c index 3f562a7c0a99..f99d489822d5 100644 --- a/arch/arm/kernel/ptrace.c +++ b/arch/arm/kernel/ptrace.c | |||
| @@ -52,6 +52,102 @@ | |||
| 52 | #define BREAKINST_THUMB 0xde01 | 52 | #define BREAKINST_THUMB 0xde01 |
| 53 | #endif | 53 | #endif |
| 54 | 54 | ||
| 55 | struct pt_regs_offset { | ||
| 56 | const char *name; | ||
| 57 | int offset; | ||
| 58 | }; | ||
| 59 | |||
| 60 | #define REG_OFFSET_NAME(r) \ | ||
| 61 | {.name = #r, .offset = offsetof(struct pt_regs, ARM_##r)} | ||
| 62 | #define REG_OFFSET_END {.name = NULL, .offset = 0} | ||
| 63 | |||
| 64 | static const struct pt_regs_offset regoffset_table[] = { | ||
| 65 | REG_OFFSET_NAME(r0), | ||
| 66 | REG_OFFSET_NAME(r1), | ||
| 67 | REG_OFFSET_NAME(r2), | ||
| 68 | REG_OFFSET_NAME(r3), | ||
| 69 | REG_OFFSET_NAME(r4), | ||
| 70 | REG_OFFSET_NAME(r5), | ||
| 71 | REG_OFFSET_NAME(r6), | ||
| 72 | REG_OFFSET_NAME(r7), | ||
| 73 | REG_OFFSET_NAME(r8), | ||
| 74 | REG_OFFSET_NAME(r9), | ||
| 75 | REG_OFFSET_NAME(r10), | ||
| 76 | REG_OFFSET_NAME(fp), | ||
| 77 | REG_OFFSET_NAME(ip), | ||
| 78 | REG_OFFSET_NAME(sp), | ||
| 79 | REG_OFFSET_NAME(lr), | ||
| 80 | REG_OFFSET_NAME(pc), | ||
| 81 | REG_OFFSET_NAME(cpsr), | ||
| 82 | REG_OFFSET_NAME(ORIG_r0), | ||
| 83 | REG_OFFSET_END, | ||
| 84 | }; | ||
| 85 | |||
| 86 | /** | ||
| 87 | * regs_query_register_offset() - query register offset from its name | ||
| 88 | * @name: the name of a register | ||
| 89 | * | ||
| 90 | * regs_query_register_offset() returns the offset of a register in struct | ||
| 91 | * pt_regs from its name. If the name is invalid, this returns -EINVAL; | ||
| 92 | */ | ||
| 93 | int regs_query_register_offset(const char *name) | ||
| 94 | { | ||
| 95 | const struct pt_regs_offset *roff; | ||
| 96 | for (roff = regoffset_table; roff->name != NULL; roff++) | ||
| 97 | if (!strcmp(roff->name, name)) | ||
| 98 | return roff->offset; | ||
| 99 | return -EINVAL; | ||
| 100 | } | ||
| 101 | |||
| 102 | /** | ||
| 103 | * regs_query_register_name() - query register name from its offset | ||
| 104 | * @offset: the offset of a register in struct pt_regs. | ||
| 105 | * | ||
| 106 | * regs_query_register_name() returns the name of a register from its | ||
| 107 | * offset in struct pt_regs. If the @offset is invalid, this returns NULL; | ||
| 108 | */ | ||
| 109 | const char *regs_query_register_name(unsigned int offset) | ||
| 110 | { | ||
| 111 | const struct pt_regs_offset *roff; | ||
| 112 | for (roff = regoffset_table; roff->name != NULL; roff++) | ||
| 113 | if (roff->offset == offset) | ||
| 114 | return roff->name; | ||
| 115 | return NULL; | ||
| 116 | } | ||
| 117 | |||
| 118 | /** | ||
| 119 | * regs_within_kernel_stack() - check the address in the stack | ||
| 120 | * @regs: pt_regs which contains kernel stack pointer. | ||
| 121 | * @addr: address which is checked. | ||
| 122 | * | ||
| 123 | * regs_within_kernel_stack() checks @addr is within the kernel stack page(s). | ||
| 124 | * If @addr is within the kernel stack, it returns true. If not, returns false. | ||
| 125 | */ | ||
| 126 | bool regs_within_kernel_stack(struct pt_regs *regs, unsigned long addr) | ||
| 127 | { | ||
| 128 | return ((addr & ~(THREAD_SIZE - 1)) == | ||
| 129 | (kernel_stack_pointer(regs) & ~(THREAD_SIZE - 1))); | ||
| 130 | } | ||
| 131 | |||
| 132 | /** | ||
| 133 | * regs_get_kernel_stack_nth() - get Nth entry of the stack | ||
| 134 | * @regs: pt_regs which contains kernel stack pointer. | ||
| 135 | * @n: stack entry number. | ||
| 136 | * | ||
| 137 | * regs_get_kernel_stack_nth() returns @n th entry of the kernel stack which | ||
| 138 | * is specified by @regs. If the @n th entry is NOT in the kernel stack, | ||
| 139 | * this returns 0. | ||
| 140 | */ | ||
| 141 | unsigned long regs_get_kernel_stack_nth(struct pt_regs *regs, unsigned int n) | ||
| 142 | { | ||
| 143 | unsigned long *addr = (unsigned long *)kernel_stack_pointer(regs); | ||
| 144 | addr += n; | ||
| 145 | if (regs_within_kernel_stack(regs, (unsigned long)addr)) | ||
| 146 | return *addr; | ||
| 147 | else | ||
| 148 | return 0; | ||
| 149 | } | ||
| 150 | |||
| 55 | /* | 151 | /* |
| 56 | * this routine will get a word off of the processes privileged stack. | 152 | * this routine will get a word off of the processes privileged stack. |
| 57 | * the offset is how far from the base addr as stored in the THREAD. | 153 | * the offset is how far from the base addr as stored in the THREAD. |
diff --git a/arch/arm/kernel/relocate_kernel.S b/arch/arm/kernel/relocate_kernel.S index 61930eb09029..fd26f8d65151 100644 --- a/arch/arm/kernel/relocate_kernel.S +++ b/arch/arm/kernel/relocate_kernel.S | |||
| @@ -10,6 +10,12 @@ relocate_new_kernel: | |||
| 10 | ldr r0,kexec_indirection_page | 10 | ldr r0,kexec_indirection_page |
| 11 | ldr r1,kexec_start_address | 11 | ldr r1,kexec_start_address |
| 12 | 12 | ||
| 13 | /* | ||
| 14 | * If there is no indirection page (we are doing crashdumps) | ||
| 15 | * skip any relocation. | ||
| 16 | */ | ||
| 17 | cmp r0, #0 | ||
| 18 | beq 2f | ||
| 13 | 19 | ||
| 14 | 0: /* top, read another word for the indirection page */ | 20 | 0: /* top, read another word for the indirection page */ |
| 15 | ldr r3, [r0],#4 | 21 | ldr r3, [r0],#4 |
diff --git a/arch/arm/kernel/setup.c b/arch/arm/kernel/setup.c index 122d999bdc7c..776ea1aa974b 100644 --- a/arch/arm/kernel/setup.c +++ b/arch/arm/kernel/setup.c | |||
| @@ -19,12 +19,15 @@ | |||
| 19 | #include <linux/seq_file.h> | 19 | #include <linux/seq_file.h> |
| 20 | #include <linux/screen_info.h> | 20 | #include <linux/screen_info.h> |
| 21 | #include <linux/init.h> | 21 | #include <linux/init.h> |
| 22 | #include <linux/kexec.h> | ||
| 23 | #include <linux/crash_dump.h> | ||
| 22 | #include <linux/root_dev.h> | 24 | #include <linux/root_dev.h> |
| 23 | #include <linux/cpu.h> | 25 | #include <linux/cpu.h> |
| 24 | #include <linux/interrupt.h> | 26 | #include <linux/interrupt.h> |
| 25 | #include <linux/smp.h> | 27 | #include <linux/smp.h> |
| 26 | #include <linux/fs.h> | 28 | #include <linux/fs.h> |
| 27 | #include <linux/proc_fs.h> | 29 | #include <linux/proc_fs.h> |
| 30 | #include <linux/memblock.h> | ||
| 28 | 31 | ||
| 29 | #include <asm/unified.h> | 32 | #include <asm/unified.h> |
| 30 | #include <asm/cpu.h> | 33 | #include <asm/cpu.h> |
| @@ -269,6 +272,21 @@ static void __init cacheid_init(void) | |||
| 269 | extern struct proc_info_list *lookup_processor_type(unsigned int); | 272 | extern struct proc_info_list *lookup_processor_type(unsigned int); |
| 270 | extern struct machine_desc *lookup_machine_type(unsigned int); | 273 | extern struct machine_desc *lookup_machine_type(unsigned int); |
| 271 | 274 | ||
| 275 | static void __init feat_v6_fixup(void) | ||
| 276 | { | ||
| 277 | int id = read_cpuid_id(); | ||
| 278 | |||
| 279 | if ((id & 0xff0f0000) != 0x41070000) | ||
| 280 | return; | ||
| 281 | |||
| 282 | /* | ||
| 283 | * HWCAP_TLS is available only on 1136 r1p0 and later, | ||
| 284 | * see also kuser_get_tls_init. | ||
| 285 | */ | ||
| 286 | if ((((id >> 4) & 0xfff) == 0xb36) && (((id >> 20) & 3) == 0)) | ||
| 287 | elf_hwcap &= ~HWCAP_TLS; | ||
| 288 | } | ||
| 289 | |||
| 272 | static void __init setup_processor(void) | 290 | static void __init setup_processor(void) |
| 273 | { | 291 | { |
| 274 | struct proc_info_list *list; | 292 | struct proc_info_list *list; |
| @@ -311,6 +329,8 @@ static void __init setup_processor(void) | |||
| 311 | elf_hwcap &= ~HWCAP_THUMB; | 329 | elf_hwcap &= ~HWCAP_THUMB; |
| 312 | #endif | 330 | #endif |
| 313 | 331 | ||
| 332 | feat_v6_fixup(); | ||
| 333 | |||
| 314 | cacheid_init(); | 334 | cacheid_init(); |
| 315 | cpu_proc_init(); | 335 | cpu_proc_init(); |
| 316 | } | 336 | } |
| @@ -402,13 +422,12 @@ static int __init arm_add_memory(unsigned long start, unsigned long size) | |||
| 402 | size -= start & ~PAGE_MASK; | 422 | size -= start & ~PAGE_MASK; |
| 403 | bank->start = PAGE_ALIGN(start); | 423 | bank->start = PAGE_ALIGN(start); |
| 404 | bank->size = size & PAGE_MASK; | 424 | bank->size = size & PAGE_MASK; |
| 405 | bank->node = PHYS_TO_NID(start); | ||
| 406 | 425 | ||
| 407 | /* | 426 | /* |
| 408 | * Check whether this memory region has non-zero size or | 427 | * Check whether this memory region has non-zero size or |
| 409 | * invalid node number. | 428 | * invalid node number. |
| 410 | */ | 429 | */ |
| 411 | if (bank->size == 0 || bank->node >= MAX_NUMNODES) | 430 | if (bank->size == 0) |
| 412 | return -EINVAL; | 431 | return -EINVAL; |
| 413 | 432 | ||
| 414 | meminfo.nr_banks++; | 433 | meminfo.nr_banks++; |
| @@ -663,6 +682,79 @@ static int __init customize_machine(void) | |||
| 663 | } | 682 | } |
| 664 | arch_initcall(customize_machine); | 683 | arch_initcall(customize_machine); |
| 665 | 684 | ||
| 685 | #ifdef CONFIG_KEXEC | ||
| 686 | static inline unsigned long long get_total_mem(void) | ||
| 687 | { | ||
| 688 | unsigned long total; | ||
| 689 | |||
| 690 | total = max_low_pfn - min_low_pfn; | ||
| 691 | return total << PAGE_SHIFT; | ||
| 692 | } | ||
| 693 | |||
| 694 | /** | ||
| 695 | * reserve_crashkernel() - reserves memory are for crash kernel | ||
| 696 | * | ||
| 697 | * This function reserves memory area given in "crashkernel=" kernel command | ||
| 698 | * line parameter. The memory reserved is used by a dump capture kernel when | ||
| 699 | * primary kernel is crashing. | ||
| 700 | */ | ||
| 701 | static void __init reserve_crashkernel(void) | ||
| 702 | { | ||
| 703 | unsigned long long crash_size, crash_base; | ||
| 704 | unsigned long long total_mem; | ||
| 705 | int ret; | ||
| 706 | |||
| 707 | total_mem = get_total_mem(); | ||
| 708 | ret = parse_crashkernel(boot_command_line, total_mem, | ||
| 709 | &crash_size, &crash_base); | ||
| 710 | if (ret) | ||
| 711 | return; | ||
| 712 | |||
| 713 | ret = reserve_bootmem(crash_base, crash_size, BOOTMEM_EXCLUSIVE); | ||
| 714 | if (ret < 0) { | ||
| 715 | printk(KERN_WARNING "crashkernel reservation failed - " | ||
| 716 | "memory is in use (0x%lx)\n", (unsigned long)crash_base); | ||
| 717 | return; | ||
| 718 | } | ||
| 719 | |||
| 720 | printk(KERN_INFO "Reserving %ldMB of memory at %ldMB " | ||
| 721 | "for crashkernel (System RAM: %ldMB)\n", | ||
| 722 | (unsigned long)(crash_size >> 20), | ||
| 723 | (unsigned long)(crash_base >> 20), | ||
| 724 | (unsigned long)(total_mem >> 20)); | ||
| 725 | |||
| 726 | crashk_res.start = crash_base; | ||
| 727 | crashk_res.end = crash_base + crash_size - 1; | ||
| 728 | insert_resource(&iomem_resource, &crashk_res); | ||
| 729 | } | ||
| 730 | #else | ||
| 731 | static inline void reserve_crashkernel(void) {} | ||
| 732 | #endif /* CONFIG_KEXEC */ | ||
| 733 | |||
| 734 | /* | ||
| 735 | * Note: elfcorehdr_addr is not just limited to vmcore. It is also used by | ||
| 736 | * is_kdump_kernel() to determine if we are booting after a panic. Hence | ||
| 737 | * ifdef it under CONFIG_CRASH_DUMP and not CONFIG_PROC_VMCORE. | ||
| 738 | */ | ||
| 739 | |||
| 740 | #ifdef CONFIG_CRASH_DUMP | ||
| 741 | /* | ||
| 742 | * elfcorehdr= specifies the location of elf core header stored by the crashed | ||
| 743 | * kernel. This option will be passed by kexec loader to the capture kernel. | ||
| 744 | */ | ||
| 745 | static int __init setup_elfcorehdr(char *arg) | ||
| 746 | { | ||
| 747 | char *end; | ||
| 748 | |||
| 749 | if (!arg) | ||
| 750 | return -EINVAL; | ||
| 751 | |||
| 752 | elfcorehdr_addr = memparse(arg, &end); | ||
| 753 | return end > arg ? 0 : -EINVAL; | ||
| 754 | } | ||
| 755 | early_param("elfcorehdr", setup_elfcorehdr); | ||
| 756 | #endif /* CONFIG_CRASH_DUMP */ | ||
| 757 | |||
| 666 | void __init setup_arch(char **cmdline_p) | 758 | void __init setup_arch(char **cmdline_p) |
| 667 | { | 759 | { |
| 668 | struct tag *tags = (struct tag *)&init_tags; | 760 | struct tag *tags = (struct tag *)&init_tags; |
| @@ -716,12 +808,15 @@ void __init setup_arch(char **cmdline_p) | |||
| 716 | 808 | ||
| 717 | parse_early_param(); | 809 | parse_early_param(); |
| 718 | 810 | ||
| 811 | arm_memblock_init(&meminfo, mdesc); | ||
| 812 | |||
| 719 | paging_init(mdesc); | 813 | paging_init(mdesc); |
| 720 | request_standard_resources(&meminfo, mdesc); | 814 | request_standard_resources(&meminfo, mdesc); |
| 721 | 815 | ||
| 722 | #ifdef CONFIG_SMP | 816 | #ifdef CONFIG_SMP |
| 723 | smp_init_cpus(); | 817 | smp_init_cpus(); |
| 724 | #endif | 818 | #endif |
| 819 | reserve_crashkernel(); | ||
| 725 | 820 | ||
| 726 | cpu_init(); | 821 | cpu_init(); |
| 727 | tcm_init(); | 822 | tcm_init(); |
| @@ -729,6 +824,7 @@ void __init setup_arch(char **cmdline_p) | |||
| 729 | /* | 824 | /* |
| 730 | * Set up various architecture-specific pointers | 825 | * Set up various architecture-specific pointers |
| 731 | */ | 826 | */ |
| 827 | arch_nr_irqs = mdesc->nr_irqs; | ||
| 732 | init_arch_irq = mdesc->init_irq; | 828 | init_arch_irq = mdesc->init_irq; |
| 733 | system_timer = mdesc->timer; | 829 | system_timer = mdesc->timer; |
| 734 | init_machine = mdesc->init_machine; | 830 | init_machine = mdesc->init_machine; |
diff --git a/arch/arm/kernel/traps.c b/arch/arm/kernel/traps.c index 1621e5327b2a..cda78d59aa31 100644 --- a/arch/arm/kernel/traps.c +++ b/arch/arm/kernel/traps.c | |||
| @@ -30,6 +30,7 @@ | |||
| 30 | #include <asm/unistd.h> | 30 | #include <asm/unistd.h> |
| 31 | #include <asm/traps.h> | 31 | #include <asm/traps.h> |
| 32 | #include <asm/unwind.h> | 32 | #include <asm/unwind.h> |
| 33 | #include <asm/tls.h> | ||
| 33 | 34 | ||
| 34 | #include "ptrace.h" | 35 | #include "ptrace.h" |
| 35 | #include "signal.h" | 36 | #include "signal.h" |
| @@ -518,17 +519,20 @@ asmlinkage int arm_syscall(int no, struct pt_regs *regs) | |||
| 518 | 519 | ||
| 519 | case NR(set_tls): | 520 | case NR(set_tls): |
| 520 | thread->tp_value = regs->ARM_r0; | 521 | thread->tp_value = regs->ARM_r0; |
| 521 | #if defined(CONFIG_HAS_TLS_REG) | 522 | if (tls_emu) |
| 522 | asm ("mcr p15, 0, %0, c13, c0, 3" : : "r" (regs->ARM_r0) ); | 523 | return 0; |
| 523 | #elif !defined(CONFIG_TLS_REG_EMUL) | 524 | if (has_tls_reg) { |
| 524 | /* | 525 | asm ("mcr p15, 0, %0, c13, c0, 3" |
| 525 | * User space must never try to access this directly. | 526 | : : "r" (regs->ARM_r0)); |
| 526 | * Expect your app to break eventually if you do so. | 527 | } else { |
| 527 | * The user helper at 0xffff0fe0 must be used instead. | 528 | /* |
| 528 | * (see entry-armv.S for details) | 529 | * User space must never try to access this directly. |
| 529 | */ | 530 | * Expect your app to break eventually if you do so. |
| 530 | *((unsigned int *)0xffff0ff0) = regs->ARM_r0; | 531 | * The user helper at 0xffff0fe0 must be used instead. |
| 531 | #endif | 532 | * (see entry-armv.S for details) |
| 533 | */ | ||
| 534 | *((unsigned int *)0xffff0ff0) = regs->ARM_r0; | ||
| 535 | } | ||
| 532 | return 0; | 536 | return 0; |
| 533 | 537 | ||
| 534 | #ifdef CONFIG_NEEDS_SYSCALL_FOR_CMPXCHG | 538 | #ifdef CONFIG_NEEDS_SYSCALL_FOR_CMPXCHG |
| @@ -743,6 +747,16 @@ void __init trap_init(void) | |||
| 743 | return; | 747 | return; |
| 744 | } | 748 | } |
| 745 | 749 | ||
| 750 | static void __init kuser_get_tls_init(unsigned long vectors) | ||
| 751 | { | ||
| 752 | /* | ||
| 753 | * vectors + 0xfe0 = __kuser_get_tls | ||
| 754 | * vectors + 0xfe8 = hardware TLS instruction at 0xffff0fe8 | ||
| 755 | */ | ||
| 756 | if (tls_emu || has_tls_reg) | ||
| 757 | memcpy((void *)vectors + 0xfe0, (void *)vectors + 0xfe8, 4); | ||
| 758 | } | ||
| 759 | |||
| 746 | void __init early_trap_init(void) | 760 | void __init early_trap_init(void) |
| 747 | { | 761 | { |
| 748 | unsigned long vectors = CONFIG_VECTORS_BASE; | 762 | unsigned long vectors = CONFIG_VECTORS_BASE; |
| @@ -761,6 +775,11 @@ void __init early_trap_init(void) | |||
| 761 | memcpy((void *)vectors + 0x1000 - kuser_sz, __kuser_helper_start, kuser_sz); | 775 | memcpy((void *)vectors + 0x1000 - kuser_sz, __kuser_helper_start, kuser_sz); |
| 762 | 776 | ||
| 763 | /* | 777 | /* |
| 778 | * Do processor specific fixups for the kuser helpers | ||
| 779 | */ | ||
| 780 | kuser_get_tls_init(vectors); | ||
| 781 | |||
| 782 | /* | ||
| 764 | * Copy signal return handlers into the vector page, and | 783 | * Copy signal return handlers into the vector page, and |
| 765 | * set sigreturn to be a pointer to these. | 784 | * set sigreturn to be a pointer to these. |
| 766 | */ | 785 | */ |
diff --git a/arch/arm/lib/Makefile b/arch/arm/lib/Makefile index 030ba7219f48..59ff42ddf0ae 100644 --- a/arch/arm/lib/Makefile +++ b/arch/arm/lib/Makefile | |||
| @@ -41,7 +41,6 @@ else | |||
| 41 | endif | 41 | endif |
| 42 | 42 | ||
| 43 | lib-$(CONFIG_ARCH_RPC) += ecard.o io-acorn.o floppydma.o | 43 | lib-$(CONFIG_ARCH_RPC) += ecard.o io-acorn.o floppydma.o |
| 44 | lib-$(CONFIG_ARCH_L7200) += io-acorn.o | ||
| 45 | lib-$(CONFIG_ARCH_SHARK) += io-shark.o | 44 | lib-$(CONFIG_ARCH_SHARK) += io-shark.o |
| 46 | 45 | ||
| 47 | $(obj)/csumpartialcopy.o: $(obj)/csumpartialcopygeneric.S | 46 | $(obj)/csumpartialcopy.o: $(obj)/csumpartialcopygeneric.S |
diff --git a/arch/arm/mach-aaec2000/include/mach/memory.h b/arch/arm/mach-aaec2000/include/mach/memory.h index c00822543d9f..4f93c567a35a 100644 --- a/arch/arm/mach-aaec2000/include/mach/memory.h +++ b/arch/arm/mach-aaec2000/include/mach/memory.h | |||
| @@ -14,14 +14,4 @@ | |||
| 14 | 14 | ||
| 15 | #define PHYS_OFFSET UL(0xf0000000) | 15 | #define PHYS_OFFSET UL(0xf0000000) |
| 16 | 16 | ||
| 17 | /* | ||
| 18 | * The nodes are the followings: | ||
| 19 | * | ||
| 20 | * node 0: 0xf000.0000 - 0xf3ff.ffff | ||
| 21 | * node 1: 0xf400.0000 - 0xf7ff.ffff | ||
| 22 | * node 2: 0xf800.0000 - 0xfbff.ffff | ||
| 23 | * node 3: 0xfc00.0000 - 0xffff.ffff | ||
| 24 | */ | ||
| 25 | #define NODE_MEM_SIZE_BITS 26 | ||
| 26 | |||
| 27 | #endif /* __ASM_ARCH_MEMORY_H */ | 17 | #endif /* __ASM_ARCH_MEMORY_H */ |
diff --git a/arch/arm/mach-at91/Kconfig b/arch/arm/mach-at91/Kconfig index 841eaf8f27e2..939bccd70569 100644 --- a/arch/arm/mach-at91/Kconfig +++ b/arch/arm/mach-at91/Kconfig | |||
| @@ -366,6 +366,17 @@ config MACH_STAMP9G20 | |||
| 366 | 366 | ||
| 367 | endif | 367 | endif |
| 368 | 368 | ||
| 369 | if (ARCH_AT91SAM9260 || ARCH_AT91SAM9G20) | ||
| 370 | comment "AT91SAM9260/AT91SAM9G20 boards" | ||
| 371 | |||
| 372 | config MACH_SNAPPER_9260 | ||
| 373 | bool "Bluewater Systems Snapper 9260/9G20 module" | ||
| 374 | help | ||
| 375 | Select this if you are using the Bluewater Systems Snapper 9260 or | ||
| 376 | Snapper 9G20 modules. | ||
| 377 | <http://www.bluewatersys.com/> | ||
| 378 | endif | ||
| 379 | |||
| 369 | # ---------------------------------------------------------- | 380 | # ---------------------------------------------------------- |
| 370 | 381 | ||
| 371 | if ARCH_AT91SAM9G45 | 382 | if ARCH_AT91SAM9G45 |
diff --git a/arch/arm/mach-at91/Makefile b/arch/arm/mach-at91/Makefile index c1f821e58222..ca2ac003f41f 100644 --- a/arch/arm/mach-at91/Makefile +++ b/arch/arm/mach-at91/Makefile | |||
| @@ -66,6 +66,9 @@ obj-$(CONFIG_MACH_CPU9G20) += board-cpu9krea.o | |||
| 66 | obj-$(CONFIG_MACH_STAMP9G20) += board-stamp9g20.o | 66 | obj-$(CONFIG_MACH_STAMP9G20) += board-stamp9g20.o |
| 67 | obj-$(CONFIG_MACH_PORTUXG20) += board-stamp9g20.o | 67 | obj-$(CONFIG_MACH_PORTUXG20) += board-stamp9g20.o |
| 68 | 68 | ||
| 69 | # AT91SAM9260/AT91SAM9G20 board-specific support | ||
| 70 | obj-$(CONFIG_MACH_SNAPPER_9260) += board-snapper9260.o | ||
| 71 | |||
| 69 | # AT91SAM9G45 board-specific support | 72 | # AT91SAM9G45 board-specific support |
| 70 | obj-$(CONFIG_MACH_AT91SAM9G45EKES) += board-sam9m10g45ek.o | 73 | obj-$(CONFIG_MACH_AT91SAM9G45EKES) += board-sam9m10g45ek.o |
| 71 | 74 | ||
diff --git a/arch/arm/mach-at91/at91sam9g45.c b/arch/arm/mach-at91/at91sam9g45.c index 85166b7e69a1..753c0d31a3d3 100644 --- a/arch/arm/mach-at91/at91sam9g45.c +++ b/arch/arm/mach-at91/at91sam9g45.c | |||
| @@ -20,6 +20,7 @@ | |||
| 20 | #include <mach/at91_pmc.h> | 20 | #include <mach/at91_pmc.h> |
| 21 | #include <mach/at91_rstc.h> | 21 | #include <mach/at91_rstc.h> |
| 22 | #include <mach/at91_shdwc.h> | 22 | #include <mach/at91_shdwc.h> |
| 23 | #include <mach/cpu.h> | ||
| 23 | 24 | ||
| 24 | #include "generic.h" | 25 | #include "generic.h" |
| 25 | #include "clock.h" | 26 | #include "clock.h" |
| @@ -176,6 +177,13 @@ static struct clk mmc1_clk = { | |||
| 176 | .type = CLK_TYPE_PERIPHERAL, | 177 | .type = CLK_TYPE_PERIPHERAL, |
| 177 | }; | 178 | }; |
| 178 | 179 | ||
| 180 | /* Video decoder clock - Only for sam9m10/sam9m11 */ | ||
| 181 | static struct clk vdec_clk = { | ||
| 182 | .name = "vdec_clk", | ||
| 183 | .pmc_mask = 1 << AT91SAM9G45_ID_VDEC, | ||
| 184 | .type = CLK_TYPE_PERIPHERAL, | ||
| 185 | }; | ||
| 186 | |||
| 179 | /* One additional fake clock for ohci */ | 187 | /* One additional fake clock for ohci */ |
| 180 | static struct clk ohci_clk = { | 188 | static struct clk ohci_clk = { |
| 181 | .name = "ohci_clk", | 189 | .name = "ohci_clk", |
| @@ -239,6 +247,9 @@ static void __init at91sam9g45_register_clocks(void) | |||
| 239 | for (i = 0; i < ARRAY_SIZE(periph_clocks); i++) | 247 | for (i = 0; i < ARRAY_SIZE(periph_clocks); i++) |
| 240 | clk_register(periph_clocks[i]); | 248 | clk_register(periph_clocks[i]); |
| 241 | 249 | ||
| 250 | if (cpu_is_at91sam9m10() || cpu_is_at91sam9m11()) | ||
| 251 | clk_register(&vdec_clk); | ||
| 252 | |||
| 242 | clk_register(&pck0); | 253 | clk_register(&pck0); |
| 243 | clk_register(&pck1); | 254 | clk_register(&pck1); |
| 244 | } | 255 | } |
diff --git a/arch/arm/mach-at91/board-sam9g20ek-2slot-mmc.c b/arch/arm/mach-at91/board-sam9g20ek-2slot-mmc.c index a4102d72cc9b..c49f5c003ee1 100644 --- a/arch/arm/mach-at91/board-sam9g20ek-2slot-mmc.c +++ b/arch/arm/mach-at91/board-sam9g20ek-2slot-mmc.c | |||
| @@ -26,6 +26,9 @@ | |||
| 26 | #include <linux/spi/spi.h> | 26 | #include <linux/spi/spi.h> |
| 27 | #include <linux/spi/at73c213.h> | 27 | #include <linux/spi/at73c213.h> |
| 28 | #include <linux/clk.h> | 28 | #include <linux/clk.h> |
| 29 | #include <linux/regulator/machine.h> | ||
| 30 | #include <linux/regulator/fixed.h> | ||
| 31 | #include <linux/regulator/consumer.h> | ||
| 29 | 32 | ||
| 30 | #include <mach/hardware.h> | 33 | #include <mach/hardware.h> |
| 31 | #include <asm/setup.h> | 34 | #include <asm/setup.h> |
| @@ -235,6 +238,46 @@ static struct gpio_led ek_leds[] = { | |||
| 235 | } | 238 | } |
| 236 | }; | 239 | }; |
| 237 | 240 | ||
| 241 | #if defined(CONFIG_REGULATOR_FIXED_VOLTAGE) || defined(CONFIG_REGULATOR_FIXED_VOLTAGE_MODULE) | ||
| 242 | static struct regulator_consumer_supply ek_audio_consumer_supplies[] = { | ||
| 243 | REGULATOR_SUPPLY("AVDD", "0-001b"), | ||
| 244 | REGULATOR_SUPPLY("HPVDD", "0-001b"), | ||
| 245 | REGULATOR_SUPPLY("DBVDD", "0-001b"), | ||
| 246 | REGULATOR_SUPPLY("DCVDD", "0-001b"), | ||
| 247 | }; | ||
| 248 | |||
| 249 | static struct regulator_init_data ek_avdd_reg_init_data = { | ||
| 250 | .constraints = { | ||
| 251 | .name = "3V3", | ||
| 252 | .valid_ops_mask = REGULATOR_CHANGE_STATUS, | ||
| 253 | }, | ||
| 254 | .consumer_supplies = ek_audio_consumer_supplies, | ||
| 255 | .num_consumer_supplies = ARRAY_SIZE(ek_audio_consumer_supplies), | ||
| 256 | }; | ||
| 257 | |||
| 258 | static struct fixed_voltage_config ek_vdd_pdata = { | ||
| 259 | .supply_name = "board-3V3", | ||
| 260 | .microvolts = 3300000, | ||
| 261 | .gpio = -EINVAL, | ||
| 262 | .enabled_at_boot = 0, | ||
| 263 | .init_data = &ek_avdd_reg_init_data, | ||
| 264 | }; | ||
| 265 | static struct platform_device ek_voltage_regulator = { | ||
| 266 | .name = "reg-fixed-voltage", | ||
| 267 | .id = -1, | ||
| 268 | .num_resources = 0, | ||
| 269 | .dev = { | ||
| 270 | .platform_data = &ek_vdd_pdata, | ||
| 271 | }, | ||
| 272 | }; | ||
| 273 | static void __init ek_add_regulators(void) | ||
| 274 | { | ||
| 275 | platform_device_register(&ek_voltage_regulator); | ||
| 276 | } | ||
| 277 | #else | ||
| 278 | static void __init ek_add_regulators(void) {} | ||
| 279 | #endif | ||
| 280 | |||
| 238 | static struct i2c_board_info __initdata ek_i2c_devices[] = { | 281 | static struct i2c_board_info __initdata ek_i2c_devices[] = { |
| 239 | { | 282 | { |
| 240 | I2C_BOARD_INFO("24c512", 0x50), | 283 | I2C_BOARD_INFO("24c512", 0x50), |
| @@ -256,6 +299,8 @@ static void __init ek_board_init(void) | |||
| 256 | ek_add_device_nand(); | 299 | ek_add_device_nand(); |
| 257 | /* Ethernet */ | 300 | /* Ethernet */ |
| 258 | at91_add_device_eth(&ek_macb_data); | 301 | at91_add_device_eth(&ek_macb_data); |
| 302 | /* Regulators */ | ||
| 303 | ek_add_regulators(); | ||
| 259 | /* MMC */ | 304 | /* MMC */ |
| 260 | #if defined(CONFIG_MMC_ATMELMCI) || defined(CONFIG_MMC_ATMELMCI_MODULE) | 305 | #if defined(CONFIG_MMC_ATMELMCI) || defined(CONFIG_MMC_ATMELMCI_MODULE) |
| 261 | at91_add_device_mci(0, &ek_mmc_data); | 306 | at91_add_device_mci(0, &ek_mmc_data); |
diff --git a/arch/arm/mach-at91/board-sam9g20ek.c b/arch/arm/mach-at91/board-sam9g20ek.c index c11fd47aec5d..6ea9808b8868 100644 --- a/arch/arm/mach-at91/board-sam9g20ek.c +++ b/arch/arm/mach-at91/board-sam9g20ek.c | |||
| @@ -27,6 +27,9 @@ | |||
| 27 | #include <linux/gpio_keys.h> | 27 | #include <linux/gpio_keys.h> |
| 28 | #include <linux/input.h> | 28 | #include <linux/input.h> |
| 29 | #include <linux/clk.h> | 29 | #include <linux/clk.h> |
| 30 | #include <linux/regulator/machine.h> | ||
| 31 | #include <linux/regulator/fixed.h> | ||
| 32 | #include <linux/regulator/consumer.h> | ||
| 30 | 33 | ||
| 31 | #include <mach/hardware.h> | 34 | #include <mach/hardware.h> |
| 32 | #include <asm/setup.h> | 35 | #include <asm/setup.h> |
| @@ -269,6 +272,46 @@ static void __init ek_add_device_buttons(void) | |||
| 269 | static void __init ek_add_device_buttons(void) {} | 272 | static void __init ek_add_device_buttons(void) {} |
| 270 | #endif | 273 | #endif |
| 271 | 274 | ||
| 275 | #if defined(CONFIG_REGULATOR_FIXED_VOLTAGE) || defined(CONFIG_REGULATOR_FIXED_VOLTAGE_MODULE) | ||
| 276 | static struct regulator_consumer_supply ek_audio_consumer_supplies[] = { | ||
| 277 | REGULATOR_SUPPLY("AVDD", "0-001b"), | ||
| 278 | REGULATOR_SUPPLY("HPVDD", "0-001b"), | ||
| 279 | REGULATOR_SUPPLY("DBVDD", "0-001b"), | ||
| 280 | REGULATOR_SUPPLY("DCVDD", "0-001b"), | ||
| 281 | }; | ||
| 282 | |||
| 283 | static struct regulator_init_data ek_avdd_reg_init_data = { | ||
| 284 | .constraints = { | ||
| 285 | .name = "3V3", | ||
| 286 | .valid_ops_mask = REGULATOR_CHANGE_STATUS, | ||
| 287 | }, | ||
| 288 | .consumer_supplies = ek_audio_consumer_supplies, | ||
| 289 | .num_consumer_supplies = ARRAY_SIZE(ek_audio_consumer_supplies), | ||
| 290 | }; | ||
| 291 | |||
| 292 | static struct fixed_voltage_config ek_vdd_pdata = { | ||
| 293 | .supply_name = "board-3V3", | ||
| 294 | .microvolts = 3300000, | ||
| 295 | .gpio = -EINVAL, | ||
| 296 | .enabled_at_boot = 0, | ||
| 297 | .init_data = &ek_avdd_reg_init_data, | ||
| 298 | }; | ||
| 299 | static struct platform_device ek_voltage_regulator = { | ||
| 300 | .name = "reg-fixed-voltage", | ||
| 301 | .id = -1, | ||
| 302 | .num_resources = 0, | ||
| 303 | .dev = { | ||
| 304 | .platform_data = &ek_vdd_pdata, | ||
| 305 | }, | ||
| 306 | }; | ||
| 307 | static void __init ek_add_regulators(void) | ||
| 308 | { | ||
| 309 | platform_device_register(&ek_voltage_regulator); | ||
| 310 | } | ||
| 311 | #else | ||
| 312 | static void __init ek_add_regulators(void) {} | ||
| 313 | #endif | ||
| 314 | |||
| 272 | 315 | ||
| 273 | static struct i2c_board_info __initdata ek_i2c_devices[] = { | 316 | static struct i2c_board_info __initdata ek_i2c_devices[] = { |
| 274 | { | 317 | { |
| @@ -294,6 +337,8 @@ static void __init ek_board_init(void) | |||
| 294 | ek_add_device_nand(); | 337 | ek_add_device_nand(); |
| 295 | /* Ethernet */ | 338 | /* Ethernet */ |
| 296 | at91_add_device_eth(&ek_macb_data); | 339 | at91_add_device_eth(&ek_macb_data); |
| 340 | /* Regulators */ | ||
| 341 | ek_add_regulators(); | ||
| 297 | /* MMC */ | 342 | /* MMC */ |
| 298 | at91_add_device_mmc(0, &ek_mmc_data); | 343 | at91_add_device_mmc(0, &ek_mmc_data); |
| 299 | /* I2C */ | 344 | /* I2C */ |
diff --git a/arch/arm/mach-at91/board-snapper9260.c b/arch/arm/mach-at91/board-snapper9260.c new file mode 100644 index 000000000000..2c08ae4ad3a1 --- /dev/null +++ b/arch/arm/mach-at91/board-snapper9260.c | |||
| @@ -0,0 +1,189 @@ | |||
| 1 | /* | ||
| 2 | * linux/arch/arm/mach-at91/board-snapper9260.c | ||
| 3 | * | ||
| 4 | * Copyright (C) 2010 Bluewater System Ltd | ||
| 5 | * | ||
| 6 | * Author: Andre Renaud <andre@bluewatersys.com> | ||
| 7 | * Author: Ryan Mallon <ryan@bluewatersys.com> | ||
| 8 | * | ||
| 9 | * This program is free software; you can redistribute it and/or modify | ||
| 10 | * it under the terms of the GNU General Public License as published by | ||
| 11 | * the Free Software Foundation; either version 2 of the License, or | ||
| 12 | * (at your option) any later version. | ||
| 13 | * | ||
| 14 | * This program is distributed in the hope that it will be useful, | ||
| 15 | * but WITHOUT ANY WARRANTY; without even the implied warranty of | ||
| 16 | * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the | ||
| 17 | * GNU General Public License for more details. | ||
| 18 | * | ||
| 19 | * You should have received a copy of the GNU General Public License | ||
| 20 | * along with this program; if not, write to the Free Software | ||
| 21 | * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA | ||
| 22 | * | ||
| 23 | */ | ||
| 24 | |||
| 25 | #include <linux/init.h> | ||
| 26 | #include <linux/gpio.h> | ||
| 27 | #include <linux/platform_device.h> | ||
| 28 | #include <linux/spi/spi.h> | ||
| 29 | #include <linux/i2c/pca953x.h> | ||
| 30 | |||
| 31 | #include <asm/mach-types.h> | ||
| 32 | #include <asm/mach/arch.h> | ||
| 33 | |||
| 34 | #include <mach/hardware.h> | ||
| 35 | #include <mach/board.h> | ||
| 36 | #include <mach/at91sam9_smc.h> | ||
| 37 | |||
| 38 | #include "sam9_smc.h" | ||
| 39 | #include "generic.h" | ||
| 40 | |||
| 41 | #define SNAPPER9260_IO_EXP_GPIO(x) (NR_BUILTIN_GPIO + (x)) | ||
| 42 | |||
| 43 | static void __init snapper9260_map_io(void) | ||
| 44 | { | ||
| 45 | at91sam9260_initialize(18432000); | ||
| 46 | |||
| 47 | /* Debug on ttyS0 */ | ||
| 48 | at91_register_uart(0, 0, 0); | ||
| 49 | at91_set_serial_console(0); | ||
| 50 | |||
| 51 | at91_register_uart(AT91SAM9260_ID_US0, 1, | ||
| 52 | ATMEL_UART_CTS | ATMEL_UART_RTS); | ||
| 53 | at91_register_uart(AT91SAM9260_ID_US1, 2, | ||
| 54 | ATMEL_UART_CTS | ATMEL_UART_RTS); | ||
| 55 | at91_register_uart(AT91SAM9260_ID_US2, 3, 0); | ||
| 56 | } | ||
| 57 | |||
| 58 | static void __init snapper9260_init_irq(void) | ||
| 59 | { | ||
| 60 | at91sam9260_init_interrupts(NULL); | ||
| 61 | } | ||
| 62 | |||
| 63 | static struct at91_usbh_data __initdata snapper9260_usbh_data = { | ||
| 64 | .ports = 2, | ||
| 65 | }; | ||
| 66 | |||
| 67 | static struct at91_udc_data __initdata snapper9260_udc_data = { | ||
| 68 | .vbus_pin = SNAPPER9260_IO_EXP_GPIO(5), | ||
| 69 | .vbus_active_low = 1, | ||
| 70 | .vbus_polled = 1, | ||
| 71 | }; | ||
| 72 | |||
| 73 | static struct at91_eth_data snapper9260_macb_data = { | ||
| 74 | .is_rmii = 1, | ||
| 75 | }; | ||
| 76 | |||
| 77 | static struct mtd_partition __initdata snapper9260_nand_partitions[] = { | ||
| 78 | { | ||
| 79 | .name = "Preboot", | ||
| 80 | .offset = 0, | ||
| 81 | .size = SZ_128K, | ||
| 82 | }, | ||
| 83 | { | ||
| 84 | .name = "Bootloader", | ||
| 85 | .offset = MTDPART_OFS_APPEND, | ||
| 86 | .size = SZ_256K, | ||
| 87 | }, | ||
| 88 | { | ||
| 89 | .name = "Environment", | ||
| 90 | .offset = MTDPART_OFS_APPEND, | ||
| 91 | .size = SZ_128K, | ||
| 92 | }, | ||
| 93 | { | ||
| 94 | .name = "Kernel", | ||
| 95 | .offset = MTDPART_OFS_APPEND, | ||
| 96 | .size = SZ_4M, | ||
| 97 | }, | ||
| 98 | { | ||
| 99 | .name = "Filesystem", | ||
| 100 | .offset = MTDPART_OFS_APPEND, | ||
| 101 | .size = MTDPART_SIZ_FULL, | ||
| 102 | }, | ||
| 103 | }; | ||
| 104 | |||
| 105 | static struct mtd_partition * __init | ||
| 106 | snapper9260_nand_partition_info(int size, int *num_partitions) | ||
| 107 | { | ||
| 108 | *num_partitions = ARRAY_SIZE(snapper9260_nand_partitions); | ||
| 109 | return snapper9260_nand_partitions; | ||
| 110 | } | ||
| 111 | |||
| 112 | static struct atmel_nand_data __initdata snapper9260_nand_data = { | ||
| 113 | .ale = 21, | ||
| 114 | .cle = 22, | ||
| 115 | .rdy_pin = AT91_PIN_PC13, | ||
| 116 | .partition_info = snapper9260_nand_partition_info, | ||
| 117 | .bus_width_16 = 0, | ||
| 118 | }; | ||
| 119 | |||
| 120 | static struct sam9_smc_config __initdata snapper9260_nand_smc_config = { | ||
| 121 | .ncs_read_setup = 0, | ||
| 122 | .nrd_setup = 0, | ||
| 123 | .ncs_write_setup = 0, | ||
| 124 | .nwe_setup = 0, | ||
| 125 | |||
| 126 | .ncs_read_pulse = 5, | ||
| 127 | .nrd_pulse = 2, | ||
| 128 | .ncs_write_pulse = 5, | ||
| 129 | .nwe_pulse = 2, | ||
| 130 | |||
| 131 | .read_cycle = 7, | ||
| 132 | .write_cycle = 7, | ||
| 133 | |||
| 134 | .mode = (AT91_SMC_READMODE | AT91_SMC_WRITEMODE | | ||
| 135 | AT91_SMC_EXNWMODE_DISABLE), | ||
| 136 | .tdf_cycles = 1, | ||
| 137 | }; | ||
| 138 | |||
| 139 | static struct pca953x_platform_data snapper9260_io_expander_data = { | ||
| 140 | .gpio_base = SNAPPER9260_IO_EXP_GPIO(0), | ||
| 141 | }; | ||
| 142 | |||
| 143 | static struct i2c_board_info __initdata snapper9260_i2c_devices[] = { | ||
| 144 | { | ||
| 145 | /* IO expander */ | ||
| 146 | I2C_BOARD_INFO("max7312", 0x28), | ||
| 147 | .platform_data = &snapper9260_io_expander_data, | ||
| 148 | }, | ||
| 149 | { | ||
| 150 | /* Audio codec */ | ||
| 151 | I2C_BOARD_INFO("tlv320aic23", 0x1a), | ||
| 152 | }, | ||
| 153 | { | ||
| 154 | /* RTC */ | ||
| 155 | I2C_BOARD_INFO("isl1208", 0x6f), | ||
| 156 | }, | ||
| 157 | }; | ||
| 158 | |||
| 159 | static void __init snapper9260_add_device_nand(void) | ||
| 160 | { | ||
| 161 | at91_set_A_periph(AT91_PIN_PC14, 0); | ||
| 162 | sam9_smc_configure(3, &snapper9260_nand_smc_config); | ||
| 163 | at91_add_device_nand(&snapper9260_nand_data); | ||
| 164 | } | ||
| 165 | |||
| 166 | static void __init snapper9260_board_init(void) | ||
| 167 | { | ||
| 168 | at91_add_device_i2c(snapper9260_i2c_devices, | ||
| 169 | ARRAY_SIZE(snapper9260_i2c_devices)); | ||
| 170 | at91_add_device_serial(); | ||
| 171 | at91_add_device_usbh(&snapper9260_usbh_data); | ||
| 172 | at91_add_device_udc(&snapper9260_udc_data); | ||
| 173 | at91_add_device_eth(&snapper9260_macb_data); | ||
| 174 | at91_add_device_ssc(AT91SAM9260_ID_SSC, (ATMEL_SSC_TF | ATMEL_SSC_TK | | ||
| 175 | ATMEL_SSC_TD | ATMEL_SSC_RD)); | ||
| 176 | snapper9260_add_device_nand(); | ||
| 177 | } | ||
| 178 | |||
| 179 | MACHINE_START(SNAPPER_9260, "Bluewater Systems Snapper 9260/9G20 module") | ||
| 180 | .phys_io = AT91_BASE_SYS, | ||
| 181 | .io_pg_offst = (AT91_VA_BASE_SYS >> 18) & 0xfffc, | ||
| 182 | .boot_params = AT91_SDRAM_BASE + 0x100, | ||
| 183 | .timer = &at91sam926x_timer, | ||
| 184 | .map_io = snapper9260_map_io, | ||
| 185 | .init_irq = snapper9260_init_irq, | ||
| 186 | .init_machine = snapper9260_board_init, | ||
| 187 | MACHINE_END | ||
| 188 | |||
| 189 | |||
diff --git a/arch/arm/mach-at91/include/mach/at91cap9.h b/arch/arm/mach-at91/include/mach/at91cap9.h index d8c1ededaa75..9c6af9737485 100644 --- a/arch/arm/mach-at91/include/mach/at91cap9.h +++ b/arch/arm/mach-at91/include/mach/at91cap9.h | |||
| @@ -84,7 +84,7 @@ | |||
| 84 | */ | 84 | */ |
| 85 | #define AT91_ECC (0xffffe200 - AT91_BASE_SYS) | 85 | #define AT91_ECC (0xffffe200 - AT91_BASE_SYS) |
| 86 | #define AT91_BCRAMC (0xffffe400 - AT91_BASE_SYS) | 86 | #define AT91_BCRAMC (0xffffe400 - AT91_BASE_SYS) |
| 87 | #define AT91_DDRSDRC (0xffffe600 - AT91_BASE_SYS) | 87 | #define AT91_DDRSDRC0 (0xffffe600 - AT91_BASE_SYS) |
| 88 | #define AT91_SMC (0xffffe800 - AT91_BASE_SYS) | 88 | #define AT91_SMC (0xffffe800 - AT91_BASE_SYS) |
| 89 | #define AT91_MATRIX (0xffffea00 - AT91_BASE_SYS) | 89 | #define AT91_MATRIX (0xffffea00 - AT91_BASE_SYS) |
| 90 | #define AT91_CCFG (0xffffeb10 - AT91_BASE_SYS) | 90 | #define AT91_CCFG (0xffffeb10 - AT91_BASE_SYS) |
diff --git a/arch/arm/mach-at91/include/mach/at91cap9_ddrsdr.h b/arch/arm/mach-at91/include/mach/at91cap9_ddrsdr.h index 1499b1cbffdd..976f4a6c3353 100644 --- a/arch/arm/mach-at91/include/mach/at91cap9_ddrsdr.h +++ b/arch/arm/mach-at91/include/mach/at91cap9_ddrsdr.h | |||
| @@ -15,7 +15,7 @@ | |||
| 15 | #ifndef AT91CAP9_DDRSDR_H | 15 | #ifndef AT91CAP9_DDRSDR_H |
| 16 | #define AT91CAP9_DDRSDR_H | 16 | #define AT91CAP9_DDRSDR_H |
| 17 | 17 | ||
| 18 | #define AT91_DDRSDRC_MR (AT91_DDRSDRC + 0x00) /* Mode Register */ | 18 | #define AT91_DDRSDRC_MR 0x00 /* Mode Register */ |
| 19 | #define AT91_DDRSDRC_MODE (0xf << 0) /* Command Mode */ | 19 | #define AT91_DDRSDRC_MODE (0xf << 0) /* Command Mode */ |
| 20 | #define AT91_DDRSDRC_MODE_NORMAL 0 | 20 | #define AT91_DDRSDRC_MODE_NORMAL 0 |
| 21 | #define AT91_DDRSDRC_MODE_NOP 1 | 21 | #define AT91_DDRSDRC_MODE_NOP 1 |
| @@ -25,10 +25,10 @@ | |||
| 25 | #define AT91_DDRSDRC_MODE_EXT_LMR 5 | 25 | #define AT91_DDRSDRC_MODE_EXT_LMR 5 |
| 26 | #define AT91_DDRSDRC_MODE_DEEP 6 | 26 | #define AT91_DDRSDRC_MODE_DEEP 6 |
| 27 | 27 | ||
| 28 | #define AT91_DDRSDRC_RTR (AT91_DDRSDRC + 0x04) /* Refresh Timer Register */ | 28 | #define AT91_DDRSDRC_RTR 0x04 /* Refresh Timer Register */ |
| 29 | #define AT91_DDRSDRC_COUNT (0xfff << 0) /* Refresh Timer Counter */ | 29 | #define AT91_DDRSDRC_COUNT (0xfff << 0) /* Refresh Timer Counter */ |
| 30 | 30 | ||
| 31 | #define AT91_DDRSDRC_CR (AT91_DDRSDRC + 0x08) /* Configuration Register */ | 31 | #define AT91_DDRSDRC_CR 0x08 /* Configuration Register */ |
| 32 | #define AT91_DDRSDRC_NC (3 << 0) /* Number of Column Bits */ | 32 | #define AT91_DDRSDRC_NC (3 << 0) /* Number of Column Bits */ |
| 33 | #define AT91_DDRSDRC_NC_SDR8 (0 << 0) | 33 | #define AT91_DDRSDRC_NC_SDR8 (0 << 0) |
| 34 | #define AT91_DDRSDRC_NC_SDR9 (1 << 0) | 34 | #define AT91_DDRSDRC_NC_SDR9 (1 << 0) |
| @@ -49,7 +49,7 @@ | |||
| 49 | #define AT91_DDRSDRC_DLL (1 << 7) /* Reset DLL */ | 49 | #define AT91_DDRSDRC_DLL (1 << 7) /* Reset DLL */ |
| 50 | #define AT91_DDRSDRC_DICDS (1 << 8) /* Output impedance control */ | 50 | #define AT91_DDRSDRC_DICDS (1 << 8) /* Output impedance control */ |
| 51 | 51 | ||
| 52 | #define AT91_DDRSDRC_T0PR (AT91_DDRSDRC + 0x0C) /* Timing 0 Register */ | 52 | #define AT91_DDRSDRC_T0PR 0x0C /* Timing 0 Register */ |
| 53 | #define AT91_DDRSDRC_TRAS (0xf << 0) /* Active to Precharge delay */ | 53 | #define AT91_DDRSDRC_TRAS (0xf << 0) /* Active to Precharge delay */ |
| 54 | #define AT91_DDRSDRC_TRCD (0xf << 4) /* Row to Column delay */ | 54 | #define AT91_DDRSDRC_TRCD (0xf << 4) /* Row to Column delay */ |
| 55 | #define AT91_DDRSDRC_TWR (0xf << 8) /* Write recovery delay */ | 55 | #define AT91_DDRSDRC_TWR (0xf << 8) /* Write recovery delay */ |
| @@ -59,13 +59,13 @@ | |||
| 59 | #define AT91_DDRSDRC_TWTR (1 << 24) /* Internal Write to Read delay */ | 59 | #define AT91_DDRSDRC_TWTR (1 << 24) /* Internal Write to Read delay */ |
| 60 | #define AT91_DDRSDRC_TMRD (0xf << 28) /* Load mode to active/refresh delay */ | 60 | #define AT91_DDRSDRC_TMRD (0xf << 28) /* Load mode to active/refresh delay */ |
| 61 | 61 | ||
| 62 | #define AT91_DDRSDRC_T1PR (AT91_DDRSDRC + 0x10) /* Timing 1 Register */ | 62 | #define AT91_DDRSDRC_T1PR 0x10 /* Timing 1 Register */ |
| 63 | #define AT91_DDRSDRC_TRFC (0x1f << 0) /* Row Cycle Delay */ | 63 | #define AT91_DDRSDRC_TRFC (0x1f << 0) /* Row Cycle Delay */ |
| 64 | #define AT91_DDRSDRC_TXSNR (0xff << 8) /* Exit self-refresh to non-read */ | 64 | #define AT91_DDRSDRC_TXSNR (0xff << 8) /* Exit self-refresh to non-read */ |
| 65 | #define AT91_DDRSDRC_TXSRD (0xff << 16) /* Exit self-refresh to read */ | 65 | #define AT91_DDRSDRC_TXSRD (0xff << 16) /* Exit self-refresh to read */ |
| 66 | #define AT91_DDRSDRC_TXP (0xf << 24) /* Exit power-down delay */ | 66 | #define AT91_DDRSDRC_TXP (0xf << 24) /* Exit power-down delay */ |
| 67 | 67 | ||
| 68 | #define AT91_DDRSDRC_LPR (AT91_DDRSDRC + 0x18) /* Low Power Register */ | 68 | #define AT91_DDRSDRC_LPR 0x18 /* Low Power Register */ |
| 69 | #define AT91_DDRSDRC_LPCB (3 << 0) /* Low-power Configurations */ | 69 | #define AT91_DDRSDRC_LPCB (3 << 0) /* Low-power Configurations */ |
| 70 | #define AT91_DDRSDRC_LPCB_DISABLE 0 | 70 | #define AT91_DDRSDRC_LPCB_DISABLE 0 |
| 71 | #define AT91_DDRSDRC_LPCB_SELF_REFRESH 1 | 71 | #define AT91_DDRSDRC_LPCB_SELF_REFRESH 1 |
| @@ -80,14 +80,14 @@ | |||
| 80 | #define AT91_DDRSDRC_TIMEOUT_64_CLK_CYCLES (1 << 12) | 80 | #define AT91_DDRSDRC_TIMEOUT_64_CLK_CYCLES (1 << 12) |
| 81 | #define AT91_DDRSDRC_TIMEOUT_128_CLK_CYCLES (2 << 12) | 81 | #define AT91_DDRSDRC_TIMEOUT_128_CLK_CYCLES (2 << 12) |
| 82 | 82 | ||
| 83 | #define AT91_DDRSDRC_MDR (AT91_DDRSDRC + 0x1C) /* Memory Device Register */ | 83 | #define AT91_DDRSDRC_MDR 0x1C /* Memory Device Register */ |
| 84 | #define AT91_DDRSDRC_MD (3 << 0) /* Memory Device Type */ | 84 | #define AT91_DDRSDRC_MD (3 << 0) /* Memory Device Type */ |
| 85 | #define AT91_DDRSDRC_MD_SDR 0 | 85 | #define AT91_DDRSDRC_MD_SDR 0 |
| 86 | #define AT91_DDRSDRC_MD_LOW_POWER_SDR 1 | 86 | #define AT91_DDRSDRC_MD_LOW_POWER_SDR 1 |
| 87 | #define AT91_DDRSDRC_MD_DDR 2 | 87 | #define AT91_DDRSDRC_MD_DDR 2 |
| 88 | #define AT91_DDRSDRC_MD_LOW_POWER_DDR 3 | 88 | #define AT91_DDRSDRC_MD_LOW_POWER_DDR 3 |
| 89 | 89 | ||
| 90 | #define AT91_DDRSDRC_DLLR (AT91_DDRSDRC + 0x20) /* DLL Information Register */ | 90 | #define AT91_DDRSDRC_DLLR 0x20 /* DLL Information Register */ |
| 91 | #define AT91_DDRSDRC_MDINC (1 << 0) /* Master Delay increment */ | 91 | #define AT91_DDRSDRC_MDINC (1 << 0) /* Master Delay increment */ |
| 92 | #define AT91_DDRSDRC_MDDEC (1 << 1) /* Master Delay decrement */ | 92 | #define AT91_DDRSDRC_MDDEC (1 << 1) /* Master Delay decrement */ |
| 93 | #define AT91_DDRSDRC_MDOVF (1 << 2) /* Master Delay Overflow */ | 93 | #define AT91_DDRSDRC_MDOVF (1 << 2) /* Master Delay Overflow */ |
| @@ -98,5 +98,11 @@ | |||
| 98 | #define AT91_DDRSDRC_SDVAL (0xff << 16) /* Slave Delay value */ | 98 | #define AT91_DDRSDRC_SDVAL (0xff << 16) /* Slave Delay value */ |
| 99 | #define AT91_DDRSDRC_SDCVAL (0xff << 24) /* Slave Delay Correction value */ | 99 | #define AT91_DDRSDRC_SDCVAL (0xff << 24) /* Slave Delay Correction value */ |
| 100 | 100 | ||
| 101 | /* Register access macros */ | ||
| 102 | #define at91_ramc_read(num, reg) \ | ||
| 103 | at91_sys_read(AT91_DDRSDRC##num + reg) | ||
| 104 | #define at91_ramc_write(num, reg, value) \ | ||
| 105 | at91_sys_write(AT91_DDRSDRC##num + reg, value) | ||
| 106 | |||
| 101 | 107 | ||
| 102 | #endif | 108 | #endif |
diff --git a/arch/arm/mach-at91/include/mach/at91sam9260.h b/arch/arm/mach-at91/include/mach/at91sam9260.h index 43c396b9b4cb..4e79036d3b80 100644 --- a/arch/arm/mach-at91/include/mach/at91sam9260.h +++ b/arch/arm/mach-at91/include/mach/at91sam9260.h | |||
| @@ -84,7 +84,7 @@ | |||
| 84 | * System Peripherals (offset from AT91_BASE_SYS) | 84 | * System Peripherals (offset from AT91_BASE_SYS) |
| 85 | */ | 85 | */ |
| 86 | #define AT91_ECC (0xffffe800 - AT91_BASE_SYS) | 86 | #define AT91_ECC (0xffffe800 - AT91_BASE_SYS) |
| 87 | #define AT91_SDRAMC (0xffffea00 - AT91_BASE_SYS) | 87 | #define AT91_SDRAMC0 (0xffffea00 - AT91_BASE_SYS) |
| 88 | #define AT91_SMC (0xffffec00 - AT91_BASE_SYS) | 88 | #define AT91_SMC (0xffffec00 - AT91_BASE_SYS) |
| 89 | #define AT91_MATRIX (0xffffee00 - AT91_BASE_SYS) | 89 | #define AT91_MATRIX (0xffffee00 - AT91_BASE_SYS) |
| 90 | #define AT91_CCFG (0xffffef10 - AT91_BASE_SYS) | 90 | #define AT91_CCFG (0xffffef10 - AT91_BASE_SYS) |
diff --git a/arch/arm/mach-at91/include/mach/at91sam9261.h b/arch/arm/mach-at91/include/mach/at91sam9261.h index 87de8be17484..2b5618518129 100644 --- a/arch/arm/mach-at91/include/mach/at91sam9261.h +++ b/arch/arm/mach-at91/include/mach/at91sam9261.h | |||
| @@ -68,7 +68,7 @@ | |||
| 68 | /* | 68 | /* |
| 69 | * System Peripherals (offset from AT91_BASE_SYS) | 69 | * System Peripherals (offset from AT91_BASE_SYS) |
| 70 | */ | 70 | */ |
| 71 | #define AT91_SDRAMC (0xffffea00 - AT91_BASE_SYS) | 71 | #define AT91_SDRAMC0 (0xffffea00 - AT91_BASE_SYS) |
| 72 | #define AT91_SMC (0xffffec00 - AT91_BASE_SYS) | 72 | #define AT91_SMC (0xffffec00 - AT91_BASE_SYS) |
| 73 | #define AT91_MATRIX (0xffffee00 - AT91_BASE_SYS) | 73 | #define AT91_MATRIX (0xffffee00 - AT91_BASE_SYS) |
| 74 | #define AT91_AIC (0xfffff000 - AT91_BASE_SYS) | 74 | #define AT91_AIC (0xfffff000 - AT91_BASE_SYS) |
diff --git a/arch/arm/mach-at91/include/mach/at91sam9_ddrsdr.h b/arch/arm/mach-at91/include/mach/at91sam9_ddrsdr.h new file mode 100644 index 000000000000..d27b15ba8ebf --- /dev/null +++ b/arch/arm/mach-at91/include/mach/at91sam9_ddrsdr.h | |||
| @@ -0,0 +1,130 @@ | |||
| 1 | /* | ||
| 2 | * Header file for the Atmel DDR/SDR SDRAM Controller | ||
| 3 | * | ||
| 4 | * Copyright (C) 2010 Atmel Corporation | ||
| 5 | * Nicolas Ferre <nicolas.ferre@atmel.com> | ||
| 6 | * | ||
| 7 | * This program is free software; you can redistribute it and/or modify | ||
| 8 | * it under the terms of the GNU General Public License as published by | ||
| 9 | * the Free Software Foundation; either version 2 of the License, or | ||
| 10 | * (at your option) any later version. | ||
| 11 | */ | ||
| 12 | #ifndef AT91SAM9_DDRSDR_H | ||
| 13 | #define AT91SAM9_DDRSDR_H | ||
| 14 | |||
| 15 | #define AT91_DDRSDRC_MR 0x00 /* Mode Register */ | ||
| 16 | #define AT91_DDRSDRC_MODE (0x7 << 0) /* Command Mode */ | ||
| 17 | #define AT91_DDRSDRC_MODE_NORMAL 0 | ||
| 18 | #define AT91_DDRSDRC_MODE_NOP 1 | ||
| 19 | #define AT91_DDRSDRC_MODE_PRECHARGE 2 | ||
| 20 | #define AT91_DDRSDRC_MODE_LMR 3 | ||
| 21 | #define AT91_DDRSDRC_MODE_REFRESH 4 | ||
| 22 | #define AT91_DDRSDRC_MODE_EXT_LMR 5 | ||
| 23 | #define AT91_DDRSDRC_MODE_DEEP 6 | ||
| 24 | |||
| 25 | #define AT91_DDRSDRC_RTR 0x04 /* Refresh Timer Register */ | ||
| 26 | #define AT91_DDRSDRC_COUNT (0xfff << 0) /* Refresh Timer Counter */ | ||
| 27 | |||
| 28 | #define AT91_DDRSDRC_CR 0x08 /* Configuration Register */ | ||
| 29 | #define AT91_DDRSDRC_NC (3 << 0) /* Number of Column Bits */ | ||
| 30 | #define AT91_DDRSDRC_NC_SDR8 (0 << 0) | ||
| 31 | #define AT91_DDRSDRC_NC_SDR9 (1 << 0) | ||
| 32 | #define AT91_DDRSDRC_NC_SDR10 (2 << 0) | ||
| 33 | #define AT91_DDRSDRC_NC_SDR11 (3 << 0) | ||
| 34 | #define AT91_DDRSDRC_NC_DDR9 (0 << 0) | ||
| 35 | #define AT91_DDRSDRC_NC_DDR10 (1 << 0) | ||
| 36 | #define AT91_DDRSDRC_NC_DDR11 (2 << 0) | ||
| 37 | #define AT91_DDRSDRC_NC_DDR12 (3 << 0) | ||
| 38 | #define AT91_DDRSDRC_NR (3 << 2) /* Number of Row Bits */ | ||
| 39 | #define AT91_DDRSDRC_NR_11 (0 << 2) | ||
| 40 | #define AT91_DDRSDRC_NR_12 (1 << 2) | ||
| 41 | #define AT91_DDRSDRC_NR_13 (2 << 2) | ||
| 42 | #define AT91_DDRSDRC_NR_14 (3 << 2) | ||
| 43 | #define AT91_DDRSDRC_CAS (7 << 4) /* CAS Latency */ | ||
| 44 | #define AT91_DDRSDRC_CAS_2 (2 << 4) | ||
| 45 | #define AT91_DDRSDRC_CAS_3 (3 << 4) | ||
| 46 | #define AT91_DDRSDRC_CAS_25 (6 << 4) | ||
| 47 | #define AT91_DDRSDRC_RST_DLL (1 << 7) /* Reset DLL */ | ||
| 48 | #define AT91_DDRSDRC_DICDS (1 << 8) /* Output impedance control */ | ||
| 49 | #define AT91_DDRSDRC_DIS_DLL (1 << 9) /* Disable DLL */ | ||
| 50 | #define AT91_DDRSDRC_OCD (1 << 12) /* Off-Chip Driver */ | ||
| 51 | #define AT91_DDRSDRC_DQMS (1 << 16) /* Mask Data is Shared */ | ||
| 52 | #define AT91_DDRSDRC_ACTBST (1 << 18) /* Active Bank X to Burst Stop Read Access Bank Y */ | ||
| 53 | |||
| 54 | #define AT91_DDRSDRC_T0PR 0x0C /* Timing 0 Register */ | ||
| 55 | #define AT91_DDRSDRC_TRAS (0xf << 0) /* Active to Precharge delay */ | ||
| 56 | #define AT91_DDRSDRC_TRCD (0xf << 4) /* Row to Column delay */ | ||
| 57 | #define AT91_DDRSDRC_TWR (0xf << 8) /* Write recovery delay */ | ||
| 58 | #define AT91_DDRSDRC_TRC (0xf << 12) /* Row cycle delay */ | ||
| 59 | #define AT91_DDRSDRC_TRP (0xf << 16) /* Row precharge delay */ | ||
| 60 | #define AT91_DDRSDRC_TRRD (0xf << 20) /* Active BankA to BankB */ | ||
| 61 | #define AT91_DDRSDRC_TWTR (0x7 << 24) /* Internal Write to Read delay */ | ||
| 62 | #define AT91_DDRSDRC_RED_WRRD (0x1 << 27) /* Reduce Write to Read Delay */ | ||
| 63 | #define AT91_DDRSDRC_TMRD (0xf << 28) /* Load mode to active/refresh delay */ | ||
| 64 | |||
| 65 | #define AT91_DDRSDRC_T1PR 0x10 /* Timing 1 Register */ | ||
| 66 | #define AT91_DDRSDRC_TRFC (0x1f << 0) /* Row Cycle Delay */ | ||
| 67 | #define AT91_DDRSDRC_TXSNR (0xff << 8) /* Exit self-refresh to non-read */ | ||
| 68 | #define AT91_DDRSDRC_TXSRD (0xff << 16) /* Exit self-refresh to read */ | ||
| 69 | #define AT91_DDRSDRC_TXP (0xf << 24) /* Exit power-down delay */ | ||
| 70 | |||
| 71 | #define AT91_DDRSDRC_T2PR 0x14 /* Timing 2 Register */ | ||
| 72 | #define AT91_DDRSDRC_TXARD (0xf << 0) /* Exit active power down delay to read command in mode "Fast Exit" */ | ||
| 73 | #define AT91_DDRSDRC_TXARDS (0xf << 4) /* Exit active power down delay to read command in mode "Slow Exit" */ | ||
| 74 | #define AT91_DDRSDRC_TRPA (0xf << 8) /* Row Precharge All delay */ | ||
| 75 | #define AT91_DDRSDRC_TRTP (0x7 << 12) /* Read to Precharge delay */ | ||
| 76 | |||
| 77 | #define AT91_DDRSDRC_LPR 0x1C /* Low Power Register */ | ||
| 78 | #define AT91_DDRSDRC_LPCB (3 << 0) /* Low-power Configurations */ | ||
| 79 | #define AT91_DDRSDRC_LPCB_DISABLE 0 | ||
| 80 | #define AT91_DDRSDRC_LPCB_SELF_REFRESH 1 | ||
| 81 | #define AT91_DDRSDRC_LPCB_POWER_DOWN 2 | ||
| 82 | #define AT91_DDRSDRC_LPCB_DEEP_POWER_DOWN 3 | ||
| 83 | #define AT91_DDRSDRC_CLKFR (1 << 2) /* Clock Frozen */ | ||
| 84 | #define AT91_DDRSDRC_PASR (7 << 4) /* Partial Array Self Refresh */ | ||
| 85 | #define AT91_DDRSDRC_TCSR (3 << 8) /* Temperature Compensated Self Refresh */ | ||
| 86 | #define AT91_DDRSDRC_DS (3 << 10) /* Drive Strength */ | ||
| 87 | #define AT91_DDRSDRC_TIMEOUT (3 << 12) /* Time to define when Low Power Mode is enabled */ | ||
| 88 | #define AT91_DDRSDRC_TIMEOUT_0_CLK_CYCLES (0 << 12) | ||
| 89 | #define AT91_DDRSDRC_TIMEOUT_64_CLK_CYCLES (1 << 12) | ||
| 90 | #define AT91_DDRSDRC_TIMEOUT_128_CLK_CYCLES (2 << 12) | ||
| 91 | #define AT91_DDRSDRC_APDE (1 << 16) /* Active power down exit time */ | ||
| 92 | #define AT91_DDRSDRC_UPD_MR (3 << 20) /* Update load mode register and extended mode register */ | ||
| 93 | |||
| 94 | #define AT91_DDRSDRC_MDR 0x20 /* Memory Device Register */ | ||
| 95 | #define AT91_DDRSDRC_MD (3 << 0) /* Memory Device Type */ | ||
| 96 | #define AT91_DDRSDRC_MD_SDR 0 | ||
| 97 | #define AT91_DDRSDRC_MD_LOW_POWER_SDR 1 | ||
| 98 | #define AT91_DDRSDRC_MD_LOW_POWER_DDR 3 | ||
| 99 | #define AT91_DDRSDRC_MD_DDR2 6 | ||
| 100 | #define AT91_DDRSDRC_DBW (1 << 4) /* Data Bus Width */ | ||
| 101 | #define AT91_DDRSDRC_DBW_32BITS (0 << 4) | ||
| 102 | #define AT91_DDRSDRC_DBW_16BITS (1 << 4) | ||
| 103 | |||
| 104 | #define AT91_DDRSDRC_DLL 0x24 /* DLL Information Register */ | ||
| 105 | #define AT91_DDRSDRC_MDINC (1 << 0) /* Master Delay increment */ | ||
| 106 | #define AT91_DDRSDRC_MDDEC (1 << 1) /* Master Delay decrement */ | ||
| 107 | #define AT91_DDRSDRC_MDOVF (1 << 2) /* Master Delay Overflow */ | ||
| 108 | #define AT91_DDRSDRC_MDVAL (0xff << 8) /* Master Delay value */ | ||
| 109 | |||
| 110 | #define AT91_DDRSDRC_HS 0x2C /* High Speed Register */ | ||
| 111 | #define AT91_DDRSDRC_DIS_ATCP_RD (1 << 2) /* Anticip read access is disabled */ | ||
| 112 | |||
| 113 | #define AT91_DDRSDRC_DELAY(n) (0x30 + (0x4 * (n))) /* Delay I/O Register n */ | ||
| 114 | |||
| 115 | #define AT91_DDRSDRC_WPMR 0xE4 /* Write Protect Mode Register */ | ||
| 116 | #define AT91_DDRSDRC_WP (1 << 0) /* Write protect enable */ | ||
| 117 | #define AT91_DDRSDRC_WPKEY (0xffffff << 8) /* Write protect key */ | ||
| 118 | #define AT91_DDRSDRC_KEY (0x444452 << 8) /* Write protect key = "DDR" */ | ||
| 119 | |||
| 120 | #define AT91_DDRSDRC_WPSR 0xE8 /* Write Protect Status Register */ | ||
| 121 | #define AT91_DDRSDRC_WPVS (1 << 0) /* Write protect violation status */ | ||
| 122 | #define AT91_DDRSDRC_WPVSRC (0xffff << 8) /* Write protect violation source */ | ||
| 123 | |||
| 124 | /* Register access macros */ | ||
| 125 | #define at91_ramc_read(num, reg) \ | ||
| 126 | at91_sys_read(AT91_DDRSDRC##num + reg) | ||
| 127 | #define at91_ramc_write(num, reg, value) \ | ||
| 128 | at91_sys_write(AT91_DDRSDRC##num + reg, value) | ||
| 129 | |||
| 130 | #endif | ||
diff --git a/arch/arm/mach-at91/include/mach/at91sam9_sdramc.h b/arch/arm/mach-at91/include/mach/at91sam9_sdramc.h index b7260389f7ca..100f5a592926 100644 --- a/arch/arm/mach-at91/include/mach/at91sam9_sdramc.h +++ b/arch/arm/mach-at91/include/mach/at91sam9_sdramc.h | |||
| @@ -17,7 +17,7 @@ | |||
| 17 | #define AT91SAM9_SDRAMC_H | 17 | #define AT91SAM9_SDRAMC_H |
| 18 | 18 | ||
| 19 | /* SDRAM Controller (SDRAMC) registers */ | 19 | /* SDRAM Controller (SDRAMC) registers */ |
| 20 | #define AT91_SDRAMC_MR (AT91_SDRAMC + 0x00) /* SDRAM Controller Mode Register */ | 20 | #define AT91_SDRAMC_MR 0x00 /* SDRAM Controller Mode Register */ |
| 21 | #define AT91_SDRAMC_MODE (0xf << 0) /* Command Mode */ | 21 | #define AT91_SDRAMC_MODE (0xf << 0) /* Command Mode */ |
| 22 | #define AT91_SDRAMC_MODE_NORMAL 0 | 22 | #define AT91_SDRAMC_MODE_NORMAL 0 |
| 23 | #define AT91_SDRAMC_MODE_NOP 1 | 23 | #define AT91_SDRAMC_MODE_NOP 1 |
| @@ -27,10 +27,10 @@ | |||
| 27 | #define AT91_SDRAMC_MODE_EXT_LMR 5 | 27 | #define AT91_SDRAMC_MODE_EXT_LMR 5 |
| 28 | #define AT91_SDRAMC_MODE_DEEP 6 | 28 | #define AT91_SDRAMC_MODE_DEEP 6 |
| 29 | 29 | ||
| 30 | #define AT91_SDRAMC_TR (AT91_SDRAMC + 0x04) /* SDRAM Controller Refresh Timer Register */ | 30 | #define AT91_SDRAMC_TR 0x04 /* SDRAM Controller Refresh Timer Register */ |
| 31 | #define AT91_SDRAMC_COUNT (0xfff << 0) /* Refresh Timer Counter */ | 31 | #define AT91_SDRAMC_COUNT (0xfff << 0) /* Refresh Timer Counter */ |
| 32 | 32 | ||
| 33 | #define AT91_SDRAMC_CR (AT91_SDRAMC + 0x08) /* SDRAM Controller Configuration Register */ | 33 | #define AT91_SDRAMC_CR 0x08 /* SDRAM Controller Configuration Register */ |
| 34 | #define AT91_SDRAMC_NC (3 << 0) /* Number of Column Bits */ | 34 | #define AT91_SDRAMC_NC (3 << 0) /* Number of Column Bits */ |
| 35 | #define AT91_SDRAMC_NC_8 (0 << 0) | 35 | #define AT91_SDRAMC_NC_8 (0 << 0) |
| 36 | #define AT91_SDRAMC_NC_9 (1 << 0) | 36 | #define AT91_SDRAMC_NC_9 (1 << 0) |
| @@ -57,7 +57,7 @@ | |||
| 57 | #define AT91_SDRAMC_TRAS (0xf << 24) /* Active to Precharge Delay */ | 57 | #define AT91_SDRAMC_TRAS (0xf << 24) /* Active to Precharge Delay */ |
| 58 | #define AT91_SDRAMC_TXSR (0xf << 28) /* Exit Self Refresh to Active Delay */ | 58 | #define AT91_SDRAMC_TXSR (0xf << 28) /* Exit Self Refresh to Active Delay */ |
| 59 | 59 | ||
| 60 | #define AT91_SDRAMC_LPR (AT91_SDRAMC + 0x10) /* SDRAM Controller Low Power Register */ | 60 | #define AT91_SDRAMC_LPR 0x10 /* SDRAM Controller Low Power Register */ |
| 61 | #define AT91_SDRAMC_LPCB (3 << 0) /* Low-power Configurations */ | 61 | #define AT91_SDRAMC_LPCB (3 << 0) /* Low-power Configurations */ |
| 62 | #define AT91_SDRAMC_LPCB_DISABLE 0 | 62 | #define AT91_SDRAMC_LPCB_DISABLE 0 |
| 63 | #define AT91_SDRAMC_LPCB_SELF_REFRESH 1 | 63 | #define AT91_SDRAMC_LPCB_SELF_REFRESH 1 |
| @@ -71,16 +71,21 @@ | |||
| 71 | #define AT91_SDRAMC_TIMEOUT_64_CLK_CYCLES (1 << 12) | 71 | #define AT91_SDRAMC_TIMEOUT_64_CLK_CYCLES (1 << 12) |
| 72 | #define AT91_SDRAMC_TIMEOUT_128_CLK_CYCLES (2 << 12) | 72 | #define AT91_SDRAMC_TIMEOUT_128_CLK_CYCLES (2 << 12) |
| 73 | 73 | ||
| 74 | #define AT91_SDRAMC_IER (AT91_SDRAMC + 0x14) /* SDRAM Controller Interrupt Enable Register */ | 74 | #define AT91_SDRAMC_IER 0x14 /* SDRAM Controller Interrupt Enable Register */ |
| 75 | #define AT91_SDRAMC_IDR (AT91_SDRAMC + 0x18) /* SDRAM Controller Interrupt Disable Register */ | 75 | #define AT91_SDRAMC_IDR 0x18 /* SDRAM Controller Interrupt Disable Register */ |
| 76 | #define AT91_SDRAMC_IMR (AT91_SDRAMC + 0x1C) /* SDRAM Controller Interrupt Mask Register */ | 76 | #define AT91_SDRAMC_IMR 0x1C /* SDRAM Controller Interrupt Mask Register */ |
| 77 | #define AT91_SDRAMC_ISR (AT91_SDRAMC + 0x20) /* SDRAM Controller Interrupt Status Register */ | 77 | #define AT91_SDRAMC_ISR 0x20 /* SDRAM Controller Interrupt Status Register */ |
| 78 | #define AT91_SDRAMC_RES (1 << 0) /* Refresh Error Status */ | 78 | #define AT91_SDRAMC_RES (1 << 0) /* Refresh Error Status */ |
| 79 | 79 | ||
| 80 | #define AT91_SDRAMC_MDR (AT91_SDRAMC + 0x24) /* SDRAM Memory Device Register */ | 80 | #define AT91_SDRAMC_MDR 0x24 /* SDRAM Memory Device Register */ |
| 81 | #define AT91_SDRAMC_MD (3 << 0) /* Memory Device Type */ | 81 | #define AT91_SDRAMC_MD (3 << 0) /* Memory Device Type */ |
| 82 | #define AT91_SDRAMC_MD_SDRAM 0 | 82 | #define AT91_SDRAMC_MD_SDRAM 0 |
| 83 | #define AT91_SDRAMC_MD_LOW_POWER_SDRAM 1 | 83 | #define AT91_SDRAMC_MD_LOW_POWER_SDRAM 1 |
| 84 | 84 | ||
| 85 | /* Register access macros */ | ||
| 86 | #define at91_ramc_read(num, reg) \ | ||
| 87 | at91_sys_read(AT91_SDRAMC##num + reg) | ||
| 88 | #define at91_ramc_write(num, reg, value) \ | ||
| 89 | at91_sys_write(AT91_SDRAMC##num + reg, value) | ||
| 85 | 90 | ||
| 86 | #endif | 91 | #endif |
diff --git a/arch/arm/mach-at91/include/mach/at91sam9rl.h b/arch/arm/mach-at91/include/mach/at91sam9rl.h index fc2de6c09c86..87ba8517ad98 100644 --- a/arch/arm/mach-at91/include/mach/at91sam9rl.h +++ b/arch/arm/mach-at91/include/mach/at91sam9rl.h | |||
| @@ -74,7 +74,7 @@ | |||
| 74 | */ | 74 | */ |
| 75 | #define AT91_DMA (0xffffe600 - AT91_BASE_SYS) | 75 | #define AT91_DMA (0xffffe600 - AT91_BASE_SYS) |
| 76 | #define AT91_ECC (0xffffe800 - AT91_BASE_SYS) | 76 | #define AT91_ECC (0xffffe800 - AT91_BASE_SYS) |
| 77 | #define AT91_SDRAMC (0xffffea00 - AT91_BASE_SYS) | 77 | #define AT91_SDRAMC0 (0xffffea00 - AT91_BASE_SYS) |
| 78 | #define AT91_SMC (0xffffec00 - AT91_BASE_SYS) | 78 | #define AT91_SMC (0xffffec00 - AT91_BASE_SYS) |
| 79 | #define AT91_MATRIX (0xffffee00 - AT91_BASE_SYS) | 79 | #define AT91_MATRIX (0xffffee00 - AT91_BASE_SYS) |
| 80 | #define AT91_CCFG (0xffffef10 - AT91_BASE_SYS) | 80 | #define AT91_CCFG (0xffffef10 - AT91_BASE_SYS) |
diff --git a/arch/arm/mach-at91/include/mach/board.h b/arch/arm/mach-at91/include/mach/board.h index df2ed848c9f8..58528aa9c8a8 100644 --- a/arch/arm/mach-at91/include/mach/board.h +++ b/arch/arm/mach-at91/include/mach/board.h | |||
| @@ -44,6 +44,8 @@ | |||
| 44 | /* USB Device */ | 44 | /* USB Device */ |
| 45 | struct at91_udc_data { | 45 | struct at91_udc_data { |
| 46 | u8 vbus_pin; /* high == host powering us */ | 46 | u8 vbus_pin; /* high == host powering us */ |
| 47 | u8 vbus_active_low; /* vbus polarity */ | ||
| 48 | u8 vbus_polled; /* Use polling, not interrupt */ | ||
| 47 | u8 pullup_pin; /* active == D+ pulled up */ | 49 | u8 pullup_pin; /* active == D+ pulled up */ |
| 48 | u8 pullup_active_low; /* true == pullup_pin is active low */ | 50 | u8 pullup_active_low; /* true == pullup_pin is active low */ |
| 49 | }; | 51 | }; |
diff --git a/arch/arm/mach-at91/include/mach/cpu.h b/arch/arm/mach-at91/include/mach/cpu.h index 833659d1200a..3bef931d0b1c 100644 --- a/arch/arm/mach-at91/include/mach/cpu.h +++ b/arch/arm/mach-at91/include/mach/cpu.h | |||
| @@ -52,6 +52,7 @@ static inline unsigned long at91_cpu_fully_identify(void) | |||
| 52 | 52 | ||
| 53 | #define ARCH_EXID_AT91SAM9M11 0x00000001 | 53 | #define ARCH_EXID_AT91SAM9M11 0x00000001 |
| 54 | #define ARCH_EXID_AT91SAM9M10 0x00000002 | 54 | #define ARCH_EXID_AT91SAM9M10 0x00000002 |
| 55 | #define ARCH_EXID_AT91SAM9G46 0x00000003 | ||
| 55 | #define ARCH_EXID_AT91SAM9G45 0x00000004 | 56 | #define ARCH_EXID_AT91SAM9G45 0x00000004 |
| 56 | 57 | ||
| 57 | static inline unsigned long at91_exid_identify(void) | 58 | static inline unsigned long at91_exid_identify(void) |
| @@ -128,9 +129,18 @@ static inline unsigned long at91cap9_rev_identify(void) | |||
| 128 | #ifdef CONFIG_ARCH_AT91SAM9G45 | 129 | #ifdef CONFIG_ARCH_AT91SAM9G45 |
| 129 | #define cpu_is_at91sam9g45() (at91_cpu_identify() == ARCH_ID_AT91SAM9G45) | 130 | #define cpu_is_at91sam9g45() (at91_cpu_identify() == ARCH_ID_AT91SAM9G45) |
| 130 | #define cpu_is_at91sam9g45es() (at91_cpu_fully_identify() == ARCH_ID_AT91SAM9G45ES) | 131 | #define cpu_is_at91sam9g45es() (at91_cpu_fully_identify() == ARCH_ID_AT91SAM9G45ES) |
| 132 | #define cpu_is_at91sam9m10() (cpu_is_at91sam9g45() && \ | ||
| 133 | (at91_exid_identify() == ARCH_EXID_AT91SAM9M10)) | ||
| 134 | #define cpu_is_at91sam9m46() (cpu_is_at91sam9g45() && \ | ||
| 135 | (at91_exid_identify() == ARCH_EXID_AT91SAM9G46)) | ||
| 136 | #define cpu_is_at91sam9m11() (cpu_is_at91sam9g45() && \ | ||
| 137 | (at91_exid_identify() == ARCH_EXID_AT91SAM9M11)) | ||
| 131 | #else | 138 | #else |
| 132 | #define cpu_is_at91sam9g45() (0) | 139 | #define cpu_is_at91sam9g45() (0) |
| 133 | #define cpu_is_at91sam9g45es() (0) | 140 | #define cpu_is_at91sam9g45es() (0) |
| 141 | #define cpu_is_at91sam9m10() (0) | ||
| 142 | #define cpu_is_at91sam9g46() (0) | ||
| 143 | #define cpu_is_at91sam9m11() (0) | ||
| 134 | #endif | 144 | #endif |
| 135 | 145 | ||
| 136 | #ifdef CONFIG_ARCH_AT91CAP9 | 146 | #ifdef CONFIG_ARCH_AT91CAP9 |
diff --git a/arch/arm/mach-at91/include/mach/gpio.h b/arch/arm/mach-at91/include/mach/gpio.h index 04c91e31c9c5..bfdd8ab26dc8 100644 --- a/arch/arm/mach-at91/include/mach/gpio.h +++ b/arch/arm/mach-at91/include/mach/gpio.h | |||
| @@ -19,6 +19,7 @@ | |||
| 19 | #define PIN_BASE NR_AIC_IRQS | 19 | #define PIN_BASE NR_AIC_IRQS |
| 20 | 20 | ||
| 21 | #define MAX_GPIO_BANKS 5 | 21 | #define MAX_GPIO_BANKS 5 |
| 22 | #define NR_BUILTIN_GPIO (PIN_BASE + (MAX_GPIO_BANKS * 32)) | ||
| 22 | 23 | ||
| 23 | /* these pin numbers double as IRQ numbers, like AT91xxx_ID_* values */ | 24 | /* these pin numbers double as IRQ numbers, like AT91xxx_ID_* values */ |
| 24 | 25 | ||
diff --git a/arch/arm/mach-at91/pm.h b/arch/arm/mach-at91/pm.h index 08322c44df1a..8c87d0c1b8f8 100644 --- a/arch/arm/mach-at91/pm.h +++ b/arch/arm/mach-at91/pm.h | |||
| @@ -30,14 +30,50 @@ static inline u32 sdram_selfrefresh_enable(void) | |||
| 30 | { | 30 | { |
| 31 | u32 saved_lpr, lpr; | 31 | u32 saved_lpr, lpr; |
| 32 | 32 | ||
| 33 | saved_lpr = at91_sys_read(AT91_DDRSDRC_LPR); | 33 | saved_lpr = at91_ramc_read(0, AT91_DDRSDRC_LPR); |
| 34 | 34 | ||
| 35 | lpr = saved_lpr & ~AT91_DDRSDRC_LPCB; | 35 | lpr = saved_lpr & ~AT91_DDRSDRC_LPCB; |
| 36 | at91_sys_write(AT91_DDRSDRC_LPR, lpr | AT91_DDRSDRC_LPCB_SELF_REFRESH); | 36 | at91_ramc_write(0, AT91_DDRSDRC_LPR, lpr | AT91_DDRSDRC_LPCB_SELF_REFRESH); |
| 37 | return saved_lpr; | 37 | return saved_lpr; |
| 38 | } | 38 | } |
| 39 | 39 | ||
| 40 | #define sdram_selfrefresh_disable(saved_lpr) at91_sys_write(AT91_DDRSDRC_LPR, saved_lpr) | 40 | #define sdram_selfrefresh_disable(saved_lpr) at91_ramc_write(0, AT91_DDRSDRC_LPR, saved_lpr) |
| 41 | |||
| 42 | #elif defined(CONFIG_ARCH_AT91SAM9G45) | ||
| 43 | #include <mach/at91sam9_ddrsdr.h> | ||
| 44 | |||
| 45 | /* We manage both DDRAM/SDRAM controllers, we need more than one value to | ||
| 46 | * remember. | ||
| 47 | */ | ||
| 48 | static u32 saved_lpr1; | ||
| 49 | |||
| 50 | static inline u32 sdram_selfrefresh_enable(void) | ||
| 51 | { | ||
| 52 | /* Those tow values allow us to delay self-refresh activation | ||
| 53 | * to the maximum. */ | ||
| 54 | u32 lpr0, lpr1; | ||
| 55 | u32 saved_lpr0; | ||
| 56 | |||
| 57 | saved_lpr1 = at91_ramc_read(1, AT91_DDRSDRC_LPR); | ||
| 58 | lpr1 = saved_lpr1 & ~AT91_DDRSDRC_LPCB; | ||
| 59 | lpr1 |= AT91_DDRSDRC_LPCB_SELF_REFRESH; | ||
| 60 | |||
| 61 | saved_lpr0 = at91_ramc_read(0, AT91_DDRSDRC_LPR); | ||
| 62 | lpr0 = saved_lpr0 & ~AT91_DDRSDRC_LPCB; | ||
| 63 | lpr0 |= AT91_DDRSDRC_LPCB_SELF_REFRESH; | ||
| 64 | |||
| 65 | /* self-refresh mode now */ | ||
| 66 | at91_ramc_write(0, AT91_DDRSDRC_LPR, lpr0); | ||
| 67 | at91_ramc_write(1, AT91_DDRSDRC_LPR, lpr1); | ||
| 68 | |||
| 69 | return saved_lpr0; | ||
| 70 | } | ||
| 71 | |||
| 72 | #define sdram_selfrefresh_disable(saved_lpr0) \ | ||
| 73 | do { \ | ||
| 74 | at91_ramc_write(0, AT91_DDRSDRC_LPR, saved_lpr0); \ | ||
| 75 | at91_ramc_write(1, AT91_DDRSDRC_LPR, saved_lpr1); \ | ||
| 76 | } while (0) | ||
| 41 | 77 | ||
| 42 | #else | 78 | #else |
| 43 | #include <mach/at91sam9_sdramc.h> | 79 | #include <mach/at91sam9_sdramc.h> |
| @@ -47,7 +83,6 @@ static inline u32 sdram_selfrefresh_enable(void) | |||
| 47 | * FIXME either or both the SDRAM controllers (EB0, EB1) might be in use; | 83 | * FIXME either or both the SDRAM controllers (EB0, EB1) might be in use; |
| 48 | * handle those cases both here and in the Suspend-To-RAM support. | 84 | * handle those cases both here and in the Suspend-To-RAM support. |
| 49 | */ | 85 | */ |
| 50 | #define AT91_SDRAMC AT91_SDRAMC0 | ||
| 51 | #warning Assuming EB1 SDRAM controller is *NOT* used | 86 | #warning Assuming EB1 SDRAM controller is *NOT* used |
| 52 | #endif | 87 | #endif |
| 53 | 88 | ||
| @@ -55,13 +90,13 @@ static inline u32 sdram_selfrefresh_enable(void) | |||
| 55 | { | 90 | { |
| 56 | u32 saved_lpr, lpr; | 91 | u32 saved_lpr, lpr; |
| 57 | 92 | ||
| 58 | saved_lpr = at91_sys_read(AT91_SDRAMC_LPR); | 93 | saved_lpr = at91_ramc_read(0, AT91_SDRAMC_LPR); |
| 59 | 94 | ||
| 60 | lpr = saved_lpr & ~AT91_SDRAMC_LPCB; | 95 | lpr = saved_lpr & ~AT91_SDRAMC_LPCB; |
| 61 | at91_sys_write(AT91_SDRAMC_LPR, lpr | AT91_SDRAMC_LPCB_SELF_REFRESH); | 96 | at91_ramc_write(0, AT91_SDRAMC_LPR, lpr | AT91_SDRAMC_LPCB_SELF_REFRESH); |
| 62 | return saved_lpr; | 97 | return saved_lpr; |
| 63 | } | 98 | } |
| 64 | 99 | ||
| 65 | #define sdram_selfrefresh_disable(saved_lpr) at91_sys_write(AT91_SDRAMC_LPR, saved_lpr) | 100 | #define sdram_selfrefresh_disable(saved_lpr) at91_ramc_write(0, AT91_SDRAMC_LPR, saved_lpr) |
| 66 | 101 | ||
| 67 | #endif | 102 | #endif |
diff --git a/arch/arm/mach-at91/pm_slowclock.S b/arch/arm/mach-at91/pm_slowclock.S index 9c5b48e68a71..b6b00a1f6125 100644 --- a/arch/arm/mach-at91/pm_slowclock.S +++ b/arch/arm/mach-at91/pm_slowclock.S | |||
| @@ -16,10 +16,12 @@ | |||
| 16 | #include <mach/hardware.h> | 16 | #include <mach/hardware.h> |
| 17 | #include <mach/at91_pmc.h> | 17 | #include <mach/at91_pmc.h> |
| 18 | 18 | ||
| 19 | #ifdef CONFIG_ARCH_AT91RM9200 | 19 | #if defined(CONFIG_ARCH_AT91RM9200) |
| 20 | #include <mach/at91rm9200_mc.h> | 20 | #include <mach/at91rm9200_mc.h> |
| 21 | #elif defined(CONFIG_ARCH_AT91CAP9) | 21 | #elif defined(CONFIG_ARCH_AT91CAP9) |
| 22 | #include <mach/at91cap9_ddrsdr.h> | 22 | #include <mach/at91cap9_ddrsdr.h> |
| 23 | #elif defined(CONFIG_ARCH_AT91SAM9G45) | ||
| 24 | #include <mach/at91sam9_ddrsdr.h> | ||
| 23 | #else | 25 | #else |
| 24 | #include <mach/at91sam9_sdramc.h> | 26 | #include <mach/at91sam9_sdramc.h> |
| 25 | #endif | 27 | #endif |
| @@ -30,7 +32,6 @@ | |||
| 30 | * FIXME either or both the SDRAM controllers (EB0, EB1) might be in use; | 32 | * FIXME either or both the SDRAM controllers (EB0, EB1) might be in use; |
| 31 | * handle those cases both here and in the Suspend-To-RAM support. | 33 | * handle those cases both here and in the Suspend-To-RAM support. |
| 32 | */ | 34 | */ |
| 33 | #define AT91_SDRAMC AT91_SDRAMC0 | ||
| 34 | #warning Assuming EB1 SDRAM controller is *NOT* used | 35 | #warning Assuming EB1 SDRAM controller is *NOT* used |
| 35 | #endif | 36 | #endif |
| 36 | 37 | ||
| @@ -113,12 +114,14 @@ ENTRY(at91_slow_clock) | |||
| 113 | /* | 114 | /* |
| 114 | * Register usage: | 115 | * Register usage: |
| 115 | * R1 = Base address of AT91_PMC | 116 | * R1 = Base address of AT91_PMC |
| 116 | * R2 = Base address of AT91_SDRAMC (or AT91_SYS on AT91RM9200) | 117 | * R2 = Base address of RAM Controller (SDRAM, DDRSDR, or AT91_SYS) |
| 117 | * R3 = temporary register | 118 | * R3 = temporary register |
| 118 | * R4 = temporary register | 119 | * R4 = temporary register |
| 120 | * R5 = Base address of second RAM Controller or 0 if not present | ||
| 119 | */ | 121 | */ |
| 120 | ldr r1, .at91_va_base_pmc | 122 | ldr r1, .at91_va_base_pmc |
| 121 | ldr r2, .at91_va_base_sdramc | 123 | ldr r2, .at91_va_base_sdramc |
| 124 | ldr r5, .at91_va_base_ramc1 | ||
| 122 | 125 | ||
| 123 | /* Drain write buffer */ | 126 | /* Drain write buffer */ |
| 124 | mcr p15, 0, r0, c7, c10, 4 | 127 | mcr p15, 0, r0, c7, c10, 4 |
| @@ -127,20 +130,33 @@ ENTRY(at91_slow_clock) | |||
| 127 | /* Put SDRAM in self-refresh mode */ | 130 | /* Put SDRAM in self-refresh mode */ |
| 128 | mov r3, #1 | 131 | mov r3, #1 |
| 129 | str r3, [r2, #AT91_SDRAMC_SRR] | 132 | str r3, [r2, #AT91_SDRAMC_SRR] |
| 130 | #elif defined(CONFIG_ARCH_AT91CAP9) | 133 | #elif defined(CONFIG_ARCH_AT91CAP9) \ |
| 131 | /* Enable SDRAM self-refresh mode */ | 134 | || defined(CONFIG_ARCH_AT91SAM9G45) |
| 132 | ldr r3, [r2, #AT91_DDRSDRC_LPR - AT91_DDRSDRC] | ||
| 133 | str r3, .saved_sam9_lpr | ||
| 134 | 135 | ||
| 135 | mov r3, #AT91_DDRSDRC_LPCB_SELF_REFRESH | 136 | /* prepare for DDRAM self-refresh mode */ |
| 136 | str r3, [r2, #AT91_DDRSDRC_LPR - AT91_DDRSDRC] | 137 | ldr r3, [r2, #AT91_DDRSDRC_LPR] |
| 138 | str r3, .saved_sam9_lpr | ||
| 139 | bic r3, #AT91_DDRSDRC_LPCB | ||
| 140 | orr r3, #AT91_DDRSDRC_LPCB_SELF_REFRESH | ||
| 141 | |||
| 142 | /* figure out if we use the second ram controller */ | ||
| 143 | cmp r5, #0 | ||
| 144 | ldrne r4, [r5, #AT91_DDRSDRC_LPR] | ||
| 145 | strne r4, .saved_sam9_lpr1 | ||
| 146 | bicne r4, #AT91_DDRSDRC_LPCB | ||
| 147 | orrne r4, #AT91_DDRSDRC_LPCB_SELF_REFRESH | ||
| 148 | |||
| 149 | /* Enable DDRAM self-refresh mode */ | ||
| 150 | str r3, [r2, #AT91_DDRSDRC_LPR] | ||
| 151 | strne r4, [r5, #AT91_DDRSDRC_LPR] | ||
| 137 | #else | 152 | #else |
| 138 | /* Enable SDRAM self-refresh mode */ | 153 | /* Enable SDRAM self-refresh mode */ |
| 139 | ldr r3, [r2, #AT91_SDRAMC_LPR - AT91_SDRAMC] | 154 | ldr r3, [r2, #AT91_SDRAMC_LPR] |
| 140 | str r3, .saved_sam9_lpr | 155 | str r3, .saved_sam9_lpr |
| 141 | 156 | ||
| 142 | mov r3, #AT91_SDRAMC_LPCB_SELF_REFRESH | 157 | bic r3, #AT91_SDRAMC_LPCB |
| 143 | str r3, [r2, #AT91_SDRAMC_LPR - AT91_SDRAMC] | 158 | orr r3, #AT91_SDRAMC_LPCB_SELF_REFRESH |
| 159 | str r3, [r2, #AT91_SDRAMC_LPR] | ||
| 144 | #endif | 160 | #endif |
| 145 | 161 | ||
| 146 | /* Save Master clock setting */ | 162 | /* Save Master clock setting */ |
| @@ -247,14 +263,21 @@ ENTRY(at91_slow_clock) | |||
| 247 | 263 | ||
| 248 | #ifdef CONFIG_ARCH_AT91RM9200 | 264 | #ifdef CONFIG_ARCH_AT91RM9200 |
| 249 | /* Do nothing - self-refresh is automatically disabled. */ | 265 | /* Do nothing - self-refresh is automatically disabled. */ |
| 250 | #elif defined(CONFIG_ARCH_AT91CAP9) | 266 | #elif defined(CONFIG_ARCH_AT91CAP9) \ |
| 251 | /* Restore LPR on AT91CAP9 */ | 267 | || defined(CONFIG_ARCH_AT91SAM9G45) |
| 268 | /* Restore LPR on AT91 with DDRAM */ | ||
| 252 | ldr r3, .saved_sam9_lpr | 269 | ldr r3, .saved_sam9_lpr |
| 253 | str r3, [r2, #AT91_DDRSDRC_LPR - AT91_DDRSDRC] | 270 | str r3, [r2, #AT91_DDRSDRC_LPR] |
| 271 | |||
| 272 | /* if we use the second ram controller */ | ||
| 273 | cmp r5, #0 | ||
| 274 | ldrne r4, .saved_sam9_lpr1 | ||
| 275 | strne r4, [r5, #AT91_DDRSDRC_LPR] | ||
| 276 | |||
| 254 | #else | 277 | #else |
| 255 | /* Restore LPR on AT91SAM9 */ | 278 | /* Restore LPR on AT91 with SDRAM */ |
| 256 | ldr r3, .saved_sam9_lpr | 279 | ldr r3, .saved_sam9_lpr |
| 257 | str r3, [r2, #AT91_SDRAMC_LPR - AT91_SDRAMC] | 280 | str r3, [r2, #AT91_SDRAMC_LPR] |
| 258 | #endif | 281 | #endif |
| 259 | 282 | ||
| 260 | /* Restore registers, and return */ | 283 | /* Restore registers, and return */ |
| @@ -273,18 +296,29 @@ ENTRY(at91_slow_clock) | |||
| 273 | .saved_sam9_lpr: | 296 | .saved_sam9_lpr: |
| 274 | .word 0 | 297 | .word 0 |
| 275 | 298 | ||
| 299 | .saved_sam9_lpr1: | ||
| 300 | .word 0 | ||
| 301 | |||
| 276 | .at91_va_base_pmc: | 302 | .at91_va_base_pmc: |
| 277 | .word AT91_VA_BASE_SYS + AT91_PMC | 303 | .word AT91_VA_BASE_SYS + AT91_PMC |
| 278 | 304 | ||
| 279 | #ifdef CONFIG_ARCH_AT91RM9200 | 305 | #ifdef CONFIG_ARCH_AT91RM9200 |
| 280 | .at91_va_base_sdramc: | 306 | .at91_va_base_sdramc: |
| 281 | .word AT91_VA_BASE_SYS | 307 | .word AT91_VA_BASE_SYS |
| 282 | #elif defined(CONFIG_ARCH_AT91CAP9) | 308 | #elif defined(CONFIG_ARCH_AT91CAP9) \ |
| 309 | || defined(CONFIG_ARCH_AT91SAM9G45) | ||
| 283 | .at91_va_base_sdramc: | 310 | .at91_va_base_sdramc: |
| 284 | .word AT91_VA_BASE_SYS + AT91_DDRSDRC | 311 | .word AT91_VA_BASE_SYS + AT91_DDRSDRC0 |
| 285 | #else | 312 | #else |
| 286 | .at91_va_base_sdramc: | 313 | .at91_va_base_sdramc: |
| 287 | .word AT91_VA_BASE_SYS + AT91_SDRAMC | 314 | .word AT91_VA_BASE_SYS + AT91_SDRAMC0 |
| 315 | #endif | ||
| 316 | |||
| 317 | .at91_va_base_ramc1: | ||
| 318 | #if defined(CONFIG_ARCH_AT91SAM9G45) | ||
| 319 | .word AT91_VA_BASE_SYS + AT91_DDRSDRC1 | ||
| 320 | #else | ||
| 321 | .word 0 | ||
| 288 | #endif | 322 | #endif |
| 289 | 323 | ||
| 290 | ENTRY(at91_slow_clock_sz) | 324 | ENTRY(at91_slow_clock_sz) |
diff --git a/arch/arm/mach-bcmring/core.c b/arch/arm/mach-bcmring/core.c index 72e405df0fb0..d3f959e92b2d 100644 --- a/arch/arm/mach-bcmring/core.c +++ b/arch/arm/mach-bcmring/core.c | |||
| @@ -91,14 +91,23 @@ static struct clk uart_clk = { | |||
| 91 | .parent = &pll1_clk, | 91 | .parent = &pll1_clk, |
| 92 | }; | 92 | }; |
| 93 | 93 | ||
| 94 | static struct clk dummy_apb_pclk = { | ||
| 95 | .name = "BUSCLK", | ||
| 96 | .type = CLK_TYPE_PRIMARY, | ||
| 97 | .mode = CLK_MODE_XTAL, | ||
| 98 | }; | ||
| 99 | |||
| 94 | static struct clk_lookup lookups[] = { | 100 | static struct clk_lookup lookups[] = { |
| 95 | { /* UART0 */ | 101 | { /* Bus clock */ |
| 96 | .dev_id = "uarta", | 102 | .con_id = "apb_pclk", |
| 97 | .clk = &uart_clk, | 103 | .clk = &dummy_apb_pclk, |
| 98 | }, { /* UART1 */ | 104 | }, { /* UART0 */ |
| 99 | .dev_id = "uartb", | 105 | .dev_id = "uarta", |
| 100 | .clk = &uart_clk, | 106 | .clk = &uart_clk, |
| 101 | } | 107 | }, { /* UART1 */ |
| 108 | .dev_id = "uartb", | ||
| 109 | .clk = &uart_clk, | ||
| 110 | } | ||
| 102 | }; | 111 | }; |
| 103 | 112 | ||
| 104 | static struct amba_device *amba_devs[] __initdata = { | 113 | static struct amba_device *amba_devs[] __initdata = { |
diff --git a/arch/arm/mach-clps711x/Kconfig b/arch/arm/mach-clps711x/Kconfig index dbaae5f746a1..eb34bd1251d4 100644 --- a/arch/arm/mach-clps711x/Kconfig +++ b/arch/arm/mach-clps711x/Kconfig | |||
| @@ -30,7 +30,6 @@ config ARCH_CLEP7312 | |||
| 30 | config ARCH_EDB7211 | 30 | config ARCH_EDB7211 |
| 31 | bool "EDB7211" | 31 | bool "EDB7211" |
| 32 | select ISA | 32 | select ISA |
| 33 | select ARCH_DISCONTIGMEM_ENABLE | ||
| 34 | select ARCH_SPARSEMEM_ENABLE | 33 | select ARCH_SPARSEMEM_ENABLE |
| 35 | select ARCH_SELECT_MEMORY_MODEL | 34 | select ARCH_SELECT_MEMORY_MODEL |
| 36 | help | 35 | help |
diff --git a/arch/arm/mach-clps711x/clep7312.c b/arch/arm/mach-clps711x/clep7312.c index 09fb57e45213..3c3bf45039ff 100644 --- a/arch/arm/mach-clps711x/clep7312.c +++ b/arch/arm/mach-clps711x/clep7312.c | |||
| @@ -32,7 +32,6 @@ fixup_clep7312(struct machine_desc *desc, struct tag *tags, | |||
| 32 | mi->nr_banks=1; | 32 | mi->nr_banks=1; |
| 33 | mi->bank[0].start = 0xc0000000; | 33 | mi->bank[0].start = 0xc0000000; |
| 34 | mi->bank[0].size = 0x01000000; | 34 | mi->bank[0].size = 0x01000000; |
| 35 | mi->bank[0].node = 0; | ||
| 36 | } | 35 | } |
| 37 | 36 | ||
| 38 | 37 | ||
diff --git a/arch/arm/mach-clps711x/edb7211-arch.c b/arch/arm/mach-clps711x/edb7211-arch.c index dc81cc68595d..4a7a2322979a 100644 --- a/arch/arm/mach-clps711x/edb7211-arch.c +++ b/arch/arm/mach-clps711x/edb7211-arch.c | |||
| @@ -18,6 +18,7 @@ | |||
| 18 | * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA | 18 | * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA |
| 19 | */ | 19 | */ |
| 20 | #include <linux/init.h> | 20 | #include <linux/init.h> |
| 21 | #include <linux/memblock.h> | ||
| 21 | #include <linux/types.h> | 22 | #include <linux/types.h> |
| 22 | #include <linux/string.h> | 23 | #include <linux/string.h> |
| 23 | 24 | ||
| @@ -29,6 +30,12 @@ | |||
| 29 | 30 | ||
| 30 | extern void edb7211_map_io(void); | 31 | extern void edb7211_map_io(void); |
| 31 | 32 | ||
| 33 | /* Reserve screen memory region at the start of main system memory. */ | ||
| 34 | static void __init edb7211_reserve(void) | ||
| 35 | { | ||
| 36 | memblock_reserve(PHYS_OFFSET, 0x00020000); | ||
| 37 | } | ||
| 38 | |||
| 32 | static void __init | 39 | static void __init |
| 33 | fixup_edb7211(struct machine_desc *desc, struct tag *tags, | 40 | fixup_edb7211(struct machine_desc *desc, struct tag *tags, |
| 34 | char **cmdline, struct meminfo *mi) | 41 | char **cmdline, struct meminfo *mi) |
| @@ -43,10 +50,8 @@ fixup_edb7211(struct machine_desc *desc, struct tag *tags, | |||
| 43 | */ | 50 | */ |
| 44 | mi->bank[0].start = 0xc0000000; | 51 | mi->bank[0].start = 0xc0000000; |
| 45 | mi->bank[0].size = 8*1024*1024; | 52 | mi->bank[0].size = 8*1024*1024; |
| 46 | mi->bank[0].node = 0; | ||
| 47 | mi->bank[1].start = 0xc1000000; | 53 | mi->bank[1].start = 0xc1000000; |
| 48 | mi->bank[1].size = 8*1024*1024; | 54 | mi->bank[1].size = 8*1024*1024; |
| 49 | mi->bank[1].node = 1; | ||
| 50 | mi->nr_banks = 2; | 55 | mi->nr_banks = 2; |
| 51 | } | 56 | } |
| 52 | 57 | ||
| @@ -57,6 +62,7 @@ MACHINE_START(EDB7211, "CL-EDB7211 (EP7211 eval board)") | |||
| 57 | .boot_params = 0xc0020100, /* 0xc0000000 - 0xc001ffff can be video RAM */ | 62 | .boot_params = 0xc0020100, /* 0xc0000000 - 0xc001ffff can be video RAM */ |
| 58 | .fixup = fixup_edb7211, | 63 | .fixup = fixup_edb7211, |
| 59 | .map_io = edb7211_map_io, | 64 | .map_io = edb7211_map_io, |
| 65 | .reserve = edb7211_reserve, | ||
| 60 | .init_irq = clps711x_init_irq, | 66 | .init_irq = clps711x_init_irq, |
| 61 | .timer = &clps711x_timer, | 67 | .timer = &clps711x_timer, |
| 62 | MACHINE_END | 68 | MACHINE_END |
diff --git a/arch/arm/mach-clps711x/fortunet.c b/arch/arm/mach-clps711x/fortunet.c index 7430e4049d87..a696099aa4f8 100644 --- a/arch/arm/mach-clps711x/fortunet.c +++ b/arch/arm/mach-clps711x/fortunet.c | |||
| @@ -39,7 +39,6 @@ struct meminfo memmap = { | |||
| 39 | { | 39 | { |
| 40 | .start = 0xC0000000, | 40 | .start = 0xC0000000, |
| 41 | .size = 0x01000000, | 41 | .size = 0x01000000, |
| 42 | .node = 0 | ||
| 43 | }, | 42 | }, |
| 44 | }, | 43 | }, |
| 45 | }; | 44 | }; |
diff --git a/arch/arm/mach-clps711x/include/mach/debug-macro.S b/arch/arm/mach-clps711x/include/mach/debug-macro.S index fedd8076a689..072cc6b61ba3 100644 --- a/arch/arm/mach-clps711x/include/mach/debug-macro.S +++ b/arch/arm/mach-clps711x/include/mach/debug-macro.S | |||
| @@ -11,6 +11,7 @@ | |||
| 11 | * | 11 | * |
| 12 | */ | 12 | */ |
| 13 | 13 | ||
| 14 | #include <mach/hardware.h> | ||
| 14 | #include <asm/hardware/clps7111.h> | 15 | #include <asm/hardware/clps7111.h> |
| 15 | 16 | ||
| 16 | .macro addruart, rx, tmp | 17 | .macro addruart, rx, tmp |
diff --git a/arch/arm/mach-clps711x/include/mach/memory.h b/arch/arm/mach-clps711x/include/mach/memory.h index f70d52be48a2..f45c8e892cb5 100644 --- a/arch/arm/mach-clps711x/include/mach/memory.h +++ b/arch/arm/mach-clps711x/include/mach/memory.h | |||
| @@ -20,7 +20,6 @@ | |||
| 20 | #ifndef __ASM_ARCH_MEMORY_H | 20 | #ifndef __ASM_ARCH_MEMORY_H |
| 21 | #define __ASM_ARCH_MEMORY_H | 21 | #define __ASM_ARCH_MEMORY_H |
| 22 | 22 | ||
| 23 | |||
| 24 | /* | 23 | /* |
| 25 | * Physical DRAM offset. | 24 | * Physical DRAM offset. |
| 26 | */ | 25 | */ |
| @@ -72,7 +71,6 @@ | |||
| 72 | * node 2: 0xd0000000 - 0xd7ffffff | 71 | * node 2: 0xd0000000 - 0xd7ffffff |
| 73 | * node 3: 0xd8000000 - 0xdfffffff | 72 | * node 3: 0xd8000000 - 0xdfffffff |
| 74 | */ | 73 | */ |
| 75 | #define NODE_MEM_SIZE_BITS 24 | ||
| 76 | #define SECTION_SIZE_BITS 24 | 74 | #define SECTION_SIZE_BITS 24 |
| 77 | #define MAX_PHYSMEM_BITS 32 | 75 | #define MAX_PHYSMEM_BITS 32 |
| 78 | 76 | ||
diff --git a/arch/arm/mach-davinci/board-da850-evm.c b/arch/arm/mach-davinci/board-da850-evm.c index 2ec3095ffb7b..b280efb1fa12 100644 --- a/arch/arm/mach-davinci/board-da850-evm.c +++ b/arch/arm/mach-davinci/board-da850-evm.c | |||
| @@ -25,6 +25,7 @@ | |||
| 25 | #include <linux/mtd/partitions.h> | 25 | #include <linux/mtd/partitions.h> |
| 26 | #include <linux/mtd/physmap.h> | 26 | #include <linux/mtd/physmap.h> |
| 27 | #include <linux/regulator/machine.h> | 27 | #include <linux/regulator/machine.h> |
| 28 | #include <linux/regulator/tps6507x.h> | ||
| 28 | #include <linux/mfd/tps6507x.h> | 29 | #include <linux/mfd/tps6507x.h> |
| 29 | #include <linux/input/tps6507x-ts.h> | 30 | #include <linux/input/tps6507x-ts.h> |
| 30 | 31 | ||
| @@ -469,6 +470,11 @@ struct regulator_consumer_supply tps65070_ldo2_consumers[] = { | |||
| 469 | }, | 470 | }, |
| 470 | }; | 471 | }; |
| 471 | 472 | ||
| 473 | /* We take advantage of the fact that both defdcdc{2,3} are tied high */ | ||
| 474 | static struct tps6507x_reg_platform_data tps6507x_platform_data = { | ||
| 475 | .defdcdc_default = true, | ||
| 476 | }; | ||
| 477 | |||
| 472 | struct regulator_init_data tps65070_regulator_data[] = { | 478 | struct regulator_init_data tps65070_regulator_data[] = { |
| 473 | /* dcdc1 */ | 479 | /* dcdc1 */ |
| 474 | { | 480 | { |
| @@ -494,6 +500,7 @@ struct regulator_init_data tps65070_regulator_data[] = { | |||
| 494 | }, | 500 | }, |
| 495 | .num_consumer_supplies = ARRAY_SIZE(tps65070_dcdc2_consumers), | 501 | .num_consumer_supplies = ARRAY_SIZE(tps65070_dcdc2_consumers), |
| 496 | .consumer_supplies = tps65070_dcdc2_consumers, | 502 | .consumer_supplies = tps65070_dcdc2_consumers, |
| 503 | .driver_data = &tps6507x_platform_data, | ||
| 497 | }, | 504 | }, |
| 498 | 505 | ||
| 499 | /* dcdc3 */ | 506 | /* dcdc3 */ |
| @@ -507,6 +514,7 @@ struct regulator_init_data tps65070_regulator_data[] = { | |||
| 507 | }, | 514 | }, |
| 508 | .num_consumer_supplies = ARRAY_SIZE(tps65070_dcdc3_consumers), | 515 | .num_consumer_supplies = ARRAY_SIZE(tps65070_dcdc3_consumers), |
| 509 | .consumer_supplies = tps65070_dcdc3_consumers, | 516 | .consumer_supplies = tps65070_dcdc3_consumers, |
| 517 | .driver_data = &tps6507x_platform_data, | ||
| 510 | }, | 518 | }, |
| 511 | 519 | ||
| 512 | /* ldo1 */ | 520 | /* ldo1 */ |
diff --git a/arch/arm/mach-davinci/include/mach/memory.h b/arch/arm/mach-davinci/include/mach/memory.h index a91edfb8beea..22eb97c1c30b 100644 --- a/arch/arm/mach-davinci/include/mach/memory.h +++ b/arch/arm/mach-davinci/include/mach/memory.h | |||
| @@ -48,19 +48,16 @@ | |||
| 48 | * below 128M | 48 | * below 128M |
| 49 | */ | 49 | */ |
| 50 | static inline void | 50 | static inline void |
| 51 | __arch_adjust_zones(int node, unsigned long *size, unsigned long *holes) | 51 | __arch_adjust_zones(unsigned long *size, unsigned long *holes) |
| 52 | { | 52 | { |
| 53 | unsigned int sz = (128<<20) >> PAGE_SHIFT; | 53 | unsigned int sz = (128<<20) >> PAGE_SHIFT; |
| 54 | 54 | ||
| 55 | if (node != 0) | ||
| 56 | sz = 0; | ||
| 57 | |||
| 58 | size[1] = size[0] - sz; | 55 | size[1] = size[0] - sz; |
| 59 | size[0] = sz; | 56 | size[0] = sz; |
| 60 | } | 57 | } |
| 61 | 58 | ||
| 62 | #define arch_adjust_zones(node, zone_size, holes) \ | 59 | #define arch_adjust_zones(zone_size, holes) \ |
| 63 | if ((meminfo.bank[0].size >> 20) > 128) __arch_adjust_zones(node, zone_size, holes) | 60 | if ((meminfo.bank[0].size >> 20) > 128) __arch_adjust_zones(zone_size, holes) |
| 64 | 61 | ||
| 65 | #define ISA_DMA_THRESHOLD (PHYS_OFFSET + (128<<20) - 1) | 62 | #define ISA_DMA_THRESHOLD (PHYS_OFFSET + (128<<20) - 1) |
| 66 | #define MAX_DMA_ADDRESS (PAGE_OFFSET + (128<<20)) | 63 | #define MAX_DMA_ADDRESS (PAGE_OFFSET + (128<<20)) |
diff --git a/arch/arm/mach-ep93xx/adssphere.c b/arch/arm/mach-ep93xx/adssphere.c index 3a1a855bfdca..f744f676783f 100644 --- a/arch/arm/mach-ep93xx/adssphere.c +++ b/arch/arm/mach-ep93xx/adssphere.c | |||
| @@ -13,7 +13,6 @@ | |||
| 13 | #include <linux/kernel.h> | 13 | #include <linux/kernel.h> |
| 14 | #include <linux/init.h> | 14 | #include <linux/init.h> |
| 15 | #include <linux/platform_device.h> | 15 | #include <linux/platform_device.h> |
| 16 | #include <linux/mtd/physmap.h> | ||
| 17 | 16 | ||
| 18 | #include <mach/hardware.h> | 17 | #include <mach/hardware.h> |
| 19 | 18 | ||
| @@ -21,26 +20,6 @@ | |||
| 21 | #include <asm/mach/arch.h> | 20 | #include <asm/mach/arch.h> |
| 22 | 21 | ||
| 23 | 22 | ||
| 24 | static struct physmap_flash_data adssphere_flash_data = { | ||
| 25 | .width = 4, | ||
| 26 | }; | ||
| 27 | |||
| 28 | static struct resource adssphere_flash_resource = { | ||
| 29 | .start = EP93XX_CS6_PHYS_BASE, | ||
| 30 | .end = EP93XX_CS6_PHYS_BASE + SZ_32M - 1, | ||
| 31 | .flags = IORESOURCE_MEM, | ||
| 32 | }; | ||
| 33 | |||
| 34 | static struct platform_device adssphere_flash = { | ||
| 35 | .name = "physmap-flash", | ||
| 36 | .id = 0, | ||
| 37 | .dev = { | ||
| 38 | .platform_data = &adssphere_flash_data, | ||
| 39 | }, | ||
| 40 | .num_resources = 1, | ||
| 41 | .resource = &adssphere_flash_resource, | ||
| 42 | }; | ||
| 43 | |||
| 44 | static struct ep93xx_eth_data __initdata adssphere_eth_data = { | 23 | static struct ep93xx_eth_data __initdata adssphere_eth_data = { |
| 45 | .phy_id = 1, | 24 | .phy_id = 1, |
| 46 | }; | 25 | }; |
| @@ -48,8 +27,7 @@ static struct ep93xx_eth_data __initdata adssphere_eth_data = { | |||
| 48 | static void __init adssphere_init_machine(void) | 27 | static void __init adssphere_init_machine(void) |
| 49 | { | 28 | { |
| 50 | ep93xx_init_devices(); | 29 | ep93xx_init_devices(); |
| 51 | platform_device_register(&adssphere_flash); | 30 | ep93xx_register_flash(4, EP93XX_CS6_PHYS_BASE, SZ_32M); |
| 52 | |||
| 53 | ep93xx_register_eth(&adssphere_eth_data, 1); | 31 | ep93xx_register_eth(&adssphere_eth_data, 1); |
| 54 | } | 32 | } |
| 55 | 33 | ||
diff --git a/arch/arm/mach-ep93xx/clock.c b/arch/arm/mach-ep93xx/clock.c index e29bdef9b2e2..7f3039761d91 100644 --- a/arch/arm/mach-ep93xx/clock.c +++ b/arch/arm/mach-ep93xx/clock.c | |||
| @@ -185,7 +185,7 @@ static struct clk_lookup clocks[] = { | |||
| 185 | INIT_CK(NULL, "pll1", &clk_pll1), | 185 | INIT_CK(NULL, "pll1", &clk_pll1), |
| 186 | INIT_CK(NULL, "fclk", &clk_f), | 186 | INIT_CK(NULL, "fclk", &clk_f), |
| 187 | INIT_CK(NULL, "hclk", &clk_h), | 187 | INIT_CK(NULL, "hclk", &clk_h), |
| 188 | INIT_CK(NULL, "pclk", &clk_p), | 188 | INIT_CK(NULL, "apb_pclk", &clk_p), |
| 189 | INIT_CK(NULL, "pll2", &clk_pll2), | 189 | INIT_CK(NULL, "pll2", &clk_pll2), |
| 190 | INIT_CK("ep93xx-ohci", NULL, &clk_usb_host), | 190 | INIT_CK("ep93xx-ohci", NULL, &clk_usb_host), |
| 191 | INIT_CK("ep93xx-keypad", NULL, &clk_keypad), | 191 | INIT_CK("ep93xx-keypad", NULL, &clk_keypad), |
diff --git a/arch/arm/mach-ep93xx/core.c b/arch/arm/mach-ep93xx/core.c index 9092677f63eb..8e37a045188c 100644 --- a/arch/arm/mach-ep93xx/core.c +++ b/arch/arm/mach-ep93xx/core.c | |||
| @@ -29,6 +29,7 @@ | |||
| 29 | #include <linux/termios.h> | 29 | #include <linux/termios.h> |
| 30 | #include <linux/amba/bus.h> | 30 | #include <linux/amba/bus.h> |
| 31 | #include <linux/amba/serial.h> | 31 | #include <linux/amba/serial.h> |
| 32 | #include <linux/mtd/physmap.h> | ||
| 32 | #include <linux/i2c.h> | 33 | #include <linux/i2c.h> |
| 33 | #include <linux/i2c-gpio.h> | 34 | #include <linux/i2c-gpio.h> |
| 34 | #include <linux/spi/spi.h> | 35 | #include <linux/spi/spi.h> |
| @@ -215,8 +216,8 @@ void ep93xx_devcfg_set_clear(unsigned int set_bits, unsigned int clear_bits) | |||
| 215 | spin_lock_irqsave(&syscon_swlock, flags); | 216 | spin_lock_irqsave(&syscon_swlock, flags); |
| 216 | 217 | ||
| 217 | val = __raw_readl(EP93XX_SYSCON_DEVCFG); | 218 | val = __raw_readl(EP93XX_SYSCON_DEVCFG); |
| 218 | val |= set_bits; | ||
| 219 | val &= ~clear_bits; | 219 | val &= ~clear_bits; |
| 220 | val |= set_bits; | ||
| 220 | __raw_writel(0xaa, EP93XX_SYSCON_SWLOCK); | 221 | __raw_writel(0xaa, EP93XX_SYSCON_SWLOCK); |
| 221 | __raw_writel(val, EP93XX_SYSCON_DEVCFG); | 222 | __raw_writel(val, EP93XX_SYSCON_DEVCFG); |
| 222 | 223 | ||
| @@ -348,6 +349,43 @@ static struct platform_device ep93xx_ohci_device = { | |||
| 348 | 349 | ||
| 349 | 350 | ||
| 350 | /************************************************************************* | 351 | /************************************************************************* |
| 352 | * EP93xx physmap'ed flash | ||
| 353 | *************************************************************************/ | ||
| 354 | static struct physmap_flash_data ep93xx_flash_data; | ||
| 355 | |||
| 356 | static struct resource ep93xx_flash_resource = { | ||
| 357 | .flags = IORESOURCE_MEM, | ||
| 358 | }; | ||
| 359 | |||
| 360 | static struct platform_device ep93xx_flash = { | ||
| 361 | .name = "physmap-flash", | ||
| 362 | .id = 0, | ||
| 363 | .dev = { | ||
| 364 | .platform_data = &ep93xx_flash_data, | ||
| 365 | }, | ||
| 366 | .num_resources = 1, | ||
| 367 | .resource = &ep93xx_flash_resource, | ||
| 368 | }; | ||
| 369 | |||
| 370 | /** | ||
| 371 | * ep93xx_register_flash() - Register the external flash device. | ||
| 372 | * @width: bank width in octets | ||
| 373 | * @start: resource start address | ||
| 374 | * @size: resource size | ||
| 375 | */ | ||
| 376 | void __init ep93xx_register_flash(unsigned int width, | ||
| 377 | resource_size_t start, resource_size_t size) | ||
| 378 | { | ||
| 379 | ep93xx_flash_data.width = width; | ||
| 380 | |||
| 381 | ep93xx_flash_resource.start = start; | ||
| 382 | ep93xx_flash_resource.end = start + size - 1; | ||
| 383 | |||
| 384 | platform_device_register(&ep93xx_flash); | ||
| 385 | } | ||
| 386 | |||
| 387 | |||
| 388 | /************************************************************************* | ||
| 351 | * EP93xx ethernet peripheral handling | 389 | * EP93xx ethernet peripheral handling |
| 352 | *************************************************************************/ | 390 | *************************************************************************/ |
| 353 | static struct ep93xx_eth_data ep93xx_eth_data; | 391 | static struct ep93xx_eth_data ep93xx_eth_data; |
| @@ -620,6 +658,11 @@ static struct platform_device ep93xx_fb_device = { | |||
| 620 | .resource = ep93xx_fb_resource, | 658 | .resource = ep93xx_fb_resource, |
| 621 | }; | 659 | }; |
| 622 | 660 | ||
| 661 | static struct platform_device ep93xx_bl_device = { | ||
| 662 | .name = "ep93xx-bl", | ||
| 663 | .id = -1, | ||
| 664 | }; | ||
| 665 | |||
| 623 | /** | 666 | /** |
| 624 | * ep93xx_register_fb - Register the framebuffer platform device. | 667 | * ep93xx_register_fb - Register the framebuffer platform device. |
| 625 | * @data: platform specific framebuffer configuration (__initdata) | 668 | * @data: platform specific framebuffer configuration (__initdata) |
| @@ -628,6 +671,7 @@ void __init ep93xx_register_fb(struct ep93xxfb_mach_info *data) | |||
| 628 | { | 671 | { |
| 629 | ep93xxfb_data = *data; | 672 | ep93xxfb_data = *data; |
| 630 | platform_device_register(&ep93xx_fb_device); | 673 | platform_device_register(&ep93xx_fb_device); |
| 674 | platform_device_register(&ep93xx_bl_device); | ||
| 631 | } | 675 | } |
| 632 | 676 | ||
| 633 | 677 | ||
diff --git a/arch/arm/mach-ep93xx/edb93xx.c b/arch/arm/mach-ep93xx/edb93xx.c index 3884182cd362..c2ce9034ba87 100644 --- a/arch/arm/mach-ep93xx/edb93xx.c +++ b/arch/arm/mach-ep93xx/edb93xx.c | |||
| @@ -27,7 +27,6 @@ | |||
| 27 | #include <linux/kernel.h> | 27 | #include <linux/kernel.h> |
| 28 | #include <linux/init.h> | 28 | #include <linux/init.h> |
| 29 | #include <linux/platform_device.h> | 29 | #include <linux/platform_device.h> |
| 30 | #include <linux/mtd/physmap.h> | ||
| 31 | #include <linux/gpio.h> | 30 | #include <linux/gpio.h> |
| 32 | #include <linux/i2c.h> | 31 | #include <linux/i2c.h> |
| 33 | #include <linux/i2c-gpio.h> | 32 | #include <linux/i2c-gpio.h> |
| @@ -38,39 +37,13 @@ | |||
| 38 | #include <asm/mach/arch.h> | 37 | #include <asm/mach/arch.h> |
| 39 | 38 | ||
| 40 | 39 | ||
| 41 | static struct physmap_flash_data edb93xx_flash_data; | ||
| 42 | |||
| 43 | static struct resource edb93xx_flash_resource = { | ||
| 44 | .flags = IORESOURCE_MEM, | ||
| 45 | }; | ||
| 46 | |||
| 47 | static struct platform_device edb93xx_flash = { | ||
| 48 | .name = "physmap-flash", | ||
| 49 | .id = 0, | ||
| 50 | .dev = { | ||
| 51 | .platform_data = &edb93xx_flash_data, | ||
| 52 | }, | ||
| 53 | .num_resources = 1, | ||
| 54 | .resource = &edb93xx_flash_resource, | ||
| 55 | }; | ||
| 56 | |||
| 57 | static void __init __edb93xx_register_flash(unsigned int width, | ||
| 58 | resource_size_t start, resource_size_t size) | ||
| 59 | { | ||
| 60 | edb93xx_flash_data.width = width; | ||
| 61 | edb93xx_flash_resource.start = start; | ||
| 62 | edb93xx_flash_resource.end = start + size - 1; | ||
| 63 | |||
| 64 | platform_device_register(&edb93xx_flash); | ||
| 65 | } | ||
| 66 | |||
| 67 | static void __init edb93xx_register_flash(void) | 40 | static void __init edb93xx_register_flash(void) |
| 68 | { | 41 | { |
| 69 | if (machine_is_edb9307() || machine_is_edb9312() || | 42 | if (machine_is_edb9307() || machine_is_edb9312() || |
| 70 | machine_is_edb9315()) { | 43 | machine_is_edb9315()) { |
| 71 | __edb93xx_register_flash(4, EP93XX_CS6_PHYS_BASE, SZ_32M); | 44 | ep93xx_register_flash(4, EP93XX_CS6_PHYS_BASE, SZ_32M); |
| 72 | } else { | 45 | } else { |
| 73 | __edb93xx_register_flash(2, EP93XX_CS6_PHYS_BASE, SZ_16M); | 46 | ep93xx_register_flash(2, EP93XX_CS6_PHYS_BASE, SZ_16M); |
| 74 | } | 47 | } |
| 75 | } | 48 | } |
| 76 | 49 | ||
diff --git a/arch/arm/mach-ep93xx/gesbc9312.c b/arch/arm/mach-ep93xx/gesbc9312.c index a809618e9f05..d97168c0ba33 100644 --- a/arch/arm/mach-ep93xx/gesbc9312.c +++ b/arch/arm/mach-ep93xx/gesbc9312.c | |||
| @@ -13,7 +13,6 @@ | |||
| 13 | #include <linux/kernel.h> | 13 | #include <linux/kernel.h> |
| 14 | #include <linux/init.h> | 14 | #include <linux/init.h> |
| 15 | #include <linux/platform_device.h> | 15 | #include <linux/platform_device.h> |
| 16 | #include <linux/mtd/physmap.h> | ||
| 17 | 16 | ||
| 18 | #include <mach/hardware.h> | 17 | #include <mach/hardware.h> |
| 19 | 18 | ||
| @@ -21,26 +20,6 @@ | |||
| 21 | #include <asm/mach/arch.h> | 20 | #include <asm/mach/arch.h> |
| 22 | 21 | ||
| 23 | 22 | ||
| 24 | static struct physmap_flash_data gesbc9312_flash_data = { | ||
| 25 | .width = 4, | ||
| 26 | }; | ||
| 27 | |||
| 28 | static struct resource gesbc9312_flash_resource = { | ||
| 29 | .start = EP93XX_CS6_PHYS_BASE, | ||
| 30 | .end = EP93XX_CS6_PHYS_BASE + SZ_8M - 1, | ||
| 31 | .flags = IORESOURCE_MEM, | ||
| 32 | }; | ||
| 33 | |||
| 34 | static struct platform_device gesbc9312_flash = { | ||
| 35 | .name = "physmap-flash", | ||
| 36 | .id = 0, | ||
| 37 | .dev = { | ||
| 38 | .platform_data = &gesbc9312_flash_data, | ||
| 39 | }, | ||
| 40 | .num_resources = 1, | ||
| 41 | .resource = &gesbc9312_flash_resource, | ||
| 42 | }; | ||
| 43 | |||
| 44 | static struct ep93xx_eth_data __initdata gesbc9312_eth_data = { | 23 | static struct ep93xx_eth_data __initdata gesbc9312_eth_data = { |
| 45 | .phy_id = 1, | 24 | .phy_id = 1, |
| 46 | }; | 25 | }; |
| @@ -48,8 +27,7 @@ static struct ep93xx_eth_data __initdata gesbc9312_eth_data = { | |||
| 48 | static void __init gesbc9312_init_machine(void) | 27 | static void __init gesbc9312_init_machine(void) |
| 49 | { | 28 | { |
| 50 | ep93xx_init_devices(); | 29 | ep93xx_init_devices(); |
| 51 | platform_device_register(&gesbc9312_flash); | 30 | ep93xx_register_flash(4, EP93XX_CS6_PHYS_BASE, SZ_8M); |
| 52 | |||
| 53 | ep93xx_register_eth(&gesbc9312_eth_data, 0); | 31 | ep93xx_register_eth(&gesbc9312_eth_data, 0); |
| 54 | } | 32 | } |
| 55 | 33 | ||
diff --git a/arch/arm/mach-ep93xx/include/mach/platform.h b/arch/arm/mach-ep93xx/include/mach/platform.h index 9a4413dd44bb..a6c09176334c 100644 --- a/arch/arm/mach-ep93xx/include/mach/platform.h +++ b/arch/arm/mach-ep93xx/include/mach/platform.h | |||
| @@ -43,6 +43,9 @@ static inline void ep93xx_devcfg_clear_bits(unsigned int bits) | |||
| 43 | 43 | ||
| 44 | unsigned int ep93xx_chip_revision(void); | 44 | unsigned int ep93xx_chip_revision(void); |
| 45 | 45 | ||
| 46 | void ep93xx_register_flash(unsigned int width, | ||
| 47 | resource_size_t start, resource_size_t size); | ||
| 48 | |||
| 46 | void ep93xx_register_eth(struct ep93xx_eth_data *data, int copy_addr); | 49 | void ep93xx_register_eth(struct ep93xx_eth_data *data, int copy_addr); |
| 47 | void ep93xx_register_i2c(struct i2c_gpio_platform_data *data, | 50 | void ep93xx_register_i2c(struct i2c_gpio_platform_data *data, |
| 48 | struct i2c_board_info *devices, int num); | 51 | struct i2c_board_info *devices, int num); |
diff --git a/arch/arm/mach-ep93xx/micro9.c b/arch/arm/mach-ep93xx/micro9.c index 1cc911b4efa6..2ba776320a82 100644 --- a/arch/arm/mach-ep93xx/micro9.c +++ b/arch/arm/mach-ep93xx/micro9.c | |||
| @@ -14,7 +14,6 @@ | |||
| 14 | #include <linux/kernel.h> | 14 | #include <linux/kernel.h> |
| 15 | #include <linux/init.h> | 15 | #include <linux/init.h> |
| 16 | #include <linux/platform_device.h> | 16 | #include <linux/platform_device.h> |
| 17 | #include <linux/mtd/physmap.h> | ||
| 18 | #include <linux/io.h> | 17 | #include <linux/io.h> |
| 19 | 18 | ||
| 20 | #include <mach/hardware.h> | 19 | #include <mach/hardware.h> |
| @@ -31,31 +30,6 @@ | |||
| 31 | * Micro9-Lite uses a separate MTD map driver for flash support | 30 | * Micro9-Lite uses a separate MTD map driver for flash support |
| 32 | * Micro9-Slim has up to 64MB of either 32-bit or 16-bit flash on CS1 | 31 | * Micro9-Slim has up to 64MB of either 32-bit or 16-bit flash on CS1 |
| 33 | *************************************************************************/ | 32 | *************************************************************************/ |
| 34 | static struct physmap_flash_data micro9_flash_data; | ||
| 35 | |||
| 36 | static struct resource micro9_flash_resource = { | ||
| 37 | .start = EP93XX_CS1_PHYS_BASE, | ||
| 38 | .end = EP93XX_CS1_PHYS_BASE + SZ_64M - 1, | ||
| 39 | .flags = IORESOURCE_MEM, | ||
| 40 | }; | ||
| 41 | |||
| 42 | static struct platform_device micro9_flash = { | ||
| 43 | .name = "physmap-flash", | ||
| 44 | .id = 0, | ||
| 45 | .dev = { | ||
| 46 | .platform_data = µ9_flash_data, | ||
| 47 | }, | ||
| 48 | .num_resources = 1, | ||
| 49 | .resource = µ9_flash_resource, | ||
| 50 | }; | ||
| 51 | |||
| 52 | static void __init __micro9_register_flash(unsigned int width) | ||
| 53 | { | ||
| 54 | micro9_flash_data.width = width; | ||
| 55 | |||
| 56 | platform_device_register(µ9_flash); | ||
| 57 | } | ||
| 58 | |||
| 59 | static unsigned int __init micro9_detect_bootwidth(void) | 33 | static unsigned int __init micro9_detect_bootwidth(void) |
| 60 | { | 34 | { |
| 61 | u32 v; | 35 | u32 v; |
| @@ -70,10 +44,17 @@ static unsigned int __init micro9_detect_bootwidth(void) | |||
| 70 | 44 | ||
| 71 | static void __init micro9_register_flash(void) | 45 | static void __init micro9_register_flash(void) |
| 72 | { | 46 | { |
| 47 | unsigned int width; | ||
| 48 | |||
| 73 | if (machine_is_micro9()) | 49 | if (machine_is_micro9()) |
| 74 | __micro9_register_flash(4); | 50 | width = 4; |
| 75 | else if (machine_is_micro9m() || machine_is_micro9s()) | 51 | else if (machine_is_micro9m() || machine_is_micro9s()) |
| 76 | __micro9_register_flash(micro9_detect_bootwidth()); | 52 | width = micro9_detect_bootwidth(); |
| 53 | else | ||
| 54 | width = 0; | ||
| 55 | |||
| 56 | if (width) | ||
| 57 | ep93xx_register_flash(width, EP93XX_CS1_PHYS_BASE, SZ_64M); | ||
| 77 | } | 58 | } |
| 78 | 59 | ||
| 79 | 60 | ||
diff --git a/arch/arm/mach-ep93xx/simone.c b/arch/arm/mach-ep93xx/simone.c index 388aec95f60e..5dded5884133 100644 --- a/arch/arm/mach-ep93xx/simone.c +++ b/arch/arm/mach-ep93xx/simone.c | |||
| @@ -18,7 +18,6 @@ | |||
| 18 | #include <linux/kernel.h> | 18 | #include <linux/kernel.h> |
| 19 | #include <linux/init.h> | 19 | #include <linux/init.h> |
| 20 | #include <linux/platform_device.h> | 20 | #include <linux/platform_device.h> |
| 21 | #include <linux/mtd/physmap.h> | ||
| 22 | #include <linux/gpio.h> | 21 | #include <linux/gpio.h> |
| 23 | #include <linux/i2c.h> | 22 | #include <linux/i2c.h> |
| 24 | #include <linux/i2c-gpio.h> | 23 | #include <linux/i2c-gpio.h> |
| @@ -29,26 +28,6 @@ | |||
| 29 | #include <asm/mach-types.h> | 28 | #include <asm/mach-types.h> |
| 30 | #include <asm/mach/arch.h> | 29 | #include <asm/mach/arch.h> |
| 31 | 30 | ||
| 32 | static struct physmap_flash_data simone_flash_data = { | ||
| 33 | .width = 2, | ||
| 34 | }; | ||
| 35 | |||
| 36 | static struct resource simone_flash_resource = { | ||
| 37 | .start = EP93XX_CS6_PHYS_BASE, | ||
| 38 | .end = EP93XX_CS6_PHYS_BASE + SZ_8M - 1, | ||
| 39 | .flags = IORESOURCE_MEM, | ||
| 40 | }; | ||
| 41 | |||
| 42 | static struct platform_device simone_flash = { | ||
| 43 | .name = "physmap-flash", | ||
| 44 | .id = 0, | ||
| 45 | .num_resources = 1, | ||
| 46 | .resource = &simone_flash_resource, | ||
| 47 | .dev = { | ||
| 48 | .platform_data = &simone_flash_data, | ||
| 49 | }, | ||
| 50 | }; | ||
| 51 | |||
| 52 | static struct ep93xx_eth_data __initdata simone_eth_data = { | 31 | static struct ep93xx_eth_data __initdata simone_eth_data = { |
| 53 | .phy_id = 1, | 32 | .phy_id = 1, |
| 54 | }; | 33 | }; |
| @@ -77,8 +56,7 @@ static struct i2c_board_info __initdata simone_i2c_board_info[] = { | |||
| 77 | static void __init simone_init_machine(void) | 56 | static void __init simone_init_machine(void) |
| 78 | { | 57 | { |
| 79 | ep93xx_init_devices(); | 58 | ep93xx_init_devices(); |
| 80 | 59 | ep93xx_register_flash(2, EP93XX_CS6_PHYS_BASE, SZ_8M); | |
| 81 | platform_device_register(&simone_flash); | ||
| 82 | ep93xx_register_eth(&simone_eth_data, 1); | 60 | ep93xx_register_eth(&simone_eth_data, 1); |
| 83 | ep93xx_register_fb(&simone_fb_info); | 61 | ep93xx_register_fb(&simone_fb_info); |
| 84 | ep93xx_register_i2c(&simone_i2c_gpio_data, simone_i2c_board_info, | 62 | ep93xx_register_i2c(&simone_i2c_gpio_data, simone_i2c_board_info, |
diff --git a/arch/arm/mach-ep93xx/ts72xx.c b/arch/arm/mach-ep93xx/ts72xx.c index ae7319e588c7..93aeab8af705 100644 --- a/arch/arm/mach-ep93xx/ts72xx.c +++ b/arch/arm/mach-ep93xx/ts72xx.c | |||
| @@ -17,7 +17,6 @@ | |||
| 17 | #include <linux/platform_device.h> | 17 | #include <linux/platform_device.h> |
| 18 | #include <linux/io.h> | 18 | #include <linux/io.h> |
| 19 | #include <linux/m48t86.h> | 19 | #include <linux/m48t86.h> |
| 20 | #include <linux/mtd/physmap.h> | ||
| 21 | #include <linux/mtd/nand.h> | 20 | #include <linux/mtd/nand.h> |
| 22 | #include <linux/mtd/partitions.h> | 21 | #include <linux/mtd/partitions.h> |
| 23 | 22 | ||
| @@ -173,31 +172,13 @@ static struct platform_device ts72xx_nand_flash = { | |||
| 173 | }; | 172 | }; |
| 174 | 173 | ||
| 175 | 174 | ||
| 176 | /************************************************************************* | ||
| 177 | * NOR flash (TS-7200 only) | ||
| 178 | *************************************************************************/ | ||
| 179 | static struct physmap_flash_data ts72xx_nor_data = { | ||
| 180 | .width = 2, | ||
| 181 | }; | ||
| 182 | |||
| 183 | static struct resource ts72xx_nor_resource = { | ||
| 184 | .start = EP93XX_CS6_PHYS_BASE, | ||
| 185 | .end = EP93XX_CS6_PHYS_BASE + SZ_16M - 1, | ||
| 186 | .flags = IORESOURCE_MEM, | ||
| 187 | }; | ||
| 188 | |||
| 189 | static struct platform_device ts72xx_nor_flash = { | ||
| 190 | .name = "physmap-flash", | ||
| 191 | .id = 0, | ||
| 192 | .dev.platform_data = &ts72xx_nor_data, | ||
| 193 | .resource = &ts72xx_nor_resource, | ||
| 194 | .num_resources = 1, | ||
| 195 | }; | ||
| 196 | |||
| 197 | static void __init ts72xx_register_flash(void) | 175 | static void __init ts72xx_register_flash(void) |
| 198 | { | 176 | { |
| 177 | /* | ||
| 178 | * TS7200 has NOR flash all other TS72xx board have NAND flash. | ||
| 179 | */ | ||
| 199 | if (board_is_ts7200()) { | 180 | if (board_is_ts7200()) { |
| 200 | platform_device_register(&ts72xx_nor_flash); | 181 | ep93xx_register_flash(2, EP93XX_CS6_PHYS_BASE, SZ_16M); |
| 201 | } else { | 182 | } else { |
| 202 | resource_size_t start; | 183 | resource_size_t start; |
| 203 | 184 | ||
diff --git a/arch/arm/mach-footbridge/common.c b/arch/arm/mach-footbridge/common.c index e3bc3f6f6b10..88b3dd89be89 100644 --- a/arch/arm/mach-footbridge/common.c +++ b/arch/arm/mach-footbridge/common.c | |||
| @@ -232,7 +232,7 @@ EXPORT_SYMBOL(__bus_to_virt); | |||
| 232 | 232 | ||
| 233 | unsigned long __pfn_to_bus(unsigned long pfn) | 233 | unsigned long __pfn_to_bus(unsigned long pfn) |
| 234 | { | 234 | { |
| 235 | return __pfn_to_phys(pfn) + (fb_bus_sdram_offset() - PHYS_OFFSET)); | 235 | return __pfn_to_phys(pfn) + (fb_bus_sdram_offset() - PHYS_OFFSET); |
| 236 | } | 236 | } |
| 237 | EXPORT_SYMBOL(__pfn_to_bus); | 237 | EXPORT_SYMBOL(__pfn_to_bus); |
| 238 | 238 | ||
diff --git a/arch/arm/mach-h720x/include/mach/debug-macro.S b/arch/arm/mach-h720x/include/mach/debug-macro.S index a9ee8f0d48b7..27cafd12f033 100644 --- a/arch/arm/mach-h720x/include/mach/debug-macro.S +++ b/arch/arm/mach-h720x/include/mach/debug-macro.S | |||
| @@ -11,8 +11,10 @@ | |||
| 11 | * | 11 | * |
| 12 | */ | 12 | */ |
| 13 | 13 | ||
| 14 | .equ io_virt, IO_BASE | 14 | #include <mach/hardware.h> |
| 15 | .equ io_phys, IO_START | 15 | |
| 16 | .equ io_virt, IO_VIRT | ||
| 17 | .equ io_phys, IO_PHYS | ||
| 16 | 18 | ||
| 17 | .macro addruart, rx, tmp | 19 | .macro addruart, rx, tmp |
| 18 | mrc p15, 0, \rx, c1, c0 | 20 | mrc p15, 0, \rx, c1, c0 |
diff --git a/arch/arm/mach-integrator/common.h b/arch/arm/mach-integrator/common.h new file mode 100644 index 000000000000..5f96e1518aa9 --- /dev/null +++ b/arch/arm/mach-integrator/common.h | |||
| @@ -0,0 +1 @@ | |||
| void integrator_reserve(void); | |||
diff --git a/arch/arm/mach-integrator/core.c b/arch/arm/mach-integrator/core.c index b02cfc06e0ae..8f4fb6d638f7 100644 --- a/arch/arm/mach-integrator/core.c +++ b/arch/arm/mach-integrator/core.c | |||
| @@ -14,6 +14,7 @@ | |||
| 14 | #include <linux/spinlock.h> | 14 | #include <linux/spinlock.h> |
| 15 | #include <linux/interrupt.h> | 15 | #include <linux/interrupt.h> |
| 16 | #include <linux/irq.h> | 16 | #include <linux/irq.h> |
| 17 | #include <linux/memblock.h> | ||
| 17 | #include <linux/sched.h> | 18 | #include <linux/sched.h> |
| 18 | #include <linux/smp.h> | 19 | #include <linux/smp.h> |
| 19 | #include <linux/termios.h> | 20 | #include <linux/termios.h> |
| @@ -30,6 +31,7 @@ | |||
| 30 | #include <asm/system.h> | 31 | #include <asm/system.h> |
| 31 | #include <asm/leds.h> | 32 | #include <asm/leds.h> |
| 32 | #include <asm/mach/time.h> | 33 | #include <asm/mach/time.h> |
| 34 | #include <asm/pgtable.h> | ||
| 33 | 35 | ||
| 34 | static struct amba_pl010_data integrator_uart_data; | 36 | static struct amba_pl010_data integrator_uart_data; |
| 35 | 37 | ||
| @@ -119,8 +121,13 @@ static struct clk uartclk = { | |||
| 119 | .rate = 14745600, | 121 | .rate = 14745600, |
| 120 | }; | 122 | }; |
| 121 | 123 | ||
| 124 | static struct clk dummy_apb_pclk; | ||
| 125 | |||
| 122 | static struct clk_lookup lookups[] = { | 126 | static struct clk_lookup lookups[] = { |
| 123 | { /* UART0 */ | 127 | { /* Bus clock */ |
| 128 | .con_id = "apb_pclk", | ||
| 129 | .clk = &dummy_apb_pclk, | ||
| 130 | }, { /* UART0 */ | ||
| 124 | .dev_id = "mb:16", | 131 | .dev_id = "mb:16", |
| 125 | .clk = &uartclk, | 132 | .clk = &uartclk, |
| 126 | }, { /* UART1 */ | 133 | }, { /* UART1 */ |
| @@ -215,3 +222,13 @@ void cm_control(u32 mask, u32 set) | |||
| 215 | } | 222 | } |
| 216 | 223 | ||
| 217 | EXPORT_SYMBOL(cm_control); | 224 | EXPORT_SYMBOL(cm_control); |
| 225 | |||
| 226 | /* | ||
| 227 | * We need to stop things allocating the low memory; ideally we need a | ||
| 228 | * better implementation of GFP_DMA which does not assume that DMA-able | ||
| 229 | * memory starts at zero. | ||
| 230 | */ | ||
| 231 | void __init integrator_reserve(void) | ||
| 232 | { | ||
| 233 | memblock_reserve(PHYS_OFFSET, __pa(swapper_pg_dir) - PHYS_OFFSET); | ||
| 234 | } | ||
diff --git a/arch/arm/mach-integrator/integrator_ap.c b/arch/arm/mach-integrator/integrator_ap.c index 227cf4d05088..6ab5a03ab9d8 100644 --- a/arch/arm/mach-integrator/integrator_ap.c +++ b/arch/arm/mach-integrator/integrator_ap.c | |||
| @@ -48,6 +48,8 @@ | |||
| 48 | #include <asm/mach/map.h> | 48 | #include <asm/mach/map.h> |
| 49 | #include <asm/mach/time.h> | 49 | #include <asm/mach/time.h> |
| 50 | 50 | ||
| 51 | #include "common.h" | ||
| 52 | |||
| 51 | /* | 53 | /* |
| 52 | * All IO addresses are mapped onto VA 0xFFFx.xxxx, where x.xxxx | 54 | * All IO addresses are mapped onto VA 0xFFFx.xxxx, where x.xxxx |
| 53 | * is the (PA >> 12). | 55 | * is the (PA >> 12). |
| @@ -502,6 +504,7 @@ MACHINE_START(INTEGRATOR, "ARM-Integrator") | |||
| 502 | .io_pg_offst = ((0xf1600000) >> 18) & 0xfffc, | 504 | .io_pg_offst = ((0xf1600000) >> 18) & 0xfffc, |
| 503 | .boot_params = 0x00000100, | 505 | .boot_params = 0x00000100, |
| 504 | .map_io = ap_map_io, | 506 | .map_io = ap_map_io, |
| 507 | .reserve = integrator_reserve, | ||
| 505 | .init_irq = ap_init_irq, | 508 | .init_irq = ap_init_irq, |
| 506 | .timer = &ap_timer, | 509 | .timer = &ap_timer, |
| 507 | .init_machine = ap_init, | 510 | .init_machine = ap_init, |
diff --git a/arch/arm/mach-integrator/integrator_cp.c b/arch/arm/mach-integrator/integrator_cp.c index cde57b2b83b5..05db40e3c4f7 100644 --- a/arch/arm/mach-integrator/integrator_cp.c +++ b/arch/arm/mach-integrator/integrator_cp.c | |||
| @@ -43,6 +43,8 @@ | |||
| 43 | 43 | ||
| 44 | #include <plat/timer-sp.h> | 44 | #include <plat/timer-sp.h> |
| 45 | 45 | ||
| 46 | #include "common.h" | ||
| 47 | |||
| 46 | #define INTCP_PA_FLASH_BASE 0x24000000 | 48 | #define INTCP_PA_FLASH_BASE 0x24000000 |
| 47 | #define INTCP_FLASH_SIZE SZ_32M | 49 | #define INTCP_FLASH_SIZE SZ_32M |
| 48 | 50 | ||
| @@ -601,6 +603,7 @@ MACHINE_START(CINTEGRATOR, "ARM-IntegratorCP") | |||
| 601 | .io_pg_offst = ((0xf1600000) >> 18) & 0xfffc, | 603 | .io_pg_offst = ((0xf1600000) >> 18) & 0xfffc, |
| 602 | .boot_params = 0x00000100, | 604 | .boot_params = 0x00000100, |
| 603 | .map_io = intcp_map_io, | 605 | .map_io = intcp_map_io, |
| 606 | .reserve = integrator_reserve, | ||
| 604 | .init_irq = intcp_init_irq, | 607 | .init_irq = intcp_init_irq, |
| 605 | .timer = &cp_timer, | 608 | .timer = &cp_timer, |
| 606 | .init_machine = intcp_init, | 609 | .init_machine = intcp_init, |
diff --git a/arch/arm/mach-iop13xx/include/mach/memory.h b/arch/arm/mach-iop13xx/include/mach/memory.h index 25b1da9a5035..7415e4338651 100644 --- a/arch/arm/mach-iop13xx/include/mach/memory.h +++ b/arch/arm/mach-iop13xx/include/mach/memory.h | |||
| @@ -69,6 +69,4 @@ static inline unsigned long __lbus_to_virt(dma_addr_t x) | |||
| 69 | #endif /* CONFIG_ARCH_IOP13XX */ | 69 | #endif /* CONFIG_ARCH_IOP13XX */ |
| 70 | #endif /* !ASSEMBLY */ | 70 | #endif /* !ASSEMBLY */ |
| 71 | 71 | ||
| 72 | #define PFN_TO_NID(addr) (0) | ||
| 73 | |||
| 74 | #endif | 72 | #endif |
diff --git a/arch/arm/mach-ixp4xx/common-pci.c b/arch/arm/mach-ixp4xx/common-pci.c index e3181534c7f9..333d04c53650 100644 --- a/arch/arm/mach-ixp4xx/common-pci.c +++ b/arch/arm/mach-ixp4xx/common-pci.c | |||
| @@ -348,7 +348,7 @@ int dma_needs_bounce(struct device *dev, dma_addr_t dma_addr, size_t size) | |||
| 348 | * This is really ugly and we need a better way of specifying | 348 | * This is really ugly and we need a better way of specifying |
| 349 | * DMA-capable regions of memory. | 349 | * DMA-capable regions of memory. |
| 350 | */ | 350 | */ |
| 351 | void __init ixp4xx_adjust_zones(int node, unsigned long *zone_size, | 351 | void __init ixp4xx_adjust_zones(unsigned long *zone_size, |
| 352 | unsigned long *zhole_size) | 352 | unsigned long *zhole_size) |
| 353 | { | 353 | { |
| 354 | unsigned int sz = SZ_64M >> PAGE_SHIFT; | 354 | unsigned int sz = SZ_64M >> PAGE_SHIFT; |
| @@ -356,7 +356,7 @@ void __init ixp4xx_adjust_zones(int node, unsigned long *zone_size, | |||
| 356 | /* | 356 | /* |
| 357 | * Only adjust if > 64M on current system | 357 | * Only adjust if > 64M on current system |
| 358 | */ | 358 | */ |
| 359 | if (node || (zone_size[0] <= sz)) | 359 | if (zone_size[0] <= sz) |
| 360 | return; | 360 | return; |
| 361 | 361 | ||
| 362 | zone_size[1] = zone_size[0] - sz; | 362 | zone_size[1] = zone_size[0] - sz; |
diff --git a/arch/arm/mach-ixp4xx/include/mach/memory.h b/arch/arm/mach-ixp4xx/include/mach/memory.h index 98f5e5e20980..0136eaa29224 100644 --- a/arch/arm/mach-ixp4xx/include/mach/memory.h +++ b/arch/arm/mach-ixp4xx/include/mach/memory.h | |||
| @@ -16,10 +16,10 @@ | |||
| 16 | 16 | ||
| 17 | #if !defined(__ASSEMBLY__) && defined(CONFIG_PCI) | 17 | #if !defined(__ASSEMBLY__) && defined(CONFIG_PCI) |
| 18 | 18 | ||
| 19 | void ixp4xx_adjust_zones(int node, unsigned long *size, unsigned long *holes); | 19 | void ixp4xx_adjust_zones(unsigned long *size, unsigned long *holes); |
| 20 | 20 | ||
| 21 | #define arch_adjust_zones(node, size, holes) \ | 21 | #define arch_adjust_zones(size, holes) \ |
| 22 | ixp4xx_adjust_zones(node, size, holes) | 22 | ixp4xx_adjust_zones(size, holes) |
| 23 | 23 | ||
| 24 | #define ISA_DMA_THRESHOLD (SZ_64M - 1) | 24 | #define ISA_DMA_THRESHOLD (SZ_64M - 1) |
| 25 | #define MAX_DMA_ADDRESS (PAGE_OFFSET + SZ_64M) | 25 | #define MAX_DMA_ADDRESS (PAGE_OFFSET + SZ_64M) |
diff --git a/arch/arm/mach-kirkwood/tsx1x-common.c b/arch/arm/mach-kirkwood/tsx1x-common.c index 7221c20b2afa..f781164e623f 100644 --- a/arch/arm/mach-kirkwood/tsx1x-common.c +++ b/arch/arm/mach-kirkwood/tsx1x-common.c | |||
| @@ -77,7 +77,7 @@ struct spi_board_info __initdata qnap_tsx1x_spi_slave_info[] = { | |||
| 77 | }, | 77 | }, |
| 78 | }; | 78 | }; |
| 79 | 79 | ||
| 80 | void qnap_tsx1x_register_flash(void) | 80 | void __init qnap_tsx1x_register_flash(void) |
| 81 | { | 81 | { |
| 82 | spi_register_board_info(qnap_tsx1x_spi_slave_info, | 82 | spi_register_board_info(qnap_tsx1x_spi_slave_info, |
| 83 | ARRAY_SIZE(qnap_tsx1x_spi_slave_info)); | 83 | ARRAY_SIZE(qnap_tsx1x_spi_slave_info)); |
diff --git a/arch/arm/mach-kirkwood/tsx1x-common.h b/arch/arm/mach-kirkwood/tsx1x-common.h index 9a592962a6ea..7fa037361b55 100644 --- a/arch/arm/mach-kirkwood/tsx1x-common.h +++ b/arch/arm/mach-kirkwood/tsx1x-common.h | |||
| @@ -1,7 +1,7 @@ | |||
| 1 | #ifndef __ARCH_KIRKWOOD_TSX1X_COMMON_H | 1 | #ifndef __ARCH_KIRKWOOD_TSX1X_COMMON_H |
| 2 | #define __ARCH_KIRKWOOD_TSX1X_COMMON_H | 2 | #define __ARCH_KIRKWOOD_TSX1X_COMMON_H |
| 3 | 3 | ||
| 4 | extern void qnap_tsx1x_register_flash(void); | 4 | extern void __init qnap_tsx1x_register_flash(void); |
| 5 | extern void qnap_tsx1x_power_off(void); | 5 | extern void qnap_tsx1x_power_off(void); |
| 6 | 6 | ||
| 7 | #endif | 7 | #endif |
diff --git a/arch/arm/mach-l7200/Makefile b/arch/arm/mach-l7200/Makefile deleted file mode 100644 index 4bd8ebd70e7b..000000000000 --- a/arch/arm/mach-l7200/Makefile +++ /dev/null | |||
| @@ -1,11 +0,0 @@ | |||
| 1 | # | ||
| 2 | # Makefile for the linux kernel. | ||
| 3 | # | ||
| 4 | |||
| 5 | # Object file lists. | ||
| 6 | |||
| 7 | obj-y := core.o | ||
| 8 | obj-m := | ||
| 9 | obj-n := | ||
| 10 | obj- := | ||
| 11 | |||
diff --git a/arch/arm/mach-l7200/Makefile.boot b/arch/arm/mach-l7200/Makefile.boot deleted file mode 100644 index 6c72ecbe6b64..000000000000 --- a/arch/arm/mach-l7200/Makefile.boot +++ /dev/null | |||
| @@ -1,2 +0,0 @@ | |||
| 1 | zreladdr-y := 0xf0008000 | ||
| 2 | |||
diff --git a/arch/arm/mach-l7200/core.c b/arch/arm/mach-l7200/core.c deleted file mode 100644 index 50d23246d4f0..000000000000 --- a/arch/arm/mach-l7200/core.c +++ /dev/null | |||
| @@ -1,100 +0,0 @@ | |||
| 1 | /* | ||
| 2 | * linux/arch/arm/mm/mm-lusl7200.c | ||
| 3 | * | ||
| 4 | * Copyright (C) 2000 Steve Hill (sjhill@cotw.com) | ||
| 5 | * | ||
| 6 | * Extra MM routines for L7200 architecture | ||
| 7 | */ | ||
| 8 | #include <linux/kernel.h> | ||
| 9 | #include <linux/init.h> | ||
| 10 | #include <linux/irq.h> | ||
| 11 | #include <linux/device.h> | ||
| 12 | |||
| 13 | #include <asm/types.h> | ||
| 14 | #include <asm/irq.h> | ||
| 15 | #include <asm/mach-types.h> | ||
| 16 | #include <mach/hardware.h> | ||
| 17 | #include <asm/page.h> | ||
| 18 | |||
| 19 | #include <asm/mach/arch.h> | ||
| 20 | #include <asm/mach/map.h> | ||
| 21 | #include <asm/mach/irq.h> | ||
| 22 | |||
| 23 | /* | ||
| 24 | * IRQ base register | ||
| 25 | */ | ||
| 26 | #define IRQ_BASE (IO_BASE_2 + 0x1000) | ||
| 27 | |||
| 28 | /* | ||
| 29 | * Normal IRQ registers | ||
| 30 | */ | ||
| 31 | #define IRQ_STATUS (*(volatile unsigned long *) (IRQ_BASE + 0x000)) | ||
| 32 | #define IRQ_RAWSTATUS (*(volatile unsigned long *) (IRQ_BASE + 0x004)) | ||
| 33 | #define IRQ_ENABLE (*(volatile unsigned long *) (IRQ_BASE + 0x008)) | ||
| 34 | #define IRQ_ENABLECLEAR (*(volatile unsigned long *) (IRQ_BASE + 0x00c)) | ||
| 35 | #define IRQ_SOFT (*(volatile unsigned long *) (IRQ_BASE + 0x010)) | ||
| 36 | #define IRQ_SOURCESEL (*(volatile unsigned long *) (IRQ_BASE + 0x018)) | ||
| 37 | |||
| 38 | /* | ||
| 39 | * Fast IRQ registers | ||
| 40 | */ | ||
| 41 | #define FIQ_STATUS (*(volatile unsigned long *) (IRQ_BASE + 0x100)) | ||
| 42 | #define FIQ_RAWSTATUS (*(volatile unsigned long *) (IRQ_BASE + 0x104)) | ||
| 43 | #define FIQ_ENABLE (*(volatile unsigned long *) (IRQ_BASE + 0x108)) | ||
| 44 | #define FIQ_ENABLECLEAR (*(volatile unsigned long *) (IRQ_BASE + 0x10c)) | ||
| 45 | #define FIQ_SOFT (*(volatile unsigned long *) (IRQ_BASE + 0x110)) | ||
| 46 | #define FIQ_SOURCESEL (*(volatile unsigned long *) (IRQ_BASE + 0x118)) | ||
| 47 | |||
| 48 | static void l7200_mask_irq(unsigned int irq) | ||
| 49 | { | ||
| 50 | IRQ_ENABLECLEAR = 1 << irq; | ||
| 51 | } | ||
| 52 | |||
| 53 | static void l7200_unmask_irq(unsigned int irq) | ||
| 54 | { | ||
| 55 | IRQ_ENABLE = 1 << irq; | ||
| 56 | } | ||
| 57 | |||
| 58 | static struct irq_chip l7200_irq_chip = { | ||
| 59 | .ack = l7200_mask_irq, | ||
| 60 | .mask = l7200_mask_irq, | ||
| 61 | .unmask = l7200_unmask_irq | ||
| 62 | }; | ||
| 63 | |||
| 64 | static void __init l7200_init_irq(void) | ||
| 65 | { | ||
| 66 | int irq; | ||
| 67 | |||
| 68 | IRQ_ENABLECLEAR = 0xffffffff; /* clear all interrupt enables */ | ||
| 69 | FIQ_ENABLECLEAR = 0xffffffff; /* clear all fast interrupt enables */ | ||
| 70 | |||
| 71 | for (irq = 0; irq < NR_IRQS; irq++) { | ||
| 72 | set_irq_chip(irq, &l7200_irq_chip); | ||
| 73 | set_irq_flags(irq, IRQF_VALID); | ||
| 74 | set_irq_handler(irq, handle_level_irq); | ||
| 75 | } | ||
| 76 | |||
| 77 | init_FIQ(); | ||
| 78 | } | ||
| 79 | |||
| 80 | static struct map_desc l7200_io_desc[] __initdata = { | ||
| 81 | { IO_BASE, IO_START, IO_SIZE, MT_DEVICE }, | ||
| 82 | { IO_BASE_2, IO_START_2, IO_SIZE_2, MT_DEVICE }, | ||
| 83 | { AUX_BASE, AUX_START, AUX_SIZE, MT_DEVICE }, | ||
| 84 | { FLASH1_BASE, FLASH1_START, FLASH1_SIZE, MT_DEVICE }, | ||
| 85 | { FLASH2_BASE, FLASH2_START, FLASH2_SIZE, MT_DEVICE } | ||
| 86 | }; | ||
| 87 | |||
| 88 | static void __init l7200_map_io(void) | ||
| 89 | { | ||
| 90 | iotable_init(l7200_io_desc, ARRAY_SIZE(l7200_io_desc)); | ||
| 91 | } | ||
| 92 | |||
| 93 | MACHINE_START(L7200, "LinkUp Systems L7200") | ||
| 94 | /* Maintainer: Steve Hill / Scott McConnell */ | ||
| 95 | .phys_io = 0x80040000, | ||
| 96 | .io_pg_offst = ((0xd0000000) >> 18) & 0xfffc, | ||
| 97 | .map_io = l7200_map_io, | ||
| 98 | .init_irq = l7200_init_irq, | ||
| 99 | MACHINE_END | ||
| 100 | |||
diff --git a/arch/arm/mach-l7200/include/mach/aux_reg.h b/arch/arm/mach-l7200/include/mach/aux_reg.h deleted file mode 100644 index 4671558cdd51..000000000000 --- a/arch/arm/mach-l7200/include/mach/aux_reg.h +++ /dev/null | |||
| @@ -1,28 +0,0 @@ | |||
| 1 | /* | ||
| 2 | * arch/arm/mach-l7200/include/mach/aux_reg.h | ||
| 3 | * | ||
| 4 | * Copyright (C) 2000 Steve Hill (sjhill@cotw.com) | ||
| 5 | * | ||
| 6 | * Changelog: | ||
| 7 | * 08-02-2000 SJH Created file | ||
| 8 | */ | ||
| 9 | #ifndef _ASM_ARCH_AUXREG_H | ||
| 10 | #define _ASM_ARCH_AUXREG_H | ||
| 11 | |||
| 12 | #include <mach/hardware.h> | ||
| 13 | |||
| 14 | #define l7200aux_reg *((volatile unsigned int *) (AUX_BASE)) | ||
| 15 | |||
| 16 | /* | ||
| 17 | * Auxillary register values | ||
| 18 | */ | ||
| 19 | #define AUX_CLEAR 0x00000000 | ||
| 20 | #define AUX_DIAG_LED_ON 0x00000002 | ||
| 21 | #define AUX_RTS_UART1 0x00000004 | ||
| 22 | #define AUX_DTR_UART1 0x00000008 | ||
| 23 | #define AUX_KBD_COLUMN_12_HIGH 0x00000010 | ||
| 24 | #define AUX_KBD_COLUMN_12_OFF 0x00000020 | ||
| 25 | #define AUX_KBD_COLUMN_13_HIGH 0x00000040 | ||
| 26 | #define AUX_KBD_COLUMN_13_OFF 0x00000080 | ||
| 27 | |||
| 28 | #endif | ||
diff --git a/arch/arm/mach-l7200/include/mach/debug-macro.S b/arch/arm/mach-l7200/include/mach/debug-macro.S deleted file mode 100644 index b69ed344c7c9..000000000000 --- a/arch/arm/mach-l7200/include/mach/debug-macro.S +++ /dev/null | |||
| @@ -1,40 +0,0 @@ | |||
| 1 | /* arch/arm/mach-l7200/include/mach/debug-macro.S | ||
| 2 | * | ||
| 3 | * Debugging macro include header | ||
| 4 | * | ||
| 5 | * Copyright (C) 1994-1999 Russell King | ||
| 6 | * Moved from linux/arch/arm/kernel/debug.S by Ben Dooks | ||
| 7 | * | ||
| 8 | * This program is free software; you can redistribute it and/or modify | ||
| 9 | * it under the terms of the GNU General Public License version 2 as | ||
| 10 | * published by the Free Software Foundation. | ||
| 11 | * | ||
| 12 | */ | ||
| 13 | |||
| 14 | .equ io_virt, IO_BASE | ||
| 15 | .equ io_phys, IO_START | ||
| 16 | |||
| 17 | .macro addruart, rx, tmp | ||
| 18 | mrc p15, 0, \rx, c1, c0 | ||
| 19 | tst \rx, #1 @ MMU enabled? | ||
| 20 | moveq \rx, #io_phys @ physical base address | ||
| 21 | movne \rx, #io_virt @ virtual address | ||
| 22 | add \rx, \rx, #0x00044000 @ UART1 | ||
| 23 | @ add \rx, \rx, #0x00045000 @ UART2 | ||
| 24 | .endm | ||
| 25 | |||
| 26 | .macro senduart,rd,rx | ||
| 27 | str \rd, [\rx, #0x0] @ UARTDR | ||
| 28 | .endm | ||
| 29 | |||
| 30 | .macro waituart,rd,rx | ||
| 31 | 1001: ldr \rd, [\rx, #0x18] @ UARTFLG | ||
| 32 | tst \rd, #1 << 5 @ UARTFLGUTXFF - 1 when full | ||
| 33 | bne 1001b | ||
| 34 | .endm | ||
| 35 | |||
| 36 | .macro busyuart,rd,rx | ||
| 37 | 1001: ldr \rd, [\rx, #0x18] @ UARTFLG | ||
| 38 | tst \rd, #1 << 3 @ UARTFLGUBUSY - 1 when busy | ||
| 39 | bne 1001b | ||
| 40 | .endm | ||
diff --git a/arch/arm/mach-l7200/include/mach/entry-macro.S b/arch/arm/mach-l7200/include/mach/entry-macro.S deleted file mode 100644 index 1726d91fc1d3..000000000000 --- a/arch/arm/mach-l7200/include/mach/entry-macro.S +++ /dev/null | |||
| @@ -1,35 +0,0 @@ | |||
| 1 | /* | ||
| 2 | * arch/arm/mach-l7200/include/mach/entry-macro.S | ||
| 3 | * | ||
| 4 | * Low-level IRQ helper macros for L7200-based platforms | ||
| 5 | * | ||
| 6 | * This file is licensed under the terms of the GNU General Public | ||
| 7 | * License version 2. This program is licensed "as is" without any | ||
| 8 | * warranty of any kind, whether express or implied. | ||
| 9 | */ | ||
| 10 | #include <mach/hardware.h> | ||
| 11 | |||
| 12 | .equ irq_base_addr, IO_BASE_2 | ||
| 13 | |||
| 14 | .macro disable_fiq | ||
| 15 | .endm | ||
| 16 | |||
| 17 | .macro get_irqnr_preamble, base, tmp | ||
| 18 | .endm | ||
| 19 | |||
| 20 | .macro arch_ret_to_user, tmp1, tmp2 | ||
| 21 | .endm | ||
| 22 | |||
| 23 | .macro get_irqnr_and_base, irqnr, irqstat, base, tmp | ||
| 24 | mov \irqstat, #irq_base_addr @ Virt addr IRQ regs | ||
| 25 | add \irqstat, \irqstat, #0x00001000 @ Status reg | ||
| 26 | ldr \irqstat, [\irqstat, #0] @ get interrupts | ||
| 27 | mov \irqnr, #0 | ||
| 28 | 1001: tst \irqstat, #1 | ||
| 29 | addeq \irqnr, \irqnr, #1 | ||
| 30 | moveq \irqstat, \irqstat, lsr #1 | ||
| 31 | tsteq \irqnr, #32 | ||
| 32 | beq 1001b | ||
| 33 | teq \irqnr, #32 | ||
| 34 | .endm | ||
| 35 | |||
diff --git a/arch/arm/mach-l7200/include/mach/gp_timers.h b/arch/arm/mach-l7200/include/mach/gp_timers.h deleted file mode 100644 index 2b7086a26b81..000000000000 --- a/arch/arm/mach-l7200/include/mach/gp_timers.h +++ /dev/null | |||
| @@ -1,42 +0,0 @@ | |||
| 1 | /* | ||
| 2 | * arch/arm/mach-l7200/include/mach/gp_timers.h | ||
| 3 | * | ||
| 4 | * Copyright (C) 2000 Steve Hill (sjhill@cotw.com) | ||
| 5 | * | ||
| 6 | * Changelog: | ||
| 7 | * 07-28-2000 SJH Created file | ||
| 8 | * 08-02-2000 SJH Used structure for registers | ||
| 9 | */ | ||
| 10 | #ifndef _ASM_ARCH_GPTIMERS_H | ||
| 11 | #define _ASM_ARCH_GPTIMERS_H | ||
| 12 | |||
| 13 | #include <mach/hardware.h> | ||
| 14 | |||
| 15 | /* | ||
| 16 | * Layout of L7200 general purpose timer registers | ||
| 17 | */ | ||
| 18 | struct GPT_Regs { | ||
| 19 | unsigned int TIMERLOAD; | ||
| 20 | unsigned int TIMERVALUE; | ||
| 21 | unsigned int TIMERCONTROL; | ||
| 22 | unsigned int TIMERCLEAR; | ||
| 23 | }; | ||
| 24 | |||
| 25 | #define GPT_BASE (IO_BASE_2 + 0x3000) | ||
| 26 | #define l7200_timer1_regs ((volatile struct GPT_Regs *) (GPT_BASE)) | ||
| 27 | #define l7200_timer2_regs ((volatile struct GPT_Regs *) (GPT_BASE + 0x20)) | ||
| 28 | |||
| 29 | /* | ||
| 30 | * General register values | ||
| 31 | */ | ||
| 32 | #define GPT_PRESCALE_1 0x00000000 | ||
| 33 | #define GPT_PRESCALE_16 0x00000004 | ||
| 34 | #define GPT_PRESCALE_256 0x00000008 | ||
| 35 | #define GPT_MODE_FREERUN 0x00000000 | ||
| 36 | #define GPT_MODE_PERIODIC 0x00000040 | ||
| 37 | #define GPT_ENABLE 0x00000080 | ||
| 38 | #define GPT_BZTOG 0x00000100 | ||
| 39 | #define GPT_BZMOD 0x00000200 | ||
| 40 | #define GPT_LOAD_MASK 0x0000ffff | ||
| 41 | |||
| 42 | #endif | ||
diff --git a/arch/arm/mach-l7200/include/mach/gpio.h b/arch/arm/mach-l7200/include/mach/gpio.h deleted file mode 100644 index c7b0a5d7b8bb..000000000000 --- a/arch/arm/mach-l7200/include/mach/gpio.h +++ /dev/null | |||
| @@ -1,105 +0,0 @@ | |||
| 1 | /****************************************************************************/ | ||
| 2 | /* | ||
| 3 | * arch/arm/mach-l7200/include/mach/gpio.h | ||
| 4 | * | ||
| 5 | * Registers and helper functions for the L7200 Link-Up Systems | ||
| 6 | * GPIO. | ||
| 7 | * | ||
| 8 | * (C) Copyright 2000, S A McConnell (samcconn@cotw.com) | ||
| 9 | * | ||
| 10 | * This file is subject to the terms and conditions of the GNU General Public | ||
| 11 | * License. See the file COPYING in the main directory of this archive for | ||
| 12 | * more details. | ||
| 13 | */ | ||
| 14 | |||
| 15 | /****************************************************************************/ | ||
| 16 | |||
| 17 | #define GPIO_OFF 0x00005000 /* Offset from IO_START to the GPIO reg's. */ | ||
| 18 | |||
| 19 | /* IO_START and IO_BASE are defined in hardware.h */ | ||
| 20 | |||
| 21 | #define GPIO_START (IO_START_2 + GPIO_OFF) /* Physical addr of the GPIO reg. */ | ||
| 22 | #define GPIO_BASE (IO_BASE_2 + GPIO_OFF) /* Virtual addr of the GPIO reg. */ | ||
| 23 | |||
| 24 | /* Offsets from the start of the GPIO for all the registers. */ | ||
| 25 | #define PADR_OFF 0x000 | ||
| 26 | #define PADDR_OFF 0x004 | ||
| 27 | #define PASBSR_OFF 0x008 | ||
| 28 | #define PAEENR_OFF 0x00c | ||
| 29 | #define PAESNR_OFF 0x010 | ||
| 30 | #define PAESTR_OFF 0x014 | ||
| 31 | #define PAIMR_OFF 0x018 | ||
| 32 | #define PAINT_OFF 0x01c | ||
| 33 | |||
| 34 | #define PBDR_OFF 0x020 | ||
| 35 | #define PBDDR_OFF 0x024 | ||
| 36 | #define PBSBSR_OFF 0x028 | ||
| 37 | #define PBIMR_OFF 0x038 | ||
| 38 | #define PBINT_OFF 0x03c | ||
| 39 | |||
| 40 | #define PCDR_OFF 0x040 | ||
| 41 | #define PCDDR_OFF 0x044 | ||
| 42 | #define PCSBSR_OFF 0x048 | ||
| 43 | #define PCIMR_OFF 0x058 | ||
| 44 | #define PCINT_OFF 0x05c | ||
| 45 | |||
| 46 | #define PDDR_OFF 0x060 | ||
| 47 | #define PDDDR_OFF 0x064 | ||
| 48 | #define PDSBSR_OFF 0x068 | ||
| 49 | #define PDEENR_OFF 0x06c | ||
| 50 | #define PDESNR_OFF 0x070 | ||
| 51 | #define PDESTR_OFF 0x074 | ||
| 52 | #define PDIMR_OFF 0x078 | ||
| 53 | #define PDINT_OFF 0x07c | ||
| 54 | |||
| 55 | #define PEDR_OFF 0x080 | ||
| 56 | #define PEDDR_OFF 0x084 | ||
| 57 | #define PESBSR_OFF 0x088 | ||
| 58 | #define PEEENR_OFF 0x08c | ||
| 59 | #define PEESNR_OFF 0x090 | ||
| 60 | #define PEESTR_OFF 0x094 | ||
| 61 | #define PEIMR_OFF 0x098 | ||
| 62 | #define PEINT_OFF 0x09c | ||
| 63 | |||
| 64 | /* Define the GPIO registers for use by device drivers and the kernel. */ | ||
| 65 | #define PADR (*(volatile unsigned long *)(GPIO_BASE+PADR_OFF)) | ||
| 66 | #define PADDR (*(volatile unsigned long *)(GPIO_BASE+PADDR_OFF)) | ||
| 67 | #define PASBSR (*(volatile unsigned long *)(GPIO_BASE+PASBSR_OFF)) | ||
| 68 | #define PAEENR (*(volatile unsigned long *)(GPIO_BASE+PAEENR_OFF)) | ||
| 69 | #define PAESNR (*(volatile unsigned long *)(GPIO_BASE+PAESNR_OFF)) | ||
| 70 | #define PAESTR (*(volatile unsigned long *)(GPIO_BASE+PAESTR_OFF)) | ||
| 71 | #define PAIMR (*(volatile unsigned long *)(GPIO_BASE+PAIMR_OFF)) | ||
| 72 | #define PAINT (*(volatile unsigned long *)(GPIO_BASE+PAINT_OFF)) | ||
| 73 | |||
| 74 | #define PBDR (*(volatile unsigned long *)(GPIO_BASE+PBDR_OFF)) | ||
| 75 | #define PBDDR (*(volatile unsigned long *)(GPIO_BASE+PBDDR_OFF)) | ||
| 76 | #define PBSBSR (*(volatile unsigned long *)(GPIO_BASE+PBSBSR_OFF)) | ||
| 77 | #define PBIMR (*(volatile unsigned long *)(GPIO_BASE+PBIMR_OFF)) | ||
| 78 | #define PBINT (*(volatile unsigned long *)(GPIO_BASE+PBINT_OFF)) | ||
| 79 | |||
| 80 | #define PCDR (*(volatile unsigned long *)(GPIO_BASE+PCDR_OFF)) | ||
| 81 | #define PCDDR (*(volatile unsigned long *)(GPIO_BASE+PCDDR_OFF)) | ||
| 82 | #define PCSBSR (*(volatile unsigned long *)(GPIO_BASE+PCSBSR_OFF)) | ||
| 83 | #define PCIMR (*(volatile unsigned long *)(GPIO_BASE+PCIMR_OFF)) | ||
| 84 | #define PCINT (*(volatile unsigned long *)(GPIO_BASE+PCINT_OFF)) | ||
| 85 | |||
| 86 | #define PDDR (*(volatile unsigned long *)(GPIO_BASE+PDDR_OFF)) | ||
| 87 | #define PDDDR (*(volatile unsigned long *)(GPIO_BASE+PDDDR_OFF)) | ||
| 88 | #define PDSBSR (*(volatile unsigned long *)(GPIO_BASE+PDSBSR_OFF)) | ||
| 89 | #define PDEENR (*(volatile unsigned long *)(GPIO_BASE+PDEENR_OFF)) | ||
| 90 | #define PDESNR (*(volatile unsigned long *)(GPIO_BASE+PDESNR_OFF)) | ||
| 91 | #define PDESTR (*(volatile unsigned long *)(GPIO_BASE+PDESTR_OFF)) | ||
| 92 | #define PDIMR (*(volatile unsigned long *)(GPIO_BASE+PDIMR_OFF)) | ||
| 93 | #define PDINT (*(volatile unsigned long *)(GPIO_BASE+PDINT_OFF)) | ||
| 94 | |||
| 95 | #define PEDR (*(volatile unsigned long *)(GPIO_BASE+PEDR_OFF)) | ||
| 96 | #define PEDDR (*(volatile unsigned long *)(GPIO_BASE+PEDDR_OFF)) | ||
| 97 | #define PESBSR (*(volatile unsigned long *)(GPIO_BASE+PESBSR_OFF)) | ||
| 98 | #define PEEENR (*(volatile unsigned long *)(GPIO_BASE+PEEENR_OFF)) | ||
| 99 | #define PEESNR (*(volatile unsigned long *)(GPIO_BASE+PEESNR_OFF)) | ||
| 100 | #define PEESTR (*(volatile unsigned long *)(GPIO_BASE+PEESTR_OFF)) | ||
| 101 | #define PEIMR (*(volatile unsigned long *)(GPIO_BASE+PEIMR_OFF)) | ||
| 102 | #define PEINT (*(volatile unsigned long *)(GPIO_BASE+PEINT_OFF)) | ||
| 103 | |||
| 104 | #define VEE_EN 0x02 | ||
| 105 | #define BACKLIGHT_EN 0x04 | ||
diff --git a/arch/arm/mach-l7200/include/mach/hardware.h b/arch/arm/mach-l7200/include/mach/hardware.h deleted file mode 100644 index c31909cfc254..000000000000 --- a/arch/arm/mach-l7200/include/mach/hardware.h +++ /dev/null | |||
| @@ -1,57 +0,0 @@ | |||
| 1 | /* | ||
| 2 | * arch/arm/mach-l7200/include/mach/hardware.h | ||
| 3 | * | ||
| 4 | * Copyright (C) 2000 Rob Scott (rscott@mtrob.fdns.net) | ||
| 5 | * Steve Hill (sjhill@cotw.com) | ||
| 6 | * | ||
| 7 | * This file contains the hardware definitions for the | ||
| 8 | * LinkUp Systems L7200 SOC development board. | ||
| 9 | * | ||
| 10 | * Changelog: | ||
| 11 | * 02-01-2000 RS Created L7200 version, derived from rpc code | ||
| 12 | * 03-21-2000 SJH Cleaned up file | ||
| 13 | * 04-21-2000 RS Changed mapping of I/O in virtual space | ||
| 14 | * 04-25-2000 SJH Removed unused symbols and such | ||
| 15 | * 05-05-2000 SJH Complete rewrite | ||
| 16 | * 07-31-2000 SJH Added undocumented debug auxillary port to | ||
| 17 | * get at last two columns for keyboard driver | ||
| 18 | */ | ||
| 19 | #ifndef __ASM_ARCH_HARDWARE_H | ||
| 20 | #define __ASM_ARCH_HARDWARE_H | ||
| 21 | |||
| 22 | /* Hardware addresses of major areas. | ||
| 23 | * *_START is the physical address | ||
| 24 | * *_SIZE is the size of the region | ||
| 25 | * *_BASE is the virtual address | ||
| 26 | */ | ||
| 27 | #define RAM_START 0xf0000000 | ||
| 28 | #define RAM_SIZE 0x02000000 | ||
| 29 | #define RAM_BASE 0xc0000000 | ||
| 30 | |||
| 31 | #define IO_START 0x80000000 /* I/O */ | ||
| 32 | #define IO_SIZE 0x01000000 | ||
| 33 | #define IO_BASE 0xd0000000 | ||
| 34 | |||
| 35 | #define IO_START_2 0x90000000 /* I/O */ | ||
| 36 | #define IO_SIZE_2 0x01000000 | ||
| 37 | #define IO_BASE_2 0xd1000000 | ||
| 38 | |||
| 39 | #define AUX_START 0x1a000000 /* AUX PORT */ | ||
| 40 | #define AUX_SIZE 0x01000000 | ||
| 41 | #define AUX_BASE 0xd2000000 | ||
| 42 | |||
| 43 | #define FLASH1_START 0x00000000 /* FLASH BANK 1 */ | ||
| 44 | #define FLASH1_SIZE 0x01000000 | ||
| 45 | #define FLASH1_BASE 0xd3000000 | ||
| 46 | |||
| 47 | #define FLASH2_START 0x10000000 /* FLASH BANK 2 */ | ||
| 48 | #define FLASH2_SIZE 0x01000000 | ||
| 49 | #define FLASH2_BASE 0xd4000000 | ||
| 50 | |||
| 51 | #define ISA_START 0x20000000 /* ISA */ | ||
| 52 | #define ISA_SIZE 0x20000000 | ||
| 53 | #define ISA_BASE 0xe0000000 | ||
| 54 | |||
| 55 | #define PCIO_BASE IO_BASE | ||
| 56 | |||
| 57 | #endif | ||
diff --git a/arch/arm/mach-l7200/include/mach/io.h b/arch/arm/mach-l7200/include/mach/io.h deleted file mode 100644 index a770a89fb708..000000000000 --- a/arch/arm/mach-l7200/include/mach/io.h +++ /dev/null | |||
| @@ -1,21 +0,0 @@ | |||
| 1 | /* | ||
| 2 | * arch/arm/mach-l7200/include/mach/io.h | ||
| 3 | * | ||
| 4 | * Copyright (C) 2000 Steve Hill (sjhill@cotw.com) | ||
| 5 | * | ||
| 6 | * Changelog: | ||
| 7 | * 03-21-2000 SJH Created from arch/arm/mach-nexuspci/include/mach/io.h | ||
| 8 | * 08-31-2000 SJH Added in IO functions necessary for new drivers | ||
| 9 | */ | ||
| 10 | #ifndef __ASM_ARM_ARCH_IO_H | ||
| 11 | #define __ASM_ARM_ARCH_IO_H | ||
| 12 | |||
| 13 | #define IO_SPACE_LIMIT 0xffffffff | ||
| 14 | |||
| 15 | /* | ||
| 16 | * There are not real ISA nor PCI buses, so we fake it. | ||
| 17 | */ | ||
| 18 | #define __io(a) __typesafe_io(a) | ||
| 19 | #define __mem_pci(a) (a) | ||
| 20 | |||
| 21 | #endif | ||
diff --git a/arch/arm/mach-l7200/include/mach/irqs.h b/arch/arm/mach-l7200/include/mach/irqs.h deleted file mode 100644 index 7edffd713c5b..000000000000 --- a/arch/arm/mach-l7200/include/mach/irqs.h +++ /dev/null | |||
| @@ -1,56 +0,0 @@ | |||
| 1 | /* | ||
| 2 | * arch/arm/mach-l7200/include/mach/irqs.h | ||
| 3 | * | ||
| 4 | * Copyright (C) 2000 Rob Scott (rscott@mtrob.fdns.net) | ||
| 5 | * Steve Hill (sjhill@cotw.com) | ||
| 6 | * | ||
| 7 | * Changelog: | ||
| 8 | * 01-02-2000 RS Create l7200 version | ||
| 9 | * 03-28-2000 SJH Removed unused interrupt | ||
| 10 | * 07-28-2000 SJH Added pseudo-keyboard interrupt | ||
| 11 | */ | ||
| 12 | |||
| 13 | /* | ||
| 14 | * NOTE: The second timer (Timer 2) is used as the keyboard | ||
| 15 | * interrupt when the keyboard driver is enabled. | ||
| 16 | */ | ||
| 17 | |||
| 18 | #define NR_IRQS 32 | ||
| 19 | |||
| 20 | #define IRQ_STWDOG 0 /* Watchdog timer */ | ||
| 21 | #define IRQ_PROG 1 /* Programmable interrupt */ | ||
| 22 | #define IRQ_DEBUG_RX 2 /* Comm Rx debug */ | ||
| 23 | #define IRQ_DEBUG_TX 3 /* Comm Tx debug */ | ||
| 24 | #define IRQ_GCTC1 4 /* Timer 1 */ | ||
| 25 | #define IRQ_GCTC2 5 /* Timer 2 / Keyboard */ | ||
| 26 | #define IRQ_DMA 6 /* DMA controller */ | ||
| 27 | #define IRQ_CLCD 7 /* Color LCD controller */ | ||
| 28 | #define IRQ_SM_RX 8 /* Smart card */ | ||
| 29 | #define IRQ_SM_TX 9 /* Smart cart */ | ||
| 30 | #define IRQ_SM_RST 10 /* Smart card */ | ||
| 31 | #define IRQ_SIB 11 /* Serial Interface Bus */ | ||
| 32 | #define IRQ_MMC 12 /* MultiMediaCard */ | ||
| 33 | #define IRQ_SSP1 13 /* Synchronous Serial Port 1 */ | ||
| 34 | #define IRQ_SSP2 14 /* Synchronous Serial Port 1 */ | ||
| 35 | #define IRQ_SPI 15 /* SPI slave */ | ||
| 36 | #define IRQ_UART_1 16 /* UART 1 */ | ||
| 37 | #define IRQ_UART_2 17 /* UART 2 */ | ||
| 38 | #define IRQ_IRDA 18 /* IRDA */ | ||
| 39 | #define IRQ_RTC_TICK 19 /* Real Time Clock tick */ | ||
| 40 | #define IRQ_RTC_ALARM 20 /* Real Time Clock alarm */ | ||
| 41 | #define IRQ_GPIO 21 /* General Purpose IO */ | ||
| 42 | #define IRQ_GPIO_DMA 22 /* General Purpose IO, DMA */ | ||
| 43 | #define IRQ_M2M 23 /* Memory to memory DMA */ | ||
| 44 | #define IRQ_RESERVED 24 /* RESERVED, don't use */ | ||
| 45 | #define IRQ_INTF 25 /* External active low interrupt */ | ||
| 46 | #define IRQ_INT0 26 /* External active low interrupt */ | ||
| 47 | #define IRQ_INT1 27 /* External active low interrupt */ | ||
| 48 | #define IRQ_INT2 28 /* External active low interrupt */ | ||
| 49 | #define IRQ_UCB1200 29 /* Interrupt generated by UCB1200*/ | ||
| 50 | #define IRQ_BAT_LO 30 /* Low batery or external power */ | ||
| 51 | #define IRQ_MEDIA_CHG 31 /* Media change interrupt */ | ||
| 52 | |||
| 53 | /* | ||
| 54 | * This is the offset of the FIQ "IRQ" numbers | ||
| 55 | */ | ||
| 56 | #define FIQ_START 64 | ||
diff --git a/arch/arm/mach-l7200/include/mach/memory.h b/arch/arm/mach-l7200/include/mach/memory.h deleted file mode 100644 index 9fb40ed2f03b..000000000000 --- a/arch/arm/mach-l7200/include/mach/memory.h +++ /dev/null | |||
| @@ -1,26 +0,0 @@ | |||
| 1 | /* | ||
| 2 | * arch/arm/mach-l7200/include/mach/memory.h | ||
| 3 | * | ||
| 4 | * Copyright (c) 2000 Steve Hill (sjhill@cotw.com) | ||
| 5 | * Copyright (c) 2000 Rob Scott (rscott@mtrob.fdns.net) | ||
| 6 | * | ||
| 7 | * Changelog: | ||
| 8 | * 03-13-2000 SJH Created | ||
| 9 | * 04-13-2000 RS Changed bus macros for new addr | ||
| 10 | * 05-03-2000 SJH Removed bus macros and fixed virt_to_phys macro | ||
| 11 | */ | ||
| 12 | #ifndef __ASM_ARCH_MEMORY_H | ||
| 13 | #define __ASM_ARCH_MEMORY_H | ||
| 14 | |||
| 15 | /* | ||
| 16 | * Physical DRAM offset on the L7200 SDB. | ||
| 17 | */ | ||
| 18 | #define PHYS_OFFSET UL(0xf0000000) | ||
| 19 | |||
| 20 | /* | ||
| 21 | * Cache flushing area - ROM | ||
| 22 | */ | ||
| 23 | #define FLUSH_BASE_PHYS 0x40000000 | ||
| 24 | #define FLUSH_BASE 0xdf000000 | ||
| 25 | |||
| 26 | #endif | ||
diff --git a/arch/arm/mach-l7200/include/mach/pmpcon.h b/arch/arm/mach-l7200/include/mach/pmpcon.h deleted file mode 100644 index 3959871e8361..000000000000 --- a/arch/arm/mach-l7200/include/mach/pmpcon.h +++ /dev/null | |||
| @@ -1,46 +0,0 @@ | |||
| 1 | /****************************************************************************/ | ||
| 2 | /* | ||
| 3 | * arch/arm/mach-l7200/include/mach/pmpcon.h | ||
| 4 | * | ||
| 5 | * Registers and helper functions for the L7200 Link-Up Systems | ||
| 6 | * DC/DC converter register. | ||
| 7 | * | ||
| 8 | * (C) Copyright 2000, S A McConnell (samcconn@cotw.com) | ||
| 9 | * | ||
| 10 | * This file is subject to the terms and conditions of the GNU General Public | ||
| 11 | * License. See the file COPYING in the main directory of this archive for | ||
| 12 | * more details. | ||
| 13 | */ | ||
| 14 | |||
| 15 | /****************************************************************************/ | ||
| 16 | |||
| 17 | #define PMPCON_OFF 0x00006000 /* Offset from IO_START_2. */ | ||
| 18 | |||
| 19 | /* IO_START_2 and IO_BASE_2 are defined in hardware.h */ | ||
| 20 | |||
| 21 | #define PMPCON_START (IO_START_2 + PMPCON_OFF) /* Physical address of reg. */ | ||
| 22 | #define PMPCON_BASE (IO_BASE_2 + PMPCON_OFF) /* Virtual address of reg. */ | ||
| 23 | |||
| 24 | |||
| 25 | #define PMPCON (*(volatile unsigned int *)(PMPCON_BASE)) | ||
| 26 | |||
| 27 | #define PWM2_50CYCLE 0x800 | ||
| 28 | #define CONTRAST 0x9 | ||
| 29 | |||
| 30 | #define PWM1H (CONTRAST) | ||
| 31 | #define PWM1L (CONTRAST << 4) | ||
| 32 | |||
| 33 | #define PMPCON_VALUE (PWM2_50CYCLE | PWM1L | PWM1H) | ||
| 34 | |||
| 35 | /* PMPCON = 0x811; // too light and fuzzy | ||
| 36 | * PMPCON = 0x844; | ||
| 37 | * PMPCON = 0x866; // better color poor depth | ||
| 38 | * PMPCON = 0x888; // Darker but better depth | ||
| 39 | * PMPCON = 0x899; // Darker even better depth | ||
| 40 | * PMPCON = 0x8aa; // too dark even better depth | ||
| 41 | * PMPCON = 0X8cc; // Way too dark | ||
| 42 | */ | ||
| 43 | |||
| 44 | /* As CONTRAST value increases the greater the depth perception and | ||
| 45 | * the darker the colors. | ||
| 46 | */ | ||
diff --git a/arch/arm/mach-l7200/include/mach/pmu.h b/arch/arm/mach-l7200/include/mach/pmu.h deleted file mode 100644 index a2da7aedf208..000000000000 --- a/arch/arm/mach-l7200/include/mach/pmu.h +++ /dev/null | |||
| @@ -1,125 +0,0 @@ | |||
| 1 | /****************************************************************************/ | ||
| 2 | /* | ||
| 3 | * arch/arm/mach-l7200/include/mach/pmu.h | ||
| 4 | * | ||
| 5 | * Registers and helper functions for the L7200 Link-Up Systems | ||
| 6 | * Power Management Unit (PMU). | ||
| 7 | * | ||
| 8 | * (C) Copyright 2000, S A McConnell (samcconn@cotw.com) | ||
| 9 | * | ||
| 10 | * This file is subject to the terms and conditions of the GNU General Public | ||
| 11 | * License. See the file COPYING in the main directory of this archive for | ||
| 12 | * more details. | ||
| 13 | */ | ||
| 14 | |||
| 15 | /****************************************************************************/ | ||
| 16 | |||
| 17 | #define PMU_OFF 0x00050000 /* Offset from IO_START to the PMU registers. */ | ||
| 18 | |||
| 19 | /* IO_START and IO_BASE are defined in hardware.h */ | ||
| 20 | |||
| 21 | #define PMU_START (IO_START + PMU_OFF) /* Physical addr. of the PMU reg. */ | ||
| 22 | #define PMU_BASE (IO_BASE + PMU_OFF) /* Virtual addr. of the PMU reg. */ | ||
| 23 | |||
| 24 | |||
| 25 | /* Define the PMU registers for use by device drivers and the kernel. */ | ||
| 26 | |||
| 27 | typedef struct { | ||
| 28 | unsigned int CURRENT; /* Current configuration register */ | ||
| 29 | unsigned int NEXT; /* Next configuration register */ | ||
| 30 | unsigned int reserved; | ||
| 31 | unsigned int RUN; /* Run configuration register */ | ||
| 32 | unsigned int COMM; /* Configuration command register */ | ||
| 33 | unsigned int SDRAM; /* SDRAM configuration bypass register */ | ||
| 34 | } pmu_interface; | ||
| 35 | |||
| 36 | #define PMU ((volatile pmu_interface *)(PMU_BASE)) | ||
| 37 | |||
| 38 | |||
| 39 | /* Macro's for reading the common register fields. */ | ||
| 40 | |||
| 41 | #define GET_TRANSOP(reg) ((reg >> 25) & 0x03) /* Bits 26-25 */ | ||
| 42 | #define GET_OSCEN(reg) ((reg >> 16) & 0x01) | ||
| 43 | #define GET_OSCMUX(reg) ((reg >> 15) & 0x01) | ||
| 44 | #define GET_PLLMUL(reg) ((reg >> 9) & 0x3f) /* Bits 14-9 */ | ||
| 45 | #define GET_PLLEN(reg) ((reg >> 8) & 0x01) | ||
| 46 | #define GET_PLLMUX(reg) ((reg >> 7) & 0x01) | ||
| 47 | #define GET_BCLK_DIV(reg) ((reg >> 3) & 0x03) /* Bits 4-3 */ | ||
| 48 | #define GET_SDRB_SEL(reg) ((reg >> 2) & 0x01) | ||
| 49 | #define GET_SDRF_SEL(reg) ((reg >> 1) & 0x01) | ||
| 50 | #define GET_FASTBUS(reg) (reg & 0x1) | ||
| 51 | |||
| 52 | /* CFG_NEXT register */ | ||
| 53 | |||
| 54 | #define CFG_NEXT_CLOCKRECOVERY ((PMU->NEXT >> 18) & 0x7f) /* Bits 24-18 */ | ||
| 55 | #define CFG_NEXT_INTRET ((PMU->NEXT >> 17) & 0x01) | ||
| 56 | #define CFG_NEXT_SDR_STOP ((PMU->NEXT >> 6) & 0x01) | ||
| 57 | #define CFG_NEXT_SYSCLKEN ((PMU->NEXT >> 5) & 0x01) | ||
| 58 | |||
| 59 | /* Useful field values that can be used to construct the | ||
| 60 | * CFG_NEXT and CFG_RUN registers. | ||
| 61 | */ | ||
| 62 | |||
| 63 | #define TRANSOP_NOP 0<<25 /* NOCHANGE_NOSTALL */ | ||
| 64 | #define NOCHANGE_STALL 1<<25 | ||
| 65 | #define CHANGE_NOSTALL 2<<25 | ||
| 66 | #define CHANGE_STALL 3<<25 | ||
| 67 | |||
| 68 | #define INTRET 1<<17 | ||
| 69 | #define OSCEN 1<<16 | ||
| 70 | #define OSCMUX 1<<15 | ||
| 71 | |||
| 72 | /* PLL frequencies */ | ||
| 73 | |||
| 74 | #define PLLMUL_0 0<<9 /* 3.6864 MHz */ | ||
| 75 | #define PLLMUL_1 1<<9 /* ?????? MHz */ | ||
| 76 | #define PLLMUL_5 5<<9 /* 18.432 MHz */ | ||
| 77 | #define PLLMUL_10 10<<9 /* 36.864 MHz */ | ||
| 78 | #define PLLMUL_18 18<<9 /* ?????? MHz */ | ||
| 79 | #define PLLMUL_20 20<<9 /* 73.728 MHz */ | ||
| 80 | #define PLLMUL_32 32<<9 /* ?????? MHz */ | ||
| 81 | #define PLLMUL_35 35<<9 /* 129.024 MHz */ | ||
| 82 | #define PLLMUL_36 36<<9 /* ?????? MHz */ | ||
| 83 | #define PLLMUL_39 39<<9 /* ?????? MHz */ | ||
| 84 | #define PLLMUL_40 40<<9 /* 147.456 MHz */ | ||
| 85 | |||
| 86 | /* Clock recovery times */ | ||
| 87 | |||
| 88 | #define CRCLOCK_1 1<<18 | ||
| 89 | #define CRCLOCK_2 2<<18 | ||
| 90 | #define CRCLOCK_4 4<<18 | ||
| 91 | #define CRCLOCK_8 8<<18 | ||
| 92 | #define CRCLOCK_16 16<<18 | ||
| 93 | #define CRCLOCK_32 32<<18 | ||
| 94 | #define CRCLOCK_63 63<<18 | ||
| 95 | #define CRCLOCK_127 127<<18 | ||
| 96 | |||
| 97 | #define PLLEN 1<<8 | ||
| 98 | #define PLLMUX 1<<7 | ||
| 99 | #define SDR_STOP 1<<6 | ||
| 100 | #define SYSCLKEN 1<<5 | ||
| 101 | |||
| 102 | #define BCLK_DIV_4 2<<3 | ||
| 103 | #define BCLK_DIV_2 1<<3 | ||
| 104 | #define BCLK_DIV_1 0<<3 | ||
| 105 | |||
| 106 | #define SDRB_SEL 1<<2 | ||
| 107 | #define SDRF_SEL 1<<1 | ||
| 108 | #define FASTBUS 1<<0 | ||
| 109 | |||
| 110 | |||
| 111 | /* CFG_SDRAM */ | ||
| 112 | |||
| 113 | #define SDRREFFQ 1<<0 /* Only if SDRSTOPRQ is not set. */ | ||
| 114 | #define SDRREFACK 1<<1 /* Read-only */ | ||
| 115 | #define SDRSTOPRQ 1<<2 /* Only if SDRREFFQ is not set. */ | ||
| 116 | #define SDRSTOPACK 1<<3 /* Read-only */ | ||
| 117 | #define PICEN 1<<4 /* Enable Co-procesor */ | ||
| 118 | #define PICTEST 1<<5 | ||
| 119 | |||
| 120 | #define GET_SDRREFFQ ((PMU->SDRAM >> 0) & 0x01) | ||
| 121 | #define GET_SDRREFACK ((PMU->SDRAM >> 1) & 0x01) /* Read-only */ | ||
| 122 | #define GET_SDRSTOPRQ ((PMU->SDRAM >> 2) & 0x01) | ||
| 123 | #define GET_SDRSTOPACK ((PMU->SDRAM >> 3) & 0x01) /* Read-only */ | ||
| 124 | #define GET_PICEN ((PMU->SDRAM >> 4) & 0x01) | ||
| 125 | #define GET_PICTEST ((PMU->SDRAM >> 5) & 0x01) | ||
diff --git a/arch/arm/mach-l7200/include/mach/serial.h b/arch/arm/mach-l7200/include/mach/serial.h deleted file mode 100644 index adc05e5f8378..000000000000 --- a/arch/arm/mach-l7200/include/mach/serial.h +++ /dev/null | |||
| @@ -1,37 +0,0 @@ | |||
| 1 | /* | ||
| 2 | * arch/arm/mach-l7200/include/mach/serial.h | ||
| 3 | * | ||
| 4 | * Copyright (c) 2000 Rob Scott (rscott@mtrob.fdns.net) | ||
| 5 | * Steve Hill (sjhill@cotw.com) | ||
| 6 | * | ||
| 7 | * Changelog: | ||
| 8 | * 03-20-2000 SJH Created | ||
| 9 | * 03-26-2000 SJH Added flags for serial ports | ||
| 10 | * 03-27-2000 SJH Corrected BASE_BAUD value | ||
| 11 | * 04-14-2000 RS Made register addr dependent on IO_BASE | ||
| 12 | * 05-03-2000 SJH Complete rewrite | ||
| 13 | * 05-09-2000 SJH Stripped out architecture specific serial stuff | ||
| 14 | * and placed it in a separate file | ||
| 15 | * 07-28-2000 SJH Moved base baud rate variable | ||
| 16 | */ | ||
| 17 | #ifndef __ASM_ARCH_SERIAL_H | ||
| 18 | #define __ASM_ARCH_SERIAL_H | ||
| 19 | |||
| 20 | /* | ||
| 21 | * This assumes you have a 3.6864 MHz clock for your UART. | ||
| 22 | */ | ||
| 23 | #define BASE_BAUD 3686400 | ||
| 24 | |||
| 25 | /* | ||
| 26 | * Standard COM flags | ||
| 27 | */ | ||
| 28 | #define STD_COM_FLAGS (ASYNC_BOOT_AUTOCONF | ASYNC_SKIP_TEST) | ||
| 29 | |||
| 30 | #define STD_SERIAL_PORT_DEFNS \ | ||
| 31 | /* MAGIC UART CLK PORT IRQ FLAGS */ \ | ||
| 32 | { 0, BASE_BAUD, UART1_BASE, IRQ_UART_1, STD_COM_FLAGS }, /* ttyLU0 */ \ | ||
| 33 | { 0, BASE_BAUD, UART2_BASE, IRQ_UART_2, STD_COM_FLAGS }, /* ttyLU1 */ \ | ||
| 34 | |||
| 35 | #define EXTRA_SERIAL_PORT_DEFNS | ||
| 36 | |||
| 37 | #endif | ||
diff --git a/arch/arm/mach-l7200/include/mach/serial_l7200.h b/arch/arm/mach-l7200/include/mach/serial_l7200.h deleted file mode 100644 index 645f1c5e568d..000000000000 --- a/arch/arm/mach-l7200/include/mach/serial_l7200.h +++ /dev/null | |||
| @@ -1,101 +0,0 @@ | |||
| 1 | /* | ||
| 2 | * arch/arm/mach-l7200/include/mach/serial_l7200.h | ||
| 3 | * | ||
| 4 | * Copyright (c) 2000 Steven Hill (sjhill@cotw.com) | ||
| 5 | * | ||
| 6 | * Changelog: | ||
| 7 | * 05-09-2000 SJH Created | ||
| 8 | */ | ||
| 9 | #ifndef __ASM_ARCH_SERIAL_L7200_H | ||
| 10 | #define __ASM_ARCH_SERIAL_L7200_H | ||
| 11 | |||
| 12 | #include <mach/memory.h> | ||
| 13 | |||
| 14 | /* | ||
| 15 | * This assumes you have a 3.6864 MHz clock for your UART. | ||
| 16 | */ | ||
| 17 | #define BASE_BAUD 3686400 | ||
| 18 | |||
| 19 | /* | ||
| 20 | * UART base register addresses | ||
| 21 | */ | ||
| 22 | #define UART1_BASE (IO_BASE + 0x00044000) | ||
| 23 | #define UART2_BASE (IO_BASE + 0x00045000) | ||
| 24 | |||
| 25 | /* | ||
| 26 | * UART register offsets | ||
| 27 | */ | ||
| 28 | #define UARTDR 0x00 /* Tx/Rx data */ | ||
| 29 | #define RXSTAT 0x04 /* Rx status */ | ||
| 30 | #define H_UBRLCR 0x08 /* mode register high */ | ||
| 31 | #define M_UBRLCR 0x0C /* mode reg mid (MSB of baud)*/ | ||
| 32 | #define L_UBRLCR 0x10 /* mode reg low (LSB of baud)*/ | ||
| 33 | #define UARTCON 0x14 /* control register */ | ||
| 34 | #define UARTFLG 0x18 /* flag register */ | ||
| 35 | #define UARTINTSTAT 0x1C /* FIFO IRQ status register */ | ||
| 36 | #define UARTINTMASK 0x20 /* FIFO IRQ mask register */ | ||
| 37 | |||
| 38 | /* | ||
| 39 | * UART baud rate register values | ||
| 40 | */ | ||
| 41 | #define BR_110 0x827 | ||
| 42 | #define BR_1200 0x06e | ||
| 43 | #define BR_2400 0x05f | ||
| 44 | #define BR_4800 0x02f | ||
| 45 | #define BR_9600 0x017 | ||
| 46 | #define BR_14400 0x00f | ||
| 47 | #define BR_19200 0x00b | ||
| 48 | #define BR_38400 0x005 | ||
| 49 | #define BR_57600 0x003 | ||
| 50 | #define BR_76800 0x002 | ||
| 51 | #define BR_115200 0x001 | ||
| 52 | |||
| 53 | /* | ||
| 54 | * Receiver status register (RXSTAT) mask values | ||
| 55 | */ | ||
| 56 | #define RXSTAT_NO_ERR 0x00 /* No error */ | ||
| 57 | #define RXSTAT_FRM_ERR 0x01 /* Framing error */ | ||
| 58 | #define RXSTAT_PAR_ERR 0x02 /* Parity error */ | ||
| 59 | #define RXSTAT_OVR_ERR 0x04 /* Overrun error */ | ||
| 60 | |||
| 61 | /* | ||
| 62 | * High byte of UART bit rate and line control register (H_UBRLCR) values | ||
| 63 | */ | ||
| 64 | #define UBRLCR_BRK 0x01 /* generate break on tx */ | ||
| 65 | #define UBRLCR_PEN 0x02 /* enable parity */ | ||
| 66 | #define UBRLCR_PDIS 0x00 /* disable parity */ | ||
| 67 | #define UBRLCR_EVEN 0x04 /* 1= even parity,0 = odd parity */ | ||
| 68 | #define UBRLCR_STP2 0x08 /* transmit 2 stop bits */ | ||
| 69 | #define UBRLCR_FIFO 0x10 /* enable FIFO */ | ||
| 70 | #define UBRLCR_LEN5 0x60 /* word length5 */ | ||
| 71 | #define UBRLCR_LEN6 0x40 /* word length6 */ | ||
| 72 | #define UBRLCR_LEN7 0x20 /* word length7 */ | ||
| 73 | #define UBRLCR_LEN8 0x00 /* word length8 */ | ||
| 74 | |||
| 75 | /* | ||
| 76 | * UART control register (UARTCON) values | ||
| 77 | */ | ||
| 78 | #define UARTCON_UARTEN 0x01 /* Enable UART */ | ||
| 79 | #define UARTCON_DMAONERR 0x08 /* Mask RxDmaRq when errors occur */ | ||
| 80 | |||
| 81 | /* | ||
| 82 | * UART flag register (UARTFLG) mask values | ||
| 83 | */ | ||
| 84 | #define UARTFLG_UTXFF 0x20 /* Transmit FIFO full */ | ||
| 85 | #define UARTFLG_URXFE 0x10 /* Receiver FIFO empty */ | ||
| 86 | #define UARTFLG_UBUSY 0x08 /* Transmitter busy */ | ||
| 87 | #define UARTFLG_DCD 0x04 /* Data carrier detect */ | ||
| 88 | #define UARTFLG_DSR 0x02 /* Data set ready */ | ||
| 89 | #define UARTFLG_CTS 0x01 /* Clear to send */ | ||
| 90 | |||
| 91 | /* | ||
| 92 | * UART interrupt status/clear registers (UARTINTSTAT/CLR) values | ||
| 93 | */ | ||
| 94 | #define UART_TXINT 0x01 /* TX interrupt */ | ||
| 95 | #define UART_RXINT 0x02 /* RX interrupt */ | ||
| 96 | #define UART_RXERRINT 0x04 /* RX error interrupt */ | ||
| 97 | #define UART_MSINT 0x08 /* Modem Status interrupt */ | ||
| 98 | #define UART_UDINT 0x10 /* UART Disabled interrupt */ | ||
| 99 | #define UART_ALLIRQS 0x1f /* All interrupts */ | ||
| 100 | |||
| 101 | #endif | ||
diff --git a/arch/arm/mach-l7200/include/mach/sib.h b/arch/arm/mach-l7200/include/mach/sib.h deleted file mode 100644 index 965728712cf3..000000000000 --- a/arch/arm/mach-l7200/include/mach/sib.h +++ /dev/null | |||
| @@ -1,119 +0,0 @@ | |||
| 1 | /****************************************************************************/ | ||
| 2 | /* | ||
| 3 | * arch/arm/mach-l7200/include/mach/sib.h | ||
| 4 | * | ||
| 5 | * Registers and helper functions for the Serial Interface Bus. | ||
| 6 | * | ||
| 7 | * (C) Copyright 2000, S A McConnell (samcconn@cotw.com) | ||
| 8 | * | ||
| 9 | * This file is subject to the terms and conditions of the GNU General Public | ||
| 10 | * License. See the file COPYING in the main directory of this archive for | ||
| 11 | * more details. | ||
| 12 | */ | ||
| 13 | |||
| 14 | /****************************************************************************/ | ||
| 15 | |||
| 16 | #define SIB_OFF 0x00040000 /* Offset from IO_START to the SIB reg's. */ | ||
| 17 | |||
| 18 | /* IO_START and IO_BASE are defined in hardware.h */ | ||
| 19 | |||
| 20 | #define SIB_START (IO_START + SIB_OFF) /* Physical addr of the SIB reg. */ | ||
| 21 | #define SIB_BASE (IO_BASE + SIB_OFF) /* Virtual addr of the SIB reg. */ | ||
| 22 | |||
| 23 | /* Offsets from the start of the SIB for all the registers. */ | ||
| 24 | |||
| 25 | /* Define the SIB registers for use by device drivers and the kernel. */ | ||
| 26 | |||
| 27 | typedef struct | ||
| 28 | { | ||
| 29 | unsigned int MCCR; /* SIB Control Register Offset: 0x00 */ | ||
| 30 | unsigned int RES1; /* Reserved Offset: 0x04 */ | ||
| 31 | unsigned int MCDR0; /* SIB Data Register 0 Offset: 0x08 */ | ||
| 32 | unsigned int MCDR1; /* SIB Data Register 1 Offset: 0x0c */ | ||
| 33 | unsigned int MCDR2; /* SIB Data Register 2 (UCB1x00) Offset: 0x10 */ | ||
| 34 | unsigned int RES2; /* Reserved Offset: 0x14 */ | ||
| 35 | unsigned int MCSR; /* SIB Status Register Offset: 0x18 */ | ||
| 36 | } SIB_Interface; | ||
| 37 | |||
| 38 | #define SIB ((volatile SIB_Interface *) (SIB_BASE)) | ||
| 39 | |||
| 40 | /* MCCR */ | ||
| 41 | |||
| 42 | #define INTERNAL_FREQ 9216000 /* Hertz */ | ||
| 43 | #define AUDIO_FREQ 5000 /* Hertz */ | ||
| 44 | #define TELECOM_FREQ 5000 /* Hertz */ | ||
| 45 | |||
| 46 | #define AUDIO_DIVIDE (INTERNAL_FREQ / (32 * AUDIO_FREQ)) | ||
| 47 | #define TELECOM_DIVIDE (INTERNAL_FREQ / (32 * TELECOM_FREQ)) | ||
| 48 | |||
| 49 | #define MCCR_ASD57 AUDIO_DIVIDE | ||
| 50 | #define MCCR_TSD57 (TELECOM_DIVIDE << 8) | ||
| 51 | #define MCCR_MCE (1 << 16) /* SIB enable */ | ||
| 52 | #define MCCR_ECS (1 << 17) /* External Clock Select */ | ||
| 53 | #define MCCR_ADM (1 << 18) /* A/D Data Sampling */ | ||
| 54 | #define MCCR_PMC (1 << 26) /* PIN Multiplexer Control */ | ||
| 55 | |||
| 56 | |||
| 57 | #define GET_ASD ((SIB->MCCR >> 0) & 0x3f) /* Audio Sample Rate Div. */ | ||
| 58 | #define GET_TSD ((SIB->MCCR >> 8) & 0x3f) /* Telcom Sample Rate Div. */ | ||
| 59 | #define GET_MCE ((SIB->MCCR >> 16) & 0x01) /* SIB Enable */ | ||
| 60 | #define GET_ECS ((SIB->MCCR >> 17) & 0x01) /* External Clock Select */ | ||
| 61 | #define GET_ADM ((SIB->MCCR >> 18) & 0x01) /* A/D Data Sampling Mode */ | ||
| 62 | #define GET_TTM ((SIB->MCCR >> 19) & 0x01) /* Telco Trans. FIFO I mask */ | ||
| 63 | #define GET_TRM ((SIB->MCCR >> 20) & 0x01) /* Telco Recv. FIFO I mask */ | ||
| 64 | #define GET_ATM ((SIB->MCCR >> 21) & 0x01) /* Audio Trans. FIFO I mask */ | ||
| 65 | #define GET_ARM ((SIB->MCCR >> 22) & 0x01) /* Audio Recv. FIFO I mask */ | ||
| 66 | #define GET_LBM ((SIB->MCCR >> 23) & 0x01) /* Loop Back Mode */ | ||
| 67 | #define GET_ECP ((SIB->MCCR >> 24) & 0x03) /* Extern. Clck Prescale sel */ | ||
| 68 | #define GET_PMC ((SIB->MCCR >> 26) & 0x01) /* PIN Multiplexer Control */ | ||
| 69 | #define GET_ERI ((SIB->MCCR >> 27) & 0x01) /* External Read Interrupt */ | ||
| 70 | #define GET_EWI ((SIB->MCCR >> 28) & 0x01) /* External Write Interrupt */ | ||
| 71 | |||
| 72 | /* MCDR0 */ | ||
| 73 | |||
| 74 | #define AUDIO_RECV ((SIB->MCDR0 >> 4) & 0xfff) | ||
| 75 | #define AUDIO_WRITE(v) ((SIB->MCDR0 = (v & 0xfff) << 4)) | ||
| 76 | |||
| 77 | /* MCDR1 */ | ||
| 78 | |||
| 79 | #define TELECOM_RECV ((SIB->MCDR1 >> 2) & 032fff) | ||
| 80 | #define TELECOM_WRITE(v) ((SIB->MCDR1 = (v & 0x3fff) << 2)) | ||
| 81 | |||
| 82 | |||
| 83 | /* MCSR */ | ||
| 84 | |||
| 85 | #define MCSR_ATU (1 << 4) /* Audio Transmit FIFO Underrun */ | ||
| 86 | #define MCSR_ARO (1 << 5) /* Audio Receive FIFO Underrun */ | ||
| 87 | #define MCSR_TTU (1 << 6) /* TELECOM Transmit FIFO Underrun */ | ||
| 88 | #define MCSR_TRO (1 << 7) /* TELECOM Receive FIFO Underrun */ | ||
| 89 | |||
| 90 | #define MCSR_CLEAR_UNDERUN_BITS (MCSR_ATU | MCSR_ARO | MCSR_TTU | MCSR_TRO) | ||
| 91 | |||
| 92 | |||
| 93 | #define GET_ATS ((SIB->MCSR >> 0) & 0x01) /* Audio Transmit FIFO Service Req*/ | ||
| 94 | #define GET_ARS ((SIB->MCSR >> 1) & 0x01) /* Audio Recv FIFO Service Request*/ | ||
| 95 | #define GET_TTS ((SIB->MCSR >> 2) & 0x01) /* TELECOM Transmit FIFO Flag */ | ||
| 96 | #define GET_TRS ((SIB->MCSR >> 3) & 0x01) /* TELECOM Recv FIFO Service Req. */ | ||
| 97 | #define GET_ATU ((SIB->MCSR >> 4) & 0x01) /* Audio Transmit FIFO Underrun */ | ||
| 98 | #define GET_ARO ((SIB->MCSR >> 5) & 0x01) /* Audio Receive FIFO Underrun */ | ||
| 99 | #define GET_TTU ((SIB->MCSR >> 6) & 0x01) /* TELECOM Transmit FIFO Underrun */ | ||
| 100 | #define GET_TRO ((SIB->MCSR >> 7) & 0x01) /* TELECOM Receive FIFO Underrun */ | ||
| 101 | #define GET_ANF ((SIB->MCSR >> 8) & 0x01) /* Audio Transmit FIFO not full */ | ||
| 102 | #define GET_ANE ((SIB->MCSR >> 9) & 0x01) /* Audio Receive FIFO not empty */ | ||
| 103 | #define GET_TNF ((SIB->MCSR >> 10) & 0x01) /* Telecom Transmit FIFO not full */ | ||
| 104 | #define GET_TNE ((SIB->MCSR >> 11) & 0x01) /* Telecom Receive FIFO not empty */ | ||
| 105 | #define GET_CWC ((SIB->MCSR >> 12) & 0x01) /* Codec Write Complete */ | ||
| 106 | #define GET_CRC ((SIB->MCSR >> 13) & 0x01) /* Codec Read Complete */ | ||
| 107 | #define GET_ACE ((SIB->MCSR >> 14) & 0x01) /* Audio Codec Enabled */ | ||
| 108 | #define GET_TCE ((SIB->MCSR >> 15) & 0x01) /* Telecom Codec Enabled */ | ||
| 109 | |||
| 110 | /* MCDR2 */ | ||
| 111 | |||
| 112 | #define MCDR2_rW (1 << 16) | ||
| 113 | |||
| 114 | #define WRITE_MCDR2(reg, data) (SIB->MCDR2 =((reg<<17)|MCDR2_rW|(data&0xffff))) | ||
| 115 | #define MCDR2_WRITE_COMPLETE GET_CWC | ||
| 116 | |||
| 117 | #define INITIATE_MCDR2_READ(reg) (SIB->MCDR2 = (reg << 17)) | ||
| 118 | #define MCDR2_READ_COMPLETE GET_CRC | ||
| 119 | #define MCDR2_READ (SIB->MCDR2 & 0xffff) | ||
diff --git a/arch/arm/mach-l7200/include/mach/sys-clock.h b/arch/arm/mach-l7200/include/mach/sys-clock.h deleted file mode 100644 index e9729a35751d..000000000000 --- a/arch/arm/mach-l7200/include/mach/sys-clock.h +++ /dev/null | |||
| @@ -1,67 +0,0 @@ | |||
| 1 | /****************************************************************************/ | ||
| 2 | /* | ||
| 3 | * arch/arm/mach-l7200/include/mach/sys-clock.h | ||
| 4 | * | ||
| 5 | * Registers and helper functions for the L7200 Link-Up Systems | ||
| 6 | * System clocks. | ||
| 7 | * | ||
| 8 | * (C) Copyright 2000, S A McConnell (samcconn@cotw.com) | ||
| 9 | * | ||
| 10 | * This file is subject to the terms and conditions of the GNU General Public | ||
| 11 | * License. See the file COPYING in the main directory of this archive for | ||
| 12 | * more details. | ||
| 13 | */ | ||
| 14 | |||
| 15 | /****************************************************************************/ | ||
| 16 | |||
| 17 | #define SYS_CLOCK_OFF 0x00050030 /* Offset from IO_START. */ | ||
| 18 | |||
| 19 | /* IO_START and IO_BASE are defined in hardware.h */ | ||
| 20 | |||
| 21 | #define SYS_CLOCK_START (IO_START + SYS_CLOCK_OFF) /* Physical address */ | ||
| 22 | #define SYS_CLOCK_BASE (IO_BASE + SYS_CLOCK_OFF) /* Virtual address */ | ||
| 23 | |||
| 24 | /* Define the interface to the SYS_CLOCK */ | ||
| 25 | |||
| 26 | typedef struct | ||
| 27 | { | ||
| 28 | unsigned int ENABLE; | ||
| 29 | unsigned int ESYNC; | ||
| 30 | unsigned int SELECT; | ||
| 31 | } sys_clock_interface; | ||
| 32 | |||
| 33 | #define SYS_CLOCK ((volatile sys_clock_interface *)(SYS_CLOCK_BASE)) | ||
| 34 | |||
| 35 | //#define CLOCK_EN (*(volatile unsigned long *)(PMU_BASE+CLOCK_EN_OFF)) | ||
| 36 | //#define CLOCK_ESYNC (*(volatile unsigned long *)(PMU_BASE+CLOCK_ESYNC_OFF)) | ||
| 37 | //#define CLOCK_SEL (*(volatile unsigned long *)(PMU_BASE+CLOCK_SEL_OFF)) | ||
| 38 | |||
| 39 | /* SYS_CLOCK -> ENABLE */ | ||
| 40 | |||
| 41 | #define SYN_EN 1<<0 | ||
| 42 | #define B18M_EN 1<<1 | ||
| 43 | #define CLK3M6_EN 1<<2 | ||
| 44 | #define BUART_EN 1<<3 | ||
| 45 | #define CLK18MU_EN 1<<4 | ||
| 46 | #define FIR_EN 1<<5 | ||
| 47 | #define MIRN_EN 1<<6 | ||
| 48 | #define UARTM_EN 1<<7 | ||
| 49 | #define SIBADC_EN 1<<8 | ||
| 50 | #define ALTD_EN 1<<9 | ||
| 51 | #define CLCLK_EN 1<<10 | ||
| 52 | |||
| 53 | /* SYS_CLOCK -> SELECT */ | ||
| 54 | |||
| 55 | #define CLK18M_DIV 1<<0 | ||
| 56 | #define MIR_SEL 1<<1 | ||
| 57 | #define SSP_SEL 1<<4 | ||
| 58 | #define MM_DIV 1<<5 | ||
| 59 | #define MM_SEL 1<<6 | ||
| 60 | #define ADC_SEL_2 0<<7 | ||
| 61 | #define ADC_SEL_4 1<<7 | ||
| 62 | #define ADC_SEL_8 3<<7 | ||
| 63 | #define ADC_SEL_16 7<<7 | ||
| 64 | #define ADC_SEL_32 0x0f<<7 | ||
| 65 | #define ADC_SEL_64 0x1f<<7 | ||
| 66 | #define ADC_SEL_128 0x3f<<7 | ||
| 67 | #define ALTD_SEL 1<<13 | ||
diff --git a/arch/arm/mach-l7200/include/mach/system.h b/arch/arm/mach-l7200/include/mach/system.h deleted file mode 100644 index e0dd3b6ae4aa..000000000000 --- a/arch/arm/mach-l7200/include/mach/system.h +++ /dev/null | |||
| @@ -1,29 +0,0 @@ | |||
| 1 | /* | ||
| 2 | * arch/arm/mach-l7200/include/mach/system.h | ||
| 3 | * | ||
| 4 | * Copyright (c) 2000 Steve Hill (sjhill@cotw.com) | ||
| 5 | * | ||
| 6 | * Changelog | ||
| 7 | * 03-21-2000 SJH Created | ||
| 8 | * 04-26-2000 SJH Fixed functions | ||
| 9 | * 05-03-2000 SJH Removed usage of obsolete 'iomd.h' | ||
| 10 | * 05-31-2000 SJH Properly implemented 'arch_idle' | ||
| 11 | */ | ||
| 12 | #ifndef __ASM_ARCH_SYSTEM_H | ||
| 13 | #define __ASM_ARCH_SYSTEM_H | ||
| 14 | |||
| 15 | #include <mach/hardware.h> | ||
| 16 | |||
| 17 | static inline void arch_idle(void) | ||
| 18 | { | ||
| 19 | *(unsigned long *)(IO_BASE + 0x50004) = 1; /* idle mode */ | ||
| 20 | } | ||
| 21 | |||
| 22 | static inline void arch_reset(char mode, const char *cmd) | ||
| 23 | { | ||
| 24 | if (mode == 's') { | ||
| 25 | cpu_reset(0); | ||
| 26 | } | ||
| 27 | } | ||
| 28 | |||
| 29 | #endif | ||
diff --git a/arch/arm/mach-l7200/include/mach/time.h b/arch/arm/mach-l7200/include/mach/time.h deleted file mode 100644 index 061771c2c2bd..000000000000 --- a/arch/arm/mach-l7200/include/mach/time.h +++ /dev/null | |||
| @@ -1,73 +0,0 @@ | |||
| 1 | /* | ||
| 2 | * arch/arm/mach-l7200/include/mach/time.h | ||
| 3 | * | ||
| 4 | * Copyright (C) 2000 Rob Scott (rscott@mtrob.fdns.net) | ||
| 5 | * Steve Hill (sjhill@cotw.com) | ||
| 6 | * | ||
| 7 | * Changelog: | ||
| 8 | * 01-02-2000 RS Created l7200 version, derived from rpc code | ||
| 9 | * 05-03-2000 SJH Complete rewrite | ||
| 10 | */ | ||
| 11 | #ifndef _ASM_ARCH_TIME_H | ||
| 12 | #define _ASM_ARCH_TIME_H | ||
| 13 | |||
| 14 | #include <mach/irqs.h> | ||
| 15 | |||
| 16 | /* | ||
| 17 | * RTC base register address | ||
| 18 | */ | ||
| 19 | #define RTC_BASE (IO_BASE_2 + 0x2000) | ||
| 20 | |||
| 21 | /* | ||
| 22 | * RTC registers | ||
| 23 | */ | ||
| 24 | #define RTC_RTCDR (*(volatile unsigned char *) (RTC_BASE + 0x000)) | ||
| 25 | #define RTC_RTCMR (*(volatile unsigned char *) (RTC_BASE + 0x004)) | ||
| 26 | #define RTC_RTCS (*(volatile unsigned char *) (RTC_BASE + 0x008)) | ||
| 27 | #define RTC_RTCC (*(volatile unsigned char *) (RTC_BASE + 0x008)) | ||
| 28 | #define RTC_RTCDV (*(volatile unsigned char *) (RTC_BASE + 0x00c)) | ||
| 29 | #define RTC_RTCCR (*(volatile unsigned char *) (RTC_BASE + 0x010)) | ||
| 30 | |||
| 31 | /* | ||
| 32 | * RTCCR register values | ||
| 33 | */ | ||
| 34 | #define RTC_RATE_32 0x00 /* 32 Hz tick */ | ||
| 35 | #define RTC_RATE_64 0x10 /* 64 Hz tick */ | ||
| 36 | #define RTC_RATE_128 0x20 /* 128 Hz tick */ | ||
| 37 | #define RTC_RATE_256 0x30 /* 256 Hz tick */ | ||
| 38 | #define RTC_EN_ALARM 0x01 /* Enable alarm */ | ||
| 39 | #define RTC_EN_TIC 0x04 /* Enable counter */ | ||
| 40 | #define RTC_EN_STWDOG 0x08 /* Enable watchdog */ | ||
| 41 | |||
| 42 | /* | ||
| 43 | * Handler for RTC timer interrupt | ||
| 44 | */ | ||
| 45 | static irqreturn_t | ||
| 46 | timer_interrupt(int irq, void *dev_id) | ||
| 47 | { | ||
| 48 | struct pt_regs *regs = get_irq_regs(); | ||
| 49 | do_timer(1); | ||
| 50 | #ifndef CONFIG_SMP | ||
| 51 | update_process_times(user_mode(regs)); | ||
| 52 | #endif | ||
| 53 | do_profile(regs); | ||
| 54 | RTC_RTCC = 0; /* Clear interrupt */ | ||
| 55 | |||
| 56 | return IRQ_HANDLED; | ||
| 57 | } | ||
| 58 | |||
| 59 | /* | ||
| 60 | * Set up RTC timer interrupt, and return the current time in seconds. | ||
| 61 | */ | ||
| 62 | void __init time_init(void) | ||
| 63 | { | ||
| 64 | RTC_RTCC = 0; /* Clear interrupt */ | ||
| 65 | |||
| 66 | timer_irq.handler = timer_interrupt; | ||
| 67 | |||
| 68 | setup_irq(IRQ_RTC_TICK, &timer_irq); | ||
| 69 | |||
| 70 | RTC_RTCCR = RTC_RATE_128 | RTC_EN_TIC; /* Set rate and enable timer */ | ||
| 71 | } | ||
| 72 | |||
| 73 | #endif | ||
diff --git a/arch/arm/mach-l7200/include/mach/timex.h b/arch/arm/mach-l7200/include/mach/timex.h deleted file mode 100644 index ffc96a63b5a2..000000000000 --- a/arch/arm/mach-l7200/include/mach/timex.h +++ /dev/null | |||
| @@ -1,20 +0,0 @@ | |||
| 1 | /* | ||
| 2 | * arch/arm/mach-l7200/include/mach/timex.h | ||
| 3 | * | ||
| 4 | * Copyright (C) 2000 Rob Scott (rscott@mtrob.fdns.net) | ||
| 5 | * Steve Hill (sjhill@cotw.com) | ||
| 6 | * | ||
| 7 | * 04-21-2000 RS Created file | ||
| 8 | * 05-03-2000 SJH Tick rate was wrong | ||
| 9 | * | ||
| 10 | */ | ||
| 11 | |||
| 12 | /* | ||
| 13 | * On the ARM720T, clock ticks are set to 128 Hz. | ||
| 14 | * | ||
| 15 | * NOTE: The actual RTC value is set in 'time.h' which | ||
| 16 | * must be changed when choosing a different tick | ||
| 17 | * rate. The value of HZ in 'param.h' must also | ||
| 18 | * be changed to match below. | ||
| 19 | */ | ||
| 20 | #define CLOCK_TICK_RATE 128 | ||
diff --git a/arch/arm/mach-l7200/include/mach/uncompress.h b/arch/arm/mach-l7200/include/mach/uncompress.h deleted file mode 100644 index 591c962bb315..000000000000 --- a/arch/arm/mach-l7200/include/mach/uncompress.h +++ /dev/null | |||
| @@ -1,39 +0,0 @@ | |||
| 1 | /* | ||
| 2 | * arch/arm/mach-l7200/include/mach/uncompress.h | ||
| 3 | * | ||
| 4 | * Copyright (C) 2000 Steve Hill (sjhill@cotw.com) | ||
| 5 | * | ||
| 6 | * Changelog: | ||
| 7 | * 05-01-2000 SJH Created | ||
| 8 | * 05-13-2000 SJH Filled in function bodies | ||
| 9 | * 07-26-2000 SJH Removed hard coded baud rate | ||
| 10 | */ | ||
| 11 | |||
| 12 | #include <mach/hardware.h> | ||
| 13 | |||
| 14 | #define IO_UART IO_START + 0x00044000 | ||
| 15 | |||
| 16 | #define __raw_writeb(v,p) (*(volatile unsigned char *)(p) = (v)) | ||
| 17 | #define __raw_readb(p) (*(volatile unsigned char *)(p)) | ||
| 18 | |||
| 19 | static inline void putc(int c) | ||
| 20 | { | ||
| 21 | while(__raw_readb(IO_UART + 0x18) & 0x20 || | ||
| 22 | __raw_readb(IO_UART + 0x18) & 0x08) | ||
| 23 | barrier(); | ||
| 24 | |||
| 25 | __raw_writeb(c, IO_UART + 0x00); | ||
| 26 | } | ||
| 27 | |||
| 28 | static inline void flush(void) | ||
| 29 | { | ||
| 30 | } | ||
| 31 | |||
| 32 | static __inline__ void arch_decomp_setup(void) | ||
| 33 | { | ||
| 34 | __raw_writeb(0x00, IO_UART + 0x08); /* Set HSB */ | ||
| 35 | __raw_writeb(0x00, IO_UART + 0x20); /* Disable IRQs */ | ||
| 36 | __raw_writeb(0x01, IO_UART + 0x14); /* Enable UART */ | ||
| 37 | } | ||
| 38 | |||
| 39 | #define arch_decomp_wdog() | ||
diff --git a/arch/arm/mach-l7200/include/mach/vmalloc.h b/arch/arm/mach-l7200/include/mach/vmalloc.h deleted file mode 100644 index 85f0abbf15f1..000000000000 --- a/arch/arm/mach-l7200/include/mach/vmalloc.h +++ /dev/null | |||
| @@ -1,4 +0,0 @@ | |||
| 1 | /* | ||
| 2 | * arch/arm/mach-l7200/include/mach/vmalloc.h | ||
| 3 | */ | ||
| 4 | #define VMALLOC_END (PAGE_OFFSET + 0x10000000) | ||
diff --git a/arch/arm/mach-lh7a40x/include/mach/memory.h b/arch/arm/mach-lh7a40x/include/mach/memory.h index 189d20e543e7..edb8f5faf5d5 100644 --- a/arch/arm/mach-lh7a40x/include/mach/memory.h +++ b/arch/arm/mach-lh7a40x/include/mach/memory.h | |||
| @@ -19,50 +19,6 @@ | |||
| 19 | */ | 19 | */ |
| 20 | #define PHYS_OFFSET UL(0xc0000000) | 20 | #define PHYS_OFFSET UL(0xc0000000) |
| 21 | 21 | ||
| 22 | #ifdef CONFIG_DISCONTIGMEM | ||
| 23 | |||
| 24 | /* | ||
| 25 | * Given a kernel address, find the home node of the underlying memory. | ||
| 26 | */ | ||
| 27 | |||
| 28 | # ifdef CONFIG_LH7A40X_ONE_BANK_PER_NODE | ||
| 29 | # define KVADDR_TO_NID(addr) \ | ||
| 30 | ( ((((unsigned long) (addr) - PAGE_OFFSET) >> 24) & 1)\ | ||
| 31 | | ((((unsigned long) (addr) - PAGE_OFFSET) >> 25) & ~1)) | ||
| 32 | # else /* 2 banks per node */ | ||
| 33 | # define KVADDR_TO_NID(addr) \ | ||
| 34 | (((unsigned long) (addr) - PAGE_OFFSET) >> 26) | ||
| 35 | # endif | ||
| 36 | |||
| 37 | /* | ||
| 38 | * Given a page frame number, convert it to a node id. | ||
| 39 | */ | ||
| 40 | |||
| 41 | # ifdef CONFIG_LH7A40X_ONE_BANK_PER_NODE | ||
| 42 | # define PFN_TO_NID(pfn) \ | ||
| 43 | (((((pfn) - PHYS_PFN_OFFSET) >> (24 - PAGE_SHIFT)) & 1)\ | ||
| 44 | | ((((pfn) - PHYS_PFN_OFFSET) >> (25 - PAGE_SHIFT)) & ~1)) | ||
| 45 | # else /* 2 banks per node */ | ||
| 46 | # define PFN_TO_NID(pfn) \ | ||
| 47 | (((pfn) - PHYS_PFN_OFFSET) >> (26 - PAGE_SHIFT)) | ||
| 48 | #endif | ||
| 49 | |||
| 50 | /* | ||
| 51 | * Given a kaddr, LOCAL_MEM_MAP finds the owning node of the memory | ||
| 52 | * and returns the index corresponding to the appropriate page in the | ||
| 53 | * node's mem_map. | ||
| 54 | */ | ||
| 55 | |||
| 56 | # ifdef CONFIG_LH7A40X_ONE_BANK_PER_NODE | ||
| 57 | # define LOCAL_MAP_NR(addr) \ | ||
| 58 | (((unsigned long)(addr) & 0x003fffff) >> PAGE_SHIFT) | ||
| 59 | # else /* 2 banks per node */ | ||
| 60 | # define LOCAL_MAP_NR(addr) \ | ||
| 61 | (((unsigned long)(addr) & 0x01ffffff) >> PAGE_SHIFT) | ||
| 62 | # endif | ||
| 63 | |||
| 64 | #endif | ||
| 65 | |||
| 66 | /* | 22 | /* |
| 67 | * Sparsemem version of the above | 23 | * Sparsemem version of the above |
| 68 | */ | 24 | */ |
diff --git a/arch/arm/mach-msm/board-trout.c b/arch/arm/mach-msm/board-trout.c index dca5a5f062dc..e69a1502e4e8 100644 --- a/arch/arm/mach-msm/board-trout.c +++ b/arch/arm/mach-msm/board-trout.c | |||
| @@ -50,7 +50,6 @@ static void __init trout_fixup(struct machine_desc *desc, struct tag *tags, | |||
| 50 | { | 50 | { |
| 51 | mi->nr_banks = 1; | 51 | mi->nr_banks = 1; |
| 52 | mi->bank[0].start = PHYS_OFFSET; | 52 | mi->bank[0].start = PHYS_OFFSET; |
| 53 | mi->bank[0].node = PHYS_TO_NID(PHYS_OFFSET); | ||
| 54 | mi->bank[0].size = (101*1024*1024); | 53 | mi->bank[0].size = (101*1024*1024); |
| 55 | } | 54 | } |
| 56 | 55 | ||
diff --git a/arch/arm/mach-nomadik/clock.c b/arch/arm/mach-nomadik/clock.c index f035f4185274..89f793adf776 100644 --- a/arch/arm/mach-nomadik/clock.c +++ b/arch/arm/mach-nomadik/clock.c | |||
| @@ -53,6 +53,10 @@ static struct clk clk_default; | |||
| 53 | } | 53 | } |
| 54 | 54 | ||
| 55 | static struct clk_lookup lookups[] = { | 55 | static struct clk_lookup lookups[] = { |
| 56 | { | ||
| 57 | .con_id = "apb_pclk", | ||
| 58 | .clk = &clk_default, | ||
| 59 | }, | ||
| 56 | CLK(&clk_24, "mtu0"), | 60 | CLK(&clk_24, "mtu0"), |
| 57 | CLK(&clk_24, "mtu1"), | 61 | CLK(&clk_24, "mtu1"), |
| 58 | CLK(&clk_48, "uart0"), | 62 | CLK(&clk_48, "uart0"), |
diff --git a/arch/arm/mach-ns9xxx/include/mach/debug-macro.S b/arch/arm/mach-ns9xxx/include/mach/debug-macro.S index 0859336a8e6d..5c934bdb7158 100644 --- a/arch/arm/mach-ns9xxx/include/mach/debug-macro.S +++ b/arch/arm/mach-ns9xxx/include/mach/debug-macro.S | |||
| @@ -8,6 +8,7 @@ | |||
| 8 | * the Free Software Foundation. | 8 | * the Free Software Foundation. |
| 9 | */ | 9 | */ |
| 10 | #include <mach/hardware.h> | 10 | #include <mach/hardware.h> |
| 11 | #include <asm/memory.h> | ||
| 11 | 12 | ||
| 12 | #include <mach/regs-board-a9m9750dev.h> | 13 | #include <mach/regs-board-a9m9750dev.h> |
| 13 | 14 | ||
diff --git a/arch/arm/mach-ns9xxx/include/mach/uncompress.h b/arch/arm/mach-ns9xxx/include/mach/uncompress.h index 1b12d324b087..770a68c46e81 100644 --- a/arch/arm/mach-ns9xxx/include/mach/uncompress.h +++ b/arch/arm/mach-ns9xxx/include/mach/uncompress.h | |||
| @@ -20,50 +20,49 @@ static void putc_dummy(char c, void __iomem *base) | |||
| 20 | /* nothing */ | 20 | /* nothing */ |
| 21 | } | 21 | } |
| 22 | 22 | ||
| 23 | static int timeout; | ||
| 24 | |||
| 23 | static void putc_ns9360(char c, void __iomem *base) | 25 | static void putc_ns9360(char c, void __iomem *base) |
| 24 | { | 26 | { |
| 25 | static int t = 0x10000; | ||
| 26 | do { | 27 | do { |
| 27 | if (t) | 28 | if (timeout) |
| 28 | --t; | 29 | --timeout; |
| 29 | 30 | ||
| 30 | if (__raw_readl(base + 8) & (1 << 3)) { | 31 | if (__raw_readl(base + 8) & (1 << 3)) { |
| 31 | __raw_writeb(c, base + 16); | 32 | __raw_writeb(c, base + 16); |
| 32 | t = 0x10000; | 33 | timeout = 0x10000; |
| 33 | break; | 34 | break; |
| 34 | } | 35 | } |
| 35 | } while (t); | 36 | } while (timeout); |
| 36 | } | 37 | } |
| 37 | 38 | ||
| 38 | static void putc_a9m9750dev(char c, void __iomem *base) | 39 | static void putc_a9m9750dev(char c, void __iomem *base) |
| 39 | { | 40 | { |
| 40 | static int t = 0x10000; | ||
| 41 | do { | 41 | do { |
| 42 | if (t) | 42 | if (timeout) |
| 43 | --t; | 43 | --timeout; |
| 44 | 44 | ||
| 45 | if (__raw_readb(base + 5) & (1 << 5)) { | 45 | if (__raw_readb(base + 5) & (1 << 5)) { |
| 46 | __raw_writeb(c, base); | 46 | __raw_writeb(c, base); |
| 47 | t = 0x10000; | 47 | timeout = 0x10000; |
| 48 | break; | 48 | break; |
| 49 | } | 49 | } |
| 50 | } while (t); | 50 | } while (timeout); |
| 51 | 51 | ||
| 52 | } | 52 | } |
| 53 | 53 | ||
| 54 | static void putc_ns921x(char c, void __iomem *base) | 54 | static void putc_ns921x(char c, void __iomem *base) |
| 55 | { | 55 | { |
| 56 | static int t = 0x10000; | ||
| 57 | do { | 56 | do { |
| 58 | if (t) | 57 | if (timeout) |
| 59 | --t; | 58 | --timeout; |
| 60 | 59 | ||
| 61 | if (!(__raw_readl(base) & (1 << 11))) { | 60 | if (!(__raw_readl(base) & (1 << 11))) { |
| 62 | __raw_writeb(c, base + 0x0028); | 61 | __raw_writeb(c, base + 0x0028); |
| 63 | t = 0x10000; | 62 | timeout = 0x10000; |
| 64 | break; | 63 | break; |
| 65 | } | 64 | } |
| 66 | } while (t); | 65 | } while (timeout); |
| 67 | } | 66 | } |
| 68 | 67 | ||
| 69 | #define MSCS __REG(0xA0900184) | 68 | #define MSCS __REG(0xA0900184) |
| @@ -89,6 +88,7 @@ static void putc_ns921x(char c, void __iomem *base) | |||
| 89 | 88 | ||
| 90 | static void autodetect(void (**putc)(char, void __iomem *), void __iomem **base) | 89 | static void autodetect(void (**putc)(char, void __iomem *), void __iomem **base) |
| 91 | { | 90 | { |
| 91 | timeout = 0x10000; | ||
| 92 | if (((__raw_readl(MSCS) >> 16) & 0xfe) == 0x00) { | 92 | if (((__raw_readl(MSCS) >> 16) & 0xfe) == 0x00) { |
| 93 | /* ns9360 or ns9750 */ | 93 | /* ns9360 or ns9750 */ |
| 94 | if (NS9360_UART_ENABLED(NS9360_UARTA)) { | 94 | if (NS9360_UART_ENABLED(NS9360_UARTA)) { |
diff --git a/arch/arm/mach-omap1/board-ams-delta.c b/arch/arm/mach-omap1/board-ams-delta.c index fdd1dd53fa9c..0a9d61d2d229 100644 --- a/arch/arm/mach-omap1/board-ams-delta.c +++ b/arch/arm/mach-omap1/board-ams-delta.c | |||
| @@ -301,6 +301,7 @@ MACHINE_START(AMS_DELTA, "Amstrad E3 (Delta)") | |||
| 301 | .io_pg_offst = ((0xfef00000) >> 18) & 0xfffc, | 301 | .io_pg_offst = ((0xfef00000) >> 18) & 0xfffc, |
| 302 | .boot_params = 0x10000100, | 302 | .boot_params = 0x10000100, |
| 303 | .map_io = ams_delta_map_io, | 303 | .map_io = ams_delta_map_io, |
| 304 | .reserve = omap_reserve, | ||
| 304 | .init_irq = ams_delta_init_irq, | 305 | .init_irq = ams_delta_init_irq, |
| 305 | .init_machine = ams_delta_init, | 306 | .init_machine = ams_delta_init, |
| 306 | .timer = &omap_timer, | 307 | .timer = &omap_timer, |
diff --git a/arch/arm/mach-omap1/board-fsample.c b/arch/arm/mach-omap1/board-fsample.c index 096f2ed102cb..059bac60b35a 100644 --- a/arch/arm/mach-omap1/board-fsample.c +++ b/arch/arm/mach-omap1/board-fsample.c | |||
| @@ -378,6 +378,7 @@ MACHINE_START(OMAP_FSAMPLE, "OMAP730 F-Sample") | |||
| 378 | .io_pg_offst = ((0xfef00000) >> 18) & 0xfffc, | 378 | .io_pg_offst = ((0xfef00000) >> 18) & 0xfffc, |
| 379 | .boot_params = 0x10000100, | 379 | .boot_params = 0x10000100, |
| 380 | .map_io = omap_fsample_map_io, | 380 | .map_io = omap_fsample_map_io, |
| 381 | .reserve = omap_reserve, | ||
| 381 | .init_irq = omap_fsample_init_irq, | 382 | .init_irq = omap_fsample_init_irq, |
| 382 | .init_machine = omap_fsample_init, | 383 | .init_machine = omap_fsample_init, |
| 383 | .timer = &omap_timer, | 384 | .timer = &omap_timer, |
diff --git a/arch/arm/mach-omap1/board-generic.c b/arch/arm/mach-omap1/board-generic.c index e1195a3467b8..7a65684d2a15 100644 --- a/arch/arm/mach-omap1/board-generic.c +++ b/arch/arm/mach-omap1/board-generic.c | |||
| @@ -98,6 +98,7 @@ MACHINE_START(OMAP_GENERIC, "Generic OMAP1510/1610/1710") | |||
| 98 | .io_pg_offst = ((0xfef00000) >> 18) & 0xfffc, | 98 | .io_pg_offst = ((0xfef00000) >> 18) & 0xfffc, |
| 99 | .boot_params = 0x10000100, | 99 | .boot_params = 0x10000100, |
| 100 | .map_io = omap_generic_map_io, | 100 | .map_io = omap_generic_map_io, |
| 101 | .reserve = omap_reserve, | ||
| 101 | .init_irq = omap_generic_init_irq, | 102 | .init_irq = omap_generic_init_irq, |
| 102 | .init_machine = omap_generic_init, | 103 | .init_machine = omap_generic_init, |
| 103 | .timer = &omap_timer, | 104 | .timer = &omap_timer, |
diff --git a/arch/arm/mach-omap1/board-h2.c b/arch/arm/mach-omap1/board-h2.c index d1100e4f65ac..68b2beda8b99 100644 --- a/arch/arm/mach-omap1/board-h2.c +++ b/arch/arm/mach-omap1/board-h2.c | |||
| @@ -467,6 +467,7 @@ MACHINE_START(OMAP_H2, "TI-H2") | |||
| 467 | .io_pg_offst = ((0xfef00000) >> 18) & 0xfffc, | 467 | .io_pg_offst = ((0xfef00000) >> 18) & 0xfffc, |
| 468 | .boot_params = 0x10000100, | 468 | .boot_params = 0x10000100, |
| 469 | .map_io = h2_map_io, | 469 | .map_io = h2_map_io, |
| 470 | .reserve = omap_reserve, | ||
| 470 | .init_irq = h2_init_irq, | 471 | .init_irq = h2_init_irq, |
| 471 | .init_machine = h2_init, | 472 | .init_machine = h2_init, |
| 472 | .timer = &omap_timer, | 473 | .timer = &omap_timer, |
diff --git a/arch/arm/mach-omap1/board-h3.c b/arch/arm/mach-omap1/board-h3.c index a53ab8297d25..0b0825fe6751 100644 --- a/arch/arm/mach-omap1/board-h3.c +++ b/arch/arm/mach-omap1/board-h3.c | |||
| @@ -437,6 +437,7 @@ MACHINE_START(OMAP_H3, "TI OMAP1710 H3 board") | |||
| 437 | .io_pg_offst = ((0xfef00000) >> 18) & 0xfffc, | 437 | .io_pg_offst = ((0xfef00000) >> 18) & 0xfffc, |
| 438 | .boot_params = 0x10000100, | 438 | .boot_params = 0x10000100, |
| 439 | .map_io = h3_map_io, | 439 | .map_io = h3_map_io, |
| 440 | .reserve = omap_reserve, | ||
| 440 | .init_irq = h3_init_irq, | 441 | .init_irq = h3_init_irq, |
| 441 | .init_machine = h3_init, | 442 | .init_machine = h3_init, |
| 442 | .timer = &omap_timer, | 443 | .timer = &omap_timer, |
diff --git a/arch/arm/mach-omap1/board-htcherald.c b/arch/arm/mach-omap1/board-htcherald.c index 8e313b4b99a9..d70a4f0923f5 100644 --- a/arch/arm/mach-omap1/board-htcherald.c +++ b/arch/arm/mach-omap1/board-htcherald.c | |||
| @@ -304,6 +304,7 @@ MACHINE_START(HERALD, "HTC Herald") | |||
| 304 | .io_pg_offst = ((0xfef00000) >> 18) & 0xfffc, | 304 | .io_pg_offst = ((0xfef00000) >> 18) & 0xfffc, |
| 305 | .boot_params = 0x10000100, | 305 | .boot_params = 0x10000100, |
| 306 | .map_io = htcherald_map_io, | 306 | .map_io = htcherald_map_io, |
| 307 | .reserve = omap_reserve, | ||
| 307 | .init_irq = htcherald_init_irq, | 308 | .init_irq = htcherald_init_irq, |
| 308 | .init_machine = htcherald_init, | 309 | .init_machine = htcherald_init, |
| 309 | .timer = &omap_timer, | 310 | .timer = &omap_timer, |
diff --git a/arch/arm/mach-omap1/board-innovator.c b/arch/arm/mach-omap1/board-innovator.c index 5d12fd35681b..91064b37859a 100644 --- a/arch/arm/mach-omap1/board-innovator.c +++ b/arch/arm/mach-omap1/board-innovator.c | |||
| @@ -463,6 +463,7 @@ MACHINE_START(OMAP_INNOVATOR, "TI-Innovator") | |||
| 463 | .io_pg_offst = ((0xfef00000) >> 18) & 0xfffc, | 463 | .io_pg_offst = ((0xfef00000) >> 18) & 0xfffc, |
| 464 | .boot_params = 0x10000100, | 464 | .boot_params = 0x10000100, |
| 465 | .map_io = innovator_map_io, | 465 | .map_io = innovator_map_io, |
| 466 | .reserve = omap_reserve, | ||
| 466 | .init_irq = innovator_init_irq, | 467 | .init_irq = innovator_init_irq, |
| 467 | .init_machine = innovator_init, | 468 | .init_machine = innovator_init, |
| 468 | .timer = &omap_timer, | 469 | .timer = &omap_timer, |
diff --git a/arch/arm/mach-omap1/board-nokia770.c b/arch/arm/mach-omap1/board-nokia770.c index 71e1a3fad0ea..8c28b10f3dae 100644 --- a/arch/arm/mach-omap1/board-nokia770.c +++ b/arch/arm/mach-omap1/board-nokia770.c | |||
| @@ -400,6 +400,7 @@ MACHINE_START(NOKIA770, "Nokia 770") | |||
| 400 | .io_pg_offst = ((0xfef00000) >> 18) & 0xfffc, | 400 | .io_pg_offst = ((0xfef00000) >> 18) & 0xfffc, |
| 401 | .boot_params = 0x10000100, | 401 | .boot_params = 0x10000100, |
| 402 | .map_io = omap_nokia770_map_io, | 402 | .map_io = omap_nokia770_map_io, |
| 403 | .reserve = omap_reserve, | ||
| 403 | .init_irq = omap_nokia770_init_irq, | 404 | .init_irq = omap_nokia770_init_irq, |
| 404 | .init_machine = omap_nokia770_init, | 405 | .init_machine = omap_nokia770_init, |
| 405 | .timer = &omap_timer, | 406 | .timer = &omap_timer, |
diff --git a/arch/arm/mach-omap1/board-osk.c b/arch/arm/mach-omap1/board-osk.c index 80d862001def..e2a72af30890 100644 --- a/arch/arm/mach-omap1/board-osk.c +++ b/arch/arm/mach-omap1/board-osk.c | |||
| @@ -584,6 +584,7 @@ MACHINE_START(OMAP_OSK, "TI-OSK") | |||
| 584 | .io_pg_offst = ((0xfef00000) >> 18) & 0xfffc, | 584 | .io_pg_offst = ((0xfef00000) >> 18) & 0xfffc, |
| 585 | .boot_params = 0x10000100, | 585 | .boot_params = 0x10000100, |
| 586 | .map_io = osk_map_io, | 586 | .map_io = osk_map_io, |
| 587 | .reserve = omap_reserve, | ||
| 587 | .init_irq = osk_init_irq, | 588 | .init_irq = osk_init_irq, |
| 588 | .init_machine = osk_init, | 589 | .init_machine = osk_init, |
| 589 | .timer = &omap_timer, | 590 | .timer = &omap_timer, |
diff --git a/arch/arm/mach-omap1/board-palmte.c b/arch/arm/mach-omap1/board-palmte.c index 569b4c9085cd..61a2321b9732 100644 --- a/arch/arm/mach-omap1/board-palmte.c +++ b/arch/arm/mach-omap1/board-palmte.c | |||
| @@ -373,6 +373,7 @@ MACHINE_START(OMAP_PALMTE, "OMAP310 based Palm Tungsten E") | |||
| 373 | .io_pg_offst = ((0xfef00000) >> 18) & 0xfffc, | 373 | .io_pg_offst = ((0xfef00000) >> 18) & 0xfffc, |
| 374 | .boot_params = 0x10000100, | 374 | .boot_params = 0x10000100, |
| 375 | .map_io = omap_palmte_map_io, | 375 | .map_io = omap_palmte_map_io, |
| 376 | .reserve = omap_reserve, | ||
| 376 | .init_irq = omap_palmte_init_irq, | 377 | .init_irq = omap_palmte_init_irq, |
| 377 | .init_machine = omap_palmte_init, | 378 | .init_machine = omap_palmte_init, |
| 378 | .timer = &omap_timer, | 379 | .timer = &omap_timer, |
diff --git a/arch/arm/mach-omap1/board-palmtt.c b/arch/arm/mach-omap1/board-palmtt.c index 6ad49a2cc1a0..21c01c6afcc1 100644 --- a/arch/arm/mach-omap1/board-palmtt.c +++ b/arch/arm/mach-omap1/board-palmtt.c | |||
| @@ -321,6 +321,7 @@ MACHINE_START(OMAP_PALMTT, "OMAP1510 based Palm Tungsten|T") | |||
| 321 | .io_pg_offst = ((0xfef00000) >> 18) & 0xfffc, | 321 | .io_pg_offst = ((0xfef00000) >> 18) & 0xfffc, |
| 322 | .boot_params = 0x10000100, | 322 | .boot_params = 0x10000100, |
| 323 | .map_io = omap_palmtt_map_io, | 323 | .map_io = omap_palmtt_map_io, |
| 324 | .reserve = omap_reserve, | ||
| 324 | .init_irq = omap_palmtt_init_irq, | 325 | .init_irq = omap_palmtt_init_irq, |
| 325 | .init_machine = omap_palmtt_init, | 326 | .init_machine = omap_palmtt_init, |
| 326 | .timer = &omap_timer, | 327 | .timer = &omap_timer, |
diff --git a/arch/arm/mach-omap1/board-palmz71.c b/arch/arm/mach-omap1/board-palmz71.c index 6641de9257ef..f32492451533 100644 --- a/arch/arm/mach-omap1/board-palmz71.c +++ b/arch/arm/mach-omap1/board-palmz71.c | |||
| @@ -338,10 +338,12 @@ omap_palmz71_map_io(void) | |||
| 338 | } | 338 | } |
| 339 | 339 | ||
| 340 | MACHINE_START(OMAP_PALMZ71, "OMAP310 based Palm Zire71") | 340 | MACHINE_START(OMAP_PALMZ71, "OMAP310 based Palm Zire71") |
| 341 | .phys_io = 0xfff00000, | 341 | .phys_io = 0xfff00000, |
| 342 | .io_pg_offst = ((0xfef00000) >> 18) & 0xfffc, | 342 | .io_pg_offst = ((0xfef00000) >> 18) & 0xfffc, |
| 343 | .boot_params = 0x10000100,.map_io = omap_palmz71_map_io, | 343 | .boot_params = 0x10000100, |
| 344 | .init_irq = omap_palmz71_init_irq, | 344 | .map_io = omap_palmz71_map_io, |
| 345 | .init_machine = omap_palmz71_init, | 345 | .reserve = omap_reserve, |
| 346 | .timer = &omap_timer, | 346 | .init_irq = omap_palmz71_init_irq, |
| 347 | .init_machine = omap_palmz71_init, | ||
| 348 | .timer = &omap_timer, | ||
| 347 | MACHINE_END | 349 | MACHINE_END |
diff --git a/arch/arm/mach-omap1/board-perseus2.c b/arch/arm/mach-omap1/board-perseus2.c index e854d5741c88..8b5ab1fcc405 100644 --- a/arch/arm/mach-omap1/board-perseus2.c +++ b/arch/arm/mach-omap1/board-perseus2.c | |||
| @@ -339,6 +339,7 @@ MACHINE_START(OMAP_PERSEUS2, "OMAP730 Perseus2") | |||
| 339 | .io_pg_offst = ((0xfef00000) >> 18) & 0xfffc, | 339 | .io_pg_offst = ((0xfef00000) >> 18) & 0xfffc, |
| 340 | .boot_params = 0x10000100, | 340 | .boot_params = 0x10000100, |
| 341 | .map_io = omap_perseus2_map_io, | 341 | .map_io = omap_perseus2_map_io, |
| 342 | .reserve = omap_reserve, | ||
| 342 | .init_irq = omap_perseus2_init_irq, | 343 | .init_irq = omap_perseus2_init_irq, |
| 343 | .init_machine = omap_perseus2_init, | 344 | .init_machine = omap_perseus2_init, |
| 344 | .timer = &omap_timer, | 345 | .timer = &omap_timer, |
diff --git a/arch/arm/mach-omap1/board-sx1.c b/arch/arm/mach-omap1/board-sx1.c index 2fb1e5f8e2ec..995566b862bb 100644 --- a/arch/arm/mach-omap1/board-sx1.c +++ b/arch/arm/mach-omap1/board-sx1.c | |||
| @@ -423,7 +423,8 @@ MACHINE_START(SX1, "OMAP310 based Siemens SX1") | |||
| 423 | .io_pg_offst = ((0xfef00000) >> 18) & 0xfffc, | 423 | .io_pg_offst = ((0xfef00000) >> 18) & 0xfffc, |
| 424 | .boot_params = 0x10000100, | 424 | .boot_params = 0x10000100, |
| 425 | .map_io = omap_sx1_map_io, | 425 | .map_io = omap_sx1_map_io, |
| 426 | .init_irq = omap_sx1_init_irq, | 426 | .reserve = omap_reserve, |
| 427 | .init_irq = omap_sx1_init_irq, | ||
| 427 | .init_machine = omap_sx1_init, | 428 | .init_machine = omap_sx1_init, |
| 428 | .timer = &omap_timer, | 429 | .timer = &omap_timer, |
| 429 | MACHINE_END | 430 | MACHINE_END |
diff --git a/arch/arm/mach-omap1/board-voiceblue.c b/arch/arm/mach-omap1/board-voiceblue.c index 87b9436fe7c0..4c483dc1de5c 100644 --- a/arch/arm/mach-omap1/board-voiceblue.c +++ b/arch/arm/mach-omap1/board-voiceblue.c | |||
| @@ -287,6 +287,7 @@ MACHINE_START(VOICEBLUE, "VoiceBlue OMAP5910") | |||
| 287 | .io_pg_offst = ((0xfef00000) >> 18) & 0xfffc, | 287 | .io_pg_offst = ((0xfef00000) >> 18) & 0xfffc, |
| 288 | .boot_params = 0x10000100, | 288 | .boot_params = 0x10000100, |
| 289 | .map_io = voiceblue_map_io, | 289 | .map_io = voiceblue_map_io, |
| 290 | .reserve = omap_reserve, | ||
| 290 | .init_irq = voiceblue_init_irq, | 291 | .init_irq = voiceblue_init_irq, |
| 291 | .init_machine = voiceblue_init, | 292 | .init_machine = voiceblue_init, |
| 292 | .timer = &omap_timer, | 293 | .timer = &omap_timer, |
diff --git a/arch/arm/mach-omap1/io.c b/arch/arm/mach-omap1/io.c index d9b8d82530ae..0ce3fec2d257 100644 --- a/arch/arm/mach-omap1/io.c +++ b/arch/arm/mach-omap1/io.c | |||
| @@ -22,7 +22,6 @@ | |||
| 22 | 22 | ||
| 23 | extern void omap_check_revision(void); | 23 | extern void omap_check_revision(void); |
| 24 | extern void omap_sram_init(void); | 24 | extern void omap_sram_init(void); |
| 25 | extern void omapfb_reserve_sdram(void); | ||
| 26 | 25 | ||
| 27 | /* | 26 | /* |
| 28 | * The machine specific code may provide the extra mapping besides the | 27 | * The machine specific code may provide the extra mapping besides the |
| @@ -122,7 +121,6 @@ void __init omap1_map_common_io(void) | |||
| 122 | #endif | 121 | #endif |
| 123 | 122 | ||
| 124 | omap_sram_init(); | 123 | omap_sram_init(); |
| 125 | omapfb_reserve_sdram(); | ||
| 126 | } | 124 | } |
| 127 | 125 | ||
| 128 | /* | 126 | /* |
diff --git a/arch/arm/mach-omap2/board-2430sdp.c b/arch/arm/mach-omap2/board-2430sdp.c index a11a575745e4..42f49f785c93 100644 --- a/arch/arm/mach-omap2/board-2430sdp.c +++ b/arch/arm/mach-omap2/board-2430sdp.c | |||
| @@ -248,6 +248,7 @@ MACHINE_START(OMAP_2430SDP, "OMAP2430 sdp2430 board") | |||
| 248 | .io_pg_offst = ((0xfa000000) >> 18) & 0xfffc, | 248 | .io_pg_offst = ((0xfa000000) >> 18) & 0xfffc, |
| 249 | .boot_params = 0x80000100, | 249 | .boot_params = 0x80000100, |
| 250 | .map_io = omap_2430sdp_map_io, | 250 | .map_io = omap_2430sdp_map_io, |
| 251 | .reserve = omap_reserve, | ||
| 251 | .init_irq = omap_2430sdp_init_irq, | 252 | .init_irq = omap_2430sdp_init_irq, |
| 252 | .init_machine = omap_2430sdp_init, | 253 | .init_machine = omap_2430sdp_init, |
| 253 | .timer = &omap_timer, | 254 | .timer = &omap_timer, |
diff --git a/arch/arm/mach-omap2/board-3430sdp.c b/arch/arm/mach-omap2/board-3430sdp.c index f474a80b8867..dd9c03171a19 100644 --- a/arch/arm/mach-omap2/board-3430sdp.c +++ b/arch/arm/mach-omap2/board-3430sdp.c | |||
| @@ -815,6 +815,7 @@ MACHINE_START(OMAP_3430SDP, "OMAP3430 3430SDP board") | |||
| 815 | .io_pg_offst = ((0xfa000000) >> 18) & 0xfffc, | 815 | .io_pg_offst = ((0xfa000000) >> 18) & 0xfffc, |
| 816 | .boot_params = 0x80000100, | 816 | .boot_params = 0x80000100, |
| 817 | .map_io = omap_3430sdp_map_io, | 817 | .map_io = omap_3430sdp_map_io, |
| 818 | .reserve = omap_reserve, | ||
| 818 | .init_irq = omap_3430sdp_init_irq, | 819 | .init_irq = omap_3430sdp_init_irq, |
| 819 | .init_machine = omap_3430sdp_init, | 820 | .init_machine = omap_3430sdp_init, |
| 820 | .timer = &omap_timer, | 821 | .timer = &omap_timer, |
diff --git a/arch/arm/mach-omap2/board-3630sdp.c b/arch/arm/mach-omap2/board-3630sdp.c index 504d2bd222fe..57290fb3fcd7 100644 --- a/arch/arm/mach-omap2/board-3630sdp.c +++ b/arch/arm/mach-omap2/board-3630sdp.c | |||
| @@ -108,6 +108,7 @@ MACHINE_START(OMAP_3630SDP, "OMAP 3630SDP board") | |||
| 108 | .io_pg_offst = ((0xfa000000) >> 18) & 0xfffc, | 108 | .io_pg_offst = ((0xfa000000) >> 18) & 0xfffc, |
| 109 | .boot_params = 0x80000100, | 109 | .boot_params = 0x80000100, |
| 110 | .map_io = omap_sdp_map_io, | 110 | .map_io = omap_sdp_map_io, |
| 111 | .reserve = omap_reserve, | ||
| 111 | .init_irq = omap_sdp_init_irq, | 112 | .init_irq = omap_sdp_init_irq, |
| 112 | .init_machine = omap_sdp_init, | 113 | .init_machine = omap_sdp_init, |
| 113 | .timer = &omap_timer, | 114 | .timer = &omap_timer, |
diff --git a/arch/arm/mach-omap2/board-4430sdp.c b/arch/arm/mach-omap2/board-4430sdp.c index e4a5d66b83b8..4bb2c5d151ec 100644 --- a/arch/arm/mach-omap2/board-4430sdp.c +++ b/arch/arm/mach-omap2/board-4430sdp.c | |||
| @@ -402,6 +402,7 @@ MACHINE_START(OMAP_4430SDP, "OMAP4430 4430SDP board") | |||
| 402 | .io_pg_offst = ((0xfa000000) >> 18) & 0xfffc, | 402 | .io_pg_offst = ((0xfa000000) >> 18) & 0xfffc, |
| 403 | .boot_params = 0x80000100, | 403 | .boot_params = 0x80000100, |
| 404 | .map_io = omap_4430sdp_map_io, | 404 | .map_io = omap_4430sdp_map_io, |
| 405 | .reserve = omap_reserve, | ||
| 405 | .init_irq = omap_4430sdp_init_irq, | 406 | .init_irq = omap_4430sdp_init_irq, |
| 406 | .init_machine = omap_4430sdp_init, | 407 | .init_machine = omap_4430sdp_init, |
| 407 | .timer = &omap_timer, | 408 | .timer = &omap_timer, |
diff --git a/arch/arm/mach-omap2/board-am3517evm.c b/arch/arm/mach-omap2/board-am3517evm.c index af383a876943..7da92defcde0 100644 --- a/arch/arm/mach-omap2/board-am3517evm.c +++ b/arch/arm/mach-omap2/board-am3517evm.c | |||
| @@ -472,6 +472,7 @@ MACHINE_START(OMAP3517EVM, "OMAP3517/AM3517 EVM") | |||
| 472 | .io_pg_offst = ((0xd8000000) >> 18) & 0xfffc, | 472 | .io_pg_offst = ((0xd8000000) >> 18) & 0xfffc, |
| 473 | .boot_params = 0x80000100, | 473 | .boot_params = 0x80000100, |
| 474 | .map_io = am3517_evm_map_io, | 474 | .map_io = am3517_evm_map_io, |
| 475 | .reserve = omap_reserve, | ||
| 475 | .init_irq = am3517_evm_init_irq, | 476 | .init_irq = am3517_evm_init_irq, |
| 476 | .init_machine = am3517_evm_init, | 477 | .init_machine = am3517_evm_init, |
| 477 | .timer = &omap_timer, | 478 | .timer = &omap_timer, |
diff --git a/arch/arm/mach-omap2/board-apollon.c b/arch/arm/mach-omap2/board-apollon.c index aa69fb999748..bd75642aee65 100644 --- a/arch/arm/mach-omap2/board-apollon.c +++ b/arch/arm/mach-omap2/board-apollon.c | |||
| @@ -346,6 +346,7 @@ MACHINE_START(OMAP_APOLLON, "OMAP24xx Apollon") | |||
| 346 | .io_pg_offst = ((0xfa000000) >> 18) & 0xfffc, | 346 | .io_pg_offst = ((0xfa000000) >> 18) & 0xfffc, |
| 347 | .boot_params = 0x80000100, | 347 | .boot_params = 0x80000100, |
| 348 | .map_io = omap_apollon_map_io, | 348 | .map_io = omap_apollon_map_io, |
| 349 | .reserve = omap_reserve, | ||
| 349 | .init_irq = omap_apollon_init_irq, | 350 | .init_irq = omap_apollon_init_irq, |
| 350 | .init_machine = omap_apollon_init, | 351 | .init_machine = omap_apollon_init, |
| 351 | .timer = &omap_timer, | 352 | .timer = &omap_timer, |
diff --git a/arch/arm/mach-omap2/board-cm-t35.c b/arch/arm/mach-omap2/board-cm-t35.c index e679a2cc86c3..bc4c3f807068 100644 --- a/arch/arm/mach-omap2/board-cm-t35.c +++ b/arch/arm/mach-omap2/board-cm-t35.c | |||
| @@ -837,6 +837,7 @@ MACHINE_START(CM_T35, "Compulab CM-T35") | |||
| 837 | .io_pg_offst = ((0xd8000000) >> 18) & 0xfffc, | 837 | .io_pg_offst = ((0xd8000000) >> 18) & 0xfffc, |
| 838 | .boot_params = 0x80000100, | 838 | .boot_params = 0x80000100, |
| 839 | .map_io = cm_t35_map_io, | 839 | .map_io = cm_t35_map_io, |
| 840 | .reserve = omap_reserve, | ||
| 840 | .init_irq = cm_t35_init_irq, | 841 | .init_irq = cm_t35_init_irq, |
| 841 | .init_machine = cm_t35_init, | 842 | .init_machine = cm_t35_init, |
| 842 | .timer = &omap_timer, | 843 | .timer = &omap_timer, |
diff --git a/arch/arm/mach-omap2/board-devkit8000.c b/arch/arm/mach-omap2/board-devkit8000.c index 77022b588816..922b7464807f 100644 --- a/arch/arm/mach-omap2/board-devkit8000.c +++ b/arch/arm/mach-omap2/board-devkit8000.c | |||
| @@ -825,6 +825,7 @@ MACHINE_START(DEVKIT8000, "OMAP3 Devkit8000") | |||
| 825 | .io_pg_offst = ((0xd8000000) >> 18) & 0xfffc, | 825 | .io_pg_offst = ((0xd8000000) >> 18) & 0xfffc, |
| 826 | .boot_params = 0x80000100, | 826 | .boot_params = 0x80000100, |
| 827 | .map_io = devkit8000_map_io, | 827 | .map_io = devkit8000_map_io, |
| 828 | .reserve = omap_reserve, | ||
| 828 | .init_irq = devkit8000_init_irq, | 829 | .init_irq = devkit8000_init_irq, |
| 829 | .init_machine = devkit8000_init, | 830 | .init_machine = devkit8000_init, |
| 830 | .timer = &omap_timer, | 831 | .timer = &omap_timer, |
diff --git a/arch/arm/mach-omap2/board-generic.c b/arch/arm/mach-omap2/board-generic.c index 16cc06860670..9242902d3a43 100644 --- a/arch/arm/mach-omap2/board-generic.c +++ b/arch/arm/mach-omap2/board-generic.c | |||
| @@ -59,6 +59,7 @@ MACHINE_START(OMAP_GENERIC, "Generic OMAP24xx") | |||
| 59 | .io_pg_offst = ((0xfa000000) >> 18) & 0xfffc, | 59 | .io_pg_offst = ((0xfa000000) >> 18) & 0xfffc, |
| 60 | .boot_params = 0x80000100, | 60 | .boot_params = 0x80000100, |
| 61 | .map_io = omap_generic_map_io, | 61 | .map_io = omap_generic_map_io, |
| 62 | .reserve = omap_reserve, | ||
| 62 | .init_irq = omap_generic_init_irq, | 63 | .init_irq = omap_generic_init_irq, |
| 63 | .init_machine = omap_generic_init, | 64 | .init_machine = omap_generic_init, |
| 64 | .timer = &omap_timer, | 65 | .timer = &omap_timer, |
diff --git a/arch/arm/mach-omap2/board-h4.c b/arch/arm/mach-omap2/board-h4.c index 0665f2c8dc8e..16703fdb3515 100644 --- a/arch/arm/mach-omap2/board-h4.c +++ b/arch/arm/mach-omap2/board-h4.c | |||
| @@ -378,6 +378,7 @@ MACHINE_START(OMAP_H4, "OMAP2420 H4 board") | |||
| 378 | .io_pg_offst = ((0xfa000000) >> 18) & 0xfffc, | 378 | .io_pg_offst = ((0xfa000000) >> 18) & 0xfffc, |
| 379 | .boot_params = 0x80000100, | 379 | .boot_params = 0x80000100, |
| 380 | .map_io = omap_h4_map_io, | 380 | .map_io = omap_h4_map_io, |
| 381 | .reserve = omap_reserve, | ||
| 381 | .init_irq = omap_h4_init_irq, | 382 | .init_irq = omap_h4_init_irq, |
| 382 | .init_machine = omap_h4_init, | 383 | .init_machine = omap_h4_init, |
| 383 | .timer = &omap_timer, | 384 | .timer = &omap_timer, |
diff --git a/arch/arm/mach-omap2/board-igep0020.c b/arch/arm/mach-omap2/board-igep0020.c index d55c57b761a9..759e39d1a702 100644 --- a/arch/arm/mach-omap2/board-igep0020.c +++ b/arch/arm/mach-omap2/board-igep0020.c | |||
| @@ -543,6 +543,7 @@ MACHINE_START(IGEP0020, "IGEP v2 board") | |||
| 543 | .io_pg_offst = ((0xfa000000) >> 18) & 0xfffc, | 543 | .io_pg_offst = ((0xfa000000) >> 18) & 0xfffc, |
| 544 | .boot_params = 0x80000100, | 544 | .boot_params = 0x80000100, |
| 545 | .map_io = igep2_map_io, | 545 | .map_io = igep2_map_io, |
| 546 | .reserve = omap_reserve, | ||
| 546 | .init_irq = igep2_init_irq, | 547 | .init_irq = igep2_init_irq, |
| 547 | .init_machine = igep2_init, | 548 | .init_machine = igep2_init, |
| 548 | .timer = &omap_timer, | 549 | .timer = &omap_timer, |
diff --git a/arch/arm/mach-omap2/board-ldp.c b/arch/arm/mach-omap2/board-ldp.c index fefd7e6e9779..9cd2669113e4 100644 --- a/arch/arm/mach-omap2/board-ldp.c +++ b/arch/arm/mach-omap2/board-ldp.c | |||
| @@ -417,6 +417,7 @@ MACHINE_START(OMAP_LDP, "OMAP LDP board") | |||
| 417 | .io_pg_offst = ((0xfa000000) >> 18) & 0xfffc, | 417 | .io_pg_offst = ((0xfa000000) >> 18) & 0xfffc, |
| 418 | .boot_params = 0x80000100, | 418 | .boot_params = 0x80000100, |
| 419 | .map_io = omap_ldp_map_io, | 419 | .map_io = omap_ldp_map_io, |
| 420 | .reserve = omap_reserve, | ||
| 420 | .init_irq = omap_ldp_init_irq, | 421 | .init_irq = omap_ldp_init_irq, |
| 421 | .init_machine = omap_ldp_init, | 422 | .init_machine = omap_ldp_init, |
| 422 | .timer = &omap_timer, | 423 | .timer = &omap_timer, |
diff --git a/arch/arm/mach-omap2/board-n8x0.c b/arch/arm/mach-omap2/board-n8x0.c index 3ccc34ebdcc7..2565ff08a221 100644 --- a/arch/arm/mach-omap2/board-n8x0.c +++ b/arch/arm/mach-omap2/board-n8x0.c | |||
| @@ -667,6 +667,7 @@ MACHINE_START(NOKIA_N800, "Nokia N800") | |||
| 667 | .io_pg_offst = ((0xfa000000) >> 18) & 0xfffc, | 667 | .io_pg_offst = ((0xfa000000) >> 18) & 0xfffc, |
| 668 | .boot_params = 0x80000100, | 668 | .boot_params = 0x80000100, |
| 669 | .map_io = n8x0_map_io, | 669 | .map_io = n8x0_map_io, |
| 670 | .reserve = omap_reserve, | ||
| 670 | .init_irq = n8x0_init_irq, | 671 | .init_irq = n8x0_init_irq, |
| 671 | .init_machine = n8x0_init_machine, | 672 | .init_machine = n8x0_init_machine, |
| 672 | .timer = &omap_timer, | 673 | .timer = &omap_timer, |
| @@ -677,6 +678,7 @@ MACHINE_START(NOKIA_N810, "Nokia N810") | |||
| 677 | .io_pg_offst = ((0xfa000000) >> 18) & 0xfffc, | 678 | .io_pg_offst = ((0xfa000000) >> 18) & 0xfffc, |
| 678 | .boot_params = 0x80000100, | 679 | .boot_params = 0x80000100, |
| 679 | .map_io = n8x0_map_io, | 680 | .map_io = n8x0_map_io, |
| 681 | .reserve = omap_reserve, | ||
| 680 | .init_irq = n8x0_init_irq, | 682 | .init_irq = n8x0_init_irq, |
| 681 | .init_machine = n8x0_init_machine, | 683 | .init_machine = n8x0_init_machine, |
| 682 | .timer = &omap_timer, | 684 | .timer = &omap_timer, |
| @@ -687,6 +689,7 @@ MACHINE_START(NOKIA_N810_WIMAX, "Nokia N810 WiMAX") | |||
| 687 | .io_pg_offst = ((0xfa000000) >> 18) & 0xfffc, | 689 | .io_pg_offst = ((0xfa000000) >> 18) & 0xfffc, |
| 688 | .boot_params = 0x80000100, | 690 | .boot_params = 0x80000100, |
| 689 | .map_io = n8x0_map_io, | 691 | .map_io = n8x0_map_io, |
| 692 | .reserve = omap_reserve, | ||
| 690 | .init_irq = n8x0_init_irq, | 693 | .init_irq = n8x0_init_irq, |
| 691 | .init_machine = n8x0_init_machine, | 694 | .init_machine = n8x0_init_machine, |
| 692 | .timer = &omap_timer, | 695 | .timer = &omap_timer, |
diff --git a/arch/arm/mach-omap2/board-omap3beagle.c b/arch/arm/mach-omap2/board-omap3beagle.c index 69b154cdc75d..0ab0c26db4dd 100644 --- a/arch/arm/mach-omap2/board-omap3beagle.c +++ b/arch/arm/mach-omap2/board-omap3beagle.c | |||
| @@ -519,6 +519,7 @@ MACHINE_START(OMAP3_BEAGLE, "OMAP3 Beagle Board") | |||
| 519 | .io_pg_offst = ((0xfa000000) >> 18) & 0xfffc, | 519 | .io_pg_offst = ((0xfa000000) >> 18) & 0xfffc, |
| 520 | .boot_params = 0x80000100, | 520 | .boot_params = 0x80000100, |
| 521 | .map_io = omap3_beagle_map_io, | 521 | .map_io = omap3_beagle_map_io, |
| 522 | .reserve = omap_reserve, | ||
| 522 | .init_irq = omap3_beagle_init_irq, | 523 | .init_irq = omap3_beagle_init_irq, |
| 523 | .init_machine = omap3_beagle_init, | 524 | .init_machine = omap3_beagle_init, |
| 524 | .timer = &omap_timer, | 525 | .timer = &omap_timer, |
diff --git a/arch/arm/mach-omap2/board-omap3evm.c b/arch/arm/mach-omap2/board-omap3evm.c index b95261013812..a3d2e285e116 100644 --- a/arch/arm/mach-omap2/board-omap3evm.c +++ b/arch/arm/mach-omap2/board-omap3evm.c | |||
| @@ -727,6 +727,7 @@ MACHINE_START(OMAP3EVM, "OMAP3 EVM") | |||
| 727 | .io_pg_offst = ((0xfa000000) >> 18) & 0xfffc, | 727 | .io_pg_offst = ((0xfa000000) >> 18) & 0xfffc, |
| 728 | .boot_params = 0x80000100, | 728 | .boot_params = 0x80000100, |
| 729 | .map_io = omap3_evm_map_io, | 729 | .map_io = omap3_evm_map_io, |
| 730 | .reserve = omap_reserve, | ||
| 730 | .init_irq = omap3_evm_init_irq, | 731 | .init_irq = omap3_evm_init_irq, |
| 731 | .init_machine = omap3_evm_init, | 732 | .init_machine = omap3_evm_init, |
| 732 | .timer = &omap_timer, | 733 | .timer = &omap_timer, |
diff --git a/arch/arm/mach-omap2/board-omap3pandora.c b/arch/arm/mach-omap2/board-omap3pandora.c index db06dc910ba7..c0f4f12eba54 100644 --- a/arch/arm/mach-omap2/board-omap3pandora.c +++ b/arch/arm/mach-omap2/board-omap3pandora.c | |||
| @@ -601,6 +601,7 @@ MACHINE_START(OMAP3_PANDORA, "Pandora Handheld Console") | |||
| 601 | .io_pg_offst = ((0xfa000000) >> 18) & 0xfffc, | 601 | .io_pg_offst = ((0xfa000000) >> 18) & 0xfffc, |
| 602 | .boot_params = 0x80000100, | 602 | .boot_params = 0x80000100, |
| 603 | .map_io = omap3pandora_map_io, | 603 | .map_io = omap3pandora_map_io, |
| 604 | .reserve = omap_reserve, | ||
| 604 | .init_irq = omap3pandora_init_irq, | 605 | .init_irq = omap3pandora_init_irq, |
| 605 | .init_machine = omap3pandora_init, | 606 | .init_machine = omap3pandora_init, |
| 606 | .timer = &omap_timer, | 607 | .timer = &omap_timer, |
diff --git a/arch/arm/mach-omap2/board-omap3touchbook.c b/arch/arm/mach-omap2/board-omap3touchbook.c index 2f5f8233dd5b..f05b867c5851 100644 --- a/arch/arm/mach-omap2/board-omap3touchbook.c +++ b/arch/arm/mach-omap2/board-omap3touchbook.c | |||
| @@ -571,6 +571,7 @@ MACHINE_START(TOUCHBOOK, "OMAP3 touchbook Board") | |||
| 571 | .io_pg_offst = ((0xd8000000) >> 18) & 0xfffc, | 571 | .io_pg_offst = ((0xd8000000) >> 18) & 0xfffc, |
| 572 | .boot_params = 0x80000100, | 572 | .boot_params = 0x80000100, |
| 573 | .map_io = omap3_touchbook_map_io, | 573 | .map_io = omap3_touchbook_map_io, |
| 574 | .reserve = omap_reserve, | ||
| 574 | .init_irq = omap3_touchbook_init_irq, | 575 | .init_irq = omap3_touchbook_init_irq, |
| 575 | .init_machine = omap3_touchbook_init, | 576 | .init_machine = omap3_touchbook_init, |
| 576 | .timer = &omap_timer, | 577 | .timer = &omap_timer, |
diff --git a/arch/arm/mach-omap2/board-overo.c b/arch/arm/mach-omap2/board-overo.c index 79ac41400c21..87acb2f198ec 100644 --- a/arch/arm/mach-omap2/board-overo.c +++ b/arch/arm/mach-omap2/board-overo.c | |||
| @@ -495,6 +495,7 @@ MACHINE_START(OVERO, "Gumstix Overo") | |||
| 495 | .io_pg_offst = ((0xfa000000) >> 18) & 0xfffc, | 495 | .io_pg_offst = ((0xfa000000) >> 18) & 0xfffc, |
| 496 | .boot_params = 0x80000100, | 496 | .boot_params = 0x80000100, |
| 497 | .map_io = overo_map_io, | 497 | .map_io = overo_map_io, |
| 498 | .reserve = omap_reserve, | ||
| 498 | .init_irq = overo_init_irq, | 499 | .init_irq = overo_init_irq, |
| 499 | .init_machine = overo_init, | 500 | .init_machine = overo_init, |
| 500 | .timer = &omap_timer, | 501 | .timer = &omap_timer, |
diff --git a/arch/arm/mach-omap2/board-rx51-peripherals.c b/arch/arm/mach-omap2/board-rx51-peripherals.c index abdf321c2d41..03483920ed6e 100644 --- a/arch/arm/mach-omap2/board-rx51-peripherals.c +++ b/arch/arm/mach-omap2/board-rx51-peripherals.c | |||
| @@ -175,6 +175,10 @@ static void __init rx51_add_gpio_keys(void) | |||
| 175 | #endif /* CONFIG_KEYBOARD_GPIO || CONFIG_KEYBOARD_GPIO_MODULE */ | 175 | #endif /* CONFIG_KEYBOARD_GPIO || CONFIG_KEYBOARD_GPIO_MODULE */ |
| 176 | 176 | ||
| 177 | static int board_keymap[] = { | 177 | static int board_keymap[] = { |
| 178 | /* | ||
| 179 | * Note that KEY(x, 8, KEY_XXX) entries represent "entrire row | ||
| 180 | * connected to the ground" matrix state. | ||
| 181 | */ | ||
| 178 | KEY(0, 0, KEY_Q), | 182 | KEY(0, 0, KEY_Q), |
| 179 | KEY(0, 1, KEY_O), | 183 | KEY(0, 1, KEY_O), |
| 180 | KEY(0, 2, KEY_P), | 184 | KEY(0, 2, KEY_P), |
| @@ -182,6 +186,7 @@ static int board_keymap[] = { | |||
| 182 | KEY(0, 4, KEY_BACKSPACE), | 186 | KEY(0, 4, KEY_BACKSPACE), |
| 183 | KEY(0, 6, KEY_A), | 187 | KEY(0, 6, KEY_A), |
| 184 | KEY(0, 7, KEY_S), | 188 | KEY(0, 7, KEY_S), |
| 189 | |||
| 185 | KEY(1, 0, KEY_W), | 190 | KEY(1, 0, KEY_W), |
| 186 | KEY(1, 1, KEY_D), | 191 | KEY(1, 1, KEY_D), |
| 187 | KEY(1, 2, KEY_F), | 192 | KEY(1, 2, KEY_F), |
| @@ -190,6 +195,7 @@ static int board_keymap[] = { | |||
| 190 | KEY(1, 5, KEY_J), | 195 | KEY(1, 5, KEY_J), |
| 191 | KEY(1, 6, KEY_K), | 196 | KEY(1, 6, KEY_K), |
| 192 | KEY(1, 7, KEY_L), | 197 | KEY(1, 7, KEY_L), |
| 198 | |||
| 193 | KEY(2, 0, KEY_E), | 199 | KEY(2, 0, KEY_E), |
| 194 | KEY(2, 1, KEY_DOT), | 200 | KEY(2, 1, KEY_DOT), |
| 195 | KEY(2, 2, KEY_UP), | 201 | KEY(2, 2, KEY_UP), |
| @@ -197,6 +203,8 @@ static int board_keymap[] = { | |||
| 197 | KEY(2, 5, KEY_Z), | 203 | KEY(2, 5, KEY_Z), |
| 198 | KEY(2, 6, KEY_X), | 204 | KEY(2, 6, KEY_X), |
| 199 | KEY(2, 7, KEY_C), | 205 | KEY(2, 7, KEY_C), |
| 206 | KEY(2, 8, KEY_F9), | ||
| 207 | |||
| 200 | KEY(3, 0, KEY_R), | 208 | KEY(3, 0, KEY_R), |
| 201 | KEY(3, 1, KEY_V), | 209 | KEY(3, 1, KEY_V), |
| 202 | KEY(3, 2, KEY_B), | 210 | KEY(3, 2, KEY_B), |
| @@ -205,20 +213,23 @@ static int board_keymap[] = { | |||
| 205 | KEY(3, 5, KEY_SPACE), | 213 | KEY(3, 5, KEY_SPACE), |
| 206 | KEY(3, 6, KEY_SPACE), | 214 | KEY(3, 6, KEY_SPACE), |
| 207 | KEY(3, 7, KEY_LEFT), | 215 | KEY(3, 7, KEY_LEFT), |
| 216 | |||
| 208 | KEY(4, 0, KEY_T), | 217 | KEY(4, 0, KEY_T), |
| 209 | KEY(4, 1, KEY_DOWN), | 218 | KEY(4, 1, KEY_DOWN), |
| 210 | KEY(4, 2, KEY_RIGHT), | 219 | KEY(4, 2, KEY_RIGHT), |
| 211 | KEY(4, 4, KEY_LEFTCTRL), | 220 | KEY(4, 4, KEY_LEFTCTRL), |
| 212 | KEY(4, 5, KEY_RIGHTALT), | 221 | KEY(4, 5, KEY_RIGHTALT), |
| 213 | KEY(4, 6, KEY_LEFTSHIFT), | 222 | KEY(4, 6, KEY_LEFTSHIFT), |
| 223 | KEY(4, 8, KEY_F10), | ||
| 224 | |||
| 214 | KEY(5, 0, KEY_Y), | 225 | KEY(5, 0, KEY_Y), |
| 226 | KEY(5, 8, KEY_F11), | ||
| 227 | |||
| 215 | KEY(6, 0, KEY_U), | 228 | KEY(6, 0, KEY_U), |
| 229 | |||
| 216 | KEY(7, 0, KEY_I), | 230 | KEY(7, 0, KEY_I), |
| 217 | KEY(7, 1, KEY_F7), | 231 | KEY(7, 1, KEY_F7), |
| 218 | KEY(7, 2, KEY_F8), | 232 | KEY(7, 2, KEY_F8), |
| 219 | KEY(0xff, 2, KEY_F9), | ||
| 220 | KEY(0xff, 4, KEY_F10), | ||
| 221 | KEY(0xff, 5, KEY_F11), | ||
| 222 | }; | 233 | }; |
| 223 | 234 | ||
| 224 | static struct matrix_keymap_data board_map_data = { | 235 | static struct matrix_keymap_data board_map_data = { |
diff --git a/arch/arm/mach-omap2/board-rx51.c b/arch/arm/mach-omap2/board-rx51.c index 1b86b5bb87a2..3bd956f9e19f 100644 --- a/arch/arm/mach-omap2/board-rx51.c +++ b/arch/arm/mach-omap2/board-rx51.c | |||
| @@ -154,6 +154,7 @@ MACHINE_START(NOKIA_RX51, "Nokia RX-51 board") | |||
| 154 | .io_pg_offst = ((0xfa000000) >> 18) & 0xfffc, | 154 | .io_pg_offst = ((0xfa000000) >> 18) & 0xfffc, |
| 155 | .boot_params = 0x80000100, | 155 | .boot_params = 0x80000100, |
| 156 | .map_io = rx51_map_io, | 156 | .map_io = rx51_map_io, |
| 157 | .reserve = omap_reserve, | ||
| 157 | .init_irq = rx51_init_irq, | 158 | .init_irq = rx51_init_irq, |
| 158 | .init_machine = rx51_init, | 159 | .init_machine = rx51_init, |
| 159 | .timer = &omap_timer, | 160 | .timer = &omap_timer, |
diff --git a/arch/arm/mach-omap2/board-zoom2.c b/arch/arm/mach-omap2/board-zoom2.c index 803ef14cbf2d..ffe188cb18e9 100644 --- a/arch/arm/mach-omap2/board-zoom2.c +++ b/arch/arm/mach-omap2/board-zoom2.c | |||
| @@ -95,6 +95,7 @@ MACHINE_START(OMAP_ZOOM2, "OMAP Zoom2 board") | |||
| 95 | .io_pg_offst = (ZOOM_UART_VIRT >> 18) & 0xfffc, | 95 | .io_pg_offst = (ZOOM_UART_VIRT >> 18) & 0xfffc, |
| 96 | .boot_params = 0x80000100, | 96 | .boot_params = 0x80000100, |
| 97 | .map_io = omap_zoom2_map_io, | 97 | .map_io = omap_zoom2_map_io, |
| 98 | .reserve = omap_reserve, | ||
| 98 | .init_irq = omap_zoom2_init_irq, | 99 | .init_irq = omap_zoom2_init_irq, |
| 99 | .init_machine = omap_zoom2_init, | 100 | .init_machine = omap_zoom2_init, |
| 100 | .timer = &omap_timer, | 101 | .timer = &omap_timer, |
diff --git a/arch/arm/mach-omap2/board-zoom3.c b/arch/arm/mach-omap2/board-zoom3.c index 33147042485f..5b605eba3e7b 100644 --- a/arch/arm/mach-omap2/board-zoom3.c +++ b/arch/arm/mach-omap2/board-zoom3.c | |||
| @@ -77,6 +77,7 @@ MACHINE_START(OMAP_ZOOM3, "OMAP Zoom3 board") | |||
| 77 | .io_pg_offst = (ZOOM_UART_VIRT >> 18) & 0xfffc, | 77 | .io_pg_offst = (ZOOM_UART_VIRT >> 18) & 0xfffc, |
| 78 | .boot_params = 0x80000100, | 78 | .boot_params = 0x80000100, |
| 79 | .map_io = omap_zoom_map_io, | 79 | .map_io = omap_zoom_map_io, |
| 80 | .reserve = omap_reserve, | ||
| 80 | .init_irq = omap_zoom_init_irq, | 81 | .init_irq = omap_zoom_init_irq, |
| 81 | .init_machine = omap_zoom_init, | 82 | .init_machine = omap_zoom_init, |
| 82 | .timer = &omap_timer, | 83 | .timer = &omap_timer, |
diff --git a/arch/arm/mach-omap2/clock3xxx_data.c b/arch/arm/mach-omap2/clock3xxx_data.c index 41b155acfca7..d33744117ce2 100644 --- a/arch/arm/mach-omap2/clock3xxx_data.c +++ b/arch/arm/mach-omap2/clock3xxx_data.c | |||
| @@ -3166,6 +3166,10 @@ static struct clk uart4_ick_am35xx = { | |||
| 3166 | .recalc = &followparent_recalc, | 3166 | .recalc = &followparent_recalc, |
| 3167 | }; | 3167 | }; |
| 3168 | 3168 | ||
| 3169 | static struct clk dummy_apb_pclk = { | ||
| 3170 | .name = "apb_pclk", | ||
| 3171 | .ops = &clkops_null, | ||
| 3172 | }; | ||
| 3169 | 3173 | ||
| 3170 | /* | 3174 | /* |
| 3171 | * clkdev | 3175 | * clkdev |
| @@ -3173,6 +3177,7 @@ static struct clk uart4_ick_am35xx = { | |||
| 3173 | 3177 | ||
| 3174 | /* XXX At some point we should rename this file to clock3xxx_data.c */ | 3178 | /* XXX At some point we should rename this file to clock3xxx_data.c */ |
| 3175 | static struct omap_clk omap3xxx_clks[] = { | 3179 | static struct omap_clk omap3xxx_clks[] = { |
| 3180 | CLK(NULL, "apb_pclk", &dummy_apb_pclk, CK_3XXX), | ||
| 3176 | CLK(NULL, "omap_32k_fck", &omap_32k_fck, CK_3XXX), | 3181 | CLK(NULL, "omap_32k_fck", &omap_32k_fck, CK_3XXX), |
| 3177 | CLK(NULL, "virt_12m_ck", &virt_12m_ck, CK_3XXX), | 3182 | CLK(NULL, "virt_12m_ck", &virt_12m_ck, CK_3XXX), |
| 3178 | CLK(NULL, "virt_13m_ck", &virt_13m_ck, CK_3XXX), | 3183 | CLK(NULL, "virt_13m_ck", &virt_13m_ck, CK_3XXX), |
diff --git a/arch/arm/mach-omap2/io.c b/arch/arm/mach-omap2/io.c index 3cfb425ea67e..4e1f53d0b880 100644 --- a/arch/arm/mach-omap2/io.c +++ b/arch/arm/mach-omap2/io.c | |||
| @@ -33,7 +33,6 @@ | |||
| 33 | #include <plat/sdrc.h> | 33 | #include <plat/sdrc.h> |
| 34 | #include <plat/gpmc.h> | 34 | #include <plat/gpmc.h> |
| 35 | #include <plat/serial.h> | 35 | #include <plat/serial.h> |
| 36 | #include <plat/vram.h> | ||
| 37 | 36 | ||
| 38 | #include "clock2xxx.h" | 37 | #include "clock2xxx.h" |
| 39 | #include "clock3xxx.h" | 38 | #include "clock3xxx.h" |
| @@ -241,8 +240,6 @@ static void __init _omap2_map_common_io(void) | |||
| 241 | 240 | ||
| 242 | omap2_check_revision(); | 241 | omap2_check_revision(); |
| 243 | omap_sram_init(); | 242 | omap_sram_init(); |
| 244 | omapfb_reserve_sdram(); | ||
| 245 | omap_vram_reserve_sdram(); | ||
| 246 | } | 243 | } |
| 247 | 244 | ||
| 248 | #ifdef CONFIG_ARCH_OMAP2420 | 245 | #ifdef CONFIG_ARCH_OMAP2420 |
diff --git a/arch/arm/mach-pxa/cm-x2xx-pci.c b/arch/arm/mach-pxa/cm-x2xx-pci.c index 161fc2d61207..0f3130599770 100644 --- a/arch/arm/mach-pxa/cm-x2xx-pci.c +++ b/arch/arm/mach-pxa/cm-x2xx-pci.c | |||
| @@ -35,7 +35,7 @@ static int cmx2xx_it8152_irq_gpio; | |||
| 35 | * This is really ugly and we need a better way of specifying | 35 | * This is really ugly and we need a better way of specifying |
| 36 | * DMA-capable regions of memory. | 36 | * DMA-capable regions of memory. |
| 37 | */ | 37 | */ |
| 38 | void __init cmx2xx_pci_adjust_zones(int node, unsigned long *zone_size, | 38 | void __init cmx2xx_pci_adjust_zones(unsigned long *zone_size, |
| 39 | unsigned long *zhole_size) | 39 | unsigned long *zhole_size) |
| 40 | { | 40 | { |
| 41 | unsigned int sz = SZ_64M >> PAGE_SHIFT; | 41 | unsigned int sz = SZ_64M >> PAGE_SHIFT; |
| @@ -46,7 +46,7 @@ void __init cmx2xx_pci_adjust_zones(int node, unsigned long *zone_size, | |||
| 46 | /* | 46 | /* |
| 47 | * Only adjust if > 64M on current system | 47 | * Only adjust if > 64M on current system |
| 48 | */ | 48 | */ |
| 49 | if (node || (zone_size[0] <= sz)) | 49 | if (zone_size[0] <= sz) |
| 50 | return; | 50 | return; |
| 51 | 51 | ||
| 52 | zone_size[1] = zone_size[0] - sz; | 52 | zone_size[1] = zone_size[0] - sz; |
diff --git a/arch/arm/mach-pxa/colibri-pxa300.c b/arch/arm/mach-pxa/colibri-pxa300.c index 45c23fd6df31..40b6ac2de876 100644 --- a/arch/arm/mach-pxa/colibri-pxa300.c +++ b/arch/arm/mach-pxa/colibri-pxa300.c | |||
| @@ -26,6 +26,7 @@ | |||
| 26 | #include <mach/colibri.h> | 26 | #include <mach/colibri.h> |
| 27 | #include <mach/ohci.h> | 27 | #include <mach/ohci.h> |
| 28 | #include <mach/pxafb.h> | 28 | #include <mach/pxafb.h> |
| 29 | #include <mach/audio.h> | ||
| 29 | 30 | ||
| 30 | #include "generic.h" | 31 | #include "generic.h" |
| 31 | #include "devices.h" | 32 | #include "devices.h" |
| @@ -145,7 +146,7 @@ static void __init colibri_pxa300_init_lcd(void) | |||
| 145 | static inline void colibri_pxa300_init_lcd(void) {} | 146 | static inline void colibri_pxa300_init_lcd(void) {} |
| 146 | #endif /* CONFIG_FB_PXA || CONFIG_FB_PXA_MODULE */ | 147 | #endif /* CONFIG_FB_PXA || CONFIG_FB_PXA_MODULE */ |
| 147 | 148 | ||
| 148 | #if defined(SND_AC97_CODEC) || defined(SND_AC97_CODEC_MODULE) | 149 | #if defined(CONFIG_SND_AC97_CODEC) || defined(CONFIG_SND_AC97_CODEC_MODULE) |
| 149 | static mfp_cfg_t colibri_pxa310_ac97_pin_config[] __initdata = { | 150 | static mfp_cfg_t colibri_pxa310_ac97_pin_config[] __initdata = { |
| 150 | GPIO24_AC97_SYSCLK, | 151 | GPIO24_AC97_SYSCLK, |
| 151 | GPIO23_AC97_nACRESET, | 152 | GPIO23_AC97_nACRESET, |
diff --git a/arch/arm/mach-pxa/corgi.c b/arch/arm/mach-pxa/corgi.c index 3d1dcb9ac08f..461ba4080155 100644 --- a/arch/arm/mach-pxa/corgi.c +++ b/arch/arm/mach-pxa/corgi.c | |||
| @@ -446,7 +446,7 @@ static struct platform_device corgiled_device = { | |||
| 446 | static struct pxamci_platform_data corgi_mci_platform_data = { | 446 | static struct pxamci_platform_data corgi_mci_platform_data = { |
| 447 | .detect_delay_ms = 250, | 447 | .detect_delay_ms = 250, |
| 448 | .ocr_mask = MMC_VDD_32_33|MMC_VDD_33_34, | 448 | .ocr_mask = MMC_VDD_32_33|MMC_VDD_33_34, |
| 449 | .gpio_card_detect = -1, | 449 | .gpio_card_detect = CORGI_GPIO_nSD_DETECT, |
| 450 | .gpio_card_ro = CORGI_GPIO_nSD_WP, | 450 | .gpio_card_ro = CORGI_GPIO_nSD_WP, |
| 451 | .gpio_power = CORGI_GPIO_SD_PWR, | 451 | .gpio_power = CORGI_GPIO_SD_PWR, |
| 452 | }; | 452 | }; |
| @@ -715,7 +715,6 @@ static void __init fixup_corgi(struct machine_desc *desc, | |||
| 715 | sharpsl_save_param(); | 715 | sharpsl_save_param(); |
| 716 | mi->nr_banks=1; | 716 | mi->nr_banks=1; |
| 717 | mi->bank[0].start = 0xa0000000; | 717 | mi->bank[0].start = 0xa0000000; |
| 718 | mi->bank[0].node = 0; | ||
| 719 | if (machine_is_corgi()) | 718 | if (machine_is_corgi()) |
| 720 | mi->bank[0].size = (32*1024*1024); | 719 | mi->bank[0].size = (32*1024*1024); |
| 721 | else | 720 | else |
diff --git a/arch/arm/mach-pxa/cpufreq-pxa2xx.c b/arch/arm/mach-pxa/cpufreq-pxa2xx.c index 9e4d9816726a..268a9bc6be8a 100644 --- a/arch/arm/mach-pxa/cpufreq-pxa2xx.c +++ b/arch/arm/mach-pxa/cpufreq-pxa2xx.c | |||
| @@ -256,13 +256,9 @@ static void init_sdram_rows(void) | |||
| 256 | 256 | ||
| 257 | static u32 mdrefr_dri(unsigned int freq) | 257 | static u32 mdrefr_dri(unsigned int freq) |
| 258 | { | 258 | { |
| 259 | u32 dri = 0; | 259 | u32 interval = freq * SDRAM_TREF / sdram_rows; |
| 260 | 260 | ||
| 261 | if (cpu_is_pxa25x()) | 261 | return (interval - (cpu_is_pxa27x() ? 31 : 0)) / 32; |
| 262 | dri = ((freq * SDRAM_TREF) / (sdram_rows * 32)); | ||
| 263 | if (cpu_is_pxa27x()) | ||
| 264 | dri = ((freq * SDRAM_TREF) / (sdram_rows - 31)) / 32; | ||
| 265 | return dri; | ||
| 266 | } | 262 | } |
| 267 | 263 | ||
| 268 | /* find a valid frequency point */ | 264 | /* find a valid frequency point */ |
diff --git a/arch/arm/mach-pxa/eseries.c b/arch/arm/mach-pxa/eseries.c index 96ed13081639..a0ab3082a000 100644 --- a/arch/arm/mach-pxa/eseries.c +++ b/arch/arm/mach-pxa/eseries.c | |||
| @@ -34,7 +34,6 @@ void __init eseries_fixup(struct machine_desc *desc, | |||
| 34 | { | 34 | { |
| 35 | mi->nr_banks=1; | 35 | mi->nr_banks=1; |
| 36 | mi->bank[0].start = 0xa0000000; | 36 | mi->bank[0].start = 0xa0000000; |
| 37 | mi->bank[0].node = 0; | ||
| 38 | if (machine_is_e800()) | 37 | if (machine_is_e800()) |
| 39 | mi->bank[0].size = (128*1024*1024); | 38 | mi->bank[0].size = (128*1024*1024); |
| 40 | else | 39 | else |
diff --git a/arch/arm/mach-pxa/generic.h b/arch/arm/mach-pxa/generic.h index 890fb90a672f..c6305c5b8a72 100644 --- a/arch/arm/mach-pxa/generic.h +++ b/arch/arm/mach-pxa/generic.h | |||
| @@ -26,8 +26,7 @@ extern unsigned int get_clk_frequency_khz(int info); | |||
| 26 | 26 | ||
| 27 | #define SET_BANK(__nr,__start,__size) \ | 27 | #define SET_BANK(__nr,__start,__size) \ |
| 28 | mi->bank[__nr].start = (__start), \ | 28 | mi->bank[__nr].start = (__start), \ |
| 29 | mi->bank[__nr].size = (__size), \ | 29 | mi->bank[__nr].size = (__size) |
| 30 | mi->bank[__nr].node = (((unsigned)(__start) - PHYS_OFFSET) >> 27) | ||
| 31 | 30 | ||
| 32 | #define ARRAY_AND_SIZE(x) (x), ARRAY_SIZE(x) | 31 | #define ARRAY_AND_SIZE(x) (x), ARRAY_SIZE(x) |
| 33 | 32 | ||
diff --git a/arch/arm/mach-pxa/include/mach/memory.h b/arch/arm/mach-pxa/include/mach/memory.h index f626730ee42e..92361a66b223 100644 --- a/arch/arm/mach-pxa/include/mach/memory.h +++ b/arch/arm/mach-pxa/include/mach/memory.h | |||
| @@ -17,24 +17,11 @@ | |||
| 17 | */ | 17 | */ |
| 18 | #define PHYS_OFFSET UL(0xa0000000) | 18 | #define PHYS_OFFSET UL(0xa0000000) |
| 19 | 19 | ||
| 20 | /* | ||
| 21 | * The nodes are matched with the physical SDRAM banks as follows: | ||
| 22 | * | ||
| 23 | * node 0: 0xa0000000-0xa3ffffff --> 0xc0000000-0xc3ffffff | ||
| 24 | * node 1: 0xa4000000-0xa7ffffff --> 0xc4000000-0xc7ffffff | ||
| 25 | * node 2: 0xa8000000-0xabffffff --> 0xc8000000-0xcbffffff | ||
| 26 | * node 3: 0xac000000-0xafffffff --> 0xcc000000-0xcfffffff | ||
| 27 | * | ||
| 28 | * This needs a node mem size of 26 bits. | ||
| 29 | */ | ||
| 30 | #define NODE_MEM_SIZE_BITS 26 | ||
| 31 | |||
| 32 | #if !defined(__ASSEMBLY__) && defined(CONFIG_MACH_ARMCORE) && defined(CONFIG_PCI) | 20 | #if !defined(__ASSEMBLY__) && defined(CONFIG_MACH_ARMCORE) && defined(CONFIG_PCI) |
| 33 | void cmx2xx_pci_adjust_zones(int node, unsigned long *size, | 21 | void cmx2xx_pci_adjust_zones(unsigned long *size, unsigned long *holes); |
| 34 | unsigned long *holes); | ||
| 35 | 22 | ||
| 36 | #define arch_adjust_zones(node, size, holes) \ | 23 | #define arch_adjust_zones(size, holes) \ |
| 37 | cmx2xx_pci_adjust_zones(node, size, holes) | 24 | cmx2xx_pci_adjust_zones(size, holes) |
| 38 | 25 | ||
| 39 | #define ISA_DMA_THRESHOLD (PHYS_OFFSET + SZ_64M - 1) | 26 | #define ISA_DMA_THRESHOLD (PHYS_OFFSET + SZ_64M - 1) |
| 40 | #define MAX_DMA_ADDRESS (PAGE_OFFSET + SZ_64M) | 27 | #define MAX_DMA_ADDRESS (PAGE_OFFSET + SZ_64M) |
diff --git a/arch/arm/mach-pxa/palmt5.c b/arch/arm/mach-pxa/palmt5.c index 5305a3993e69..5e92d84fe50d 100644 --- a/arch/arm/mach-pxa/palmt5.c +++ b/arch/arm/mach-pxa/palmt5.c | |||
| @@ -21,6 +21,7 @@ | |||
| 21 | #include <linux/irq.h> | 21 | #include <linux/irq.h> |
| 22 | #include <linux/gpio_keys.h> | 22 | #include <linux/gpio_keys.h> |
| 23 | #include <linux/input.h> | 23 | #include <linux/input.h> |
| 24 | #include <linux/memblock.h> | ||
| 24 | #include <linux/pda_power.h> | 25 | #include <linux/pda_power.h> |
| 25 | #include <linux/pwm_backlight.h> | 26 | #include <linux/pwm_backlight.h> |
| 26 | #include <linux/gpio.h> | 27 | #include <linux/gpio.h> |
| @@ -396,6 +397,11 @@ static void __init palmt5_udc_init(void) | |||
| 396 | } | 397 | } |
| 397 | } | 398 | } |
| 398 | 399 | ||
| 400 | static void __init palmt5_reserve(void) | ||
| 401 | { | ||
| 402 | memblock_reserve(0xa0200000, 0x1000); | ||
| 403 | } | ||
| 404 | |||
| 399 | static void __init palmt5_init(void) | 405 | static void __init palmt5_init(void) |
| 400 | { | 406 | { |
| 401 | pxa2xx_mfp_config(ARRAY_AND_SIZE(palmt5_pin_config)); | 407 | pxa2xx_mfp_config(ARRAY_AND_SIZE(palmt5_pin_config)); |
| @@ -421,6 +427,7 @@ MACHINE_START(PALMT5, "Palm Tungsten|T5") | |||
| 421 | .io_pg_offst = (io_p2v(0x40000000) >> 18) & 0xfffc, | 427 | .io_pg_offst = (io_p2v(0x40000000) >> 18) & 0xfffc, |
| 422 | .boot_params = 0xa0000100, | 428 | .boot_params = 0xa0000100, |
| 423 | .map_io = pxa_map_io, | 429 | .map_io = pxa_map_io, |
| 430 | .reserve = palmt5_reserve, | ||
| 424 | .init_irq = pxa27x_init_irq, | 431 | .init_irq = pxa27x_init_irq, |
| 425 | .timer = &pxa_timer, | 432 | .timer = &pxa_timer, |
| 426 | .init_machine = palmt5_init | 433 | .init_machine = palmt5_init |
diff --git a/arch/arm/mach-pxa/palmtreo.c b/arch/arm/mach-pxa/palmtreo.c index d8b4469607a1..3d0c9cc2a406 100644 --- a/arch/arm/mach-pxa/palmtreo.c +++ b/arch/arm/mach-pxa/palmtreo.c | |||
| @@ -20,6 +20,7 @@ | |||
| 20 | #include <linux/irq.h> | 20 | #include <linux/irq.h> |
| 21 | #include <linux/gpio_keys.h> | 21 | #include <linux/gpio_keys.h> |
| 22 | #include <linux/input.h> | 22 | #include <linux/input.h> |
| 23 | #include <linux/memblock.h> | ||
| 23 | #include <linux/pda_power.h> | 24 | #include <linux/pda_power.h> |
| 24 | #include <linux/pwm_backlight.h> | 25 | #include <linux/pwm_backlight.h> |
| 25 | #include <linux/gpio.h> | 26 | #include <linux/gpio.h> |
| @@ -633,6 +634,12 @@ static void __init treo_lcd_power_init(void) | |||
| 633 | treo_lcd_screen.pxafb_lcd_power = treo_lcd_power; | 634 | treo_lcd_screen.pxafb_lcd_power = treo_lcd_power; |
| 634 | } | 635 | } |
| 635 | 636 | ||
| 637 | static void __init treo_reserve(void) | ||
| 638 | { | ||
| 639 | memblock_reserve(0xa0000000, 0x1000); | ||
| 640 | memblock_reserve(0xa2000000, 0x1000); | ||
| 641 | } | ||
| 642 | |||
| 636 | static void __init treo_init(void) | 643 | static void __init treo_init(void) |
| 637 | { | 644 | { |
| 638 | pxa_set_ffuart_info(NULL); | 645 | pxa_set_ffuart_info(NULL); |
| @@ -668,6 +675,7 @@ MACHINE_START(TREO680, "Palm Treo 680") | |||
| 668 | .io_pg_offst = io_p2v(0x40000000), | 675 | .io_pg_offst = io_p2v(0x40000000), |
| 669 | .boot_params = 0xa0000100, | 676 | .boot_params = 0xa0000100, |
| 670 | .map_io = pxa_map_io, | 677 | .map_io = pxa_map_io, |
| 678 | .reserve = treo_reserve, | ||
| 671 | .init_irq = pxa27x_init_irq, | 679 | .init_irq = pxa27x_init_irq, |
| 672 | .timer = &pxa_timer, | 680 | .timer = &pxa_timer, |
| 673 | .init_machine = treo680_init, | 681 | .init_machine = treo680_init, |
| @@ -691,6 +699,7 @@ MACHINE_START(CENTRO, "Palm Centro 685") | |||
| 691 | .io_pg_offst = io_p2v(0x40000000), | 699 | .io_pg_offst = io_p2v(0x40000000), |
| 692 | .boot_params = 0xa0000100, | 700 | .boot_params = 0xa0000100, |
| 693 | .map_io = pxa_map_io, | 701 | .map_io = pxa_map_io, |
| 702 | .reserve = treo_reserve, | ||
| 694 | .init_irq = pxa27x_init_irq, | 703 | .init_irq = pxa27x_init_irq, |
| 695 | .timer = &pxa_timer, | 704 | .timer = &pxa_timer, |
| 696 | .init_machine = centro_init, | 705 | .init_machine = centro_init, |
diff --git a/arch/arm/mach-pxa/poodle.c b/arch/arm/mach-pxa/poodle.c index f4abdaafdac4..bc2758b54446 100644 --- a/arch/arm/mach-pxa/poodle.c +++ b/arch/arm/mach-pxa/poodle.c | |||
| @@ -463,7 +463,6 @@ static void __init fixup_poodle(struct machine_desc *desc, | |||
| 463 | sharpsl_save_param(); | 463 | sharpsl_save_param(); |
| 464 | mi->nr_banks=1; | 464 | mi->nr_banks=1; |
| 465 | mi->bank[0].start = 0xa0000000; | 465 | mi->bank[0].start = 0xa0000000; |
| 466 | mi->bank[0].node = 0; | ||
| 467 | mi->bank[0].size = (32*1024*1024); | 466 | mi->bank[0].size = (32*1024*1024); |
| 468 | } | 467 | } |
| 469 | 468 | ||
diff --git a/arch/arm/mach-pxa/pxa27x.c b/arch/arm/mach-pxa/pxa27x.c index 0af36177ff08..c059dac02b61 100644 --- a/arch/arm/mach-pxa/pxa27x.c +++ b/arch/arm/mach-pxa/pxa27x.c | |||
| @@ -41,10 +41,10 @@ void pxa27x_clear_otgph(void) | |||
| 41 | EXPORT_SYMBOL(pxa27x_clear_otgph); | 41 | EXPORT_SYMBOL(pxa27x_clear_otgph); |
| 42 | 42 | ||
| 43 | static unsigned long ac97_reset_config[] = { | 43 | static unsigned long ac97_reset_config[] = { |
| 44 | GPIO95_AC97_nRESET, | ||
| 45 | GPIO95_GPIO, | ||
| 46 | GPIO113_AC97_nRESET, | ||
| 47 | GPIO113_GPIO, | 44 | GPIO113_GPIO, |
| 45 | GPIO113_AC97_nRESET, | ||
| 46 | GPIO95_GPIO, | ||
| 47 | GPIO95_AC97_nRESET, | ||
| 48 | }; | 48 | }; |
| 49 | 49 | ||
| 50 | void pxa27x_assert_ac97reset(int reset_gpio, int on) | 50 | void pxa27x_assert_ac97reset(int reset_gpio, int on) |
diff --git a/arch/arm/mach-pxa/spitz.c b/arch/arm/mach-pxa/spitz.c index c1048a35f187..51756c723557 100644 --- a/arch/arm/mach-pxa/spitz.c +++ b/arch/arm/mach-pxa/spitz.c | |||
| @@ -847,7 +847,6 @@ static void __init fixup_spitz(struct machine_desc *desc, | |||
| 847 | sharpsl_save_param(); | 847 | sharpsl_save_param(); |
| 848 | mi->nr_banks = 1; | 848 | mi->nr_banks = 1; |
| 849 | mi->bank[0].start = 0xa0000000; | 849 | mi->bank[0].start = 0xa0000000; |
| 850 | mi->bank[0].node = 0; | ||
| 851 | mi->bank[0].size = (64*1024*1024); | 850 | mi->bank[0].size = (64*1024*1024); |
| 852 | } | 851 | } |
| 853 | 852 | ||
diff --git a/arch/arm/mach-pxa/tosa.c b/arch/arm/mach-pxa/tosa.c index 7512b822c6ca..83cc3a18c2e9 100644 --- a/arch/arm/mach-pxa/tosa.c +++ b/arch/arm/mach-pxa/tosa.c | |||
| @@ -948,7 +948,6 @@ static void __init fixup_tosa(struct machine_desc *desc, | |||
| 948 | sharpsl_save_param(); | 948 | sharpsl_save_param(); |
| 949 | mi->nr_banks=1; | 949 | mi->nr_banks=1; |
| 950 | mi->bank[0].start = 0xa0000000; | 950 | mi->bank[0].start = 0xa0000000; |
| 951 | mi->bank[0].node = 0; | ||
| 952 | mi->bank[0].size = (64*1024*1024); | 951 | mi->bank[0].size = (64*1024*1024); |
| 953 | } | 952 | } |
| 954 | 953 | ||
diff --git a/arch/arm/mach-realview/core.c b/arch/arm/mach-realview/core.c index 595be19f8ad5..a54fbda77e45 100644 --- a/arch/arm/mach-realview/core.c +++ b/arch/arm/mach-realview/core.c | |||
| @@ -61,12 +61,11 @@ void __iomem *gic_cpu_base_addr; | |||
| 61 | /* | 61 | /* |
| 62 | * Adjust the zones if there are restrictions for DMA access. | 62 | * Adjust the zones if there are restrictions for DMA access. |
| 63 | */ | 63 | */ |
| 64 | void __init realview_adjust_zones(int node, unsigned long *size, | 64 | void __init realview_adjust_zones(unsigned long *size, unsigned long *hole) |
| 65 | unsigned long *hole) | ||
| 66 | { | 65 | { |
| 67 | unsigned long dma_size = SZ_256M >> PAGE_SHIFT; | 66 | unsigned long dma_size = SZ_256M >> PAGE_SHIFT; |
| 68 | 67 | ||
| 69 | if (!machine_is_realview_pbx() || node || (size[0] <= dma_size)) | 68 | if (!machine_is_realview_pbx() || size[0] <= dma_size) |
| 70 | return; | 69 | return; |
| 71 | 70 | ||
| 72 | size[ZONE_NORMAL] = size[0] - dma_size; | 71 | size[ZONE_NORMAL] = size[0] - dma_size; |
| @@ -232,6 +231,21 @@ static unsigned int realview_mmc_status(struct device *dev) | |||
| 232 | struct amba_device *adev = container_of(dev, struct amba_device, dev); | 231 | struct amba_device *adev = container_of(dev, struct amba_device, dev); |
| 233 | u32 mask; | 232 | u32 mask; |
| 234 | 233 | ||
| 234 | if (machine_is_realview_pb1176()) { | ||
| 235 | static bool inserted = false; | ||
| 236 | |||
| 237 | /* | ||
| 238 | * The PB1176 does not have the status register, | ||
| 239 | * assume it is inserted at startup, then invert | ||
| 240 | * for each call so card insertion/removal will | ||
| 241 | * be detected anyway. This will not be called if | ||
| 242 | * GPIO on PL061 is active, which is the proper | ||
| 243 | * way to do this on the PB1176. | ||
| 244 | */ | ||
| 245 | inserted = !inserted; | ||
| 246 | return inserted ? 0 : 1; | ||
| 247 | } | ||
| 248 | |||
| 235 | if (adev->res.start == REALVIEW_MMCI0_BASE) | 249 | if (adev->res.start == REALVIEW_MMCI0_BASE) |
| 236 | mask = 1; | 250 | mask = 1; |
| 237 | else | 251 | else |
| @@ -300,8 +314,13 @@ static struct clk ref24_clk = { | |||
| 300 | .rate = 24000000, | 314 | .rate = 24000000, |
| 301 | }; | 315 | }; |
| 302 | 316 | ||
| 317 | static struct clk dummy_apb_pclk; | ||
| 318 | |||
| 303 | static struct clk_lookup lookups[] = { | 319 | static struct clk_lookup lookups[] = { |
| 304 | { /* UART0 */ | 320 | { /* Bus clock */ |
| 321 | .con_id = "apb_pclk", | ||
| 322 | .clk = &dummy_apb_pclk, | ||
| 323 | }, { /* UART0 */ | ||
| 305 | .dev_id = "dev:uart0", | 324 | .dev_id = "dev:uart0", |
| 306 | .clk = &ref24_clk, | 325 | .clk = &ref24_clk, |
| 307 | }, { /* UART1 */ | 326 | }, { /* UART1 */ |
| @@ -313,6 +332,12 @@ static struct clk_lookup lookups[] = { | |||
| 313 | }, { /* UART3 */ | 332 | }, { /* UART3 */ |
| 314 | .dev_id = "fpga:uart3", | 333 | .dev_id = "fpga:uart3", |
| 315 | .clk = &ref24_clk, | 334 | .clk = &ref24_clk, |
| 335 | }, { /* UART3 is on the dev chip in PB1176 */ | ||
| 336 | .dev_id = "dev:uart3", | ||
| 337 | .clk = &ref24_clk, | ||
| 338 | }, { /* UART4 only exists in PB1176 */ | ||
| 339 | .dev_id = "fpga:uart4", | ||
| 340 | .clk = &ref24_clk, | ||
| 316 | }, { /* KMI0 */ | 341 | }, { /* KMI0 */ |
| 317 | .dev_id = "fpga:kmi0", | 342 | .dev_id = "fpga:kmi0", |
| 318 | .clk = &ref24_clk, | 343 | .clk = &ref24_clk, |
| @@ -322,12 +347,15 @@ static struct clk_lookup lookups[] = { | |||
| 322 | }, { /* MMC0 */ | 347 | }, { /* MMC0 */ |
| 323 | .dev_id = "fpga:mmc0", | 348 | .dev_id = "fpga:mmc0", |
| 324 | .clk = &ref24_clk, | 349 | .clk = &ref24_clk, |
| 325 | }, { /* EB:CLCD */ | 350 | }, { /* CLCD is in the PB1176 and EB DevChip */ |
| 326 | .dev_id = "dev:clcd", | 351 | .dev_id = "dev:clcd", |
| 327 | .clk = &oscvco_clk, | 352 | .clk = &oscvco_clk, |
| 328 | }, { /* PB:CLCD */ | 353 | }, { /* PB:CLCD */ |
| 329 | .dev_id = "issp:clcd", | 354 | .dev_id = "issp:clcd", |
| 330 | .clk = &oscvco_clk, | 355 | .clk = &oscvco_clk, |
| 356 | }, { /* SSP */ | ||
| 357 | .dev_id = "dev:ssp0", | ||
| 358 | .clk = &ref24_clk, | ||
| 331 | } | 359 | } |
| 332 | }; | 360 | }; |
| 333 | 361 | ||
| @@ -342,7 +370,7 @@ static int __init clk_init(void) | |||
| 342 | 370 | ||
| 343 | return 0; | 371 | return 0; |
| 344 | } | 372 | } |
| 345 | arch_initcall(clk_init); | 373 | core_initcall(clk_init); |
| 346 | 374 | ||
| 347 | /* | 375 | /* |
| 348 | * CLCD support. | 376 | * CLCD support. |
diff --git a/arch/arm/mach-realview/include/mach/board-pb1176.h b/arch/arm/mach-realview/include/mach/board-pb1176.h index 2f5ccb298858..002ab5d8c11c 100644 --- a/arch/arm/mach-realview/include/mach/board-pb1176.h +++ b/arch/arm/mach-realview/include/mach/board-pb1176.h | |||
| @@ -26,6 +26,7 @@ | |||
| 26 | /* | 26 | /* |
| 27 | * Peripheral addresses | 27 | * Peripheral addresses |
| 28 | */ | 28 | */ |
| 29 | #define REALVIEW_PB1176_UART4_BASE 0x10009000 /* UART 4 */ | ||
| 29 | #define REALVIEW_PB1176_SCTL_BASE 0x10100000 /* System controller */ | 30 | #define REALVIEW_PB1176_SCTL_BASE 0x10100000 /* System controller */ |
| 30 | #define REALVIEW_PB1176_SMC_BASE 0x10111000 /* SMC */ | 31 | #define REALVIEW_PB1176_SMC_BASE 0x10111000 /* SMC */ |
| 31 | #define REALVIEW_PB1176_DMC_BASE 0x10109000 /* DMC configuration */ | 32 | #define REALVIEW_PB1176_DMC_BASE 0x10109000 /* DMC configuration */ |
diff --git a/arch/arm/mach-realview/include/mach/irqs-pb1176.h b/arch/arm/mach-realview/include/mach/irqs-pb1176.h index 830055bb8628..5c3c625e3e04 100644 --- a/arch/arm/mach-realview/include/mach/irqs-pb1176.h +++ b/arch/arm/mach-realview/include/mach/irqs-pb1176.h | |||
| @@ -40,6 +40,7 @@ | |||
| 40 | #define IRQ_DC1176_L2CC (IRQ_DC1176_GIC_START + 13) | 40 | #define IRQ_DC1176_L2CC (IRQ_DC1176_GIC_START + 13) |
| 41 | #define IRQ_DC1176_RTC (IRQ_DC1176_GIC_START + 14) | 41 | #define IRQ_DC1176_RTC (IRQ_DC1176_GIC_START + 14) |
| 42 | #define IRQ_DC1176_CLCD (IRQ_DC1176_GIC_START + 15) /* CLCD controller */ | 42 | #define IRQ_DC1176_CLCD (IRQ_DC1176_GIC_START + 15) /* CLCD controller */ |
| 43 | #define IRQ_DC1176_SSP (IRQ_DC1176_GIC_START + 17) /* SSP port */ | ||
| 43 | #define IRQ_DC1176_UART0 (IRQ_DC1176_GIC_START + 18) /* UART 0 on development chip */ | 44 | #define IRQ_DC1176_UART0 (IRQ_DC1176_GIC_START + 18) /* UART 0 on development chip */ |
| 44 | #define IRQ_DC1176_UART1 (IRQ_DC1176_GIC_START + 19) /* UART 1 on development chip */ | 45 | #define IRQ_DC1176_UART1 (IRQ_DC1176_GIC_START + 19) /* UART 1 on development chip */ |
| 45 | #define IRQ_DC1176_UART2 (IRQ_DC1176_GIC_START + 20) /* UART 2 on development chip */ | 46 | #define IRQ_DC1176_UART2 (IRQ_DC1176_GIC_START + 20) /* UART 2 on development chip */ |
| @@ -73,7 +74,6 @@ | |||
| 73 | #define IRQ_PB1176_RTC (IRQ_PB1176_GIC_START + 25) /* Real Time Clock */ | 74 | #define IRQ_PB1176_RTC (IRQ_PB1176_GIC_START + 25) /* Real Time Clock */ |
| 74 | 75 | ||
| 75 | #define IRQ_PB1176_GPIO0 -1 | 76 | #define IRQ_PB1176_GPIO0 -1 |
| 76 | #define IRQ_PB1176_SSP -1 | ||
| 77 | #define IRQ_PB1176_SCTL -1 | 77 | #define IRQ_PB1176_SCTL -1 |
| 78 | 78 | ||
| 79 | #define NR_GIC_PB1176 2 | 79 | #define NR_GIC_PB1176 2 |
diff --git a/arch/arm/mach-realview/include/mach/memory.h b/arch/arm/mach-realview/include/mach/memory.h index 2417bbcf97fd..5dafc157b276 100644 --- a/arch/arm/mach-realview/include/mach/memory.h +++ b/arch/arm/mach-realview/include/mach/memory.h | |||
| @@ -30,10 +30,9 @@ | |||
| 30 | #endif | 30 | #endif |
| 31 | 31 | ||
| 32 | #if !defined(__ASSEMBLY__) && defined(CONFIG_ZONE_DMA) | 32 | #if !defined(__ASSEMBLY__) && defined(CONFIG_ZONE_DMA) |
| 33 | extern void realview_adjust_zones(int node, unsigned long *size, | 33 | extern void realview_adjust_zones(unsigned long *size, unsigned long *hole); |
| 34 | unsigned long *hole); | 34 | #define arch_adjust_zones(size, hole) \ |
| 35 | #define arch_adjust_zones(node, size, hole) \ | 35 | realview_adjust_zones(size, hole) |
| 36 | realview_adjust_zones(node, size, hole) | ||
| 37 | 36 | ||
| 38 | #define ISA_DMA_THRESHOLD (PHYS_OFFSET + SZ_256M - 1) | 37 | #define ISA_DMA_THRESHOLD (PHYS_OFFSET + SZ_256M - 1) |
| 39 | #define MAX_DMA_ADDRESS (PAGE_OFFSET + SZ_256M) | 38 | #define MAX_DMA_ADDRESS (PAGE_OFFSET + SZ_256M) |
diff --git a/arch/arm/mach-realview/realview_eb.c b/arch/arm/mach-realview/realview_eb.c index 4425018fab82..991c1f8390e2 100644 --- a/arch/arm/mach-realview/realview_eb.c +++ b/arch/arm/mach-realview/realview_eb.c | |||
| @@ -25,6 +25,7 @@ | |||
| 25 | #include <linux/amba/bus.h> | 25 | #include <linux/amba/bus.h> |
| 26 | #include <linux/amba/pl061.h> | 26 | #include <linux/amba/pl061.h> |
| 27 | #include <linux/amba/mmci.h> | 27 | #include <linux/amba/mmci.h> |
| 28 | #include <linux/amba/pl022.h> | ||
| 28 | #include <linux/io.h> | 29 | #include <linux/io.h> |
| 29 | 30 | ||
| 30 | #include <mach/hardware.h> | 31 | #include <mach/hardware.h> |
| @@ -129,6 +130,12 @@ static struct pl061_platform_data gpio2_plat_data = { | |||
| 129 | .irq_base = -1, | 130 | .irq_base = -1, |
| 130 | }; | 131 | }; |
| 131 | 132 | ||
| 133 | static struct pl022_ssp_controller ssp0_plat_data = { | ||
| 134 | .bus_id = 0, | ||
| 135 | .enable_dma = 0, | ||
| 136 | .num_chipselect = 1, | ||
| 137 | }; | ||
| 138 | |||
| 132 | /* | 139 | /* |
| 133 | * RealView EB AMBA devices | 140 | * RealView EB AMBA devices |
| 134 | */ | 141 | */ |
| @@ -213,7 +220,7 @@ AMBA_DEVICE(sci0, "dev:sci0", SCI, NULL); | |||
| 213 | AMBA_DEVICE(uart0, "dev:uart0", EB_UART0, NULL); | 220 | AMBA_DEVICE(uart0, "dev:uart0", EB_UART0, NULL); |
| 214 | AMBA_DEVICE(uart1, "dev:uart1", EB_UART1, NULL); | 221 | AMBA_DEVICE(uart1, "dev:uart1", EB_UART1, NULL); |
| 215 | AMBA_DEVICE(uart2, "dev:uart2", EB_UART2, NULL); | 222 | AMBA_DEVICE(uart2, "dev:uart2", EB_UART2, NULL); |
| 216 | AMBA_DEVICE(ssp0, "dev:ssp0", EB_SSP, NULL); | 223 | AMBA_DEVICE(ssp0, "dev:ssp0", EB_SSP, &ssp0_plat_data); |
| 217 | 224 | ||
| 218 | static struct amba_device *amba_devs[] __initdata = { | 225 | static struct amba_device *amba_devs[] __initdata = { |
| 219 | &dmac_device, | 226 | &dmac_device, |
| @@ -324,6 +331,26 @@ static struct platform_device pmu_device = { | |||
| 324 | .resource = pmu_resources, | 331 | .resource = pmu_resources, |
| 325 | }; | 332 | }; |
| 326 | 333 | ||
| 334 | static struct resource char_lcd_resources[] = { | ||
| 335 | { | ||
| 336 | .start = REALVIEW_CHAR_LCD_BASE, | ||
| 337 | .end = (REALVIEW_CHAR_LCD_BASE + SZ_4K - 1), | ||
| 338 | .flags = IORESOURCE_MEM, | ||
| 339 | }, | ||
| 340 | { | ||
| 341 | .start = IRQ_EB_CHARLCD, | ||
| 342 | .end = IRQ_EB_CHARLCD, | ||
| 343 | .flags = IORESOURCE_IRQ, | ||
| 344 | }, | ||
| 345 | }; | ||
| 346 | |||
| 347 | static struct platform_device char_lcd_device = { | ||
| 348 | .name = "arm-charlcd", | ||
| 349 | .id = -1, | ||
| 350 | .num_resources = ARRAY_SIZE(char_lcd_resources), | ||
| 351 | .resource = char_lcd_resources, | ||
| 352 | }; | ||
| 353 | |||
| 327 | static void __init gic_init_irq(void) | 354 | static void __init gic_init_irq(void) |
| 328 | { | 355 | { |
| 329 | if (core_tile_eb11mp() || core_tile_a9mp()) { | 356 | if (core_tile_eb11mp() || core_tile_a9mp()) { |
| @@ -442,6 +469,7 @@ static void __init realview_eb_init(void) | |||
| 442 | 469 | ||
| 443 | realview_flash_register(&realview_eb_flash_resource, 1); | 470 | realview_flash_register(&realview_eb_flash_resource, 1); |
| 444 | platform_device_register(&realview_i2c_device); | 471 | platform_device_register(&realview_i2c_device); |
| 472 | platform_device_register(&char_lcd_device); | ||
| 445 | eth_device_register(); | 473 | eth_device_register(); |
| 446 | realview_usb_register(realview_eb_isp1761_resources); | 474 | realview_usb_register(realview_eb_isp1761_resources); |
| 447 | 475 | ||
diff --git a/arch/arm/mach-realview/realview_pb1176.c b/arch/arm/mach-realview/realview_pb1176.c index 099a1f125cf8..d2be12eb829e 100644 --- a/arch/arm/mach-realview/realview_pb1176.c +++ b/arch/arm/mach-realview/realview_pb1176.c | |||
| @@ -25,6 +25,7 @@ | |||
| 25 | #include <linux/amba/bus.h> | 25 | #include <linux/amba/bus.h> |
| 26 | #include <linux/amba/pl061.h> | 26 | #include <linux/amba/pl061.h> |
| 27 | #include <linux/amba/mmci.h> | 27 | #include <linux/amba/mmci.h> |
| 28 | #include <linux/amba/pl022.h> | ||
| 28 | #include <linux/io.h> | 29 | #include <linux/io.h> |
| 29 | 30 | ||
| 30 | #include <mach/hardware.h> | 31 | #include <mach/hardware.h> |
| @@ -123,6 +124,12 @@ static struct pl061_platform_data gpio2_plat_data = { | |||
| 123 | .irq_base = -1, | 124 | .irq_base = -1, |
| 124 | }; | 125 | }; |
| 125 | 126 | ||
| 127 | static struct pl022_ssp_controller ssp0_plat_data = { | ||
| 128 | .bus_id = 0, | ||
| 129 | .enable_dma = 0, | ||
| 130 | .num_chipselect = 1, | ||
| 131 | }; | ||
| 132 | |||
| 126 | /* | 133 | /* |
| 127 | * RealView PB1176 AMBA devices | 134 | * RealView PB1176 AMBA devices |
| 128 | */ | 135 | */ |
| @@ -144,8 +151,6 @@ static struct pl061_platform_data gpio2_plat_data = { | |||
| 144 | #define MPMC_DMA { 0, 0 } | 151 | #define MPMC_DMA { 0, 0 } |
| 145 | #define PB1176_CLCD_IRQ { IRQ_DC1176_CLCD, NO_IRQ } | 152 | #define PB1176_CLCD_IRQ { IRQ_DC1176_CLCD, NO_IRQ } |
| 146 | #define PB1176_CLCD_DMA { 0, 0 } | 153 | #define PB1176_CLCD_DMA { 0, 0 } |
| 147 | #define DMAC_IRQ { IRQ_PB1176_DMAC, NO_IRQ } | ||
| 148 | #define DMAC_DMA { 0, 0 } | ||
| 149 | #define SCTL_IRQ { NO_IRQ, NO_IRQ } | 154 | #define SCTL_IRQ { NO_IRQ, NO_IRQ } |
| 150 | #define SCTL_DMA { 0, 0 } | 155 | #define SCTL_DMA { 0, 0 } |
| 151 | #define PB1176_WATCHDOG_IRQ { IRQ_DC1176_WATCHDOG, NO_IRQ } | 156 | #define PB1176_WATCHDOG_IRQ { IRQ_DC1176_WATCHDOG, NO_IRQ } |
| @@ -166,7 +171,9 @@ static struct pl061_platform_data gpio2_plat_data = { | |||
| 166 | #define PB1176_UART2_DMA { 11, 10 } | 171 | #define PB1176_UART2_DMA { 11, 10 } |
| 167 | #define PB1176_UART3_IRQ { IRQ_DC1176_UART3, NO_IRQ } | 172 | #define PB1176_UART3_IRQ { IRQ_DC1176_UART3, NO_IRQ } |
| 168 | #define PB1176_UART3_DMA { 0x86, 0x87 } | 173 | #define PB1176_UART3_DMA { 0x86, 0x87 } |
| 169 | #define PB1176_SSP_IRQ { IRQ_PB1176_SSP, NO_IRQ } | 174 | #define PB1176_UART4_IRQ { IRQ_PB1176_UART4, NO_IRQ } |
| 175 | #define PB1176_UART4_DMA { 0, 0 } | ||
| 176 | #define PB1176_SSP_IRQ { IRQ_DC1176_SSP, NO_IRQ } | ||
| 170 | #define PB1176_SSP_DMA { 9, 8 } | 177 | #define PB1176_SSP_DMA { 9, 8 } |
| 171 | 178 | ||
| 172 | /* FPGA Primecells */ | 179 | /* FPGA Primecells */ |
| @@ -174,7 +181,7 @@ AMBA_DEVICE(aaci, "fpga:aaci", AACI, NULL); | |||
| 174 | AMBA_DEVICE(mmc0, "fpga:mmc0", MMCI0, &realview_mmc0_plat_data); | 181 | AMBA_DEVICE(mmc0, "fpga:mmc0", MMCI0, &realview_mmc0_plat_data); |
| 175 | AMBA_DEVICE(kmi0, "fpga:kmi0", KMI0, NULL); | 182 | AMBA_DEVICE(kmi0, "fpga:kmi0", KMI0, NULL); |
| 176 | AMBA_DEVICE(kmi1, "fpga:kmi1", KMI1, NULL); | 183 | AMBA_DEVICE(kmi1, "fpga:kmi1", KMI1, NULL); |
| 177 | AMBA_DEVICE(uart3, "fpga:uart3", PB1176_UART3, NULL); | 184 | AMBA_DEVICE(uart4, "fpga:uart4", PB1176_UART4, NULL); |
| 178 | 185 | ||
| 179 | /* DevChip Primecells */ | 186 | /* DevChip Primecells */ |
| 180 | AMBA_DEVICE(smc, "dev:smc", PB1176_SMC, NULL); | 187 | AMBA_DEVICE(smc, "dev:smc", PB1176_SMC, NULL); |
| @@ -188,18 +195,16 @@ AMBA_DEVICE(sci0, "dev:sci0", SCI, NULL); | |||
| 188 | AMBA_DEVICE(uart0, "dev:uart0", PB1176_UART0, NULL); | 195 | AMBA_DEVICE(uart0, "dev:uart0", PB1176_UART0, NULL); |
| 189 | AMBA_DEVICE(uart1, "dev:uart1", PB1176_UART1, NULL); | 196 | AMBA_DEVICE(uart1, "dev:uart1", PB1176_UART1, NULL); |
| 190 | AMBA_DEVICE(uart2, "dev:uart2", PB1176_UART2, NULL); | 197 | AMBA_DEVICE(uart2, "dev:uart2", PB1176_UART2, NULL); |
| 191 | AMBA_DEVICE(ssp0, "dev:ssp0", PB1176_SSP, NULL); | 198 | AMBA_DEVICE(uart3, "dev:uart3", PB1176_UART3, NULL); |
| 192 | 199 | AMBA_DEVICE(ssp0, "dev:ssp0", PB1176_SSP, &ssp0_plat_data); | |
| 193 | /* Primecells on the NEC ISSP chip */ | 200 | AMBA_DEVICE(clcd, "dev:clcd", PB1176_CLCD, &clcd_plat_data); |
| 194 | AMBA_DEVICE(clcd, "issp:clcd", PB1176_CLCD, &clcd_plat_data); | ||
| 195 | //AMBA_DEVICE(dmac, "issp:dmac", PB1176_DMAC, NULL); | ||
| 196 | 201 | ||
| 197 | static struct amba_device *amba_devs[] __initdata = { | 202 | static struct amba_device *amba_devs[] __initdata = { |
| 198 | // &dmac_device, | ||
| 199 | &uart0_device, | 203 | &uart0_device, |
| 200 | &uart1_device, | 204 | &uart1_device, |
| 201 | &uart2_device, | 205 | &uart2_device, |
| 202 | &uart3_device, | 206 | &uart3_device, |
| 207 | &uart4_device, | ||
| 203 | &smc_device, | 208 | &smc_device, |
| 204 | &clcd_device, | 209 | &clcd_device, |
| 205 | &sctl_device, | 210 | &sctl_device, |
| @@ -276,6 +281,26 @@ static struct platform_device pmu_device = { | |||
| 276 | .resource = &pmu_resource, | 281 | .resource = &pmu_resource, |
| 277 | }; | 282 | }; |
| 278 | 283 | ||
| 284 | static struct resource char_lcd_resources[] = { | ||
| 285 | { | ||
| 286 | .start = REALVIEW_CHAR_LCD_BASE, | ||
| 287 | .end = (REALVIEW_CHAR_LCD_BASE + SZ_4K - 1), | ||
| 288 | .flags = IORESOURCE_MEM, | ||
| 289 | }, | ||
| 290 | { | ||
| 291 | .start = IRQ_PB1176_CHARLCD, | ||
| 292 | .end = IRQ_PB1176_CHARLCD, | ||
| 293 | .flags = IORESOURCE_IRQ, | ||
| 294 | }, | ||
| 295 | }; | ||
| 296 | |||
| 297 | static struct platform_device char_lcd_device = { | ||
| 298 | .name = "arm-charlcd", | ||
| 299 | .id = -1, | ||
| 300 | .num_resources = ARRAY_SIZE(char_lcd_resources), | ||
| 301 | .resource = char_lcd_resources, | ||
| 302 | }; | ||
| 303 | |||
| 279 | static void __init gic_init_irq(void) | 304 | static void __init gic_init_irq(void) |
| 280 | { | 305 | { |
| 281 | /* ARM1176 DevChip GIC, primary */ | 306 | /* ARM1176 DevChip GIC, primary */ |
| @@ -338,6 +363,7 @@ static void __init realview_pb1176_init(void) | |||
| 338 | platform_device_register(&realview_i2c_device); | 363 | platform_device_register(&realview_i2c_device); |
| 339 | realview_usb_register(realview_pb1176_isp1761_resources); | 364 | realview_usb_register(realview_pb1176_isp1761_resources); |
| 340 | platform_device_register(&pmu_device); | 365 | platform_device_register(&pmu_device); |
| 366 | platform_device_register(&char_lcd_device); | ||
| 341 | 367 | ||
| 342 | for (i = 0; i < ARRAY_SIZE(amba_devs); i++) { | 368 | for (i = 0; i < ARRAY_SIZE(amba_devs); i++) { |
| 343 | struct amba_device *d = amba_devs[i]; | 369 | struct amba_device *d = amba_devs[i]; |
diff --git a/arch/arm/mach-realview/realview_pb11mp.c b/arch/arm/mach-realview/realview_pb11mp.c index 0e07a5ccb75f..d591bc00b86e 100644 --- a/arch/arm/mach-realview/realview_pb11mp.c +++ b/arch/arm/mach-realview/realview_pb11mp.c | |||
| @@ -25,6 +25,7 @@ | |||
| 25 | #include <linux/amba/bus.h> | 25 | #include <linux/amba/bus.h> |
| 26 | #include <linux/amba/pl061.h> | 26 | #include <linux/amba/pl061.h> |
| 27 | #include <linux/amba/mmci.h> | 27 | #include <linux/amba/mmci.h> |
| 28 | #include <linux/amba/pl022.h> | ||
| 28 | #include <linux/io.h> | 29 | #include <linux/io.h> |
| 29 | 30 | ||
| 30 | #include <mach/hardware.h> | 31 | #include <mach/hardware.h> |
| @@ -124,6 +125,12 @@ static struct pl061_platform_data gpio2_plat_data = { | |||
| 124 | .irq_base = -1, | 125 | .irq_base = -1, |
| 125 | }; | 126 | }; |
| 126 | 127 | ||
| 128 | static struct pl022_ssp_controller ssp0_plat_data = { | ||
| 129 | .bus_id = 0, | ||
| 130 | .enable_dma = 0, | ||
| 131 | .num_chipselect = 1, | ||
| 132 | }; | ||
| 133 | |||
| 127 | /* | 134 | /* |
| 128 | * RealView PB11MPCore AMBA devices | 135 | * RealView PB11MPCore AMBA devices |
| 129 | */ | 136 | */ |
| @@ -190,7 +197,7 @@ AMBA_DEVICE(sci0, "dev:sci0", SCI, NULL); | |||
| 190 | AMBA_DEVICE(uart0, "dev:uart0", PB11MP_UART0, NULL); | 197 | AMBA_DEVICE(uart0, "dev:uart0", PB11MP_UART0, NULL); |
| 191 | AMBA_DEVICE(uart1, "dev:uart1", PB11MP_UART1, NULL); | 198 | AMBA_DEVICE(uart1, "dev:uart1", PB11MP_UART1, NULL); |
| 192 | AMBA_DEVICE(uart2, "dev:uart2", PB11MP_UART2, NULL); | 199 | AMBA_DEVICE(uart2, "dev:uart2", PB11MP_UART2, NULL); |
| 193 | AMBA_DEVICE(ssp0, "dev:ssp0", PB11MP_SSP, NULL); | 200 | AMBA_DEVICE(ssp0, "dev:ssp0", PB11MP_SSP, &ssp0_plat_data); |
| 194 | 201 | ||
| 195 | /* Primecells on the NEC ISSP chip */ | 202 | /* Primecells on the NEC ISSP chip */ |
| 196 | AMBA_DEVICE(clcd, "issp:clcd", PB11MP_CLCD, &clcd_plat_data); | 203 | AMBA_DEVICE(clcd, "issp:clcd", PB11MP_CLCD, &clcd_plat_data); |
diff --git a/arch/arm/mach-realview/realview_pba8.c b/arch/arm/mach-realview/realview_pba8.c index ac2f06f1ca50..6c37621217bc 100644 --- a/arch/arm/mach-realview/realview_pba8.c +++ b/arch/arm/mach-realview/realview_pba8.c | |||
| @@ -25,6 +25,7 @@ | |||
| 25 | #include <linux/amba/bus.h> | 25 | #include <linux/amba/bus.h> |
| 26 | #include <linux/amba/pl061.h> | 26 | #include <linux/amba/pl061.h> |
| 27 | #include <linux/amba/mmci.h> | 27 | #include <linux/amba/mmci.h> |
| 28 | #include <linux/amba/pl022.h> | ||
| 28 | #include <linux/io.h> | 29 | #include <linux/io.h> |
| 29 | 30 | ||
| 30 | #include <asm/irq.h> | 31 | #include <asm/irq.h> |
| @@ -114,6 +115,12 @@ static struct pl061_platform_data gpio2_plat_data = { | |||
| 114 | .irq_base = -1, | 115 | .irq_base = -1, |
| 115 | }; | 116 | }; |
| 116 | 117 | ||
| 118 | static struct pl022_ssp_controller ssp0_plat_data = { | ||
| 119 | .bus_id = 0, | ||
| 120 | .enable_dma = 0, | ||
| 121 | .num_chipselect = 1, | ||
| 122 | }; | ||
| 123 | |||
| 117 | /* | 124 | /* |
| 118 | * RealView PBA8Core AMBA devices | 125 | * RealView PBA8Core AMBA devices |
| 119 | */ | 126 | */ |
| @@ -180,7 +187,7 @@ AMBA_DEVICE(sci0, "dev:sci0", SCI, NULL); | |||
| 180 | AMBA_DEVICE(uart0, "dev:uart0", PBA8_UART0, NULL); | 187 | AMBA_DEVICE(uart0, "dev:uart0", PBA8_UART0, NULL); |
| 181 | AMBA_DEVICE(uart1, "dev:uart1", PBA8_UART1, NULL); | 188 | AMBA_DEVICE(uart1, "dev:uart1", PBA8_UART1, NULL); |
| 182 | AMBA_DEVICE(uart2, "dev:uart2", PBA8_UART2, NULL); | 189 | AMBA_DEVICE(uart2, "dev:uart2", PBA8_UART2, NULL); |
| 183 | AMBA_DEVICE(ssp0, "dev:ssp0", PBA8_SSP, NULL); | 190 | AMBA_DEVICE(ssp0, "dev:ssp0", PBA8_SSP, &ssp0_plat_data); |
| 184 | 191 | ||
| 185 | /* Primecells on the NEC ISSP chip */ | 192 | /* Primecells on the NEC ISSP chip */ |
| 186 | AMBA_DEVICE(clcd, "issp:clcd", PBA8_CLCD, &clcd_plat_data); | 193 | AMBA_DEVICE(clcd, "issp:clcd", PBA8_CLCD, &clcd_plat_data); |
diff --git a/arch/arm/mach-realview/realview_pbx.c b/arch/arm/mach-realview/realview_pbx.c index 08fd683adc4c..9428eff0b116 100644 --- a/arch/arm/mach-realview/realview_pbx.c +++ b/arch/arm/mach-realview/realview_pbx.c | |||
| @@ -24,6 +24,7 @@ | |||
| 24 | #include <linux/amba/bus.h> | 24 | #include <linux/amba/bus.h> |
| 25 | #include <linux/amba/pl061.h> | 25 | #include <linux/amba/pl061.h> |
| 26 | #include <linux/amba/mmci.h> | 26 | #include <linux/amba/mmci.h> |
| 27 | #include <linux/amba/pl022.h> | ||
| 27 | #include <linux/io.h> | 28 | #include <linux/io.h> |
| 28 | 29 | ||
| 29 | #include <asm/irq.h> | 30 | #include <asm/irq.h> |
| @@ -136,6 +137,12 @@ static struct pl061_platform_data gpio2_plat_data = { | |||
| 136 | .irq_base = -1, | 137 | .irq_base = -1, |
| 137 | }; | 138 | }; |
| 138 | 139 | ||
| 140 | static struct pl022_ssp_controller ssp0_plat_data = { | ||
| 141 | .bus_id = 0, | ||
| 142 | .enable_dma = 0, | ||
| 143 | .num_chipselect = 1, | ||
| 144 | }; | ||
| 145 | |||
| 139 | /* | 146 | /* |
| 140 | * RealView PBXCore AMBA devices | 147 | * RealView PBXCore AMBA devices |
| 141 | */ | 148 | */ |
| @@ -202,7 +209,7 @@ AMBA_DEVICE(sci0, "dev:sci0", SCI, NULL); | |||
| 202 | AMBA_DEVICE(uart0, "dev:uart0", PBX_UART0, NULL); | 209 | AMBA_DEVICE(uart0, "dev:uart0", PBX_UART0, NULL); |
| 203 | AMBA_DEVICE(uart1, "dev:uart1", PBX_UART1, NULL); | 210 | AMBA_DEVICE(uart1, "dev:uart1", PBX_UART1, NULL); |
| 204 | AMBA_DEVICE(uart2, "dev:uart2", PBX_UART2, NULL); | 211 | AMBA_DEVICE(uart2, "dev:uart2", PBX_UART2, NULL); |
| 205 | AMBA_DEVICE(ssp0, "dev:ssp0", PBX_SSP, NULL); | 212 | AMBA_DEVICE(ssp0, "dev:ssp0", PBX_SSP, &ssp0_plat_data); |
| 206 | 213 | ||
| 207 | /* Primecells on the NEC ISSP chip */ | 214 | /* Primecells on the NEC ISSP chip */ |
| 208 | AMBA_DEVICE(clcd, "issp:clcd", PBX_CLCD, &clcd_plat_data); | 215 | AMBA_DEVICE(clcd, "issp:clcd", PBX_CLCD, &clcd_plat_data); |
diff --git a/arch/arm/mach-s3c2410/mach-h1940.c b/arch/arm/mach-s3c2410/mach-h1940.c index 779b45b3f80f..3ba3bab139d0 100644 --- a/arch/arm/mach-s3c2410/mach-h1940.c +++ b/arch/arm/mach-s3c2410/mach-h1940.c | |||
| @@ -15,6 +15,7 @@ | |||
| 15 | #include <linux/types.h> | 15 | #include <linux/types.h> |
| 16 | #include <linux/interrupt.h> | 16 | #include <linux/interrupt.h> |
| 17 | #include <linux/list.h> | 17 | #include <linux/list.h> |
| 18 | #include <linux/memblock.h> | ||
| 18 | #include <linux/timer.h> | 19 | #include <linux/timer.h> |
| 19 | #include <linux/init.h> | 20 | #include <linux/init.h> |
| 20 | #include <linux/sysdev.h> | 21 | #include <linux/sysdev.h> |
| @@ -304,6 +305,13 @@ static void __init h1940_map_io(void) | |||
| 304 | s3c_pm_init(); | 305 | s3c_pm_init(); |
| 305 | } | 306 | } |
| 306 | 307 | ||
| 308 | /* H1940 and RX3715 need to reserve this for suspend */ | ||
| 309 | static void __init h1940_reserve(void) | ||
| 310 | { | ||
| 311 | memblock_reserve(0x30003000, 0x1000); | ||
| 312 | memblock_reserve(0x30081000, 0x1000); | ||
| 313 | } | ||
| 314 | |||
| 307 | static void __init h1940_init_irq(void) | 315 | static void __init h1940_init_irq(void) |
| 308 | { | 316 | { |
| 309 | s3c24xx_init_irq(); | 317 | s3c24xx_init_irq(); |
| @@ -346,6 +354,7 @@ MACHINE_START(H1940, "IPAQ-H1940") | |||
| 346 | .io_pg_offst = (((u32)S3C24XX_VA_UART) >> 18) & 0xfffc, | 354 | .io_pg_offst = (((u32)S3C24XX_VA_UART) >> 18) & 0xfffc, |
| 347 | .boot_params = S3C2410_SDRAM_PA + 0x100, | 355 | .boot_params = S3C2410_SDRAM_PA + 0x100, |
| 348 | .map_io = h1940_map_io, | 356 | .map_io = h1940_map_io, |
| 357 | .reserve = h1940_reserve, | ||
| 349 | .init_irq = h1940_init_irq, | 358 | .init_irq = h1940_init_irq, |
| 350 | .init_machine = h1940_init, | 359 | .init_machine = h1940_init, |
| 351 | .timer = &s3c24xx_timer, | 360 | .timer = &s3c24xx_timer, |
diff --git a/arch/arm/mach-s3c2412/mach-smdk2413.c b/arch/arm/mach-s3c2412/mach-smdk2413.c index ba93a356a839..054c9f92232a 100644 --- a/arch/arm/mach-s3c2412/mach-smdk2413.c +++ b/arch/arm/mach-s3c2412/mach-smdk2413.c | |||
| @@ -119,7 +119,6 @@ static void __init smdk2413_fixup(struct machine_desc *desc, | |||
| 119 | mi->nr_banks=1; | 119 | mi->nr_banks=1; |
| 120 | mi->bank[0].start = 0x30000000; | 120 | mi->bank[0].start = 0x30000000; |
| 121 | mi->bank[0].size = SZ_64M; | 121 | mi->bank[0].size = SZ_64M; |
| 122 | mi->bank[0].node = 0; | ||
| 123 | } | 122 | } |
| 124 | } | 123 | } |
| 125 | 124 | ||
diff --git a/arch/arm/mach-s3c2412/mach-vstms.c b/arch/arm/mach-s3c2412/mach-vstms.c index 3ca9265b6997..f291ac25d312 100644 --- a/arch/arm/mach-s3c2412/mach-vstms.c +++ b/arch/arm/mach-s3c2412/mach-vstms.c | |||
| @@ -137,7 +137,6 @@ static void __init vstms_fixup(struct machine_desc *desc, | |||
| 137 | mi->nr_banks=1; | 137 | mi->nr_banks=1; |
| 138 | mi->bank[0].start = 0x30000000; | 138 | mi->bank[0].start = 0x30000000; |
| 139 | mi->bank[0].size = SZ_64M; | 139 | mi->bank[0].size = SZ_64M; |
| 140 | mi->bank[0].node = 0; | ||
| 141 | } | 140 | } |
| 142 | } | 141 | } |
| 143 | 142 | ||
diff --git a/arch/arm/mach-s3c2440/mach-rx1950.c b/arch/arm/mach-s3c2440/mach-rx1950.c index 8603b577a24b..142d1f921176 100644 --- a/arch/arm/mach-s3c2440/mach-rx1950.c +++ b/arch/arm/mach-s3c2440/mach-rx1950.c | |||
| @@ -15,6 +15,7 @@ | |||
| 15 | #include <linux/types.h> | 15 | #include <linux/types.h> |
| 16 | #include <linux/interrupt.h> | 16 | #include <linux/interrupt.h> |
| 17 | #include <linux/list.h> | 17 | #include <linux/list.h> |
| 18 | #include <linux/memblock.h> | ||
| 18 | #include <linux/delay.h> | 19 | #include <linux/delay.h> |
| 19 | #include <linux/timer.h> | 20 | #include <linux/timer.h> |
| 20 | #include <linux/init.h> | 21 | #include <linux/init.h> |
| @@ -570,12 +571,20 @@ static void __init rx1950_init_machine(void) | |||
| 570 | platform_add_devices(rx1950_devices, ARRAY_SIZE(rx1950_devices)); | 571 | platform_add_devices(rx1950_devices, ARRAY_SIZE(rx1950_devices)); |
| 571 | } | 572 | } |
| 572 | 573 | ||
| 574 | /* H1940 and RX3715 need to reserve this for suspend */ | ||
| 575 | static void __init rx1950_reserve(void) | ||
| 576 | { | ||
| 577 | memblock_reserve(0x30003000, 0x1000); | ||
| 578 | memblock_reserve(0x30081000, 0x1000); | ||
| 579 | } | ||
| 580 | |||
| 573 | MACHINE_START(RX1950, "HP iPAQ RX1950") | 581 | MACHINE_START(RX1950, "HP iPAQ RX1950") |
| 574 | /* Maintainers: Vasily Khoruzhick */ | 582 | /* Maintainers: Vasily Khoruzhick */ |
| 575 | .phys_io = S3C2410_PA_UART, | 583 | .phys_io = S3C2410_PA_UART, |
| 576 | .io_pg_offst = (((u32) S3C24XX_VA_UART) >> 18) & 0xfffc, | 584 | .io_pg_offst = (((u32) S3C24XX_VA_UART) >> 18) & 0xfffc, |
| 577 | .boot_params = S3C2410_SDRAM_PA + 0x100, | 585 | .boot_params = S3C2410_SDRAM_PA + 0x100, |
| 578 | .map_io = rx1950_map_io, | 586 | .map_io = rx1950_map_io, |
| 587 | .reserve = rx1950_reserve, | ||
| 579 | .init_irq = s3c24xx_init_irq, | 588 | .init_irq = s3c24xx_init_irq, |
| 580 | .init_machine = rx1950_init_machine, | 589 | .init_machine = rx1950_init_machine, |
| 581 | .timer = &s3c24xx_timer, | 590 | .timer = &s3c24xx_timer, |
diff --git a/arch/arm/mach-s3c2440/mach-rx3715.c b/arch/arm/mach-s3c2440/mach-rx3715.c index d2946de3f365..6bb44f75a9ce 100644 --- a/arch/arm/mach-s3c2440/mach-rx3715.c +++ b/arch/arm/mach-s3c2440/mach-rx3715.c | |||
| @@ -15,6 +15,7 @@ | |||
| 15 | #include <linux/types.h> | 15 | #include <linux/types.h> |
| 16 | #include <linux/interrupt.h> | 16 | #include <linux/interrupt.h> |
| 17 | #include <linux/list.h> | 17 | #include <linux/list.h> |
| 18 | #include <linux/memblock.h> | ||
| 18 | #include <linux/timer.h> | 19 | #include <linux/timer.h> |
| 19 | #include <linux/init.h> | 20 | #include <linux/init.h> |
| 20 | #include <linux/tty.h> | 21 | #include <linux/tty.h> |
| @@ -191,6 +192,13 @@ static void __init rx3715_map_io(void) | |||
| 191 | s3c24xx_init_uarts(rx3715_uartcfgs, ARRAY_SIZE(rx3715_uartcfgs)); | 192 | s3c24xx_init_uarts(rx3715_uartcfgs, ARRAY_SIZE(rx3715_uartcfgs)); |
| 192 | } | 193 | } |
| 193 | 194 | ||
| 195 | /* H1940 and RX3715 need to reserve this for suspend */ | ||
| 196 | static void __init rx3715_reserve(void) | ||
| 197 | { | ||
| 198 | memblock_reserve(0x30003000, 0x1000); | ||
| 199 | memblock_reserve(0x30081000, 0x1000); | ||
| 200 | } | ||
| 201 | |||
| 194 | static void __init rx3715_init_irq(void) | 202 | static void __init rx3715_init_irq(void) |
| 195 | { | 203 | { |
| 196 | s3c24xx_init_irq(); | 204 | s3c24xx_init_irq(); |
| @@ -214,6 +222,7 @@ MACHINE_START(RX3715, "IPAQ-RX3715") | |||
| 214 | .io_pg_offst = (((u32)S3C24XX_VA_UART) >> 18) & 0xfffc, | 222 | .io_pg_offst = (((u32)S3C24XX_VA_UART) >> 18) & 0xfffc, |
| 215 | .boot_params = S3C2410_SDRAM_PA + 0x100, | 223 | .boot_params = S3C2410_SDRAM_PA + 0x100, |
| 216 | .map_io = rx3715_map_io, | 224 | .map_io = rx3715_map_io, |
| 225 | .reserve = rx3715_reserve, | ||
| 217 | .init_irq = rx3715_init_irq, | 226 | .init_irq = rx3715_init_irq, |
| 218 | .init_machine = rx3715_init_machine, | 227 | .init_machine = rx3715_init_machine, |
| 219 | .timer = &s3c24xx_timer, | 228 | .timer = &s3c24xx_timer, |
diff --git a/arch/arm/mach-sa1100/generic.h b/arch/arm/mach-sa1100/generic.h index ec03f187c52b..b7a9a601c2d1 100644 --- a/arch/arm/mach-sa1100/generic.h +++ b/arch/arm/mach-sa1100/generic.h | |||
| @@ -13,8 +13,7 @@ extern void __init sa1100_init_gpio(void); | |||
| 13 | 13 | ||
| 14 | #define SET_BANK(__nr,__start,__size) \ | 14 | #define SET_BANK(__nr,__start,__size) \ |
| 15 | mi->bank[__nr].start = (__start), \ | 15 | mi->bank[__nr].start = (__start), \ |
| 16 | mi->bank[__nr].size = (__size), \ | 16 | mi->bank[__nr].size = (__size) |
| 17 | mi->bank[__nr].node = (((unsigned)(__start) - PHYS_OFFSET) >> 27) | ||
| 18 | 17 | ||
| 19 | extern void (*sa1100fb_backlight_power)(int on); | 18 | extern void (*sa1100fb_backlight_power)(int on); |
| 20 | extern void (*sa1100fb_lcd_power)(int on); | 19 | extern void (*sa1100fb_lcd_power)(int on); |
diff --git a/arch/arm/mach-sa1100/include/mach/memory.h b/arch/arm/mach-sa1100/include/mach/memory.h index d5277f9bee77..128a1dfa96b9 100644 --- a/arch/arm/mach-sa1100/include/mach/memory.h +++ b/arch/arm/mach-sa1100/include/mach/memory.h | |||
| @@ -17,10 +17,10 @@ | |||
| 17 | #ifndef __ASSEMBLY__ | 17 | #ifndef __ASSEMBLY__ |
| 18 | 18 | ||
| 19 | #ifdef CONFIG_SA1111 | 19 | #ifdef CONFIG_SA1111 |
| 20 | void sa1111_adjust_zones(int node, unsigned long *size, unsigned long *holes); | 20 | void sa1111_adjust_zones(unsigned long *size, unsigned long *holes); |
| 21 | 21 | ||
| 22 | #define arch_adjust_zones(node, size, holes) \ | 22 | #define arch_adjust_zones(size, holes) \ |
| 23 | sa1111_adjust_zones(node, size, holes) | 23 | sa1111_adjust_zones(size, holes) |
| 24 | 24 | ||
| 25 | #define ISA_DMA_THRESHOLD (PHYS_OFFSET + SZ_1M - 1) | 25 | #define ISA_DMA_THRESHOLD (PHYS_OFFSET + SZ_1M - 1) |
| 26 | #define MAX_DMA_ADDRESS (PAGE_OFFSET + SZ_1M) | 26 | #define MAX_DMA_ADDRESS (PAGE_OFFSET + SZ_1M) |
diff --git a/arch/arm/mach-shark/include/mach/debug-macro.S b/arch/arm/mach-shark/include/mach/debug-macro.S index 50f071c5bf4d..5ea24d4d1ba6 100644 --- a/arch/arm/mach-shark/include/mach/debug-macro.S +++ b/arch/arm/mach-shark/include/mach/debug-macro.S | |||
| @@ -20,6 +20,9 @@ | |||
| 20 | strb \rd, [\rx] | 20 | strb \rd, [\rx] |
| 21 | .endm | 21 | .endm |
| 22 | 22 | ||
| 23 | .macro waituart,rd,rx | ||
| 24 | .endm | ||
| 25 | |||
| 23 | .macro busyuart,rd,rx | 26 | .macro busyuart,rd,rx |
| 24 | mov \rd, #0 | 27 | mov \rd, #0 |
| 25 | 1001: add \rd, \rd, #1 | 28 | 1001: add \rd, \rd, #1 |
diff --git a/arch/arm/mach-shark/include/mach/memory.h b/arch/arm/mach-shark/include/mach/memory.h index 3053e5b7f168..d9c4812f1c31 100644 --- a/arch/arm/mach-shark/include/mach/memory.h +++ b/arch/arm/mach-shark/include/mach/memory.h | |||
| @@ -19,9 +19,8 @@ | |||
| 19 | 19 | ||
| 20 | #ifndef __ASSEMBLY__ | 20 | #ifndef __ASSEMBLY__ |
| 21 | 21 | ||
| 22 | static inline void __arch_adjust_zones(int node, unsigned long *zone_size, unsigned long *zhole_size) | 22 | static inline void __arch_adjust_zones(unsigned long *zone_size, unsigned long *zhole_size) |
| 23 | { | 23 | { |
| 24 | if (node != 0) return; | ||
| 25 | /* Only the first 4 MB (=1024 Pages) are usable for DMA */ | 24 | /* Only the first 4 MB (=1024 Pages) are usable for DMA */ |
| 26 | /* See dev / -> .properties in OpenFirmware. */ | 25 | /* See dev / -> .properties in OpenFirmware. */ |
| 27 | zone_size[1] = zone_size[0] - 1024; | 26 | zone_size[1] = zone_size[0] - 1024; |
| @@ -30,8 +29,8 @@ static inline void __arch_adjust_zones(int node, unsigned long *zone_size, unsig | |||
| 30 | zhole_size[0] = 0; | 29 | zhole_size[0] = 0; |
| 31 | } | 30 | } |
| 32 | 31 | ||
| 33 | #define arch_adjust_zones(node, size, holes) \ | 32 | #define arch_adjust_zones(size, holes) \ |
| 34 | __arch_adjust_zones(node, size, holes) | 33 | __arch_adjust_zones(size, holes) |
| 35 | 34 | ||
| 36 | #define ISA_DMA_THRESHOLD (PHYS_OFFSET + SZ_4M - 1) | 35 | #define ISA_DMA_THRESHOLD (PHYS_OFFSET + SZ_4M - 1) |
| 37 | #define MAX_DMA_ADDRESS (PAGE_OFFSET + SZ_4M) | 36 | #define MAX_DMA_ADDRESS (PAGE_OFFSET + SZ_4M) |
diff --git a/arch/arm/mach-shmobile/Kconfig b/arch/arm/mach-shmobile/Kconfig index f2b88c5fe142..4c704b4e8b34 100644 --- a/arch/arm/mach-shmobile/Kconfig +++ b/arch/arm/mach-shmobile/Kconfig | |||
| @@ -70,6 +70,18 @@ endmenu | |||
| 70 | 70 | ||
| 71 | menu "Timer and clock configuration" | 71 | menu "Timer and clock configuration" |
| 72 | 72 | ||
| 73 | config SHMOBILE_TIMER_HZ | ||
| 74 | int "Kernel HZ (jiffies per second)" | ||
| 75 | range 32 1024 | ||
| 76 | default "128" | ||
| 77 | help | ||
| 78 | Allows the configuration of the timer frequency. It is customary | ||
| 79 | to have the timer interrupt run at 1000 Hz or 100 Hz, but in the | ||
| 80 | case of low timer frequencies other values may be more suitable. | ||
| 81 | SH-Mobile systems using a 32768 Hz RCLK for clock events may want | ||
| 82 | to select a HZ value such as 128 that can evenly divide RCLK. | ||
| 83 | A HZ value that does not divide evenly may cause timer drift. | ||
| 84 | |||
| 73 | config SH_TIMER_CMT | 85 | config SH_TIMER_CMT |
| 74 | bool "CMT timer driver" | 86 | bool "CMT timer driver" |
| 75 | default y | 87 | default y |
diff --git a/arch/arm/mach-shmobile/include/mach/irqs.h b/arch/arm/mach-shmobile/include/mach/irqs.h index 5179b72e1ee3..132256bb8c81 100644 --- a/arch/arm/mach-shmobile/include/mach/irqs.h +++ b/arch/arm/mach-shmobile/include/mach/irqs.h | |||
| @@ -2,7 +2,6 @@ | |||
| 2 | #define __ASM_MACH_IRQS_H | 2 | #define __ASM_MACH_IRQS_H |
| 3 | 3 | ||
| 4 | #define NR_IRQS 512 | 4 | #define NR_IRQS 512 |
| 5 | #define NR_IRQS_LEGACY 8 | ||
| 6 | 5 | ||
| 7 | #define evt2irq(evt) (((evt) >> 5) - 16) | 6 | #define evt2irq(evt) (((evt) >> 5) - 16) |
| 8 | #define irq2evt(irq) (((irq) + 16) << 5) | 7 | #define irq2evt(irq) (((irq) + 16) << 5) |
diff --git a/arch/arm/mach-spear3xx/clock.c b/arch/arm/mach-spear3xx/clock.c index 39f6ccf22294..18febf92f20a 100644 --- a/arch/arm/mach-spear3xx/clock.c +++ b/arch/arm/mach-spear3xx/clock.c | |||
| @@ -341,8 +341,11 @@ static struct clk gpio_clk = { | |||
| 341 | .recalc = &follow_parent, | 341 | .recalc = &follow_parent, |
| 342 | }; | 342 | }; |
| 343 | 343 | ||
| 344 | static struct clk dummy_apb_pclk; | ||
| 345 | |||
| 344 | /* array of all spear 3xx clock lookups */ | 346 | /* array of all spear 3xx clock lookups */ |
| 345 | static struct clk_lookup spear_clk_lookups[] = { | 347 | static struct clk_lookup spear_clk_lookups[] = { |
| 348 | { .con_id = "apb_pclk", .clk = &dummy_apb_pclk}, | ||
| 346 | /* root clks */ | 349 | /* root clks */ |
| 347 | { .con_id = "osc_32k_clk", .clk = &osc_32k_clk}, | 350 | { .con_id = "osc_32k_clk", .clk = &osc_32k_clk}, |
| 348 | { .con_id = "osc_24m_clk", .clk = &osc_24m_clk}, | 351 | { .con_id = "osc_24m_clk", .clk = &osc_24m_clk}, |
diff --git a/arch/arm/mach-spear6xx/clock.c b/arch/arm/mach-spear6xx/clock.c index 13e27c769685..36ff056b7321 100644 --- a/arch/arm/mach-spear6xx/clock.c +++ b/arch/arm/mach-spear6xx/clock.c | |||
| @@ -428,8 +428,11 @@ static struct clk gpio2_clk = { | |||
| 428 | .recalc = &follow_parent, | 428 | .recalc = &follow_parent, |
| 429 | }; | 429 | }; |
| 430 | 430 | ||
| 431 | static struct clk dummy_apb_pclk; | ||
| 432 | |||
| 431 | /* array of all spear 6xx clock lookups */ | 433 | /* array of all spear 6xx clock lookups */ |
| 432 | static struct clk_lookup spear_clk_lookups[] = { | 434 | static struct clk_lookup spear_clk_lookups[] = { |
| 435 | { .con_id = "apb_pclk", .clk = &dummy_apb_pclk}, | ||
| 433 | /* root clks */ | 436 | /* root clks */ |
| 434 | { .con_id = "osc_32k_clk", .clk = &osc_32k_clk}, | 437 | { .con_id = "osc_32k_clk", .clk = &osc_32k_clk}, |
| 435 | { .con_id = "osc_30m_clk", .clk = &osc_30m_clk}, | 438 | { .con_id = "osc_30m_clk", .clk = &osc_30m_clk}, |
diff --git a/arch/arm/mach-u300/clock.c b/arch/arm/mach-u300/clock.c index 5af71d5ba665..5d12d547789e 100644 --- a/arch/arm/mach-u300/clock.c +++ b/arch/arm/mach-u300/clock.c | |||
| @@ -1212,6 +1212,8 @@ static struct clk ppm_clk = { | |||
| 1212 | }; | 1212 | }; |
| 1213 | #endif | 1213 | #endif |
| 1214 | 1214 | ||
| 1215 | static struct clk dummy_apb_pclk; | ||
| 1216 | |||
| 1215 | #define DEF_LOOKUP(devid, clkref) \ | 1217 | #define DEF_LOOKUP(devid, clkref) \ |
| 1216 | { \ | 1218 | { \ |
| 1217 | .dev_id = devid, \ | 1219 | .dev_id = devid, \ |
| @@ -1223,6 +1225,10 @@ static struct clk ppm_clk = { | |||
| 1223 | * look up through clockdevice. | 1225 | * look up through clockdevice. |
| 1224 | */ | 1226 | */ |
| 1225 | static struct clk_lookup lookups[] = { | 1227 | static struct clk_lookup lookups[] = { |
| 1228 | { | ||
| 1229 | .con_id = "apb_pclk", | ||
| 1230 | .clk = &dummy_apb_pclk, | ||
| 1231 | }, | ||
| 1226 | /* Connected directly to the AMBA bus */ | 1232 | /* Connected directly to the AMBA bus */ |
| 1227 | DEF_LOOKUP("amba", &amba_clk), | 1233 | DEF_LOOKUP("amba", &amba_clk), |
| 1228 | DEF_LOOKUP("cpu", &cpu_clk), | 1234 | DEF_LOOKUP("cpu", &cpu_clk), |
diff --git a/arch/arm/mach-u300/u300.c b/arch/arm/mach-u300/u300.c index d2a0b8847a18..bfcda9820888 100644 --- a/arch/arm/mach-u300/u300.c +++ b/arch/arm/mach-u300/u300.c | |||
| @@ -14,6 +14,7 @@ | |||
| 14 | #include <linux/sched.h> | 14 | #include <linux/sched.h> |
| 15 | #include <linux/interrupt.h> | 15 | #include <linux/interrupt.h> |
| 16 | #include <linux/ioport.h> | 16 | #include <linux/ioport.h> |
| 17 | #include <linux/memblock.h> | ||
| 17 | #include <linux/platform_device.h> | 18 | #include <linux/platform_device.h> |
| 18 | #include <linux/io.h> | 19 | #include <linux/io.h> |
| 19 | #include <mach/hardware.h> | 20 | #include <mach/hardware.h> |
| @@ -22,6 +23,21 @@ | |||
| 22 | #include <asm/mach-types.h> | 23 | #include <asm/mach-types.h> |
| 23 | #include <asm/mach/arch.h> | 24 | #include <asm/mach/arch.h> |
| 24 | 25 | ||
| 26 | static void __init u300_reserve(void) | ||
| 27 | { | ||
| 28 | /* | ||
| 29 | * U300 - This platform family can share physical memory | ||
| 30 | * between two ARM cpus, one running Linux and the other | ||
| 31 | * running another OS. | ||
| 32 | */ | ||
| 33 | #ifdef CONFIG_MACH_U300_SINGLE_RAM | ||
| 34 | #if ((CONFIG_MACH_U300_ACCESS_MEM_SIZE & 1) == 1) && \ | ||
| 35 | CONFIG_MACH_U300_2MB_ALIGNMENT_FIX | ||
| 36 | memblock_reserve(PHYS_OFFSET, 0x00100000); | ||
| 37 | #endif | ||
| 38 | #endif | ||
| 39 | } | ||
| 40 | |||
| 25 | static void __init u300_init_machine(void) | 41 | static void __init u300_init_machine(void) |
| 26 | { | 42 | { |
| 27 | u300_init_devices(); | 43 | u300_init_devices(); |
| @@ -49,6 +65,7 @@ MACHINE_START(U300, MACH_U300_STRING) | |||
| 49 | .io_pg_offst = ((U300_AHB_PER_VIRT_BASE) >> 18) & 0xfffc, | 65 | .io_pg_offst = ((U300_AHB_PER_VIRT_BASE) >> 18) & 0xfffc, |
| 50 | .boot_params = BOOT_PARAMS_OFFSET, | 66 | .boot_params = BOOT_PARAMS_OFFSET, |
| 51 | .map_io = u300_map_io, | 67 | .map_io = u300_map_io, |
| 68 | .reserve = u300_reserve, | ||
| 52 | .init_irq = u300_init_irq, | 69 | .init_irq = u300_init_irq, |
| 53 | .timer = &u300_timer, | 70 | .timer = &u300_timer, |
| 54 | .init_machine = u300_init_machine, | 71 | .init_machine = u300_init_machine, |
diff --git a/arch/arm/mach-ux500/board-mop500.c b/arch/arm/mach-ux500/board-mop500.c index bb8d7b771817..0e8fd135a57d 100644 --- a/arch/arm/mach-ux500/board-mop500.c +++ b/arch/arm/mach-ux500/board-mop500.c | |||
| @@ -13,19 +13,42 @@ | |||
| 13 | #include <linux/interrupt.h> | 13 | #include <linux/interrupt.h> |
| 14 | #include <linux/platform_device.h> | 14 | #include <linux/platform_device.h> |
| 15 | #include <linux/io.h> | 15 | #include <linux/io.h> |
| 16 | #include <linux/gpio.h> | ||
| 16 | #include <linux/amba/bus.h> | 17 | #include <linux/amba/bus.h> |
| 17 | #include <linux/amba/pl022.h> | 18 | #include <linux/amba/pl022.h> |
| 18 | #include <linux/spi/spi.h> | 19 | #include <linux/spi/spi.h> |
| 20 | #include <linux/mfd/ab8500.h> | ||
| 19 | 21 | ||
| 20 | #include <asm/mach-types.h> | 22 | #include <asm/mach-types.h> |
| 21 | #include <asm/mach/arch.h> | 23 | #include <asm/mach/arch.h> |
| 22 | 24 | ||
| 25 | #include <plat/pincfg.h> | ||
| 23 | #include <plat/i2c.h> | 26 | #include <plat/i2c.h> |
| 24 | 27 | ||
| 25 | #include <mach/hardware.h> | 28 | #include <mach/hardware.h> |
| 26 | #include <mach/setup.h> | 29 | #include <mach/setup.h> |
| 27 | #include <mach/devices.h> | 30 | #include <mach/devices.h> |
| 28 | 31 | ||
| 32 | #include "pins-db8500.h" | ||
| 33 | |||
| 34 | static pin_cfg_t mop500_pins[] = { | ||
| 35 | /* SSP0 */ | ||
| 36 | GPIO143_SSP0_CLK, | ||
| 37 | GPIO144_SSP0_FRM, | ||
| 38 | GPIO145_SSP0_RXD, | ||
| 39 | GPIO146_SSP0_TXD, | ||
| 40 | |||
| 41 | /* I2C */ | ||
| 42 | GPIO147_I2C0_SCL, | ||
| 43 | GPIO148_I2C0_SDA, | ||
| 44 | GPIO16_I2C1_SCL, | ||
| 45 | GPIO17_I2C1_SDA, | ||
| 46 | GPIO10_I2C2_SDA, | ||
| 47 | GPIO11_I2C2_SCL, | ||
| 48 | GPIO229_I2C3_SDA, | ||
| 49 | GPIO230_I2C3_SCL, | ||
| 50 | }; | ||
| 51 | |||
| 29 | static void ab4500_spi_cs_control(u32 command) | 52 | static void ab4500_spi_cs_control(u32 command) |
| 30 | { | 53 | { |
| 31 | /* set the FRM signal, which is CS - TODO */ | 54 | /* set the FRM signal, which is CS - TODO */ |
| @@ -48,15 +71,20 @@ struct pl022_config_chip ab4500_chip_info = { | |||
| 48 | .cs_control = ab4500_spi_cs_control, | 71 | .cs_control = ab4500_spi_cs_control, |
| 49 | }; | 72 | }; |
| 50 | 73 | ||
| 74 | static struct ab8500_platform_data ab8500_platdata = { | ||
| 75 | .irq_base = MOP500_AB8500_IRQ_BASE, | ||
| 76 | }; | ||
| 77 | |||
| 51 | static struct spi_board_info u8500_spi_devices[] = { | 78 | static struct spi_board_info u8500_spi_devices[] = { |
| 52 | { | 79 | { |
| 53 | .modalias = "ab8500", | 80 | .modalias = "ab8500", |
| 54 | .controller_data = &ab4500_chip_info, | 81 | .controller_data = &ab4500_chip_info, |
| 82 | .platform_data = &ab8500_platdata, | ||
| 55 | .max_speed_hz = 12000000, | 83 | .max_speed_hz = 12000000, |
| 56 | .bus_num = 0, | 84 | .bus_num = 0, |
| 57 | .chip_select = 0, | 85 | .chip_select = 0, |
| 58 | .mode = SPI_MODE_0, | 86 | .mode = SPI_MODE_0, |
| 59 | .irq = IRQ_AB4500, | 87 | .irq = IRQ_DB8500_AB8500, |
| 60 | }, | 88 | }, |
| 61 | }; | 89 | }; |
| 62 | 90 | ||
| @@ -118,6 +146,10 @@ static void __init u8500_init_machine(void) | |||
| 118 | { | 146 | { |
| 119 | int i; | 147 | int i; |
| 120 | 148 | ||
| 149 | u8500_init_devices(); | ||
| 150 | |||
| 151 | nmk_config_pins(mop500_pins, ARRAY_SIZE(mop500_pins)); | ||
| 152 | |||
| 121 | u8500_i2c0_device.dev.platform_data = &u8500_i2c0_data; | 153 | u8500_i2c0_device.dev.platform_data = &u8500_i2c0_data; |
| 122 | ux500_i2c1_device.dev.platform_data = &u8500_i2c1_data; | 154 | ux500_i2c1_device.dev.platform_data = &u8500_i2c1_data; |
| 123 | ux500_i2c2_device.dev.platform_data = &u8500_i2c2_data; | 155 | ux500_i2c2_device.dev.platform_data = &u8500_i2c2_data; |
| @@ -133,8 +165,6 @@ static void __init u8500_init_machine(void) | |||
| 133 | 165 | ||
| 134 | spi_register_board_info(u8500_spi_devices, | 166 | spi_register_board_info(u8500_spi_devices, |
| 135 | ARRAY_SIZE(u8500_spi_devices)); | 167 | ARRAY_SIZE(u8500_spi_devices)); |
| 136 | |||
| 137 | u8500_init_devices(); | ||
| 138 | } | 168 | } |
| 139 | 169 | ||
| 140 | MACHINE_START(U8500, "ST-Ericsson MOP500 platform") | 170 | MACHINE_START(U8500, "ST-Ericsson MOP500 platform") |
diff --git a/arch/arm/mach-ux500/clock.c b/arch/arm/mach-ux500/clock.c index 0a1318fc8e2b..d8ab7f184fe4 100644 --- a/arch/arm/mach-ux500/clock.c +++ b/arch/arm/mach-ux500/clock.c | |||
| @@ -453,7 +453,11 @@ static DEFINE_PRCC_CLK_CUSTOM(7, mtu0_ed, 2, -1, NULL, clk_mtu_get_rate, 0); | |||
| 453 | static DEFINE_PRCC_CLK(7, wdg_ed, 1, -1, NULL); | 453 | static DEFINE_PRCC_CLK(7, wdg_ed, 1, -1, NULL); |
| 454 | static DEFINE_PRCC_CLK(7, cfgreg_ed, 0, -1, NULL); | 454 | static DEFINE_PRCC_CLK(7, cfgreg_ed, 0, -1, NULL); |
| 455 | 455 | ||
| 456 | static struct clk clk_dummy_apb_pclk; | ||
| 457 | |||
| 456 | static struct clk_lookup u8500_common_clks[] = { | 458 | static struct clk_lookup u8500_common_clks[] = { |
| 459 | CLK(dummy_apb_pclk, NULL, "apb_pclk"), | ||
| 460 | |||
| 457 | /* Peripheral Cluster #1 */ | 461 | /* Peripheral Cluster #1 */ |
| 458 | CLK(gpio0, "gpio.0", NULL), | 462 | CLK(gpio0, "gpio.0", NULL), |
| 459 | CLK(gpio0, "gpio.1", NULL), | 463 | CLK(gpio0, "gpio.1", NULL), |
diff --git a/arch/arm/mach-ux500/devices-db8500.c b/arch/arm/mach-ux500/devices-db8500.c index 822903421943..654fca944e65 100644 --- a/arch/arm/mach-ux500/devices-db8500.c +++ b/arch/arm/mach-ux500/devices-db8500.c | |||
| @@ -65,7 +65,7 @@ struct amba_device u8500_ssp0_device = { | |||
| 65 | .end = U8500_SSP0_BASE + SZ_4K - 1, | 65 | .end = U8500_SSP0_BASE + SZ_4K - 1, |
| 66 | .flags = IORESOURCE_MEM, | 66 | .flags = IORESOURCE_MEM, |
| 67 | }, | 67 | }, |
| 68 | .irq = {IRQ_SSP0, NO_IRQ }, | 68 | .irq = {IRQ_DB8500_SSP0, NO_IRQ }, |
| 69 | /* ST-Ericsson modified id */ | 69 | /* ST-Ericsson modified id */ |
| 70 | .periphid = SSP_PER_ID, | 70 | .periphid = SSP_PER_ID, |
| 71 | }; | 71 | }; |
| @@ -77,8 +77,8 @@ static struct resource u8500_i2c0_resources[] = { | |||
| 77 | .flags = IORESOURCE_MEM, | 77 | .flags = IORESOURCE_MEM, |
| 78 | }, | 78 | }, |
| 79 | [1] = { | 79 | [1] = { |
| 80 | .start = IRQ_I2C0, | 80 | .start = IRQ_DB8500_I2C0, |
| 81 | .end = IRQ_I2C0, | 81 | .end = IRQ_DB8500_I2C0, |
| 82 | .flags = IORESOURCE_IRQ, | 82 | .flags = IORESOURCE_IRQ, |
| 83 | } | 83 | } |
| 84 | }; | 84 | }; |
| @@ -97,8 +97,8 @@ static struct resource u8500_i2c4_resources[] = { | |||
| 97 | .flags = IORESOURCE_MEM, | 97 | .flags = IORESOURCE_MEM, |
| 98 | }, | 98 | }, |
| 99 | [1] = { | 99 | [1] = { |
| 100 | .start = IRQ_I2C4, | 100 | .start = IRQ_DB8500_I2C4, |
| 101 | .end = IRQ_I2C4, | 101 | .end = IRQ_DB8500_I2C4, |
| 102 | .flags = IORESOURCE_IRQ, | 102 | .flags = IORESOURCE_IRQ, |
| 103 | } | 103 | } |
| 104 | }; | 104 | }; |
| @@ -130,8 +130,8 @@ static struct resource dma40_resources[] = { | |||
| 130 | .name = "lcla", | 130 | .name = "lcla", |
| 131 | }, | 131 | }, |
| 132 | [3] = { | 132 | [3] = { |
| 133 | .start = IRQ_DMA, | 133 | .start = IRQ_DB8500_DMA, |
| 134 | .end = IRQ_DMA, | 134 | .end = IRQ_DB8500_DMA, |
| 135 | .flags = IORESOURCE_IRQ} | 135 | .flags = IORESOURCE_IRQ} |
| 136 | }; | 136 | }; |
| 137 | 137 | ||
diff --git a/arch/arm/mach-ux500/include/mach/irqs-board-mop500.h b/arch/arm/mach-ux500/include/mach/irqs-board-mop500.h new file mode 100644 index 000000000000..cca4f705601e --- /dev/null +++ b/arch/arm/mach-ux500/include/mach/irqs-board-mop500.h | |||
| @@ -0,0 +1,23 @@ | |||
| 1 | /* | ||
| 2 | * Copyright (C) ST-Ericsson SA 2010 | ||
| 3 | * | ||
| 4 | * Author: Rabin Vincent <rabin.vincent@stericsson.com> | ||
| 5 | * License terms: GNU General Public License (GPL) version 2 | ||
| 6 | */ | ||
| 7 | |||
| 8 | #ifndef __MACH_IRQS_BOARD_MOP500_H | ||
| 9 | #define __MACH_IRQS_BOARD_MOP500_H | ||
| 10 | |||
| 11 | #define AB8500_NR_IRQS 104 | ||
| 12 | |||
| 13 | #define MOP500_AB8500_IRQ_BASE IRQ_BOARD_START | ||
| 14 | #define MOP500_AB8500_IRQ_END (MOP500_AB8500_IRQ_BASE \ | ||
| 15 | + AB8500_NR_IRQS) | ||
| 16 | #define MOP500_IRQ_END MOP500_AB8500_IRQ_END | ||
| 17 | |||
| 18 | #if MOP500_IRQ_END > IRQ_BOARD_END | ||
| 19 | #undef IRQ_BOARD_END | ||
| 20 | #define IRQ_BOARD_END MOP500_IRQ_END | ||
| 21 | #endif | ||
| 22 | |||
| 23 | #endif | ||
diff --git a/arch/arm/mach-ux500/include/mach/irqs-db5500.h b/arch/arm/mach-ux500/include/mach/irqs-db5500.h new file mode 100644 index 000000000000..6fbfe5e2065a --- /dev/null +++ b/arch/arm/mach-ux500/include/mach/irqs-db5500.h | |||
| @@ -0,0 +1,85 @@ | |||
| 1 | /* | ||
| 2 | * Copyright (C) ST-Ericsson SA 2010 | ||
| 3 | * | ||
| 4 | * Author: Rabin Vincent <rabin.vincent@stericsson.com> | ||
| 5 | * License terms: GNU General Public License (GPL) version 2 | ||
| 6 | */ | ||
| 7 | |||
| 8 | #ifndef __MACH_IRQS_DB5500_H | ||
| 9 | #define __MACH_IRQS_DB5500_H | ||
| 10 | |||
| 11 | #define IRQ_DB5500_MTU0 (IRQ_SHPI_START + 4) | ||
| 12 | #define IRQ_DB5500_SPI2 (IRQ_SHPI_START + 6) | ||
| 13 | #define IRQ_DB5500_PMU0 (IRQ_SHPI_START + 7) | ||
| 14 | #define IRQ_DB5500_SPI0 (IRQ_SHPI_START + 8) | ||
| 15 | #define IRQ_DB5500_RTT (IRQ_SHPI_START + 9) | ||
| 16 | #define IRQ_DB5500_PKA (IRQ_SHPI_START + 10) | ||
| 17 | #define IRQ_DB5500_UART0 (IRQ_SHPI_START + 11) | ||
| 18 | #define IRQ_DB5500_I2C3 (IRQ_SHPI_START + 12) | ||
| 19 | #define IRQ_DB5500_L2CC (IRQ_SHPI_START + 13) | ||
| 20 | #define IRQ_DB5500_MSP0 (IRQ_SHPI_START + 14) | ||
| 21 | #define IRQ_DB5500_CRYP1 (IRQ_SHPI_START + 15) | ||
| 22 | #define IRQ_DB5500_PMU1 (IRQ_SHPI_START + 16) | ||
| 23 | #define IRQ_DB5500_MTU1 (IRQ_SHPI_START + 17) | ||
| 24 | #define IRQ_DB5500_RTC (IRQ_SHPI_START + 18) | ||
| 25 | #define IRQ_DB5500_UART1 (IRQ_SHPI_START + 19) | ||
| 26 | #define IRQ_DB5500_USB_WAKEUP (IRQ_SHPI_START + 20) | ||
| 27 | #define IRQ_DB5500_I2C0 (IRQ_SHPI_START + 21) | ||
| 28 | #define IRQ_DB5500_I2C1 (IRQ_SHPI_START + 22) | ||
| 29 | #define IRQ_DB5500_USBOTG (IRQ_SHPI_START + 23) | ||
| 30 | #define IRQ_DB5500_DMA_SECURE (IRQ_SHPI_START + 24) | ||
| 31 | #define IRQ_DB5500_DMA (IRQ_SHPI_START + 25) | ||
| 32 | #define IRQ_DB5500_UART2 (IRQ_SHPI_START + 26) | ||
| 33 | #define IRQ_DB5500_ICN_PMU1 (IRQ_SHPI_START + 27) | ||
| 34 | #define IRQ_DB5500_ICN_PMU2 (IRQ_SHPI_START + 28) | ||
| 35 | #define IRQ_DB5500_UART3 (IRQ_SHPI_START + 29) | ||
| 36 | #define IRQ_DB5500_SPI3 (IRQ_SHPI_START + 30) | ||
| 37 | #define IRQ_DB5500_SDMMC4 (IRQ_SHPI_START + 31) | ||
| 38 | #define IRQ_DB5500_IRRC (IRQ_SHPI_START + 33) | ||
| 39 | #define IRQ_DB5500_IRDA_FT (IRQ_SHPI_START + 34) | ||
| 40 | #define IRQ_DB5500_IRDA_SD (IRQ_SHPI_START + 35) | ||
| 41 | #define IRQ_DB5500_IRDA_FI (IRQ_SHPI_START + 36) | ||
| 42 | #define IRQ_DB5500_IRDA_FD (IRQ_SHPI_START + 37) | ||
| 43 | #define IRQ_DB5500_FSMC_CODEREADY (IRQ_SHPI_START + 38) | ||
| 44 | #define IRQ_DB5500_FSMC_NANDWAIT (IRQ_SHPI_START + 39) | ||
| 45 | #define IRQ_DB5500_AB5500 (IRQ_SHPI_START + 40) | ||
| 46 | #define IRQ_DB5500_SDMMC2 (IRQ_SHPI_START + 41) | ||
| 47 | #define IRQ_DB5500_SIA (IRQ_SHPI_START + 42) | ||
| 48 | #define IRQ_DB5500_SIA2 (IRQ_SHPI_START + 43) | ||
| 49 | #define IRQ_DB5500_HVA (IRQ_SHPI_START + 44) | ||
| 50 | #define IRQ_DB5500_HVA2 (IRQ_SHPI_START + 45) | ||
| 51 | #define IRQ_DB5500_PRCMU0 (IRQ_SHPI_START + 46) | ||
| 52 | #define IRQ_DB5500_PRCMU1 (IRQ_SHPI_START + 47) | ||
| 53 | #define IRQ_DB5500_DISP (IRQ_SHPI_START + 48) | ||
| 54 | #define IRQ_DB5500_SDMMC1 (IRQ_SHPI_START + 50) | ||
| 55 | #define IRQ_DB5500_MSP1 (IRQ_SHPI_START + 52) | ||
| 56 | #define IRQ_DB5500_KBD (IRQ_SHPI_START + 53) | ||
| 57 | #define IRQ_DB5500_I2C2 (IRQ_SHPI_START + 55) | ||
| 58 | #define IRQ_DB5500_B2R2 (IRQ_SHPI_START + 56) | ||
| 59 | #define IRQ_DB5500_CRYP0 (IRQ_SHPI_START + 57) | ||
| 60 | #define IRQ_DB5500_SDMMC3 (IRQ_SHPI_START + 59) | ||
| 61 | #define IRQ_DB5500_SDMMC0 (IRQ_SHPI_START + 60) | ||
| 62 | #define IRQ_DB5500_HSEM (IRQ_SHPI_START + 61) | ||
| 63 | #define IRQ_DB5500_SBAG (IRQ_SHPI_START + 63) | ||
| 64 | #define IRQ_DB5500_SPI1 (IRQ_SHPI_START + 96) | ||
| 65 | #define IRQ_DB5500_MSP2 (IRQ_SHPI_START + 98) | ||
| 66 | #define IRQ_DB5500_SRPTIMER (IRQ_SHPI_START + 101) | ||
| 67 | #define IRQ_DB5500_CTI0 (IRQ_SHPI_START + 108) | ||
| 68 | #define IRQ_DB5500_CTI1 (IRQ_SHPI_START + 109) | ||
| 69 | #define IRQ_DB5500_ICN_ERR (IRQ_SHPI_START + 110) | ||
| 70 | #define IRQ_DB5500_MALI_PPMMU (IRQ_SHPI_START + 112) | ||
| 71 | #define IRQ_DB5500_MALI_PP (IRQ_SHPI_START + 113) | ||
| 72 | #define IRQ_DB5500_MALI_GPMMU (IRQ_SHPI_START + 114) | ||
| 73 | #define IRQ_DB5500_MALI_GP (IRQ_SHPI_START + 115) | ||
| 74 | #define IRQ_DB5500_MALI (IRQ_SHPI_START + 116) | ||
| 75 | #define IRQ_DB5500_PRCMU_SEM (IRQ_SHPI_START + 118) | ||
| 76 | #define IRQ_DB5500_GPIO0 (IRQ_SHPI_START + 119) | ||
| 77 | #define IRQ_DB5500_GPIO1 (IRQ_SHPI_START + 120) | ||
| 78 | #define IRQ_DB5500_GPIO2 (IRQ_SHPI_START + 121) | ||
| 79 | #define IRQ_DB5500_GPIO3 (IRQ_SHPI_START + 122) | ||
| 80 | #define IRQ_DB5500_GPIO4 (IRQ_SHPI_START + 123) | ||
| 81 | #define IRQ_DB5500_GPIO5 (IRQ_SHPI_START + 124) | ||
| 82 | #define IRQ_DB5500_GPIO6 (IRQ_SHPI_START + 125) | ||
| 83 | #define IRQ_DB5500_GPIO7 (IRQ_SHPI_START + 126) | ||
| 84 | |||
| 85 | #endif | ||
diff --git a/arch/arm/mach-ux500/include/mach/irqs-db8500.h b/arch/arm/mach-ux500/include/mach/irqs-db8500.h new file mode 100644 index 000000000000..8b5d9f0a1633 --- /dev/null +++ b/arch/arm/mach-ux500/include/mach/irqs-db8500.h | |||
| @@ -0,0 +1,96 @@ | |||
| 1 | /* | ||
| 2 | * Copyright (C) ST-Ericsson SA 2010 | ||
| 3 | * | ||
| 4 | * Author: Rabin Vincent <rabin.vincent@stericsson.com> | ||
| 5 | * License terms: GNU General Public License (GPL) version 2 | ||
| 6 | */ | ||
| 7 | |||
| 8 | #ifndef __MACH_IRQS_DB8500_H | ||
| 9 | #define __MACH_IRQS_DB8500_H | ||
| 10 | |||
| 11 | #define IRQ_DB8500_MTU0 (IRQ_SHPI_START + 4) | ||
| 12 | #define IRQ_DB8500_SPI2 (IRQ_SHPI_START + 6) | ||
| 13 | #define IRQ_DB8500_PMU (IRQ_SHPI_START + 7) | ||
| 14 | #define IRQ_DB8500_SPI0 (IRQ_SHPI_START + 8) | ||
| 15 | #define IRQ_DB8500_RTT (IRQ_SHPI_START + 9) | ||
| 16 | #define IRQ_DB8500_PKA (IRQ_SHPI_START + 10) | ||
| 17 | #define IRQ_DB8500_UART0 (IRQ_SHPI_START + 11) | ||
| 18 | #define IRQ_DB8500_I2C3 (IRQ_SHPI_START + 12) | ||
| 19 | #define IRQ_DB8500_L2CC (IRQ_SHPI_START + 13) | ||
| 20 | #define IRQ_DB8500_SSP0 (IRQ_SHPI_START + 14) | ||
| 21 | #define IRQ_DB8500_CRYP1 (IRQ_SHPI_START + 15) | ||
| 22 | #define IRQ_DB8500_MSP1_RX (IRQ_SHPI_START + 16) | ||
| 23 | #define IRQ_DB8500_MTU1 (IRQ_SHPI_START + 17) | ||
| 24 | #define IRQ_DB8500_RTC (IRQ_SHPI_START + 18) | ||
| 25 | #define IRQ_DB8500_UART1 (IRQ_SHPI_START + 19) | ||
| 26 | #define IRQ_DB8500_USB_WAKEUP (IRQ_SHPI_START + 20) | ||
| 27 | #define IRQ_DB8500_I2C0 (IRQ_SHPI_START + 21) | ||
| 28 | #define IRQ_DB8500_I2C1 (IRQ_SHPI_START + 22) | ||
| 29 | #define IRQ_DB8500_USBOTG (IRQ_SHPI_START + 23) | ||
| 30 | #define IRQ_DB8500_DMA_SECURE (IRQ_SHPI_START + 24) | ||
| 31 | #define IRQ_DB8500_DMA (IRQ_SHPI_START + 25) | ||
| 32 | #define IRQ_DB8500_UART2 (IRQ_SHPI_START + 26) | ||
| 33 | #define IRQ_DB8500_ICN_PMU1 (IRQ_SHPI_START + 27) | ||
| 34 | #define IRQ_DB8500_ICN_PMU2 (IRQ_SHPI_START + 28) | ||
| 35 | #define IRQ_DB8500_HSIR_EXCEP (IRQ_SHPI_START + 29) | ||
| 36 | #define IRQ_DB8500_MSP0 (IRQ_SHPI_START + 31) | ||
| 37 | #define IRQ_DB8500_HSIR_CH0_OVRRUN (IRQ_SHPI_START + 32) | ||
| 38 | #define IRQ_DB8500_HSIR_CH1_OVRRUN (IRQ_SHPI_START + 33) | ||
| 39 | #define IRQ_DB8500_HSIR_CH2_OVRRUN (IRQ_SHPI_START + 34) | ||
| 40 | #define IRQ_DB8500_HSIR_CH3_OVRRUN (IRQ_SHPI_START + 35) | ||
| 41 | #define IRQ_DB8500_HSIR_CH4_OVRRUN (IRQ_SHPI_START + 36) | ||
| 42 | #define IRQ_DB8500_HSIR_CH5_OVRRUN (IRQ_SHPI_START + 37) | ||
| 43 | #define IRQ_DB8500_HSIR_CH6_OVRRUN (IRQ_SHPI_START + 38) | ||
| 44 | #define IRQ_DB8500_HSIR_CH7_OVRRUN (IRQ_SHPI_START + 39) | ||
| 45 | #define IRQ_DB8500_AB8500 (IRQ_SHPI_START + 40) | ||
| 46 | #define IRQ_DB8500_SDMMC2 (IRQ_SHPI_START + 41) | ||
| 47 | #define IRQ_DB8500_SIA (IRQ_SHPI_START + 42) | ||
| 48 | #define IRQ_DB8500_SIA2 (IRQ_SHPI_START + 43) | ||
| 49 | #define IRQ_DB8500_SVA (IRQ_SHPI_START + 44) | ||
| 50 | #define IRQ_DB8500_SVA2 (IRQ_SHPI_START + 45) | ||
| 51 | #define IRQ_DB8500_PRCMU0 (IRQ_SHPI_START + 46) | ||
| 52 | #define IRQ_DB8500_PRCMU1 (IRQ_SHPI_START + 47) | ||
| 53 | #define IRQ_DB8500_DISP (IRQ_SHPI_START + 48) | ||
| 54 | #define IRQ_DB8500_SPI3 (IRQ_SHPI_START + 49) | ||
| 55 | #define IRQ_DB8500_SDMMC1 (IRQ_SHPI_START + 50) | ||
| 56 | #define IRQ_DB8500_I2C4 (IRQ_SHPI_START + 51) | ||
| 57 | #define IRQ_DB8500_SSP1 (IRQ_SHPI_START + 52) | ||
| 58 | #define IRQ_DB8500_SKE (IRQ_SHPI_START + 53) | ||
| 59 | #define IRQ_DB8500_KB (IRQ_SHPI_START + 54) | ||
| 60 | #define IRQ_DB8500_I2C2 (IRQ_SHPI_START + 55) | ||
| 61 | #define IRQ_DB8500_B2R2 (IRQ_SHPI_START + 56) | ||
| 62 | #define IRQ_DB8500_CRYP0 (IRQ_SHPI_START + 57) | ||
| 63 | #define IRQ_DB8500_SDMMC3 (IRQ_SHPI_START + 59) | ||
| 64 | #define IRQ_DB8500_SDMMC0 (IRQ_SHPI_START + 60) | ||
| 65 | #define IRQ_DB8500_HSEM (IRQ_SHPI_START + 61) | ||
| 66 | #define IRQ_DB8500_MSP1 (IRQ_SHPI_START + 62) | ||
| 67 | #define IRQ_DB8500_SBAG (IRQ_SHPI_START + 63) | ||
| 68 | #define IRQ_DB8500_SPI1 (IRQ_SHPI_START + 96) | ||
| 69 | #define IRQ_DB8500_SRPTIMER (IRQ_SHPI_START + 97) | ||
| 70 | #define IRQ_DB8500_MSP2 (IRQ_SHPI_START + 98) | ||
| 71 | #define IRQ_DB8500_SDMMC4 (IRQ_SHPI_START + 99) | ||
| 72 | #define IRQ_DB8500_SDMMC5 (IRQ_SHPI_START + 100) | ||
| 73 | #define IRQ_DB8500_HSIRD0 (IRQ_SHPI_START + 104) | ||
| 74 | #define IRQ_DB8500_HSIRD1 (IRQ_SHPI_START + 105) | ||
| 75 | #define IRQ_DB8500_HSITD0 (IRQ_SHPI_START + 106) | ||
| 76 | #define IRQ_DB8500_HSITD1 (IRQ_SHPI_START + 107) | ||
| 77 | #define IRQ_DB8500_CTI0 (IRQ_SHPI_START + 108) | ||
| 78 | #define IRQ_DB8500_CTI1 (IRQ_SHPI_START + 109) | ||
| 79 | #define IRQ_DB8500_ICN_ERR (IRQ_SHPI_START + 110) | ||
| 80 | #define IRQ_DB8500_MALI_PPMMU (IRQ_SHPI_START + 112) | ||
| 81 | #define IRQ_DB8500_MALI_PP (IRQ_SHPI_START + 113) | ||
| 82 | #define IRQ_DB8500_MALI_GPMMU (IRQ_SHPI_START + 114) | ||
| 83 | #define IRQ_DB8500_MALI_GP (IRQ_SHPI_START + 115) | ||
| 84 | #define IRQ_DB8500_MALI (IRQ_SHPI_START + 116) | ||
| 85 | #define IRQ_DB8500_PRCMU_SEM (IRQ_SHPI_START + 118) | ||
| 86 | #define IRQ_DB8500_GPIO0 (IRQ_SHPI_START + 119) | ||
| 87 | #define IRQ_DB8500_GPIO1 (IRQ_SHPI_START + 120) | ||
| 88 | #define IRQ_DB8500_GPIO2 (IRQ_SHPI_START + 121) | ||
| 89 | #define IRQ_DB8500_GPIO3 (IRQ_SHPI_START + 122) | ||
| 90 | #define IRQ_DB8500_GPIO4 (IRQ_SHPI_START + 123) | ||
| 91 | #define IRQ_DB8500_GPIO5 (IRQ_SHPI_START + 124) | ||
| 92 | #define IRQ_DB8500_GPIO6 (IRQ_SHPI_START + 125) | ||
| 93 | #define IRQ_DB8500_GPIO7 (IRQ_SHPI_START + 126) | ||
| 94 | #define IRQ_DB8500_GPIO8 (IRQ_SHPI_START + 127) | ||
| 95 | |||
| 96 | #endif | ||
diff --git a/arch/arm/mach-ux500/include/mach/irqs.h b/arch/arm/mach-ux500/include/mach/irqs.h index 7970684b1d09..10385bdc2b77 100644 --- a/arch/arm/mach-ux500/include/mach/irqs.h +++ b/arch/arm/mach-ux500/include/mach/irqs.h | |||
| @@ -10,7 +10,8 @@ | |||
| 10 | #ifndef ASM_ARCH_IRQS_H | 10 | #ifndef ASM_ARCH_IRQS_H |
| 11 | #define ASM_ARCH_IRQS_H | 11 | #define ASM_ARCH_IRQS_H |
| 12 | 12 | ||
| 13 | #include <mach/hardware.h> | 13 | #include <mach/irqs-db5500.h> |
| 14 | #include <mach/irqs-db8500.h> | ||
| 14 | 15 | ||
| 15 | #define IRQ_LOCALTIMER 29 | 16 | #define IRQ_LOCALTIMER 29 |
| 16 | #define IRQ_LOCALWDOG 30 | 17 | #define IRQ_LOCALWDOG 30 |
| @@ -67,12 +68,21 @@ | |||
| 67 | /* There are 128 shared peripheral interrupts assigned to | 68 | /* There are 128 shared peripheral interrupts assigned to |
| 68 | * INTID[160:32]. The first 32 interrupts are reserved. | 69 | * INTID[160:32]. The first 32 interrupts are reserved. |
| 69 | */ | 70 | */ |
| 70 | #define U8500_SOC_NR_IRQS 161 | 71 | #define DBX500_NR_INTERNAL_IRQS 161 |
| 71 | 72 | ||
| 72 | /* After chip-specific IRQ numbers we have the GPIO ones */ | 73 | /* After chip-specific IRQ numbers we have the GPIO ones */ |
| 73 | #define NOMADIK_NR_GPIO 288 | 74 | #define NOMADIK_NR_GPIO 288 |
| 74 | #define NOMADIK_GPIO_TO_IRQ(gpio) ((gpio) + U8500_SOC_NR_IRQS) | 75 | #define NOMADIK_GPIO_TO_IRQ(gpio) ((gpio) + DBX500_NR_INTERNAL_IRQS) |
| 75 | #define NOMADIK_IRQ_TO_GPIO(irq) ((irq) - U8500_SOC_NR_IRQS) | 76 | #define NOMADIK_IRQ_TO_GPIO(irq) ((irq) - DBX500_NR_INTERNAL_IRQS) |
| 76 | #define NR_IRQS NOMADIK_GPIO_TO_IRQ(NOMADIK_NR_GPIO) | 77 | #define IRQ_BOARD_START NOMADIK_GPIO_TO_IRQ(NOMADIK_NR_GPIO) |
| 77 | 78 | ||
| 78 | #endif /*ASM_ARCH_IRQS_H*/ | 79 | /* This will be overridden by board-specific irq headers */ |
| 80 | #define IRQ_BOARD_END IRQ_BOARD_START | ||
| 81 | |||
| 82 | #ifdef CONFIG_MACH_U8500_MOP | ||
| 83 | #include <mach/irqs-board-mop500.h> | ||
| 84 | #endif | ||
| 85 | |||
| 86 | #define NR_IRQS IRQ_BOARD_END | ||
| 87 | |||
| 88 | #endif /* ASM_ARCH_IRQS_H */ | ||
diff --git a/arch/arm/mach-ux500/pins-db8500.h b/arch/arm/mach-ux500/pins-db8500.h new file mode 100644 index 000000000000..9055d5d3233c --- /dev/null +++ b/arch/arm/mach-ux500/pins-db8500.h | |||
| @@ -0,0 +1,742 @@ | |||
| 1 | /* | ||
| 2 | * Copyright (C) ST-Ericsson SA 2010 | ||
| 3 | * | ||
| 4 | * License terms: GNU General Public License, version 2 | ||
| 5 | * Author: Rabin Vincent <rabin.vincent@stericsson.com> | ||
| 6 | */ | ||
| 7 | |||
| 8 | #ifndef __MACH_PINS_DB8500_H | ||
| 9 | #define __MACH_PINS_DB8500_H | ||
| 10 | |||
| 11 | /* | ||
| 12 | * TODO: Eventually encode all non-board specific pull up/down configuration | ||
| 13 | * here. | ||
| 14 | */ | ||
| 15 | |||
| 16 | #define GPIO0_GPIO PIN_CFG(0, GPIO) | ||
| 17 | #define GPIO0_U0_CTSn PIN_CFG(0, ALT_A) | ||
| 18 | #define GPIO0_TRIG_OUT PIN_CFG(0, ALT_B) | ||
| 19 | #define GPIO0_IP_TDO PIN_CFG(0, ALT_C) | ||
| 20 | |||
| 21 | #define GPIO1_GPIO PIN_CFG(1, GPIO) | ||
| 22 | #define GPIO1_U0_RTSn PIN_CFG(1, ALT_A) | ||
| 23 | #define GPIO1_TRIG_IN PIN_CFG(1, ALT_B) | ||
| 24 | #define GPIO1_IP_TDI PIN_CFG(1, ALT_C) | ||
| 25 | |||
| 26 | #define GPIO2_GPIO PIN_CFG(2, GPIO) | ||
| 27 | #define GPIO2_U0_RXD PIN_CFG(2, ALT_A) | ||
| 28 | #define GPIO2_NONE PIN_CFG(2, ALT_B) | ||
| 29 | #define GPIO2_IP_TMS PIN_CFG(2, ALT_C) | ||
| 30 | |||
| 31 | #define GPIO3_GPIO PIN_CFG(3, GPIO) | ||
| 32 | #define GPIO3_U0_TXD PIN_CFG(3, ALT_A) | ||
| 33 | #define GPIO3_NONE PIN_CFG(3, ALT_B) | ||
| 34 | #define GPIO3_IP_TCK PIN_CFG(3, ALT_C) | ||
| 35 | |||
| 36 | #define GPIO4_GPIO PIN_CFG(4, GPIO) | ||
| 37 | #define GPIO4_U1_RXD PIN_CFG(4, ALT_A) | ||
| 38 | #define GPIO4_I2C4_SCL PIN_CFG_PULL(4, ALT_B, UP) | ||
| 39 | #define GPIO4_IP_TRSTn PIN_CFG(4, ALT_C) | ||
| 40 | |||
| 41 | #define GPIO5_GPIO PIN_CFG(5, GPIO) | ||
| 42 | #define GPIO5_U1_TXD PIN_CFG(5, ALT_A) | ||
| 43 | #define GPIO5_I2C4_SDA PIN_CFG_PULL(5, ALT_B, UP) | ||
| 44 | #define GPIO5_IP_GPIO6 PIN_CFG(5, ALT_C) | ||
| 45 | |||
| 46 | #define GPIO6_GPIO PIN_CFG(6, GPIO) | ||
| 47 | #define GPIO6_U1_CTSn PIN_CFG(6, ALT_A) | ||
| 48 | #define GPIO6_I2C1_SCL PIN_CFG_PULL(6, ALT_B, UP) | ||
| 49 | #define GPIO6_IP_GPIO0 PIN_CFG(6, ALT_C) | ||
| 50 | |||
| 51 | #define GPIO7_GPIO PIN_CFG(7, GPIO) | ||
| 52 | #define GPIO7_U1_RTSn PIN_CFG(7, ALT_A) | ||
| 53 | #define GPIO7_I2C1_SDA PIN_CFG_PULL(7, ALT_B, UP) | ||
| 54 | #define GPIO7_IP_GPIO1 PIN_CFG(7, ALT_C) | ||
| 55 | |||
| 56 | #define GPIO8_GPIO PIN_CFG(8, GPIO) | ||
| 57 | #define GPIO8_IPI2C_SDA PIN_CFG_PULL(8, ALT_A, UP) | ||
| 58 | #define GPIO8_I2C2_SDA PIN_CFG_PULL(8, ALT_B, UP) | ||
| 59 | |||
| 60 | #define GPIO9_GPIO PIN_CFG(9, GPIO) | ||
| 61 | #define GPIO9_IPI2C_SCL PIN_CFG_PULL(9, ALT_A, UP) | ||
| 62 | #define GPIO9_I2C2_SCL PIN_CFG_PULL(9, ALT_B, UP) | ||
| 63 | |||
| 64 | #define GPIO10_GPIO PIN_CFG(10, GPIO) | ||
| 65 | #define GPIO10_IPI2C_SDA PIN_CFG_PULL(10, ALT_A, UP) | ||
| 66 | #define GPIO10_I2C2_SDA PIN_CFG_PULL(10, ALT_B, UP) | ||
| 67 | #define GPIO10_IP_GPIO3 PIN_CFG(10, ALT_C) | ||
| 68 | |||
| 69 | #define GPIO11_GPIO PIN_CFG(11, GPIO) | ||
| 70 | #define GPIO11_IPI2C_SCL PIN_CFG_PULL(11, ALT_A, UP) | ||
| 71 | #define GPIO11_I2C2_SCL PIN_CFG_PULL(11, ALT_B, UP) | ||
| 72 | #define GPIO11_IP_GPIO2 PIN_CFG(11, ALT_C) | ||
| 73 | |||
| 74 | #define GPIO12_GPIO PIN_CFG(12, GPIO) | ||
| 75 | #define GPIO12_MSP0_TXD PIN_CFG(12, ALT_A) | ||
| 76 | #define GPIO12_MSP0_RXD PIN_CFG(12, ALT_B) | ||
| 77 | |||
| 78 | #define GPIO13_GPIO PIN_CFG(13, GPIO) | ||
| 79 | #define GPIO13_MSP0_TFS PIN_CFG(13, ALT_A) | ||
| 80 | |||
| 81 | #define GPIO14_GPIO PIN_CFG(14, GPIO) | ||
| 82 | #define GPIO14_MSP0_TCK PIN_CFG(14, ALT_A) | ||
| 83 | |||
| 84 | #define GPIO15_GPIO PIN_CFG(15, GPIO) | ||
| 85 | #define GPIO15_MSP0_RXD PIN_CFG(15, ALT_A) | ||
| 86 | #define GPIO15_MSP0_TXD PIN_CFG(15, ALT_B) | ||
| 87 | |||
| 88 | #define GPIO16_GPIO PIN_CFG(16, GPIO) | ||
| 89 | #define GPIO16_MSP0_RFS PIN_CFG(16, ALT_A) | ||
| 90 | #define GPIO16_I2C1_SCL PIN_CFG_PULL(16, ALT_B, UP) | ||
| 91 | #define GPIO16_SLIM0_DAT PIN_CFG(16, ALT_C) | ||
| 92 | |||
| 93 | #define GPIO17_GPIO PIN_CFG(17, GPIO) | ||
| 94 | #define GPIO17_MSP0_RCK PIN_CFG(17, ALT_A) | ||
| 95 | #define GPIO17_I2C1_SDA PIN_CFG_PULL(17, ALT_B, UP) | ||
| 96 | #define GPIO17_SLIM0_CLK PIN_CFG(17, ALT_C) | ||
| 97 | |||
| 98 | #define GPIO18_GPIO PIN_CFG(18, GPIO) | ||
| 99 | #define GPIO18_MC0_CMDDIR PIN_CFG(18, ALT_A) | ||
| 100 | #define GPIO18_U2_RXD PIN_CFG(18, ALT_B) | ||
| 101 | #define GPIO18_MS_IEP PIN_CFG(18, ALT_C) | ||
| 102 | |||
| 103 | #define GPIO19_GPIO PIN_CFG(19, GPIO) | ||
| 104 | #define GPIO19_MC0_DAT0DIR PIN_CFG(19, ALT_A) | ||
| 105 | #define GPIO19_U2_TXD PIN_CFG(19, ALT_B) | ||
| 106 | #define GPIO19_MS_DAT0DIR PIN_CFG(19, ALT_C) | ||
| 107 | |||
| 108 | #define GPIO20_GPIO PIN_CFG(20, GPIO) | ||
| 109 | #define GPIO20_MC0_DAT2DIR PIN_CFG(20, ALT_A) | ||
| 110 | #define GPIO20_UARTMOD_TXD PIN_CFG(20, ALT_B) | ||
| 111 | #define GPIO20_IP_TRIGOUT PIN_CFG(20, ALT_C) | ||
| 112 | |||
| 113 | #define GPIO21_GPIO PIN_CFG(21, GPIO) | ||
| 114 | #define GPIO21_MC0_DAT31DIR PIN_CFG(21, ALT_A) | ||
| 115 | #define GPIO21_MSP0_SCK PIN_CFG(21, ALT_B) | ||
| 116 | #define GPIO21_MS_DAT31DIR PIN_CFG(21, ALT_C) | ||
| 117 | |||
| 118 | #define GPIO22_GPIO PIN_CFG(22, GPIO) | ||
| 119 | #define GPIO22_MC0_FBCLK PIN_CFG(22, ALT_A) | ||
| 120 | #define GPIO22_UARTMOD_RXD PIN_CFG(22, ALT_B) | ||
| 121 | #define GPIO22_MS_FBCLK PIN_CFG(22, ALT_C) | ||
| 122 | |||
| 123 | #define GPIO23_GPIO PIN_CFG(23, GPIO) | ||
| 124 | #define GPIO23_MC0_CLK PIN_CFG(23, ALT_A) | ||
| 125 | #define GPIO23_STMMOD_CLK PIN_CFG(23, ALT_B) | ||
| 126 | #define GPIO23_MS_CLK PIN_CFG(23, ALT_C) | ||
| 127 | |||
| 128 | #define GPIO24_GPIO PIN_CFG(24, GPIO) | ||
| 129 | #define GPIO24_MC0_CMD PIN_CFG(24, ALT_A) | ||
| 130 | #define GPIO24_UARTMOD_RXD PIN_CFG(24, ALT_B) | ||
| 131 | #define GPIO24_MS_BS PIN_CFG(24, ALT_C) | ||
| 132 | |||
| 133 | #define GPIO25_GPIO PIN_CFG(25, GPIO) | ||
| 134 | #define GPIO25_MC0_DAT0 PIN_CFG(25, ALT_A) | ||
| 135 | #define GPIO25_STMMOD_DAT0 PIN_CFG(25, ALT_B) | ||
| 136 | #define GPIO25_MS_DAT0 PIN_CFG(25, ALT_C) | ||
| 137 | |||
| 138 | #define GPIO26_GPIO PIN_CFG(26, GPIO) | ||
| 139 | #define GPIO26_MC0_DAT1 PIN_CFG(26, ALT_A) | ||
| 140 | #define GPIO26_STMMOD_DAT1 PIN_CFG(26, ALT_B) | ||
| 141 | #define GPIO26_MS_DAT1 PIN_CFG(26, ALT_C) | ||
| 142 | |||
| 143 | #define GPIO27_GPIO PIN_CFG(27, GPIO) | ||
| 144 | #define GPIO27_MC0_DAT2 PIN_CFG(27, ALT_A) | ||
| 145 | #define GPIO27_STMMOD_DAT2 PIN_CFG(27, ALT_B) | ||
| 146 | #define GPIO27_MS_DAT2 PIN_CFG(27, ALT_C) | ||
| 147 | |||
| 148 | #define GPIO28_GPIO PIN_CFG(28, GPIO) | ||
| 149 | #define GPIO28_MC0_DAT3 PIN_CFG(28, ALT_A) | ||
| 150 | #define GPIO28_STMMOD_DAT3 PIN_CFG(28, ALT_B) | ||
| 151 | #define GPIO28_MS_DAT3 PIN_CFG(28, ALT_C) | ||
| 152 | |||
| 153 | #define GPIO29_GPIO PIN_CFG(29, GPIO) | ||
| 154 | #define GPIO29_MC0_DAT4 PIN_CFG(29, ALT_A) | ||
| 155 | #define GPIO29_SPI3_CLK PIN_CFG(29, ALT_B) | ||
| 156 | #define GPIO29_U2_RXD PIN_CFG(29, ALT_C) | ||
| 157 | |||
| 158 | #define GPIO30_GPIO PIN_CFG(30, GPIO) | ||
| 159 | #define GPIO30_MC0_DAT5 PIN_CFG(30, ALT_A) | ||
| 160 | #define GPIO30_SPI3_RXD PIN_CFG(30, ALT_B) | ||
| 161 | #define GPIO30_U2_TXD PIN_CFG(30, ALT_C) | ||
| 162 | |||
| 163 | #define GPIO31_GPIO PIN_CFG(31, GPIO) | ||
| 164 | #define GPIO31_MC0_DAT6 PIN_CFG(31, ALT_A) | ||
| 165 | #define GPIO31_SPI3_FRM PIN_CFG(31, ALT_B) | ||
| 166 | #define GPIO31_U2_CTSn PIN_CFG(31, ALT_C) | ||
| 167 | |||
| 168 | #define GPIO32_GPIO PIN_CFG(32, GPIO) | ||
| 169 | #define GPIO32_MC0_DAT7 PIN_CFG(32, ALT_A) | ||
| 170 | #define GPIO32_SPI3_TXD PIN_CFG(32, ALT_B) | ||
| 171 | #define GPIO32_U2_RTSn PIN_CFG(32, ALT_C) | ||
| 172 | |||
| 173 | #define GPIO33_GPIO PIN_CFG(33, GPIO) | ||
| 174 | #define GPIO33_MSP1_TXD PIN_CFG(33, ALT_A) | ||
| 175 | #define GPIO33_MSP1_RXD PIN_CFG(33, ALT_B) | ||
| 176 | #define GPIO33_U0_DTRn PIN_CFG(33, ALT_C) | ||
| 177 | |||
| 178 | #define GPIO34_GPIO PIN_CFG(34, GPIO) | ||
| 179 | #define GPIO34_MSP1_TFS PIN_CFG(34, ALT_A) | ||
| 180 | #define GPIO34_NONE PIN_CFG(34, ALT_B) | ||
| 181 | #define GPIO34_U0_DCDn PIN_CFG(34, ALT_C) | ||
| 182 | |||
| 183 | #define GPIO35_GPIO PIN_CFG(35, GPIO) | ||
| 184 | #define GPIO35_MSP1_TCK PIN_CFG(35, ALT_A) | ||
| 185 | #define GPIO35_NONE PIN_CFG(35, ALT_B) | ||
| 186 | #define GPIO35_U0_DSRn PIN_CFG(35, ALT_C) | ||
| 187 | |||
| 188 | #define GPIO36_GPIO PIN_CFG(36, GPIO) | ||
| 189 | #define GPIO36_MSP1_RXD PIN_CFG(36, ALT_A) | ||
| 190 | #define GPIO36_MSP1_TXD PIN_CFG(36, ALT_B) | ||
| 191 | #define GPIO36_U0_RIn PIN_CFG(36, ALT_C) | ||
| 192 | |||
| 193 | #define GPIO64_GPIO PIN_CFG(64, GPIO) | ||
| 194 | #define GPIO64_LCDB_DE PIN_CFG(64, ALT_A) | ||
| 195 | #define GPIO64_KP_O1 PIN_CFG(64, ALT_B) | ||
| 196 | #define GPIO64_IP_GPIO4 PIN_CFG(64, ALT_C) | ||
| 197 | |||
| 198 | #define GPIO65_GPIO PIN_CFG(65, GPIO) | ||
| 199 | #define GPIO65_LCDB_HSO PIN_CFG(65, ALT_A) | ||
| 200 | #define GPIO65_KP_O0 PIN_CFG(65, ALT_B) | ||
| 201 | #define GPIO65_IP_GPIO5 PIN_CFG(65, ALT_C) | ||
| 202 | |||
| 203 | #define GPIO66_GPIO PIN_CFG(66, GPIO) | ||
| 204 | #define GPIO66_LCDB_VSO PIN_CFG(66, ALT_A) | ||
| 205 | #define GPIO66_KP_I1 PIN_CFG(66, ALT_B) | ||
| 206 | #define GPIO66_IP_GPIO6 PIN_CFG(66, ALT_C) | ||
| 207 | |||
| 208 | #define GPIO67_GPIO PIN_CFG(67, GPIO) | ||
| 209 | #define GPIO67_LCDB_CLK PIN_CFG(67, ALT_A) | ||
| 210 | #define GPIO67_KP_I0 PIN_CFG(67, ALT_B) | ||
| 211 | #define GPIO67_IP_GPIO7 PIN_CFG(67, ALT_C) | ||
| 212 | |||
| 213 | #define GPIO68_GPIO PIN_CFG(68, GPIO) | ||
| 214 | #define GPIO68_LCD_VSI0 PIN_CFG(68, ALT_A) | ||
| 215 | #define GPIO68_KP_O7 PIN_CFG(68, ALT_B) | ||
| 216 | #define GPIO68_SM_CLE PIN_CFG(68, ALT_C) | ||
| 217 | |||
| 218 | #define GPIO69_GPIO PIN_CFG(69, GPIO) | ||
| 219 | #define GPIO69_LCD_VSI1 PIN_CFG(69, ALT_A) | ||
| 220 | #define GPIO69_KP_I7 PIN_CFG(69, ALT_B) | ||
| 221 | #define GPIO69_SM_ALE PIN_CFG(69, ALT_C) | ||
| 222 | |||
| 223 | #define GPIO70_GPIO PIN_CFG(70, GPIO) | ||
| 224 | #define GPIO70_LCD_D0 PIN_CFG(70, ALT_A) | ||
| 225 | #define GPIO70_KP_O5 PIN_CFG(70, ALT_B) | ||
| 226 | #define GPIO70_STMAPE_CLK PIN_CFG(70, ALT_C) | ||
| 227 | |||
| 228 | #define GPIO71_GPIO PIN_CFG(71, GPIO) | ||
| 229 | #define GPIO71_LCD_D1 PIN_CFG(71, ALT_A) | ||
| 230 | #define GPIO71_KP_O4 PIN_CFG(71, ALT_B) | ||
| 231 | #define GPIO71_STMAPE_DAT3 PIN_CFG(71, ALT_C) | ||
| 232 | |||
| 233 | #define GPIO72_GPIO PIN_CFG(72, GPIO) | ||
| 234 | #define GPIO72_LCD_D2 PIN_CFG(72, ALT_A) | ||
| 235 | #define GPIO72_KP_O3 PIN_CFG(72, ALT_B) | ||
| 236 | #define GPIO72_STMAPE_DAT2 PIN_CFG(72, ALT_C) | ||
| 237 | |||
| 238 | #define GPIO73_GPIO PIN_CFG(73, GPIO) | ||
| 239 | #define GPIO73_LCD_D3 PIN_CFG(73, ALT_A) | ||
| 240 | #define GPIO73_KP_O2 PIN_CFG(73, ALT_B) | ||
| 241 | #define GPIO73_STMAPE_DAT1 PIN_CFG(73, ALT_C) | ||
| 242 | |||
| 243 | #define GPIO74_GPIO PIN_CFG(74, GPIO) | ||
| 244 | #define GPIO74_LCD_D4 PIN_CFG(74, ALT_A) | ||
| 245 | #define GPIO74_KP_I5 PIN_CFG(74, ALT_B) | ||
| 246 | #define GPIO74_STMAPE_DAT0 PIN_CFG(74, ALT_C) | ||
| 247 | |||
| 248 | #define GPIO75_GPIO PIN_CFG(75, GPIO) | ||
| 249 | #define GPIO75_LCD_D5 PIN_CFG(75, ALT_A) | ||
| 250 | #define GPIO75_KP_I4 PIN_CFG(75, ALT_B) | ||
| 251 | #define GPIO75_U2_RXD PIN_CFG(75, ALT_C) | ||
| 252 | |||
| 253 | #define GPIO76_GPIO PIN_CFG(76, GPIO) | ||
| 254 | #define GPIO76_LCD_D6 PIN_CFG(76, ALT_A) | ||
| 255 | #define GPIO76_KP_I3 PIN_CFG(76, ALT_B) | ||
| 256 | #define GPIO76_U2_TXD PIN_CFG(76, ALT_C) | ||
| 257 | |||
| 258 | #define GPIO77_GPIO PIN_CFG(77, GPIO) | ||
| 259 | #define GPIO77_LCD_D7 PIN_CFG(77, ALT_A) | ||
| 260 | #define GPIO77_KP_I2 PIN_CFG(77, ALT_B) | ||
| 261 | #define GPIO77_NONE PIN_CFG(77, ALT_C) | ||
| 262 | |||
| 263 | #define GPIO78_GPIO PIN_CFG(78, GPIO) | ||
| 264 | #define GPIO78_LCD_D8 PIN_CFG(78, ALT_A) | ||
| 265 | #define GPIO78_KP_O6 PIN_CFG(78, ALT_B) | ||
| 266 | #define GPIO78_IP_GPIO2 PIN_CFG(78, ALT_C) | ||
| 267 | |||
| 268 | #define GPIO79_GPIO PIN_CFG(79, GPIO) | ||
| 269 | #define GPIO79_LCD_D9 PIN_CFG(79, ALT_A) | ||
| 270 | #define GPIO79_KP_I6 PIN_CFG(79, ALT_B) | ||
| 271 | #define GPIO79_IP_GPIO3 PIN_CFG(79, ALT_C) | ||
| 272 | |||
| 273 | #define GPIO80_GPIO PIN_CFG(80, GPIO) | ||
| 274 | #define GPIO80_LCD_D10 PIN_CFG(80, ALT_A) | ||
| 275 | #define GPIO80_KP_SKA0 PIN_CFG(80, ALT_B) | ||
| 276 | #define GPIO80_IP_GPIO4 PIN_CFG(80, ALT_C) | ||
| 277 | |||
| 278 | #define GPIO81_GPIO PIN_CFG(81, GPIO) | ||
| 279 | #define GPIO81_LCD_D11 PIN_CFG(81, ALT_A) | ||
| 280 | #define GPIO81_KP_SKB0 PIN_CFG(81, ALT_B) | ||
| 281 | #define GPIO81_IP_GPIO5 PIN_CFG(81, ALT_C) | ||
| 282 | |||
| 283 | #define GPIO82_GPIO PIN_CFG(82, GPIO) | ||
| 284 | #define GPIO82_LCD_D12 PIN_CFG(82, ALT_A) | ||
| 285 | #define GPIO82_KP_O5 PIN_CFG(82, ALT_B) | ||
| 286 | |||
| 287 | #define GPIO83_GPIO PIN_CFG(83, GPIO) | ||
| 288 | #define GPIO83_LCD_D13 PIN_CFG(83, ALT_A) | ||
| 289 | #define GPIO83_KP_O4 PIN_CFG(83, ALT_B) | ||
| 290 | |||
| 291 | #define GPIO84_GPIO PIN_CFG(84, GPIO) | ||
| 292 | #define GPIO84_LCD_D14 PIN_CFG(84, ALT_A) | ||
| 293 | #define GPIO84_KP_I5 PIN_CFG(84, ALT_B) | ||
| 294 | |||
| 295 | #define GPIO85_GPIO PIN_CFG(85, GPIO) | ||
| 296 | #define GPIO85_LCD_D15 PIN_CFG(85, ALT_A) | ||
| 297 | #define GPIO85_KP_I4 PIN_CFG(85, ALT_B) | ||
| 298 | |||
| 299 | #define GPIO86_GPIO PIN_CFG(86, GPIO) | ||
| 300 | #define GPIO86_LCD_D16 PIN_CFG(86, ALT_A) | ||
| 301 | #define GPIO86_SM_ADQ0 PIN_CFG(86, ALT_B) | ||
| 302 | #define GPIO86_MC5_DAT0 PIN_CFG(86, ALT_C) | ||
| 303 | |||
| 304 | #define GPIO87_GPIO PIN_CFG(87, GPIO) | ||
| 305 | #define GPIO87_LCD_D17 PIN_CFG(87, ALT_A) | ||
| 306 | #define GPIO87_SM_ADQ1 PIN_CFG(87, ALT_B) | ||
| 307 | #define GPIO87_MC5_DAT1 PIN_CFG(87, ALT_C) | ||
| 308 | |||
| 309 | #define GPIO88_GPIO PIN_CFG(88, GPIO) | ||
| 310 | #define GPIO88_LCD_D18 PIN_CFG(88, ALT_A) | ||
| 311 | #define GPIO88_SM_ADQ2 PIN_CFG(88, ALT_B) | ||
| 312 | #define GPIO88_MC5_DAT2 PIN_CFG(88, ALT_C) | ||
| 313 | |||
| 314 | #define GPIO89_GPIO PIN_CFG(89, GPIO) | ||
| 315 | #define GPIO89_LCD_D19 PIN_CFG(89, ALT_A) | ||
| 316 | #define GPIO89_SM_ADQ3 PIN_CFG(89, ALT_B) | ||
| 317 | #define GPIO89_MC5_DAT3 PIN_CFG(89, ALT_C) | ||
| 318 | |||
| 319 | #define GPIO90_GPIO PIN_CFG(90, GPIO) | ||
| 320 | #define GPIO90_LCD_D20 PIN_CFG(90, ALT_A) | ||
| 321 | #define GPIO90_SM_ADQ4 PIN_CFG(90, ALT_B) | ||
| 322 | #define GPIO90_MC5_CMD PIN_CFG(90, ALT_C) | ||
| 323 | |||
| 324 | #define GPIO91_GPIO PIN_CFG(91, GPIO) | ||
| 325 | #define GPIO91_LCD_D21 PIN_CFG(91, ALT_A) | ||
| 326 | #define GPIO91_SM_ADQ5 PIN_CFG(91, ALT_B) | ||
| 327 | #define GPIO91_MC5_FBCLK PIN_CFG(91, ALT_C) | ||
| 328 | |||
| 329 | #define GPIO92_GPIO PIN_CFG(92, GPIO) | ||
| 330 | #define GPIO92_LCD_D22 PIN_CFG(92, ALT_A) | ||
| 331 | #define GPIO92_SM_ADQ6 PIN_CFG(92, ALT_B) | ||
| 332 | #define GPIO92_MC5_CLK PIN_CFG(92, ALT_C) | ||
| 333 | |||
| 334 | #define GPIO93_GPIO PIN_CFG(93, GPIO) | ||
| 335 | #define GPIO93_LCD_D23 PIN_CFG(93, ALT_A) | ||
| 336 | #define GPIO93_SM_ADQ7 PIN_CFG(93, ALT_B) | ||
| 337 | #define GPIO93_MC5_DAT4 PIN_CFG(93, ALT_C) | ||
| 338 | |||
| 339 | #define GPIO94_GPIO PIN_CFG(94, GPIO) | ||
| 340 | #define GPIO94_KP_O7 PIN_CFG(94, ALT_A) | ||
| 341 | #define GPIO94_SM_ADVn PIN_CFG(94, ALT_B) | ||
| 342 | #define GPIO94_MC5_DAT5 PIN_CFG(94, ALT_C) | ||
| 343 | |||
| 344 | #define GPIO95_GPIO PIN_CFG(95, GPIO) | ||
| 345 | #define GPIO95_KP_I7 PIN_CFG(95, ALT_A) | ||
| 346 | #define GPIO95_SM_CS0n PIN_CFG(95, ALT_B) | ||
| 347 | #define GPIO95_SM_PS0n PIN_CFG(95, ALT_C) | ||
| 348 | |||
| 349 | #define GPIO96_GPIO PIN_CFG(96, GPIO) | ||
| 350 | #define GPIO96_KP_O6 PIN_CFG(96, ALT_A) | ||
| 351 | #define GPIO96_SM_OEn PIN_CFG(96, ALT_B) | ||
| 352 | #define GPIO96_MC5_DAT6 PIN_CFG(96, ALT_C) | ||
| 353 | |||
| 354 | #define GPIO97_GPIO PIN_CFG(97, GPIO) | ||
| 355 | #define GPIO97_KP_I6 PIN_CFG(97, ALT_A) | ||
| 356 | #define GPIO97_SM_WEn PIN_CFG(97, ALT_B) | ||
| 357 | #define GPIO97_MC5_DAT7 PIN_CFG(97, ALT_C) | ||
| 358 | |||
| 359 | #define GPIO128_GPIO PIN_CFG(128, GPIO) | ||
| 360 | #define GPIO128_MC2_CLK PIN_CFG(128, ALT_A) | ||
| 361 | #define GPIO128_SM_CKO PIN_CFG(128, ALT_B) | ||
| 362 | |||
| 363 | #define GPIO129_GPIO PIN_CFG(129, GPIO) | ||
| 364 | #define GPIO129_MC2_CMD PIN_CFG(129, ALT_A) | ||
| 365 | #define GPIO129_SM_WAIT0n PIN_CFG(129, ALT_B) | ||
| 366 | |||
| 367 | #define GPIO130_GPIO PIN_CFG(130, GPIO) | ||
| 368 | #define GPIO130_MC2_FBCLK PIN_CFG(130, ALT_A) | ||
| 369 | #define GPIO130_SM_FBCLK PIN_CFG(130, ALT_B) | ||
| 370 | #define GPIO130_MC2_RSTN PIN_CFG(130, ALT_C) | ||
| 371 | |||
| 372 | #define GPIO131_GPIO PIN_CFG(131, GPIO) | ||
| 373 | #define GPIO131_MC2_DAT0 PIN_CFG(131, ALT_A) | ||
| 374 | #define GPIO131_SM_ADQ8 PIN_CFG(131, ALT_B) | ||
| 375 | |||
| 376 | #define GPIO132_GPIO PIN_CFG(132, GPIO) | ||
| 377 | #define GPIO132_MC2_DAT1 PIN_CFG(132, ALT_A) | ||
| 378 | #define GPIO132_SM_ADQ9 PIN_CFG(132, ALT_B) | ||
| 379 | |||
| 380 | #define GPIO133_GPIO PIN_CFG(133, GPIO) | ||
| 381 | #define GPIO133_MC2_DAT2 PIN_CFG(133, ALT_A) | ||
| 382 | #define GPIO133_SM_ADQ10 PIN_CFG(133, ALT_B) | ||
| 383 | |||
| 384 | #define GPIO134_GPIO PIN_CFG(134, GPIO) | ||
| 385 | #define GPIO134_MC2_DAT3 PIN_CFG(134, ALT_A) | ||
| 386 | #define GPIO134_SM_ADQ11 PIN_CFG(134, ALT_B) | ||
| 387 | |||
| 388 | #define GPIO135_GPIO PIN_CFG(135, GPIO) | ||
| 389 | #define GPIO135_MC2_DAT4 PIN_CFG(135, ALT_A) | ||
| 390 | #define GPIO135_SM_ADQ12 PIN_CFG(135, ALT_B) | ||
| 391 | |||
| 392 | #define GPIO136_GPIO PIN_CFG(136, GPIO) | ||
| 393 | #define GPIO136_MC2_DAT5 PIN_CFG(136, ALT_A) | ||
| 394 | #define GPIO136_SM_ADQ13 PIN_CFG(136, ALT_B) | ||
| 395 | |||
| 396 | #define GPIO137_GPIO PIN_CFG(137, GPIO) | ||
| 397 | #define GPIO137_MC2_DAT6 PIN_CFG(137, ALT_A) | ||
| 398 | #define GPIO137_SM_ADQ14 PIN_CFG(137, ALT_B) | ||
| 399 | |||
| 400 | #define GPIO138_GPIO PIN_CFG(138, GPIO) | ||
| 401 | #define GPIO138_MC2_DAT7 PIN_CFG(138, ALT_A) | ||
| 402 | #define GPIO138_SM_ADQ15 PIN_CFG(138, ALT_B) | ||
| 403 | |||
| 404 | #define GPIO139_GPIO PIN_CFG(139, GPIO) | ||
| 405 | #define GPIO139_SSP1_RXD PIN_CFG(139, ALT_A) | ||
| 406 | #define GPIO139_SM_WAIT1n PIN_CFG(139, ALT_B) | ||
| 407 | #define GPIO139_KP_O8 PIN_CFG(139, ALT_C) | ||
| 408 | |||
| 409 | #define GPIO140_GPIO PIN_CFG(140, GPIO) | ||
| 410 | #define GPIO140_SSP1_TXD PIN_CFG(140, ALT_A) | ||
| 411 | #define GPIO140_IP_GPIO7 PIN_CFG(140, ALT_B) | ||
| 412 | #define GPIO140_KP_SKA1 PIN_CFG(140, ALT_C) | ||
| 413 | |||
| 414 | #define GPIO141_GPIO PIN_CFG(141, GPIO) | ||
| 415 | #define GPIO141_SSP1_CLK PIN_CFG(141, ALT_A) | ||
| 416 | #define GPIO141_IP_GPIO2 PIN_CFG(141, ALT_B) | ||
| 417 | #define GPIO141_KP_O9 PIN_CFG(141, ALT_C) | ||
| 418 | |||
| 419 | #define GPIO142_GPIO PIN_CFG(142, GPIO) | ||
| 420 | #define GPIO142_SSP1_FRM PIN_CFG(142, ALT_A) | ||
| 421 | #define GPIO142_IP_GPIO3 PIN_CFG(142, ALT_B) | ||
| 422 | #define GPIO142_KP_SKB1 PIN_CFG(142, ALT_C) | ||
| 423 | |||
| 424 | #define GPIO143_GPIO PIN_CFG(143, GPIO) | ||
| 425 | #define GPIO143_SSP0_CLK PIN_CFG(143, ALT_A) | ||
| 426 | |||
| 427 | #define GPIO144_GPIO PIN_CFG(144, GPIO) | ||
| 428 | #define GPIO144_SSP0_FRM PIN_CFG(144, ALT_A) | ||
| 429 | |||
| 430 | #define GPIO145_GPIO PIN_CFG(145, GPIO) | ||
| 431 | #define GPIO145_SSP0_RXD PIN_CFG(145, ALT_A) | ||
| 432 | |||
| 433 | #define GPIO146_GPIO PIN_CFG(146, GPIO) | ||
| 434 | #define GPIO146_SSP0_TXD PIN_CFG(146, ALT_A) | ||
| 435 | |||
| 436 | #define GPIO147_GPIO PIN_CFG(147, GPIO) | ||
| 437 | #define GPIO147_I2C0_SCL PIN_CFG_PULL(147, ALT_A, UP) | ||
| 438 | |||
| 439 | #define GPIO148_GPIO PIN_CFG(148, GPIO) | ||
| 440 | #define GPIO148_I2C0_SDA PIN_CFG_PULL(148, ALT_A, UP) | ||
| 441 | |||
| 442 | #define GPIO149_GPIO PIN_CFG(149, GPIO) | ||
| 443 | #define GPIO149_IP_GPIO0 PIN_CFG(149, ALT_A) | ||
| 444 | #define GPIO149_SM_CS1n PIN_CFG(149, ALT_B) | ||
| 445 | #define GPIO149_SM_PS1n PIN_CFG(149, ALT_C) | ||
| 446 | |||
| 447 | #define GPIO150_GPIO PIN_CFG(150, GPIO) | ||
| 448 | #define GPIO150_IP_GPIO1 PIN_CFG(150, ALT_A) | ||
| 449 | #define GPIO150_LCDA_CLK PIN_CFG(150, ALT_B) | ||
| 450 | |||
| 451 | #define GPIO151_GPIO PIN_CFG(151, GPIO) | ||
| 452 | #define GPIO151_KP_SKA0 PIN_CFG(151, ALT_A) | ||
| 453 | #define GPIO151_LCD_VSI0 PIN_CFG(151, ALT_B) | ||
| 454 | #define GPIO151_KP_O8 PIN_CFG(151, ALT_C) | ||
| 455 | |||
| 456 | #define GPIO152_GPIO PIN_CFG(152, GPIO) | ||
| 457 | #define GPIO152_KP_SKB0 PIN_CFG(152, ALT_A) | ||
| 458 | #define GPIO152_LCD_VSI1 PIN_CFG(152, ALT_B) | ||
| 459 | #define GPIO152_KP_O9 PIN_CFG(152, ALT_C) | ||
| 460 | |||
| 461 | #define GPIO153_GPIO PIN_CFG(153, GPIO) | ||
| 462 | #define GPIO153_KP_I7 PIN_CFG(153, ALT_A) | ||
| 463 | #define GPIO153_LCD_D24 PIN_CFG(153, ALT_B) | ||
| 464 | #define GPIO153_U2_RXD PIN_CFG(153, ALT_C) | ||
| 465 | |||
| 466 | #define GPIO154_GPIO PIN_CFG(154, GPIO) | ||
| 467 | #define GPIO154_KP_I6 PIN_CFG(154, ALT_A) | ||
| 468 | #define GPIO154_LCD_D25 PIN_CFG(154, ALT_B) | ||
| 469 | #define GPIO154_U2_TXD PIN_CFG(154, ALT_C) | ||
| 470 | |||
| 471 | #define GPIO155_GPIO PIN_CFG(155, GPIO) | ||
| 472 | #define GPIO155_KP_I5 PIN_CFG(155, ALT_A) | ||
| 473 | #define GPIO155_LCD_D26 PIN_CFG(155, ALT_B) | ||
| 474 | #define GPIO155_STMAPE_CLK PIN_CFG(155, ALT_C) | ||
| 475 | |||
| 476 | #define GPIO156_GPIO PIN_CFG(156, GPIO) | ||
| 477 | #define GPIO156_KP_I4 PIN_CFG(156, ALT_A) | ||
| 478 | #define GPIO156_LCD_D27 PIN_CFG(156, ALT_B) | ||
| 479 | #define GPIO156_STMAPE_DAT3 PIN_CFG(156, ALT_C) | ||
| 480 | |||
| 481 | #define GPIO157_GPIO PIN_CFG(157, GPIO) | ||
| 482 | #define GPIO157_KP_O7 PIN_CFG(157, ALT_A) | ||
| 483 | #define GPIO157_LCD_D28 PIN_CFG(157, ALT_B) | ||
| 484 | #define GPIO157_STMAPE_DAT2 PIN_CFG(157, ALT_C) | ||
| 485 | |||
| 486 | #define GPIO158_GPIO PIN_CFG(158, GPIO) | ||
| 487 | #define GPIO158_KP_O6 PIN_CFG(158, ALT_A) | ||
| 488 | #define GPIO158_LCD_D29 PIN_CFG(158, ALT_B) | ||
| 489 | #define GPIO158_STMAPE_DAT1 PIN_CFG(158, ALT_C) | ||
| 490 | |||
| 491 | #define GPIO159_GPIO PIN_CFG(159, GPIO) | ||
| 492 | #define GPIO159_KP_O5 PIN_CFG(159, ALT_A) | ||
| 493 | #define GPIO159_LCD_D30 PIN_CFG(159, ALT_B) | ||
| 494 | #define GPIO159_STMAPE_DAT0 PIN_CFG(159, ALT_C) | ||
| 495 | |||
| 496 | #define GPIO160_GPIO PIN_CFG(160, GPIO) | ||
| 497 | #define GPIO160_KP_O4 PIN_CFG(160, ALT_A) | ||
| 498 | #define GPIO160_LCD_D31 PIN_CFG(160, ALT_B) | ||
| 499 | #define GPIO160_NONE PIN_CFG(160, ALT_C) | ||
| 500 | |||
| 501 | #define GPIO161_GPIO PIN_CFG(161, GPIO) | ||
| 502 | #define GPIO161_KP_I3 PIN_CFG(161, ALT_A) | ||
| 503 | #define GPIO161_LCD_D32 PIN_CFG(161, ALT_B) | ||
| 504 | #define GPIO161_UARTMOD_RXD PIN_CFG(161, ALT_C) | ||
| 505 | |||
| 506 | #define GPIO162_GPIO PIN_CFG(162, GPIO) | ||
| 507 | #define GPIO162_KP_I2 PIN_CFG(162, ALT_A) | ||
| 508 | #define GPIO162_LCD_D33 PIN_CFG(162, ALT_B) | ||
| 509 | #define GPIO162_UARTMOD_TXD PIN_CFG(162, ALT_C) | ||
| 510 | |||
| 511 | #define GPIO163_GPIO PIN_CFG(163, GPIO) | ||
| 512 | #define GPIO163_KP_I1 PIN_CFG(163, ALT_A) | ||
| 513 | #define GPIO163_LCD_D34 PIN_CFG(163, ALT_B) | ||
| 514 | #define GPIO163_STMMOD_CLK PIN_CFG(163, ALT_C) | ||
| 515 | |||
| 516 | #define GPIO164_GPIO PIN_CFG(164, GPIO) | ||
| 517 | #define GPIO164_KP_I0 PIN_CFG(164, ALT_A) | ||
| 518 | #define GPIO164_LCD_D35 PIN_CFG(164, ALT_B) | ||
| 519 | #define GPIO164_STMMOD_DAT3 PIN_CFG(164, ALT_C) | ||
| 520 | |||
| 521 | #define GPIO165_GPIO PIN_CFG(165, GPIO) | ||
| 522 | #define GPIO165_KP_O3 PIN_CFG(165, ALT_A) | ||
| 523 | #define GPIO165_LCD_D36 PIN_CFG(165, ALT_B) | ||
| 524 | #define GPIO165_STMMOD_DAT2 PIN_CFG(165, ALT_C) | ||
| 525 | |||
| 526 | #define GPIO166_GPIO PIN_CFG(166, GPIO) | ||
| 527 | #define GPIO166_KP_O2 PIN_CFG(166, ALT_A) | ||
| 528 | #define GPIO166_LCD_D37 PIN_CFG(166, ALT_B) | ||
| 529 | #define GPIO166_STMMOD_DAT1 PIN_CFG(166, ALT_C) | ||
| 530 | |||
| 531 | #define GPIO167_GPIO PIN_CFG(167, GPIO) | ||
| 532 | #define GPIO167_KP_O1 PIN_CFG(167, ALT_A) | ||
| 533 | #define GPIO167_LCD_D38 PIN_CFG(167, ALT_B) | ||
| 534 | #define GPIO167_STMMOD_DAT0 PIN_CFG(167, ALT_C) | ||
| 535 | |||
| 536 | #define GPIO168_GPIO PIN_CFG(168, GPIO) | ||
| 537 | #define GPIO168_KP_O0 PIN_CFG(168, ALT_A) | ||
| 538 | #define GPIO168_LCD_D39 PIN_CFG(168, ALT_B) | ||
| 539 | #define GPIO168_NONE PIN_CFG(168, ALT_C) | ||
| 540 | |||
| 541 | #define GPIO169_GPIO PIN_CFG(169, GPIO) | ||
| 542 | #define GPIO169_RF_PURn PIN_CFG(169, ALT_A) | ||
| 543 | #define GPIO169_LCDA_DE PIN_CFG(169, ALT_B) | ||
| 544 | #define GPIO169_USBSIM_PDC PIN_CFG(169, ALT_C) | ||
| 545 | |||
| 546 | #define GPIO170_GPIO PIN_CFG(170, GPIO) | ||
| 547 | #define GPIO170_MODEM_STATE PIN_CFG(170, ALT_A) | ||
| 548 | #define GPIO170_LCDA_VSO PIN_CFG(170, ALT_B) | ||
| 549 | #define GPIO170_KP_SKA1 PIN_CFG(170, ALT_C) | ||
| 550 | |||
| 551 | #define GPIO171_GPIO PIN_CFG(171, GPIO) | ||
| 552 | #define GPIO171_MODEM_PWREN PIN_CFG(171, ALT_A) | ||
| 553 | #define GPIO171_LCDA_HSO PIN_CFG(171, ALT_B) | ||
| 554 | #define GPIO171_KP_SKB1 PIN_CFG(171, ALT_C) | ||
| 555 | |||
| 556 | #define GPIO192_GPIO PIN_CFG(192, GPIO) | ||
| 557 | #define GPIO192_MSP2_SCK PIN_CFG(192, ALT_A) | ||
| 558 | |||
| 559 | #define GPIO193_GPIO PIN_CFG(193, GPIO) | ||
| 560 | #define GPIO193_MSP2_TXD PIN_CFG(193, ALT_A) | ||
| 561 | |||
| 562 | #define GPIO194_GPIO PIN_CFG(194, GPIO) | ||
| 563 | #define GPIO194_MSP2_TCK PIN_CFG(194, ALT_A) | ||
| 564 | |||
| 565 | #define GPIO195_GPIO PIN_CFG(195, GPIO) | ||
| 566 | #define GPIO195_MSP2_TFS PIN_CFG(195, ALT_A) | ||
| 567 | |||
| 568 | #define GPIO196_GPIO PIN_CFG(196, GPIO) | ||
| 569 | #define GPIO196_MSP2_RXD PIN_CFG(196, ALT_A) | ||
| 570 | |||
| 571 | #define GPIO197_GPIO PIN_CFG(197, GPIO) | ||
| 572 | #define GPIO197_MC4_DAT3 PIN_CFG(197, ALT_A) | ||
| 573 | |||
| 574 | #define GPIO198_GPIO PIN_CFG(198, GPIO) | ||
| 575 | #define GPIO198_MC4_DAT2 PIN_CFG(198, ALT_A) | ||
| 576 | |||
| 577 | #define GPIO199_GPIO PIN_CFG(199, GPIO) | ||
| 578 | #define GPIO199_MC4_DAT1 PIN_CFG(199, ALT_A) | ||
| 579 | |||
| 580 | #define GPIO200_GPIO PIN_CFG(200, GPIO) | ||
| 581 | #define GPIO200_MC4_DAT0 PIN_CFG(200, ALT_A) | ||
| 582 | |||
| 583 | #define GPIO201_GPIO PIN_CFG(201, GPIO) | ||
| 584 | #define GPIO201_MC4_CMD PIN_CFG(201, ALT_A) | ||
| 585 | |||
| 586 | #define GPIO202_GPIO PIN_CFG(202, GPIO) | ||
| 587 | #define GPIO202_MC4_FBCLK PIN_CFG(202, ALT_A) | ||
| 588 | #define GPIO202_PWL PIN_CFG(202, ALT_B) | ||
| 589 | #define GPIO202_MC4_RSTN PIN_CFG(202, ALT_C) | ||
| 590 | |||
| 591 | #define GPIO203_GPIO PIN_CFG(203, GPIO) | ||
| 592 | #define GPIO203_MC4_CLK PIN_CFG(203, ALT_A) | ||
| 593 | |||
| 594 | #define GPIO204_GPIO PIN_CFG(204, GPIO) | ||
| 595 | #define GPIO204_MC4_DAT7 PIN_CFG(204, ALT_A) | ||
| 596 | |||
| 597 | #define GPIO205_GPIO PIN_CFG(205, GPIO) | ||
| 598 | #define GPIO205_MC4_DAT6 PIN_CFG(205, ALT_A) | ||
| 599 | |||
| 600 | #define GPIO206_GPIO PIN_CFG(206, GPIO) | ||
| 601 | #define GPIO206_MC4_DAT5 PIN_CFG(206, ALT_A) | ||
| 602 | |||
| 603 | #define GPIO207_GPIO PIN_CFG(207, GPIO) | ||
| 604 | #define GPIO207_MC4_DAT4 PIN_CFG(207, ALT_A) | ||
| 605 | |||
| 606 | #define GPIO208_GPIO PIN_CFG(208, GPIO) | ||
| 607 | #define GPIO208_MC1_CLK PIN_CFG(208, ALT_A) | ||
| 608 | |||
| 609 | #define GPIO209_GPIO PIN_CFG(209, GPIO) | ||
| 610 | #define GPIO209_MC1_FBCLK PIN_CFG(209, ALT_A) | ||
| 611 | #define GPIO209_SPI1_CLK PIN_CFG(209, ALT_B) | ||
| 612 | |||
| 613 | #define GPIO210_GPIO PIN_CFG(210, GPIO) | ||
| 614 | #define GPIO210_MC1_CMD PIN_CFG(210, ALT_A) | ||
| 615 | |||
| 616 | #define GPIO211_GPIO PIN_CFG(211, GPIO) | ||
| 617 | #define GPIO211_MC1_DAT0 PIN_CFG(211, ALT_A) | ||
| 618 | |||
| 619 | #define GPIO212_GPIO PIN_CFG(212, GPIO) | ||
| 620 | #define GPIO212_MC1_DAT1 PIN_CFG(212, ALT_A) | ||
| 621 | #define GPIO212_SPI1_FRM PIN_CFG(212, ALT_B) | ||
| 622 | |||
| 623 | #define GPIO213_GPIO PIN_CFG(213, GPIO) | ||
| 624 | #define GPIO213_MC1_DAT2 PIN_CFG(213, ALT_A) | ||
| 625 | #define GPIO213_SPI1_TXD PIN_CFG(213, ALT_B) | ||
| 626 | |||
| 627 | #define GPIO214_GPIO PIN_CFG(214, GPIO) | ||
| 628 | #define GPIO214_MC1_DAT3 PIN_CFG(214, ALT_A) | ||
| 629 | #define GPIO214_SPI1_RXD PIN_CFG(214, ALT_B) | ||
| 630 | |||
| 631 | #define GPIO215_GPIO PIN_CFG(215, GPIO) | ||
| 632 | #define GPIO215_MC1_CMDDIR PIN_CFG(215, ALT_A) | ||
| 633 | #define GPIO215_MC3_DAT2DIR PIN_CFG(215, ALT_B) | ||
| 634 | #define GPIO215_CLKOUT1 PIN_CFG(215, ALT_C) | ||
| 635 | |||
| 636 | #define GPIO216_GPIO PIN_CFG(216, GPIO) | ||
| 637 | #define GPIO216_MC1_DAT2DIR PIN_CFG(216, ALT_A) | ||
| 638 | #define GPIO216_MC3_CMDDIR PIN_CFG(216, ALT_B) | ||
| 639 | #define GPIO216_I2C3_SDA PIN_CFG_PULL(216, ALT_C, UP) | ||
| 640 | |||
| 641 | #define GPIO217_GPIO PIN_CFG(217, GPIO) | ||
| 642 | #define GPIO217_MC1_DAT0DIR PIN_CFG(217, ALT_A) | ||
| 643 | #define GPIO217_MC3_DAT31DIR PIN_CFG(217, ALT_B) | ||
| 644 | #define GPIO217_CLKOUT2 PIN_CFG(217, ALT_C) | ||
| 645 | |||
| 646 | #define GPIO218_GPIO PIN_CFG(218, GPIO) | ||
| 647 | #define GPIO218_MC1_DAT31DIR PIN_CFG(218, ALT_A) | ||
| 648 | #define GPIO218_MC3_DAT0DIR PIN_CFG(218, ALT_B) | ||
| 649 | #define GPIO218_I2C3_SCL PIN_CFG_PULL(218, ALT_C, UP) | ||
| 650 | |||
| 651 | #define GPIO219_GPIO PIN_CFG(219, GPIO) | ||
| 652 | #define GPIO219_HSIR_FLA0 PIN_CFG(219, ALT_A) | ||
| 653 | #define GPIO219_MC3_CLK PIN_CFG(219, ALT_B) | ||
| 654 | |||
| 655 | #define GPIO220_GPIO PIN_CFG(220, GPIO) | ||
| 656 | #define GPIO220_HSIR_DAT0 PIN_CFG(220, ALT_A) | ||
| 657 | #define GPIO220_MC3_FBCLK PIN_CFG(220, ALT_B) | ||
| 658 | #define GPIO220_SPI0_CLK PIN_CFG(220, ALT_C) | ||
| 659 | |||
| 660 | #define GPIO221_GPIO PIN_CFG(221, GPIO) | ||
| 661 | #define GPIO221_HSIR_RDY0 PIN_CFG(221, ALT_A) | ||
| 662 | #define GPIO221_MC3_CMD PIN_CFG(221, ALT_B) | ||
| 663 | |||
| 664 | #define GPIO222_GPIO PIN_CFG(222, GPIO) | ||
| 665 | #define GPIO222_HSIT_FLA0 PIN_CFG(222, ALT_A) | ||
| 666 | #define GPIO222_MC3_DAT0 PIN_CFG(222, ALT_B) | ||
| 667 | |||
| 668 | #define GPIO223_GPIO PIN_CFG(223, GPIO) | ||
| 669 | #define GPIO223_HSIT_DAT0 PIN_CFG(223, ALT_A) | ||
| 670 | #define GPIO223_MC3_DAT1 PIN_CFG(223, ALT_B) | ||
| 671 | #define GPIO223_SPI0_FRM PIN_CFG(223, ALT_C) | ||
| 672 | |||
| 673 | #define GPIO224_GPIO PIN_CFG(224, GPIO) | ||
| 674 | #define GPIO224_HSIT_RDY0 PIN_CFG(224, ALT_A) | ||
| 675 | #define GPIO224_MC3_DAT2 PIN_CFG(224, ALT_B) | ||
| 676 | #define GPIO224_SPI0_TXD PIN_CFG(224, ALT_C) | ||
| 677 | |||
| 678 | #define GPIO225_GPIO PIN_CFG(225, GPIO) | ||
| 679 | #define GPIO225_HSIT_CAWAKE0 PIN_CFG(225, ALT_A) | ||
| 680 | #define GPIO225_MC3_DAT3 PIN_CFG(225, ALT_B) | ||
| 681 | #define GPIO225_SPI0_RXD PIN_CFG(225, ALT_C) | ||
| 682 | |||
| 683 | #define GPIO226_GPIO PIN_CFG(226, GPIO) | ||
| 684 | #define GPIO226_HSIT_ACWAKE0 PIN_CFG(226, ALT_A) | ||
| 685 | #define GPIO226_PWL PIN_CFG(226, ALT_B) | ||
| 686 | #define GPIO226_USBSIM_PDC PIN_CFG(226, ALT_C) | ||
| 687 | |||
| 688 | #define GPIO227_GPIO PIN_CFG(227, GPIO) | ||
| 689 | #define GPIO227_CLKOUT1 PIN_CFG(227, ALT_A) | ||
| 690 | |||
| 691 | #define GPIO228_GPIO PIN_CFG(228, GPIO) | ||
| 692 | #define GPIO228_CLKOUT2 PIN_CFG(228, ALT_A) | ||
| 693 | |||
| 694 | #define GPIO229_GPIO PIN_CFG(229, GPIO) | ||
| 695 | #define GPIO229_CLKOUT1 PIN_CFG(229, ALT_A) | ||
| 696 | #define GPIO229_PWL PIN_CFG(229, ALT_B) | ||
| 697 | #define GPIO229_I2C3_SDA PIN_CFG_PULL(229, ALT_C, UP) | ||
| 698 | |||
| 699 | #define GPIO230_GPIO PIN_CFG(230, GPIO) | ||
| 700 | #define GPIO230_CLKOUT2 PIN_CFG(230, ALT_A) | ||
| 701 | #define GPIO230_PWL PIN_CFG(230, ALT_B) | ||
| 702 | #define GPIO230_I2C3_SCL PIN_CFG_PULL(230, ALT_C, UP) | ||
| 703 | |||
| 704 | #define GPIO256_GPIO PIN_CFG(256, GPIO) | ||
| 705 | #define GPIO256_USB_NXT PIN_CFG(256, ALT_A) | ||
| 706 | |||
| 707 | #define GPIO257_GPIO PIN_CFG(257, GPIO) | ||
| 708 | #define GPIO257_USB_STP PIN_CFG(257, ALT_A) | ||
| 709 | |||
| 710 | #define GPIO258_GPIO PIN_CFG(258, GPIO) | ||
| 711 | #define GPIO258_USB_XCLK PIN_CFG(258, ALT_A) | ||
| 712 | #define GPIO258_NONE PIN_CFG(258, ALT_B) | ||
| 713 | #define GPIO258_DDR_TRIG PIN_CFG(258, ALT_C) | ||
| 714 | |||
| 715 | #define GPIO259_GPIO PIN_CFG(259, GPIO) | ||
| 716 | #define GPIO259_USB_DIR PIN_CFG(259, ALT_A) | ||
| 717 | |||
| 718 | #define GPIO260_GPIO PIN_CFG(260, GPIO) | ||
| 719 | #define GPIO260_USB_DAT7 PIN_CFG(260, ALT_A) | ||
| 720 | |||
| 721 | #define GPIO261_GPIO PIN_CFG(261, GPIO) | ||
| 722 | #define GPIO261_USB_DAT6 PIN_CFG(261, ALT_A) | ||
| 723 | |||
| 724 | #define GPIO262_GPIO PIN_CFG(262, GPIO) | ||
| 725 | #define GPIO262_USB_DAT5 PIN_CFG(262, ALT_A) | ||
| 726 | |||
| 727 | #define GPIO263_GPIO PIN_CFG(263, GPIO) | ||
| 728 | #define GPIO263_USB_DAT4 PIN_CFG(263, ALT_A) | ||
| 729 | |||
| 730 | #define GPIO264_GPIO PIN_CFG(264, GPIO) | ||
| 731 | #define GPIO264_USB_DAT3 PIN_CFG(264, ALT_A) | ||
| 732 | |||
| 733 | #define GPIO265_GPIO PIN_CFG(265, GPIO) | ||
| 734 | #define GPIO265_USB_DAT2 PIN_CFG(265, ALT_A) | ||
| 735 | |||
| 736 | #define GPIO266_GPIO PIN_CFG(266, GPIO) | ||
| 737 | #define GPIO266_USB_DAT1 PIN_CFG(266, ALT_A) | ||
| 738 | |||
| 739 | #define GPIO267_GPIO PIN_CFG(267, GPIO) | ||
| 740 | #define GPIO267_USB_DAT0 PIN_CFG(267, ALT_A) | ||
| 741 | |||
| 742 | #endif | ||
diff --git a/arch/arm/mach-versatile/core.c b/arch/arm/mach-versatile/core.c index 3dff8641b03f..e38acb0f89c8 100644 --- a/arch/arm/mach-versatile/core.c +++ b/arch/arm/mach-versatile/core.c | |||
| @@ -28,6 +28,7 @@ | |||
| 28 | #include <linux/amba/clcd.h> | 28 | #include <linux/amba/clcd.h> |
| 29 | #include <linux/amba/pl061.h> | 29 | #include <linux/amba/pl061.h> |
| 30 | #include <linux/amba/mmci.h> | 30 | #include <linux/amba/mmci.h> |
| 31 | #include <linux/amba/pl022.h> | ||
| 31 | #include <linux/io.h> | 32 | #include <linux/io.h> |
| 32 | #include <linux/gfp.h> | 33 | #include <linux/gfp.h> |
| 33 | 34 | ||
| @@ -354,6 +355,21 @@ static struct mmci_platform_data mmc0_plat_data = { | |||
| 354 | .gpio_cd = -1, | 355 | .gpio_cd = -1, |
| 355 | }; | 356 | }; |
| 356 | 357 | ||
| 358 | static struct resource char_lcd_resources[] = { | ||
| 359 | { | ||
| 360 | .start = VERSATILE_CHAR_LCD_BASE, | ||
| 361 | .end = (VERSATILE_CHAR_LCD_BASE + SZ_4K - 1), | ||
| 362 | .flags = IORESOURCE_MEM, | ||
| 363 | }, | ||
| 364 | }; | ||
| 365 | |||
| 366 | static struct platform_device char_lcd_device = { | ||
| 367 | .name = "arm-charlcd", | ||
| 368 | .id = -1, | ||
| 369 | .num_resources = ARRAY_SIZE(char_lcd_resources), | ||
| 370 | .resource = char_lcd_resources, | ||
| 371 | }; | ||
| 372 | |||
| 357 | /* | 373 | /* |
| 358 | * Clock handling | 374 | * Clock handling |
| 359 | */ | 375 | */ |
| @@ -400,8 +416,13 @@ static struct clk ref24_clk = { | |||
| 400 | .rate = 24000000, | 416 | .rate = 24000000, |
| 401 | }; | 417 | }; |
| 402 | 418 | ||
| 419 | static struct clk dummy_apb_pclk; | ||
| 420 | |||
| 403 | static struct clk_lookup lookups[] = { | 421 | static struct clk_lookup lookups[] = { |
| 404 | { /* UART0 */ | 422 | { /* AMBA bus clock */ |
| 423 | .con_id = "apb_pclk", | ||
| 424 | .clk = &dummy_apb_pclk, | ||
| 425 | }, { /* UART0 */ | ||
| 405 | .dev_id = "dev:f1", | 426 | .dev_id = "dev:f1", |
| 406 | .clk = &ref24_clk, | 427 | .clk = &ref24_clk, |
| 407 | }, { /* UART1 */ | 428 | }, { /* UART1 */ |
| @@ -425,6 +446,9 @@ static struct clk_lookup lookups[] = { | |||
| 425 | }, { /* MMC1 */ | 446 | }, { /* MMC1 */ |
| 426 | .dev_id = "fpga:0b", | 447 | .dev_id = "fpga:0b", |
| 427 | .clk = &ref24_clk, | 448 | .clk = &ref24_clk, |
| 449 | }, { /* SSP */ | ||
| 450 | .dev_id = "dev:f4", | ||
| 451 | .clk = &ref24_clk, | ||
| 428 | }, { /* CLCD */ | 452 | }, { /* CLCD */ |
| 429 | .dev_id = "dev:20", | 453 | .dev_id = "dev:20", |
| 430 | .clk = &osc4_clk, | 454 | .clk = &osc4_clk, |
| @@ -703,6 +727,12 @@ static struct pl061_platform_data gpio1_plat_data = { | |||
| 703 | .irq_base = IRQ_GPIO1_START, | 727 | .irq_base = IRQ_GPIO1_START, |
| 704 | }; | 728 | }; |
| 705 | 729 | ||
| 730 | static struct pl022_ssp_controller ssp0_plat_data = { | ||
| 731 | .bus_id = 0, | ||
| 732 | .enable_dma = 0, | ||
| 733 | .num_chipselect = 1, | ||
| 734 | }; | ||
| 735 | |||
| 706 | #define AACI_IRQ { IRQ_AACI, NO_IRQ } | 736 | #define AACI_IRQ { IRQ_AACI, NO_IRQ } |
| 707 | #define AACI_DMA { 0x80, 0x81 } | 737 | #define AACI_DMA { 0x80, 0x81 } |
| 708 | #define MMCI0_IRQ { IRQ_MMCI0A,IRQ_SIC_MMCI0B } | 738 | #define MMCI0_IRQ { IRQ_MMCI0A,IRQ_SIC_MMCI0B } |
| @@ -772,7 +802,7 @@ AMBA_DEVICE(sci0, "dev:f0", SCI, NULL); | |||
| 772 | AMBA_DEVICE(uart0, "dev:f1", UART0, NULL); | 802 | AMBA_DEVICE(uart0, "dev:f1", UART0, NULL); |
| 773 | AMBA_DEVICE(uart1, "dev:f2", UART1, NULL); | 803 | AMBA_DEVICE(uart1, "dev:f2", UART1, NULL); |
| 774 | AMBA_DEVICE(uart2, "dev:f3", UART2, NULL); | 804 | AMBA_DEVICE(uart2, "dev:f3", UART2, NULL); |
| 775 | AMBA_DEVICE(ssp0, "dev:f4", SSP, NULL); | 805 | AMBA_DEVICE(ssp0, "dev:f4", SSP, &ssp0_plat_data); |
| 776 | 806 | ||
| 777 | static struct amba_device *amba_devs[] __initdata = { | 807 | static struct amba_device *amba_devs[] __initdata = { |
| 778 | &dmac_device, | 808 | &dmac_device, |
| @@ -843,6 +873,7 @@ void __init versatile_init(void) | |||
| 843 | platform_device_register(&versatile_flash_device); | 873 | platform_device_register(&versatile_flash_device); |
| 844 | platform_device_register(&versatile_i2c_device); | 874 | platform_device_register(&versatile_i2c_device); |
| 845 | platform_device_register(&smc91x_device); | 875 | platform_device_register(&smc91x_device); |
| 876 | platform_device_register(&char_lcd_device); | ||
| 846 | 877 | ||
| 847 | for (i = 0; i < ARRAY_SIZE(amba_devs); i++) { | 878 | for (i = 0; i < ARRAY_SIZE(amba_devs); i++) { |
| 848 | struct amba_device *d = amba_devs[i]; | 879 | struct amba_device *d = amba_devs[i]; |
diff --git a/arch/arm/mach-versatile/pci.c b/arch/arm/mach-versatile/pci.c index 334f0df4e948..13c7e5f90a82 100644 --- a/arch/arm/mach-versatile/pci.c +++ b/arch/arm/mach-versatile/pci.c | |||
| @@ -304,7 +304,7 @@ int __init pci_versatile_setup(int nr, struct pci_sys_data *sys) | |||
| 304 | } | 304 | } |
| 305 | 305 | ||
| 306 | 306 | ||
| 307 | struct pci_bus *pci_versatile_scan_bus(int nr, struct pci_sys_data *sys) | 307 | struct pci_bus * __init pci_versatile_scan_bus(int nr, struct pci_sys_data *sys) |
| 308 | { | 308 | { |
| 309 | return pci_scan_bus(sys->busnr, &pci_versatile_ops, sys); | 309 | return pci_scan_bus(sys->busnr, &pci_versatile_ops, sys); |
| 310 | } | 310 | } |
diff --git a/arch/arm/mach-vexpress/ct-ca9x4.c b/arch/arm/mach-vexpress/ct-ca9x4.c index 6353459bb567..577df6cccb08 100644 --- a/arch/arm/mach-vexpress/ct-ca9x4.c +++ b/arch/arm/mach-vexpress/ct-ca9x4.c | |||
| @@ -16,6 +16,7 @@ | |||
| 16 | #include <asm/hardware/gic.h> | 16 | #include <asm/hardware/gic.h> |
| 17 | #include <asm/mach-types.h> | 17 | #include <asm/mach-types.h> |
| 18 | #include <asm/pmu.h> | 18 | #include <asm/pmu.h> |
| 19 | #include <asm/smp_twd.h> | ||
| 19 | 20 | ||
| 20 | #include <mach/clkdev.h> | 21 | #include <mach/clkdev.h> |
| 21 | #include <mach/ct-ca9x4.h> | 22 | #include <mach/ct-ca9x4.h> |
| @@ -53,6 +54,7 @@ static struct map_desc ct_ca9x4_io_desc[] __initdata = { | |||
| 53 | 54 | ||
| 54 | static void __init ct_ca9x4_map_io(void) | 55 | static void __init ct_ca9x4_map_io(void) |
| 55 | { | 56 | { |
| 57 | twd_base = MMIO_P2V(A9_MPCORE_TWD); | ||
| 56 | v2m_map_io(ct_ca9x4_io_desc, ARRAY_SIZE(ct_ca9x4_io_desc)); | 58 | v2m_map_io(ct_ca9x4_io_desc, ARRAY_SIZE(ct_ca9x4_io_desc)); |
| 57 | } | 59 | } |
| 58 | 60 | ||
diff --git a/arch/arm/mach-vexpress/include/mach/ct-ca9x4.h b/arch/arm/mach-vexpress/include/mach/ct-ca9x4.h index 8650f04136ef..f9e2f8d22962 100644 --- a/arch/arm/mach-vexpress/include/mach/ct-ca9x4.h +++ b/arch/arm/mach-vexpress/include/mach/ct-ca9x4.h | |||
| @@ -28,6 +28,7 @@ | |||
| 28 | #define A9_MPCORE_SCU (CT_CA9X4_MPIC + 0x0000) | 28 | #define A9_MPCORE_SCU (CT_CA9X4_MPIC + 0x0000) |
| 29 | #define A9_MPCORE_GIC_CPU (CT_CA9X4_MPIC + 0x0100) | 29 | #define A9_MPCORE_GIC_CPU (CT_CA9X4_MPIC + 0x0100) |
| 30 | #define A9_MPCORE_GIT (CT_CA9X4_MPIC + 0x0200) | 30 | #define A9_MPCORE_GIT (CT_CA9X4_MPIC + 0x0200) |
| 31 | #define A9_MPCORE_TWD (CT_CA9X4_MPIC + 0x0600) | ||
| 31 | #define A9_MPCORE_GIC_DIST (CT_CA9X4_MPIC + 0x1000) | 32 | #define A9_MPCORE_GIC_DIST (CT_CA9X4_MPIC + 0x1000) |
| 32 | 33 | ||
| 33 | /* | 34 | /* |
diff --git a/arch/arm/mach-vexpress/v2m.c b/arch/arm/mach-vexpress/v2m.c index d250711b8c7a..d6db3453908b 100644 --- a/arch/arm/mach-vexpress/v2m.c +++ b/arch/arm/mach-vexpress/v2m.c | |||
| @@ -298,8 +298,13 @@ static struct clk osc2_clk = { | |||
| 298 | .rate = 24000000, | 298 | .rate = 24000000, |
| 299 | }; | 299 | }; |
| 300 | 300 | ||
| 301 | static struct clk dummy_apb_pclk; | ||
| 302 | |||
| 301 | static struct clk_lookup v2m_lookups[] = { | 303 | static struct clk_lookup v2m_lookups[] = { |
| 302 | { /* UART0 */ | 304 | { /* AMBA bus clock */ |
| 305 | .con_id = "apb_pclk", | ||
| 306 | .clk = &dummy_apb_pclk, | ||
| 307 | }, { /* UART0 */ | ||
| 303 | .dev_id = "mb:uart0", | 308 | .dev_id = "mb:uart0", |
| 304 | .clk = &osc2_clk, | 309 | .clk = &osc2_clk, |
| 305 | }, { /* UART1 */ | 310 | }, { /* UART1 */ |
diff --git a/arch/arm/mach-w90x900/cpu.c b/arch/arm/mach-w90x900/cpu.c index 642207e18198..83c56324a472 100644 --- a/arch/arm/mach-w90x900/cpu.c +++ b/arch/arm/mach-w90x900/cpu.c | |||
| @@ -93,7 +93,7 @@ static struct clk_lookup nuc900_clkregs[] = { | |||
| 93 | DEF_CLKLOOK(&clk_kpi, "nuc900-kpi", NULL), | 93 | DEF_CLKLOOK(&clk_kpi, "nuc900-kpi", NULL), |
| 94 | DEF_CLKLOOK(&clk_wdt, "nuc900-wdt", NULL), | 94 | DEF_CLKLOOK(&clk_wdt, "nuc900-wdt", NULL), |
| 95 | DEF_CLKLOOK(&clk_gdma, "nuc900-gdma", NULL), | 95 | DEF_CLKLOOK(&clk_gdma, "nuc900-gdma", NULL), |
| 96 | DEF_CLKLOOK(&clk_adc, "nuc900-adc", NULL), | 96 | DEF_CLKLOOK(&clk_adc, "nuc900-ts", NULL), |
| 97 | DEF_CLKLOOK(&clk_usi, "nuc900-spi", NULL), | 97 | DEF_CLKLOOK(&clk_usi, "nuc900-spi", NULL), |
| 98 | DEF_CLKLOOK(&clk_ext, NULL, "ext"), | 98 | DEF_CLKLOOK(&clk_ext, NULL, "ext"), |
| 99 | DEF_CLKLOOK(&clk_timer0, NULL, "timer0"), | 99 | DEF_CLKLOOK(&clk_timer0, NULL, "timer0"), |
diff --git a/arch/arm/mm/Kconfig b/arch/arm/mm/Kconfig index 101105e52610..87ec141fcaa6 100644 --- a/arch/arm/mm/Kconfig +++ b/arch/arm/mm/Kconfig | |||
| @@ -717,17 +717,6 @@ config TLS_REG_EMUL | |||
| 717 | a few prototypes like that in existence) and therefore access to | 717 | a few prototypes like that in existence) and therefore access to |
| 718 | that required register must be emulated. | 718 | that required register must be emulated. |
| 719 | 719 | ||
| 720 | config HAS_TLS_REG | ||
| 721 | bool | ||
| 722 | depends on !TLS_REG_EMUL | ||
| 723 | default y if SMP || CPU_32v7 | ||
| 724 | help | ||
| 725 | This selects support for the CP15 thread register. | ||
| 726 | It is defined to be available on some ARMv6 processors (including | ||
| 727 | all SMP capable ARMv6's) or later processors. User space may | ||
| 728 | assume directly accessing that register and always obtain the | ||
| 729 | expected value only on ARMv7 and above. | ||
| 730 | |||
| 731 | config NEEDS_SYSCALL_FOR_CMPXCHG | 720 | config NEEDS_SYSCALL_FOR_CMPXCHG |
| 732 | bool | 721 | bool |
| 733 | help | 722 | help |
diff --git a/arch/arm/mm/Makefile b/arch/arm/mm/Makefile index e8d34a80851c..d63b6c413758 100644 --- a/arch/arm/mm/Makefile +++ b/arch/arm/mm/Makefile | |||
| @@ -15,7 +15,6 @@ endif | |||
| 15 | obj-$(CONFIG_MODULES) += proc-syms.o | 15 | obj-$(CONFIG_MODULES) += proc-syms.o |
| 16 | 16 | ||
| 17 | obj-$(CONFIG_ALIGNMENT_TRAP) += alignment.o | 17 | obj-$(CONFIG_ALIGNMENT_TRAP) += alignment.o |
| 18 | obj-$(CONFIG_DISCONTIGMEM) += discontig.o | ||
| 19 | obj-$(CONFIG_HIGHMEM) += highmem.o | 18 | obj-$(CONFIG_HIGHMEM) += highmem.o |
| 20 | 19 | ||
| 21 | obj-$(CONFIG_CPU_ABRT_NOMMU) += abort-nommu.o | 20 | obj-$(CONFIG_CPU_ABRT_NOMMU) += abort-nommu.o |
diff --git a/arch/arm/mm/discontig.c b/arch/arm/mm/discontig.c deleted file mode 100644 index c8c0c4b0f0a3..000000000000 --- a/arch/arm/mm/discontig.c +++ /dev/null | |||
| @@ -1,45 +0,0 @@ | |||
| 1 | /* | ||
| 2 | * linux/arch/arm/mm/discontig.c | ||
| 3 | * | ||
| 4 | * Discontiguous memory support. | ||
| 5 | * | ||
| 6 | * Initial code: Copyright (C) 1999-2000 Nicolas Pitre | ||
| 7 | * | ||
| 8 | * This program is free software; you can redistribute it and/or modify | ||
| 9 | * it under the terms of the GNU General Public License version 2 as | ||
| 10 | * published by the Free Software Foundation. | ||
| 11 | */ | ||
| 12 | #include <linux/module.h> | ||
| 13 | #include <linux/mmzone.h> | ||
| 14 | #include <linux/bootmem.h> | ||
| 15 | |||
| 16 | #if MAX_NUMNODES != 4 && MAX_NUMNODES != 16 | ||
| 17 | # error Fix Me Please | ||
| 18 | #endif | ||
| 19 | |||
| 20 | /* | ||
| 21 | * Our node_data structure for discontiguous memory. | ||
| 22 | */ | ||
| 23 | |||
| 24 | pg_data_t discontig_node_data[MAX_NUMNODES] = { | ||
| 25 | { .bdata = &bootmem_node_data[0] }, | ||
| 26 | { .bdata = &bootmem_node_data[1] }, | ||
| 27 | { .bdata = &bootmem_node_data[2] }, | ||
| 28 | { .bdata = &bootmem_node_data[3] }, | ||
| 29 | #if MAX_NUMNODES == 16 | ||
| 30 | { .bdata = &bootmem_node_data[4] }, | ||
| 31 | { .bdata = &bootmem_node_data[5] }, | ||
| 32 | { .bdata = &bootmem_node_data[6] }, | ||
| 33 | { .bdata = &bootmem_node_data[7] }, | ||
| 34 | { .bdata = &bootmem_node_data[8] }, | ||
| 35 | { .bdata = &bootmem_node_data[9] }, | ||
| 36 | { .bdata = &bootmem_node_data[10] }, | ||
| 37 | { .bdata = &bootmem_node_data[11] }, | ||
| 38 | { .bdata = &bootmem_node_data[12] }, | ||
| 39 | { .bdata = &bootmem_node_data[13] }, | ||
| 40 | { .bdata = &bootmem_node_data[14] }, | ||
| 41 | { .bdata = &bootmem_node_data[15] }, | ||
| 42 | #endif | ||
| 43 | }; | ||
| 44 | |||
| 45 | EXPORT_SYMBOL(discontig_node_data); | ||
diff --git a/arch/arm/mm/init.c b/arch/arm/mm/init.c index f6a999465323..599d121c81e7 100644 --- a/arch/arm/mm/init.c +++ b/arch/arm/mm/init.c | |||
| @@ -17,6 +17,7 @@ | |||
| 17 | #include <linux/initrd.h> | 17 | #include <linux/initrd.h> |
| 18 | #include <linux/highmem.h> | 18 | #include <linux/highmem.h> |
| 19 | #include <linux/gfp.h> | 19 | #include <linux/gfp.h> |
| 20 | #include <linux/memblock.h> | ||
| 20 | 21 | ||
| 21 | #include <asm/mach-types.h> | 22 | #include <asm/mach-types.h> |
| 22 | #include <asm/sections.h> | 23 | #include <asm/sections.h> |
| @@ -79,38 +80,37 @@ struct meminfo meminfo; | |||
| 79 | void show_mem(void) | 80 | void show_mem(void) |
| 80 | { | 81 | { |
| 81 | int free = 0, total = 0, reserved = 0; | 82 | int free = 0, total = 0, reserved = 0; |
| 82 | int shared = 0, cached = 0, slab = 0, node, i; | 83 | int shared = 0, cached = 0, slab = 0, i; |
| 83 | struct meminfo * mi = &meminfo; | 84 | struct meminfo * mi = &meminfo; |
| 84 | 85 | ||
| 85 | printk("Mem-info:\n"); | 86 | printk("Mem-info:\n"); |
| 86 | show_free_areas(); | 87 | show_free_areas(); |
| 87 | for_each_online_node(node) { | 88 | |
| 88 | for_each_nodebank (i,mi,node) { | 89 | for_each_bank (i, mi) { |
| 89 | struct membank *bank = &mi->bank[i]; | 90 | struct membank *bank = &mi->bank[i]; |
| 90 | unsigned int pfn1, pfn2; | 91 | unsigned int pfn1, pfn2; |
| 91 | struct page *page, *end; | 92 | struct page *page, *end; |
| 92 | 93 | ||
| 93 | pfn1 = bank_pfn_start(bank); | 94 | pfn1 = bank_pfn_start(bank); |
| 94 | pfn2 = bank_pfn_end(bank); | 95 | pfn2 = bank_pfn_end(bank); |
| 95 | 96 | ||
| 96 | page = pfn_to_page(pfn1); | 97 | page = pfn_to_page(pfn1); |
| 97 | end = pfn_to_page(pfn2 - 1) + 1; | 98 | end = pfn_to_page(pfn2 - 1) + 1; |
| 98 | 99 | ||
| 99 | do { | 100 | do { |
| 100 | total++; | 101 | total++; |
| 101 | if (PageReserved(page)) | 102 | if (PageReserved(page)) |
| 102 | reserved++; | 103 | reserved++; |
| 103 | else if (PageSwapCache(page)) | 104 | else if (PageSwapCache(page)) |
| 104 | cached++; | 105 | cached++; |
| 105 | else if (PageSlab(page)) | 106 | else if (PageSlab(page)) |
| 106 | slab++; | 107 | slab++; |
| 107 | else if (!page_count(page)) | 108 | else if (!page_count(page)) |
| 108 | free++; | 109 | free++; |
| 109 | else | 110 | else |
| 110 | shared += page_count(page) - 1; | 111 | shared += page_count(page) - 1; |
| 111 | page++; | 112 | page++; |
| 112 | } while (page < end); | 113 | } while (page < end); |
| 113 | } | ||
| 114 | } | 114 | } |
| 115 | 115 | ||
| 116 | printk("%d pages of RAM\n", total); | 116 | printk("%d pages of RAM\n", total); |
| @@ -121,7 +121,7 @@ void show_mem(void) | |||
| 121 | printk("%d pages swap cached\n", cached); | 121 | printk("%d pages swap cached\n", cached); |
| 122 | } | 122 | } |
| 123 | 123 | ||
| 124 | static void __init find_node_limits(int node, struct meminfo *mi, | 124 | static void __init find_limits(struct meminfo *mi, |
| 125 | unsigned long *min, unsigned long *max_low, unsigned long *max_high) | 125 | unsigned long *min, unsigned long *max_low, unsigned long *max_high) |
| 126 | { | 126 | { |
| 127 | int i; | 127 | int i; |
| @@ -129,7 +129,7 @@ static void __init find_node_limits(int node, struct meminfo *mi, | |||
| 129 | *min = -1UL; | 129 | *min = -1UL; |
| 130 | *max_low = *max_high = 0; | 130 | *max_low = *max_high = 0; |
| 131 | 131 | ||
| 132 | for_each_nodebank(i, mi, node) { | 132 | for_each_bank (i, mi) { |
| 133 | struct membank *bank = &mi->bank[i]; | 133 | struct membank *bank = &mi->bank[i]; |
| 134 | unsigned long start, end; | 134 | unsigned long start, end; |
| 135 | 135 | ||
| @@ -147,155 +147,64 @@ static void __init find_node_limits(int node, struct meminfo *mi, | |||
| 147 | } | 147 | } |
| 148 | } | 148 | } |
| 149 | 149 | ||
| 150 | /* | 150 | static void __init arm_bootmem_init(struct meminfo *mi, |
| 151 | * FIXME: We really want to avoid allocating the bootmap bitmap | ||
| 152 | * over the top of the initrd. Hopefully, this is located towards | ||
| 153 | * the start of a bank, so if we allocate the bootmap bitmap at | ||
| 154 | * the end, we won't clash. | ||
| 155 | */ | ||
| 156 | static unsigned int __init | ||
| 157 | find_bootmap_pfn(int node, struct meminfo *mi, unsigned int bootmap_pages) | ||
| 158 | { | ||
| 159 | unsigned int start_pfn, i, bootmap_pfn; | ||
| 160 | |||
| 161 | start_pfn = PAGE_ALIGN(__pa(_end)) >> PAGE_SHIFT; | ||
| 162 | bootmap_pfn = 0; | ||
| 163 | |||
| 164 | for_each_nodebank(i, mi, node) { | ||
| 165 | struct membank *bank = &mi->bank[i]; | ||
| 166 | unsigned int start, end; | ||
| 167 | |||
| 168 | start = bank_pfn_start(bank); | ||
| 169 | end = bank_pfn_end(bank); | ||
| 170 | |||
| 171 | if (end < start_pfn) | ||
| 172 | continue; | ||
| 173 | |||
| 174 | if (start < start_pfn) | ||
| 175 | start = start_pfn; | ||
| 176 | |||
| 177 | if (end <= start) | ||
| 178 | continue; | ||
| 179 | |||
| 180 | if (end - start >= bootmap_pages) { | ||
| 181 | bootmap_pfn = start; | ||
| 182 | break; | ||
| 183 | } | ||
| 184 | } | ||
| 185 | |||
| 186 | if (bootmap_pfn == 0) | ||
| 187 | BUG(); | ||
| 188 | |||
| 189 | return bootmap_pfn; | ||
| 190 | } | ||
| 191 | |||
| 192 | static int __init check_initrd(struct meminfo *mi) | ||
| 193 | { | ||
| 194 | int initrd_node = -2; | ||
| 195 | #ifdef CONFIG_BLK_DEV_INITRD | ||
| 196 | unsigned long end = phys_initrd_start + phys_initrd_size; | ||
| 197 | |||
| 198 | /* | ||
| 199 | * Make sure that the initrd is within a valid area of | ||
| 200 | * memory. | ||
| 201 | */ | ||
| 202 | if (phys_initrd_size) { | ||
| 203 | unsigned int i; | ||
| 204 | |||
| 205 | initrd_node = -1; | ||
| 206 | |||
| 207 | for (i = 0; i < mi->nr_banks; i++) { | ||
| 208 | struct membank *bank = &mi->bank[i]; | ||
| 209 | if (bank_phys_start(bank) <= phys_initrd_start && | ||
| 210 | end <= bank_phys_end(bank)) | ||
| 211 | initrd_node = bank->node; | ||
| 212 | } | ||
| 213 | } | ||
| 214 | |||
| 215 | if (initrd_node == -1) { | ||
| 216 | printk(KERN_ERR "INITRD: 0x%08lx+0x%08lx extends beyond " | ||
| 217 | "physical memory - disabling initrd\n", | ||
| 218 | phys_initrd_start, phys_initrd_size); | ||
| 219 | phys_initrd_start = phys_initrd_size = 0; | ||
| 220 | } | ||
| 221 | #endif | ||
| 222 | |||
| 223 | return initrd_node; | ||
| 224 | } | ||
| 225 | |||
| 226 | static void __init bootmem_init_node(int node, struct meminfo *mi, | ||
| 227 | unsigned long start_pfn, unsigned long end_pfn) | 151 | unsigned long start_pfn, unsigned long end_pfn) |
| 228 | { | 152 | { |
| 229 | unsigned long boot_pfn; | ||
| 230 | unsigned int boot_pages; | 153 | unsigned int boot_pages; |
| 154 | phys_addr_t bitmap; | ||
| 231 | pg_data_t *pgdat; | 155 | pg_data_t *pgdat; |
| 232 | int i; | 156 | int i; |
| 233 | 157 | ||
| 234 | /* | 158 | /* |
| 235 | * Allocate the bootmem bitmap page. | 159 | * Allocate the bootmem bitmap page. This must be in a region |
| 160 | * of memory which has already been mapped. | ||
| 236 | */ | 161 | */ |
| 237 | boot_pages = bootmem_bootmap_pages(end_pfn - start_pfn); | 162 | boot_pages = bootmem_bootmap_pages(end_pfn - start_pfn); |
| 238 | boot_pfn = find_bootmap_pfn(node, mi, boot_pages); | 163 | bitmap = memblock_alloc_base(boot_pages << PAGE_SHIFT, L1_CACHE_BYTES, |
| 164 | __pfn_to_phys(end_pfn)); | ||
| 239 | 165 | ||
| 240 | /* | 166 | /* |
| 241 | * Initialise the bootmem allocator for this node, handing the | 167 | * Initialise the bootmem allocator, handing the |
| 242 | * memory banks over to bootmem. | 168 | * memory banks over to bootmem. |
| 243 | */ | 169 | */ |
| 244 | node_set_online(node); | 170 | node_set_online(0); |
| 245 | pgdat = NODE_DATA(node); | 171 | pgdat = NODE_DATA(0); |
| 246 | init_bootmem_node(pgdat, boot_pfn, start_pfn, end_pfn); | 172 | init_bootmem_node(pgdat, __phys_to_pfn(bitmap), start_pfn, end_pfn); |
| 247 | 173 | ||
| 248 | for_each_nodebank(i, mi, node) { | 174 | for_each_bank(i, mi) { |
| 249 | struct membank *bank = &mi->bank[i]; | 175 | struct membank *bank = &mi->bank[i]; |
| 250 | if (!bank->highmem) | 176 | if (!bank->highmem) |
| 251 | free_bootmem_node(pgdat, bank_phys_start(bank), bank_phys_size(bank)); | 177 | free_bootmem(bank_phys_start(bank), bank_phys_size(bank)); |
| 252 | } | 178 | } |
| 253 | 179 | ||
| 254 | /* | 180 | /* |
| 255 | * Reserve the bootmem bitmap for this node. | 181 | * Reserve the memblock reserved regions in bootmem. |
| 256 | */ | 182 | */ |
| 257 | reserve_bootmem_node(pgdat, boot_pfn << PAGE_SHIFT, | 183 | for (i = 0; i < memblock.reserved.cnt; i++) { |
| 258 | boot_pages << PAGE_SHIFT, BOOTMEM_DEFAULT); | 184 | phys_addr_t start = memblock_start_pfn(&memblock.reserved, i); |
| 259 | } | 185 | if (start >= start_pfn && |
| 260 | 186 | memblock_end_pfn(&memblock.reserved, i) <= end_pfn) | |
| 261 | static void __init bootmem_reserve_initrd(int node) | 187 | reserve_bootmem_node(pgdat, __pfn_to_phys(start), |
| 262 | { | 188 | memblock_size_bytes(&memblock.reserved, i), |
| 263 | #ifdef CONFIG_BLK_DEV_INITRD | 189 | BOOTMEM_DEFAULT); |
| 264 | pg_data_t *pgdat = NODE_DATA(node); | ||
| 265 | int res; | ||
| 266 | |||
| 267 | res = reserve_bootmem_node(pgdat, phys_initrd_start, | ||
| 268 | phys_initrd_size, BOOTMEM_EXCLUSIVE); | ||
| 269 | |||
| 270 | if (res == 0) { | ||
| 271 | initrd_start = __phys_to_virt(phys_initrd_start); | ||
| 272 | initrd_end = initrd_start + phys_initrd_size; | ||
| 273 | } else { | ||
| 274 | printk(KERN_ERR | ||
| 275 | "INITRD: 0x%08lx+0x%08lx overlaps in-use " | ||
| 276 | "memory region - disabling initrd\n", | ||
| 277 | phys_initrd_start, phys_initrd_size); | ||
| 278 | } | 190 | } |
| 279 | #endif | ||
| 280 | } | 191 | } |
| 281 | 192 | ||
| 282 | static void __init bootmem_free_node(int node, struct meminfo *mi) | 193 | static void __init arm_bootmem_free(struct meminfo *mi, unsigned long min, |
| 194 | unsigned long max_low, unsigned long max_high) | ||
| 283 | { | 195 | { |
| 284 | unsigned long zone_size[MAX_NR_ZONES], zhole_size[MAX_NR_ZONES]; | 196 | unsigned long zone_size[MAX_NR_ZONES], zhole_size[MAX_NR_ZONES]; |
| 285 | unsigned long min, max_low, max_high; | ||
| 286 | int i; | 197 | int i; |
| 287 | 198 | ||
| 288 | find_node_limits(node, mi, &min, &max_low, &max_high); | ||
| 289 | |||
| 290 | /* | 199 | /* |
| 291 | * initialise the zones within this node. | 200 | * initialise the zones. |
| 292 | */ | 201 | */ |
| 293 | memset(zone_size, 0, sizeof(zone_size)); | 202 | memset(zone_size, 0, sizeof(zone_size)); |
| 294 | 203 | ||
| 295 | /* | 204 | /* |
| 296 | * The size of this node has already been determined. If we need | 205 | * The memory size has already been determined. If we need |
| 297 | * to do anything fancy with the allocation of this memory to the | 206 | * to do anything fancy with the allocation of this memory |
| 298 | * zones, now is the time to do it. | 207 | * to the zones, now is the time to do it. |
| 299 | */ | 208 | */ |
| 300 | zone_size[0] = max_low - min; | 209 | zone_size[0] = max_low - min; |
| 301 | #ifdef CONFIG_HIGHMEM | 210 | #ifdef CONFIG_HIGHMEM |
| @@ -303,11 +212,11 @@ static void __init bootmem_free_node(int node, struct meminfo *mi) | |||
| 303 | #endif | 212 | #endif |
| 304 | 213 | ||
| 305 | /* | 214 | /* |
| 306 | * For each bank in this node, calculate the size of the holes. | 215 | * Calculate the size of the holes. |
| 307 | * holes = node_size - sum(bank_sizes_in_node) | 216 | * holes = node_size - sum(bank_sizes) |
| 308 | */ | 217 | */ |
| 309 | memcpy(zhole_size, zone_size, sizeof(zhole_size)); | 218 | memcpy(zhole_size, zone_size, sizeof(zhole_size)); |
| 310 | for_each_nodebank(i, mi, node) { | 219 | for_each_bank(i, mi) { |
| 311 | int idx = 0; | 220 | int idx = 0; |
| 312 | #ifdef CONFIG_HIGHMEM | 221 | #ifdef CONFIG_HIGHMEM |
| 313 | if (mi->bank[i].highmem) | 222 | if (mi->bank[i].highmem) |
| @@ -320,24 +229,23 @@ static void __init bootmem_free_node(int node, struct meminfo *mi) | |||
| 320 | * Adjust the sizes according to any special requirements for | 229 | * Adjust the sizes according to any special requirements for |
| 321 | * this machine type. | 230 | * this machine type. |
| 322 | */ | 231 | */ |
| 323 | arch_adjust_zones(node, zone_size, zhole_size); | 232 | arch_adjust_zones(zone_size, zhole_size); |
| 324 | 233 | ||
| 325 | free_area_init_node(node, zone_size, min, zhole_size); | 234 | free_area_init_node(0, zone_size, min, zhole_size); |
| 326 | } | 235 | } |
| 327 | 236 | ||
| 328 | #ifndef CONFIG_SPARSEMEM | 237 | #ifndef CONFIG_SPARSEMEM |
| 329 | int pfn_valid(unsigned long pfn) | 238 | int pfn_valid(unsigned long pfn) |
| 330 | { | 239 | { |
| 331 | struct meminfo *mi = &meminfo; | 240 | struct memblock_region *mem = &memblock.memory; |
| 332 | unsigned int left = 0, right = mi->nr_banks; | 241 | unsigned int left = 0, right = mem->cnt; |
| 333 | 242 | ||
| 334 | do { | 243 | do { |
| 335 | unsigned int mid = (right + left) / 2; | 244 | unsigned int mid = (right + left) / 2; |
| 336 | struct membank *bank = &mi->bank[mid]; | ||
| 337 | 245 | ||
| 338 | if (pfn < bank_pfn_start(bank)) | 246 | if (pfn < memblock_start_pfn(mem, mid)) |
| 339 | right = mid; | 247 | right = mid; |
| 340 | else if (pfn >= bank_pfn_end(bank)) | 248 | else if (pfn >= memblock_end_pfn(mem, mid)) |
| 341 | left = mid + 1; | 249 | left = mid + 1; |
| 342 | else | 250 | else |
| 343 | return 1; | 251 | return 1; |
| @@ -346,73 +254,69 @@ int pfn_valid(unsigned long pfn) | |||
| 346 | } | 254 | } |
| 347 | EXPORT_SYMBOL(pfn_valid); | 255 | EXPORT_SYMBOL(pfn_valid); |
| 348 | 256 | ||
| 349 | static void arm_memory_present(struct meminfo *mi, int node) | 257 | static void arm_memory_present(void) |
| 350 | { | 258 | { |
| 351 | } | 259 | } |
| 352 | #else | 260 | #else |
| 353 | static void arm_memory_present(struct meminfo *mi, int node) | 261 | static void arm_memory_present(void) |
| 354 | { | 262 | { |
| 355 | int i; | 263 | int i; |
| 356 | for_each_nodebank(i, mi, node) { | 264 | for (i = 0; i < memblock.memory.cnt; i++) |
| 357 | struct membank *bank = &mi->bank[i]; | 265 | memory_present(0, memblock_start_pfn(&memblock.memory, i), |
| 358 | memory_present(node, bank_pfn_start(bank), bank_pfn_end(bank)); | 266 | memblock_end_pfn(&memblock.memory, i)); |
| 359 | } | ||
| 360 | } | 267 | } |
| 361 | #endif | 268 | #endif |
| 362 | 269 | ||
| 363 | void __init bootmem_init(void) | 270 | void __init arm_memblock_init(struct meminfo *mi, struct machine_desc *mdesc) |
| 364 | { | 271 | { |
| 365 | struct meminfo *mi = &meminfo; | 272 | int i; |
| 366 | unsigned long min, max_low, max_high; | ||
| 367 | int node, initrd_node; | ||
| 368 | 273 | ||
| 369 | /* | 274 | memblock_init(); |
| 370 | * Locate which node contains the ramdisk image, if any. | 275 | for (i = 0; i < mi->nr_banks; i++) |
| 371 | */ | 276 | memblock_add(mi->bank[i].start, mi->bank[i].size); |
| 372 | initrd_node = check_initrd(mi); | ||
| 373 | 277 | ||
| 374 | max_low = max_high = 0; | 278 | /* Register the kernel text, kernel data and initrd with memblock. */ |
| 279 | #ifdef CONFIG_XIP_KERNEL | ||
| 280 | memblock_reserve(__pa(_data), _end - _data); | ||
| 281 | #else | ||
| 282 | memblock_reserve(__pa(_stext), _end - _stext); | ||
| 283 | #endif | ||
| 284 | #ifdef CONFIG_BLK_DEV_INITRD | ||
| 285 | if (phys_initrd_size) { | ||
| 286 | memblock_reserve(phys_initrd_start, phys_initrd_size); | ||
| 375 | 287 | ||
| 376 | /* | 288 | /* Now convert initrd to virtual addresses */ |
| 377 | * Run through each node initialising the bootmem allocator. | 289 | initrd_start = __phys_to_virt(phys_initrd_start); |
| 378 | */ | 290 | initrd_end = initrd_start + phys_initrd_size; |
| 379 | for_each_node(node) { | 291 | } |
| 380 | unsigned long node_low, node_high; | 292 | #endif |
| 381 | 293 | ||
| 382 | find_node_limits(node, mi, &min, &node_low, &node_high); | 294 | arm_mm_memblock_reserve(); |
| 383 | 295 | ||
| 384 | if (node_low > max_low) | 296 | /* reserve any platform specific memblock areas */ |
| 385 | max_low = node_low; | 297 | if (mdesc->reserve) |
| 386 | if (node_high > max_high) | 298 | mdesc->reserve(); |
| 387 | max_high = node_high; | ||
| 388 | 299 | ||
| 389 | /* | 300 | memblock_analyze(); |
| 390 | * If there is no memory in this node, ignore it. | 301 | memblock_dump_all(); |
| 391 | * (We can't have nodes which have no lowmem) | 302 | } |
| 392 | */ | ||
| 393 | if (node_low == 0) | ||
| 394 | continue; | ||
| 395 | 303 | ||
| 396 | bootmem_init_node(node, mi, min, node_low); | 304 | void __init bootmem_init(void) |
| 305 | { | ||
| 306 | struct meminfo *mi = &meminfo; | ||
| 307 | unsigned long min, max_low, max_high; | ||
| 397 | 308 | ||
| 398 | /* | 309 | max_low = max_high = 0; |
| 399 | * Reserve any special node zero regions. | ||
| 400 | */ | ||
| 401 | if (node == 0) | ||
| 402 | reserve_node_zero(NODE_DATA(node)); | ||
| 403 | 310 | ||
| 404 | /* | 311 | find_limits(mi, &min, &max_low, &max_high); |
| 405 | * If the initrd is in this node, reserve its memory. | ||
| 406 | */ | ||
| 407 | if (node == initrd_node) | ||
| 408 | bootmem_reserve_initrd(node); | ||
| 409 | 312 | ||
| 410 | /* | 313 | arm_bootmem_init(mi, min, max_low); |
| 411 | * Sparsemem tries to allocate bootmem in memory_present(), | 314 | |
| 412 | * so must be done after the fixed reservations | 315 | /* |
| 413 | */ | 316 | * Sparsemem tries to allocate bootmem in memory_present(), |
| 414 | arm_memory_present(mi, node); | 317 | * so must be done after the fixed reservations |
| 415 | } | 318 | */ |
| 319 | arm_memory_present(); | ||
| 416 | 320 | ||
| 417 | /* | 321 | /* |
| 418 | * sparse_init() needs the bootmem allocator up and running. | 322 | * sparse_init() needs the bootmem allocator up and running. |
| @@ -420,12 +324,11 @@ void __init bootmem_init(void) | |||
| 420 | sparse_init(); | 324 | sparse_init(); |
| 421 | 325 | ||
| 422 | /* | 326 | /* |
| 423 | * Now free memory in each node - free_area_init_node needs | 327 | * Now free the memory - free_area_init_node needs |
| 424 | * the sparse mem_map arrays initialized by sparse_init() | 328 | * the sparse mem_map arrays initialized by sparse_init() |
| 425 | * for memmap_init_zone(), otherwise all PFNs are invalid. | 329 | * for memmap_init_zone(), otherwise all PFNs are invalid. |
| 426 | */ | 330 | */ |
| 427 | for_each_node(node) | 331 | arm_bootmem_free(mi, min, max_low, max_high); |
| 428 | bootmem_free_node(node, mi); | ||
| 429 | 332 | ||
| 430 | high_memory = __va((max_low << PAGE_SHIFT) - 1) + 1; | 333 | high_memory = __va((max_low << PAGE_SHIFT) - 1) + 1; |
| 431 | 334 | ||
| @@ -460,7 +363,7 @@ static inline int free_area(unsigned long pfn, unsigned long end, char *s) | |||
| 460 | } | 363 | } |
| 461 | 364 | ||
| 462 | static inline void | 365 | static inline void |
| 463 | free_memmap(int node, unsigned long start_pfn, unsigned long end_pfn) | 366 | free_memmap(unsigned long start_pfn, unsigned long end_pfn) |
| 464 | { | 367 | { |
| 465 | struct page *start_pg, *end_pg; | 368 | struct page *start_pg, *end_pg; |
| 466 | unsigned long pg, pgend; | 369 | unsigned long pg, pgend; |
| @@ -483,13 +386,13 @@ free_memmap(int node, unsigned long start_pfn, unsigned long end_pfn) | |||
| 483 | * free the section of the memmap array. | 386 | * free the section of the memmap array. |
| 484 | */ | 387 | */ |
| 485 | if (pg < pgend) | 388 | if (pg < pgend) |
| 486 | free_bootmem_node(NODE_DATA(node), pg, pgend - pg); | 389 | free_bootmem(pg, pgend - pg); |
| 487 | } | 390 | } |
| 488 | 391 | ||
| 489 | /* | 392 | /* |
| 490 | * The mem_map array can get very big. Free the unused area of the memory map. | 393 | * The mem_map array can get very big. Free the unused area of the memory map. |
| 491 | */ | 394 | */ |
| 492 | static void __init free_unused_memmap_node(int node, struct meminfo *mi) | 395 | static void __init free_unused_memmap(struct meminfo *mi) |
| 493 | { | 396 | { |
| 494 | unsigned long bank_start, prev_bank_end = 0; | 397 | unsigned long bank_start, prev_bank_end = 0; |
| 495 | unsigned int i; | 398 | unsigned int i; |
| @@ -499,7 +402,7 @@ static void __init free_unused_memmap_node(int node, struct meminfo *mi) | |||
| 499 | * may not be the case, especially if the user has provided the | 402 | * may not be the case, especially if the user has provided the |
| 500 | * information on the command line. | 403 | * information on the command line. |
| 501 | */ | 404 | */ |
| 502 | for_each_nodebank(i, mi, node) { | 405 | for_each_bank(i, mi) { |
| 503 | struct membank *bank = &mi->bank[i]; | 406 | struct membank *bank = &mi->bank[i]; |
| 504 | 407 | ||
| 505 | bank_start = bank_pfn_start(bank); | 408 | bank_start = bank_pfn_start(bank); |
| @@ -514,7 +417,7 @@ static void __init free_unused_memmap_node(int node, struct meminfo *mi) | |||
| 514 | * between the current bank and the previous, free it. | 417 | * between the current bank and the previous, free it. |
| 515 | */ | 418 | */ |
| 516 | if (prev_bank_end && prev_bank_end != bank_start) | 419 | if (prev_bank_end && prev_bank_end != bank_start) |
| 517 | free_memmap(node, prev_bank_end, bank_start); | 420 | free_memmap(prev_bank_end, bank_start); |
| 518 | 421 | ||
| 519 | prev_bank_end = bank_pfn_end(bank); | 422 | prev_bank_end = bank_pfn_end(bank); |
| 520 | } | 423 | } |
| @@ -528,21 +431,14 @@ static void __init free_unused_memmap_node(int node, struct meminfo *mi) | |||
| 528 | void __init mem_init(void) | 431 | void __init mem_init(void) |
| 529 | { | 432 | { |
| 530 | unsigned long reserved_pages, free_pages; | 433 | unsigned long reserved_pages, free_pages; |
| 531 | int i, node; | 434 | int i; |
| 532 | 435 | ||
| 533 | #ifndef CONFIG_DISCONTIGMEM | ||
| 534 | max_mapnr = pfn_to_page(max_pfn + PHYS_PFN_OFFSET) - mem_map; | 436 | max_mapnr = pfn_to_page(max_pfn + PHYS_PFN_OFFSET) - mem_map; |
| 535 | #endif | ||
| 536 | 437 | ||
| 537 | /* this will put all unused low memory onto the freelists */ | 438 | /* this will put all unused low memory onto the freelists */ |
| 538 | for_each_online_node(node) { | 439 | free_unused_memmap(&meminfo); |
| 539 | pg_data_t *pgdat = NODE_DATA(node); | ||
| 540 | |||
| 541 | free_unused_memmap_node(node, &meminfo); | ||
| 542 | 440 | ||
| 543 | if (pgdat->node_spanned_pages != 0) | 441 | totalram_pages += free_all_bootmem(); |
| 544 | totalram_pages += free_all_bootmem_node(pgdat); | ||
| 545 | } | ||
| 546 | 442 | ||
| 547 | #ifdef CONFIG_SA1111 | 443 | #ifdef CONFIG_SA1111 |
| 548 | /* now that our DMA memory is actually so designated, we can free it */ | 444 | /* now that our DMA memory is actually so designated, we can free it */ |
| @@ -552,39 +448,35 @@ void __init mem_init(void) | |||
| 552 | 448 | ||
| 553 | #ifdef CONFIG_HIGHMEM | 449 | #ifdef CONFIG_HIGHMEM |
| 554 | /* set highmem page free */ | 450 | /* set highmem page free */ |
| 555 | for_each_online_node(node) { | 451 | for_each_bank (i, &meminfo) { |
| 556 | for_each_nodebank (i, &meminfo, node) { | 452 | unsigned long start = bank_pfn_start(&meminfo.bank[i]); |
| 557 | unsigned long start = bank_pfn_start(&meminfo.bank[i]); | 453 | unsigned long end = bank_pfn_end(&meminfo.bank[i]); |
| 558 | unsigned long end = bank_pfn_end(&meminfo.bank[i]); | 454 | if (start >= max_low_pfn + PHYS_PFN_OFFSET) |
| 559 | if (start >= max_low_pfn + PHYS_PFN_OFFSET) | 455 | totalhigh_pages += free_area(start, end, NULL); |
| 560 | totalhigh_pages += free_area(start, end, NULL); | ||
| 561 | } | ||
| 562 | } | 456 | } |
| 563 | totalram_pages += totalhigh_pages; | 457 | totalram_pages += totalhigh_pages; |
| 564 | #endif | 458 | #endif |
| 565 | 459 | ||
| 566 | reserved_pages = free_pages = 0; | 460 | reserved_pages = free_pages = 0; |
| 567 | 461 | ||
| 568 | for_each_online_node(node) { | 462 | for_each_bank(i, &meminfo) { |
| 569 | for_each_nodebank(i, &meminfo, node) { | 463 | struct membank *bank = &meminfo.bank[i]; |
| 570 | struct membank *bank = &meminfo.bank[i]; | 464 | unsigned int pfn1, pfn2; |
| 571 | unsigned int pfn1, pfn2; | 465 | struct page *page, *end; |
| 572 | struct page *page, *end; | 466 | |
| 573 | 467 | pfn1 = bank_pfn_start(bank); | |
| 574 | pfn1 = bank_pfn_start(bank); | 468 | pfn2 = bank_pfn_end(bank); |
| 575 | pfn2 = bank_pfn_end(bank); | 469 | |
| 576 | 470 | page = pfn_to_page(pfn1); | |
| 577 | page = pfn_to_page(pfn1); | 471 | end = pfn_to_page(pfn2 - 1) + 1; |
| 578 | end = pfn_to_page(pfn2 - 1) + 1; | 472 | |
| 579 | 473 | do { | |
| 580 | do { | 474 | if (PageReserved(page)) |
| 581 | if (PageReserved(page)) | 475 | reserved_pages++; |
| 582 | reserved_pages++; | 476 | else if (!page_count(page)) |
| 583 | else if (!page_count(page)) | 477 | free_pages++; |
| 584 | free_pages++; | 478 | page++; |
| 585 | page++; | 479 | } while (page < end); |
| 586 | } while (page < end); | ||
| 587 | } | ||
| 588 | } | 480 | } |
| 589 | 481 | ||
| 590 | /* | 482 | /* |
diff --git a/arch/arm/mm/ioremap.c b/arch/arm/mm/ioremap.c index 28c8b950ef04..03f11935ed08 100644 --- a/arch/arm/mm/ioremap.c +++ b/arch/arm/mm/ioremap.c | |||
| @@ -268,6 +268,12 @@ void __iomem * __arm_ioremap_pfn_caller(unsigned long pfn, | |||
| 268 | if (pfn >= 0x100000 && (__pfn_to_phys(pfn) & ~SUPERSECTION_MASK)) | 268 | if (pfn >= 0x100000 && (__pfn_to_phys(pfn) & ~SUPERSECTION_MASK)) |
| 269 | return NULL; | 269 | return NULL; |
| 270 | 270 | ||
| 271 | /* | ||
| 272 | * Don't allow RAM to be mapped - this causes problems with ARMv6+ | ||
| 273 | */ | ||
| 274 | if (WARN_ON(pfn_valid(pfn))) | ||
| 275 | return NULL; | ||
| 276 | |||
| 271 | type = get_mem_type(mtype); | 277 | type = get_mem_type(mtype); |
| 272 | if (!type) | 278 | if (!type) |
| 273 | return NULL; | 279 | return NULL; |
diff --git a/arch/arm/mm/mm.h b/arch/arm/mm/mm.h index 815d08eecbb0..6630620380a4 100644 --- a/arch/arm/mm/mm.h +++ b/arch/arm/mm/mm.h | |||
| @@ -28,7 +28,5 @@ extern void __flush_dcache_page(struct address_space *mapping, struct page *page | |||
| 28 | 28 | ||
| 29 | #endif | 29 | #endif |
| 30 | 30 | ||
| 31 | struct pglist_data; | ||
| 32 | |||
| 33 | void __init bootmem_init(void); | 31 | void __init bootmem_init(void); |
| 34 | void reserve_node_zero(struct pglist_data *pgdat); | 32 | void arm_mm_memblock_reserve(void); |
diff --git a/arch/arm/mm/mmu.c b/arch/arm/mm/mmu.c index 285894171186..d5541adc3520 100644 --- a/arch/arm/mm/mmu.c +++ b/arch/arm/mm/mmu.c | |||
| @@ -11,13 +11,12 @@ | |||
| 11 | #include <linux/kernel.h> | 11 | #include <linux/kernel.h> |
| 12 | #include <linux/errno.h> | 12 | #include <linux/errno.h> |
| 13 | #include <linux/init.h> | 13 | #include <linux/init.h> |
| 14 | #include <linux/bootmem.h> | ||
| 15 | #include <linux/mman.h> | 14 | #include <linux/mman.h> |
| 16 | #include <linux/nodemask.h> | 15 | #include <linux/nodemask.h> |
| 16 | #include <linux/memblock.h> | ||
| 17 | #include <linux/sort.h> | 17 | #include <linux/sort.h> |
| 18 | 18 | ||
| 19 | #include <asm/cputype.h> | 19 | #include <asm/cputype.h> |
| 20 | #include <asm/mach-types.h> | ||
| 21 | #include <asm/sections.h> | 20 | #include <asm/sections.h> |
| 22 | #include <asm/cachetype.h> | 21 | #include <asm/cachetype.h> |
| 23 | #include <asm/setup.h> | 22 | #include <asm/setup.h> |
| @@ -488,18 +487,28 @@ static void __init build_mem_type_table(void) | |||
| 488 | 487 | ||
| 489 | #define vectors_base() (vectors_high() ? 0xffff0000 : 0) | 488 | #define vectors_base() (vectors_high() ? 0xffff0000 : 0) |
| 490 | 489 | ||
| 491 | static void __init alloc_init_pte(pmd_t *pmd, unsigned long addr, | 490 | static void __init *early_alloc(unsigned long sz) |
| 492 | unsigned long end, unsigned long pfn, | ||
| 493 | const struct mem_type *type) | ||
| 494 | { | 491 | { |
| 495 | pte_t *pte; | 492 | void *ptr = __va(memblock_alloc(sz, sz)); |
| 493 | memset(ptr, 0, sz); | ||
| 494 | return ptr; | ||
| 495 | } | ||
| 496 | 496 | ||
| 497 | static pte_t * __init early_pte_alloc(pmd_t *pmd, unsigned long addr, unsigned long prot) | ||
| 498 | { | ||
| 497 | if (pmd_none(*pmd)) { | 499 | if (pmd_none(*pmd)) { |
| 498 | pte = alloc_bootmem_low_pages(2 * PTRS_PER_PTE * sizeof(pte_t)); | 500 | pte_t *pte = early_alloc(2 * PTRS_PER_PTE * sizeof(pte_t)); |
| 499 | __pmd_populate(pmd, __pa(pte) | type->prot_l1); | 501 | __pmd_populate(pmd, __pa(pte) | prot); |
| 500 | } | 502 | } |
| 503 | BUG_ON(pmd_bad(*pmd)); | ||
| 504 | return pte_offset_kernel(pmd, addr); | ||
| 505 | } | ||
| 501 | 506 | ||
| 502 | pte = pte_offset_kernel(pmd, addr); | 507 | static void __init alloc_init_pte(pmd_t *pmd, unsigned long addr, |
| 508 | unsigned long end, unsigned long pfn, | ||
| 509 | const struct mem_type *type) | ||
| 510 | { | ||
| 511 | pte_t *pte = early_pte_alloc(pmd, addr, type->prot_l1); | ||
| 503 | do { | 512 | do { |
| 504 | set_pte_ext(pte, pfn_pte(pfn, __pgprot(type->prot_pte)), 0); | 513 | set_pte_ext(pte, pfn_pte(pfn, __pgprot(type->prot_pte)), 0); |
| 505 | pfn++; | 514 | pfn++; |
| @@ -668,7 +677,7 @@ void __init iotable_init(struct map_desc *io_desc, int nr) | |||
| 668 | create_mapping(io_desc + i); | 677 | create_mapping(io_desc + i); |
| 669 | } | 678 | } |
| 670 | 679 | ||
| 671 | static unsigned long __initdata vmalloc_reserve = SZ_128M; | 680 | static void * __initdata vmalloc_min = (void *)(VMALLOC_END - SZ_128M); |
| 672 | 681 | ||
| 673 | /* | 682 | /* |
| 674 | * vmalloc=size forces the vmalloc area to be exactly 'size' | 683 | * vmalloc=size forces the vmalloc area to be exactly 'size' |
| @@ -677,7 +686,7 @@ static unsigned long __initdata vmalloc_reserve = SZ_128M; | |||
| 677 | */ | 686 | */ |
| 678 | static int __init early_vmalloc(char *arg) | 687 | static int __init early_vmalloc(char *arg) |
| 679 | { | 688 | { |
| 680 | vmalloc_reserve = memparse(arg, NULL); | 689 | unsigned long vmalloc_reserve = memparse(arg, NULL); |
| 681 | 690 | ||
| 682 | if (vmalloc_reserve < SZ_16M) { | 691 | if (vmalloc_reserve < SZ_16M) { |
| 683 | vmalloc_reserve = SZ_16M; | 692 | vmalloc_reserve = SZ_16M; |
| @@ -692,22 +701,26 @@ static int __init early_vmalloc(char *arg) | |||
| 692 | "vmalloc area is too big, limiting to %luMB\n", | 701 | "vmalloc area is too big, limiting to %luMB\n", |
| 693 | vmalloc_reserve >> 20); | 702 | vmalloc_reserve >> 20); |
| 694 | } | 703 | } |
| 704 | |||
| 705 | vmalloc_min = (void *)(VMALLOC_END - vmalloc_reserve); | ||
| 695 | return 0; | 706 | return 0; |
| 696 | } | 707 | } |
| 697 | early_param("vmalloc", early_vmalloc); | 708 | early_param("vmalloc", early_vmalloc); |
| 698 | 709 | ||
| 699 | #define VMALLOC_MIN (void *)(VMALLOC_END - vmalloc_reserve) | 710 | phys_addr_t lowmem_end_addr; |
| 700 | 711 | ||
| 701 | static void __init sanity_check_meminfo(void) | 712 | static void __init sanity_check_meminfo(void) |
| 702 | { | 713 | { |
| 703 | int i, j, highmem = 0; | 714 | int i, j, highmem = 0; |
| 704 | 715 | ||
| 716 | lowmem_end_addr = __pa(vmalloc_min - 1) + 1; | ||
| 717 | |||
| 705 | for (i = 0, j = 0; i < meminfo.nr_banks; i++) { | 718 | for (i = 0, j = 0; i < meminfo.nr_banks; i++) { |
| 706 | struct membank *bank = &meminfo.bank[j]; | 719 | struct membank *bank = &meminfo.bank[j]; |
| 707 | *bank = meminfo.bank[i]; | 720 | *bank = meminfo.bank[i]; |
| 708 | 721 | ||
| 709 | #ifdef CONFIG_HIGHMEM | 722 | #ifdef CONFIG_HIGHMEM |
| 710 | if (__va(bank->start) > VMALLOC_MIN || | 723 | if (__va(bank->start) > vmalloc_min || |
| 711 | __va(bank->start) < (void *)PAGE_OFFSET) | 724 | __va(bank->start) < (void *)PAGE_OFFSET) |
| 712 | highmem = 1; | 725 | highmem = 1; |
| 713 | 726 | ||
| @@ -717,8 +730,8 @@ static void __init sanity_check_meminfo(void) | |||
| 717 | * Split those memory banks which are partially overlapping | 730 | * Split those memory banks which are partially overlapping |
| 718 | * the vmalloc area greatly simplifying things later. | 731 | * the vmalloc area greatly simplifying things later. |
| 719 | */ | 732 | */ |
| 720 | if (__va(bank->start) < VMALLOC_MIN && | 733 | if (__va(bank->start) < vmalloc_min && |
| 721 | bank->size > VMALLOC_MIN - __va(bank->start)) { | 734 | bank->size > vmalloc_min - __va(bank->start)) { |
| 722 | if (meminfo.nr_banks >= NR_BANKS) { | 735 | if (meminfo.nr_banks >= NR_BANKS) { |
| 723 | printk(KERN_CRIT "NR_BANKS too low, " | 736 | printk(KERN_CRIT "NR_BANKS too low, " |
| 724 | "ignoring high memory\n"); | 737 | "ignoring high memory\n"); |
| @@ -727,12 +740,12 @@ static void __init sanity_check_meminfo(void) | |||
| 727 | (meminfo.nr_banks - i) * sizeof(*bank)); | 740 | (meminfo.nr_banks - i) * sizeof(*bank)); |
| 728 | meminfo.nr_banks++; | 741 | meminfo.nr_banks++; |
| 729 | i++; | 742 | i++; |
| 730 | bank[1].size -= VMALLOC_MIN - __va(bank->start); | 743 | bank[1].size -= vmalloc_min - __va(bank->start); |
| 731 | bank[1].start = __pa(VMALLOC_MIN - 1) + 1; | 744 | bank[1].start = __pa(vmalloc_min - 1) + 1; |
| 732 | bank[1].highmem = highmem = 1; | 745 | bank[1].highmem = highmem = 1; |
| 733 | j++; | 746 | j++; |
| 734 | } | 747 | } |
| 735 | bank->size = VMALLOC_MIN - __va(bank->start); | 748 | bank->size = vmalloc_min - __va(bank->start); |
| 736 | } | 749 | } |
| 737 | #else | 750 | #else |
| 738 | bank->highmem = highmem; | 751 | bank->highmem = highmem; |
| @@ -741,7 +754,7 @@ static void __init sanity_check_meminfo(void) | |||
| 741 | * Check whether this memory bank would entirely overlap | 754 | * Check whether this memory bank would entirely overlap |
| 742 | * the vmalloc area. | 755 | * the vmalloc area. |
| 743 | */ | 756 | */ |
| 744 | if (__va(bank->start) >= VMALLOC_MIN || | 757 | if (__va(bank->start) >= vmalloc_min || |
| 745 | __va(bank->start) < (void *)PAGE_OFFSET) { | 758 | __va(bank->start) < (void *)PAGE_OFFSET) { |
| 746 | printk(KERN_NOTICE "Ignoring RAM at %.8lx-%.8lx " | 759 | printk(KERN_NOTICE "Ignoring RAM at %.8lx-%.8lx " |
| 747 | "(vmalloc region overlap).\n", | 760 | "(vmalloc region overlap).\n", |
| @@ -753,9 +766,9 @@ static void __init sanity_check_meminfo(void) | |||
| 753 | * Check whether this memory bank would partially overlap | 766 | * Check whether this memory bank would partially overlap |
| 754 | * the vmalloc area. | 767 | * the vmalloc area. |
| 755 | */ | 768 | */ |
| 756 | if (__va(bank->start + bank->size) > VMALLOC_MIN || | 769 | if (__va(bank->start + bank->size) > vmalloc_min || |
| 757 | __va(bank->start + bank->size) < __va(bank->start)) { | 770 | __va(bank->start + bank->size) < __va(bank->start)) { |
| 758 | unsigned long newsize = VMALLOC_MIN - __va(bank->start); | 771 | unsigned long newsize = vmalloc_min - __va(bank->start); |
| 759 | printk(KERN_NOTICE "Truncating RAM at %.8lx-%.8lx " | 772 | printk(KERN_NOTICE "Truncating RAM at %.8lx-%.8lx " |
| 760 | "to -%.8lx (vmalloc region overlap).\n", | 773 | "to -%.8lx (vmalloc region overlap).\n", |
| 761 | bank->start, bank->start + bank->size - 1, | 774 | bank->start, bank->start + bank->size - 1, |
| @@ -827,101 +840,23 @@ static inline void prepare_page_table(void) | |||
| 827 | } | 840 | } |
| 828 | 841 | ||
| 829 | /* | 842 | /* |
| 830 | * Reserve the various regions of node 0 | 843 | * Reserve the special regions of memory |
| 831 | */ | 844 | */ |
| 832 | void __init reserve_node_zero(pg_data_t *pgdat) | 845 | void __init arm_mm_memblock_reserve(void) |
| 833 | { | 846 | { |
| 834 | unsigned long res_size = 0; | ||
| 835 | |||
| 836 | /* | ||
| 837 | * Register the kernel text and data with bootmem. | ||
| 838 | * Note that this can only be in node 0. | ||
| 839 | */ | ||
| 840 | #ifdef CONFIG_XIP_KERNEL | ||
| 841 | reserve_bootmem_node(pgdat, __pa(_data), _end - _data, | ||
| 842 | BOOTMEM_DEFAULT); | ||
| 843 | #else | ||
| 844 | reserve_bootmem_node(pgdat, __pa(_stext), _end - _stext, | ||
| 845 | BOOTMEM_DEFAULT); | ||
| 846 | #endif | ||
| 847 | |||
| 848 | /* | 847 | /* |
| 849 | * Reserve the page tables. These are already in use, | 848 | * Reserve the page tables. These are already in use, |
| 850 | * and can only be in node 0. | 849 | * and can only be in node 0. |
| 851 | */ | 850 | */ |
| 852 | reserve_bootmem_node(pgdat, __pa(swapper_pg_dir), | 851 | memblock_reserve(__pa(swapper_pg_dir), PTRS_PER_PGD * sizeof(pgd_t)); |
| 853 | PTRS_PER_PGD * sizeof(pgd_t), BOOTMEM_DEFAULT); | ||
| 854 | |||
| 855 | /* | ||
| 856 | * Hmm... This should go elsewhere, but we really really need to | ||
| 857 | * stop things allocating the low memory; ideally we need a better | ||
| 858 | * implementation of GFP_DMA which does not assume that DMA-able | ||
| 859 | * memory starts at zero. | ||
| 860 | */ | ||
| 861 | if (machine_is_integrator() || machine_is_cintegrator()) | ||
| 862 | res_size = __pa(swapper_pg_dir) - PHYS_OFFSET; | ||
| 863 | |||
| 864 | /* | ||
| 865 | * These should likewise go elsewhere. They pre-reserve the | ||
| 866 | * screen memory region at the start of main system memory. | ||
| 867 | */ | ||
| 868 | if (machine_is_edb7211()) | ||
| 869 | res_size = 0x00020000; | ||
| 870 | if (machine_is_p720t()) | ||
| 871 | res_size = 0x00014000; | ||
| 872 | |||
| 873 | /* H1940, RX3715 and RX1950 need to reserve this for suspend */ | ||
| 874 | |||
| 875 | if (machine_is_h1940() || machine_is_rx3715() | ||
| 876 | || machine_is_rx1950()) { | ||
| 877 | reserve_bootmem_node(pgdat, 0x30003000, 0x1000, | ||
| 878 | BOOTMEM_DEFAULT); | ||
| 879 | reserve_bootmem_node(pgdat, 0x30081000, 0x1000, | ||
| 880 | BOOTMEM_DEFAULT); | ||
| 881 | } | ||
| 882 | |||
| 883 | if (machine_is_palmld() || machine_is_palmtx()) { | ||
| 884 | reserve_bootmem_node(pgdat, 0xa0000000, 0x1000, | ||
| 885 | BOOTMEM_EXCLUSIVE); | ||
| 886 | reserve_bootmem_node(pgdat, 0xa0200000, 0x1000, | ||
| 887 | BOOTMEM_EXCLUSIVE); | ||
| 888 | } | ||
| 889 | |||
| 890 | if (machine_is_treo680() || machine_is_centro()) { | ||
| 891 | reserve_bootmem_node(pgdat, 0xa0000000, 0x1000, | ||
| 892 | BOOTMEM_EXCLUSIVE); | ||
| 893 | reserve_bootmem_node(pgdat, 0xa2000000, 0x1000, | ||
| 894 | BOOTMEM_EXCLUSIVE); | ||
| 895 | } | ||
| 896 | |||
| 897 | if (machine_is_palmt5()) | ||
| 898 | reserve_bootmem_node(pgdat, 0xa0200000, 0x1000, | ||
| 899 | BOOTMEM_EXCLUSIVE); | ||
| 900 | |||
| 901 | /* | ||
| 902 | * U300 - This platform family can share physical memory | ||
| 903 | * between two ARM cpus, one running Linux and the other | ||
| 904 | * running another OS. | ||
| 905 | */ | ||
| 906 | if (machine_is_u300()) { | ||
| 907 | #ifdef CONFIG_MACH_U300_SINGLE_RAM | ||
| 908 | #if ((CONFIG_MACH_U300_ACCESS_MEM_SIZE & 1) == 1) && \ | ||
| 909 | CONFIG_MACH_U300_2MB_ALIGNMENT_FIX | ||
| 910 | res_size = 0x00100000; | ||
| 911 | #endif | ||
| 912 | #endif | ||
| 913 | } | ||
| 914 | 852 | ||
| 915 | #ifdef CONFIG_SA1111 | 853 | #ifdef CONFIG_SA1111 |
| 916 | /* | 854 | /* |
| 917 | * Because of the SA1111 DMA bug, we want to preserve our | 855 | * Because of the SA1111 DMA bug, we want to preserve our |
| 918 | * precious DMA-able memory... | 856 | * precious DMA-able memory... |
| 919 | */ | 857 | */ |
| 920 | res_size = __pa(swapper_pg_dir) - PHYS_OFFSET; | 858 | memblock_reserve(PHYS_OFFSET, __pa(swapper_pg_dir) - PHYS_OFFSET); |
| 921 | #endif | 859 | #endif |
| 922 | if (res_size) | ||
| 923 | reserve_bootmem_node(pgdat, PHYS_OFFSET, res_size, | ||
| 924 | BOOTMEM_DEFAULT); | ||
| 925 | } | 860 | } |
| 926 | 861 | ||
| 927 | /* | 862 | /* |
| @@ -940,7 +875,7 @@ static void __init devicemaps_init(struct machine_desc *mdesc) | |||
| 940 | /* | 875 | /* |
| 941 | * Allocate the vector page early. | 876 | * Allocate the vector page early. |
| 942 | */ | 877 | */ |
| 943 | vectors = alloc_bootmem_low_pages(PAGE_SIZE); | 878 | vectors = early_alloc(PAGE_SIZE); |
| 944 | 879 | ||
| 945 | for (addr = VMALLOC_END; addr; addr += PGDIR_SIZE) | 880 | for (addr = VMALLOC_END; addr; addr += PGDIR_SIZE) |
| 946 | pmd_clear(pmd_off_k(addr)); | 881 | pmd_clear(pmd_off_k(addr)); |
| @@ -1011,11 +946,8 @@ static void __init devicemaps_init(struct machine_desc *mdesc) | |||
| 1011 | static void __init kmap_init(void) | 946 | static void __init kmap_init(void) |
| 1012 | { | 947 | { |
| 1013 | #ifdef CONFIG_HIGHMEM | 948 | #ifdef CONFIG_HIGHMEM |
| 1014 | pmd_t *pmd = pmd_off_k(PKMAP_BASE); | 949 | pkmap_page_table = early_pte_alloc(pmd_off_k(PKMAP_BASE), |
| 1015 | pte_t *pte = alloc_bootmem_low_pages(2 * PTRS_PER_PTE * sizeof(pte_t)); | 950 | PKMAP_BASE, _PAGE_KERNEL_TABLE); |
| 1016 | BUG_ON(!pmd_none(*pmd) || !pte); | ||
| 1017 | __pmd_populate(pmd, __pa(pte) | _PAGE_KERNEL_TABLE); | ||
| 1018 | pkmap_page_table = pte + PTRS_PER_PTE; | ||
| 1019 | #endif | 951 | #endif |
| 1020 | } | 952 | } |
| 1021 | 953 | ||
| @@ -1066,17 +998,16 @@ void __init paging_init(struct machine_desc *mdesc) | |||
| 1066 | sanity_check_meminfo(); | 998 | sanity_check_meminfo(); |
| 1067 | prepare_page_table(); | 999 | prepare_page_table(); |
| 1068 | map_lowmem(); | 1000 | map_lowmem(); |
| 1069 | bootmem_init(); | ||
| 1070 | devicemaps_init(mdesc); | 1001 | devicemaps_init(mdesc); |
| 1071 | kmap_init(); | 1002 | kmap_init(); |
| 1072 | 1003 | ||
| 1073 | top_pmd = pmd_off_k(0xffff0000); | 1004 | top_pmd = pmd_off_k(0xffff0000); |
| 1074 | 1005 | ||
| 1075 | /* | 1006 | /* allocate the zero page. */ |
| 1076 | * allocate the zero page. Note that this always succeeds and | 1007 | zero_page = early_alloc(PAGE_SIZE); |
| 1077 | * returns a zeroed result. | 1008 | |
| 1078 | */ | 1009 | bootmem_init(); |
| 1079 | zero_page = alloc_bootmem_low_pages(PAGE_SIZE); | 1010 | |
| 1080 | empty_zero_page = virt_to_page(zero_page); | 1011 | empty_zero_page = virt_to_page(zero_page); |
| 1081 | __flush_dcache_page(NULL, empty_zero_page); | 1012 | __flush_dcache_page(NULL, empty_zero_page); |
| 1082 | } | 1013 | } |
diff --git a/arch/arm/mm/nommu.c b/arch/arm/mm/nommu.c index 33b327379f07..687d02319a41 100644 --- a/arch/arm/mm/nommu.c +++ b/arch/arm/mm/nommu.c | |||
| @@ -6,8 +6,8 @@ | |||
| 6 | #include <linux/module.h> | 6 | #include <linux/module.h> |
| 7 | #include <linux/mm.h> | 7 | #include <linux/mm.h> |
| 8 | #include <linux/pagemap.h> | 8 | #include <linux/pagemap.h> |
| 9 | #include <linux/bootmem.h> | ||
| 10 | #include <linux/io.h> | 9 | #include <linux/io.h> |
| 10 | #include <linux/memblock.h> | ||
| 11 | 11 | ||
| 12 | #include <asm/cacheflush.h> | 12 | #include <asm/cacheflush.h> |
| 13 | #include <asm/sections.h> | 13 | #include <asm/sections.h> |
| @@ -17,30 +17,14 @@ | |||
| 17 | 17 | ||
| 18 | #include "mm.h" | 18 | #include "mm.h" |
| 19 | 19 | ||
| 20 | /* | 20 | void __init arm_mm_memblock_reserve(void) |
| 21 | * Reserve the various regions of node 0 | ||
| 22 | */ | ||
| 23 | void __init reserve_node_zero(pg_data_t *pgdat) | ||
| 24 | { | 21 | { |
| 25 | /* | 22 | /* |
| 26 | * Register the kernel text and data with bootmem. | ||
| 27 | * Note that this can only be in node 0. | ||
| 28 | */ | ||
| 29 | #ifdef CONFIG_XIP_KERNEL | ||
| 30 | reserve_bootmem_node(pgdat, __pa(_data), _end - _data, | ||
| 31 | BOOTMEM_DEFAULT); | ||
| 32 | #else | ||
| 33 | reserve_bootmem_node(pgdat, __pa(_stext), _end - _stext, | ||
| 34 | BOOTMEM_DEFAULT); | ||
| 35 | #endif | ||
| 36 | |||
| 37 | /* | ||
| 38 | * Register the exception vector page. | 23 | * Register the exception vector page. |
| 39 | * some architectures which the DRAM is the exception vector to trap, | 24 | * some architectures which the DRAM is the exception vector to trap, |
| 40 | * alloc_page breaks with error, although it is not NULL, but "0." | 25 | * alloc_page breaks with error, although it is not NULL, but "0." |
| 41 | */ | 26 | */ |
| 42 | reserve_bootmem_node(pgdat, CONFIG_VECTORS_BASE, PAGE_SIZE, | 27 | memblock_reserve(CONFIG_VECTORS_BASE, PAGE_SIZE); |
| 43 | BOOTMEM_DEFAULT); | ||
| 44 | } | 28 | } |
| 45 | 29 | ||
| 46 | /* | 30 | /* |
diff --git a/arch/arm/mm/proc-v6.S b/arch/arm/mm/proc-v6.S index 7a5337ed7d68..2f5a3c23a0fe 100644 --- a/arch/arm/mm/proc-v6.S +++ b/arch/arm/mm/proc-v6.S | |||
| @@ -239,7 +239,8 @@ __v6_proc_info: | |||
| 239 | b __v6_setup | 239 | b __v6_setup |
| 240 | .long cpu_arch_name | 240 | .long cpu_arch_name |
| 241 | .long cpu_elf_name | 241 | .long cpu_elf_name |
| 242 | .long HWCAP_SWP|HWCAP_HALF|HWCAP_THUMB|HWCAP_FAST_MULT|HWCAP_EDSP|HWCAP_JAVA | 242 | /* See also feat_v6_fixup() for HWCAP_TLS */ |
| 243 | .long HWCAP_SWP|HWCAP_HALF|HWCAP_THUMB|HWCAP_FAST_MULT|HWCAP_EDSP|HWCAP_JAVA|HWCAP_TLS | ||
| 243 | .long cpu_v6_name | 244 | .long cpu_v6_name |
| 244 | .long v6_processor_functions | 245 | .long v6_processor_functions |
| 245 | .long v6wbi_tlb_fns | 246 | .long v6wbi_tlb_fns |
| @@ -262,7 +263,7 @@ __pj4_v6_proc_info: | |||
| 262 | b __v6_setup | 263 | b __v6_setup |
| 263 | .long cpu_arch_name | 264 | .long cpu_arch_name |
| 264 | .long cpu_elf_name | 265 | .long cpu_elf_name |
| 265 | .long HWCAP_SWP|HWCAP_HALF|HWCAP_THUMB|HWCAP_FAST_MULT|HWCAP_EDSP | 266 | .long HWCAP_SWP|HWCAP_HALF|HWCAP_THUMB|HWCAP_FAST_MULT|HWCAP_EDSP|HWCAP_TLS |
| 266 | .long cpu_pj4_name | 267 | .long cpu_pj4_name |
| 267 | .long v6_processor_functions | 268 | .long v6_processor_functions |
| 268 | .long v6wbi_tlb_fns | 269 | .long v6wbi_tlb_fns |
diff --git a/arch/arm/mm/proc-v7.S b/arch/arm/mm/proc-v7.S index 7aaf88a3b7aa..8071bcd4c995 100644 --- a/arch/arm/mm/proc-v7.S +++ b/arch/arm/mm/proc-v7.S | |||
| @@ -344,7 +344,7 @@ __v7_proc_info: | |||
| 344 | b __v7_setup | 344 | b __v7_setup |
| 345 | .long cpu_arch_name | 345 | .long cpu_arch_name |
| 346 | .long cpu_elf_name | 346 | .long cpu_elf_name |
| 347 | .long HWCAP_SWP|HWCAP_HALF|HWCAP_THUMB|HWCAP_FAST_MULT|HWCAP_EDSP | 347 | .long HWCAP_SWP|HWCAP_HALF|HWCAP_THUMB|HWCAP_FAST_MULT|HWCAP_EDSP|HWCAP_TLS |
| 348 | .long cpu_v7_name | 348 | .long cpu_v7_name |
| 349 | .long v7_processor_functions | 349 | .long v7_processor_functions |
| 350 | .long v7wbi_tlb_fns | 350 | .long v7wbi_tlb_fns |
diff --git a/arch/arm/plat-iop/time.c b/arch/arm/plat-iop/time.c index 6c8a02ad98e3..85d3e55ca4a9 100644 --- a/arch/arm/plat-iop/time.c +++ b/arch/arm/plat-iop/time.c | |||
| @@ -29,6 +29,11 @@ | |||
| 29 | #include <mach/time.h> | 29 | #include <mach/time.h> |
| 30 | 30 | ||
| 31 | /* | 31 | /* |
| 32 | * Minimum clocksource/clockevent timer range in seconds | ||
| 33 | */ | ||
| 34 | #define IOP_MIN_RANGE 4 | ||
| 35 | |||
| 36 | /* | ||
| 32 | * IOP clocksource (free-running timer 1). | 37 | * IOP clocksource (free-running timer 1). |
| 33 | */ | 38 | */ |
| 34 | static cycle_t iop_clocksource_read(struct clocksource *unused) | 39 | static cycle_t iop_clocksource_read(struct clocksource *unused) |
| @@ -44,27 +49,6 @@ static struct clocksource iop_clocksource = { | |||
| 44 | .flags = CLOCK_SOURCE_IS_CONTINUOUS, | 49 | .flags = CLOCK_SOURCE_IS_CONTINUOUS, |
| 45 | }; | 50 | }; |
| 46 | 51 | ||
| 47 | static void __init iop_clocksource_set_hz(struct clocksource *cs, unsigned int hz) | ||
| 48 | { | ||
| 49 | u64 temp; | ||
| 50 | u32 shift; | ||
| 51 | |||
| 52 | /* Find shift and mult values for hz. */ | ||
| 53 | shift = 32; | ||
| 54 | do { | ||
| 55 | temp = (u64) NSEC_PER_SEC << shift; | ||
| 56 | do_div(temp, hz); | ||
| 57 | if ((temp >> 32) == 0) | ||
| 58 | break; | ||
| 59 | } while (--shift != 0); | ||
| 60 | |||
| 61 | cs->shift = shift; | ||
| 62 | cs->mult = (u32) temp; | ||
| 63 | |||
| 64 | printk(KERN_INFO "clocksource: %s uses shift %u mult %#x\n", | ||
| 65 | cs->name, cs->shift, cs->mult); | ||
| 66 | } | ||
| 67 | |||
| 68 | /* | 52 | /* |
| 69 | * IOP sched_clock() implementation via its clocksource. | 53 | * IOP sched_clock() implementation via its clocksource. |
| 70 | */ | 54 | */ |
| @@ -130,27 +114,6 @@ static struct clock_event_device iop_clockevent = { | |||
| 130 | .set_mode = iop_set_mode, | 114 | .set_mode = iop_set_mode, |
| 131 | }; | 115 | }; |
| 132 | 116 | ||
| 133 | static void __init iop_clockevent_set_hz(struct clock_event_device *ce, unsigned int hz) | ||
| 134 | { | ||
| 135 | u64 temp; | ||
| 136 | u32 shift; | ||
| 137 | |||
| 138 | /* Find shift and mult values for hz. */ | ||
| 139 | shift = 32; | ||
| 140 | do { | ||
| 141 | temp = (u64) hz << shift; | ||
| 142 | do_div(temp, NSEC_PER_SEC); | ||
| 143 | if ((temp >> 32) == 0) | ||
| 144 | break; | ||
| 145 | } while (--shift != 0); | ||
| 146 | |||
| 147 | ce->shift = shift; | ||
| 148 | ce->mult = (u32) temp; | ||
| 149 | |||
| 150 | printk(KERN_INFO "clockevent: %s uses shift %u mult %#lx\n", | ||
| 151 | ce->name, ce->shift, ce->mult); | ||
| 152 | } | ||
| 153 | |||
| 154 | static irqreturn_t | 117 | static irqreturn_t |
| 155 | iop_timer_interrupt(int irq, void *dev_id) | 118 | iop_timer_interrupt(int irq, void *dev_id) |
| 156 | { | 119 | { |
| @@ -190,7 +153,8 @@ void __init iop_init_time(unsigned long tick_rate) | |||
| 190 | */ | 153 | */ |
| 191 | write_tmr0(timer_ctl & ~IOP_TMR_EN); | 154 | write_tmr0(timer_ctl & ~IOP_TMR_EN); |
| 192 | setup_irq(IRQ_IOP_TIMER0, &iop_timer_irq); | 155 | setup_irq(IRQ_IOP_TIMER0, &iop_timer_irq); |
| 193 | iop_clockevent_set_hz(&iop_clockevent, tick_rate); | 156 | clockevents_calc_mult_shift(&iop_clockevent, |
| 157 | tick_rate, IOP_MIN_RANGE); | ||
| 194 | iop_clockevent.max_delta_ns = | 158 | iop_clockevent.max_delta_ns = |
| 195 | clockevent_delta2ns(0xfffffffe, &iop_clockevent); | 159 | clockevent_delta2ns(0xfffffffe, &iop_clockevent); |
| 196 | iop_clockevent.min_delta_ns = | 160 | iop_clockevent.min_delta_ns = |
| @@ -207,6 +171,7 @@ void __init iop_init_time(unsigned long tick_rate) | |||
| 207 | write_trr1(0xffffffff); | 171 | write_trr1(0xffffffff); |
| 208 | write_tcr1(0xffffffff); | 172 | write_tcr1(0xffffffff); |
| 209 | write_tmr1(timer_ctl); | 173 | write_tmr1(timer_ctl); |
| 210 | iop_clocksource_set_hz(&iop_clocksource, tick_rate); | 174 | clocksource_calc_mult_shift(&iop_clocksource, tick_rate, |
| 175 | IOP_MIN_RANGE); | ||
| 211 | clocksource_register(&iop_clocksource); | 176 | clocksource_register(&iop_clocksource); |
| 212 | } | 177 | } |
diff --git a/arch/arm/plat-nomadik/gpio.c b/arch/arm/plat-nomadik/gpio.c index 5a6ef252c38b..977c8f9a07a2 100644 --- a/arch/arm/plat-nomadik/gpio.c +++ b/arch/arm/plat-nomadik/gpio.c | |||
| @@ -23,6 +23,7 @@ | |||
| 23 | #include <linux/irq.h> | 23 | #include <linux/irq.h> |
| 24 | #include <linux/slab.h> | 24 | #include <linux/slab.h> |
| 25 | 25 | ||
| 26 | #include <plat/pincfg.h> | ||
| 26 | #include <mach/hardware.h> | 27 | #include <mach/hardware.h> |
| 27 | #include <mach/gpio.h> | 28 | #include <mach/gpio.h> |
| 28 | 29 | ||
| @@ -46,28 +47,217 @@ struct nmk_gpio_chip { | |||
| 46 | u32 edge_falling; | 47 | u32 edge_falling; |
| 47 | }; | 48 | }; |
| 48 | 49 | ||
| 50 | static void __nmk_gpio_set_mode(struct nmk_gpio_chip *nmk_chip, | ||
| 51 | unsigned offset, int gpio_mode) | ||
| 52 | { | ||
| 53 | u32 bit = 1 << offset; | ||
| 54 | u32 afunc, bfunc; | ||
| 55 | |||
| 56 | afunc = readl(nmk_chip->addr + NMK_GPIO_AFSLA) & ~bit; | ||
| 57 | bfunc = readl(nmk_chip->addr + NMK_GPIO_AFSLB) & ~bit; | ||
| 58 | if (gpio_mode & NMK_GPIO_ALT_A) | ||
| 59 | afunc |= bit; | ||
| 60 | if (gpio_mode & NMK_GPIO_ALT_B) | ||
| 61 | bfunc |= bit; | ||
| 62 | writel(afunc, nmk_chip->addr + NMK_GPIO_AFSLA); | ||
| 63 | writel(bfunc, nmk_chip->addr + NMK_GPIO_AFSLB); | ||
| 64 | } | ||
| 65 | |||
| 66 | static void __nmk_gpio_set_slpm(struct nmk_gpio_chip *nmk_chip, | ||
| 67 | unsigned offset, enum nmk_gpio_slpm mode) | ||
| 68 | { | ||
| 69 | u32 bit = 1 << offset; | ||
| 70 | u32 slpm; | ||
| 71 | |||
| 72 | slpm = readl(nmk_chip->addr + NMK_GPIO_SLPC); | ||
| 73 | if (mode == NMK_GPIO_SLPM_NOCHANGE) | ||
| 74 | slpm |= bit; | ||
| 75 | else | ||
| 76 | slpm &= ~bit; | ||
| 77 | writel(slpm, nmk_chip->addr + NMK_GPIO_SLPC); | ||
| 78 | } | ||
| 79 | |||
| 80 | static void __nmk_gpio_set_pull(struct nmk_gpio_chip *nmk_chip, | ||
| 81 | unsigned offset, enum nmk_gpio_pull pull) | ||
| 82 | { | ||
| 83 | u32 bit = 1 << offset; | ||
| 84 | u32 pdis; | ||
| 85 | |||
| 86 | pdis = readl(nmk_chip->addr + NMK_GPIO_PDIS); | ||
| 87 | if (pull == NMK_GPIO_PULL_NONE) | ||
| 88 | pdis |= bit; | ||
| 89 | else | ||
| 90 | pdis &= ~bit; | ||
| 91 | writel(pdis, nmk_chip->addr + NMK_GPIO_PDIS); | ||
| 92 | |||
| 93 | if (pull == NMK_GPIO_PULL_UP) | ||
| 94 | writel(bit, nmk_chip->addr + NMK_GPIO_DATS); | ||
| 95 | else if (pull == NMK_GPIO_PULL_DOWN) | ||
| 96 | writel(bit, nmk_chip->addr + NMK_GPIO_DATC); | ||
| 97 | } | ||
| 98 | |||
| 99 | static void __nmk_gpio_make_input(struct nmk_gpio_chip *nmk_chip, | ||
| 100 | unsigned offset) | ||
| 101 | { | ||
| 102 | writel(1 << offset, nmk_chip->addr + NMK_GPIO_DIRC); | ||
| 103 | } | ||
| 104 | |||
| 105 | static void __nmk_config_pin(struct nmk_gpio_chip *nmk_chip, unsigned offset, | ||
| 106 | pin_cfg_t cfg) | ||
| 107 | { | ||
| 108 | static const char *afnames[] = { | ||
| 109 | [NMK_GPIO_ALT_GPIO] = "GPIO", | ||
| 110 | [NMK_GPIO_ALT_A] = "A", | ||
| 111 | [NMK_GPIO_ALT_B] = "B", | ||
| 112 | [NMK_GPIO_ALT_C] = "C" | ||
| 113 | }; | ||
| 114 | static const char *pullnames[] = { | ||
| 115 | [NMK_GPIO_PULL_NONE] = "none", | ||
| 116 | [NMK_GPIO_PULL_UP] = "up", | ||
| 117 | [NMK_GPIO_PULL_DOWN] = "down", | ||
| 118 | [3] /* illegal */ = "??" | ||
| 119 | }; | ||
| 120 | static const char *slpmnames[] = { | ||
| 121 | [NMK_GPIO_SLPM_INPUT] = "input", | ||
| 122 | [NMK_GPIO_SLPM_NOCHANGE] = "no-change", | ||
| 123 | }; | ||
| 124 | |||
| 125 | int pin = PIN_NUM(cfg); | ||
| 126 | int pull = PIN_PULL(cfg); | ||
| 127 | int af = PIN_ALT(cfg); | ||
| 128 | int slpm = PIN_SLPM(cfg); | ||
| 129 | |||
| 130 | dev_dbg(nmk_chip->chip.dev, "pin %d: af %s, pull %s, slpm %s\n", | ||
| 131 | pin, afnames[af], pullnames[pull], slpmnames[slpm]); | ||
| 132 | |||
| 133 | __nmk_gpio_make_input(nmk_chip, offset); | ||
| 134 | __nmk_gpio_set_pull(nmk_chip, offset, pull); | ||
| 135 | __nmk_gpio_set_slpm(nmk_chip, offset, slpm); | ||
| 136 | __nmk_gpio_set_mode(nmk_chip, offset, af); | ||
| 137 | } | ||
| 138 | |||
| 139 | /** | ||
| 140 | * nmk_config_pin - configure a pin's mux attributes | ||
| 141 | * @cfg: pin confguration | ||
| 142 | * | ||
| 143 | * Configures a pin's mode (alternate function or GPIO), its pull up status, | ||
| 144 | * and its sleep mode based on the specified configuration. The @cfg is | ||
| 145 | * usually one of the SoC specific macros defined in mach/<soc>-pins.h. These | ||
| 146 | * are constructed using, and can be further enhanced with, the macros in | ||
| 147 | * plat/pincfg.h. | ||
| 148 | * | ||
| 149 | * If a pin's mode is set to GPIO, it is configured as an input to avoid | ||
| 150 | * side-effects. The gpio can be manipulated later using standard GPIO API | ||
| 151 | * calls. | ||
| 152 | */ | ||
| 153 | int nmk_config_pin(pin_cfg_t cfg) | ||
| 154 | { | ||
| 155 | struct nmk_gpio_chip *nmk_chip; | ||
| 156 | int gpio = PIN_NUM(cfg); | ||
| 157 | unsigned long flags; | ||
| 158 | |||
| 159 | nmk_chip = get_irq_chip_data(NOMADIK_GPIO_TO_IRQ(gpio)); | ||
| 160 | if (!nmk_chip) | ||
| 161 | return -EINVAL; | ||
| 162 | |||
| 163 | spin_lock_irqsave(&nmk_chip->lock, flags); | ||
| 164 | __nmk_config_pin(nmk_chip, gpio - nmk_chip->chip.base, cfg); | ||
| 165 | spin_unlock_irqrestore(&nmk_chip->lock, flags); | ||
| 166 | |||
| 167 | return 0; | ||
| 168 | } | ||
| 169 | EXPORT_SYMBOL(nmk_config_pin); | ||
| 170 | |||
| 171 | /** | ||
| 172 | * nmk_config_pins - configure several pins at once | ||
| 173 | * @cfgs: array of pin configurations | ||
| 174 | * @num: number of elments in the array | ||
| 175 | * | ||
| 176 | * Configures several pins using nmk_config_pin(). Refer to that function for | ||
| 177 | * further information. | ||
| 178 | */ | ||
| 179 | int nmk_config_pins(pin_cfg_t *cfgs, int num) | ||
| 180 | { | ||
| 181 | int ret = 0; | ||
| 182 | int i; | ||
| 183 | |||
| 184 | for (i = 0; i < num; i++) { | ||
| 185 | int ret = nmk_config_pin(cfgs[i]); | ||
| 186 | if (ret) | ||
| 187 | break; | ||
| 188 | } | ||
| 189 | |||
| 190 | return ret; | ||
| 191 | } | ||
| 192 | EXPORT_SYMBOL(nmk_config_pins); | ||
| 193 | |||
| 194 | /** | ||
| 195 | * nmk_gpio_set_slpm() - configure the sleep mode of a pin | ||
| 196 | * @gpio: pin number | ||
| 197 | * @mode: NMK_GPIO_SLPM_INPUT or NMK_GPIO_SLPM_NOCHANGE, | ||
| 198 | * | ||
| 199 | * Sets the sleep mode of a pin. If @mode is NMK_GPIO_SLPM_INPUT, the pin is | ||
| 200 | * changed to an input (with pullup/down enabled) in sleep and deep sleep. If | ||
| 201 | * @mode is NMK_GPIO_SLPM_NOCHANGE, the pin remains in the state it was | ||
| 202 | * configured even when in sleep and deep sleep. | ||
| 203 | */ | ||
| 204 | int nmk_gpio_set_slpm(int gpio, enum nmk_gpio_slpm mode) | ||
| 205 | { | ||
| 206 | struct nmk_gpio_chip *nmk_chip; | ||
| 207 | unsigned long flags; | ||
| 208 | |||
| 209 | nmk_chip = get_irq_chip_data(NOMADIK_GPIO_TO_IRQ(gpio)); | ||
| 210 | if (!nmk_chip) | ||
| 211 | return -EINVAL; | ||
| 212 | |||
| 213 | spin_lock_irqsave(&nmk_chip->lock, flags); | ||
| 214 | __nmk_gpio_set_slpm(nmk_chip, gpio - nmk_chip->chip.base, mode); | ||
| 215 | spin_unlock_irqrestore(&nmk_chip->lock, flags); | ||
| 216 | |||
| 217 | return 0; | ||
| 218 | } | ||
| 219 | |||
| 220 | /** | ||
| 221 | * nmk_gpio_set_pull() - enable/disable pull up/down on a gpio | ||
| 222 | * @gpio: pin number | ||
| 223 | * @pull: one of NMK_GPIO_PULL_DOWN, NMK_GPIO_PULL_UP, and NMK_GPIO_PULL_NONE | ||
| 224 | * | ||
| 225 | * Enables/disables pull up/down on a specified pin. This only takes effect if | ||
| 226 | * the pin is configured as an input (either explicitly or by the alternate | ||
| 227 | * function). | ||
| 228 | * | ||
| 229 | * NOTE: If enabling the pull up/down, the caller must ensure that the GPIO is | ||
| 230 | * configured as an input. Otherwise, due to the way the controller registers | ||
| 231 | * work, this function will change the value output on the pin. | ||
| 232 | */ | ||
| 233 | int nmk_gpio_set_pull(int gpio, enum nmk_gpio_pull pull) | ||
| 234 | { | ||
| 235 | struct nmk_gpio_chip *nmk_chip; | ||
| 236 | unsigned long flags; | ||
| 237 | |||
| 238 | nmk_chip = get_irq_chip_data(NOMADIK_GPIO_TO_IRQ(gpio)); | ||
| 239 | if (!nmk_chip) | ||
| 240 | return -EINVAL; | ||
| 241 | |||
| 242 | spin_lock_irqsave(&nmk_chip->lock, flags); | ||
| 243 | __nmk_gpio_set_pull(nmk_chip, gpio - nmk_chip->chip.base, pull); | ||
| 244 | spin_unlock_irqrestore(&nmk_chip->lock, flags); | ||
| 245 | |||
| 246 | return 0; | ||
| 247 | } | ||
| 248 | |||
| 49 | /* Mode functions */ | 249 | /* Mode functions */ |
| 50 | int nmk_gpio_set_mode(int gpio, int gpio_mode) | 250 | int nmk_gpio_set_mode(int gpio, int gpio_mode) |
| 51 | { | 251 | { |
| 52 | struct nmk_gpio_chip *nmk_chip; | 252 | struct nmk_gpio_chip *nmk_chip; |
| 53 | unsigned long flags; | 253 | unsigned long flags; |
| 54 | u32 afunc, bfunc, bit; | ||
| 55 | 254 | ||
| 56 | nmk_chip = get_irq_chip_data(NOMADIK_GPIO_TO_IRQ(gpio)); | 255 | nmk_chip = get_irq_chip_data(NOMADIK_GPIO_TO_IRQ(gpio)); |
| 57 | if (!nmk_chip) | 256 | if (!nmk_chip) |
| 58 | return -EINVAL; | 257 | return -EINVAL; |
| 59 | 258 | ||
| 60 | bit = 1 << (gpio - nmk_chip->chip.base); | ||
| 61 | |||
| 62 | spin_lock_irqsave(&nmk_chip->lock, flags); | 259 | spin_lock_irqsave(&nmk_chip->lock, flags); |
| 63 | afunc = readl(nmk_chip->addr + NMK_GPIO_AFSLA) & ~bit; | 260 | __nmk_gpio_set_mode(nmk_chip, gpio - nmk_chip->chip.base, gpio_mode); |
| 64 | bfunc = readl(nmk_chip->addr + NMK_GPIO_AFSLB) & ~bit; | ||
| 65 | if (gpio_mode & NMK_GPIO_ALT_A) | ||
| 66 | afunc |= bit; | ||
| 67 | if (gpio_mode & NMK_GPIO_ALT_B) | ||
| 68 | bfunc |= bit; | ||
| 69 | writel(afunc, nmk_chip->addr + NMK_GPIO_AFSLA); | ||
| 70 | writel(bfunc, nmk_chip->addr + NMK_GPIO_AFSLB); | ||
| 71 | spin_unlock_irqrestore(&nmk_chip->lock, flags); | 261 | spin_unlock_irqrestore(&nmk_chip->lock, flags); |
| 72 | 262 | ||
| 73 | return 0; | 263 | return 0; |
| @@ -111,32 +301,41 @@ static void nmk_gpio_irq_ack(unsigned int irq) | |||
| 111 | writel(nmk_gpio_get_bitmask(gpio), nmk_chip->addr + NMK_GPIO_IC); | 301 | writel(nmk_gpio_get_bitmask(gpio), nmk_chip->addr + NMK_GPIO_IC); |
| 112 | } | 302 | } |
| 113 | 303 | ||
| 304 | enum nmk_gpio_irq_type { | ||
| 305 | NORMAL, | ||
| 306 | WAKE, | ||
| 307 | }; | ||
| 308 | |||
| 114 | static void __nmk_gpio_irq_modify(struct nmk_gpio_chip *nmk_chip, | 309 | static void __nmk_gpio_irq_modify(struct nmk_gpio_chip *nmk_chip, |
| 115 | int gpio, bool enable) | 310 | int gpio, enum nmk_gpio_irq_type which, |
| 311 | bool enable) | ||
| 116 | { | 312 | { |
| 313 | u32 rimsc = which == WAKE ? NMK_GPIO_RWIMSC : NMK_GPIO_RIMSC; | ||
| 314 | u32 fimsc = which == WAKE ? NMK_GPIO_FWIMSC : NMK_GPIO_FIMSC; | ||
| 117 | u32 bitmask = nmk_gpio_get_bitmask(gpio); | 315 | u32 bitmask = nmk_gpio_get_bitmask(gpio); |
| 118 | u32 reg; | 316 | u32 reg; |
| 119 | 317 | ||
| 120 | /* we must individually set/clear the two edges */ | 318 | /* we must individually set/clear the two edges */ |
| 121 | if (nmk_chip->edge_rising & bitmask) { | 319 | if (nmk_chip->edge_rising & bitmask) { |
| 122 | reg = readl(nmk_chip->addr + NMK_GPIO_RIMSC); | 320 | reg = readl(nmk_chip->addr + rimsc); |
| 123 | if (enable) | 321 | if (enable) |
| 124 | reg |= bitmask; | 322 | reg |= bitmask; |
| 125 | else | 323 | else |
| 126 | reg &= ~bitmask; | 324 | reg &= ~bitmask; |
| 127 | writel(reg, nmk_chip->addr + NMK_GPIO_RIMSC); | 325 | writel(reg, nmk_chip->addr + rimsc); |
| 128 | } | 326 | } |
| 129 | if (nmk_chip->edge_falling & bitmask) { | 327 | if (nmk_chip->edge_falling & bitmask) { |
| 130 | reg = readl(nmk_chip->addr + NMK_GPIO_FIMSC); | 328 | reg = readl(nmk_chip->addr + fimsc); |
| 131 | if (enable) | 329 | if (enable) |
| 132 | reg |= bitmask; | 330 | reg |= bitmask; |
| 133 | else | 331 | else |
| 134 | reg &= ~bitmask; | 332 | reg &= ~bitmask; |
| 135 | writel(reg, nmk_chip->addr + NMK_GPIO_FIMSC); | 333 | writel(reg, nmk_chip->addr + fimsc); |
| 136 | } | 334 | } |
| 137 | } | 335 | } |
| 138 | 336 | ||
| 139 | static void nmk_gpio_irq_modify(unsigned int irq, bool enable) | 337 | static int nmk_gpio_irq_modify(unsigned int irq, enum nmk_gpio_irq_type which, |
| 338 | bool enable) | ||
| 140 | { | 339 | { |
| 141 | int gpio; | 340 | int gpio; |
| 142 | struct nmk_gpio_chip *nmk_chip; | 341 | struct nmk_gpio_chip *nmk_chip; |
| @@ -147,26 +346,35 @@ static void nmk_gpio_irq_modify(unsigned int irq, bool enable) | |||
| 147 | nmk_chip = get_irq_chip_data(irq); | 346 | nmk_chip = get_irq_chip_data(irq); |
| 148 | bitmask = nmk_gpio_get_bitmask(gpio); | 347 | bitmask = nmk_gpio_get_bitmask(gpio); |
| 149 | if (!nmk_chip) | 348 | if (!nmk_chip) |
| 150 | return; | 349 | return -EINVAL; |
| 151 | 350 | ||
| 152 | spin_lock_irqsave(&nmk_chip->lock, flags); | 351 | spin_lock_irqsave(&nmk_chip->lock, flags); |
| 153 | __nmk_gpio_irq_modify(nmk_chip, gpio, enable); | 352 | __nmk_gpio_irq_modify(nmk_chip, gpio, which, enable); |
| 154 | spin_unlock_irqrestore(&nmk_chip->lock, flags); | 353 | spin_unlock_irqrestore(&nmk_chip->lock, flags); |
| 354 | |||
| 355 | return 0; | ||
| 155 | } | 356 | } |
| 156 | 357 | ||
| 157 | static void nmk_gpio_irq_mask(unsigned int irq) | 358 | static void nmk_gpio_irq_mask(unsigned int irq) |
| 158 | { | 359 | { |
| 159 | nmk_gpio_irq_modify(irq, false); | 360 | nmk_gpio_irq_modify(irq, NORMAL, false); |
| 160 | }; | 361 | } |
| 161 | 362 | ||
| 162 | static void nmk_gpio_irq_unmask(unsigned int irq) | 363 | static void nmk_gpio_irq_unmask(unsigned int irq) |
| 163 | { | 364 | { |
| 164 | nmk_gpio_irq_modify(irq, true); | 365 | nmk_gpio_irq_modify(irq, NORMAL, true); |
| 366 | } | ||
| 367 | |||
| 368 | static int nmk_gpio_irq_set_wake(unsigned int irq, unsigned int on) | ||
| 369 | { | ||
| 370 | return nmk_gpio_irq_modify(irq, WAKE, on); | ||
| 165 | } | 371 | } |
| 166 | 372 | ||
| 167 | static int nmk_gpio_irq_set_type(unsigned int irq, unsigned int type) | 373 | static int nmk_gpio_irq_set_type(unsigned int irq, unsigned int type) |
| 168 | { | 374 | { |
| 169 | bool enabled = !(irq_to_desc(irq)->status & IRQ_DISABLED); | 375 | struct irq_desc *desc = irq_to_desc(irq); |
| 376 | bool enabled = !(desc->status & IRQ_DISABLED); | ||
| 377 | bool wake = desc->wake_depth; | ||
| 170 | int gpio; | 378 | int gpio; |
| 171 | struct nmk_gpio_chip *nmk_chip; | 379 | struct nmk_gpio_chip *nmk_chip; |
| 172 | unsigned long flags; | 380 | unsigned long flags; |
| @@ -186,7 +394,10 @@ static int nmk_gpio_irq_set_type(unsigned int irq, unsigned int type) | |||
| 186 | spin_lock_irqsave(&nmk_chip->lock, flags); | 394 | spin_lock_irqsave(&nmk_chip->lock, flags); |
| 187 | 395 | ||
| 188 | if (enabled) | 396 | if (enabled) |
| 189 | __nmk_gpio_irq_modify(nmk_chip, gpio, false); | 397 | __nmk_gpio_irq_modify(nmk_chip, gpio, NORMAL, false); |
| 398 | |||
| 399 | if (wake) | ||
| 400 | __nmk_gpio_irq_modify(nmk_chip, gpio, WAKE, false); | ||
| 190 | 401 | ||
| 191 | nmk_chip->edge_rising &= ~bitmask; | 402 | nmk_chip->edge_rising &= ~bitmask; |
| 192 | if (type & IRQ_TYPE_EDGE_RISING) | 403 | if (type & IRQ_TYPE_EDGE_RISING) |
| @@ -197,7 +408,10 @@ static int nmk_gpio_irq_set_type(unsigned int irq, unsigned int type) | |||
| 197 | nmk_chip->edge_falling |= bitmask; | 408 | nmk_chip->edge_falling |= bitmask; |
| 198 | 409 | ||
| 199 | if (enabled) | 410 | if (enabled) |
| 200 | __nmk_gpio_irq_modify(nmk_chip, gpio, true); | 411 | __nmk_gpio_irq_modify(nmk_chip, gpio, NORMAL, true); |
| 412 | |||
| 413 | if (wake) | ||
| 414 | __nmk_gpio_irq_modify(nmk_chip, gpio, WAKE, true); | ||
| 201 | 415 | ||
| 202 | spin_unlock_irqrestore(&nmk_chip->lock, flags); | 416 | spin_unlock_irqrestore(&nmk_chip->lock, flags); |
| 203 | 417 | ||
| @@ -210,6 +424,7 @@ static struct irq_chip nmk_gpio_irq_chip = { | |||
| 210 | .mask = nmk_gpio_irq_mask, | 424 | .mask = nmk_gpio_irq_mask, |
| 211 | .unmask = nmk_gpio_irq_unmask, | 425 | .unmask = nmk_gpio_irq_unmask, |
| 212 | .set_type = nmk_gpio_irq_set_type, | 426 | .set_type = nmk_gpio_irq_set_type, |
| 427 | .set_wake = nmk_gpio_irq_set_wake, | ||
| 213 | }; | 428 | }; |
| 214 | 429 | ||
| 215 | static void nmk_gpio_irq_handler(unsigned int irq, struct irq_desc *desc) | 430 | static void nmk_gpio_irq_handler(unsigned int irq, struct irq_desc *desc) |
| @@ -266,16 +481,6 @@ static int nmk_gpio_make_input(struct gpio_chip *chip, unsigned offset) | |||
| 266 | return 0; | 481 | return 0; |
| 267 | } | 482 | } |
| 268 | 483 | ||
| 269 | static int nmk_gpio_make_output(struct gpio_chip *chip, unsigned offset, | ||
| 270 | int val) | ||
| 271 | { | ||
| 272 | struct nmk_gpio_chip *nmk_chip = | ||
| 273 | container_of(chip, struct nmk_gpio_chip, chip); | ||
| 274 | |||
| 275 | writel(1 << offset, nmk_chip->addr + NMK_GPIO_DIRS); | ||
| 276 | return 0; | ||
| 277 | } | ||
| 278 | |||
| 279 | static int nmk_gpio_get_input(struct gpio_chip *chip, unsigned offset) | 484 | static int nmk_gpio_get_input(struct gpio_chip *chip, unsigned offset) |
| 280 | { | 485 | { |
| 281 | struct nmk_gpio_chip *nmk_chip = | 486 | struct nmk_gpio_chip *nmk_chip = |
| @@ -298,12 +503,33 @@ static void nmk_gpio_set_output(struct gpio_chip *chip, unsigned offset, | |||
| 298 | writel(bit, nmk_chip->addr + NMK_GPIO_DATC); | 503 | writel(bit, nmk_chip->addr + NMK_GPIO_DATC); |
| 299 | } | 504 | } |
| 300 | 505 | ||
| 506 | static int nmk_gpio_make_output(struct gpio_chip *chip, unsigned offset, | ||
| 507 | int val) | ||
| 508 | { | ||
| 509 | struct nmk_gpio_chip *nmk_chip = | ||
| 510 | container_of(chip, struct nmk_gpio_chip, chip); | ||
| 511 | |||
| 512 | writel(1 << offset, nmk_chip->addr + NMK_GPIO_DIRS); | ||
| 513 | nmk_gpio_set_output(chip, offset, val); | ||
| 514 | |||
| 515 | return 0; | ||
| 516 | } | ||
| 517 | |||
| 518 | static int nmk_gpio_to_irq(struct gpio_chip *chip, unsigned offset) | ||
| 519 | { | ||
| 520 | struct nmk_gpio_chip *nmk_chip = | ||
| 521 | container_of(chip, struct nmk_gpio_chip, chip); | ||
| 522 | |||
| 523 | return NOMADIK_GPIO_TO_IRQ(nmk_chip->chip.base) + offset; | ||
| 524 | } | ||
| 525 | |||
| 301 | /* This structure is replicated for each GPIO block allocated at probe time */ | 526 | /* This structure is replicated for each GPIO block allocated at probe time */ |
| 302 | static struct gpio_chip nmk_gpio_template = { | 527 | static struct gpio_chip nmk_gpio_template = { |
| 303 | .direction_input = nmk_gpio_make_input, | 528 | .direction_input = nmk_gpio_make_input, |
| 304 | .get = nmk_gpio_get_input, | 529 | .get = nmk_gpio_get_input, |
| 305 | .direction_output = nmk_gpio_make_output, | 530 | .direction_output = nmk_gpio_make_output, |
| 306 | .set = nmk_gpio_set_output, | 531 | .set = nmk_gpio_set_output, |
| 532 | .to_irq = nmk_gpio_to_irq, | ||
| 307 | .ngpio = NMK_GPIO_PER_CHIP, | 533 | .ngpio = NMK_GPIO_PER_CHIP, |
| 308 | .can_sleep = 0, | 534 | .can_sleep = 0, |
| 309 | }; | 535 | }; |
| @@ -393,30 +619,12 @@ out: | |||
| 393 | return ret; | 619 | return ret; |
| 394 | } | 620 | } |
| 395 | 621 | ||
| 396 | static int __exit nmk_gpio_remove(struct platform_device *dev) | ||
| 397 | { | ||
| 398 | struct nmk_gpio_chip *nmk_chip; | ||
| 399 | struct resource *res; | ||
| 400 | |||
| 401 | res = platform_get_resource(dev, IORESOURCE_MEM, 0); | ||
| 402 | |||
| 403 | nmk_chip = platform_get_drvdata(dev); | ||
| 404 | gpiochip_remove(&nmk_chip->chip); | ||
| 405 | clk_disable(nmk_chip->clk); | ||
| 406 | clk_put(nmk_chip->clk); | ||
| 407 | kfree(nmk_chip); | ||
| 408 | release_mem_region(res->start, resource_size(res)); | ||
| 409 | return 0; | ||
| 410 | } | ||
| 411 | |||
| 412 | |||
| 413 | static struct platform_driver nmk_gpio_driver = { | 622 | static struct platform_driver nmk_gpio_driver = { |
| 414 | .driver = { | 623 | .driver = { |
| 415 | .owner = THIS_MODULE, | 624 | .owner = THIS_MODULE, |
| 416 | .name = "gpio", | 625 | .name = "gpio", |
| 417 | }, | 626 | }, |
| 418 | .probe = nmk_gpio_probe, | 627 | .probe = nmk_gpio_probe, |
| 419 | .remove = __exit_p(nmk_gpio_remove), | ||
| 420 | .suspend = NULL, /* to be done */ | 628 | .suspend = NULL, /* to be done */ |
| 421 | .resume = NULL, | 629 | .resume = NULL, |
| 422 | }; | 630 | }; |
| @@ -426,7 +634,7 @@ static int __init nmk_gpio_init(void) | |||
| 426 | return platform_driver_register(&nmk_gpio_driver); | 634 | return platform_driver_register(&nmk_gpio_driver); |
| 427 | } | 635 | } |
| 428 | 636 | ||
| 429 | arch_initcall(nmk_gpio_init); | 637 | core_initcall(nmk_gpio_init); |
| 430 | 638 | ||
| 431 | MODULE_AUTHOR("Prafulla WADASKAR and Alessandro Rubini"); | 639 | MODULE_AUTHOR("Prafulla WADASKAR and Alessandro Rubini"); |
| 432 | MODULE_DESCRIPTION("Nomadik GPIO Driver"); | 640 | MODULE_DESCRIPTION("Nomadik GPIO Driver"); |
diff --git a/arch/arm/plat-nomadik/include/plat/gpio.h b/arch/arm/plat-nomadik/include/plat/gpio.h index 4200811249ca..aba355101f49 100644 --- a/arch/arm/plat-nomadik/include/plat/gpio.h +++ b/arch/arm/plat-nomadik/include/plat/gpio.h | |||
| @@ -55,6 +55,21 @@ | |||
| 55 | #define NMK_GPIO_ALT_B 2 | 55 | #define NMK_GPIO_ALT_B 2 |
| 56 | #define NMK_GPIO_ALT_C (NMK_GPIO_ALT_A | NMK_GPIO_ALT_B) | 56 | #define NMK_GPIO_ALT_C (NMK_GPIO_ALT_A | NMK_GPIO_ALT_B) |
| 57 | 57 | ||
| 58 | /* Pull up/down values */ | ||
| 59 | enum nmk_gpio_pull { | ||
| 60 | NMK_GPIO_PULL_NONE, | ||
| 61 | NMK_GPIO_PULL_UP, | ||
| 62 | NMK_GPIO_PULL_DOWN, | ||
| 63 | }; | ||
| 64 | |||
| 65 | /* Sleep mode */ | ||
| 66 | enum nmk_gpio_slpm { | ||
| 67 | NMK_GPIO_SLPM_INPUT, | ||
| 68 | NMK_GPIO_SLPM_NOCHANGE, | ||
| 69 | }; | ||
| 70 | |||
| 71 | extern int nmk_gpio_set_slpm(int gpio, enum nmk_gpio_slpm mode); | ||
| 72 | extern int nmk_gpio_set_pull(int gpio, enum nmk_gpio_pull pull); | ||
| 58 | extern int nmk_gpio_set_mode(int gpio, int gpio_mode); | 73 | extern int nmk_gpio_set_mode(int gpio, int gpio_mode); |
| 59 | extern int nmk_gpio_get_mode(int gpio); | 74 | extern int nmk_gpio_get_mode(int gpio); |
| 60 | 75 | ||
diff --git a/arch/arm/plat-nomadik/include/plat/mtu.h b/arch/arm/plat-nomadik/include/plat/mtu.h index 42c907258b14..65704a3d4241 100644 --- a/arch/arm/plat-nomadik/include/plat/mtu.h +++ b/arch/arm/plat-nomadik/include/plat/mtu.h | |||
| @@ -1,6 +1,12 @@ | |||
| 1 | #ifndef __PLAT_MTU_H | 1 | #ifndef __PLAT_MTU_H |
| 2 | #define __PLAT_MTU_H | 2 | #define __PLAT_MTU_H |
| 3 | 3 | ||
| 4 | /* | ||
| 5 | * Guaranteed runtime conversion range in seconds for | ||
| 6 | * the clocksource and clockevent. | ||
| 7 | */ | ||
| 8 | #define MTU_MIN_RANGE 4 | ||
| 9 | |||
| 4 | /* should be set by the platform code */ | 10 | /* should be set by the platform code */ |
| 5 | extern void __iomem *mtu_base; | 11 | extern void __iomem *mtu_base; |
| 6 | 12 | ||
diff --git a/arch/arm/plat-nomadik/include/plat/pincfg.h b/arch/arm/plat-nomadik/include/plat/pincfg.h new file mode 100644 index 000000000000..7eed11c1038d --- /dev/null +++ b/arch/arm/plat-nomadik/include/plat/pincfg.h | |||
| @@ -0,0 +1,72 @@ | |||
| 1 | /* | ||
| 2 | * Copyright (C) ST-Ericsson SA 2010 | ||
| 3 | * | ||
| 4 | * License terms: GNU General Public License, version 2 | ||
| 5 | * Author: Rabin Vincent <rabin.vincent@stericsson.com> for ST-Ericsson | ||
| 6 | * | ||
| 7 | * Based on arch/arm/mach-pxa/include/mach/mfp.h: | ||
| 8 | * Copyright (C) 2007 Marvell International Ltd. | ||
| 9 | * eric miao <eric.miao@marvell.com> | ||
| 10 | */ | ||
| 11 | |||
| 12 | #ifndef __PLAT_PINCFG_H | ||
| 13 | #define __PLAT_PINCFG_H | ||
| 14 | |||
| 15 | /* | ||
| 16 | * pin configurations are represented by 32-bit integers: | ||
| 17 | * | ||
| 18 | * bit 0.. 8 - Pin Number (512 Pins Maximum) | ||
| 19 | * bit 9..10 - Alternate Function Selection | ||
| 20 | * bit 11..12 - Pull up/down state | ||
| 21 | * bit 13 - Sleep mode behaviour | ||
| 22 | * | ||
| 23 | * to facilitate the definition, the following macros are provided | ||
| 24 | * | ||
| 25 | * PIN_CFG_DEFAULT - default config (0): | ||
| 26 | * pull up/down = disabled | ||
| 27 | * sleep mode = input | ||
| 28 | * | ||
| 29 | * PIN_CFG - default config with alternate function | ||
| 30 | * PIN_CFG_PULL - default config with alternate function and pull up/down | ||
| 31 | */ | ||
| 32 | |||
| 33 | typedef unsigned long pin_cfg_t; | ||
| 34 | |||
| 35 | #define PIN_NUM_MASK 0x1ff | ||
| 36 | #define PIN_NUM(x) ((x) & PIN_NUM_MASK) | ||
| 37 | |||
| 38 | #define PIN_ALT_SHIFT 9 | ||
| 39 | #define PIN_ALT_MASK (0x3 << PIN_ALT_SHIFT) | ||
| 40 | #define PIN_ALT(x) (((x) & PIN_ALT_MASK) >> PIN_ALT_SHIFT) | ||
| 41 | #define PIN_GPIO (NMK_GPIO_ALT_GPIO << PIN_ALT_SHIFT) | ||
| 42 | #define PIN_ALT_A (NMK_GPIO_ALT_A << PIN_ALT_SHIFT) | ||
| 43 | #define PIN_ALT_B (NMK_GPIO_ALT_B << PIN_ALT_SHIFT) | ||
| 44 | #define PIN_ALT_C (NMK_GPIO_ALT_C << PIN_ALT_SHIFT) | ||
| 45 | |||
| 46 | #define PIN_PULL_SHIFT 11 | ||
| 47 | #define PIN_PULL_MASK (0x3 << PIN_PULL_SHIFT) | ||
| 48 | #define PIN_PULL(x) (((x) & PIN_PULL_MASK) >> PIN_PULL_SHIFT) | ||
| 49 | #define PIN_PULL_NONE (NMK_GPIO_PULL_NONE << PIN_PULL_SHIFT) | ||
| 50 | #define PIN_PULL_UP (NMK_GPIO_PULL_UP << PIN_PULL_SHIFT) | ||
| 51 | #define PIN_PULL_DOWN (NMK_GPIO_PULL_DOWN << PIN_PULL_SHIFT) | ||
| 52 | |||
| 53 | #define PIN_SLPM_SHIFT 13 | ||
| 54 | #define PIN_SLPM_MASK (0x1 << PIN_SLPM_SHIFT) | ||
| 55 | #define PIN_SLPM(x) (((x) & PIN_SLPM_MASK) >> PIN_SLPM_SHIFT) | ||
| 56 | #define PIN_SLPM_INPUT (NMK_GPIO_SLPM_INPUT << PIN_SLPM_SHIFT) | ||
| 57 | #define PIN_SLPM_NOCHANGE (NMK_GPIO_SLPM_NOCHANGE << PIN_SLPM_SHIFT) | ||
| 58 | |||
| 59 | #define PIN_CFG_DEFAULT (PIN_PULL_NONE | PIN_SLPM_INPUT) | ||
| 60 | |||
| 61 | #define PIN_CFG(num, alt) \ | ||
| 62 | (PIN_CFG_DEFAULT |\ | ||
| 63 | (PIN_NUM(num) | PIN_##alt)) | ||
| 64 | |||
| 65 | #define PIN_CFG_PULL(num, alt, pull) \ | ||
| 66 | ((PIN_CFG_DEFAULT & ~PIN_PULL_MASK) |\ | ||
| 67 | (PIN_NUM(num) | PIN_##alt | PIN_PULL_##pull)) | ||
| 68 | |||
| 69 | extern int nmk_config_pin(pin_cfg_t cfg); | ||
| 70 | extern int nmk_config_pins(pin_cfg_t *cfgs, int num); | ||
| 71 | |||
| 72 | #endif | ||
diff --git a/arch/arm/plat-nomadik/timer.c b/arch/arm/plat-nomadik/timer.c index 08aaa4a7f65f..ea3ca86c5283 100644 --- a/arch/arm/plat-nomadik/timer.c +++ b/arch/arm/plat-nomadik/timer.c | |||
| @@ -42,7 +42,6 @@ static struct clocksource nmdk_clksrc = { | |||
| 42 | .rating = 200, | 42 | .rating = 200, |
| 43 | .read = nmdk_read_timer_dummy, | 43 | .read = nmdk_read_timer_dummy, |
| 44 | .mask = CLOCKSOURCE_MASK(32), | 44 | .mask = CLOCKSOURCE_MASK(32), |
| 45 | .shift = 20, | ||
| 46 | .flags = CLOCK_SOURCE_IS_CONTINUOUS, | 45 | .flags = CLOCK_SOURCE_IS_CONTINUOUS, |
| 47 | }; | 46 | }; |
| 48 | 47 | ||
| @@ -82,6 +81,12 @@ static void nmdk_clkevt_mode(enum clock_event_mode mode, | |||
| 82 | case CLOCK_EVT_MODE_UNUSED: | 81 | case CLOCK_EVT_MODE_UNUSED: |
| 83 | /* disable irq */ | 82 | /* disable irq */ |
| 84 | writel(0, mtu_base + MTU_IMSC); | 83 | writel(0, mtu_base + MTU_IMSC); |
| 84 | /* disable timer */ | ||
| 85 | cr = readl(mtu_base + MTU_CR(1)); | ||
| 86 | cr &= ~MTU_CRn_ENA; | ||
| 87 | writel(cr, mtu_base + MTU_CR(1)); | ||
| 88 | /* load some high default value */ | ||
| 89 | writel(0xffffffff, mtu_base + MTU_LR(1)); | ||
| 85 | break; | 90 | break; |
| 86 | case CLOCK_EVT_MODE_RESUME: | 91 | case CLOCK_EVT_MODE_RESUME: |
| 87 | break; | 92 | break; |
| @@ -98,7 +103,6 @@ static int nmdk_clkevt_next(unsigned long evt, struct clock_event_device *ev) | |||
| 98 | static struct clock_event_device nmdk_clkevt = { | 103 | static struct clock_event_device nmdk_clkevt = { |
| 99 | .name = "mtu_1", | 104 | .name = "mtu_1", |
| 100 | .features = CLOCK_EVT_FEAT_ONESHOT, | 105 | .features = CLOCK_EVT_FEAT_ONESHOT, |
| 101 | .shift = 32, | ||
| 102 | .rating = 200, | 106 | .rating = 200, |
| 103 | .set_mode = nmdk_clkevt_mode, | 107 | .set_mode = nmdk_clkevt_mode, |
| 104 | .set_next_event = nmdk_clkevt_next, | 108 | .set_next_event = nmdk_clkevt_next, |
| @@ -151,6 +155,7 @@ void __init nmdk_timer_init(void) | |||
| 151 | } else { | 155 | } else { |
| 152 | cr |= MTU_CRn_PRESCALE_1; | 156 | cr |= MTU_CRn_PRESCALE_1; |
| 153 | } | 157 | } |
| 158 | clocksource_calc_mult_shift(&nmdk_clksrc, rate, MTU_MIN_RANGE); | ||
| 154 | 159 | ||
| 155 | /* Timer 0 is the free running clocksource */ | 160 | /* Timer 0 is the free running clocksource */ |
| 156 | writel(cr, mtu_base + MTU_CR(0)); | 161 | writel(cr, mtu_base + MTU_CR(0)); |
| @@ -158,7 +163,6 @@ void __init nmdk_timer_init(void) | |||
| 158 | writel(0, mtu_base + MTU_BGLR(0)); | 163 | writel(0, mtu_base + MTU_BGLR(0)); |
| 159 | writel(cr | MTU_CRn_ENA, mtu_base + MTU_CR(0)); | 164 | writel(cr | MTU_CRn_ENA, mtu_base + MTU_CR(0)); |
| 160 | 165 | ||
| 161 | nmdk_clksrc.mult = clocksource_hz2mult(rate, nmdk_clksrc.shift); | ||
| 162 | /* Now the scheduling clock is ready */ | 166 | /* Now the scheduling clock is ready */ |
| 163 | nmdk_clksrc.read = nmdk_read_timer; | 167 | nmdk_clksrc.read = nmdk_read_timer; |
| 164 | 168 | ||
| @@ -175,8 +179,10 @@ void __init nmdk_timer_init(void) | |||
| 175 | } else { | 179 | } else { |
| 176 | cr |= MTU_CRn_PRESCALE_1; | 180 | cr |= MTU_CRn_PRESCALE_1; |
| 177 | } | 181 | } |
| 182 | clockevents_calc_mult_shift(&nmdk_clkevt, rate, MTU_MIN_RANGE); | ||
| 183 | |||
| 178 | writel(cr | MTU_CRn_ONESHOT, mtu_base + MTU_CR(1)); /* off, currently */ | 184 | writel(cr | MTU_CRn_ONESHOT, mtu_base + MTU_CR(1)); /* off, currently */ |
| 179 | nmdk_clkevt.mult = div_sc(rate, NSEC_PER_SEC, nmdk_clkevt.shift); | 185 | |
| 180 | nmdk_clkevt.max_delta_ns = | 186 | nmdk_clkevt.max_delta_ns = |
| 181 | clockevent_delta2ns(0xffffffff, &nmdk_clkevt); | 187 | clockevent_delta2ns(0xffffffff, &nmdk_clkevt); |
| 182 | nmdk_clkevt.min_delta_ns = | 188 | nmdk_clkevt.min_delta_ns = |
diff --git a/arch/arm/plat-omap/common.c b/arch/arm/plat-omap/common.c index 219c01e82bc5..ebed82699eb2 100644 --- a/arch/arm/plat-omap/common.c +++ b/arch/arm/plat-omap/common.c | |||
| @@ -22,6 +22,7 @@ | |||
| 22 | #include <linux/serial_reg.h> | 22 | #include <linux/serial_reg.h> |
| 23 | #include <linux/clk.h> | 23 | #include <linux/clk.h> |
| 24 | #include <linux/io.h> | 24 | #include <linux/io.h> |
| 25 | #include <linux/omapfb.h> | ||
| 25 | 26 | ||
| 26 | #include <mach/hardware.h> | 27 | #include <mach/hardware.h> |
| 27 | #include <asm/system.h> | 28 | #include <asm/system.h> |
| @@ -35,6 +36,7 @@ | |||
| 35 | #include <plat/mux.h> | 36 | #include <plat/mux.h> |
| 36 | #include <plat/fpga.h> | 37 | #include <plat/fpga.h> |
| 37 | #include <plat/serial.h> | 38 | #include <plat/serial.h> |
| 39 | #include <plat/vram.h> | ||
| 38 | 40 | ||
| 39 | #include <plat/clock.h> | 41 | #include <plat/clock.h> |
| 40 | 42 | ||
| @@ -81,6 +83,12 @@ const void *omap_get_var_config(u16 tag, size_t *len) | |||
| 81 | } | 83 | } |
| 82 | EXPORT_SYMBOL(omap_get_var_config); | 84 | EXPORT_SYMBOL(omap_get_var_config); |
| 83 | 85 | ||
| 86 | void __init omap_reserve(void) | ||
| 87 | { | ||
| 88 | omapfb_reserve_sdram_memblock(); | ||
| 89 | omap_vram_reserve_sdram_memblock(); | ||
| 90 | } | ||
| 91 | |||
| 84 | /* | 92 | /* |
| 85 | * 32KHz clocksource ... always available, on pretty most chips except | 93 | * 32KHz clocksource ... always available, on pretty most chips except |
| 86 | * OMAP 730 and 1510. Other timers could be used as clocksources, with | 94 | * OMAP 730 and 1510. Other timers could be used as clocksources, with |
diff --git a/arch/arm/plat-omap/fb.c b/arch/arm/plat-omap/fb.c index d3eea4f47533..0054b9501a53 100644 --- a/arch/arm/plat-omap/fb.c +++ b/arch/arm/plat-omap/fb.c | |||
| @@ -26,7 +26,7 @@ | |||
| 26 | #include <linux/mm.h> | 26 | #include <linux/mm.h> |
| 27 | #include <linux/init.h> | 27 | #include <linux/init.h> |
| 28 | #include <linux/platform_device.h> | 28 | #include <linux/platform_device.h> |
| 29 | #include <linux/bootmem.h> | 29 | #include <linux/memblock.h> |
| 30 | #include <linux/io.h> | 30 | #include <linux/io.h> |
| 31 | #include <linux/omapfb.h> | 31 | #include <linux/omapfb.h> |
| 32 | 32 | ||
| @@ -171,49 +171,78 @@ static int check_fbmem_region(int region_idx, struct omapfb_mem_region *rg, | |||
| 171 | return 0; | 171 | return 0; |
| 172 | } | 172 | } |
| 173 | 173 | ||
| 174 | static int valid_sdram(unsigned long addr, unsigned long size) | ||
| 175 | { | ||
| 176 | struct memblock_property res; | ||
| 177 | |||
| 178 | res.base = addr; | ||
| 179 | res.size = size; | ||
| 180 | return !memblock_find(&res) && res.base == addr && res.size == size; | ||
| 181 | } | ||
| 182 | |||
| 183 | static int reserve_sdram(unsigned long addr, unsigned long size) | ||
| 184 | { | ||
| 185 | if (memblock_is_region_reserved(addr, size)) | ||
| 186 | return -EBUSY; | ||
| 187 | if (memblock_reserve(addr, size)) | ||
| 188 | return -ENOMEM; | ||
| 189 | return 0; | ||
| 190 | } | ||
| 191 | |||
| 174 | /* | 192 | /* |
| 175 | * Called from map_io. We need to call to this early enough so that we | 193 | * Called from map_io. We need to call to this early enough so that we |
| 176 | * can reserve the fixed SDRAM regions before VM could get hold of them. | 194 | * can reserve the fixed SDRAM regions before VM could get hold of them. |
| 177 | */ | 195 | */ |
| 178 | void __init omapfb_reserve_sdram(void) | 196 | void __init omapfb_reserve_sdram_memblock(void) |
| 179 | { | 197 | { |
| 180 | struct bootmem_data *bdata; | 198 | unsigned long reserved = 0; |
| 181 | unsigned long sdram_start, sdram_size; | 199 | int i; |
| 182 | unsigned long reserved; | ||
| 183 | int i; | ||
| 184 | 200 | ||
| 185 | if (config_invalid) | 201 | if (config_invalid) |
| 186 | return; | 202 | return; |
| 187 | 203 | ||
| 188 | bdata = NODE_DATA(0)->bdata; | ||
| 189 | sdram_start = bdata->node_min_pfn << PAGE_SHIFT; | ||
| 190 | sdram_size = (bdata->node_low_pfn << PAGE_SHIFT) - sdram_start; | ||
| 191 | reserved = 0; | ||
| 192 | for (i = 0; ; i++) { | 204 | for (i = 0; ; i++) { |
| 193 | struct omapfb_mem_region rg; | 205 | struct omapfb_mem_region rg; |
| 194 | 206 | ||
| 195 | if (get_fbmem_region(i, &rg) < 0) | 207 | if (get_fbmem_region(i, &rg) < 0) |
| 196 | break; | 208 | break; |
| 209 | |||
| 197 | if (i == OMAPFB_PLANE_NUM) { | 210 | if (i == OMAPFB_PLANE_NUM) { |
| 198 | printk(KERN_ERR | 211 | pr_err("Extraneous FB mem configuration entries\n"); |
| 199 | "Extraneous FB mem configuration entries\n"); | ||
| 200 | config_invalid = 1; | 212 | config_invalid = 1; |
| 201 | return; | 213 | return; |
| 202 | } | 214 | } |
| 215 | |||
| 203 | /* Check if it's our memory type. */ | 216 | /* Check if it's our memory type. */ |
| 204 | if (set_fbmem_region_type(&rg, OMAPFB_MEMTYPE_SDRAM, | 217 | if (rg.type != OMAPFB_MEMTYPE_SDRAM) |
| 205 | sdram_start, sdram_size) < 0 || | ||
| 206 | (rg.type != OMAPFB_MEMTYPE_SDRAM)) | ||
| 207 | continue; | 218 | continue; |
| 208 | BUG_ON(omapfb_config.mem_desc.region[i].size); | 219 | |
| 209 | if (check_fbmem_region(i, &rg, sdram_start, sdram_size) < 0) { | 220 | /* Check if the region falls within SDRAM */ |
| 221 | if (rg.paddr && !valid_sdram(rg.paddr, rg.size)) | ||
| 222 | continue; | ||
| 223 | |||
| 224 | if (rg.size == 0) { | ||
| 225 | pr_err("Zero size for FB region %d\n", i); | ||
| 210 | config_invalid = 1; | 226 | config_invalid = 1; |
| 211 | return; | 227 | return; |
| 212 | } | 228 | } |
| 229 | |||
| 213 | if (rg.paddr) { | 230 | if (rg.paddr) { |
| 214 | reserve_bootmem(rg.paddr, rg.size, BOOTMEM_DEFAULT); | 231 | if (reserve_sdram(rg.paddr, rg.size)) { |
| 232 | pr_err("Trying to use reserved memory for FB region %d\n", | ||
| 233 | i); | ||
| 234 | config_invalid = 1; | ||
| 235 | return; | ||
| 236 | } | ||
| 215 | reserved += rg.size; | 237 | reserved += rg.size; |
| 216 | } | 238 | } |
| 239 | |||
| 240 | if (omapfb_config.mem_desc.region[i].size) { | ||
| 241 | pr_err("FB region %d already set\n", i); | ||
| 242 | config_invalid = 1; | ||
| 243 | return; | ||
| 244 | } | ||
| 245 | |||
| 217 | omapfb_config.mem_desc.region[i] = rg; | 246 | omapfb_config.mem_desc.region[i] = rg; |
| 218 | configured_regions++; | 247 | configured_regions++; |
| 219 | } | 248 | } |
| @@ -359,7 +388,10 @@ static inline int omap_init_fb(void) | |||
| 359 | 388 | ||
| 360 | arch_initcall(omap_init_fb); | 389 | arch_initcall(omap_init_fb); |
| 361 | 390 | ||
| 362 | void omapfb_reserve_sdram(void) {} | 391 | void omapfb_reserve_sdram_memblock(void) |
| 392 | { | ||
| 393 | } | ||
| 394 | |||
| 363 | unsigned long omapfb_reserve_sram(unsigned long sram_pstart, | 395 | unsigned long omapfb_reserve_sram(unsigned long sram_pstart, |
| 364 | unsigned long sram_vstart, | 396 | unsigned long sram_vstart, |
| 365 | unsigned long sram_size, | 397 | unsigned long sram_size, |
| @@ -375,7 +407,10 @@ void omapfb_set_platform_data(struct omapfb_platform_data *data) | |||
| 375 | { | 407 | { |
| 376 | } | 408 | } |
| 377 | 409 | ||
| 378 | void omapfb_reserve_sdram(void) {} | 410 | void omapfb_reserve_sdram_memblock(void) |
| 411 | { | ||
| 412 | } | ||
| 413 | |||
| 379 | unsigned long omapfb_reserve_sram(unsigned long sram_pstart, | 414 | unsigned long omapfb_reserve_sram(unsigned long sram_pstart, |
| 380 | unsigned long sram_vstart, | 415 | unsigned long sram_vstart, |
| 381 | unsigned long sram_size, | 416 | unsigned long sram_size, |
diff --git a/arch/arm/plat-omap/include/plat/common.h b/arch/arm/plat-omap/include/plat/common.h index d265018f5e6b..5e4afbee0fd7 100644 --- a/arch/arm/plat-omap/include/plat/common.h +++ b/arch/arm/plat-omap/include/plat/common.h | |||
| @@ -34,6 +34,8 @@ struct sys_timer; | |||
| 34 | extern void omap_map_common_io(void); | 34 | extern void omap_map_common_io(void); |
| 35 | extern struct sys_timer omap_timer; | 35 | extern struct sys_timer omap_timer; |
| 36 | 36 | ||
| 37 | extern void omap_reserve(void); | ||
| 38 | |||
| 37 | /* | 39 | /* |
| 38 | * IO bases for various OMAP processors | 40 | * IO bases for various OMAP processors |
| 39 | * Except the tap base, rest all the io bases | 41 | * Except the tap base, rest all the io bases |
diff --git a/arch/arm/plat-omap/include/plat/vram.h b/arch/arm/plat-omap/include/plat/vram.h index edd4987758a6..0aa4ecd12c7d 100644 --- a/arch/arm/plat-omap/include/plat/vram.h +++ b/arch/arm/plat-omap/include/plat/vram.h | |||
| @@ -38,7 +38,7 @@ extern void omap_vram_get_info(unsigned long *vram, unsigned long *free_vram, | |||
| 38 | extern void omap_vram_set_sdram_vram(u32 size, u32 start); | 38 | extern void omap_vram_set_sdram_vram(u32 size, u32 start); |
| 39 | extern void omap_vram_set_sram_vram(u32 size, u32 start); | 39 | extern void omap_vram_set_sram_vram(u32 size, u32 start); |
| 40 | 40 | ||
| 41 | extern void omap_vram_reserve_sdram(void); | 41 | extern void omap_vram_reserve_sdram_memblock(void); |
| 42 | extern unsigned long omap_vram_reserve_sram(unsigned long sram_pstart, | 42 | extern unsigned long omap_vram_reserve_sram(unsigned long sram_pstart, |
| 43 | unsigned long sram_vstart, | 43 | unsigned long sram_vstart, |
| 44 | unsigned long sram_size, | 44 | unsigned long sram_size, |
| @@ -48,7 +48,7 @@ extern unsigned long omap_vram_reserve_sram(unsigned long sram_pstart, | |||
| 48 | static inline void omap_vram_set_sdram_vram(u32 size, u32 start) { } | 48 | static inline void omap_vram_set_sdram_vram(u32 size, u32 start) { } |
| 49 | static inline void omap_vram_set_sram_vram(u32 size, u32 start) { } | 49 | static inline void omap_vram_set_sram_vram(u32 size, u32 start) { } |
| 50 | 50 | ||
| 51 | static inline void omap_vram_reserve_sdram(void) { } | 51 | static inline void omap_vram_reserve_sdram_memblock(void) { } |
| 52 | static inline unsigned long omap_vram_reserve_sram(unsigned long sram_pstart, | 52 | static inline unsigned long omap_vram_reserve_sram(unsigned long sram_pstart, |
| 53 | unsigned long sram_vstart, | 53 | unsigned long sram_vstart, |
| 54 | unsigned long sram_size, | 54 | unsigned long sram_size, |
diff --git a/arch/arm/plat-spear/include/plat/debug-macro.S b/arch/arm/plat-spear/include/plat/debug-macro.S index 1670734b7e51..37fa593884ee 100644 --- a/arch/arm/plat-spear/include/plat/debug-macro.S +++ b/arch/arm/plat-spear/include/plat/debug-macro.S | |||
| @@ -17,8 +17,8 @@ | |||
| 17 | .macro addruart, rx | 17 | .macro addruart, rx |
| 18 | mrc p15, 0, \rx, c1, c0 | 18 | mrc p15, 0, \rx, c1, c0 |
| 19 | tst \rx, #1 @ MMU enabled? | 19 | tst \rx, #1 @ MMU enabled? |
| 20 | moveq \rx, =SPEAR_DBG_UART_BASE @ Physical base | 20 | moveq \rx, #SPEAR_DBG_UART_BASE @ Physical base |
| 21 | movne \rx, =VA_SPEAR_DBG_UART_BASE @ Virtual base | 21 | movne \rx, #VA_SPEAR_DBG_UART_BASE @ Virtual base |
| 22 | .endm | 22 | .endm |
| 23 | 23 | ||
| 24 | .macro senduart, rd, rx | 24 | .macro senduart, rd, rx |
diff --git a/arch/arm/plat-spear/time.c b/arch/arm/plat-spear/time.c index a1025d38f383..ab211652e4ca 100644 --- a/arch/arm/plat-spear/time.c +++ b/arch/arm/plat-spear/time.c | |||
| @@ -58,6 +58,11 @@ | |||
| 58 | 58 | ||
| 59 | #define INT_STATUS 0x1 | 59 | #define INT_STATUS 0x1 |
| 60 | 60 | ||
| 61 | /* | ||
| 62 | * Minimum clocksource/clockevent timer range in seconds | ||
| 63 | */ | ||
| 64 | #define SPEAR_MIN_RANGE 4 | ||
| 65 | |||
| 61 | static __iomem void *gpt_base; | 66 | static __iomem void *gpt_base; |
| 62 | static struct clk *gpt_clk; | 67 | static struct clk *gpt_clk; |
| 63 | 68 | ||
| @@ -66,44 +71,6 @@ static void clockevent_set_mode(enum clock_event_mode mode, | |||
| 66 | static int clockevent_next_event(unsigned long evt, | 71 | static int clockevent_next_event(unsigned long evt, |
| 67 | struct clock_event_device *clk_event_dev); | 72 | struct clock_event_device *clk_event_dev); |
| 68 | 73 | ||
| 69 | /* | ||
| 70 | * Following clocksource_set_clock and clockevent_set_clock picked | ||
| 71 | * from arch/mips/kernel/time.c | ||
| 72 | */ | ||
| 73 | |||
| 74 | void __init clocksource_set_clock(struct clocksource *cs, unsigned int clock) | ||
| 75 | { | ||
| 76 | u64 temp; | ||
| 77 | u32 shift; | ||
| 78 | |||
| 79 | /* Find a shift value */ | ||
| 80 | for (shift = 32; shift > 0; shift--) { | ||
| 81 | temp = (u64) NSEC_PER_SEC << shift; | ||
| 82 | do_div(temp, clock); | ||
| 83 | if ((temp >> 32) == 0) | ||
| 84 | break; | ||
| 85 | } | ||
| 86 | cs->shift = shift; | ||
| 87 | cs->mult = (u32) temp; | ||
| 88 | } | ||
| 89 | |||
| 90 | void __init clockevent_set_clock(struct clock_event_device *cd, | ||
| 91 | unsigned int clock) | ||
| 92 | { | ||
| 93 | u64 temp; | ||
| 94 | u32 shift; | ||
| 95 | |||
| 96 | /* Find a shift value */ | ||
| 97 | for (shift = 32; shift > 0; shift--) { | ||
| 98 | temp = (u64) clock << shift; | ||
| 99 | do_div(temp, NSEC_PER_SEC); | ||
| 100 | if ((temp >> 32) == 0) | ||
| 101 | break; | ||
| 102 | } | ||
| 103 | cd->shift = shift; | ||
| 104 | cd->mult = (u32) temp; | ||
| 105 | } | ||
| 106 | |||
| 107 | static cycle_t clocksource_read_cycles(struct clocksource *cs) | 74 | static cycle_t clocksource_read_cycles(struct clocksource *cs) |
| 108 | { | 75 | { |
| 109 | return (cycle_t) readw(gpt_base + COUNT(CLKSRC)); | 76 | return (cycle_t) readw(gpt_base + COUNT(CLKSRC)); |
| @@ -138,7 +105,7 @@ static void spear_clocksource_init(void) | |||
| 138 | val |= CTRL_ENABLE ; | 105 | val |= CTRL_ENABLE ; |
| 139 | writew(val, gpt_base + CR(CLKSRC)); | 106 | writew(val, gpt_base + CR(CLKSRC)); |
| 140 | 107 | ||
| 141 | clocksource_set_clock(&clksrc, tick_rate); | 108 | clocksource_calc_mult_shift(&clksrc, tick_rate, SPEAR_MIN_RANGE); |
| 142 | 109 | ||
| 143 | /* register the clocksource */ | 110 | /* register the clocksource */ |
| 144 | clocksource_register(&clksrc); | 111 | clocksource_register(&clksrc); |
| @@ -233,7 +200,7 @@ static void __init spear_clockevent_init(void) | |||
| 233 | tick_rate = clk_get_rate(gpt_clk); | 200 | tick_rate = clk_get_rate(gpt_clk); |
| 234 | tick_rate >>= CTRL_PRESCALER16; | 201 | tick_rate >>= CTRL_PRESCALER16; |
| 235 | 202 | ||
| 236 | clockevent_set_clock(&clkevt, tick_rate); | 203 | clockevents_calc_mult_shift(&clkevt, tick_rate, SPEAR_MIN_RANGE); |
| 237 | 204 | ||
| 238 | clkevt.max_delta_ns = clockevent_delta2ns(0xfff0, | 205 | clkevt.max_delta_ns = clockevent_delta2ns(0xfff0, |
| 239 | &clkevt); | 206 | &clkevt); |
diff --git a/arch/arm/plat-versatile/Makefile b/arch/arm/plat-versatile/Makefile index 9b1a66816aa6..5cf88e8427b1 100644 --- a/arch/arm/plat-versatile/Makefile +++ b/arch/arm/plat-versatile/Makefile | |||
| @@ -2,3 +2,7 @@ obj-y := clock.o | |||
| 2 | obj-$(CONFIG_ARM_TIMER_SP804) += timer-sp.o | 2 | obj-$(CONFIG_ARM_TIMER_SP804) += timer-sp.o |
| 3 | obj-$(CONFIG_ARCH_REALVIEW) += sched-clock.o | 3 | obj-$(CONFIG_ARCH_REALVIEW) += sched-clock.o |
| 4 | obj-$(CONFIG_ARCH_VERSATILE) += sched-clock.o | 4 | obj-$(CONFIG_ARCH_VERSATILE) += sched-clock.o |
| 5 | ifeq ($(CONFIG_LEDS_CLASS),y) | ||
| 6 | obj-$(CONFIG_ARCH_REALVIEW) += leds.o | ||
| 7 | obj-$(CONFIG_ARCH_VERSATILE) += leds.o | ||
| 8 | endif | ||
diff --git a/arch/arm/plat-versatile/leds.c b/arch/arm/plat-versatile/leds.c new file mode 100644 index 000000000000..3169fa555ea6 --- /dev/null +++ b/arch/arm/plat-versatile/leds.c | |||
| @@ -0,0 +1,103 @@ | |||
| 1 | /* | ||
| 2 | * Driver for the 8 user LEDs found on the RealViews and Versatiles | ||
| 3 | * Based on DaVinci's DM365 board code | ||
| 4 | * | ||
| 5 | * License terms: GNU General Public License (GPL) version 2 | ||
| 6 | * Author: Linus Walleij <triad@df.lth.se> | ||
| 7 | */ | ||
| 8 | #include <linux/kernel.h> | ||
| 9 | #include <linux/init.h> | ||
| 10 | #include <linux/io.h> | ||
| 11 | #include <linux/slab.h> | ||
| 12 | #include <linux/leds.h> | ||
| 13 | |||
| 14 | #include <mach/hardware.h> | ||
| 15 | #include <mach/platform.h> | ||
| 16 | |||
| 17 | #ifdef VERSATILE_SYS_BASE | ||
| 18 | #define LEDREG (__io_address(VERSATILE_SYS_BASE) + VERSATILE_SYS_LED_OFFSET) | ||
| 19 | #endif | ||
| 20 | |||
| 21 | #ifdef REALVIEW_SYS_BASE | ||
| 22 | #define LEDREG (__io_address(REALVIEW_SYS_BASE) + REALVIEW_SYS_LED_OFFSET) | ||
| 23 | #endif | ||
| 24 | |||
| 25 | struct versatile_led { | ||
| 26 | struct led_classdev cdev; | ||
| 27 | u8 mask; | ||
| 28 | }; | ||
| 29 | |||
| 30 | /* | ||
| 31 | * The triggers lines up below will only be used if the | ||
| 32 | * LED triggers are compiled in. | ||
| 33 | */ | ||
| 34 | static const struct { | ||
| 35 | const char *name; | ||
| 36 | const char *trigger; | ||
| 37 | } versatile_leds[] = { | ||
| 38 | { "versatile:0", "heartbeat", }, | ||
| 39 | { "versatile:1", "mmc0", }, | ||
| 40 | { "versatile:2", }, | ||
| 41 | { "versatile:3", }, | ||
| 42 | { "versatile:4", }, | ||
| 43 | { "versatile:5", }, | ||
| 44 | { "versatile:6", }, | ||
| 45 | { "versatile:7", }, | ||
| 46 | }; | ||
| 47 | |||
| 48 | static void versatile_led_set(struct led_classdev *cdev, | ||
| 49 | enum led_brightness b) | ||
| 50 | { | ||
| 51 | struct versatile_led *led = container_of(cdev, | ||
| 52 | struct versatile_led, cdev); | ||
| 53 | u32 reg = readl(LEDREG); | ||
| 54 | |||
| 55 | if (b != LED_OFF) | ||
| 56 | reg |= led->mask; | ||
| 57 | else | ||
| 58 | reg &= ~led->mask; | ||
| 59 | writel(reg, LEDREG); | ||
| 60 | } | ||
| 61 | |||
| 62 | static enum led_brightness versatile_led_get(struct led_classdev *cdev) | ||
| 63 | { | ||
| 64 | struct versatile_led *led = container_of(cdev, | ||
| 65 | struct versatile_led, cdev); | ||
| 66 | u32 reg = readl(LEDREG); | ||
| 67 | |||
| 68 | return (reg & led->mask) ? LED_FULL : LED_OFF; | ||
| 69 | } | ||
| 70 | |||
| 71 | static int __init versatile_leds_init(void) | ||
| 72 | { | ||
| 73 | int i; | ||
| 74 | |||
| 75 | /* All ON */ | ||
| 76 | writel(0xff, LEDREG); | ||
| 77 | for (i = 0; i < ARRAY_SIZE(versatile_leds); i++) { | ||
| 78 | struct versatile_led *led; | ||
| 79 | |||
| 80 | led = kzalloc(sizeof(*led), GFP_KERNEL); | ||
| 81 | if (!led) | ||
| 82 | break; | ||
| 83 | |||
| 84 | led->cdev.name = versatile_leds[i].name; | ||
| 85 | led->cdev.brightness_set = versatile_led_set; | ||
| 86 | led->cdev.brightness_get = versatile_led_get; | ||
| 87 | led->cdev.default_trigger = versatile_leds[i].trigger; | ||
| 88 | led->mask = BIT(i); | ||
| 89 | |||
| 90 | if (led_classdev_register(NULL, &led->cdev) < 0) { | ||
| 91 | kfree(led); | ||
| 92 | break; | ||
| 93 | } | ||
| 94 | } | ||
| 95 | |||
| 96 | return 0; | ||
| 97 | } | ||
| 98 | |||
| 99 | /* | ||
| 100 | * Since we may have triggers on any subsystem, defer registration | ||
| 101 | * until after subsystem_init. | ||
| 102 | */ | ||
| 103 | fs_initcall(versatile_leds_init); | ||
diff --git a/arch/arm/vfp/vfpmodule.c b/arch/arm/vfp/vfpmodule.c index 315a540c7ce5..8063a322c790 100644 --- a/arch/arm/vfp/vfpmodule.c +++ b/arch/arm/vfp/vfpmodule.c | |||
| @@ -15,6 +15,7 @@ | |||
| 15 | #include <linux/sched.h> | 15 | #include <linux/sched.h> |
| 16 | #include <linux/init.h> | 16 | #include <linux/init.h> |
| 17 | 17 | ||
| 18 | #include <asm/cputype.h> | ||
| 18 | #include <asm/thread_notify.h> | 19 | #include <asm/thread_notify.h> |
| 19 | #include <asm/vfp.h> | 20 | #include <asm/vfp.h> |
| 20 | 21 | ||
| @@ -549,10 +550,13 @@ static int __init vfp_init(void) | |||
| 549 | /* | 550 | /* |
| 550 | * Check for the presence of the Advanced SIMD | 551 | * Check for the presence of the Advanced SIMD |
| 551 | * load/store instructions, integer and single | 552 | * load/store instructions, integer and single |
| 552 | * precision floating point operations. | 553 | * precision floating point operations. Only check |
| 554 | * for NEON if the hardware has the MVFR registers. | ||
| 553 | */ | 555 | */ |
| 554 | if ((fmrx(MVFR1) & 0x000fff00) == 0x00011100) | 556 | if ((read_cpuid_id() & 0x000f0000) == 0x000f0000) { |
| 555 | elf_hwcap |= HWCAP_NEON; | 557 | if ((fmrx(MVFR1) & 0x000fff00) == 0x00011100) |
| 558 | elf_hwcap |= HWCAP_NEON; | ||
| 559 | } | ||
| 556 | #endif | 560 | #endif |
| 557 | } | 561 | } |
| 558 | return 0; | 562 | return 0; |
diff --git a/arch/avr32/include/asm/ioctls.h b/arch/avr32/include/asm/ioctls.h index 0cf2c0a4502b..e6ac0b661076 100644 --- a/arch/avr32/include/asm/ioctls.h +++ b/arch/avr32/include/asm/ioctls.h | |||
| @@ -54,6 +54,9 @@ | |||
| 54 | #define TIOCGPTN _IOR('T',0x30, unsigned int) /* Get Pty Number (of pty-mux device) */ | 54 | #define TIOCGPTN _IOR('T',0x30, unsigned int) /* Get Pty Number (of pty-mux device) */ |
| 55 | #define TIOCSPTLCK _IOW('T',0x31, int) /* Lock/unlock Pty */ | 55 | #define TIOCSPTLCK _IOW('T',0x31, int) /* Lock/unlock Pty */ |
| 56 | 56 | ||
| 57 | #define TIOCGRS485 0x542E | ||
| 58 | #define TIOCSRS485 0x542F | ||
| 59 | |||
| 57 | #define FIONCLEX 0x5450 | 60 | #define FIONCLEX 0x5450 |
| 58 | #define FIOCLEX 0x5451 | 61 | #define FIOCLEX 0x5451 |
| 59 | #define FIOASYNC 0x5452 | 62 | #define FIOASYNC 0x5452 |
diff --git a/arch/avr32/mach-at32ap/include/mach/board.h b/arch/avr32/mach-at32ap/include/mach/board.h index c7f25bb1d068..61740201b311 100644 --- a/arch/avr32/mach-at32ap/include/mach/board.h +++ b/arch/avr32/mach-at32ap/include/mach/board.h | |||
| @@ -5,6 +5,7 @@ | |||
| 5 | #define __ASM_ARCH_BOARD_H | 5 | #define __ASM_ARCH_BOARD_H |
| 6 | 6 | ||
| 7 | #include <linux/types.h> | 7 | #include <linux/types.h> |
| 8 | #include <linux/serial.h> | ||
| 8 | 9 | ||
| 9 | #define GPIO_PIN_NONE (-1) | 10 | #define GPIO_PIN_NONE (-1) |
| 10 | 11 | ||
| @@ -35,6 +36,7 @@ struct atmel_uart_data { | |||
| 35 | short use_dma_tx; /* use transmit DMA? */ | 36 | short use_dma_tx; /* use transmit DMA? */ |
| 36 | short use_dma_rx; /* use receive DMA? */ | 37 | short use_dma_rx; /* use receive DMA? */ |
| 37 | void __iomem *regs; /* virtual base address, if any */ | 38 | void __iomem *regs; /* virtual base address, if any */ |
| 39 | struct serial_rs485 rs485; /* rs485 settings */ | ||
| 38 | }; | 40 | }; |
| 39 | void at32_map_usart(unsigned int hw_id, unsigned int line, int flags); | 41 | void at32_map_usart(unsigned int hw_id, unsigned int line, int flags); |
| 40 | struct platform_device *at32_add_device_usart(unsigned int id); | 42 | struct platform_device *at32_add_device_usart(unsigned int id); |
diff --git a/arch/mips/alchemy/common/platform.c b/arch/mips/alchemy/common/platform.c index 2580e77624d2..f9e5622ebc95 100644 --- a/arch/mips/alchemy/common/platform.c +++ b/arch/mips/alchemy/common/platform.c | |||
| @@ -435,20 +435,21 @@ static struct platform_device *au1xxx_platform_devices[] __initdata = { | |||
| 435 | static int __init au1xxx_platform_init(void) | 435 | static int __init au1xxx_platform_init(void) |
| 436 | { | 436 | { |
| 437 | unsigned int uartclk = get_au1x00_uart_baud_base() * 16; | 437 | unsigned int uartclk = get_au1x00_uart_baud_base() * 16; |
| 438 | int i; | 438 | int err, i; |
| 439 | 439 | ||
| 440 | /* Fill up uartclk. */ | 440 | /* Fill up uartclk. */ |
| 441 | for (i = 0; au1x00_uart_data[i].flags; i++) | 441 | for (i = 0; au1x00_uart_data[i].flags; i++) |
| 442 | au1x00_uart_data[i].uartclk = uartclk; | 442 | au1x00_uart_data[i].uartclk = uartclk; |
| 443 | 443 | ||
| 444 | err = platform_add_devices(au1xxx_platform_devices, | ||
| 445 | ARRAY_SIZE(au1xxx_platform_devices)); | ||
| 444 | #ifndef CONFIG_SOC_AU1100 | 446 | #ifndef CONFIG_SOC_AU1100 |
| 445 | /* Register second MAC if enabled in pinfunc */ | 447 | /* Register second MAC if enabled in pinfunc */ |
| 446 | if (!(au_readl(SYS_PINFUNC) & (u32)SYS_PF_NI2)) | 448 | if (!err && !(au_readl(SYS_PINFUNC) & (u32)SYS_PF_NI2)) |
| 447 | platform_device_register(&au1xxx_eth1_device); | 449 | platform_device_register(&au1xxx_eth1_device); |
| 448 | #endif | 450 | #endif |
| 449 | 451 | ||
| 450 | return platform_add_devices(au1xxx_platform_devices, | 452 | return err; |
| 451 | ARRAY_SIZE(au1xxx_platform_devices)); | ||
| 452 | } | 453 | } |
| 453 | 454 | ||
| 454 | arch_initcall(au1xxx_platform_init); | 455 | arch_initcall(au1xxx_platform_init); |
diff --git a/arch/mips/alchemy/mtx-1/board_setup.c b/arch/mips/alchemy/mtx-1/board_setup.c index a9f0336e1f1f..52d883d37dd7 100644 --- a/arch/mips/alchemy/mtx-1/board_setup.c +++ b/arch/mips/alchemy/mtx-1/board_setup.c | |||
| @@ -67,8 +67,6 @@ static void mtx1_power_off(void) | |||
| 67 | 67 | ||
| 68 | void __init board_setup(void) | 68 | void __init board_setup(void) |
| 69 | { | 69 | { |
| 70 | alchemy_gpio2_enable(); | ||
| 71 | |||
| 72 | #if defined(CONFIG_USB_OHCI_HCD) || defined(CONFIG_USB_OHCI_HCD_MODULE) | 70 | #if defined(CONFIG_USB_OHCI_HCD) || defined(CONFIG_USB_OHCI_HCD_MODULE) |
| 73 | /* Enable USB power switch */ | 71 | /* Enable USB power switch */ |
| 74 | alchemy_gpio_direction_output(204, 0); | 72 | alchemy_gpio_direction_output(204, 0); |
| @@ -117,11 +115,11 @@ mtx1_pci_idsel(unsigned int devsel, int assert) | |||
| 117 | 115 | ||
| 118 | if (assert && devsel != 0) | 116 | if (assert && devsel != 0) |
| 119 | /* Suppress signal to Cardbus */ | 117 | /* Suppress signal to Cardbus */ |
| 120 | gpio_set_value(1, 0); /* set EXT_IO3 OFF */ | 118 | alchemy_gpio_set_value(1, 0); /* set EXT_IO3 OFF */ |
| 121 | else | 119 | else |
| 122 | gpio_set_value(1, 1); /* set EXT_IO3 ON */ | 120 | alchemy_gpio_set_value(1, 1); /* set EXT_IO3 ON */ |
| 123 | 121 | ||
| 124 | au_sync_udelay(1); | 122 | udelay(1); |
| 125 | return 1; | 123 | return 1; |
| 126 | } | 124 | } |
| 127 | 125 | ||
diff --git a/arch/mips/bcm63xx/dev-enet.c b/arch/mips/bcm63xx/dev-enet.c index 9f544badd0b4..39c23366c5c7 100644 --- a/arch/mips/bcm63xx/dev-enet.c +++ b/arch/mips/bcm63xx/dev-enet.c | |||
| @@ -104,6 +104,9 @@ int __init bcm63xx_enet_register(int unit, | |||
| 104 | if (unit > 1) | 104 | if (unit > 1) |
| 105 | return -ENODEV; | 105 | return -ENODEV; |
| 106 | 106 | ||
| 107 | if (unit == 1 && BCMCPU_IS_6338()) | ||
| 108 | return -ENODEV; | ||
| 109 | |||
| 107 | if (!shared_device_registered) { | 110 | if (!shared_device_registered) { |
| 108 | shared_res[0].start = bcm63xx_regset_address(RSET_ENETDMA); | 111 | shared_res[0].start = bcm63xx_regset_address(RSET_ENETDMA); |
| 109 | shared_res[0].end = shared_res[0].start; | 112 | shared_res[0].end = shared_res[0].start; |
diff --git a/arch/mips/include/asm/atomic.h b/arch/mips/include/asm/atomic.h index 59dc0c7ef733..c63c56bfd184 100644 --- a/arch/mips/include/asm/atomic.h +++ b/arch/mips/include/asm/atomic.h | |||
| @@ -434,7 +434,7 @@ static __inline__ void atomic64_add(long i, atomic64_t * v) | |||
| 434 | __asm__ __volatile__( | 434 | __asm__ __volatile__( |
| 435 | " .set mips3 \n" | 435 | " .set mips3 \n" |
| 436 | "1: lld %0, %1 # atomic64_add \n" | 436 | "1: lld %0, %1 # atomic64_add \n" |
| 437 | " addu %0, %2 \n" | 437 | " daddu %0, %2 \n" |
| 438 | " scd %0, %1 \n" | 438 | " scd %0, %1 \n" |
| 439 | " beqzl %0, 1b \n" | 439 | " beqzl %0, 1b \n" |
| 440 | " .set mips0 \n" | 440 | " .set mips0 \n" |
| @@ -446,7 +446,7 @@ static __inline__ void atomic64_add(long i, atomic64_t * v) | |||
| 446 | __asm__ __volatile__( | 446 | __asm__ __volatile__( |
| 447 | " .set mips3 \n" | 447 | " .set mips3 \n" |
| 448 | "1: lld %0, %1 # atomic64_add \n" | 448 | "1: lld %0, %1 # atomic64_add \n" |
| 449 | " addu %0, %2 \n" | 449 | " daddu %0, %2 \n" |
| 450 | " scd %0, %1 \n" | 450 | " scd %0, %1 \n" |
| 451 | " beqz %0, 2f \n" | 451 | " beqz %0, 2f \n" |
| 452 | " .subsection 2 \n" | 452 | " .subsection 2 \n" |
| @@ -479,7 +479,7 @@ static __inline__ void atomic64_sub(long i, atomic64_t * v) | |||
| 479 | __asm__ __volatile__( | 479 | __asm__ __volatile__( |
| 480 | " .set mips3 \n" | 480 | " .set mips3 \n" |
| 481 | "1: lld %0, %1 # atomic64_sub \n" | 481 | "1: lld %0, %1 # atomic64_sub \n" |
| 482 | " subu %0, %2 \n" | 482 | " dsubu %0, %2 \n" |
| 483 | " scd %0, %1 \n" | 483 | " scd %0, %1 \n" |
| 484 | " beqzl %0, 1b \n" | 484 | " beqzl %0, 1b \n" |
| 485 | " .set mips0 \n" | 485 | " .set mips0 \n" |
| @@ -491,7 +491,7 @@ static __inline__ void atomic64_sub(long i, atomic64_t * v) | |||
| 491 | __asm__ __volatile__( | 491 | __asm__ __volatile__( |
| 492 | " .set mips3 \n" | 492 | " .set mips3 \n" |
| 493 | "1: lld %0, %1 # atomic64_sub \n" | 493 | "1: lld %0, %1 # atomic64_sub \n" |
| 494 | " subu %0, %2 \n" | 494 | " dsubu %0, %2 \n" |
| 495 | " scd %0, %1 \n" | 495 | " scd %0, %1 \n" |
| 496 | " beqz %0, 2f \n" | 496 | " beqz %0, 2f \n" |
| 497 | " .subsection 2 \n" | 497 | " .subsection 2 \n" |
| @@ -524,10 +524,10 @@ static __inline__ long atomic64_add_return(long i, atomic64_t * v) | |||
| 524 | __asm__ __volatile__( | 524 | __asm__ __volatile__( |
| 525 | " .set mips3 \n" | 525 | " .set mips3 \n" |
| 526 | "1: lld %1, %2 # atomic64_add_return \n" | 526 | "1: lld %1, %2 # atomic64_add_return \n" |
| 527 | " addu %0, %1, %3 \n" | 527 | " daddu %0, %1, %3 \n" |
| 528 | " scd %0, %2 \n" | 528 | " scd %0, %2 \n" |
| 529 | " beqzl %0, 1b \n" | 529 | " beqzl %0, 1b \n" |
| 530 | " addu %0, %1, %3 \n" | 530 | " daddu %0, %1, %3 \n" |
| 531 | " .set mips0 \n" | 531 | " .set mips0 \n" |
| 532 | : "=&r" (result), "=&r" (temp), "=m" (v->counter) | 532 | : "=&r" (result), "=&r" (temp), "=m" (v->counter) |
| 533 | : "Ir" (i), "m" (v->counter) | 533 | : "Ir" (i), "m" (v->counter) |
| @@ -538,10 +538,10 @@ static __inline__ long atomic64_add_return(long i, atomic64_t * v) | |||
| 538 | __asm__ __volatile__( | 538 | __asm__ __volatile__( |
| 539 | " .set mips3 \n" | 539 | " .set mips3 \n" |
| 540 | "1: lld %1, %2 # atomic64_add_return \n" | 540 | "1: lld %1, %2 # atomic64_add_return \n" |
| 541 | " addu %0, %1, %3 \n" | 541 | " daddu %0, %1, %3 \n" |
| 542 | " scd %0, %2 \n" | 542 | " scd %0, %2 \n" |
| 543 | " beqz %0, 2f \n" | 543 | " beqz %0, 2f \n" |
| 544 | " addu %0, %1, %3 \n" | 544 | " daddu %0, %1, %3 \n" |
| 545 | " .subsection 2 \n" | 545 | " .subsection 2 \n" |
| 546 | "2: b 1b \n" | 546 | "2: b 1b \n" |
| 547 | " .previous \n" | 547 | " .previous \n" |
| @@ -576,10 +576,10 @@ static __inline__ long atomic64_sub_return(long i, atomic64_t * v) | |||
| 576 | __asm__ __volatile__( | 576 | __asm__ __volatile__( |
| 577 | " .set mips3 \n" | 577 | " .set mips3 \n" |
| 578 | "1: lld %1, %2 # atomic64_sub_return \n" | 578 | "1: lld %1, %2 # atomic64_sub_return \n" |
| 579 | " subu %0, %1, %3 \n" | 579 | " dsubu %0, %1, %3 \n" |
| 580 | " scd %0, %2 \n" | 580 | " scd %0, %2 \n" |
| 581 | " beqzl %0, 1b \n" | 581 | " beqzl %0, 1b \n" |
| 582 | " subu %0, %1, %3 \n" | 582 | " dsubu %0, %1, %3 \n" |
| 583 | " .set mips0 \n" | 583 | " .set mips0 \n" |
| 584 | : "=&r" (result), "=&r" (temp), "=m" (v->counter) | 584 | : "=&r" (result), "=&r" (temp), "=m" (v->counter) |
| 585 | : "Ir" (i), "m" (v->counter) | 585 | : "Ir" (i), "m" (v->counter) |
| @@ -590,10 +590,10 @@ static __inline__ long atomic64_sub_return(long i, atomic64_t * v) | |||
| 590 | __asm__ __volatile__( | 590 | __asm__ __volatile__( |
| 591 | " .set mips3 \n" | 591 | " .set mips3 \n" |
| 592 | "1: lld %1, %2 # atomic64_sub_return \n" | 592 | "1: lld %1, %2 # atomic64_sub_return \n" |
| 593 | " subu %0, %1, %3 \n" | 593 | " dsubu %0, %1, %3 \n" |
| 594 | " scd %0, %2 \n" | 594 | " scd %0, %2 \n" |
| 595 | " beqz %0, 2f \n" | 595 | " beqz %0, 2f \n" |
| 596 | " subu %0, %1, %3 \n" | 596 | " dsubu %0, %1, %3 \n" |
| 597 | " .subsection 2 \n" | 597 | " .subsection 2 \n" |
| 598 | "2: b 1b \n" | 598 | "2: b 1b \n" |
| 599 | " .previous \n" | 599 | " .previous \n" |
diff --git a/arch/mips/include/asm/unistd.h b/arch/mips/include/asm/unistd.h index 1b5a6648eb86..baa318a59c97 100644 --- a/arch/mips/include/asm/unistd.h +++ b/arch/mips/include/asm/unistd.h | |||
| @@ -984,16 +984,17 @@ | |||
| 984 | #define __NR_perf_event_open (__NR_Linux + 296) | 984 | #define __NR_perf_event_open (__NR_Linux + 296) |
| 985 | #define __NR_accept4 (__NR_Linux + 297) | 985 | #define __NR_accept4 (__NR_Linux + 297) |
| 986 | #define __NR_recvmmsg (__NR_Linux + 298) | 986 | #define __NR_recvmmsg (__NR_Linux + 298) |
| 987 | #define __NR_getdents64 (__NR_Linux + 299) | ||
| 987 | 988 | ||
| 988 | /* | 989 | /* |
| 989 | * Offset of the last N32 flavoured syscall | 990 | * Offset of the last N32 flavoured syscall |
| 990 | */ | 991 | */ |
| 991 | #define __NR_Linux_syscalls 298 | 992 | #define __NR_Linux_syscalls 299 |
| 992 | 993 | ||
| 993 | #endif /* _MIPS_SIM == _MIPS_SIM_NABI32 */ | 994 | #endif /* _MIPS_SIM == _MIPS_SIM_NABI32 */ |
| 994 | 995 | ||
| 995 | #define __NR_N32_Linux 6000 | 996 | #define __NR_N32_Linux 6000 |
| 996 | #define __NR_N32_Linux_syscalls 298 | 997 | #define __NR_N32_Linux_syscalls 299 |
| 997 | 998 | ||
| 998 | #ifdef __KERNEL__ | 999 | #ifdef __KERNEL__ |
| 999 | 1000 | ||
diff --git a/arch/mips/kernel/scall64-n32.S b/arch/mips/kernel/scall64-n32.S index a5297e2a353a..a4faceea9d88 100644 --- a/arch/mips/kernel/scall64-n32.S +++ b/arch/mips/kernel/scall64-n32.S | |||
| @@ -419,4 +419,5 @@ EXPORT(sysn32_call_table) | |||
| 419 | PTR sys_perf_event_open | 419 | PTR sys_perf_event_open |
| 420 | PTR sys_accept4 | 420 | PTR sys_accept4 |
| 421 | PTR compat_sys_recvmmsg | 421 | PTR compat_sys_recvmmsg |
| 422 | PTR sys_getdents | ||
| 422 | .size sysn32_call_table,.-sysn32_call_table | 423 | .size sysn32_call_table,.-sysn32_call_table |
diff --git a/arch/mips/kernel/vdso.c b/arch/mips/kernel/vdso.c index b773c1112b14..e5cdfd603f8f 100644 --- a/arch/mips/kernel/vdso.c +++ b/arch/mips/kernel/vdso.c | |||
| @@ -61,11 +61,9 @@ static int __init init_vdso(void) | |||
| 61 | 61 | ||
| 62 | vunmap(vdso); | 62 | vunmap(vdso); |
| 63 | 63 | ||
| 64 | pr_notice("init_vdso successfull\n"); | ||
| 65 | |||
| 66 | return 0; | 64 | return 0; |
| 67 | } | 65 | } |
| 68 | device_initcall(init_vdso); | 66 | subsys_initcall(init_vdso); |
| 69 | 67 | ||
| 70 | static unsigned long vdso_addr(unsigned long start) | 68 | static unsigned long vdso_addr(unsigned long start) |
| 71 | { | 69 | { |
diff --git a/arch/mips/mti-malta/malta-pci.c b/arch/mips/mti-malta/malta-pci.c index 2fbfa1a8c3a9..bf80921f2f56 100644 --- a/arch/mips/mti-malta/malta-pci.c +++ b/arch/mips/mti-malta/malta-pci.c | |||
| @@ -247,6 +247,8 @@ void __init mips_pcibios_init(void) | |||
| 247 | iomem_resource.end &= 0xfffffffffULL; /* 64 GB */ | 247 | iomem_resource.end &= 0xfffffffffULL; /* 64 GB */ |
| 248 | ioport_resource.end = controller->io_resource->end; | 248 | ioport_resource.end = controller->io_resource->end; |
| 249 | 249 | ||
| 250 | controller->io_map_base = mips_io_port_base; | ||
| 251 | |||
| 250 | register_pci_controller(controller); | 252 | register_pci_controller(controller); |
| 251 | } | 253 | } |
| 252 | 254 | ||
diff --git a/arch/mips/nxp/pnx8550/common/pci.c b/arch/mips/nxp/pnx8550/common/pci.c index eee4f3dfc410..98e86ddb86cc 100644 --- a/arch/mips/nxp/pnx8550/common/pci.c +++ b/arch/mips/nxp/pnx8550/common/pci.c | |||
| @@ -44,6 +44,7 @@ extern struct pci_ops pnx8550_pci_ops; | |||
| 44 | 44 | ||
| 45 | static struct pci_controller pnx8550_controller = { | 45 | static struct pci_controller pnx8550_controller = { |
| 46 | .pci_ops = &pnx8550_pci_ops, | 46 | .pci_ops = &pnx8550_pci_ops, |
| 47 | .io_map_base = PNX8550_PORT_BASE, | ||
| 47 | .io_resource = &pci_io_resource, | 48 | .io_resource = &pci_io_resource, |
| 48 | .mem_resource = &pci_mem_resource, | 49 | .mem_resource = &pci_mem_resource, |
| 49 | }; | 50 | }; |
diff --git a/arch/mips/nxp/pnx8550/common/setup.c b/arch/mips/nxp/pnx8550/common/setup.c index 2aed50fef10f..64246c9c875c 100644 --- a/arch/mips/nxp/pnx8550/common/setup.c +++ b/arch/mips/nxp/pnx8550/common/setup.c | |||
| @@ -113,7 +113,7 @@ void __init plat_mem_setup(void) | |||
| 113 | PNX8550_GLB2_ENAB_INTA_O = 0; | 113 | PNX8550_GLB2_ENAB_INTA_O = 0; |
| 114 | 114 | ||
| 115 | /* IO/MEM resources. */ | 115 | /* IO/MEM resources. */ |
| 116 | set_io_port_base(KSEG1); | 116 | set_io_port_base(PNX8550_PORT_BASE); |
| 117 | ioport_resource.start = 0; | 117 | ioport_resource.start = 0; |
| 118 | ioport_resource.end = ~0; | 118 | ioport_resource.end = ~0; |
| 119 | iomem_resource.start = 0; | 119 | iomem_resource.start = 0; |
diff --git a/arch/mips/pci/ops-pmcmsp.c b/arch/mips/pci/ops-pmcmsp.c index 04b31478a6d7..b7c03d80c88c 100644 --- a/arch/mips/pci/ops-pmcmsp.c +++ b/arch/mips/pci/ops-pmcmsp.c | |||
| @@ -944,6 +944,7 @@ static struct pci_controller msp_pci_controller = { | |||
| 944 | .pci_ops = &msp_pci_ops, | 944 | .pci_ops = &msp_pci_ops, |
| 945 | .mem_resource = &pci_mem_resource, | 945 | .mem_resource = &pci_mem_resource, |
| 946 | .mem_offset = 0, | 946 | .mem_offset = 0, |
| 947 | .io_map_base = MSP_PCI_IOSPACE_BASE, | ||
| 947 | .io_resource = &pci_io_resource, | 948 | .io_resource = &pci_io_resource, |
| 948 | .io_offset = 0 | 949 | .io_offset = 0 |
| 949 | }; | 950 | }; |
diff --git a/arch/mips/pci/pci-yosemite.c b/arch/mips/pci/pci-yosemite.c index 0357946f30e6..cf5e1a25cb7d 100644 --- a/arch/mips/pci/pci-yosemite.c +++ b/arch/mips/pci/pci-yosemite.c | |||
| @@ -54,6 +54,7 @@ static int __init pmc_yosemite_setup(void) | |||
| 54 | panic(ioremap_failed); | 54 | panic(ioremap_failed); |
| 55 | 55 | ||
| 56 | set_io_port_base(io_v_base); | 56 | set_io_port_base(io_v_base); |
| 57 | py_controller.io_map_base = io_v_base; | ||
| 57 | TITAN_WRITE(RM9000x2_OCD_LKM7, TITAN_READ(RM9000x2_OCD_LKM7) | 1); | 58 | TITAN_WRITE(RM9000x2_OCD_LKM7, TITAN_READ(RM9000x2_OCD_LKM7) | 1); |
| 58 | 59 | ||
| 59 | ioport_resource.end = TITAN_IO_SIZE - 1; | 60 | ioport_resource.end = TITAN_IO_SIZE - 1; |
diff --git a/arch/mips/powertv/asic/asic_devices.c b/arch/mips/powertv/asic/asic_devices.c index 8ee77887306a..9ec523e4dd06 100644 --- a/arch/mips/powertv/asic/asic_devices.c +++ b/arch/mips/powertv/asic/asic_devices.c | |||
| @@ -472,6 +472,9 @@ void __init configure_platform(void) | |||
| 472 | * it*/ | 472 | * it*/ |
| 473 | platform_features = FFS_CAPABLE | DISPLAY_CAPABLE; | 473 | platform_features = FFS_CAPABLE | DISPLAY_CAPABLE; |
| 474 | 474 | ||
| 475 | /* Cronus and Cronus Lite have the same register map */ | ||
| 476 | set_register_map(CRONUS_IO_BASE, &cronus_register_map); | ||
| 477 | |||
| 475 | /* ASIC version will determine if this is a real CronusLite or | 478 | /* ASIC version will determine if this is a real CronusLite or |
| 476 | * Castrati(Cronus) */ | 479 | * Castrati(Cronus) */ |
| 477 | chipversion = asic_read(chipver3) << 24; | 480 | chipversion = asic_read(chipver3) << 24; |
| @@ -484,8 +487,6 @@ void __init configure_platform(void) | |||
| 484 | else | 487 | else |
| 485 | asic = ASIC_CRONUSLITE; | 488 | asic = ASIC_CRONUSLITE; |
| 486 | 489 | ||
| 487 | /* Cronus and Cronus Lite have the same register map */ | ||
| 488 | set_register_map(CRONUS_IO_BASE, &cronus_register_map); | ||
| 489 | gp_resources = non_dvr_cronuslite_resources; | 490 | gp_resources = non_dvr_cronuslite_resources; |
| 490 | pr_info("Platform: 4600 - %s, NON_DVR_CAPABLE, " | 491 | pr_info("Platform: 4600 - %s, NON_DVR_CAPABLE, " |
| 491 | "chipversion=0x%08X\n", | 492 | "chipversion=0x%08X\n", |
diff --git a/arch/powerpc/include/asm/kexec.h b/arch/powerpc/include/asm/kexec.h index 2a9cd74a841e..076327f2eff7 100644 --- a/arch/powerpc/include/asm/kexec.h +++ b/arch/powerpc/include/asm/kexec.h | |||
| @@ -8,9 +8,9 @@ | |||
| 8 | * On FSL-BookE we setup a 1:1 mapping which covers the first 2GiB of memory | 8 | * On FSL-BookE we setup a 1:1 mapping which covers the first 2GiB of memory |
| 9 | * and therefore we can only deal with memory within this range | 9 | * and therefore we can only deal with memory within this range |
| 10 | */ | 10 | */ |
| 11 | #define KEXEC_SOURCE_MEMORY_LIMIT (2 * 1024 * 1024 * 1024UL) | 11 | #define KEXEC_SOURCE_MEMORY_LIMIT (2 * 1024 * 1024 * 1024UL - 1) |
| 12 | #define KEXEC_DESTINATION_MEMORY_LIMIT (2 * 1024 * 1024 * 1024UL) | 12 | #define KEXEC_DESTINATION_MEMORY_LIMIT (2 * 1024 * 1024 * 1024UL - 1) |
| 13 | #define KEXEC_CONTROL_MEMORY_LIMIT (2 * 1024 * 1024 * 1024UL) | 13 | #define KEXEC_CONTROL_MEMORY_LIMIT (2 * 1024 * 1024 * 1024UL - 1) |
| 14 | 14 | ||
| 15 | #else | 15 | #else |
| 16 | 16 | ||
diff --git a/arch/powerpc/include/asm/mmu-hash64.h b/arch/powerpc/include/asm/mmu-hash64.h index 2102b214a87c..0e398cfee2c8 100644 --- a/arch/powerpc/include/asm/mmu-hash64.h +++ b/arch/powerpc/include/asm/mmu-hash64.h | |||
| @@ -250,7 +250,9 @@ extern int hash_page(unsigned long ea, unsigned long access, unsigned long trap) | |||
| 250 | int __hash_page_huge(unsigned long ea, unsigned long access, unsigned long vsid, | 250 | int __hash_page_huge(unsigned long ea, unsigned long access, unsigned long vsid, |
| 251 | pte_t *ptep, unsigned long trap, int local, int ssize, | 251 | pte_t *ptep, unsigned long trap, int local, int ssize, |
| 252 | unsigned int shift, unsigned int mmu_psize); | 252 | unsigned int shift, unsigned int mmu_psize); |
| 253 | 253 | extern void hash_failure_debug(unsigned long ea, unsigned long access, | |
| 254 | unsigned long vsid, unsigned long trap, | ||
| 255 | int ssize, int psize, unsigned long pte); | ||
| 254 | extern int htab_bolt_mapping(unsigned long vstart, unsigned long vend, | 256 | extern int htab_bolt_mapping(unsigned long vstart, unsigned long vend, |
| 255 | unsigned long pstart, unsigned long prot, | 257 | unsigned long pstart, unsigned long prot, |
| 256 | int psize, int ssize); | 258 | int psize, int ssize); |
diff --git a/arch/powerpc/kernel/perf_event_fsl_emb.c b/arch/powerpc/kernel/perf_event_fsl_emb.c index 369872f6cf78..babcceecd2ea 100644 --- a/arch/powerpc/kernel/perf_event_fsl_emb.c +++ b/arch/powerpc/kernel/perf_event_fsl_emb.c | |||
| @@ -566,9 +566,9 @@ static void record_and_restart(struct perf_event *event, unsigned long val, | |||
| 566 | * Finally record data if requested. | 566 | * Finally record data if requested. |
| 567 | */ | 567 | */ |
| 568 | if (record) { | 568 | if (record) { |
| 569 | struct perf_sample_data data = { | 569 | struct perf_sample_data data; |
| 570 | .period = event->hw.last_period, | 570 | |
| 571 | }; | 571 | perf_sample_data_init(&data, 0); |
| 572 | 572 | ||
| 573 | if (perf_event_overflow(event, nmi, &data, regs)) { | 573 | if (perf_event_overflow(event, nmi, &data, regs)) { |
| 574 | /* | 574 | /* |
diff --git a/arch/powerpc/kernel/prom.c b/arch/powerpc/kernel/prom.c index 9d3953983fb7..fed9bf6187d1 100644 --- a/arch/powerpc/kernel/prom.c +++ b/arch/powerpc/kernel/prom.c | |||
| @@ -414,7 +414,7 @@ static int __init early_init_dt_scan_drconf_memory(unsigned long node) | |||
| 414 | u64 base, size, memblock_size; | 414 | u64 base, size, memblock_size; |
| 415 | unsigned int is_kexec_kdump = 0, rngs; | 415 | unsigned int is_kexec_kdump = 0, rngs; |
| 416 | 416 | ||
| 417 | ls = of_get_flat_dt_prop(node, "ibm,memblock-size", &l); | 417 | ls = of_get_flat_dt_prop(node, "ibm,lmb-size", &l); |
| 418 | if (ls == NULL || l < dt_root_size_cells * sizeof(__be32)) | 418 | if (ls == NULL || l < dt_root_size_cells * sizeof(__be32)) |
| 419 | return 0; | 419 | return 0; |
| 420 | memblock_size = dt_mem_next_cell(dt_root_size_cells, &ls); | 420 | memblock_size = dt_mem_next_cell(dt_root_size_cells, &ls); |
diff --git a/arch/powerpc/mm/hash_low_64.S b/arch/powerpc/mm/hash_low_64.S index a719f53921a5..3079f6b44cf5 100644 --- a/arch/powerpc/mm/hash_low_64.S +++ b/arch/powerpc/mm/hash_low_64.S | |||
| @@ -68,9 +68,6 @@ _GLOBAL(__hash_page_4K) | |||
| 68 | std r8,STK_PARM(r8)(r1) | 68 | std r8,STK_PARM(r8)(r1) |
| 69 | std r9,STK_PARM(r9)(r1) | 69 | std r9,STK_PARM(r9)(r1) |
| 70 | 70 | ||
| 71 | /* Add _PAGE_PRESENT to access */ | ||
| 72 | ori r4,r4,_PAGE_PRESENT | ||
| 73 | |||
| 74 | /* Save non-volatile registers. | 71 | /* Save non-volatile registers. |
| 75 | * r31 will hold "old PTE" | 72 | * r31 will hold "old PTE" |
| 76 | * r30 is "new PTE" | 73 | * r30 is "new PTE" |
| @@ -347,9 +344,6 @@ _GLOBAL(__hash_page_4K) | |||
| 347 | std r8,STK_PARM(r8)(r1) | 344 | std r8,STK_PARM(r8)(r1) |
| 348 | std r9,STK_PARM(r9)(r1) | 345 | std r9,STK_PARM(r9)(r1) |
| 349 | 346 | ||
| 350 | /* Add _PAGE_PRESENT to access */ | ||
| 351 | ori r4,r4,_PAGE_PRESENT | ||
| 352 | |||
| 353 | /* Save non-volatile registers. | 347 | /* Save non-volatile registers. |
| 354 | * r31 will hold "old PTE" | 348 | * r31 will hold "old PTE" |
| 355 | * r30 is "new PTE" | 349 | * r30 is "new PTE" |
| @@ -687,9 +681,6 @@ _GLOBAL(__hash_page_64K) | |||
| 687 | std r8,STK_PARM(r8)(r1) | 681 | std r8,STK_PARM(r8)(r1) |
| 688 | std r9,STK_PARM(r9)(r1) | 682 | std r9,STK_PARM(r9)(r1) |
| 689 | 683 | ||
| 690 | /* Add _PAGE_PRESENT to access */ | ||
| 691 | ori r4,r4,_PAGE_PRESENT | ||
| 692 | |||
| 693 | /* Save non-volatile registers. | 684 | /* Save non-volatile registers. |
| 694 | * r31 will hold "old PTE" | 685 | * r31 will hold "old PTE" |
| 695 | * r30 is "new PTE" | 686 | * r30 is "new PTE" |
diff --git a/arch/powerpc/mm/hash_utils_64.c b/arch/powerpc/mm/hash_utils_64.c index 98f262de5585..09dffe6efa46 100644 --- a/arch/powerpc/mm/hash_utils_64.c +++ b/arch/powerpc/mm/hash_utils_64.c | |||
| @@ -871,6 +871,18 @@ static inline int subpage_protection(struct mm_struct *mm, unsigned long ea) | |||
| 871 | } | 871 | } |
| 872 | #endif | 872 | #endif |
| 873 | 873 | ||
| 874 | void hash_failure_debug(unsigned long ea, unsigned long access, | ||
| 875 | unsigned long vsid, unsigned long trap, | ||
| 876 | int ssize, int psize, unsigned long pte) | ||
| 877 | { | ||
| 878 | if (!printk_ratelimit()) | ||
| 879 | return; | ||
| 880 | pr_info("mm: Hashing failure ! EA=0x%lx access=0x%lx current=%s\n", | ||
| 881 | ea, access, current->comm); | ||
| 882 | pr_info(" trap=0x%lx vsid=0x%lx ssize=%d psize=%d pte=0x%lx\n", | ||
| 883 | trap, vsid, ssize, psize, pte); | ||
| 884 | } | ||
| 885 | |||
| 874 | /* Result code is: | 886 | /* Result code is: |
| 875 | * 0 - handled | 887 | * 0 - handled |
| 876 | * 1 - normal page fault | 888 | * 1 - normal page fault |
| @@ -955,6 +967,17 @@ int hash_page(unsigned long ea, unsigned long access, unsigned long trap) | |||
| 955 | return 1; | 967 | return 1; |
| 956 | } | 968 | } |
| 957 | 969 | ||
| 970 | /* Add _PAGE_PRESENT to the required access perm */ | ||
| 971 | access |= _PAGE_PRESENT; | ||
| 972 | |||
| 973 | /* Pre-check access permissions (will be re-checked atomically | ||
| 974 | * in __hash_page_XX but this pre-check is a fast path | ||
| 975 | */ | ||
| 976 | if (access & ~pte_val(*ptep)) { | ||
| 977 | DBG_LOW(" no access !\n"); | ||
| 978 | return 1; | ||
| 979 | } | ||
| 980 | |||
| 958 | #ifdef CONFIG_HUGETLB_PAGE | 981 | #ifdef CONFIG_HUGETLB_PAGE |
| 959 | if (hugeshift) | 982 | if (hugeshift) |
| 960 | return __hash_page_huge(ea, access, vsid, ptep, trap, local, | 983 | return __hash_page_huge(ea, access, vsid, ptep, trap, local, |
| @@ -967,14 +990,6 @@ int hash_page(unsigned long ea, unsigned long access, unsigned long trap) | |||
| 967 | DBG_LOW(" i-pte: %016lx %016lx\n", pte_val(*ptep), | 990 | DBG_LOW(" i-pte: %016lx %016lx\n", pte_val(*ptep), |
| 968 | pte_val(*(ptep + PTRS_PER_PTE))); | 991 | pte_val(*(ptep + PTRS_PER_PTE))); |
| 969 | #endif | 992 | #endif |
| 970 | /* Pre-check access permissions (will be re-checked atomically | ||
| 971 | * in __hash_page_XX but this pre-check is a fast path | ||
| 972 | */ | ||
| 973 | if (access & ~pte_val(*ptep)) { | ||
| 974 | DBG_LOW(" no access !\n"); | ||
| 975 | return 1; | ||
| 976 | } | ||
| 977 | |||
| 978 | /* Do actual hashing */ | 993 | /* Do actual hashing */ |
| 979 | #ifdef CONFIG_PPC_64K_PAGES | 994 | #ifdef CONFIG_PPC_64K_PAGES |
| 980 | /* If _PAGE_4K_PFN is set, make sure this is a 4k segment */ | 995 | /* If _PAGE_4K_PFN is set, make sure this is a 4k segment */ |
| @@ -1033,6 +1048,12 @@ int hash_page(unsigned long ea, unsigned long access, unsigned long trap) | |||
| 1033 | local, ssize, spp); | 1048 | local, ssize, spp); |
| 1034 | } | 1049 | } |
| 1035 | 1050 | ||
| 1051 | /* Dump some info in case of hash insertion failure, they should | ||
| 1052 | * never happen so it is really useful to know if/when they do | ||
| 1053 | */ | ||
| 1054 | if (rc == -1) | ||
| 1055 | hash_failure_debug(ea, access, vsid, trap, ssize, psize, | ||
| 1056 | pte_val(*ptep)); | ||
| 1036 | #ifndef CONFIG_PPC_64K_PAGES | 1057 | #ifndef CONFIG_PPC_64K_PAGES |
| 1037 | DBG_LOW(" o-pte: %016lx\n", pte_val(*ptep)); | 1058 | DBG_LOW(" o-pte: %016lx\n", pte_val(*ptep)); |
| 1038 | #else | 1059 | #else |
| @@ -1051,8 +1072,7 @@ void hash_preload(struct mm_struct *mm, unsigned long ea, | |||
| 1051 | void *pgdir; | 1072 | void *pgdir; |
| 1052 | pte_t *ptep; | 1073 | pte_t *ptep; |
| 1053 | unsigned long flags; | 1074 | unsigned long flags; |
| 1054 | int local = 0; | 1075 | int rc, ssize, local = 0; |
| 1055 | int ssize; | ||
| 1056 | 1076 | ||
| 1057 | BUG_ON(REGION_ID(ea) != USER_REGION_ID); | 1077 | BUG_ON(REGION_ID(ea) != USER_REGION_ID); |
| 1058 | 1078 | ||
| @@ -1098,11 +1118,18 @@ void hash_preload(struct mm_struct *mm, unsigned long ea, | |||
| 1098 | /* Hash it in */ | 1118 | /* Hash it in */ |
| 1099 | #ifdef CONFIG_PPC_HAS_HASH_64K | 1119 | #ifdef CONFIG_PPC_HAS_HASH_64K |
| 1100 | if (mm->context.user_psize == MMU_PAGE_64K) | 1120 | if (mm->context.user_psize == MMU_PAGE_64K) |
| 1101 | __hash_page_64K(ea, access, vsid, ptep, trap, local, ssize); | 1121 | rc = __hash_page_64K(ea, access, vsid, ptep, trap, local, ssize); |
| 1102 | else | 1122 | else |
| 1103 | #endif /* CONFIG_PPC_HAS_HASH_64K */ | 1123 | #endif /* CONFIG_PPC_HAS_HASH_64K */ |
| 1104 | __hash_page_4K(ea, access, vsid, ptep, trap, local, ssize, | 1124 | rc = __hash_page_4K(ea, access, vsid, ptep, trap, local, ssize, |
| 1105 | subpage_protection(pgdir, ea)); | 1125 | subpage_protection(pgdir, ea)); |
| 1126 | |||
| 1127 | /* Dump some info in case of hash insertion failure, they should | ||
| 1128 | * never happen so it is really useful to know if/when they do | ||
| 1129 | */ | ||
| 1130 | if (rc == -1) | ||
| 1131 | hash_failure_debug(ea, access, vsid, trap, ssize, | ||
| 1132 | mm->context.user_psize, pte_val(*ptep)); | ||
| 1106 | 1133 | ||
| 1107 | local_irq_restore(flags); | 1134 | local_irq_restore(flags); |
| 1108 | } | 1135 | } |
diff --git a/arch/powerpc/mm/hugetlbpage-hash64.c b/arch/powerpc/mm/hugetlbpage-hash64.c index 199539882f92..cc5c273086cf 100644 --- a/arch/powerpc/mm/hugetlbpage-hash64.c +++ b/arch/powerpc/mm/hugetlbpage-hash64.c | |||
| @@ -21,21 +21,13 @@ int __hash_page_huge(unsigned long ea, unsigned long access, unsigned long vsid, | |||
| 21 | unsigned long old_pte, new_pte; | 21 | unsigned long old_pte, new_pte; |
| 22 | unsigned long va, rflags, pa, sz; | 22 | unsigned long va, rflags, pa, sz; |
| 23 | long slot; | 23 | long slot; |
| 24 | int err = 1; | ||
| 25 | 24 | ||
| 26 | BUG_ON(shift != mmu_psize_defs[mmu_psize].shift); | 25 | BUG_ON(shift != mmu_psize_defs[mmu_psize].shift); |
| 27 | 26 | ||
| 28 | /* Search the Linux page table for a match with va */ | 27 | /* Search the Linux page table for a match with va */ |
| 29 | va = hpt_va(ea, vsid, ssize); | 28 | va = hpt_va(ea, vsid, ssize); |
| 30 | 29 | ||
| 31 | /* | 30 | /* At this point, we have a pte (old_pte) which can be used to build |
| 32 | * Check the user's access rights to the page. If access should be | ||
| 33 | * prevented then send the problem up to do_page_fault. | ||
| 34 | */ | ||
| 35 | if (unlikely(access & ~pte_val(*ptep))) | ||
| 36 | goto out; | ||
| 37 | /* | ||
| 38 | * At this point, we have a pte (old_pte) which can be used to build | ||
| 39 | * or update an HPTE. There are 2 cases: | 31 | * or update an HPTE. There are 2 cases: |
| 40 | * | 32 | * |
| 41 | * 1. There is a valid (present) pte with no associated HPTE (this is | 33 | * 1. There is a valid (present) pte with no associated HPTE (this is |
| @@ -49,9 +41,17 @@ int __hash_page_huge(unsigned long ea, unsigned long access, unsigned long vsid, | |||
| 49 | 41 | ||
| 50 | do { | 42 | do { |
| 51 | old_pte = pte_val(*ptep); | 43 | old_pte = pte_val(*ptep); |
| 52 | if (old_pte & _PAGE_BUSY) | 44 | /* If PTE busy, retry the access */ |
| 53 | goto out; | 45 | if (unlikely(old_pte & _PAGE_BUSY)) |
| 46 | return 0; | ||
| 47 | /* If PTE permissions don't match, take page fault */ | ||
| 48 | if (unlikely(access & ~old_pte)) | ||
| 49 | return 1; | ||
| 50 | /* Try to lock the PTE, add ACCESSED and DIRTY if it was | ||
| 51 | * a write access */ | ||
| 54 | new_pte = old_pte | _PAGE_BUSY | _PAGE_ACCESSED; | 52 | new_pte = old_pte | _PAGE_BUSY | _PAGE_ACCESSED; |
| 53 | if (access & _PAGE_RW) | ||
| 54 | new_pte |= _PAGE_DIRTY; | ||
| 55 | } while(old_pte != __cmpxchg_u64((unsigned long *)ptep, | 55 | } while(old_pte != __cmpxchg_u64((unsigned long *)ptep, |
| 56 | old_pte, new_pte)); | 56 | old_pte, new_pte)); |
| 57 | 57 | ||
| @@ -121,8 +121,16 @@ repeat: | |||
| 121 | } | 121 | } |
| 122 | } | 122 | } |
| 123 | 123 | ||
| 124 | if (unlikely(slot == -2)) | 124 | /* |
| 125 | panic("hash_huge_page: pte_insert failed\n"); | 125 | * Hypervisor failure. Restore old pte and return -1 |
| 126 | * similar to __hash_page_* | ||
| 127 | */ | ||
| 128 | if (unlikely(slot == -2)) { | ||
| 129 | *ptep = __pte(old_pte); | ||
| 130 | hash_failure_debug(ea, access, vsid, trap, ssize, | ||
| 131 | mmu_psize, old_pte); | ||
| 132 | return -1; | ||
| 133 | } | ||
| 126 | 134 | ||
| 127 | new_pte |= (slot << 12) & (_PAGE_F_SECOND | _PAGE_F_GIX); | 135 | new_pte |= (slot << 12) & (_PAGE_F_SECOND | _PAGE_F_GIX); |
| 128 | } | 136 | } |
| @@ -131,9 +139,5 @@ repeat: | |||
| 131 | * No need to use ldarx/stdcx here | 139 | * No need to use ldarx/stdcx here |
| 132 | */ | 140 | */ |
| 133 | *ptep = __pte(new_pte & ~_PAGE_BUSY); | 141 | *ptep = __pte(new_pte & ~_PAGE_BUSY); |
| 134 | 142 | return 0; | |
| 135 | err = 0; | ||
| 136 | |||
| 137 | out: | ||
| 138 | return err; | ||
| 139 | } | 143 | } |
diff --git a/arch/powerpc/mm/numa.c b/arch/powerpc/mm/numa.c index f47364585ecd..aa731af720c0 100644 --- a/arch/powerpc/mm/numa.c +++ b/arch/powerpc/mm/numa.c | |||
| @@ -398,15 +398,15 @@ static int of_get_drconf_memory(struct device_node *memory, const u32 **dm) | |||
| 398 | } | 398 | } |
| 399 | 399 | ||
| 400 | /* | 400 | /* |
| 401 | * Retreive and validate the ibm,memblock-size property for drconf memory | 401 | * Retreive and validate the ibm,lmb-size property for drconf memory |
| 402 | * from the device tree. | 402 | * from the device tree. |
| 403 | */ | 403 | */ |
| 404 | static u64 of_get_memblock_size(struct device_node *memory) | 404 | static u64 of_get_lmb_size(struct device_node *memory) |
| 405 | { | 405 | { |
| 406 | const u32 *prop; | 406 | const u32 *prop; |
| 407 | u32 len; | 407 | u32 len; |
| 408 | 408 | ||
| 409 | prop = of_get_property(memory, "ibm,memblock-size", &len); | 409 | prop = of_get_property(memory, "ibm,lmb-size", &len); |
| 410 | if (!prop || len < sizeof(unsigned int)) | 410 | if (!prop || len < sizeof(unsigned int)) |
| 411 | return 0; | 411 | return 0; |
| 412 | 412 | ||
| @@ -562,7 +562,7 @@ static unsigned long __init numa_enforce_memory_limit(unsigned long start, | |||
| 562 | static inline int __init read_usm_ranges(const u32 **usm) | 562 | static inline int __init read_usm_ranges(const u32 **usm) |
| 563 | { | 563 | { |
| 564 | /* | 564 | /* |
| 565 | * For each memblock in ibm,dynamic-memory a corresponding | 565 | * For each lmb in ibm,dynamic-memory a corresponding |
| 566 | * entry in linux,drconf-usable-memory property contains | 566 | * entry in linux,drconf-usable-memory property contains |
| 567 | * a counter followed by that many (base, size) duple. | 567 | * a counter followed by that many (base, size) duple. |
| 568 | * read the counter from linux,drconf-usable-memory | 568 | * read the counter from linux,drconf-usable-memory |
| @@ -578,7 +578,7 @@ static void __init parse_drconf_memory(struct device_node *memory) | |||
| 578 | { | 578 | { |
| 579 | const u32 *dm, *usm; | 579 | const u32 *dm, *usm; |
| 580 | unsigned int n, rc, ranges, is_kexec_kdump = 0; | 580 | unsigned int n, rc, ranges, is_kexec_kdump = 0; |
| 581 | unsigned long memblock_size, base, size, sz; | 581 | unsigned long lmb_size, base, size, sz; |
| 582 | int nid; | 582 | int nid; |
| 583 | struct assoc_arrays aa; | 583 | struct assoc_arrays aa; |
| 584 | 584 | ||
| @@ -586,8 +586,8 @@ static void __init parse_drconf_memory(struct device_node *memory) | |||
| 586 | if (!n) | 586 | if (!n) |
| 587 | return; | 587 | return; |
| 588 | 588 | ||
| 589 | memblock_size = of_get_memblock_size(memory); | 589 | lmb_size = of_get_lmb_size(memory); |
| 590 | if (!memblock_size) | 590 | if (!lmb_size) |
| 591 | return; | 591 | return; |
| 592 | 592 | ||
| 593 | rc = of_get_assoc_arrays(memory, &aa); | 593 | rc = of_get_assoc_arrays(memory, &aa); |
| @@ -611,7 +611,7 @@ static void __init parse_drconf_memory(struct device_node *memory) | |||
| 611 | continue; | 611 | continue; |
| 612 | 612 | ||
| 613 | base = drmem.base_addr; | 613 | base = drmem.base_addr; |
| 614 | size = memblock_size; | 614 | size = lmb_size; |
| 615 | ranges = 1; | 615 | ranges = 1; |
| 616 | 616 | ||
| 617 | if (is_kexec_kdump) { | 617 | if (is_kexec_kdump) { |
| @@ -1072,7 +1072,7 @@ static int hot_add_drconf_scn_to_nid(struct device_node *memory, | |||
| 1072 | { | 1072 | { |
| 1073 | const u32 *dm; | 1073 | const u32 *dm; |
| 1074 | unsigned int drconf_cell_cnt, rc; | 1074 | unsigned int drconf_cell_cnt, rc; |
| 1075 | unsigned long memblock_size; | 1075 | unsigned long lmb_size; |
| 1076 | struct assoc_arrays aa; | 1076 | struct assoc_arrays aa; |
| 1077 | int nid = -1; | 1077 | int nid = -1; |
| 1078 | 1078 | ||
| @@ -1080,8 +1080,8 @@ static int hot_add_drconf_scn_to_nid(struct device_node *memory, | |||
| 1080 | if (!drconf_cell_cnt) | 1080 | if (!drconf_cell_cnt) |
| 1081 | return -1; | 1081 | return -1; |
| 1082 | 1082 | ||
| 1083 | memblock_size = of_get_memblock_size(memory); | 1083 | lmb_size = of_get_lmb_size(memory); |
| 1084 | if (!memblock_size) | 1084 | if (!lmb_size) |
| 1085 | return -1; | 1085 | return -1; |
| 1086 | 1086 | ||
| 1087 | rc = of_get_assoc_arrays(memory, &aa); | 1087 | rc = of_get_assoc_arrays(memory, &aa); |
| @@ -1100,7 +1100,7 @@ static int hot_add_drconf_scn_to_nid(struct device_node *memory, | |||
| 1100 | continue; | 1100 | continue; |
| 1101 | 1101 | ||
| 1102 | if ((scn_addr < drmem.base_addr) | 1102 | if ((scn_addr < drmem.base_addr) |
| 1103 | || (scn_addr >= (drmem.base_addr + memblock_size))) | 1103 | || (scn_addr >= (drmem.base_addr + lmb_size))) |
| 1104 | continue; | 1104 | continue; |
| 1105 | 1105 | ||
| 1106 | nid = of_drconf_to_nid_single(&drmem, &aa); | 1106 | nid = of_drconf_to_nid_single(&drmem, &aa); |
diff --git a/arch/powerpc/platforms/pseries/hotplug-memory.c b/arch/powerpc/platforms/pseries/hotplug-memory.c index deab5f946090..bc8803664140 100644 --- a/arch/powerpc/platforms/pseries/hotplug-memory.c +++ b/arch/powerpc/platforms/pseries/hotplug-memory.c | |||
| @@ -69,7 +69,7 @@ static int pseries_remove_memory(struct device_node *np) | |||
| 69 | const char *type; | 69 | const char *type; |
| 70 | const unsigned int *regs; | 70 | const unsigned int *regs; |
| 71 | unsigned long base; | 71 | unsigned long base; |
| 72 | unsigned int memblock_size; | 72 | unsigned int lmb_size; |
| 73 | int ret = -EINVAL; | 73 | int ret = -EINVAL; |
| 74 | 74 | ||
| 75 | /* | 75 | /* |
| @@ -87,9 +87,9 @@ static int pseries_remove_memory(struct device_node *np) | |||
| 87 | return ret; | 87 | return ret; |
| 88 | 88 | ||
| 89 | base = *(unsigned long *)regs; | 89 | base = *(unsigned long *)regs; |
| 90 | memblock_size = regs[3]; | 90 | lmb_size = regs[3]; |
| 91 | 91 | ||
| 92 | ret = pseries_remove_memblock(base, memblock_size); | 92 | ret = pseries_remove_memblock(base, lmb_size); |
| 93 | return ret; | 93 | return ret; |
| 94 | } | 94 | } |
| 95 | 95 | ||
| @@ -98,7 +98,7 @@ static int pseries_add_memory(struct device_node *np) | |||
| 98 | const char *type; | 98 | const char *type; |
| 99 | const unsigned int *regs; | 99 | const unsigned int *regs; |
| 100 | unsigned long base; | 100 | unsigned long base; |
| 101 | unsigned int memblock_size; | 101 | unsigned int lmb_size; |
| 102 | int ret = -EINVAL; | 102 | int ret = -EINVAL; |
| 103 | 103 | ||
| 104 | /* | 104 | /* |
| @@ -116,36 +116,36 @@ static int pseries_add_memory(struct device_node *np) | |||
| 116 | return ret; | 116 | return ret; |
| 117 | 117 | ||
| 118 | base = *(unsigned long *)regs; | 118 | base = *(unsigned long *)regs; |
| 119 | memblock_size = regs[3]; | 119 | lmb_size = regs[3]; |
| 120 | 120 | ||
| 121 | /* | 121 | /* |
| 122 | * Update memory region to represent the memory add | 122 | * Update memory region to represent the memory add |
| 123 | */ | 123 | */ |
| 124 | ret = memblock_add(base, memblock_size); | 124 | ret = memblock_add(base, lmb_size); |
| 125 | return (ret < 0) ? -EINVAL : 0; | 125 | return (ret < 0) ? -EINVAL : 0; |
| 126 | } | 126 | } |
| 127 | 127 | ||
| 128 | static int pseries_drconf_memory(unsigned long *base, unsigned int action) | 128 | static int pseries_drconf_memory(unsigned long *base, unsigned int action) |
| 129 | { | 129 | { |
| 130 | struct device_node *np; | 130 | struct device_node *np; |
| 131 | const unsigned long *memblock_size; | 131 | const unsigned long *lmb_size; |
| 132 | int rc; | 132 | int rc; |
| 133 | 133 | ||
| 134 | np = of_find_node_by_path("/ibm,dynamic-reconfiguration-memory"); | 134 | np = of_find_node_by_path("/ibm,dynamic-reconfiguration-memory"); |
| 135 | if (!np) | 135 | if (!np) |
| 136 | return -EINVAL; | 136 | return -EINVAL; |
| 137 | 137 | ||
| 138 | memblock_size = of_get_property(np, "ibm,memblock-size", NULL); | 138 | lmb_size = of_get_property(np, "ibm,lmb-size", NULL); |
| 139 | if (!memblock_size) { | 139 | if (!lmb_size) { |
| 140 | of_node_put(np); | 140 | of_node_put(np); |
| 141 | return -EINVAL; | 141 | return -EINVAL; |
| 142 | } | 142 | } |
| 143 | 143 | ||
| 144 | if (action == PSERIES_DRCONF_MEM_ADD) { | 144 | if (action == PSERIES_DRCONF_MEM_ADD) { |
| 145 | rc = memblock_add(*base, *memblock_size); | 145 | rc = memblock_add(*base, *lmb_size); |
| 146 | rc = (rc < 0) ? -EINVAL : 0; | 146 | rc = (rc < 0) ? -EINVAL : 0; |
| 147 | } else if (action == PSERIES_DRCONF_MEM_REMOVE) { | 147 | } else if (action == PSERIES_DRCONF_MEM_REMOVE) { |
| 148 | rc = pseries_remove_memblock(*base, *memblock_size); | 148 | rc = pseries_remove_memblock(*base, *lmb_size); |
| 149 | } else { | 149 | } else { |
| 150 | rc = -EINVAL; | 150 | rc = -EINVAL; |
| 151 | } | 151 | } |
diff --git a/arch/x86/kernel/acpi/cstate.c b/arch/x86/kernel/acpi/cstate.c index 2e837f5080fe..fb7a5f052e2b 100644 --- a/arch/x86/kernel/acpi/cstate.c +++ b/arch/x86/kernel/acpi/cstate.c | |||
| @@ -145,6 +145,15 @@ int acpi_processor_ffh_cstate_probe(unsigned int cpu, | |||
| 145 | percpu_entry->states[cx->index].eax = cx->address; | 145 | percpu_entry->states[cx->index].eax = cx->address; |
| 146 | percpu_entry->states[cx->index].ecx = MWAIT_ECX_INTERRUPT_BREAK; | 146 | percpu_entry->states[cx->index].ecx = MWAIT_ECX_INTERRUPT_BREAK; |
| 147 | } | 147 | } |
| 148 | |||
| 149 | /* | ||
| 150 | * For _CST FFH on Intel, if GAS.access_size bit 1 is cleared, | ||
| 151 | * then we should skip checking BM_STS for this C-state. | ||
| 152 | * ref: "Intel Processor Vendor-Specific ACPI Interface Specification" | ||
| 153 | */ | ||
| 154 | if ((c->x86_vendor == X86_VENDOR_INTEL) && !(reg->access_size & 0x2)) | ||
| 155 | cx->bm_sts_skip = 1; | ||
| 156 | |||
| 148 | return retval; | 157 | return retval; |
| 149 | } | 158 | } |
| 150 | EXPORT_SYMBOL_GPL(acpi_processor_ffh_cstate_probe); | 159 | EXPORT_SYMBOL_GPL(acpi_processor_ffh_cstate_probe); |
diff --git a/arch/x86/kernel/acpi/sleep.c b/arch/x86/kernel/acpi/sleep.c index 82e508677b91..fcc3c61fdecc 100644 --- a/arch/x86/kernel/acpi/sleep.c +++ b/arch/x86/kernel/acpi/sleep.c | |||
| @@ -157,9 +157,14 @@ static int __init acpi_sleep_setup(char *str) | |||
| 157 | #ifdef CONFIG_HIBERNATION | 157 | #ifdef CONFIG_HIBERNATION |
| 158 | if (strncmp(str, "s4_nohwsig", 10) == 0) | 158 | if (strncmp(str, "s4_nohwsig", 10) == 0) |
| 159 | acpi_no_s4_hw_signature(); | 159 | acpi_no_s4_hw_signature(); |
| 160 | if (strncmp(str, "s4_nonvs", 8) == 0) | 160 | if (strncmp(str, "s4_nonvs", 8) == 0) { |
| 161 | acpi_s4_no_nvs(); | 161 | pr_warning("ACPI: acpi_sleep=s4_nonvs is deprecated, " |
| 162 | "please use acpi_sleep=nonvs instead"); | ||
| 163 | acpi_nvs_nosave(); | ||
| 164 | } | ||
| 162 | #endif | 165 | #endif |
| 166 | if (strncmp(str, "nonvs", 5) == 0) | ||
| 167 | acpi_nvs_nosave(); | ||
| 163 | if (strncmp(str, "old_ordering", 12) == 0) | 168 | if (strncmp(str, "old_ordering", 12) == 0) |
| 164 | acpi_old_suspend_ordering(); | 169 | acpi_old_suspend_ordering(); |
| 165 | str = strchr(str, ','); | 170 | str = strchr(str, ','); |
diff --git a/arch/x86/kernel/cpu/cpufreq/pcc-cpufreq.c b/arch/x86/kernel/cpu/cpufreq/pcc-cpufreq.c index ce7cde713e71..a36de5bbb622 100644 --- a/arch/x86/kernel/cpu/cpufreq/pcc-cpufreq.c +++ b/arch/x86/kernel/cpu/cpufreq/pcc-cpufreq.c | |||
| @@ -368,22 +368,16 @@ static int __init pcc_cpufreq_do_osc(acpi_handle *handle) | |||
| 368 | return -ENODEV; | 368 | return -ENODEV; |
| 369 | 369 | ||
| 370 | out_obj = output.pointer; | 370 | out_obj = output.pointer; |
| 371 | if (out_obj->type != ACPI_TYPE_BUFFER) { | 371 | if (out_obj->type != ACPI_TYPE_BUFFER) |
| 372 | ret = -ENODEV; | 372 | return -ENODEV; |
| 373 | goto out_free; | ||
| 374 | } | ||
| 375 | 373 | ||
| 376 | errors = *((u32 *)out_obj->buffer.pointer) & ~(1 << 0); | 374 | errors = *((u32 *)out_obj->buffer.pointer) & ~(1 << 0); |
| 377 | if (errors) { | 375 | if (errors) |
| 378 | ret = -ENODEV; | 376 | return -ENODEV; |
| 379 | goto out_free; | ||
| 380 | } | ||
| 381 | 377 | ||
| 382 | supported = *((u32 *)(out_obj->buffer.pointer + 4)); | 378 | supported = *((u32 *)(out_obj->buffer.pointer + 4)); |
| 383 | if (!(supported & 0x1)) { | 379 | if (!(supported & 0x1)) |
| 384 | ret = -ENODEV; | 380 | return -ENODEV; |
| 385 | goto out_free; | ||
| 386 | } | ||
| 387 | 381 | ||
| 388 | out_free: | 382 | out_free: |
| 389 | kfree(output.pointer); | 383 | kfree(output.pointer); |
| @@ -397,13 +391,17 @@ static int __init pcc_cpufreq_probe(void) | |||
| 397 | struct pcc_memory_resource *mem_resource; | 391 | struct pcc_memory_resource *mem_resource; |
| 398 | struct pcc_register_resource *reg_resource; | 392 | struct pcc_register_resource *reg_resource; |
| 399 | union acpi_object *out_obj, *member; | 393 | union acpi_object *out_obj, *member; |
| 400 | acpi_handle handle, osc_handle; | 394 | acpi_handle handle, osc_handle, pcch_handle; |
| 401 | int ret = 0; | 395 | int ret = 0; |
| 402 | 396 | ||
| 403 | status = acpi_get_handle(NULL, "\\_SB", &handle); | 397 | status = acpi_get_handle(NULL, "\\_SB", &handle); |
| 404 | if (ACPI_FAILURE(status)) | 398 | if (ACPI_FAILURE(status)) |
| 405 | return -ENODEV; | 399 | return -ENODEV; |
| 406 | 400 | ||
| 401 | status = acpi_get_handle(handle, "PCCH", &pcch_handle); | ||
| 402 | if (ACPI_FAILURE(status)) | ||
| 403 | return -ENODEV; | ||
| 404 | |||
| 407 | status = acpi_get_handle(handle, "_OSC", &osc_handle); | 405 | status = acpi_get_handle(handle, "_OSC", &osc_handle); |
| 408 | if (ACPI_SUCCESS(status)) { | 406 | if (ACPI_SUCCESS(status)) { |
| 409 | ret = pcc_cpufreq_do_osc(&osc_handle); | 407 | ret = pcc_cpufreq_do_osc(&osc_handle); |
| @@ -543,13 +541,13 @@ static int pcc_cpufreq_cpu_init(struct cpufreq_policy *policy) | |||
| 543 | 541 | ||
| 544 | if (!pcch_virt_addr) { | 542 | if (!pcch_virt_addr) { |
| 545 | result = -1; | 543 | result = -1; |
| 546 | goto pcch_null; | 544 | goto out; |
| 547 | } | 545 | } |
| 548 | 546 | ||
| 549 | result = pcc_get_offset(cpu); | 547 | result = pcc_get_offset(cpu); |
| 550 | if (result) { | 548 | if (result) { |
| 551 | dprintk("init: PCCP evaluation failed\n"); | 549 | dprintk("init: PCCP evaluation failed\n"); |
| 552 | goto free; | 550 | goto out; |
| 553 | } | 551 | } |
| 554 | 552 | ||
| 555 | policy->max = policy->cpuinfo.max_freq = | 553 | policy->max = policy->cpuinfo.max_freq = |
| @@ -558,14 +556,15 @@ static int pcc_cpufreq_cpu_init(struct cpufreq_policy *policy) | |||
| 558 | ioread32(&pcch_hdr->minimum_frequency) * 1000; | 556 | ioread32(&pcch_hdr->minimum_frequency) * 1000; |
| 559 | policy->cur = pcc_get_freq(cpu); | 557 | policy->cur = pcc_get_freq(cpu); |
| 560 | 558 | ||
| 559 | if (!policy->cur) { | ||
| 560 | dprintk("init: Unable to get current CPU frequency\n"); | ||
| 561 | result = -EINVAL; | ||
| 562 | goto out; | ||
| 563 | } | ||
| 564 | |||
| 561 | dprintk("init: policy->max is %d, policy->min is %d\n", | 565 | dprintk("init: policy->max is %d, policy->min is %d\n", |
| 562 | policy->max, policy->min); | 566 | policy->max, policy->min); |
| 563 | 567 | out: | |
| 564 | return 0; | ||
| 565 | free: | ||
| 566 | pcc_clear_mapping(); | ||
| 567 | free_percpu(pcc_cpu_info); | ||
| 568 | pcch_null: | ||
| 569 | return result; | 568 | return result; |
| 570 | } | 569 | } |
| 571 | 570 | ||
diff --git a/arch/x86/kernel/cpu/cpufreq/powernow-k8.c b/arch/x86/kernel/cpu/cpufreq/powernow-k8.c index 7ec2123838e6..3e90cce3dc8b 100644 --- a/arch/x86/kernel/cpu/cpufreq/powernow-k8.c +++ b/arch/x86/kernel/cpu/cpufreq/powernow-k8.c | |||
| @@ -1023,13 +1023,12 @@ static int get_transition_latency(struct powernow_k8_data *data) | |||
| 1023 | } | 1023 | } |
| 1024 | if (max_latency == 0) { | 1024 | if (max_latency == 0) { |
| 1025 | /* | 1025 | /* |
| 1026 | * Fam 11h always returns 0 as transition latency. | 1026 | * Fam 11h and later may return 0 as transition latency. This |
| 1027 | * This is intended and means "very fast". While cpufreq core | 1027 | * is intended and means "very fast". While cpufreq core and |
| 1028 | * and governors currently can handle that gracefully, better | 1028 | * governors currently can handle that gracefully, better set it |
| 1029 | * set it to 1 to avoid problems in the future. | 1029 | * to 1 to avoid problems in the future. |
| 1030 | * For all others it's a BIOS bug. | ||
| 1031 | */ | 1030 | */ |
| 1032 | if (boot_cpu_data.x86 != 0x11) | 1031 | if (boot_cpu_data.x86 < 0x11) |
| 1033 | printk(KERN_ERR FW_WARN PFX "Invalid zero transition " | 1032 | printk(KERN_ERR FW_WARN PFX "Invalid zero transition " |
| 1034 | "latency\n"); | 1033 | "latency\n"); |
| 1035 | max_latency = 1; | 1034 | max_latency = 1; |
diff --git a/arch/x86/kernel/entry_64.S b/arch/x86/kernel/entry_64.S index 0697ff139837..4db7c4d12ffa 100644 --- a/arch/x86/kernel/entry_64.S +++ b/arch/x86/kernel/entry_64.S | |||
| @@ -571,8 +571,8 @@ auditsys: | |||
| 571 | * masked off. | 571 | * masked off. |
| 572 | */ | 572 | */ |
| 573 | sysret_audit: | 573 | sysret_audit: |
| 574 | movq %rax,%rsi /* second arg, syscall return value */ | 574 | movq RAX-ARGOFFSET(%rsp),%rsi /* second arg, syscall return value */ |
| 575 | cmpq $0,%rax /* is it < 0? */ | 575 | cmpq $0,%rsi /* is it < 0? */ |
| 576 | setl %al /* 1 if so, 0 if not */ | 576 | setl %al /* 1 if so, 0 if not */ |
| 577 | movzbl %al,%edi /* zero-extend that into %edi */ | 577 | movzbl %al,%edi /* zero-extend that into %edi */ |
| 578 | inc %edi /* first arg, 0->1(AUDITSC_SUCCESS), 1->2(AUDITSC_FAILURE) */ | 578 | inc %edi /* first arg, 0->1(AUDITSC_SUCCESS), 1->2(AUDITSC_FAILURE) */ |
diff --git a/arch/x86/kernel/hpet.c b/arch/x86/kernel/hpet.c index a198b7c87a12..ba390d731175 100644 --- a/arch/x86/kernel/hpet.c +++ b/arch/x86/kernel/hpet.c | |||
| @@ -964,7 +964,7 @@ fs_initcall(hpet_late_init); | |||
| 964 | 964 | ||
| 965 | void hpet_disable(void) | 965 | void hpet_disable(void) |
| 966 | { | 966 | { |
| 967 | if (is_hpet_capable()) { | 967 | if (is_hpet_capable() && hpet_virt_address) { |
| 968 | unsigned int cfg = hpet_readl(HPET_CFG); | 968 | unsigned int cfg = hpet_readl(HPET_CFG); |
| 969 | 969 | ||
| 970 | if (hpet_legacy_int_enabled) { | 970 | if (hpet_legacy_int_enabled) { |
diff --git a/arch/x86/kernel/i8259.c b/arch/x86/kernel/i8259.c index 7c9f02c130f3..cafa7c80ac95 100644 --- a/arch/x86/kernel/i8259.c +++ b/arch/x86/kernel/i8259.c | |||
| @@ -276,16 +276,6 @@ static struct sys_device device_i8259A = { | |||
| 276 | .cls = &i8259_sysdev_class, | 276 | .cls = &i8259_sysdev_class, |
| 277 | }; | 277 | }; |
| 278 | 278 | ||
| 279 | static int __init i8259A_init_sysfs(void) | ||
| 280 | { | ||
| 281 | int error = sysdev_class_register(&i8259_sysdev_class); | ||
| 282 | if (!error) | ||
| 283 | error = sysdev_register(&device_i8259A); | ||
| 284 | return error; | ||
| 285 | } | ||
| 286 | |||
| 287 | device_initcall(i8259A_init_sysfs); | ||
| 288 | |||
| 289 | static void mask_8259A(void) | 279 | static void mask_8259A(void) |
| 290 | { | 280 | { |
| 291 | unsigned long flags; | 281 | unsigned long flags; |
| @@ -407,3 +397,18 @@ struct legacy_pic default_legacy_pic = { | |||
| 407 | }; | 397 | }; |
| 408 | 398 | ||
| 409 | struct legacy_pic *legacy_pic = &default_legacy_pic; | 399 | struct legacy_pic *legacy_pic = &default_legacy_pic; |
| 400 | |||
| 401 | static int __init i8259A_init_sysfs(void) | ||
| 402 | { | ||
| 403 | int error; | ||
| 404 | |||
| 405 | if (legacy_pic != &default_legacy_pic) | ||
| 406 | return 0; | ||
| 407 | |||
| 408 | error = sysdev_class_register(&i8259_sysdev_class); | ||
| 409 | if (!error) | ||
| 410 | error = sysdev_register(&device_i8259A); | ||
| 411 | return error; | ||
| 412 | } | ||
| 413 | |||
| 414 | device_initcall(i8259A_init_sysfs); | ||
diff --git a/arch/x86/kernel/kgdb.c b/arch/x86/kernel/kgdb.c index 4f4af75b9482..01ab17ae2ae7 100644 --- a/arch/x86/kernel/kgdb.c +++ b/arch/x86/kernel/kgdb.c | |||
| @@ -572,7 +572,6 @@ static int __kgdb_notify(struct die_args *args, unsigned long cmd) | |||
| 572 | return NOTIFY_STOP; | 572 | return NOTIFY_STOP; |
| 573 | } | 573 | } |
| 574 | 574 | ||
| 575 | #ifdef CONFIG_KGDB_LOW_LEVEL_TRAP | ||
| 576 | int kgdb_ll_trap(int cmd, const char *str, | 575 | int kgdb_ll_trap(int cmd, const char *str, |
| 577 | struct pt_regs *regs, long err, int trap, int sig) | 576 | struct pt_regs *regs, long err, int trap, int sig) |
| 578 | { | 577 | { |
| @@ -590,7 +589,6 @@ int kgdb_ll_trap(int cmd, const char *str, | |||
| 590 | 589 | ||
| 591 | return __kgdb_notify(&args, cmd); | 590 | return __kgdb_notify(&args, cmd); |
| 592 | } | 591 | } |
| 593 | #endif /* CONFIG_KGDB_LOW_LEVEL_TRAP */ | ||
| 594 | 592 | ||
| 595 | static int | 593 | static int |
| 596 | kgdb_notify(struct notifier_block *self, unsigned long cmd, void *ptr) | 594 | kgdb_notify(struct notifier_block *self, unsigned long cmd, void *ptr) |
| @@ -625,6 +623,12 @@ int kgdb_arch_init(void) | |||
| 625 | return register_die_notifier(&kgdb_notifier); | 623 | return register_die_notifier(&kgdb_notifier); |
| 626 | } | 624 | } |
| 627 | 625 | ||
| 626 | static void kgdb_hw_overflow_handler(struct perf_event *event, int nmi, | ||
| 627 | struct perf_sample_data *data, struct pt_regs *regs) | ||
| 628 | { | ||
| 629 | kgdb_ll_trap(DIE_DEBUG, "debug", regs, 0, 0, SIGTRAP); | ||
| 630 | } | ||
| 631 | |||
| 628 | void kgdb_arch_late(void) | 632 | void kgdb_arch_late(void) |
| 629 | { | 633 | { |
| 630 | int i, cpu; | 634 | int i, cpu; |
| @@ -655,6 +659,7 @@ void kgdb_arch_late(void) | |||
| 655 | for_each_online_cpu(cpu) { | 659 | for_each_online_cpu(cpu) { |
| 656 | pevent = per_cpu_ptr(breakinfo[i].pev, cpu); | 660 | pevent = per_cpu_ptr(breakinfo[i].pev, cpu); |
| 657 | pevent[0]->hw.sample_period = 1; | 661 | pevent[0]->hw.sample_period = 1; |
| 662 | pevent[0]->overflow_handler = kgdb_hw_overflow_handler; | ||
| 658 | if (pevent[0]->destroy != NULL) { | 663 | if (pevent[0]->destroy != NULL) { |
| 659 | pevent[0]->destroy = NULL; | 664 | pevent[0]->destroy = NULL; |
| 660 | release_bp_slot(*pevent); | 665 | release_bp_slot(*pevent); |
diff --git a/arch/x86/kvm/paging_tmpl.h b/arch/x86/kvm/paging_tmpl.h index 89d66ca4d87c..2331bdc2b549 100644 --- a/arch/x86/kvm/paging_tmpl.h +++ b/arch/x86/kvm/paging_tmpl.h | |||
| @@ -342,6 +342,7 @@ static u64 *FNAME(fetch)(struct kvm_vcpu *vcpu, gva_t addr, | |||
| 342 | /* advance table_gfn when emulating 1gb pages with 4k */ | 342 | /* advance table_gfn when emulating 1gb pages with 4k */ |
| 343 | if (delta == 0) | 343 | if (delta == 0) |
| 344 | table_gfn += PT_INDEX(addr, level); | 344 | table_gfn += PT_INDEX(addr, level); |
| 345 | access &= gw->pte_access; | ||
| 345 | } else { | 346 | } else { |
| 346 | direct = 0; | 347 | direct = 0; |
| 347 | table_gfn = gw->table_gfn[level - 2]; | 348 | table_gfn = gw->table_gfn[level - 2]; |
diff --git a/arch/x86/kvm/x86.c b/arch/x86/kvm/x86.c index 05d571f6f196..7fa89c39c64f 100644 --- a/arch/x86/kvm/x86.c +++ b/arch/x86/kvm/x86.c | |||
| @@ -1562,7 +1562,7 @@ static int msr_io(struct kvm_vcpu *vcpu, struct kvm_msrs __user *user_msrs, | |||
| 1562 | 1562 | ||
| 1563 | r = -ENOMEM; | 1563 | r = -ENOMEM; |
| 1564 | size = sizeof(struct kvm_msr_entry) * msrs.nmsrs; | 1564 | size = sizeof(struct kvm_msr_entry) * msrs.nmsrs; |
| 1565 | entries = vmalloc(size); | 1565 | entries = kmalloc(size, GFP_KERNEL); |
| 1566 | if (!entries) | 1566 | if (!entries) |
| 1567 | goto out; | 1567 | goto out; |
| 1568 | 1568 | ||
| @@ -1581,7 +1581,7 @@ static int msr_io(struct kvm_vcpu *vcpu, struct kvm_msrs __user *user_msrs, | |||
| 1581 | r = n; | 1581 | r = n; |
| 1582 | 1582 | ||
| 1583 | out_free: | 1583 | out_free: |
| 1584 | vfree(entries); | 1584 | kfree(entries); |
| 1585 | out: | 1585 | out: |
| 1586 | return r; | 1586 | return r; |
| 1587 | } | 1587 | } |
diff --git a/drivers/acpi/acpica/evxfevnt.c b/drivers/acpi/acpica/evxfevnt.c index d97b8dce1668..18b3f1468b7d 100644 --- a/drivers/acpi/acpica/evxfevnt.c +++ b/drivers/acpi/acpica/evxfevnt.c | |||
| @@ -70,6 +70,7 @@ acpi_ev_get_gpe_device(struct acpi_gpe_xrupt_info *gpe_xrupt_info, | |||
| 70 | acpi_status acpi_enable(void) | 70 | acpi_status acpi_enable(void) |
| 71 | { | 71 | { |
| 72 | acpi_status status; | 72 | acpi_status status; |
| 73 | int retry; | ||
| 73 | 74 | ||
| 74 | ACPI_FUNCTION_TRACE(acpi_enable); | 75 | ACPI_FUNCTION_TRACE(acpi_enable); |
| 75 | 76 | ||
| @@ -98,16 +99,18 @@ acpi_status acpi_enable(void) | |||
| 98 | 99 | ||
| 99 | /* Sanity check that transition succeeded */ | 100 | /* Sanity check that transition succeeded */ |
| 100 | 101 | ||
| 101 | if (acpi_hw_get_mode() != ACPI_SYS_MODE_ACPI) { | 102 | for (retry = 0; retry < 30000; ++retry) { |
| 102 | ACPI_ERROR((AE_INFO, | 103 | if (acpi_hw_get_mode() == ACPI_SYS_MODE_ACPI) { |
| 103 | "Hardware did not enter ACPI mode")); | 104 | if (retry != 0) |
| 104 | return_ACPI_STATUS(AE_NO_HARDWARE_RESPONSE); | 105 | ACPI_WARNING((AE_INFO, |
| 106 | "Platform took > %d00 usec to enter ACPI mode", retry)); | ||
| 107 | return_ACPI_STATUS(AE_OK); | ||
| 108 | } | ||
| 109 | acpi_os_stall(100); /* 100 usec */ | ||
| 105 | } | 110 | } |
| 106 | 111 | ||
| 107 | ACPI_DEBUG_PRINT((ACPI_DB_INIT, | 112 | ACPI_ERROR((AE_INFO, "Hardware did not enter ACPI mode")); |
| 108 | "Transition to ACPI mode successful\n")); | 113 | return_ACPI_STATUS(AE_NO_HARDWARE_RESPONSE); |
| 109 | |||
| 110 | return_ACPI_STATUS(AE_OK); | ||
| 111 | } | 114 | } |
| 112 | 115 | ||
| 113 | ACPI_EXPORT_SYMBOL(acpi_enable) | 116 | ACPI_EXPORT_SYMBOL(acpi_enable) |
diff --git a/drivers/acpi/battery.c b/drivers/acpi/battery.c index 3026e3fa83ef..dc58402b0a17 100644 --- a/drivers/acpi/battery.c +++ b/drivers/acpi/battery.c | |||
| @@ -868,9 +868,15 @@ static void acpi_battery_remove_fs(struct acpi_device *device) | |||
| 868 | static void acpi_battery_notify(struct acpi_device *device, u32 event) | 868 | static void acpi_battery_notify(struct acpi_device *device, u32 event) |
| 869 | { | 869 | { |
| 870 | struct acpi_battery *battery = acpi_driver_data(device); | 870 | struct acpi_battery *battery = acpi_driver_data(device); |
| 871 | #ifdef CONFIG_ACPI_SYSFS_POWER | ||
| 872 | struct device *old; | ||
| 873 | #endif | ||
| 871 | 874 | ||
| 872 | if (!battery) | 875 | if (!battery) |
| 873 | return; | 876 | return; |
| 877 | #ifdef CONFIG_ACPI_SYSFS_POWER | ||
| 878 | old = battery->bat.dev; | ||
| 879 | #endif | ||
| 874 | acpi_battery_update(battery); | 880 | acpi_battery_update(battery); |
| 875 | acpi_bus_generate_proc_event(device, event, | 881 | acpi_bus_generate_proc_event(device, event, |
| 876 | acpi_battery_present(battery)); | 882 | acpi_battery_present(battery)); |
| @@ -879,7 +885,7 @@ static void acpi_battery_notify(struct acpi_device *device, u32 event) | |||
| 879 | acpi_battery_present(battery)); | 885 | acpi_battery_present(battery)); |
| 880 | #ifdef CONFIG_ACPI_SYSFS_POWER | 886 | #ifdef CONFIG_ACPI_SYSFS_POWER |
| 881 | /* acpi_battery_update could remove power_supply object */ | 887 | /* acpi_battery_update could remove power_supply object */ |
| 882 | if (battery->bat.dev) | 888 | if (old && battery->bat.dev) |
| 883 | power_supply_changed(&battery->bat); | 889 | power_supply_changed(&battery->bat); |
| 884 | #endif | 890 | #endif |
| 885 | } | 891 | } |
diff --git a/drivers/acpi/blacklist.c b/drivers/acpi/blacklist.c index 01381be05e96..2bb28b9d91c4 100644 --- a/drivers/acpi/blacklist.c +++ b/drivers/acpi/blacklist.c | |||
| @@ -214,7 +214,7 @@ static struct dmi_system_id acpi_osi_dmi_table[] __initdata = { | |||
| 214 | .ident = "Sony VGN-SR290J", | 214 | .ident = "Sony VGN-SR290J", |
| 215 | .matches = { | 215 | .matches = { |
| 216 | DMI_MATCH(DMI_SYS_VENDOR, "Sony Corporation"), | 216 | DMI_MATCH(DMI_SYS_VENDOR, "Sony Corporation"), |
| 217 | DMI_MATCH(DMI_PRODUCT_NAME, "Sony VGN-SR290J"), | 217 | DMI_MATCH(DMI_PRODUCT_NAME, "VGN-SR290J"), |
| 218 | }, | 218 | }, |
| 219 | }, | 219 | }, |
| 220 | { | 220 | { |
diff --git a/drivers/acpi/processor_core.c b/drivers/acpi/processor_core.c index 51284351418f..e9699aaed109 100644 --- a/drivers/acpi/processor_core.c +++ b/drivers/acpi/processor_core.c | |||
| @@ -223,7 +223,7 @@ static bool processor_physically_present(acpi_handle handle) | |||
| 223 | type = (acpi_type == ACPI_TYPE_DEVICE) ? 1 : 0; | 223 | type = (acpi_type == ACPI_TYPE_DEVICE) ? 1 : 0; |
| 224 | cpuid = acpi_get_cpuid(handle, type, acpi_id); | 224 | cpuid = acpi_get_cpuid(handle, type, acpi_id); |
| 225 | 225 | ||
| 226 | if (cpuid == -1) | 226 | if ((cpuid == -1) && (num_possible_cpus() > 1)) |
| 227 | return false; | 227 | return false; |
| 228 | 228 | ||
| 229 | return true; | 229 | return true; |
diff --git a/drivers/acpi/processor_idle.c b/drivers/acpi/processor_idle.c index b1b385692f46..e9a8026d39f0 100644 --- a/drivers/acpi/processor_idle.c +++ b/drivers/acpi/processor_idle.c | |||
| @@ -76,14 +76,19 @@ static unsigned int max_cstate __read_mostly = ACPI_PROCESSOR_MAX_POWER; | |||
| 76 | module_param(max_cstate, uint, 0000); | 76 | module_param(max_cstate, uint, 0000); |
| 77 | static unsigned int nocst __read_mostly; | 77 | static unsigned int nocst __read_mostly; |
| 78 | module_param(nocst, uint, 0000); | 78 | module_param(nocst, uint, 0000); |
| 79 | static int bm_check_disable __read_mostly; | ||
| 80 | module_param(bm_check_disable, uint, 0000); | ||
| 79 | 81 | ||
| 80 | static unsigned int latency_factor __read_mostly = 2; | 82 | static unsigned int latency_factor __read_mostly = 2; |
| 81 | module_param(latency_factor, uint, 0644); | 83 | module_param(latency_factor, uint, 0644); |
| 82 | 84 | ||
| 85 | #ifdef CONFIG_ACPI_PROCFS | ||
| 83 | static u64 us_to_pm_timer_ticks(s64 t) | 86 | static u64 us_to_pm_timer_ticks(s64 t) |
| 84 | { | 87 | { |
| 85 | return div64_u64(t * PM_TIMER_FREQUENCY, 1000000); | 88 | return div64_u64(t * PM_TIMER_FREQUENCY, 1000000); |
| 86 | } | 89 | } |
| 90 | #endif | ||
| 91 | |||
| 87 | /* | 92 | /* |
| 88 | * IBM ThinkPad R40e crashes mysteriously when going into C2 or C3. | 93 | * IBM ThinkPad R40e crashes mysteriously when going into C2 or C3. |
| 89 | * For now disable this. Probably a bug somewhere else. | 94 | * For now disable this. Probably a bug somewhere else. |
| @@ -763,6 +768,9 @@ static int acpi_idle_bm_check(void) | |||
| 763 | { | 768 | { |
| 764 | u32 bm_status = 0; | 769 | u32 bm_status = 0; |
| 765 | 770 | ||
| 771 | if (bm_check_disable) | ||
| 772 | return 0; | ||
| 773 | |||
| 766 | acpi_read_bit_register(ACPI_BITREG_BUS_MASTER_STATUS, &bm_status); | 774 | acpi_read_bit_register(ACPI_BITREG_BUS_MASTER_STATUS, &bm_status); |
| 767 | if (bm_status) | 775 | if (bm_status) |
| 768 | acpi_write_bit_register(ACPI_BITREG_BUS_MASTER_STATUS, 1); | 776 | acpi_write_bit_register(ACPI_BITREG_BUS_MASTER_STATUS, 1); |
| @@ -947,7 +955,7 @@ static int acpi_idle_enter_bm(struct cpuidle_device *dev, | |||
| 947 | if (acpi_idle_suspend) | 955 | if (acpi_idle_suspend) |
| 948 | return(acpi_idle_enter_c1(dev, state)); | 956 | return(acpi_idle_enter_c1(dev, state)); |
| 949 | 957 | ||
| 950 | if (acpi_idle_bm_check()) { | 958 | if (!cx->bm_sts_skip && acpi_idle_bm_check()) { |
| 951 | if (dev->safe_state) { | 959 | if (dev->safe_state) { |
| 952 | dev->last_state = dev->safe_state; | 960 | dev->last_state = dev->safe_state; |
| 953 | return dev->safe_state->enter(dev, dev->safe_state); | 961 | return dev->safe_state->enter(dev, dev->safe_state); |
diff --git a/drivers/acpi/sleep.c b/drivers/acpi/sleep.c index 5b7c52e4a00f..2862c781b372 100644 --- a/drivers/acpi/sleep.c +++ b/drivers/acpi/sleep.c | |||
| @@ -82,6 +82,20 @@ static int acpi_sleep_prepare(u32 acpi_state) | |||
| 82 | static u32 acpi_target_sleep_state = ACPI_STATE_S0; | 82 | static u32 acpi_target_sleep_state = ACPI_STATE_S0; |
| 83 | 83 | ||
| 84 | /* | 84 | /* |
| 85 | * The ACPI specification wants us to save NVS memory regions during hibernation | ||
| 86 | * and to restore them during the subsequent resume. Windows does that also for | ||
| 87 | * suspend to RAM. However, it is known that this mechanism does not work on | ||
| 88 | * all machines, so we allow the user to disable it with the help of the | ||
| 89 | * 'acpi_sleep=nonvs' kernel command line option. | ||
| 90 | */ | ||
| 91 | static bool nvs_nosave; | ||
| 92 | |||
| 93 | void __init acpi_nvs_nosave(void) | ||
| 94 | { | ||
| 95 | nvs_nosave = true; | ||
| 96 | } | ||
| 97 | |||
| 98 | /* | ||
| 85 | * ACPI 1.0 wants us to execute _PTS before suspending devices, so we allow the | 99 | * ACPI 1.0 wants us to execute _PTS before suspending devices, so we allow the |
| 86 | * user to request that behavior by using the 'acpi_old_suspend_ordering' | 100 | * user to request that behavior by using the 'acpi_old_suspend_ordering' |
| 87 | * kernel command line option that causes the following variable to be set. | 101 | * kernel command line option that causes the following variable to be set. |
| @@ -197,8 +211,7 @@ static int acpi_suspend_begin(suspend_state_t pm_state) | |||
| 197 | u32 acpi_state = acpi_suspend_states[pm_state]; | 211 | u32 acpi_state = acpi_suspend_states[pm_state]; |
| 198 | int error = 0; | 212 | int error = 0; |
| 199 | 213 | ||
| 200 | error = suspend_nvs_alloc(); | 214 | error = nvs_nosave ? 0 : suspend_nvs_alloc(); |
| 201 | |||
| 202 | if (error) | 215 | if (error) |
| 203 | return error; | 216 | return error; |
| 204 | 217 | ||
| @@ -388,20 +401,6 @@ static struct dmi_system_id __initdata acpisleep_dmi_table[] = { | |||
| 388 | #endif /* CONFIG_SUSPEND */ | 401 | #endif /* CONFIG_SUSPEND */ |
| 389 | 402 | ||
| 390 | #ifdef CONFIG_HIBERNATION | 403 | #ifdef CONFIG_HIBERNATION |
| 391 | /* | ||
| 392 | * The ACPI specification wants us to save NVS memory regions during hibernation | ||
| 393 | * and to restore them during the subsequent resume. However, it is not certain | ||
| 394 | * if this mechanism is going to work on all machines, so we allow the user to | ||
| 395 | * disable this mechanism using the 'acpi_sleep=s4_nonvs' kernel command line | ||
| 396 | * option. | ||
| 397 | */ | ||
| 398 | static bool s4_no_nvs; | ||
| 399 | |||
| 400 | void __init acpi_s4_no_nvs(void) | ||
| 401 | { | ||
| 402 | s4_no_nvs = true; | ||
| 403 | } | ||
| 404 | |||
| 405 | static unsigned long s4_hardware_signature; | 404 | static unsigned long s4_hardware_signature; |
| 406 | static struct acpi_table_facs *facs; | 405 | static struct acpi_table_facs *facs; |
| 407 | static bool nosigcheck; | 406 | static bool nosigcheck; |
| @@ -415,7 +414,7 @@ static int acpi_hibernation_begin(void) | |||
| 415 | { | 414 | { |
| 416 | int error; | 415 | int error; |
| 417 | 416 | ||
| 418 | error = s4_no_nvs ? 0 : suspend_nvs_alloc(); | 417 | error = nvs_nosave ? 0 : suspend_nvs_alloc(); |
| 419 | if (!error) { | 418 | if (!error) { |
| 420 | acpi_target_sleep_state = ACPI_STATE_S4; | 419 | acpi_target_sleep_state = ACPI_STATE_S4; |
| 421 | acpi_sleep_tts_switch(acpi_target_sleep_state); | 420 | acpi_sleep_tts_switch(acpi_target_sleep_state); |
| @@ -510,7 +509,7 @@ static int acpi_hibernation_begin_old(void) | |||
| 510 | error = acpi_sleep_prepare(ACPI_STATE_S4); | 509 | error = acpi_sleep_prepare(ACPI_STATE_S4); |
| 511 | 510 | ||
| 512 | if (!error) { | 511 | if (!error) { |
| 513 | if (!s4_no_nvs) | 512 | if (!nvs_nosave) |
| 514 | error = suspend_nvs_alloc(); | 513 | error = suspend_nvs_alloc(); |
| 515 | if (!error) | 514 | if (!error) |
| 516 | acpi_target_sleep_state = ACPI_STATE_S4; | 515 | acpi_target_sleep_state = ACPI_STATE_S4; |
diff --git a/drivers/amba/bus.c b/drivers/amba/bus.c index f60b2b6a0931..d31590e7011b 100644 --- a/drivers/amba/bus.c +++ b/drivers/amba/bus.c | |||
| @@ -122,6 +122,31 @@ static int __init amba_init(void) | |||
| 122 | 122 | ||
| 123 | postcore_initcall(amba_init); | 123 | postcore_initcall(amba_init); |
| 124 | 124 | ||
| 125 | static int amba_get_enable_pclk(struct amba_device *pcdev) | ||
| 126 | { | ||
| 127 | struct clk *pclk = clk_get(&pcdev->dev, "apb_pclk"); | ||
| 128 | int ret; | ||
| 129 | |||
| 130 | pcdev->pclk = pclk; | ||
| 131 | |||
| 132 | if (IS_ERR(pclk)) | ||
| 133 | return PTR_ERR(pclk); | ||
| 134 | |||
| 135 | ret = clk_enable(pclk); | ||
| 136 | if (ret) | ||
| 137 | clk_put(pclk); | ||
| 138 | |||
| 139 | return ret; | ||
| 140 | } | ||
| 141 | |||
| 142 | static void amba_put_disable_pclk(struct amba_device *pcdev) | ||
| 143 | { | ||
| 144 | struct clk *pclk = pcdev->pclk; | ||
| 145 | |||
| 146 | clk_disable(pclk); | ||
| 147 | clk_put(pclk); | ||
| 148 | } | ||
| 149 | |||
| 125 | /* | 150 | /* |
| 126 | * These are the device model conversion veneers; they convert the | 151 | * These are the device model conversion veneers; they convert the |
| 127 | * device model structures to our more specific structures. | 152 | * device model structures to our more specific structures. |
| @@ -130,17 +155,33 @@ static int amba_probe(struct device *dev) | |||
| 130 | { | 155 | { |
| 131 | struct amba_device *pcdev = to_amba_device(dev); | 156 | struct amba_device *pcdev = to_amba_device(dev); |
| 132 | struct amba_driver *pcdrv = to_amba_driver(dev->driver); | 157 | struct amba_driver *pcdrv = to_amba_driver(dev->driver); |
| 133 | struct amba_id *id; | 158 | struct amba_id *id = amba_lookup(pcdrv->id_table, pcdev); |
| 159 | int ret; | ||
| 134 | 160 | ||
| 135 | id = amba_lookup(pcdrv->id_table, pcdev); | 161 | do { |
| 162 | ret = amba_get_enable_pclk(pcdev); | ||
| 163 | if (ret) | ||
| 164 | break; | ||
| 165 | |||
| 166 | ret = pcdrv->probe(pcdev, id); | ||
| 167 | if (ret == 0) | ||
| 168 | break; | ||
| 136 | 169 | ||
| 137 | return pcdrv->probe(pcdev, id); | 170 | amba_put_disable_pclk(pcdev); |
| 171 | } while (0); | ||
| 172 | |||
| 173 | return ret; | ||
| 138 | } | 174 | } |
| 139 | 175 | ||
| 140 | static int amba_remove(struct device *dev) | 176 | static int amba_remove(struct device *dev) |
| 141 | { | 177 | { |
| 178 | struct amba_device *pcdev = to_amba_device(dev); | ||
| 142 | struct amba_driver *drv = to_amba_driver(dev->driver); | 179 | struct amba_driver *drv = to_amba_driver(dev->driver); |
| 143 | return drv->remove(to_amba_device(dev)); | 180 | int ret = drv->remove(pcdev); |
| 181 | |||
| 182 | amba_put_disable_pclk(pcdev); | ||
| 183 | |||
| 184 | return ret; | ||
| 144 | } | 185 | } |
| 145 | 186 | ||
| 146 | static void amba_shutdown(struct device *dev) | 187 | static void amba_shutdown(struct device *dev) |
| @@ -203,7 +244,6 @@ static void amba_device_release(struct device *dev) | |||
| 203 | */ | 244 | */ |
| 204 | int amba_device_register(struct amba_device *dev, struct resource *parent) | 245 | int amba_device_register(struct amba_device *dev, struct resource *parent) |
| 205 | { | 246 | { |
| 206 | u32 pid, cid; | ||
| 207 | u32 size; | 247 | u32 size; |
| 208 | void __iomem *tmp; | 248 | void __iomem *tmp; |
| 209 | int i, ret; | 249 | int i, ret; |
| @@ -241,25 +281,35 @@ int amba_device_register(struct amba_device *dev, struct resource *parent) | |||
| 241 | goto err_release; | 281 | goto err_release; |
| 242 | } | 282 | } |
| 243 | 283 | ||
| 244 | /* | 284 | ret = amba_get_enable_pclk(dev); |
| 245 | * Read pid and cid based on size of resource | 285 | if (ret == 0) { |
| 246 | * they are located at end of region | 286 | u32 pid, cid; |
| 247 | */ | ||
| 248 | for (pid = 0, i = 0; i < 4; i++) | ||
| 249 | pid |= (readl(tmp + size - 0x20 + 4 * i) & 255) << (i * 8); | ||
| 250 | for (cid = 0, i = 0; i < 4; i++) | ||
| 251 | cid |= (readl(tmp + size - 0x10 + 4 * i) & 255) << (i * 8); | ||
| 252 | 287 | ||
| 253 | iounmap(tmp); | 288 | /* |
| 289 | * Read pid and cid based on size of resource | ||
| 290 | * they are located at end of region | ||
| 291 | */ | ||
| 292 | for (pid = 0, i = 0; i < 4; i++) | ||
| 293 | pid |= (readl(tmp + size - 0x20 + 4 * i) & 255) << | ||
| 294 | (i * 8); | ||
| 295 | for (cid = 0, i = 0; i < 4; i++) | ||
| 296 | cid |= (readl(tmp + size - 0x10 + 4 * i) & 255) << | ||
| 297 | (i * 8); | ||
| 254 | 298 | ||
| 255 | if (cid == 0xb105f00d) | 299 | amba_put_disable_pclk(dev); |
| 256 | dev->periphid = pid; | ||
| 257 | 300 | ||
| 258 | if (!dev->periphid) { | 301 | if (cid == 0xb105f00d) |
| 259 | ret = -ENODEV; | 302 | dev->periphid = pid; |
| 260 | goto err_release; | 303 | |
| 304 | if (!dev->periphid) | ||
| 305 | ret = -ENODEV; | ||
| 261 | } | 306 | } |
| 262 | 307 | ||
| 308 | iounmap(tmp); | ||
| 309 | |||
| 310 | if (ret) | ||
| 311 | goto err_release; | ||
| 312 | |||
| 263 | ret = device_add(&dev->dev); | 313 | ret = device_add(&dev->dev); |
| 264 | if (ret) | 314 | if (ret) |
| 265 | goto err_release; | 315 | goto err_release; |
diff --git a/drivers/base/core.c b/drivers/base/core.c index 9630fbdf4e6c..9b9d3bd54e3a 100644 --- a/drivers/base/core.c +++ b/drivers/base/core.c | |||
| @@ -673,7 +673,7 @@ static struct kobject *get_device_parent(struct device *dev, | |||
| 673 | */ | 673 | */ |
| 674 | if (parent == NULL) | 674 | if (parent == NULL) |
| 675 | parent_kobj = virtual_device_parent(dev); | 675 | parent_kobj = virtual_device_parent(dev); |
| 676 | else if (parent->class) | 676 | else if (parent->class && !dev->class->ns_type) |
| 677 | return &parent->kobj; | 677 | return &parent->kobj; |
| 678 | else | 678 | else |
| 679 | parent_kobj = &parent->kobj; | 679 | parent_kobj = &parent->kobj; |
diff --git a/drivers/char/agp/intel-gtt.c b/drivers/char/agp/intel-gtt.c index 9344216183a4..a7547150a705 100644 --- a/drivers/char/agp/intel-gtt.c +++ b/drivers/char/agp/intel-gtt.c | |||
| @@ -1216,17 +1216,20 @@ static int intel_i915_get_gtt_size(void) | |||
| 1216 | 1216 | ||
| 1217 | /* G33's GTT size defined in gmch_ctrl */ | 1217 | /* G33's GTT size defined in gmch_ctrl */ |
| 1218 | pci_read_config_word(agp_bridge->dev, I830_GMCH_CTRL, &gmch_ctrl); | 1218 | pci_read_config_word(agp_bridge->dev, I830_GMCH_CTRL, &gmch_ctrl); |
| 1219 | switch (gmch_ctrl & G33_PGETBL_SIZE_MASK) { | 1219 | switch (gmch_ctrl & I830_GMCH_GMS_MASK) { |
| 1220 | case G33_PGETBL_SIZE_1M: | 1220 | case I830_GMCH_GMS_STOLEN_512: |
| 1221 | size = 512; | ||
| 1222 | break; | ||
| 1223 | case I830_GMCH_GMS_STOLEN_1024: | ||
| 1221 | size = 1024; | 1224 | size = 1024; |
| 1222 | break; | 1225 | break; |
| 1223 | case G33_PGETBL_SIZE_2M: | 1226 | case I830_GMCH_GMS_STOLEN_8192: |
| 1224 | size = 2048; | 1227 | size = 8*1024; |
| 1225 | break; | 1228 | break; |
| 1226 | default: | 1229 | default: |
| 1227 | dev_info(&agp_bridge->dev->dev, | 1230 | dev_info(&agp_bridge->dev->dev, |
| 1228 | "unknown page table size 0x%x, assuming 512KB\n", | 1231 | "unknown page table size 0x%x, assuming 512KB\n", |
| 1229 | (gmch_ctrl & G33_PGETBL_SIZE_MASK)); | 1232 | (gmch_ctrl & I830_GMCH_GMS_MASK)); |
| 1230 | size = 512; | 1233 | size = 512; |
| 1231 | } | 1234 | } |
| 1232 | } else { | 1235 | } else { |
diff --git a/drivers/char/sysrq.c b/drivers/char/sysrq.c index 5d64e3acb000..878ac0c2cc68 100644 --- a/drivers/char/sysrq.c +++ b/drivers/char/sysrq.c | |||
| @@ -493,7 +493,7 @@ static void __sysrq_put_key_op(int key, struct sysrq_key_op *op_p) | |||
| 493 | sysrq_key_table[i] = op_p; | 493 | sysrq_key_table[i] = op_p; |
| 494 | } | 494 | } |
| 495 | 495 | ||
| 496 | static void __handle_sysrq(int key, struct tty_struct *tty, int check_mask) | 496 | void __handle_sysrq(int key, struct tty_struct *tty, int check_mask) |
| 497 | { | 497 | { |
| 498 | struct sysrq_key_op *op_p; | 498 | struct sysrq_key_op *op_p; |
| 499 | int orig_log_level; | 499 | int orig_log_level; |
diff --git a/drivers/char/tpm/tpm_tis.c b/drivers/char/tpm/tpm_tis.c index 24314a9cffe8..1030f8420137 100644 --- a/drivers/char/tpm/tpm_tis.c +++ b/drivers/char/tpm/tpm_tis.c | |||
| @@ -623,7 +623,14 @@ static int tpm_tis_pnp_suspend(struct pnp_dev *dev, pm_message_t msg) | |||
| 623 | 623 | ||
| 624 | static int tpm_tis_pnp_resume(struct pnp_dev *dev) | 624 | static int tpm_tis_pnp_resume(struct pnp_dev *dev) |
| 625 | { | 625 | { |
| 626 | return tpm_pm_resume(&dev->dev); | 626 | struct tpm_chip *chip = pnp_get_drvdata(dev); |
| 627 | int ret; | ||
| 628 | |||
| 629 | ret = tpm_pm_resume(&dev->dev); | ||
| 630 | if (!ret) | ||
| 631 | tpm_continue_selftest(chip); | ||
| 632 | |||
| 633 | return ret; | ||
| 627 | } | 634 | } |
| 628 | 635 | ||
| 629 | static struct pnp_device_id tpm_pnp_tbl[] __devinitdata = { | 636 | static struct pnp_device_id tpm_pnp_tbl[] __devinitdata = { |
diff --git a/drivers/cpufreq/cpufreq.c b/drivers/cpufreq/cpufreq.c index 063b2184caf5..938b74ea9ffb 100644 --- a/drivers/cpufreq/cpufreq.c +++ b/drivers/cpufreq/cpufreq.c | |||
| @@ -1077,6 +1077,7 @@ err_out_unregister: | |||
| 1077 | 1077 | ||
| 1078 | err_unlock_policy: | 1078 | err_unlock_policy: |
| 1079 | unlock_policy_rwsem_write(cpu); | 1079 | unlock_policy_rwsem_write(cpu); |
| 1080 | free_cpumask_var(policy->related_cpus); | ||
| 1080 | err_free_cpumask: | 1081 | err_free_cpumask: |
| 1081 | free_cpumask_var(policy->cpus); | 1082 | free_cpumask_var(policy->cpus); |
| 1082 | err_free_policy: | 1083 | err_free_policy: |
| @@ -1762,17 +1763,8 @@ static int __cpufreq_set_policy(struct cpufreq_policy *data, | |||
| 1762 | dprintk("governor switch\n"); | 1763 | dprintk("governor switch\n"); |
| 1763 | 1764 | ||
| 1764 | /* end old governor */ | 1765 | /* end old governor */ |
| 1765 | if (data->governor) { | 1766 | if (data->governor) |
| 1766 | /* | ||
| 1767 | * Need to release the rwsem around governor | ||
| 1768 | * stop due to lock dependency between | ||
| 1769 | * cancel_delayed_work_sync and the read lock | ||
| 1770 | * taken in the delayed work handler. | ||
| 1771 | */ | ||
| 1772 | unlock_policy_rwsem_write(data->cpu); | ||
| 1773 | __cpufreq_governor(data, CPUFREQ_GOV_STOP); | 1767 | __cpufreq_governor(data, CPUFREQ_GOV_STOP); |
| 1774 | lock_policy_rwsem_write(data->cpu); | ||
| 1775 | } | ||
| 1776 | 1768 | ||
| 1777 | /* start new governor */ | 1769 | /* start new governor */ |
| 1778 | data->governor = policy->governor; | 1770 | data->governor = policy->governor; |
diff --git a/drivers/crypto/talitos.c b/drivers/crypto/talitos.c index 637c105f53d2..bd78acf3c365 100644 --- a/drivers/crypto/talitos.c +++ b/drivers/crypto/talitos.c | |||
| @@ -1183,10 +1183,14 @@ static size_t sg_copy_end_to_buffer(struct scatterlist *sgl, unsigned int nents, | |||
| 1183 | /* Copy part of this segment */ | 1183 | /* Copy part of this segment */ |
| 1184 | ignore = skip - offset; | 1184 | ignore = skip - offset; |
| 1185 | len = miter.length - ignore; | 1185 | len = miter.length - ignore; |
| 1186 | if (boffset + len > buflen) | ||
| 1187 | len = buflen - boffset; | ||
| 1186 | memcpy(buf + boffset, miter.addr + ignore, len); | 1188 | memcpy(buf + boffset, miter.addr + ignore, len); |
| 1187 | } else { | 1189 | } else { |
| 1188 | /* Copy all of this segment */ | 1190 | /* Copy all of this segment (up to buflen) */ |
| 1189 | len = miter.length; | 1191 | len = miter.length; |
| 1192 | if (boffset + len > buflen) | ||
| 1193 | len = buflen - boffset; | ||
| 1190 | memcpy(buf + boffset, miter.addr, len); | 1194 | memcpy(buf + boffset, miter.addr, len); |
| 1191 | } | 1195 | } |
| 1192 | boffset += len; | 1196 | boffset += len; |
diff --git a/drivers/edac/i7core_edac.c b/drivers/edac/i7core_edac.c index cc9357da0e34..e0187d16dd7c 100644 --- a/drivers/edac/i7core_edac.c +++ b/drivers/edac/i7core_edac.c | |||
| @@ -1300,7 +1300,7 @@ int i7core_get_onedevice(struct pci_dev **prev, int devno, | |||
| 1300 | if (devno == 0) | 1300 | if (devno == 0) |
| 1301 | return -ENODEV; | 1301 | return -ENODEV; |
| 1302 | 1302 | ||
| 1303 | i7core_printk(KERN_ERR, | 1303 | i7core_printk(KERN_INFO, |
| 1304 | "Device not found: dev %02x.%d PCI ID %04x:%04x\n", | 1304 | "Device not found: dev %02x.%d PCI ID %04x:%04x\n", |
| 1305 | dev_descr->dev, dev_descr->func, | 1305 | dev_descr->dev, dev_descr->func, |
| 1306 | PCI_VENDOR_ID_INTEL, dev_descr->dev_id); | 1306 | PCI_VENDOR_ID_INTEL, dev_descr->dev_id); |
diff --git a/drivers/edac/mpc85xx_edac.c b/drivers/edac/mpc85xx_edac.c index f39b00a46eda..1052340e6802 100644 --- a/drivers/edac/mpc85xx_edac.c +++ b/drivers/edac/mpc85xx_edac.c | |||
| @@ -336,6 +336,7 @@ static struct of_device_id mpc85xx_pci_err_of_match[] = { | |||
| 336 | }, | 336 | }, |
| 337 | {}, | 337 | {}, |
| 338 | }; | 338 | }; |
| 339 | MODULE_DEVICE_TABLE(of, mpc85xx_pci_err_of_match); | ||
| 339 | 340 | ||
| 340 | static struct of_platform_driver mpc85xx_pci_err_driver = { | 341 | static struct of_platform_driver mpc85xx_pci_err_driver = { |
| 341 | .probe = mpc85xx_pci_err_probe, | 342 | .probe = mpc85xx_pci_err_probe, |
| @@ -650,6 +651,7 @@ static struct of_device_id mpc85xx_l2_err_of_match[] = { | |||
| 650 | { .compatible = "fsl,p2020-l2-cache-controller", }, | 651 | { .compatible = "fsl,p2020-l2-cache-controller", }, |
| 651 | {}, | 652 | {}, |
| 652 | }; | 653 | }; |
| 654 | MODULE_DEVICE_TABLE(of, mpc85xx_l2_err_of_match); | ||
| 653 | 655 | ||
| 654 | static struct of_platform_driver mpc85xx_l2_err_driver = { | 656 | static struct of_platform_driver mpc85xx_l2_err_driver = { |
| 655 | .probe = mpc85xx_l2_err_probe, | 657 | .probe = mpc85xx_l2_err_probe, |
| @@ -1126,6 +1128,7 @@ static struct of_device_id mpc85xx_mc_err_of_match[] = { | |||
| 1126 | { .compatible = "fsl,p2020-memory-controller", }, | 1128 | { .compatible = "fsl,p2020-memory-controller", }, |
| 1127 | {}, | 1129 | {}, |
| 1128 | }; | 1130 | }; |
| 1131 | MODULE_DEVICE_TABLE(of, mpc85xx_mc_err_of_match); | ||
| 1129 | 1132 | ||
| 1130 | static struct of_platform_driver mpc85xx_mc_err_driver = { | 1133 | static struct of_platform_driver mpc85xx_mc_err_driver = { |
| 1131 | .probe = mpc85xx_mc_err_probe, | 1134 | .probe = mpc85xx_mc_err_probe, |
diff --git a/drivers/gpio/gpiolib.c b/drivers/gpio/gpiolib.c index 3ca36542e338..4e51fe3c1fc4 100644 --- a/drivers/gpio/gpiolib.c +++ b/drivers/gpio/gpiolib.c | |||
| @@ -893,10 +893,12 @@ EXPORT_SYMBOL_GPL(gpio_sysfs_set_active_low); | |||
| 893 | void gpio_unexport(unsigned gpio) | 893 | void gpio_unexport(unsigned gpio) |
| 894 | { | 894 | { |
| 895 | struct gpio_desc *desc; | 895 | struct gpio_desc *desc; |
| 896 | int status = -EINVAL; | 896 | int status = 0; |
| 897 | 897 | ||
| 898 | if (!gpio_is_valid(gpio)) | 898 | if (!gpio_is_valid(gpio)) { |
| 899 | status = -EINVAL; | ||
| 899 | goto done; | 900 | goto done; |
| 901 | } | ||
| 900 | 902 | ||
| 901 | mutex_lock(&sysfs_lock); | 903 | mutex_lock(&sysfs_lock); |
| 902 | 904 | ||
| @@ -911,7 +913,6 @@ void gpio_unexport(unsigned gpio) | |||
| 911 | clear_bit(FLAG_EXPORT, &desc->flags); | 913 | clear_bit(FLAG_EXPORT, &desc->flags); |
| 912 | put_device(dev); | 914 | put_device(dev); |
| 913 | device_unregister(dev); | 915 | device_unregister(dev); |
| 914 | status = 0; | ||
| 915 | } else | 916 | } else |
| 916 | status = -ENODEV; | 917 | status = -ENODEV; |
| 917 | } | 918 | } |
diff --git a/drivers/gpu/drm/i915/i915_debugfs.c b/drivers/gpu/drm/i915/i915_debugfs.c index aee83fa178f6..9214119c0154 100644 --- a/drivers/gpu/drm/i915/i915_debugfs.c +++ b/drivers/gpu/drm/i915/i915_debugfs.c | |||
| @@ -605,6 +605,9 @@ static int i915_fbc_status(struct seq_file *m, void *unused) | |||
| 605 | case FBC_NOT_TILED: | 605 | case FBC_NOT_TILED: |
| 606 | seq_printf(m, "scanout buffer not tiled"); | 606 | seq_printf(m, "scanout buffer not tiled"); |
| 607 | break; | 607 | break; |
| 608 | case FBC_MULTIPLE_PIPES: | ||
| 609 | seq_printf(m, "multiple pipes are enabled"); | ||
| 610 | break; | ||
| 608 | default: | 611 | default: |
| 609 | seq_printf(m, "unknown reason"); | 612 | seq_printf(m, "unknown reason"); |
| 610 | } | 613 | } |
diff --git a/drivers/gpu/drm/i915/i915_dma.c b/drivers/gpu/drm/i915/i915_dma.c index f00c5ae9556c..2305a1234f1e 100644 --- a/drivers/gpu/drm/i915/i915_dma.c +++ b/drivers/gpu/drm/i915/i915_dma.c | |||
| @@ -1300,7 +1300,7 @@ static void i915_cleanup_compression(struct drm_device *dev) | |||
| 1300 | struct drm_i915_private *dev_priv = dev->dev_private; | 1300 | struct drm_i915_private *dev_priv = dev->dev_private; |
| 1301 | 1301 | ||
| 1302 | drm_mm_put_block(dev_priv->compressed_fb); | 1302 | drm_mm_put_block(dev_priv->compressed_fb); |
| 1303 | if (!IS_GM45(dev)) | 1303 | if (dev_priv->compressed_llb) |
| 1304 | drm_mm_put_block(dev_priv->compressed_llb); | 1304 | drm_mm_put_block(dev_priv->compressed_llb); |
| 1305 | } | 1305 | } |
| 1306 | 1306 | ||
diff --git a/drivers/gpu/drm/i915/i915_drv.h b/drivers/gpu/drm/i915/i915_drv.h index d147ab2f5bfc..2e1744d37ad5 100644 --- a/drivers/gpu/drm/i915/i915_drv.h +++ b/drivers/gpu/drm/i915/i915_drv.h | |||
| @@ -215,6 +215,7 @@ enum no_fbc_reason { | |||
| 215 | FBC_MODE_TOO_LARGE, /* mode too large for compression */ | 215 | FBC_MODE_TOO_LARGE, /* mode too large for compression */ |
| 216 | FBC_BAD_PLANE, /* fbc not supported on plane */ | 216 | FBC_BAD_PLANE, /* fbc not supported on plane */ |
| 217 | FBC_NOT_TILED, /* buffer not tiled */ | 217 | FBC_NOT_TILED, /* buffer not tiled */ |
| 218 | FBC_MULTIPLE_PIPES, /* more than one pipe active */ | ||
| 218 | }; | 219 | }; |
| 219 | 220 | ||
| 220 | enum intel_pch { | 221 | enum intel_pch { |
| @@ -222,6 +223,8 @@ enum intel_pch { | |||
| 222 | PCH_CPT, /* Cougarpoint PCH */ | 223 | PCH_CPT, /* Cougarpoint PCH */ |
| 223 | }; | 224 | }; |
| 224 | 225 | ||
| 226 | #define QUIRK_PIPEA_FORCE (1<<0) | ||
| 227 | |||
| 225 | struct intel_fbdev; | 228 | struct intel_fbdev; |
| 226 | 229 | ||
| 227 | typedef struct drm_i915_private { | 230 | typedef struct drm_i915_private { |
| @@ -337,6 +340,8 @@ typedef struct drm_i915_private { | |||
| 337 | /* PCH chipset type */ | 340 | /* PCH chipset type */ |
| 338 | enum intel_pch pch_type; | 341 | enum intel_pch pch_type; |
| 339 | 342 | ||
| 343 | unsigned long quirks; | ||
| 344 | |||
| 340 | /* Register state */ | 345 | /* Register state */ |
| 341 | bool modeset_on_lid; | 346 | bool modeset_on_lid; |
| 342 | u8 saveLBB; | 347 | u8 saveLBB; |
diff --git a/drivers/gpu/drm/i915/i915_gem.c b/drivers/gpu/drm/i915/i915_gem.c index 51bd301cf10d..5aa747fc25a9 100644 --- a/drivers/gpu/drm/i915/i915_gem.c +++ b/drivers/gpu/drm/i915/i915_gem.c | |||
| @@ -3647,6 +3647,7 @@ i915_gem_wait_for_pending_flip(struct drm_device *dev, | |||
| 3647 | return ret; | 3647 | return ret; |
| 3648 | } | 3648 | } |
| 3649 | 3649 | ||
| 3650 | |||
| 3650 | int | 3651 | int |
| 3651 | i915_gem_do_execbuffer(struct drm_device *dev, void *data, | 3652 | i915_gem_do_execbuffer(struct drm_device *dev, void *data, |
| 3652 | struct drm_file *file_priv, | 3653 | struct drm_file *file_priv, |
| @@ -3794,7 +3795,7 @@ i915_gem_do_execbuffer(struct drm_device *dev, void *data, | |||
| 3794 | unsigned long long total_size = 0; | 3795 | unsigned long long total_size = 0; |
| 3795 | int num_fences = 0; | 3796 | int num_fences = 0; |
| 3796 | for (i = 0; i < args->buffer_count; i++) { | 3797 | for (i = 0; i < args->buffer_count; i++) { |
| 3797 | obj_priv = object_list[i]->driver_private; | 3798 | obj_priv = to_intel_bo(object_list[i]); |
| 3798 | 3799 | ||
| 3799 | total_size += object_list[i]->size; | 3800 | total_size += object_list[i]->size; |
| 3800 | num_fences += | 3801 | num_fences += |
diff --git a/drivers/gpu/drm/i915/i915_reg.h b/drivers/gpu/drm/i915/i915_reg.h index 6d9b0288272a..cf41c672defe 100644 --- a/drivers/gpu/drm/i915/i915_reg.h +++ b/drivers/gpu/drm/i915/i915_reg.h | |||
| @@ -2869,6 +2869,7 @@ | |||
| 2869 | 2869 | ||
| 2870 | #define PCH_PP_STATUS 0xc7200 | 2870 | #define PCH_PP_STATUS 0xc7200 |
| 2871 | #define PCH_PP_CONTROL 0xc7204 | 2871 | #define PCH_PP_CONTROL 0xc7204 |
| 2872 | #define PANEL_UNLOCK_REGS (0xabcd << 16) | ||
| 2872 | #define EDP_FORCE_VDD (1 << 3) | 2873 | #define EDP_FORCE_VDD (1 << 3) |
| 2873 | #define EDP_BLC_ENABLE (1 << 2) | 2874 | #define EDP_BLC_ENABLE (1 << 2) |
| 2874 | #define PANEL_POWER_RESET (1 << 1) | 2875 | #define PANEL_POWER_RESET (1 << 1) |
diff --git a/drivers/gpu/drm/i915/intel_display.c b/drivers/gpu/drm/i915/intel_display.c index 68dcf36e2793..5e21b3119824 100644 --- a/drivers/gpu/drm/i915/intel_display.c +++ b/drivers/gpu/drm/i915/intel_display.c | |||
| @@ -862,8 +862,8 @@ intel_g4x_find_best_PLL(const intel_limit_t *limit, struct drm_crtc *crtc, | |||
| 862 | intel_clock_t clock; | 862 | intel_clock_t clock; |
| 863 | int max_n; | 863 | int max_n; |
| 864 | bool found; | 864 | bool found; |
| 865 | /* approximately equals target * 0.00488 */ | 865 | /* approximately equals target * 0.00585 */ |
| 866 | int err_most = (target >> 8) + (target >> 10); | 866 | int err_most = (target >> 8) + (target >> 9); |
| 867 | found = false; | 867 | found = false; |
| 868 | 868 | ||
| 869 | if (intel_pipe_has_type(crtc, INTEL_OUTPUT_LVDS)) { | 869 | if (intel_pipe_has_type(crtc, INTEL_OUTPUT_LVDS)) { |
| @@ -1180,8 +1180,12 @@ static void intel_update_fbc(struct drm_crtc *crtc, | |||
| 1180 | struct drm_framebuffer *fb = crtc->fb; | 1180 | struct drm_framebuffer *fb = crtc->fb; |
| 1181 | struct intel_framebuffer *intel_fb; | 1181 | struct intel_framebuffer *intel_fb; |
| 1182 | struct drm_i915_gem_object *obj_priv; | 1182 | struct drm_i915_gem_object *obj_priv; |
| 1183 | struct drm_crtc *tmp_crtc; | ||
| 1183 | struct intel_crtc *intel_crtc = to_intel_crtc(crtc); | 1184 | struct intel_crtc *intel_crtc = to_intel_crtc(crtc); |
| 1184 | int plane = intel_crtc->plane; | 1185 | int plane = intel_crtc->plane; |
| 1186 | int crtcs_enabled = 0; | ||
| 1187 | |||
| 1188 | DRM_DEBUG_KMS("\n"); | ||
| 1185 | 1189 | ||
| 1186 | if (!i915_powersave) | 1190 | if (!i915_powersave) |
| 1187 | return; | 1191 | return; |
| @@ -1199,10 +1203,21 @@ static void intel_update_fbc(struct drm_crtc *crtc, | |||
| 1199 | * If FBC is already on, we just have to verify that we can | 1203 | * If FBC is already on, we just have to verify that we can |
| 1200 | * keep it that way... | 1204 | * keep it that way... |
| 1201 | * Need to disable if: | 1205 | * Need to disable if: |
| 1206 | * - more than one pipe is active | ||
| 1202 | * - changing FBC params (stride, fence, mode) | 1207 | * - changing FBC params (stride, fence, mode) |
| 1203 | * - new fb is too large to fit in compressed buffer | 1208 | * - new fb is too large to fit in compressed buffer |
| 1204 | * - going to an unsupported config (interlace, pixel multiply, etc.) | 1209 | * - going to an unsupported config (interlace, pixel multiply, etc.) |
| 1205 | */ | 1210 | */ |
| 1211 | list_for_each_entry(tmp_crtc, &dev->mode_config.crtc_list, head) { | ||
| 1212 | if (tmp_crtc->enabled) | ||
| 1213 | crtcs_enabled++; | ||
| 1214 | } | ||
| 1215 | DRM_DEBUG_KMS("%d pipes active\n", crtcs_enabled); | ||
| 1216 | if (crtcs_enabled > 1) { | ||
| 1217 | DRM_DEBUG_KMS("more than one pipe active, disabling compression\n"); | ||
| 1218 | dev_priv->no_fbc_reason = FBC_MULTIPLE_PIPES; | ||
| 1219 | goto out_disable; | ||
| 1220 | } | ||
| 1206 | if (intel_fb->obj->size > dev_priv->cfb_size) { | 1221 | if (intel_fb->obj->size > dev_priv->cfb_size) { |
| 1207 | DRM_DEBUG_KMS("framebuffer too large, disabling " | 1222 | DRM_DEBUG_KMS("framebuffer too large, disabling " |
| 1208 | "compression\n"); | 1223 | "compression\n"); |
| @@ -1255,7 +1270,7 @@ out_disable: | |||
| 1255 | } | 1270 | } |
| 1256 | } | 1271 | } |
| 1257 | 1272 | ||
| 1258 | static int | 1273 | int |
| 1259 | intel_pin_and_fence_fb_obj(struct drm_device *dev, struct drm_gem_object *obj) | 1274 | intel_pin_and_fence_fb_obj(struct drm_device *dev, struct drm_gem_object *obj) |
| 1260 | { | 1275 | { |
| 1261 | struct drm_i915_gem_object *obj_priv = to_intel_bo(obj); | 1276 | struct drm_i915_gem_object *obj_priv = to_intel_bo(obj); |
| @@ -2255,6 +2270,11 @@ static void i9xx_crtc_dpms(struct drm_crtc *crtc, int mode) | |||
| 2255 | intel_wait_for_vblank(dev); | 2270 | intel_wait_for_vblank(dev); |
| 2256 | } | 2271 | } |
| 2257 | 2272 | ||
| 2273 | /* Don't disable pipe A or pipe A PLLs if needed */ | ||
| 2274 | if (pipeconf_reg == PIPEACONF && | ||
| 2275 | (dev_priv->quirks & QUIRK_PIPEA_FORCE)) | ||
| 2276 | goto skip_pipe_off; | ||
| 2277 | |||
| 2258 | /* Next, disable display pipes */ | 2278 | /* Next, disable display pipes */ |
| 2259 | temp = I915_READ(pipeconf_reg); | 2279 | temp = I915_READ(pipeconf_reg); |
| 2260 | if ((temp & PIPEACONF_ENABLE) != 0) { | 2280 | if ((temp & PIPEACONF_ENABLE) != 0) { |
| @@ -2270,7 +2290,7 @@ static void i9xx_crtc_dpms(struct drm_crtc *crtc, int mode) | |||
| 2270 | I915_WRITE(dpll_reg, temp & ~DPLL_VCO_ENABLE); | 2290 | I915_WRITE(dpll_reg, temp & ~DPLL_VCO_ENABLE); |
| 2271 | I915_READ(dpll_reg); | 2291 | I915_READ(dpll_reg); |
| 2272 | } | 2292 | } |
| 2273 | 2293 | skip_pipe_off: | |
| 2274 | /* Wait for the clocks to turn off. */ | 2294 | /* Wait for the clocks to turn off. */ |
| 2275 | udelay(150); | 2295 | udelay(150); |
| 2276 | break; | 2296 | break; |
| @@ -2356,8 +2376,6 @@ static bool intel_crtc_mode_fixup(struct drm_crtc *crtc, | |||
| 2356 | if (mode->clock * 3 > 27000 * 4) | 2376 | if (mode->clock * 3 > 27000 * 4) |
| 2357 | return MODE_CLOCK_HIGH; | 2377 | return MODE_CLOCK_HIGH; |
| 2358 | } | 2378 | } |
| 2359 | |||
| 2360 | drm_mode_set_crtcinfo(adjusted_mode, 0); | ||
| 2361 | return true; | 2379 | return true; |
| 2362 | } | 2380 | } |
| 2363 | 2381 | ||
| @@ -3736,6 +3754,7 @@ static int intel_crtc_mode_set(struct drm_crtc *crtc, | |||
| 3736 | if (dev_priv->lvds_dither) { | 3754 | if (dev_priv->lvds_dither) { |
| 3737 | if (HAS_PCH_SPLIT(dev)) { | 3755 | if (HAS_PCH_SPLIT(dev)) { |
| 3738 | pipeconf |= PIPE_ENABLE_DITHER; | 3756 | pipeconf |= PIPE_ENABLE_DITHER; |
| 3757 | pipeconf &= ~PIPE_DITHER_TYPE_MASK; | ||
| 3739 | pipeconf |= PIPE_DITHER_TYPE_ST01; | 3758 | pipeconf |= PIPE_DITHER_TYPE_ST01; |
| 3740 | } else | 3759 | } else |
| 3741 | lvds |= LVDS_ENABLE_DITHER; | 3760 | lvds |= LVDS_ENABLE_DITHER; |
| @@ -4412,7 +4431,8 @@ static void intel_increase_pllclock(struct drm_crtc *crtc, bool schedule) | |||
| 4412 | DRM_DEBUG_DRIVER("upclocking LVDS\n"); | 4431 | DRM_DEBUG_DRIVER("upclocking LVDS\n"); |
| 4413 | 4432 | ||
| 4414 | /* Unlock panel regs */ | 4433 | /* Unlock panel regs */ |
| 4415 | I915_WRITE(PP_CONTROL, I915_READ(PP_CONTROL) | (0xabcd << 16)); | 4434 | I915_WRITE(PP_CONTROL, I915_READ(PP_CONTROL) | |
| 4435 | PANEL_UNLOCK_REGS); | ||
| 4416 | 4436 | ||
| 4417 | dpll &= ~DISPLAY_RATE_SELECT_FPA1; | 4437 | dpll &= ~DISPLAY_RATE_SELECT_FPA1; |
| 4418 | I915_WRITE(dpll_reg, dpll); | 4438 | I915_WRITE(dpll_reg, dpll); |
| @@ -4455,7 +4475,8 @@ static void intel_decrease_pllclock(struct drm_crtc *crtc) | |||
| 4455 | DRM_DEBUG_DRIVER("downclocking LVDS\n"); | 4475 | DRM_DEBUG_DRIVER("downclocking LVDS\n"); |
| 4456 | 4476 | ||
| 4457 | /* Unlock panel regs */ | 4477 | /* Unlock panel regs */ |
| 4458 | I915_WRITE(PP_CONTROL, I915_READ(PP_CONTROL) | (0xabcd << 16)); | 4478 | I915_WRITE(PP_CONTROL, I915_READ(PP_CONTROL) | |
| 4479 | PANEL_UNLOCK_REGS); | ||
| 4459 | 4480 | ||
| 4460 | dpll |= DISPLAY_RATE_SELECT_FPA1; | 4481 | dpll |= DISPLAY_RATE_SELECT_FPA1; |
| 4461 | I915_WRITE(dpll_reg, dpll); | 4482 | I915_WRITE(dpll_reg, dpll); |
| @@ -4695,7 +4716,7 @@ static int intel_crtc_page_flip(struct drm_crtc *crtc, | |||
| 4695 | struct drm_gem_object *obj; | 4716 | struct drm_gem_object *obj; |
| 4696 | struct intel_crtc *intel_crtc = to_intel_crtc(crtc); | 4717 | struct intel_crtc *intel_crtc = to_intel_crtc(crtc); |
| 4697 | struct intel_unpin_work *work; | 4718 | struct intel_unpin_work *work; |
| 4698 | unsigned long flags; | 4719 | unsigned long flags, offset; |
| 4699 | int pipesrc_reg = (intel_crtc->pipe == 0) ? PIPEASRC : PIPEBSRC; | 4720 | int pipesrc_reg = (intel_crtc->pipe == 0) ? PIPEASRC : PIPEBSRC; |
| 4700 | int ret, pipesrc; | 4721 | int ret, pipesrc; |
| 4701 | u32 flip_mask; | 4722 | u32 flip_mask; |
| @@ -4762,19 +4783,23 @@ static int intel_crtc_page_flip(struct drm_crtc *crtc, | |||
| 4762 | while (I915_READ(ISR) & flip_mask) | 4783 | while (I915_READ(ISR) & flip_mask) |
| 4763 | ; | 4784 | ; |
| 4764 | 4785 | ||
| 4786 | /* Offset into the new buffer for cases of shared fbs between CRTCs */ | ||
| 4787 | offset = obj_priv->gtt_offset; | ||
| 4788 | offset += (crtc->y * fb->pitch) + (crtc->x * (fb->bits_per_pixel) / 8); | ||
| 4789 | |||
| 4765 | BEGIN_LP_RING(4); | 4790 | BEGIN_LP_RING(4); |
| 4766 | if (IS_I965G(dev)) { | 4791 | if (IS_I965G(dev)) { |
| 4767 | OUT_RING(MI_DISPLAY_FLIP | | 4792 | OUT_RING(MI_DISPLAY_FLIP | |
| 4768 | MI_DISPLAY_FLIP_PLANE(intel_crtc->plane)); | 4793 | MI_DISPLAY_FLIP_PLANE(intel_crtc->plane)); |
| 4769 | OUT_RING(fb->pitch); | 4794 | OUT_RING(fb->pitch); |
| 4770 | OUT_RING(obj_priv->gtt_offset | obj_priv->tiling_mode); | 4795 | OUT_RING(offset | obj_priv->tiling_mode); |
| 4771 | pipesrc = I915_READ(pipesrc_reg); | 4796 | pipesrc = I915_READ(pipesrc_reg); |
| 4772 | OUT_RING(pipesrc & 0x0fff0fff); | 4797 | OUT_RING(pipesrc & 0x0fff0fff); |
| 4773 | } else { | 4798 | } else { |
| 4774 | OUT_RING(MI_DISPLAY_FLIP_I915 | | 4799 | OUT_RING(MI_DISPLAY_FLIP_I915 | |
| 4775 | MI_DISPLAY_FLIP_PLANE(intel_crtc->plane)); | 4800 | MI_DISPLAY_FLIP_PLANE(intel_crtc->plane)); |
| 4776 | OUT_RING(fb->pitch); | 4801 | OUT_RING(fb->pitch); |
| 4777 | OUT_RING(obj_priv->gtt_offset); | 4802 | OUT_RING(offset); |
| 4778 | OUT_RING(MI_NOOP); | 4803 | OUT_RING(MI_NOOP); |
| 4779 | } | 4804 | } |
| 4780 | ADVANCE_LP_RING(); | 4805 | ADVANCE_LP_RING(); |
| @@ -5506,6 +5531,66 @@ static void intel_init_display(struct drm_device *dev) | |||
| 5506 | } | 5531 | } |
| 5507 | } | 5532 | } |
| 5508 | 5533 | ||
| 5534 | /* | ||
| 5535 | * Some BIOSes insist on assuming the GPU's pipe A is enabled at suspend, | ||
| 5536 | * resume, or other times. This quirk makes sure that's the case for | ||
| 5537 | * affected systems. | ||
| 5538 | */ | ||
| 5539 | static void quirk_pipea_force (struct drm_device *dev) | ||
| 5540 | { | ||
| 5541 | struct drm_i915_private *dev_priv = dev->dev_private; | ||
| 5542 | |||
| 5543 | dev_priv->quirks |= QUIRK_PIPEA_FORCE; | ||
| 5544 | DRM_DEBUG_DRIVER("applying pipe a force quirk\n"); | ||
| 5545 | } | ||
| 5546 | |||
| 5547 | struct intel_quirk { | ||
| 5548 | int device; | ||
| 5549 | int subsystem_vendor; | ||
| 5550 | int subsystem_device; | ||
| 5551 | void (*hook)(struct drm_device *dev); | ||
| 5552 | }; | ||
| 5553 | |||
| 5554 | struct intel_quirk intel_quirks[] = { | ||
| 5555 | /* HP Compaq 2730p needs pipe A force quirk (LP: #291555) */ | ||
| 5556 | { 0x2a42, 0x103c, 0x30eb, quirk_pipea_force }, | ||
| 5557 | /* HP Mini needs pipe A force quirk (LP: #322104) */ | ||
| 5558 | { 0x27ae,0x103c, 0x361a, quirk_pipea_force }, | ||
| 5559 | |||
| 5560 | /* Thinkpad R31 needs pipe A force quirk */ | ||
| 5561 | { 0x3577, 0x1014, 0x0505, quirk_pipea_force }, | ||
| 5562 | /* Toshiba Protege R-205, S-209 needs pipe A force quirk */ | ||
| 5563 | { 0x2592, 0x1179, 0x0001, quirk_pipea_force }, | ||
| 5564 | |||
| 5565 | /* ThinkPad X30 needs pipe A force quirk (LP: #304614) */ | ||
| 5566 | { 0x3577, 0x1014, 0x0513, quirk_pipea_force }, | ||
| 5567 | /* ThinkPad X40 needs pipe A force quirk */ | ||
| 5568 | |||
| 5569 | /* ThinkPad T60 needs pipe A force quirk (bug #16494) */ | ||
| 5570 | { 0x2782, 0x17aa, 0x201a, quirk_pipea_force }, | ||
| 5571 | |||
| 5572 | /* 855 & before need to leave pipe A & dpll A up */ | ||
| 5573 | { 0x3582, PCI_ANY_ID, PCI_ANY_ID, quirk_pipea_force }, | ||
| 5574 | { 0x2562, PCI_ANY_ID, PCI_ANY_ID, quirk_pipea_force }, | ||
| 5575 | }; | ||
| 5576 | |||
| 5577 | static void intel_init_quirks(struct drm_device *dev) | ||
| 5578 | { | ||
| 5579 | struct pci_dev *d = dev->pdev; | ||
| 5580 | int i; | ||
| 5581 | |||
| 5582 | for (i = 0; i < ARRAY_SIZE(intel_quirks); i++) { | ||
| 5583 | struct intel_quirk *q = &intel_quirks[i]; | ||
| 5584 | |||
| 5585 | if (d->device == q->device && | ||
| 5586 | (d->subsystem_vendor == q->subsystem_vendor || | ||
| 5587 | q->subsystem_vendor == PCI_ANY_ID) && | ||
| 5588 | (d->subsystem_device == q->subsystem_device || | ||
| 5589 | q->subsystem_device == PCI_ANY_ID)) | ||
| 5590 | q->hook(dev); | ||
| 5591 | } | ||
| 5592 | } | ||
| 5593 | |||
| 5509 | void intel_modeset_init(struct drm_device *dev) | 5594 | void intel_modeset_init(struct drm_device *dev) |
| 5510 | { | 5595 | { |
| 5511 | struct drm_i915_private *dev_priv = dev->dev_private; | 5596 | struct drm_i915_private *dev_priv = dev->dev_private; |
| @@ -5518,6 +5603,8 @@ void intel_modeset_init(struct drm_device *dev) | |||
| 5518 | 5603 | ||
| 5519 | dev->mode_config.funcs = (void *)&intel_mode_funcs; | 5604 | dev->mode_config.funcs = (void *)&intel_mode_funcs; |
| 5520 | 5605 | ||
| 5606 | intel_init_quirks(dev); | ||
| 5607 | |||
| 5521 | intel_init_display(dev); | 5608 | intel_init_display(dev); |
| 5522 | 5609 | ||
| 5523 | if (IS_I965G(dev)) { | 5610 | if (IS_I965G(dev)) { |
diff --git a/drivers/gpu/drm/i915/intel_dp.c b/drivers/gpu/drm/i915/intel_dp.c index 1aac59e83bff..5dde80f9e652 100644 --- a/drivers/gpu/drm/i915/intel_dp.c +++ b/drivers/gpu/drm/i915/intel_dp.c | |||
| @@ -717,6 +717,51 @@ intel_dp_mode_set(struct drm_encoder *encoder, struct drm_display_mode *mode, | |||
| 717 | } | 717 | } |
| 718 | } | 718 | } |
| 719 | 719 | ||
| 720 | static void ironlake_edp_panel_on (struct drm_device *dev) | ||
| 721 | { | ||
| 722 | struct drm_i915_private *dev_priv = dev->dev_private; | ||
| 723 | unsigned long timeout = jiffies + msecs_to_jiffies(5000); | ||
| 724 | u32 pp, pp_status; | ||
| 725 | |||
| 726 | pp_status = I915_READ(PCH_PP_STATUS); | ||
| 727 | if (pp_status & PP_ON) | ||
| 728 | return; | ||
| 729 | |||
| 730 | pp = I915_READ(PCH_PP_CONTROL); | ||
| 731 | pp |= PANEL_UNLOCK_REGS | POWER_TARGET_ON; | ||
| 732 | I915_WRITE(PCH_PP_CONTROL, pp); | ||
| 733 | do { | ||
| 734 | pp_status = I915_READ(PCH_PP_STATUS); | ||
| 735 | } while (((pp_status & PP_ON) == 0) && !time_after(jiffies, timeout)); | ||
| 736 | |||
| 737 | if (time_after(jiffies, timeout)) | ||
| 738 | DRM_DEBUG_KMS("panel on wait timed out: 0x%08x\n", pp_status); | ||
| 739 | |||
| 740 | pp &= ~(PANEL_UNLOCK_REGS | EDP_FORCE_VDD); | ||
| 741 | I915_WRITE(PCH_PP_CONTROL, pp); | ||
| 742 | } | ||
| 743 | |||
| 744 | static void ironlake_edp_panel_off (struct drm_device *dev) | ||
| 745 | { | ||
| 746 | struct drm_i915_private *dev_priv = dev->dev_private; | ||
| 747 | unsigned long timeout = jiffies + msecs_to_jiffies(5000); | ||
| 748 | u32 pp, pp_status; | ||
| 749 | |||
| 750 | pp = I915_READ(PCH_PP_CONTROL); | ||
| 751 | pp &= ~POWER_TARGET_ON; | ||
| 752 | I915_WRITE(PCH_PP_CONTROL, pp); | ||
| 753 | do { | ||
| 754 | pp_status = I915_READ(PCH_PP_STATUS); | ||
| 755 | } while ((pp_status & PP_ON) && !time_after(jiffies, timeout)); | ||
| 756 | |||
| 757 | if (time_after(jiffies, timeout)) | ||
| 758 | DRM_DEBUG_KMS("panel off wait timed out\n"); | ||
| 759 | |||
| 760 | /* Make sure VDD is enabled so DP AUX will work */ | ||
| 761 | pp |= EDP_FORCE_VDD; | ||
| 762 | I915_WRITE(PCH_PP_CONTROL, pp); | ||
| 763 | } | ||
| 764 | |||
| 720 | static void ironlake_edp_backlight_on (struct drm_device *dev) | 765 | static void ironlake_edp_backlight_on (struct drm_device *dev) |
| 721 | { | 766 | { |
| 722 | struct drm_i915_private *dev_priv = dev->dev_private; | 767 | struct drm_i915_private *dev_priv = dev->dev_private; |
| @@ -751,14 +796,18 @@ intel_dp_dpms(struct drm_encoder *encoder, int mode) | |||
| 751 | if (mode != DRM_MODE_DPMS_ON) { | 796 | if (mode != DRM_MODE_DPMS_ON) { |
| 752 | if (dp_reg & DP_PORT_EN) { | 797 | if (dp_reg & DP_PORT_EN) { |
| 753 | intel_dp_link_down(intel_encoder, dp_priv->DP); | 798 | intel_dp_link_down(intel_encoder, dp_priv->DP); |
| 754 | if (IS_eDP(intel_encoder)) | 799 | if (IS_eDP(intel_encoder)) { |
| 755 | ironlake_edp_backlight_off(dev); | 800 | ironlake_edp_backlight_off(dev); |
| 801 | ironlake_edp_panel_off(dev); | ||
| 802 | } | ||
| 756 | } | 803 | } |
| 757 | } else { | 804 | } else { |
| 758 | if (!(dp_reg & DP_PORT_EN)) { | 805 | if (!(dp_reg & DP_PORT_EN)) { |
| 759 | intel_dp_link_train(intel_encoder, dp_priv->DP, dp_priv->link_configuration); | 806 | intel_dp_link_train(intel_encoder, dp_priv->DP, dp_priv->link_configuration); |
| 760 | if (IS_eDP(intel_encoder)) | 807 | if (IS_eDP(intel_encoder)) { |
| 808 | ironlake_edp_panel_on(dev); | ||
| 761 | ironlake_edp_backlight_on(dev); | 809 | ironlake_edp_backlight_on(dev); |
| 810 | } | ||
| 762 | } | 811 | } |
| 763 | } | 812 | } |
| 764 | dp_priv->dpms_mode = mode; | 813 | dp_priv->dpms_mode = mode; |
diff --git a/drivers/gpu/drm/i915/intel_drv.h b/drivers/gpu/drm/i915/intel_drv.h index 72206f37c4fb..2f7970be9051 100644 --- a/drivers/gpu/drm/i915/intel_drv.h +++ b/drivers/gpu/drm/i915/intel_drv.h | |||
| @@ -215,6 +215,9 @@ extern void intel_init_clock_gating(struct drm_device *dev); | |||
| 215 | extern void ironlake_enable_drps(struct drm_device *dev); | 215 | extern void ironlake_enable_drps(struct drm_device *dev); |
| 216 | extern void ironlake_disable_drps(struct drm_device *dev); | 216 | extern void ironlake_disable_drps(struct drm_device *dev); |
| 217 | 217 | ||
| 218 | extern int intel_pin_and_fence_fb_obj(struct drm_device *dev, | ||
| 219 | struct drm_gem_object *obj); | ||
| 220 | |||
| 218 | extern int intel_framebuffer_init(struct drm_device *dev, | 221 | extern int intel_framebuffer_init(struct drm_device *dev, |
| 219 | struct intel_framebuffer *ifb, | 222 | struct intel_framebuffer *ifb, |
| 220 | struct drm_mode_fb_cmd *mode_cmd, | 223 | struct drm_mode_fb_cmd *mode_cmd, |
diff --git a/drivers/gpu/drm/i915/intel_fb.c b/drivers/gpu/drm/i915/intel_fb.c index c3c505244e07..3e18c9e7729b 100644 --- a/drivers/gpu/drm/i915/intel_fb.c +++ b/drivers/gpu/drm/i915/intel_fb.c | |||
| @@ -98,7 +98,7 @@ static int intelfb_create(struct intel_fbdev *ifbdev, | |||
| 98 | 98 | ||
| 99 | mutex_lock(&dev->struct_mutex); | 99 | mutex_lock(&dev->struct_mutex); |
| 100 | 100 | ||
| 101 | ret = i915_gem_object_pin(fbo, 64*1024); | 101 | ret = intel_pin_and_fence_fb_obj(dev, fbo); |
| 102 | if (ret) { | 102 | if (ret) { |
| 103 | DRM_ERROR("failed to pin fb: %d\n", ret); | 103 | DRM_ERROR("failed to pin fb: %d\n", ret); |
| 104 | goto out_unref; | 104 | goto out_unref; |
| @@ -236,7 +236,7 @@ int intel_fbdev_destroy(struct drm_device *dev, | |||
| 236 | 236 | ||
| 237 | drm_framebuffer_cleanup(&ifb->base); | 237 | drm_framebuffer_cleanup(&ifb->base); |
| 238 | if (ifb->obj) | 238 | if (ifb->obj) |
| 239 | drm_gem_object_unreference_unlocked(ifb->obj); | 239 | drm_gem_object_unreference(ifb->obj); |
| 240 | 240 | ||
| 241 | return 0; | 241 | return 0; |
| 242 | } | 242 | } |
diff --git a/drivers/gpu/drm/i915/intel_lvds.c b/drivers/gpu/drm/i915/intel_lvds.c index 31df55f0a0a7..0eab8df5bf7e 100644 --- a/drivers/gpu/drm/i915/intel_lvds.c +++ b/drivers/gpu/drm/i915/intel_lvds.c | |||
| @@ -599,6 +599,26 @@ static int intel_lvds_get_modes(struct drm_connector *connector) | |||
| 599 | return 0; | 599 | return 0; |
| 600 | } | 600 | } |
| 601 | 601 | ||
| 602 | static int intel_no_modeset_on_lid_dmi_callback(const struct dmi_system_id *id) | ||
| 603 | { | ||
| 604 | DRM_DEBUG_KMS("Skipping forced modeset for %s\n", id->ident); | ||
| 605 | return 1; | ||
| 606 | } | ||
| 607 | |||
| 608 | /* The GPU hangs up on these systems if modeset is performed on LID open */ | ||
| 609 | static const struct dmi_system_id intel_no_modeset_on_lid[] = { | ||
| 610 | { | ||
| 611 | .callback = intel_no_modeset_on_lid_dmi_callback, | ||
| 612 | .ident = "Toshiba Tecra A11", | ||
| 613 | .matches = { | ||
| 614 | DMI_MATCH(DMI_SYS_VENDOR, "TOSHIBA"), | ||
| 615 | DMI_MATCH(DMI_PRODUCT_NAME, "TECRA A11"), | ||
| 616 | }, | ||
| 617 | }, | ||
| 618 | |||
| 619 | { } /* terminating entry */ | ||
| 620 | }; | ||
| 621 | |||
| 602 | /* | 622 | /* |
| 603 | * Lid events. Note the use of 'modeset_on_lid': | 623 | * Lid events. Note the use of 'modeset_on_lid': |
| 604 | * - we set it on lid close, and reset it on open | 624 | * - we set it on lid close, and reset it on open |
| @@ -622,6 +642,9 @@ static int intel_lid_notify(struct notifier_block *nb, unsigned long val, | |||
| 622 | */ | 642 | */ |
| 623 | if (connector) | 643 | if (connector) |
| 624 | connector->status = connector->funcs->detect(connector); | 644 | connector->status = connector->funcs->detect(connector); |
| 645 | /* Don't force modeset on machines where it causes a GPU lockup */ | ||
| 646 | if (dmi_check_system(intel_no_modeset_on_lid)) | ||
| 647 | return NOTIFY_OK; | ||
| 625 | if (!acpi_lid_open()) { | 648 | if (!acpi_lid_open()) { |
| 626 | dev_priv->modeset_on_lid = 1; | 649 | dev_priv->modeset_on_lid = 1; |
| 627 | return NOTIFY_OK; | 650 | return NOTIFY_OK; |
diff --git a/drivers/gpu/drm/radeon/evergreen_cs.c b/drivers/gpu/drm/radeon/evergreen_cs.c index 010963d4570f..345a75a03c96 100644 --- a/drivers/gpu/drm/radeon/evergreen_cs.c +++ b/drivers/gpu/drm/radeon/evergreen_cs.c | |||
| @@ -333,7 +333,6 @@ static int evergreen_cs_packet_parse_vline(struct radeon_cs_parser *p) | |||
| 333 | header = radeon_get_ib_value(p, h_idx); | 333 | header = radeon_get_ib_value(p, h_idx); |
| 334 | crtc_id = radeon_get_ib_value(p, h_idx + 2 + 7 + 1); | 334 | crtc_id = radeon_get_ib_value(p, h_idx + 2 + 7 + 1); |
| 335 | reg = CP_PACKET0_GET_REG(header); | 335 | reg = CP_PACKET0_GET_REG(header); |
| 336 | mutex_lock(&p->rdev->ddev->mode_config.mutex); | ||
| 337 | obj = drm_mode_object_find(p->rdev->ddev, crtc_id, DRM_MODE_OBJECT_CRTC); | 336 | obj = drm_mode_object_find(p->rdev->ddev, crtc_id, DRM_MODE_OBJECT_CRTC); |
| 338 | if (!obj) { | 337 | if (!obj) { |
| 339 | DRM_ERROR("cannot find crtc %d\n", crtc_id); | 338 | DRM_ERROR("cannot find crtc %d\n", crtc_id); |
| @@ -368,7 +367,6 @@ static int evergreen_cs_packet_parse_vline(struct radeon_cs_parser *p) | |||
| 368 | } | 367 | } |
| 369 | } | 368 | } |
| 370 | out: | 369 | out: |
| 371 | mutex_unlock(&p->rdev->ddev->mode_config.mutex); | ||
| 372 | return r; | 370 | return r; |
| 373 | } | 371 | } |
| 374 | 372 | ||
diff --git a/drivers/gpu/drm/radeon/r100.c b/drivers/gpu/drm/radeon/r100.c index aab5ba040bd6..a89a15ab524d 100644 --- a/drivers/gpu/drm/radeon/r100.c +++ b/drivers/gpu/drm/radeon/r100.c | |||
| @@ -1230,7 +1230,6 @@ int r100_cs_packet_parse_vline(struct radeon_cs_parser *p) | |||
| 1230 | header = radeon_get_ib_value(p, h_idx); | 1230 | header = radeon_get_ib_value(p, h_idx); |
| 1231 | crtc_id = radeon_get_ib_value(p, h_idx + 5); | 1231 | crtc_id = radeon_get_ib_value(p, h_idx + 5); |
| 1232 | reg = CP_PACKET0_GET_REG(header); | 1232 | reg = CP_PACKET0_GET_REG(header); |
| 1233 | mutex_lock(&p->rdev->ddev->mode_config.mutex); | ||
| 1234 | obj = drm_mode_object_find(p->rdev->ddev, crtc_id, DRM_MODE_OBJECT_CRTC); | 1233 | obj = drm_mode_object_find(p->rdev->ddev, crtc_id, DRM_MODE_OBJECT_CRTC); |
| 1235 | if (!obj) { | 1234 | if (!obj) { |
| 1236 | DRM_ERROR("cannot find crtc %d\n", crtc_id); | 1235 | DRM_ERROR("cannot find crtc %d\n", crtc_id); |
| @@ -1264,7 +1263,6 @@ int r100_cs_packet_parse_vline(struct radeon_cs_parser *p) | |||
| 1264 | ib[h_idx + 3] |= RADEON_ENG_DISPLAY_SELECT_CRTC1; | 1263 | ib[h_idx + 3] |= RADEON_ENG_DISPLAY_SELECT_CRTC1; |
| 1265 | } | 1264 | } |
| 1266 | out: | 1265 | out: |
| 1267 | mutex_unlock(&p->rdev->ddev->mode_config.mutex); | ||
| 1268 | return r; | 1266 | return r; |
| 1269 | } | 1267 | } |
| 1270 | 1268 | ||
diff --git a/drivers/gpu/drm/radeon/r600_cs.c b/drivers/gpu/drm/radeon/r600_cs.c index c39c1bc13016..144c32d37136 100644 --- a/drivers/gpu/drm/radeon/r600_cs.c +++ b/drivers/gpu/drm/radeon/r600_cs.c | |||
| @@ -585,7 +585,7 @@ static int r600_cs_packet_parse_vline(struct radeon_cs_parser *p) | |||
| 585 | header = radeon_get_ib_value(p, h_idx); | 585 | header = radeon_get_ib_value(p, h_idx); |
| 586 | crtc_id = radeon_get_ib_value(p, h_idx + 2 + 7 + 1); | 586 | crtc_id = radeon_get_ib_value(p, h_idx + 2 + 7 + 1); |
| 587 | reg = CP_PACKET0_GET_REG(header); | 587 | reg = CP_PACKET0_GET_REG(header); |
| 588 | mutex_lock(&p->rdev->ddev->mode_config.mutex); | 588 | |
| 589 | obj = drm_mode_object_find(p->rdev->ddev, crtc_id, DRM_MODE_OBJECT_CRTC); | 589 | obj = drm_mode_object_find(p->rdev->ddev, crtc_id, DRM_MODE_OBJECT_CRTC); |
| 590 | if (!obj) { | 590 | if (!obj) { |
| 591 | DRM_ERROR("cannot find crtc %d\n", crtc_id); | 591 | DRM_ERROR("cannot find crtc %d\n", crtc_id); |
| @@ -620,7 +620,6 @@ static int r600_cs_packet_parse_vline(struct radeon_cs_parser *p) | |||
| 620 | ib[h_idx + 4] = AVIVO_D2MODE_VLINE_STATUS >> 2; | 620 | ib[h_idx + 4] = AVIVO_D2MODE_VLINE_STATUS >> 2; |
| 621 | } | 621 | } |
| 622 | out: | 622 | out: |
| 623 | mutex_unlock(&p->rdev->ddev->mode_config.mutex); | ||
| 624 | return r; | 623 | return r; |
| 625 | } | 624 | } |
| 626 | 625 | ||
diff --git a/drivers/gpu/drm/radeon/radeon_combios.c b/drivers/gpu/drm/radeon/radeon_combios.c index d1c1d8dd93ce..2417d7b06fdb 100644 --- a/drivers/gpu/drm/radeon/radeon_combios.c +++ b/drivers/gpu/drm/radeon/radeon_combios.c | |||
| @@ -3050,6 +3050,14 @@ void radeon_combios_asic_init(struct drm_device *dev) | |||
| 3050 | rdev->pdev->subsystem_device == 0x308b) | 3050 | rdev->pdev->subsystem_device == 0x308b) |
| 3051 | return; | 3051 | return; |
| 3052 | 3052 | ||
| 3053 | /* quirk for rs4xx HP dv5000 laptop to make it resume | ||
| 3054 | * - it hangs on resume inside the dynclk 1 table. | ||
| 3055 | */ | ||
| 3056 | if (rdev->family == CHIP_RS480 && | ||
| 3057 | rdev->pdev->subsystem_vendor == 0x103c && | ||
| 3058 | rdev->pdev->subsystem_device == 0x30a4) | ||
| 3059 | return; | ||
| 3060 | |||
| 3053 | /* DYN CLK 1 */ | 3061 | /* DYN CLK 1 */ |
| 3054 | table = combios_get_table_offset(dev, COMBIOS_DYN_CLK_1_TABLE); | 3062 | table = combios_get_table_offset(dev, COMBIOS_DYN_CLK_1_TABLE); |
| 3055 | if (table) | 3063 | if (table) |
diff --git a/drivers/gpu/drm/radeon/radeon_kms.c b/drivers/gpu/drm/radeon/radeon_kms.c index 6a70c0dc7f92..ab389f89fa8d 100644 --- a/drivers/gpu/drm/radeon/radeon_kms.c +++ b/drivers/gpu/drm/radeon/radeon_kms.c | |||
| @@ -128,7 +128,8 @@ int radeon_info_ioctl(struct drm_device *dev, void *data, struct drm_file *filp) | |||
| 128 | for (i = 0, found = 0; i < rdev->num_crtc; i++) { | 128 | for (i = 0, found = 0; i < rdev->num_crtc; i++) { |
| 129 | crtc = (struct drm_crtc *)minfo->crtcs[i]; | 129 | crtc = (struct drm_crtc *)minfo->crtcs[i]; |
| 130 | if (crtc && crtc->base.id == value) { | 130 | if (crtc && crtc->base.id == value) { |
| 131 | value = i; | 131 | struct radeon_crtc *radeon_crtc = to_radeon_crtc(crtc); |
| 132 | value = radeon_crtc->crtc_id; | ||
| 132 | found = 1; | 133 | found = 1; |
| 133 | break; | 134 | break; |
| 134 | } | 135 | } |
diff --git a/drivers/gpu/drm/radeon/radeon_legacy_encoders.c b/drivers/gpu/drm/radeon/radeon_legacy_encoders.c index bad77f40a9da..5688a0cf6bbe 100644 --- a/drivers/gpu/drm/radeon/radeon_legacy_encoders.c +++ b/drivers/gpu/drm/radeon/radeon_legacy_encoders.c | |||
| @@ -108,6 +108,7 @@ static void radeon_legacy_lvds_dpms(struct drm_encoder *encoder, int mode) | |||
| 108 | udelay(panel_pwr_delay * 1000); | 108 | udelay(panel_pwr_delay * 1000); |
| 109 | WREG32(RADEON_LVDS_GEN_CNTL, lvds_gen_cntl); | 109 | WREG32(RADEON_LVDS_GEN_CNTL, lvds_gen_cntl); |
| 110 | WREG32_PLL(RADEON_PIXCLKS_CNTL, pixclks_cntl); | 110 | WREG32_PLL(RADEON_PIXCLKS_CNTL, pixclks_cntl); |
| 111 | udelay(panel_pwr_delay * 1000); | ||
| 111 | break; | 112 | break; |
| 112 | } | 113 | } |
| 113 | 114 | ||
diff --git a/drivers/gpu/drm/ttm/ttm_page_alloc.c b/drivers/gpu/drm/ttm/ttm_page_alloc.c index d233c65f3f7f..ca904799f018 100644 --- a/drivers/gpu/drm/ttm/ttm_page_alloc.c +++ b/drivers/gpu/drm/ttm/ttm_page_alloc.c | |||
| @@ -40,13 +40,13 @@ | |||
| 40 | #include <linux/slab.h> | 40 | #include <linux/slab.h> |
| 41 | 41 | ||
| 42 | #include <asm/atomic.h> | 42 | #include <asm/atomic.h> |
| 43 | #ifdef TTM_HAS_AGP | ||
| 44 | #include <asm/agp.h> | ||
| 45 | #endif | ||
| 46 | 43 | ||
| 47 | #include "ttm/ttm_bo_driver.h" | 44 | #include "ttm/ttm_bo_driver.h" |
| 48 | #include "ttm/ttm_page_alloc.h" | 45 | #include "ttm/ttm_page_alloc.h" |
| 49 | 46 | ||
| 47 | #ifdef TTM_HAS_AGP | ||
| 48 | #include <asm/agp.h> | ||
| 49 | #endif | ||
| 50 | 50 | ||
| 51 | #define NUM_PAGES_TO_ALLOC (PAGE_SIZE/sizeof(struct page *)) | 51 | #define NUM_PAGES_TO_ALLOC (PAGE_SIZE/sizeof(struct page *)) |
| 52 | #define SMALL_ALLOCATION 16 | 52 | #define SMALL_ALLOCATION 16 |
diff --git a/drivers/input/joystick/gamecon.c b/drivers/input/joystick/gamecon.c index fbd62abb66f9..0ffaf2c77a19 100644 --- a/drivers/input/joystick/gamecon.c +++ b/drivers/input/joystick/gamecon.c | |||
| @@ -89,7 +89,6 @@ struct gc_pad { | |||
| 89 | struct gc { | 89 | struct gc { |
| 90 | struct pardevice *pd; | 90 | struct pardevice *pd; |
| 91 | struct gc_pad pads[GC_MAX_DEVICES]; | 91 | struct gc_pad pads[GC_MAX_DEVICES]; |
| 92 | struct input_dev *dev[GC_MAX_DEVICES]; | ||
| 93 | struct timer_list timer; | 92 | struct timer_list timer; |
| 94 | int pad_count[GC_MAX]; | 93 | int pad_count[GC_MAX]; |
| 95 | int used; | 94 | int used; |
| @@ -387,7 +386,7 @@ static void gc_nes_process_packet(struct gc *gc) | |||
| 387 | for (i = 0; i < GC_MAX_DEVICES; i++) { | 386 | for (i = 0; i < GC_MAX_DEVICES; i++) { |
| 388 | 387 | ||
| 389 | pad = &gc->pads[i]; | 388 | pad = &gc->pads[i]; |
| 390 | dev = gc->dev[i]; | 389 | dev = pad->dev; |
| 391 | s = gc_status_bit[i]; | 390 | s = gc_status_bit[i]; |
| 392 | 391 | ||
| 393 | switch (pad->type) { | 392 | switch (pad->type) { |
| @@ -579,7 +578,7 @@ static void gc_psx_command(struct gc *gc, int b, unsigned char *data) | |||
| 579 | read = parport_read_status(port) ^ 0x80; | 578 | read = parport_read_status(port) ^ 0x80; |
| 580 | 579 | ||
| 581 | for (j = 0; j < GC_MAX_DEVICES; j++) { | 580 | for (j = 0; j < GC_MAX_DEVICES; j++) { |
| 582 | struct gc_pad *pad = &gc->pads[i]; | 581 | struct gc_pad *pad = &gc->pads[j]; |
| 583 | 582 | ||
| 584 | if (pad->type == GC_PSX || pad->type == GC_DDR) | 583 | if (pad->type == GC_PSX || pad->type == GC_DDR) |
| 585 | data[j] |= (read & gc_status_bit[j]) ? (1 << i) : 0; | 584 | data[j] |= (read & gc_status_bit[j]) ? (1 << i) : 0; |
diff --git a/drivers/input/keyboard/Kconfig b/drivers/input/keyboard/Kconfig index 3525f533e186..1ba25145b333 100644 --- a/drivers/input/keyboard/Kconfig +++ b/drivers/input/keyboard/Kconfig | |||
| @@ -124,7 +124,7 @@ config KEYBOARD_ATKBD_RDI_KEYCODES | |||
| 124 | right-hand column will be interpreted as the key shown in the | 124 | right-hand column will be interpreted as the key shown in the |
| 125 | left-hand column. | 125 | left-hand column. |
| 126 | 126 | ||
| 127 | config QT2160 | 127 | config KEYBOARD_QT2160 |
| 128 | tristate "Atmel AT42QT2160 Touch Sensor Chip" | 128 | tristate "Atmel AT42QT2160 Touch Sensor Chip" |
| 129 | depends on I2C && EXPERIMENTAL | 129 | depends on I2C && EXPERIMENTAL |
| 130 | help | 130 | help |
diff --git a/drivers/input/keyboard/twl4030_keypad.c b/drivers/input/keyboard/twl4030_keypad.c index 7aa59e07b689..fb16b5e5ea13 100644 --- a/drivers/input/keyboard/twl4030_keypad.c +++ b/drivers/input/keyboard/twl4030_keypad.c | |||
| @@ -51,8 +51,12 @@ | |||
| 51 | */ | 51 | */ |
| 52 | #define TWL4030_MAX_ROWS 8 /* TWL4030 hard limit */ | 52 | #define TWL4030_MAX_ROWS 8 /* TWL4030 hard limit */ |
| 53 | #define TWL4030_MAX_COLS 8 | 53 | #define TWL4030_MAX_COLS 8 |
| 54 | #define TWL4030_ROW_SHIFT 3 | 54 | /* |
| 55 | #define TWL4030_KEYMAP_SIZE (TWL4030_MAX_ROWS * TWL4030_MAX_COLS) | 55 | * Note that we add space for an extra column so that we can handle |
| 56 | * row lines connected to the gnd (see twl4030_col_xlate()). | ||
| 57 | */ | ||
| 58 | #define TWL4030_ROW_SHIFT 4 | ||
| 59 | #define TWL4030_KEYMAP_SIZE (TWL4030_MAX_ROWS << TWL4030_ROW_SHIFT) | ||
| 56 | 60 | ||
| 57 | struct twl4030_keypad { | 61 | struct twl4030_keypad { |
| 58 | unsigned short keymap[TWL4030_KEYMAP_SIZE]; | 62 | unsigned short keymap[TWL4030_KEYMAP_SIZE]; |
| @@ -182,7 +186,7 @@ static int twl4030_read_kp_matrix_state(struct twl4030_keypad *kp, u16 *state) | |||
| 182 | return ret; | 186 | return ret; |
| 183 | } | 187 | } |
| 184 | 188 | ||
| 185 | static int twl4030_is_in_ghost_state(struct twl4030_keypad *kp, u16 *key_state) | 189 | static bool twl4030_is_in_ghost_state(struct twl4030_keypad *kp, u16 *key_state) |
| 186 | { | 190 | { |
| 187 | int i; | 191 | int i; |
| 188 | u16 check = 0; | 192 | u16 check = 0; |
| @@ -191,12 +195,12 @@ static int twl4030_is_in_ghost_state(struct twl4030_keypad *kp, u16 *key_state) | |||
| 191 | u16 col = key_state[i]; | 195 | u16 col = key_state[i]; |
| 192 | 196 | ||
| 193 | if ((col & check) && hweight16(col) > 1) | 197 | if ((col & check) && hweight16(col) > 1) |
| 194 | return 1; | 198 | return true; |
| 195 | 199 | ||
| 196 | check |= col; | 200 | check |= col; |
| 197 | } | 201 | } |
| 198 | 202 | ||
| 199 | return 0; | 203 | return false; |
| 200 | } | 204 | } |
| 201 | 205 | ||
| 202 | static void twl4030_kp_scan(struct twl4030_keypad *kp, bool release_all) | 206 | static void twl4030_kp_scan(struct twl4030_keypad *kp, bool release_all) |
| @@ -225,7 +229,8 @@ static void twl4030_kp_scan(struct twl4030_keypad *kp, bool release_all) | |||
| 225 | if (!changed) | 229 | if (!changed) |
| 226 | continue; | 230 | continue; |
| 227 | 231 | ||
| 228 | for (col = 0; col < kp->n_cols; col++) { | 232 | /* Extra column handles "all gnd" rows */ |
| 233 | for (col = 0; col < kp->n_cols + 1; col++) { | ||
| 229 | int code; | 234 | int code; |
| 230 | 235 | ||
| 231 | if (!(changed & (1 << col))) | 236 | if (!(changed & (1 << col))) |
diff --git a/drivers/input/keyboard/w90p910_keypad.c b/drivers/input/keyboard/w90p910_keypad.c index 4ef764cc493c..ee2bf6bcf291 100644 --- a/drivers/input/keyboard/w90p910_keypad.c +++ b/drivers/input/keyboard/w90p910_keypad.c | |||
| @@ -258,7 +258,7 @@ static struct platform_driver w90p910_keypad_driver = { | |||
| 258 | .probe = w90p910_keypad_probe, | 258 | .probe = w90p910_keypad_probe, |
| 259 | .remove = __devexit_p(w90p910_keypad_remove), | 259 | .remove = __devexit_p(w90p910_keypad_remove), |
| 260 | .driver = { | 260 | .driver = { |
| 261 | .name = "nuc900-keypad", | 261 | .name = "nuc900-kpi", |
| 262 | .owner = THIS_MODULE, | 262 | .owner = THIS_MODULE, |
| 263 | }, | 263 | }, |
| 264 | }; | 264 | }; |
diff --git a/drivers/input/mouse/synaptics.c b/drivers/input/mouse/synaptics.c index 9ba9c4a17e15..705589dc9ac5 100644 --- a/drivers/input/mouse/synaptics.c +++ b/drivers/input/mouse/synaptics.c | |||
| @@ -141,8 +141,13 @@ static int synaptics_capability(struct psmouse *psmouse) | |||
| 141 | priv->capabilities = (cap[0] << 16) | (cap[1] << 8) | cap[2]; | 141 | priv->capabilities = (cap[0] << 16) | (cap[1] << 8) | cap[2]; |
| 142 | priv->ext_cap = priv->ext_cap_0c = 0; | 142 | priv->ext_cap = priv->ext_cap_0c = 0; |
| 143 | 143 | ||
| 144 | if (!SYN_CAP_VALID(priv->capabilities)) | 144 | /* |
| 145 | * Older firmwares had submodel ID fixed to 0x47 | ||
| 146 | */ | ||
| 147 | if (SYN_ID_FULL(priv->identity) < 0x705 && | ||
| 148 | SYN_CAP_SUBMODEL_ID(priv->capabilities) != 0x47) { | ||
| 145 | return -1; | 149 | return -1; |
| 150 | } | ||
| 146 | 151 | ||
| 147 | /* | 152 | /* |
| 148 | * Unless capExtended is set the rest of the flags should be ignored | 153 | * Unless capExtended is set the rest of the flags should be ignored |
diff --git a/drivers/input/mouse/synaptics.h b/drivers/input/mouse/synaptics.h index 7d4d5e12c0df..b6aa7d20d8a3 100644 --- a/drivers/input/mouse/synaptics.h +++ b/drivers/input/mouse/synaptics.h | |||
| @@ -47,7 +47,7 @@ | |||
| 47 | #define SYN_CAP_FOUR_BUTTON(c) ((c) & (1 << 3)) | 47 | #define SYN_CAP_FOUR_BUTTON(c) ((c) & (1 << 3)) |
| 48 | #define SYN_CAP_MULTIFINGER(c) ((c) & (1 << 1)) | 48 | #define SYN_CAP_MULTIFINGER(c) ((c) & (1 << 1)) |
| 49 | #define SYN_CAP_PALMDETECT(c) ((c) & (1 << 0)) | 49 | #define SYN_CAP_PALMDETECT(c) ((c) & (1 << 0)) |
| 50 | #define SYN_CAP_VALID(c) ((((c) & 0x00ff00) >> 8) == 0x47) | 50 | #define SYN_CAP_SUBMODEL_ID(c) (((c) & 0x00ff00) >> 8) |
| 51 | #define SYN_EXT_CAP_REQUESTS(c) (((c) & 0x700000) >> 20) | 51 | #define SYN_EXT_CAP_REQUESTS(c) (((c) & 0x700000) >> 20) |
| 52 | #define SYN_CAP_MULTI_BUTTON_NO(ec) (((ec) & 0x00f000) >> 12) | 52 | #define SYN_CAP_MULTI_BUTTON_NO(ec) (((ec) & 0x00f000) >> 12) |
| 53 | #define SYN_CAP_PRODUCT_ID(ec) (((ec) & 0xff0000) >> 16) | 53 | #define SYN_CAP_PRODUCT_ID(ec) (((ec) & 0xff0000) >> 16) |
| @@ -66,6 +66,7 @@ | |||
| 66 | #define SYN_ID_MODEL(i) (((i) >> 4) & 0x0f) | 66 | #define SYN_ID_MODEL(i) (((i) >> 4) & 0x0f) |
| 67 | #define SYN_ID_MAJOR(i) ((i) & 0x0f) | 67 | #define SYN_ID_MAJOR(i) ((i) & 0x0f) |
| 68 | #define SYN_ID_MINOR(i) (((i) >> 16) & 0xff) | 68 | #define SYN_ID_MINOR(i) (((i) >> 16) & 0xff) |
| 69 | #define SYN_ID_FULL(i) ((SYN_ID_MAJOR(i) << 8) | SYN_ID_MINOR(i)) | ||
| 69 | #define SYN_ID_IS_SYNAPTICS(i) ((((i) >> 8) & 0xff) == 0x47) | 70 | #define SYN_ID_IS_SYNAPTICS(i) ((((i) >> 8) & 0xff) == 0x47) |
| 70 | 71 | ||
| 71 | /* synaptics special commands */ | 72 | /* synaptics special commands */ |
diff --git a/drivers/input/serio/i8042-x86ia64io.h b/drivers/input/serio/i8042-x86ia64io.h index 81003c4739f4..ed7ad7416b24 100644 --- a/drivers/input/serio/i8042-x86ia64io.h +++ b/drivers/input/serio/i8042-x86ia64io.h | |||
| @@ -170,6 +170,13 @@ static const struct dmi_system_id __initconst i8042_dmi_noloop_table[] = { | |||
| 170 | }, | 170 | }, |
| 171 | }, | 171 | }, |
| 172 | { | 172 | { |
| 173 | /* Gigabyte Spring Peak - defines wrong chassis type */ | ||
| 174 | .matches = { | ||
| 175 | DMI_MATCH(DMI_SYS_VENDOR, "GIGABYTE"), | ||
| 176 | DMI_MATCH(DMI_PRODUCT_NAME, "Spring Peak"), | ||
| 177 | }, | ||
| 178 | }, | ||
| 179 | { | ||
| 173 | .matches = { | 180 | .matches = { |
| 174 | DMI_MATCH(DMI_SYS_VENDOR, "Hewlett-Packard"), | 181 | DMI_MATCH(DMI_SYS_VENDOR, "Hewlett-Packard"), |
| 175 | DMI_MATCH(DMI_PRODUCT_NAME, "HP Pavilion dv9700"), | 182 | DMI_MATCH(DMI_PRODUCT_NAME, "HP Pavilion dv9700"), |
diff --git a/drivers/misc/Kconfig b/drivers/misc/Kconfig index 26386a92f5aa..9b089dfb173e 100644 --- a/drivers/misc/Kconfig +++ b/drivers/misc/Kconfig | |||
| @@ -353,6 +353,16 @@ config VMWARE_BALLOON | |||
| 353 | To compile this driver as a module, choose M here: the | 353 | To compile this driver as a module, choose M here: the |
| 354 | module will be called vmware_balloon. | 354 | module will be called vmware_balloon. |
| 355 | 355 | ||
| 356 | config ARM_CHARLCD | ||
| 357 | bool "ARM Ltd. Character LCD Driver" | ||
| 358 | depends on PLAT_VERSATILE | ||
| 359 | help | ||
| 360 | This is a driver for the character LCD found on the ARM Ltd. | ||
| 361 | Versatile and RealView Platform Baseboards. It doesn't do | ||
| 362 | very much more than display the text "ARM Linux" on the first | ||
| 363 | line and the Linux version on the second line, but that's | ||
| 364 | still useful. | ||
| 365 | |||
| 356 | source "drivers/misc/c2port/Kconfig" | 366 | source "drivers/misc/c2port/Kconfig" |
| 357 | source "drivers/misc/eeprom/Kconfig" | 367 | source "drivers/misc/eeprom/Kconfig" |
| 358 | source "drivers/misc/cb710/Kconfig" | 368 | source "drivers/misc/cb710/Kconfig" |
diff --git a/drivers/misc/Makefile b/drivers/misc/Makefile index 6ed06a19474a..67552d6e9327 100644 --- a/drivers/misc/Makefile +++ b/drivers/misc/Makefile | |||
| @@ -31,3 +31,4 @@ obj-$(CONFIG_IWMC3200TOP) += iwmc3200top/ | |||
| 31 | obj-y += eeprom/ | 31 | obj-y += eeprom/ |
| 32 | obj-y += cb710/ | 32 | obj-y += cb710/ |
| 33 | obj-$(CONFIG_VMWARE_BALLOON) += vmware_balloon.o | 33 | obj-$(CONFIG_VMWARE_BALLOON) += vmware_balloon.o |
| 34 | obj-$(CONFIG_ARM_CHARLCD) += arm-charlcd.o | ||
diff --git a/drivers/misc/arm-charlcd.c b/drivers/misc/arm-charlcd.c new file mode 100644 index 000000000000..9e3879ef58f2 --- /dev/null +++ b/drivers/misc/arm-charlcd.c | |||
| @@ -0,0 +1,396 @@ | |||
| 1 | /* | ||
| 2 | * Driver for the on-board character LCD found on some ARM reference boards | ||
| 3 | * This is basically an Hitachi HD44780 LCD with a custom IP block to drive it | ||
| 4 | * http://en.wikipedia.org/wiki/HD44780_Character_LCD | ||
| 5 | * Currently it will just display the text "ARM Linux" and the linux version | ||
| 6 | * | ||
| 7 | * License terms: GNU General Public License (GPL) version 2 | ||
| 8 | * Author: Linus Walleij <triad@df.lth.se> | ||
| 9 | */ | ||
| 10 | #include <linux/init.h> | ||
| 11 | #include <linux/module.h> | ||
| 12 | #include <linux/interrupt.h> | ||
| 13 | #include <linux/platform_device.h> | ||
| 14 | #include <linux/completion.h> | ||
| 15 | #include <linux/delay.h> | ||
| 16 | #include <linux/io.h> | ||
| 17 | #include <linux/slab.h> | ||
| 18 | #include <linux/workqueue.h> | ||
| 19 | #include <generated/utsrelease.h> | ||
| 20 | |||
| 21 | #define DRIVERNAME "arm-charlcd" | ||
| 22 | #define CHARLCD_TIMEOUT (msecs_to_jiffies(1000)) | ||
| 23 | |||
| 24 | /* Offsets to registers */ | ||
| 25 | #define CHAR_COM 0x00U | ||
| 26 | #define CHAR_DAT 0x04U | ||
| 27 | #define CHAR_RD 0x08U | ||
| 28 | #define CHAR_RAW 0x0CU | ||
| 29 | #define CHAR_MASK 0x10U | ||
| 30 | #define CHAR_STAT 0x14U | ||
| 31 | |||
| 32 | #define CHAR_RAW_CLEAR 0x00000000U | ||
| 33 | #define CHAR_RAW_VALID 0x00000100U | ||
| 34 | |||
| 35 | /* Hitachi HD44780 display commands */ | ||
| 36 | #define HD_CLEAR 0x01U | ||
| 37 | #define HD_HOME 0x02U | ||
| 38 | #define HD_ENTRYMODE 0x04U | ||
| 39 | #define HD_ENTRYMODE_INCREMENT 0x02U | ||
| 40 | #define HD_ENTRYMODE_SHIFT 0x01U | ||
| 41 | #define HD_DISPCTRL 0x08U | ||
| 42 | #define HD_DISPCTRL_ON 0x04U | ||
| 43 | #define HD_DISPCTRL_CURSOR_ON 0x02U | ||
| 44 | #define HD_DISPCTRL_CURSOR_BLINK 0x01U | ||
| 45 | #define HD_CRSR_SHIFT 0x10U | ||
| 46 | #define HD_CRSR_SHIFT_DISPLAY 0x08U | ||
| 47 | #define HD_CRSR_SHIFT_DISPLAY_RIGHT 0x04U | ||
| 48 | #define HD_FUNCSET 0x20U | ||
| 49 | #define HD_FUNCSET_8BIT 0x10U | ||
| 50 | #define HD_FUNCSET_2_LINES 0x08U | ||
| 51 | #define HD_FUNCSET_FONT_5X10 0x04U | ||
| 52 | #define HD_SET_CGRAM 0x40U | ||
| 53 | #define HD_SET_DDRAM 0x80U | ||
| 54 | #define HD_BUSY_FLAG 0x80U | ||
| 55 | |||
| 56 | /** | ||
| 57 | * @dev: a pointer back to containing device | ||
| 58 | * @phybase: the offset to the controller in physical memory | ||
| 59 | * @physize: the size of the physical page | ||
| 60 | * @virtbase: the offset to the controller in virtual memory | ||
| 61 | * @irq: reserved interrupt number | ||
| 62 | * @complete: completion structure for the last LCD command | ||
| 63 | */ | ||
| 64 | struct charlcd { | ||
| 65 | struct device *dev; | ||
| 66 | u32 phybase; | ||
| 67 | u32 physize; | ||
| 68 | void __iomem *virtbase; | ||
| 69 | int irq; | ||
| 70 | struct completion complete; | ||
| 71 | struct delayed_work init_work; | ||
| 72 | }; | ||
| 73 | |||
| 74 | static irqreturn_t charlcd_interrupt(int irq, void *data) | ||
| 75 | { | ||
| 76 | struct charlcd *lcd = data; | ||
| 77 | u8 status; | ||
| 78 | |||
| 79 | status = readl(lcd->virtbase + CHAR_STAT) & 0x01; | ||
| 80 | /* Clear IRQ */ | ||
| 81 | writel(CHAR_RAW_CLEAR, lcd->virtbase + CHAR_RAW); | ||
| 82 | if (status) | ||
| 83 | complete(&lcd->complete); | ||
| 84 | else | ||
| 85 | dev_info(lcd->dev, "Spurious IRQ (%02x)\n", status); | ||
| 86 | return IRQ_HANDLED; | ||
| 87 | } | ||
| 88 | |||
| 89 | |||
| 90 | static void charlcd_wait_complete_irq(struct charlcd *lcd) | ||
| 91 | { | ||
| 92 | int ret; | ||
| 93 | |||
| 94 | ret = wait_for_completion_interruptible_timeout(&lcd->complete, | ||
| 95 | CHARLCD_TIMEOUT); | ||
| 96 | /* Disable IRQ after completion */ | ||
| 97 | writel(0x00, lcd->virtbase + CHAR_MASK); | ||
| 98 | |||
| 99 | if (ret < 0) { | ||
| 100 | dev_err(lcd->dev, | ||
| 101 | "wait_for_completion_interruptible_timeout() " | ||
| 102 | "returned %d waiting for ready\n", ret); | ||
| 103 | return; | ||
| 104 | } | ||
| 105 | |||
| 106 | if (ret == 0) { | ||
| 107 | dev_err(lcd->dev, "charlcd controller timed out " | ||
| 108 | "waiting for ready\n"); | ||
| 109 | return; | ||
| 110 | } | ||
| 111 | } | ||
| 112 | |||
| 113 | static u8 charlcd_4bit_read_char(struct charlcd *lcd) | ||
| 114 | { | ||
| 115 | u8 data; | ||
| 116 | u32 val; | ||
| 117 | int i; | ||
| 118 | |||
| 119 | /* If we can, use an IRQ to wait for the data, else poll */ | ||
| 120 | if (lcd->irq >= 0) | ||
| 121 | charlcd_wait_complete_irq(lcd); | ||
| 122 | else { | ||
| 123 | i = 0; | ||
| 124 | val = 0; | ||
| 125 | while (!(val & CHAR_RAW_VALID) && i < 10) { | ||
| 126 | udelay(100); | ||
| 127 | val = readl(lcd->virtbase + CHAR_RAW); | ||
| 128 | i++; | ||
| 129 | } | ||
| 130 | |||
| 131 | writel(CHAR_RAW_CLEAR, lcd->virtbase + CHAR_RAW); | ||
| 132 | } | ||
| 133 | msleep(1); | ||
| 134 | |||
| 135 | /* Read the 4 high bits of the data */ | ||
| 136 | data = readl(lcd->virtbase + CHAR_RD) & 0xf0; | ||
| 137 | |||
| 138 | /* | ||
| 139 | * The second read for the low bits does not trigger an IRQ | ||
| 140 | * so in this case we have to poll for the 4 lower bits | ||
| 141 | */ | ||
| 142 | i = 0; | ||
| 143 | val = 0; | ||
| 144 | while (!(val & CHAR_RAW_VALID) && i < 10) { | ||
| 145 | udelay(100); | ||
| 146 | val = readl(lcd->virtbase + CHAR_RAW); | ||
| 147 | i++; | ||
| 148 | } | ||
| 149 | writel(CHAR_RAW_CLEAR, lcd->virtbase + CHAR_RAW); | ||
| 150 | msleep(1); | ||
| 151 | |||
| 152 | /* Read the 4 low bits of the data */ | ||
| 153 | data |= (readl(lcd->virtbase + CHAR_RD) >> 4) & 0x0f; | ||
| 154 | |||
| 155 | return data; | ||
| 156 | } | ||
| 157 | |||
| 158 | static bool charlcd_4bit_read_bf(struct charlcd *lcd) | ||
| 159 | { | ||
| 160 | if (lcd->irq >= 0) { | ||
| 161 | /* | ||
| 162 | * If we'll use IRQs to wait for the busyflag, clear any | ||
| 163 | * pending flag and enable IRQ | ||
| 164 | */ | ||
| 165 | writel(CHAR_RAW_CLEAR, lcd->virtbase + CHAR_RAW); | ||
| 166 | init_completion(&lcd->complete); | ||
| 167 | writel(0x01, lcd->virtbase + CHAR_MASK); | ||
| 168 | } | ||
| 169 | readl(lcd->virtbase + CHAR_COM); | ||
| 170 | return charlcd_4bit_read_char(lcd) & HD_BUSY_FLAG ? true : false; | ||
| 171 | } | ||
| 172 | |||
| 173 | static void charlcd_4bit_wait_busy(struct charlcd *lcd) | ||
| 174 | { | ||
| 175 | int retries = 50; | ||
| 176 | |||
| 177 | udelay(100); | ||
| 178 | while (charlcd_4bit_read_bf(lcd) && retries) | ||
| 179 | retries--; | ||
| 180 | if (!retries) | ||
| 181 | dev_err(lcd->dev, "timeout waiting for busyflag\n"); | ||
| 182 | } | ||
| 183 | |||
| 184 | static void charlcd_4bit_command(struct charlcd *lcd, u8 cmd) | ||
| 185 | { | ||
| 186 | u32 cmdlo = (cmd << 4) & 0xf0; | ||
| 187 | u32 cmdhi = (cmd & 0xf0); | ||
| 188 | |||
| 189 | writel(cmdhi, lcd->virtbase + CHAR_COM); | ||
| 190 | udelay(10); | ||
| 191 | writel(cmdlo, lcd->virtbase + CHAR_COM); | ||
| 192 | charlcd_4bit_wait_busy(lcd); | ||
| 193 | } | ||
| 194 | |||
| 195 | static void charlcd_4bit_char(struct charlcd *lcd, u8 ch) | ||
| 196 | { | ||
| 197 | u32 chlo = (ch << 4) & 0xf0; | ||
| 198 | u32 chhi = (ch & 0xf0); | ||
| 199 | |||
| 200 | writel(chhi, lcd->virtbase + CHAR_DAT); | ||
| 201 | udelay(10); | ||
| 202 | writel(chlo, lcd->virtbase + CHAR_DAT); | ||
| 203 | charlcd_4bit_wait_busy(lcd); | ||
| 204 | } | ||
| 205 | |||
| 206 | static void charlcd_4bit_print(struct charlcd *lcd, int line, const char *str) | ||
| 207 | { | ||
| 208 | u8 offset; | ||
| 209 | int i; | ||
| 210 | |||
| 211 | /* | ||
| 212 | * We support line 0, 1 | ||
| 213 | * Line 1 runs from 0x00..0x27 | ||
| 214 | * Line 2 runs from 0x28..0x4f | ||
| 215 | */ | ||
| 216 | if (line == 0) | ||
| 217 | offset = 0; | ||
| 218 | else if (line == 1) | ||
| 219 | offset = 0x28; | ||
| 220 | else | ||
| 221 | return; | ||
| 222 | |||
| 223 | /* Set offset */ | ||
| 224 | charlcd_4bit_command(lcd, HD_SET_DDRAM | offset); | ||
| 225 | |||
| 226 | /* Send string */ | ||
| 227 | for (i = 0; i < strlen(str) && i < 0x28; i++) | ||
| 228 | charlcd_4bit_char(lcd, str[i]); | ||
| 229 | } | ||
| 230 | |||
| 231 | static void charlcd_4bit_init(struct charlcd *lcd) | ||
| 232 | { | ||
| 233 | /* These commands cannot be checked with the busy flag */ | ||
| 234 | writel(HD_FUNCSET | HD_FUNCSET_8BIT, lcd->virtbase + CHAR_COM); | ||
| 235 | msleep(5); | ||
| 236 | writel(HD_FUNCSET | HD_FUNCSET_8BIT, lcd->virtbase + CHAR_COM); | ||
| 237 | udelay(100); | ||
| 238 | writel(HD_FUNCSET | HD_FUNCSET_8BIT, lcd->virtbase + CHAR_COM); | ||
| 239 | udelay(100); | ||
| 240 | /* Go to 4bit mode */ | ||
| 241 | writel(HD_FUNCSET, lcd->virtbase + CHAR_COM); | ||
| 242 | udelay(100); | ||
| 243 | /* | ||
| 244 | * 4bit mode, 2 lines, 5x8 font, after this the number of lines | ||
| 245 | * and the font cannot be changed until the next initialization sequence | ||
| 246 | */ | ||
| 247 | charlcd_4bit_command(lcd, HD_FUNCSET | HD_FUNCSET_2_LINES); | ||
| 248 | charlcd_4bit_command(lcd, HD_DISPCTRL | HD_DISPCTRL_ON); | ||
| 249 | charlcd_4bit_command(lcd, HD_ENTRYMODE | HD_ENTRYMODE_INCREMENT); | ||
| 250 | charlcd_4bit_command(lcd, HD_CLEAR); | ||
| 251 | charlcd_4bit_command(lcd, HD_HOME); | ||
| 252 | /* Put something useful in the display */ | ||
| 253 | charlcd_4bit_print(lcd, 0, "ARM Linux"); | ||
| 254 | charlcd_4bit_print(lcd, 1, UTS_RELEASE); | ||
| 255 | } | ||
| 256 | |||
| 257 | static void charlcd_init_work(struct work_struct *work) | ||
| 258 | { | ||
| 259 | struct charlcd *lcd = | ||
| 260 | container_of(work, struct charlcd, init_work.work); | ||
| 261 | |||
| 262 | charlcd_4bit_init(lcd); | ||
| 263 | } | ||
| 264 | |||
| 265 | static int __init charlcd_probe(struct platform_device *pdev) | ||
| 266 | { | ||
| 267 | int ret; | ||
| 268 | struct charlcd *lcd; | ||
| 269 | struct resource *res; | ||
| 270 | |||
| 271 | lcd = kzalloc(sizeof(struct charlcd), GFP_KERNEL); | ||
| 272 | if (!lcd) | ||
| 273 | return -ENOMEM; | ||
| 274 | |||
| 275 | lcd->dev = &pdev->dev; | ||
| 276 | |||
| 277 | res = platform_get_resource(pdev, IORESOURCE_MEM, 0); | ||
| 278 | if (!res) { | ||
| 279 | ret = -ENOENT; | ||
| 280 | goto out_no_resource; | ||
| 281 | } | ||
| 282 | lcd->phybase = res->start; | ||
| 283 | lcd->physize = resource_size(res); | ||
| 284 | |||
| 285 | if (request_mem_region(lcd->phybase, lcd->physize, | ||
| 286 | DRIVERNAME) == NULL) { | ||
| 287 | ret = -EBUSY; | ||
| 288 | goto out_no_memregion; | ||
| 289 | } | ||
| 290 | |||
| 291 | lcd->virtbase = ioremap(lcd->phybase, lcd->physize); | ||
| 292 | if (!lcd->virtbase) { | ||
| 293 | ret = -ENOMEM; | ||
| 294 | goto out_no_remap; | ||
| 295 | } | ||
| 296 | |||
| 297 | lcd->irq = platform_get_irq(pdev, 0); | ||
| 298 | /* If no IRQ is supplied, we'll survive without it */ | ||
| 299 | if (lcd->irq >= 0) { | ||
| 300 | if (request_irq(lcd->irq, charlcd_interrupt, IRQF_DISABLED, | ||
| 301 | DRIVERNAME, lcd)) { | ||
| 302 | ret = -EIO; | ||
| 303 | goto out_no_irq; | ||
| 304 | } | ||
| 305 | } | ||
| 306 | |||
| 307 | platform_set_drvdata(pdev, lcd); | ||
| 308 | |||
| 309 | /* | ||
| 310 | * Initialize the display in a delayed work, because | ||
| 311 | * it is VERY slow and would slow down the boot of the system. | ||
| 312 | */ | ||
| 313 | INIT_DELAYED_WORK(&lcd->init_work, charlcd_init_work); | ||
| 314 | schedule_delayed_work(&lcd->init_work, 0); | ||
| 315 | |||
| 316 | dev_info(&pdev->dev, "initalized ARM character LCD at %08x\n", | ||
| 317 | lcd->phybase); | ||
| 318 | |||
| 319 | return 0; | ||
| 320 | |||
| 321 | out_no_irq: | ||
| 322 | iounmap(lcd->virtbase); | ||
| 323 | out_no_remap: | ||
| 324 | platform_set_drvdata(pdev, NULL); | ||
| 325 | out_no_memregion: | ||
| 326 | release_mem_region(lcd->phybase, SZ_4K); | ||
| 327 | out_no_resource: | ||
| 328 | kfree(lcd); | ||
| 329 | return ret; | ||
| 330 | } | ||
| 331 | |||
| 332 | static int __exit charlcd_remove(struct platform_device *pdev) | ||
| 333 | { | ||
| 334 | struct charlcd *lcd = platform_get_drvdata(pdev); | ||
| 335 | |||
| 336 | if (lcd) { | ||
| 337 | free_irq(lcd->irq, lcd); | ||
| 338 | iounmap(lcd->virtbase); | ||
| 339 | release_mem_region(lcd->phybase, lcd->physize); | ||
| 340 | platform_set_drvdata(pdev, NULL); | ||
| 341 | kfree(lcd); | ||
| 342 | } | ||
| 343 | |||
| 344 | return 0; | ||
| 345 | } | ||
| 346 | |||
| 347 | static int charlcd_suspend(struct device *dev) | ||
| 348 | { | ||
| 349 | struct platform_device *pdev = to_platform_device(dev); | ||
| 350 | struct charlcd *lcd = platform_get_drvdata(pdev); | ||
| 351 | |||
| 352 | /* Power the display off */ | ||
| 353 | charlcd_4bit_command(lcd, HD_DISPCTRL); | ||
| 354 | return 0; | ||
| 355 | } | ||
| 356 | |||
| 357 | static int charlcd_resume(struct device *dev) | ||
| 358 | { | ||
| 359 | struct platform_device *pdev = to_platform_device(dev); | ||
| 360 | struct charlcd *lcd = platform_get_drvdata(pdev); | ||
| 361 | |||
| 362 | /* Turn the display back on */ | ||
| 363 | charlcd_4bit_command(lcd, HD_DISPCTRL | HD_DISPCTRL_ON); | ||
| 364 | return 0; | ||
| 365 | } | ||
| 366 | |||
| 367 | static const struct dev_pm_ops charlcd_pm_ops = { | ||
| 368 | .suspend = charlcd_suspend, | ||
| 369 | .resume = charlcd_resume, | ||
| 370 | }; | ||
| 371 | |||
| 372 | static struct platform_driver charlcd_driver = { | ||
| 373 | .driver = { | ||
| 374 | .name = DRIVERNAME, | ||
| 375 | .owner = THIS_MODULE, | ||
| 376 | .pm = &charlcd_pm_ops, | ||
| 377 | }, | ||
| 378 | .remove = __exit_p(charlcd_remove), | ||
| 379 | }; | ||
| 380 | |||
| 381 | static int __init charlcd_init(void) | ||
| 382 | { | ||
| 383 | return platform_driver_probe(&charlcd_driver, charlcd_probe); | ||
| 384 | } | ||
| 385 | |||
| 386 | static void __exit charlcd_exit(void) | ||
| 387 | { | ||
| 388 | platform_driver_unregister(&charlcd_driver); | ||
| 389 | } | ||
| 390 | |||
| 391 | module_init(charlcd_init); | ||
| 392 | module_exit(charlcd_exit); | ||
| 393 | |||
| 394 | MODULE_AUTHOR("Linus Walleij <triad@df.lth.se>"); | ||
| 395 | MODULE_DESCRIPTION("ARM Character LCD Driver"); | ||
| 396 | MODULE_LICENSE("GPL v2"); | ||
diff --git a/drivers/net/bnx2x.h b/drivers/net/bnx2x.h index 8bd23687c530..bb0872a63315 100644 --- a/drivers/net/bnx2x.h +++ b/drivers/net/bnx2x.h | |||
| @@ -1062,6 +1062,10 @@ struct bnx2x { | |||
| 1062 | 1062 | ||
| 1063 | /* used to synchronize stats collecting */ | 1063 | /* used to synchronize stats collecting */ |
| 1064 | int stats_state; | 1064 | int stats_state; |
| 1065 | |||
| 1066 | /* used for synchronization of concurrent threads statistics handling */ | ||
| 1067 | spinlock_t stats_lock; | ||
| 1068 | |||
| 1065 | /* used by dmae command loader */ | 1069 | /* used by dmae command loader */ |
| 1066 | struct dmae_command stats_dmae; | 1070 | struct dmae_command stats_dmae; |
| 1067 | int executer_idx; | 1071 | int executer_idx; |
diff --git a/drivers/net/bnx2x_main.c b/drivers/net/bnx2x_main.c index 57ff5b3bcce6..46167c081727 100644 --- a/drivers/net/bnx2x_main.c +++ b/drivers/net/bnx2x_main.c | |||
| @@ -57,8 +57,8 @@ | |||
| 57 | #include "bnx2x_init_ops.h" | 57 | #include "bnx2x_init_ops.h" |
| 58 | #include "bnx2x_dump.h" | 58 | #include "bnx2x_dump.h" |
| 59 | 59 | ||
| 60 | #define DRV_MODULE_VERSION "1.52.53-1" | 60 | #define DRV_MODULE_VERSION "1.52.53-2" |
| 61 | #define DRV_MODULE_RELDATE "2010/18/04" | 61 | #define DRV_MODULE_RELDATE "2010/21/07" |
| 62 | #define BNX2X_BC_VER 0x040200 | 62 | #define BNX2X_BC_VER 0x040200 |
| 63 | 63 | ||
| 64 | #include <linux/firmware.h> | 64 | #include <linux/firmware.h> |
| @@ -3789,6 +3789,8 @@ static void bnx2x_storm_stats_post(struct bnx2x *bp) | |||
| 3789 | struct eth_query_ramrod_data ramrod_data = {0}; | 3789 | struct eth_query_ramrod_data ramrod_data = {0}; |
| 3790 | int i, rc; | 3790 | int i, rc; |
| 3791 | 3791 | ||
| 3792 | spin_lock_bh(&bp->stats_lock); | ||
| 3793 | |||
| 3792 | ramrod_data.drv_counter = bp->stats_counter++; | 3794 | ramrod_data.drv_counter = bp->stats_counter++; |
| 3793 | ramrod_data.collect_port = bp->port.pmf ? 1 : 0; | 3795 | ramrod_data.collect_port = bp->port.pmf ? 1 : 0; |
| 3794 | for_each_queue(bp, i) | 3796 | for_each_queue(bp, i) |
| @@ -3802,6 +3804,8 @@ static void bnx2x_storm_stats_post(struct bnx2x *bp) | |||
| 3802 | bp->spq_left++; | 3804 | bp->spq_left++; |
| 3803 | bp->stats_pending = 1; | 3805 | bp->stats_pending = 1; |
| 3804 | } | 3806 | } |
| 3807 | |||
| 3808 | spin_unlock_bh(&bp->stats_lock); | ||
| 3805 | } | 3809 | } |
| 3806 | } | 3810 | } |
| 3807 | 3811 | ||
| @@ -4367,6 +4371,14 @@ static int bnx2x_storm_stats_update(struct bnx2x *bp) | |||
| 4367 | struct host_func_stats *fstats = bnx2x_sp(bp, func_stats); | 4371 | struct host_func_stats *fstats = bnx2x_sp(bp, func_stats); |
| 4368 | struct bnx2x_eth_stats *estats = &bp->eth_stats; | 4372 | struct bnx2x_eth_stats *estats = &bp->eth_stats; |
| 4369 | int i; | 4373 | int i; |
| 4374 | u16 cur_stats_counter; | ||
| 4375 | |||
| 4376 | /* Make sure we use the value of the counter | ||
| 4377 | * used for sending the last stats ramrod. | ||
| 4378 | */ | ||
| 4379 | spin_lock_bh(&bp->stats_lock); | ||
| 4380 | cur_stats_counter = bp->stats_counter - 1; | ||
| 4381 | spin_unlock_bh(&bp->stats_lock); | ||
| 4370 | 4382 | ||
| 4371 | memcpy(&(fstats->total_bytes_received_hi), | 4383 | memcpy(&(fstats->total_bytes_received_hi), |
| 4372 | &(bnx2x_sp(bp, func_stats_base)->total_bytes_received_hi), | 4384 | &(bnx2x_sp(bp, func_stats_base)->total_bytes_received_hi), |
| @@ -4394,25 +4406,22 @@ static int bnx2x_storm_stats_update(struct bnx2x *bp) | |||
| 4394 | u32 diff; | 4406 | u32 diff; |
| 4395 | 4407 | ||
| 4396 | /* are storm stats valid? */ | 4408 | /* are storm stats valid? */ |
| 4397 | if ((u16)(le16_to_cpu(xclient->stats_counter) + 1) != | 4409 | if (le16_to_cpu(xclient->stats_counter) != cur_stats_counter) { |
| 4398 | bp->stats_counter) { | ||
| 4399 | DP(BNX2X_MSG_STATS, "[%d] stats not updated by xstorm" | 4410 | DP(BNX2X_MSG_STATS, "[%d] stats not updated by xstorm" |
| 4400 | " xstorm counter (0x%x) != stats_counter (0x%x)\n", | 4411 | " xstorm counter (0x%x) != stats_counter (0x%x)\n", |
| 4401 | i, xclient->stats_counter, bp->stats_counter); | 4412 | i, xclient->stats_counter, cur_stats_counter + 1); |
| 4402 | return -1; | 4413 | return -1; |
| 4403 | } | 4414 | } |
| 4404 | if ((u16)(le16_to_cpu(tclient->stats_counter) + 1) != | 4415 | if (le16_to_cpu(tclient->stats_counter) != cur_stats_counter) { |
| 4405 | bp->stats_counter) { | ||
| 4406 | DP(BNX2X_MSG_STATS, "[%d] stats not updated by tstorm" | 4416 | DP(BNX2X_MSG_STATS, "[%d] stats not updated by tstorm" |
| 4407 | " tstorm counter (0x%x) != stats_counter (0x%x)\n", | 4417 | " tstorm counter (0x%x) != stats_counter (0x%x)\n", |
| 4408 | i, tclient->stats_counter, bp->stats_counter); | 4418 | i, tclient->stats_counter, cur_stats_counter + 1); |
| 4409 | return -2; | 4419 | return -2; |
| 4410 | } | 4420 | } |
| 4411 | if ((u16)(le16_to_cpu(uclient->stats_counter) + 1) != | 4421 | if (le16_to_cpu(uclient->stats_counter) != cur_stats_counter) { |
| 4412 | bp->stats_counter) { | ||
| 4413 | DP(BNX2X_MSG_STATS, "[%d] stats not updated by ustorm" | 4422 | DP(BNX2X_MSG_STATS, "[%d] stats not updated by ustorm" |
| 4414 | " ustorm counter (0x%x) != stats_counter (0x%x)\n", | 4423 | " ustorm counter (0x%x) != stats_counter (0x%x)\n", |
| 4415 | i, uclient->stats_counter, bp->stats_counter); | 4424 | i, uclient->stats_counter, cur_stats_counter + 1); |
| 4416 | return -4; | 4425 | return -4; |
| 4417 | } | 4426 | } |
| 4418 | 4427 | ||
| @@ -4849,16 +4858,18 @@ static const struct { | |||
| 4849 | 4858 | ||
| 4850 | static void bnx2x_stats_handle(struct bnx2x *bp, enum bnx2x_stats_event event) | 4859 | static void bnx2x_stats_handle(struct bnx2x *bp, enum bnx2x_stats_event event) |
| 4851 | { | 4860 | { |
| 4852 | enum bnx2x_stats_state state = bp->stats_state; | 4861 | enum bnx2x_stats_state state; |
| 4853 | 4862 | ||
| 4854 | if (unlikely(bp->panic)) | 4863 | if (unlikely(bp->panic)) |
| 4855 | return; | 4864 | return; |
| 4856 | 4865 | ||
| 4857 | bnx2x_stats_stm[state][event].action(bp); | 4866 | /* Protect a state change flow */ |
| 4867 | spin_lock_bh(&bp->stats_lock); | ||
| 4868 | state = bp->stats_state; | ||
| 4858 | bp->stats_state = bnx2x_stats_stm[state][event].next_state; | 4869 | bp->stats_state = bnx2x_stats_stm[state][event].next_state; |
| 4870 | spin_unlock_bh(&bp->stats_lock); | ||
| 4859 | 4871 | ||
| 4860 | /* Make sure the state has been "changed" */ | 4872 | bnx2x_stats_stm[state][event].action(bp); |
| 4861 | smp_wmb(); | ||
| 4862 | 4873 | ||
| 4863 | if ((event != STATS_EVENT_UPDATE) || netif_msg_timer(bp)) | 4874 | if ((event != STATS_EVENT_UPDATE) || netif_msg_timer(bp)) |
| 4864 | DP(BNX2X_MSG_STATS, "state %d -> event %d -> state %d\n", | 4875 | DP(BNX2X_MSG_STATS, "state %d -> event %d -> state %d\n", |
| @@ -9908,6 +9919,7 @@ static int __devinit bnx2x_init_bp(struct bnx2x *bp) | |||
| 9908 | 9919 | ||
| 9909 | mutex_init(&bp->port.phy_mutex); | 9920 | mutex_init(&bp->port.phy_mutex); |
| 9910 | mutex_init(&bp->fw_mb_mutex); | 9921 | mutex_init(&bp->fw_mb_mutex); |
| 9922 | spin_lock_init(&bp->stats_lock); | ||
| 9911 | #ifdef BCM_CNIC | 9923 | #ifdef BCM_CNIC |
| 9912 | mutex_init(&bp->cnic_mutex); | 9924 | mutex_init(&bp->cnic_mutex); |
| 9913 | #endif | 9925 | #endif |
diff --git a/drivers/net/bonding/bond_alb.c b/drivers/net/bonding/bond_alb.c index df483076eda6..8d7dfd2f1e90 100644 --- a/drivers/net/bonding/bond_alb.c +++ b/drivers/net/bonding/bond_alb.c | |||
| @@ -822,7 +822,7 @@ static int rlb_initialize(struct bonding *bond) | |||
| 822 | 822 | ||
| 823 | /*initialize packet type*/ | 823 | /*initialize packet type*/ |
| 824 | pk_type->type = cpu_to_be16(ETH_P_ARP); | 824 | pk_type->type = cpu_to_be16(ETH_P_ARP); |
| 825 | pk_type->dev = NULL; | 825 | pk_type->dev = bond->dev; |
| 826 | pk_type->func = rlb_arp_recv; | 826 | pk_type->func = rlb_arp_recv; |
| 827 | 827 | ||
| 828 | /* register to receive ARPs */ | 828 | /* register to receive ARPs */ |
diff --git a/drivers/net/declance.c b/drivers/net/declance.c index 1d973db27c32..d7de376d7178 100644 --- a/drivers/net/declance.c +++ b/drivers/net/declance.c | |||
| @@ -1022,7 +1022,7 @@ static const struct net_device_ops lance_netdev_ops = { | |||
| 1022 | .ndo_set_mac_address = eth_mac_addr, | 1022 | .ndo_set_mac_address = eth_mac_addr, |
| 1023 | }; | 1023 | }; |
| 1024 | 1024 | ||
| 1025 | static int __init dec_lance_probe(struct device *bdev, const int type) | 1025 | static int __devinit dec_lance_probe(struct device *bdev, const int type) |
| 1026 | { | 1026 | { |
| 1027 | static unsigned version_printed; | 1027 | static unsigned version_printed; |
| 1028 | static const char fmt[] = "declance%d"; | 1028 | static const char fmt[] = "declance%d"; |
| @@ -1326,7 +1326,7 @@ static void __exit dec_lance_platform_remove(void) | |||
| 1326 | } | 1326 | } |
| 1327 | 1327 | ||
| 1328 | #ifdef CONFIG_TC | 1328 | #ifdef CONFIG_TC |
| 1329 | static int __init dec_lance_tc_probe(struct device *dev); | 1329 | static int __devinit dec_lance_tc_probe(struct device *dev); |
| 1330 | static int __exit dec_lance_tc_remove(struct device *dev); | 1330 | static int __exit dec_lance_tc_remove(struct device *dev); |
| 1331 | 1331 | ||
| 1332 | static const struct tc_device_id dec_lance_tc_table[] = { | 1332 | static const struct tc_device_id dec_lance_tc_table[] = { |
| @@ -1345,7 +1345,7 @@ static struct tc_driver dec_lance_tc_driver = { | |||
| 1345 | }, | 1345 | }, |
| 1346 | }; | 1346 | }; |
| 1347 | 1347 | ||
| 1348 | static int __init dec_lance_tc_probe(struct device *dev) | 1348 | static int __devinit dec_lance_tc_probe(struct device *dev) |
| 1349 | { | 1349 | { |
| 1350 | int status = dec_lance_probe(dev, PMAD_LANCE); | 1350 | int status = dec_lance_probe(dev, PMAD_LANCE); |
| 1351 | if (!status) | 1351 | if (!status) |
diff --git a/drivers/net/igb/igb_main.c b/drivers/net/igb/igb_main.c index 3881918f5382..cea37e0837ff 100644 --- a/drivers/net/igb/igb_main.c +++ b/drivers/net/igb/igb_main.c | |||
| @@ -1722,6 +1722,15 @@ static int __devinit igb_probe(struct pci_dev *pdev, | |||
| 1722 | u16 eeprom_apme_mask = IGB_EEPROM_APME; | 1722 | u16 eeprom_apme_mask = IGB_EEPROM_APME; |
| 1723 | u32 part_num; | 1723 | u32 part_num; |
| 1724 | 1724 | ||
| 1725 | /* Catch broken hardware that put the wrong VF device ID in | ||
| 1726 | * the PCIe SR-IOV capability. | ||
| 1727 | */ | ||
| 1728 | if (pdev->is_virtfn) { | ||
| 1729 | WARN(1, KERN_ERR "%s (%hx:%hx) should not be a VF!\n", | ||
| 1730 | pci_name(pdev), pdev->vendor, pdev->device); | ||
| 1731 | return -EINVAL; | ||
| 1732 | } | ||
| 1733 | |||
| 1725 | err = pci_enable_device_mem(pdev); | 1734 | err = pci_enable_device_mem(pdev); |
| 1726 | if (err) | 1735 | if (err) |
| 1727 | return err; | 1736 | return err; |
diff --git a/drivers/net/ixgbe/ixgbe_main.c b/drivers/net/ixgbe/ixgbe_main.c index 7b5d9764f317..74d9b6df3029 100644 --- a/drivers/net/ixgbe/ixgbe_main.c +++ b/drivers/net/ixgbe/ixgbe_main.c | |||
| @@ -6492,6 +6492,15 @@ static int __devinit ixgbe_probe(struct pci_dev *pdev, | |||
| 6492 | #endif | 6492 | #endif |
| 6493 | u32 part_num, eec; | 6493 | u32 part_num, eec; |
| 6494 | 6494 | ||
| 6495 | /* Catch broken hardware that put the wrong VF device ID in | ||
| 6496 | * the PCIe SR-IOV capability. | ||
| 6497 | */ | ||
| 6498 | if (pdev->is_virtfn) { | ||
| 6499 | WARN(1, KERN_ERR "%s (%hx:%hx) should not be a VF!\n", | ||
| 6500 | pci_name(pdev), pdev->vendor, pdev->device); | ||
| 6501 | return -EINVAL; | ||
| 6502 | } | ||
| 6503 | |||
| 6495 | err = pci_enable_device_mem(pdev); | 6504 | err = pci_enable_device_mem(pdev); |
| 6496 | if (err) | 6505 | if (err) |
| 6497 | return err; | 6506 | return err; |
diff --git a/drivers/net/macvlan.c b/drivers/net/macvlan.c index 87e8d4cb4057..f15fe2cf72ae 100644 --- a/drivers/net/macvlan.c +++ b/drivers/net/macvlan.c | |||
| @@ -499,7 +499,7 @@ static const struct net_device_ops macvlan_netdev_ops = { | |||
| 499 | .ndo_validate_addr = eth_validate_addr, | 499 | .ndo_validate_addr = eth_validate_addr, |
| 500 | }; | 500 | }; |
| 501 | 501 | ||
| 502 | static void macvlan_setup(struct net_device *dev) | 502 | void macvlan_common_setup(struct net_device *dev) |
| 503 | { | 503 | { |
| 504 | ether_setup(dev); | 504 | ether_setup(dev); |
| 505 | 505 | ||
| @@ -508,6 +508,12 @@ static void macvlan_setup(struct net_device *dev) | |||
| 508 | dev->destructor = free_netdev; | 508 | dev->destructor = free_netdev; |
| 509 | dev->header_ops = &macvlan_hard_header_ops, | 509 | dev->header_ops = &macvlan_hard_header_ops, |
| 510 | dev->ethtool_ops = &macvlan_ethtool_ops; | 510 | dev->ethtool_ops = &macvlan_ethtool_ops; |
| 511 | } | ||
| 512 | EXPORT_SYMBOL_GPL(macvlan_common_setup); | ||
| 513 | |||
| 514 | static void macvlan_setup(struct net_device *dev) | ||
| 515 | { | ||
| 516 | macvlan_common_setup(dev); | ||
| 511 | dev->tx_queue_len = 0; | 517 | dev->tx_queue_len = 0; |
| 512 | } | 518 | } |
| 513 | 519 | ||
| @@ -705,7 +711,6 @@ int macvlan_link_register(struct rtnl_link_ops *ops) | |||
| 705 | /* common fields */ | 711 | /* common fields */ |
| 706 | ops->priv_size = sizeof(struct macvlan_dev); | 712 | ops->priv_size = sizeof(struct macvlan_dev); |
| 707 | ops->get_tx_queues = macvlan_get_tx_queues; | 713 | ops->get_tx_queues = macvlan_get_tx_queues; |
| 708 | ops->setup = macvlan_setup; | ||
| 709 | ops->validate = macvlan_validate; | 714 | ops->validate = macvlan_validate; |
| 710 | ops->maxtype = IFLA_MACVLAN_MAX; | 715 | ops->maxtype = IFLA_MACVLAN_MAX; |
| 711 | ops->policy = macvlan_policy; | 716 | ops->policy = macvlan_policy; |
| @@ -719,6 +724,7 @@ EXPORT_SYMBOL_GPL(macvlan_link_register); | |||
| 719 | 724 | ||
| 720 | static struct rtnl_link_ops macvlan_link_ops = { | 725 | static struct rtnl_link_ops macvlan_link_ops = { |
| 721 | .kind = "macvlan", | 726 | .kind = "macvlan", |
| 727 | .setup = macvlan_setup, | ||
| 722 | .newlink = macvlan_newlink, | 728 | .newlink = macvlan_newlink, |
| 723 | .dellink = macvlan_dellink, | 729 | .dellink = macvlan_dellink, |
| 724 | }; | 730 | }; |
diff --git a/drivers/net/macvtap.c b/drivers/net/macvtap.c index a8a94e2f6ddc..ff02b836c3c4 100644 --- a/drivers/net/macvtap.c +++ b/drivers/net/macvtap.c | |||
| @@ -180,11 +180,18 @@ static int macvtap_forward(struct net_device *dev, struct sk_buff *skb) | |||
| 180 | { | 180 | { |
| 181 | struct macvtap_queue *q = macvtap_get_queue(dev, skb); | 181 | struct macvtap_queue *q = macvtap_get_queue(dev, skb); |
| 182 | if (!q) | 182 | if (!q) |
| 183 | return -ENOLINK; | 183 | goto drop; |
| 184 | |||
| 185 | if (skb_queue_len(&q->sk.sk_receive_queue) >= dev->tx_queue_len) | ||
| 186 | goto drop; | ||
| 184 | 187 | ||
| 185 | skb_queue_tail(&q->sk.sk_receive_queue, skb); | 188 | skb_queue_tail(&q->sk.sk_receive_queue, skb); |
| 186 | wake_up_interruptible_poll(sk_sleep(&q->sk), POLLIN | POLLRDNORM | POLLRDBAND); | 189 | wake_up_interruptible_poll(sk_sleep(&q->sk), POLLIN | POLLRDNORM | POLLRDBAND); |
| 187 | return 0; | 190 | return NET_RX_SUCCESS; |
| 191 | |||
| 192 | drop: | ||
| 193 | kfree_skb(skb); | ||
| 194 | return NET_RX_DROP; | ||
| 188 | } | 195 | } |
| 189 | 196 | ||
| 190 | /* | 197 | /* |
| @@ -235,8 +242,15 @@ static void macvtap_dellink(struct net_device *dev, | |||
| 235 | macvlan_dellink(dev, head); | 242 | macvlan_dellink(dev, head); |
| 236 | } | 243 | } |
| 237 | 244 | ||
| 245 | static void macvtap_setup(struct net_device *dev) | ||
| 246 | { | ||
| 247 | macvlan_common_setup(dev); | ||
| 248 | dev->tx_queue_len = TUN_READQ_SIZE; | ||
| 249 | } | ||
| 250 | |||
| 238 | static struct rtnl_link_ops macvtap_link_ops __read_mostly = { | 251 | static struct rtnl_link_ops macvtap_link_ops __read_mostly = { |
| 239 | .kind = "macvtap", | 252 | .kind = "macvtap", |
| 253 | .setup = macvtap_setup, | ||
| 240 | .newlink = macvtap_newlink, | 254 | .newlink = macvtap_newlink, |
| 241 | .dellink = macvtap_dellink, | 255 | .dellink = macvtap_dellink, |
| 242 | }; | 256 | }; |
diff --git a/drivers/net/s2io.h b/drivers/net/s2io.h index 5e52c75892df..7f3a53dcc6ef 100644 --- a/drivers/net/s2io.h +++ b/drivers/net/s2io.h | |||
| @@ -65,7 +65,7 @@ static int debug_level = ERR_DBG; | |||
| 65 | 65 | ||
| 66 | /* DEBUG message print. */ | 66 | /* DEBUG message print. */ |
| 67 | #define DBG_PRINT(dbg_level, fmt, args...) do { \ | 67 | #define DBG_PRINT(dbg_level, fmt, args...) do { \ |
| 68 | if (dbg_level >= debug_level) \ | 68 | if (dbg_level <= debug_level) \ |
| 69 | pr_info(fmt, ##args); \ | 69 | pr_info(fmt, ##args); \ |
| 70 | } while (0) | 70 | } while (0) |
| 71 | 71 | ||
diff --git a/drivers/net/tun.c b/drivers/net/tun.c index 6ad6fe706312..63042596f0cf 100644 --- a/drivers/net/tun.c +++ b/drivers/net/tun.c | |||
| @@ -736,8 +736,18 @@ static __inline__ ssize_t tun_put_user(struct tun_struct *tun, | |||
| 736 | gso.gso_type = VIRTIO_NET_HDR_GSO_TCPV6; | 736 | gso.gso_type = VIRTIO_NET_HDR_GSO_TCPV6; |
| 737 | else if (sinfo->gso_type & SKB_GSO_UDP) | 737 | else if (sinfo->gso_type & SKB_GSO_UDP) |
| 738 | gso.gso_type = VIRTIO_NET_HDR_GSO_UDP; | 738 | gso.gso_type = VIRTIO_NET_HDR_GSO_UDP; |
| 739 | else | 739 | else { |
| 740 | BUG(); | 740 | printk(KERN_ERR "tun: unexpected GSO type: " |
| 741 | "0x%x, gso_size %d, hdr_len %d\n", | ||
| 742 | sinfo->gso_type, gso.gso_size, | ||
| 743 | gso.hdr_len); | ||
| 744 | print_hex_dump(KERN_ERR, "tun: ", | ||
| 745 | DUMP_PREFIX_NONE, | ||
| 746 | 16, 1, skb->head, | ||
| 747 | min((int)gso.hdr_len, 64), true); | ||
| 748 | WARN_ON_ONCE(1); | ||
| 749 | return -EINVAL; | ||
| 750 | } | ||
| 741 | if (sinfo->gso_type & SKB_GSO_TCP_ECN) | 751 | if (sinfo->gso_type & SKB_GSO_TCP_ECN) |
| 742 | gso.gso_type |= VIRTIO_NET_HDR_GSO_ECN; | 752 | gso.gso_type |= VIRTIO_NET_HDR_GSO_ECN; |
| 743 | } else | 753 | } else |
diff --git a/drivers/net/wimax/i2400m/i2400m-usb.h b/drivers/net/wimax/i2400m/i2400m-usb.h index 2d7c96d7e865..eb80243e22df 100644 --- a/drivers/net/wimax/i2400m/i2400m-usb.h +++ b/drivers/net/wimax/i2400m/i2400m-usb.h | |||
| @@ -152,6 +152,7 @@ enum { | |||
| 152 | /* Device IDs */ | 152 | /* Device IDs */ |
| 153 | USB_DEVICE_ID_I6050 = 0x0186, | 153 | USB_DEVICE_ID_I6050 = 0x0186, |
| 154 | USB_DEVICE_ID_I6050_2 = 0x0188, | 154 | USB_DEVICE_ID_I6050_2 = 0x0188, |
| 155 | USB_DEVICE_ID_I6250 = 0x0187, | ||
| 155 | }; | 156 | }; |
| 156 | 157 | ||
| 157 | 158 | ||
diff --git a/drivers/net/wimax/i2400m/usb.c b/drivers/net/wimax/i2400m/usb.c index 0d5081d77dc0..d3365ac85dde 100644 --- a/drivers/net/wimax/i2400m/usb.c +++ b/drivers/net/wimax/i2400m/usb.c | |||
| @@ -491,6 +491,7 @@ int i2400mu_probe(struct usb_interface *iface, | |||
| 491 | switch (id->idProduct) { | 491 | switch (id->idProduct) { |
| 492 | case USB_DEVICE_ID_I6050: | 492 | case USB_DEVICE_ID_I6050: |
| 493 | case USB_DEVICE_ID_I6050_2: | 493 | case USB_DEVICE_ID_I6050_2: |
| 494 | case USB_DEVICE_ID_I6250: | ||
| 494 | i2400mu->i6050 = 1; | 495 | i2400mu->i6050 = 1; |
| 495 | break; | 496 | break; |
| 496 | default: | 497 | default: |
| @@ -739,6 +740,7 @@ static | |||
| 739 | struct usb_device_id i2400mu_id_table[] = { | 740 | struct usb_device_id i2400mu_id_table[] = { |
| 740 | { USB_DEVICE(0x8086, USB_DEVICE_ID_I6050) }, | 741 | { USB_DEVICE(0x8086, USB_DEVICE_ID_I6050) }, |
| 741 | { USB_DEVICE(0x8086, USB_DEVICE_ID_I6050_2) }, | 742 | { USB_DEVICE(0x8086, USB_DEVICE_ID_I6050_2) }, |
| 743 | { USB_DEVICE(0x8086, USB_DEVICE_ID_I6250) }, | ||
| 742 | { USB_DEVICE(0x8086, 0x0181) }, | 744 | { USB_DEVICE(0x8086, 0x0181) }, |
| 743 | { USB_DEVICE(0x8086, 0x1403) }, | 745 | { USB_DEVICE(0x8086, 0x1403) }, |
| 744 | { USB_DEVICE(0x8086, 0x1405) }, | 746 | { USB_DEVICE(0x8086, 0x1405) }, |
diff --git a/drivers/net/wireless/ath/ath9k/recv.c b/drivers/net/wireless/ath/ath9k/recv.c index ca6065b71b46..e3e52913d83a 100644 --- a/drivers/net/wireless/ath/ath9k/recv.c +++ b/drivers/net/wireless/ath/ath9k/recv.c | |||
| @@ -844,9 +844,9 @@ int ath_rx_tasklet(struct ath_softc *sc, int flush, bool hp) | |||
| 844 | int dma_type; | 844 | int dma_type; |
| 845 | 845 | ||
| 846 | if (edma) | 846 | if (edma) |
| 847 | dma_type = DMA_FROM_DEVICE; | ||
| 848 | else | ||
| 849 | dma_type = DMA_BIDIRECTIONAL; | 847 | dma_type = DMA_BIDIRECTIONAL; |
| 848 | else | ||
| 849 | dma_type = DMA_FROM_DEVICE; | ||
| 850 | 850 | ||
| 851 | qtype = hp ? ATH9K_RX_QUEUE_HP : ATH9K_RX_QUEUE_LP; | 851 | qtype = hp ? ATH9K_RX_QUEUE_HP : ATH9K_RX_QUEUE_LP; |
| 852 | spin_lock_bh(&sc->rx.rxbuflock); | 852 | spin_lock_bh(&sc->rx.rxbuflock); |
diff --git a/drivers/pcmcia/pxa2xx_base.c b/drivers/pcmcia/pxa2xx_base.c index df4532e91b1a..f370476d5417 100644 --- a/drivers/pcmcia/pxa2xx_base.c +++ b/drivers/pcmcia/pxa2xx_base.c | |||
| @@ -178,7 +178,6 @@ pxa2xx_pcmcia_frequency_change(struct soc_pcmcia_socket *skt, | |||
| 178 | unsigned long val, | 178 | unsigned long val, |
| 179 | struct cpufreq_freqs *freqs) | 179 | struct cpufreq_freqs *freqs) |
| 180 | { | 180 | { |
| 181 | #warning "it's not clear if this is right since the core CPU (N) clock has no effect on the memory (L) clock" | ||
| 182 | switch (val) { | 181 | switch (val) { |
| 183 | case CPUFREQ_PRECHANGE: | 182 | case CPUFREQ_PRECHANGE: |
| 184 | if (freqs->new > freqs->old) { | 183 | if (freqs->new > freqs->old) { |
| @@ -186,7 +185,7 @@ pxa2xx_pcmcia_frequency_change(struct soc_pcmcia_socket *skt, | |||
| 186 | "pre-updating\n", | 185 | "pre-updating\n", |
| 187 | freqs->new / 1000, (freqs->new / 100) % 10, | 186 | freqs->new / 1000, (freqs->new / 100) % 10, |
| 188 | freqs->old / 1000, (freqs->old / 100) % 10); | 187 | freqs->old / 1000, (freqs->old / 100) % 10); |
| 189 | pxa2xx_pcmcia_set_mcxx(skt, freqs->new); | 188 | pxa2xx_pcmcia_set_timing(skt); |
| 190 | } | 189 | } |
| 191 | break; | 190 | break; |
| 192 | 191 | ||
| @@ -196,7 +195,7 @@ pxa2xx_pcmcia_frequency_change(struct soc_pcmcia_socket *skt, | |||
| 196 | "post-updating\n", | 195 | "post-updating\n", |
| 197 | freqs->new / 1000, (freqs->new / 100) % 10, | 196 | freqs->new / 1000, (freqs->new / 100) % 10, |
| 198 | freqs->old / 1000, (freqs->old / 100) % 10); | 197 | freqs->old / 1000, (freqs->old / 100) % 10); |
| 199 | pxa2xx_pcmcia_set_mcxx(skt, freqs->new); | 198 | pxa2xx_pcmcia_set_timing(skt); |
| 200 | } | 199 | } |
| 201 | break; | 200 | break; |
| 202 | } | 201 | } |
diff --git a/drivers/power/ds2782_battery.c b/drivers/power/ds2782_battery.c index 2afbeec8b791..84d3c43cf2bc 100644 --- a/drivers/power/ds2782_battery.c +++ b/drivers/power/ds2782_battery.c | |||
| @@ -43,10 +43,9 @@ | |||
| 43 | struct ds278x_info; | 43 | struct ds278x_info; |
| 44 | 44 | ||
| 45 | struct ds278x_battery_ops { | 45 | struct ds278x_battery_ops { |
| 46 | int (*get_current)(struct ds278x_info *info, int *current_uA); | 46 | int (*get_battery_current)(struct ds278x_info *info, int *current_uA); |
| 47 | int (*get_voltage)(struct ds278x_info *info, int *voltage_uA); | 47 | int (*get_battery_voltage)(struct ds278x_info *info, int *voltage_uA); |
| 48 | int (*get_capacity)(struct ds278x_info *info, int *capacity_uA); | 48 | int (*get_battery_capacity)(struct ds278x_info *info, int *capacity_uA); |
| 49 | |||
| 50 | }; | 49 | }; |
| 51 | 50 | ||
| 52 | #define to_ds278x_info(x) container_of(x, struct ds278x_info, battery) | 51 | #define to_ds278x_info(x) container_of(x, struct ds278x_info, battery) |
| @@ -213,11 +212,11 @@ static int ds278x_get_status(struct ds278x_info *info, int *status) | |||
| 213 | int current_uA; | 212 | int current_uA; |
| 214 | int capacity; | 213 | int capacity; |
| 215 | 214 | ||
| 216 | err = info->ops->get_current(info, ¤t_uA); | 215 | err = info->ops->get_battery_current(info, ¤t_uA); |
| 217 | if (err) | 216 | if (err) |
| 218 | return err; | 217 | return err; |
| 219 | 218 | ||
| 220 | err = info->ops->get_capacity(info, &capacity); | 219 | err = info->ops->get_battery_capacity(info, &capacity); |
| 221 | if (err) | 220 | if (err) |
| 222 | return err; | 221 | return err; |
| 223 | 222 | ||
| @@ -246,15 +245,15 @@ static int ds278x_battery_get_property(struct power_supply *psy, | |||
| 246 | break; | 245 | break; |
| 247 | 246 | ||
| 248 | case POWER_SUPPLY_PROP_CAPACITY: | 247 | case POWER_SUPPLY_PROP_CAPACITY: |
| 249 | ret = info->ops->get_capacity(info, &val->intval); | 248 | ret = info->ops->get_battery_capacity(info, &val->intval); |
| 250 | break; | 249 | break; |
| 251 | 250 | ||
| 252 | case POWER_SUPPLY_PROP_VOLTAGE_NOW: | 251 | case POWER_SUPPLY_PROP_VOLTAGE_NOW: |
| 253 | ret = info->ops->get_voltage(info, &val->intval); | 252 | ret = info->ops->get_battery_voltage(info, &val->intval); |
| 254 | break; | 253 | break; |
| 255 | 254 | ||
| 256 | case POWER_SUPPLY_PROP_CURRENT_NOW: | 255 | case POWER_SUPPLY_PROP_CURRENT_NOW: |
| 257 | ret = info->ops->get_current(info, &val->intval); | 256 | ret = info->ops->get_battery_current(info, &val->intval); |
| 258 | break; | 257 | break; |
| 259 | 258 | ||
| 260 | case POWER_SUPPLY_PROP_TEMP: | 259 | case POWER_SUPPLY_PROP_TEMP: |
| @@ -307,14 +306,14 @@ enum ds278x_num_id { | |||
| 307 | 306 | ||
| 308 | static struct ds278x_battery_ops ds278x_ops[] = { | 307 | static struct ds278x_battery_ops ds278x_ops[] = { |
| 309 | [DS2782] = { | 308 | [DS2782] = { |
| 310 | .get_current = ds2782_get_current, | 309 | .get_battery_current = ds2782_get_current, |
| 311 | .get_voltage = ds2782_get_voltage, | 310 | .get_battery_voltage = ds2782_get_voltage, |
| 312 | .get_capacity = ds2782_get_capacity, | 311 | .get_battery_capacity = ds2782_get_capacity, |
| 313 | }, | 312 | }, |
| 314 | [DS2786] = { | 313 | [DS2786] = { |
| 315 | .get_current = ds2786_get_current, | 314 | .get_battery_current = ds2786_get_current, |
| 316 | .get_voltage = ds2786_get_voltage, | 315 | .get_battery_voltage = ds2786_get_voltage, |
| 317 | .get_capacity = ds2786_get_capacity, | 316 | .get_battery_capacity = ds2786_get_capacity, |
| 318 | } | 317 | } |
| 319 | }; | 318 | }; |
| 320 | 319 | ||
diff --git a/drivers/regulator/ab3100.c b/drivers/regulator/ab3100.c index 7b14a67bdca2..11790990277a 100644 --- a/drivers/regulator/ab3100.c +++ b/drivers/regulator/ab3100.c | |||
| @@ -286,7 +286,7 @@ static int ab3100_list_voltage_regulator(struct regulator_dev *reg, | |||
| 286 | { | 286 | { |
| 287 | struct ab3100_regulator *abreg = reg->reg_data; | 287 | struct ab3100_regulator *abreg = reg->reg_data; |
| 288 | 288 | ||
| 289 | if (selector > abreg->voltages_len) | 289 | if (selector >= abreg->voltages_len) |
| 290 | return -EINVAL; | 290 | return -EINVAL; |
| 291 | return abreg->typ_voltages[selector]; | 291 | return abreg->typ_voltages[selector]; |
| 292 | } | 292 | } |
| @@ -318,7 +318,7 @@ static int ab3100_get_voltage_regulator(struct regulator_dev *reg) | |||
| 318 | regval &= 0xE0; | 318 | regval &= 0xE0; |
| 319 | regval >>= 5; | 319 | regval >>= 5; |
| 320 | 320 | ||
| 321 | if (regval > abreg->voltages_len) { | 321 | if (regval >= abreg->voltages_len) { |
| 322 | dev_err(®->dev, | 322 | dev_err(®->dev, |
| 323 | "regulator register %02x contains an illegal voltage setting\n", | 323 | "regulator register %02x contains an illegal voltage setting\n", |
| 324 | abreg->regreg); | 324 | abreg->regreg); |
diff --git a/drivers/regulator/tps6507x-regulator.c b/drivers/regulator/tps6507x-regulator.c index 14b4576281c5..8152d65220f5 100644 --- a/drivers/regulator/tps6507x-regulator.c +++ b/drivers/regulator/tps6507x-regulator.c | |||
| @@ -22,6 +22,7 @@ | |||
| 22 | #include <linux/platform_device.h> | 22 | #include <linux/platform_device.h> |
| 23 | #include <linux/regulator/driver.h> | 23 | #include <linux/regulator/driver.h> |
| 24 | #include <linux/regulator/machine.h> | 24 | #include <linux/regulator/machine.h> |
| 25 | #include <linux/regulator/tps6507x.h> | ||
| 25 | #include <linux/delay.h> | 26 | #include <linux/delay.h> |
| 26 | #include <linux/slab.h> | 27 | #include <linux/slab.h> |
| 27 | #include <linux/mfd/tps6507x.h> | 28 | #include <linux/mfd/tps6507x.h> |
| @@ -101,9 +102,12 @@ struct tps_info { | |||
| 101 | unsigned max_uV; | 102 | unsigned max_uV; |
| 102 | u8 table_len; | 103 | u8 table_len; |
| 103 | const u16 *table; | 104 | const u16 *table; |
| 105 | |||
| 106 | /* Does DCDC high or the low register defines output voltage? */ | ||
| 107 | bool defdcdc_default; | ||
| 104 | }; | 108 | }; |
| 105 | 109 | ||
| 106 | static const struct tps_info tps6507x_pmic_regs[] = { | 110 | static struct tps_info tps6507x_pmic_regs[] = { |
| 107 | { | 111 | { |
| 108 | .name = "VDCDC1", | 112 | .name = "VDCDC1", |
| 109 | .min_uV = 725000, | 113 | .min_uV = 725000, |
| @@ -145,7 +149,7 @@ struct tps6507x_pmic { | |||
| 145 | struct regulator_desc desc[TPS6507X_NUM_REGULATOR]; | 149 | struct regulator_desc desc[TPS6507X_NUM_REGULATOR]; |
| 146 | struct tps6507x_dev *mfd; | 150 | struct tps6507x_dev *mfd; |
| 147 | struct regulator_dev *rdev[TPS6507X_NUM_REGULATOR]; | 151 | struct regulator_dev *rdev[TPS6507X_NUM_REGULATOR]; |
| 148 | const struct tps_info *info[TPS6507X_NUM_REGULATOR]; | 152 | struct tps_info *info[TPS6507X_NUM_REGULATOR]; |
| 149 | struct mutex io_lock; | 153 | struct mutex io_lock; |
| 150 | }; | 154 | }; |
| 151 | static inline int tps6507x_pmic_read(struct tps6507x_pmic *tps, u8 reg) | 155 | static inline int tps6507x_pmic_read(struct tps6507x_pmic *tps, u8 reg) |
| @@ -341,10 +345,16 @@ static int tps6507x_pmic_dcdc_get_voltage(struct regulator_dev *dev) | |||
| 341 | reg = TPS6507X_REG_DEFDCDC1; | 345 | reg = TPS6507X_REG_DEFDCDC1; |
| 342 | break; | 346 | break; |
| 343 | case TPS6507X_DCDC_2: | 347 | case TPS6507X_DCDC_2: |
| 344 | reg = TPS6507X_REG_DEFDCDC2_LOW; | 348 | if (tps->info[dcdc]->defdcdc_default) |
| 349 | reg = TPS6507X_REG_DEFDCDC2_HIGH; | ||
| 350 | else | ||
| 351 | reg = TPS6507X_REG_DEFDCDC2_LOW; | ||
| 345 | break; | 352 | break; |
| 346 | case TPS6507X_DCDC_3: | 353 | case TPS6507X_DCDC_3: |
| 347 | reg = TPS6507X_REG_DEFDCDC3_LOW; | 354 | if (tps->info[dcdc]->defdcdc_default) |
| 355 | reg = TPS6507X_REG_DEFDCDC3_HIGH; | ||
| 356 | else | ||
| 357 | reg = TPS6507X_REG_DEFDCDC3_LOW; | ||
| 348 | break; | 358 | break; |
| 349 | default: | 359 | default: |
| 350 | return -EINVAL; | 360 | return -EINVAL; |
| @@ -370,10 +380,16 @@ static int tps6507x_pmic_dcdc_set_voltage(struct regulator_dev *dev, | |||
| 370 | reg = TPS6507X_REG_DEFDCDC1; | 380 | reg = TPS6507X_REG_DEFDCDC1; |
| 371 | break; | 381 | break; |
| 372 | case TPS6507X_DCDC_2: | 382 | case TPS6507X_DCDC_2: |
| 373 | reg = TPS6507X_REG_DEFDCDC2_LOW; | 383 | if (tps->info[dcdc]->defdcdc_default) |
| 384 | reg = TPS6507X_REG_DEFDCDC2_HIGH; | ||
| 385 | else | ||
| 386 | reg = TPS6507X_REG_DEFDCDC2_LOW; | ||
| 374 | break; | 387 | break; |
| 375 | case TPS6507X_DCDC_3: | 388 | case TPS6507X_DCDC_3: |
| 376 | reg = TPS6507X_REG_DEFDCDC3_LOW; | 389 | if (tps->info[dcdc]->defdcdc_default) |
| 390 | reg = TPS6507X_REG_DEFDCDC3_HIGH; | ||
| 391 | else | ||
| 392 | reg = TPS6507X_REG_DEFDCDC3_LOW; | ||
| 377 | break; | 393 | break; |
| 378 | default: | 394 | default: |
| 379 | return -EINVAL; | 395 | return -EINVAL; |
| @@ -532,7 +548,7 @@ int tps6507x_pmic_probe(struct platform_device *pdev) | |||
| 532 | { | 548 | { |
| 533 | struct tps6507x_dev *tps6507x_dev = dev_get_drvdata(pdev->dev.parent); | 549 | struct tps6507x_dev *tps6507x_dev = dev_get_drvdata(pdev->dev.parent); |
| 534 | static int desc_id; | 550 | static int desc_id; |
| 535 | const struct tps_info *info = &tps6507x_pmic_regs[0]; | 551 | struct tps_info *info = &tps6507x_pmic_regs[0]; |
| 536 | struct regulator_init_data *init_data; | 552 | struct regulator_init_data *init_data; |
| 537 | struct regulator_dev *rdev; | 553 | struct regulator_dev *rdev; |
| 538 | struct tps6507x_pmic *tps; | 554 | struct tps6507x_pmic *tps; |
| @@ -569,6 +585,12 @@ int tps6507x_pmic_probe(struct platform_device *pdev) | |||
| 569 | for (i = 0; i < TPS6507X_NUM_REGULATOR; i++, info++, init_data++) { | 585 | for (i = 0; i < TPS6507X_NUM_REGULATOR; i++, info++, init_data++) { |
| 570 | /* Register the regulators */ | 586 | /* Register the regulators */ |
| 571 | tps->info[i] = info; | 587 | tps->info[i] = info; |
| 588 | if (init_data->driver_data) { | ||
| 589 | struct tps6507x_reg_platform_data *data = | ||
| 590 | init_data->driver_data; | ||
| 591 | tps->info[i]->defdcdc_default = data->defdcdc_default; | ||
| 592 | } | ||
| 593 | |||
| 572 | tps->desc[i].name = info->name; | 594 | tps->desc[i].name = info->name; |
| 573 | tps->desc[i].id = desc_id++; | 595 | tps->desc[i].id = desc_id++; |
| 574 | tps->desc[i].n_voltages = num_voltages[i]; | 596 | tps->desc[i].n_voltages = num_voltages[i]; |
diff --git a/drivers/regulator/wm8350-regulator.c b/drivers/regulator/wm8350-regulator.c index 723cd1fb4867..0e6ed7db9364 100644 --- a/drivers/regulator/wm8350-regulator.c +++ b/drivers/regulator/wm8350-regulator.c | |||
| @@ -1495,7 +1495,7 @@ int wm8350_register_regulator(struct wm8350 *wm8350, int reg, | |||
| 1495 | if (ret != 0) { | 1495 | if (ret != 0) { |
| 1496 | dev_err(wm8350->dev, "Failed to register regulator %d: %d\n", | 1496 | dev_err(wm8350->dev, "Failed to register regulator %d: %d\n", |
| 1497 | reg, ret); | 1497 | reg, ret); |
| 1498 | platform_device_del(pdev); | 1498 | platform_device_put(pdev); |
| 1499 | wm8350->pmic.pdev[reg] = NULL; | 1499 | wm8350->pmic.pdev[reg] = NULL; |
| 1500 | } | 1500 | } |
| 1501 | 1501 | ||
diff --git a/drivers/rtc/rtc-rx8581.c b/drivers/rtc/rtc-rx8581.c index 9718aaaa8215..600b890a3c15 100644 --- a/drivers/rtc/rtc-rx8581.c +++ b/drivers/rtc/rtc-rx8581.c | |||
| @@ -168,7 +168,7 @@ static int rx8581_set_datetime(struct i2c_client *client, struct rtc_time *tm) | |||
| 168 | return -EIO; | 168 | return -EIO; |
| 169 | } | 169 | } |
| 170 | 170 | ||
| 171 | err = i2c_smbus_write_byte_data(client, RX8581_REG_FLAG, | 171 | err = i2c_smbus_write_byte_data(client, RX8581_REG_CTRL, |
| 172 | (data | RX8581_CTRL_STOP)); | 172 | (data | RX8581_CTRL_STOP)); |
| 173 | if (err < 0) { | 173 | if (err < 0) { |
| 174 | dev_err(&client->dev, "Unable to write control register\n"); | 174 | dev_err(&client->dev, "Unable to write control register\n"); |
| @@ -182,6 +182,20 @@ static int rx8581_set_datetime(struct i2c_client *client, struct rtc_time *tm) | |||
| 182 | return -EIO; | 182 | return -EIO; |
| 183 | } | 183 | } |
| 184 | 184 | ||
| 185 | /* get VLF and clear it */ | ||
| 186 | data = i2c_smbus_read_byte_data(client, RX8581_REG_FLAG); | ||
| 187 | if (data < 0) { | ||
| 188 | dev_err(&client->dev, "Unable to read flag register\n"); | ||
| 189 | return -EIO; | ||
| 190 | } | ||
| 191 | |||
| 192 | err = i2c_smbus_write_byte_data(client, RX8581_REG_FLAG, | ||
| 193 | (data & ~(RX8581_FLAG_VLF))); | ||
| 194 | if (err != 0) { | ||
| 195 | dev_err(&client->dev, "Unable to write flag register\n"); | ||
| 196 | return -EIO; | ||
| 197 | } | ||
| 198 | |||
| 185 | /* Restart the clock */ | 199 | /* Restart the clock */ |
| 186 | data = i2c_smbus_read_byte_data(client, RX8581_REG_CTRL); | 200 | data = i2c_smbus_read_byte_data(client, RX8581_REG_CTRL); |
| 187 | if (data < 0) { | 201 | if (data < 0) { |
| @@ -189,8 +203,8 @@ static int rx8581_set_datetime(struct i2c_client *client, struct rtc_time *tm) | |||
| 189 | return -EIO; | 203 | return -EIO; |
| 190 | } | 204 | } |
| 191 | 205 | ||
| 192 | err = i2c_smbus_write_byte_data(client, RX8581_REG_FLAG, | 206 | err = i2c_smbus_write_byte_data(client, RX8581_REG_CTRL, |
| 193 | (data | ~(RX8581_CTRL_STOP))); | 207 | (data & ~(RX8581_CTRL_STOP))); |
| 194 | if (err != 0) { | 208 | if (err != 0) { |
| 195 | dev_err(&client->dev, "Unable to write control register\n"); | 209 | dev_err(&client->dev, "Unable to write control register\n"); |
| 196 | return -EIO; | 210 | return -EIO; |
diff --git a/drivers/s390/scsi/zfcp_erp.c b/drivers/s390/scsi/zfcp_erp.c index e3dbeda97179..fd068bc1bd0a 100644 --- a/drivers/s390/scsi/zfcp_erp.c +++ b/drivers/s390/scsi/zfcp_erp.c | |||
| @@ -714,6 +714,14 @@ static int zfcp_erp_adapter_strategy_open_fsf(struct zfcp_erp_action *act) | |||
| 714 | if (zfcp_erp_adapter_strategy_open_fsf_xport(act) == ZFCP_ERP_FAILED) | 714 | if (zfcp_erp_adapter_strategy_open_fsf_xport(act) == ZFCP_ERP_FAILED) |
| 715 | return ZFCP_ERP_FAILED; | 715 | return ZFCP_ERP_FAILED; |
| 716 | 716 | ||
| 717 | if (mempool_resize(act->adapter->pool.status_read_data, | ||
| 718 | act->adapter->stat_read_buf_num, GFP_KERNEL)) | ||
| 719 | return ZFCP_ERP_FAILED; | ||
| 720 | |||
| 721 | if (mempool_resize(act->adapter->pool.status_read_req, | ||
| 722 | act->adapter->stat_read_buf_num, GFP_KERNEL)) | ||
| 723 | return ZFCP_ERP_FAILED; | ||
| 724 | |||
| 717 | atomic_set(&act->adapter->stat_miss, act->adapter->stat_read_buf_num); | 725 | atomic_set(&act->adapter->stat_miss, act->adapter->stat_read_buf_num); |
| 718 | if (zfcp_status_read_refill(act->adapter)) | 726 | if (zfcp_status_read_refill(act->adapter)) |
| 719 | return ZFCP_ERP_FAILED; | 727 | return ZFCP_ERP_FAILED; |
diff --git a/drivers/s390/scsi/zfcp_fsf.c b/drivers/s390/scsi/zfcp_fsf.c index 9ac6a6e4a604..71663fb77310 100644 --- a/drivers/s390/scsi/zfcp_fsf.c +++ b/drivers/s390/scsi/zfcp_fsf.c | |||
| @@ -496,7 +496,8 @@ static int zfcp_fsf_exchange_config_evaluate(struct zfcp_fsf_req *req) | |||
| 496 | 496 | ||
| 497 | adapter->hydra_version = bottom->adapter_type; | 497 | adapter->hydra_version = bottom->adapter_type; |
| 498 | adapter->timer_ticks = bottom->timer_interval; | 498 | adapter->timer_ticks = bottom->timer_interval; |
| 499 | adapter->stat_read_buf_num = max(bottom->status_read_buf_num, (u16)16); | 499 | adapter->stat_read_buf_num = max(bottom->status_read_buf_num, |
| 500 | (u16)FSF_STATUS_READS_RECOM); | ||
| 500 | 501 | ||
| 501 | if (fc_host_permanent_port_name(shost) == -1) | 502 | if (fc_host_permanent_port_name(shost) == -1) |
| 502 | fc_host_permanent_port_name(shost) = fc_host_port_name(shost); | 503 | fc_host_permanent_port_name(shost) = fc_host_port_name(shost); |
| @@ -719,11 +720,6 @@ static struct zfcp_fsf_req *zfcp_fsf_req_create(struct zfcp_qdio *qdio, | |||
| 719 | zfcp_qdio_req_init(adapter->qdio, &req->qdio_req, req->req_id, sbtype, | 720 | zfcp_qdio_req_init(adapter->qdio, &req->qdio_req, req->req_id, sbtype, |
| 720 | req->qtcb, sizeof(struct fsf_qtcb)); | 721 | req->qtcb, sizeof(struct fsf_qtcb)); |
| 721 | 722 | ||
| 722 | if (!(atomic_read(&adapter->status) & ZFCP_STATUS_ADAPTER_QDIOUP)) { | ||
| 723 | zfcp_fsf_req_free(req); | ||
| 724 | return ERR_PTR(-EIO); | ||
| 725 | } | ||
| 726 | |||
| 727 | return req; | 723 | return req; |
| 728 | } | 724 | } |
| 729 | 725 | ||
| @@ -981,7 +977,7 @@ static int zfcp_fsf_setup_ct_els_sbals(struct zfcp_fsf_req *req, | |||
| 981 | } | 977 | } |
| 982 | 978 | ||
| 983 | /* use single, unchained SBAL if it can hold the request */ | 979 | /* use single, unchained SBAL if it can hold the request */ |
| 984 | if (zfcp_qdio_sg_one_sbale(sg_req) || zfcp_qdio_sg_one_sbale(sg_resp)) { | 980 | if (zfcp_qdio_sg_one_sbale(sg_req) && zfcp_qdio_sg_one_sbale(sg_resp)) { |
| 985 | zfcp_fsf_setup_ct_els_unchained(adapter->qdio, &req->qdio_req, | 981 | zfcp_fsf_setup_ct_els_unchained(adapter->qdio, &req->qdio_req, |
| 986 | sg_req, sg_resp); | 982 | sg_req, sg_resp); |
| 987 | return 0; | 983 | return 0; |
diff --git a/drivers/s390/scsi/zfcp_qdio.c b/drivers/s390/scsi/zfcp_qdio.c index 28117e130e2c..6fa5e0453176 100644 --- a/drivers/s390/scsi/zfcp_qdio.c +++ b/drivers/s390/scsi/zfcp_qdio.c | |||
| @@ -251,7 +251,8 @@ static int zfcp_qdio_sbal_check(struct zfcp_qdio *qdio) | |||
| 251 | struct zfcp_qdio_queue *req_q = &qdio->req_q; | 251 | struct zfcp_qdio_queue *req_q = &qdio->req_q; |
| 252 | 252 | ||
| 253 | spin_lock_bh(&qdio->req_q_lock); | 253 | spin_lock_bh(&qdio->req_q_lock); |
| 254 | if (atomic_read(&req_q->count)) | 254 | if (atomic_read(&req_q->count) || |
| 255 | !(atomic_read(&qdio->adapter->status) & ZFCP_STATUS_ADAPTER_QDIOUP)) | ||
| 255 | return 1; | 256 | return 1; |
| 256 | spin_unlock_bh(&qdio->req_q_lock); | 257 | spin_unlock_bh(&qdio->req_q_lock); |
| 257 | return 0; | 258 | return 0; |
| @@ -274,8 +275,13 @@ int zfcp_qdio_sbal_get(struct zfcp_qdio *qdio) | |||
| 274 | spin_unlock_bh(&qdio->req_q_lock); | 275 | spin_unlock_bh(&qdio->req_q_lock); |
| 275 | ret = wait_event_interruptible_timeout(qdio->req_q_wq, | 276 | ret = wait_event_interruptible_timeout(qdio->req_q_wq, |
| 276 | zfcp_qdio_sbal_check(qdio), 5 * HZ); | 277 | zfcp_qdio_sbal_check(qdio), 5 * HZ); |
| 278 | |||
| 279 | if (!(atomic_read(&qdio->adapter->status) & ZFCP_STATUS_ADAPTER_QDIOUP)) | ||
| 280 | return -EIO; | ||
| 281 | |||
| 277 | if (ret > 0) | 282 | if (ret > 0) |
| 278 | return 0; | 283 | return 0; |
| 284 | |||
| 279 | if (!ret) { | 285 | if (!ret) { |
| 280 | atomic_inc(&qdio->req_q_full); | 286 | atomic_inc(&qdio->req_q_full); |
| 281 | /* assume hanging outbound queue, try queue recovery */ | 287 | /* assume hanging outbound queue, try queue recovery */ |
| @@ -375,6 +381,8 @@ void zfcp_qdio_close(struct zfcp_qdio *qdio) | |||
| 375 | atomic_clear_mask(ZFCP_STATUS_ADAPTER_QDIOUP, &qdio->adapter->status); | 381 | atomic_clear_mask(ZFCP_STATUS_ADAPTER_QDIOUP, &qdio->adapter->status); |
| 376 | spin_unlock_bh(&qdio->req_q_lock); | 382 | spin_unlock_bh(&qdio->req_q_lock); |
| 377 | 383 | ||
| 384 | wake_up(&qdio->req_q_wq); | ||
| 385 | |||
| 378 | qdio_shutdown(qdio->adapter->ccw_device, | 386 | qdio_shutdown(qdio->adapter->ccw_device, |
| 379 | QDIO_FLAG_CLEANUP_USING_CLEAR); | 387 | QDIO_FLAG_CLEANUP_USING_CLEAR); |
| 380 | 388 | ||
diff --git a/drivers/scsi/ibmvscsi/rpa_vscsi.c b/drivers/scsi/ibmvscsi/rpa_vscsi.c index a864ccc0a342..989b9a8ba72d 100644 --- a/drivers/scsi/ibmvscsi/rpa_vscsi.c +++ b/drivers/scsi/ibmvscsi/rpa_vscsi.c | |||
| @@ -277,6 +277,12 @@ static int rpavscsi_init_crq_queue(struct crq_queue *queue, | |||
| 277 | goto reg_crq_failed; | 277 | goto reg_crq_failed; |
| 278 | } | 278 | } |
| 279 | 279 | ||
| 280 | queue->cur = 0; | ||
| 281 | spin_lock_init(&queue->lock); | ||
| 282 | |||
| 283 | tasklet_init(&hostdata->srp_task, (void *)rpavscsi_task, | ||
| 284 | (unsigned long)hostdata); | ||
| 285 | |||
| 280 | if (request_irq(vdev->irq, | 286 | if (request_irq(vdev->irq, |
| 281 | rpavscsi_handle_event, | 287 | rpavscsi_handle_event, |
| 282 | 0, "ibmvscsi", (void *)hostdata) != 0) { | 288 | 0, "ibmvscsi", (void *)hostdata) != 0) { |
| @@ -291,15 +297,10 @@ static int rpavscsi_init_crq_queue(struct crq_queue *queue, | |||
| 291 | goto req_irq_failed; | 297 | goto req_irq_failed; |
| 292 | } | 298 | } |
| 293 | 299 | ||
| 294 | queue->cur = 0; | ||
| 295 | spin_lock_init(&queue->lock); | ||
| 296 | |||
| 297 | tasklet_init(&hostdata->srp_task, (void *)rpavscsi_task, | ||
| 298 | (unsigned long)hostdata); | ||
| 299 | |||
| 300 | return retrc; | 300 | return retrc; |
| 301 | 301 | ||
| 302 | req_irq_failed: | 302 | req_irq_failed: |
| 303 | tasklet_kill(&hostdata->srp_task); | ||
| 303 | do { | 304 | do { |
| 304 | rc = plpar_hcall_norets(H_FREE_CRQ, vdev->unit_address); | 305 | rc = plpar_hcall_norets(H_FREE_CRQ, vdev->unit_address); |
| 305 | } while ((rc == H_BUSY) || (H_IS_LONG_BUSY(rc))); | 306 | } while ((rc == H_BUSY) || (H_IS_LONG_BUSY(rc))); |
diff --git a/drivers/scsi/ipr.c b/drivers/scsi/ipr.c index 82ea4a8226b0..f820cffb7f00 100644 --- a/drivers/scsi/ipr.c +++ b/drivers/scsi/ipr.c | |||
| @@ -1129,20 +1129,22 @@ static int ipr_is_same_device(struct ipr_resource_entry *res, | |||
| 1129 | } | 1129 | } |
| 1130 | 1130 | ||
| 1131 | /** | 1131 | /** |
| 1132 | * ipr_format_resource_path - Format the resource path for printing. | 1132 | * ipr_format_res_path - Format the resource path for printing. |
| 1133 | * @res_path: resource path | 1133 | * @res_path: resource path |
| 1134 | * @buf: buffer | 1134 | * @buf: buffer |
| 1135 | * | 1135 | * |
| 1136 | * Return value: | 1136 | * Return value: |
| 1137 | * pointer to buffer | 1137 | * pointer to buffer |
| 1138 | **/ | 1138 | **/ |
| 1139 | static char *ipr_format_resource_path(u8 *res_path, char *buffer) | 1139 | static char *ipr_format_res_path(u8 *res_path, char *buffer, int len) |
| 1140 | { | 1140 | { |
| 1141 | int i; | 1141 | int i; |
| 1142 | char *p = buffer; | ||
| 1142 | 1143 | ||
| 1143 | sprintf(buffer, "%02X", res_path[0]); | 1144 | res_path[0] = '\0'; |
| 1144 | for (i=1; res_path[i] != 0xff; i++) | 1145 | p += snprintf(p, buffer + len - p, "%02X", res_path[0]); |
| 1145 | sprintf(buffer, "%s-%02X", buffer, res_path[i]); | 1146 | for (i = 1; res_path[i] != 0xff && ((i * 3) < len); i++) |
| 1147 | p += snprintf(p, buffer + len - p, "-%02X", res_path[i]); | ||
| 1146 | 1148 | ||
| 1147 | return buffer; | 1149 | return buffer; |
| 1148 | } | 1150 | } |
| @@ -1187,7 +1189,8 @@ static void ipr_update_res_entry(struct ipr_resource_entry *res, | |||
| 1187 | 1189 | ||
| 1188 | if (res->sdev && new_path) | 1190 | if (res->sdev && new_path) |
| 1189 | sdev_printk(KERN_INFO, res->sdev, "Resource path: %s\n", | 1191 | sdev_printk(KERN_INFO, res->sdev, "Resource path: %s\n", |
| 1190 | ipr_format_resource_path(&res->res_path[0], &buffer[0])); | 1192 | ipr_format_res_path(res->res_path, buffer, |
| 1193 | sizeof(buffer))); | ||
| 1191 | } else { | 1194 | } else { |
| 1192 | res->flags = cfgtew->u.cfgte->flags; | 1195 | res->flags = cfgtew->u.cfgte->flags; |
| 1193 | if (res->flags & IPR_IS_IOA_RESOURCE) | 1196 | if (res->flags & IPR_IS_IOA_RESOURCE) |
| @@ -1573,7 +1576,8 @@ static void ipr_log_sis64_config_error(struct ipr_ioa_cfg *ioa_cfg, | |||
| 1573 | ipr_err_separator; | 1576 | ipr_err_separator; |
| 1574 | 1577 | ||
| 1575 | ipr_err("Device %d : %s", i + 1, | 1578 | ipr_err("Device %d : %s", i + 1, |
| 1576 | ipr_format_resource_path(&dev_entry->res_path[0], &buffer[0])); | 1579 | ipr_format_res_path(dev_entry->res_path, buffer, |
| 1580 | sizeof(buffer))); | ||
| 1577 | ipr_log_ext_vpd(&dev_entry->vpd); | 1581 | ipr_log_ext_vpd(&dev_entry->vpd); |
| 1578 | 1582 | ||
| 1579 | ipr_err("-----New Device Information-----\n"); | 1583 | ipr_err("-----New Device Information-----\n"); |
| @@ -1919,13 +1923,14 @@ static void ipr_log64_fabric_path(struct ipr_hostrcb *hostrcb, | |||
| 1919 | 1923 | ||
| 1920 | ipr_hcam_err(hostrcb, "%s %s: Resource Path=%s\n", | 1924 | ipr_hcam_err(hostrcb, "%s %s: Resource Path=%s\n", |
| 1921 | path_active_desc[i].desc, path_state_desc[j].desc, | 1925 | path_active_desc[i].desc, path_state_desc[j].desc, |
| 1922 | ipr_format_resource_path(&fabric->res_path[0], &buffer[0])); | 1926 | ipr_format_res_path(fabric->res_path, buffer, |
| 1927 | sizeof(buffer))); | ||
| 1923 | return; | 1928 | return; |
| 1924 | } | 1929 | } |
| 1925 | } | 1930 | } |
| 1926 | 1931 | ||
| 1927 | ipr_err("Path state=%02X Resource Path=%s\n", path_state, | 1932 | ipr_err("Path state=%02X Resource Path=%s\n", path_state, |
| 1928 | ipr_format_resource_path(&fabric->res_path[0], &buffer[0])); | 1933 | ipr_format_res_path(fabric->res_path, buffer, sizeof(buffer))); |
| 1929 | } | 1934 | } |
| 1930 | 1935 | ||
| 1931 | static const struct { | 1936 | static const struct { |
| @@ -2066,7 +2071,8 @@ static void ipr_log64_path_elem(struct ipr_hostrcb *hostrcb, | |||
| 2066 | 2071 | ||
| 2067 | ipr_hcam_err(hostrcb, "%s %s: Resource Path=%s, Link rate=%s, WWN=%08X%08X\n", | 2072 | ipr_hcam_err(hostrcb, "%s %s: Resource Path=%s, Link rate=%s, WWN=%08X%08X\n", |
| 2068 | path_status_desc[j].desc, path_type_desc[i].desc, | 2073 | path_status_desc[j].desc, path_type_desc[i].desc, |
| 2069 | ipr_format_resource_path(&cfg->res_path[0], &buffer[0]), | 2074 | ipr_format_res_path(cfg->res_path, buffer, |
| 2075 | sizeof(buffer)), | ||
| 2070 | link_rate[cfg->link_rate & IPR_PHY_LINK_RATE_MASK], | 2076 | link_rate[cfg->link_rate & IPR_PHY_LINK_RATE_MASK], |
| 2071 | be32_to_cpu(cfg->wwid[0]), be32_to_cpu(cfg->wwid[1])); | 2077 | be32_to_cpu(cfg->wwid[0]), be32_to_cpu(cfg->wwid[1])); |
| 2072 | return; | 2078 | return; |
| @@ -2074,7 +2080,7 @@ static void ipr_log64_path_elem(struct ipr_hostrcb *hostrcb, | |||
| 2074 | } | 2080 | } |
| 2075 | ipr_hcam_err(hostrcb, "Path element=%02X: Resource Path=%s, Link rate=%s " | 2081 | ipr_hcam_err(hostrcb, "Path element=%02X: Resource Path=%s, Link rate=%s " |
| 2076 | "WWN=%08X%08X\n", cfg->type_status, | 2082 | "WWN=%08X%08X\n", cfg->type_status, |
| 2077 | ipr_format_resource_path(&cfg->res_path[0], &buffer[0]), | 2083 | ipr_format_res_path(cfg->res_path, buffer, sizeof(buffer)), |
| 2078 | link_rate[cfg->link_rate & IPR_PHY_LINK_RATE_MASK], | 2084 | link_rate[cfg->link_rate & IPR_PHY_LINK_RATE_MASK], |
| 2079 | be32_to_cpu(cfg->wwid[0]), be32_to_cpu(cfg->wwid[1])); | 2085 | be32_to_cpu(cfg->wwid[0]), be32_to_cpu(cfg->wwid[1])); |
| 2080 | } | 2086 | } |
| @@ -2139,7 +2145,7 @@ static void ipr_log_sis64_array_error(struct ipr_ioa_cfg *ioa_cfg, | |||
| 2139 | 2145 | ||
| 2140 | ipr_err("RAID %s Array Configuration: %s\n", | 2146 | ipr_err("RAID %s Array Configuration: %s\n", |
| 2141 | error->protection_level, | 2147 | error->protection_level, |
| 2142 | ipr_format_resource_path(&error->last_res_path[0], &buffer[0])); | 2148 | ipr_format_res_path(error->last_res_path, buffer, sizeof(buffer))); |
| 2143 | 2149 | ||
| 2144 | ipr_err_separator; | 2150 | ipr_err_separator; |
| 2145 | 2151 | ||
| @@ -2160,9 +2166,11 @@ static void ipr_log_sis64_array_error(struct ipr_ioa_cfg *ioa_cfg, | |||
| 2160 | ipr_err("Array Member %d:\n", i); | 2166 | ipr_err("Array Member %d:\n", i); |
| 2161 | ipr_log_ext_vpd(&array_entry->vpd); | 2167 | ipr_log_ext_vpd(&array_entry->vpd); |
| 2162 | ipr_err("Current Location: %s", | 2168 | ipr_err("Current Location: %s", |
| 2163 | ipr_format_resource_path(&array_entry->res_path[0], &buffer[0])); | 2169 | ipr_format_res_path(array_entry->res_path, buffer, |
| 2170 | sizeof(buffer))); | ||
| 2164 | ipr_err("Expected Location: %s", | 2171 | ipr_err("Expected Location: %s", |
| 2165 | ipr_format_resource_path(&array_entry->expected_res_path[0], &buffer[0])); | 2172 | ipr_format_res_path(array_entry->expected_res_path, |
| 2173 | buffer, sizeof(buffer))); | ||
| 2166 | 2174 | ||
| 2167 | ipr_err_separator; | 2175 | ipr_err_separator; |
| 2168 | } | 2176 | } |
| @@ -4079,7 +4087,8 @@ static struct device_attribute ipr_adapter_handle_attr = { | |||
| 4079 | }; | 4087 | }; |
| 4080 | 4088 | ||
| 4081 | /** | 4089 | /** |
| 4082 | * ipr_show_resource_path - Show the resource path for this device. | 4090 | * ipr_show_resource_path - Show the resource path or the resource address for |
| 4091 | * this device. | ||
| 4083 | * @dev: device struct | 4092 | * @dev: device struct |
| 4084 | * @buf: buffer | 4093 | * @buf: buffer |
| 4085 | * | 4094 | * |
| @@ -4097,9 +4106,14 @@ static ssize_t ipr_show_resource_path(struct device *dev, struct device_attribut | |||
| 4097 | 4106 | ||
| 4098 | spin_lock_irqsave(ioa_cfg->host->host_lock, lock_flags); | 4107 | spin_lock_irqsave(ioa_cfg->host->host_lock, lock_flags); |
| 4099 | res = (struct ipr_resource_entry *)sdev->hostdata; | 4108 | res = (struct ipr_resource_entry *)sdev->hostdata; |
| 4100 | if (res) | 4109 | if (res && ioa_cfg->sis64) |
| 4101 | len = snprintf(buf, PAGE_SIZE, "%s\n", | 4110 | len = snprintf(buf, PAGE_SIZE, "%s\n", |
| 4102 | ipr_format_resource_path(&res->res_path[0], &buffer[0])); | 4111 | ipr_format_res_path(res->res_path, buffer, |
| 4112 | sizeof(buffer))); | ||
| 4113 | else if (res) | ||
| 4114 | len = snprintf(buf, PAGE_SIZE, "%d:%d:%d:%d\n", ioa_cfg->host->host_no, | ||
| 4115 | res->bus, res->target, res->lun); | ||
| 4116 | |||
| 4103 | spin_unlock_irqrestore(ioa_cfg->host->host_lock, lock_flags); | 4117 | spin_unlock_irqrestore(ioa_cfg->host->host_lock, lock_flags); |
| 4104 | return len; | 4118 | return len; |
| 4105 | } | 4119 | } |
| @@ -4351,7 +4365,8 @@ static int ipr_slave_configure(struct scsi_device *sdev) | |||
| 4351 | scsi_adjust_queue_depth(sdev, 0, sdev->host->cmd_per_lun); | 4365 | scsi_adjust_queue_depth(sdev, 0, sdev->host->cmd_per_lun); |
| 4352 | if (ioa_cfg->sis64) | 4366 | if (ioa_cfg->sis64) |
| 4353 | sdev_printk(KERN_INFO, sdev, "Resource path: %s\n", | 4367 | sdev_printk(KERN_INFO, sdev, "Resource path: %s\n", |
| 4354 | ipr_format_resource_path(&res->res_path[0], &buffer[0])); | 4368 | ipr_format_res_path(res->res_path, buffer, |
| 4369 | sizeof(buffer))); | ||
| 4355 | return 0; | 4370 | return 0; |
| 4356 | } | 4371 | } |
| 4357 | spin_unlock_irqrestore(ioa_cfg->host->host_lock, lock_flags); | 4372 | spin_unlock_irqrestore(ioa_cfg->host->host_lock, lock_flags); |
diff --git a/drivers/scsi/ipr.h b/drivers/scsi/ipr.h index 9ecd2259eb39..b965f3587c9d 100644 --- a/drivers/scsi/ipr.h +++ b/drivers/scsi/ipr.h | |||
| @@ -1684,8 +1684,9 @@ struct ipr_ucode_image_header { | |||
| 1684 | if (ipr_is_device(hostrcb)) { \ | 1684 | if (ipr_is_device(hostrcb)) { \ |
| 1685 | if ((hostrcb)->ioa_cfg->sis64) { \ | 1685 | if ((hostrcb)->ioa_cfg->sis64) { \ |
| 1686 | printk(KERN_ERR IPR_NAME ": %s: " fmt, \ | 1686 | printk(KERN_ERR IPR_NAME ": %s: " fmt, \ |
| 1687 | ipr_format_resource_path(&hostrcb->hcam.u.error64.fd_res_path[0], \ | 1687 | ipr_format_res_path(hostrcb->hcam.u.error64.fd_res_path, \ |
| 1688 | &hostrcb->rp_buffer[0]), \ | 1688 | hostrcb->rp_buffer, \ |
| 1689 | sizeof(hostrcb->rp_buffer)), \ | ||
| 1689 | __VA_ARGS__); \ | 1690 | __VA_ARGS__); \ |
| 1690 | } else { \ | 1691 | } else { \ |
| 1691 | ipr_ra_err((hostrcb)->ioa_cfg, \ | 1692 | ipr_ra_err((hostrcb)->ioa_cfg, \ |
diff --git a/drivers/serial/atmel_serial.c b/drivers/serial/atmel_serial.c index eed3c2d8dd1c..a182def7007d 100644 --- a/drivers/serial/atmel_serial.c +++ b/drivers/serial/atmel_serial.c | |||
| @@ -41,6 +41,7 @@ | |||
| 41 | #include <linux/uaccess.h> | 41 | #include <linux/uaccess.h> |
| 42 | 42 | ||
| 43 | #include <asm/io.h> | 43 | #include <asm/io.h> |
| 44 | #include <asm/ioctls.h> | ||
| 44 | 45 | ||
| 45 | #include <asm/mach/serial_at91.h> | 46 | #include <asm/mach/serial_at91.h> |
| 46 | #include <mach/board.h> | 47 | #include <mach/board.h> |
diff --git a/drivers/usb/class/cdc-acm.c b/drivers/usb/class/cdc-acm.c index 61d75507d5d0..162c95a088ed 100644 --- a/drivers/usb/class/cdc-acm.c +++ b/drivers/usb/class/cdc-acm.c | |||
| @@ -1596,6 +1596,7 @@ static const struct usb_device_id acm_ids[] = { | |||
| 1596 | { NOKIA_PCSUITE_ACM_INFO(0x00e9), }, /* Nokia 5320 XpressMusic */ | 1596 | { NOKIA_PCSUITE_ACM_INFO(0x00e9), }, /* Nokia 5320 XpressMusic */ |
| 1597 | { NOKIA_PCSUITE_ACM_INFO(0x0108), }, /* Nokia 5320 XpressMusic 2G */ | 1597 | { NOKIA_PCSUITE_ACM_INFO(0x0108), }, /* Nokia 5320 XpressMusic 2G */ |
| 1598 | { NOKIA_PCSUITE_ACM_INFO(0x01f5), }, /* Nokia N97, RM-505 */ | 1598 | { NOKIA_PCSUITE_ACM_INFO(0x01f5), }, /* Nokia N97, RM-505 */ |
| 1599 | { NOKIA_PCSUITE_ACM_INFO(0x02e3), }, /* Nokia 5230, RM-588 */ | ||
| 1599 | 1600 | ||
| 1600 | /* NOTE: non-Nokia COMM/ACM/0xff is likely MSFT RNDIS... NOT a modem! */ | 1601 | /* NOTE: non-Nokia COMM/ACM/0xff is likely MSFT RNDIS... NOT a modem! */ |
| 1601 | 1602 | ||
diff --git a/drivers/usb/core/hub.c b/drivers/usb/core/hub.c index 83e7bbbe97fa..70cccc75a362 100644 --- a/drivers/usb/core/hub.c +++ b/drivers/usb/core/hub.c | |||
| @@ -1982,6 +1982,8 @@ static int hub_port_wait_reset(struct usb_hub *hub, int port1, | |||
| 1982 | (portstatus & USB_PORT_STAT_ENABLE)) { | 1982 | (portstatus & USB_PORT_STAT_ENABLE)) { |
| 1983 | if (hub_is_wusb(hub)) | 1983 | if (hub_is_wusb(hub)) |
| 1984 | udev->speed = USB_SPEED_WIRELESS; | 1984 | udev->speed = USB_SPEED_WIRELESS; |
| 1985 | else if (portstatus & USB_PORT_STAT_SUPER_SPEED) | ||
| 1986 | udev->speed = USB_SPEED_SUPER; | ||
| 1985 | else if (portstatus & USB_PORT_STAT_HIGH_SPEED) | 1987 | else if (portstatus & USB_PORT_STAT_HIGH_SPEED) |
| 1986 | udev->speed = USB_SPEED_HIGH; | 1988 | udev->speed = USB_SPEED_HIGH; |
| 1987 | else if (portstatus & USB_PORT_STAT_LOW_SPEED) | 1989 | else if (portstatus & USB_PORT_STAT_LOW_SPEED) |
diff --git a/drivers/usb/core/quirks.c b/drivers/usb/core/quirks.c index f22d03df8b17..db99c084df92 100644 --- a/drivers/usb/core/quirks.c +++ b/drivers/usb/core/quirks.c | |||
| @@ -41,6 +41,10 @@ static const struct usb_device_id usb_quirk_list[] = { | |||
| 41 | /* Philips PSC805 audio device */ | 41 | /* Philips PSC805 audio device */ |
| 42 | { USB_DEVICE(0x0471, 0x0155), .driver_info = USB_QUIRK_RESET_RESUME }, | 42 | { USB_DEVICE(0x0471, 0x0155), .driver_info = USB_QUIRK_RESET_RESUME }, |
| 43 | 43 | ||
| 44 | /* Artisman Watchdog Dongle */ | ||
| 45 | { USB_DEVICE(0x04b4, 0x0526), .driver_info = | ||
| 46 | USB_QUIRK_CONFIG_INTF_STRINGS }, | ||
| 47 | |||
| 44 | /* Roland SC-8820 */ | 48 | /* Roland SC-8820 */ |
| 45 | { USB_DEVICE(0x0582, 0x0007), .driver_info = USB_QUIRK_RESET_RESUME }, | 49 | { USB_DEVICE(0x0582, 0x0007), .driver_info = USB_QUIRK_RESET_RESUME }, |
| 46 | 50 | ||
| @@ -64,6 +68,9 @@ static const struct usb_device_id usb_quirk_list[] = { | |||
| 64 | /* X-Rite/Gretag-Macbeth Eye-One Pro display colorimeter */ | 68 | /* X-Rite/Gretag-Macbeth Eye-One Pro display colorimeter */ |
| 65 | { USB_DEVICE(0x0971, 0x2000), .driver_info = USB_QUIRK_NO_SET_INTF }, | 69 | { USB_DEVICE(0x0971, 0x2000), .driver_info = USB_QUIRK_NO_SET_INTF }, |
| 66 | 70 | ||
| 71 | /* Broadcom BCM92035DGROM BT dongle */ | ||
| 72 | { USB_DEVICE(0x0a5c, 0x2021), .driver_info = USB_QUIRK_RESET_RESUME }, | ||
| 73 | |||
| 67 | /* Action Semiconductor flash disk */ | 74 | /* Action Semiconductor flash disk */ |
| 68 | { USB_DEVICE(0x10d6, 0x2200), .driver_info = | 75 | { USB_DEVICE(0x10d6, 0x2200), .driver_info = |
| 69 | USB_QUIRK_STRING_FETCH_255 }, | 76 | USB_QUIRK_STRING_FETCH_255 }, |
diff --git a/drivers/usb/gadget/at91_udc.c b/drivers/usb/gadget/at91_udc.c index eaa79c8a9b8c..93ead19507b6 100644 --- a/drivers/usb/gadget/at91_udc.c +++ b/drivers/usb/gadget/at91_udc.c | |||
| @@ -76,11 +76,12 @@ | |||
| 76 | static const char driver_name [] = "at91_udc"; | 76 | static const char driver_name [] = "at91_udc"; |
| 77 | static const char ep0name[] = "ep0"; | 77 | static const char ep0name[] = "ep0"; |
| 78 | 78 | ||
| 79 | #define VBUS_POLL_TIMEOUT msecs_to_jiffies(1000) | ||
| 79 | 80 | ||
| 80 | #define at91_udp_read(dev, reg) \ | 81 | #define at91_udp_read(udc, reg) \ |
| 81 | __raw_readl((dev)->udp_baseaddr + (reg)) | 82 | __raw_readl((udc)->udp_baseaddr + (reg)) |
| 82 | #define at91_udp_write(dev, reg, val) \ | 83 | #define at91_udp_write(udc, reg, val) \ |
| 83 | __raw_writel((val), (dev)->udp_baseaddr + (reg)) | 84 | __raw_writel((val), (udc)->udp_baseaddr + (reg)) |
| 84 | 85 | ||
| 85 | /*-------------------------------------------------------------------------*/ | 86 | /*-------------------------------------------------------------------------*/ |
| 86 | 87 | ||
| @@ -102,8 +103,9 @@ static void proc_ep_show(struct seq_file *s, struct at91_ep *ep) | |||
| 102 | u32 csr; | 103 | u32 csr; |
| 103 | struct at91_request *req; | 104 | struct at91_request *req; |
| 104 | unsigned long flags; | 105 | unsigned long flags; |
| 106 | struct at91_udc *udc = ep->udc; | ||
| 105 | 107 | ||
| 106 | local_irq_save(flags); | 108 | spin_lock_irqsave(&udc->lock, flags); |
| 107 | 109 | ||
| 108 | csr = __raw_readl(ep->creg); | 110 | csr = __raw_readl(ep->creg); |
| 109 | 111 | ||
| @@ -147,7 +149,7 @@ static void proc_ep_show(struct seq_file *s, struct at91_ep *ep) | |||
| 147 | &req->req, length, | 149 | &req->req, length, |
| 148 | req->req.length, req->req.buf); | 150 | req->req.length, req->req.buf); |
| 149 | } | 151 | } |
| 150 | local_irq_restore(flags); | 152 | spin_unlock_irqrestore(&udc->lock, flags); |
| 151 | } | 153 | } |
| 152 | 154 | ||
| 153 | static void proc_irq_show(struct seq_file *s, const char *label, u32 mask) | 155 | static void proc_irq_show(struct seq_file *s, const char *label, u32 mask) |
| @@ -272,7 +274,9 @@ static void done(struct at91_ep *ep, struct at91_request *req, int status) | |||
| 272 | VDBG("%s done %p, status %d\n", ep->ep.name, req, status); | 274 | VDBG("%s done %p, status %d\n", ep->ep.name, req, status); |
| 273 | 275 | ||
| 274 | ep->stopped = 1; | 276 | ep->stopped = 1; |
| 277 | spin_unlock(&udc->lock); | ||
| 275 | req->req.complete(&ep->ep, &req->req); | 278 | req->req.complete(&ep->ep, &req->req); |
| 279 | spin_lock(&udc->lock); | ||
| 276 | ep->stopped = stopped; | 280 | ep->stopped = stopped; |
| 277 | 281 | ||
| 278 | /* ep0 is always ready; other endpoints need a non-empty queue */ | 282 | /* ep0 is always ready; other endpoints need a non-empty queue */ |
| @@ -472,7 +476,7 @@ static int at91_ep_enable(struct usb_ep *_ep, | |||
| 472 | const struct usb_endpoint_descriptor *desc) | 476 | const struct usb_endpoint_descriptor *desc) |
| 473 | { | 477 | { |
| 474 | struct at91_ep *ep = container_of(_ep, struct at91_ep, ep); | 478 | struct at91_ep *ep = container_of(_ep, struct at91_ep, ep); |
| 475 | struct at91_udc *dev = ep->udc; | 479 | struct at91_udc *udc = ep->udc; |
| 476 | u16 maxpacket; | 480 | u16 maxpacket; |
| 477 | u32 tmp; | 481 | u32 tmp; |
| 478 | unsigned long flags; | 482 | unsigned long flags; |
| @@ -487,7 +491,7 @@ static int at91_ep_enable(struct usb_ep *_ep, | |||
| 487 | return -EINVAL; | 491 | return -EINVAL; |
| 488 | } | 492 | } |
| 489 | 493 | ||
| 490 | if (!dev->driver || dev->gadget.speed == USB_SPEED_UNKNOWN) { | 494 | if (!udc->driver || udc->gadget.speed == USB_SPEED_UNKNOWN) { |
| 491 | DBG("bogus device state\n"); | 495 | DBG("bogus device state\n"); |
| 492 | return -ESHUTDOWN; | 496 | return -ESHUTDOWN; |
| 493 | } | 497 | } |
| @@ -521,7 +525,7 @@ bogus_max: | |||
| 521 | } | 525 | } |
| 522 | 526 | ||
| 523 | ok: | 527 | ok: |
| 524 | local_irq_save(flags); | 528 | spin_lock_irqsave(&udc->lock, flags); |
| 525 | 529 | ||
| 526 | /* initialize endpoint to match this descriptor */ | 530 | /* initialize endpoint to match this descriptor */ |
| 527 | ep->is_in = usb_endpoint_dir_in(desc); | 531 | ep->is_in = usb_endpoint_dir_in(desc); |
| @@ -540,10 +544,10 @@ ok: | |||
| 540 | * reset/init endpoint fifo. NOTE: leaves fifo_bank alone, | 544 | * reset/init endpoint fifo. NOTE: leaves fifo_bank alone, |
| 541 | * since endpoint resets don't reset hw pingpong state. | 545 | * since endpoint resets don't reset hw pingpong state. |
| 542 | */ | 546 | */ |
| 543 | at91_udp_write(dev, AT91_UDP_RST_EP, ep->int_mask); | 547 | at91_udp_write(udc, AT91_UDP_RST_EP, ep->int_mask); |
| 544 | at91_udp_write(dev, AT91_UDP_RST_EP, 0); | 548 | at91_udp_write(udc, AT91_UDP_RST_EP, 0); |
| 545 | 549 | ||
| 546 | local_irq_restore(flags); | 550 | spin_unlock_irqrestore(&udc->lock, flags); |
| 547 | return 0; | 551 | return 0; |
| 548 | } | 552 | } |
| 549 | 553 | ||
| @@ -556,7 +560,7 @@ static int at91_ep_disable (struct usb_ep * _ep) | |||
| 556 | if (ep == &ep->udc->ep[0]) | 560 | if (ep == &ep->udc->ep[0]) |
| 557 | return -EINVAL; | 561 | return -EINVAL; |
| 558 | 562 | ||
| 559 | local_irq_save(flags); | 563 | spin_lock_irqsave(&udc->lock, flags); |
| 560 | 564 | ||
| 561 | nuke(ep, -ESHUTDOWN); | 565 | nuke(ep, -ESHUTDOWN); |
| 562 | 566 | ||
| @@ -571,7 +575,7 @@ static int at91_ep_disable (struct usb_ep * _ep) | |||
| 571 | __raw_writel(0, ep->creg); | 575 | __raw_writel(0, ep->creg); |
| 572 | } | 576 | } |
| 573 | 577 | ||
| 574 | local_irq_restore(flags); | 578 | spin_unlock_irqrestore(&udc->lock, flags); |
| 575 | return 0; | 579 | return 0; |
| 576 | } | 580 | } |
| 577 | 581 | ||
| @@ -607,7 +611,7 @@ static int at91_ep_queue(struct usb_ep *_ep, | |||
| 607 | { | 611 | { |
| 608 | struct at91_request *req; | 612 | struct at91_request *req; |
| 609 | struct at91_ep *ep; | 613 | struct at91_ep *ep; |
| 610 | struct at91_udc *dev; | 614 | struct at91_udc *udc; |
| 611 | int status; | 615 | int status; |
| 612 | unsigned long flags; | 616 | unsigned long flags; |
| 613 | 617 | ||
| @@ -625,9 +629,9 @@ static int at91_ep_queue(struct usb_ep *_ep, | |||
| 625 | return -EINVAL; | 629 | return -EINVAL; |
| 626 | } | 630 | } |
| 627 | 631 | ||
| 628 | dev = ep->udc; | 632 | udc = ep->udc; |
| 629 | 633 | ||
| 630 | if (!dev || !dev->driver || dev->gadget.speed == USB_SPEED_UNKNOWN) { | 634 | if (!udc || !udc->driver || udc->gadget.speed == USB_SPEED_UNKNOWN) { |
| 631 | DBG("invalid device\n"); | 635 | DBG("invalid device\n"); |
| 632 | return -EINVAL; | 636 | return -EINVAL; |
| 633 | } | 637 | } |
| @@ -635,7 +639,7 @@ static int at91_ep_queue(struct usb_ep *_ep, | |||
| 635 | _req->status = -EINPROGRESS; | 639 | _req->status = -EINPROGRESS; |
| 636 | _req->actual = 0; | 640 | _req->actual = 0; |
| 637 | 641 | ||
| 638 | local_irq_save(flags); | 642 | spin_lock_irqsave(&udc->lock, flags); |
| 639 | 643 | ||
| 640 | /* try to kickstart any empty and idle queue */ | 644 | /* try to kickstart any empty and idle queue */ |
| 641 | if (list_empty(&ep->queue) && !ep->stopped) { | 645 | if (list_empty(&ep->queue) && !ep->stopped) { |
| @@ -653,7 +657,7 @@ static int at91_ep_queue(struct usb_ep *_ep, | |||
| 653 | if (is_ep0) { | 657 | if (is_ep0) { |
| 654 | u32 tmp; | 658 | u32 tmp; |
| 655 | 659 | ||
| 656 | if (!dev->req_pending) { | 660 | if (!udc->req_pending) { |
| 657 | status = -EINVAL; | 661 | status = -EINVAL; |
| 658 | goto done; | 662 | goto done; |
| 659 | } | 663 | } |
| @@ -662,11 +666,11 @@ static int at91_ep_queue(struct usb_ep *_ep, | |||
| 662 | * defer changing CONFG until after the gadget driver | 666 | * defer changing CONFG until after the gadget driver |
| 663 | * reconfigures the endpoints. | 667 | * reconfigures the endpoints. |
| 664 | */ | 668 | */ |
| 665 | if (dev->wait_for_config_ack) { | 669 | if (udc->wait_for_config_ack) { |
| 666 | tmp = at91_udp_read(dev, AT91_UDP_GLB_STAT); | 670 | tmp = at91_udp_read(udc, AT91_UDP_GLB_STAT); |
| 667 | tmp ^= AT91_UDP_CONFG; | 671 | tmp ^= AT91_UDP_CONFG; |
| 668 | VDBG("toggle config\n"); | 672 | VDBG("toggle config\n"); |
| 669 | at91_udp_write(dev, AT91_UDP_GLB_STAT, tmp); | 673 | at91_udp_write(udc, AT91_UDP_GLB_STAT, tmp); |
| 670 | } | 674 | } |
| 671 | if (req->req.length == 0) { | 675 | if (req->req.length == 0) { |
| 672 | ep0_in_status: | 676 | ep0_in_status: |
| @@ -676,7 +680,7 @@ ep0_in_status: | |||
| 676 | tmp &= ~SET_FX; | 680 | tmp &= ~SET_FX; |
| 677 | tmp |= CLR_FX | AT91_UDP_TXPKTRDY; | 681 | tmp |= CLR_FX | AT91_UDP_TXPKTRDY; |
| 678 | __raw_writel(tmp, ep->creg); | 682 | __raw_writel(tmp, ep->creg); |
| 679 | dev->req_pending = 0; | 683 | udc->req_pending = 0; |
| 680 | goto done; | 684 | goto done; |
| 681 | } | 685 | } |
| 682 | } | 686 | } |
| @@ -695,31 +699,40 @@ ep0_in_status: | |||
| 695 | 699 | ||
| 696 | if (req && !status) { | 700 | if (req && !status) { |
| 697 | list_add_tail (&req->queue, &ep->queue); | 701 | list_add_tail (&req->queue, &ep->queue); |
| 698 | at91_udp_write(dev, AT91_UDP_IER, ep->int_mask); | 702 | at91_udp_write(udc, AT91_UDP_IER, ep->int_mask); |
| 699 | } | 703 | } |
| 700 | done: | 704 | done: |
| 701 | local_irq_restore(flags); | 705 | spin_unlock_irqrestore(&udc->lock, flags); |
| 702 | return (status < 0) ? status : 0; | 706 | return (status < 0) ? status : 0; |
| 703 | } | 707 | } |
| 704 | 708 | ||
| 705 | static int at91_ep_dequeue(struct usb_ep *_ep, struct usb_request *_req) | 709 | static int at91_ep_dequeue(struct usb_ep *_ep, struct usb_request *_req) |
| 706 | { | 710 | { |
| 707 | struct at91_ep *ep; | 711 | struct at91_ep *ep; |
| 708 | struct at91_request *req; | 712 | struct at91_request *req; |
| 713 | unsigned long flags; | ||
| 714 | struct at91_udc *udc; | ||
| 709 | 715 | ||
| 710 | ep = container_of(_ep, struct at91_ep, ep); | 716 | ep = container_of(_ep, struct at91_ep, ep); |
| 711 | if (!_ep || ep->ep.name == ep0name) | 717 | if (!_ep || ep->ep.name == ep0name) |
| 712 | return -EINVAL; | 718 | return -EINVAL; |
| 713 | 719 | ||
| 720 | udc = ep->udc; | ||
| 721 | |||
| 722 | spin_lock_irqsave(&udc->lock, flags); | ||
| 723 | |||
| 714 | /* make sure it's actually queued on this endpoint */ | 724 | /* make sure it's actually queued on this endpoint */ |
| 715 | list_for_each_entry (req, &ep->queue, queue) { | 725 | list_for_each_entry (req, &ep->queue, queue) { |
| 716 | if (&req->req == _req) | 726 | if (&req->req == _req) |
| 717 | break; | 727 | break; |
| 718 | } | 728 | } |
| 719 | if (&req->req != _req) | 729 | if (&req->req != _req) { |
| 730 | spin_unlock_irqrestore(&udc->lock, flags); | ||
| 720 | return -EINVAL; | 731 | return -EINVAL; |
| 732 | } | ||
| 721 | 733 | ||
| 722 | done(ep, req, -ECONNRESET); | 734 | done(ep, req, -ECONNRESET); |
| 735 | spin_unlock_irqrestore(&udc->lock, flags); | ||
| 723 | return 0; | 736 | return 0; |
| 724 | } | 737 | } |
| 725 | 738 | ||
| @@ -736,7 +749,7 @@ static int at91_ep_set_halt(struct usb_ep *_ep, int value) | |||
| 736 | return -EINVAL; | 749 | return -EINVAL; |
| 737 | 750 | ||
| 738 | creg = ep->creg; | 751 | creg = ep->creg; |
| 739 | local_irq_save(flags); | 752 | spin_lock_irqsave(&udc->lock, flags); |
| 740 | 753 | ||
| 741 | csr = __raw_readl(creg); | 754 | csr = __raw_readl(creg); |
| 742 | 755 | ||
| @@ -761,7 +774,7 @@ static int at91_ep_set_halt(struct usb_ep *_ep, int value) | |||
| 761 | __raw_writel(csr, creg); | 774 | __raw_writel(csr, creg); |
| 762 | } | 775 | } |
| 763 | 776 | ||
| 764 | local_irq_restore(flags); | 777 | spin_unlock_irqrestore(&udc->lock, flags); |
| 765 | return status; | 778 | return status; |
| 766 | } | 779 | } |
| 767 | 780 | ||
| @@ -795,7 +808,7 @@ static int at91_wakeup(struct usb_gadget *gadget) | |||
| 795 | unsigned long flags; | 808 | unsigned long flags; |
| 796 | 809 | ||
| 797 | DBG("%s\n", __func__ ); | 810 | DBG("%s\n", __func__ ); |
| 798 | local_irq_save(flags); | 811 | spin_lock_irqsave(&udc->lock, flags); |
| 799 | 812 | ||
| 800 | if (!udc->clocked || !udc->suspended) | 813 | if (!udc->clocked || !udc->suspended) |
| 801 | goto done; | 814 | goto done; |
| @@ -809,7 +822,7 @@ static int at91_wakeup(struct usb_gadget *gadget) | |||
| 809 | at91_udp_write(udc, AT91_UDP_GLB_STAT, glbstate); | 822 | at91_udp_write(udc, AT91_UDP_GLB_STAT, glbstate); |
| 810 | 823 | ||
| 811 | done: | 824 | done: |
| 812 | local_irq_restore(flags); | 825 | spin_unlock_irqrestore(&udc->lock, flags); |
| 813 | return status; | 826 | return status; |
| 814 | } | 827 | } |
| 815 | 828 | ||
| @@ -851,8 +864,11 @@ static void stop_activity(struct at91_udc *udc) | |||
| 851 | ep->stopped = 1; | 864 | ep->stopped = 1; |
| 852 | nuke(ep, -ESHUTDOWN); | 865 | nuke(ep, -ESHUTDOWN); |
| 853 | } | 866 | } |
| 854 | if (driver) | 867 | if (driver) { |
| 868 | spin_unlock(&udc->lock); | ||
| 855 | driver->disconnect(&udc->gadget); | 869 | driver->disconnect(&udc->gadget); |
| 870 | spin_lock(&udc->lock); | ||
| 871 | } | ||
| 856 | 872 | ||
| 857 | udc_reinit(udc); | 873 | udc_reinit(udc); |
| 858 | } | 874 | } |
| @@ -935,13 +951,13 @@ static int at91_vbus_session(struct usb_gadget *gadget, int is_active) | |||
| 935 | unsigned long flags; | 951 | unsigned long flags; |
| 936 | 952 | ||
| 937 | // VDBG("vbus %s\n", is_active ? "on" : "off"); | 953 | // VDBG("vbus %s\n", is_active ? "on" : "off"); |
| 938 | local_irq_save(flags); | 954 | spin_lock_irqsave(&udc->lock, flags); |
| 939 | udc->vbus = (is_active != 0); | 955 | udc->vbus = (is_active != 0); |
| 940 | if (udc->driver) | 956 | if (udc->driver) |
| 941 | pullup(udc, is_active); | 957 | pullup(udc, is_active); |
| 942 | else | 958 | else |
| 943 | pullup(udc, 0); | 959 | pullup(udc, 0); |
| 944 | local_irq_restore(flags); | 960 | spin_unlock_irqrestore(&udc->lock, flags); |
| 945 | return 0; | 961 | return 0; |
| 946 | } | 962 | } |
| 947 | 963 | ||
| @@ -950,10 +966,10 @@ static int at91_pullup(struct usb_gadget *gadget, int is_on) | |||
| 950 | struct at91_udc *udc = to_udc(gadget); | 966 | struct at91_udc *udc = to_udc(gadget); |
| 951 | unsigned long flags; | 967 | unsigned long flags; |
| 952 | 968 | ||
| 953 | local_irq_save(flags); | 969 | spin_lock_irqsave(&udc->lock, flags); |
| 954 | udc->enabled = is_on = !!is_on; | 970 | udc->enabled = is_on = !!is_on; |
| 955 | pullup(udc, is_on); | 971 | pullup(udc, is_on); |
| 956 | local_irq_restore(flags); | 972 | spin_unlock_irqrestore(&udc->lock, flags); |
| 957 | return 0; | 973 | return 0; |
| 958 | } | 974 | } |
| 959 | 975 | ||
| @@ -962,9 +978,9 @@ static int at91_set_selfpowered(struct usb_gadget *gadget, int is_on) | |||
| 962 | struct at91_udc *udc = to_udc(gadget); | 978 | struct at91_udc *udc = to_udc(gadget); |
| 963 | unsigned long flags; | 979 | unsigned long flags; |
| 964 | 980 | ||
| 965 | local_irq_save(flags); | 981 | spin_lock_irqsave(&udc->lock, flags); |
| 966 | udc->selfpowered = (is_on != 0); | 982 | udc->selfpowered = (is_on != 0); |
| 967 | local_irq_restore(flags); | 983 | spin_unlock_irqrestore(&udc->lock, flags); |
| 968 | return 0; | 984 | return 0; |
| 969 | } | 985 | } |
| 970 | 986 | ||
| @@ -1226,8 +1242,11 @@ static void handle_setup(struct at91_udc *udc, struct at91_ep *ep, u32 csr) | |||
| 1226 | #undef w_length | 1242 | #undef w_length |
| 1227 | 1243 | ||
| 1228 | /* pass request up to the gadget driver */ | 1244 | /* pass request up to the gadget driver */ |
| 1229 | if (udc->driver) | 1245 | if (udc->driver) { |
| 1246 | spin_unlock(&udc->lock); | ||
| 1230 | status = udc->driver->setup(&udc->gadget, &pkt.r); | 1247 | status = udc->driver->setup(&udc->gadget, &pkt.r); |
| 1248 | spin_lock(&udc->lock); | ||
| 1249 | } | ||
| 1231 | else | 1250 | else |
| 1232 | status = -ENODEV; | 1251 | status = -ENODEV; |
| 1233 | if (status < 0) { | 1252 | if (status < 0) { |
| @@ -1378,6 +1397,9 @@ static irqreturn_t at91_udc_irq (int irq, void *_udc) | |||
| 1378 | struct at91_udc *udc = _udc; | 1397 | struct at91_udc *udc = _udc; |
| 1379 | u32 rescans = 5; | 1398 | u32 rescans = 5; |
| 1380 | int disable_clock = 0; | 1399 | int disable_clock = 0; |
| 1400 | unsigned long flags; | ||
| 1401 | |||
| 1402 | spin_lock_irqsave(&udc->lock, flags); | ||
| 1381 | 1403 | ||
| 1382 | if (!udc->clocked) { | 1404 | if (!udc->clocked) { |
| 1383 | clk_on(udc); | 1405 | clk_on(udc); |
| @@ -1433,8 +1455,11 @@ static irqreturn_t at91_udc_irq (int irq, void *_udc) | |||
| 1433 | * and then into standby to avoid drawing more than | 1455 | * and then into standby to avoid drawing more than |
| 1434 | * 500uA power (2500uA for some high-power configs). | 1456 | * 500uA power (2500uA for some high-power configs). |
| 1435 | */ | 1457 | */ |
| 1436 | if (udc->driver && udc->driver->suspend) | 1458 | if (udc->driver && udc->driver->suspend) { |
| 1459 | spin_unlock(&udc->lock); | ||
| 1437 | udc->driver->suspend(&udc->gadget); | 1460 | udc->driver->suspend(&udc->gadget); |
| 1461 | spin_lock(&udc->lock); | ||
| 1462 | } | ||
| 1438 | 1463 | ||
| 1439 | /* host initiated resume */ | 1464 | /* host initiated resume */ |
| 1440 | } else if (status & AT91_UDP_RXRSM) { | 1465 | } else if (status & AT91_UDP_RXRSM) { |
| @@ -1451,8 +1476,11 @@ static irqreturn_t at91_udc_irq (int irq, void *_udc) | |||
| 1451 | * would normally want to switch out of slow clock | 1476 | * would normally want to switch out of slow clock |
| 1452 | * mode into normal mode. | 1477 | * mode into normal mode. |
| 1453 | */ | 1478 | */ |
| 1454 | if (udc->driver && udc->driver->resume) | 1479 | if (udc->driver && udc->driver->resume) { |
| 1480 | spin_unlock(&udc->lock); | ||
| 1455 | udc->driver->resume(&udc->gadget); | 1481 | udc->driver->resume(&udc->gadget); |
| 1482 | spin_lock(&udc->lock); | ||
| 1483 | } | ||
| 1456 | 1484 | ||
| 1457 | /* endpoint IRQs are cleared by handling them */ | 1485 | /* endpoint IRQs are cleared by handling them */ |
| 1458 | } else { | 1486 | } else { |
| @@ -1474,6 +1502,8 @@ static irqreturn_t at91_udc_irq (int irq, void *_udc) | |||
| 1474 | if (disable_clock) | 1502 | if (disable_clock) |
| 1475 | clk_off(udc); | 1503 | clk_off(udc); |
| 1476 | 1504 | ||
| 1505 | spin_unlock_irqrestore(&udc->lock, flags); | ||
| 1506 | |||
| 1477 | return IRQ_HANDLED; | 1507 | return IRQ_HANDLED; |
| 1478 | } | 1508 | } |
| 1479 | 1509 | ||
| @@ -1556,24 +1586,53 @@ static struct at91_udc controller = { | |||
| 1556 | /* ep6 and ep7 are also reserved (custom silicon might use them) */ | 1586 | /* ep6 and ep7 are also reserved (custom silicon might use them) */ |
| 1557 | }; | 1587 | }; |
| 1558 | 1588 | ||
| 1589 | static void at91_vbus_update(struct at91_udc *udc, unsigned value) | ||
| 1590 | { | ||
| 1591 | value ^= udc->board.vbus_active_low; | ||
| 1592 | if (value != udc->vbus) | ||
| 1593 | at91_vbus_session(&udc->gadget, value); | ||
| 1594 | } | ||
| 1595 | |||
| 1559 | static irqreturn_t at91_vbus_irq(int irq, void *_udc) | 1596 | static irqreturn_t at91_vbus_irq(int irq, void *_udc) |
| 1560 | { | 1597 | { |
| 1561 | struct at91_udc *udc = _udc; | 1598 | struct at91_udc *udc = _udc; |
| 1562 | unsigned value; | ||
| 1563 | 1599 | ||
| 1564 | /* vbus needs at least brief debouncing */ | 1600 | /* vbus needs at least brief debouncing */ |
| 1565 | udelay(10); | 1601 | udelay(10); |
| 1566 | value = gpio_get_value(udc->board.vbus_pin); | 1602 | at91_vbus_update(udc, gpio_get_value(udc->board.vbus_pin)); |
| 1567 | if (value != udc->vbus) | ||
| 1568 | at91_vbus_session(&udc->gadget, value); | ||
| 1569 | 1603 | ||
| 1570 | return IRQ_HANDLED; | 1604 | return IRQ_HANDLED; |
| 1571 | } | 1605 | } |
| 1572 | 1606 | ||
| 1607 | static void at91_vbus_timer_work(struct work_struct *work) | ||
| 1608 | { | ||
| 1609 | struct at91_udc *udc = container_of(work, struct at91_udc, | ||
| 1610 | vbus_timer_work); | ||
| 1611 | |||
| 1612 | at91_vbus_update(udc, gpio_get_value_cansleep(udc->board.vbus_pin)); | ||
| 1613 | |||
| 1614 | if (!timer_pending(&udc->vbus_timer)) | ||
| 1615 | mod_timer(&udc->vbus_timer, jiffies + VBUS_POLL_TIMEOUT); | ||
| 1616 | } | ||
| 1617 | |||
| 1618 | static void at91_vbus_timer(unsigned long data) | ||
| 1619 | { | ||
| 1620 | struct at91_udc *udc = (struct at91_udc *)data; | ||
| 1621 | |||
| 1622 | /* | ||
| 1623 | * If we are polling vbus it is likely that the gpio is on an | ||
| 1624 | * bus such as i2c or spi which may sleep, so schedule some work | ||
| 1625 | * to read the vbus gpio | ||
| 1626 | */ | ||
| 1627 | if (!work_pending(&udc->vbus_timer_work)) | ||
| 1628 | schedule_work(&udc->vbus_timer_work); | ||
| 1629 | } | ||
| 1630 | |||
| 1573 | int usb_gadget_register_driver (struct usb_gadget_driver *driver) | 1631 | int usb_gadget_register_driver (struct usb_gadget_driver *driver) |
| 1574 | { | 1632 | { |
| 1575 | struct at91_udc *udc = &controller; | 1633 | struct at91_udc *udc = &controller; |
| 1576 | int retval; | 1634 | int retval; |
| 1635 | unsigned long flags; | ||
| 1577 | 1636 | ||
| 1578 | if (!driver | 1637 | if (!driver |
| 1579 | || driver->speed < USB_SPEED_FULL | 1638 | || driver->speed < USB_SPEED_FULL |
| @@ -1605,9 +1664,9 @@ int usb_gadget_register_driver (struct usb_gadget_driver *driver) | |||
| 1605 | return retval; | 1664 | return retval; |
| 1606 | } | 1665 | } |
| 1607 | 1666 | ||
| 1608 | local_irq_disable(); | 1667 | spin_lock_irqsave(&udc->lock, flags); |
| 1609 | pullup(udc, 1); | 1668 | pullup(udc, 1); |
| 1610 | local_irq_enable(); | 1669 | spin_unlock_irqrestore(&udc->lock, flags); |
| 1611 | 1670 | ||
| 1612 | DBG("bound to %s\n", driver->driver.name); | 1671 | DBG("bound to %s\n", driver->driver.name); |
| 1613 | return 0; | 1672 | return 0; |
| @@ -1617,15 +1676,16 @@ EXPORT_SYMBOL (usb_gadget_register_driver); | |||
| 1617 | int usb_gadget_unregister_driver (struct usb_gadget_driver *driver) | 1676 | int usb_gadget_unregister_driver (struct usb_gadget_driver *driver) |
| 1618 | { | 1677 | { |
| 1619 | struct at91_udc *udc = &controller; | 1678 | struct at91_udc *udc = &controller; |
| 1679 | unsigned long flags; | ||
| 1620 | 1680 | ||
| 1621 | if (!driver || driver != udc->driver || !driver->unbind) | 1681 | if (!driver || driver != udc->driver || !driver->unbind) |
| 1622 | return -EINVAL; | 1682 | return -EINVAL; |
| 1623 | 1683 | ||
| 1624 | local_irq_disable(); | 1684 | spin_lock_irqsave(&udc->lock, flags); |
| 1625 | udc->enabled = 0; | 1685 | udc->enabled = 0; |
| 1626 | at91_udp_write(udc, AT91_UDP_IDR, ~0); | 1686 | at91_udp_write(udc, AT91_UDP_IDR, ~0); |
| 1627 | pullup(udc, 0); | 1687 | pullup(udc, 0); |
| 1628 | local_irq_enable(); | 1688 | spin_unlock_irqrestore(&udc->lock, flags); |
| 1629 | 1689 | ||
| 1630 | driver->unbind(&udc->gadget); | 1690 | driver->unbind(&udc->gadget); |
| 1631 | udc->gadget.dev.driver = NULL; | 1691 | udc->gadget.dev.driver = NULL; |
| @@ -1641,8 +1701,13 @@ EXPORT_SYMBOL (usb_gadget_unregister_driver); | |||
| 1641 | 1701 | ||
| 1642 | static void at91udc_shutdown(struct platform_device *dev) | 1702 | static void at91udc_shutdown(struct platform_device *dev) |
| 1643 | { | 1703 | { |
| 1704 | struct at91_udc *udc = platform_get_drvdata(dev); | ||
| 1705 | unsigned long flags; | ||
| 1706 | |||
| 1644 | /* force disconnect on reboot */ | 1707 | /* force disconnect on reboot */ |
| 1708 | spin_lock_irqsave(&udc->lock, flags); | ||
| 1645 | pullup(platform_get_drvdata(dev), 0); | 1709 | pullup(platform_get_drvdata(dev), 0); |
| 1710 | spin_unlock_irqrestore(&udc->lock, flags); | ||
| 1646 | } | 1711 | } |
| 1647 | 1712 | ||
| 1648 | static int __init at91udc_probe(struct platform_device *pdev) | 1713 | static int __init at91udc_probe(struct platform_device *pdev) |
| @@ -1683,6 +1748,7 @@ static int __init at91udc_probe(struct platform_device *pdev) | |||
| 1683 | udc->board = *(struct at91_udc_data *) dev->platform_data; | 1748 | udc->board = *(struct at91_udc_data *) dev->platform_data; |
| 1684 | udc->pdev = pdev; | 1749 | udc->pdev = pdev; |
| 1685 | udc->enabled = 0; | 1750 | udc->enabled = 0; |
| 1751 | spin_lock_init(&udc->lock); | ||
| 1686 | 1752 | ||
| 1687 | /* rm9200 needs manual D+ pullup; off by default */ | 1753 | /* rm9200 needs manual D+ pullup; off by default */ |
| 1688 | if (cpu_is_at91rm9200()) { | 1754 | if (cpu_is_at91rm9200()) { |
| @@ -1763,13 +1829,23 @@ static int __init at91udc_probe(struct platform_device *pdev) | |||
| 1763 | * Get the initial state of VBUS - we cannot expect | 1829 | * Get the initial state of VBUS - we cannot expect |
| 1764 | * a pending interrupt. | 1830 | * a pending interrupt. |
| 1765 | */ | 1831 | */ |
| 1766 | udc->vbus = gpio_get_value(udc->board.vbus_pin); | 1832 | udc->vbus = gpio_get_value_cansleep(udc->board.vbus_pin) ^ |
| 1767 | if (request_irq(udc->board.vbus_pin, at91_vbus_irq, | 1833 | udc->board.vbus_active_low; |
| 1768 | IRQF_DISABLED, driver_name, udc)) { | 1834 | |
| 1769 | DBG("request vbus irq %d failed\n", | 1835 | if (udc->board.vbus_polled) { |
| 1770 | udc->board.vbus_pin); | 1836 | INIT_WORK(&udc->vbus_timer_work, at91_vbus_timer_work); |
| 1771 | retval = -EBUSY; | 1837 | setup_timer(&udc->vbus_timer, at91_vbus_timer, |
| 1772 | goto fail3; | 1838 | (unsigned long)udc); |
| 1839 | mod_timer(&udc->vbus_timer, | ||
| 1840 | jiffies + VBUS_POLL_TIMEOUT); | ||
| 1841 | } else { | ||
| 1842 | if (request_irq(udc->board.vbus_pin, at91_vbus_irq, | ||
| 1843 | IRQF_DISABLED, driver_name, udc)) { | ||
| 1844 | DBG("request vbus irq %d failed\n", | ||
| 1845 | udc->board.vbus_pin); | ||
| 1846 | retval = -EBUSY; | ||
| 1847 | goto fail3; | ||
| 1848 | } | ||
| 1773 | } | 1849 | } |
| 1774 | } else { | 1850 | } else { |
| 1775 | DBG("no VBUS detection, assuming always-on\n"); | 1851 | DBG("no VBUS detection, assuming always-on\n"); |
| @@ -1804,13 +1880,16 @@ static int __exit at91udc_remove(struct platform_device *pdev) | |||
| 1804 | { | 1880 | { |
| 1805 | struct at91_udc *udc = platform_get_drvdata(pdev); | 1881 | struct at91_udc *udc = platform_get_drvdata(pdev); |
| 1806 | struct resource *res; | 1882 | struct resource *res; |
| 1883 | unsigned long flags; | ||
| 1807 | 1884 | ||
| 1808 | DBG("remove\n"); | 1885 | DBG("remove\n"); |
| 1809 | 1886 | ||
| 1810 | if (udc->driver) | 1887 | if (udc->driver) |
| 1811 | return -EBUSY; | 1888 | return -EBUSY; |
| 1812 | 1889 | ||
| 1890 | spin_lock_irqsave(&udc->lock, flags); | ||
| 1813 | pullup(udc, 0); | 1891 | pullup(udc, 0); |
| 1892 | spin_unlock_irqrestore(&udc->lock, flags); | ||
| 1814 | 1893 | ||
| 1815 | device_init_wakeup(&pdev->dev, 0); | 1894 | device_init_wakeup(&pdev->dev, 0); |
| 1816 | remove_debug_file(udc); | 1895 | remove_debug_file(udc); |
| @@ -1840,6 +1919,7 @@ static int at91udc_suspend(struct platform_device *pdev, pm_message_t mesg) | |||
| 1840 | { | 1919 | { |
| 1841 | struct at91_udc *udc = platform_get_drvdata(pdev); | 1920 | struct at91_udc *udc = platform_get_drvdata(pdev); |
| 1842 | int wake = udc->driver && device_may_wakeup(&pdev->dev); | 1921 | int wake = udc->driver && device_may_wakeup(&pdev->dev); |
| 1922 | unsigned long flags; | ||
| 1843 | 1923 | ||
| 1844 | /* Unless we can act normally to the host (letting it wake us up | 1924 | /* Unless we can act normally to the host (letting it wake us up |
| 1845 | * whenever it has work for us) force disconnect. Wakeup requires | 1925 | * whenever it has work for us) force disconnect. Wakeup requires |
| @@ -1849,13 +1929,15 @@ static int at91udc_suspend(struct platform_device *pdev, pm_message_t mesg) | |||
| 1849 | if ((!udc->suspended && udc->addr) | 1929 | if ((!udc->suspended && udc->addr) |
| 1850 | || !wake | 1930 | || !wake |
| 1851 | || at91_suspend_entering_slow_clock()) { | 1931 | || at91_suspend_entering_slow_clock()) { |
| 1932 | spin_lock_irqsave(&udc->lock, flags); | ||
| 1852 | pullup(udc, 0); | 1933 | pullup(udc, 0); |
| 1853 | wake = 0; | 1934 | wake = 0; |
| 1935 | spin_unlock_irqrestore(&udc->lock, flags); | ||
| 1854 | } else | 1936 | } else |
| 1855 | enable_irq_wake(udc->udp_irq); | 1937 | enable_irq_wake(udc->udp_irq); |
| 1856 | 1938 | ||
| 1857 | udc->active_suspend = wake; | 1939 | udc->active_suspend = wake; |
| 1858 | if (udc->board.vbus_pin > 0 && wake) | 1940 | if (udc->board.vbus_pin > 0 && !udc->board.vbus_polled && wake) |
| 1859 | enable_irq_wake(udc->board.vbus_pin); | 1941 | enable_irq_wake(udc->board.vbus_pin); |
| 1860 | return 0; | 1942 | return 0; |
| 1861 | } | 1943 | } |
| @@ -1863,15 +1945,20 @@ static int at91udc_suspend(struct platform_device *pdev, pm_message_t mesg) | |||
| 1863 | static int at91udc_resume(struct platform_device *pdev) | 1945 | static int at91udc_resume(struct platform_device *pdev) |
| 1864 | { | 1946 | { |
| 1865 | struct at91_udc *udc = platform_get_drvdata(pdev); | 1947 | struct at91_udc *udc = platform_get_drvdata(pdev); |
| 1948 | unsigned long flags; | ||
| 1866 | 1949 | ||
| 1867 | if (udc->board.vbus_pin > 0 && udc->active_suspend) | 1950 | if (udc->board.vbus_pin > 0 && !udc->board.vbus_polled && |
| 1951 | udc->active_suspend) | ||
| 1868 | disable_irq_wake(udc->board.vbus_pin); | 1952 | disable_irq_wake(udc->board.vbus_pin); |
| 1869 | 1953 | ||
| 1870 | /* maybe reconnect to host; if so, clocks on */ | 1954 | /* maybe reconnect to host; if so, clocks on */ |
| 1871 | if (udc->active_suspend) | 1955 | if (udc->active_suspend) |
| 1872 | disable_irq_wake(udc->udp_irq); | 1956 | disable_irq_wake(udc->udp_irq); |
| 1873 | else | 1957 | else { |
| 1958 | spin_lock_irqsave(&udc->lock, flags); | ||
| 1874 | pullup(udc, 1); | 1959 | pullup(udc, 1); |
| 1960 | spin_unlock_irqrestore(&udc->lock, flags); | ||
| 1961 | } | ||
| 1875 | return 0; | 1962 | return 0; |
| 1876 | } | 1963 | } |
| 1877 | #else | 1964 | #else |
diff --git a/drivers/usb/gadget/at91_udc.h b/drivers/usb/gadget/at91_udc.h index c65d62295890..108ca54f9092 100644 --- a/drivers/usb/gadget/at91_udc.h +++ b/drivers/usb/gadget/at91_udc.h | |||
| @@ -144,6 +144,9 @@ struct at91_udc { | |||
| 144 | struct proc_dir_entry *pde; | 144 | struct proc_dir_entry *pde; |
| 145 | void __iomem *udp_baseaddr; | 145 | void __iomem *udp_baseaddr; |
| 146 | int udp_irq; | 146 | int udp_irq; |
| 147 | spinlock_t lock; | ||
| 148 | struct timer_list vbus_timer; | ||
| 149 | struct work_struct vbus_timer_work; | ||
| 147 | }; | 150 | }; |
| 148 | 151 | ||
| 149 | static inline struct at91_udc *to_udc(struct usb_gadget *g) | 152 | static inline struct at91_udc *to_udc(struct usb_gadget *g) |
diff --git a/drivers/usb/gadget/pxa27x_udc.c b/drivers/usb/gadget/pxa27x_udc.c index 85b0d8921eae..980762453a9c 100644 --- a/drivers/usb/gadget/pxa27x_udc.c +++ b/drivers/usb/gadget/pxa27x_udc.c | |||
| @@ -2561,7 +2561,7 @@ static void pxa_udc_shutdown(struct platform_device *_dev) | |||
| 2561 | udc_disable(udc); | 2561 | udc_disable(udc); |
| 2562 | } | 2562 | } |
| 2563 | 2563 | ||
| 2564 | #ifdef CONFIG_CPU_PXA27x | 2564 | #ifdef CONFIG_PXA27x |
| 2565 | extern void pxa27x_clear_otgph(void); | 2565 | extern void pxa27x_clear_otgph(void); |
| 2566 | #else | 2566 | #else |
| 2567 | #define pxa27x_clear_otgph() do {} while (0) | 2567 | #define pxa27x_clear_otgph() do {} while (0) |
diff --git a/drivers/usb/gadget/s3c2410_udc.c b/drivers/usb/gadget/s3c2410_udc.c index e724a051bfdd..ea2b3c7ebee5 100644 --- a/drivers/usb/gadget/s3c2410_udc.c +++ b/drivers/usb/gadget/s3c2410_udc.c | |||
| @@ -735,6 +735,10 @@ static void s3c2410_udc_handle_ep0_idle(struct s3c2410_udc *dev, | |||
| 735 | else | 735 | else |
| 736 | dev->ep0state = EP0_OUT_DATA_PHASE; | 736 | dev->ep0state = EP0_OUT_DATA_PHASE; |
| 737 | 737 | ||
| 738 | if (!dev->driver) | ||
| 739 | return; | ||
| 740 | |||
| 741 | /* deliver the request to the gadget driver */ | ||
| 738 | ret = dev->driver->setup(&dev->gadget, crq); | 742 | ret = dev->driver->setup(&dev->gadget, crq); |
| 739 | if (ret < 0) { | 743 | if (ret < 0) { |
| 740 | if (dev->req_config) { | 744 | if (dev->req_config) { |
diff --git a/drivers/usb/host/ohci-pxa27x.c b/drivers/usb/host/ohci-pxa27x.c index a18debdd79b8..418163894775 100644 --- a/drivers/usb/host/ohci-pxa27x.c +++ b/drivers/usb/host/ohci-pxa27x.c | |||
| @@ -203,7 +203,7 @@ static inline void pxa27x_reset_hc(struct pxa27x_ohci *ohci) | |||
| 203 | __raw_writel(uhchr & ~UHCHR_FHR, ohci->mmio_base + UHCHR); | 203 | __raw_writel(uhchr & ~UHCHR_FHR, ohci->mmio_base + UHCHR); |
| 204 | } | 204 | } |
| 205 | 205 | ||
| 206 | #ifdef CONFIG_CPU_PXA27x | 206 | #ifdef CONFIG_PXA27x |
| 207 | extern void pxa27x_clear_otgph(void); | 207 | extern void pxa27x_clear_otgph(void); |
| 208 | #else | 208 | #else |
| 209 | #define pxa27x_clear_otgph() do {} while (0) | 209 | #define pxa27x_clear_otgph() do {} while (0) |
diff --git a/drivers/usb/host/xhci-mem.c b/drivers/usb/host/xhci-mem.c index fd9e03afd91c..2eb658d26394 100644 --- a/drivers/usb/host/xhci-mem.c +++ b/drivers/usb/host/xhci-mem.c | |||
| @@ -835,6 +835,27 @@ fail: | |||
| 835 | return 0; | 835 | return 0; |
| 836 | } | 836 | } |
| 837 | 837 | ||
| 838 | void xhci_copy_ep0_dequeue_into_input_ctx(struct xhci_hcd *xhci, | ||
| 839 | struct usb_device *udev) | ||
| 840 | { | ||
| 841 | struct xhci_virt_device *virt_dev; | ||
| 842 | struct xhci_ep_ctx *ep0_ctx; | ||
| 843 | struct xhci_ring *ep_ring; | ||
| 844 | |||
| 845 | virt_dev = xhci->devs[udev->slot_id]; | ||
| 846 | ep0_ctx = xhci_get_ep_ctx(xhci, virt_dev->in_ctx, 0); | ||
| 847 | ep_ring = virt_dev->eps[0].ring; | ||
| 848 | /* | ||
| 849 | * FIXME we don't keep track of the dequeue pointer very well after a | ||
| 850 | * Set TR dequeue pointer, so we're setting the dequeue pointer of the | ||
| 851 | * host to our enqueue pointer. This should only be called after a | ||
| 852 | * configured device has reset, so all control transfers should have | ||
| 853 | * been completed or cancelled before the reset. | ||
| 854 | */ | ||
| 855 | ep0_ctx->deq = xhci_trb_virt_to_dma(ep_ring->enq_seg, ep_ring->enqueue); | ||
| 856 | ep0_ctx->deq |= ep_ring->cycle_state; | ||
| 857 | } | ||
| 858 | |||
| 838 | /* Setup an xHCI virtual device for a Set Address command */ | 859 | /* Setup an xHCI virtual device for a Set Address command */ |
| 839 | int xhci_setup_addressable_virt_dev(struct xhci_hcd *xhci, struct usb_device *udev) | 860 | int xhci_setup_addressable_virt_dev(struct xhci_hcd *xhci, struct usb_device *udev) |
| 840 | { | 861 | { |
| @@ -1002,7 +1023,7 @@ static inline unsigned int xhci_get_endpoint_interval(struct usb_device *udev, | |||
| 1002 | return EP_INTERVAL(interval); | 1023 | return EP_INTERVAL(interval); |
| 1003 | } | 1024 | } |
| 1004 | 1025 | ||
| 1005 | /* The "Mult" field in the endpoint context is only set for SuperSpeed devices. | 1026 | /* The "Mult" field in the endpoint context is only set for SuperSpeed isoc eps. |
| 1006 | * High speed endpoint descriptors can define "the number of additional | 1027 | * High speed endpoint descriptors can define "the number of additional |
| 1007 | * transaction opportunities per microframe", but that goes in the Max Burst | 1028 | * transaction opportunities per microframe", but that goes in the Max Burst |
| 1008 | * endpoint context field. | 1029 | * endpoint context field. |
| @@ -1010,7 +1031,8 @@ static inline unsigned int xhci_get_endpoint_interval(struct usb_device *udev, | |||
| 1010 | static inline u32 xhci_get_endpoint_mult(struct usb_device *udev, | 1031 | static inline u32 xhci_get_endpoint_mult(struct usb_device *udev, |
| 1011 | struct usb_host_endpoint *ep) | 1032 | struct usb_host_endpoint *ep) |
| 1012 | { | 1033 | { |
| 1013 | if (udev->speed != USB_SPEED_SUPER) | 1034 | if (udev->speed != USB_SPEED_SUPER || |
| 1035 | !usb_endpoint_xfer_isoc(&ep->desc)) | ||
| 1014 | return 0; | 1036 | return 0; |
| 1015 | return ep->ss_ep_comp.bmAttributes; | 1037 | return ep->ss_ep_comp.bmAttributes; |
| 1016 | } | 1038 | } |
diff --git a/drivers/usb/host/xhci-ring.c b/drivers/usb/host/xhci-ring.c index 94e6934edb09..bfc99a939455 100644 --- a/drivers/usb/host/xhci-ring.c +++ b/drivers/usb/host/xhci-ring.c | |||
| @@ -2380,16 +2380,19 @@ static int queue_command(struct xhci_hcd *xhci, u32 field1, u32 field2, | |||
| 2380 | u32 field3, u32 field4, bool command_must_succeed) | 2380 | u32 field3, u32 field4, bool command_must_succeed) |
| 2381 | { | 2381 | { |
| 2382 | int reserved_trbs = xhci->cmd_ring_reserved_trbs; | 2382 | int reserved_trbs = xhci->cmd_ring_reserved_trbs; |
| 2383 | int ret; | ||
| 2384 | |||
| 2383 | if (!command_must_succeed) | 2385 | if (!command_must_succeed) |
| 2384 | reserved_trbs++; | 2386 | reserved_trbs++; |
| 2385 | 2387 | ||
| 2386 | if (!room_on_ring(xhci, xhci->cmd_ring, reserved_trbs)) { | 2388 | ret = prepare_ring(xhci, xhci->cmd_ring, EP_STATE_RUNNING, |
| 2387 | if (!in_interrupt()) | 2389 | reserved_trbs, GFP_ATOMIC); |
| 2388 | xhci_err(xhci, "ERR: No room for command on command ring\n"); | 2390 | if (ret < 0) { |
| 2391 | xhci_err(xhci, "ERR: No room for command on command ring\n"); | ||
| 2389 | if (command_must_succeed) | 2392 | if (command_must_succeed) |
| 2390 | xhci_err(xhci, "ERR: Reserved TRB counting for " | 2393 | xhci_err(xhci, "ERR: Reserved TRB counting for " |
| 2391 | "unfailable commands failed.\n"); | 2394 | "unfailable commands failed.\n"); |
| 2392 | return -ENOMEM; | 2395 | return ret; |
| 2393 | } | 2396 | } |
| 2394 | queue_trb(xhci, xhci->cmd_ring, false, false, field1, field2, field3, | 2397 | queue_trb(xhci, xhci->cmd_ring, false, false, field1, field2, field3, |
| 2395 | field4 | xhci->cmd_ring->cycle_state); | 2398 | field4 | xhci->cmd_ring->cycle_state); |
diff --git a/drivers/usb/host/xhci.c b/drivers/usb/host/xhci.c index 27345cd04da0..3998f72cd0c4 100644 --- a/drivers/usb/host/xhci.c +++ b/drivers/usb/host/xhci.c | |||
| @@ -2134,6 +2134,8 @@ int xhci_address_device(struct usb_hcd *hcd, struct usb_device *udev) | |||
| 2134 | /* If this is a Set Address to an unconfigured device, setup ep 0 */ | 2134 | /* If this is a Set Address to an unconfigured device, setup ep 0 */ |
| 2135 | if (!udev->config) | 2135 | if (!udev->config) |
| 2136 | xhci_setup_addressable_virt_dev(xhci, udev); | 2136 | xhci_setup_addressable_virt_dev(xhci, udev); |
| 2137 | else | ||
| 2138 | xhci_copy_ep0_dequeue_into_input_ctx(xhci, udev); | ||
| 2137 | /* Otherwise, assume the core has the device configured how it wants */ | 2139 | /* Otherwise, assume the core has the device configured how it wants */ |
| 2138 | xhci_dbg(xhci, "Slot ID %d Input Context:\n", udev->slot_id); | 2140 | xhci_dbg(xhci, "Slot ID %d Input Context:\n", udev->slot_id); |
| 2139 | xhci_dbg_ctx(xhci, virt_dev->in_ctx, 2); | 2141 | xhci_dbg_ctx(xhci, virt_dev->in_ctx, 2); |
diff --git a/drivers/usb/host/xhci.h b/drivers/usb/host/xhci.h index 8b4b7d39f79c..6c7e3430ec93 100644 --- a/drivers/usb/host/xhci.h +++ b/drivers/usb/host/xhci.h | |||
| @@ -1292,6 +1292,8 @@ int xhci_mem_init(struct xhci_hcd *xhci, gfp_t flags); | |||
| 1292 | void xhci_free_virt_device(struct xhci_hcd *xhci, int slot_id); | 1292 | void xhci_free_virt_device(struct xhci_hcd *xhci, int slot_id); |
| 1293 | int xhci_alloc_virt_device(struct xhci_hcd *xhci, int slot_id, struct usb_device *udev, gfp_t flags); | 1293 | int xhci_alloc_virt_device(struct xhci_hcd *xhci, int slot_id, struct usb_device *udev, gfp_t flags); |
| 1294 | int xhci_setup_addressable_virt_dev(struct xhci_hcd *xhci, struct usb_device *udev); | 1294 | int xhci_setup_addressable_virt_dev(struct xhci_hcd *xhci, struct usb_device *udev); |
| 1295 | void xhci_copy_ep0_dequeue_into_input_ctx(struct xhci_hcd *xhci, | ||
| 1296 | struct usb_device *udev); | ||
| 1295 | unsigned int xhci_get_endpoint_index(struct usb_endpoint_descriptor *desc); | 1297 | unsigned int xhci_get_endpoint_index(struct usb_endpoint_descriptor *desc); |
| 1296 | unsigned int xhci_get_endpoint_flag(struct usb_endpoint_descriptor *desc); | 1298 | unsigned int xhci_get_endpoint_flag(struct usb_endpoint_descriptor *desc); |
| 1297 | unsigned int xhci_get_endpoint_flag_from_index(unsigned int ep_index); | 1299 | unsigned int xhci_get_endpoint_flag_from_index(unsigned int ep_index); |
diff --git a/drivers/usb/misc/sisusbvga/sisusb.c b/drivers/usb/misc/sisusbvga/sisusb.c index 30d930386b65..d25814c172b2 100644 --- a/drivers/usb/misc/sisusbvga/sisusb.c +++ b/drivers/usb/misc/sisusbvga/sisusb.c | |||
| @@ -2436,7 +2436,8 @@ sisusb_open(struct inode *inode, struct file *file) | |||
| 2436 | } | 2436 | } |
| 2437 | 2437 | ||
| 2438 | if (!sisusb->devinit) { | 2438 | if (!sisusb->devinit) { |
| 2439 | if (sisusb->sisusb_dev->speed == USB_SPEED_HIGH) { | 2439 | if (sisusb->sisusb_dev->speed == USB_SPEED_HIGH || |
| 2440 | sisusb->sisusb_dev->speed == USB_SPEED_SUPER) { | ||
| 2440 | if (sisusb_init_gfxdevice(sisusb, 0)) { | 2441 | if (sisusb_init_gfxdevice(sisusb, 0)) { |
| 2441 | mutex_unlock(&sisusb->lock); | 2442 | mutex_unlock(&sisusb->lock); |
| 2442 | dev_err(&sisusb->sisusb_dev->dev, "Failed to initialize device\n"); | 2443 | dev_err(&sisusb->sisusb_dev->dev, "Failed to initialize device\n"); |
| @@ -3166,7 +3167,7 @@ static int sisusb_probe(struct usb_interface *intf, | |||
| 3166 | 3167 | ||
| 3167 | sisusb->present = 1; | 3168 | sisusb->present = 1; |
| 3168 | 3169 | ||
| 3169 | if (dev->speed == USB_SPEED_HIGH) { | 3170 | if (dev->speed == USB_SPEED_HIGH || dev->speed == USB_SPEED_SUPER) { |
| 3170 | int initscreen = 1; | 3171 | int initscreen = 1; |
| 3171 | #ifdef INCL_SISUSB_CON | 3172 | #ifdef INCL_SISUSB_CON |
| 3172 | if (sisusb_first_vc > 0 && | 3173 | if (sisusb_first_vc > 0 && |
diff --git a/drivers/usb/musb/tusb6010.c b/drivers/usb/musb/tusb6010.c index 05c077f8f9ac..3c48e77a0aa2 100644 --- a/drivers/usb/musb/tusb6010.c +++ b/drivers/usb/musb/tusb6010.c | |||
| @@ -29,19 +29,6 @@ static void tusb_source_power(struct musb *musb, int is_on); | |||
| 29 | #define TUSB_REV_MAJOR(reg_val) ((reg_val >> 4) & 0xf) | 29 | #define TUSB_REV_MAJOR(reg_val) ((reg_val >> 4) & 0xf) |
| 30 | #define TUSB_REV_MINOR(reg_val) (reg_val & 0xf) | 30 | #define TUSB_REV_MINOR(reg_val) (reg_val & 0xf) |
| 31 | 31 | ||
| 32 | #ifdef CONFIG_PM | ||
| 33 | /* REVISIT: These should be only needed if somebody implements off idle */ | ||
| 34 | void musb_platform_save_context(struct musb *musb, | ||
| 35 | struct musb_context_registers *musb_context) | ||
| 36 | { | ||
| 37 | } | ||
| 38 | |||
| 39 | void musb_platform_restore_context(struct musb *musb, | ||
| 40 | struct musb_context_registers *musb_context) | ||
| 41 | { | ||
| 42 | } | ||
| 43 | #endif | ||
| 44 | |||
| 45 | /* | 32 | /* |
| 46 | * Checks the revision. We need to use the DMA register as 3.0 does not | 33 | * Checks the revision. We need to use the DMA register as 3.0 does not |
| 47 | * have correct versions for TUSB_PRCM_REV or TUSB_INT_CTRL_REV. | 34 | * have correct versions for TUSB_PRCM_REV or TUSB_INT_CTRL_REV. |
diff --git a/drivers/usb/serial/ftdi_sio.c b/drivers/usb/serial/ftdi_sio.c index da7e334b0407..e298dc4baed7 100644 --- a/drivers/usb/serial/ftdi_sio.c +++ b/drivers/usb/serial/ftdi_sio.c | |||
| @@ -691,6 +691,7 @@ static struct usb_device_id id_table_combined [] = { | |||
| 691 | { USB_DEVICE(FTDI_VID, FTDI_NDI_AURORA_SCU_PID), | 691 | { USB_DEVICE(FTDI_VID, FTDI_NDI_AURORA_SCU_PID), |
| 692 | .driver_info = (kernel_ulong_t)&ftdi_NDI_device_quirk }, | 692 | .driver_info = (kernel_ulong_t)&ftdi_NDI_device_quirk }, |
| 693 | { USB_DEVICE(TELLDUS_VID, TELLDUS_TELLSTICK_PID) }, | 693 | { USB_DEVICE(TELLDUS_VID, TELLDUS_TELLSTICK_PID) }, |
| 694 | { USB_DEVICE(RTSYSTEMS_VID, RTSYSTEMS_SERIAL_VX7_PID) }, | ||
| 694 | { USB_DEVICE(FTDI_VID, FTDI_MAXSTREAM_PID) }, | 695 | { USB_DEVICE(FTDI_VID, FTDI_MAXSTREAM_PID) }, |
| 695 | { USB_DEVICE(FTDI_VID, FTDI_PHI_FISCO_PID) }, | 696 | { USB_DEVICE(FTDI_VID, FTDI_PHI_FISCO_PID) }, |
| 696 | { USB_DEVICE(TML_VID, TML_USB_SERIAL_PID) }, | 697 | { USB_DEVICE(TML_VID, TML_USB_SERIAL_PID) }, |
| @@ -737,6 +738,14 @@ static struct usb_device_id id_table_combined [] = { | |||
| 737 | { USB_DEVICE(FTDI_VID, MJSG_SR_RADIO_PID) }, | 738 | { USB_DEVICE(FTDI_VID, MJSG_SR_RADIO_PID) }, |
| 738 | { USB_DEVICE(FTDI_VID, MJSG_HD_RADIO_PID) }, | 739 | { USB_DEVICE(FTDI_VID, MJSG_HD_RADIO_PID) }, |
| 739 | { USB_DEVICE(FTDI_VID, MJSG_XM_RADIO_PID) }, | 740 | { USB_DEVICE(FTDI_VID, MJSG_XM_RADIO_PID) }, |
| 741 | { USB_DEVICE(FTDI_VID, XVERVE_SIGNALYZER_ST_PID), | ||
| 742 | .driver_info = (kernel_ulong_t)&ftdi_jtag_quirk }, | ||
| 743 | { USB_DEVICE(FTDI_VID, XVERVE_SIGNALYZER_SLITE_PID), | ||
| 744 | .driver_info = (kernel_ulong_t)&ftdi_jtag_quirk }, | ||
| 745 | { USB_DEVICE(FTDI_VID, XVERVE_SIGNALYZER_SH2_PID), | ||
| 746 | .driver_info = (kernel_ulong_t)&ftdi_jtag_quirk }, | ||
| 747 | { USB_DEVICE(FTDI_VID, XVERVE_SIGNALYZER_SH4_PID), | ||
| 748 | .driver_info = (kernel_ulong_t)&ftdi_jtag_quirk }, | ||
| 740 | { }, /* Optional parameter entry */ | 749 | { }, /* Optional parameter entry */ |
| 741 | { } /* Terminating entry */ | 750 | { } /* Terminating entry */ |
| 742 | }; | 751 | }; |
diff --git a/drivers/usb/serial/ftdi_sio_ids.h b/drivers/usb/serial/ftdi_sio_ids.h index bbc159a1df45..d01946db8fac 100644 --- a/drivers/usb/serial/ftdi_sio_ids.h +++ b/drivers/usb/serial/ftdi_sio_ids.h | |||
| @@ -696,6 +696,12 @@ | |||
| 696 | #define TELLDUS_TELLSTICK_PID 0x0C30 /* RF control dongle 433 MHz using FT232RL */ | 696 | #define TELLDUS_TELLSTICK_PID 0x0C30 /* RF control dongle 433 MHz using FT232RL */ |
| 697 | 697 | ||
| 698 | /* | 698 | /* |
| 699 | * RT Systems programming cables for various ham radios | ||
| 700 | */ | ||
| 701 | #define RTSYSTEMS_VID 0x2100 /* Vendor ID */ | ||
| 702 | #define RTSYSTEMS_SERIAL_VX7_PID 0x9e52 /* Serial converter for VX-7 Radios using FT232RL */ | ||
| 703 | |||
| 704 | /* | ||
| 699 | * Bayer Ascensia Contour blood glucose meter USB-converter cable. | 705 | * Bayer Ascensia Contour blood glucose meter USB-converter cable. |
| 700 | * http://winglucofacts.com/cables/ | 706 | * http://winglucofacts.com/cables/ |
| 701 | */ | 707 | */ |
| @@ -1017,3 +1023,12 @@ | |||
| 1017 | #define MJSG_SR_RADIO_PID 0x9379 | 1023 | #define MJSG_SR_RADIO_PID 0x9379 |
| 1018 | #define MJSG_XM_RADIO_PID 0x937A | 1024 | #define MJSG_XM_RADIO_PID 0x937A |
| 1019 | #define MJSG_HD_RADIO_PID 0x937C | 1025 | #define MJSG_HD_RADIO_PID 0x937C |
| 1026 | |||
| 1027 | /* | ||
| 1028 | * Xverve Signalyzer tools (http://www.signalyzer.com/) | ||
| 1029 | */ | ||
| 1030 | #define XVERVE_SIGNALYZER_ST_PID 0xBCA0 | ||
| 1031 | #define XVERVE_SIGNALYZER_SLITE_PID 0xBCA1 | ||
| 1032 | #define XVERVE_SIGNALYZER_SH2_PID 0xBCA2 | ||
| 1033 | #define XVERVE_SIGNALYZER_SH4_PID 0xBCA4 | ||
| 1034 | |||
diff --git a/drivers/usb/serial/option.c b/drivers/usb/serial/option.c index e280ad8e12f7..5cd30e4345c6 100644 --- a/drivers/usb/serial/option.c +++ b/drivers/usb/serial/option.c | |||
| @@ -206,6 +206,7 @@ static void option_instat_callback(struct urb *urb); | |||
| 206 | #define AMOI_PRODUCT_H01 0x0800 | 206 | #define AMOI_PRODUCT_H01 0x0800 |
| 207 | #define AMOI_PRODUCT_H01A 0x7002 | 207 | #define AMOI_PRODUCT_H01A 0x7002 |
| 208 | #define AMOI_PRODUCT_H02 0x0802 | 208 | #define AMOI_PRODUCT_H02 0x0802 |
| 209 | #define AMOI_PRODUCT_SKYPEPHONE_S2 0x0407 | ||
| 209 | 210 | ||
| 210 | #define DELL_VENDOR_ID 0x413C | 211 | #define DELL_VENDOR_ID 0x413C |
| 211 | 212 | ||
| @@ -302,6 +303,7 @@ static void option_instat_callback(struct urb *urb); | |||
| 302 | #define QISDA_PRODUCT_H21_4512 0x4512 | 303 | #define QISDA_PRODUCT_H21_4512 0x4512 |
| 303 | #define QISDA_PRODUCT_H21_4523 0x4523 | 304 | #define QISDA_PRODUCT_H21_4523 0x4523 |
| 304 | #define QISDA_PRODUCT_H20_4515 0x4515 | 305 | #define QISDA_PRODUCT_H20_4515 0x4515 |
| 306 | #define QISDA_PRODUCT_H20_4518 0x4518 | ||
| 305 | #define QISDA_PRODUCT_H20_4519 0x4519 | 307 | #define QISDA_PRODUCT_H20_4519 0x4519 |
| 306 | 308 | ||
| 307 | /* TLAYTECH PRODUCTS */ | 309 | /* TLAYTECH PRODUCTS */ |
| @@ -516,6 +518,7 @@ static const struct usb_device_id option_ids[] = { | |||
| 516 | { USB_DEVICE(AMOI_VENDOR_ID, AMOI_PRODUCT_H01) }, | 518 | { USB_DEVICE(AMOI_VENDOR_ID, AMOI_PRODUCT_H01) }, |
| 517 | { USB_DEVICE(AMOI_VENDOR_ID, AMOI_PRODUCT_H01A) }, | 519 | { USB_DEVICE(AMOI_VENDOR_ID, AMOI_PRODUCT_H01A) }, |
| 518 | { USB_DEVICE(AMOI_VENDOR_ID, AMOI_PRODUCT_H02) }, | 520 | { USB_DEVICE(AMOI_VENDOR_ID, AMOI_PRODUCT_H02) }, |
| 521 | { USB_DEVICE(AMOI_VENDOR_ID, AMOI_PRODUCT_SKYPEPHONE_S2) }, | ||
| 519 | 522 | ||
| 520 | { USB_DEVICE(DELL_VENDOR_ID, DELL_PRODUCT_5700_MINICARD) }, /* Dell Wireless 5700 Mobile Broadband CDMA/EVDO Mini-Card == Novatel Expedite EV620 CDMA/EV-DO */ | 523 | { USB_DEVICE(DELL_VENDOR_ID, DELL_PRODUCT_5700_MINICARD) }, /* Dell Wireless 5700 Mobile Broadband CDMA/EVDO Mini-Card == Novatel Expedite EV620 CDMA/EV-DO */ |
| 521 | { USB_DEVICE(DELL_VENDOR_ID, DELL_PRODUCT_5500_MINICARD) }, /* Dell Wireless 5500 Mobile Broadband HSDPA Mini-Card == Novatel Expedite EU740 HSDPA/3G */ | 524 | { USB_DEVICE(DELL_VENDOR_ID, DELL_PRODUCT_5500_MINICARD) }, /* Dell Wireless 5500 Mobile Broadband HSDPA Mini-Card == Novatel Expedite EU740 HSDPA/3G */ |
| @@ -852,6 +855,7 @@ static const struct usb_device_id option_ids[] = { | |||
| 852 | { USB_DEVICE(QISDA_VENDOR_ID, QISDA_PRODUCT_H21_4512) }, | 855 | { USB_DEVICE(QISDA_VENDOR_ID, QISDA_PRODUCT_H21_4512) }, |
| 853 | { USB_DEVICE(QISDA_VENDOR_ID, QISDA_PRODUCT_H21_4523) }, | 856 | { USB_DEVICE(QISDA_VENDOR_ID, QISDA_PRODUCT_H21_4523) }, |
| 854 | { USB_DEVICE(QISDA_VENDOR_ID, QISDA_PRODUCT_H20_4515) }, | 857 | { USB_DEVICE(QISDA_VENDOR_ID, QISDA_PRODUCT_H20_4515) }, |
| 858 | { USB_DEVICE(QISDA_VENDOR_ID, QISDA_PRODUCT_H20_4518) }, | ||
| 855 | { USB_DEVICE(QISDA_VENDOR_ID, QISDA_PRODUCT_H20_4519) }, | 859 | { USB_DEVICE(QISDA_VENDOR_ID, QISDA_PRODUCT_H20_4519) }, |
| 856 | { USB_DEVICE(TOSHIBA_VENDOR_ID, TOSHIBA_PRODUCT_G450) }, | 860 | { USB_DEVICE(TOSHIBA_VENDOR_ID, TOSHIBA_PRODUCT_G450) }, |
| 857 | { USB_DEVICE(TOSHIBA_VENDOR_ID, TOSHIBA_PRODUCT_HSDPA_MINICARD ) }, /* Toshiba 3G HSDPA == Novatel Expedite EU870D MiniCard */ | 861 | { USB_DEVICE(TOSHIBA_VENDOR_ID, TOSHIBA_PRODUCT_HSDPA_MINICARD ) }, /* Toshiba 3G HSDPA == Novatel Expedite EU870D MiniCard */ |
diff --git a/drivers/usb/serial/qcserial.c b/drivers/usb/serial/qcserial.c index 93d72eb8cafc..cde67cacb2c3 100644 --- a/drivers/usb/serial/qcserial.c +++ b/drivers/usb/serial/qcserial.c | |||
| @@ -51,6 +51,8 @@ static const struct usb_device_id id_table[] = { | |||
| 51 | {USB_DEVICE(0x1f45, 0x0001)}, /* Unknown Gobi QDL device */ | 51 | {USB_DEVICE(0x1f45, 0x0001)}, /* Unknown Gobi QDL device */ |
| 52 | {USB_DEVICE(0x413c, 0x8185)}, /* Dell Gobi 2000 QDL device (N0218, VU936) */ | 52 | {USB_DEVICE(0x413c, 0x8185)}, /* Dell Gobi 2000 QDL device (N0218, VU936) */ |
| 53 | {USB_DEVICE(0x413c, 0x8186)}, /* Dell Gobi 2000 Modem device (N0218, VU936) */ | 53 | {USB_DEVICE(0x413c, 0x8186)}, /* Dell Gobi 2000 Modem device (N0218, VU936) */ |
| 54 | {USB_DEVICE(0x05c6, 0x9208)}, /* Generic Gobi 2000 QDL device */ | ||
| 55 | {USB_DEVICE(0x05c6, 0x920b)}, /* Generic Gobi 2000 Modem device */ | ||
| 54 | {USB_DEVICE(0x05c6, 0x9224)}, /* Sony Gobi 2000 QDL device (N0279, VU730) */ | 56 | {USB_DEVICE(0x05c6, 0x9224)}, /* Sony Gobi 2000 QDL device (N0279, VU730) */ |
| 55 | {USB_DEVICE(0x05c6, 0x9225)}, /* Sony Gobi 2000 Modem device (N0279, VU730) */ | 57 | {USB_DEVICE(0x05c6, 0x9225)}, /* Sony Gobi 2000 Modem device (N0279, VU730) */ |
| 56 | {USB_DEVICE(0x05c6, 0x9244)}, /* Samsung Gobi 2000 QDL device (VL176) */ | 58 | {USB_DEVICE(0x05c6, 0x9244)}, /* Samsung Gobi 2000 QDL device (VL176) */ |
diff --git a/drivers/usb/serial/sierra.c b/drivers/usb/serial/sierra.c index ef0bdb08d788..d47b56e9e8ce 100644 --- a/drivers/usb/serial/sierra.c +++ b/drivers/usb/serial/sierra.c | |||
| @@ -245,6 +245,7 @@ static const struct usb_device_id id_table[] = { | |||
| 245 | { USB_DEVICE(0x1199, 0x0021) }, /* Sierra Wireless AirCard 597E */ | 245 | { USB_DEVICE(0x1199, 0x0021) }, /* Sierra Wireless AirCard 597E */ |
| 246 | { USB_DEVICE(0x1199, 0x0112) }, /* Sierra Wireless AirCard 580 */ | 246 | { USB_DEVICE(0x1199, 0x0112) }, /* Sierra Wireless AirCard 580 */ |
| 247 | { USB_DEVICE(0x1199, 0x0120) }, /* Sierra Wireless USB Dongle 595U */ | 247 | { USB_DEVICE(0x1199, 0x0120) }, /* Sierra Wireless USB Dongle 595U */ |
| 248 | { USB_DEVICE(0x1199, 0x0301) }, /* Sierra Wireless USB Dongle 250U */ | ||
| 248 | /* Sierra Wireless C597 */ | 249 | /* Sierra Wireless C597 */ |
| 249 | { USB_DEVICE_AND_INTERFACE_INFO(0x1199, 0x0023, 0xFF, 0xFF, 0xFF) }, | 250 | { USB_DEVICE_AND_INTERFACE_INFO(0x1199, 0x0023, 0xFF, 0xFF, 0xFF) }, |
| 250 | /* Sierra Wireless T598 */ | 251 | /* Sierra Wireless T598 */ |
diff --git a/drivers/usb/storage/transport.c b/drivers/usb/storage/transport.c index 44716427c51c..64ec073e89de 100644 --- a/drivers/usb/storage/transport.c +++ b/drivers/usb/storage/transport.c | |||
| @@ -139,9 +139,7 @@ static int usb_stor_msg_common(struct us_data *us, int timeout) | |||
| 139 | 139 | ||
| 140 | /* fill the common fields in the URB */ | 140 | /* fill the common fields in the URB */ |
| 141 | us->current_urb->context = &urb_done; | 141 | us->current_urb->context = &urb_done; |
| 142 | us->current_urb->actual_length = 0; | 142 | us->current_urb->transfer_flags = 0; |
| 143 | us->current_urb->error_count = 0; | ||
| 144 | us->current_urb->status = 0; | ||
| 145 | 143 | ||
| 146 | /* we assume that if transfer_buffer isn't us->iobuf then it | 144 | /* we assume that if transfer_buffer isn't us->iobuf then it |
| 147 | * hasn't been mapped for DMA. Yes, this is clunky, but it's | 145 | * hasn't been mapped for DMA. Yes, this is clunky, but it's |
diff --git a/drivers/video/au1100fb.c b/drivers/video/au1100fb.c index 40f61320ce16..34b2fc472fe8 100644 --- a/drivers/video/au1100fb.c +++ b/drivers/video/au1100fb.c | |||
| @@ -95,7 +95,7 @@ struct fb_bitfield rgb_bitfields[][4] = | |||
| 95 | { { 8, 4, 0 }, { 4, 4, 0 }, { 0, 4, 0 }, { 0, 0, 0 } }, | 95 | { { 8, 4, 0 }, { 4, 4, 0 }, { 0, 4, 0 }, { 0, 0, 0 } }, |
| 96 | }; | 96 | }; |
| 97 | 97 | ||
| 98 | static struct fb_fix_screeninfo au1100fb_fix __initdata = { | 98 | static struct fb_fix_screeninfo au1100fb_fix __devinitdata = { |
| 99 | .id = "AU1100 FB", | 99 | .id = "AU1100 FB", |
| 100 | .xpanstep = 1, | 100 | .xpanstep = 1, |
| 101 | .ypanstep = 1, | 101 | .ypanstep = 1, |
| @@ -103,7 +103,7 @@ static struct fb_fix_screeninfo au1100fb_fix __initdata = { | |||
| 103 | .accel = FB_ACCEL_NONE, | 103 | .accel = FB_ACCEL_NONE, |
| 104 | }; | 104 | }; |
| 105 | 105 | ||
| 106 | static struct fb_var_screeninfo au1100fb_var __initdata = { | 106 | static struct fb_var_screeninfo au1100fb_var __devinitdata = { |
| 107 | .activate = FB_ACTIVATE_NOW, | 107 | .activate = FB_ACTIVATE_NOW, |
| 108 | .height = -1, | 108 | .height = -1, |
| 109 | .width = -1, | 109 | .width = -1, |
| @@ -458,7 +458,7 @@ static struct fb_ops au1100fb_ops = | |||
| 458 | 458 | ||
| 459 | /* AU1100 LCD controller device driver */ | 459 | /* AU1100 LCD controller device driver */ |
| 460 | 460 | ||
| 461 | static int __init au1100fb_drv_probe(struct platform_device *dev) | 461 | static int __devinit au1100fb_drv_probe(struct platform_device *dev) |
| 462 | { | 462 | { |
| 463 | struct au1100fb_device *fbdev = NULL; | 463 | struct au1100fb_device *fbdev = NULL; |
| 464 | struct resource *regs_res; | 464 | struct resource *regs_res; |
diff --git a/drivers/video/gbefb.c b/drivers/video/gbefb.c index 7d8c55d7fd28..ca3355e430bf 100644 --- a/drivers/video/gbefb.c +++ b/drivers/video/gbefb.c | |||
| @@ -91,10 +91,10 @@ static uint32_t pseudo_palette[16]; | |||
| 91 | static uint32_t gbe_cmap[256]; | 91 | static uint32_t gbe_cmap[256]; |
| 92 | static int gbe_turned_on; /* 0 turned off, 1 turned on */ | 92 | static int gbe_turned_on; /* 0 turned off, 1 turned on */ |
| 93 | 93 | ||
| 94 | static char *mode_option __initdata = NULL; | 94 | static char *mode_option __devinitdata = NULL; |
| 95 | 95 | ||
| 96 | /* default CRT mode */ | 96 | /* default CRT mode */ |
| 97 | static struct fb_var_screeninfo default_var_CRT __initdata = { | 97 | static struct fb_var_screeninfo default_var_CRT __devinitdata = { |
| 98 | /* 640x480, 60 Hz, Non-Interlaced (25.175 MHz dotclock) */ | 98 | /* 640x480, 60 Hz, Non-Interlaced (25.175 MHz dotclock) */ |
| 99 | .xres = 640, | 99 | .xres = 640, |
| 100 | .yres = 480, | 100 | .yres = 480, |
| @@ -125,7 +125,7 @@ static struct fb_var_screeninfo default_var_CRT __initdata = { | |||
| 125 | }; | 125 | }; |
| 126 | 126 | ||
| 127 | /* default LCD mode */ | 127 | /* default LCD mode */ |
| 128 | static struct fb_var_screeninfo default_var_LCD __initdata = { | 128 | static struct fb_var_screeninfo default_var_LCD __devinitdata = { |
| 129 | /* 1600x1024, 8 bpp */ | 129 | /* 1600x1024, 8 bpp */ |
| 130 | .xres = 1600, | 130 | .xres = 1600, |
| 131 | .yres = 1024, | 131 | .yres = 1024, |
| @@ -157,7 +157,7 @@ static struct fb_var_screeninfo default_var_LCD __initdata = { | |||
| 157 | 157 | ||
| 158 | /* default modedb mode */ | 158 | /* default modedb mode */ |
| 159 | /* 640x480, 60 Hz, Non-Interlaced (25.172 MHz dotclock) */ | 159 | /* 640x480, 60 Hz, Non-Interlaced (25.172 MHz dotclock) */ |
| 160 | static struct fb_videomode default_mode_CRT __initdata = { | 160 | static struct fb_videomode default_mode_CRT __devinitdata = { |
| 161 | .refresh = 60, | 161 | .refresh = 60, |
| 162 | .xres = 640, | 162 | .xres = 640, |
| 163 | .yres = 480, | 163 | .yres = 480, |
| @@ -172,7 +172,7 @@ static struct fb_videomode default_mode_CRT __initdata = { | |||
| 172 | .vmode = FB_VMODE_NONINTERLACED, | 172 | .vmode = FB_VMODE_NONINTERLACED, |
| 173 | }; | 173 | }; |
| 174 | /* 1600x1024 SGI flatpanel 1600sw */ | 174 | /* 1600x1024 SGI flatpanel 1600sw */ |
| 175 | static struct fb_videomode default_mode_LCD __initdata = { | 175 | static struct fb_videomode default_mode_LCD __devinitdata = { |
| 176 | /* 1600x1024, 8 bpp */ | 176 | /* 1600x1024, 8 bpp */ |
| 177 | .xres = 1600, | 177 | .xres = 1600, |
| 178 | .yres = 1024, | 178 | .yres = 1024, |
| @@ -186,8 +186,8 @@ static struct fb_videomode default_mode_LCD __initdata = { | |||
| 186 | .vmode = FB_VMODE_NONINTERLACED, | 186 | .vmode = FB_VMODE_NONINTERLACED, |
| 187 | }; | 187 | }; |
| 188 | 188 | ||
| 189 | static struct fb_videomode *default_mode __initdata = &default_mode_CRT; | 189 | static struct fb_videomode *default_mode __devinitdata = &default_mode_CRT; |
| 190 | static struct fb_var_screeninfo *default_var __initdata = &default_var_CRT; | 190 | static struct fb_var_screeninfo *default_var __devinitdata = &default_var_CRT; |
| 191 | 191 | ||
| 192 | static int flat_panel_enabled = 0; | 192 | static int flat_panel_enabled = 0; |
| 193 | 193 | ||
| @@ -1098,7 +1098,7 @@ static void gbefb_create_sysfs(struct device *dev) | |||
| 1098 | * Initialization | 1098 | * Initialization |
| 1099 | */ | 1099 | */ |
| 1100 | 1100 | ||
| 1101 | static int __init gbefb_setup(char *options) | 1101 | static int __devinit gbefb_setup(char *options) |
| 1102 | { | 1102 | { |
| 1103 | char *this_opt; | 1103 | char *this_opt; |
| 1104 | 1104 | ||
diff --git a/drivers/video/omap2/vram.c b/drivers/video/omap2/vram.c index 3b1237ad85ed..f6fdc2085f3e 100644 --- a/drivers/video/omap2/vram.c +++ b/drivers/video/omap2/vram.c | |||
| @@ -25,7 +25,7 @@ | |||
| 25 | #include <linux/list.h> | 25 | #include <linux/list.h> |
| 26 | #include <linux/slab.h> | 26 | #include <linux/slab.h> |
| 27 | #include <linux/seq_file.h> | 27 | #include <linux/seq_file.h> |
| 28 | #include <linux/bootmem.h> | 28 | #include <linux/memblock.h> |
| 29 | #include <linux/completion.h> | 29 | #include <linux/completion.h> |
| 30 | #include <linux/debugfs.h> | 30 | #include <linux/debugfs.h> |
| 31 | #include <linux/jiffies.h> | 31 | #include <linux/jiffies.h> |
| @@ -525,10 +525,8 @@ early_param("vram", omap_vram_early_vram); | |||
| 525 | * Called from map_io. We need to call to this early enough so that we | 525 | * Called from map_io. We need to call to this early enough so that we |
| 526 | * can reserve the fixed SDRAM regions before VM could get hold of them. | 526 | * can reserve the fixed SDRAM regions before VM could get hold of them. |
| 527 | */ | 527 | */ |
| 528 | void __init omap_vram_reserve_sdram(void) | 528 | void __init omap_vram_reserve_sdram_memblock(void) |
| 529 | { | 529 | { |
| 530 | struct bootmem_data *bdata; | ||
| 531 | unsigned long sdram_start, sdram_size; | ||
| 532 | u32 paddr; | 530 | u32 paddr; |
| 533 | u32 size = 0; | 531 | u32 size = 0; |
| 534 | 532 | ||
| @@ -555,29 +553,28 @@ void __init omap_vram_reserve_sdram(void) | |||
| 555 | 553 | ||
| 556 | size = PAGE_ALIGN(size); | 554 | size = PAGE_ALIGN(size); |
| 557 | 555 | ||
| 558 | bdata = NODE_DATA(0)->bdata; | ||
| 559 | sdram_start = bdata->node_min_pfn << PAGE_SHIFT; | ||
| 560 | sdram_size = (bdata->node_low_pfn << PAGE_SHIFT) - sdram_start; | ||
| 561 | |||
| 562 | if (paddr) { | 556 | if (paddr) { |
| 563 | if ((paddr & ~PAGE_MASK) || paddr < sdram_start || | 557 | struct memblock_property res; |
| 564 | paddr + size > sdram_start + sdram_size) { | 558 | |
| 559 | res.base = paddr; | ||
| 560 | res.size = size; | ||
| 561 | if ((paddr & ~PAGE_MASK) || memblock_find(&res) || | ||
| 562 | res.base != paddr || res.size != size) { | ||
| 565 | pr_err("Illegal SDRAM region for VRAM\n"); | 563 | pr_err("Illegal SDRAM region for VRAM\n"); |
| 566 | return; | 564 | return; |
| 567 | } | 565 | } |
| 568 | 566 | ||
| 569 | if (reserve_bootmem(paddr, size, BOOTMEM_EXCLUSIVE) < 0) { | 567 | if (memblock_is_region_reserved(paddr, size)) { |
| 570 | pr_err("FB: failed to reserve VRAM\n"); | 568 | pr_err("FB: failed to reserve VRAM - busy\n"); |
| 571 | return; | 569 | return; |
| 572 | } | 570 | } |
| 573 | } else { | 571 | |
| 574 | if (size > sdram_size) { | 572 | if (memblock_reserve(paddr, size) < 0) { |
| 575 | pr_err("Illegal SDRAM size for VRAM\n"); | 573 | pr_err("FB: failed to reserve VRAM - no memory\n"); |
| 576 | return; | 574 | return; |
| 577 | } | 575 | } |
| 578 | 576 | } else { | |
| 579 | paddr = virt_to_phys(alloc_bootmem_pages(size)); | 577 | paddr = memblock_alloc_base(size, PAGE_SIZE, MEMBLOCK_REAL_LIMIT); |
| 580 | BUG_ON(paddr & ~PAGE_MASK); | ||
| 581 | } | 578 | } |
| 582 | 579 | ||
| 583 | omap_vram_add_region(paddr, size); | 580 | omap_vram_add_region(paddr, size); |
diff --git a/drivers/video/pmag-ba-fb.c b/drivers/video/pmag-ba-fb.c index 0f361b6100d2..0c69fa20251b 100644 --- a/drivers/video/pmag-ba-fb.c +++ b/drivers/video/pmag-ba-fb.c | |||
| @@ -44,7 +44,7 @@ struct pmagbafb_par { | |||
| 44 | }; | 44 | }; |
| 45 | 45 | ||
| 46 | 46 | ||
| 47 | static struct fb_var_screeninfo pmagbafb_defined __initdata = { | 47 | static struct fb_var_screeninfo pmagbafb_defined __devinitdata = { |
| 48 | .xres = 1024, | 48 | .xres = 1024, |
| 49 | .yres = 864, | 49 | .yres = 864, |
| 50 | .xres_virtual = 1024, | 50 | .xres_virtual = 1024, |
| @@ -68,7 +68,7 @@ static struct fb_var_screeninfo pmagbafb_defined __initdata = { | |||
| 68 | .vmode = FB_VMODE_NONINTERLACED, | 68 | .vmode = FB_VMODE_NONINTERLACED, |
| 69 | }; | 69 | }; |
| 70 | 70 | ||
| 71 | static struct fb_fix_screeninfo pmagbafb_fix __initdata = { | 71 | static struct fb_fix_screeninfo pmagbafb_fix __devinitdata = { |
| 72 | .id = "PMAG-BA", | 72 | .id = "PMAG-BA", |
| 73 | .smem_len = (1024 * 1024), | 73 | .smem_len = (1024 * 1024), |
| 74 | .type = FB_TYPE_PACKED_PIXELS, | 74 | .type = FB_TYPE_PACKED_PIXELS, |
| @@ -142,7 +142,7 @@ static void __init pmagbafb_erase_cursor(struct fb_info *info) | |||
| 142 | } | 142 | } |
| 143 | 143 | ||
| 144 | 144 | ||
| 145 | static int __init pmagbafb_probe(struct device *dev) | 145 | static int __devinit pmagbafb_probe(struct device *dev) |
| 146 | { | 146 | { |
| 147 | struct tc_dev *tdev = to_tc_dev(dev); | 147 | struct tc_dev *tdev = to_tc_dev(dev); |
| 148 | resource_size_t start, len; | 148 | resource_size_t start, len; |
diff --git a/drivers/video/pmagb-b-fb.c b/drivers/video/pmagb-b-fb.c index 2de0806421b4..22fcb9a3d5c0 100644 --- a/drivers/video/pmagb-b-fb.c +++ b/drivers/video/pmagb-b-fb.c | |||
| @@ -45,7 +45,7 @@ struct pmagbbfb_par { | |||
| 45 | }; | 45 | }; |
| 46 | 46 | ||
| 47 | 47 | ||
| 48 | static struct fb_var_screeninfo pmagbbfb_defined __initdata = { | 48 | static struct fb_var_screeninfo pmagbbfb_defined __devinitdata = { |
| 49 | .bits_per_pixel = 8, | 49 | .bits_per_pixel = 8, |
| 50 | .red.length = 8, | 50 | .red.length = 8, |
| 51 | .green.length = 8, | 51 | .green.length = 8, |
| @@ -58,7 +58,7 @@ static struct fb_var_screeninfo pmagbbfb_defined __initdata = { | |||
| 58 | .vmode = FB_VMODE_NONINTERLACED, | 58 | .vmode = FB_VMODE_NONINTERLACED, |
| 59 | }; | 59 | }; |
| 60 | 60 | ||
| 61 | static struct fb_fix_screeninfo pmagbbfb_fix __initdata = { | 61 | static struct fb_fix_screeninfo pmagbbfb_fix __devinitdata = { |
| 62 | .id = "PMAGB-BA", | 62 | .id = "PMAGB-BA", |
| 63 | .smem_len = (2048 * 1024), | 63 | .smem_len = (2048 * 1024), |
| 64 | .type = FB_TYPE_PACKED_PIXELS, | 64 | .type = FB_TYPE_PACKED_PIXELS, |
| @@ -148,7 +148,7 @@ static void __init pmagbbfb_erase_cursor(struct fb_info *info) | |||
| 148 | /* | 148 | /* |
| 149 | * Set up screen parameters. | 149 | * Set up screen parameters. |
| 150 | */ | 150 | */ |
| 151 | static void __init pmagbbfb_screen_setup(struct fb_info *info) | 151 | static void __devinit pmagbbfb_screen_setup(struct fb_info *info) |
| 152 | { | 152 | { |
| 153 | struct pmagbbfb_par *par = info->par; | 153 | struct pmagbbfb_par *par = info->par; |
| 154 | 154 | ||
| @@ -180,9 +180,9 @@ static void __init pmagbbfb_screen_setup(struct fb_info *info) | |||
| 180 | /* | 180 | /* |
| 181 | * Determine oscillator configuration. | 181 | * Determine oscillator configuration. |
| 182 | */ | 182 | */ |
| 183 | static void __init pmagbbfb_osc_setup(struct fb_info *info) | 183 | static void __devinit pmagbbfb_osc_setup(struct fb_info *info) |
| 184 | { | 184 | { |
| 185 | static unsigned int pmagbbfb_freqs[] __initdata = { | 185 | static unsigned int pmagbbfb_freqs[] __devinitdata = { |
| 186 | 130808, 119843, 104000, 92980, 74370, 72800, | 186 | 130808, 119843, 104000, 92980, 74370, 72800, |
| 187 | 69197, 66000, 65000, 50350, 36000, 32000, 25175 | 187 | 69197, 66000, 65000, 50350, 36000, 32000, 25175 |
| 188 | }; | 188 | }; |
| @@ -247,7 +247,7 @@ static void __init pmagbbfb_osc_setup(struct fb_info *info) | |||
| 247 | }; | 247 | }; |
| 248 | 248 | ||
| 249 | 249 | ||
| 250 | static int __init pmagbbfb_probe(struct device *dev) | 250 | static int __devinit pmagbbfb_probe(struct device *dev) |
| 251 | { | 251 | { |
| 252 | struct tc_dev *tdev = to_tc_dev(dev); | 252 | struct tc_dev *tdev = to_tc_dev(dev); |
| 253 | resource_size_t start, len; | 253 | resource_size_t start, len; |
diff --git a/drivers/virtio/virtio_ring.c b/drivers/virtio/virtio_ring.c index afe7e21dd0ae..1475ed6b575f 100644 --- a/drivers/virtio/virtio_ring.c +++ b/drivers/virtio/virtio_ring.c | |||
| @@ -164,7 +164,8 @@ int virtqueue_add_buf_gfp(struct virtqueue *_vq, | |||
| 164 | gfp_t gfp) | 164 | gfp_t gfp) |
| 165 | { | 165 | { |
| 166 | struct vring_virtqueue *vq = to_vvq(_vq); | 166 | struct vring_virtqueue *vq = to_vvq(_vq); |
| 167 | unsigned int i, avail, head, uninitialized_var(prev); | 167 | unsigned int i, avail, uninitialized_var(prev); |
| 168 | int head; | ||
| 168 | 169 | ||
| 169 | START_USE(vq); | 170 | START_USE(vq); |
| 170 | 171 | ||
| @@ -174,7 +175,7 @@ int virtqueue_add_buf_gfp(struct virtqueue *_vq, | |||
| 174 | * buffers, then go indirect. FIXME: tune this threshold */ | 175 | * buffers, then go indirect. FIXME: tune this threshold */ |
| 175 | if (vq->indirect && (out + in) > 1 && vq->num_free) { | 176 | if (vq->indirect && (out + in) > 1 && vq->num_free) { |
| 176 | head = vring_add_indirect(vq, sg, out, in, gfp); | 177 | head = vring_add_indirect(vq, sg, out, in, gfp); |
| 177 | if (head != vq->vring.num) | 178 | if (likely(head >= 0)) |
| 178 | goto add_head; | 179 | goto add_head; |
| 179 | } | 180 | } |
| 180 | 181 | ||
diff --git a/fs/9p/vfs_dir.c b/fs/9p/vfs_dir.c index d61e3b28ce37..36d961f342af 100644 --- a/fs/9p/vfs_dir.c +++ b/fs/9p/vfs_dir.c | |||
| @@ -146,7 +146,7 @@ static int v9fs_dir_readdir(struct file *filp, void *dirent, filldir_t filldir) | |||
| 146 | while (rdir->head < rdir->tail) { | 146 | while (rdir->head < rdir->tail) { |
| 147 | p9stat_init(&st); | 147 | p9stat_init(&st); |
| 148 | err = p9stat_read(rdir->buf + rdir->head, | 148 | err = p9stat_read(rdir->buf + rdir->head, |
| 149 | buflen - rdir->head, &st, | 149 | rdir->tail - rdir->head, &st, |
| 150 | fid->clnt->proto_version); | 150 | fid->clnt->proto_version); |
| 151 | if (err) { | 151 | if (err) { |
| 152 | P9_DPRINTK(P9_DEBUG_VFS, "returned %d\n", err); | 152 | P9_DPRINTK(P9_DEBUG_VFS, "returned %d\n", err); |
diff --git a/fs/ceph/Kconfig b/fs/ceph/Kconfig index 04b8280582a9..bc87b9c1d27e 100644 --- a/fs/ceph/Kconfig +++ b/fs/ceph/Kconfig | |||
| @@ -2,7 +2,7 @@ config CEPH_FS | |||
| 2 | tristate "Ceph distributed file system (EXPERIMENTAL)" | 2 | tristate "Ceph distributed file system (EXPERIMENTAL)" |
| 3 | depends on INET && EXPERIMENTAL | 3 | depends on INET && EXPERIMENTAL |
| 4 | select LIBCRC32C | 4 | select LIBCRC32C |
| 5 | select CONFIG_CRYPTO_AES | 5 | select CRYPTO_AES |
| 6 | help | 6 | help |
| 7 | Choose Y or M here to include support for mounting the | 7 | Choose Y or M here to include support for mounting the |
| 8 | experimental Ceph distributed file system. Ceph is an extremely | 8 | experimental Ceph distributed file system. Ceph is an extremely |
diff --git a/fs/ceph/caps.c b/fs/ceph/caps.c index 74144d6389f0..b81be9a56487 100644 --- a/fs/ceph/caps.c +++ b/fs/ceph/caps.c | |||
| @@ -627,7 +627,7 @@ retry: | |||
| 627 | if (fmode >= 0) | 627 | if (fmode >= 0) |
| 628 | __ceph_get_fmode(ci, fmode); | 628 | __ceph_get_fmode(ci, fmode); |
| 629 | spin_unlock(&inode->i_lock); | 629 | spin_unlock(&inode->i_lock); |
| 630 | wake_up(&ci->i_cap_wq); | 630 | wake_up_all(&ci->i_cap_wq); |
| 631 | return 0; | 631 | return 0; |
| 632 | } | 632 | } |
| 633 | 633 | ||
| @@ -1181,7 +1181,7 @@ static int __send_cap(struct ceph_mds_client *mdsc, struct ceph_cap *cap, | |||
| 1181 | } | 1181 | } |
| 1182 | 1182 | ||
| 1183 | if (wake) | 1183 | if (wake) |
| 1184 | wake_up(&ci->i_cap_wq); | 1184 | wake_up_all(&ci->i_cap_wq); |
| 1185 | 1185 | ||
| 1186 | return delayed; | 1186 | return delayed; |
| 1187 | } | 1187 | } |
| @@ -2153,7 +2153,7 @@ void ceph_put_cap_refs(struct ceph_inode_info *ci, int had) | |||
| 2153 | else if (flushsnaps) | 2153 | else if (flushsnaps) |
| 2154 | ceph_flush_snaps(ci); | 2154 | ceph_flush_snaps(ci); |
| 2155 | if (wake) | 2155 | if (wake) |
| 2156 | wake_up(&ci->i_cap_wq); | 2156 | wake_up_all(&ci->i_cap_wq); |
| 2157 | if (put) | 2157 | if (put) |
| 2158 | iput(inode); | 2158 | iput(inode); |
| 2159 | } | 2159 | } |
| @@ -2229,7 +2229,7 @@ void ceph_put_wrbuffer_cap_refs(struct ceph_inode_info *ci, int nr, | |||
| 2229 | iput(inode); | 2229 | iput(inode); |
| 2230 | } else if (complete_capsnap) { | 2230 | } else if (complete_capsnap) { |
| 2231 | ceph_flush_snaps(ci); | 2231 | ceph_flush_snaps(ci); |
| 2232 | wake_up(&ci->i_cap_wq); | 2232 | wake_up_all(&ci->i_cap_wq); |
| 2233 | } | 2233 | } |
| 2234 | if (drop_capsnap) | 2234 | if (drop_capsnap) |
| 2235 | iput(inode); | 2235 | iput(inode); |
| @@ -2405,7 +2405,7 @@ static void handle_cap_grant(struct inode *inode, struct ceph_mds_caps *grant, | |||
| 2405 | if (queue_invalidate) | 2405 | if (queue_invalidate) |
| 2406 | ceph_queue_invalidate(inode); | 2406 | ceph_queue_invalidate(inode); |
| 2407 | if (wake) | 2407 | if (wake) |
| 2408 | wake_up(&ci->i_cap_wq); | 2408 | wake_up_all(&ci->i_cap_wq); |
| 2409 | 2409 | ||
| 2410 | if (check_caps == 1) | 2410 | if (check_caps == 1) |
| 2411 | ceph_check_caps(ci, CHECK_CAPS_NODELAY|CHECK_CAPS_AUTHONLY, | 2411 | ceph_check_caps(ci, CHECK_CAPS_NODELAY|CHECK_CAPS_AUTHONLY, |
| @@ -2460,7 +2460,7 @@ static void handle_cap_flush_ack(struct inode *inode, u64 flush_tid, | |||
| 2460 | struct ceph_inode_info, | 2460 | struct ceph_inode_info, |
| 2461 | i_flushing_item)->vfs_inode); | 2461 | i_flushing_item)->vfs_inode); |
| 2462 | mdsc->num_cap_flushing--; | 2462 | mdsc->num_cap_flushing--; |
| 2463 | wake_up(&mdsc->cap_flushing_wq); | 2463 | wake_up_all(&mdsc->cap_flushing_wq); |
| 2464 | dout(" inode %p now !flushing\n", inode); | 2464 | dout(" inode %p now !flushing\n", inode); |
| 2465 | 2465 | ||
| 2466 | if (ci->i_dirty_caps == 0) { | 2466 | if (ci->i_dirty_caps == 0) { |
| @@ -2472,7 +2472,7 @@ static void handle_cap_flush_ack(struct inode *inode, u64 flush_tid, | |||
| 2472 | } | 2472 | } |
| 2473 | } | 2473 | } |
| 2474 | spin_unlock(&mdsc->cap_dirty_lock); | 2474 | spin_unlock(&mdsc->cap_dirty_lock); |
| 2475 | wake_up(&ci->i_cap_wq); | 2475 | wake_up_all(&ci->i_cap_wq); |
| 2476 | 2476 | ||
| 2477 | out: | 2477 | out: |
| 2478 | spin_unlock(&inode->i_lock); | 2478 | spin_unlock(&inode->i_lock); |
| @@ -2984,6 +2984,7 @@ int ceph_encode_dentry_release(void **p, struct dentry *dentry, | |||
| 2984 | memcpy(*p, dentry->d_name.name, dentry->d_name.len); | 2984 | memcpy(*p, dentry->d_name.name, dentry->d_name.len); |
| 2985 | *p += dentry->d_name.len; | 2985 | *p += dentry->d_name.len; |
| 2986 | rel->dname_seq = cpu_to_le32(di->lease_seq); | 2986 | rel->dname_seq = cpu_to_le32(di->lease_seq); |
| 2987 | __ceph_mdsc_drop_dentry_lease(dentry); | ||
| 2987 | } | 2988 | } |
| 2988 | spin_unlock(&dentry->d_lock); | 2989 | spin_unlock(&dentry->d_lock); |
| 2989 | return ret; | 2990 | return ret; |
diff --git a/fs/ceph/dir.c b/fs/ceph/dir.c index f85719310db2..f94ed3c7f6a5 100644 --- a/fs/ceph/dir.c +++ b/fs/ceph/dir.c | |||
| @@ -266,6 +266,7 @@ static int ceph_readdir(struct file *filp, void *dirent, filldir_t filldir) | |||
| 266 | spin_lock(&inode->i_lock); | 266 | spin_lock(&inode->i_lock); |
| 267 | if ((filp->f_pos == 2 || fi->dentry) && | 267 | if ((filp->f_pos == 2 || fi->dentry) && |
| 268 | !ceph_test_opt(client, NOASYNCREADDIR) && | 268 | !ceph_test_opt(client, NOASYNCREADDIR) && |
| 269 | ceph_snap(inode) != CEPH_SNAPDIR && | ||
| 269 | (ci->i_ceph_flags & CEPH_I_COMPLETE) && | 270 | (ci->i_ceph_flags & CEPH_I_COMPLETE) && |
| 270 | __ceph_caps_issued_mask(ci, CEPH_CAP_FILE_SHARED, 1)) { | 271 | __ceph_caps_issued_mask(ci, CEPH_CAP_FILE_SHARED, 1)) { |
| 271 | err = __dcache_readdir(filp, dirent, filldir); | 272 | err = __dcache_readdir(filp, dirent, filldir); |
| @@ -1013,18 +1014,22 @@ out_touch: | |||
| 1013 | 1014 | ||
| 1014 | /* | 1015 | /* |
| 1015 | * When a dentry is released, clear the dir I_COMPLETE if it was part | 1016 | * When a dentry is released, clear the dir I_COMPLETE if it was part |
| 1016 | * of the current dir gen. | 1017 | * of the current dir gen or if this is in the snapshot namespace. |
| 1017 | */ | 1018 | */ |
| 1018 | static void ceph_dentry_release(struct dentry *dentry) | 1019 | static void ceph_dentry_release(struct dentry *dentry) |
| 1019 | { | 1020 | { |
| 1020 | struct ceph_dentry_info *di = ceph_dentry(dentry); | 1021 | struct ceph_dentry_info *di = ceph_dentry(dentry); |
| 1021 | struct inode *parent_inode = dentry->d_parent->d_inode; | 1022 | struct inode *parent_inode = dentry->d_parent->d_inode; |
| 1023 | u64 snapid = ceph_snap(parent_inode); | ||
| 1022 | 1024 | ||
| 1023 | if (parent_inode) { | 1025 | dout("dentry_release %p parent %p\n", dentry, parent_inode); |
| 1026 | |||
| 1027 | if (parent_inode && snapid != CEPH_SNAPDIR) { | ||
| 1024 | struct ceph_inode_info *ci = ceph_inode(parent_inode); | 1028 | struct ceph_inode_info *ci = ceph_inode(parent_inode); |
| 1025 | 1029 | ||
| 1026 | spin_lock(&parent_inode->i_lock); | 1030 | spin_lock(&parent_inode->i_lock); |
| 1027 | if (ci->i_shared_gen == di->lease_shared_gen) { | 1031 | if (ci->i_shared_gen == di->lease_shared_gen || |
| 1032 | snapid <= CEPH_MAXSNAP) { | ||
| 1028 | dout(" clearing %p complete (d_release)\n", | 1033 | dout(" clearing %p complete (d_release)\n", |
| 1029 | parent_inode); | 1034 | parent_inode); |
| 1030 | ci->i_ceph_flags &= ~CEPH_I_COMPLETE; | 1035 | ci->i_ceph_flags &= ~CEPH_I_COMPLETE; |
| @@ -1241,7 +1246,9 @@ struct dentry_operations ceph_dentry_ops = { | |||
| 1241 | 1246 | ||
| 1242 | struct dentry_operations ceph_snapdir_dentry_ops = { | 1247 | struct dentry_operations ceph_snapdir_dentry_ops = { |
| 1243 | .d_revalidate = ceph_snapdir_d_revalidate, | 1248 | .d_revalidate = ceph_snapdir_d_revalidate, |
| 1249 | .d_release = ceph_dentry_release, | ||
| 1244 | }; | 1250 | }; |
| 1245 | 1251 | ||
| 1246 | struct dentry_operations ceph_snap_dentry_ops = { | 1252 | struct dentry_operations ceph_snap_dentry_ops = { |
| 1253 | .d_release = ceph_dentry_release, | ||
| 1247 | }; | 1254 | }; |
diff --git a/fs/ceph/file.c b/fs/ceph/file.c index 6251a1574b94..7c08698fad3e 100644 --- a/fs/ceph/file.c +++ b/fs/ceph/file.c | |||
| @@ -265,7 +265,7 @@ int ceph_release(struct inode *inode, struct file *file) | |||
| 265 | kmem_cache_free(ceph_file_cachep, cf); | 265 | kmem_cache_free(ceph_file_cachep, cf); |
| 266 | 266 | ||
| 267 | /* wake up anyone waiting for caps on this inode */ | 267 | /* wake up anyone waiting for caps on this inode */ |
| 268 | wake_up(&ci->i_cap_wq); | 268 | wake_up_all(&ci->i_cap_wq); |
| 269 | return 0; | 269 | return 0; |
| 270 | } | 270 | } |
| 271 | 271 | ||
diff --git a/fs/ceph/inode.c b/fs/ceph/inode.c index 8f9b9fe8ef9f..389f9dbd9949 100644 --- a/fs/ceph/inode.c +++ b/fs/ceph/inode.c | |||
| @@ -1199,8 +1199,10 @@ retry_lookup: | |||
| 1199 | goto out; | 1199 | goto out; |
| 1200 | } | 1200 | } |
| 1201 | err = ceph_init_dentry(dn); | 1201 | err = ceph_init_dentry(dn); |
| 1202 | if (err < 0) | 1202 | if (err < 0) { |
| 1203 | dput(dn); | ||
| 1203 | goto out; | 1204 | goto out; |
| 1205 | } | ||
| 1204 | } else if (dn->d_inode && | 1206 | } else if (dn->d_inode && |
| 1205 | (ceph_ino(dn->d_inode) != vino.ino || | 1207 | (ceph_ino(dn->d_inode) != vino.ino || |
| 1206 | ceph_snap(dn->d_inode) != vino.snap)) { | 1208 | ceph_snap(dn->d_inode) != vino.snap)) { |
| @@ -1499,7 +1501,7 @@ retry: | |||
| 1499 | if (wrbuffer_refs == 0) | 1501 | if (wrbuffer_refs == 0) |
| 1500 | ceph_check_caps(ci, CHECK_CAPS_AUTHONLY, NULL); | 1502 | ceph_check_caps(ci, CHECK_CAPS_AUTHONLY, NULL); |
| 1501 | if (wake) | 1503 | if (wake) |
| 1502 | wake_up(&ci->i_cap_wq); | 1504 | wake_up_all(&ci->i_cap_wq); |
| 1503 | } | 1505 | } |
| 1504 | 1506 | ||
| 1505 | 1507 | ||
diff --git a/fs/ceph/mds_client.c b/fs/ceph/mds_client.c index 416c08d315db..dd440bd438a9 100644 --- a/fs/ceph/mds_client.c +++ b/fs/ceph/mds_client.c | |||
| @@ -868,7 +868,7 @@ static int wake_up_session_cb(struct inode *inode, struct ceph_cap *cap, | |||
| 868 | { | 868 | { |
| 869 | struct ceph_inode_info *ci = ceph_inode(inode); | 869 | struct ceph_inode_info *ci = ceph_inode(inode); |
| 870 | 870 | ||
| 871 | wake_up(&ci->i_cap_wq); | 871 | wake_up_all(&ci->i_cap_wq); |
| 872 | if (arg) { | 872 | if (arg) { |
| 873 | spin_lock(&inode->i_lock); | 873 | spin_lock(&inode->i_lock); |
| 874 | ci->i_wanted_max_size = 0; | 874 | ci->i_wanted_max_size = 0; |
| @@ -1564,7 +1564,7 @@ static void complete_request(struct ceph_mds_client *mdsc, | |||
| 1564 | if (req->r_callback) | 1564 | if (req->r_callback) |
| 1565 | req->r_callback(mdsc, req); | 1565 | req->r_callback(mdsc, req); |
| 1566 | else | 1566 | else |
| 1567 | complete(&req->r_completion); | 1567 | complete_all(&req->r_completion); |
| 1568 | } | 1568 | } |
| 1569 | 1569 | ||
| 1570 | /* | 1570 | /* |
| @@ -1932,7 +1932,7 @@ static void handle_reply(struct ceph_mds_session *session, struct ceph_msg *msg) | |||
| 1932 | if (head->safe) { | 1932 | if (head->safe) { |
| 1933 | req->r_got_safe = true; | 1933 | req->r_got_safe = true; |
| 1934 | __unregister_request(mdsc, req); | 1934 | __unregister_request(mdsc, req); |
| 1935 | complete(&req->r_safe_completion); | 1935 | complete_all(&req->r_safe_completion); |
| 1936 | 1936 | ||
| 1937 | if (req->r_got_unsafe) { | 1937 | if (req->r_got_unsafe) { |
| 1938 | /* | 1938 | /* |
| @@ -1947,7 +1947,7 @@ static void handle_reply(struct ceph_mds_session *session, struct ceph_msg *msg) | |||
| 1947 | 1947 | ||
| 1948 | /* last unsafe request during umount? */ | 1948 | /* last unsafe request during umount? */ |
| 1949 | if (mdsc->stopping && !__get_oldest_req(mdsc)) | 1949 | if (mdsc->stopping && !__get_oldest_req(mdsc)) |
| 1950 | complete(&mdsc->safe_umount_waiters); | 1950 | complete_all(&mdsc->safe_umount_waiters); |
| 1951 | mutex_unlock(&mdsc->mutex); | 1951 | mutex_unlock(&mdsc->mutex); |
| 1952 | goto out; | 1952 | goto out; |
| 1953 | } | 1953 | } |
| @@ -2126,7 +2126,7 @@ static void handle_session(struct ceph_mds_session *session, | |||
| 2126 | pr_info("mds%d reconnect denied\n", session->s_mds); | 2126 | pr_info("mds%d reconnect denied\n", session->s_mds); |
| 2127 | remove_session_caps(session); | 2127 | remove_session_caps(session); |
| 2128 | wake = 1; /* for good measure */ | 2128 | wake = 1; /* for good measure */ |
| 2129 | complete(&mdsc->session_close_waiters); | 2129 | complete_all(&mdsc->session_close_waiters); |
| 2130 | kick_requests(mdsc, mds); | 2130 | kick_requests(mdsc, mds); |
| 2131 | break; | 2131 | break; |
| 2132 | 2132 | ||
diff --git a/fs/ceph/mon_client.c b/fs/ceph/mon_client.c index cc115eafae11..54fe01c50706 100644 --- a/fs/ceph/mon_client.c +++ b/fs/ceph/mon_client.c | |||
| @@ -345,7 +345,7 @@ static void ceph_monc_handle_map(struct ceph_mon_client *monc, | |||
| 345 | 345 | ||
| 346 | out: | 346 | out: |
| 347 | mutex_unlock(&monc->mutex); | 347 | mutex_unlock(&monc->mutex); |
| 348 | wake_up(&client->auth_wq); | 348 | wake_up_all(&client->auth_wq); |
| 349 | } | 349 | } |
| 350 | 350 | ||
| 351 | /* | 351 | /* |
| @@ -462,7 +462,7 @@ static void handle_statfs_reply(struct ceph_mon_client *monc, | |||
| 462 | } | 462 | } |
| 463 | mutex_unlock(&monc->mutex); | 463 | mutex_unlock(&monc->mutex); |
| 464 | if (req) { | 464 | if (req) { |
| 465 | complete(&req->completion); | 465 | complete_all(&req->completion); |
| 466 | put_generic_request(req); | 466 | put_generic_request(req); |
| 467 | } | 467 | } |
| 468 | return; | 468 | return; |
| @@ -718,7 +718,7 @@ static void handle_auth_reply(struct ceph_mon_client *monc, | |||
| 718 | monc->m_auth->front_max); | 718 | monc->m_auth->front_max); |
| 719 | if (ret < 0) { | 719 | if (ret < 0) { |
| 720 | monc->client->auth_err = ret; | 720 | monc->client->auth_err = ret; |
| 721 | wake_up(&monc->client->auth_wq); | 721 | wake_up_all(&monc->client->auth_wq); |
| 722 | } else if (ret > 0) { | 722 | } else if (ret > 0) { |
| 723 | __send_prepared_auth_request(monc, ret); | 723 | __send_prepared_auth_request(monc, ret); |
| 724 | } else if (!was_auth && monc->auth->ops->is_authenticated(monc->auth)) { | 724 | } else if (!was_auth && monc->auth->ops->is_authenticated(monc->auth)) { |
diff --git a/fs/ceph/osd_client.c b/fs/ceph/osd_client.c index 92b7251a53f1..e38522347898 100644 --- a/fs/ceph/osd_client.c +++ b/fs/ceph/osd_client.c | |||
| @@ -862,12 +862,12 @@ static void handle_reply(struct ceph_osd_client *osdc, struct ceph_msg *msg, | |||
| 862 | if (req->r_callback) | 862 | if (req->r_callback) |
| 863 | req->r_callback(req, msg); | 863 | req->r_callback(req, msg); |
| 864 | else | 864 | else |
| 865 | complete(&req->r_completion); | 865 | complete_all(&req->r_completion); |
| 866 | 866 | ||
| 867 | if (flags & CEPH_OSD_FLAG_ONDISK) { | 867 | if (flags & CEPH_OSD_FLAG_ONDISK) { |
| 868 | if (req->r_safe_callback) | 868 | if (req->r_safe_callback) |
| 869 | req->r_safe_callback(req, msg); | 869 | req->r_safe_callback(req, msg); |
| 870 | complete(&req->r_safe_completion); /* fsync waiter */ | 870 | complete_all(&req->r_safe_completion); /* fsync waiter */ |
| 871 | } | 871 | } |
| 872 | 872 | ||
| 873 | done: | 873 | done: |
| @@ -1083,7 +1083,7 @@ done: | |||
| 1083 | if (newmap) | 1083 | if (newmap) |
| 1084 | kick_requests(osdc, NULL); | 1084 | kick_requests(osdc, NULL); |
| 1085 | up_read(&osdc->map_sem); | 1085 | up_read(&osdc->map_sem); |
| 1086 | wake_up(&osdc->client->auth_wq); | 1086 | wake_up_all(&osdc->client->auth_wq); |
| 1087 | return; | 1087 | return; |
| 1088 | 1088 | ||
| 1089 | bad: | 1089 | bad: |
diff --git a/fs/ceph/osdmap.c b/fs/ceph/osdmap.c index 277f8b339577..416d46adbf87 100644 --- a/fs/ceph/osdmap.c +++ b/fs/ceph/osdmap.c | |||
| @@ -831,12 +831,13 @@ struct ceph_osdmap *osdmap_apply_incremental(void **p, void *end, | |||
| 831 | /* remove any? */ | 831 | /* remove any? */ |
| 832 | while (rbp && pgid_cmp(rb_entry(rbp, struct ceph_pg_mapping, | 832 | while (rbp && pgid_cmp(rb_entry(rbp, struct ceph_pg_mapping, |
| 833 | node)->pgid, pgid) <= 0) { | 833 | node)->pgid, pgid) <= 0) { |
| 834 | struct rb_node *cur = rbp; | 834 | struct ceph_pg_mapping *cur = |
| 835 | rb_entry(rbp, struct ceph_pg_mapping, node); | ||
| 836 | |||
| 835 | rbp = rb_next(rbp); | 837 | rbp = rb_next(rbp); |
| 836 | dout(" removed pg_temp %llx\n", | 838 | dout(" removed pg_temp %llx\n", *(u64 *)&cur->pgid); |
| 837 | *(u64 *)&rb_entry(cur, struct ceph_pg_mapping, | 839 | rb_erase(&cur->node, &map->pg_temp); |
| 838 | node)->pgid); | 840 | kfree(cur); |
| 839 | rb_erase(cur, &map->pg_temp); | ||
| 840 | } | 841 | } |
| 841 | 842 | ||
| 842 | if (pglen) { | 843 | if (pglen) { |
| @@ -852,19 +853,22 @@ struct ceph_osdmap *osdmap_apply_incremental(void **p, void *end, | |||
| 852 | for (j = 0; j < pglen; j++) | 853 | for (j = 0; j < pglen; j++) |
| 853 | pg->osds[j] = ceph_decode_32(p); | 854 | pg->osds[j] = ceph_decode_32(p); |
| 854 | err = __insert_pg_mapping(pg, &map->pg_temp); | 855 | err = __insert_pg_mapping(pg, &map->pg_temp); |
| 855 | if (err) | 856 | if (err) { |
| 857 | kfree(pg); | ||
| 856 | goto bad; | 858 | goto bad; |
| 859 | } | ||
| 857 | dout(" added pg_temp %llx len %d\n", *(u64 *)&pgid, | 860 | dout(" added pg_temp %llx len %d\n", *(u64 *)&pgid, |
| 858 | pglen); | 861 | pglen); |
| 859 | } | 862 | } |
| 860 | } | 863 | } |
| 861 | while (rbp) { | 864 | while (rbp) { |
| 862 | struct rb_node *cur = rbp; | 865 | struct ceph_pg_mapping *cur = |
| 866 | rb_entry(rbp, struct ceph_pg_mapping, node); | ||
| 867 | |||
| 863 | rbp = rb_next(rbp); | 868 | rbp = rb_next(rbp); |
| 864 | dout(" removed pg_temp %llx\n", | 869 | dout(" removed pg_temp %llx\n", *(u64 *)&cur->pgid); |
| 865 | *(u64 *)&rb_entry(cur, struct ceph_pg_mapping, | 870 | rb_erase(&cur->node, &map->pg_temp); |
| 866 | node)->pgid); | 871 | kfree(cur); |
| 867 | rb_erase(cur, &map->pg_temp); | ||
| 868 | } | 872 | } |
| 869 | 873 | ||
| 870 | /* ignore the rest */ | 874 | /* ignore the rest */ |
diff --git a/fs/cifs/cifsfs.c b/fs/cifs/cifsfs.c index 484e52bb40bb..2cb1a70214d7 100644 --- a/fs/cifs/cifsfs.c +++ b/fs/cifs/cifsfs.c | |||
| @@ -923,7 +923,7 @@ init_cifs(void) | |||
| 923 | goto out_unregister_filesystem; | 923 | goto out_unregister_filesystem; |
| 924 | #endif | 924 | #endif |
| 925 | #ifdef CONFIG_CIFS_DFS_UPCALL | 925 | #ifdef CONFIG_CIFS_DFS_UPCALL |
| 926 | rc = register_key_type(&key_type_dns_resolver); | 926 | rc = cifs_init_dns_resolver(); |
| 927 | if (rc) | 927 | if (rc) |
| 928 | goto out_unregister_key_type; | 928 | goto out_unregister_key_type; |
| 929 | #endif | 929 | #endif |
| @@ -935,7 +935,7 @@ init_cifs(void) | |||
| 935 | 935 | ||
| 936 | out_unregister_resolver_key: | 936 | out_unregister_resolver_key: |
| 937 | #ifdef CONFIG_CIFS_DFS_UPCALL | 937 | #ifdef CONFIG_CIFS_DFS_UPCALL |
| 938 | unregister_key_type(&key_type_dns_resolver); | 938 | cifs_exit_dns_resolver(); |
| 939 | out_unregister_key_type: | 939 | out_unregister_key_type: |
| 940 | #endif | 940 | #endif |
| 941 | #ifdef CONFIG_CIFS_UPCALL | 941 | #ifdef CONFIG_CIFS_UPCALL |
| @@ -961,7 +961,7 @@ exit_cifs(void) | |||
| 961 | cifs_proc_clean(); | 961 | cifs_proc_clean(); |
| 962 | #ifdef CONFIG_CIFS_DFS_UPCALL | 962 | #ifdef CONFIG_CIFS_DFS_UPCALL |
| 963 | cifs_dfs_release_automount_timer(); | 963 | cifs_dfs_release_automount_timer(); |
| 964 | unregister_key_type(&key_type_dns_resolver); | 964 | cifs_exit_dns_resolver(); |
| 965 | #endif | 965 | #endif |
| 966 | #ifdef CONFIG_CIFS_UPCALL | 966 | #ifdef CONFIG_CIFS_UPCALL |
| 967 | unregister_key_type(&cifs_spnego_key_type); | 967 | unregister_key_type(&cifs_spnego_key_type); |
diff --git a/fs/cifs/dns_resolve.c b/fs/cifs/dns_resolve.c index 4db2c5e7283f..49315cbf742d 100644 --- a/fs/cifs/dns_resolve.c +++ b/fs/cifs/dns_resolve.c | |||
| @@ -24,12 +24,16 @@ | |||
| 24 | */ | 24 | */ |
| 25 | 25 | ||
| 26 | #include <linux/slab.h> | 26 | #include <linux/slab.h> |
| 27 | #include <linux/keyctl.h> | ||
| 28 | #include <linux/key-type.h> | ||
| 27 | #include <keys/user-type.h> | 29 | #include <keys/user-type.h> |
| 28 | #include "dns_resolve.h" | 30 | #include "dns_resolve.h" |
| 29 | #include "cifsglob.h" | 31 | #include "cifsglob.h" |
| 30 | #include "cifsproto.h" | 32 | #include "cifsproto.h" |
| 31 | #include "cifs_debug.h" | 33 | #include "cifs_debug.h" |
| 32 | 34 | ||
| 35 | static const struct cred *dns_resolver_cache; | ||
| 36 | |||
| 33 | /* Checks if supplied name is IP address | 37 | /* Checks if supplied name is IP address |
| 34 | * returns: | 38 | * returns: |
| 35 | * 1 - name is IP | 39 | * 1 - name is IP |
| @@ -94,6 +98,7 @@ struct key_type key_type_dns_resolver = { | |||
| 94 | int | 98 | int |
| 95 | dns_resolve_server_name_to_ip(const char *unc, char **ip_addr) | 99 | dns_resolve_server_name_to_ip(const char *unc, char **ip_addr) |
| 96 | { | 100 | { |
| 101 | const struct cred *saved_cred; | ||
| 97 | int rc = -EAGAIN; | 102 | int rc = -EAGAIN; |
| 98 | struct key *rkey = ERR_PTR(-EAGAIN); | 103 | struct key *rkey = ERR_PTR(-EAGAIN); |
| 99 | char *name; | 104 | char *name; |
| @@ -133,8 +138,15 @@ dns_resolve_server_name_to_ip(const char *unc, char **ip_addr) | |||
| 133 | goto skip_upcall; | 138 | goto skip_upcall; |
| 134 | } | 139 | } |
| 135 | 140 | ||
| 141 | saved_cred = override_creds(dns_resolver_cache); | ||
| 136 | rkey = request_key(&key_type_dns_resolver, name, ""); | 142 | rkey = request_key(&key_type_dns_resolver, name, ""); |
| 143 | revert_creds(saved_cred); | ||
| 137 | if (!IS_ERR(rkey)) { | 144 | if (!IS_ERR(rkey)) { |
| 145 | if (!(rkey->perm & KEY_USR_VIEW)) { | ||
| 146 | down_read(&rkey->sem); | ||
| 147 | rkey->perm |= KEY_USR_VIEW; | ||
| 148 | up_read(&rkey->sem); | ||
| 149 | } | ||
| 138 | len = rkey->type_data.x[0]; | 150 | len = rkey->type_data.x[0]; |
| 139 | data = rkey->payload.data; | 151 | data = rkey->payload.data; |
| 140 | } else { | 152 | } else { |
| @@ -165,4 +177,61 @@ out: | |||
| 165 | return rc; | 177 | return rc; |
| 166 | } | 178 | } |
| 167 | 179 | ||
| 180 | int __init cifs_init_dns_resolver(void) | ||
| 181 | { | ||
| 182 | struct cred *cred; | ||
| 183 | struct key *keyring; | ||
| 184 | int ret; | ||
| 185 | |||
| 186 | printk(KERN_NOTICE "Registering the %s key type\n", | ||
| 187 | key_type_dns_resolver.name); | ||
| 188 | |||
| 189 | /* create an override credential set with a special thread keyring in | ||
| 190 | * which DNS requests are cached | ||
| 191 | * | ||
| 192 | * this is used to prevent malicious redirections from being installed | ||
| 193 | * with add_key(). | ||
| 194 | */ | ||
| 195 | cred = prepare_kernel_cred(NULL); | ||
| 196 | if (!cred) | ||
| 197 | return -ENOMEM; | ||
| 198 | |||
| 199 | keyring = key_alloc(&key_type_keyring, ".dns_resolver", 0, 0, cred, | ||
| 200 | (KEY_POS_ALL & ~KEY_POS_SETATTR) | | ||
| 201 | KEY_USR_VIEW | KEY_USR_READ, | ||
| 202 | KEY_ALLOC_NOT_IN_QUOTA); | ||
| 203 | if (IS_ERR(keyring)) { | ||
| 204 | ret = PTR_ERR(keyring); | ||
| 205 | goto failed_put_cred; | ||
| 206 | } | ||
| 207 | |||
| 208 | ret = key_instantiate_and_link(keyring, NULL, 0, NULL, NULL); | ||
| 209 | if (ret < 0) | ||
| 210 | goto failed_put_key; | ||
| 211 | |||
| 212 | ret = register_key_type(&key_type_dns_resolver); | ||
| 213 | if (ret < 0) | ||
| 214 | goto failed_put_key; | ||
| 215 | |||
| 216 | /* instruct request_key() to use this special keyring as a cache for | ||
| 217 | * the results it looks up */ | ||
| 218 | cred->thread_keyring = keyring; | ||
| 219 | cred->jit_keyring = KEY_REQKEY_DEFL_THREAD_KEYRING; | ||
| 220 | dns_resolver_cache = cred; | ||
| 221 | return 0; | ||
| 222 | |||
| 223 | failed_put_key: | ||
| 224 | key_put(keyring); | ||
| 225 | failed_put_cred: | ||
| 226 | put_cred(cred); | ||
| 227 | return ret; | ||
| 228 | } | ||
| 168 | 229 | ||
| 230 | void __exit cifs_exit_dns_resolver(void) | ||
| 231 | { | ||
| 232 | key_revoke(dns_resolver_cache->thread_keyring); | ||
| 233 | unregister_key_type(&key_type_dns_resolver); | ||
| 234 | put_cred(dns_resolver_cache); | ||
| 235 | printk(KERN_NOTICE "Unregistered %s key type\n", | ||
| 236 | key_type_dns_resolver.name); | ||
| 237 | } | ||
diff --git a/fs/cifs/dns_resolve.h b/fs/cifs/dns_resolve.h index 966e9288930b..26b9eaa9f5ee 100644 --- a/fs/cifs/dns_resolve.h +++ b/fs/cifs/dns_resolve.h | |||
| @@ -24,8 +24,8 @@ | |||
| 24 | #define _DNS_RESOLVE_H | 24 | #define _DNS_RESOLVE_H |
| 25 | 25 | ||
| 26 | #ifdef __KERNEL__ | 26 | #ifdef __KERNEL__ |
| 27 | #include <linux/key-type.h> | 27 | extern int __init cifs_init_dns_resolver(void); |
| 28 | extern struct key_type key_type_dns_resolver; | 28 | extern void __exit cifs_exit_dns_resolver(void); |
| 29 | extern int dns_resolve_server_name_to_ip(const char *unc, char **ip_addr); | 29 | extern int dns_resolve_server_name_to_ip(const char *unc, char **ip_addr); |
| 30 | #endif /* KERNEL */ | 30 | #endif /* KERNEL */ |
| 31 | 31 | ||
diff --git a/fs/ecryptfs/messaging.c b/fs/ecryptfs/messaging.c index 2d8dbce9d485..46c4dd8dfcc3 100644 --- a/fs/ecryptfs/messaging.c +++ b/fs/ecryptfs/messaging.c | |||
| @@ -31,9 +31,9 @@ static struct mutex ecryptfs_msg_ctx_lists_mux; | |||
| 31 | 31 | ||
| 32 | static struct hlist_head *ecryptfs_daemon_hash; | 32 | static struct hlist_head *ecryptfs_daemon_hash; |
| 33 | struct mutex ecryptfs_daemon_hash_mux; | 33 | struct mutex ecryptfs_daemon_hash_mux; |
| 34 | static int ecryptfs_hash_buckets; | 34 | static int ecryptfs_hash_bits; |
| 35 | #define ecryptfs_uid_hash(uid) \ | 35 | #define ecryptfs_uid_hash(uid) \ |
| 36 | hash_long((unsigned long)uid, ecryptfs_hash_buckets) | 36 | hash_long((unsigned long)uid, ecryptfs_hash_bits) |
| 37 | 37 | ||
| 38 | static u32 ecryptfs_msg_counter; | 38 | static u32 ecryptfs_msg_counter; |
| 39 | static struct ecryptfs_msg_ctx *ecryptfs_msg_ctx_arr; | 39 | static struct ecryptfs_msg_ctx *ecryptfs_msg_ctx_arr; |
| @@ -486,18 +486,19 @@ int ecryptfs_init_messaging(void) | |||
| 486 | } | 486 | } |
| 487 | mutex_init(&ecryptfs_daemon_hash_mux); | 487 | mutex_init(&ecryptfs_daemon_hash_mux); |
| 488 | mutex_lock(&ecryptfs_daemon_hash_mux); | 488 | mutex_lock(&ecryptfs_daemon_hash_mux); |
| 489 | ecryptfs_hash_buckets = 1; | 489 | ecryptfs_hash_bits = 1; |
| 490 | while (ecryptfs_number_of_users >> ecryptfs_hash_buckets) | 490 | while (ecryptfs_number_of_users >> ecryptfs_hash_bits) |
| 491 | ecryptfs_hash_buckets++; | 491 | ecryptfs_hash_bits++; |
| 492 | ecryptfs_daemon_hash = kmalloc((sizeof(struct hlist_head) | 492 | ecryptfs_daemon_hash = kmalloc((sizeof(struct hlist_head) |
| 493 | * ecryptfs_hash_buckets), GFP_KERNEL); | 493 | * (1 << ecryptfs_hash_bits)), |
| 494 | GFP_KERNEL); | ||
| 494 | if (!ecryptfs_daemon_hash) { | 495 | if (!ecryptfs_daemon_hash) { |
| 495 | rc = -ENOMEM; | 496 | rc = -ENOMEM; |
| 496 | printk(KERN_ERR "%s: Failed to allocate memory\n", __func__); | 497 | printk(KERN_ERR "%s: Failed to allocate memory\n", __func__); |
| 497 | mutex_unlock(&ecryptfs_daemon_hash_mux); | 498 | mutex_unlock(&ecryptfs_daemon_hash_mux); |
| 498 | goto out; | 499 | goto out; |
| 499 | } | 500 | } |
| 500 | for (i = 0; i < ecryptfs_hash_buckets; i++) | 501 | for (i = 0; i < (1 << ecryptfs_hash_bits); i++) |
| 501 | INIT_HLIST_HEAD(&ecryptfs_daemon_hash[i]); | 502 | INIT_HLIST_HEAD(&ecryptfs_daemon_hash[i]); |
| 502 | mutex_unlock(&ecryptfs_daemon_hash_mux); | 503 | mutex_unlock(&ecryptfs_daemon_hash_mux); |
| 503 | ecryptfs_msg_ctx_arr = kmalloc((sizeof(struct ecryptfs_msg_ctx) | 504 | ecryptfs_msg_ctx_arr = kmalloc((sizeof(struct ecryptfs_msg_ctx) |
| @@ -554,7 +555,7 @@ void ecryptfs_release_messaging(void) | |||
| 554 | int i; | 555 | int i; |
| 555 | 556 | ||
| 556 | mutex_lock(&ecryptfs_daemon_hash_mux); | 557 | mutex_lock(&ecryptfs_daemon_hash_mux); |
| 557 | for (i = 0; i < ecryptfs_hash_buckets; i++) { | 558 | for (i = 0; i < (1 << ecryptfs_hash_bits); i++) { |
| 558 | int rc; | 559 | int rc; |
| 559 | 560 | ||
| 560 | hlist_for_each_entry(daemon, elem, | 561 | hlist_for_each_entry(daemon, elem, |
diff --git a/fs/gfs2/dir.c b/fs/gfs2/dir.c index 26ca3361a8bc..6b48d7c268b2 100644 --- a/fs/gfs2/dir.c +++ b/fs/gfs2/dir.c | |||
| @@ -1231,6 +1231,25 @@ static int do_filldir_main(struct gfs2_inode *dip, u64 *offset, | |||
| 1231 | return 0; | 1231 | return 0; |
| 1232 | } | 1232 | } |
| 1233 | 1233 | ||
| 1234 | static void *gfs2_alloc_sort_buffer(unsigned size) | ||
| 1235 | { | ||
| 1236 | void *ptr = NULL; | ||
| 1237 | |||
| 1238 | if (size < KMALLOC_MAX_SIZE) | ||
| 1239 | ptr = kmalloc(size, GFP_NOFS | __GFP_NOWARN); | ||
| 1240 | if (!ptr) | ||
| 1241 | ptr = __vmalloc(size, GFP_NOFS, PAGE_KERNEL); | ||
| 1242 | return ptr; | ||
| 1243 | } | ||
| 1244 | |||
| 1245 | static void gfs2_free_sort_buffer(void *ptr) | ||
| 1246 | { | ||
| 1247 | if (is_vmalloc_addr(ptr)) | ||
| 1248 | vfree(ptr); | ||
| 1249 | else | ||
| 1250 | kfree(ptr); | ||
| 1251 | } | ||
| 1252 | |||
| 1234 | static int gfs2_dir_read_leaf(struct inode *inode, u64 *offset, void *opaque, | 1253 | static int gfs2_dir_read_leaf(struct inode *inode, u64 *offset, void *opaque, |
| 1235 | filldir_t filldir, int *copied, unsigned *depth, | 1254 | filldir_t filldir, int *copied, unsigned *depth, |
| 1236 | u64 leaf_no) | 1255 | u64 leaf_no) |
| @@ -1271,7 +1290,7 @@ static int gfs2_dir_read_leaf(struct inode *inode, u64 *offset, void *opaque, | |||
| 1271 | * 99 is the maximum number of entries that can fit in a single | 1290 | * 99 is the maximum number of entries that can fit in a single |
| 1272 | * leaf block. | 1291 | * leaf block. |
| 1273 | */ | 1292 | */ |
| 1274 | larr = vmalloc((leaves + entries + 99) * sizeof(void *)); | 1293 | larr = gfs2_alloc_sort_buffer((leaves + entries + 99) * sizeof(void *)); |
| 1275 | if (!larr) | 1294 | if (!larr) |
| 1276 | goto out; | 1295 | goto out; |
| 1277 | darr = (const struct gfs2_dirent **)(larr + leaves); | 1296 | darr = (const struct gfs2_dirent **)(larr + leaves); |
| @@ -1282,7 +1301,7 @@ static int gfs2_dir_read_leaf(struct inode *inode, u64 *offset, void *opaque, | |||
| 1282 | do { | 1301 | do { |
| 1283 | error = get_leaf(ip, lfn, &bh); | 1302 | error = get_leaf(ip, lfn, &bh); |
| 1284 | if (error) | 1303 | if (error) |
| 1285 | goto out_kfree; | 1304 | goto out_free; |
| 1286 | lf = (struct gfs2_leaf *)bh->b_data; | 1305 | lf = (struct gfs2_leaf *)bh->b_data; |
| 1287 | lfn = be64_to_cpu(lf->lf_next); | 1306 | lfn = be64_to_cpu(lf->lf_next); |
| 1288 | if (lf->lf_entries) { | 1307 | if (lf->lf_entries) { |
| @@ -1291,7 +1310,7 @@ static int gfs2_dir_read_leaf(struct inode *inode, u64 *offset, void *opaque, | |||
| 1291 | gfs2_dirent_gather, NULL, &g); | 1310 | gfs2_dirent_gather, NULL, &g); |
| 1292 | error = PTR_ERR(dent); | 1311 | error = PTR_ERR(dent); |
| 1293 | if (IS_ERR(dent)) | 1312 | if (IS_ERR(dent)) |
| 1294 | goto out_kfree; | 1313 | goto out_free; |
| 1295 | if (entries2 != g.offset) { | 1314 | if (entries2 != g.offset) { |
| 1296 | fs_warn(sdp, "Number of entries corrupt in dir " | 1315 | fs_warn(sdp, "Number of entries corrupt in dir " |
| 1297 | "leaf %llu, entries2 (%u) != " | 1316 | "leaf %llu, entries2 (%u) != " |
| @@ -1300,7 +1319,7 @@ static int gfs2_dir_read_leaf(struct inode *inode, u64 *offset, void *opaque, | |||
| 1300 | entries2, g.offset); | 1319 | entries2, g.offset); |
| 1301 | 1320 | ||
| 1302 | error = -EIO; | 1321 | error = -EIO; |
| 1303 | goto out_kfree; | 1322 | goto out_free; |
| 1304 | } | 1323 | } |
| 1305 | error = 0; | 1324 | error = 0; |
| 1306 | larr[leaf++] = bh; | 1325 | larr[leaf++] = bh; |
| @@ -1312,10 +1331,10 @@ static int gfs2_dir_read_leaf(struct inode *inode, u64 *offset, void *opaque, | |||
| 1312 | BUG_ON(entries2 != entries); | 1331 | BUG_ON(entries2 != entries); |
| 1313 | error = do_filldir_main(ip, offset, opaque, filldir, darr, | 1332 | error = do_filldir_main(ip, offset, opaque, filldir, darr, |
| 1314 | entries, copied); | 1333 | entries, copied); |
| 1315 | out_kfree: | 1334 | out_free: |
| 1316 | for(i = 0; i < leaf; i++) | 1335 | for(i = 0; i < leaf; i++) |
| 1317 | brelse(larr[i]); | 1336 | brelse(larr[i]); |
| 1318 | vfree(larr); | 1337 | gfs2_free_sort_buffer(larr); |
| 1319 | out: | 1338 | out: |
| 1320 | return error; | 1339 | return error; |
| 1321 | } | 1340 | } |
diff --git a/fs/sysfs/symlink.c b/fs/sysfs/symlink.c index f71246bebfe4..a7ac78f8e67a 100644 --- a/fs/sysfs/symlink.c +++ b/fs/sysfs/symlink.c | |||
| @@ -28,6 +28,7 @@ static int sysfs_do_create_link(struct kobject *kobj, struct kobject *target, | |||
| 28 | struct sysfs_dirent *target_sd = NULL; | 28 | struct sysfs_dirent *target_sd = NULL; |
| 29 | struct sysfs_dirent *sd = NULL; | 29 | struct sysfs_dirent *sd = NULL; |
| 30 | struct sysfs_addrm_cxt acxt; | 30 | struct sysfs_addrm_cxt acxt; |
| 31 | enum kobj_ns_type ns_type; | ||
| 31 | int error; | 32 | int error; |
| 32 | 33 | ||
| 33 | BUG_ON(!name); | 34 | BUG_ON(!name); |
| @@ -58,16 +59,29 @@ static int sysfs_do_create_link(struct kobject *kobj, struct kobject *target, | |||
| 58 | if (!sd) | 59 | if (!sd) |
| 59 | goto out_put; | 60 | goto out_put; |
| 60 | 61 | ||
| 61 | if (sysfs_ns_type(parent_sd)) | 62 | ns_type = sysfs_ns_type(parent_sd); |
| 63 | if (ns_type) | ||
| 62 | sd->s_ns = target->ktype->namespace(target); | 64 | sd->s_ns = target->ktype->namespace(target); |
| 63 | sd->s_symlink.target_sd = target_sd; | 65 | sd->s_symlink.target_sd = target_sd; |
| 64 | target_sd = NULL; /* reference is now owned by the symlink */ | 66 | target_sd = NULL; /* reference is now owned by the symlink */ |
| 65 | 67 | ||
| 66 | sysfs_addrm_start(&acxt, parent_sd); | 68 | sysfs_addrm_start(&acxt, parent_sd); |
| 67 | if (warn) | 69 | /* Symlinks must be between directories with the same ns_type */ |
| 68 | error = sysfs_add_one(&acxt, sd); | 70 | if (!ns_type || |
| 69 | else | 71 | (ns_type == sysfs_ns_type(sd->s_symlink.target_sd->s_parent))) { |
| 70 | error = __sysfs_add_one(&acxt, sd); | 72 | if (warn) |
| 73 | error = sysfs_add_one(&acxt, sd); | ||
| 74 | else | ||
| 75 | error = __sysfs_add_one(&acxt, sd); | ||
| 76 | } else { | ||
| 77 | error = -EINVAL; | ||
| 78 | WARN(1, KERN_WARNING | ||
| 79 | "sysfs: symlink across ns_types %s/%s -> %s/%s\n", | ||
| 80 | parent_sd->s_name, | ||
| 81 | sd->s_name, | ||
| 82 | sd->s_symlink.target_sd->s_parent->s_name, | ||
| 83 | sd->s_symlink.target_sd->s_name); | ||
| 84 | } | ||
| 71 | sysfs_addrm_finish(&acxt); | 85 | sysfs_addrm_finish(&acxt); |
| 72 | 86 | ||
| 73 | if (error) | 87 | if (error) |
| @@ -122,7 +136,7 @@ void sysfs_delete_link(struct kobject *kobj, struct kobject *targ, | |||
| 122 | { | 136 | { |
| 123 | const void *ns = NULL; | 137 | const void *ns = NULL; |
| 124 | spin_lock(&sysfs_assoc_lock); | 138 | spin_lock(&sysfs_assoc_lock); |
| 125 | if (targ->sd) | 139 | if (targ->sd && sysfs_ns_type(kobj->sd)) |
| 126 | ns = targ->sd->s_ns; | 140 | ns = targ->sd->s_ns; |
| 127 | spin_unlock(&sysfs_assoc_lock); | 141 | spin_unlock(&sysfs_assoc_lock); |
| 128 | sysfs_hash_and_remove(kobj->sd, ns, name); | 142 | sysfs_hash_and_remove(kobj->sd, ns, name); |
diff --git a/include/acpi/processor.h b/include/acpi/processor.h index da565a48240e..a68ca8a11a53 100644 --- a/include/acpi/processor.h +++ b/include/acpi/processor.h | |||
| @@ -48,7 +48,7 @@ struct acpi_power_register { | |||
| 48 | u8 space_id; | 48 | u8 space_id; |
| 49 | u8 bit_width; | 49 | u8 bit_width; |
| 50 | u8 bit_offset; | 50 | u8 bit_offset; |
| 51 | u8 reserved; | 51 | u8 access_size; |
| 52 | u64 address; | 52 | u64 address; |
| 53 | } __attribute__ ((packed)); | 53 | } __attribute__ ((packed)); |
| 54 | 54 | ||
| @@ -63,6 +63,7 @@ struct acpi_processor_cx { | |||
| 63 | u32 power; | 63 | u32 power; |
| 64 | u32 usage; | 64 | u32 usage; |
| 65 | u64 time; | 65 | u64 time; |
| 66 | u8 bm_sts_skip; | ||
| 66 | char desc[ACPI_CX_DESC_LEN]; | 67 | char desc[ACPI_CX_DESC_LEN]; |
| 67 | }; | 68 | }; |
| 68 | 69 | ||
diff --git a/include/asm-generic/vmlinux.lds.h b/include/asm-generic/vmlinux.lds.h index 48c5299cbf26..030a954ed292 100644 --- a/include/asm-generic/vmlinux.lds.h +++ b/include/asm-generic/vmlinux.lds.h | |||
| @@ -63,6 +63,12 @@ | |||
| 63 | /* Align . to a 8 byte boundary equals to maximum function alignment. */ | 63 | /* Align . to a 8 byte boundary equals to maximum function alignment. */ |
| 64 | #define ALIGN_FUNCTION() . = ALIGN(8) | 64 | #define ALIGN_FUNCTION() . = ALIGN(8) |
| 65 | 65 | ||
| 66 | /* | ||
| 67 | * Align to a 32 byte boundary equal to the | ||
| 68 | * alignment gcc 4.5 uses for a struct | ||
| 69 | */ | ||
| 70 | #define STRUCT_ALIGN() . = ALIGN(32) | ||
| 71 | |||
| 66 | /* The actual configuration determine if the init/exit sections | 72 | /* The actual configuration determine if the init/exit sections |
| 67 | * are handled as text/data or they can be discarded (which | 73 | * are handled as text/data or they can be discarded (which |
| 68 | * often happens at runtime) | 74 | * often happens at runtime) |
| @@ -166,7 +172,11 @@ | |||
| 166 | LIKELY_PROFILE() \ | 172 | LIKELY_PROFILE() \ |
| 167 | BRANCH_PROFILE() \ | 173 | BRANCH_PROFILE() \ |
| 168 | TRACE_PRINTKS() \ | 174 | TRACE_PRINTKS() \ |
| 175 | \ | ||
| 176 | STRUCT_ALIGN(); \ | ||
| 169 | FTRACE_EVENTS() \ | 177 | FTRACE_EVENTS() \ |
| 178 | \ | ||
| 179 | STRUCT_ALIGN(); \ | ||
| 170 | TRACE_SYSCALLS() | 180 | TRACE_SYSCALLS() |
| 171 | 181 | ||
| 172 | /* | 182 | /* |
| @@ -435,7 +445,7 @@ | |||
| 435 | */ | 445 | */ |
| 436 | #define INIT_TASK_DATA_SECTION(align) \ | 446 | #define INIT_TASK_DATA_SECTION(align) \ |
| 437 | . = ALIGN(align); \ | 447 | . = ALIGN(align); \ |
| 438 | .data..init_task : { \ | 448 | .data..init_task : AT(ADDR(.data..init_task) - LOAD_OFFSET) { \ |
| 439 | INIT_TASK_DATA(align) \ | 449 | INIT_TASK_DATA(align) \ |
| 440 | } | 450 | } |
| 441 | 451 | ||
diff --git a/include/linux/acpi.h b/include/linux/acpi.h index 224a38c960d4..ccf94dc5acdf 100644 --- a/include/linux/acpi.h +++ b/include/linux/acpi.h | |||
| @@ -253,7 +253,7 @@ int acpi_resources_are_enforced(void); | |||
| 253 | #ifdef CONFIG_PM_SLEEP | 253 | #ifdef CONFIG_PM_SLEEP |
| 254 | void __init acpi_no_s4_hw_signature(void); | 254 | void __init acpi_no_s4_hw_signature(void); |
| 255 | void __init acpi_old_suspend_ordering(void); | 255 | void __init acpi_old_suspend_ordering(void); |
| 256 | void __init acpi_s4_no_nvs(void); | 256 | void __init acpi_nvs_nosave(void); |
| 257 | #endif /* CONFIG_PM_SLEEP */ | 257 | #endif /* CONFIG_PM_SLEEP */ |
| 258 | 258 | ||
| 259 | struct acpi_osc_context { | 259 | struct acpi_osc_context { |
diff --git a/include/linux/amba/bus.h b/include/linux/amba/bus.h index 8b1038607831..b0c174012436 100644 --- a/include/linux/amba/bus.h +++ b/include/linux/amba/bus.h | |||
| @@ -14,14 +14,19 @@ | |||
| 14 | #ifndef ASMARM_AMBA_H | 14 | #ifndef ASMARM_AMBA_H |
| 15 | #define ASMARM_AMBA_H | 15 | #define ASMARM_AMBA_H |
| 16 | 16 | ||
| 17 | #include <linux/clk.h> | ||
| 17 | #include <linux/device.h> | 18 | #include <linux/device.h> |
| 19 | #include <linux/err.h> | ||
| 18 | #include <linux/resource.h> | 20 | #include <linux/resource.h> |
| 19 | 21 | ||
| 20 | #define AMBA_NR_IRQS 2 | 22 | #define AMBA_NR_IRQS 2 |
| 21 | 23 | ||
| 24 | struct clk; | ||
| 25 | |||
| 22 | struct amba_device { | 26 | struct amba_device { |
| 23 | struct device dev; | 27 | struct device dev; |
| 24 | struct resource res; | 28 | struct resource res; |
| 29 | struct clk *pclk; | ||
| 25 | u64 dma_mask; | 30 | u64 dma_mask; |
| 26 | unsigned int periphid; | 31 | unsigned int periphid; |
| 27 | unsigned int irq[AMBA_NR_IRQS]; | 32 | unsigned int irq[AMBA_NR_IRQS]; |
| @@ -59,6 +64,12 @@ struct amba_device *amba_find_device(const char *, struct device *, unsigned int | |||
| 59 | int amba_request_regions(struct amba_device *, const char *); | 64 | int amba_request_regions(struct amba_device *, const char *); |
| 60 | void amba_release_regions(struct amba_device *); | 65 | void amba_release_regions(struct amba_device *); |
| 61 | 66 | ||
| 67 | #define amba_pclk_enable(d) \ | ||
| 68 | (IS_ERR((d)->pclk) ? 0 : clk_enable((d)->pclk)) | ||
| 69 | |||
| 70 | #define amba_pclk_disable(d) \ | ||
| 71 | do { if (!IS_ERR((d)->pclk)) clk_disable((d)->pclk); } while (0) | ||
| 72 | |||
| 62 | #define amba_config(d) (((d)->periphid >> 24) & 0xff) | 73 | #define amba_config(d) (((d)->periphid >> 24) & 0xff) |
| 63 | #define amba_rev(d) (((d)->periphid >> 20) & 0x0f) | 74 | #define amba_rev(d) (((d)->periphid >> 20) & 0x0f) |
| 64 | #define amba_manf(d) (((d)->periphid >> 12) & 0xff) | 75 | #define amba_manf(d) (((d)->periphid >> 12) & 0xff) |
diff --git a/include/linux/if_macvlan.h b/include/linux/if_macvlan.h index 9ea047aca795..1ffaeffeff74 100644 --- a/include/linux/if_macvlan.h +++ b/include/linux/if_macvlan.h | |||
| @@ -67,6 +67,8 @@ static inline void macvlan_count_rx(const struct macvlan_dev *vlan, | |||
| 67 | } | 67 | } |
| 68 | } | 68 | } |
| 69 | 69 | ||
| 70 | extern void macvlan_common_setup(struct net_device *dev); | ||
| 71 | |||
| 70 | extern int macvlan_common_newlink(struct net *src_net, struct net_device *dev, | 72 | extern int macvlan_common_newlink(struct net *src_net, struct net_device *dev, |
| 71 | struct nlattr *tb[], struct nlattr *data[], | 73 | struct nlattr *tb[], struct nlattr *data[], |
| 72 | int (*receive)(struct sk_buff *skb), | 74 | int (*receive)(struct sk_buff *skb), |
diff --git a/include/linux/omapfb.h b/include/linux/omapfb.h index 9bdd91486b49..7e4cd616bcb5 100644 --- a/include/linux/omapfb.h +++ b/include/linux/omapfb.h | |||
| @@ -253,7 +253,7 @@ struct omapfb_platform_data { | |||
| 253 | /* in arch/arm/plat-omap/fb.c */ | 253 | /* in arch/arm/plat-omap/fb.c */ |
| 254 | extern void omapfb_set_platform_data(struct omapfb_platform_data *data); | 254 | extern void omapfb_set_platform_data(struct omapfb_platform_data *data); |
| 255 | extern void omapfb_set_ctrl_platform_data(void *pdata); | 255 | extern void omapfb_set_ctrl_platform_data(void *pdata); |
| 256 | extern void omapfb_reserve_sdram(void); | 256 | extern void omapfb_reserve_sdram_memblock(void); |
| 257 | 257 | ||
| 258 | #endif | 258 | #endif |
| 259 | 259 | ||
diff --git a/include/linux/regulator/tps6507x.h b/include/linux/regulator/tps6507x.h new file mode 100644 index 000000000000..4892f591bab1 --- /dev/null +++ b/include/linux/regulator/tps6507x.h | |||
| @@ -0,0 +1,32 @@ | |||
| 1 | /* | ||
| 2 | * tps6507x.h -- Voltage regulation for the Texas Instruments TPS6507X | ||
| 3 | * | ||
| 4 | * Copyright (C) 2010 Texas Instruments, Inc. | ||
| 5 | * | ||
| 6 | * This program is free software; you can redistribute it and/or modify | ||
| 7 | * it under the terms of the GNU General Public License version 2 as | ||
| 8 | * published by the Free Software Foundation | ||
| 9 | * | ||
| 10 | * This program is distributed in the hope that it will be useful, | ||
| 11 | * but WITHOUT ANY WARRANTY; without even the implied warranty of | ||
| 12 | * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the | ||
| 13 | * GNU General Public License for more details. | ||
| 14 | * | ||
| 15 | * You should have received a copy of the GNU General Public License | ||
| 16 | * along with this program; if not, write to the Free Software | ||
| 17 | * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA | ||
| 18 | */ | ||
| 19 | |||
| 20 | #ifndef REGULATOR_TPS6507X | ||
| 21 | #define REGULATOR_TPS6507X | ||
| 22 | |||
| 23 | /** | ||
| 24 | * tps6507x_reg_platform_data - platform data for tps6507x | ||
| 25 | * @defdcdc_default: Defines whether DCDC high or the low register controls | ||
| 26 | * output voltage by default. Valid for DCDC2 and DCDC3 outputs only. | ||
| 27 | */ | ||
| 28 | struct tps6507x_reg_platform_data { | ||
| 29 | bool defdcdc_default; | ||
| 30 | }; | ||
| 31 | |||
| 32 | #endif | ||
diff --git a/include/linux/sysrq.h b/include/linux/sysrq.h index 4496322e28dd..609e8ca5f534 100644 --- a/include/linux/sysrq.h +++ b/include/linux/sysrq.h | |||
| @@ -45,6 +45,7 @@ struct sysrq_key_op { | |||
| 45 | */ | 45 | */ |
| 46 | 46 | ||
| 47 | void handle_sysrq(int key, struct tty_struct *tty); | 47 | void handle_sysrq(int key, struct tty_struct *tty); |
| 48 | void __handle_sysrq(int key, struct tty_struct *tty, int check_mask); | ||
| 48 | int register_sysrq_key(int key, struct sysrq_key_op *op); | 49 | int register_sysrq_key(int key, struct sysrq_key_op *op); |
| 49 | int unregister_sysrq_key(int key, struct sysrq_key_op *op); | 50 | int unregister_sysrq_key(int key, struct sysrq_key_op *op); |
| 50 | struct sysrq_key_op *__sysrq_get_key_op(int key); | 51 | struct sysrq_key_op *__sysrq_get_key_op(int key); |
diff --git a/include/net/tc_act/tc_mirred.h b/include/net/tc_act/tc_mirred.h index ceac661cdfd5..cfe2943690ff 100644 --- a/include/net/tc_act/tc_mirred.h +++ b/include/net/tc_act/tc_mirred.h | |||
| @@ -9,6 +9,7 @@ struct tcf_mirred { | |||
| 9 | int tcfm_ifindex; | 9 | int tcfm_ifindex; |
| 10 | int tcfm_ok_push; | 10 | int tcfm_ok_push; |
| 11 | struct net_device *tcfm_dev; | 11 | struct net_device *tcfm_dev; |
| 12 | struct list_head tcfm_list; | ||
| 12 | }; | 13 | }; |
| 13 | #define to_mirred(pc) \ | 14 | #define to_mirred(pc) \ |
| 14 | container_of(pc, struct tcf_mirred, common) | 15 | container_of(pc, struct tcf_mirred, common) |
diff --git a/kernel/debug/debug_core.c b/kernel/debug/debug_core.c index 5cb7cd1de10c..8bc5eeffec8a 100644 --- a/kernel/debug/debug_core.c +++ b/kernel/debug/debug_core.c | |||
| @@ -605,13 +605,13 @@ cpu_master_loop: | |||
| 605 | if (dbg_kdb_mode) { | 605 | if (dbg_kdb_mode) { |
| 606 | kgdb_connected = 1; | 606 | kgdb_connected = 1; |
| 607 | error = kdb_stub(ks); | 607 | error = kdb_stub(ks); |
| 608 | kgdb_connected = 0; | ||
| 608 | } else { | 609 | } else { |
| 609 | error = gdb_serial_stub(ks); | 610 | error = gdb_serial_stub(ks); |
| 610 | } | 611 | } |
| 611 | 612 | ||
| 612 | if (error == DBG_PASS_EVENT) { | 613 | if (error == DBG_PASS_EVENT) { |
| 613 | dbg_kdb_mode = !dbg_kdb_mode; | 614 | dbg_kdb_mode = !dbg_kdb_mode; |
| 614 | kgdb_connected = 0; | ||
| 615 | } else if (error == DBG_SWITCH_CPU_EVENT) { | 615 | } else if (error == DBG_SWITCH_CPU_EVENT) { |
| 616 | dbg_cpu_switch(cpu, dbg_switch_cpu); | 616 | dbg_cpu_switch(cpu, dbg_switch_cpu); |
| 617 | goto cpu_loop; | 617 | goto cpu_loop; |
diff --git a/kernel/debug/gdbstub.c b/kernel/debug/gdbstub.c index 4b17b3269525..e8fd6868682d 100644 --- a/kernel/debug/gdbstub.c +++ b/kernel/debug/gdbstub.c | |||
| @@ -621,10 +621,8 @@ static void gdb_cmd_query(struct kgdb_state *ks) | |||
| 621 | switch (remcom_in_buffer[1]) { | 621 | switch (remcom_in_buffer[1]) { |
| 622 | case 's': | 622 | case 's': |
| 623 | case 'f': | 623 | case 'f': |
| 624 | if (memcmp(remcom_in_buffer + 2, "ThreadInfo", 10)) { | 624 | if (memcmp(remcom_in_buffer + 2, "ThreadInfo", 10)) |
| 625 | error_packet(remcom_out_buffer, -EINVAL); | ||
| 626 | break; | 625 | break; |
| 627 | } | ||
| 628 | 626 | ||
| 629 | i = 0; | 627 | i = 0; |
| 630 | remcom_out_buffer[0] = 'm'; | 628 | remcom_out_buffer[0] = 'm'; |
| @@ -665,10 +663,9 @@ static void gdb_cmd_query(struct kgdb_state *ks) | |||
| 665 | pack_threadid(remcom_out_buffer + 2, thref); | 663 | pack_threadid(remcom_out_buffer + 2, thref); |
| 666 | break; | 664 | break; |
| 667 | case 'T': | 665 | case 'T': |
| 668 | if (memcmp(remcom_in_buffer + 1, "ThreadExtraInfo,", 16)) { | 666 | if (memcmp(remcom_in_buffer + 1, "ThreadExtraInfo,", 16)) |
| 669 | error_packet(remcom_out_buffer, -EINVAL); | ||
| 670 | break; | 667 | break; |
| 671 | } | 668 | |
| 672 | ks->threadid = 0; | 669 | ks->threadid = 0; |
| 673 | ptr = remcom_in_buffer + 17; | 670 | ptr = remcom_in_buffer + 17; |
| 674 | kgdb_hex2long(&ptr, &ks->threadid); | 671 | kgdb_hex2long(&ptr, &ks->threadid); |
diff --git a/kernel/debug/kdb/kdb_main.c b/kernel/debug/kdb/kdb_main.c index 184cd8209c36..ebe4a287419e 100644 --- a/kernel/debug/kdb/kdb_main.c +++ b/kernel/debug/kdb/kdb_main.c | |||
| @@ -1820,9 +1820,8 @@ static int kdb_sr(int argc, const char **argv) | |||
| 1820 | { | 1820 | { |
| 1821 | if (argc != 1) | 1821 | if (argc != 1) |
| 1822 | return KDB_ARGCOUNT; | 1822 | return KDB_ARGCOUNT; |
| 1823 | sysrq_toggle_support(1); | ||
| 1824 | kdb_trap_printk++; | 1823 | kdb_trap_printk++; |
| 1825 | handle_sysrq(*argv[1], NULL); | 1824 | __handle_sysrq(*argv[1], NULL, 0); |
| 1826 | kdb_trap_printk--; | 1825 | kdb_trap_printk--; |
| 1827 | 1826 | ||
| 1828 | return 0; | 1827 | return 0; |
| @@ -1883,6 +1882,7 @@ static int kdb_lsmod(int argc, const char **argv) | |||
| 1883 | kdb_printf(" (Loading)"); | 1882 | kdb_printf(" (Loading)"); |
| 1884 | else | 1883 | else |
| 1885 | kdb_printf(" (Live)"); | 1884 | kdb_printf(" (Live)"); |
| 1885 | kdb_printf(" 0x%p", mod->module_core); | ||
| 1886 | 1886 | ||
| 1887 | #ifdef CONFIG_MODULE_UNLOAD | 1887 | #ifdef CONFIG_MODULE_UNLOAD |
| 1888 | { | 1888 | { |
| @@ -2291,6 +2291,9 @@ static int kdb_ll(int argc, const char **argv) | |||
| 2291 | while (va) { | 2291 | while (va) { |
| 2292 | char buf[80]; | 2292 | char buf[80]; |
| 2293 | 2293 | ||
| 2294 | if (KDB_FLAG(CMD_INTERRUPT)) | ||
| 2295 | return 0; | ||
| 2296 | |||
| 2294 | sprintf(buf, "%s " kdb_machreg_fmt "\n", command, va); | 2297 | sprintf(buf, "%s " kdb_machreg_fmt "\n", command, va); |
| 2295 | diag = kdb_parse(buf); | 2298 | diag = kdb_parse(buf); |
| 2296 | if (diag) | 2299 | if (diag) |
diff --git a/kernel/module.c b/kernel/module.c index 5d2d28197c82..6c562828c85c 100644 --- a/kernel/module.c +++ b/kernel/module.c | |||
| @@ -787,7 +787,6 @@ SYSCALL_DEFINE2(delete_module, const char __user *, name_user, | |||
| 787 | 787 | ||
| 788 | /* Store the name of the last unloaded module for diagnostic purposes */ | 788 | /* Store the name of the last unloaded module for diagnostic purposes */ |
| 789 | strlcpy(last_unloaded_module, mod->name, sizeof(last_unloaded_module)); | 789 | strlcpy(last_unloaded_module, mod->name, sizeof(last_unloaded_module)); |
| 790 | ddebug_remove_module(mod->name); | ||
| 791 | 790 | ||
| 792 | free_module(mod); | 791 | free_module(mod); |
| 793 | return 0; | 792 | return 0; |
| @@ -1550,6 +1549,9 @@ static void free_module(struct module *mod) | |||
| 1550 | remove_sect_attrs(mod); | 1549 | remove_sect_attrs(mod); |
| 1551 | mod_kobject_remove(mod); | 1550 | mod_kobject_remove(mod); |
| 1552 | 1551 | ||
| 1552 | /* Remove dynamic debug info */ | ||
| 1553 | ddebug_remove_module(mod->name); | ||
| 1554 | |||
| 1553 | /* Arch-specific cleanup. */ | 1555 | /* Arch-specific cleanup. */ |
| 1554 | module_arch_cleanup(mod); | 1556 | module_arch_cleanup(mod); |
| 1555 | 1557 | ||
diff --git a/net/core/dev.c b/net/core/dev.c index 0ea10f849be8..1f466e82ac33 100644 --- a/net/core/dev.c +++ b/net/core/dev.c | |||
| @@ -1488,6 +1488,7 @@ static inline void net_timestamp_check(struct sk_buff *skb) | |||
| 1488 | int dev_forward_skb(struct net_device *dev, struct sk_buff *skb) | 1488 | int dev_forward_skb(struct net_device *dev, struct sk_buff *skb) |
| 1489 | { | 1489 | { |
| 1490 | skb_orphan(skb); | 1490 | skb_orphan(skb); |
| 1491 | nf_reset(skb); | ||
| 1491 | 1492 | ||
| 1492 | if (!(dev->flags & IFF_UP) || | 1493 | if (!(dev->flags & IFF_UP) || |
| 1493 | (skb->len > (dev->mtu + dev->hard_header_len))) { | 1494 | (skb->len > (dev->mtu + dev->hard_header_len))) { |
diff --git a/net/core/skbuff.c b/net/core/skbuff.c index 34432b4e96bb..ce88293a34e2 100644 --- a/net/core/skbuff.c +++ b/net/core/skbuff.c | |||
| @@ -843,7 +843,9 @@ int pskb_expand_head(struct sk_buff *skb, int nhead, int ntail, | |||
| 843 | skb->network_header += off; | 843 | skb->network_header += off; |
| 844 | if (skb_mac_header_was_set(skb)) | 844 | if (skb_mac_header_was_set(skb)) |
| 845 | skb->mac_header += off; | 845 | skb->mac_header += off; |
| 846 | skb->csum_start += nhead; | 846 | /* Only adjust this if it actually is csum_start rather than csum */ |
| 847 | if (skb->ip_summed == CHECKSUM_PARTIAL) | ||
| 848 | skb->csum_start += nhead; | ||
| 847 | skb->cloned = 0; | 849 | skb->cloned = 0; |
| 848 | skb->hdr_len = 0; | 850 | skb->hdr_len = 0; |
| 849 | skb->nohdr = 0; | 851 | skb->nohdr = 0; |
| @@ -930,7 +932,8 @@ struct sk_buff *skb_copy_expand(const struct sk_buff *skb, | |||
| 930 | copy_skb_header(n, skb); | 932 | copy_skb_header(n, skb); |
| 931 | 933 | ||
| 932 | off = newheadroom - oldheadroom; | 934 | off = newheadroom - oldheadroom; |
| 933 | n->csum_start += off; | 935 | if (n->ip_summed == CHECKSUM_PARTIAL) |
| 936 | n->csum_start += off; | ||
| 934 | #ifdef NET_SKBUFF_DATA_USES_OFFSET | 937 | #ifdef NET_SKBUFF_DATA_USES_OFFSET |
| 935 | n->transport_header += off; | 938 | n->transport_header += off; |
| 936 | n->network_header += off; | 939 | n->network_header += off; |
diff --git a/net/ipv6/addrconf.c b/net/ipv6/addrconf.c index e1a698df5706..784f34d11fdd 100644 --- a/net/ipv6/addrconf.c +++ b/net/ipv6/addrconf.c | |||
| @@ -1760,7 +1760,10 @@ static struct inet6_dev *addrconf_add_dev(struct net_device *dev) | |||
| 1760 | 1760 | ||
| 1761 | idev = ipv6_find_idev(dev); | 1761 | idev = ipv6_find_idev(dev); |
| 1762 | if (!idev) | 1762 | if (!idev) |
| 1763 | return NULL; | 1763 | return ERR_PTR(-ENOBUFS); |
| 1764 | |||
| 1765 | if (idev->cnf.disable_ipv6) | ||
| 1766 | return ERR_PTR(-EACCES); | ||
| 1764 | 1767 | ||
| 1765 | /* Add default multicast route */ | 1768 | /* Add default multicast route */ |
| 1766 | addrconf_add_mroute(dev); | 1769 | addrconf_add_mroute(dev); |
| @@ -2129,8 +2132,9 @@ static int inet6_addr_add(struct net *net, int ifindex, struct in6_addr *pfx, | |||
| 2129 | if (!dev) | 2132 | if (!dev) |
| 2130 | return -ENODEV; | 2133 | return -ENODEV; |
| 2131 | 2134 | ||
| 2132 | if ((idev = addrconf_add_dev(dev)) == NULL) | 2135 | idev = addrconf_add_dev(dev); |
| 2133 | return -ENOBUFS; | 2136 | if (IS_ERR(idev)) |
| 2137 | return PTR_ERR(idev); | ||
| 2134 | 2138 | ||
| 2135 | scope = ipv6_addr_scope(pfx); | 2139 | scope = ipv6_addr_scope(pfx); |
| 2136 | 2140 | ||
| @@ -2377,7 +2381,7 @@ static void addrconf_dev_config(struct net_device *dev) | |||
| 2377 | } | 2381 | } |
| 2378 | 2382 | ||
| 2379 | idev = addrconf_add_dev(dev); | 2383 | idev = addrconf_add_dev(dev); |
| 2380 | if (idev == NULL) | 2384 | if (IS_ERR(idev)) |
| 2381 | return; | 2385 | return; |
| 2382 | 2386 | ||
| 2383 | memset(&addr, 0, sizeof(struct in6_addr)); | 2387 | memset(&addr, 0, sizeof(struct in6_addr)); |
| @@ -2468,7 +2472,7 @@ static void addrconf_ip6_tnl_config(struct net_device *dev) | |||
| 2468 | ASSERT_RTNL(); | 2472 | ASSERT_RTNL(); |
| 2469 | 2473 | ||
| 2470 | idev = addrconf_add_dev(dev); | 2474 | idev = addrconf_add_dev(dev); |
| 2471 | if (!idev) { | 2475 | if (IS_ERR(idev)) { |
| 2472 | printk(KERN_DEBUG "init ip6-ip6: add_dev failed\n"); | 2476 | printk(KERN_DEBUG "init ip6-ip6: add_dev failed\n"); |
| 2473 | return; | 2477 | return; |
| 2474 | } | 2478 | } |
diff --git a/net/mac80211/cfg.c b/net/mac80211/cfg.c index c7000a6ca379..67ee34f57df7 100644 --- a/net/mac80211/cfg.c +++ b/net/mac80211/cfg.c | |||
| @@ -632,7 +632,7 @@ static void ieee80211_send_layer2_update(struct sta_info *sta) | |||
| 632 | skb->dev = sta->sdata->dev; | 632 | skb->dev = sta->sdata->dev; |
| 633 | skb->protocol = eth_type_trans(skb, sta->sdata->dev); | 633 | skb->protocol = eth_type_trans(skb, sta->sdata->dev); |
| 634 | memset(skb->cb, 0, sizeof(skb->cb)); | 634 | memset(skb->cb, 0, sizeof(skb->cb)); |
| 635 | netif_rx(skb); | 635 | netif_rx_ni(skb); |
| 636 | } | 636 | } |
| 637 | 637 | ||
| 638 | static void sta_apply_parameters(struct ieee80211_local *local, | 638 | static void sta_apply_parameters(struct ieee80211_local *local, |
diff --git a/net/sched/act_mirred.c b/net/sched/act_mirred.c index c0b6863e3b87..1980b71c283f 100644 --- a/net/sched/act_mirred.c +++ b/net/sched/act_mirred.c | |||
| @@ -33,6 +33,7 @@ | |||
| 33 | static struct tcf_common *tcf_mirred_ht[MIRRED_TAB_MASK + 1]; | 33 | static struct tcf_common *tcf_mirred_ht[MIRRED_TAB_MASK + 1]; |
| 34 | static u32 mirred_idx_gen; | 34 | static u32 mirred_idx_gen; |
| 35 | static DEFINE_RWLOCK(mirred_lock); | 35 | static DEFINE_RWLOCK(mirred_lock); |
| 36 | static LIST_HEAD(mirred_list); | ||
| 36 | 37 | ||
| 37 | static struct tcf_hashinfo mirred_hash_info = { | 38 | static struct tcf_hashinfo mirred_hash_info = { |
| 38 | .htab = tcf_mirred_ht, | 39 | .htab = tcf_mirred_ht, |
| @@ -47,7 +48,9 @@ static inline int tcf_mirred_release(struct tcf_mirred *m, int bind) | |||
| 47 | m->tcf_bindcnt--; | 48 | m->tcf_bindcnt--; |
| 48 | m->tcf_refcnt--; | 49 | m->tcf_refcnt--; |
| 49 | if(!m->tcf_bindcnt && m->tcf_refcnt <= 0) { | 50 | if(!m->tcf_bindcnt && m->tcf_refcnt <= 0) { |
| 50 | dev_put(m->tcfm_dev); | 51 | list_del(&m->tcfm_list); |
| 52 | if (m->tcfm_dev) | ||
| 53 | dev_put(m->tcfm_dev); | ||
| 51 | tcf_hash_destroy(&m->common, &mirred_hash_info); | 54 | tcf_hash_destroy(&m->common, &mirred_hash_info); |
| 52 | return 1; | 55 | return 1; |
| 53 | } | 56 | } |
| @@ -134,8 +137,10 @@ static int tcf_mirred_init(struct nlattr *nla, struct nlattr *est, | |||
| 134 | m->tcfm_ok_push = ok_push; | 137 | m->tcfm_ok_push = ok_push; |
| 135 | } | 138 | } |
| 136 | spin_unlock_bh(&m->tcf_lock); | 139 | spin_unlock_bh(&m->tcf_lock); |
| 137 | if (ret == ACT_P_CREATED) | 140 | if (ret == ACT_P_CREATED) { |
| 141 | list_add(&m->tcfm_list, &mirred_list); | ||
| 138 | tcf_hash_insert(pc, &mirred_hash_info); | 142 | tcf_hash_insert(pc, &mirred_hash_info); |
| 143 | } | ||
| 139 | 144 | ||
| 140 | return ret; | 145 | return ret; |
| 141 | } | 146 | } |
| @@ -162,9 +167,14 @@ static int tcf_mirred(struct sk_buff *skb, struct tc_action *a, | |||
| 162 | m->tcf_tm.lastuse = jiffies; | 167 | m->tcf_tm.lastuse = jiffies; |
| 163 | 168 | ||
| 164 | dev = m->tcfm_dev; | 169 | dev = m->tcfm_dev; |
| 170 | if (!dev) { | ||
| 171 | printk_once(KERN_NOTICE "tc mirred: target device is gone\n"); | ||
| 172 | goto out; | ||
| 173 | } | ||
| 174 | |||
| 165 | if (!(dev->flags & IFF_UP)) { | 175 | if (!(dev->flags & IFF_UP)) { |
| 166 | if (net_ratelimit()) | 176 | if (net_ratelimit()) |
| 167 | pr_notice("tc mirred to Houston: device %s is gone!\n", | 177 | pr_notice("tc mirred to Houston: device %s is down\n", |
| 168 | dev->name); | 178 | dev->name); |
| 169 | goto out; | 179 | goto out; |
| 170 | } | 180 | } |
| @@ -232,6 +242,28 @@ nla_put_failure: | |||
| 232 | return -1; | 242 | return -1; |
| 233 | } | 243 | } |
| 234 | 244 | ||
| 245 | static int mirred_device_event(struct notifier_block *unused, | ||
| 246 | unsigned long event, void *ptr) | ||
| 247 | { | ||
| 248 | struct net_device *dev = ptr; | ||
| 249 | struct tcf_mirred *m; | ||
| 250 | |||
| 251 | if (event == NETDEV_UNREGISTER) | ||
| 252 | list_for_each_entry(m, &mirred_list, tcfm_list) { | ||
| 253 | if (m->tcfm_dev == dev) { | ||
| 254 | dev_put(dev); | ||
| 255 | m->tcfm_dev = NULL; | ||
| 256 | } | ||
| 257 | } | ||
| 258 | |||
| 259 | return NOTIFY_DONE; | ||
| 260 | } | ||
| 261 | |||
| 262 | static struct notifier_block mirred_device_notifier = { | ||
| 263 | .notifier_call = mirred_device_event, | ||
| 264 | }; | ||
| 265 | |||
| 266 | |||
| 235 | static struct tc_action_ops act_mirred_ops = { | 267 | static struct tc_action_ops act_mirred_ops = { |
| 236 | .kind = "mirred", | 268 | .kind = "mirred", |
| 237 | .hinfo = &mirred_hash_info, | 269 | .hinfo = &mirred_hash_info, |
| @@ -252,12 +284,17 @@ MODULE_LICENSE("GPL"); | |||
| 252 | 284 | ||
| 253 | static int __init mirred_init_module(void) | 285 | static int __init mirred_init_module(void) |
| 254 | { | 286 | { |
| 287 | int err = register_netdevice_notifier(&mirred_device_notifier); | ||
| 288 | if (err) | ||
| 289 | return err; | ||
| 290 | |||
| 255 | pr_info("Mirror/redirect action on\n"); | 291 | pr_info("Mirror/redirect action on\n"); |
| 256 | return tcf_register_action(&act_mirred_ops); | 292 | return tcf_register_action(&act_mirred_ops); |
| 257 | } | 293 | } |
| 258 | 294 | ||
| 259 | static void __exit mirred_cleanup_module(void) | 295 | static void __exit mirred_cleanup_module(void) |
| 260 | { | 296 | { |
| 297 | unregister_netdevice_notifier(&mirred_device_notifier); | ||
| 261 | tcf_unregister_action(&act_mirred_ops); | 298 | tcf_unregister_action(&act_mirred_ops); |
| 262 | } | 299 | } |
| 263 | 300 | ||
diff --git a/scripts/kconfig/nconf.gui.c b/scripts/kconfig/nconf.gui.c index 115edb437fb1..a9d9344e1365 100644 --- a/scripts/kconfig/nconf.gui.c +++ b/scripts/kconfig/nconf.gui.c | |||
| @@ -226,7 +226,7 @@ void fill_window(WINDOW *win, const char *text) | |||
| 226 | int len = get_line_length(line); | 226 | int len = get_line_length(line); |
| 227 | strncpy(tmp, line, min(len, x)); | 227 | strncpy(tmp, line, min(len, x)); |
| 228 | tmp[len] = '\0'; | 228 | tmp[len] = '\0'; |
| 229 | mvwprintw(win, i, 0, tmp); | 229 | mvwprintw(win, i, 0, "%s", tmp); |
| 230 | } | 230 | } |
| 231 | } | 231 | } |
| 232 | 232 | ||
diff --git a/scripts/package/Makefile b/scripts/package/Makefile index 3a681ef25306..d2c29b63adda 100644 --- a/scripts/package/Makefile +++ b/scripts/package/Makefile | |||
| @@ -44,7 +44,7 @@ rpm-pkg rpm: $(objtree)/kernel.spec FORCE | |||
| 44 | fi | 44 | fi |
| 45 | $(MAKE) clean | 45 | $(MAKE) clean |
| 46 | $(PREV) ln -sf $(srctree) $(KERNELPATH) | 46 | $(PREV) ln -sf $(srctree) $(KERNELPATH) |
| 47 | $(CONFIG_SHELL) $(srctree)/scripts/setlocalversion --scm-only > $(objtree)/.scmversion | 47 | $(CONFIG_SHELL) $(srctree)/scripts/setlocalversion --save-scmversion |
| 48 | $(PREV) tar -cz $(RCS_TAR_IGNORE) -f $(KERNELPATH).tar.gz $(KERNELPATH)/. | 48 | $(PREV) tar -cz $(RCS_TAR_IGNORE) -f $(KERNELPATH).tar.gz $(KERNELPATH)/. |
| 49 | $(PREV) rm $(KERNELPATH) | 49 | $(PREV) rm $(KERNELPATH) |
| 50 | rm -f $(objtree)/.scmversion | 50 | rm -f $(objtree)/.scmversion |
diff --git a/scripts/setlocalversion b/scripts/setlocalversion index d6a866ed1835..64a9cb5556cd 100755 --- a/scripts/setlocalversion +++ b/scripts/setlocalversion | |||
| @@ -10,13 +10,13 @@ | |||
| 10 | # | 10 | # |
| 11 | 11 | ||
| 12 | usage() { | 12 | usage() { |
| 13 | echo "Usage: $0 [--scm-only] [srctree]" >&2 | 13 | echo "Usage: $0 [--save-scmversion] [srctree]" >&2 |
| 14 | exit 1 | 14 | exit 1 |
| 15 | } | 15 | } |
| 16 | 16 | ||
| 17 | scm_only=false | 17 | scm_only=false |
| 18 | srctree=. | 18 | srctree=. |
| 19 | if test "$1" = "--scm-only"; then | 19 | if test "$1" = "--save-scmversion"; then |
| 20 | scm_only=true | 20 | scm_only=true |
| 21 | shift | 21 | shift |
| 22 | fi | 22 | fi |
| @@ -30,11 +30,12 @@ fi | |||
| 30 | 30 | ||
| 31 | scm_version() | 31 | scm_version() |
| 32 | { | 32 | { |
| 33 | local short=false | 33 | local short |
| 34 | short=false | ||
| 34 | 35 | ||
| 35 | cd "$srctree" | 36 | cd "$srctree" |
| 36 | if test -e .scmversion; then | 37 | if test -e .scmversion; then |
| 37 | cat "$_" | 38 | cat .scmversion |
| 38 | return | 39 | return |
| 39 | fi | 40 | fi |
| 40 | if test "$1" = "--short"; then | 41 | if test "$1" = "--short"; then |
| @@ -131,12 +132,15 @@ collect_files() | |||
| 131 | } | 132 | } |
| 132 | 133 | ||
| 133 | if $scm_only; then | 134 | if $scm_only; then |
| 134 | scm_version | 135 | if test ! -e .scmversion; then |
| 136 | res=$(scm_version) | ||
| 137 | echo "$res" >.scmversion | ||
| 138 | fi | ||
| 135 | exit | 139 | exit |
| 136 | fi | 140 | fi |
| 137 | 141 | ||
| 138 | if test -e include/config/auto.conf; then | 142 | if test -e include/config/auto.conf; then |
| 139 | source "$_" | 143 | . include/config/auto.conf |
| 140 | else | 144 | else |
| 141 | echo "Error: kernelrelease not valid - run 'make prepare' to update it" | 145 | echo "Error: kernelrelease not valid - run 'make prepare' to update it" |
| 142 | exit 1 | 146 | exit 1 |
diff --git a/sound/soc/au1x/psc-i2s.c b/sound/soc/au1x/psc-i2s.c index 495be6e71931..24454c98d0ee 100644 --- a/sound/soc/au1x/psc-i2s.c +++ b/sound/soc/au1x/psc-i2s.c | |||
| @@ -300,7 +300,7 @@ struct snd_soc_dai au1xpsc_i2s_dai = { | |||
| 300 | }; | 300 | }; |
| 301 | EXPORT_SYMBOL(au1xpsc_i2s_dai); | 301 | EXPORT_SYMBOL(au1xpsc_i2s_dai); |
| 302 | 302 | ||
| 303 | static int __init au1xpsc_i2s_drvprobe(struct platform_device *pdev) | 303 | static int __devinit au1xpsc_i2s_drvprobe(struct platform_device *pdev) |
| 304 | { | 304 | { |
| 305 | struct resource *r; | 305 | struct resource *r; |
| 306 | unsigned long sel; | 306 | unsigned long sel; |
diff --git a/tools/perf/Makefile b/tools/perf/Makefile index 3d8f31ed771d..d75c28a825f5 100644 --- a/tools/perf/Makefile +++ b/tools/perf/Makefile | |||
| @@ -600,30 +600,32 @@ endif | |||
| 600 | 600 | ||
| 601 | ifdef NO_DEMANGLE | 601 | ifdef NO_DEMANGLE |
| 602 | BASIC_CFLAGS += -DNO_DEMANGLE | 602 | BASIC_CFLAGS += -DNO_DEMANGLE |
| 603 | else ifdef HAVE_CPLUS_DEMANGLE | ||
| 604 | EXTLIBS += -liberty | ||
| 605 | BASIC_CFLAGS += -DHAVE_CPLUS_DEMANGLE | ||
| 606 | else | 603 | else |
| 607 | has_bfd := $(shell sh -c "(echo '\#include <bfd.h>'; echo 'int main(void) { bfd_demangle(0, 0, 0); return 0; }') | $(CC) -x c - $(ALL_CFLAGS) -o $(BITBUCKET) $(ALL_LDFLAGS) $(EXTLIBS) -lbfd "$(QUIET_STDERR)" && echo y") | 604 | ifdef HAVE_CPLUS_DEMANGLE |
| 608 | 605 | EXTLIBS += -liberty | |
| 609 | ifeq ($(has_bfd),y) | 606 | BASIC_CFLAGS += -DHAVE_CPLUS_DEMANGLE |
| 610 | EXTLIBS += -lbfd | ||
| 611 | else | 607 | else |
| 612 | has_bfd_iberty := $(shell sh -c "(echo '\#include <bfd.h>'; echo 'int main(void) { bfd_demangle(0, 0, 0); return 0; }') | $(CC) -x c - $(ALL_CFLAGS) -o $(BITBUCKET) $(ALL_LDFLAGS) $(EXTLIBS) -lbfd -liberty "$(QUIET_STDERR)" && echo y") | 608 | has_bfd := $(shell sh -c "(echo '\#include <bfd.h>'; echo 'int main(void) { bfd_demangle(0, 0, 0); return 0; }') | $(CC) -x c - $(ALL_CFLAGS) -o $(BITBUCKET) $(ALL_LDFLAGS) $(EXTLIBS) -lbfd "$(QUIET_STDERR)" && echo y") |
| 613 | ifeq ($(has_bfd_iberty),y) | 609 | |
| 614 | EXTLIBS += -lbfd -liberty | 610 | ifeq ($(has_bfd),y) |
| 611 | EXTLIBS += -lbfd | ||
| 615 | else | 612 | else |
| 616 | has_bfd_iberty_z := $(shell sh -c "(echo '\#include <bfd.h>'; echo 'int main(void) { bfd_demangle(0, 0, 0); return 0; }') | $(CC) -x c - $(ALL_CFLAGS) -o $(BITBUCKET) $(ALL_LDFLAGS) $(EXTLIBS) -lbfd -liberty -lz "$(QUIET_STDERR)" && echo y") | 613 | has_bfd_iberty := $(shell sh -c "(echo '\#include <bfd.h>'; echo 'int main(void) { bfd_demangle(0, 0, 0); return 0; }') | $(CC) -x c - $(ALL_CFLAGS) -o $(BITBUCKET) $(ALL_LDFLAGS) $(EXTLIBS) -lbfd -liberty "$(QUIET_STDERR)" && echo y") |
| 617 | ifeq ($(has_bfd_iberty_z),y) | 614 | ifeq ($(has_bfd_iberty),y) |
| 618 | EXTLIBS += -lbfd -liberty -lz | 615 | EXTLIBS += -lbfd -liberty |
| 619 | else | 616 | else |
| 620 | has_cplus_demangle := $(shell sh -c "(echo 'extern char *cplus_demangle(const char *, int);'; echo 'int main(void) { cplus_demangle(0, 0); return 0; }') | $(CC) -x c - $(ALL_CFLAGS) -o $(BITBUCKET) $(ALL_LDFLAGS) $(EXTLIBS) -liberty "$(QUIET_STDERR)" && echo y") | 617 | has_bfd_iberty_z := $(shell sh -c "(echo '\#include <bfd.h>'; echo 'int main(void) { bfd_demangle(0, 0, 0); return 0; }') | $(CC) -x c - $(ALL_CFLAGS) -o $(BITBUCKET) $(ALL_LDFLAGS) $(EXTLIBS) -lbfd -liberty -lz "$(QUIET_STDERR)" && echo y") |
| 621 | ifeq ($(has_cplus_demangle),y) | 618 | ifeq ($(has_bfd_iberty_z),y) |
| 622 | EXTLIBS += -liberty | 619 | EXTLIBS += -lbfd -liberty -lz |
| 623 | BASIC_CFLAGS += -DHAVE_CPLUS_DEMANGLE | ||
| 624 | else | 620 | else |
| 625 | msg := $(warning No bfd.h/libbfd found, install binutils-dev[el]/zlib-static to gain symbol demangling) | 621 | has_cplus_demangle := $(shell sh -c "(echo 'extern char *cplus_demangle(const char *, int);'; echo 'int main(void) { cplus_demangle(0, 0); return 0; }') | $(CC) -x c - $(ALL_CFLAGS) -o $(BITBUCKET) $(ALL_LDFLAGS) $(EXTLIBS) -liberty "$(QUIET_STDERR)" && echo y") |
| 626 | BASIC_CFLAGS += -DNO_DEMANGLE | 622 | ifeq ($(has_cplus_demangle),y) |
| 623 | EXTLIBS += -liberty | ||
| 624 | BASIC_CFLAGS += -DHAVE_CPLUS_DEMANGLE | ||
| 625 | else | ||
| 626 | msg := $(warning No bfd.h/libbfd found, install binutils-dev[el]/zlib-static to gain symbol demangling) | ||
| 627 | BASIC_CFLAGS += -DNO_DEMANGLE | ||
| 628 | endif | ||
| 627 | endif | 629 | endif |
| 628 | endif | 630 | endif |
| 629 | endif | 631 | endif |
diff --git a/tools/perf/arch/arm/Makefile b/tools/perf/arch/arm/Makefile new file mode 100644 index 000000000000..15130b50dfe3 --- /dev/null +++ b/tools/perf/arch/arm/Makefile | |||
| @@ -0,0 +1,4 @@ | |||
| 1 | ifndef NO_DWARF | ||
| 2 | PERF_HAVE_DWARF_REGS := 1 | ||
| 3 | LIB_OBJS += $(OUTPUT)arch/$(ARCH)/util/dwarf-regs.o | ||
| 4 | endif | ||
diff --git a/tools/perf/arch/arm/util/dwarf-regs.c b/tools/perf/arch/arm/util/dwarf-regs.c new file mode 100644 index 000000000000..fff6450c8c99 --- /dev/null +++ b/tools/perf/arch/arm/util/dwarf-regs.c | |||
| @@ -0,0 +1,64 @@ | |||
| 1 | /* | ||
| 2 | * Mapping of DWARF debug register numbers into register names. | ||
| 3 | * | ||
| 4 | * Copyright (C) 2010 Will Deacon, ARM Ltd. | ||
| 5 | * | ||
| 6 | * This program is free software; you can redistribute it and/or modify | ||
| 7 | * it under the terms of the GNU General Public License version 2 as | ||
| 8 | * published by the Free Software Foundation. | ||
| 9 | */ | ||
| 10 | |||
| 11 | #include <libio.h> | ||
| 12 | #include <dwarf-regs.h> | ||
| 13 | |||
| 14 | struct pt_regs_dwarfnum { | ||
| 15 | const char *name; | ||
| 16 | unsigned int dwarfnum; | ||
| 17 | }; | ||
| 18 | |||
| 19 | #define STR(s) #s | ||
| 20 | #define REG_DWARFNUM_NAME(r, num) {.name = r, .dwarfnum = num} | ||
| 21 | #define GPR_DWARFNUM_NAME(num) \ | ||
| 22 | {.name = STR(%r##num), .dwarfnum = num} | ||
| 23 | #define REG_DWARFNUM_END {.name = NULL, .dwarfnum = 0} | ||
| 24 | |||
| 25 | /* | ||
| 26 | * Reference: | ||
| 27 | * http://infocenter.arm.com/help/topic/com.arm.doc.ihi0040a/IHI0040A_aadwarf.pdf | ||
| 28 | */ | ||
| 29 | static const struct pt_regs_dwarfnum regdwarfnum_table[] = { | ||
| 30 | GPR_DWARFNUM_NAME(0), | ||
| 31 | GPR_DWARFNUM_NAME(1), | ||
| 32 | GPR_DWARFNUM_NAME(2), | ||
| 33 | GPR_DWARFNUM_NAME(3), | ||
| 34 | GPR_DWARFNUM_NAME(4), | ||
| 35 | GPR_DWARFNUM_NAME(5), | ||
| 36 | GPR_DWARFNUM_NAME(6), | ||
| 37 | GPR_DWARFNUM_NAME(7), | ||
| 38 | GPR_DWARFNUM_NAME(8), | ||
| 39 | GPR_DWARFNUM_NAME(9), | ||
| 40 | GPR_DWARFNUM_NAME(10), | ||
| 41 | REG_DWARFNUM_NAME("%fp", 11), | ||
| 42 | REG_DWARFNUM_NAME("%ip", 12), | ||
| 43 | REG_DWARFNUM_NAME("%sp", 13), | ||
| 44 | REG_DWARFNUM_NAME("%lr", 14), | ||
| 45 | REG_DWARFNUM_NAME("%pc", 15), | ||
| 46 | REG_DWARFNUM_END, | ||
| 47 | }; | ||
| 48 | |||
| 49 | /** | ||
| 50 | * get_arch_regstr() - lookup register name from it's DWARF register number | ||
| 51 | * @n: the DWARF register number | ||
| 52 | * | ||
| 53 | * get_arch_regstr() returns the name of the register in struct | ||
| 54 | * regdwarfnum_table from it's DWARF register number. If the register is not | ||
| 55 | * found in the table, this returns NULL; | ||
| 56 | */ | ||
| 57 | const char *get_arch_regstr(unsigned int n) | ||
| 58 | { | ||
| 59 | const struct pt_regs_dwarfnum *roff; | ||
| 60 | for (roff = regdwarfnum_table; roff->name != NULL; roff++) | ||
| 61 | if (roff->dwarfnum == n) | ||
| 62 | return roff->name; | ||
| 63 | return NULL; | ||
| 64 | } | ||
diff --git a/tools/perf/util/hist.c b/tools/perf/util/hist.c index 07f89b66b318..784ee0bdda77 100644 --- a/tools/perf/util/hist.c +++ b/tools/perf/util/hist.c | |||
| @@ -631,9 +631,14 @@ int hist_entry__fprintf(struct hist_entry *self, struct hists *pair_hists, | |||
| 631 | u64 session_total) | 631 | u64 session_total) |
| 632 | { | 632 | { |
| 633 | char bf[512]; | 633 | char bf[512]; |
| 634 | hist_entry__snprintf(self, bf, sizeof(bf), pair_hists, | 634 | int ret; |
| 635 | show_displacement, displacement, | 635 | |
| 636 | true, session_total); | 636 | ret = hist_entry__snprintf(self, bf, sizeof(bf), pair_hists, |
| 637 | show_displacement, displacement, | ||
| 638 | true, session_total); | ||
| 639 | if (!ret) | ||
| 640 | return 0; | ||
| 641 | |||
| 637 | return fprintf(fp, "%s\n", bf); | 642 | return fprintf(fp, "%s\n", bf); |
| 638 | } | 643 | } |
| 639 | 644 | ||
| @@ -762,6 +767,7 @@ size_t hists__fprintf(struct hists *self, struct hists *pair, | |||
| 762 | print_entries: | 767 | print_entries: |
| 763 | for (nd = rb_first(&self->entries); nd; nd = rb_next(nd)) { | 768 | for (nd = rb_first(&self->entries); nd; nd = rb_next(nd)) { |
| 764 | struct hist_entry *h = rb_entry(nd, struct hist_entry, rb_node); | 769 | struct hist_entry *h = rb_entry(nd, struct hist_entry, rb_node); |
| 770 | int cnt; | ||
| 765 | 771 | ||
| 766 | if (show_displacement) { | 772 | if (show_displacement) { |
| 767 | if (h->pair != NULL) | 773 | if (h->pair != NULL) |
| @@ -771,8 +777,13 @@ print_entries: | |||
| 771 | displacement = 0; | 777 | displacement = 0; |
| 772 | ++position; | 778 | ++position; |
| 773 | } | 779 | } |
| 774 | ret += hist_entry__fprintf(h, pair, show_displacement, | 780 | cnt = hist_entry__fprintf(h, pair, show_displacement, |
| 775 | displacement, fp, self->stats.total_period); | 781 | displacement, fp, self->stats.total_period); |
| 782 | /* Ignore those that didn't match the parent filter */ | ||
| 783 | if (!cnt) | ||
| 784 | continue; | ||
| 785 | |||
| 786 | ret += cnt; | ||
| 776 | 787 | ||
| 777 | if (symbol_conf.use_callchain) | 788 | if (symbol_conf.use_callchain) |
| 778 | ret += hist_entry__fprintf_callchain(h, fp, self->stats.total_period); | 789 | ret += hist_entry__fprintf_callchain(h, fp, self->stats.total_period); |
| @@ -965,13 +976,17 @@ static int hist_entry__parse_objdump_line(struct hist_entry *self, FILE *file, | |||
| 965 | * Parse hexa addresses followed by ':' | 976 | * Parse hexa addresses followed by ':' |
| 966 | */ | 977 | */ |
| 967 | line_ip = strtoull(tmp, &tmp2, 16); | 978 | line_ip = strtoull(tmp, &tmp2, 16); |
| 968 | if (*tmp2 != ':' || tmp == tmp2) | 979 | if (*tmp2 != ':' || tmp == tmp2 || tmp2[1] == '\0') |
| 969 | line_ip = -1; | 980 | line_ip = -1; |
| 970 | } | 981 | } |
| 971 | 982 | ||
| 972 | if (line_ip != -1) { | 983 | if (line_ip != -1) { |
| 973 | u64 start = map__rip_2objdump(self->ms.map, sym->start); | 984 | u64 start = map__rip_2objdump(self->ms.map, sym->start), |
| 985 | end = map__rip_2objdump(self->ms.map, sym->end); | ||
| 986 | |||
| 974 | offset = line_ip - start; | 987 | offset = line_ip - start; |
| 988 | if (offset < 0 || (u64)line_ip > end) | ||
| 989 | offset = -1; | ||
| 975 | } | 990 | } |
| 976 | 991 | ||
| 977 | objdump_line = objdump_line__new(offset, line); | 992 | objdump_line = objdump_line__new(offset, line); |
diff --git a/tools/perf/util/symbol.c b/tools/perf/util/symbol.c index b63e5713849f..5b276833e2bf 100644 --- a/tools/perf/util/symbol.c +++ b/tools/perf/util/symbol.c | |||
| @@ -1443,6 +1443,7 @@ static int map_groups__set_modules_path_dir(struct map_groups *self, | |||
| 1443 | { | 1443 | { |
| 1444 | struct dirent *dent; | 1444 | struct dirent *dent; |
| 1445 | DIR *dir = opendir(dir_name); | 1445 | DIR *dir = opendir(dir_name); |
| 1446 | int ret = 0; | ||
| 1446 | 1447 | ||
| 1447 | if (!dir) { | 1448 | if (!dir) { |
| 1448 | pr_debug("%s: cannot open %s dir\n", __func__, dir_name); | 1449 | pr_debug("%s: cannot open %s dir\n", __func__, dir_name); |
| @@ -1465,8 +1466,9 @@ static int map_groups__set_modules_path_dir(struct map_groups *self, | |||
| 1465 | 1466 | ||
| 1466 | snprintf(path, sizeof(path), "%s/%s", | 1467 | snprintf(path, sizeof(path), "%s/%s", |
| 1467 | dir_name, dent->d_name); | 1468 | dir_name, dent->d_name); |
| 1468 | if (map_groups__set_modules_path_dir(self, path) < 0) | 1469 | ret = map_groups__set_modules_path_dir(self, path); |
| 1469 | goto failure; | 1470 | if (ret < 0) |
| 1471 | goto out; | ||
| 1470 | } else { | 1472 | } else { |
| 1471 | char *dot = strrchr(dent->d_name, '.'), | 1473 | char *dot = strrchr(dent->d_name, '.'), |
| 1472 | dso_name[PATH_MAX]; | 1474 | dso_name[PATH_MAX]; |
| @@ -1487,17 +1489,18 @@ static int map_groups__set_modules_path_dir(struct map_groups *self, | |||
| 1487 | dir_name, dent->d_name); | 1489 | dir_name, dent->d_name); |
| 1488 | 1490 | ||
| 1489 | long_name = strdup(path); | 1491 | long_name = strdup(path); |
| 1490 | if (long_name == NULL) | 1492 | if (long_name == NULL) { |
| 1491 | goto failure; | 1493 | ret = -1; |
| 1494 | goto out; | ||
| 1495 | } | ||
| 1492 | dso__set_long_name(map->dso, long_name); | 1496 | dso__set_long_name(map->dso, long_name); |
| 1493 | dso__kernel_module_get_build_id(map->dso, ""); | 1497 | dso__kernel_module_get_build_id(map->dso, ""); |
| 1494 | } | 1498 | } |
| 1495 | } | 1499 | } |
| 1496 | 1500 | ||
| 1497 | return 0; | 1501 | out: |
| 1498 | failure: | ||
| 1499 | closedir(dir); | 1502 | closedir(dir); |
| 1500 | return -1; | 1503 | return ret; |
| 1501 | } | 1504 | } |
| 1502 | 1505 | ||
| 1503 | static char *get_kernel_version(const char *root_dir) | 1506 | static char *get_kernel_version(const char *root_dir) |
