diff options
130 files changed, 5222 insertions, 1106 deletions
| diff --git a/Documentation/spi/pxa2xx b/Documentation/spi/pxa2xx index f9717fe9bd85..215e3b8e7266 100644 --- a/Documentation/spi/pxa2xx +++ b/Documentation/spi/pxa2xx | |||
| @@ -62,7 +62,7 @@ static struct resource pxa_spi_nssp_resources[] = { | |||
| 62 | 62 | ||
| 63 | static struct pxa2xx_spi_master pxa_nssp_master_info = { | 63 | static struct pxa2xx_spi_master pxa_nssp_master_info = { | 
| 64 | .ssp_type = PXA25x_NSSP, /* Type of SSP */ | 64 | .ssp_type = PXA25x_NSSP, /* Type of SSP */ | 
| 65 | .clock_enable = CKEN9_NSSP, /* NSSP Peripheral clock */ | 65 | .clock_enable = CKEN_NSSP, /* NSSP Peripheral clock */ | 
| 66 | .num_chipselect = 1, /* Matches the number of chips attached to NSSP */ | 66 | .num_chipselect = 1, /* Matches the number of chips attached to NSSP */ | 
| 67 | .enable_dma = 1, /* Enables NSSP DMA */ | 67 | .enable_dma = 1, /* Enables NSSP DMA */ | 
| 68 | }; | 68 | }; | 
| diff --git a/arch/arm/Kconfig b/arch/arm/Kconfig index e7baca29f3fb..11b45714a429 100644 --- a/arch/arm/Kconfig +++ b/arch/arm/Kconfig | |||
| @@ -29,6 +29,10 @@ config GENERIC_TIME | |||
| 29 | bool | 29 | bool | 
| 30 | default n | 30 | default n | 
| 31 | 31 | ||
| 32 | config GENERIC_CLOCKEVENTS | ||
| 33 | bool | ||
| 34 | default n | ||
| 35 | |||
| 32 | config MMU | 36 | config MMU | 
| 33 | bool | 37 | bool | 
| 34 | default y | 38 | default y | 
| @@ -67,6 +71,14 @@ config GENERIC_HARDIRQS | |||
| 67 | bool | 71 | bool | 
| 68 | default y | 72 | default y | 
| 69 | 73 | ||
| 74 | config STACKTRACE_SUPPORT | ||
| 75 | bool | ||
| 76 | default y | ||
| 77 | |||
| 78 | config LOCKDEP_SUPPORT | ||
| 79 | bool | ||
| 80 | default y | ||
| 81 | |||
| 70 | config TRACE_IRQFLAGS_SUPPORT | 82 | config TRACE_IRQFLAGS_SUPPORT | 
| 71 | bool | 83 | bool | 
| 72 | default y | 84 | default y | 
| @@ -162,6 +174,8 @@ config ARCH_VERSATILE | |||
| 162 | select ARM_AMBA | 174 | select ARM_AMBA | 
| 163 | select ARM_VIC | 175 | select ARM_VIC | 
| 164 | select ICST307 | 176 | select ICST307 | 
| 177 | select GENERIC_TIME | ||
| 178 | select GENERIC_CLOCKEVENTS | ||
| 165 | help | 179 | help | 
| 166 | This enables support for ARM Ltd Versatile board. | 180 | This enables support for ARM Ltd Versatile board. | 
| 167 | 181 | ||
| @@ -262,6 +276,7 @@ config ARCH_IXP4XX | |||
| 262 | bool "IXP4xx-based" | 276 | bool "IXP4xx-based" | 
| 263 | depends on MMU | 277 | depends on MMU | 
| 264 | select GENERIC_TIME | 278 | select GENERIC_TIME | 
| 279 | select GENERIC_CLOCKEVENTS | ||
| 265 | help | 280 | help | 
| 266 | Support for Intel's IXP4XX (XScale) family of processors. | 281 | Support for Intel's IXP4XX (XScale) family of processors. | 
| 267 | 282 | ||
| @@ -363,6 +378,7 @@ config ARCH_LH7A40X | |||
| 363 | config ARCH_OMAP | 378 | config ARCH_OMAP | 
| 364 | bool "TI OMAP" | 379 | bool "TI OMAP" | 
| 365 | select GENERIC_GPIO | 380 | select GENERIC_GPIO | 
| 381 | select GENERIC_TIME | ||
| 366 | help | 382 | help | 
| 367 | Support for TI's OMAP platform (OMAP1 and OMAP2). | 383 | Support for TI's OMAP platform (OMAP1 and OMAP2). | 
| 368 | 384 | ||
| @@ -513,6 +529,8 @@ endmenu | |||
| 513 | 529 | ||
| 514 | menu "Kernel Features" | 530 | menu "Kernel Features" | 
| 515 | 531 | ||
| 532 | source "kernel/time/Kconfig" | ||
| 533 | |||
| 516 | config SMP | 534 | config SMP | 
| 517 | bool "Symmetric Multi-Processing (EXPERIMENTAL)" | 535 | bool "Symmetric Multi-Processing (EXPERIMENTAL)" | 
| 518 | depends on EXPERIMENTAL && REALVIEW_MPCORE | 536 | depends on EXPERIMENTAL && REALVIEW_MPCORE | 
| @@ -572,6 +590,7 @@ config PREEMPT | |||
| 572 | 590 | ||
| 573 | config NO_IDLE_HZ | 591 | config NO_IDLE_HZ | 
| 574 | bool "Dynamic tick timer" | 592 | bool "Dynamic tick timer" | 
| 593 | depends on !GENERIC_CLOCKEVENTS | ||
| 575 | help | 594 | help | 
| 576 | Select this option if you want to disable continuous timer ticks | 595 | Select this option if you want to disable continuous timer ticks | 
| 577 | and have them programmed to occur as required. This option saves | 596 | and have them programmed to occur as required. This option saves | 
| @@ -669,6 +688,7 @@ config LEDS_TIMER | |||
| 669 | bool "Timer LED" if (!ARCH_CDB89712 && !ARCH_OMAP) || \ | 688 | bool "Timer LED" if (!ARCH_CDB89712 && !ARCH_OMAP) || \ | 
| 670 | MACH_OMAP_H2 || MACH_OMAP_PERSEUS2 | 689 | MACH_OMAP_H2 || MACH_OMAP_PERSEUS2 | 
| 671 | depends on LEDS | 690 | depends on LEDS | 
| 691 | depends on !GENERIC_CLOCKEVENTS | ||
| 672 | default y if ARCH_EBSA110 | 692 | default y if ARCH_EBSA110 | 
| 673 | help | 693 | help | 
| 674 | If you say Y here, one of the system LEDs (the green one on the | 694 | If you say Y here, one of the system LEDs (the green one on the | 
| diff --git a/arch/arm/boot/compressed/head-at91rm9200.S b/arch/arm/boot/compressed/head-at91rm9200.S index d68b9acd826e..11782ccd93a1 100644 --- a/arch/arm/boot/compressed/head-at91rm9200.S +++ b/arch/arm/boot/compressed/head-at91rm9200.S | |||
| @@ -61,6 +61,12 @@ | |||
| 61 | cmp r7, r3 | 61 | cmp r7, r3 | 
| 62 | beq 99f | 62 | beq 99f | 
| 63 | 63 | ||
| 64 | @ picotux 200 : 963 | ||
| 65 | mov r3, #(MACH_TYPE_PICOTUX2XX & 0xff) | ||
| 66 | orr r3, r3, #(MACH_TYPE_PICOTUX2XX & 0xff00) | ||
| 67 | cmp r7, r3 | ||
| 68 | beq 99f | ||
| 69 | |||
| 64 | @ Ajeco 1ARM : 1075 | 70 | @ Ajeco 1ARM : 1075 | 
| 65 | mov r3, #(MACH_TYPE_ONEARM & 0xff) | 71 | mov r3, #(MACH_TYPE_ONEARM & 0xff) | 
| 66 | orr r3, r3, #(MACH_TYPE_ONEARM & 0xff00) | 72 | orr r3, r3, #(MACH_TYPE_ONEARM & 0xff00) | 
| diff --git a/arch/arm/configs/picotux200_defconfig b/arch/arm/configs/picotux200_defconfig new file mode 100644 index 000000000000..339c48953a62 --- /dev/null +++ b/arch/arm/configs/picotux200_defconfig | |||
| @@ -0,0 +1,1386 @@ | |||
| 1 | # | ||
| 2 | # Automatically generated make config: don't edit | ||
| 3 | # Linux kernel version: 2.6.21-rc4 | ||
| 4 | # Wed Mar 28 16:19:50 2007 | ||
| 5 | # | ||
| 6 | CONFIG_ARM=y | ||
| 7 | CONFIG_SYS_SUPPORTS_APM_EMULATION=y | ||
| 8 | CONFIG_GENERIC_GPIO=y | ||
| 9 | # CONFIG_GENERIC_TIME is not set | ||
| 10 | CONFIG_MMU=y | ||
| 11 | # CONFIG_NO_IOPORT is not set | ||
| 12 | CONFIG_GENERIC_HARDIRQS=y | ||
| 13 | CONFIG_TRACE_IRQFLAGS_SUPPORT=y | ||
| 14 | CONFIG_HARDIRQS_SW_RESEND=y | ||
| 15 | CONFIG_GENERIC_IRQ_PROBE=y | ||
| 16 | CONFIG_RWSEM_GENERIC_SPINLOCK=y | ||
| 17 | # CONFIG_ARCH_HAS_ILOG2_U32 is not set | ||
| 18 | # CONFIG_ARCH_HAS_ILOG2_U64 is not set | ||
| 19 | CONFIG_GENERIC_HWEIGHT=y | ||
| 20 | CONFIG_GENERIC_CALIBRATE_DELAY=y | ||
| 21 | CONFIG_ZONE_DMA=y | ||
| 22 | CONFIG_VECTORS_BASE=0xffff0000 | ||
| 23 | CONFIG_DEFCONFIG_LIST="/lib/modules/$UNAME_RELEASE/.config" | ||
| 24 | |||
| 25 | # | ||
| 26 | # Code maturity level options | ||
| 27 | # | ||
| 28 | CONFIG_EXPERIMENTAL=y | ||
| 29 | CONFIG_BROKEN_ON_SMP=y | ||
| 30 | CONFIG_INIT_ENV_ARG_LIMIT=32 | ||
| 31 | |||
| 32 | # | ||
| 33 | # General setup | ||
| 34 | # | ||
| 35 | CONFIG_LOCALVERSION="" | ||
| 36 | CONFIG_LOCALVERSION_AUTO=y | ||
| 37 | CONFIG_SWAP=y | ||
| 38 | CONFIG_SYSVIPC=y | ||
| 39 | # CONFIG_IPC_NS is not set | ||
| 40 | CONFIG_SYSVIPC_SYSCTL=y | ||
| 41 | # CONFIG_POSIX_MQUEUE is not set | ||
| 42 | # CONFIG_BSD_PROCESS_ACCT is not set | ||
| 43 | # CONFIG_TASKSTATS is not set | ||
| 44 | # CONFIG_UTS_NS is not set | ||
| 45 | # CONFIG_AUDIT is not set | ||
| 46 | CONFIG_IKCONFIG=m | ||
| 47 | CONFIG_IKCONFIG_PROC=y | ||
| 48 | # CONFIG_SYSFS_DEPRECATED is not set | ||
| 49 | # CONFIG_RELAY is not set | ||
| 50 | # CONFIG_BLK_DEV_INITRD is not set | ||
| 51 | CONFIG_CC_OPTIMIZE_FOR_SIZE=y | ||
| 52 | CONFIG_SYSCTL=y | ||
| 53 | CONFIG_EMBEDDED=y | ||
| 54 | CONFIG_UID16=y | ||
| 55 | CONFIG_SYSCTL_SYSCALL=y | ||
| 56 | # CONFIG_KALLSYMS is not set | ||
| 57 | CONFIG_HOTPLUG=y | ||
| 58 | CONFIG_PRINTK=y | ||
| 59 | CONFIG_BUG=y | ||
| 60 | CONFIG_ELF_CORE=y | ||
| 61 | CONFIG_BASE_FULL=y | ||
| 62 | CONFIG_FUTEX=y | ||
| 63 | CONFIG_EPOLL=y | ||
| 64 | CONFIG_SHMEM=y | ||
| 65 | CONFIG_SLAB=y | ||
| 66 | CONFIG_VM_EVENT_COUNTERS=y | ||
| 67 | CONFIG_RT_MUTEXES=y | ||
| 68 | # CONFIG_TINY_SHMEM is not set | ||
| 69 | CONFIG_BASE_SMALL=0 | ||
| 70 | # CONFIG_SLOB is not set | ||
| 71 | |||
| 72 | # | ||
| 73 | # Loadable module support | ||
| 74 | # | ||
| 75 | CONFIG_MODULES=y | ||
| 76 | CONFIG_MODULE_UNLOAD=y | ||
| 77 | # CONFIG_MODULE_FORCE_UNLOAD is not set | ||
| 78 | # CONFIG_MODVERSIONS is not set | ||
| 79 | # CONFIG_MODULE_SRCVERSION_ALL is not set | ||
| 80 | CONFIG_KMOD=y | ||
| 81 | |||
| 82 | # | ||
| 83 | # Block layer | ||
| 84 | # | ||
| 85 | CONFIG_BLOCK=y | ||
| 86 | # CONFIG_LBD is not set | ||
| 87 | # CONFIG_BLK_DEV_IO_TRACE is not set | ||
| 88 | # CONFIG_LSF is not set | ||
| 89 | |||
| 90 | # | ||
| 91 | # IO Schedulers | ||
| 92 | # | ||
| 93 | CONFIG_IOSCHED_NOOP=y | ||
| 94 | # CONFIG_IOSCHED_AS is not set | ||
| 95 | # CONFIG_IOSCHED_DEADLINE is not set | ||
| 96 | # CONFIG_IOSCHED_CFQ is not set | ||
| 97 | # CONFIG_DEFAULT_AS is not set | ||
| 98 | # CONFIG_DEFAULT_DEADLINE is not set | ||
| 99 | # CONFIG_DEFAULT_CFQ is not set | ||
| 100 | CONFIG_DEFAULT_NOOP=y | ||
| 101 | CONFIG_DEFAULT_IOSCHED="noop" | ||
| 102 | |||
| 103 | # | ||
| 104 | # System Type | ||
| 105 | # | ||
| 106 | # CONFIG_ARCH_AAEC2000 is not set | ||
| 107 | # CONFIG_ARCH_INTEGRATOR is not set | ||
| 108 | # CONFIG_ARCH_REALVIEW is not set | ||
| 109 | # CONFIG_ARCH_VERSATILE is not set | ||
| 110 | CONFIG_ARCH_AT91=y | ||
| 111 | # CONFIG_ARCH_CLPS7500 is not set | ||
| 112 | # CONFIG_ARCH_CLPS711X is not set | ||
| 113 | # CONFIG_ARCH_CO285 is not set | ||
| 114 | # CONFIG_ARCH_EBSA110 is not set | ||
| 115 | # CONFIG_ARCH_EP93XX is not set | ||
| 116 | # CONFIG_ARCH_FOOTBRIDGE is not set | ||
| 117 | # CONFIG_ARCH_NETX is not set | ||
| 118 | # CONFIG_ARCH_H720X is not set | ||
| 119 | # CONFIG_ARCH_IMX is not set | ||
| 120 | # CONFIG_ARCH_IOP32X is not set | ||
| 121 | # CONFIG_ARCH_IOP33X is not set | ||
| 122 | # CONFIG_ARCH_IOP13XX is not set | ||
| 123 | # CONFIG_ARCH_IXP4XX is not set | ||
| 124 | # CONFIG_ARCH_IXP2000 is not set | ||
| 125 | # CONFIG_ARCH_IXP23XX is not set | ||
| 126 | # CONFIG_ARCH_L7200 is not set | ||
| 127 | # CONFIG_ARCH_NS9XXX is not set | ||
| 128 | # CONFIG_ARCH_PNX4008 is not set | ||
| 129 | # CONFIG_ARCH_PXA is not set | ||
| 130 | # CONFIG_ARCH_RPC is not set | ||
| 131 | # CONFIG_ARCH_SA1100 is not set | ||
| 132 | # CONFIG_ARCH_S3C2410 is not set | ||
| 133 | # CONFIG_ARCH_SHARK is not set | ||
| 134 | # CONFIG_ARCH_LH7A40X is not set | ||
| 135 | # CONFIG_ARCH_OMAP is not set | ||
| 136 | |||
| 137 | # | ||
| 138 | # Atmel AT91 System-on-Chip | ||
| 139 | # | ||
| 140 | CONFIG_ARCH_AT91RM9200=y | ||
| 141 | # CONFIG_ARCH_AT91SAM9260 is not set | ||
| 142 | # CONFIG_ARCH_AT91SAM9261 is not set | ||
| 143 | # CONFIG_ARCH_AT91SAM9263 is not set | ||
| 144 | |||
| 145 | # | ||
| 146 | # AT91RM9200 Board Type | ||
| 147 | # | ||
| 148 | # CONFIG_MACH_ONEARM is not set | ||
| 149 | # CONFIG_ARCH_AT91RM9200DK is not set | ||
| 150 | # CONFIG_MACH_AT91RM9200EK is not set | ||
| 151 | # CONFIG_MACH_CSB337 is not set | ||
| 152 | # CONFIG_MACH_CSB637 is not set | ||
| 153 | # CONFIG_MACH_CARMEVA is not set | ||
| 154 | # CONFIG_MACH_ATEB9200 is not set | ||
| 155 | # CONFIG_MACH_KB9200 is not set | ||
| 156 | CONFIG_MACH_PICOTUX2XX=y | ||
| 157 | # CONFIG_MACH_KAFA is not set | ||
| 158 | |||
| 159 | # | ||
| 160 | # AT91 Board Options | ||
| 161 | # | ||
| 162 | |||
| 163 | # | ||
| 164 | # AT91 Feature Selections | ||
| 165 | # | ||
| 166 | CONFIG_AT91_PROGRAMMABLE_CLOCKS=y | ||
| 167 | |||
| 168 | # | ||
| 169 | # Processor Type | ||
| 170 | # | ||
| 171 | CONFIG_CPU_32=y | ||
| 172 | CONFIG_CPU_ARM920T=y | ||
| 173 | CONFIG_CPU_32v4T=y | ||
| 174 | CONFIG_CPU_ABRT_EV4T=y | ||
| 175 | CONFIG_CPU_CACHE_V4WT=y | ||
| 176 | CONFIG_CPU_CACHE_VIVT=y | ||
| 177 | CONFIG_CPU_COPY_V4WB=y | ||
| 178 | CONFIG_CPU_TLB_V4WBI=y | ||
| 179 | CONFIG_CPU_CP15=y | ||
| 180 | CONFIG_CPU_CP15_MMU=y | ||
| 181 | |||
| 182 | # | ||
| 183 | # Processor Features | ||
| 184 | # | ||
| 185 | CONFIG_ARM_THUMB=y | ||
| 186 | # CONFIG_CPU_ICACHE_DISABLE is not set | ||
| 187 | # CONFIG_CPU_DCACHE_DISABLE is not set | ||
| 188 | # CONFIG_CPU_DCACHE_WRITETHROUGH is not set | ||
| 189 | # CONFIG_OUTER_CACHE is not set | ||
| 190 | |||
| 191 | # | ||
| 192 | # Bus support | ||
| 193 | # | ||
| 194 | |||
| 195 | # | ||
| 196 | # PCCARD (PCMCIA/CardBus) support | ||
| 197 | # | ||
| 198 | # CONFIG_PCCARD is not set | ||
| 199 | |||
| 200 | # | ||
| 201 | # Kernel Features | ||
| 202 | # | ||
| 203 | # CONFIG_PREEMPT is not set | ||
| 204 | CONFIG_NO_IDLE_HZ=y | ||
| 205 | CONFIG_HZ=100 | ||
| 206 | CONFIG_AEABI=y | ||
| 207 | CONFIG_OABI_COMPAT=y | ||
| 208 | # CONFIG_ARCH_DISCONTIGMEM_ENABLE is not set | ||
| 209 | CONFIG_SELECT_MEMORY_MODEL=y | ||
| 210 | CONFIG_FLATMEM_MANUAL=y | ||
| 211 | # CONFIG_DISCONTIGMEM_MANUAL is not set | ||
| 212 | # CONFIG_SPARSEMEM_MANUAL is not set | ||
| 213 | CONFIG_FLATMEM=y | ||
| 214 | CONFIG_FLAT_NODE_MEM_MAP=y | ||
| 215 | # CONFIG_SPARSEMEM_STATIC is not set | ||
| 216 | CONFIG_SPLIT_PTLOCK_CPUS=4096 | ||
| 217 | # CONFIG_RESOURCES_64BIT is not set | ||
| 218 | CONFIG_ZONE_DMA_FLAG=1 | ||
| 219 | # CONFIG_LEDS is not set | ||
| 220 | CONFIG_ALIGNMENT_TRAP=y | ||
| 221 | |||
| 222 | # | ||
| 223 | # Boot options | ||
| 224 | # | ||
| 225 | CONFIG_ZBOOT_ROM_TEXT=0x0 | ||
| 226 | CONFIG_ZBOOT_ROM_BSS=0x0 | ||
| 227 | CONFIG_CMDLINE="" | ||
| 228 | # CONFIG_XIP_KERNEL is not set | ||
| 229 | CONFIG_KEXEC=y | ||
| 230 | |||
| 231 | # | ||
| 232 | # Floating point emulation | ||
| 233 | # | ||
| 234 | |||
| 235 | # | ||
| 236 | # At least one emulation must be selected | ||
| 237 | # | ||
| 238 | CONFIG_FPE_NWFPE=y | ||
| 239 | # CONFIG_FPE_NWFPE_XP is not set | ||
| 240 | # CONFIG_FPE_FASTFPE is not set | ||
| 241 | |||
| 242 | # | ||
| 243 | # Userspace binary formats | ||
| 244 | # | ||
| 245 | CONFIG_BINFMT_ELF=y | ||
| 246 | # CONFIG_BINFMT_AOUT is not set | ||
| 247 | CONFIG_BINFMT_MISC=m | ||
| 248 | |||
| 249 | # | ||
| 250 | # Power management options | ||
| 251 | # | ||
| 252 | # CONFIG_PM is not set | ||
| 253 | |||
| 254 | # | ||
| 255 | # Networking | ||
| 256 | # | ||
| 257 | CONFIG_NET=y | ||
| 258 | |||
| 259 | # | ||
| 260 | # Networking options | ||
| 261 | # | ||
| 262 | # CONFIG_NETDEBUG is not set | ||
| 263 | CONFIG_PACKET=m | ||
| 264 | CONFIG_PACKET_MMAP=y | ||
| 265 | CONFIG_UNIX=y | ||
| 266 | CONFIG_XFRM=y | ||
| 267 | CONFIG_XFRM_USER=m | ||
| 268 | # CONFIG_XFRM_SUB_POLICY is not set | ||
| 269 | # CONFIG_XFRM_MIGRATE is not set | ||
| 270 | # CONFIG_NET_KEY is not set | ||
| 271 | CONFIG_INET=y | ||
| 272 | # CONFIG_IP_MULTICAST is not set | ||
| 273 | # CONFIG_IP_ADVANCED_ROUTER is not set | ||
| 274 | CONFIG_IP_FIB_HASH=y | ||
| 275 | CONFIG_IP_PNP=y | ||
| 276 | # CONFIG_IP_PNP_DHCP is not set | ||
| 277 | CONFIG_IP_PNP_BOOTP=y | ||
| 278 | # CONFIG_IP_PNP_RARP is not set | ||
| 279 | CONFIG_NET_IPIP=m | ||
| 280 | CONFIG_NET_IPGRE=m | ||
| 281 | # CONFIG_ARPD is not set | ||
| 282 | # CONFIG_SYN_COOKIES is not set | ||
| 283 | CONFIG_INET_AH=m | ||
| 284 | CONFIG_INET_ESP=m | ||
| 285 | CONFIG_INET_IPCOMP=m | ||
| 286 | CONFIG_INET_XFRM_TUNNEL=m | ||
| 287 | CONFIG_INET_TUNNEL=m | ||
| 288 | CONFIG_INET_XFRM_MODE_TRANSPORT=m | ||
| 289 | CONFIG_INET_XFRM_MODE_TUNNEL=m | ||
| 290 | CONFIG_INET_XFRM_MODE_BEET=m | ||
| 291 | CONFIG_INET_DIAG=m | ||
| 292 | CONFIG_INET_TCP_DIAG=m | ||
| 293 | # CONFIG_TCP_CONG_ADVANCED is not set | ||
| 294 | CONFIG_TCP_CONG_CUBIC=y | ||
| 295 | CONFIG_DEFAULT_TCP_CONG="cubic" | ||
| 296 | # CONFIG_TCP_MD5SIG is not set | ||
| 297 | CONFIG_IPV6=m | ||
| 298 | CONFIG_IPV6_PRIVACY=y | ||
| 299 | CONFIG_IPV6_ROUTER_PREF=y | ||
| 300 | CONFIG_IPV6_ROUTE_INFO=y | ||
| 301 | CONFIG_INET6_AH=m | ||
| 302 | CONFIG_INET6_ESP=m | ||
| 303 | CONFIG_INET6_IPCOMP=m | ||
| 304 | CONFIG_IPV6_MIP6=y | ||
| 305 | CONFIG_INET6_XFRM_TUNNEL=m | ||
| 306 | CONFIG_INET6_TUNNEL=m | ||
| 307 | CONFIG_INET6_XFRM_MODE_TRANSPORT=m | ||
| 308 | CONFIG_INET6_XFRM_MODE_TUNNEL=m | ||
| 309 | CONFIG_INET6_XFRM_MODE_BEET=m | ||
| 310 | CONFIG_INET6_XFRM_MODE_ROUTEOPTIMIZATION=m | ||
| 311 | CONFIG_IPV6_SIT=m | ||
| 312 | CONFIG_IPV6_TUNNEL=m | ||
| 313 | # CONFIG_IPV6_MULTIPLE_TABLES is not set | ||
| 314 | # CONFIG_NETWORK_SECMARK is not set | ||
| 315 | # CONFIG_NETFILTER is not set | ||
| 316 | |||
| 317 | # | ||
| 318 | # DCCP Configuration (EXPERIMENTAL) | ||
| 319 | # | ||
| 320 | # CONFIG_IP_DCCP is not set | ||
| 321 | |||
| 322 | # | ||
| 323 | # SCTP Configuration (EXPERIMENTAL) | ||
| 324 | # | ||
| 325 | # CONFIG_IP_SCTP is not set | ||
| 326 | |||
| 327 | # | ||
| 328 | # TIPC Configuration (EXPERIMENTAL) | ||
| 329 | # | ||
| 330 | # CONFIG_TIPC is not set | ||
| 331 | # CONFIG_ATM is not set | ||
| 332 | CONFIG_BRIDGE=m | ||
| 333 | CONFIG_VLAN_8021Q=m | ||
| 334 | # CONFIG_DECNET is not set | ||
| 335 | CONFIG_LLC=m | ||
| 336 | # CONFIG_LLC2 is not set | ||
| 337 | # CONFIG_IPX is not set | ||
| 338 | # CONFIG_ATALK is not set | ||
| 339 | # CONFIG_X25 is not set | ||
| 340 | # CONFIG_LAPB is not set | ||
| 341 | # CONFIG_ECONET is not set | ||
| 342 | # CONFIG_WAN_ROUTER is not set | ||
| 343 | |||
| 344 | # | ||
| 345 | # QoS and/or fair queueing | ||
| 346 | # | ||
| 347 | # CONFIG_NET_SCHED is not set | ||
| 348 | |||
| 349 | # | ||
| 350 | # Network testing | ||
| 351 | # | ||
| 352 | # CONFIG_NET_PKTGEN is not set | ||
| 353 | # CONFIG_HAMRADIO is not set | ||
| 354 | # CONFIG_IRDA is not set | ||
| 355 | CONFIG_BT=m | ||
| 356 | CONFIG_BT_L2CAP=m | ||
| 357 | CONFIG_BT_SCO=m | ||
| 358 | CONFIG_BT_RFCOMM=m | ||
| 359 | CONFIG_BT_RFCOMM_TTY=y | ||
| 360 | CONFIG_BT_BNEP=m | ||
| 361 | CONFIG_BT_BNEP_MC_FILTER=y | ||
| 362 | CONFIG_BT_BNEP_PROTO_FILTER=y | ||
| 363 | CONFIG_BT_HIDP=m | ||
| 364 | |||
| 365 | # | ||
| 366 | # Bluetooth device drivers | ||
| 367 | # | ||
| 368 | CONFIG_BT_HCIUSB=m | ||
| 369 | CONFIG_BT_HCIUSB_SCO=y | ||
| 370 | # CONFIG_BT_HCIUART is not set | ||
| 371 | # CONFIG_BT_HCIBCM203X is not set | ||
| 372 | # CONFIG_BT_HCIBPA10X is not set | ||
| 373 | # CONFIG_BT_HCIBFUSB is not set | ||
| 374 | # CONFIG_BT_HCIVHCI is not set | ||
| 375 | # CONFIG_IEEE80211 is not set | ||
| 376 | |||
| 377 | # | ||
| 378 | # Device Drivers | ||
| 379 | # | ||
| 380 | |||
| 381 | # | ||
| 382 | # Generic Driver Options | ||
| 383 | # | ||
| 384 | CONFIG_STANDALONE=y | ||
| 385 | CONFIG_PREVENT_FIRMWARE_BUILD=y | ||
| 386 | CONFIG_FW_LOADER=m | ||
| 387 | # CONFIG_DEBUG_DRIVER is not set | ||
| 388 | # CONFIG_DEBUG_DEVRES is not set | ||
| 389 | # CONFIG_SYS_HYPERVISOR is not set | ||
| 390 | |||
| 391 | # | ||
| 392 | # Connector - unified userspace <-> kernelspace linker | ||
| 393 | # | ||
| 394 | # CONFIG_CONNECTOR is not set | ||
| 395 | |||
| 396 | # | ||
| 397 | # Memory Technology Devices (MTD) | ||
| 398 | # | ||
| 399 | CONFIG_MTD=y | ||
| 400 | # CONFIG_MTD_DEBUG is not set | ||
| 401 | # CONFIG_MTD_CONCAT is not set | ||
| 402 | CONFIG_MTD_PARTITIONS=y | ||
| 403 | # CONFIG_MTD_REDBOOT_PARTS is not set | ||
| 404 | CONFIG_MTD_CMDLINE_PARTS=y | ||
| 405 | # CONFIG_MTD_AFS_PARTS is not set | ||
| 406 | |||
| 407 | # | ||
| 408 | # User Modules And Translation Layers | ||
| 409 | # | ||
| 410 | CONFIG_MTD_CHAR=y | ||
| 411 | CONFIG_MTD_BLKDEVS=y | ||
| 412 | CONFIG_MTD_BLOCK=y | ||
| 413 | # CONFIG_FTL is not set | ||
| 414 | # CONFIG_NFTL is not set | ||
| 415 | # CONFIG_INFTL is not set | ||
| 416 | # CONFIG_RFD_FTL is not set | ||
| 417 | # CONFIG_SSFDC is not set | ||
| 418 | |||
| 419 | # | ||
| 420 | # RAM/ROM/Flash chip drivers | ||
| 421 | # | ||
| 422 | CONFIG_MTD_CFI=y | ||
| 423 | # CONFIG_MTD_JEDECPROBE is not set | ||
| 424 | CONFIG_MTD_GEN_PROBE=y | ||
| 425 | # CONFIG_MTD_CFI_ADV_OPTIONS is not set | ||
| 426 | CONFIG_MTD_MAP_BANK_WIDTH_1=y | ||
| 427 | CONFIG_MTD_MAP_BANK_WIDTH_2=y | ||
| 428 | CONFIG_MTD_MAP_BANK_WIDTH_4=y | ||
| 429 | # CONFIG_MTD_MAP_BANK_WIDTH_8 is not set | ||
| 430 | # CONFIG_MTD_MAP_BANK_WIDTH_16 is not set | ||
| 431 | # CONFIG_MTD_MAP_BANK_WIDTH_32 is not set | ||
| 432 | CONFIG_MTD_CFI_I1=y | ||
| 433 | CONFIG_MTD_CFI_I2=y | ||
| 434 | # CONFIG_MTD_CFI_I4 is not set | ||
| 435 | # CONFIG_MTD_CFI_I8 is not set | ||
| 436 | # CONFIG_MTD_CFI_INTELEXT is not set | ||
| 437 | CONFIG_MTD_CFI_AMDSTD=y | ||
| 438 | # CONFIG_MTD_CFI_STAA is not set | ||
| 439 | CONFIG_MTD_CFI_UTIL=y | ||
| 440 | # CONFIG_MTD_RAM is not set | ||
| 441 | # CONFIG_MTD_ROM is not set | ||
| 442 | # CONFIG_MTD_ABSENT is not set | ||
| 443 | # CONFIG_MTD_OBSOLETE_CHIPS is not set | ||
| 444 | |||
| 445 | # | ||
| 446 | # Mapping drivers for chip access | ||
| 447 | # | ||
| 448 | # CONFIG_MTD_COMPLEX_MAPPINGS is not set | ||
| 449 | CONFIG_MTD_PHYSMAP=y | ||
| 450 | CONFIG_MTD_PHYSMAP_START=0x8000000 | ||
| 451 | CONFIG_MTD_PHYSMAP_LEN=0x0 | ||
| 452 | CONFIG_MTD_PHYSMAP_BANKWIDTH=2 | ||
| 453 | # CONFIG_MTD_ARM_INTEGRATOR is not set | ||
| 454 | # CONFIG_MTD_PLATRAM is not set | ||
| 455 | |||
| 456 | # | ||
| 457 | # Self-contained MTD device drivers | ||
| 458 | # | ||
| 459 | # CONFIG_MTD_SLRAM is not set | ||
| 460 | # CONFIG_MTD_PHRAM is not set | ||
| 461 | # CONFIG_MTD_MTDRAM is not set | ||
| 462 | # CONFIG_MTD_BLOCK2MTD is not set | ||
| 463 | |||
| 464 | # | ||
| 465 | # Disk-On-Chip Device Drivers | ||
| 466 | # | ||
| 467 | # CONFIG_MTD_DOC2000 is not set | ||
| 468 | # CONFIG_MTD_DOC2001 is not set | ||
| 469 | # CONFIG_MTD_DOC2001PLUS is not set | ||
| 470 | |||
| 471 | # | ||
| 472 | # NAND Flash Device Drivers | ||
| 473 | # | ||
| 474 | # CONFIG_MTD_NAND is not set | ||
| 475 | |||
| 476 | # | ||
| 477 | # OneNAND Flash Device Drivers | ||
| 478 | # | ||
| 479 | # CONFIG_MTD_ONENAND is not set | ||
| 480 | |||
| 481 | # | ||
| 482 | # Parallel port support | ||
| 483 | # | ||
| 484 | # CONFIG_PARPORT is not set | ||
| 485 | |||
| 486 | # | ||
| 487 | # Plug and Play support | ||
| 488 | # | ||
| 489 | # CONFIG_PNPACPI is not set | ||
| 490 | |||
| 491 | # | ||
| 492 | # Block devices | ||
| 493 | # | ||
| 494 | # CONFIG_BLK_DEV_COW_COMMON is not set | ||
| 495 | CONFIG_BLK_DEV_LOOP=m | ||
| 496 | # CONFIG_BLK_DEV_CRYPTOLOOP is not set | ||
| 497 | # CONFIG_BLK_DEV_NBD is not set | ||
| 498 | # CONFIG_BLK_DEV_UB is not set | ||
| 499 | # CONFIG_BLK_DEV_RAM is not set | ||
| 500 | # CONFIG_CDROM_PKTCDVD is not set | ||
| 501 | # CONFIG_ATA_OVER_ETH is not set | ||
| 502 | |||
| 503 | # | ||
| 504 | # SCSI device support | ||
| 505 | # | ||
| 506 | # CONFIG_RAID_ATTRS is not set | ||
| 507 | CONFIG_SCSI=m | ||
| 508 | # CONFIG_SCSI_TGT is not set | ||
| 509 | # CONFIG_SCSI_NETLINK is not set | ||
| 510 | CONFIG_SCSI_PROC_FS=y | ||
| 511 | |||
| 512 | # | ||
| 513 | # SCSI support type (disk, tape, CD-ROM) | ||
| 514 | # | ||
| 515 | CONFIG_BLK_DEV_SD=m | ||
| 516 | # CONFIG_CHR_DEV_ST is not set | ||
| 517 | # CONFIG_CHR_DEV_OSST is not set | ||
| 518 | CONFIG_BLK_DEV_SR=m | ||
| 519 | CONFIG_BLK_DEV_SR_VENDOR=y | ||
| 520 | CONFIG_CHR_DEV_SG=m | ||
| 521 | # CONFIG_CHR_DEV_SCH is not set | ||
| 522 | |||
| 523 | # | ||
| 524 | # Some SCSI devices (e.g. CD jukebox) support multiple LUNs | ||
| 525 | # | ||
| 526 | # CONFIG_SCSI_MULTI_LUN is not set | ||
| 527 | # CONFIG_SCSI_CONSTANTS is not set | ||
| 528 | # CONFIG_SCSI_LOGGING is not set | ||
| 529 | # CONFIG_SCSI_SCAN_ASYNC is not set | ||
| 530 | |||
| 531 | # | ||
| 532 | # SCSI Transports | ||
| 533 | # | ||
| 534 | # CONFIG_SCSI_SPI_ATTRS is not set | ||
| 535 | # CONFIG_SCSI_FC_ATTRS is not set | ||
| 536 | # CONFIG_SCSI_ISCSI_ATTRS is not set | ||
| 537 | # CONFIG_SCSI_SAS_ATTRS is not set | ||
| 538 | # CONFIG_SCSI_SAS_LIBSAS is not set | ||
| 539 | |||
| 540 | # | ||
| 541 | # SCSI low-level drivers | ||
| 542 | # | ||
| 543 | # CONFIG_ISCSI_TCP is not set | ||
| 544 | # CONFIG_SCSI_DEBUG is not set | ||
| 545 | |||
| 546 | # | ||
| 547 | # Serial ATA (prod) and Parallel ATA (experimental) drivers | ||
| 548 | # | ||
| 549 | # CONFIG_ATA is not set | ||
| 550 | |||
| 551 | # | ||
| 552 | # Multi-device support (RAID and LVM) | ||
| 553 | # | ||
| 554 | # CONFIG_MD is not set | ||
| 555 | |||
| 556 | # | ||
| 557 | # Fusion MPT device support | ||
| 558 | # | ||
| 559 | # CONFIG_FUSION is not set | ||
| 560 | |||
| 561 | # | ||
| 562 | # IEEE 1394 (FireWire) support | ||
| 563 | # | ||
| 564 | |||
| 565 | # | ||
| 566 | # I2O device support | ||
| 567 | # | ||
| 568 | |||
| 569 | # | ||
| 570 | # Network device support | ||
| 571 | # | ||
| 572 | CONFIG_NETDEVICES=y | ||
| 573 | # CONFIG_DUMMY is not set | ||
| 574 | # CONFIG_BONDING is not set | ||
| 575 | # CONFIG_EQUALIZER is not set | ||
| 576 | CONFIG_TUN=m | ||
| 577 | |||
| 578 | # | ||
| 579 | # PHY device support | ||
| 580 | # | ||
| 581 | # CONFIG_PHYLIB is not set | ||
| 582 | |||
| 583 | # | ||
| 584 | # Ethernet (10 or 100Mbit) | ||
| 585 | # | ||
| 586 | CONFIG_NET_ETHERNET=y | ||
| 587 | CONFIG_MII=y | ||
| 588 | CONFIG_ARM_AT91_ETHER=y | ||
| 589 | # CONFIG_SMC91X is not set | ||
| 590 | # CONFIG_DM9000 is not set | ||
| 591 | |||
| 592 | # | ||
| 593 | # Ethernet (1000 Mbit) | ||
| 594 | # | ||
| 595 | |||
| 596 | # | ||
| 597 | # Ethernet (10000 Mbit) | ||
| 598 | # | ||
| 599 | |||
| 600 | # | ||
| 601 | # Token Ring devices | ||
| 602 | # | ||
| 603 | |||
| 604 | # | ||
| 605 | # Wireless LAN (non-hamradio) | ||
| 606 | # | ||
| 607 | # CONFIG_NET_RADIO is not set | ||
| 608 | |||
| 609 | # | ||
| 610 | # Wan interfaces | ||
| 611 | # | ||
| 612 | # CONFIG_WAN is not set | ||
| 613 | CONFIG_PPP=m | ||
| 614 | # CONFIG_PPP_MULTILINK is not set | ||
| 615 | CONFIG_PPP_FILTER=y | ||
| 616 | CONFIG_PPP_ASYNC=m | ||
| 617 | # CONFIG_PPP_SYNC_TTY is not set | ||
| 618 | CONFIG_PPP_DEFLATE=m | ||
| 619 | CONFIG_PPP_BSDCOMP=m | ||
| 620 | CONFIG_PPP_MPPE=m | ||
| 621 | CONFIG_PPPOE=m | ||
| 622 | CONFIG_SLIP=m | ||
| 623 | CONFIG_SLIP_COMPRESSED=y | ||
| 624 | CONFIG_SLHC=m | ||
| 625 | CONFIG_SLIP_SMART=y | ||
| 626 | CONFIG_SLIP_MODE_SLIP6=y | ||
| 627 | # CONFIG_SHAPER is not set | ||
| 628 | # CONFIG_NETCONSOLE is not set | ||
| 629 | # CONFIG_NETPOLL is not set | ||
| 630 | # CONFIG_NET_POLL_CONTROLLER is not set | ||
| 631 | |||
| 632 | # | ||
| 633 | # ISDN subsystem | ||
| 634 | # | ||
| 635 | # CONFIG_ISDN is not set | ||
| 636 | |||
| 637 | # | ||
| 638 | # Input device support | ||
| 639 | # | ||
| 640 | CONFIG_INPUT=y | ||
| 641 | # CONFIG_INPUT_FF_MEMLESS is not set | ||
| 642 | |||
| 643 | # | ||
| 644 | # Userland interfaces | ||
| 645 | # | ||
| 646 | # CONFIG_INPUT_MOUSEDEV is not set | ||
| 647 | # CONFIG_INPUT_JOYDEV is not set | ||
| 648 | # CONFIG_INPUT_TSDEV is not set | ||
| 649 | # CONFIG_INPUT_EVDEV is not set | ||
| 650 | # CONFIG_INPUT_EVBUG is not set | ||
| 651 | |||
| 652 | # | ||
| 653 | # Input Device Drivers | ||
| 654 | # | ||
| 655 | # CONFIG_INPUT_KEYBOARD is not set | ||
| 656 | # CONFIG_INPUT_MOUSE is not set | ||
| 657 | # CONFIG_INPUT_JOYSTICK is not set | ||
| 658 | # CONFIG_INPUT_TOUCHSCREEN is not set | ||
| 659 | # CONFIG_INPUT_MISC is not set | ||
| 660 | |||
| 661 | # | ||
| 662 | # Hardware I/O ports | ||
| 663 | # | ||
| 664 | # CONFIG_SERIO is not set | ||
| 665 | # CONFIG_GAMEPORT is not set | ||
| 666 | |||
| 667 | # | ||
| 668 | # Character devices | ||
| 669 | # | ||
| 670 | # CONFIG_VT is not set | ||
| 671 | # CONFIG_SERIAL_NONSTANDARD is not set | ||
| 672 | |||
| 673 | # | ||
| 674 | # Serial drivers | ||
| 675 | # | ||
| 676 | # CONFIG_SERIAL_8250 is not set | ||
| 677 | |||
| 678 | # | ||
| 679 | # Non-8250 serial port support | ||
| 680 | # | ||
| 681 | CONFIG_SERIAL_ATMEL=y | ||
| 682 | CONFIG_SERIAL_ATMEL_CONSOLE=y | ||
| 683 | # CONFIG_SERIAL_ATMEL_TTYAT is not set | ||
| 684 | CONFIG_SERIAL_CORE=y | ||
| 685 | CONFIG_SERIAL_CORE_CONSOLE=y | ||
| 686 | CONFIG_UNIX98_PTYS=y | ||
| 687 | # CONFIG_LEGACY_PTYS is not set | ||
| 688 | |||
| 689 | # | ||
| 690 | # IPMI | ||
| 691 | # | ||
| 692 | # CONFIG_IPMI_HANDLER is not set | ||
| 693 | |||
| 694 | # | ||
| 695 | # Watchdog Cards | ||
| 696 | # | ||
| 697 | CONFIG_WATCHDOG=y | ||
| 698 | CONFIG_WATCHDOG_NOWAYOUT=y | ||
| 699 | |||
| 700 | # | ||
| 701 | # Watchdog Device Drivers | ||
| 702 | # | ||
| 703 | # CONFIG_SOFT_WATCHDOG is not set | ||
| 704 | CONFIG_AT91RM9200_WATCHDOG=m | ||
| 705 | |||
| 706 | # | ||
| 707 | # USB-based Watchdog Cards | ||
| 708 | # | ||
| 709 | # CONFIG_USBPCWATCHDOG is not set | ||
| 710 | CONFIG_HW_RANDOM=m | ||
| 711 | # CONFIG_NVRAM is not set | ||
| 712 | # CONFIG_DTLK is not set | ||
| 713 | # CONFIG_R3964 is not set | ||
| 714 | # CONFIG_RAW_DRIVER is not set | ||
| 715 | |||
| 716 | # | ||
| 717 | # TPM devices | ||
| 718 | # | ||
| 719 | # CONFIG_TCG_TPM is not set | ||
| 720 | |||
| 721 | # | ||
| 722 | # I2C support | ||
| 723 | # | ||
| 724 | CONFIG_I2C=m | ||
| 725 | CONFIG_I2C_CHARDEV=m | ||
| 726 | |||
| 727 | # | ||
| 728 | # I2C Algorithms | ||
| 729 | # | ||
| 730 | # CONFIG_I2C_ALGOBIT is not set | ||
| 731 | # CONFIG_I2C_ALGOPCF is not set | ||
| 732 | # CONFIG_I2C_ALGOPCA is not set | ||
| 733 | |||
| 734 | # | ||
| 735 | # I2C Hardware Bus support | ||
| 736 | # | ||
| 737 | CONFIG_I2C_AT91=m | ||
| 738 | CONFIG_I2C_ISA=m | ||
| 739 | # CONFIG_I2C_OCORES is not set | ||
| 740 | # CONFIG_I2C_PARPORT_LIGHT is not set | ||
| 741 | # CONFIG_I2C_STUB is not set | ||
| 742 | # CONFIG_I2C_PCA_ISA is not set | ||
| 743 | |||
| 744 | # | ||
| 745 | # Miscellaneous I2C Chip support | ||
| 746 | # | ||
| 747 | CONFIG_SENSORS_DS1337=m | ||
| 748 | CONFIG_SENSORS_DS1374=m | ||
| 749 | CONFIG_SENSORS_EEPROM=m | ||
| 750 | CONFIG_SENSORS_PCF8574=m | ||
| 751 | CONFIG_SENSORS_PCA9539=m | ||
| 752 | CONFIG_SENSORS_PCF8591=m | ||
| 753 | # CONFIG_SENSORS_MAX6875 is not set | ||
| 754 | # CONFIG_I2C_DEBUG_CORE is not set | ||
| 755 | # CONFIG_I2C_DEBUG_ALGO is not set | ||
| 756 | # CONFIG_I2C_DEBUG_BUS is not set | ||
| 757 | # CONFIG_I2C_DEBUG_CHIP is not set | ||
| 758 | |||
| 759 | # | ||
| 760 | # SPI support | ||
| 761 | # | ||
| 762 | # CONFIG_SPI is not set | ||
| 763 | # CONFIG_SPI_MASTER is not set | ||
| 764 | |||
| 765 | # | ||
| 766 | # Dallas's 1-wire bus | ||
| 767 | # | ||
| 768 | # CONFIG_W1 is not set | ||
| 769 | |||
| 770 | # | ||
| 771 | # Hardware Monitoring support | ||
| 772 | # | ||
| 773 | CONFIG_HWMON=m | ||
| 774 | CONFIG_HWMON_VID=m | ||
| 775 | # CONFIG_SENSORS_ABITUGURU is not set | ||
| 776 | CONFIG_SENSORS_ADM1021=m | ||
| 777 | CONFIG_SENSORS_ADM1025=m | ||
| 778 | CONFIG_SENSORS_ADM1026=m | ||
| 779 | CONFIG_SENSORS_ADM1029=m | ||
| 780 | CONFIG_SENSORS_ADM1031=m | ||
| 781 | CONFIG_SENSORS_ADM9240=m | ||
| 782 | # CONFIG_SENSORS_ASB100 is not set | ||
| 783 | # CONFIG_SENSORS_ATXP1 is not set | ||
| 784 | CONFIG_SENSORS_DS1621=m | ||
| 785 | # CONFIG_SENSORS_F71805F is not set | ||
| 786 | # CONFIG_SENSORS_FSCHER is not set | ||
| 787 | # CONFIG_SENSORS_FSCPOS is not set | ||
| 788 | CONFIG_SENSORS_GL518SM=m | ||
| 789 | CONFIG_SENSORS_GL520SM=m | ||
| 790 | CONFIG_SENSORS_IT87=m | ||
| 791 | CONFIG_SENSORS_LM63=m | ||
| 792 | CONFIG_SENSORS_LM75=m | ||
| 793 | CONFIG_SENSORS_LM77=m | ||
| 794 | CONFIG_SENSORS_LM78=m | ||
| 795 | CONFIG_SENSORS_LM80=m | ||
| 796 | CONFIG_SENSORS_LM83=m | ||
| 797 | CONFIG_SENSORS_LM85=m | ||
| 798 | CONFIG_SENSORS_LM87=m | ||
| 799 | CONFIG_SENSORS_LM90=m | ||
| 800 | CONFIG_SENSORS_LM92=m | ||
| 801 | CONFIG_SENSORS_MAX1619=m | ||
| 802 | # CONFIG_SENSORS_PC87360 is not set | ||
| 803 | # CONFIG_SENSORS_PC87427 is not set | ||
| 804 | # CONFIG_SENSORS_SMSC47M1 is not set | ||
| 805 | # CONFIG_SENSORS_SMSC47M192 is not set | ||
| 806 | CONFIG_SENSORS_SMSC47B397=m | ||
| 807 | # CONFIG_SENSORS_VT1211 is not set | ||
| 808 | CONFIG_SENSORS_W83781D=m | ||
| 809 | CONFIG_SENSORS_W83791D=m | ||
| 810 | CONFIG_SENSORS_W83792D=m | ||
| 811 | CONFIG_SENSORS_W83793=m | ||
| 812 | CONFIG_SENSORS_W83L785TS=m | ||
| 813 | # CONFIG_SENSORS_W83627HF is not set | ||
| 814 | # CONFIG_SENSORS_W83627EHF is not set | ||
| 815 | # CONFIG_HWMON_DEBUG_CHIP is not set | ||
| 816 | |||
| 817 | # | ||
| 818 | # Misc devices | ||
| 819 | # | ||
| 820 | |||
| 821 | # | ||
| 822 | # Multifunction device drivers | ||
| 823 | # | ||
| 824 | # CONFIG_MFD_SM501 is not set | ||
| 825 | |||
| 826 | # | ||
| 827 | # LED devices | ||
| 828 | # | ||
| 829 | # CONFIG_NEW_LEDS is not set | ||
| 830 | |||
| 831 | # | ||
| 832 | # LED drivers | ||
| 833 | # | ||
| 834 | |||
| 835 | # | ||
| 836 | # LED Triggers | ||
| 837 | # | ||
| 838 | |||
| 839 | # | ||
| 840 | # Multimedia devices | ||
| 841 | # | ||
| 842 | # CONFIG_VIDEO_DEV is not set | ||
| 843 | |||
| 844 | # | ||
| 845 | # Digital Video Broadcasting Devices | ||
| 846 | # | ||
| 847 | # CONFIG_DVB is not set | ||
| 848 | # CONFIG_USB_DABUSB is not set | ||
| 849 | |||
| 850 | # | ||
| 851 | # Graphics support | ||
| 852 | # | ||
| 853 | # CONFIG_BACKLIGHT_LCD_SUPPORT is not set | ||
| 854 | # CONFIG_FB is not set | ||
| 855 | |||
| 856 | # | ||
| 857 | # Sound | ||
| 858 | # | ||
| 859 | # CONFIG_SOUND is not set | ||
| 860 | |||
| 861 | # | ||
| 862 | # HID Devices | ||
| 863 | # | ||
| 864 | CONFIG_HID=m | ||
| 865 | # CONFIG_HID_DEBUG is not set | ||
| 866 | |||
| 867 | # | ||
| 868 | # USB support | ||
| 869 | # | ||
| 870 | CONFIG_USB_ARCH_HAS_HCD=y | ||
| 871 | CONFIG_USB_ARCH_HAS_OHCI=y | ||
| 872 | # CONFIG_USB_ARCH_HAS_EHCI is not set | ||
| 873 | CONFIG_USB=m | ||
| 874 | # CONFIG_USB_DEBUG is not set | ||
| 875 | |||
| 876 | # | ||
| 877 | # Miscellaneous USB options | ||
| 878 | # | ||
| 879 | CONFIG_USB_DEVICEFS=y | ||
| 880 | # CONFIG_USB_DYNAMIC_MINORS is not set | ||
| 881 | # CONFIG_USB_OTG is not set | ||
| 882 | |||
| 883 | # | ||
| 884 | # USB Host Controller Drivers | ||
| 885 | # | ||
| 886 | # CONFIG_USB_ISP116X_HCD is not set | ||
| 887 | CONFIG_USB_OHCI_HCD=m | ||
| 888 | # CONFIG_USB_OHCI_BIG_ENDIAN_DESC is not set | ||
| 889 | # CONFIG_USB_OHCI_BIG_ENDIAN_MMIO is not set | ||
| 890 | CONFIG_USB_OHCI_LITTLE_ENDIAN=y | ||
| 891 | # CONFIG_USB_SL811_HCD is not set | ||
| 892 | |||
| 893 | # | ||
| 894 | # USB Device Class drivers | ||
| 895 | # | ||
| 896 | CONFIG_USB_ACM=m | ||
| 897 | CONFIG_USB_PRINTER=m | ||
| 898 | |||
| 899 | # | ||
| 900 | # NOTE: USB_STORAGE enables SCSI, and 'SCSI disk support' | ||
| 901 | # | ||
| 902 | |||
| 903 | # | ||
| 904 | # may also be needed; see USB_STORAGE Help for more information | ||
| 905 | # | ||
| 906 | CONFIG_USB_STORAGE=m | ||
| 907 | # CONFIG_USB_STORAGE_DEBUG is not set | ||
| 908 | # CONFIG_USB_STORAGE_DATAFAB is not set | ||
| 909 | # CONFIG_USB_STORAGE_FREECOM is not set | ||
| 910 | # CONFIG_USB_STORAGE_DPCM is not set | ||
| 911 | # CONFIG_USB_STORAGE_USBAT is not set | ||
| 912 | # CONFIG_USB_STORAGE_SDDR09 is not set | ||
| 913 | # CONFIG_USB_STORAGE_SDDR55 is not set | ||
| 914 | # CONFIG_USB_STORAGE_JUMPSHOT is not set | ||
| 915 | # CONFIG_USB_STORAGE_ALAUDA is not set | ||
| 916 | # CONFIG_USB_STORAGE_KARMA is not set | ||
| 917 | # CONFIG_USB_LIBUSUAL is not set | ||
| 918 | |||
| 919 | # | ||
| 920 | # USB Input Devices | ||
| 921 | # | ||
| 922 | CONFIG_USB_HID=m | ||
| 923 | # CONFIG_USB_HIDINPUT_POWERBOOK is not set | ||
| 924 | # CONFIG_HID_FF is not set | ||
| 925 | # CONFIG_USB_HIDDEV is not set | ||
| 926 | |||
| 927 | # | ||
| 928 | # USB HID Boot Protocol drivers | ||
| 929 | # | ||
| 930 | # CONFIG_USB_KBD is not set | ||
| 931 | # CONFIG_USB_MOUSE is not set | ||
| 932 | # CONFIG_USB_AIPTEK is not set | ||
| 933 | # CONFIG_USB_WACOM is not set | ||
| 934 | # CONFIG_USB_ACECAD is not set | ||
| 935 | # CONFIG_USB_KBTAB is not set | ||
| 936 | # CONFIG_USB_POWERMATE is not set | ||
| 937 | # CONFIG_USB_TOUCHSCREEN is not set | ||
| 938 | # CONFIG_USB_YEALINK is not set | ||
| 939 | # CONFIG_USB_XPAD is not set | ||
| 940 | # CONFIG_USB_ATI_REMOTE is not set | ||
| 941 | # CONFIG_USB_ATI_REMOTE2 is not set | ||
| 942 | # CONFIG_USB_KEYSPAN_REMOTE is not set | ||
| 943 | # CONFIG_USB_APPLETOUCH is not set | ||
| 944 | # CONFIG_USB_GTCO is not set | ||
| 945 | |||
| 946 | # | ||
| 947 | # USB Imaging devices | ||
| 948 | # | ||
| 949 | # CONFIG_USB_MDC800 is not set | ||
| 950 | # CONFIG_USB_MICROTEK is not set | ||
| 951 | |||
| 952 | # | ||
| 953 | # USB Network Adapters | ||
| 954 | # | ||
| 955 | CONFIG_USB_CATC=m | ||
| 956 | CONFIG_USB_KAWETH=m | ||
| 957 | CONFIG_USB_PEGASUS=m | ||
| 958 | CONFIG_USB_RTL8150=m | ||
| 959 | CONFIG_USB_USBNET_MII=m | ||
| 960 | CONFIG_USB_USBNET=m | ||
| 961 | CONFIG_USB_NET_AX8817X=m | ||
| 962 | CONFIG_USB_NET_CDCETHER=m | ||
| 963 | CONFIG_USB_NET_DM9601=m | ||
| 964 | CONFIG_USB_NET_GL620A=m | ||
| 965 | CONFIG_USB_NET_NET1080=m | ||
| 966 | CONFIG_USB_NET_PLUSB=m | ||
| 967 | CONFIG_USB_NET_MCS7830=m | ||
| 968 | CONFIG_USB_NET_RNDIS_HOST=m | ||
| 969 | CONFIG_USB_NET_CDC_SUBSET=m | ||
| 970 | CONFIG_USB_ALI_M5632=y | ||
| 971 | CONFIG_USB_AN2720=y | ||
| 972 | CONFIG_USB_BELKIN=y | ||
| 973 | CONFIG_USB_ARMLINUX=y | ||
| 974 | CONFIG_USB_EPSON2888=y | ||
| 975 | CONFIG_USB_KC2190=y | ||
| 976 | CONFIG_USB_NET_ZAURUS=m | ||
| 977 | # CONFIG_USB_MON is not set | ||
| 978 | |||
| 979 | # | ||
| 980 | # USB port drivers | ||
| 981 | # | ||
| 982 | |||
| 983 | # | ||
| 984 | # USB Serial Converter support | ||
| 985 | # | ||
| 986 | CONFIG_USB_SERIAL=m | ||
| 987 | CONFIG_USB_SERIAL_GENERIC=y | ||
| 988 | # CONFIG_USB_SERIAL_AIRCABLE is not set | ||
| 989 | # CONFIG_USB_SERIAL_AIRPRIME is not set | ||
| 990 | # CONFIG_USB_SERIAL_ARK3116 is not set | ||
| 991 | # CONFIG_USB_SERIAL_BELKIN is not set | ||
| 992 | # CONFIG_USB_SERIAL_WHITEHEAT is not set | ||
| 993 | # CONFIG_USB_SERIAL_DIGI_ACCELEPORT is not set | ||
| 994 | # CONFIG_USB_SERIAL_CP2101 is not set | ||
| 995 | # CONFIG_USB_SERIAL_CYPRESS_M8 is not set | ||
| 996 | # CONFIG_USB_SERIAL_EMPEG is not set | ||
| 997 | # CONFIG_USB_SERIAL_FTDI_SIO is not set | ||
| 998 | # CONFIG_USB_SERIAL_FUNSOFT is not set | ||
| 999 | # CONFIG_USB_SERIAL_VISOR is not set | ||
| 1000 | # CONFIG_USB_SERIAL_IPAQ is not set | ||
| 1001 | # CONFIG_USB_SERIAL_IR is not set | ||
| 1002 | # CONFIG_USB_SERIAL_EDGEPORT is not set | ||
| 1003 | # CONFIG_USB_SERIAL_EDGEPORT_TI is not set | ||
| 1004 | # CONFIG_USB_SERIAL_GARMIN is not set | ||
| 1005 | # CONFIG_USB_SERIAL_IPW is not set | ||
| 1006 | # CONFIG_USB_SERIAL_KEYSPAN_PDA is not set | ||
| 1007 | # CONFIG_USB_SERIAL_KEYSPAN is not set | ||
| 1008 | # CONFIG_USB_SERIAL_KLSI is not set | ||
| 1009 | # CONFIG_USB_SERIAL_KOBIL_SCT is not set | ||
| 1010 | # CONFIG_USB_SERIAL_MCT_U232 is not set | ||
| 1011 | # CONFIG_USB_SERIAL_MOS7720 is not set | ||
| 1012 | # CONFIG_USB_SERIAL_MOS7840 is not set | ||
| 1013 | # CONFIG_USB_SERIAL_NAVMAN is not set | ||
| 1014 | CONFIG_USB_SERIAL_PL2303=m | ||
| 1015 | # CONFIG_USB_SERIAL_HP4X is not set | ||
| 1016 | # CONFIG_USB_SERIAL_SAFE is not set | ||
| 1017 | # CONFIG_USB_SERIAL_SIERRAWIRELESS is not set | ||
| 1018 | # CONFIG_USB_SERIAL_TI is not set | ||
| 1019 | # CONFIG_USB_SERIAL_CYBERJACK is not set | ||
| 1020 | # CONFIG_USB_SERIAL_XIRCOM is not set | ||
| 1021 | # CONFIG_USB_SERIAL_OPTION is not set | ||
| 1022 | # CONFIG_USB_SERIAL_OMNINET is not set | ||
| 1023 | # CONFIG_USB_SERIAL_DEBUG is not set | ||
| 1024 | |||
| 1025 | # | ||
| 1026 | # USB Miscellaneous drivers | ||
| 1027 | # | ||
| 1028 | # CONFIG_USB_EMI62 is not set | ||
| 1029 | # CONFIG_USB_EMI26 is not set | ||
| 1030 | # CONFIG_USB_ADUTUX is not set | ||
| 1031 | # CONFIG_USB_AUERSWALD is not set | ||
| 1032 | # CONFIG_USB_RIO500 is not set | ||
| 1033 | # CONFIG_USB_LEGOTOWER is not set | ||
| 1034 | # CONFIG_USB_LCD is not set | ||
| 1035 | # CONFIG_USB_BERRY_CHARGE is not set | ||
| 1036 | # CONFIG_USB_LED is not set | ||
| 1037 | # CONFIG_USB_CYPRESS_CY7C63 is not set | ||
| 1038 | # CONFIG_USB_CYTHERM is not set | ||
| 1039 | # CONFIG_USB_PHIDGET is not set | ||
| 1040 | # CONFIG_USB_IDMOUSE is not set | ||
| 1041 | # CONFIG_USB_FTDI_ELAN is not set | ||
| 1042 | # CONFIG_USB_APPLEDISPLAY is not set | ||
| 1043 | # CONFIG_USB_LD is not set | ||
| 1044 | # CONFIG_USB_TRANCEVIBRATOR is not set | ||
| 1045 | # CONFIG_USB_IOWARRIOR is not set | ||
| 1046 | # CONFIG_USB_TEST is not set | ||
| 1047 | |||
| 1048 | # | ||
| 1049 | # USB DSL modem support | ||
| 1050 | # | ||
| 1051 | |||
| 1052 | # | ||
| 1053 | # USB Gadget Support | ||
| 1054 | # | ||
| 1055 | # CONFIG_USB_GADGET is not set | ||
| 1056 | |||
| 1057 | # | ||
| 1058 | # MMC/SD Card support | ||
| 1059 | # | ||
| 1060 | CONFIG_MMC=m | ||
| 1061 | # CONFIG_MMC_DEBUG is not set | ||
| 1062 | CONFIG_MMC_BLOCK=m | ||
| 1063 | CONFIG_MMC_AT91=m | ||
| 1064 | |||
| 1065 | # | ||
| 1066 | # Real Time Clock | ||
| 1067 | # | ||
| 1068 | CONFIG_RTC_LIB=y | ||
| 1069 | CONFIG_RTC_CLASS=m | ||
| 1070 | |||
| 1071 | # | ||
| 1072 | # RTC interfaces | ||
| 1073 | # | ||
| 1074 | CONFIG_RTC_INTF_SYSFS=m | ||
| 1075 | CONFIG_RTC_INTF_PROC=m | ||
| 1076 | CONFIG_RTC_INTF_DEV=m | ||
| 1077 | # CONFIG_RTC_INTF_DEV_UIE_EMUL is not set | ||
| 1078 | |||
| 1079 | # | ||
| 1080 | # RTC drivers | ||
| 1081 | # | ||
| 1082 | # CONFIG_RTC_DRV_CMOS is not set | ||
| 1083 | # CONFIG_RTC_DRV_X1205 is not set | ||
| 1084 | # CONFIG_RTC_DRV_DS1307 is not set | ||
| 1085 | # CONFIG_RTC_DRV_DS1553 is not set | ||
| 1086 | # CONFIG_RTC_DRV_ISL1208 is not set | ||
| 1087 | # CONFIG_RTC_DRV_DS1672 is not set | ||
| 1088 | # CONFIG_RTC_DRV_DS1742 is not set | ||
| 1089 | # CONFIG_RTC_DRV_PCF8563 is not set | ||
| 1090 | # CONFIG_RTC_DRV_RS5C372 is not set | ||
| 1091 | # CONFIG_RTC_DRV_M48T86 is not set | ||
| 1092 | CONFIG_RTC_DRV_AT91RM9200=m | ||
| 1093 | # CONFIG_RTC_DRV_TEST is not set | ||
| 1094 | # CONFIG_RTC_DRV_V3020 is not set | ||
| 1095 | |||
| 1096 | # | ||
| 1097 | # File systems | ||
| 1098 | # | ||
| 1099 | CONFIG_EXT2_FS=m | ||
| 1100 | # CONFIG_EXT2_FS_XATTR is not set | ||
| 1101 | # CONFIG_EXT2_FS_XIP is not set | ||
| 1102 | CONFIG_EXT3_FS=m | ||
| 1103 | # CONFIG_EXT3_FS_XATTR is not set | ||
| 1104 | # CONFIG_EXT4DEV_FS is not set | ||
| 1105 | CONFIG_JBD=m | ||
| 1106 | # CONFIG_JBD_DEBUG is not set | ||
| 1107 | # CONFIG_REISERFS_FS is not set | ||
| 1108 | # CONFIG_JFS_FS is not set | ||
| 1109 | # CONFIG_FS_POSIX_ACL is not set | ||
| 1110 | # CONFIG_XFS_FS is not set | ||
| 1111 | # CONFIG_GFS2_FS is not set | ||
| 1112 | # CONFIG_OCFS2_FS is not set | ||
| 1113 | # CONFIG_MINIX_FS is not set | ||
| 1114 | # CONFIG_ROMFS_FS is not set | ||
| 1115 | CONFIG_INOTIFY=y | ||
| 1116 | CONFIG_INOTIFY_USER=y | ||
| 1117 | # CONFIG_QUOTA is not set | ||
| 1118 | CONFIG_DNOTIFY=y | ||
| 1119 | # CONFIG_AUTOFS_FS is not set | ||
| 1120 | # CONFIG_AUTOFS4_FS is not set | ||
| 1121 | # CONFIG_FUSE_FS is not set | ||
| 1122 | |||
| 1123 | # | ||
| 1124 | # CD-ROM/DVD Filesystems | ||
| 1125 | # | ||
| 1126 | CONFIG_ISO9660_FS=m | ||
| 1127 | CONFIG_JOLIET=y | ||
| 1128 | # CONFIG_ZISOFS is not set | ||
| 1129 | CONFIG_UDF_FS=m | ||
| 1130 | CONFIG_UDF_NLS=y | ||
| 1131 | |||
| 1132 | # | ||
| 1133 | # DOS/FAT/NT Filesystems | ||
| 1134 | # | ||
| 1135 | CONFIG_FAT_FS=m | ||
| 1136 | CONFIG_MSDOS_FS=m | ||
| 1137 | CONFIG_VFAT_FS=m | ||
| 1138 | CONFIG_FAT_DEFAULT_CODEPAGE=437 | ||
| 1139 | CONFIG_FAT_DEFAULT_IOCHARSET="iso8859-1" | ||
| 1140 | CONFIG_NTFS_FS=m | ||
| 1141 | # CONFIG_NTFS_DEBUG is not set | ||
| 1142 | # CONFIG_NTFS_RW is not set | ||
| 1143 | |||
| 1144 | # | ||
| 1145 | # Pseudo filesystems | ||
| 1146 | # | ||
| 1147 | CONFIG_PROC_FS=y | ||
| 1148 | CONFIG_PROC_SYSCTL=y | ||
| 1149 | CONFIG_SYSFS=y | ||
| 1150 | CONFIG_TMPFS=y | ||
| 1151 | # CONFIG_TMPFS_POSIX_ACL is not set | ||
| 1152 | # CONFIG_HUGETLB_PAGE is not set | ||
| 1153 | CONFIG_RAMFS=y | ||
| 1154 | # CONFIG_CONFIGFS_FS is not set | ||
| 1155 | |||
| 1156 | # | ||
| 1157 | # Miscellaneous filesystems | ||
| 1158 | # | ||
| 1159 | # CONFIG_ADFS_FS is not set | ||
| 1160 | # CONFIG_AFFS_FS is not set | ||
| 1161 | # CONFIG_HFS_FS is not set | ||
| 1162 | # CONFIG_HFSPLUS_FS is not set | ||
| 1163 | # CONFIG_BEFS_FS is not set | ||
| 1164 | # CONFIG_BFS_FS is not set | ||
| 1165 | # CONFIG_EFS_FS is not set | ||
| 1166 | CONFIG_JFFS2_FS=y | ||
| 1167 | CONFIG_JFFS2_FS_DEBUG=0 | ||
| 1168 | CONFIG_JFFS2_FS_WRITEBUFFER=y | ||
| 1169 | CONFIG_JFFS2_SUMMARY=y | ||
| 1170 | # CONFIG_JFFS2_FS_XATTR is not set | ||
| 1171 | CONFIG_JFFS2_COMPRESSION_OPTIONS=y | ||
| 1172 | CONFIG_JFFS2_ZLIB=y | ||
| 1173 | CONFIG_JFFS2_RTIME=y | ||
| 1174 | # CONFIG_JFFS2_RUBIN is not set | ||
| 1175 | # CONFIG_JFFS2_CMODE_NONE is not set | ||
| 1176 | CONFIG_JFFS2_CMODE_PRIORITY=y | ||
| 1177 | # CONFIG_JFFS2_CMODE_SIZE is not set | ||
| 1178 | # CONFIG_CRAMFS is not set | ||
| 1179 | # CONFIG_VXFS_FS is not set | ||
| 1180 | # CONFIG_HPFS_FS is not set | ||
| 1181 | # CONFIG_QNX4FS_FS is not set | ||
| 1182 | # CONFIG_SYSV_FS is not set | ||
| 1183 | # CONFIG_UFS_FS is not set | ||
| 1184 | |||
| 1185 | # | ||
| 1186 | # Network File Systems | ||
| 1187 | # | ||
| 1188 | CONFIG_NFS_FS=m | ||
| 1189 | # CONFIG_NFS_V3 is not set | ||
| 1190 | # CONFIG_NFS_V4 is not set | ||
| 1191 | # CONFIG_NFS_DIRECTIO is not set | ||
| 1192 | # CONFIG_NFSD is not set | ||
| 1193 | CONFIG_LOCKD=m | ||
| 1194 | CONFIG_NFS_COMMON=y | ||
| 1195 | CONFIG_SUNRPC=m | ||
| 1196 | # CONFIG_RPCSEC_GSS_KRB5 is not set | ||
| 1197 | # CONFIG_RPCSEC_GSS_SPKM3 is not set | ||
| 1198 | CONFIG_SMB_FS=m | ||
| 1199 | # CONFIG_SMB_NLS_DEFAULT is not set | ||
| 1200 | CONFIG_CIFS=m | ||
| 1201 | # CONFIG_CIFS_STATS is not set | ||
| 1202 | # CONFIG_CIFS_WEAK_PW_HASH is not set | ||
| 1203 | # CONFIG_CIFS_XATTR is not set | ||
| 1204 | # CONFIG_CIFS_DEBUG2 is not set | ||
| 1205 | # CONFIG_CIFS_EXPERIMENTAL is not set | ||
| 1206 | # CONFIG_NCP_FS is not set | ||
| 1207 | # CONFIG_CODA_FS is not set | ||
| 1208 | # CONFIG_AFS_FS is not set | ||
| 1209 | # CONFIG_9P_FS is not set | ||
| 1210 | |||
| 1211 | # | ||
| 1212 | # Partition Types | ||
| 1213 | # | ||
| 1214 | CONFIG_PARTITION_ADVANCED=y | ||
| 1215 | # CONFIG_ACORN_PARTITION is not set | ||
| 1216 | # CONFIG_OSF_PARTITION is not set | ||
| 1217 | CONFIG_AMIGA_PARTITION=y | ||
| 1218 | # CONFIG_ATARI_PARTITION is not set | ||
| 1219 | # CONFIG_MAC_PARTITION is not set | ||
| 1220 | CONFIG_MSDOS_PARTITION=y | ||
| 1221 | # CONFIG_BSD_DISKLABEL is not set | ||
| 1222 | # CONFIG_MINIX_SUBPARTITION is not set | ||
| 1223 | # CONFIG_SOLARIS_X86_PARTITION is not set | ||
| 1224 | # CONFIG_UNIXWARE_DISKLABEL is not set | ||
| 1225 | # CONFIG_LDM_PARTITION is not set | ||
| 1226 | # CONFIG_SGI_PARTITION is not set | ||
| 1227 | # CONFIG_ULTRIX_PARTITION is not set | ||
| 1228 | # CONFIG_SUN_PARTITION is not set | ||
| 1229 | # CONFIG_KARMA_PARTITION is not set | ||
| 1230 | # CONFIG_EFI_PARTITION is not set | ||
| 1231 | |||
| 1232 | # | ||
| 1233 | # Native Language Support | ||
| 1234 | # | ||
| 1235 | CONFIG_NLS=m | ||
| 1236 | CONFIG_NLS_DEFAULT="utf-8" | ||
| 1237 | CONFIG_NLS_CODEPAGE_437=m | ||
| 1238 | CONFIG_NLS_CODEPAGE_737=m | ||
| 1239 | CONFIG_NLS_CODEPAGE_775=m | ||
| 1240 | CONFIG_NLS_CODEPAGE_850=m | ||
| 1241 | CONFIG_NLS_CODEPAGE_852=m | ||
| 1242 | CONFIG_NLS_CODEPAGE_855=m | ||
| 1243 | CONFIG_NLS_CODEPAGE_857=m | ||
| 1244 | CONFIG_NLS_CODEPAGE_860=m | ||
| 1245 | CONFIG_NLS_CODEPAGE_861=m | ||
| 1246 | CONFIG_NLS_CODEPAGE_862=m | ||
| 1247 | CONFIG_NLS_CODEPAGE_863=m | ||
| 1248 | CONFIG_NLS_CODEPAGE_864=m | ||
| 1249 | CONFIG_NLS_CODEPAGE_865=m | ||
| 1250 | CONFIG_NLS_CODEPAGE_866=m | ||
| 1251 | CONFIG_NLS_CODEPAGE_869=m | ||
| 1252 | CONFIG_NLS_CODEPAGE_936=m | ||
| 1253 | CONFIG_NLS_CODEPAGE_950=m | ||
| 1254 | CONFIG_NLS_CODEPAGE_932=m | ||
| 1255 | CONFIG_NLS_CODEPAGE_949=m | ||
| 1256 | CONFIG_NLS_CODEPAGE_874=m | ||
| 1257 | CONFIG_NLS_ISO8859_8=m | ||
| 1258 | CONFIG_NLS_CODEPAGE_1250=m | ||
| 1259 | CONFIG_NLS_CODEPAGE_1251=m | ||
| 1260 | CONFIG_NLS_ASCII=m | ||
| 1261 | CONFIG_NLS_ISO8859_1=m | ||
| 1262 | CONFIG_NLS_ISO8859_2=m | ||
| 1263 | CONFIG_NLS_ISO8859_3=m | ||
| 1264 | CONFIG_NLS_ISO8859_4=m | ||
| 1265 | CONFIG_NLS_ISO8859_5=m | ||
| 1266 | CONFIG_NLS_ISO8859_6=m | ||
| 1267 | CONFIG_NLS_ISO8859_7=m | ||
| 1268 | CONFIG_NLS_ISO8859_9=m | ||
| 1269 | CONFIG_NLS_ISO8859_13=m | ||
| 1270 | CONFIG_NLS_ISO8859_14=m | ||
| 1271 | CONFIG_NLS_ISO8859_15=m | ||
| 1272 | CONFIG_NLS_KOI8_R=m | ||
| 1273 | CONFIG_NLS_KOI8_U=m | ||
| 1274 | CONFIG_NLS_UTF8=m | ||
| 1275 | |||
| 1276 | # | ||
| 1277 | # Distributed Lock Manager | ||
| 1278 | # | ||
| 1279 | # CONFIG_DLM is not set | ||
| 1280 | |||
| 1281 | # | ||
| 1282 | # Profiling support | ||
| 1283 | # | ||
| 1284 | # CONFIG_PROFILING is not set | ||
| 1285 | |||
| 1286 | # | ||
| 1287 | # Kernel hacking | ||
| 1288 | # | ||
| 1289 | # CONFIG_PRINTK_TIME is not set | ||
| 1290 | CONFIG_ENABLE_MUST_CHECK=y | ||
| 1291 | # CONFIG_MAGIC_SYSRQ is not set | ||
| 1292 | # CONFIG_UNUSED_SYMBOLS is not set | ||
| 1293 | # CONFIG_DEBUG_FS is not set | ||
| 1294 | # CONFIG_HEADERS_CHECK is not set | ||
| 1295 | CONFIG_DEBUG_KERNEL=y | ||
| 1296 | # CONFIG_DEBUG_SHIRQ is not set | ||
| 1297 | CONFIG_LOG_BUF_SHIFT=14 | ||
| 1298 | CONFIG_DETECT_SOFTLOCKUP=y | ||
| 1299 | # CONFIG_SCHEDSTATS is not set | ||
| 1300 | # CONFIG_TIMER_STATS is not set | ||
| 1301 | # CONFIG_DEBUG_SLAB is not set | ||
| 1302 | # CONFIG_DEBUG_RT_MUTEXES is not set | ||
| 1303 | # CONFIG_RT_MUTEX_TESTER is not set | ||
| 1304 | # CONFIG_DEBUG_SPINLOCK is not set | ||
| 1305 | # CONFIG_DEBUG_MUTEXES is not set | ||
| 1306 | # CONFIG_DEBUG_SPINLOCK_SLEEP is not set | ||
| 1307 | # CONFIG_DEBUG_LOCKING_API_SELFTESTS is not set | ||
| 1308 | # CONFIG_DEBUG_KOBJECT is not set | ||
| 1309 | # CONFIG_DEBUG_BUGVERBOSE is not set | ||
| 1310 | # CONFIG_DEBUG_INFO is not set | ||
| 1311 | # CONFIG_DEBUG_VM is not set | ||
| 1312 | # CONFIG_DEBUG_LIST is not set | ||
| 1313 | CONFIG_FRAME_POINTER=y | ||
| 1314 | # CONFIG_FORCED_INLINING is not set | ||
| 1315 | # CONFIG_RCU_TORTURE_TEST is not set | ||
| 1316 | # CONFIG_FAULT_INJECTION is not set | ||
| 1317 | # CONFIG_DEBUG_USER is not set | ||
| 1318 | # CONFIG_DEBUG_ERRORS is not set | ||
| 1319 | CONFIG_DEBUG_LL=y | ||
| 1320 | # CONFIG_DEBUG_ICEDCC is not set | ||
| 1321 | |||
| 1322 | # | ||
| 1323 | # Security options | ||
| 1324 | # | ||
| 1325 | # CONFIG_KEYS is not set | ||
| 1326 | # CONFIG_SECURITY is not set | ||
| 1327 | |||
| 1328 | # | ||
| 1329 | # Cryptographic options | ||
| 1330 | # | ||
| 1331 | CONFIG_CRYPTO=y | ||
| 1332 | CONFIG_CRYPTO_ALGAPI=m | ||
| 1333 | CONFIG_CRYPTO_BLKCIPHER=m | ||
| 1334 | CONFIG_CRYPTO_HASH=m | ||
| 1335 | CONFIG_CRYPTO_MANAGER=m | ||
| 1336 | CONFIG_CRYPTO_HMAC=m | ||
| 1337 | CONFIG_CRYPTO_XCBC=m | ||
| 1338 | CONFIG_CRYPTO_NULL=m | ||
| 1339 | CONFIG_CRYPTO_MD4=m | ||
| 1340 | CONFIG_CRYPTO_MD5=m | ||
| 1341 | CONFIG_CRYPTO_SHA1=m | ||
| 1342 | CONFIG_CRYPTO_SHA256=m | ||
| 1343 | CONFIG_CRYPTO_SHA512=m | ||
| 1344 | CONFIG_CRYPTO_WP512=m | ||
| 1345 | CONFIG_CRYPTO_TGR192=m | ||
| 1346 | CONFIG_CRYPTO_GF128MUL=m | ||
| 1347 | CONFIG_CRYPTO_ECB=m | ||
| 1348 | CONFIG_CRYPTO_CBC=m | ||
| 1349 | CONFIG_CRYPTO_PCBC=m | ||
| 1350 | CONFIG_CRYPTO_LRW=m | ||
| 1351 | CONFIG_CRYPTO_DES=m | ||
| 1352 | CONFIG_CRYPTO_FCRYPT=m | ||
| 1353 | CONFIG_CRYPTO_BLOWFISH=m | ||
| 1354 | CONFIG_CRYPTO_TWOFISH=m | ||
| 1355 | CONFIG_CRYPTO_TWOFISH_COMMON=m | ||
| 1356 | CONFIG_CRYPTO_SERPENT=m | ||
| 1357 | CONFIG_CRYPTO_AES=m | ||
| 1358 | CONFIG_CRYPTO_CAST5=m | ||
| 1359 | CONFIG_CRYPTO_CAST6=m | ||
| 1360 | CONFIG_CRYPTO_TEA=m | ||
| 1361 | CONFIG_CRYPTO_ARC4=m | ||
| 1362 | CONFIG_CRYPTO_KHAZAD=m | ||
| 1363 | CONFIG_CRYPTO_ANUBIS=m | ||
| 1364 | CONFIG_CRYPTO_DEFLATE=m | ||
| 1365 | CONFIG_CRYPTO_MICHAEL_MIC=m | ||
| 1366 | CONFIG_CRYPTO_CRC32C=m | ||
| 1367 | CONFIG_CRYPTO_CAMELLIA=m | ||
| 1368 | CONFIG_CRYPTO_TEST=m | ||
| 1369 | |||
| 1370 | # | ||
| 1371 | # Hardware crypto devices | ||
| 1372 | # | ||
| 1373 | |||
| 1374 | # | ||
| 1375 | # Library routines | ||
| 1376 | # | ||
| 1377 | CONFIG_BITREVERSE=y | ||
| 1378 | CONFIG_CRC_CCITT=m | ||
| 1379 | CONFIG_CRC16=m | ||
| 1380 | CONFIG_CRC32=y | ||
| 1381 | CONFIG_LIBCRC32C=m | ||
| 1382 | CONFIG_ZLIB_INFLATE=y | ||
| 1383 | CONFIG_ZLIB_DEFLATE=y | ||
| 1384 | CONFIG_PLIST=y | ||
| 1385 | CONFIG_HAS_IOMEM=y | ||
| 1386 | CONFIG_HAS_IOPORT=y | ||
| diff --git a/arch/arm/kernel/Makefile b/arch/arm/kernel/Makefile index bb28087bf818..593b56509f4f 100644 --- a/arch/arm/kernel/Makefile +++ b/arch/arm/kernel/Makefile | |||
| @@ -7,8 +7,8 @@ AFLAGS_head.o := -DTEXT_OFFSET=$(TEXT_OFFSET) | |||
| 7 | # Object file lists. | 7 | # Object file lists. | 
| 8 | 8 | ||
| 9 | obj-y := compat.o entry-armv.o entry-common.o irq.o \ | 9 | obj-y := compat.o entry-armv.o entry-common.o irq.o \ | 
| 10 | process.o ptrace.o semaphore.o setup.o signal.o sys_arm.o \ | 10 | process.o ptrace.o semaphore.o setup.o signal.o \ | 
| 11 | time.o traps.o | 11 | sys_arm.o stacktrace.o time.o traps.o | 
| 12 | 12 | ||
| 13 | obj-$(CONFIG_ISA_DMA_API) += dma.o | 13 | obj-$(CONFIG_ISA_DMA_API) += dma.o | 
| 14 | obj-$(CONFIG_ARCH_ACORN) += ecard.o | 14 | obj-$(CONFIG_ARCH_ACORN) += ecard.o | 
| diff --git a/arch/arm/kernel/ecard.c b/arch/arm/kernel/ecard.c index f1c0fb974177..bdbd7da99286 100644 --- a/arch/arm/kernel/ecard.c +++ b/arch/arm/kernel/ecard.c | |||
| @@ -40,6 +40,7 @@ | |||
| 40 | #include <linux/device.h> | 40 | #include <linux/device.h> | 
| 41 | #include <linux/init.h> | 41 | #include <linux/init.h> | 
| 42 | #include <linux/mutex.h> | 42 | #include <linux/mutex.h> | 
| 43 | #include <linux/kthread.h> | ||
| 43 | 44 | ||
| 44 | #include <asm/dma.h> | 45 | #include <asm/dma.h> | 
| 45 | #include <asm/ecard.h> | 46 | #include <asm/ecard.h> | 
| @@ -50,6 +51,8 @@ | |||
| 50 | #include <asm/mach/irq.h> | 51 | #include <asm/mach/irq.h> | 
| 51 | #include <asm/tlbflush.h> | 52 | #include <asm/tlbflush.h> | 
| 52 | 53 | ||
| 54 | #include "ecard.h" | ||
| 55 | |||
| 53 | #ifndef CONFIG_ARCH_RPC | 56 | #ifndef CONFIG_ARCH_RPC | 
| 54 | #define HAVE_EXPMASK | 57 | #define HAVE_EXPMASK | 
| 55 | #endif | 58 | #endif | 
| @@ -123,7 +126,7 @@ static void ecard_task_reset(struct ecard_request *req) | |||
| 123 | 126 | ||
| 124 | res = ec->slot_no == 8 | 127 | res = ec->slot_no == 8 | 
| 125 | ? &ec->resource[ECARD_RES_MEMC] | 128 | ? &ec->resource[ECARD_RES_MEMC] | 
| 126 | : ec->type == ECARD_EASI | 129 | : ec->easi | 
| 127 | ? &ec->resource[ECARD_RES_EASI] | 130 | ? &ec->resource[ECARD_RES_EASI] | 
| 128 | : &ec->resource[ECARD_RES_IOCSYNC]; | 131 | : &ec->resource[ECARD_RES_IOCSYNC]; | 
| 129 | 132 | ||
| @@ -178,7 +181,7 @@ static void ecard_task_readbytes(struct ecard_request *req) | |||
| 178 | index += 1; | 181 | index += 1; | 
| 179 | } | 182 | } | 
| 180 | } else { | 183 | } else { | 
| 181 | unsigned long base = (ec->type == ECARD_EASI | 184 | unsigned long base = (ec->easi | 
| 182 | ? &ec->resource[ECARD_RES_EASI] | 185 | ? &ec->resource[ECARD_RES_EASI] | 
| 183 | : &ec->resource[ECARD_RES_IOCSYNC])->start; | 186 | : &ec->resource[ECARD_RES_IOCSYNC])->start; | 
| 184 | void __iomem *pbase = (void __iomem *)base; | 187 | void __iomem *pbase = (void __iomem *)base; | 
| @@ -263,8 +266,6 @@ static int ecard_init_mm(void) | |||
| 263 | static int | 266 | static int | 
| 264 | ecard_task(void * unused) | 267 | ecard_task(void * unused) | 
| 265 | { | 268 | { | 
| 266 | daemonize("kecardd"); | ||
| 267 | |||
| 268 | /* | 269 | /* | 
| 269 | * Allocate a mm. We're not a lazy-TLB kernel task since we need | 270 | * Allocate a mm. We're not a lazy-TLB kernel task since we need | 
| 270 | * to set page table entries where the user space would be. Note | 271 | * to set page table entries where the user space would be. Note | 
| @@ -727,7 +728,7 @@ static int ecard_prints(char *buffer, ecard_t *ec) | |||
| 727 | char *start = buffer; | 728 | char *start = buffer; | 
| 728 | 729 | ||
| 729 | buffer += sprintf(buffer, " %d: %s ", ec->slot_no, | 730 | buffer += sprintf(buffer, " %d: %s ", ec->slot_no, | 
| 730 | ec->type == ECARD_EASI ? "EASI" : " "); | 731 | ec->easi ? "EASI" : " "); | 
| 731 | 732 | ||
| 732 | if (ec->cid.id == 0) { | 733 | if (ec->cid.id == 0) { | 
| 733 | struct in_chunk_dir incd; | 734 | struct in_chunk_dir incd; | 
| @@ -814,7 +815,7 @@ static struct expansion_card *__init ecard_alloc_card(int type, int slot) | |||
| 814 | } | 815 | } | 
| 815 | 816 | ||
| 816 | ec->slot_no = slot; | 817 | ec->slot_no = slot; | 
| 817 | ec->type = type; | 818 | ec->easi = type == ECARD_EASI; | 
| 818 | ec->irq = NO_IRQ; | 819 | ec->irq = NO_IRQ; | 
| 819 | ec->fiq = NO_IRQ; | 820 | ec->fiq = NO_IRQ; | 
| 820 | ec->dma = NO_DMA; | 821 | ec->dma = NO_DMA; | 
| @@ -825,6 +826,7 @@ static struct expansion_card *__init ecard_alloc_card(int type, int slot) | |||
| 825 | ec->dev.bus = &ecard_bus_type; | 826 | ec->dev.bus = &ecard_bus_type; | 
| 826 | ec->dev.dma_mask = &ec->dma_mask; | 827 | ec->dev.dma_mask = &ec->dma_mask; | 
| 827 | ec->dma_mask = (u64)0xffffffff; | 828 | ec->dma_mask = (u64)0xffffffff; | 
| 829 | ec->dev.coherent_dma_mask = ec->dma_mask; | ||
| 828 | 830 | ||
| 829 | if (slot < 4) { | 831 | if (slot < 4) { | 
| 830 | ec_set_resource(ec, ECARD_RES_MEMC, | 832 | ec_set_resource(ec, ECARD_RES_MEMC, | 
| @@ -907,7 +909,7 @@ static ssize_t ecard_show_device(struct device *dev, struct device_attribute *at | |||
| 907 | static ssize_t ecard_show_type(struct device *dev, struct device_attribute *attr, char *buf) | 909 | static ssize_t ecard_show_type(struct device *dev, struct device_attribute *attr, char *buf) | 
| 908 | { | 910 | { | 
| 909 | struct expansion_card *ec = ECARD_DEV(dev); | 911 | struct expansion_card *ec = ECARD_DEV(dev); | 
| 910 | return sprintf(buf, "%s\n", ec->type == ECARD_EASI ? "EASI" : "IOC"); | 912 | return sprintf(buf, "%s\n", ec->easi ? "EASI" : "IOC"); | 
| 911 | } | 913 | } | 
| 912 | 914 | ||
| 913 | static struct device_attribute ecard_dev_attrs[] = { | 915 | static struct device_attribute ecard_dev_attrs[] = { | 
| @@ -1058,13 +1060,14 @@ ecard_probe(int slot, card_type_t type) | |||
| 1058 | */ | 1060 | */ | 
| 1059 | static int __init ecard_init(void) | 1061 | static int __init ecard_init(void) | 
| 1060 | { | 1062 | { | 
| 1061 | int slot, irqhw, ret; | 1063 | struct task_struct *task; | 
| 1062 | 1064 | int slot, irqhw; | |
| 1063 | ret = kernel_thread(ecard_task, NULL, CLONE_KERNEL); | 1065 | |
| 1064 | if (ret < 0) { | 1066 | task = kthread_run(ecard_task, NULL, "kecardd"); | 
| 1065 | printk(KERN_ERR "Ecard: unable to create kernel thread: %d\n", | 1067 | if (IS_ERR(task)) { | 
| 1066 | ret); | 1068 | printk(KERN_ERR "Ecard: unable to create kernel thread: %ld\n", | 
| 1067 | return ret; | 1069 | PTR_ERR(task)); | 
| 1070 | return PTR_ERR(task); | ||
| 1068 | } | 1071 | } | 
| 1069 | 1072 | ||
| 1070 | printk("Probing expansion cards\n"); | 1073 | printk("Probing expansion cards\n"); | 
| diff --git a/arch/arm/kernel/ecard.h b/arch/arm/kernel/ecard.h new file mode 100644 index 000000000000..d7c2dacf935d --- /dev/null +++ b/arch/arm/kernel/ecard.h | |||
| @@ -0,0 +1,56 @@ | |||
| 1 | /* | ||
| 2 | * ecard.h | ||
| 3 | * | ||
| 4 | * Copyright 2007 Russell King | ||
| 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 | /* Definitions internal to ecard.c - for it's use only!! | ||
| 12 | * | ||
| 13 | * External expansion card header as read from the card | ||
| 14 | */ | ||
| 15 | struct ex_ecid { | ||
| 16 | unsigned char r_irq:1; | ||
| 17 | unsigned char r_zero:1; | ||
| 18 | unsigned char r_fiq:1; | ||
| 19 | unsigned char r_id:4; | ||
| 20 | unsigned char r_a:1; | ||
| 21 | |||
| 22 | unsigned char r_cd:1; | ||
| 23 | unsigned char r_is:1; | ||
| 24 | unsigned char r_w:2; | ||
| 25 | unsigned char r_r1:4; | ||
| 26 | |||
| 27 | unsigned char r_r2:8; | ||
| 28 | |||
| 29 | unsigned char r_prod[2]; | ||
| 30 | |||
| 31 | unsigned char r_manu[2]; | ||
| 32 | |||
| 33 | unsigned char r_country; | ||
| 34 | |||
| 35 | unsigned char r_fiqmask; | ||
| 36 | unsigned char r_fiqoff[3]; | ||
| 37 | |||
| 38 | unsigned char r_irqmask; | ||
| 39 | unsigned char r_irqoff[3]; | ||
| 40 | }; | ||
| 41 | |||
| 42 | /* | ||
| 43 | * Chunk directory entry as read from the card | ||
| 44 | */ | ||
| 45 | struct ex_chunk_dir { | ||
| 46 | unsigned char r_id; | ||
| 47 | unsigned char r_len[3]; | ||
| 48 | unsigned long r_start; | ||
| 49 | union { | ||
| 50 | char string[256]; | ||
| 51 | char data[1]; | ||
| 52 | } d; | ||
| 53 | #define c_id(x) ((x)->r_id) | ||
| 54 | #define c_len(x) ((x)->r_len[0]|((x)->r_len[1]<<8)|((x)->r_len[2]<<16)) | ||
| 55 | #define c_start(x) ((x)->r_start) | ||
| 56 | }; | ||
| diff --git a/arch/arm/kernel/head.S b/arch/arm/kernel/head.S index 66db0a9bf0bc..1d35edacc011 100644 --- a/arch/arm/kernel/head.S +++ b/arch/arm/kernel/head.S | |||
| @@ -257,7 +257,9 @@ __create_page_tables: | |||
| 257 | * Map some ram to cover our .data and .bss areas. | 257 | * Map some ram to cover our .data and .bss areas. | 
| 258 | */ | 258 | */ | 
| 259 | orr r3, r7, #(KERNEL_RAM_PADDR & 0xff000000) | 259 | orr r3, r7, #(KERNEL_RAM_PADDR & 0xff000000) | 
| 260 | .if (KERNEL_RAM_PADDR & 0x00f00000) | ||
| 260 | orr r3, r3, #(KERNEL_RAM_PADDR & 0x00f00000) | 261 | orr r3, r3, #(KERNEL_RAM_PADDR & 0x00f00000) | 
| 262 | .endif | ||
| 261 | add r0, r4, #(KERNEL_RAM_VADDR & 0xff000000) >> 18 | 263 | add r0, r4, #(KERNEL_RAM_VADDR & 0xff000000) >> 18 | 
| 262 | str r3, [r0, #(KERNEL_RAM_VADDR & 0x00f00000) >> 18]! | 264 | str r3, [r0, #(KERNEL_RAM_VADDR & 0x00f00000) >> 18]! | 
| 263 | ldr r6, =(_end - 1) | 265 | ldr r6, =(_end - 1) | 
| @@ -274,7 +276,9 @@ __create_page_tables: | |||
| 274 | */ | 276 | */ | 
| 275 | add r0, r4, #PAGE_OFFSET >> 18 | 277 | add r0, r4, #PAGE_OFFSET >> 18 | 
| 276 | orr r6, r7, #(PHYS_OFFSET & 0xff000000) | 278 | orr r6, r7, #(PHYS_OFFSET & 0xff000000) | 
| 277 | orr r6, r6, #(PHYS_OFFSET & 0x00e00000) | 279 | .if (PHYS_OFFSET & 0x00f00000) | 
| 280 | orr r6, r6, #(PHYS_OFFSET & 0x00f00000) | ||
| 281 | .endif | ||
| 278 | str r6, [r0] | 282 | str r6, [r0] | 
| 279 | 283 | ||
| 280 | #ifdef CONFIG_DEBUG_LL | 284 | #ifdef CONFIG_DEBUG_LL | 
| diff --git a/arch/arm/kernel/process.c b/arch/arm/kernel/process.c index 8afd83d0cbdd..5d6e6523598b 100644 --- a/arch/arm/kernel/process.c +++ b/arch/arm/kernel/process.c | |||
| @@ -27,6 +27,7 @@ | |||
| 27 | #include <linux/cpu.h> | 27 | #include <linux/cpu.h> | 
| 28 | #include <linux/elfcore.h> | 28 | #include <linux/elfcore.h> | 
| 29 | #include <linux/pm.h> | 29 | #include <linux/pm.h> | 
| 30 | #include <linux/tick.h> | ||
| 30 | 31 | ||
| 31 | #include <asm/leds.h> | 32 | #include <asm/leds.h> | 
| 32 | #include <asm/processor.h> | 33 | #include <asm/processor.h> | 
| @@ -159,9 +160,11 @@ void cpu_idle(void) | |||
| 159 | if (!idle) | 160 | if (!idle) | 
| 160 | idle = default_idle; | 161 | idle = default_idle; | 
| 161 | leds_event(led_idle_start); | 162 | leds_event(led_idle_start); | 
| 163 | tick_nohz_stop_sched_tick(); | ||
| 162 | while (!need_resched()) | 164 | while (!need_resched()) | 
| 163 | idle(); | 165 | idle(); | 
| 164 | leds_event(led_idle_end); | 166 | leds_event(led_idle_end); | 
| 167 | tick_nohz_restart_sched_tick(); | ||
| 165 | preempt_enable_no_resched(); | 168 | preempt_enable_no_resched(); | 
| 166 | schedule(); | 169 | schedule(); | 
| 167 | preempt_disable(); | 170 | preempt_disable(); | 
| diff --git a/arch/arm/kernel/ptrace.c b/arch/arm/kernel/ptrace.c index e594b84cca83..13af4006a40f 100644 --- a/arch/arm/kernel/ptrace.c +++ b/arch/arm/kernel/ptrace.c | |||
| @@ -779,8 +779,8 @@ long arch_ptrace(struct task_struct *child, long request, long addr, long data) | |||
| 779 | break; | 779 | break; | 
| 780 | 780 | ||
| 781 | case PTRACE_SET_SYSCALL: | 781 | case PTRACE_SET_SYSCALL: | 
| 782 | task_thread_info(child)->syscall = data; | ||
| 782 | ret = 0; | 783 | ret = 0; | 
| 783 | child->ptrace_message = data; | ||
| 784 | break; | 784 | break; | 
| 785 | 785 | ||
| 786 | #ifdef CONFIG_CRUNCH | 786 | #ifdef CONFIG_CRUNCH | 
| @@ -817,7 +817,7 @@ asmlinkage int syscall_trace(int why, struct pt_regs *regs, int scno) | |||
| 817 | ip = regs->ARM_ip; | 817 | ip = regs->ARM_ip; | 
| 818 | regs->ARM_ip = why; | 818 | regs->ARM_ip = why; | 
| 819 | 819 | ||
| 820 | current->ptrace_message = scno; | 820 | current_thread_info()->syscall = scno; | 
| 821 | 821 | ||
| 822 | /* the 0x80 provides a way for the tracing parent to distinguish | 822 | /* the 0x80 provides a way for the tracing parent to distinguish | 
| 823 | between a syscall stop and SIGTRAP delivery */ | 823 | between a syscall stop and SIGTRAP delivery */ | 
| @@ -834,5 +834,5 @@ asmlinkage int syscall_trace(int why, struct pt_regs *regs, int scno) | |||
| 834 | } | 834 | } | 
| 835 | regs->ARM_ip = ip; | 835 | regs->ARM_ip = ip; | 
| 836 | 836 | ||
| 837 | return current->ptrace_message; | 837 | return current_thread_info()->syscall; | 
| 838 | } | 838 | } | 
| diff --git a/arch/arm/kernel/stacktrace.c b/arch/arm/kernel/stacktrace.c new file mode 100644 index 000000000000..77ef35efaa8d --- /dev/null +++ b/arch/arm/kernel/stacktrace.c | |||
| @@ -0,0 +1,73 @@ | |||
| 1 | #include <linux/sched.h> | ||
| 2 | #include <linux/stacktrace.h> | ||
| 3 | |||
| 4 | #include "stacktrace.h" | ||
| 5 | |||
| 6 | int walk_stackframe(unsigned long fp, unsigned long low, unsigned long high, | ||
| 7 | int (*fn)(struct stackframe *, void *), void *data) | ||
| 8 | { | ||
| 9 | struct stackframe *frame; | ||
| 10 | |||
| 11 | do { | ||
| 12 | /* | ||
| 13 | * Check current frame pointer is within bounds | ||
| 14 | */ | ||
| 15 | if ((fp - 12) < low || fp + 4 >= high) | ||
| 16 | break; | ||
| 17 | |||
| 18 | frame = (struct stackframe *)(fp - 12); | ||
| 19 | |||
| 20 | if (fn(frame, data)) | ||
| 21 | break; | ||
| 22 | |||
| 23 | /* | ||
| 24 | * Update the low bound - the next frame must always | ||
| 25 | * be at a higher address than the current frame. | ||
| 26 | */ | ||
| 27 | low = fp + 4; | ||
| 28 | fp = frame->fp; | ||
| 29 | } while (fp); | ||
| 30 | |||
| 31 | return 0; | ||
| 32 | } | ||
| 33 | |||
| 34 | #ifdef CONFIG_STACKTRACE | ||
| 35 | struct stack_trace_data { | ||
| 36 | struct stack_trace *trace; | ||
| 37 | unsigned int skip; | ||
| 38 | }; | ||
| 39 | |||
| 40 | static int save_trace(struct stackframe *frame, void *d) | ||
| 41 | { | ||
| 42 | struct stack_trace_data *data = d; | ||
| 43 | struct stack_trace *trace = data->trace; | ||
| 44 | |||
| 45 | if (data->skip) { | ||
| 46 | data->skip--; | ||
| 47 | return 0; | ||
| 48 | } | ||
| 49 | |||
| 50 | trace->entries[trace->nr_entries++] = frame->lr; | ||
| 51 | |||
| 52 | return trace->nr_entries >= trace->max_entries; | ||
| 53 | } | ||
| 54 | |||
| 55 | void save_stack_trace(struct stack_trace *trace, struct task_struct *task) | ||
| 56 | { | ||
| 57 | struct stack_trace_data data; | ||
| 58 | unsigned long fp, base; | ||
| 59 | |||
| 60 | data.trace = trace; | ||
| 61 | data.skip = trace->skip; | ||
| 62 | |||
| 63 | if (task) { | ||
| 64 | base = (unsigned long)task_stack_page(task); | ||
| 65 | fp = 0; /* FIXME */ | ||
| 66 | } else { | ||
| 67 | base = (unsigned long)task_stack_page(current); | ||
| 68 | asm("mov %0, fp" : "=r" (fp)); | ||
| 69 | } | ||
| 70 | |||
| 71 | walk_stackframe(fp, base, base + THREAD_SIZE, save_trace, &data); | ||
| 72 | } | ||
| 73 | #endif | ||
| diff --git a/arch/arm/kernel/stacktrace.h b/arch/arm/kernel/stacktrace.h new file mode 100644 index 000000000000..e9fd20cb5662 --- /dev/null +++ b/arch/arm/kernel/stacktrace.h | |||
| @@ -0,0 +1,9 @@ | |||
| 1 | struct stackframe { | ||
| 2 | unsigned long fp; | ||
| 3 | unsigned long sp; | ||
| 4 | unsigned long lr; | ||
| 5 | unsigned long pc; | ||
| 6 | }; | ||
| 7 | |||
| 8 | int walk_stackframe(unsigned long fp, unsigned long low, unsigned long high, | ||
| 9 | int (*fn)(struct stackframe *, void *), void *data); | ||
| diff --git a/arch/arm/kernel/time.c b/arch/arm/kernel/time.c index f61decb89ba2..d0540e4eaf5b 100644 --- a/arch/arm/kernel/time.c +++ b/arch/arm/kernel/time.c | |||
| @@ -327,6 +327,7 @@ void restore_time_delta(struct timespec *delta, struct timespec *rtc) | |||
| 327 | } | 327 | } | 
| 328 | EXPORT_SYMBOL(restore_time_delta); | 328 | EXPORT_SYMBOL(restore_time_delta); | 
| 329 | 329 | ||
| 330 | #ifndef CONFIG_GENERIC_CLOCKEVENTS | ||
| 330 | /* | 331 | /* | 
| 331 | * Kernel system timer support. | 332 | * Kernel system timer support. | 
| 332 | */ | 333 | */ | 
| @@ -340,8 +341,9 @@ void timer_tick(void) | |||
| 340 | update_process_times(user_mode(get_irq_regs())); | 341 | update_process_times(user_mode(get_irq_regs())); | 
| 341 | #endif | 342 | #endif | 
| 342 | } | 343 | } | 
| 344 | #endif | ||
| 343 | 345 | ||
| 344 | #ifdef CONFIG_PM | 346 | #if defined(CONFIG_PM) && !defined(CONFIG_GENERIC_CLOCKEVENTS) | 
| 345 | static int timer_suspend(struct sys_device *dev, pm_message_t state) | 347 | static int timer_suspend(struct sys_device *dev, pm_message_t state) | 
| 346 | { | 348 | { | 
| 347 | struct sys_timer *timer = container_of(dev, struct sys_timer, dev); | 349 | struct sys_timer *timer = container_of(dev, struct sys_timer, dev); | 
| diff --git a/arch/arm/kernel/traps.c b/arch/arm/kernel/traps.c index 6055ab4b58d9..f05e66b0f868 100644 --- a/arch/arm/kernel/traps.c +++ b/arch/arm/kernel/traps.c | |||
| @@ -286,6 +286,7 @@ asmlinkage void __exception do_undefinstr(struct pt_regs *regs) | |||
| 286 | struct undef_hook *hook; | 286 | struct undef_hook *hook; | 
| 287 | siginfo_t info; | 287 | siginfo_t info; | 
| 288 | void __user *pc; | 288 | void __user *pc; | 
| 289 | unsigned long flags; | ||
| 289 | 290 | ||
| 290 | /* | 291 | /* | 
| 291 | * According to the ARM ARM, PC is 2 or 4 bytes ahead, | 292 | * According to the ARM ARM, PC is 2 or 4 bytes ahead, | 
| @@ -304,7 +305,7 @@ asmlinkage void __exception do_undefinstr(struct pt_regs *regs) | |||
| 304 | get_user(instr, (u32 __user *)pc); | 305 | get_user(instr, (u32 __user *)pc); | 
| 305 | } | 306 | } | 
| 306 | 307 | ||
| 307 | spin_lock_irq(&undef_lock); | 308 | spin_lock_irqsave(&undef_lock, flags); | 
| 308 | list_for_each_entry(hook, &undef_hook, node) { | 309 | list_for_each_entry(hook, &undef_hook, node) { | 
| 309 | if ((instr & hook->instr_mask) == hook->instr_val && | 310 | if ((instr & hook->instr_mask) == hook->instr_val && | 
| 310 | (regs->ARM_cpsr & hook->cpsr_mask) == hook->cpsr_val) { | 311 | (regs->ARM_cpsr & hook->cpsr_mask) == hook->cpsr_val) { | 
| @@ -314,7 +315,7 @@ asmlinkage void __exception do_undefinstr(struct pt_regs *regs) | |||
| 314 | } | 315 | } | 
| 315 | } | 316 | } | 
| 316 | } | 317 | } | 
| 317 | spin_unlock_irq(&undef_lock); | 318 | spin_unlock_irqrestore(&undef_lock, flags); | 
| 318 | 319 | ||
| 319 | #ifdef CONFIG_DEBUG_USER | 320 | #ifdef CONFIG_DEBUG_USER | 
| 320 | if (user_debug & UDBG_UNDEFINED) { | 321 | if (user_debug & UDBG_UNDEFINED) { | 
| diff --git a/arch/arm/mach-at91/Kconfig b/arch/arm/mach-at91/Kconfig index bf0d96272e3a..e238ad8cfd8f 100644 --- a/arch/arm/mach-at91/Kconfig +++ b/arch/arm/mach-at91/Kconfig | |||
| @@ -81,6 +81,13 @@ config MACH_KB9200 | |||
| 81 | Select this if you are using KwikByte's KB920x board. | 81 | Select this if you are using KwikByte's KB920x board. | 
| 82 | <http://kwikbyte.com/KB9202_description_new.htm> | 82 | <http://kwikbyte.com/KB9202_description_new.htm> | 
| 83 | 83 | ||
| 84 | config MACH_PICOTUX2XX | ||
| 85 | bool "picotux 200" | ||
| 86 | depends on ARCH_AT91RM9200 | ||
| 87 | help | ||
| 88 | Select this if you are using a picotux 200. | ||
| 89 | <http://www.picotux.com/> | ||
| 90 | |||
| 84 | config MACH_KAFA | 91 | config MACH_KAFA | 
| 85 | bool "Sperry-Sun KAFA board" | 92 | bool "Sperry-Sun KAFA board" | 
| 86 | depends on ARCH_AT91RM9200 | 93 | depends on ARCH_AT91RM9200 | 
| diff --git a/arch/arm/mach-at91/Makefile b/arch/arm/mach-at91/Makefile index 05de6cdc88f1..a412ae18a421 100644 --- a/arch/arm/mach-at91/Makefile +++ b/arch/arm/mach-at91/Makefile | |||
| @@ -25,6 +25,7 @@ obj-$(CONFIG_MACH_CARMEVA) += board-carmeva.o | |||
| 25 | obj-$(CONFIG_MACH_KB9200) += board-kb9202.o | 25 | obj-$(CONFIG_MACH_KB9200) += board-kb9202.o | 
| 26 | obj-$(CONFIG_MACH_ATEB9200) += board-eb9200.o | 26 | obj-$(CONFIG_MACH_ATEB9200) += board-eb9200.o | 
| 27 | obj-$(CONFIG_MACH_KAFA) += board-kafa.o | 27 | obj-$(CONFIG_MACH_KAFA) += board-kafa.o | 
| 28 | obj-$(CONFIG_MACH_PICOTUX2XX) += board-picotux200.o | ||
| 28 | 29 | ||
| 29 | # AT91SAM9260 board-specific support | 30 | # AT91SAM9260 board-specific support | 
| 30 | obj-$(CONFIG_MACH_AT91SAM9260EK) += board-sam9260ek.o | 31 | obj-$(CONFIG_MACH_AT91SAM9260EK) += board-sam9260ek.o | 
| diff --git a/arch/arm/mach-at91/at91rm9200.c b/arch/arm/mach-at91/at91rm9200.c index 2ddcdd69df7d..2cad2bf864be 100644 --- a/arch/arm/mach-at91/at91rm9200.c +++ b/arch/arm/mach-at91/at91rm9200.c | |||
| @@ -117,6 +117,21 @@ static struct clk pioD_clk = { | |||
| 117 | .pmc_mask = 1 << AT91RM9200_ID_PIOD, | 117 | .pmc_mask = 1 << AT91RM9200_ID_PIOD, | 
| 118 | .type = CLK_TYPE_PERIPHERAL, | 118 | .type = CLK_TYPE_PERIPHERAL, | 
| 119 | }; | 119 | }; | 
| 120 | static struct clk ssc0_clk = { | ||
| 121 | .name = "ssc0_clk", | ||
| 122 | .pmc_mask = 1 << AT91RM9200_ID_SSC0, | ||
| 123 | .type = CLK_TYPE_PERIPHERAL, | ||
| 124 | }; | ||
| 125 | static struct clk ssc1_clk = { | ||
| 126 | .name = "ssc1_clk", | ||
| 127 | .pmc_mask = 1 << AT91RM9200_ID_SSC1, | ||
| 128 | .type = CLK_TYPE_PERIPHERAL, | ||
| 129 | }; | ||
| 130 | static struct clk ssc2_clk = { | ||
| 131 | .name = "ssc2_clk", | ||
| 132 | .pmc_mask = 1 << AT91RM9200_ID_SSC2, | ||
| 133 | .type = CLK_TYPE_PERIPHERAL, | ||
| 134 | }; | ||
| 120 | static struct clk tc0_clk = { | 135 | static struct clk tc0_clk = { | 
| 121 | .name = "tc0_clk", | 136 | .name = "tc0_clk", | 
| 122 | .pmc_mask = 1 << AT91RM9200_ID_TC0, | 137 | .pmc_mask = 1 << AT91RM9200_ID_TC0, | 
| @@ -161,7 +176,9 @@ static struct clk *periph_clocks[] __initdata = { | |||
| 161 | &udc_clk, | 176 | &udc_clk, | 
| 162 | &twi_clk, | 177 | &twi_clk, | 
| 163 | &spi_clk, | 178 | &spi_clk, | 
| 164 | // ssc 0 .. ssc2 | 179 | &ssc0_clk, | 
| 180 | &ssc1_clk, | ||
| 181 | &ssc2_clk, | ||
| 165 | &tc0_clk, | 182 | &tc0_clk, | 
| 166 | &tc1_clk, | 183 | &tc1_clk, | 
| 167 | &tc2_clk, | 184 | &tc2_clk, | 
| diff --git a/arch/arm/mach-at91/at91sam9260.c b/arch/arm/mach-at91/at91sam9260.c index 6ea41d8266cb..e47381e8aaba 100644 --- a/arch/arm/mach-at91/at91sam9260.c +++ b/arch/arm/mach-at91/at91sam9260.c | |||
| @@ -119,6 +119,11 @@ static struct clk spi1_clk = { | |||
| 119 | .pmc_mask = 1 << AT91SAM9260_ID_SPI1, | 119 | .pmc_mask = 1 << AT91SAM9260_ID_SPI1, | 
| 120 | .type = CLK_TYPE_PERIPHERAL, | 120 | .type = CLK_TYPE_PERIPHERAL, | 
| 121 | }; | 121 | }; | 
| 122 | static struct clk ssc_clk = { | ||
| 123 | .name = "ssc_clk", | ||
| 124 | .pmc_mask = 1 << AT91SAM9260_ID_SSC, | ||
| 125 | .type = CLK_TYPE_PERIPHERAL, | ||
| 126 | }; | ||
| 122 | static struct clk tc0_clk = { | 127 | static struct clk tc0_clk = { | 
| 123 | .name = "tc0_clk", | 128 | .name = "tc0_clk", | 
| 124 | .pmc_mask = 1 << AT91SAM9260_ID_TC0, | 129 | .pmc_mask = 1 << AT91SAM9260_ID_TC0, | 
| @@ -193,7 +198,7 @@ static struct clk *periph_clocks[] __initdata = { | |||
| 193 | &twi_clk, | 198 | &twi_clk, | 
| 194 | &spi0_clk, | 199 | &spi0_clk, | 
| 195 | &spi1_clk, | 200 | &spi1_clk, | 
| 196 | // ssc | 201 | &ssc_clk, | 
| 197 | &tc0_clk, | 202 | &tc0_clk, | 
| 198 | &tc1_clk, | 203 | &tc1_clk, | 
| 199 | &tc2_clk, | 204 | &tc2_clk, | 
| diff --git a/arch/arm/mach-at91/at91sam9261.c b/arch/arm/mach-at91/at91sam9261.c index 784d1e682d6d..dfe8c39c9fb9 100644 --- a/arch/arm/mach-at91/at91sam9261.c +++ b/arch/arm/mach-at91/at91sam9261.c | |||
| @@ -97,6 +97,21 @@ static struct clk spi1_clk = { | |||
| 97 | .pmc_mask = 1 << AT91SAM9261_ID_SPI1, | 97 | .pmc_mask = 1 << AT91SAM9261_ID_SPI1, | 
| 98 | .type = CLK_TYPE_PERIPHERAL, | 98 | .type = CLK_TYPE_PERIPHERAL, | 
| 99 | }; | 99 | }; | 
| 100 | static struct clk ssc0_clk = { | ||
| 101 | .name = "ssc0_clk", | ||
| 102 | .pmc_mask = 1 << AT91SAM9261_ID_SSC0, | ||
| 103 | .type = CLK_TYPE_PERIPHERAL, | ||
| 104 | }; | ||
| 105 | static struct clk ssc1_clk = { | ||
| 106 | .name = "ssc1_clk", | ||
| 107 | .pmc_mask = 1 << AT91SAM9261_ID_SSC1, | ||
| 108 | .type = CLK_TYPE_PERIPHERAL, | ||
| 109 | }; | ||
| 110 | static struct clk ssc2_clk = { | ||
| 111 | .name = "ssc2_clk", | ||
| 112 | .pmc_mask = 1 << AT91SAM9261_ID_SSC2, | ||
| 113 | .type = CLK_TYPE_PERIPHERAL, | ||
| 114 | }; | ||
| 100 | static struct clk tc0_clk = { | 115 | static struct clk tc0_clk = { | 
| 101 | .name = "tc0_clk", | 116 | .name = "tc0_clk", | 
| 102 | .pmc_mask = 1 << AT91SAM9261_ID_TC0, | 117 | .pmc_mask = 1 << AT91SAM9261_ID_TC0, | 
| @@ -135,7 +150,9 @@ static struct clk *periph_clocks[] __initdata = { | |||
| 135 | &twi_clk, | 150 | &twi_clk, | 
| 136 | &spi0_clk, | 151 | &spi0_clk, | 
| 137 | &spi1_clk, | 152 | &spi1_clk, | 
| 138 | // ssc 0 .. ssc2 | 153 | &ssc0_clk, | 
| 154 | &ssc1_clk, | ||
| 155 | &ssc2_clk, | ||
| 139 | &tc0_clk, | 156 | &tc0_clk, | 
| 140 | &tc1_clk, | 157 | &tc1_clk, | 
| 141 | &tc2_clk, | 158 | &tc2_clk, | 
| diff --git a/arch/arm/mach-at91/at91sam9261_devices.c b/arch/arm/mach-at91/at91sam9261_devices.c index e1504766fd64..8e781997716a 100644 --- a/arch/arm/mach-at91/at91sam9261_devices.c +++ b/arch/arm/mach-at91/at91sam9261_devices.c | |||
| @@ -430,9 +430,9 @@ void __init at91_add_device_spi(struct spi_board_info *devices, int nr_devices) | |||
| 430 | * LCD Controller | 430 | * LCD Controller | 
| 431 | * -------------------------------------------------------------------- */ | 431 | * -------------------------------------------------------------------- */ | 
| 432 | 432 | ||
| 433 | #if defined(CONFIG_FB_AT91) || defined(CONFIG_FB_AT91_MODULE) | 433 | #if defined(CONFIG_FB_ATMEL) || defined(CONFIG_FB_ATMEL_MODULE) | 
| 434 | static u64 lcdc_dmamask = 0xffffffffUL; | 434 | static u64 lcdc_dmamask = 0xffffffffUL; | 
| 435 | static struct at91fb_info lcdc_data; | 435 | static struct atmel_lcdfb_info lcdc_data; | 
| 436 | 436 | ||
| 437 | static struct resource lcdc_resources[] = { | 437 | static struct resource lcdc_resources[] = { | 
| 438 | [0] = { | 438 | [0] = { | 
| @@ -455,7 +455,7 @@ static struct resource lcdc_resources[] = { | |||
| 455 | }; | 455 | }; | 
| 456 | 456 | ||
| 457 | static struct platform_device at91_lcdc_device = { | 457 | static struct platform_device at91_lcdc_device = { | 
| 458 | .name = "at91-fb", | 458 | .name = "atmel_lcdfb", | 
| 459 | .id = 0, | 459 | .id = 0, | 
| 460 | .dev = { | 460 | .dev = { | 
| 461 | .dma_mask = &lcdc_dmamask, | 461 | .dma_mask = &lcdc_dmamask, | 
| @@ -466,7 +466,7 @@ static struct platform_device at91_lcdc_device = { | |||
| 466 | .num_resources = ARRAY_SIZE(lcdc_resources), | 466 | .num_resources = ARRAY_SIZE(lcdc_resources), | 
| 467 | }; | 467 | }; | 
| 468 | 468 | ||
| 469 | void __init at91_add_device_lcdc(struct at91fb_info *data) | 469 | void __init at91_add_device_lcdc(struct atmel_lcdfb_info *data) | 
| 470 | { | 470 | { | 
| 471 | if (!data) { | 471 | if (!data) { | 
| 472 | return; | 472 | return; | 
| @@ -499,7 +499,7 @@ void __init at91_add_device_lcdc(struct at91fb_info *data) | |||
| 499 | platform_device_register(&at91_lcdc_device); | 499 | platform_device_register(&at91_lcdc_device); | 
| 500 | } | 500 | } | 
| 501 | #else | 501 | #else | 
| 502 | void __init at91_add_device_lcdc(struct at91fb_info *data) {} | 502 | void __init at91_add_device_lcdc(struct atmel_lcdfb_info *data) {} | 
| 503 | #endif | 503 | #endif | 
| 504 | 504 | ||
| 505 | 505 | ||
| diff --git a/arch/arm/mach-at91/at91sam9263.c b/arch/arm/mach-at91/at91sam9263.c index 0e89a7fca3fa..00e27b177857 100644 --- a/arch/arm/mach-at91/at91sam9263.c +++ b/arch/arm/mach-at91/at91sam9263.c | |||
| @@ -87,6 +87,11 @@ static struct clk mmc1_clk = { | |||
| 87 | .pmc_mask = 1 << AT91SAM9263_ID_MCI1, | 87 | .pmc_mask = 1 << AT91SAM9263_ID_MCI1, | 
| 88 | .type = CLK_TYPE_PERIPHERAL, | 88 | .type = CLK_TYPE_PERIPHERAL, | 
| 89 | }; | 89 | }; | 
| 90 | static struct clk can_clk = { | ||
| 91 | .name = "can_clk", | ||
| 92 | .pmc_mask = 1 << AT91SAM9263_ID_CAN, | ||
| 93 | .type = CLK_TYPE_PERIPHERAL, | ||
| 94 | }; | ||
| 90 | static struct clk twi_clk = { | 95 | static struct clk twi_clk = { | 
| 91 | .name = "twi_clk", | 96 | .name = "twi_clk", | 
| 92 | .pmc_mask = 1 << AT91SAM9263_ID_TWI, | 97 | .pmc_mask = 1 << AT91SAM9263_ID_TWI, | 
| @@ -102,16 +107,46 @@ static struct clk spi1_clk = { | |||
| 102 | .pmc_mask = 1 << AT91SAM9263_ID_SPI1, | 107 | .pmc_mask = 1 << AT91SAM9263_ID_SPI1, | 
| 103 | .type = CLK_TYPE_PERIPHERAL, | 108 | .type = CLK_TYPE_PERIPHERAL, | 
| 104 | }; | 109 | }; | 
| 110 | static struct clk ssc0_clk = { | ||
| 111 | .name = "ssc0_clk", | ||
| 112 | .pmc_mask = 1 << AT91SAM9263_ID_SSC0, | ||
| 113 | .type = CLK_TYPE_PERIPHERAL, | ||
| 114 | }; | ||
| 115 | static struct clk ssc1_clk = { | ||
| 116 | .name = "ssc1_clk", | ||
| 117 | .pmc_mask = 1 << AT91SAM9263_ID_SSC1, | ||
| 118 | .type = CLK_TYPE_PERIPHERAL, | ||
| 119 | }; | ||
| 120 | static struct clk ac97_clk = { | ||
| 121 | .name = "ac97_clk", | ||
| 122 | .pmc_mask = 1 << AT91SAM9263_ID_AC97C, | ||
| 123 | .type = CLK_TYPE_PERIPHERAL, | ||
| 124 | }; | ||
| 105 | static struct clk tcb_clk = { | 125 | static struct clk tcb_clk = { | 
| 106 | .name = "tcb_clk", | 126 | .name = "tcb_clk", | 
| 107 | .pmc_mask = 1 << AT91SAM9263_ID_TCB, | 127 | .pmc_mask = 1 << AT91SAM9263_ID_TCB, | 
| 108 | .type = CLK_TYPE_PERIPHERAL, | 128 | .type = CLK_TYPE_PERIPHERAL, | 
| 109 | }; | 129 | }; | 
| 130 | static struct clk pwmc_clk = { | ||
| 131 | .name = "pwmc_clk", | ||
| 132 | .pmc_mask = 1 << AT91SAM9263_ID_PWMC, | ||
| 133 | .type = CLK_TYPE_PERIPHERAL, | ||
| 134 | }; | ||
| 110 | static struct clk macb_clk = { | 135 | static struct clk macb_clk = { | 
| 111 | .name = "macb_clk", | 136 | .name = "macb_clk", | 
| 112 | .pmc_mask = 1 << AT91SAM9263_ID_EMAC, | 137 | .pmc_mask = 1 << AT91SAM9263_ID_EMAC, | 
| 113 | .type = CLK_TYPE_PERIPHERAL, | 138 | .type = CLK_TYPE_PERIPHERAL, | 
| 114 | }; | 139 | }; | 
| 140 | static struct clk dma_clk = { | ||
| 141 | .name = "dma_clk", | ||
| 142 | .pmc_mask = 1 << AT91SAM9263_ID_DMA, | ||
| 143 | .type = CLK_TYPE_PERIPHERAL, | ||
| 144 | }; | ||
| 145 | static struct clk twodge_clk = { | ||
| 146 | .name = "2dge_clk", | ||
| 147 | .pmc_mask = 1 << AT91SAM9263_ID_2DGE, | ||
| 148 | .type = CLK_TYPE_PERIPHERAL, | ||
| 149 | }; | ||
| 115 | static struct clk udc_clk = { | 150 | static struct clk udc_clk = { | 
| 116 | .name = "udc_clk", | 151 | .name = "udc_clk", | 
| 117 | .pmc_mask = 1 << AT91SAM9263_ID_UDP, | 152 | .pmc_mask = 1 << AT91SAM9263_ID_UDP, | 
| @@ -142,20 +177,21 @@ static struct clk *periph_clocks[] __initdata = { | |||
| 142 | &usart2_clk, | 177 | &usart2_clk, | 
| 143 | &mmc0_clk, | 178 | &mmc0_clk, | 
| 144 | &mmc1_clk, | 179 | &mmc1_clk, | 
| 145 | // can | 180 | &can_clk, | 
| 146 | &twi_clk, | 181 | &twi_clk, | 
| 147 | &spi0_clk, | 182 | &spi0_clk, | 
| 148 | &spi1_clk, | 183 | &spi1_clk, | 
| 149 | // ssc0 .. ssc1 | 184 | &ssc0_clk, | 
| 150 | // ac97 | 185 | &ssc1_clk, | 
| 186 | &ac97_clk, | ||
| 151 | &tcb_clk, | 187 | &tcb_clk, | 
| 152 | // pwmc | 188 | &pwmc_clk, | 
| 153 | &macb_clk, | 189 | &macb_clk, | 
| 154 | // 2dge | 190 | &twodge_clk, | 
| 155 | &udc_clk, | 191 | &udc_clk, | 
| 156 | &isi_clk, | 192 | &isi_clk, | 
| 157 | &lcdc_clk, | 193 | &lcdc_clk, | 
| 158 | // dma | 194 | &dma_clk, | 
| 159 | &ohci_clk, | 195 | &ohci_clk, | 
| 160 | // irq0 .. irq1 | 196 | // irq0 .. irq1 | 
| 161 | }; | 197 | }; | 
| diff --git a/arch/arm/mach-at91/at91sam9263_devices.c b/arch/arm/mach-at91/at91sam9263_devices.c index b77121f27f34..2b2e18a67128 100644 --- a/arch/arm/mach-at91/at91sam9263_devices.c +++ b/arch/arm/mach-at91/at91sam9263_devices.c | |||
| @@ -573,6 +573,130 @@ void __init at91_add_device_spi(struct spi_board_info *devices, int nr_devices) | |||
| 573 | 573 | ||
| 574 | 574 | ||
| 575 | /* -------------------------------------------------------------------- | 575 | /* -------------------------------------------------------------------- | 
| 576 | * AC97 | ||
| 577 | * -------------------------------------------------------------------- */ | ||
| 578 | |||
| 579 | #if defined(CONFIG_SND_AT91_AC97) || defined(CONFIG_SND_AT91_AC97_MODULE) | ||
| 580 | static u64 ac97_dmamask = 0xffffffffUL; | ||
| 581 | static struct atmel_ac97_data ac97_data; | ||
| 582 | |||
| 583 | static struct resource ac97_resources[] = { | ||
| 584 | [0] = { | ||
| 585 | .start = AT91SAM9263_BASE_AC97C, | ||
| 586 | .end = AT91SAM9263_BASE_AC97C + SZ_16K - 1, | ||
| 587 | .flags = IORESOURCE_MEM, | ||
| 588 | }, | ||
| 589 | [1] = { | ||
| 590 | .start = AT91SAM9263_ID_AC97C, | ||
| 591 | .end = AT91SAM9263_ID_AC97C, | ||
| 592 | .flags = IORESOURCE_IRQ, | ||
| 593 | }, | ||
| 594 | }; | ||
| 595 | |||
| 596 | static struct platform_device at91sam9263_ac97_device = { | ||
| 597 | .name = "ac97c", | ||
| 598 | .id = 1, | ||
| 599 | .dev = { | ||
| 600 | .dma_mask = &ac97_dmamask, | ||
| 601 | .coherent_dma_mask = 0xffffffff, | ||
| 602 | .platform_data = &ac97_data, | ||
| 603 | }, | ||
| 604 | .resource = ac97_resources, | ||
| 605 | .num_resources = ARRAY_SIZE(ac97_resources), | ||
| 606 | }; | ||
| 607 | |||
| 608 | void __init at91_add_device_ac97(struct atmel_ac97_data *data) | ||
| 609 | { | ||
| 610 | if (!data) | ||
| 611 | return; | ||
| 612 | |||
| 613 | at91_set_A_periph(AT91_PIN_PB0, 0); /* AC97FS */ | ||
| 614 | at91_set_A_periph(AT91_PIN_PB1, 0); /* AC97CK */ | ||
| 615 | at91_set_A_periph(AT91_PIN_PB2, 0); /* AC97TX */ | ||
| 616 | at91_set_A_periph(AT91_PIN_PB3, 0); /* AC97RX */ | ||
| 617 | |||
| 618 | /* reset */ | ||
| 619 | if (data->reset_pin) | ||
| 620 | at91_set_gpio_output(data->reset_pin, 0); | ||
| 621 | |||
| 622 | ac97_data = *ek_data; | ||
| 623 | platform_device_register(&at91sam9263_ac97_device); | ||
| 624 | } | ||
| 625 | #else | ||
| 626 | void __init at91_add_device_ac97(struct atmel_ac97_data *data) {} | ||
| 627 | #endif | ||
| 628 | |||
| 629 | |||
| 630 | /* -------------------------------------------------------------------- | ||
| 631 | * LCD Controller | ||
| 632 | * -------------------------------------------------------------------- */ | ||
| 633 | |||
| 634 | #if defined(CONFIG_FB_ATMEL) || defined(CONFIG_FB_ATMEL_MODULE) | ||
| 635 | static u64 lcdc_dmamask = 0xffffffffUL; | ||
| 636 | static struct atmel_lcdfb_info lcdc_data; | ||
| 637 | |||
| 638 | static struct resource lcdc_resources[] = { | ||
| 639 | [0] = { | ||
| 640 | .start = AT91SAM9263_LCDC_BASE, | ||
| 641 | .end = AT91SAM9263_LCDC_BASE + SZ_4K - 1, | ||
| 642 | .flags = IORESOURCE_MEM, | ||
| 643 | }, | ||
| 644 | [1] = { | ||
| 645 | .start = AT91SAM9263_ID_LCDC, | ||
| 646 | .end = AT91SAM9263_ID_LCDC, | ||
| 647 | .flags = IORESOURCE_IRQ, | ||
| 648 | }, | ||
| 649 | }; | ||
| 650 | |||
| 651 | static struct platform_device at91_lcdc_device = { | ||
| 652 | .name = "atmel_lcdfb", | ||
| 653 | .id = 0, | ||
| 654 | .dev = { | ||
| 655 | .dma_mask = &lcdc_dmamask, | ||
| 656 | .coherent_dma_mask = 0xffffffff, | ||
| 657 | .platform_data = &lcdc_data, | ||
| 658 | }, | ||
| 659 | .resource = lcdc_resources, | ||
| 660 | .num_resources = ARRAY_SIZE(lcdc_resources), | ||
| 661 | }; | ||
| 662 | |||
| 663 | void __init at91_add_device_lcdc(struct atmel_lcdfb_info *data) | ||
| 664 | { | ||
| 665 | if (!data) | ||
| 666 | return; | ||
| 667 | |||
| 668 | at91_set_A_periph(AT91_PIN_PC1, 0); /* LCDHSYNC */ | ||
| 669 | at91_set_A_periph(AT91_PIN_PC2, 0); /* LCDDOTCK */ | ||
| 670 | at91_set_A_periph(AT91_PIN_PC3, 0); /* LCDDEN */ | ||
| 671 | at91_set_B_periph(AT91_PIN_PB9, 0); /* LCDCC */ | ||
| 672 | at91_set_A_periph(AT91_PIN_PC6, 0); /* LCDD2 */ | ||
| 673 | at91_set_A_periph(AT91_PIN_PC7, 0); /* LCDD3 */ | ||
| 674 | at91_set_A_periph(AT91_PIN_PC8, 0); /* LCDD4 */ | ||
| 675 | at91_set_A_periph(AT91_PIN_PC9, 0); /* LCDD5 */ | ||
| 676 | at91_set_A_periph(AT91_PIN_PC10, 0); /* LCDD6 */ | ||
| 677 | at91_set_A_periph(AT91_PIN_PC11, 0); /* LCDD7 */ | ||
| 678 | at91_set_A_periph(AT91_PIN_PC14, 0); /* LCDD10 */ | ||
| 679 | at91_set_A_periph(AT91_PIN_PC15, 0); /* LCDD11 */ | ||
| 680 | at91_set_A_periph(AT91_PIN_PC16, 0); /* LCDD12 */ | ||
| 681 | at91_set_B_periph(AT91_PIN_PC12, 0); /* LCDD13 */ | ||
| 682 | at91_set_A_periph(AT91_PIN_PC18, 0); /* LCDD14 */ | ||
| 683 | at91_set_A_periph(AT91_PIN_PC19, 0); /* LCDD15 */ | ||
| 684 | at91_set_A_periph(AT91_PIN_PC22, 0); /* LCDD18 */ | ||
| 685 | at91_set_A_periph(AT91_PIN_PC23, 0); /* LCDD19 */ | ||
| 686 | at91_set_A_periph(AT91_PIN_PC24, 0); /* LCDD20 */ | ||
| 687 | at91_set_B_periph(AT91_PIN_PC17, 0); /* LCDD21 */ | ||
| 688 | at91_set_A_periph(AT91_PIN_PC26, 0); /* LCDD22 */ | ||
| 689 | at91_set_A_periph(AT91_PIN_PC27, 0); /* LCDD23 */ | ||
| 690 | |||
| 691 | lcdc_data = *data; | ||
| 692 | platform_device_register(&at91_lcdc_device); | ||
| 693 | } | ||
| 694 | #else | ||
| 695 | void __init at91_add_device_lcdc(struct atmel_lcdfb_info *data) {} | ||
| 696 | #endif | ||
| 697 | |||
| 698 | |||
| 699 | /* -------------------------------------------------------------------- | ||
| 576 | * LEDs | 700 | * LEDs | 
| 577 | * -------------------------------------------------------------------- */ | 701 | * -------------------------------------------------------------------- */ | 
| 578 | 702 | ||
| diff --git a/arch/arm/mach-at91/board-picotux200.c b/arch/arm/mach-at91/board-picotux200.c new file mode 100644 index 000000000000..49cfe7ab4a85 --- /dev/null +++ b/arch/arm/mach-at91/board-picotux200.c | |||
| @@ -0,0 +1,166 @@ | |||
| 1 | /* | ||
| 2 | * linux/arch/arm/mach-at91/board-picotux200.c | ||
| 3 | * | ||
| 4 | * Copyright (C) 2005 SAN People | ||
| 5 | * Copyright (C) 2007 Kleinhenz Elektronik GmbH | ||
| 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 | * This program is distributed in the hope that it will be useful, | ||
| 13 | * but WITHOUT ANY WARRANTY; without even the implied warranty of | ||
| 14 | * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the | ||
| 15 | * GNU General Public License for more details. | ||
| 16 | * | ||
| 17 | * You should have received a copy of the GNU General Public License | ||
| 18 | * along with this program; if not, write to the Free Software | ||
| 19 | * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA | ||
| 20 | */ | ||
| 21 | |||
| 22 | #include <linux/types.h> | ||
| 23 | #include <linux/init.h> | ||
| 24 | #include <linux/mm.h> | ||
| 25 | #include <linux/module.h> | ||
| 26 | #include <linux/platform_device.h> | ||
| 27 | #include <linux/spi/spi.h> | ||
| 28 | #include <linux/mtd/physmap.h> | ||
| 29 | |||
| 30 | #include <asm/hardware.h> | ||
| 31 | #include <asm/setup.h> | ||
| 32 | #include <asm/mach-types.h> | ||
| 33 | #include <asm/irq.h> | ||
| 34 | |||
| 35 | #include <asm/mach/arch.h> | ||
| 36 | #include <asm/mach/map.h> | ||
| 37 | #include <asm/mach/irq.h> | ||
| 38 | |||
| 39 | #include <asm/arch/board.h> | ||
| 40 | #include <asm/arch/gpio.h> | ||
| 41 | #include <asm/arch/at91rm9200_mc.h> | ||
| 42 | |||
| 43 | #include "generic.h" | ||
| 44 | |||
| 45 | |||
| 46 | /* | ||
| 47 | * Serial port configuration. | ||
| 48 | * 0 .. 3 = USART0 .. USART3 | ||
| 49 | * 4 = DBGU | ||
| 50 | */ | ||
| 51 | static struct at91_uart_config __initdata picotux200_uart_config = { | ||
| 52 | .console_tty = 0, /* ttyS0 */ | ||
| 53 | .nr_tty = 2, | ||
| 54 | .tty_map = { 4, 1, -1, -1, -1 } /* ttyS0, ..., ttyS4 */ | ||
| 55 | }; | ||
| 56 | |||
| 57 | static void __init picotux200_map_io(void) | ||
| 58 | { | ||
| 59 | /* Initialize processor: 18.432 MHz crystal */ | ||
| 60 | at91rm9200_initialize(18432000, AT91RM9200_BGA); | ||
| 61 | |||
| 62 | /* Setup the serial ports and console */ | ||
| 63 | at91_init_serial(&picotux200_uart_config); | ||
| 64 | } | ||
| 65 | |||
| 66 | static void __init picotux200_init_irq(void) | ||
| 67 | { | ||
| 68 | at91rm9200_init_interrupts(NULL); | ||
| 69 | } | ||
| 70 | |||
| 71 | static struct at91_eth_data __initdata picotux200_eth_data = { | ||
| 72 | .phy_irq_pin = AT91_PIN_PC4, | ||
| 73 | .is_rmii = 1, | ||
| 74 | }; | ||
| 75 | |||
| 76 | static struct at91_usbh_data __initdata picotux200_usbh_data = { | ||
| 77 | .ports = 1, | ||
| 78 | }; | ||
| 79 | |||
| 80 | // static struct at91_udc_data __initdata picotux200_udc_data = { | ||
| 81 | // .vbus_pin = AT91_PIN_PD4, | ||
| 82 | // .pullup_pin = AT91_PIN_PD5, | ||
| 83 | // }; | ||
| 84 | |||
| 85 | static struct at91_mmc_data __initdata picotux200_mmc_data = { | ||
| 86 | .det_pin = AT91_PIN_PB27, | ||
| 87 | .slot_b = 0, | ||
| 88 | .wire4 = 1, | ||
| 89 | .wp_pin = AT91_PIN_PA17, | ||
| 90 | }; | ||
| 91 | |||
| 92 | // static struct spi_board_info picotux200_spi_devices[] = { | ||
| 93 | // { /* DataFlash chip */ | ||
| 94 | // .modalias = "mtd_dataflash", | ||
| 95 | // .chip_select = 0, | ||
| 96 | // .max_speed_hz = 15 * 1000 * 1000, | ||
| 97 | // }, | ||
| 98 | // #ifdef CONFIG_MTD_AT91_DATAFLASH_CARD | ||
| 99 | // { /* DataFlash card */ | ||
| 100 | // .modalias = "mtd_dataflash", | ||
| 101 | // .chip_select = 3, | ||
| 102 | // .max_speed_hz = 15 * 1000 * 1000, | ||
| 103 | // }, | ||
| 104 | // #endif | ||
| 105 | // }; | ||
| 106 | |||
| 107 | #define PICOTUX200_FLASH_BASE AT91_CHIPSELECT_0 | ||
| 108 | #define PICOTUX200_FLASH_SIZE 0x400000 | ||
| 109 | |||
| 110 | static struct physmap_flash_data picotux200_flash_data = { | ||
| 111 | .width = 2, | ||
| 112 | }; | ||
| 113 | |||
| 114 | static struct resource picotux200_flash_resource = { | ||
| 115 | .start = PICOTUX200_FLASH_BASE, | ||
| 116 | .end = PICOTUX200_FLASH_BASE + PICOTUX200_FLASH_SIZE - 1, | ||
| 117 | .flags = IORESOURCE_MEM, | ||
| 118 | }; | ||
| 119 | |||
| 120 | static struct platform_device picotux200_flash = { | ||
| 121 | .name = "physmap-flash", | ||
| 122 | .id = 0, | ||
| 123 | .dev = { | ||
| 124 | .platform_data = &picotux200_flash_data, | ||
| 125 | }, | ||
| 126 | .resource = &picotux200_flash_resource, | ||
| 127 | .num_resources = 1, | ||
| 128 | }; | ||
| 129 | |||
| 130 | static void __init picotux200_board_init(void) | ||
| 131 | { | ||
| 132 | /* Serial */ | ||
| 133 | at91_add_device_serial(); | ||
| 134 | /* Ethernet */ | ||
| 135 | at91_add_device_eth(&picotux200_eth_data); | ||
| 136 | /* USB Host */ | ||
| 137 | at91_add_device_usbh(&picotux200_usbh_data); | ||
| 138 | /* USB Device */ | ||
| 139 | // at91_add_device_udc(&picotux200_udc_data); | ||
| 140 | // at91_set_multi_drive(picotux200_udc_data.pullup_pin, 1); /* pullup_pin is connected to reset */ | ||
| 141 | /* I2C */ | ||
| 142 | at91_add_device_i2c(); | ||
| 143 | /* SPI */ | ||
| 144 | // at91_add_device_spi(picotux200_spi_devices, ARRAY_SIZE(picotux200_spi_devices)); | ||
| 145 | #ifdef CONFIG_MTD_AT91_DATAFLASH_CARD | ||
| 146 | /* DataFlash card */ | ||
| 147 | at91_set_gpio_output(AT91_PIN_PB22, 0); | ||
| 148 | #else | ||
| 149 | /* MMC */ | ||
| 150 | at91_set_gpio_output(AT91_PIN_PB22, 1); /* this MMC card slot can optionally use SPI signaling (CS3). */ | ||
| 151 | at91_add_device_mmc(0, &picotux200_mmc_data); | ||
| 152 | #endif | ||
| 153 | /* NOR Flash */ | ||
| 154 | platform_device_register(&picotux200_flash); | ||
| 155 | } | ||
| 156 | |||
| 157 | MACHINE_START(PICOTUX2XX, "picotux 200") | ||
| 158 | /* Maintainer: Kleinhenz Elektronik GmbH */ | ||
| 159 | .phys_io = AT91_BASE_SYS, | ||
| 160 | .io_pg_offst = (AT91_VA_BASE_SYS >> 18) & 0xfffc, | ||
| 161 | .boot_params = AT91_SDRAM_BASE + 0x100, | ||
| 162 | .timer = &at91rm9200_timer, | ||
| 163 | .map_io = picotux200_map_io, | ||
| 164 | .init_irq = picotux200_init_irq, | ||
| 165 | .init_machine = picotux200_board_init, | ||
| 166 | MACHINE_END | ||
| diff --git a/arch/arm/mach-at91/board-sam9260ek.c b/arch/arm/mach-at91/board-sam9260ek.c index 57fb4499d969..65fa532bb4ac 100644 --- a/arch/arm/mach-at91/board-sam9260ek.c +++ b/arch/arm/mach-at91/board-sam9260ek.c | |||
| @@ -104,9 +104,9 @@ static struct spi_board_info ek_spi_devices[] = { | |||
| 104 | }, | 104 | }, | 
| 105 | #endif | 105 | #endif | 
| 106 | #endif | 106 | #endif | 
| 107 | #if defined(CONFIG_SND_AT73C213) | 107 | #if defined(CONFIG_SND_AT73C213) || defined(CONFIG_SND_AT73C213_MODULE) | 
| 108 | { /* AT73C213 DAC */ | 108 | { /* AT73C213 DAC */ | 
| 109 | .modalias = "snd_at73c213", | 109 | .modalias = "at73c213", | 
| 110 | .chip_select = 0, | 110 | .chip_select = 0, | 
| 111 | .max_speed_hz = 10 * 1000 * 1000, | 111 | .max_speed_hz = 10 * 1000 * 1000, | 
| 112 | .bus_num = 1, | 112 | .bus_num = 1, | 
| @@ -118,7 +118,7 @@ static struct spi_board_info ek_spi_devices[] = { | |||
| 118 | /* | 118 | /* | 
| 119 | * MACB Ethernet device | 119 | * MACB Ethernet device | 
| 120 | */ | 120 | */ | 
| 121 | static struct __initdata at91_eth_data ek_macb_data = { | 121 | static struct at91_eth_data __initdata ek_macb_data = { | 
| 122 | .phy_irq_pin = AT91_PIN_PA7, | 122 | .phy_irq_pin = AT91_PIN_PA7, | 
| 123 | .is_rmii = 1, | 123 | .is_rmii = 1, | 
| 124 | }; | 124 | }; | 
| @@ -140,7 +140,7 @@ static struct mtd_partition __initdata ek_nand_partition[] = { | |||
| 140 | }, | 140 | }, | 
| 141 | }; | 141 | }; | 
| 142 | 142 | ||
| 143 | static struct mtd_partition *nand_partitions(int size, int *num_partitions) | 143 | static struct mtd_partition * __init nand_partitions(int size, int *num_partitions) | 
| 144 | { | 144 | { | 
| 145 | *num_partitions = ARRAY_SIZE(ek_nand_partition); | 145 | *num_partitions = ARRAY_SIZE(ek_nand_partition); | 
| 146 | return ek_nand_partition; | 146 | return ek_nand_partition; | 
| @@ -188,6 +188,8 @@ static void __init ek_board_init(void) | |||
| 188 | at91_add_device_eth(&ek_macb_data); | 188 | at91_add_device_eth(&ek_macb_data); | 
| 189 | /* MMC */ | 189 | /* MMC */ | 
| 190 | at91_add_device_mmc(0, &ek_mmc_data); | 190 | at91_add_device_mmc(0, &ek_mmc_data); | 
| 191 | /* I2C */ | ||
| 192 | at91_add_device_i2c(); | ||
| 191 | } | 193 | } | 
| 192 | 194 | ||
| 193 | MACHINE_START(AT91SAM9260EK, "Atmel AT91SAM9260-EK") | 195 | MACHINE_START(AT91SAM9260EK, "Atmel AT91SAM9260-EK") | 
| diff --git a/arch/arm/mach-at91/board-sam9261ek.c b/arch/arm/mach-at91/board-sam9261ek.c index b7e772467cf6..bcf71536cc6d 100644 --- a/arch/arm/mach-at91/board-sam9261ek.c +++ b/arch/arm/mach-at91/board-sam9261ek.c | |||
| @@ -25,6 +25,7 @@ | |||
| 25 | #include <linux/module.h> | 25 | #include <linux/module.h> | 
| 26 | #include <linux/platform_device.h> | 26 | #include <linux/platform_device.h> | 
| 27 | #include <linux/spi/spi.h> | 27 | #include <linux/spi/spi.h> | 
| 28 | #include <linux/spi/ads7846.h> | ||
| 28 | #include <linux/dm9000.h> | 29 | #include <linux/dm9000.h> | 
| 29 | 30 | ||
| 30 | #include <asm/hardware.h> | 31 | #include <asm/hardware.h> | 
| @@ -195,6 +196,41 @@ static struct at91_nand_data __initdata ek_nand_data = { | |||
| 195 | }; | 196 | }; | 
| 196 | 197 | ||
| 197 | /* | 198 | /* | 
| 199 | * ADS7846 Touchscreen | ||
| 200 | */ | ||
| 201 | #if defined(CONFIG_TOUCHSCREEN_ADS7846) || defined(CONFIG_TOUCHSCREEN_ADS7846_MODULE) | ||
| 202 | |||
| 203 | static int ads7843_pendown_state(void) | ||
| 204 | { | ||
| 205 | return !at91_get_gpio_value(AT91_PIN_PC2); /* Touchscreen PENIRQ */ | ||
| 206 | } | ||
| 207 | |||
| 208 | static struct ads7846_platform_data ads_info = { | ||
| 209 | .model = 7843, | ||
| 210 | .x_min = 150, | ||
| 211 | .x_max = 3830, | ||
| 212 | .y_min = 190, | ||
| 213 | .y_max = 3830, | ||
| 214 | .vref_delay_usecs = 100, | ||
| 215 | .x_plate_ohms = 450, | ||
| 216 | .y_plate_ohms = 250, | ||
| 217 | .pressure_max = 15000, | ||
| 218 | .debounce_max = 1, | ||
| 219 | .debounce_rep = 0, | ||
| 220 | .debounce_tol = (~0), | ||
| 221 | .get_pendown_state = ads7843_pendown_state, | ||
| 222 | }; | ||
| 223 | |||
| 224 | static void __init ek_add_device_ts(void) | ||
| 225 | { | ||
| 226 | at91_set_B_periph(AT91_PIN_PC2, 1); /* External IRQ0, with pullup */ | ||
| 227 | at91_set_gpio_input(AT91_PIN_PA11, 1); /* Touchscreen BUSY signal */ | ||
| 228 | } | ||
| 229 | #else | ||
| 230 | static void __init ek_add_device_ts(void) {} | ||
| 231 | #endif | ||
| 232 | |||
| 233 | /* | ||
| 198 | * SPI devices | 234 | * SPI devices | 
| 199 | */ | 235 | */ | 
| 200 | static struct spi_board_info ek_spi_devices[] = { | 236 | static struct spi_board_info ek_spi_devices[] = { | 
| @@ -204,6 +240,16 @@ static struct spi_board_info ek_spi_devices[] = { | |||
| 204 | .max_speed_hz = 15 * 1000 * 1000, | 240 | .max_speed_hz = 15 * 1000 * 1000, | 
| 205 | .bus_num = 0, | 241 | .bus_num = 0, | 
| 206 | }, | 242 | }, | 
| 243 | #if defined(CONFIG_TOUCHSCREEN_ADS7846) || defined(CONFIG_TOUCHSCREEN_ADS7846_MODULE) | ||
| 244 | { | ||
| 245 | .modalias = "ads7846", | ||
| 246 | .chip_select = 2, | ||
| 247 | .max_speed_hz = 125000 * 26, /* (max sample rate @ 3V) * (cmd + data + overhead) */ | ||
| 248 | .bus_num = 0, | ||
| 249 | .platform_data = &ads_info, | ||
| 250 | .irq = AT91SAM9261_ID_IRQ0, | ||
| 251 | }, | ||
| 252 | #endif | ||
| 207 | #if defined(CONFIG_MTD_AT91_DATAFLASH_CARD) | 253 | #if defined(CONFIG_MTD_AT91_DATAFLASH_CARD) | 
| 208 | { /* DataFlash card - jumper (J12) configurable to CS3 or CS0 */ | 254 | { /* DataFlash card - jumper (J12) configurable to CS3 or CS0 */ | 
| 209 | .modalias = "mtd_dataflash", | 255 | .modalias = "mtd_dataflash", | 
| @@ -211,9 +257,9 @@ static struct spi_board_info ek_spi_devices[] = { | |||
| 211 | .max_speed_hz = 15 * 1000 * 1000, | 257 | .max_speed_hz = 15 * 1000 * 1000, | 
| 212 | .bus_num = 0, | 258 | .bus_num = 0, | 
| 213 | }, | 259 | }, | 
| 214 | #elif defined(CONFIG_SND_AT73C213) | 260 | #elif defined(CONFIG_SND_AT73C213) || defined(CONFIG_SND_AT73C213_MODULE) | 
| 215 | { /* AT73C213 DAC */ | 261 | { /* AT73C213 DAC */ | 
| 216 | .modalias = "snd_at73c213", | 262 | .modalias = "at73c213", | 
| 217 | .chip_select = 3, | 263 | .chip_select = 3, | 
| 218 | .max_speed_hz = 10 * 1000 * 1000, | 264 | .max_speed_hz = 10 * 1000 * 1000, | 
| 219 | .bus_num = 0, | 265 | .bus_num = 0, | 
| @@ -241,6 +287,8 @@ static void __init ek_board_init(void) | |||
| 241 | #if defined(CONFIG_SPI_ATMEL) || defined(CONFIG_SPI_ATMEL_MODULE) | 287 | #if defined(CONFIG_SPI_ATMEL) || defined(CONFIG_SPI_ATMEL_MODULE) | 
| 242 | /* SPI */ | 288 | /* SPI */ | 
| 243 | at91_add_device_spi(ek_spi_devices, ARRAY_SIZE(ek_spi_devices)); | 289 | at91_add_device_spi(ek_spi_devices, ARRAY_SIZE(ek_spi_devices)); | 
| 290 | /* Touchscreen */ | ||
| 291 | ek_add_device_ts(); | ||
| 244 | #else | 292 | #else | 
| 245 | /* MMC */ | 293 | /* MMC */ | 
| 246 | at91_add_device_mmc(0, &ek_mmc_data); | 294 | at91_add_device_mmc(0, &ek_mmc_data); | 
| diff --git a/arch/arm/mach-at91/board-sam9263ek.c b/arch/arm/mach-at91/board-sam9263ek.c index 8fdce11a880c..f57458559fb6 100644 --- a/arch/arm/mach-at91/board-sam9263ek.c +++ b/arch/arm/mach-at91/board-sam9263ek.c | |||
| @@ -25,6 +25,7 @@ | |||
| 25 | #include <linux/module.h> | 25 | #include <linux/module.h> | 
| 26 | #include <linux/platform_device.h> | 26 | #include <linux/platform_device.h> | 
| 27 | #include <linux/spi/spi.h> | 27 | #include <linux/spi/spi.h> | 
| 28 | #include <linux/spi/ads7846.h> | ||
| 28 | 29 | ||
| 29 | #include <asm/hardware.h> | 30 | #include <asm/hardware.h> | 
| 30 | #include <asm/setup.h> | 31 | #include <asm/setup.h> | 
| @@ -86,6 +87,40 @@ static struct at91_udc_data __initdata ek_udc_data = { | |||
| 86 | 87 | ||
| 87 | 88 | ||
| 88 | /* | 89 | /* | 
| 90 | * ADS7846 Touchscreen | ||
| 91 | */ | ||
| 92 | #if defined(CONFIG_TOUCHSCREEN_ADS7846) || defined(CONFIG_TOUCHSCREEN_ADS7846_MODULE) | ||
| 93 | static int ads7843_pendown_state(void) | ||
| 94 | { | ||
| 95 | return !at91_get_gpio_value(AT91_PIN_PA15); /* Touchscreen PENIRQ */ | ||
| 96 | } | ||
| 97 | |||
| 98 | static struct ads7846_platform_data ads_info = { | ||
| 99 | .model = 7843, | ||
| 100 | .x_min = 150, | ||
| 101 | .x_max = 3830, | ||
| 102 | .y_min = 190, | ||
| 103 | .y_max = 3830, | ||
| 104 | .vref_delay_usecs = 100, | ||
| 105 | .x_plate_ohms = 450, | ||
| 106 | .y_plate_ohms = 250, | ||
| 107 | .pressure_max = 15000, | ||
| 108 | .debounce_max = 1, | ||
| 109 | .debounce_rep = 0, | ||
| 110 | .debounce_tol = (~0), | ||
| 111 | .get_pendown_state = ads7843_pendown_state, | ||
| 112 | }; | ||
| 113 | |||
| 114 | static void __init ek_add_device_ts(void) | ||
| 115 | { | ||
| 116 | at91_set_B_periph(AT91_PIN_PA15, 1); /* External IRQ1, with pullup */ | ||
| 117 | at91_set_gpio_input(AT91_PIN_PA31, 1); /* Touchscreen BUSY signal */ | ||
| 118 | } | ||
| 119 | #else | ||
| 120 | static void __init ek_add_device_ts(void) {} | ||
| 121 | #endif | ||
| 122 | |||
| 123 | /* | ||
| 89 | * SPI devices. | 124 | * SPI devices. | 
| 90 | */ | 125 | */ | 
| 91 | static struct spi_board_info ek_spi_devices[] = { | 126 | static struct spi_board_info ek_spi_devices[] = { | 
| @@ -97,6 +132,16 @@ static struct spi_board_info ek_spi_devices[] = { | |||
| 97 | .bus_num = 0, | 132 | .bus_num = 0, | 
| 98 | }, | 133 | }, | 
| 99 | #endif | 134 | #endif | 
| 135 | #if defined(CONFIG_TOUCHSCREEN_ADS7846) || defined(CONFIG_TOUCHSCREEN_ADS7846_MODULE) | ||
| 136 | { | ||
| 137 | .modalias = "ads7846", | ||
| 138 | .chip_select = 3, | ||
| 139 | .max_speed_hz = 125000 * 26, /* (max sample rate @ 3V) * (cmd + data + overhead) */ | ||
| 140 | .bus_num = 0, | ||
| 141 | .platform_data = &ads_info, | ||
| 142 | .irq = AT91SAM9263_ID_IRQ1, | ||
| 143 | }, | ||
| 144 | #endif | ||
| 100 | }; | 145 | }; | 
| 101 | 146 | ||
| 102 | 147 | ||
| @@ -112,6 +157,14 @@ static struct at91_mmc_data __initdata ek_mmc_data = { | |||
| 112 | 157 | ||
| 113 | 158 | ||
| 114 | /* | 159 | /* | 
| 160 | * MACB Ethernet device | ||
| 161 | */ | ||
| 162 | static struct at91_eth_data __initdata ek_macb_data = { | ||
| 163 | .is_rmii = 1, | ||
| 164 | }; | ||
| 165 | |||
| 166 | |||
| 167 | /* | ||
| 115 | * NAND flash | 168 | * NAND flash | 
| 116 | */ | 169 | */ | 
| 117 | static struct mtd_partition __initdata ek_nand_partition[] = { | 170 | static struct mtd_partition __initdata ek_nand_partition[] = { | 
| @@ -148,6 +201,14 @@ static struct at91_nand_data __initdata ek_nand_data = { | |||
| 148 | }; | 201 | }; | 
| 149 | 202 | ||
| 150 | 203 | ||
| 204 | /* | ||
| 205 | * AC97 | ||
| 206 | */ | ||
| 207 | static struct atmel_ac97_data ek_ac97_data = { | ||
| 208 | .reset_pin = AT91_PIN_PA13, | ||
| 209 | }; | ||
| 210 | |||
| 211 | |||
| 151 | static void __init ek_board_init(void) | 212 | static void __init ek_board_init(void) | 
| 152 | { | 213 | { | 
| 153 | /* Serial */ | 214 | /* Serial */ | 
| @@ -157,11 +218,20 @@ static void __init ek_board_init(void) | |||
| 157 | /* USB Device */ | 218 | /* USB Device */ | 
| 158 | at91_add_device_udc(&ek_udc_data); | 219 | at91_add_device_udc(&ek_udc_data); | 
| 159 | /* SPI */ | 220 | /* SPI */ | 
| 221 | at91_set_gpio_output(AT91_PIN_PE20, 1); /* select spi0 clock */ | ||
| 160 | at91_add_device_spi(ek_spi_devices, ARRAY_SIZE(ek_spi_devices)); | 222 | at91_add_device_spi(ek_spi_devices, ARRAY_SIZE(ek_spi_devices)); | 
| 223 | /* Touchscreen */ | ||
| 224 | ek_add_device_ts(); | ||
| 161 | /* MMC */ | 225 | /* MMC */ | 
| 162 | at91_add_device_mmc(1, &ek_mmc_data); | 226 | at91_add_device_mmc(1, &ek_mmc_data); | 
| 227 | /* Ethernet */ | ||
| 228 | at91_add_device_eth(&ek_macb_data); | ||
| 163 | /* NAND */ | 229 | /* NAND */ | 
| 164 | at91_add_device_nand(&ek_nand_data); | 230 | at91_add_device_nand(&ek_nand_data); | 
| 231 | /* I2C */ | ||
| 232 | at91_add_device_i2c(); | ||
| 233 | /* AC97 */ | ||
| 234 | at91_add_device_ac97(&ek_ac97_data); | ||
| 165 | } | 235 | } | 
| 166 | 236 | ||
| 167 | MACHINE_START(AT91SAM9263EK, "Atmel AT91SAM9263-EK") | 237 | MACHINE_START(AT91SAM9263EK, "Atmel AT91SAM9263-EK") | 
| diff --git a/arch/arm/mach-ep93xx/clock.c b/arch/arm/mach-ep93xx/clock.c index f174d1a3b11c..9d7515c36bff 100644 --- a/arch/arm/mach-ep93xx/clock.c +++ b/arch/arm/mach-ep93xx/clock.c | |||
| @@ -27,6 +27,10 @@ struct clk { | |||
| 27 | u32 enable_mask; | 27 | u32 enable_mask; | 
| 28 | }; | 28 | }; | 
| 29 | 29 | ||
| 30 | static struct clk clk_uart = { | ||
| 31 | .name = "UARTCLK", | ||
| 32 | .rate = 14745600, | ||
| 33 | }; | ||
| 30 | static struct clk clk_pll1 = { | 34 | static struct clk clk_pll1 = { | 
| 31 | .name = "pll1", | 35 | .name = "pll1", | 
| 32 | }; | 36 | }; | 
| @@ -50,6 +54,7 @@ static struct clk clk_usb_host = { | |||
| 50 | 54 | ||
| 51 | 55 | ||
| 52 | static struct clk *clocks[] = { | 56 | static struct clk *clocks[] = { | 
| 57 | &clk_uart, | ||
| 53 | &clk_pll1, | 58 | &clk_pll1, | 
| 54 | &clk_f, | 59 | &clk_f, | 
| 55 | &clk_h, | 60 | &clk_h, | 
| diff --git a/arch/arm/mach-iop13xx/Makefile b/arch/arm/mach-iop13xx/Makefile index 4185e0586c33..da1609dc0dee 100644 --- a/arch/arm/mach-iop13xx/Makefile +++ b/arch/arm/mach-iop13xx/Makefile | |||
| @@ -7,5 +7,6 @@ obj-$(CONFIG_ARCH_IOP13XX) += setup.o | |||
| 7 | obj-$(CONFIG_ARCH_IOP13XX) += irq.o | 7 | obj-$(CONFIG_ARCH_IOP13XX) += irq.o | 
| 8 | obj-$(CONFIG_ARCH_IOP13XX) += pci.o | 8 | obj-$(CONFIG_ARCH_IOP13XX) += pci.o | 
| 9 | obj-$(CONFIG_ARCH_IOP13XX) += io.o | 9 | obj-$(CONFIG_ARCH_IOP13XX) += io.o | 
| 10 | obj-$(CONFIG_ARCH_IOP13XX) += tpmi.o | ||
| 10 | obj-$(CONFIG_MACH_IQ81340SC) += iq81340sc.o | 11 | obj-$(CONFIG_MACH_IQ81340SC) += iq81340sc.o | 
| 11 | obj-$(CONFIG_MACH_IQ81340MC) += iq81340mc.o | 12 | obj-$(CONFIG_MACH_IQ81340MC) += iq81340mc.o | 
| diff --git a/arch/arm/mach-iop13xx/iq81340mc.c b/arch/arm/mach-iop13xx/iq81340mc.c index a519d707571c..268a8d84999c 100644 --- a/arch/arm/mach-iop13xx/iq81340mc.c +++ b/arch/arm/mach-iop13xx/iq81340mc.c | |||
| @@ -75,11 +75,14 @@ static void __init iq81340mc_init(void) | |||
| 75 | { | 75 | { | 
| 76 | iop13xx_platform_init(); | 76 | iop13xx_platform_init(); | 
| 77 | iq81340mc_pci_init(); | 77 | iq81340mc_pci_init(); | 
| 78 | iop13xx_add_tpmi_devices(); | ||
| 78 | } | 79 | } | 
| 79 | 80 | ||
| 80 | static void __init iq81340mc_timer_init(void) | 81 | static void __init iq81340mc_timer_init(void) | 
| 81 | { | 82 | { | 
| 82 | iop_init_time(400000000); | 83 | unsigned long bus_freq = iop13xx_core_freq() / iop13xx_xsi_bus_ratio(); | 
| 84 | printk(KERN_DEBUG "%s: bus frequency: %lu\n", __FUNCTION__, bus_freq); | ||
| 85 | iop_init_time(bus_freq); | ||
| 83 | } | 86 | } | 
| 84 | 87 | ||
| 85 | static struct sys_timer iq81340mc_timer = { | 88 | static struct sys_timer iq81340mc_timer = { | 
| diff --git a/arch/arm/mach-iop13xx/iq81340sc.c b/arch/arm/mach-iop13xx/iq81340sc.c index 0e71fbcabe00..a51ffd2683e5 100644 --- a/arch/arm/mach-iop13xx/iq81340sc.c +++ b/arch/arm/mach-iop13xx/iq81340sc.c | |||
| @@ -77,11 +77,14 @@ static void __init iq81340sc_init(void) | |||
| 77 | { | 77 | { | 
| 78 | iop13xx_platform_init(); | 78 | iop13xx_platform_init(); | 
| 79 | iq81340sc_pci_init(); | 79 | iq81340sc_pci_init(); | 
| 80 | iop13xx_add_tpmi_devices(); | ||
| 80 | } | 81 | } | 
| 81 | 82 | ||
| 82 | static void __init iq81340sc_timer_init(void) | 83 | static void __init iq81340sc_timer_init(void) | 
| 83 | { | 84 | { | 
| 84 | iop_init_time(400000000); | 85 | unsigned long bus_freq = iop13xx_core_freq() / iop13xx_xsi_bus_ratio(); | 
| 86 | printk(KERN_DEBUG "%s: bus frequency: %lu\n", __FUNCTION__, bus_freq); | ||
| 87 | iop_init_time(bus_freq); | ||
| 85 | } | 88 | } | 
| 86 | 89 | ||
| 87 | static struct sys_timer iq81340sc_timer = { | 90 | static struct sys_timer iq81340sc_timer = { | 
| diff --git a/arch/arm/mach-iop13xx/pci.c b/arch/arm/mach-iop13xx/pci.c index d85b88fcb7e8..d1d0d32ca77c 100644 --- a/arch/arm/mach-iop13xx/pci.c +++ b/arch/arm/mach-iop13xx/pci.c | |||
| @@ -1023,7 +1023,7 @@ int iop13xx_pci_setup(int nr, struct pci_sys_data *sys) | |||
| 1023 | << IOP13XX_ATUX_PCIXSR_FUNC_NUM; | 1023 | << IOP13XX_ATUX_PCIXSR_FUNC_NUM; | 
| 1024 | __raw_writel(pcixsr, IOP13XX_ATUX_PCIXSR); | 1024 | __raw_writel(pcixsr, IOP13XX_ATUX_PCIXSR); | 
| 1025 | 1025 | ||
| 1026 | res[0].start = IOP13XX_PCIX_LOWER_IO_PA; | 1026 | res[0].start = IOP13XX_PCIX_LOWER_IO_PA + IOP13XX_PCIX_IO_BUS_OFFSET; | 
| 1027 | res[0].end = IOP13XX_PCIX_UPPER_IO_PA; | 1027 | res[0].end = IOP13XX_PCIX_UPPER_IO_PA; | 
| 1028 | res[0].name = "IQ81340 ATUX PCI I/O Space"; | 1028 | res[0].name = "IQ81340 ATUX PCI I/O Space"; | 
| 1029 | res[0].flags = IORESOURCE_IO; | 1029 | res[0].flags = IORESOURCE_IO; | 
| @@ -1033,7 +1033,7 @@ int iop13xx_pci_setup(int nr, struct pci_sys_data *sys) | |||
| 1033 | res[1].name = "IQ81340 ATUX PCI Memory Space"; | 1033 | res[1].name = "IQ81340 ATUX PCI Memory Space"; | 
| 1034 | res[1].flags = IORESOURCE_MEM; | 1034 | res[1].flags = IORESOURCE_MEM; | 
| 1035 | sys->mem_offset = IOP13XX_PCIX_MEM_OFFSET; | 1035 | sys->mem_offset = IOP13XX_PCIX_MEM_OFFSET; | 
| 1036 | sys->io_offset = IOP13XX_PCIX_IO_OFFSET; | 1036 | sys->io_offset = IOP13XX_PCIX_LOWER_IO_PA; | 
| 1037 | break; | 1037 | break; | 
| 1038 | case IOP13XX_INIT_ATU_ATUE: | 1038 | case IOP13XX_INIT_ATU_ATUE: | 
| 1039 | /* Note: the function number field in the PCSR is ro */ | 1039 | /* Note: the function number field in the PCSR is ro */ | 
| @@ -1044,7 +1044,7 @@ int iop13xx_pci_setup(int nr, struct pci_sys_data *sys) | |||
| 1044 | 1044 | ||
| 1045 | __raw_writel(pcsr, IOP13XX_ATUE_PCSR); | 1045 | __raw_writel(pcsr, IOP13XX_ATUE_PCSR); | 
| 1046 | 1046 | ||
| 1047 | res[0].start = IOP13XX_PCIE_LOWER_IO_PA; | 1047 | res[0].start = IOP13XX_PCIE_LOWER_IO_PA + IOP13XX_PCIE_IO_BUS_OFFSET; | 
| 1048 | res[0].end = IOP13XX_PCIE_UPPER_IO_PA; | 1048 | res[0].end = IOP13XX_PCIE_UPPER_IO_PA; | 
| 1049 | res[0].name = "IQ81340 ATUE PCI I/O Space"; | 1049 | res[0].name = "IQ81340 ATUE PCI I/O Space"; | 
| 1050 | res[0].flags = IORESOURCE_IO; | 1050 | res[0].flags = IORESOURCE_IO; | 
| @@ -1054,7 +1054,7 @@ int iop13xx_pci_setup(int nr, struct pci_sys_data *sys) | |||
| 1054 | res[1].name = "IQ81340 ATUE PCI Memory Space"; | 1054 | res[1].name = "IQ81340 ATUE PCI Memory Space"; | 
| 1055 | res[1].flags = IORESOURCE_MEM; | 1055 | res[1].flags = IORESOURCE_MEM; | 
| 1056 | sys->mem_offset = IOP13XX_PCIE_MEM_OFFSET; | 1056 | sys->mem_offset = IOP13XX_PCIE_MEM_OFFSET; | 
| 1057 | sys->io_offset = IOP13XX_PCIE_IO_OFFSET; | 1057 | sys->io_offset = IOP13XX_PCIE_LOWER_IO_PA; | 
| 1058 | sys->map_irq = iop13xx_pcie_map_irq; | 1058 | sys->map_irq = iop13xx_pcie_map_irq; | 
| 1059 | break; | 1059 | break; | 
| 1060 | default: | 1060 | default: | 
| diff --git a/arch/arm/mach-iop13xx/setup.c b/arch/arm/mach-iop13xx/setup.c index 9a46bcd5f18e..bc4871553f6a 100644 --- a/arch/arm/mach-iop13xx/setup.c +++ b/arch/arm/mach-iop13xx/setup.c | |||
| @@ -258,15 +258,11 @@ void __init iop13xx_platform_init(void) | |||
| 258 | 258 | ||
| 259 | if (init_uart == IOP13XX_INIT_UART_DEFAULT) { | 259 | if (init_uart == IOP13XX_INIT_UART_DEFAULT) { | 
| 260 | switch (iop13xx_dev_id()) { | 260 | switch (iop13xx_dev_id()) { | 
| 261 | /* enable both uarts on iop341 and iop342 */ | 261 | /* enable both uarts on iop341 */ | 
| 262 | case 0x3380: | 262 | case 0x3380: | 
| 263 | case 0x3384: | 263 | case 0x3384: | 
| 264 | case 0x3388: | 264 | case 0x3388: | 
| 265 | case 0x338c: | 265 | case 0x338c: | 
| 266 | case 0x3382: | ||
| 267 | case 0x3386: | ||
| 268 | case 0x338a: | ||
| 269 | case 0x338e: | ||
| 270 | init_uart |= IOP13XX_INIT_UART_0; | 266 | init_uart |= IOP13XX_INIT_UART_0; | 
| 271 | init_uart |= IOP13XX_INIT_UART_1; | 267 | init_uart |= IOP13XX_INIT_UART_1; | 
| 272 | break; | 268 | break; | 
| diff --git a/arch/arm/mach-iop13xx/tpmi.c b/arch/arm/mach-iop13xx/tpmi.c new file mode 100644 index 000000000000..d3dc278213da --- /dev/null +++ b/arch/arm/mach-iop13xx/tpmi.c | |||
| @@ -0,0 +1,234 @@ | |||
| 1 | /* | ||
| 2 | * iop13xx tpmi device resources | ||
| 3 | * Copyright (c) 2005-2006, Intel Corporation. | ||
| 4 | * | ||
| 5 | * This program is free software; you can redistribute it and/or modify it | ||
| 6 | * under the terms and conditions of the GNU General Public License, | ||
| 7 | * version 2, as published by the Free Software Foundation. | ||
| 8 | * | ||
| 9 | * This program is distributed in the hope it will be useful, but WITHOUT | ||
| 10 | * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or | ||
| 11 | * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for | ||
| 12 | * more details. | ||
| 13 | * | ||
| 14 | * You should have received a copy of the GNU General Public License along with | ||
| 15 | * this program; if not, write to the Free Software Foundation, Inc., 59 Temple | ||
| 16 | * Place - Suite 330, Boston, MA 02111-1307 USA. | ||
| 17 | * | ||
| 18 | */ | ||
| 19 | |||
| 20 | #include <linux/kernel.h> | ||
| 21 | #include <linux/init.h> | ||
| 22 | #include <linux/platform_device.h> | ||
| 23 | #include <linux/dma-mapping.h> | ||
| 24 | #include <asm/io.h> | ||
| 25 | #include <asm/irq.h> | ||
| 26 | #include <asm/sizes.h> | ||
| 27 | |||
| 28 | /* assumes CONTROLLER_ONLY# is never asserted in the ESSR register */ | ||
| 29 | #define IOP13XX_TPMI_MMR(dev) IOP13XX_REG_ADDR32_PHYS(0x48000 + (dev << 12)) | ||
| 30 | #define IOP13XX_TPMI_MEM(dev) IOP13XX_REG_ADDR32_PHYS(0x60000 + (dev << 13)) | ||
| 31 | #define IOP13XX_TPMI_CTRL(dev) IOP13XX_REG_ADDR32_PHYS(0x50000 + (dev << 10)) | ||
| 32 | #define IOP13XX_TPMI_MMR_SIZE (SZ_4K - 1) | ||
| 33 | #define IOP13XX_TPMI_MEM_SIZE (255) | ||
| 34 | #define IOP13XX_TPMI_MEM_CTRL (SZ_1K - 1) | ||
| 35 | #define IOP13XX_TPMI_RESOURCE_MMR 0 | ||
| 36 | #define IOP13XX_TPMI_RESOURCE_MEM 1 | ||
| 37 | #define IOP13XX_TPMI_RESOURCE_CTRL 2 | ||
| 38 | #define IOP13XX_TPMI_RESOURCE_IRQ 3 | ||
| 39 | |||
| 40 | static struct resource iop13xx_tpmi_0_resources[] = { | ||
| 41 | [IOP13XX_TPMI_RESOURCE_MMR] = { | ||
| 42 | .start = IOP13XX_TPMI_MMR(4), /* tpmi0 starts at dev == 4 */ | ||
| 43 | .end = IOP13XX_TPMI_MMR(4) + IOP13XX_TPMI_MMR_SIZE, | ||
| 44 | .flags = IORESOURCE_MEM, | ||
| 45 | }, | ||
| 46 | [IOP13XX_TPMI_RESOURCE_MEM] = { | ||
| 47 | .start = IOP13XX_TPMI_MEM(0), | ||
| 48 | .end = IOP13XX_TPMI_MEM(0) + IOP13XX_TPMI_MEM_SIZE, | ||
| 49 | .flags = IORESOURCE_MEM, | ||
| 50 | }, | ||
| 51 | [IOP13XX_TPMI_RESOURCE_CTRL] = { | ||
| 52 | .start = IOP13XX_TPMI_CTRL(0), | ||
| 53 | .end = IOP13XX_TPMI_CTRL(0) + IOP13XX_TPMI_MEM_CTRL, | ||
| 54 | .flags = IORESOURCE_MEM, | ||
| 55 | }, | ||
| 56 | [IOP13XX_TPMI_RESOURCE_IRQ] = { | ||
| 57 | .start = IRQ_IOP13XX_TPMI0_OUT, | ||
| 58 | .end = IRQ_IOP13XX_TPMI0_OUT, | ||
| 59 | .flags = IORESOURCE_IRQ | ||
| 60 | } | ||
| 61 | }; | ||
| 62 | |||
| 63 | static struct resource iop13xx_tpmi_1_resources[] = { | ||
| 64 | [IOP13XX_TPMI_RESOURCE_MMR] = { | ||
| 65 | .start = IOP13XX_TPMI_MMR(1), | ||
| 66 | .end = IOP13XX_TPMI_MMR(1) + IOP13XX_TPMI_MMR_SIZE, | ||
| 67 | .flags = IORESOURCE_MEM, | ||
| 68 | }, | ||
| 69 | [IOP13XX_TPMI_RESOURCE_MEM] = { | ||
| 70 | .start = IOP13XX_TPMI_MEM(1), | ||
| 71 | .end = IOP13XX_TPMI_MEM(1) + IOP13XX_TPMI_MEM_SIZE, | ||
| 72 | .flags = IORESOURCE_MEM, | ||
| 73 | }, | ||
| 74 | [IOP13XX_TPMI_RESOURCE_CTRL] = { | ||
| 75 | .start = IOP13XX_TPMI_CTRL(1), | ||
| 76 | .end = IOP13XX_TPMI_CTRL(1) + IOP13XX_TPMI_MEM_CTRL, | ||
| 77 | .flags = IORESOURCE_MEM, | ||
| 78 | }, | ||
| 79 | [IOP13XX_TPMI_RESOURCE_IRQ] = { | ||
| 80 | .start = IRQ_IOP13XX_TPMI1_OUT, | ||
| 81 | .end = IRQ_IOP13XX_TPMI1_OUT, | ||
| 82 | .flags = IORESOURCE_IRQ | ||
| 83 | } | ||
| 84 | }; | ||
| 85 | |||
| 86 | static struct resource iop13xx_tpmi_2_resources[] = { | ||
| 87 | [IOP13XX_TPMI_RESOURCE_MMR] = { | ||
| 88 | .start = IOP13XX_TPMI_MMR(2), | ||
| 89 | .end = IOP13XX_TPMI_MMR(2) + IOP13XX_TPMI_MMR_SIZE, | ||
| 90 | .flags = IORESOURCE_MEM, | ||
| 91 | }, | ||
| 92 | [IOP13XX_TPMI_RESOURCE_MEM] = { | ||
| 93 | .start = IOP13XX_TPMI_MEM(2), | ||
| 94 | .end = IOP13XX_TPMI_MEM(2) + IOP13XX_TPMI_MEM_SIZE, | ||
| 95 | .flags = IORESOURCE_MEM, | ||
| 96 | }, | ||
| 97 | [IOP13XX_TPMI_RESOURCE_CTRL] = { | ||
| 98 | .start = IOP13XX_TPMI_CTRL(2), | ||
| 99 | .end = IOP13XX_TPMI_CTRL(2) + IOP13XX_TPMI_MEM_CTRL, | ||
| 100 | .flags = IORESOURCE_MEM, | ||
| 101 | }, | ||
| 102 | [IOP13XX_TPMI_RESOURCE_IRQ] = { | ||
| 103 | .start = IRQ_IOP13XX_TPMI2_OUT, | ||
| 104 | .end = IRQ_IOP13XX_TPMI2_OUT, | ||
| 105 | .flags = IORESOURCE_IRQ | ||
| 106 | } | ||
| 107 | }; | ||
| 108 | |||
| 109 | static struct resource iop13xx_tpmi_3_resources[] = { | ||
| 110 | [IOP13XX_TPMI_RESOURCE_MMR] = { | ||
| 111 | .start = IOP13XX_TPMI_MMR(3), | ||
| 112 | .end = IOP13XX_TPMI_MMR(3) + IOP13XX_TPMI_MMR_SIZE, | ||
| 113 | .flags = IORESOURCE_MEM, | ||
| 114 | }, | ||
| 115 | [IOP13XX_TPMI_RESOURCE_MEM] = { | ||
| 116 | .start = IOP13XX_TPMI_MEM(3), | ||
| 117 | .end = IOP13XX_TPMI_MEM(3) + IOP13XX_TPMI_MEM_SIZE, | ||
| 118 | .flags = IORESOURCE_MEM, | ||
| 119 | }, | ||
| 120 | [IOP13XX_TPMI_RESOURCE_CTRL] = { | ||
| 121 | .start = IOP13XX_TPMI_CTRL(3), | ||
| 122 | .end = IOP13XX_TPMI_CTRL(3) + IOP13XX_TPMI_MEM_CTRL, | ||
| 123 | .flags = IORESOURCE_MEM, | ||
| 124 | }, | ||
| 125 | [IOP13XX_TPMI_RESOURCE_IRQ] = { | ||
| 126 | .start = IRQ_IOP13XX_TPMI3_OUT, | ||
| 127 | .end = IRQ_IOP13XX_TPMI3_OUT, | ||
| 128 | .flags = IORESOURCE_IRQ | ||
| 129 | } | ||
| 130 | }; | ||
| 131 | |||
| 132 | u64 iop13xx_tpmi_mask = DMA_64BIT_MASK; | ||
| 133 | static struct platform_device iop13xx_tpmi_0_device = { | ||
| 134 | .name = "iop-tpmi", | ||
| 135 | .id = 0, | ||
| 136 | .num_resources = 4, | ||
| 137 | .resource = iop13xx_tpmi_0_resources, | ||
| 138 | .dev = { | ||
| 139 | .dma_mask = &iop13xx_tpmi_mask, | ||
| 140 | .coherent_dma_mask = DMA_64BIT_MASK, | ||
| 141 | }, | ||
| 142 | }; | ||
| 143 | |||
| 144 | static struct platform_device iop13xx_tpmi_1_device = { | ||
| 145 | .name = "iop-tpmi", | ||
| 146 | .id = 1, | ||
| 147 | .num_resources = 4, | ||
| 148 | .resource = iop13xx_tpmi_1_resources, | ||
| 149 | .dev = { | ||
| 150 | .dma_mask = &iop13xx_tpmi_mask, | ||
| 151 | .coherent_dma_mask = DMA_64BIT_MASK, | ||
| 152 | }, | ||
| 153 | }; | ||
| 154 | |||
| 155 | static struct platform_device iop13xx_tpmi_2_device = { | ||
| 156 | .name = "iop-tpmi", | ||
| 157 | .id = 2, | ||
| 158 | .num_resources = 4, | ||
| 159 | .resource = iop13xx_tpmi_2_resources, | ||
| 160 | .dev = { | ||
| 161 | .dma_mask = &iop13xx_tpmi_mask, | ||
| 162 | .coherent_dma_mask = DMA_64BIT_MASK, | ||
| 163 | }, | ||
| 164 | }; | ||
| 165 | |||
| 166 | static struct platform_device iop13xx_tpmi_3_device = { | ||
| 167 | .name = "iop-tpmi", | ||
| 168 | .id = 3, | ||
| 169 | .num_resources = 4, | ||
| 170 | .resource = iop13xx_tpmi_3_resources, | ||
| 171 | .dev = { | ||
| 172 | .dma_mask = &iop13xx_tpmi_mask, | ||
| 173 | .coherent_dma_mask = DMA_64BIT_MASK, | ||
| 174 | }, | ||
| 175 | }; | ||
| 176 | |||
| 177 | __init void iop13xx_add_tpmi_devices(void) | ||
| 178 | { | ||
| 179 | unsigned short device_id; | ||
| 180 | |||
| 181 | /* tpmi's not present on iop341 or iop342 */ | ||
| 182 | if (__raw_readl(IOP13XX_ESSR0) & IOP13XX_INTERFACE_SEL_PCIX) | ||
| 183 | /* ATUE must be present */ | ||
| 184 | device_id = __raw_readw(IOP13XX_ATUE_DID); | ||
| 185 | else | ||
| 186 | /* ATUX must be present */ | ||
| 187 | device_id = __raw_readw(IOP13XX_ATUX_DID); | ||
| 188 | |||
| 189 | switch (device_id) { | ||
| 190 | /* iop34[1|2] 0-tpmi */ | ||
| 191 | case 0x3380: | ||
| 192 | case 0x3384: | ||
| 193 | case 0x3388: | ||
| 194 | case 0x338c: | ||
| 195 | case 0x3382: | ||
| 196 | case 0x3386: | ||
| 197 | case 0x338a: | ||
| 198 | case 0x338e: | ||
| 199 | return; | ||
| 200 | /* iop348 1-tpmi */ | ||
| 201 | case 0x3310: | ||
| 202 | case 0x3312: | ||
| 203 | case 0x3314: | ||
| 204 | case 0x3318: | ||
| 205 | case 0x331a: | ||
| 206 | case 0x331c: | ||
| 207 | case 0x33c0: | ||
| 208 | case 0x33c2: | ||
| 209 | case 0x33c4: | ||
| 210 | case 0x33c8: | ||
| 211 | case 0x33ca: | ||
| 212 | case 0x33cc: | ||
| 213 | case 0x33b0: | ||
| 214 | case 0x33b2: | ||
| 215 | case 0x33b4: | ||
| 216 | case 0x33b8: | ||
| 217 | case 0x33ba: | ||
| 218 | case 0x33bc: | ||
| 219 | case 0x3320: | ||
| 220 | case 0x3322: | ||
| 221 | case 0x3324: | ||
| 222 | case 0x3328: | ||
| 223 | case 0x332a: | ||
| 224 | case 0x332c: | ||
| 225 | platform_device_register(&iop13xx_tpmi_0_device); | ||
| 226 | return; | ||
| 227 | default: | ||
| 228 | platform_device_register(&iop13xx_tpmi_0_device); | ||
| 229 | platform_device_register(&iop13xx_tpmi_1_device); | ||
| 230 | platform_device_register(&iop13xx_tpmi_2_device); | ||
| 231 | platform_device_register(&iop13xx_tpmi_3_device); | ||
| 232 | return; | ||
| 233 | } | ||
| 234 | } | ||
| diff --git a/arch/arm/mach-iop32x/Kconfig b/arch/arm/mach-iop32x/Kconfig index 9dd49cff21ff..9bb02b6d7ae1 100644 --- a/arch/arm/mach-iop32x/Kconfig +++ b/arch/arm/mach-iop32x/Kconfig | |||
| @@ -34,6 +34,14 @@ config MACH_N2100 | |||
| 34 | Say Y here if you want to run your kernel on the Thecus n2100 | 34 | Say Y here if you want to run your kernel on the Thecus n2100 | 
| 35 | NAS appliance. | 35 | NAS appliance. | 
| 36 | 36 | ||
| 37 | config IOP3XX_ATU | ||
| 38 | bool "Enable the PCI Controller" | ||
| 39 | default y | ||
| 40 | help | ||
| 41 | Say Y here if you want the IOP to initialize its PCI Controller. | ||
| 42 | Say N if the IOP is an add in card, the host system owns the PCI | ||
| 43 | bus in this case. | ||
| 44 | |||
| 37 | endmenu | 45 | endmenu | 
| 38 | 46 | ||
| 39 | endif | 47 | endif | 
| diff --git a/arch/arm/mach-iop32x/iq31244.c b/arch/arm/mach-iop32x/iq31244.c index 60e74309a458..7b21c6e13e59 100644 --- a/arch/arm/mach-iop32x/iq31244.c +++ b/arch/arm/mach-iop32x/iq31244.c | |||
| @@ -178,9 +178,10 @@ static struct hw_pci iq31244_pci __initdata = { | |||
| 178 | 178 | ||
| 179 | static int __init iq31244_pci_init(void) | 179 | static int __init iq31244_pci_init(void) | 
| 180 | { | 180 | { | 
| 181 | if (is_ep80219()) | 181 | if (is_ep80219()) { | 
| 182 | pci_common_init(&ep80219_pci); | 182 | if (iop3xx_get_init_atu() == IOP3XX_INIT_ATU_ENABLE) | 
| 183 | else if (machine_is_iq31244()) { | 183 | pci_common_init(&ep80219_pci); | 
| 184 | } else if (machine_is_iq31244()) { | ||
| 184 | if (is_80219()) { | 185 | if (is_80219()) { | 
| 185 | printk("note: iq31244 board type has been selected\n"); | 186 | printk("note: iq31244 board type has been selected\n"); | 
| 186 | printk("note: to select ep80219 operation:\n"); | 187 | printk("note: to select ep80219 operation:\n"); | 
| @@ -189,7 +190,9 @@ static int __init iq31244_pci_init(void) | |||
| 189 | printk("\t2/ update boot loader to pass" | 190 | printk("\t2/ update boot loader to pass" | 
| 190 | " the ep80219 id: %d\n", MACH_TYPE_EP80219); | 191 | " the ep80219 id: %d\n", MACH_TYPE_EP80219); | 
| 191 | } | 192 | } | 
| 192 | pci_common_init(&iq31244_pci); | 193 | |
| 194 | if (iop3xx_get_init_atu() == IOP3XX_INIT_ATU_ENABLE) | ||
| 195 | pci_common_init(&iq31244_pci); | ||
| 193 | } | 196 | } | 
| 194 | 197 | ||
| 195 | return 0; | 198 | return 0; | 
| diff --git a/arch/arm/mach-iop32x/iq80321.c b/arch/arm/mach-iop32x/iq80321.c index 361c70c0f64c..bc25fb91e7b9 100644 --- a/arch/arm/mach-iop32x/iq80321.c +++ b/arch/arm/mach-iop32x/iq80321.c | |||
| @@ -113,7 +113,8 @@ static struct hw_pci iq80321_pci __initdata = { | |||
| 113 | 113 | ||
| 114 | static int __init iq80321_pci_init(void) | 114 | static int __init iq80321_pci_init(void) | 
| 115 | { | 115 | { | 
| 116 | if (machine_is_iq80321()) | 116 | if ((iop3xx_get_init_atu() == IOP3XX_INIT_ATU_ENABLE) && | 
| 117 | machine_is_iq80321()) | ||
| 117 | pci_common_init(&iq80321_pci); | 118 | pci_common_init(&iq80321_pci); | 
| 118 | 119 | ||
| 119 | return 0; | 120 | return 0; | 
| diff --git a/arch/arm/mach-iop33x/Kconfig b/arch/arm/mach-iop33x/Kconfig index 9aa016bb18f9..45598e096898 100644 --- a/arch/arm/mach-iop33x/Kconfig +++ b/arch/arm/mach-iop33x/Kconfig | |||
| @@ -16,6 +16,14 @@ config MACH_IQ80332 | |||
| 16 | Say Y here if you want to run your kernel on the Intel IQ80332 | 16 | Say Y here if you want to run your kernel on the Intel IQ80332 | 
| 17 | evaluation kit for the IOP332 chipset. | 17 | evaluation kit for the IOP332 chipset. | 
| 18 | 18 | ||
| 19 | config IOP3XX_ATU | ||
| 20 | bool "Enable the PCI Controller" | ||
| 21 | default y | ||
| 22 | help | ||
| 23 | Say Y here if you want the IOP to initialize its PCI Controller. | ||
| 24 | Say N if the IOP is an add in card, the host system owns the PCI | ||
| 25 | bus in this case. | ||
| 26 | |||
| 19 | endmenu | 27 | endmenu | 
| 20 | 28 | ||
| 21 | endif | 29 | endif | 
| diff --git a/arch/arm/mach-iop33x/iq80331.c b/arch/arm/mach-iop33x/iq80331.c index 1a9e36138d80..376c932830be 100644 --- a/arch/arm/mach-iop33x/iq80331.c +++ b/arch/arm/mach-iop33x/iq80331.c | |||
| @@ -96,7 +96,8 @@ static struct hw_pci iq80331_pci __initdata = { | |||
| 96 | 96 | ||
| 97 | static int __init iq80331_pci_init(void) | 97 | static int __init iq80331_pci_init(void) | 
| 98 | { | 98 | { | 
| 99 | if (machine_is_iq80331()) | 99 | if ((iop3xx_get_init_atu() == IOP3XX_INIT_ATU_ENABLE) && | 
| 100 | machine_is_iq80331()) | ||
| 100 | pci_common_init(&iq80331_pci); | 101 | pci_common_init(&iq80331_pci); | 
| 101 | 102 | ||
| 102 | return 0; | 103 | return 0; | 
| diff --git a/arch/arm/mach-iop33x/iq80332.c b/arch/arm/mach-iop33x/iq80332.c index 96d6f0f3cd21..58c81496c6f6 100644 --- a/arch/arm/mach-iop33x/iq80332.c +++ b/arch/arm/mach-iop33x/iq80332.c | |||
| @@ -96,7 +96,8 @@ static struct hw_pci iq80332_pci __initdata = { | |||
| 96 | 96 | ||
| 97 | static int __init iq80332_pci_init(void) | 97 | static int __init iq80332_pci_init(void) | 
| 98 | { | 98 | { | 
| 99 | if (machine_is_iq80332()) | 99 | if ((iop3xx_get_init_atu() == IOP3XX_INIT_ATU_ENABLE) && | 
| 100 | machine_is_iq80332()) | ||
| 100 | pci_common_init(&iq80332_pci); | 101 | pci_common_init(&iq80332_pci); | 
| 101 | 102 | ||
| 102 | return 0; | 103 | return 0; | 
| diff --git a/arch/arm/mach-ixp4xx/common.c b/arch/arm/mach-ixp4xx/common.c index 45068c3d8dcc..09edea9779e6 100644 --- a/arch/arm/mach-ixp4xx/common.c +++ b/arch/arm/mach-ixp4xx/common.c | |||
| @@ -27,6 +27,7 @@ | |||
| 27 | #include <linux/time.h> | 27 | #include <linux/time.h> | 
| 28 | #include <linux/timex.h> | 28 | #include <linux/timex.h> | 
| 29 | #include <linux/clocksource.h> | 29 | #include <linux/clocksource.h> | 
| 30 | #include <linux/clockchips.h> | ||
| 30 | 31 | ||
| 31 | #include <asm/arch/udc.h> | 32 | #include <asm/arch/udc.h> | 
| 32 | #include <asm/hardware.h> | 33 | #include <asm/hardware.h> | 
| @@ -41,6 +42,8 @@ | |||
| 41 | #include <asm/mach/time.h> | 42 | #include <asm/mach/time.h> | 
| 42 | 43 | ||
| 43 | static int __init ixp4xx_clocksource_init(void); | 44 | static int __init ixp4xx_clocksource_init(void); | 
| 45 | static int __init ixp4xx_clockevent_init(void); | ||
| 46 | static struct clock_event_device clockevent_ixp4xx; | ||
| 44 | 47 | ||
| 45 | /************************************************************************* | 48 | /************************************************************************* | 
| 46 | * IXP4xx chipset I/O mapping | 49 | * IXP4xx chipset I/O mapping | 
| @@ -239,52 +242,40 @@ void __init ixp4xx_init_irq(void) | |||
| 239 | * counter as a source of real clock ticks to account for missed jiffies. | 242 | * counter as a source of real clock ticks to account for missed jiffies. | 
| 240 | *************************************************************************/ | 243 | *************************************************************************/ | 
| 241 | 244 | ||
| 242 | static unsigned volatile last_jiffy_time; | ||
| 243 | |||
| 244 | #define CLOCK_TICKS_PER_USEC ((CLOCK_TICK_RATE + USEC_PER_SEC/2) / USEC_PER_SEC) | ||
| 245 | |||
| 246 | static irqreturn_t ixp4xx_timer_interrupt(int irq, void *dev_id) | 245 | static irqreturn_t ixp4xx_timer_interrupt(int irq, void *dev_id) | 
| 247 | { | 246 | { | 
| 248 | write_seqlock(&xtime_lock); | 247 | struct clock_event_device *evt = &clockevent_ixp4xx; | 
| 249 | 248 | ||
| 250 | /* Clear Pending Interrupt by writing '1' to it */ | 249 | /* Clear Pending Interrupt by writing '1' to it */ | 
| 251 | *IXP4XX_OSST = IXP4XX_OSST_TIMER_1_PEND; | 250 | *IXP4XX_OSST = IXP4XX_OSST_TIMER_1_PEND; | 
| 252 | 251 | ||
| 253 | /* | 252 | evt->event_handler(evt); | 
| 254 | * Catch up with the real idea of time | ||
| 255 | */ | ||
| 256 | while ((signed long)(*IXP4XX_OSTS - last_jiffy_time) >= LATCH) { | ||
| 257 | timer_tick(); | ||
| 258 | last_jiffy_time += LATCH; | ||
| 259 | } | ||
| 260 | |||
| 261 | write_sequnlock(&xtime_lock); | ||
| 262 | 253 | ||
| 263 | return IRQ_HANDLED; | 254 | return IRQ_HANDLED; | 
| 264 | } | 255 | } | 
| 265 | 256 | ||
| 266 | static struct irqaction ixp4xx_timer_irq = { | 257 | static struct irqaction ixp4xx_timer_irq = { | 
| 267 | .name = "IXP4xx Timer Tick", | 258 | .name = "timer1", | 
| 268 | .flags = IRQF_DISABLED | IRQF_TIMER, | 259 | .flags = IRQF_DISABLED | IRQF_TIMER, | 
| 269 | .handler = ixp4xx_timer_interrupt, | 260 | .handler = ixp4xx_timer_interrupt, | 
| 270 | }; | 261 | }; | 
| 271 | 262 | ||
| 272 | static void __init ixp4xx_timer_init(void) | 263 | static void __init ixp4xx_timer_init(void) | 
| 273 | { | 264 | { | 
| 265 | /* Reset/disable counter */ | ||
| 266 | *IXP4XX_OSRT1 = 0; | ||
| 267 | |||
| 274 | /* Clear Pending Interrupt by writing '1' to it */ | 268 | /* Clear Pending Interrupt by writing '1' to it */ | 
| 275 | *IXP4XX_OSST = IXP4XX_OSST_TIMER_1_PEND; | 269 | *IXP4XX_OSST = IXP4XX_OSST_TIMER_1_PEND; | 
| 276 | 270 | ||
| 277 | /* Setup the Timer counter value */ | ||
| 278 | *IXP4XX_OSRT1 = (LATCH & ~IXP4XX_OST_RELOAD_MASK) | IXP4XX_OST_ENABLE; | ||
| 279 | |||
| 280 | /* Reset time-stamp counter */ | 271 | /* Reset time-stamp counter */ | 
| 281 | *IXP4XX_OSTS = 0; | 272 | *IXP4XX_OSTS = 0; | 
| 282 | last_jiffy_time = 0; | ||
| 283 | 273 | ||
| 284 | /* Connect the interrupt handler and enable the interrupt */ | 274 | /* Connect the interrupt handler and enable the interrupt */ | 
| 285 | setup_irq(IRQ_IXP4XX_TIMER1, &ixp4xx_timer_irq); | 275 | setup_irq(IRQ_IXP4XX_TIMER1, &ixp4xx_timer_irq); | 
| 286 | 276 | ||
| 287 | ixp4xx_clocksource_init(); | 277 | ixp4xx_clocksource_init(); | 
| 278 | ixp4xx_clockevent_init(); | ||
| 288 | } | 279 | } | 
| 289 | 280 | ||
| 290 | struct sys_timer ixp4xx_timer = { | 281 | struct sys_timer ixp4xx_timer = { | 
| @@ -384,6 +375,9 @@ void __init ixp4xx_sys_init(void) | |||
| 384 | ixp4xx_exp_bus_size >> 20); | 375 | ixp4xx_exp_bus_size >> 20); | 
| 385 | } | 376 | } | 
| 386 | 377 | ||
| 378 | /* | ||
| 379 | * clocksource | ||
| 380 | */ | ||
| 387 | cycle_t ixp4xx_get_cycles(void) | 381 | cycle_t ixp4xx_get_cycles(void) | 
| 388 | { | 382 | { | 
| 389 | return *IXP4XX_OSTS; | 383 | return *IXP4XX_OSTS; | 
| @@ -408,3 +402,64 @@ static int __init ixp4xx_clocksource_init(void) | |||
| 408 | 402 | ||
| 409 | return 0; | 403 | return 0; | 
| 410 | } | 404 | } | 
| 405 | |||
| 406 | /* | ||
| 407 | * clockevents | ||
| 408 | */ | ||
| 409 | static int ixp4xx_set_next_event(unsigned long evt, | ||
| 410 | struct clock_event_device *unused) | ||
| 411 | { | ||
| 412 | unsigned long opts = *IXP4XX_OSRT1 & IXP4XX_OST_RELOAD_MASK; | ||
| 413 | |||
| 414 | *IXP4XX_OSRT1 = (evt & ~IXP4XX_OST_RELOAD_MASK) | opts; | ||
| 415 | |||
| 416 | return 0; | ||
| 417 | } | ||
| 418 | |||
| 419 | static void ixp4xx_set_mode(enum clock_event_mode mode, | ||
| 420 | struct clock_event_device *evt) | ||
| 421 | { | ||
| 422 | unsigned long opts, osrt = *IXP4XX_OSRT1 & ~IXP4XX_OST_RELOAD_MASK; | ||
| 423 | |||
| 424 | switch (mode) { | ||
| 425 | case CLOCK_EVT_MODE_PERIODIC: | ||
| 426 | osrt = LATCH & ~IXP4XX_OST_RELOAD_MASK; | ||
| 427 | opts = IXP4XX_OST_ENABLE; | ||
| 428 | break; | ||
| 429 | case CLOCK_EVT_MODE_ONESHOT: | ||
| 430 | /* period set by 'set next_event' */ | ||
| 431 | osrt = 0; | ||
| 432 | opts = IXP4XX_OST_ENABLE | IXP4XX_OST_ONE_SHOT; | ||
| 433 | break; | ||
| 434 | case CLOCK_EVT_MODE_SHUTDOWN: | ||
| 435 | case CLOCK_EVT_MODE_UNUSED: | ||
| 436 | default: | ||
| 437 | osrt = opts = 0; | ||
| 438 | break; | ||
| 439 | } | ||
| 440 | |||
| 441 | *IXP4XX_OSRT1 = osrt | opts; | ||
| 442 | } | ||
| 443 | |||
| 444 | static struct clock_event_device clockevent_ixp4xx = { | ||
| 445 | .name = "ixp4xx timer1", | ||
| 446 | .features = CLOCK_EVT_FEAT_PERIODIC | CLOCK_EVT_FEAT_ONESHOT, | ||
| 447 | .rating = 200, | ||
| 448 | .shift = 24, | ||
| 449 | .set_mode = ixp4xx_set_mode, | ||
| 450 | .set_next_event = ixp4xx_set_next_event, | ||
| 451 | }; | ||
| 452 | |||
| 453 | static int __init ixp4xx_clockevent_init(void) | ||
| 454 | { | ||
| 455 | clockevent_ixp4xx.mult = div_sc(FREQ, NSEC_PER_SEC, | ||
| 456 | clockevent_ixp4xx.shift); | ||
| 457 | clockevent_ixp4xx.max_delta_ns = | ||
| 458 | clockevent_delta2ns(0xfffffffe, &clockevent_ixp4xx); | ||
| 459 | clockevent_ixp4xx.min_delta_ns = | ||
| 460 | clockevent_delta2ns(0xf, &clockevent_ixp4xx); | ||
| 461 | clockevent_ixp4xx.cpumask = cpumask_of_cpu(0); | ||
| 462 | |||
| 463 | clockevents_register_device(&clockevent_ixp4xx); | ||
| 464 | return 0; | ||
| 465 | } | ||
| diff --git a/arch/arm/mach-ns9xxx/Kconfig b/arch/arm/mach-ns9xxx/Kconfig index 8175ba92a2fa..8584ed107991 100644 --- a/arch/arm/mach-ns9xxx/Kconfig +++ b/arch/arm/mach-ns9xxx/Kconfig | |||
| @@ -3,19 +3,30 @@ if ARCH_NS9XXX | |||
| 3 | menu "NS9xxx Implementations" | 3 | menu "NS9xxx Implementations" | 
| 4 | 4 | ||
| 5 | config MACH_CC9P9360DEV | 5 | config MACH_CC9P9360DEV | 
| 6 | bool "Connect Core 9P 9360 on an A9M9750 Devboard" | 6 | bool "ConnectCore 9P 9360 on an A9M9750 Devboard" | 
| 7 | select PROCESSOR_NS9360 | 7 | select PROCESSOR_NS9360 | 
| 8 | select BOARD_A9M9750DEV | 8 | select BOARD_A9M9750DEV | 
| 9 | help | 9 | help | 
| 10 | Say Y here if you are using the Digi Connect Core 9P 9360 | 10 | Say Y here if you are using the Digi ConnectCore 9P 9360 | 
| 11 | on an A9M9750 Development Board. | 11 | on an A9M9750 Development Board. | 
| 12 | 12 | ||
| 13 | config MACH_CC9P9360JS | ||
| 14 | bool "ConnectCore 9P 9360 on a JSCC9P9360 Devboard" | ||
| 15 | select PROCESSOR_NS9360 | ||
| 16 | select BOARD_JSCC9P9360 | ||
| 17 | help | ||
| 18 | Say Y here if you are using the Digi ConnectCore 9P 9360 | ||
| 19 | on an JSCC9P9360 Development Board. | ||
| 20 | |||
| 13 | config PROCESSOR_NS9360 | 21 | config PROCESSOR_NS9360 | 
| 14 | bool | 22 | bool | 
| 15 | 23 | ||
| 16 | config BOARD_A9M9750DEV | 24 | config BOARD_A9M9750DEV | 
| 17 | bool | 25 | bool | 
| 18 | 26 | ||
| 27 | config BOARD_JSCC9P9360 | ||
| 28 | bool | ||
| 29 | |||
| 19 | endmenu | 30 | endmenu | 
| 20 | 31 | ||
| 21 | endif | 32 | endif | 
| diff --git a/arch/arm/mach-ns9xxx/Makefile b/arch/arm/mach-ns9xxx/Makefile index 91e945f5e16d..53213a69f601 100644 --- a/arch/arm/mach-ns9xxx/Makefile +++ b/arch/arm/mach-ns9xxx/Makefile | |||
| @@ -3,3 +3,4 @@ obj-y := irq.o time.o generic.o | |||
| 3 | obj-$(CONFIG_MACH_CC9P9360DEV) += mach-cc9p9360dev.o | 3 | obj-$(CONFIG_MACH_CC9P9360DEV) += mach-cc9p9360dev.o | 
| 4 | 4 | ||
| 5 | obj-$(CONFIG_BOARD_A9M9750DEV) += board-a9m9750dev.o | 5 | obj-$(CONFIG_BOARD_A9M9750DEV) += board-a9m9750dev.o | 
| 6 | obj-$(CONFIG_BOARD_JSCC9P9360) += board-jscc9p9360.o | ||
| diff --git a/arch/arm/mach-ns9xxx/board-jscc9p9360.c b/arch/arm/mach-ns9xxx/board-jscc9p9360.c new file mode 100644 index 000000000000..4bd3eec04bfe --- /dev/null +++ b/arch/arm/mach-ns9xxx/board-jscc9p9360.c | |||
| @@ -0,0 +1,17 @@ | |||
| 1 | /* | ||
| 2 | * arch/arm/mach-ns9xxx/board-jscc9p9360.c | ||
| 3 | * | ||
| 4 | * Copyright (C) 2006,2007 by Digi International Inc. | ||
| 5 | * All rights reserved. | ||
| 6 | * | ||
| 7 | * This program is free software; you can redistribute it and/or modify it | ||
| 8 | * under the terms of the GNU General Public License version 2 as published by | ||
| 9 | * the Free Software Foundation. | ||
| 10 | */ | ||
| 11 | #include "board-jscc9p9360.h" | ||
| 12 | |||
| 13 | void __init board_jscc9p9360_init_machine(void) | ||
| 14 | { | ||
| 15 | /* TODO: reserve GPIOs for push buttons, etc pp */ | ||
| 16 | } | ||
| 17 | |||
| diff --git a/arch/arm/mach-ns9xxx/board-jscc9p9360.h b/arch/arm/mach-ns9xxx/board-jscc9p9360.h new file mode 100644 index 000000000000..1a81a074df45 --- /dev/null +++ b/arch/arm/mach-ns9xxx/board-jscc9p9360.h | |||
| @@ -0,0 +1,13 @@ | |||
| 1 | /* | ||
| 2 | * arch/arm/mach-ns9xxx/board-jscc9p9360.h | ||
| 3 | * | ||
| 4 | * Copyright (C) 2006 by Digi International Inc. | ||
| 5 | * All rights reserved. | ||
| 6 | * | ||
| 7 | * This program is free software; you can redistribute it and/or modify it | ||
| 8 | * under the terms of the GNU General Public License version 2 as published by | ||
| 9 | * the Free Software Foundation. | ||
| 10 | */ | ||
| 11 | #include <linux/init.h> | ||
| 12 | |||
| 13 | void __init board_jscc9p9360_init_machine(void); | ||
| diff --git a/arch/arm/mach-ns9xxx/mach-cc9p9360js.c b/arch/arm/mach-ns9xxx/mach-cc9p9360js.c new file mode 100644 index 000000000000..d09d5fa5620a --- /dev/null +++ b/arch/arm/mach-ns9xxx/mach-cc9p9360js.c | |||
| @@ -0,0 +1,29 @@ | |||
| 1 | /* | ||
| 2 | * arch/arm/mach-ns9xxx/mach-cc9p9360js.c | ||
| 3 | * | ||
| 4 | * Copyright (C) 2006 by Digi International Inc. | ||
| 5 | * All rights reserved. | ||
| 6 | * | ||
| 7 | * This program is free software; you can redistribute it and/or modify it | ||
| 8 | * under the terms of the GNU General Public License version 2 as published by | ||
| 9 | * the Free Software Foundation. | ||
| 10 | */ | ||
| 11 | #include <asm/mach/arch.h> | ||
| 12 | #include <asm/mach-types.h> | ||
| 13 | |||
| 14 | #include "board-jscc9p9360.h" | ||
| 15 | #include "generic.h" | ||
| 16 | |||
| 17 | static void __init mach_cc9p9360js_init_machine(void) | ||
| 18 | { | ||
| 19 | ns9xxx_init_machine(); | ||
| 20 | board_jscc9p9360_init_machine(); | ||
| 21 | } | ||
| 22 | |||
| 23 | MACHINE_START(CC9P9360DEV, "Digi ConnectCore 9P 9360 on an JSCC9P9360 Devboard") | ||
| 24 | .map_io = ns9xxx_map_io, | ||
| 25 | .init_irq = ns9xxx_init_irq, | ||
| 26 | .init_machine = mach_cc9p9360js_init_machine, | ||
| 27 | .timer = &ns9xxx_timer, | ||
| 28 | .boot_params = 0x100, | ||
| 29 | MACHINE_END | ||
| diff --git a/arch/arm/mach-omap1/time.c b/arch/arm/mach-omap1/time.c index 1b7e4a506c26..85e048b259f5 100644 --- a/arch/arm/mach-omap1/time.c +++ b/arch/arm/mach-omap1/time.c | |||
| @@ -39,6 +39,10 @@ | |||
| 39 | #include <linux/interrupt.h> | 39 | #include <linux/interrupt.h> | 
| 40 | #include <linux/sched.h> | 40 | #include <linux/sched.h> | 
| 41 | #include <linux/spinlock.h> | 41 | #include <linux/spinlock.h> | 
| 42 | #include <linux/clk.h> | ||
| 43 | #include <linux/err.h> | ||
| 44 | #include <linux/clocksource.h> | ||
| 45 | #include <linux/clockchips.h> | ||
| 42 | 46 | ||
| 43 | #include <asm/system.h> | 47 | #include <asm/system.h> | 
| 44 | #include <asm/hardware.h> | 48 | #include <asm/hardware.h> | 
| @@ -48,13 +52,7 @@ | |||
| 48 | #include <asm/mach/irq.h> | 52 | #include <asm/mach/irq.h> | 
| 49 | #include <asm/mach/time.h> | 53 | #include <asm/mach/time.h> | 
| 50 | 54 | ||
| 51 | struct sys_timer omap_timer; | ||
| 52 | 55 | ||
| 53 | /* | ||
| 54 | * --------------------------------------------------------------------------- | ||
| 55 | * MPU timer | ||
| 56 | * --------------------------------------------------------------------------- | ||
| 57 | */ | ||
| 58 | #define OMAP_MPU_TIMER_BASE OMAP_MPU_TIMER1_BASE | 56 | #define OMAP_MPU_TIMER_BASE OMAP_MPU_TIMER1_BASE | 
| 59 | #define OMAP_MPU_TIMER_OFFSET 0x100 | 57 | #define OMAP_MPU_TIMER_OFFSET 0x100 | 
| 60 | 58 | ||
| @@ -88,21 +86,6 @@ static inline unsigned long long cycles_2_ns(unsigned long long cyc) | |||
| 88 | return (cyc * cyc2ns_scale) >> CYC2NS_SCALE_FACTOR; | 86 | return (cyc * cyc2ns_scale) >> CYC2NS_SCALE_FACTOR; | 
| 89 | } | 87 | } | 
| 90 | 88 | ||
| 91 | /* | ||
| 92 | * MPU_TICKS_PER_SEC must be an even number, otherwise machinecycles_to_usecs | ||
| 93 | * will break. On P2, the timer count rate is 6.5 MHz after programming PTV | ||
| 94 | * with 0. This divides the 13MHz input by 2, and is undocumented. | ||
| 95 | */ | ||
| 96 | #if defined(CONFIG_MACH_OMAP_PERSEUS2) || defined(CONFIG_MACH_OMAP_FSAMPLE) | ||
| 97 | /* REVISIT: This ifdef construct should be replaced by a query to clock | ||
| 98 | * framework to see if timer base frequency is 12.0, 13.0 or 19.2 MHz. | ||
| 99 | */ | ||
| 100 | #define MPU_TICKS_PER_SEC (13000000 / 2) | ||
| 101 | #else | ||
| 102 | #define MPU_TICKS_PER_SEC (12000000 / 2) | ||
| 103 | #endif | ||
| 104 | |||
| 105 | #define MPU_TIMER_TICK_PERIOD ((MPU_TICKS_PER_SEC / HZ) - 1) | ||
| 106 | 89 | ||
| 107 | typedef struct { | 90 | typedef struct { | 
| 108 | u32 cntl; /* CNTL_TIMER, R/W */ | 91 | u32 cntl; /* CNTL_TIMER, R/W */ | 
| @@ -120,98 +103,164 @@ static inline unsigned long omap_mpu_timer_read(int nr) | |||
| 120 | return timer->read_tim; | 103 | return timer->read_tim; | 
| 121 | } | 104 | } | 
| 122 | 105 | ||
| 123 | static inline void omap_mpu_timer_start(int nr, unsigned long load_val) | 106 | static inline void omap_mpu_set_autoreset(int nr) | 
| 124 | { | 107 | { | 
| 125 | volatile omap_mpu_timer_regs_t* timer = omap_mpu_timer_base(nr); | 108 | volatile omap_mpu_timer_regs_t* timer = omap_mpu_timer_base(nr); | 
| 126 | 109 | ||
| 127 | timer->cntl = MPU_TIMER_CLOCK_ENABLE; | 110 | timer->cntl = timer->cntl | MPU_TIMER_AR; | 
| 128 | udelay(1); | ||
| 129 | timer->load_tim = load_val; | ||
| 130 | udelay(1); | ||
| 131 | timer->cntl = (MPU_TIMER_CLOCK_ENABLE | MPU_TIMER_AR | MPU_TIMER_ST); | ||
| 132 | } | 111 | } | 
| 133 | 112 | ||
| 134 | unsigned long omap_mpu_timer_ticks_to_usecs(unsigned long nr_ticks) | 113 | static inline void omap_mpu_remove_autoreset(int nr) | 
| 135 | { | 114 | { | 
| 136 | unsigned long long nsec; | 115 | volatile omap_mpu_timer_regs_t* timer = omap_mpu_timer_base(nr); | 
| 137 | 116 | ||
| 138 | nsec = cycles_2_ns((unsigned long long)nr_ticks); | 117 | timer->cntl = timer->cntl & ~MPU_TIMER_AR; | 
| 139 | return (unsigned long)nsec / 1000; | ||
| 140 | } | 118 | } | 
| 141 | 119 | ||
| 142 | /* | 120 | static inline void omap_mpu_timer_start(int nr, unsigned long load_val, | 
| 143 | * Last processed system timer interrupt | 121 | int autoreset) | 
| 144 | */ | 122 | { | 
| 145 | static unsigned long omap_mpu_timer_last = 0; | 123 | volatile omap_mpu_timer_regs_t* timer = omap_mpu_timer_base(nr); | 
| 124 | unsigned int timerflags = (MPU_TIMER_CLOCK_ENABLE | MPU_TIMER_ST); | ||
| 125 | |||
| 126 | if (autoreset) timerflags |= MPU_TIMER_AR; | ||
| 127 | |||
| 128 | timer->cntl = MPU_TIMER_CLOCK_ENABLE; | ||
| 129 | udelay(1); | ||
| 130 | timer->load_tim = load_val; | ||
| 131 | udelay(1); | ||
| 132 | timer->cntl = timerflags; | ||
| 133 | } | ||
| 146 | 134 | ||
| 147 | /* | 135 | /* | 
| 148 | * Returns elapsed usecs since last system timer interrupt | 136 | * --------------------------------------------------------------------------- | 
| 137 | * MPU timer 1 ... count down to zero, interrupt, reload | ||
| 138 | * --------------------------------------------------------------------------- | ||
| 149 | */ | 139 | */ | 
| 150 | static unsigned long omap_mpu_timer_gettimeoffset(void) | 140 | static int omap_mpu_set_next_event(unsigned long cycles, | 
| 141 | struct clock_event_device *evt) | ||
| 151 | { | 142 | { | 
| 152 | unsigned long now = 0 - omap_mpu_timer_read(0); | 143 | omap_mpu_timer_start(0, cycles, 0); | 
| 153 | unsigned long elapsed = now - omap_mpu_timer_last; | 144 | return 0; | 
| 145 | } | ||
| 154 | 146 | ||
| 155 | return omap_mpu_timer_ticks_to_usecs(elapsed); | 147 | static void omap_mpu_set_mode(enum clock_event_mode mode, | 
| 148 | struct clock_event_device *evt) | ||
| 149 | { | ||
| 150 | switch (mode) { | ||
| 151 | case CLOCK_EVT_MODE_PERIODIC: | ||
| 152 | omap_mpu_set_autoreset(0); | ||
| 153 | break; | ||
| 154 | case CLOCK_EVT_MODE_ONESHOT: | ||
| 155 | omap_mpu_remove_autoreset(0); | ||
| 156 | break; | ||
| 157 | case CLOCK_EVT_MODE_UNUSED: | ||
| 158 | case CLOCK_EVT_MODE_SHUTDOWN: | ||
| 159 | break; | ||
| 160 | } | ||
| 156 | } | 161 | } | 
| 157 | 162 | ||
| 158 | /* | 163 | static struct clock_event_device clockevent_mpu_timer1 = { | 
| 159 | * Elapsed time between interrupts is calculated using timer0. | 164 | .name = "mpu_timer1", | 
| 160 | * Latency during the interrupt is calculated using timer1. | 165 | .features = CLOCK_EVT_FEAT_PERIODIC, CLOCK_EVT_FEAT_ONESHOT, | 
| 161 | * Both timer0 and timer1 are counting at 6MHz (P2 6.5MHz). | 166 | .shift = 32, | 
| 162 | */ | 167 | .set_next_event = omap_mpu_set_next_event, | 
| 163 | static irqreturn_t omap_mpu_timer_interrupt(int irq, void *dev_id) | 168 | .set_mode = omap_mpu_set_mode, | 
| 169 | }; | ||
| 170 | |||
| 171 | static irqreturn_t omap_mpu_timer1_interrupt(int irq, void *dev_id) | ||
| 164 | { | 172 | { | 
| 165 | unsigned long now, latency; | 173 | struct clock_event_device *evt = &clockevent_mpu_timer1; | 
| 166 | 174 | ||
| 167 | write_seqlock(&xtime_lock); | 175 | evt->event_handler(evt); | 
| 168 | now = 0 - omap_mpu_timer_read(0); | ||
| 169 | latency = MPU_TICKS_PER_SEC / HZ - omap_mpu_timer_read(1); | ||
| 170 | omap_mpu_timer_last = now - latency; | ||
| 171 | timer_tick(); | ||
| 172 | write_sequnlock(&xtime_lock); | ||
| 173 | 176 | ||
| 174 | return IRQ_HANDLED; | 177 | return IRQ_HANDLED; | 
| 175 | } | 178 | } | 
| 176 | 179 | ||
| 177 | static struct irqaction omap_mpu_timer_irq = { | 180 | static struct irqaction omap_mpu_timer1_irq = { | 
| 178 | .name = "mpu timer", | 181 | .name = "mpu_timer1", | 
| 179 | .flags = IRQF_DISABLED | IRQF_TIMER, | 182 | .flags = IRQF_DISABLED | IRQF_TIMER, | 
| 180 | .handler = omap_mpu_timer_interrupt, | 183 | .handler = omap_mpu_timer1_interrupt, | 
| 181 | }; | 184 | }; | 
| 182 | 185 | ||
| 183 | static unsigned long omap_mpu_timer1_overflows; | 186 | static __init void omap_init_mpu_timer(unsigned long rate) | 
| 184 | static irqreturn_t omap_mpu_timer1_interrupt(int irq, void *dev_id) | 187 | { | 
| 188 | set_cyc2ns_scale(rate / 1000); | ||
| 189 | |||
| 190 | setup_irq(INT_TIMER1, &omap_mpu_timer1_irq); | ||
| 191 | omap_mpu_timer_start(0, (rate / HZ) - 1, 1); | ||
| 192 | |||
| 193 | clockevent_mpu_timer1.mult = div_sc(rate, NSEC_PER_SEC, | ||
| 194 | clockevent_mpu_timer1.shift); | ||
| 195 | clockevent_mpu_timer1.max_delta_ns = | ||
| 196 | clockevent_delta2ns(-1, &clockevent_mpu_timer1); | ||
| 197 | clockevent_mpu_timer1.min_delta_ns = | ||
| 198 | clockevent_delta2ns(1, &clockevent_mpu_timer1); | ||
| 199 | |||
| 200 | clockevent_mpu_timer1.cpumask = cpumask_of_cpu(0); | ||
| 201 | clockevents_register_device(&clockevent_mpu_timer1); | ||
| 202 | } | ||
| 203 | |||
| 204 | |||
| 205 | /* | ||
| 206 | * --------------------------------------------------------------------------- | ||
| 207 | * MPU timer 2 ... free running 32-bit clock source and scheduler clock | ||
| 208 | * --------------------------------------------------------------------------- | ||
| 209 | */ | ||
| 210 | |||
| 211 | static unsigned long omap_mpu_timer2_overflows; | ||
| 212 | |||
| 213 | static irqreturn_t omap_mpu_timer2_interrupt(int irq, void *dev_id) | ||
| 185 | { | 214 | { | 
| 186 | omap_mpu_timer1_overflows++; | 215 | omap_mpu_timer2_overflows++; | 
| 187 | return IRQ_HANDLED; | 216 | return IRQ_HANDLED; | 
| 188 | } | 217 | } | 
| 189 | 218 | ||
| 190 | static struct irqaction omap_mpu_timer1_irq = { | 219 | static struct irqaction omap_mpu_timer2_irq = { | 
| 191 | .name = "mpu timer1 overflow", | 220 | .name = "mpu_timer2", | 
| 192 | .flags = IRQF_DISABLED, | 221 | .flags = IRQF_DISABLED, | 
| 193 | .handler = omap_mpu_timer1_interrupt, | 222 | .handler = omap_mpu_timer2_interrupt, | 
| 194 | }; | 223 | }; | 
| 195 | 224 | ||
| 196 | static __init void omap_init_mpu_timer(void) | 225 | static cycle_t mpu_read(void) | 
| 197 | { | 226 | { | 
| 198 | set_cyc2ns_scale(MPU_TICKS_PER_SEC / 1000); | 227 | return ~omap_mpu_timer_read(1); | 
| 199 | omap_timer.offset = omap_mpu_timer_gettimeoffset; | 228 | } | 
| 200 | setup_irq(INT_TIMER1, &omap_mpu_timer1_irq); | 229 | |
| 201 | setup_irq(INT_TIMER2, &omap_mpu_timer_irq); | 230 | static struct clocksource clocksource_mpu = { | 
| 202 | omap_mpu_timer_start(0, 0xffffffff); | 231 | .name = "mpu_timer2", | 
| 203 | omap_mpu_timer_start(1, MPU_TIMER_TICK_PERIOD); | 232 | .rating = 300, | 
| 233 | .read = mpu_read, | ||
| 234 | .mask = CLOCKSOURCE_MASK(32), | ||
| 235 | .shift = 24, | ||
| 236 | .flags = CLOCK_SOURCE_IS_CONTINUOUS, | ||
| 237 | }; | ||
| 238 | |||
| 239 | static void __init omap_init_clocksource(unsigned long rate) | ||
| 240 | { | ||
| 241 | static char err[] __initdata = KERN_ERR | ||
| 242 | "%s: can't register clocksource!\n"; | ||
| 243 | |||
| 244 | clocksource_mpu.mult | ||
| 245 | = clocksource_khz2mult(rate/1000, clocksource_mpu.shift); | ||
| 246 | |||
| 247 | setup_irq(INT_TIMER2, &omap_mpu_timer2_irq); | ||
| 248 | omap_mpu_timer_start(1, ~0, 1); | ||
| 249 | |||
| 250 | if (clocksource_register(&clocksource_mpu)) | ||
| 251 | printk(err, clocksource_mpu.name); | ||
| 204 | } | 252 | } | 
| 205 | 253 | ||
| 254 | |||
| 206 | /* | 255 | /* | 
| 207 | * Scheduler clock - returns current time in nanosec units. | 256 | * Scheduler clock - returns current time in nanosec units. | 
| 208 | */ | 257 | */ | 
| 209 | unsigned long long sched_clock(void) | 258 | unsigned long long sched_clock(void) | 
| 210 | { | 259 | { | 
| 211 | unsigned long ticks = 0 - omap_mpu_timer_read(0); | 260 | unsigned long ticks = 0 - omap_mpu_timer_read(1); | 
| 212 | unsigned long long ticks64; | 261 | unsigned long long ticks64; | 
| 213 | 262 | ||
| 214 | ticks64 = omap_mpu_timer1_overflows; | 263 | ticks64 = omap_mpu_timer2_overflows; | 
| 215 | ticks64 <<= 32; | 264 | ticks64 <<= 32; | 
| 216 | ticks64 |= ticks; | 265 | ticks64 |= ticks; | 
| 217 | 266 | ||
| @@ -225,10 +274,21 @@ unsigned long long sched_clock(void) | |||
| 225 | */ | 274 | */ | 
| 226 | static void __init omap_timer_init(void) | 275 | static void __init omap_timer_init(void) | 
| 227 | { | 276 | { | 
| 228 | omap_init_mpu_timer(); | 277 | struct clk *ck_ref = clk_get(NULL, "ck_ref"); | 
| 278 | unsigned long rate; | ||
| 279 | |||
| 280 | BUG_ON(IS_ERR(ck_ref)); | ||
| 281 | |||
| 282 | rate = clk_get_rate(ck_ref); | ||
| 283 | clk_put(ck_ref); | ||
| 284 | |||
| 285 | /* PTV = 0 */ | ||
| 286 | rate /= 2; | ||
| 287 | |||
| 288 | omap_init_mpu_timer(rate); | ||
| 289 | omap_init_clocksource(rate); | ||
| 229 | } | 290 | } | 
| 230 | 291 | ||
| 231 | struct sys_timer omap_timer = { | 292 | struct sys_timer omap_timer = { | 
| 232 | .init = omap_timer_init, | 293 | .init = omap_timer_init, | 
| 233 | .offset = NULL, /* Initialized later */ | ||
| 234 | }; | 294 | }; | 
| diff --git a/arch/arm/mach-pxa/generic.c b/arch/arm/mach-pxa/generic.c index b8cb79f899d5..64b08b744f9f 100644 --- a/arch/arm/mach-pxa/generic.c +++ b/arch/arm/mach-pxa/generic.c | |||
| @@ -164,9 +164,9 @@ void pxa_set_cken(int clock, int enable) | |||
| 164 | local_irq_save(flags); | 164 | local_irq_save(flags); | 
| 165 | 165 | ||
| 166 | if (enable) | 166 | if (enable) | 
| 167 | CKEN |= clock; | 167 | CKEN |= (1 << clock); | 
| 168 | else | 168 | else | 
| 169 | CKEN &= ~clock; | 169 | CKEN &= ~(1 << clock); | 
| 170 | 170 | ||
| 171 | local_irq_restore(flags); | 171 | local_irq_restore(flags); | 
| 172 | } | 172 | } | 
| diff --git a/arch/arm/mach-pxa/irq.c b/arch/arm/mach-pxa/irq.c index 9f7499b6d435..4619d5fe606c 100644 --- a/arch/arm/mach-pxa/irq.c +++ b/arch/arm/mach-pxa/irq.c | |||
| @@ -38,11 +38,33 @@ static void pxa_unmask_low_irq(unsigned int irq) | |||
| 38 | ICMR |= (1 << (irq + PXA_IRQ_SKIP)); | 38 | ICMR |= (1 << (irq + PXA_IRQ_SKIP)); | 
| 39 | } | 39 | } | 
| 40 | 40 | ||
| 41 | static int pxa_set_wake(unsigned int irq, unsigned int on) | ||
| 42 | { | ||
| 43 | u32 mask; | ||
| 44 | |||
| 45 | switch (irq) { | ||
| 46 | case IRQ_RTCAlrm: | ||
| 47 | mask = PWER_RTC; | ||
| 48 | break; | ||
| 49 | #ifdef CONFIG_PXA27x | ||
| 50 | /* REVISIT can handle USBH1, USBH2, USB, MSL, USIM, ... */ | ||
| 51 | #endif | ||
| 52 | default: | ||
| 53 | return -EINVAL; | ||
| 54 | } | ||
| 55 | if (on) | ||
| 56 | PWER |= mask; | ||
| 57 | else | ||
| 58 | PWER &= ~mask; | ||
| 59 | return 0; | ||
| 60 | } | ||
| 61 | |||
| 41 | static struct irq_chip pxa_internal_chip_low = { | 62 | static struct irq_chip pxa_internal_chip_low = { | 
| 42 | .name = "SC", | 63 | .name = "SC", | 
| 43 | .ack = pxa_mask_low_irq, | 64 | .ack = pxa_mask_low_irq, | 
| 44 | .mask = pxa_mask_low_irq, | 65 | .mask = pxa_mask_low_irq, | 
| 45 | .unmask = pxa_unmask_low_irq, | 66 | .unmask = pxa_unmask_low_irq, | 
| 67 | .set_wake = pxa_set_wake, | ||
| 46 | }; | 68 | }; | 
| 47 | 69 | ||
| 48 | #if PXA_INTERNAL_IRQS > 32 | 70 | #if PXA_INTERNAL_IRQS > 32 | 
| @@ -70,6 +92,26 @@ static struct irq_chip pxa_internal_chip_high = { | |||
| 70 | 92 | ||
| 71 | #endif | 93 | #endif | 
| 72 | 94 | ||
| 95 | /* Note that if an input/irq line ever gets changed to an output during | ||
| 96 | * suspend, the relevant PWER, PRER, and PFER bits should be cleared. | ||
| 97 | */ | ||
| 98 | #ifdef CONFIG_PXA27x | ||
| 99 | |||
| 100 | /* PXA27x: Various gpios can issue wakeup events. This logic only | ||
| 101 | * handles the simple cases, not the WEMUX2 and WEMUX3 options | ||
| 102 | */ | ||
| 103 | #define PXA27x_GPIO_NOWAKE_MASK \ | ||
| 104 | ((1 << 8) | (1 << 7) | (1 << 6) | (1 << 5) | (1 << 2)) | ||
| 105 | #define WAKEMASK(gpio) \ | ||
| 106 | (((gpio) <= 15) \ | ||
| 107 | ? ((1 << (gpio)) & ~PXA27x_GPIO_NOWAKE_MASK) \ | ||
| 108 | : ((gpio == 35) ? (1 << 24) : 0)) | ||
| 109 | #else | ||
| 110 | |||
| 111 | /* pxa 210, 250, 255, 26x: gpios 0..15 can issue wakeups */ | ||
| 112 | #define WAKEMASK(gpio) (((gpio) <= 15) ? (1 << (gpio)) : 0) | ||
| 113 | #endif | ||
| 114 | |||
| 73 | /* | 115 | /* | 
| 74 | * PXA GPIO edge detection for IRQs: | 116 | * PXA GPIO edge detection for IRQs: | 
| 75 | * IRQs are generated on Falling-Edge, Rising-Edge, or both. | 117 | * IRQs are generated on Falling-Edge, Rising-Edge, or both. | 
| @@ -83,9 +125,11 @@ static long GPIO_IRQ_mask[4]; | |||
| 83 | static int pxa_gpio_irq_type(unsigned int irq, unsigned int type) | 125 | static int pxa_gpio_irq_type(unsigned int irq, unsigned int type) | 
| 84 | { | 126 | { | 
| 85 | int gpio, idx; | 127 | int gpio, idx; | 
| 128 | u32 mask; | ||
| 86 | 129 | ||
| 87 | gpio = IRQ_TO_GPIO(irq); | 130 | gpio = IRQ_TO_GPIO(irq); | 
| 88 | idx = gpio >> 5; | 131 | idx = gpio >> 5; | 
| 132 | mask = WAKEMASK(gpio); | ||
| 89 | 133 | ||
| 90 | if (type == IRQT_PROBE) { | 134 | if (type == IRQT_PROBE) { | 
| 91 | /* Don't mess with enabled GPIOs using preconfigured edges or | 135 | /* Don't mess with enabled GPIOs using preconfigured edges or | 
| @@ -105,14 +149,20 @@ static int pxa_gpio_irq_type(unsigned int irq, unsigned int type) | |||
| 105 | if (type & __IRQT_RISEDGE) { | 149 | if (type & __IRQT_RISEDGE) { | 
| 106 | /* printk("rising "); */ | 150 | /* printk("rising "); */ | 
| 107 | __set_bit (gpio, GPIO_IRQ_rising_edge); | 151 | __set_bit (gpio, GPIO_IRQ_rising_edge); | 
| 108 | } else | 152 | PRER |= mask; | 
| 153 | } else { | ||
| 109 | __clear_bit (gpio, GPIO_IRQ_rising_edge); | 154 | __clear_bit (gpio, GPIO_IRQ_rising_edge); | 
| 155 | PRER &= ~mask; | ||
| 156 | } | ||
| 110 | 157 | ||
| 111 | if (type & __IRQT_FALEDGE) { | 158 | if (type & __IRQT_FALEDGE) { | 
| 112 | /* printk("falling "); */ | 159 | /* printk("falling "); */ | 
| 113 | __set_bit (gpio, GPIO_IRQ_falling_edge); | 160 | __set_bit (gpio, GPIO_IRQ_falling_edge); | 
| 114 | } else | 161 | PFER |= mask; | 
| 162 | } else { | ||
| 115 | __clear_bit (gpio, GPIO_IRQ_falling_edge); | 163 | __clear_bit (gpio, GPIO_IRQ_falling_edge); | 
| 164 | PFER &= ~mask; | ||
| 165 | } | ||
| 116 | 166 | ||
| 117 | /* printk("edges\n"); */ | 167 | /* printk("edges\n"); */ | 
| 118 | 168 | ||
| @@ -130,12 +180,29 @@ static void pxa_ack_low_gpio(unsigned int irq) | |||
| 130 | GEDR0 = (1 << (irq - IRQ_GPIO0)); | 180 | GEDR0 = (1 << (irq - IRQ_GPIO0)); | 
| 131 | } | 181 | } | 
| 132 | 182 | ||
| 183 | static int pxa_set_gpio_wake(unsigned int irq, unsigned int on) | ||
| 184 | { | ||
| 185 | int gpio = IRQ_TO_GPIO(irq); | ||
| 186 | u32 mask = WAKEMASK(gpio); | ||
| 187 | |||
| 188 | if (!mask) | ||
| 189 | return -EINVAL; | ||
| 190 | |||
| 191 | if (on) | ||
| 192 | PWER |= mask; | ||
| 193 | else | ||
| 194 | PWER &= ~mask; | ||
| 195 | return 0; | ||
| 196 | } | ||
| 197 | |||
| 198 | |||
| 133 | static struct irq_chip pxa_low_gpio_chip = { | 199 | static struct irq_chip pxa_low_gpio_chip = { | 
| 134 | .name = "GPIO-l", | 200 | .name = "GPIO-l", | 
| 135 | .ack = pxa_ack_low_gpio, | 201 | .ack = pxa_ack_low_gpio, | 
| 136 | .mask = pxa_mask_low_irq, | 202 | .mask = pxa_mask_low_irq, | 
| 137 | .unmask = pxa_unmask_low_irq, | 203 | .unmask = pxa_unmask_low_irq, | 
| 138 | .set_type = pxa_gpio_irq_type, | 204 | .set_type = pxa_gpio_irq_type, | 
| 205 | .set_wake = pxa_set_gpio_wake, | ||
| 139 | }; | 206 | }; | 
| 140 | 207 | ||
| 141 | /* | 208 | /* | 
| @@ -244,6 +311,7 @@ static struct irq_chip pxa_muxed_gpio_chip = { | |||
| 244 | .mask = pxa_mask_muxed_gpio, | 311 | .mask = pxa_mask_muxed_gpio, | 
| 245 | .unmask = pxa_unmask_muxed_gpio, | 312 | .unmask = pxa_unmask_muxed_gpio, | 
| 246 | .set_type = pxa_gpio_irq_type, | 313 | .set_type = pxa_gpio_irq_type, | 
| 314 | .set_wake = pxa_set_gpio_wake, | ||
| 247 | }; | 315 | }; | 
| 248 | 316 | ||
| 249 | 317 | ||
| diff --git a/arch/arm/mach-pxa/lpd270.c b/arch/arm/mach-pxa/lpd270.c index 8e27a64fa9f4..e3097664ffe1 100644 --- a/arch/arm/mach-pxa/lpd270.c +++ b/arch/arm/mach-pxa/lpd270.c | |||
| @@ -234,7 +234,7 @@ static void lpd270_backlight_power(int on) | |||
| 234 | { | 234 | { | 
| 235 | if (on) { | 235 | if (on) { | 
| 236 | pxa_gpio_mode(GPIO16_PWM0_MD); | 236 | pxa_gpio_mode(GPIO16_PWM0_MD); | 
| 237 | pxa_set_cken(CKEN0_PWM0, 1); | 237 | pxa_set_cken(CKEN_PWM0, 1); | 
| 238 | PWM_CTRL0 = 0; | 238 | PWM_CTRL0 = 0; | 
| 239 | PWM_PWDUTY0 = 0x3ff; | 239 | PWM_PWDUTY0 = 0x3ff; | 
| 240 | PWM_PERVAL0 = 0x3ff; | 240 | PWM_PERVAL0 = 0x3ff; | 
| @@ -242,7 +242,7 @@ static void lpd270_backlight_power(int on) | |||
| 242 | PWM_CTRL0 = 0; | 242 | PWM_CTRL0 = 0; | 
| 243 | PWM_PWDUTY0 = 0x0; | 243 | PWM_PWDUTY0 = 0x0; | 
| 244 | PWM_PERVAL0 = 0x3FF; | 244 | PWM_PERVAL0 = 0x3FF; | 
| 245 | pxa_set_cken(CKEN0_PWM0, 0); | 245 | pxa_set_cken(CKEN_PWM0, 0); | 
| 246 | } | 246 | } | 
| 247 | } | 247 | } | 
| 248 | 248 | ||
| diff --git a/arch/arm/mach-pxa/lubbock.c b/arch/arm/mach-pxa/lubbock.c index 055de7f4f00a..6377b2e29ff0 100644 --- a/arch/arm/mach-pxa/lubbock.c +++ b/arch/arm/mach-pxa/lubbock.c | |||
| @@ -220,7 +220,7 @@ static struct resource pxa_ssp_resources[] = { | |||
| 220 | 220 | ||
| 221 | static struct pxa2xx_spi_master pxa_ssp_master_info = { | 221 | static struct pxa2xx_spi_master pxa_ssp_master_info = { | 
| 222 | .ssp_type = PXA25x_SSP, | 222 | .ssp_type = PXA25x_SSP, | 
| 223 | .clock_enable = CKEN3_SSP, | 223 | .clock_enable = CKEN_SSP, | 
| 224 | .num_chipselect = 0, | 224 | .num_chipselect = 0, | 
| 225 | }; | 225 | }; | 
| 226 | 226 | ||
| diff --git a/arch/arm/mach-pxa/mainstone.c b/arch/arm/mach-pxa/mainstone.c index 56d94d88d5ca..ed99a81b98f3 100644 --- a/arch/arm/mach-pxa/mainstone.c +++ b/arch/arm/mach-pxa/mainstone.c | |||
| @@ -266,7 +266,7 @@ static void mainstone_backlight_power(int on) | |||
| 266 | { | 266 | { | 
| 267 | if (on) { | 267 | if (on) { | 
| 268 | pxa_gpio_mode(GPIO16_PWM0_MD); | 268 | pxa_gpio_mode(GPIO16_PWM0_MD); | 
| 269 | pxa_set_cken(CKEN0_PWM0, 1); | 269 | pxa_set_cken(CKEN_PWM0, 1); | 
| 270 | PWM_CTRL0 = 0; | 270 | PWM_CTRL0 = 0; | 
| 271 | PWM_PWDUTY0 = 0x3ff; | 271 | PWM_PWDUTY0 = 0x3ff; | 
| 272 | PWM_PERVAL0 = 0x3ff; | 272 | PWM_PERVAL0 = 0x3ff; | 
| @@ -274,7 +274,7 @@ static void mainstone_backlight_power(int on) | |||
| 274 | PWM_CTRL0 = 0; | 274 | PWM_CTRL0 = 0; | 
| 275 | PWM_PWDUTY0 = 0x0; | 275 | PWM_PWDUTY0 = 0x0; | 
| 276 | PWM_PERVAL0 = 0x3FF; | 276 | PWM_PERVAL0 = 0x3FF; | 
| 277 | pxa_set_cken(CKEN0_PWM0, 0); | 277 | pxa_set_cken(CKEN_PWM0, 0); | 
| 278 | } | 278 | } | 
| 279 | } | 279 | } | 
| 280 | 280 | ||
| diff --git a/arch/arm/mach-pxa/pxa27x.c b/arch/arm/mach-pxa/pxa27x.c index 74eeada1e2fc..c64bab49efc4 100644 --- a/arch/arm/mach-pxa/pxa27x.c +++ b/arch/arm/mach-pxa/pxa27x.c | |||
| @@ -140,9 +140,9 @@ void pxa_cpu_pm_enter(suspend_state_t state) | |||
| 140 | extern void pxa_cpu_resume(void); | 140 | extern void pxa_cpu_resume(void); | 
| 141 | 141 | ||
| 142 | if (state == PM_SUSPEND_STANDBY) | 142 | if (state == PM_SUSPEND_STANDBY) | 
| 143 | CKEN = CKEN22_MEMC | CKEN9_OSTIMER | CKEN16_LCD |CKEN0_PWM0; | 143 | CKEN = CKEN_MEMC | CKEN_OSTIMER | CKEN_LCD | CKEN_PWM0; | 
| 144 | else | 144 | else | 
| 145 | CKEN = CKEN22_MEMC | CKEN9_OSTIMER; | 145 | CKEN = CKEN_MEMC | CKEN_OSTIMER; | 
| 146 | 146 | ||
| 147 | /* ensure voltage-change sequencer not initiated, which hangs */ | 147 | /* ensure voltage-change sequencer not initiated, which hangs */ | 
| 148 | PCFR &= ~PCFR_FVC; | 148 | PCFR &= ~PCFR_FVC; | 
| diff --git a/arch/arm/mach-pxa/ssp.c b/arch/arm/mach-pxa/ssp.c index 6cc202755fb4..71766ac0328b 100644 --- a/arch/arm/mach-pxa/ssp.c +++ b/arch/arm/mach-pxa/ssp.c | |||
| @@ -52,13 +52,13 @@ struct ssp_info_ { | |||
| 52 | */ | 52 | */ | 
| 53 | static const struct ssp_info_ ssp_info[PXA_SSP_PORTS] = { | 53 | static const struct ssp_info_ ssp_info[PXA_SSP_PORTS] = { | 
| 54 | #if defined (CONFIG_PXA27x) | 54 | #if defined (CONFIG_PXA27x) | 
| 55 | {IRQ_SSP, CKEN23_SSP1}, | 55 | {IRQ_SSP, CKEN_SSP1}, | 
| 56 | {IRQ_SSP2, CKEN3_SSP2}, | 56 | {IRQ_SSP2, CKEN_SSP2}, | 
| 57 | {IRQ_SSP3, CKEN4_SSP3}, | 57 | {IRQ_SSP3, CKEN_SSP3}, | 
| 58 | #else | 58 | #else | 
| 59 | {IRQ_SSP, CKEN3_SSP}, | 59 | {IRQ_SSP, CKEN_SSP}, | 
| 60 | {IRQ_NSSP, CKEN9_NSSP}, | 60 | {IRQ_NSSP, CKEN_NSSP}, | 
| 61 | {IRQ_ASSP, CKEN10_ASSP}, | 61 | {IRQ_ASSP, CKEN_ASSP}, | 
| 62 | #endif | 62 | #endif | 
| 63 | }; | 63 | }; | 
| 64 | 64 | ||
| diff --git a/arch/arm/mach-rpc/riscpc.c b/arch/arm/mach-rpc/riscpc.c index 208a2b5dba1b..570cf937e73b 100644 --- a/arch/arm/mach-rpc/riscpc.c +++ b/arch/arm/mach-rpc/riscpc.c | |||
| @@ -17,6 +17,7 @@ | |||
| 17 | #include <linux/sched.h> | 17 | #include <linux/sched.h> | 
| 18 | #include <linux/device.h> | 18 | #include <linux/device.h> | 
| 19 | #include <linux/serial_8250.h> | 19 | #include <linux/serial_8250.h> | 
| 20 | #include <linux/pata_platform.h> | ||
| 20 | 21 | ||
| 21 | #include <asm/elf.h> | 22 | #include <asm/elf.h> | 
| 22 | #include <asm/io.h> | 23 | #include <asm/io.h> | 
| @@ -159,11 +160,45 @@ static struct platform_device serial_device = { | |||
| 159 | }, | 160 | }, | 
| 160 | }; | 161 | }; | 
| 161 | 162 | ||
| 163 | static struct pata_platform_info pata_platform_data = { | ||
| 164 | .ioport_shift = 2, | ||
| 165 | }; | ||
| 166 | |||
| 167 | static struct resource pata_resources[] = { | ||
| 168 | [0] = { | ||
| 169 | .start = 0x030107c0, | ||
| 170 | .end = 0x030107df, | ||
| 171 | .flags = IORESOURCE_MEM, | ||
| 172 | }, | ||
| 173 | [1] = { | ||
| 174 | .start = 0x03010fd8, | ||
| 175 | .end = 0x03010fdb, | ||
| 176 | .flags = IORESOURCE_MEM, | ||
| 177 | }, | ||
| 178 | [2] = { | ||
| 179 | .start = IRQ_HARDDISK, | ||
| 180 | .end = IRQ_HARDDISK, | ||
| 181 | .flags = IORESOURCE_IRQ, | ||
| 182 | }, | ||
| 183 | }; | ||
| 184 | |||
| 185 | static struct platform_device pata_device = { | ||
| 186 | .name = "pata_platform", | ||
| 187 | .id = -1, | ||
| 188 | .num_resources = ARRAY_SIZE(pata_resources), | ||
| 189 | .resource = pata_resources, | ||
| 190 | .dev = { | ||
| 191 | .platform_data = &pata_platform_data, | ||
| 192 | .coherent_dma_mask = ~0, /* grumble */ | ||
| 193 | }, | ||
| 194 | }; | ||
| 195 | |||
| 162 | static struct platform_device *devs[] __initdata = { | 196 | static struct platform_device *devs[] __initdata = { | 
| 163 | &iomd_device, | 197 | &iomd_device, | 
| 164 | &kbd_device, | 198 | &kbd_device, | 
| 165 | &serial_device, | 199 | &serial_device, | 
| 166 | &acornfb_device, | 200 | &acornfb_device, | 
| 201 | &pata_device, | ||
| 167 | }; | 202 | }; | 
| 168 | 203 | ||
| 169 | static int __init rpc_init(void) | 204 | static int __init rpc_init(void) | 
| diff --git a/arch/arm/mach-s3c2410/mach-amlm5900.c b/arch/arm/mach-s3c2410/mach-amlm5900.c index 72f2cc4fcd03..bc308ceb91c3 100644 --- a/arch/arm/mach-s3c2410/mach-amlm5900.c +++ b/arch/arm/mach-s3c2410/mach-amlm5900.c | |||
| @@ -160,17 +160,11 @@ static struct platform_device *amlm5900_devices[] __initdata = { | |||
| 160 | #endif | 160 | #endif | 
| 161 | }; | 161 | }; | 
| 162 | 162 | ||
| 163 | static struct s3c24xx_board amlm5900_board __initdata = { | ||
| 164 | .devices = amlm5900_devices, | ||
| 165 | .devices_count = ARRAY_SIZE(amlm5900_devices) | ||
| 166 | }; | ||
| 167 | |||
| 168 | void __init amlm5900_map_io(void) | 163 | void __init amlm5900_map_io(void) | 
| 169 | { | 164 | { | 
| 170 | s3c24xx_init_io(amlm5900_iodesc, ARRAY_SIZE(amlm5900_iodesc)); | 165 | s3c24xx_init_io(amlm5900_iodesc, ARRAY_SIZE(amlm5900_iodesc)); | 
| 171 | s3c24xx_init_clocks(0); | 166 | s3c24xx_init_clocks(0); | 
| 172 | s3c24xx_init_uarts(amlm5900_uartcfgs, ARRAY_SIZE(amlm5900_uartcfgs)); | 167 | s3c24xx_init_uarts(amlm5900_uartcfgs, ARRAY_SIZE(amlm5900_uartcfgs)); | 
| 173 | s3c24xx_set_board(&amlm5900_board); | ||
| 174 | } | 168 | } | 
| 175 | 169 | ||
| 176 | #ifdef CONFIG_FB_S3C2410 | 170 | #ifdef CONFIG_FB_S3C2410 | 
| @@ -247,6 +241,7 @@ static void __init amlm5900_init(void) | |||
| 247 | #ifdef CONFIG_FB_S3C2410 | 241 | #ifdef CONFIG_FB_S3C2410 | 
| 248 | s3c24xx_fb_set_platdata(&amlm5900_lcd_info); | 242 | s3c24xx_fb_set_platdata(&amlm5900_lcd_info); | 
| 249 | #endif | 243 | #endif | 
| 244 | platform_add_devices(amlm5900_devices, ARRAY_SIZE(amlm5900_devices)); | ||
| 250 | } | 245 | } | 
| 251 | 246 | ||
| 252 | MACHINE_START(AML_M5900, "AML_M5900") | 247 | MACHINE_START(AML_M5900, "AML_M5900") | 
| diff --git a/arch/arm/mach-s3c2410/mach-bast.c b/arch/arm/mach-s3c2410/mach-bast.c index 7b81296427eb..f01de807b72f 100644 --- a/arch/arm/mach-s3c2410/mach-bast.c +++ b/arch/arm/mach-s3c2410/mach-bast.c | |||
| @@ -464,13 +464,6 @@ static struct clk *bast_clocks[] = { | |||
| 464 | &s3c24xx_uclk, | 464 | &s3c24xx_uclk, | 
| 465 | }; | 465 | }; | 
| 466 | 466 | ||
| 467 | static struct s3c24xx_board bast_board __initdata = { | ||
| 468 | .devices = bast_devices, | ||
| 469 | .devices_count = ARRAY_SIZE(bast_devices), | ||
| 470 | .clocks = bast_clocks, | ||
| 471 | .clocks_count = ARRAY_SIZE(bast_clocks), | ||
| 472 | }; | ||
| 473 | |||
| 474 | static void __init bast_map_io(void) | 467 | static void __init bast_map_io(void) | 
| 475 | { | 468 | { | 
| 476 | /* initialise the clocks */ | 469 | /* initialise the clocks */ | 
| @@ -486,19 +479,22 @@ static void __init bast_map_io(void) | |||
| 486 | 479 | ||
| 487 | s3c24xx_uclk.parent = &s3c24xx_clkout1; | 480 | s3c24xx_uclk.parent = &s3c24xx_clkout1; | 
| 488 | 481 | ||
| 482 | s3c24xx_register_clocks(bast_clocks, ARRAY_SIZE(bast_clocks)); | ||
| 483 | |||
| 489 | s3c_device_nand.dev.platform_data = &bast_nand_info; | 484 | s3c_device_nand.dev.platform_data = &bast_nand_info; | 
| 490 | s3c_device_i2c.dev.platform_data = &bast_i2c_info; | 485 | s3c_device_i2c.dev.platform_data = &bast_i2c_info; | 
| 491 | 486 | ||
| 492 | s3c24xx_init_io(bast_iodesc, ARRAY_SIZE(bast_iodesc)); | 487 | s3c24xx_init_io(bast_iodesc, ARRAY_SIZE(bast_iodesc)); | 
| 493 | s3c24xx_init_clocks(0); | 488 | s3c24xx_init_clocks(0); | 
| 494 | s3c24xx_init_uarts(bast_uartcfgs, ARRAY_SIZE(bast_uartcfgs)); | 489 | s3c24xx_init_uarts(bast_uartcfgs, ARRAY_SIZE(bast_uartcfgs)); | 
| 495 | s3c24xx_set_board(&bast_board); | 490 | |
| 496 | usb_simtec_init(); | 491 | usb_simtec_init(); | 
| 497 | } | 492 | } | 
| 498 | 493 | ||
| 499 | static void __init bast_init(void) | 494 | static void __init bast_init(void) | 
| 500 | { | 495 | { | 
| 501 | s3c24xx_fb_set_platdata(&bast_lcd_info); | 496 | s3c24xx_fb_set_platdata(&bast_lcd_info); | 
| 497 | platform_add_devices(bast_devices, ARRAY_SIZE(bast_devices)); | ||
| 502 | } | 498 | } | 
| 503 | 499 | ||
| 504 | MACHINE_START(BAST, "Simtec-BAST") | 500 | MACHINE_START(BAST, "Simtec-BAST") | 
| diff --git a/arch/arm/mach-s3c2410/mach-h1940.c b/arch/arm/mach-s3c2410/mach-h1940.c index d052ab2d9377..5d5f00e9c462 100644 --- a/arch/arm/mach-s3c2410/mach-h1940.c +++ b/arch/arm/mach-s3c2410/mach-h1940.c | |||
| @@ -129,7 +129,6 @@ static struct s3c2410_udc_mach_info h1940_udc_cfg __initdata = { | |||
| 129 | }; | 129 | }; | 
| 130 | 130 | ||
| 131 | 131 | ||
| 132 | |||
| 133 | /** | 132 | /** | 
| 134 | * Set lcd on or off | 133 | * Set lcd on or off | 
| 135 | **/ | 134 | **/ | 
| @@ -188,17 +187,11 @@ static struct platform_device *h1940_devices[] __initdata = { | |||
| 188 | &s3c_device_leds, | 187 | &s3c_device_leds, | 
| 189 | }; | 188 | }; | 
| 190 | 189 | ||
| 191 | static struct s3c24xx_board h1940_board __initdata = { | ||
| 192 | .devices = h1940_devices, | ||
| 193 | .devices_count = ARRAY_SIZE(h1940_devices) | ||
| 194 | }; | ||
| 195 | |||
| 196 | static void __init h1940_map_io(void) | 190 | static void __init h1940_map_io(void) | 
| 197 | { | 191 | { | 
| 198 | s3c24xx_init_io(h1940_iodesc, ARRAY_SIZE(h1940_iodesc)); | 192 | s3c24xx_init_io(h1940_iodesc, ARRAY_SIZE(h1940_iodesc)); | 
| 199 | s3c24xx_init_clocks(0); | 193 | s3c24xx_init_clocks(0); | 
| 200 | s3c24xx_init_uarts(h1940_uartcfgs, ARRAY_SIZE(h1940_uartcfgs)); | 194 | s3c24xx_init_uarts(h1940_uartcfgs, ARRAY_SIZE(h1940_uartcfgs)); | 
| 201 | s3c24xx_set_board(&h1940_board); | ||
| 202 | 195 | ||
| 203 | /* setup PM */ | 196 | /* setup PM */ | 
| 204 | 197 | ||
| @@ -232,6 +225,8 @@ static void __init h1940_init(void) | |||
| 232 | | (0x02 << S3C2410_PLLCON_PDIVSHIFT) | 225 | | (0x02 << S3C2410_PLLCON_PDIVSHIFT) | 
| 233 | | (0x03 << S3C2410_PLLCON_SDIVSHIFT); | 226 | | (0x03 << S3C2410_PLLCON_SDIVSHIFT); | 
| 234 | writel(tmp, S3C2410_UPLLCON); | 227 | writel(tmp, S3C2410_UPLLCON); | 
| 228 | |||
| 229 | platform_add_devices(h1940_devices, ARRAY_SIZE(h1940_devices)); | ||
| 235 | } | 230 | } | 
| 236 | 231 | ||
| 237 | MACHINE_START(H1940, "IPAQ-H1940") | 232 | MACHINE_START(H1940, "IPAQ-H1940") | 
| diff --git a/arch/arm/mach-s3c2410/mach-n30.c b/arch/arm/mach-s3c2410/mach-n30.c index 261aa4cc0770..412e50c3d28a 100644 --- a/arch/arm/mach-s3c2410/mach-n30.c +++ b/arch/arm/mach-s3c2410/mach-n30.c | |||
| @@ -90,17 +90,11 @@ static struct s3c2410_platform_i2c n30_i2ccfg = { | |||
| 90 | .max_freq = 10*1000, | 90 | .max_freq = 10*1000, | 
| 91 | }; | 91 | }; | 
| 92 | 92 | ||
| 93 | static struct s3c24xx_board n30_board __initdata = { | ||
| 94 | .devices = n30_devices, | ||
| 95 | .devices_count = ARRAY_SIZE(n30_devices) | ||
| 96 | }; | ||
| 97 | |||
| 98 | static void __init n30_map_io(void) | 93 | static void __init n30_map_io(void) | 
| 99 | { | 94 | { | 
| 100 | s3c24xx_init_io(n30_iodesc, ARRAY_SIZE(n30_iodesc)); | 95 | s3c24xx_init_io(n30_iodesc, ARRAY_SIZE(n30_iodesc)); | 
| 101 | s3c24xx_init_clocks(0); | 96 | s3c24xx_init_clocks(0); | 
| 102 | s3c24xx_init_uarts(n30_uartcfgs, ARRAY_SIZE(n30_uartcfgs)); | 97 | s3c24xx_init_uarts(n30_uartcfgs, ARRAY_SIZE(n30_uartcfgs)); | 
| 103 | s3c24xx_set_board(&n30_board); | ||
| 104 | } | 98 | } | 
| 105 | 99 | ||
| 106 | static void __init n30_init_irq(void) | 100 | static void __init n30_init_irq(void) | 
| @@ -120,6 +114,8 @@ static void __init n30_init(void) | |||
| 120 | s3c2410_modify_misccr(S3C2410_MISCCR_USBHOST | | 114 | s3c2410_modify_misccr(S3C2410_MISCCR_USBHOST | | 
| 121 | S3C2410_MISCCR_USBSUSPND0 | | 115 | S3C2410_MISCCR_USBSUSPND0 | | 
| 122 | S3C2410_MISCCR_USBSUSPND1, 0x0); | 116 | S3C2410_MISCCR_USBSUSPND1, 0x0); | 
| 117 | |||
| 118 | platform_add_devices(n30_devices, ARRAY_SIZE(n30_devices)); | ||
| 123 | } | 119 | } | 
| 124 | 120 | ||
| 125 | MACHINE_START(N30, "Acer-N30") | 121 | MACHINE_START(N30, "Acer-N30") | 
| diff --git a/arch/arm/mach-s3c2410/mach-otom.c b/arch/arm/mach-s3c2410/mach-otom.c index c78ab75b44f3..1f899fa588df 100644 --- a/arch/arm/mach-s3c2410/mach-otom.c +++ b/arch/arm/mach-s3c2410/mach-otom.c | |||
| @@ -100,20 +100,17 @@ static struct platform_device *otom11_devices[] __initdata = { | |||
| 100 | &otom_device_nor, | 100 | &otom_device_nor, | 
| 101 | }; | 101 | }; | 
| 102 | 102 | ||
| 103 | static struct s3c24xx_board otom11_board __initdata = { | ||
| 104 | .devices = otom11_devices, | ||
| 105 | .devices_count = ARRAY_SIZE(otom11_devices) | ||
| 106 | }; | ||
| 107 | |||
| 108 | |||
| 109 | static void __init otom11_map_io(void) | 103 | static void __init otom11_map_io(void) | 
| 110 | { | 104 | { | 
| 111 | s3c24xx_init_io(otom11_iodesc, ARRAY_SIZE(otom11_iodesc)); | 105 | s3c24xx_init_io(otom11_iodesc, ARRAY_SIZE(otom11_iodesc)); | 
| 112 | s3c24xx_init_clocks(0); | 106 | s3c24xx_init_clocks(0); | 
| 113 | s3c24xx_init_uarts(otom11_uartcfgs, ARRAY_SIZE(otom11_uartcfgs)); | 107 | s3c24xx_init_uarts(otom11_uartcfgs, ARRAY_SIZE(otom11_uartcfgs)); | 
| 114 | s3c24xx_set_board(&otom11_board); | ||
| 115 | } | 108 | } | 
| 116 | 109 | ||
| 110 | static void __init otom11_init(void) | ||
| 111 | { | ||
| 112 | platform_add_devices(otom11_devices, ARRAY_SIZE(otom11_devices)); | ||
| 113 | } | ||
| 117 | 114 | ||
| 118 | MACHINE_START(OTOM, "Nex Vision - Otom 1.1") | 115 | MACHINE_START(OTOM, "Nex Vision - Otom 1.1") | 
| 119 | /* Maintainer: Guillaume GOURAT <guillaume.gourat@nexvision.tv> */ | 116 | /* Maintainer: Guillaume GOURAT <guillaume.gourat@nexvision.tv> */ | 
| @@ -121,6 +118,7 @@ MACHINE_START(OTOM, "Nex Vision - Otom 1.1") | |||
| 121 | .io_pg_offst = (((u32)S3C24XX_VA_UART) >> 18) & 0xfffc, | 118 | .io_pg_offst = (((u32)S3C24XX_VA_UART) >> 18) & 0xfffc, | 
| 122 | .boot_params = S3C2410_SDRAM_PA + 0x100, | 119 | .boot_params = S3C2410_SDRAM_PA + 0x100, | 
| 123 | .map_io = otom11_map_io, | 120 | .map_io = otom11_map_io, | 
| 121 | .init_machine = otom11_init, | ||
| 124 | .init_irq = s3c24xx_init_irq, | 122 | .init_irq = s3c24xx_init_irq, | 
| 125 | .timer = &s3c24xx_timer, | 123 | .timer = &s3c24xx_timer, | 
| 126 | MACHINE_END | 124 | MACHINE_END | 
| diff --git a/arch/arm/mach-s3c2410/mach-qt2410.c b/arch/arm/mach-s3c2410/mach-qt2410.c index c6a41593de21..9cc4253d7bbc 100644 --- a/arch/arm/mach-s3c2410/mach-qt2410.c +++ b/arch/arm/mach-s3c2410/mach-qt2410.c | |||
| @@ -29,7 +29,6 @@ | |||
| 29 | #include <linux/init.h> | 29 | #include <linux/init.h> | 
| 30 | #include <linux/platform_device.h> | 30 | #include <linux/platform_device.h> | 
| 31 | #include <linux/serial_core.h> | 31 | #include <linux/serial_core.h> | 
| 32 | #include <linux/mmc/protocol.h> | ||
| 33 | #include <linux/spi/spi.h> | 32 | #include <linux/spi/spi.h> | 
| 34 | #include <linux/spi/spi_bitbang.h> | 33 | #include <linux/spi/spi_bitbang.h> | 
| 35 | 34 | ||
| @@ -331,11 +330,6 @@ static struct platform_device *qt2410_devices[] __initdata = { | |||
| 331 | &qt2410_led, | 330 | &qt2410_led, | 
| 332 | }; | 331 | }; | 
| 333 | 332 | ||
| 334 | static struct s3c24xx_board qt2410_board __initdata = { | ||
| 335 | .devices = qt2410_devices, | ||
| 336 | .devices_count = ARRAY_SIZE(qt2410_devices) | ||
| 337 | }; | ||
| 338 | |||
| 339 | static struct mtd_partition qt2410_nand_part[] = { | 333 | static struct mtd_partition qt2410_nand_part[] = { | 
| 340 | [0] = { | 334 | [0] = { | 
| 341 | .name = "U-Boot", | 335 | .name = "U-Boot", | 
| @@ -405,7 +399,6 @@ static void __init qt2410_map_io(void) | |||
| 405 | s3c24xx_init_io(qt2410_iodesc, ARRAY_SIZE(qt2410_iodesc)); | 399 | s3c24xx_init_io(qt2410_iodesc, ARRAY_SIZE(qt2410_iodesc)); | 
| 406 | s3c24xx_init_clocks(12*1000*1000); | 400 | s3c24xx_init_clocks(12*1000*1000); | 
| 407 | s3c24xx_init_uarts(smdk2410_uartcfgs, ARRAY_SIZE(smdk2410_uartcfgs)); | 401 | s3c24xx_init_uarts(smdk2410_uartcfgs, ARRAY_SIZE(smdk2410_uartcfgs)); | 
| 408 | s3c24xx_set_board(&qt2410_board); | ||
| 409 | } | 402 | } | 
| 410 | 403 | ||
| 411 | static void __init qt2410_machine_init(void) | 404 | static void __init qt2410_machine_init(void) | 
| @@ -432,6 +425,7 @@ static void __init qt2410_machine_init(void) | |||
| 432 | 425 | ||
| 433 | s3c2410_gpio_cfgpin(S3C2410_GPB5, S3C2410_GPIO_OUTPUT); | 426 | s3c2410_gpio_cfgpin(S3C2410_GPB5, S3C2410_GPIO_OUTPUT); | 
| 434 | 427 | ||
| 428 | platform_add_devices(qt2410_devices, ARRAY_SIZE(qt2410_devices)); | ||
| 435 | s3c2410_pm_init(); | 429 | s3c2410_pm_init(); | 
| 436 | } | 430 | } | 
| 437 | 431 | ||
| diff --git a/arch/arm/mach-s3c2410/mach-smdk2410.c b/arch/arm/mach-s3c2410/mach-smdk2410.c index 57b8a80f33d0..5852d300d52f 100644 --- a/arch/arm/mach-s3c2410/mach-smdk2410.c +++ b/arch/arm/mach-s3c2410/mach-smdk2410.c | |||
| @@ -94,17 +94,17 @@ static struct platform_device *smdk2410_devices[] __initdata = { | |||
| 94 | &s3c_device_iis, | 94 | &s3c_device_iis, | 
| 95 | }; | 95 | }; | 
| 96 | 96 | ||
| 97 | static struct s3c24xx_board smdk2410_board __initdata = { | ||
| 98 | .devices = smdk2410_devices, | ||
| 99 | .devices_count = ARRAY_SIZE(smdk2410_devices) | ||
| 100 | }; | ||
| 101 | |||
| 102 | static void __init smdk2410_map_io(void) | 97 | static void __init smdk2410_map_io(void) | 
| 103 | { | 98 | { | 
| 104 | s3c24xx_init_io(smdk2410_iodesc, ARRAY_SIZE(smdk2410_iodesc)); | 99 | s3c24xx_init_io(smdk2410_iodesc, ARRAY_SIZE(smdk2410_iodesc)); | 
| 105 | s3c24xx_init_clocks(0); | 100 | s3c24xx_init_clocks(0); | 
| 106 | s3c24xx_init_uarts(smdk2410_uartcfgs, ARRAY_SIZE(smdk2410_uartcfgs)); | 101 | s3c24xx_init_uarts(smdk2410_uartcfgs, ARRAY_SIZE(smdk2410_uartcfgs)); | 
| 107 | s3c24xx_set_board(&smdk2410_board); | 102 | } | 
| 103 | |||
| 104 | static void __init smdk2410_init(void) | ||
| 105 | { | ||
| 106 | platform_add_devices(smdk2410_devices, ARRAY_SIZE(smdk2410_devices)); | ||
| 107 | smdk_machine_init(); | ||
| 108 | } | 108 | } | 
| 109 | 109 | ||
| 110 | MACHINE_START(SMDK2410, "SMDK2410") /* @TODO: request a new identifier and switch | 110 | MACHINE_START(SMDK2410, "SMDK2410") /* @TODO: request a new identifier and switch | 
| @@ -115,7 +115,7 @@ MACHINE_START(SMDK2410, "SMDK2410") /* @TODO: request a new identifier and switc | |||
| 115 | .boot_params = S3C2410_SDRAM_PA + 0x100, | 115 | .boot_params = S3C2410_SDRAM_PA + 0x100, | 
| 116 | .map_io = smdk2410_map_io, | 116 | .map_io = smdk2410_map_io, | 
| 117 | .init_irq = s3c24xx_init_irq, | 117 | .init_irq = s3c24xx_init_irq, | 
| 118 | .init_machine = smdk_machine_init, | 118 | .init_machine = smdk2410_init, | 
| 119 | .timer = &s3c24xx_timer, | 119 | .timer = &s3c24xx_timer, | 
| 120 | MACHINE_END | 120 | MACHINE_END | 
| 121 | 121 | ||
| diff --git a/arch/arm/mach-s3c2410/mach-vr1000.c b/arch/arm/mach-s3c2410/mach-vr1000.c index c947c75bcbf0..7b624bb00490 100644 --- a/arch/arm/mach-s3c2410/mach-vr1000.c +++ b/arch/arm/mach-s3c2410/mach-vr1000.c | |||
| @@ -384,13 +384,6 @@ static struct clk *vr1000_clocks[] = { | |||
| 384 | &s3c24xx_uclk, | 384 | &s3c24xx_uclk, | 
| 385 | }; | 385 | }; | 
| 386 | 386 | ||
| 387 | static struct s3c24xx_board vr1000_board __initdata = { | ||
| 388 | .devices = vr1000_devices, | ||
| 389 | .devices_count = ARRAY_SIZE(vr1000_devices), | ||
| 390 | .clocks = vr1000_clocks, | ||
| 391 | .clocks_count = ARRAY_SIZE(vr1000_clocks), | ||
| 392 | }; | ||
| 393 | |||
| 394 | static void vr1000_power_off(void) | 387 | static void vr1000_power_off(void) | 
| 395 | { | 388 | { | 
| 396 | s3c2410_gpio_cfgpin(S3C2410_GPB9, S3C2410_GPB9_OUTP); | 389 | s3c2410_gpio_cfgpin(S3C2410_GPB9, S3C2410_GPB9_OUTP); | 
| @@ -412,15 +405,19 @@ static void __init vr1000_map_io(void) | |||
| 412 | 405 | ||
| 413 | s3c24xx_uclk.parent = &s3c24xx_clkout1; | 406 | s3c24xx_uclk.parent = &s3c24xx_clkout1; | 
| 414 | 407 | ||
| 408 | s3c24xx_register_clocks(vr1000_clocks, ARRAY_SIZE(vr1000_clocks)); | ||
| 409 | |||
| 415 | pm_power_off = vr1000_power_off; | 410 | pm_power_off = vr1000_power_off; | 
| 416 | 411 | ||
| 417 | s3c24xx_init_io(vr1000_iodesc, ARRAY_SIZE(vr1000_iodesc)); | 412 | s3c24xx_init_io(vr1000_iodesc, ARRAY_SIZE(vr1000_iodesc)); | 
| 418 | s3c24xx_init_clocks(0); | 413 | s3c24xx_init_clocks(0); | 
| 419 | s3c24xx_init_uarts(vr1000_uartcfgs, ARRAY_SIZE(vr1000_uartcfgs)); | 414 | s3c24xx_init_uarts(vr1000_uartcfgs, ARRAY_SIZE(vr1000_uartcfgs)); | 
| 420 | s3c24xx_set_board(&vr1000_board); | ||
| 421 | usb_simtec_init(); | ||
| 422 | } | 415 | } | 
| 423 | 416 | ||
| 417 | static void __init vr1000_init(void) | ||
| 418 | { | ||
| 419 | platform_add_devices(vr1000_devices, ARRAY_SIZE(vr1000_devices)); | ||
| 420 | } | ||
| 424 | 421 | ||
| 425 | MACHINE_START(VR1000, "Thorcom-VR1000") | 422 | MACHINE_START(VR1000, "Thorcom-VR1000") | 
| 426 | /* Maintainer: Ben Dooks <ben@simtec.co.uk> */ | 423 | /* Maintainer: Ben Dooks <ben@simtec.co.uk> */ | 
| @@ -428,6 +425,7 @@ MACHINE_START(VR1000, "Thorcom-VR1000") | |||
| 428 | .io_pg_offst = (((u32)S3C24XX_VA_UART) >> 18) & 0xfffc, | 425 | .io_pg_offst = (((u32)S3C24XX_VA_UART) >> 18) & 0xfffc, | 
| 429 | .boot_params = S3C2410_SDRAM_PA + 0x100, | 426 | .boot_params = S3C2410_SDRAM_PA + 0x100, | 
| 430 | .map_io = vr1000_map_io, | 427 | .map_io = vr1000_map_io, | 
| 428 | .init_machine = vr1000_init, | ||
| 431 | .init_irq = s3c24xx_init_irq, | 429 | .init_irq = s3c24xx_init_irq, | 
| 432 | .timer = &s3c24xx_timer, | 430 | .timer = &s3c24xx_timer, | 
| 433 | MACHINE_END | 431 | MACHINE_END | 
| diff --git a/arch/arm/mach-s3c2412/Kconfig b/arch/arm/mach-s3c2412/Kconfig index befc5fdbb613..d5be5d053264 100644 --- a/arch/arm/mach-s3c2412/Kconfig +++ b/arch/arm/mach-s3c2412/Kconfig | |||
| @@ -47,6 +47,15 @@ config MACH_S3C2413 | |||
| 47 | machine_is_s3c2413() will work when MACH_SMDK2413 is | 47 | machine_is_s3c2413() will work when MACH_SMDK2413 is | 
| 48 | selected | 48 | selected | 
| 49 | 49 | ||
| 50 | config MACH_SMDK2412 | ||
| 51 | bool "SMDK2412" | ||
| 52 | select MACH_SMDK2413 | ||
| 53 | help | ||
| 54 | Say Y here if you are using an SMDK2412 | ||
| 55 | |||
| 56 | Note, this shares support with SMDK2413, so will automatically | ||
| 57 | select MACH_SMDK2413. | ||
| 58 | |||
| 50 | config MACH_VSTMS | 59 | config MACH_VSTMS | 
| 51 | bool "VMSTMS" | 60 | bool "VMSTMS" | 
| 52 | select CPU_S3C2412 | 61 | select CPU_S3C2412 | 
| diff --git a/arch/arm/mach-s3c2412/mach-smdk2413.c b/arch/arm/mach-s3c2412/mach-smdk2413.c index b5befce6c8d3..063af09f899d 100644 --- a/arch/arm/mach-s3c2412/mach-smdk2413.c +++ b/arch/arm/mach-s3c2412/mach-smdk2413.c | |||
| @@ -110,11 +110,6 @@ static struct platform_device *smdk2413_devices[] __initdata = { | |||
| 110 | &s3c_device_usbgadget, | 110 | &s3c_device_usbgadget, | 
| 111 | }; | 111 | }; | 
| 112 | 112 | ||
| 113 | static struct s3c24xx_board smdk2413_board __initdata = { | ||
| 114 | .devices = smdk2413_devices, | ||
| 115 | .devices_count = ARRAY_SIZE(smdk2413_devices) | ||
| 116 | }; | ||
| 117 | |||
| 118 | static void __init smdk2413_fixup(struct machine_desc *desc, | 113 | static void __init smdk2413_fixup(struct machine_desc *desc, | 
| 119 | struct tag *tags, char **cmdline, | 114 | struct tag *tags, char **cmdline, | 
| 120 | struct meminfo *mi) | 115 | struct meminfo *mi) | 
| @@ -132,7 +127,6 @@ static void __init smdk2413_map_io(void) | |||
| 132 | s3c24xx_init_io(smdk2413_iodesc, ARRAY_SIZE(smdk2413_iodesc)); | 127 | s3c24xx_init_io(smdk2413_iodesc, ARRAY_SIZE(smdk2413_iodesc)); | 
| 133 | s3c24xx_init_clocks(12000000); | 128 | s3c24xx_init_clocks(12000000); | 
| 134 | s3c24xx_init_uarts(smdk2413_uartcfgs, ARRAY_SIZE(smdk2413_uartcfgs)); | 129 | s3c24xx_init_uarts(smdk2413_uartcfgs, ARRAY_SIZE(smdk2413_uartcfgs)); | 
| 135 | s3c24xx_set_board(&smdk2413_board); | ||
| 136 | } | 130 | } | 
| 137 | 131 | ||
| 138 | static void __init smdk2413_machine_init(void) | 132 | static void __init smdk2413_machine_init(void) | 
| @@ -149,6 +143,7 @@ static void __init smdk2413_machine_init(void) | |||
| 149 | 143 | ||
| 150 | s3c24xx_udc_set_platdata(&smdk2413_udc_cfg); | 144 | s3c24xx_udc_set_platdata(&smdk2413_udc_cfg); | 
| 151 | 145 | ||
| 146 | platform_add_devices(smdk2413_devices, ARRAY_SIZE(smdk2413_devices)); | ||
| 152 | smdk_machine_init(); | 147 | smdk_machine_init(); | 
| 153 | } | 148 | } | 
| 154 | 149 | ||
| diff --git a/arch/arm/mach-s3c2412/mach-vstms.c b/arch/arm/mach-s3c2412/mach-vstms.c index 4231b549d797..f2fbd65956ac 100644 --- a/arch/arm/mach-s3c2412/mach-vstms.c +++ b/arch/arm/mach-s3c2412/mach-vstms.c | |||
| @@ -129,11 +129,6 @@ static struct platform_device *vstms_devices[] __initdata = { | |||
| 129 | &s3c_device_nand, | 129 | &s3c_device_nand, | 
| 130 | }; | 130 | }; | 
| 131 | 131 | ||
| 132 | static struct s3c24xx_board vstms_board __initdata = { | ||
| 133 | .devices = vstms_devices, | ||
| 134 | .devices_count = ARRAY_SIZE(vstms_devices) | ||
| 135 | }; | ||
| 136 | |||
| 137 | static void __init vstms_fixup(struct machine_desc *desc, | 132 | static void __init vstms_fixup(struct machine_desc *desc, | 
| 138 | struct tag *tags, char **cmdline, | 133 | struct tag *tags, char **cmdline, | 
| 139 | struct meminfo *mi) | 134 | struct meminfo *mi) | 
| @@ -153,7 +148,11 @@ static void __init vstms_map_io(void) | |||
| 153 | s3c24xx_init_io(vstms_iodesc, ARRAY_SIZE(vstms_iodesc)); | 148 | s3c24xx_init_io(vstms_iodesc, ARRAY_SIZE(vstms_iodesc)); | 
| 154 | s3c24xx_init_clocks(12000000); | 149 | s3c24xx_init_clocks(12000000); | 
| 155 | s3c24xx_init_uarts(vstms_uartcfgs, ARRAY_SIZE(vstms_uartcfgs)); | 150 | s3c24xx_init_uarts(vstms_uartcfgs, ARRAY_SIZE(vstms_uartcfgs)); | 
| 156 | s3c24xx_set_board(&vstms_board); | 151 | } | 
| 152 | |||
| 153 | static void __init vstms_init(void) | ||
| 154 | { | ||
| 155 | platform_add_devices(vstms_devices, ARRAY_SIZE(vstms_devices)); | ||
| 157 | } | 156 | } | 
| 158 | 157 | ||
| 159 | MACHINE_START(VSTMS, "VSTMS") | 158 | MACHINE_START(VSTMS, "VSTMS") | 
| @@ -163,6 +162,7 @@ MACHINE_START(VSTMS, "VSTMS") | |||
| 163 | 162 | ||
| 164 | .fixup = vstms_fixup, | 163 | .fixup = vstms_fixup, | 
| 165 | .init_irq = s3c24xx_init_irq, | 164 | .init_irq = s3c24xx_init_irq, | 
| 165 | .init_machine = vstms_init, | ||
| 166 | .map_io = vstms_map_io, | 166 | .map_io = vstms_map_io, | 
| 167 | .timer = &s3c24xx_timer, | 167 | .timer = &s3c24xx_timer, | 
| 168 | MACHINE_END | 168 | MACHINE_END | 
| diff --git a/arch/arm/mach-s3c2440/mach-anubis.c b/arch/arm/mach-s3c2440/mach-anubis.c index 3f0288eb1ed5..b5d387ef37e1 100644 --- a/arch/arm/mach-s3c2440/mach-anubis.c +++ b/arch/arm/mach-s3c2440/mach-anubis.c | |||
| @@ -281,13 +281,6 @@ static struct clk *anubis_clocks[] = { | |||
| 281 | &s3c24xx_uclk, | 281 | &s3c24xx_uclk, | 
| 282 | }; | 282 | }; | 
| 283 | 283 | ||
| 284 | static struct s3c24xx_board anubis_board __initdata = { | ||
| 285 | .devices = anubis_devices, | ||
| 286 | .devices_count = ARRAY_SIZE(anubis_devices), | ||
| 287 | .clocks = anubis_clocks, | ||
| 288 | .clocks_count = ARRAY_SIZE(anubis_clocks), | ||
| 289 | }; | ||
| 290 | |||
| 291 | static void __init anubis_map_io(void) | 284 | static void __init anubis_map_io(void) | 
| 292 | { | 285 | { | 
| 293 | /* initialise the clocks */ | 286 | /* initialise the clocks */ | 
| @@ -303,23 +296,31 @@ static void __init anubis_map_io(void) | |||
| 303 | 296 | ||
| 304 | s3c24xx_uclk.parent = &s3c24xx_clkout1; | 297 | s3c24xx_uclk.parent = &s3c24xx_clkout1; | 
| 305 | 298 | ||
| 299 | s3c24xx_register_clocks(anubis_clocks, ARRAY_SIZE(anubis_clocks)); | ||
| 300 | |||
| 306 | s3c_device_nand.dev.platform_data = &anubis_nand_info; | 301 | s3c_device_nand.dev.platform_data = &anubis_nand_info; | 
| 307 | 302 | ||
| 308 | s3c24xx_init_io(anubis_iodesc, ARRAY_SIZE(anubis_iodesc)); | 303 | s3c24xx_init_io(anubis_iodesc, ARRAY_SIZE(anubis_iodesc)); | 
| 309 | s3c24xx_init_clocks(0); | 304 | s3c24xx_init_clocks(0); | 
| 310 | s3c24xx_init_uarts(anubis_uartcfgs, ARRAY_SIZE(anubis_uartcfgs)); | 305 | s3c24xx_init_uarts(anubis_uartcfgs, ARRAY_SIZE(anubis_uartcfgs)); | 
| 311 | s3c24xx_set_board(&anubis_board); | ||
| 312 | 306 | ||
| 313 | /* ensure that the GPIO is setup */ | 307 | /* ensure that the GPIO is setup */ | 
| 314 | s3c2410_gpio_setpin(S3C2410_GPA0, 1); | 308 | s3c2410_gpio_setpin(S3C2410_GPA0, 1); | 
| 315 | } | 309 | } | 
| 316 | 310 | ||
| 311 | static void __init anubis_init(void) | ||
| 312 | { | ||
| 313 | platform_add_devices(anubis_devices, ARRAY_SIZE(anubis_devices)); | ||
| 314 | } | ||
| 315 | |||
| 316 | |||
| 317 | MACHINE_START(ANUBIS, "Simtec-Anubis") | 317 | MACHINE_START(ANUBIS, "Simtec-Anubis") | 
| 318 | /* Maintainer: Ben Dooks <ben@simtec.co.uk> */ | 318 | /* Maintainer: Ben Dooks <ben@simtec.co.uk> */ | 
| 319 | .phys_io = S3C2410_PA_UART, | 319 | .phys_io = S3C2410_PA_UART, | 
| 320 | .io_pg_offst = (((u32)S3C24XX_VA_UART) >> 18) & 0xfffc, | 320 | .io_pg_offst = (((u32)S3C24XX_VA_UART) >> 18) & 0xfffc, | 
| 321 | .boot_params = S3C2410_SDRAM_PA + 0x100, | 321 | .boot_params = S3C2410_SDRAM_PA + 0x100, | 
| 322 | .map_io = anubis_map_io, | 322 | .map_io = anubis_map_io, | 
| 323 | .init_machine = anubis_init, | ||
| 323 | .init_irq = s3c24xx_init_irq, | 324 | .init_irq = s3c24xx_init_irq, | 
| 324 | .timer = &s3c24xx_timer, | 325 | .timer = &s3c24xx_timer, | 
| 325 | MACHINE_END | 326 | MACHINE_END | 
| diff --git a/arch/arm/mach-s3c2440/mach-nexcoder.c b/arch/arm/mach-s3c2440/mach-nexcoder.c index 6d551d88330b..5e61f2166c76 100644 --- a/arch/arm/mach-s3c2440/mach-nexcoder.c +++ b/arch/arm/mach-s3c2440/mach-nexcoder.c | |||
| @@ -116,12 +116,6 @@ static struct platform_device *nexcoder_devices[] __initdata = { | |||
| 116 | &nexcoder_device_nor, | 116 | &nexcoder_device_nor, | 
| 117 | }; | 117 | }; | 
| 118 | 118 | ||
| 119 | static struct s3c24xx_board nexcoder_board __initdata = { | ||
| 120 | .devices = nexcoder_devices, | ||
| 121 | .devices_count = ARRAY_SIZE(nexcoder_devices), | ||
| 122 | }; | ||
| 123 | |||
| 124 | |||
| 125 | static void __init nexcoder_sensorboard_init(void) | 119 | static void __init nexcoder_sensorboard_init(void) | 
| 126 | { | 120 | { | 
| 127 | // Initialize SCCB bus | 121 | // Initialize SCCB bus | 
| @@ -142,10 +136,14 @@ static void __init nexcoder_map_io(void) | |||
| 142 | s3c24xx_init_io(nexcoder_iodesc, ARRAY_SIZE(nexcoder_iodesc)); | 136 | s3c24xx_init_io(nexcoder_iodesc, ARRAY_SIZE(nexcoder_iodesc)); | 
| 143 | s3c24xx_init_clocks(0); | 137 | s3c24xx_init_clocks(0); | 
| 144 | s3c24xx_init_uarts(nexcoder_uartcfgs, ARRAY_SIZE(nexcoder_uartcfgs)); | 138 | s3c24xx_init_uarts(nexcoder_uartcfgs, ARRAY_SIZE(nexcoder_uartcfgs)); | 
| 145 | s3c24xx_set_board(&nexcoder_board); | 139 | |
| 146 | nexcoder_sensorboard_init(); | 140 | nexcoder_sensorboard_init(); | 
| 147 | } | 141 | } | 
| 148 | 142 | ||
| 143 | static void __init nexcoder_init(void) | ||
| 144 | { | ||
| 145 | platform_add_devices(nexcoder_devices, ARRAY_SIZE(nexcoder_devices)); | ||
| 146 | }; | ||
| 149 | 147 | ||
| 150 | MACHINE_START(NEXCODER_2440, "NexVision - Nexcoder 2440") | 148 | MACHINE_START(NEXCODER_2440, "NexVision - Nexcoder 2440") | 
| 151 | /* Maintainer: Guillaume GOURAT <guillaume.gourat@nexvision.tv> */ | 149 | /* Maintainer: Guillaume GOURAT <guillaume.gourat@nexvision.tv> */ | 
| @@ -153,6 +151,7 @@ MACHINE_START(NEXCODER_2440, "NexVision - Nexcoder 2440") | |||
| 153 | .io_pg_offst = (((u32)S3C24XX_VA_UART) >> 18) & 0xfffc, | 151 | .io_pg_offst = (((u32)S3C24XX_VA_UART) >> 18) & 0xfffc, | 
| 154 | .boot_params = S3C2410_SDRAM_PA + 0x100, | 152 | .boot_params = S3C2410_SDRAM_PA + 0x100, | 
| 155 | .map_io = nexcoder_map_io, | 153 | .map_io = nexcoder_map_io, | 
| 154 | .init_machine = nexcoder_init, | ||
| 156 | .init_irq = s3c24xx_init_irq, | 155 | .init_irq = s3c24xx_init_irq, | 
| 157 | .timer = &s3c24xx_timer, | 156 | .timer = &s3c24xx_timer, | 
| 158 | MACHINE_END | 157 | MACHINE_END | 
| diff --git a/arch/arm/mach-s3c2440/mach-osiris.c b/arch/arm/mach-s3c2440/mach-osiris.c index 2ed8e51f20c8..324f5a237921 100644 --- a/arch/arm/mach-s3c2440/mach-osiris.c +++ b/arch/arm/mach-s3c2440/mach-osiris.c | |||
| @@ -251,13 +251,6 @@ static struct clk *osiris_clocks[] = { | |||
| 251 | &s3c24xx_uclk, | 251 | &s3c24xx_uclk, | 
| 252 | }; | 252 | }; | 
| 253 | 253 | ||
| 254 | static struct s3c24xx_board osiris_board __initdata = { | ||
| 255 | .devices = osiris_devices, | ||
| 256 | .devices_count = ARRAY_SIZE(osiris_devices), | ||
| 257 | .clocks = osiris_clocks, | ||
| 258 | .clocks_count = ARRAY_SIZE(osiris_clocks), | ||
| 259 | }; | ||
| 260 | |||
| 261 | static void __init osiris_map_io(void) | 254 | static void __init osiris_map_io(void) | 
| 262 | { | 255 | { | 
| 263 | unsigned long flags; | 256 | unsigned long flags; | 
| @@ -275,12 +268,13 @@ static void __init osiris_map_io(void) | |||
| 275 | 268 | ||
| 276 | s3c24xx_uclk.parent = &s3c24xx_clkout1; | 269 | s3c24xx_uclk.parent = &s3c24xx_clkout1; | 
| 277 | 270 | ||
| 271 | s3c24xx_register_clocks(osiris_clocks, ARRAY_SIZE(osiris_clocks)); | ||
| 272 | |||
| 278 | s3c_device_nand.dev.platform_data = &osiris_nand_info; | 273 | s3c_device_nand.dev.platform_data = &osiris_nand_info; | 
| 279 | 274 | ||
| 280 | s3c24xx_init_io(osiris_iodesc, ARRAY_SIZE(osiris_iodesc)); | 275 | s3c24xx_init_io(osiris_iodesc, ARRAY_SIZE(osiris_iodesc)); | 
| 281 | s3c24xx_init_clocks(0); | 276 | s3c24xx_init_clocks(0); | 
| 282 | s3c24xx_init_uarts(osiris_uartcfgs, ARRAY_SIZE(osiris_uartcfgs)); | 277 | s3c24xx_init_uarts(osiris_uartcfgs, ARRAY_SIZE(osiris_uartcfgs)); | 
| 283 | s3c24xx_set_board(&osiris_board); | ||
| 284 | 278 | ||
| 285 | /* fix bus configuration (nBE settings wrong on ABLE pre v2.20) */ | 279 | /* fix bus configuration (nBE settings wrong on ABLE pre v2.20) */ | 
| 286 | 280 | ||
| @@ -292,12 +286,18 @@ static void __init osiris_map_io(void) | |||
| 292 | s3c2410_gpio_setpin(S3C2410_GPA0, 1); | 286 | s3c2410_gpio_setpin(S3C2410_GPA0, 1); | 
| 293 | } | 287 | } | 
| 294 | 288 | ||
| 289 | static void __init osiris_init(void) | ||
| 290 | { | ||
| 291 | platform_add_devices(osiris_devices, ARRAY_SIZE(osiris_devices)); | ||
| 292 | }; | ||
| 293 | |||
| 295 | MACHINE_START(OSIRIS, "Simtec-OSIRIS") | 294 | MACHINE_START(OSIRIS, "Simtec-OSIRIS") | 
| 296 | /* Maintainer: Ben Dooks <ben@simtec.co.uk> */ | 295 | /* Maintainer: Ben Dooks <ben@simtec.co.uk> */ | 
| 297 | .phys_io = S3C2410_PA_UART, | 296 | .phys_io = S3C2410_PA_UART, | 
| 298 | .io_pg_offst = (((u32)S3C24XX_VA_UART) >> 18) & 0xfffc, | 297 | .io_pg_offst = (((u32)S3C24XX_VA_UART) >> 18) & 0xfffc, | 
| 299 | .boot_params = S3C2410_SDRAM_PA + 0x100, | 298 | .boot_params = S3C2410_SDRAM_PA + 0x100, | 
| 300 | .map_io = osiris_map_io, | 299 | .map_io = osiris_map_io, | 
| 300 | .init_machine = osiris_init, | ||
| 301 | .init_irq = s3c24xx_init_irq, | 301 | .init_irq = s3c24xx_init_irq, | 
| 302 | .timer = &s3c24xx_timer, | 302 | .timer = &s3c24xx_timer, | 
| 303 | MACHINE_END | 303 | MACHINE_END | 
| diff --git a/arch/arm/mach-s3c2440/mach-rx3715.c b/arch/arm/mach-s3c2440/mach-rx3715.c index ae1d0a81fd6a..c3cc4bf158f6 100644 --- a/arch/arm/mach-s3c2440/mach-rx3715.c +++ b/arch/arm/mach-s3c2440/mach-rx3715.c | |||
| @@ -202,11 +202,6 @@ static struct platform_device *rx3715_devices[] __initdata = { | |||
| 202 | &s3c_device_nand, | 202 | &s3c_device_nand, | 
| 203 | }; | 203 | }; | 
| 204 | 204 | ||
| 205 | static struct s3c24xx_board rx3715_board __initdata = { | ||
| 206 | .devices = rx3715_devices, | ||
| 207 | .devices_count = ARRAY_SIZE(rx3715_devices) | ||
| 208 | }; | ||
| 209 | |||
| 210 | static void __init rx3715_map_io(void) | 205 | static void __init rx3715_map_io(void) | 
| 211 | { | 206 | { | 
| 212 | s3c_device_nand.dev.platform_data = &rx3715_nand_info; | 207 | s3c_device_nand.dev.platform_data = &rx3715_nand_info; | 
| @@ -214,7 +209,6 @@ static void __init rx3715_map_io(void) | |||
| 214 | s3c24xx_init_io(rx3715_iodesc, ARRAY_SIZE(rx3715_iodesc)); | 209 | s3c24xx_init_io(rx3715_iodesc, ARRAY_SIZE(rx3715_iodesc)); | 
| 215 | s3c24xx_init_clocks(16934000); | 210 | s3c24xx_init_clocks(16934000); | 
| 216 | s3c24xx_init_uarts(rx3715_uartcfgs, ARRAY_SIZE(rx3715_uartcfgs)); | 211 | s3c24xx_init_uarts(rx3715_uartcfgs, ARRAY_SIZE(rx3715_uartcfgs)); | 
| 217 | s3c24xx_set_board(&rx3715_board); | ||
| 218 | } | 212 | } | 
| 219 | 213 | ||
| 220 | static void __init rx3715_init_irq(void) | 214 | static void __init rx3715_init_irq(void) | 
| @@ -230,9 +224,9 @@ static void __init rx3715_init_machine(void) | |||
| 230 | s3c2410_pm_init(); | 224 | s3c2410_pm_init(); | 
| 231 | 225 | ||
| 232 | s3c24xx_fb_set_platdata(&rx3715_lcdcfg); | 226 | s3c24xx_fb_set_platdata(&rx3715_lcdcfg); | 
| 227 | platform_add_devices(rx3715_devices, ARRAY_SIZE(rx3715_devices)); | ||
| 233 | } | 228 | } | 
| 234 | 229 | ||
| 235 | |||
| 236 | MACHINE_START(RX3715, "IPAQ-RX3715") | 230 | MACHINE_START(RX3715, "IPAQ-RX3715") | 
| 237 | /* Maintainer: Ben Dooks <ben@fluff.org> */ | 231 | /* Maintainer: Ben Dooks <ben@fluff.org> */ | 
| 238 | .phys_io = S3C2410_PA_UART, | 232 | .phys_io = S3C2410_PA_UART, | 
| diff --git a/arch/arm/mach-s3c2440/mach-smdk2440.c b/arch/arm/mach-s3c2440/mach-smdk2440.c index c17eb5b1f6b4..e167254e232e 100644 --- a/arch/arm/mach-s3c2440/mach-smdk2440.c +++ b/arch/arm/mach-s3c2440/mach-smdk2440.c | |||
| @@ -174,23 +174,18 @@ static struct platform_device *smdk2440_devices[] __initdata = { | |||
| 174 | &s3c_device_iis, | 174 | &s3c_device_iis, | 
| 175 | }; | 175 | }; | 
| 176 | 176 | ||
| 177 | static struct s3c24xx_board smdk2440_board __initdata = { | ||
| 178 | .devices = smdk2440_devices, | ||
| 179 | .devices_count = ARRAY_SIZE(smdk2440_devices) | ||
| 180 | }; | ||
| 181 | |||
| 182 | static void __init smdk2440_map_io(void) | 177 | static void __init smdk2440_map_io(void) | 
| 183 | { | 178 | { | 
| 184 | s3c24xx_init_io(smdk2440_iodesc, ARRAY_SIZE(smdk2440_iodesc)); | 179 | s3c24xx_init_io(smdk2440_iodesc, ARRAY_SIZE(smdk2440_iodesc)); | 
| 185 | s3c24xx_init_clocks(16934400); | 180 | s3c24xx_init_clocks(16934400); | 
| 186 | s3c24xx_init_uarts(smdk2440_uartcfgs, ARRAY_SIZE(smdk2440_uartcfgs)); | 181 | s3c24xx_init_uarts(smdk2440_uartcfgs, ARRAY_SIZE(smdk2440_uartcfgs)); | 
| 187 | s3c24xx_set_board(&smdk2440_board); | ||
| 188 | } | 182 | } | 
| 189 | 183 | ||
| 190 | static void __init smdk2440_machine_init(void) | 184 | static void __init smdk2440_machine_init(void) | 
| 191 | { | 185 | { | 
| 192 | s3c24xx_fb_set_platdata(&smdk2440_lcd_cfg); | 186 | s3c24xx_fb_set_platdata(&smdk2440_lcd_cfg); | 
| 193 | 187 | ||
| 188 | platform_add_devices(smdk2440_devices, ARRAY_SIZE(smdk2440_devices)); | ||
| 194 | smdk_machine_init(); | 189 | smdk_machine_init(); | 
| 195 | } | 190 | } | 
| 196 | 191 | ||
| diff --git a/arch/arm/mach-s3c2443/mach-smdk2443.c b/arch/arm/mach-s3c2443/mach-smdk2443.c index e82aaff7dee4..b71ee53c2865 100644 --- a/arch/arm/mach-s3c2443/mach-smdk2443.c +++ b/arch/arm/mach-s3c2443/mach-smdk2443.c | |||
| @@ -106,21 +106,16 @@ static struct platform_device *smdk2443_devices[] __initdata = { | |||
| 106 | &s3c_device_i2c, | 106 | &s3c_device_i2c, | 
| 107 | }; | 107 | }; | 
| 108 | 108 | ||
| 109 | static struct s3c24xx_board smdk2443_board __initdata = { | ||
| 110 | .devices = smdk2443_devices, | ||
| 111 | .devices_count = ARRAY_SIZE(smdk2443_devices) | ||
| 112 | }; | ||
| 113 | |||
| 114 | static void __init smdk2443_map_io(void) | 109 | static void __init smdk2443_map_io(void) | 
| 115 | { | 110 | { | 
| 116 | s3c24xx_init_io(smdk2443_iodesc, ARRAY_SIZE(smdk2443_iodesc)); | 111 | s3c24xx_init_io(smdk2443_iodesc, ARRAY_SIZE(smdk2443_iodesc)); | 
| 117 | s3c24xx_init_clocks(12000000); | 112 | s3c24xx_init_clocks(12000000); | 
| 118 | s3c24xx_init_uarts(smdk2443_uartcfgs, ARRAY_SIZE(smdk2443_uartcfgs)); | 113 | s3c24xx_init_uarts(smdk2443_uartcfgs, ARRAY_SIZE(smdk2443_uartcfgs)); | 
| 119 | s3c24xx_set_board(&smdk2443_board); | ||
| 120 | } | 114 | } | 
| 121 | 115 | ||
| 122 | static void __init smdk2443_machine_init(void) | 116 | static void __init smdk2443_machine_init(void) | 
| 123 | { | 117 | { | 
| 118 | platform_add_devices(smdk2443_devices, ARRAY_SIZE(smdk2443_devices)); | ||
| 124 | smdk_machine_init(); | 119 | smdk_machine_init(); | 
| 125 | } | 120 | } | 
| 126 | 121 | ||
| diff --git a/arch/arm/mach-sa1100/clock.c b/arch/arm/mach-sa1100/clock.c index b1e8fd766c1a..fc97fe57ee6f 100644 --- a/arch/arm/mach-sa1100/clock.c +++ b/arch/arm/mach-sa1100/clock.c | |||
| @@ -9,14 +9,17 @@ | |||
| 9 | #include <linux/string.h> | 9 | #include <linux/string.h> | 
| 10 | #include <linux/clk.h> | 10 | #include <linux/clk.h> | 
| 11 | #include <linux/spinlock.h> | 11 | #include <linux/spinlock.h> | 
| 12 | #include <linux/mutex.h> | ||
| 12 | 13 | ||
| 13 | #include <asm/hardware.h> | 14 | #include <asm/hardware.h> | 
| 14 | #include <asm/semaphore.h> | ||
| 15 | 15 | ||
| 16 | /* | ||
| 17 | * Very simple clock implementation - we only have one clock to | ||
| 18 | * deal with at the moment, so we only match using the "name". | ||
| 19 | */ | ||
| 16 | struct clk { | 20 | struct clk { | 
| 17 | struct list_head node; | 21 | struct list_head node; | 
| 18 | unsigned long rate; | 22 | unsigned long rate; | 
| 19 | struct module *owner; | ||
| 20 | const char *name; | 23 | const char *name; | 
| 21 | unsigned int enabled; | 24 | unsigned int enabled; | 
| 22 | void (*enable)(void); | 25 | void (*enable)(void); | 
| @@ -24,21 +27,21 @@ struct clk { | |||
| 24 | }; | 27 | }; | 
| 25 | 28 | ||
| 26 | static LIST_HEAD(clocks); | 29 | static LIST_HEAD(clocks); | 
| 27 | static DECLARE_MUTEX(clocks_sem); | 30 | static DEFINE_MUTEX(clocks_mutex); | 
| 28 | static DEFINE_SPINLOCK(clocks_lock); | 31 | static DEFINE_SPINLOCK(clocks_lock); | 
| 29 | 32 | ||
| 30 | struct clk *clk_get(struct device *dev, const char *id) | 33 | struct clk *clk_get(struct device *dev, const char *id) | 
| 31 | { | 34 | { | 
| 32 | struct clk *p, *clk = ERR_PTR(-ENOENT); | 35 | struct clk *p, *clk = ERR_PTR(-ENOENT); | 
| 33 | 36 | ||
| 34 | down(&clocks_sem); | 37 | mutex_lock(&clocks_mutex); | 
| 35 | list_for_each_entry(p, &clocks, node) { | 38 | list_for_each_entry(p, &clocks, node) { | 
| 36 | if (strcmp(id, p->name) == 0 && try_module_get(p->owner)) { | 39 | if (strcmp(id, p->name) == 0) { | 
| 37 | clk = p; | 40 | clk = p; | 
| 38 | break; | 41 | break; | 
| 39 | } | 42 | } | 
| 40 | } | 43 | } | 
| 41 | up(&clocks_sem); | 44 | mutex_unlock(&clocks_mutex); | 
| 42 | 45 | ||
| 43 | return clk; | 46 | return clk; | 
| 44 | } | 47 | } | 
| @@ -46,7 +49,6 @@ EXPORT_SYMBOL(clk_get); | |||
| 46 | 49 | ||
| 47 | void clk_put(struct clk *clk) | 50 | void clk_put(struct clk *clk) | 
| 48 | { | 51 | { | 
| 49 | module_put(clk->owner); | ||
| 50 | } | 52 | } | 
| 51 | EXPORT_SYMBOL(clk_put); | 53 | EXPORT_SYMBOL(clk_put); | 
| 52 | 54 | ||
| @@ -109,18 +111,18 @@ static struct clk clk_gpio27 = { | |||
| 109 | 111 | ||
| 110 | int clk_register(struct clk *clk) | 112 | int clk_register(struct clk *clk) | 
| 111 | { | 113 | { | 
| 112 | down(&clocks_sem); | 114 | mutex_lock(&clocks_mutex); | 
| 113 | list_add(&clk->node, &clocks); | 115 | list_add(&clk->node, &clocks); | 
| 114 | up(&clocks_sem); | 116 | mutex_unlock(&clocks_mutex); | 
| 115 | return 0; | 117 | return 0; | 
| 116 | } | 118 | } | 
| 117 | EXPORT_SYMBOL(clk_register); | 119 | EXPORT_SYMBOL(clk_register); | 
| 118 | 120 | ||
| 119 | void clk_unregister(struct clk *clk) | 121 | void clk_unregister(struct clk *clk) | 
| 120 | { | 122 | { | 
| 121 | down(&clocks_sem); | 123 | mutex_lock(&clocks_mutex); | 
| 122 | list_del(&clk->node); | 124 | list_del(&clk->node); | 
| 123 | up(&clocks_sem); | 125 | mutex_unlock(&clocks_mutex); | 
| 124 | } | 126 | } | 
| 125 | EXPORT_SYMBOL(clk_unregister); | 127 | EXPORT_SYMBOL(clk_unregister); | 
| 126 | 128 | ||
| diff --git a/arch/arm/mach-versatile/core.c b/arch/arm/mach-versatile/core.c index bf71507c76fd..1275aa7d2eb1 100644 --- a/arch/arm/mach-versatile/core.c +++ b/arch/arm/mach-versatile/core.c | |||
| @@ -26,6 +26,8 @@ | |||
| 26 | #include <linux/interrupt.h> | 26 | #include <linux/interrupt.h> | 
| 27 | #include <linux/amba/bus.h> | 27 | #include <linux/amba/bus.h> | 
| 28 | #include <linux/amba/clcd.h> | 28 | #include <linux/amba/clcd.h> | 
| 29 | #include <linux/clocksource.h> | ||
| 30 | #include <linux/clockchips.h> | ||
| 29 | 31 | ||
| 30 | #include <asm/cnt32_to_63.h> | 32 | #include <asm/cnt32_to_63.h> | 
| 31 | #include <asm/system.h> | 33 | #include <asm/system.h> | 
| @@ -828,59 +830,61 @@ void __init versatile_init(void) | |||
| 828 | #define TICKS2USECS(x) ((x) / TICKS_PER_uSEC) | 830 | #define TICKS2USECS(x) ((x) / TICKS_PER_uSEC) | 
| 829 | #endif | 831 | #endif | 
| 830 | 832 | ||
| 831 | /* | 833 | static void timer_set_mode(enum clock_event_mode mode, | 
| 832 | * Returns number of ms since last clock interrupt. Note that interrupts | 834 | struct clock_event_device *clk) | 
| 833 | * will have been disabled by do_gettimeoffset() | ||
| 834 | */ | ||
| 835 | static unsigned long versatile_gettimeoffset(void) | ||
| 836 | { | 835 | { | 
| 837 | unsigned long ticks1, ticks2, status; | 836 | unsigned long ctrl; | 
| 838 | 837 | ||
| 839 | /* | 838 | switch(mode) { | 
| 840 | * Get the current number of ticks. Note that there is a race | 839 | case CLOCK_EVT_MODE_PERIODIC: | 
| 841 | * condition between us reading the timer and checking for | 840 | writel(TIMER_RELOAD, TIMER0_VA_BASE + TIMER_LOAD); | 
| 842 | * an interrupt. We get around this by ensuring that the | ||
| 843 | * counter has not reloaded between our two reads. | ||
| 844 | */ | ||
| 845 | ticks2 = readl(TIMER0_VA_BASE + TIMER_VALUE) & 0xffff; | ||
| 846 | do { | ||
| 847 | ticks1 = ticks2; | ||
| 848 | status = __raw_readl(VA_IC_BASE + VIC_RAW_STATUS); | ||
| 849 | ticks2 = readl(TIMER0_VA_BASE + TIMER_VALUE) & 0xffff; | ||
| 850 | } while (ticks2 > ticks1); | ||
| 851 | 841 | ||
| 852 | /* | 842 | ctrl = TIMER_CTRL_PERIODIC; | 
| 853 | * Number of ticks since last interrupt. | 843 | ctrl |= TIMER_CTRL_32BIT | TIMER_CTRL_IE | TIMER_CTRL_ENABLE; | 
| 854 | */ | 844 | break; | 
| 855 | ticks1 = TIMER_RELOAD - ticks2; | 845 | case CLOCK_EVT_MODE_ONESHOT: | 
| 846 | /* period set, and timer enabled in 'next_event' hook */ | ||
| 847 | ctrl = TIMER_CTRL_ONESHOT; | ||
| 848 | ctrl |= TIMER_CTRL_32BIT | TIMER_CTRL_IE; | ||
| 849 | break; | ||
| 850 | case CLOCK_EVT_MODE_UNUSED: | ||
| 851 | case CLOCK_EVT_MODE_SHUTDOWN: | ||
| 852 | default: | ||
| 853 | ctrl = 0; | ||
| 854 | } | ||
| 856 | 855 | ||
| 857 | /* | 856 | writel(ctrl, TIMER0_VA_BASE + TIMER_CTRL); | 
| 858 | * Interrupt pending? If so, we've reloaded once already. | 857 | } | 
| 859 | * | ||
| 860 | * FIXME: Need to check this is effectively timer 0 that expires | ||
| 861 | */ | ||
| 862 | if (status & IRQMASK_TIMERINT0_1) | ||
| 863 | ticks1 += TIMER_RELOAD; | ||
| 864 | 858 | ||
| 865 | /* | 859 | static int timer_set_next_event(unsigned long evt, | 
| 866 | * Convert the ticks to usecs | 860 | struct clock_event_device *unused) | 
| 867 | */ | 861 | { | 
| 868 | return TICKS2USECS(ticks1); | 862 | unsigned long ctrl = readl(TIMER0_VA_BASE + TIMER_CTRL); | 
| 863 | |||
| 864 | writel(evt, TIMER0_VA_BASE + TIMER_LOAD); | ||
| 865 | writel(ctrl | TIMER_CTRL_ENABLE, TIMER0_VA_BASE + TIMER_CTRL); | ||
| 866 | |||
| 867 | return 0; | ||
| 869 | } | 868 | } | 
| 870 | 869 | ||
| 870 | static struct clock_event_device timer0_clockevent = { | ||
| 871 | .name = "timer0", | ||
| 872 | .shift = 32, | ||
| 873 | .features = CLOCK_EVT_FEAT_PERIODIC | CLOCK_EVT_FEAT_ONESHOT, | ||
| 874 | .set_mode = timer_set_mode, | ||
| 875 | .set_next_event = timer_set_next_event, | ||
| 876 | }; | ||
| 877 | |||
| 871 | /* | 878 | /* | 
| 872 | * IRQ handler for the timer | 879 | * IRQ handler for the timer | 
| 873 | */ | 880 | */ | 
| 874 | static irqreturn_t versatile_timer_interrupt(int irq, void *dev_id) | 881 | static irqreturn_t versatile_timer_interrupt(int irq, void *dev_id) | 
| 875 | { | 882 | { | 
| 876 | write_seqlock(&xtime_lock); | 883 | struct clock_event_device *evt = &timer0_clockevent; | 
| 877 | 884 | ||
| 878 | // ...clear the interrupt | ||
| 879 | writel(1, TIMER0_VA_BASE + TIMER_INTCLR); | 885 | writel(1, TIMER0_VA_BASE + TIMER_INTCLR); | 
| 880 | 886 | ||
| 881 | timer_tick(); | 887 | evt->event_handler(evt); | 
| 882 | |||
| 883 | write_sequnlock(&xtime_lock); | ||
| 884 | 888 | ||
| 885 | return IRQ_HANDLED; | 889 | return IRQ_HANDLED; | 
| 886 | } | 890 | } | 
| @@ -891,6 +895,36 @@ static struct irqaction versatile_timer_irq = { | |||
| 891 | .handler = versatile_timer_interrupt, | 895 | .handler = versatile_timer_interrupt, | 
| 892 | }; | 896 | }; | 
| 893 | 897 | ||
| 898 | static cycle_t versatile_get_cycles(void) | ||
| 899 | { | ||
| 900 | return ~readl(TIMER3_VA_BASE + TIMER_VALUE); | ||
| 901 | } | ||
| 902 | |||
| 903 | static struct clocksource clocksource_versatile = { | ||
| 904 | .name = "timer3", | ||
| 905 | .rating = 200, | ||
| 906 | .read = versatile_get_cycles, | ||
| 907 | .mask = CLOCKSOURCE_MASK(32), | ||
| 908 | .shift = 20, | ||
| 909 | .flags = CLOCK_SOURCE_IS_CONTINUOUS, | ||
| 910 | }; | ||
| 911 | |||
| 912 | static int __init versatile_clocksource_init(void) | ||
| 913 | { | ||
| 914 | /* setup timer3 as free-running clocksource */ | ||
| 915 | writel(0, TIMER3_VA_BASE + TIMER_CTRL); | ||
| 916 | writel(0xffffffff, TIMER3_VA_BASE + TIMER_LOAD); | ||
| 917 | writel(0xffffffff, TIMER3_VA_BASE + TIMER_VALUE); | ||
| 918 | writel(TIMER_CTRL_32BIT | TIMER_CTRL_ENABLE | TIMER_CTRL_PERIODIC, | ||
| 919 | TIMER3_VA_BASE + TIMER_CTRL); | ||
| 920 | |||
| 921 | clocksource_versatile.mult = | ||
| 922 | clocksource_khz2mult(1000, clocksource_versatile.shift); | ||
| 923 | clocksource_register(&clocksource_versatile); | ||
| 924 | |||
| 925 | return 0; | ||
| 926 | } | ||
| 927 | |||
| 894 | /* | 928 | /* | 
| 895 | * Set up timer interrupt, and return the current time in seconds. | 929 | * Set up timer interrupt, and return the current time in seconds. | 
| 896 | */ | 930 | */ | 
| @@ -918,18 +952,25 @@ static void __init versatile_timer_init(void) | |||
| 918 | writel(0, TIMER2_VA_BASE + TIMER_CTRL); | 952 | writel(0, TIMER2_VA_BASE + TIMER_CTRL); | 
| 919 | writel(0, TIMER3_VA_BASE + TIMER_CTRL); | 953 | writel(0, TIMER3_VA_BASE + TIMER_CTRL); | 
| 920 | 954 | ||
| 921 | writel(TIMER_RELOAD, TIMER0_VA_BASE + TIMER_LOAD); | ||
| 922 | writel(TIMER_RELOAD, TIMER0_VA_BASE + TIMER_VALUE); | ||
| 923 | writel(TIMER_DIVISOR | TIMER_CTRL_ENABLE | TIMER_CTRL_PERIODIC | | ||
| 924 | TIMER_CTRL_IE, TIMER0_VA_BASE + TIMER_CTRL); | ||
| 925 | |||
| 926 | /* | 955 | /* | 
| 927 | * Make irqs happen for the system timer | 956 | * Make irqs happen for the system timer | 
| 928 | */ | 957 | */ | 
| 929 | setup_irq(IRQ_TIMERINT0_1, &versatile_timer_irq); | 958 | setup_irq(IRQ_TIMERINT0_1, &versatile_timer_irq); | 
| 959 | |||
| 960 | versatile_clocksource_init(); | ||
| 961 | |||
| 962 | timer0_clockevent.mult = | ||
| 963 | div_sc(1000000, NSEC_PER_SEC, timer0_clockevent.shift); | ||
| 964 | timer0_clockevent.max_delta_ns = | ||
| 965 | clockevent_delta2ns(0xffffffff, &timer0_clockevent); | ||
| 966 | timer0_clockevent.min_delta_ns = | ||
| 967 | clockevent_delta2ns(0xf, &timer0_clockevent); | ||
| 968 | |||
| 969 | timer0_clockevent.cpumask = cpumask_of_cpu(0); | ||
| 970 | clockevents_register_device(&timer0_clockevent); | ||
| 930 | } | 971 | } | 
| 931 | 972 | ||
| 932 | struct sys_timer versatile_timer = { | 973 | struct sys_timer versatile_timer = { | 
| 933 | .init = versatile_timer_init, | 974 | .init = versatile_timer_init, | 
| 934 | .offset = versatile_gettimeoffset, | ||
| 935 | }; | 975 | }; | 
| 976 | |||
| diff --git a/arch/arm/oprofile/backtrace.c b/arch/arm/oprofile/backtrace.c index 7c22c12618cc..f5ebf30151fa 100644 --- a/arch/arm/oprofile/backtrace.c +++ b/arch/arm/oprofile/backtrace.c | |||
| @@ -19,6 +19,19 @@ | |||
| 19 | #include <asm/ptrace.h> | 19 | #include <asm/ptrace.h> | 
| 20 | #include <asm/uaccess.h> | 20 | #include <asm/uaccess.h> | 
| 21 | 21 | ||
| 22 | #include "../kernel/stacktrace.h" | ||
| 23 | |||
| 24 | static int report_trace(struct stackframe *frame, void *d) | ||
| 25 | { | ||
| 26 | unsigned int *depth = d; | ||
| 27 | |||
| 28 | if (*depth) { | ||
| 29 | oprofile_add_trace(frame->lr); | ||
| 30 | (*depth)--; | ||
| 31 | } | ||
| 32 | |||
| 33 | return *depth == 0; | ||
| 34 | } | ||
| 22 | 35 | ||
| 23 | /* | 36 | /* | 
| 24 | * The registers we're interested in are at the end of the variable | 37 | * The registers we're interested in are at the end of the variable | 
| @@ -32,21 +45,6 @@ struct frame_tail { | |||
| 32 | unsigned long lr; | 45 | unsigned long lr; | 
| 33 | } __attribute__((packed)); | 46 | } __attribute__((packed)); | 
| 34 | 47 | ||
| 35 | |||
| 36 | #ifdef CONFIG_FRAME_POINTER | ||
| 37 | static struct frame_tail* kernel_backtrace(struct frame_tail *tail) | ||
| 38 | { | ||
| 39 | oprofile_add_trace(tail->lr); | ||
| 40 | |||
| 41 | /* frame pointers should strictly progress back up the stack | ||
| 42 | * (towards higher addresses) */ | ||
| 43 | if (tail >= tail->fp) | ||
| 44 | return NULL; | ||
| 45 | |||
| 46 | return tail->fp-1; | ||
| 47 | } | ||
| 48 | #endif | ||
| 49 | |||
| 50 | static struct frame_tail* user_backtrace(struct frame_tail *tail) | 48 | static struct frame_tail* user_backtrace(struct frame_tail *tail) | 
| 51 | { | 49 | { | 
| 52 | struct frame_tail buftail[2]; | 50 | struct frame_tail buftail[2]; | 
| @@ -67,47 +65,14 @@ static struct frame_tail* user_backtrace(struct frame_tail *tail) | |||
| 67 | return buftail[0].fp-1; | 65 | return buftail[0].fp-1; | 
| 68 | } | 66 | } | 
| 69 | 67 | ||
| 70 | /* | ||
| 71 | * | | /\ Higher addresses | ||
| 72 | * | | | ||
| 73 | * --------------- stack base (address of current_thread_info) | ||
| 74 | * | thread info | | ||
| 75 | * . . | ||
| 76 | * | stack | | ||
| 77 | * --------------- saved regs->ARM_fp value if valid (frame_tail address) | ||
| 78 | * . . | ||
| 79 | * --------------- struct pt_regs stored on stack (struct pt_regs *) | ||
| 80 | * | | | ||
| 81 | * . . | ||
| 82 | * | | | ||
| 83 | * --------------- %esp | ||
| 84 | * | | | ||
| 85 | * | | \/ Lower addresses | ||
| 86 | * | ||
| 87 | * Thus, &pt_regs <-> stack base restricts the valid(ish) fp values | ||
| 88 | */ | ||
| 89 | static int valid_kernel_stack(struct frame_tail *tail, struct pt_regs *regs) | ||
| 90 | { | ||
| 91 | unsigned long tailaddr = (unsigned long)tail; | ||
| 92 | unsigned long stack = (unsigned long)regs; | ||
| 93 | unsigned long stack_base = (stack & ~(THREAD_SIZE - 1)) + THREAD_SIZE; | ||
| 94 | |||
| 95 | return (tailaddr > stack) && (tailaddr < stack_base); | ||
| 96 | } | ||
| 97 | |||
| 98 | void arm_backtrace(struct pt_regs * const regs, unsigned int depth) | 68 | void arm_backtrace(struct pt_regs * const regs, unsigned int depth) | 
| 99 | { | 69 | { | 
| 100 | struct frame_tail *tail; | 70 | struct frame_tail *tail = ((struct frame_tail *) regs->ARM_fp) - 1; | 
| 101 | |||
| 102 | tail = ((struct frame_tail *) regs->ARM_fp) - 1; | ||
| 103 | 71 | ||
| 104 | if (!user_mode(regs)) { | 72 | if (!user_mode(regs)) { | 
| 105 | 73 | unsigned long base = ((unsigned long)regs) & ~(THREAD_SIZE - 1); | |
| 106 | #ifdef CONFIG_FRAME_POINTER | 74 | walk_stackframe(regs->ARM_fp, base, base + THREAD_SIZE, | 
| 107 | while (depth-- && tail && valid_kernel_stack(tail, regs)) { | 75 | report_trace, &depth); | 
| 108 | tail = kernel_backtrace(tail); | ||
| 109 | } | ||
| 110 | #endif | ||
| 111 | return; | 76 | return; | 
| 112 | } | 77 | } | 
| 113 | 78 | ||
| diff --git a/arch/arm/plat-iop/pci.c b/arch/arm/plat-iop/pci.c index b5f6ec35aafb..e2744b7227c5 100644 --- a/arch/arm/plat-iop/pci.c +++ b/arch/arm/plat-iop/pci.c | |||
| @@ -55,7 +55,7 @@ static u32 iop3xx_cfg_address(struct pci_bus *bus, int devfn, int where) | |||
| 55 | * This routine checks the status of the last configuration cycle. If an error | 55 | * This routine checks the status of the last configuration cycle. If an error | 
| 56 | * was detected it returns a 1, else it returns a 0. The errors being checked | 56 | * was detected it returns a 1, else it returns a 0. The errors being checked | 
| 57 | * are parity, master abort, target abort (master and target). These types of | 57 | * are parity, master abort, target abort (master and target). These types of | 
| 58 | * errors occure during a config cycle where there is no device, like during | 58 | * errors occur during a config cycle where there is no device, like during | 
| 59 | * the discovery stage. | 59 | * the discovery stage. | 
| 60 | */ | 60 | */ | 
| 61 | static int iop3xx_pci_status(void) | 61 | static int iop3xx_pci_status(void) | 
| @@ -223,8 +223,111 @@ struct pci_bus *iop3xx_pci_scan_bus(int nr, struct pci_sys_data *sys) | |||
| 223 | return pci_scan_bus(sys->busnr, &iop3xx_ops, sys); | 223 | return pci_scan_bus(sys->busnr, &iop3xx_ops, sys); | 
| 224 | } | 224 | } | 
| 225 | 225 | ||
| 226 | void __init iop3xx_atu_setup(void) | ||
| 227 | { | ||
| 228 | /* BAR 0 ( Disabled ) */ | ||
| 229 | *IOP3XX_IAUBAR0 = 0x0; | ||
| 230 | *IOP3XX_IABAR0 = 0x0; | ||
| 231 | *IOP3XX_IATVR0 = 0x0; | ||
| 232 | *IOP3XX_IALR0 = 0x0; | ||
| 233 | |||
| 234 | /* BAR 1 ( Disabled ) */ | ||
| 235 | *IOP3XX_IAUBAR1 = 0x0; | ||
| 236 | *IOP3XX_IABAR1 = 0x0; | ||
| 237 | *IOP3XX_IALR1 = 0x0; | ||
| 238 | |||
| 239 | /* BAR 2 (1:1 mapping with Physical RAM) */ | ||
| 240 | /* Set limit and enable */ | ||
| 241 | *IOP3XX_IALR2 = ~((u32)IOP3XX_MAX_RAM_SIZE - 1) & ~0x1; | ||
| 242 | *IOP3XX_IAUBAR2 = 0x0; | ||
| 243 | |||
| 244 | /* Align the inbound bar with the base of memory */ | ||
| 245 | *IOP3XX_IABAR2 = PHYS_OFFSET | | ||
| 246 | PCI_BASE_ADDRESS_MEM_TYPE_64 | | ||
| 247 | PCI_BASE_ADDRESS_MEM_PREFETCH; | ||
| 248 | |||
| 249 | *IOP3XX_IATVR2 = PHYS_OFFSET; | ||
| 250 | |||
| 251 | /* Outbound window 0 */ | ||
| 252 | *IOP3XX_OMWTVR0 = IOP3XX_PCI_LOWER_MEM_PA; | ||
| 253 | *IOP3XX_OUMWTVR0 = 0; | ||
| 254 | |||
| 255 | /* Outbound window 1 */ | ||
| 256 | *IOP3XX_OMWTVR1 = IOP3XX_PCI_LOWER_MEM_PA + IOP3XX_PCI_MEM_WINDOW_SIZE; | ||
| 257 | *IOP3XX_OUMWTVR1 = 0; | ||
| 258 | |||
| 259 | /* BAR 3 ( Disabled ) */ | ||
| 260 | *IOP3XX_IAUBAR3 = 0x0; | ||
| 261 | *IOP3XX_IABAR3 = 0x0; | ||
| 262 | *IOP3XX_IATVR3 = 0x0; | ||
| 263 | *IOP3XX_IALR3 = 0x0; | ||
| 264 | |||
| 265 | /* Setup the I/O Bar | ||
| 266 | */ | ||
| 267 | *IOP3XX_OIOWTVR = IOP3XX_PCI_LOWER_IO_PA;; | ||
| 268 | |||
| 269 | /* Enable inbound and outbound cycles | ||
| 270 | */ | ||
| 271 | *IOP3XX_ATUCMD |= PCI_COMMAND_MEMORY | PCI_COMMAND_MASTER | | ||
| 272 | PCI_COMMAND_PARITY | PCI_COMMAND_SERR; | ||
| 273 | *IOP3XX_ATUCR |= IOP3XX_ATUCR_OUT_EN; | ||
| 274 | } | ||
| 275 | |||
| 276 | void __init iop3xx_atu_disable(void) | ||
| 277 | { | ||
| 278 | *IOP3XX_ATUCMD = 0; | ||
| 279 | *IOP3XX_ATUCR = 0; | ||
| 280 | |||
| 281 | /* wait for cycles to quiesce */ | ||
| 282 | while (*IOP3XX_PCSR & (IOP3XX_PCSR_OUT_Q_BUSY | | ||
| 283 | IOP3XX_PCSR_IN_Q_BUSY)) | ||
| 284 | cpu_relax(); | ||
| 285 | |||
| 286 | /* BAR 0 ( Disabled ) */ | ||
| 287 | *IOP3XX_IAUBAR0 = 0x0; | ||
| 288 | *IOP3XX_IABAR0 = 0x0; | ||
| 289 | *IOP3XX_IATVR0 = 0x0; | ||
| 290 | *IOP3XX_IALR0 = 0x0; | ||
| 291 | |||
| 292 | /* BAR 1 ( Disabled ) */ | ||
| 293 | *IOP3XX_IAUBAR1 = 0x0; | ||
| 294 | *IOP3XX_IABAR1 = 0x0; | ||
| 295 | *IOP3XX_IALR1 = 0x0; | ||
| 296 | |||
| 297 | /* BAR 2 ( Disabled ) */ | ||
| 298 | *IOP3XX_IAUBAR2 = 0x0; | ||
| 299 | *IOP3XX_IABAR2 = 0x0; | ||
| 300 | *IOP3XX_IATVR2 = 0x0; | ||
| 301 | *IOP3XX_IALR2 = 0x0; | ||
| 302 | |||
| 303 | /* BAR 3 ( Disabled ) */ | ||
| 304 | *IOP3XX_IAUBAR3 = 0x0; | ||
| 305 | *IOP3XX_IABAR3 = 0x0; | ||
| 306 | *IOP3XX_IATVR3 = 0x0; | ||
| 307 | *IOP3XX_IALR3 = 0x0; | ||
| 308 | |||
| 309 | /* Clear the outbound windows */ | ||
| 310 | *IOP3XX_OIOWTVR = 0; | ||
| 311 | |||
| 312 | /* Outbound window 0 */ | ||
| 313 | *IOP3XX_OMWTVR0 = 0; | ||
| 314 | *IOP3XX_OUMWTVR0 = 0; | ||
| 315 | |||
| 316 | /* Outbound window 1 */ | ||
| 317 | *IOP3XX_OMWTVR1 = 0; | ||
| 318 | *IOP3XX_OUMWTVR1 = 0; | ||
| 319 | } | ||
| 320 | |||
| 321 | /* Flag to determine whether the ATU is initialized and the PCI bus scanned */ | ||
| 322 | int init_atu; | ||
| 323 | |||
| 226 | void iop3xx_pci_preinit(void) | 324 | void iop3xx_pci_preinit(void) | 
| 227 | { | 325 | { | 
| 326 | if (iop3xx_get_init_atu() == IOP3XX_INIT_ATU_ENABLE) { | ||
| 327 | iop3xx_atu_disable(); | ||
| 328 | iop3xx_atu_setup(); | ||
| 329 | } | ||
| 330 | |||
| 228 | DBG("PCI: Intel 803xx PCI init code.\n"); | 331 | DBG("PCI: Intel 803xx PCI init code.\n"); | 
| 229 | DBG("ATU: IOP3XX_ATUCMD=0x%04x\n", *IOP3XX_ATUCMD); | 332 | DBG("ATU: IOP3XX_ATUCMD=0x%04x\n", *IOP3XX_ATUCMD); | 
| 230 | DBG("ATU: IOP3XX_OMWTVR0=0x%04x, IOP3XX_OIOWTVR=0x%04x\n", | 333 | DBG("ATU: IOP3XX_OMWTVR0=0x%04x, IOP3XX_OIOWTVR=0x%04x\n", | 
| @@ -245,3 +348,38 @@ void iop3xx_pci_preinit(void) | |||
| 245 | 348 | ||
| 246 | hook_fault_code(16+6, iop3xx_pci_abort, SIGBUS, "imprecise external abort"); | 349 | hook_fault_code(16+6, iop3xx_pci_abort, SIGBUS, "imprecise external abort"); | 
| 247 | } | 350 | } | 
| 351 | |||
| 352 | /* allow init_atu to be user overridden */ | ||
| 353 | static int __init iop3xx_init_atu_setup(char *str) | ||
| 354 | { | ||
| 355 | init_atu = IOP3XX_INIT_ATU_DEFAULT; | ||
| 356 | if (str) { | ||
| 357 | while (*str != '\0') { | ||
| 358 | switch (*str) { | ||
| 359 | case 'y': | ||
| 360 | case 'Y': | ||
| 361 | init_atu = IOP3XX_INIT_ATU_ENABLE; | ||
| 362 | break; | ||
| 363 | case 'n': | ||
| 364 | case 'N': | ||
| 365 | init_atu = IOP3XX_INIT_ATU_DISABLE; | ||
| 366 | break; | ||
| 367 | case ',': | ||
| 368 | case '=': | ||
| 369 | break; | ||
| 370 | default: | ||
| 371 | printk(KERN_DEBUG "\"%s\" malformed at " | ||
| 372 | "character: \'%c\'", | ||
| 373 | __FUNCTION__, | ||
| 374 | *str); | ||
| 375 | *(str + 1) = '\0'; | ||
| 376 | } | ||
| 377 | str++; | ||
| 378 | } | ||
| 379 | } | ||
| 380 | |||
| 381 | return 1; | ||
| 382 | } | ||
| 383 | |||
| 384 | __setup("iop3xx_init_atu", iop3xx_init_atu_setup); | ||
| 385 | |||
| diff --git a/arch/arm/plat-iop/time.c b/arch/arm/plat-iop/time.c index 16300adfb4de..0cc26da034a1 100644 --- a/arch/arm/plat-iop/time.c +++ b/arch/arm/plat-iop/time.c | |||
| @@ -32,22 +32,22 @@ static unsigned long next_jiffy_time; | |||
| 32 | 32 | ||
| 33 | unsigned long iop_gettimeoffset(void) | 33 | unsigned long iop_gettimeoffset(void) | 
| 34 | { | 34 | { | 
| 35 | unsigned long offset, temp1, temp2; | 35 | unsigned long offset, temp; | 
| 36 | 36 | ||
| 37 | /* enable cp6, if necessary, to avoid taking the overhead of an | 37 | /* enable cp6, if necessary, to avoid taking the overhead of an | 
| 38 | * undefined instruction trap | 38 | * undefined instruction trap | 
| 39 | */ | 39 | */ | 
| 40 | asm volatile ( | 40 | asm volatile ( | 
| 41 | "mrc p15, 0, %0, c15, c1, 0\n\t" | 41 | "mrc p15, 0, %0, c15, c1, 0\n\t" | 
| 42 | "ands %1, %0, #(1 << 6)\n\t" | 42 | "tst %0, #(1 << 6)\n\t" | 
| 43 | "orreq %0, %0, #(1 << 6)\n\t" | 43 | "orreq %0, %0, #(1 << 6)\n\t" | 
| 44 | "mcreq p15, 0, %0, c15, c1, 0\n\t" | 44 | "mcreq p15, 0, %0, c15, c1, 0\n\t" | 
| 45 | #ifdef CONFIG_XSCALE | 45 | #ifdef CONFIG_CPU_XSCALE | 
| 46 | "mrceq p15, 0, %0, c15, c1, 0\n\t" | 46 | "mrceq p15, 0, %0, c15, c1, 0\n\t" | 
| 47 | "moveq %0, %0\n\t" | 47 | "moveq %0, %0\n\t" | 
| 48 | "subeq pc, pc, #4\n\t" | 48 | "subeq pc, pc, #4\n\t" | 
| 49 | #endif | 49 | #endif | 
| 50 | : "=r"(temp1), "=r"(temp2) : : "cc"); | 50 | : "=r"(temp) : : "cc"); | 
| 51 | 51 | ||
| 52 | offset = next_jiffy_time - read_tcr1(); | 52 | offset = next_jiffy_time - read_tcr1(); | 
| 53 | 53 | ||
| diff --git a/arch/arm/plat-omap/Kconfig b/arch/arm/plat-omap/Kconfig index f2dc363de66b..9e8d21eca4ec 100644 --- a/arch/arm/plat-omap/Kconfig +++ b/arch/arm/plat-omap/Kconfig | |||
| @@ -11,6 +11,7 @@ choice | |||
| 11 | 11 | ||
| 12 | config ARCH_OMAP1 | 12 | config ARCH_OMAP1 | 
| 13 | bool "TI OMAP1" | 13 | bool "TI OMAP1" | 
| 14 | select GENERIC_CLOCKEVENTS | ||
| 14 | 15 | ||
| 15 | config ARCH_OMAP2 | 16 | config ARCH_OMAP2 | 
| 16 | bool "TI OMAP2" | 17 | bool "TI OMAP2" | 
| diff --git a/arch/arm/plat-omap/common.c b/arch/arm/plat-omap/common.c index 57b7b93674a4..fecd3d625995 100644 --- a/arch/arm/plat-omap/common.c +++ b/arch/arm/plat-omap/common.c | |||
| @@ -156,3 +156,53 @@ static int __init omap_add_serial_console(void) | |||
| 156 | return add_preferred_console("ttyS", line, opt); | 156 | return add_preferred_console("ttyS", line, opt); | 
| 157 | } | 157 | } | 
| 158 | console_initcall(omap_add_serial_console); | 158 | console_initcall(omap_add_serial_console); | 
| 159 | |||
| 160 | |||
| 161 | /* | ||
| 162 | * 32KHz clocksource ... always available, on pretty most chips except | ||
| 163 | * OMAP 730 and 1510. Other timers could be used as clocksources, with | ||
| 164 | * higher resolution in free-running counter modes (e.g. 12 MHz xtal), | ||
| 165 | * but systems won't necessarily want to spend resources that way. | ||
| 166 | */ | ||
| 167 | |||
| 168 | #if defined(CONFIG_ARCH_OMAP16XX) | ||
| 169 | #define TIMER_32K_SYNCHRONIZED 0xfffbc410 | ||
| 170 | #elif defined(CONFIG_ARCH_OMAP24XX) | ||
| 171 | #define TIMER_32K_SYNCHRONIZED 0x48004010 | ||
| 172 | #endif | ||
| 173 | |||
| 174 | #ifdef TIMER_32K_SYNCHRONIZED | ||
| 175 | |||
| 176 | #include <linux/clocksource.h> | ||
| 177 | |||
| 178 | static cycle_t omap_32k_read(void) | ||
| 179 | { | ||
| 180 | return omap_readl(TIMER_32K_SYNCHRONIZED); | ||
| 181 | } | ||
| 182 | |||
| 183 | static struct clocksource clocksource_32k = { | ||
| 184 | .name = "32k_counter", | ||
| 185 | .rating = 250, | ||
| 186 | .read = omap_32k_read, | ||
| 187 | .mask = CLOCKSOURCE_MASK(32), | ||
| 188 | .shift = 10, | ||
| 189 | .flags = CLOCK_SOURCE_IS_CONTINUOUS, | ||
| 190 | }; | ||
| 191 | |||
| 192 | static int __init omap_init_clocksource_32k(void) | ||
| 193 | { | ||
| 194 | static char err[] __initdata = KERN_ERR | ||
| 195 | "%s: can't register clocksource!\n"; | ||
| 196 | |||
| 197 | if (cpu_is_omap16xx() || cpu_is_omap24xx()) { | ||
| 198 | clocksource_32k.mult = clocksource_hz2mult(32768, | ||
| 199 | clocksource_32k.shift); | ||
| 200 | |||
| 201 | if (clocksource_register(&clocksource_32k)) | ||
| 202 | printk(err, clocksource_32k.name); | ||
| 203 | } | ||
| 204 | return 0; | ||
| 205 | } | ||
| 206 | arch_initcall(omap_init_clocksource_32k); | ||
| 207 | |||
| 208 | #endif /* TIMER_32K_SYNCHRONIZED */ | ||
| diff --git a/arch/arm/plat-omap/devices.c b/arch/arm/plat-omap/devices.c index dbc3f44e07a6..eeb33fed6f7c 100644 --- a/arch/arm/plat-omap/devices.c +++ b/arch/arm/plat-omap/devices.c | |||
| @@ -429,6 +429,10 @@ static inline void omap_init_rng(void) {} | |||
| 429 | */ | 429 | */ | 
| 430 | static int __init omap_init_devices(void) | 430 | static int __init omap_init_devices(void) | 
| 431 | { | 431 | { | 
| 432 | /* | ||
| 433 | * Need to enable relevant once for 2430 SDP | ||
| 434 | */ | ||
| 435 | #ifndef CONFIG_MACH_OMAP_2430SDP | ||
| 432 | /* please keep these calls, and their implementations above, | 436 | /* please keep these calls, and their implementations above, | 
| 433 | * in alphabetical order so they're easier to sort through. | 437 | * in alphabetical order so they're easier to sort through. | 
| 434 | */ | 438 | */ | 
| @@ -438,7 +442,7 @@ static int __init omap_init_devices(void) | |||
| 438 | omap_init_uwire(); | 442 | omap_init_uwire(); | 
| 439 | omap_init_wdt(); | 443 | omap_init_wdt(); | 
| 440 | omap_init_rng(); | 444 | omap_init_rng(); | 
| 441 | 445 | #endif | |
| 442 | return 0; | 446 | return 0; | 
| 443 | } | 447 | } | 
| 444 | arch_initcall(omap_init_devices); | 448 | arch_initcall(omap_init_devices); | 
| diff --git a/arch/arm/plat-omap/dmtimer.c b/arch/arm/plat-omap/dmtimer.c index 45f0439bffba..659619f235ca 100644 --- a/arch/arm/plat-omap/dmtimer.c +++ b/arch/arm/plat-omap/dmtimer.c | |||
| @@ -506,6 +506,8 @@ int omap_dm_timer_init(void) | |||
| 506 | BUG_ON(dm_source_clocks[i] == NULL); | 506 | BUG_ON(dm_source_clocks[i] == NULL); | 
| 507 | } | 507 | } | 
| 508 | #endif | 508 | #endif | 
| 509 | if (cpu_is_omap243x()) | ||
| 510 | dm_timers[0].phys_base = 0x49018000; | ||
| 509 | 511 | ||
| 510 | for (i = 0; i < dm_timer_count; i++) { | 512 | for (i = 0; i < dm_timer_count; i++) { | 
| 511 | #ifdef CONFIG_ARCH_OMAP2 | 513 | #ifdef CONFIG_ARCH_OMAP2 | 
| diff --git a/arch/arm/plat-omap/gpio.c b/arch/arm/plat-omap/gpio.c index 8bedc8f9b6e5..9dc6d3617bdb 100644 --- a/arch/arm/plat-omap/gpio.c +++ b/arch/arm/plat-omap/gpio.c | |||
| @@ -85,10 +85,17 @@ | |||
| 85 | /* | 85 | /* | 
| 86 | * omap24xx specific GPIO registers | 86 | * omap24xx specific GPIO registers | 
| 87 | */ | 87 | */ | 
| 88 | #define OMAP24XX_GPIO1_BASE (void __iomem *)0x48018000 | 88 | #define OMAP242X_GPIO1_BASE (void __iomem *)0x48018000 | 
| 89 | #define OMAP24XX_GPIO2_BASE (void __iomem *)0x4801a000 | 89 | #define OMAP242X_GPIO2_BASE (void __iomem *)0x4801a000 | 
| 90 | #define OMAP24XX_GPIO3_BASE (void __iomem *)0x4801c000 | 90 | #define OMAP242X_GPIO3_BASE (void __iomem *)0x4801c000 | 
| 91 | #define OMAP24XX_GPIO4_BASE (void __iomem *)0x4801e000 | 91 | #define OMAP242X_GPIO4_BASE (void __iomem *)0x4801e000 | 
| 92 | |||
| 93 | #define OMAP243X_GPIO1_BASE (void __iomem *)0x4900C000 | ||
| 94 | #define OMAP243X_GPIO2_BASE (void __iomem *)0x4900E000 | ||
| 95 | #define OMAP243X_GPIO3_BASE (void __iomem *)0x49010000 | ||
| 96 | #define OMAP243X_GPIO4_BASE (void __iomem *)0x49012000 | ||
| 97 | #define OMAP243X_GPIO5_BASE (void __iomem *)0x480B6000 | ||
| 98 | |||
| 92 | #define OMAP24XX_GPIO_REVISION 0x0000 | 99 | #define OMAP24XX_GPIO_REVISION 0x0000 | 
| 93 | #define OMAP24XX_GPIO_SYSCONFIG 0x0010 | 100 | #define OMAP24XX_GPIO_SYSCONFIG 0x0010 | 
| 94 | #define OMAP24XX_GPIO_SYSSTATUS 0x0014 | 101 | #define OMAP24XX_GPIO_SYSSTATUS 0x0014 | 
| @@ -117,8 +124,18 @@ struct gpio_bank { | |||
| 117 | u16 virtual_irq_start; | 124 | u16 virtual_irq_start; | 
| 118 | int method; | 125 | int method; | 
| 119 | u32 reserved_map; | 126 | u32 reserved_map; | 
| 127 | #if defined (CONFIG_ARCH_OMAP16XX) || defined (CONFIG_ARCH_OMAP24XX) | ||
| 120 | u32 suspend_wakeup; | 128 | u32 suspend_wakeup; | 
| 121 | u32 saved_wakeup; | 129 | u32 saved_wakeup; | 
| 130 | #endif | ||
| 131 | #ifdef CONFIG_ARCH_OMAP24XX | ||
| 132 | u32 non_wakeup_gpios; | ||
| 133 | u32 enabled_non_wakeup_gpios; | ||
| 134 | |||
| 135 | u32 saved_datain; | ||
| 136 | u32 saved_fallingdetect; | ||
| 137 | u32 saved_risingdetect; | ||
| 138 | #endif | ||
| 122 | spinlock_t lock; | 139 | spinlock_t lock; | 
| 123 | }; | 140 | }; | 
| 124 | 141 | ||
| @@ -158,12 +175,22 @@ static struct gpio_bank gpio_bank_730[7] = { | |||
| 158 | #endif | 175 | #endif | 
| 159 | 176 | ||
| 160 | #ifdef CONFIG_ARCH_OMAP24XX | 177 | #ifdef CONFIG_ARCH_OMAP24XX | 
| 161 | static struct gpio_bank gpio_bank_24xx[4] = { | 178 | |
| 162 | { OMAP24XX_GPIO1_BASE, INT_24XX_GPIO_BANK1, IH_GPIO_BASE, METHOD_GPIO_24XX }, | 179 | static struct gpio_bank gpio_bank_242x[4] = { | 
| 163 | { OMAP24XX_GPIO2_BASE, INT_24XX_GPIO_BANK2, IH_GPIO_BASE + 32, METHOD_GPIO_24XX }, | 180 | { OMAP242X_GPIO1_BASE, INT_24XX_GPIO_BANK1, IH_GPIO_BASE, METHOD_GPIO_24XX }, | 
| 164 | { OMAP24XX_GPIO3_BASE, INT_24XX_GPIO_BANK3, IH_GPIO_BASE + 64, METHOD_GPIO_24XX }, | 181 | { OMAP242X_GPIO2_BASE, INT_24XX_GPIO_BANK2, IH_GPIO_BASE + 32, METHOD_GPIO_24XX }, | 
| 165 | { OMAP24XX_GPIO4_BASE, INT_24XX_GPIO_BANK4, IH_GPIO_BASE + 96, METHOD_GPIO_24XX }, | 182 | { OMAP242X_GPIO3_BASE, INT_24XX_GPIO_BANK3, IH_GPIO_BASE + 64, METHOD_GPIO_24XX }, | 
| 183 | { OMAP242X_GPIO4_BASE, INT_24XX_GPIO_BANK4, IH_GPIO_BASE + 96, METHOD_GPIO_24XX }, | ||
| 184 | }; | ||
| 185 | |||
| 186 | static struct gpio_bank gpio_bank_243x[5] = { | ||
| 187 | { OMAP243X_GPIO1_BASE, INT_24XX_GPIO_BANK1, IH_GPIO_BASE, METHOD_GPIO_24XX }, | ||
| 188 | { OMAP243X_GPIO2_BASE, INT_24XX_GPIO_BANK2, IH_GPIO_BASE + 32, METHOD_GPIO_24XX }, | ||
| 189 | { OMAP243X_GPIO3_BASE, INT_24XX_GPIO_BANK3, IH_GPIO_BASE + 64, METHOD_GPIO_24XX }, | ||
| 190 | { OMAP243X_GPIO4_BASE, INT_24XX_GPIO_BANK4, IH_GPIO_BASE + 96, METHOD_GPIO_24XX }, | ||
| 191 | { OMAP243X_GPIO5_BASE, INT_24XX_GPIO_BANK5, IH_GPIO_BASE + 128, METHOD_GPIO_24XX }, | ||
| 166 | }; | 192 | }; | 
| 193 | |||
| 167 | #endif | 194 | #endif | 
| 168 | 195 | ||
| 169 | static struct gpio_bank *gpio_bank; | 196 | static struct gpio_bank *gpio_bank; | 
| @@ -257,21 +284,34 @@ static void _set_gpio_direction(struct gpio_bank *bank, int gpio, int is_input) | |||
| 257 | u32 l; | 284 | u32 l; | 
| 258 | 285 | ||
| 259 | switch (bank->method) { | 286 | switch (bank->method) { | 
| 287 | #ifdef CONFIG_ARCH_OMAP1 | ||
| 260 | case METHOD_MPUIO: | 288 | case METHOD_MPUIO: | 
| 261 | reg += OMAP_MPUIO_IO_CNTL; | 289 | reg += OMAP_MPUIO_IO_CNTL; | 
| 262 | break; | 290 | break; | 
| 291 | #endif | ||
| 292 | #ifdef CONFIG_ARCH_OMAP15XX | ||
| 263 | case METHOD_GPIO_1510: | 293 | case METHOD_GPIO_1510: | 
| 264 | reg += OMAP1510_GPIO_DIR_CONTROL; | 294 | reg += OMAP1510_GPIO_DIR_CONTROL; | 
| 265 | break; | 295 | break; | 
| 296 | #endif | ||
| 297 | #ifdef CONFIG_ARCH_OMAP16XX | ||
| 266 | case METHOD_GPIO_1610: | 298 | case METHOD_GPIO_1610: | 
| 267 | reg += OMAP1610_GPIO_DIRECTION; | 299 | reg += OMAP1610_GPIO_DIRECTION; | 
| 268 | break; | 300 | break; | 
| 301 | #endif | ||
| 302 | #ifdef CONFIG_ARCH_OMAP730 | ||
| 269 | case METHOD_GPIO_730: | 303 | case METHOD_GPIO_730: | 
| 270 | reg += OMAP730_GPIO_DIR_CONTROL; | 304 | reg += OMAP730_GPIO_DIR_CONTROL; | 
| 271 | break; | 305 | break; | 
| 306 | #endif | ||
| 307 | #ifdef CONFIG_ARCH_OMAP24XX | ||
| 272 | case METHOD_GPIO_24XX: | 308 | case METHOD_GPIO_24XX: | 
| 273 | reg += OMAP24XX_GPIO_OE; | 309 | reg += OMAP24XX_GPIO_OE; | 
| 274 | break; | 310 | break; | 
| 311 | #endif | ||
| 312 | default: | ||
| 313 | WARN_ON(1); | ||
| 314 | return; | ||
| 275 | } | 315 | } | 
| 276 | l = __raw_readl(reg); | 316 | l = __raw_readl(reg); | 
| 277 | if (is_input) | 317 | if (is_input) | 
| @@ -299,6 +339,7 @@ static void _set_gpio_dataout(struct gpio_bank *bank, int gpio, int enable) | |||
| 299 | u32 l = 0; | 339 | u32 l = 0; | 
| 300 | 340 | ||
| 301 | switch (bank->method) { | 341 | switch (bank->method) { | 
| 342 | #ifdef CONFIG_ARCH_OMAP1 | ||
| 302 | case METHOD_MPUIO: | 343 | case METHOD_MPUIO: | 
| 303 | reg += OMAP_MPUIO_OUTPUT; | 344 | reg += OMAP_MPUIO_OUTPUT; | 
| 304 | l = __raw_readl(reg); | 345 | l = __raw_readl(reg); | 
| @@ -307,6 +348,8 @@ static void _set_gpio_dataout(struct gpio_bank *bank, int gpio, int enable) | |||
| 307 | else | 348 | else | 
| 308 | l &= ~(1 << gpio); | 349 | l &= ~(1 << gpio); | 
| 309 | break; | 350 | break; | 
| 351 | #endif | ||
| 352 | #ifdef CONFIG_ARCH_OMAP15XX | ||
| 310 | case METHOD_GPIO_1510: | 353 | case METHOD_GPIO_1510: | 
| 311 | reg += OMAP1510_GPIO_DATA_OUTPUT; | 354 | reg += OMAP1510_GPIO_DATA_OUTPUT; | 
| 312 | l = __raw_readl(reg); | 355 | l = __raw_readl(reg); | 
| @@ -315,6 +358,8 @@ static void _set_gpio_dataout(struct gpio_bank *bank, int gpio, int enable) | |||
| 315 | else | 358 | else | 
| 316 | l &= ~(1 << gpio); | 359 | l &= ~(1 << gpio); | 
| 317 | break; | 360 | break; | 
| 361 | #endif | ||
| 362 | #ifdef CONFIG_ARCH_OMAP16XX | ||
| 318 | case METHOD_GPIO_1610: | 363 | case METHOD_GPIO_1610: | 
| 319 | if (enable) | 364 | if (enable) | 
| 320 | reg += OMAP1610_GPIO_SET_DATAOUT; | 365 | reg += OMAP1610_GPIO_SET_DATAOUT; | 
| @@ -322,6 +367,8 @@ static void _set_gpio_dataout(struct gpio_bank *bank, int gpio, int enable) | |||
| 322 | reg += OMAP1610_GPIO_CLEAR_DATAOUT; | 367 | reg += OMAP1610_GPIO_CLEAR_DATAOUT; | 
| 323 | l = 1 << gpio; | 368 | l = 1 << gpio; | 
| 324 | break; | 369 | break; | 
| 370 | #endif | ||
| 371 | #ifdef CONFIG_ARCH_OMAP730 | ||
| 325 | case METHOD_GPIO_730: | 372 | case METHOD_GPIO_730: | 
| 326 | reg += OMAP730_GPIO_DATA_OUTPUT; | 373 | reg += OMAP730_GPIO_DATA_OUTPUT; | 
| 327 | l = __raw_readl(reg); | 374 | l = __raw_readl(reg); | 
| @@ -330,6 +377,8 @@ static void _set_gpio_dataout(struct gpio_bank *bank, int gpio, int enable) | |||
| 330 | else | 377 | else | 
| 331 | l &= ~(1 << gpio); | 378 | l &= ~(1 << gpio); | 
| 332 | break; | 379 | break; | 
| 380 | #endif | ||
| 381 | #ifdef CONFIG_ARCH_OMAP24XX | ||
| 333 | case METHOD_GPIO_24XX: | 382 | case METHOD_GPIO_24XX: | 
| 334 | if (enable) | 383 | if (enable) | 
| 335 | reg += OMAP24XX_GPIO_SETDATAOUT; | 384 | reg += OMAP24XX_GPIO_SETDATAOUT; | 
| @@ -337,8 +386,9 @@ static void _set_gpio_dataout(struct gpio_bank *bank, int gpio, int enable) | |||
| 337 | reg += OMAP24XX_GPIO_CLEARDATAOUT; | 386 | reg += OMAP24XX_GPIO_CLEARDATAOUT; | 
| 338 | l = 1 << gpio; | 387 | l = 1 << gpio; | 
| 339 | break; | 388 | break; | 
| 389 | #endif | ||
| 340 | default: | 390 | default: | 
| 341 | BUG(); | 391 | WARN_ON(1); | 
| 342 | return; | 392 | return; | 
| 343 | } | 393 | } | 
| 344 | __raw_writel(l, reg); | 394 | __raw_writel(l, reg); | 
| @@ -362,28 +412,37 @@ int omap_get_gpio_datain(int gpio) | |||
| 362 | void __iomem *reg; | 412 | void __iomem *reg; | 
| 363 | 413 | ||
| 364 | if (check_gpio(gpio) < 0) | 414 | if (check_gpio(gpio) < 0) | 
| 365 | return -1; | 415 | return -EINVAL; | 
| 366 | bank = get_gpio_bank(gpio); | 416 | bank = get_gpio_bank(gpio); | 
| 367 | reg = bank->base; | 417 | reg = bank->base; | 
| 368 | switch (bank->method) { | 418 | switch (bank->method) { | 
| 419 | #ifdef CONFIG_ARCH_OMAP1 | ||
| 369 | case METHOD_MPUIO: | 420 | case METHOD_MPUIO: | 
| 370 | reg += OMAP_MPUIO_INPUT_LATCH; | 421 | reg += OMAP_MPUIO_INPUT_LATCH; | 
| 371 | break; | 422 | break; | 
| 423 | #endif | ||
| 424 | #ifdef CONFIG_ARCH_OMAP15XX | ||
| 372 | case METHOD_GPIO_1510: | 425 | case METHOD_GPIO_1510: | 
| 373 | reg += OMAP1510_GPIO_DATA_INPUT; | 426 | reg += OMAP1510_GPIO_DATA_INPUT; | 
| 374 | break; | 427 | break; | 
| 428 | #endif | ||
| 429 | #ifdef CONFIG_ARCH_OMAP16XX | ||
| 375 | case METHOD_GPIO_1610: | 430 | case METHOD_GPIO_1610: | 
| 376 | reg += OMAP1610_GPIO_DATAIN; | 431 | reg += OMAP1610_GPIO_DATAIN; | 
| 377 | break; | 432 | break; | 
| 433 | #endif | ||
| 434 | #ifdef CONFIG_ARCH_OMAP730 | ||
| 378 | case METHOD_GPIO_730: | 435 | case METHOD_GPIO_730: | 
| 379 | reg += OMAP730_GPIO_DATA_INPUT; | 436 | reg += OMAP730_GPIO_DATA_INPUT; | 
| 380 | break; | 437 | break; | 
| 438 | #endif | ||
| 439 | #ifdef CONFIG_ARCH_OMAP24XX | ||
| 381 | case METHOD_GPIO_24XX: | 440 | case METHOD_GPIO_24XX: | 
| 382 | reg += OMAP24XX_GPIO_DATAIN; | 441 | reg += OMAP24XX_GPIO_DATAIN; | 
| 383 | break; | 442 | break; | 
| 443 | #endif | ||
| 384 | default: | 444 | default: | 
| 385 | BUG(); | 445 | return -EINVAL; | 
| 386 | return -1; | ||
| 387 | } | 446 | } | 
| 388 | return (__raw_readl(reg) | 447 | return (__raw_readl(reg) | 
| 389 | & (1 << get_gpio_index(gpio))) != 0; | 448 | & (1 << get_gpio_index(gpio))) != 0; | 
| @@ -397,8 +456,10 @@ do { \ | |||
| 397 | __raw_writel(l, base + reg); \ | 456 | __raw_writel(l, base + reg); \ | 
| 398 | } while(0) | 457 | } while(0) | 
| 399 | 458 | ||
| 400 | static inline void set_24xx_gpio_triggering(void __iomem *base, int gpio, int trigger) | 459 | #ifdef CONFIG_ARCH_OMAP24XX | 
| 460 | static inline void set_24xx_gpio_triggering(struct gpio_bank *bank, int gpio, int trigger) | ||
| 401 | { | 461 | { | 
| 462 | void __iomem *base = bank->base; | ||
| 402 | u32 gpio_bit = 1 << gpio; | 463 | u32 gpio_bit = 1 << gpio; | 
| 403 | 464 | ||
| 404 | MOD_REG_BIT(OMAP24XX_GPIO_LEVELDETECT0, gpio_bit, | 465 | MOD_REG_BIT(OMAP24XX_GPIO_LEVELDETECT0, gpio_bit, | 
| @@ -409,9 +470,21 @@ static inline void set_24xx_gpio_triggering(void __iomem *base, int gpio, int tr | |||
| 409 | trigger & __IRQT_RISEDGE); | 470 | trigger & __IRQT_RISEDGE); | 
| 410 | MOD_REG_BIT(OMAP24XX_GPIO_FALLINGDETECT, gpio_bit, | 471 | MOD_REG_BIT(OMAP24XX_GPIO_FALLINGDETECT, gpio_bit, | 
| 411 | trigger & __IRQT_FALEDGE); | 472 | trigger & __IRQT_FALEDGE); | 
| 473 | if (likely(!(bank->non_wakeup_gpios & gpio_bit))) { | ||
| 474 | if (trigger != 0) | ||
| 475 | __raw_writel(1 << gpio, bank->base + OMAP24XX_GPIO_SETWKUENA); | ||
| 476 | else | ||
| 477 | __raw_writel(1 << gpio, bank->base + OMAP24XX_GPIO_CLEARWKUENA); | ||
| 478 | } else { | ||
| 479 | if (trigger != 0) | ||
| 480 | bank->enabled_non_wakeup_gpios |= gpio_bit; | ||
| 481 | else | ||
| 482 | bank->enabled_non_wakeup_gpios &= ~gpio_bit; | ||
| 483 | } | ||
| 412 | /* FIXME: Possibly do 'set_irq_handler(j, handle_level_irq)' if only level | 484 | /* FIXME: Possibly do 'set_irq_handler(j, handle_level_irq)' if only level | 
| 413 | * triggering requested. */ | 485 | * triggering requested. */ | 
| 414 | } | 486 | } | 
| 487 | #endif | ||
| 415 | 488 | ||
| 416 | static int _set_gpio_triggering(struct gpio_bank *bank, int gpio, int trigger) | 489 | static int _set_gpio_triggering(struct gpio_bank *bank, int gpio, int trigger) | 
| 417 | { | 490 | { | 
| @@ -419,6 +492,7 @@ static int _set_gpio_triggering(struct gpio_bank *bank, int gpio, int trigger) | |||
| 419 | u32 l = 0; | 492 | u32 l = 0; | 
| 420 | 493 | ||
| 421 | switch (bank->method) { | 494 | switch (bank->method) { | 
| 495 | #ifdef CONFIG_ARCH_OMAP1 | ||
| 422 | case METHOD_MPUIO: | 496 | case METHOD_MPUIO: | 
| 423 | reg += OMAP_MPUIO_GPIO_INT_EDGE; | 497 | reg += OMAP_MPUIO_GPIO_INT_EDGE; | 
| 424 | l = __raw_readl(reg); | 498 | l = __raw_readl(reg); | 
| @@ -429,6 +503,8 @@ static int _set_gpio_triggering(struct gpio_bank *bank, int gpio, int trigger) | |||
| 429 | else | 503 | else | 
| 430 | goto bad; | 504 | goto bad; | 
| 431 | break; | 505 | break; | 
| 506 | #endif | ||
| 507 | #ifdef CONFIG_ARCH_OMAP15XX | ||
| 432 | case METHOD_GPIO_1510: | 508 | case METHOD_GPIO_1510: | 
| 433 | reg += OMAP1510_GPIO_INT_CONTROL; | 509 | reg += OMAP1510_GPIO_INT_CONTROL; | 
| 434 | l = __raw_readl(reg); | 510 | l = __raw_readl(reg); | 
| @@ -439,22 +515,28 @@ static int _set_gpio_triggering(struct gpio_bank *bank, int gpio, int trigger) | |||
| 439 | else | 515 | else | 
| 440 | goto bad; | 516 | goto bad; | 
| 441 | break; | 517 | break; | 
| 518 | #endif | ||
| 519 | #ifdef CONFIG_ARCH_OMAP16XX | ||
| 442 | case METHOD_GPIO_1610: | 520 | case METHOD_GPIO_1610: | 
| 443 | if (gpio & 0x08) | 521 | if (gpio & 0x08) | 
| 444 | reg += OMAP1610_GPIO_EDGE_CTRL2; | 522 | reg += OMAP1610_GPIO_EDGE_CTRL2; | 
| 445 | else | 523 | else | 
| 446 | reg += OMAP1610_GPIO_EDGE_CTRL1; | 524 | reg += OMAP1610_GPIO_EDGE_CTRL1; | 
| 447 | gpio &= 0x07; | 525 | gpio &= 0x07; | 
| 448 | /* We allow only edge triggering, i.e. two lowest bits */ | ||
| 449 | if (trigger & (__IRQT_LOWLVL | __IRQT_HIGHLVL)) | ||
| 450 | BUG(); | ||
| 451 | l = __raw_readl(reg); | 526 | l = __raw_readl(reg); | 
| 452 | l &= ~(3 << (gpio << 1)); | 527 | l &= ~(3 << (gpio << 1)); | 
| 453 | if (trigger & __IRQT_RISEDGE) | 528 | if (trigger & __IRQT_RISEDGE) | 
| 454 | l |= 2 << (gpio << 1); | 529 | l |= 2 << (gpio << 1); | 
| 455 | if (trigger & __IRQT_FALEDGE) | 530 | if (trigger & __IRQT_FALEDGE) | 
| 456 | l |= 1 << (gpio << 1); | 531 | l |= 1 << (gpio << 1); | 
| 532 | if (trigger) | ||
| 533 | /* Enable wake-up during idle for dynamic tick */ | ||
| 534 | __raw_writel(1 << gpio, bank->base + OMAP1610_GPIO_SET_WAKEUPENA); | ||
| 535 | else | ||
| 536 | __raw_writel(1 << gpio, bank->base + OMAP1610_GPIO_CLEAR_WAKEUPENA); | ||
| 457 | break; | 537 | break; | 
| 538 | #endif | ||
| 539 | #ifdef CONFIG_ARCH_OMAP730 | ||
| 458 | case METHOD_GPIO_730: | 540 | case METHOD_GPIO_730: | 
| 459 | reg += OMAP730_GPIO_INT_CONTROL; | 541 | reg += OMAP730_GPIO_INT_CONTROL; | 
| 460 | l = __raw_readl(reg); | 542 | l = __raw_readl(reg); | 
| @@ -465,11 +547,13 @@ static int _set_gpio_triggering(struct gpio_bank *bank, int gpio, int trigger) | |||
| 465 | else | 547 | else | 
| 466 | goto bad; | 548 | goto bad; | 
| 467 | break; | 549 | break; | 
| 550 | #endif | ||
| 551 | #ifdef CONFIG_ARCH_OMAP24XX | ||
| 468 | case METHOD_GPIO_24XX: | 552 | case METHOD_GPIO_24XX: | 
| 469 | set_24xx_gpio_triggering(reg, gpio, trigger); | 553 | set_24xx_gpio_triggering(bank, gpio, trigger); | 
| 470 | break; | 554 | break; | 
| 555 | #endif | ||
| 471 | default: | 556 | default: | 
| 472 | BUG(); | ||
| 473 | goto bad; | 557 | goto bad; | 
| 474 | } | 558 | } | 
| 475 | __raw_writel(l, reg); | 559 | __raw_writel(l, reg); | 
| @@ -484,7 +568,7 @@ static int gpio_irq_type(unsigned irq, unsigned type) | |||
| 484 | unsigned gpio; | 568 | unsigned gpio; | 
| 485 | int retval; | 569 | int retval; | 
| 486 | 570 | ||
| 487 | if (irq > IH_MPUIO_BASE) | 571 | if (!cpu_is_omap24xx() && irq > IH_MPUIO_BASE) | 
| 488 | gpio = OMAP_MPUIO(irq - IH_MPUIO_BASE); | 572 | gpio = OMAP_MPUIO(irq - IH_MPUIO_BASE); | 
| 489 | else | 573 | else | 
| 490 | gpio = irq - IH_GPIO_BASE; | 574 | gpio = irq - IH_GPIO_BASE; | 
| @@ -492,14 +576,21 @@ static int gpio_irq_type(unsigned irq, unsigned type) | |||
| 492 | if (check_gpio(gpio) < 0) | 576 | if (check_gpio(gpio) < 0) | 
| 493 | return -EINVAL; | 577 | return -EINVAL; | 
| 494 | 578 | ||
| 495 | if (type & IRQT_PROBE) | 579 | if (type & ~IRQ_TYPE_SENSE_MASK) | 
| 496 | return -EINVAL; | 580 | return -EINVAL; | 
| 497 | if (!cpu_is_omap24xx() && (type & (__IRQT_LOWLVL|__IRQT_HIGHLVL))) | 581 | |
| 582 | /* OMAP1 allows only only edge triggering */ | ||
| 583 | if (!cpu_is_omap24xx() | ||
| 584 | && (type & (IRQ_TYPE_LEVEL_LOW|IRQ_TYPE_LEVEL_HIGH))) | ||
| 498 | return -EINVAL; | 585 | return -EINVAL; | 
| 499 | 586 | ||
| 500 | bank = get_gpio_bank(gpio); | 587 | bank = get_irq_chip_data(irq); | 
| 501 | spin_lock(&bank->lock); | 588 | spin_lock(&bank->lock); | 
| 502 | retval = _set_gpio_triggering(bank, get_gpio_index(gpio), type); | 589 | retval = _set_gpio_triggering(bank, get_gpio_index(gpio), type); | 
| 590 | if (retval == 0) { | ||
| 591 | irq_desc[irq].status &= ~IRQ_TYPE_SENSE_MASK; | ||
| 592 | irq_desc[irq].status |= type; | ||
| 593 | } | ||
| 503 | spin_unlock(&bank->lock); | 594 | spin_unlock(&bank->lock); | 
| 504 | return retval; | 595 | return retval; | 
| 505 | } | 596 | } | 
| @@ -509,24 +600,34 @@ static void _clear_gpio_irqbank(struct gpio_bank *bank, int gpio_mask) | |||
| 509 | void __iomem *reg = bank->base; | 600 | void __iomem *reg = bank->base; | 
| 510 | 601 | ||
| 511 | switch (bank->method) { | 602 | switch (bank->method) { | 
| 603 | #ifdef CONFIG_ARCH_OMAP1 | ||
| 512 | case METHOD_MPUIO: | 604 | case METHOD_MPUIO: | 
| 513 | /* MPUIO irqstatus is reset by reading the status register, | 605 | /* MPUIO irqstatus is reset by reading the status register, | 
| 514 | * so do nothing here */ | 606 | * so do nothing here */ | 
| 515 | return; | 607 | return; | 
| 608 | #endif | ||
| 609 | #ifdef CONFIG_ARCH_OMAP15XX | ||
| 516 | case METHOD_GPIO_1510: | 610 | case METHOD_GPIO_1510: | 
| 517 | reg += OMAP1510_GPIO_INT_STATUS; | 611 | reg += OMAP1510_GPIO_INT_STATUS; | 
| 518 | break; | 612 | break; | 
| 613 | #endif | ||
| 614 | #ifdef CONFIG_ARCH_OMAP16XX | ||
| 519 | case METHOD_GPIO_1610: | 615 | case METHOD_GPIO_1610: | 
| 520 | reg += OMAP1610_GPIO_IRQSTATUS1; | 616 | reg += OMAP1610_GPIO_IRQSTATUS1; | 
| 521 | break; | 617 | break; | 
| 618 | #endif | ||
| 619 | #ifdef CONFIG_ARCH_OMAP730 | ||
| 522 | case METHOD_GPIO_730: | 620 | case METHOD_GPIO_730: | 
| 523 | reg += OMAP730_GPIO_INT_STATUS; | 621 | reg += OMAP730_GPIO_INT_STATUS; | 
| 524 | break; | 622 | break; | 
| 623 | #endif | ||
| 624 | #ifdef CONFIG_ARCH_OMAP24XX | ||
| 525 | case METHOD_GPIO_24XX: | 625 | case METHOD_GPIO_24XX: | 
| 526 | reg += OMAP24XX_GPIO_IRQSTATUS1; | 626 | reg += OMAP24XX_GPIO_IRQSTATUS1; | 
| 527 | break; | 627 | break; | 
| 628 | #endif | ||
| 528 | default: | 629 | default: | 
| 529 | BUG(); | 630 | WARN_ON(1); | 
| 530 | return; | 631 | return; | 
| 531 | } | 632 | } | 
| 532 | __raw_writel(gpio_mask, reg); | 633 | __raw_writel(gpio_mask, reg); | 
| @@ -549,31 +650,41 @@ static u32 _get_gpio_irqbank_mask(struct gpio_bank *bank) | |||
| 549 | u32 mask; | 650 | u32 mask; | 
| 550 | 651 | ||
| 551 | switch (bank->method) { | 652 | switch (bank->method) { | 
| 653 | #ifdef CONFIG_ARCH_OMAP1 | ||
| 552 | case METHOD_MPUIO: | 654 | case METHOD_MPUIO: | 
| 553 | reg += OMAP_MPUIO_GPIO_MASKIT; | 655 | reg += OMAP_MPUIO_GPIO_MASKIT; | 
| 554 | mask = 0xffff; | 656 | mask = 0xffff; | 
| 555 | inv = 1; | 657 | inv = 1; | 
| 556 | break; | 658 | break; | 
| 659 | #endif | ||
| 660 | #ifdef CONFIG_ARCH_OMAP15XX | ||
| 557 | case METHOD_GPIO_1510: | 661 | case METHOD_GPIO_1510: | 
| 558 | reg += OMAP1510_GPIO_INT_MASK; | 662 | reg += OMAP1510_GPIO_INT_MASK; | 
| 559 | mask = 0xffff; | 663 | mask = 0xffff; | 
| 560 | inv = 1; | 664 | inv = 1; | 
| 561 | break; | 665 | break; | 
| 666 | #endif | ||
| 667 | #ifdef CONFIG_ARCH_OMAP16XX | ||
| 562 | case METHOD_GPIO_1610: | 668 | case METHOD_GPIO_1610: | 
| 563 | reg += OMAP1610_GPIO_IRQENABLE1; | 669 | reg += OMAP1610_GPIO_IRQENABLE1; | 
| 564 | mask = 0xffff; | 670 | mask = 0xffff; | 
| 565 | break; | 671 | break; | 
| 672 | #endif | ||
| 673 | #ifdef CONFIG_ARCH_OMAP730 | ||
| 566 | case METHOD_GPIO_730: | 674 | case METHOD_GPIO_730: | 
| 567 | reg += OMAP730_GPIO_INT_MASK; | 675 | reg += OMAP730_GPIO_INT_MASK; | 
| 568 | mask = 0xffffffff; | 676 | mask = 0xffffffff; | 
| 569 | inv = 1; | 677 | inv = 1; | 
| 570 | break; | 678 | break; | 
| 679 | #endif | ||
| 680 | #ifdef CONFIG_ARCH_OMAP24XX | ||
| 571 | case METHOD_GPIO_24XX: | 681 | case METHOD_GPIO_24XX: | 
| 572 | reg += OMAP24XX_GPIO_IRQENABLE1; | 682 | reg += OMAP24XX_GPIO_IRQENABLE1; | 
| 573 | mask = 0xffffffff; | 683 | mask = 0xffffffff; | 
| 574 | break; | 684 | break; | 
| 685 | #endif | ||
| 575 | default: | 686 | default: | 
| 576 | BUG(); | 687 | WARN_ON(1); | 
| 577 | return 0; | 688 | return 0; | 
| 578 | } | 689 | } | 
| 579 | 690 | ||
| @@ -590,6 +701,7 @@ static void _enable_gpio_irqbank(struct gpio_bank *bank, int gpio_mask, int enab | |||
| 590 | u32 l; | 701 | u32 l; | 
| 591 | 702 | ||
| 592 | switch (bank->method) { | 703 | switch (bank->method) { | 
| 704 | #ifdef CONFIG_ARCH_OMAP1 | ||
| 593 | case METHOD_MPUIO: | 705 | case METHOD_MPUIO: | 
| 594 | reg += OMAP_MPUIO_GPIO_MASKIT; | 706 | reg += OMAP_MPUIO_GPIO_MASKIT; | 
| 595 | l = __raw_readl(reg); | 707 | l = __raw_readl(reg); | 
| @@ -598,6 +710,8 @@ static void _enable_gpio_irqbank(struct gpio_bank *bank, int gpio_mask, int enab | |||
| 598 | else | 710 | else | 
| 599 | l |= gpio_mask; | 711 | l |= gpio_mask; | 
| 600 | break; | 712 | break; | 
| 713 | #endif | ||
| 714 | #ifdef CONFIG_ARCH_OMAP15XX | ||
| 601 | case METHOD_GPIO_1510: | 715 | case METHOD_GPIO_1510: | 
| 602 | reg += OMAP1510_GPIO_INT_MASK; | 716 | reg += OMAP1510_GPIO_INT_MASK; | 
| 603 | l = __raw_readl(reg); | 717 | l = __raw_readl(reg); | 
| @@ -606,6 +720,8 @@ static void _enable_gpio_irqbank(struct gpio_bank *bank, int gpio_mask, int enab | |||
| 606 | else | 720 | else | 
| 607 | l |= gpio_mask; | 721 | l |= gpio_mask; | 
| 608 | break; | 722 | break; | 
| 723 | #endif | ||
| 724 | #ifdef CONFIG_ARCH_OMAP16XX | ||
| 609 | case METHOD_GPIO_1610: | 725 | case METHOD_GPIO_1610: | 
| 610 | if (enable) | 726 | if (enable) | 
| 611 | reg += OMAP1610_GPIO_SET_IRQENABLE1; | 727 | reg += OMAP1610_GPIO_SET_IRQENABLE1; | 
| @@ -613,6 +729,8 @@ static void _enable_gpio_irqbank(struct gpio_bank *bank, int gpio_mask, int enab | |||
| 613 | reg += OMAP1610_GPIO_CLEAR_IRQENABLE1; | 729 | reg += OMAP1610_GPIO_CLEAR_IRQENABLE1; | 
| 614 | l = gpio_mask; | 730 | l = gpio_mask; | 
| 615 | break; | 731 | break; | 
| 732 | #endif | ||
| 733 | #ifdef CONFIG_ARCH_OMAP730 | ||
| 616 | case METHOD_GPIO_730: | 734 | case METHOD_GPIO_730: | 
| 617 | reg += OMAP730_GPIO_INT_MASK; | 735 | reg += OMAP730_GPIO_INT_MASK; | 
| 618 | l = __raw_readl(reg); | 736 | l = __raw_readl(reg); | 
| @@ -621,6 +739,8 @@ static void _enable_gpio_irqbank(struct gpio_bank *bank, int gpio_mask, int enab | |||
| 621 | else | 739 | else | 
| 622 | l |= gpio_mask; | 740 | l |= gpio_mask; | 
| 623 | break; | 741 | break; | 
| 742 | #endif | ||
| 743 | #ifdef CONFIG_ARCH_OMAP24XX | ||
| 624 | case METHOD_GPIO_24XX: | 744 | case METHOD_GPIO_24XX: | 
| 625 | if (enable) | 745 | if (enable) | 
| 626 | reg += OMAP24XX_GPIO_SETIRQENABLE1; | 746 | reg += OMAP24XX_GPIO_SETIRQENABLE1; | 
| @@ -628,8 +748,9 @@ static void _enable_gpio_irqbank(struct gpio_bank *bank, int gpio_mask, int enab | |||
| 628 | reg += OMAP24XX_GPIO_CLEARIRQENABLE1; | 748 | reg += OMAP24XX_GPIO_CLEARIRQENABLE1; | 
| 629 | l = gpio_mask; | 749 | l = gpio_mask; | 
| 630 | break; | 750 | break; | 
| 751 | #endif | ||
| 631 | default: | 752 | default: | 
| 632 | BUG(); | 753 | WARN_ON(1); | 
| 633 | return; | 754 | return; | 
| 634 | } | 755 | } | 
| 635 | __raw_writel(l, reg); | 756 | __raw_writel(l, reg); | 
| @@ -651,15 +772,39 @@ static inline void _set_gpio_irqenable(struct gpio_bank *bank, int gpio, int ena | |||
| 651 | static int _set_gpio_wakeup(struct gpio_bank *bank, int gpio, int enable) | 772 | static int _set_gpio_wakeup(struct gpio_bank *bank, int gpio, int enable) | 
| 652 | { | 773 | { | 
| 653 | switch (bank->method) { | 774 | switch (bank->method) { | 
| 775 | #ifdef CONFIG_ARCH_OMAP16XX | ||
| 776 | case METHOD_MPUIO: | ||
| 654 | case METHOD_GPIO_1610: | 777 | case METHOD_GPIO_1610: | 
| 778 | spin_lock(&bank->lock); | ||
| 779 | if (enable) { | ||
| 780 | bank->suspend_wakeup |= (1 << gpio); | ||
| 781 | enable_irq_wake(bank->irq); | ||
| 782 | } else { | ||
| 783 | disable_irq_wake(bank->irq); | ||
| 784 | bank->suspend_wakeup &= ~(1 << gpio); | ||
| 785 | } | ||
| 786 | spin_unlock(&bank->lock); | ||
| 787 | return 0; | ||
| 788 | #endif | ||
| 789 | #ifdef CONFIG_ARCH_OMAP24XX | ||
| 655 | case METHOD_GPIO_24XX: | 790 | case METHOD_GPIO_24XX: | 
| 791 | if (bank->non_wakeup_gpios & (1 << gpio)) { | ||
| 792 | printk(KERN_ERR "Unable to modify wakeup on " | ||
| 793 | "non-wakeup GPIO%d\n", | ||
| 794 | (bank - gpio_bank) * 32 + gpio); | ||
| 795 | return -EINVAL; | ||
| 796 | } | ||
| 656 | spin_lock(&bank->lock); | 797 | spin_lock(&bank->lock); | 
| 657 | if (enable) | 798 | if (enable) { | 
| 658 | bank->suspend_wakeup |= (1 << gpio); | 799 | bank->suspend_wakeup |= (1 << gpio); | 
| 659 | else | 800 | enable_irq_wake(bank->irq); | 
| 801 | } else { | ||
| 802 | disable_irq_wake(bank->irq); | ||
| 660 | bank->suspend_wakeup &= ~(1 << gpio); | 803 | bank->suspend_wakeup &= ~(1 << gpio); | 
| 804 | } | ||
| 661 | spin_unlock(&bank->lock); | 805 | spin_unlock(&bank->lock); | 
| 662 | return 0; | 806 | return 0; | 
| 807 | #endif | ||
| 663 | default: | 808 | default: | 
| 664 | printk(KERN_ERR "Can't enable GPIO wakeup for method %i\n", | 809 | printk(KERN_ERR "Can't enable GPIO wakeup for method %i\n", | 
| 665 | bank->method); | 810 | bank->method); | 
| @@ -684,7 +829,7 @@ static int gpio_wake_enable(unsigned int irq, unsigned int enable) | |||
| 684 | 829 | ||
| 685 | if (check_gpio(gpio) < 0) | 830 | if (check_gpio(gpio) < 0) | 
| 686 | return -ENODEV; | 831 | return -ENODEV; | 
| 687 | bank = get_gpio_bank(gpio); | 832 | bank = get_irq_chip_data(irq); | 
| 688 | retval = _set_gpio_wakeup(bank, get_gpio_index(gpio), enable); | 833 | retval = _set_gpio_wakeup(bank, get_gpio_index(gpio), enable); | 
| 689 | 834 | ||
| 690 | return retval; | 835 | return retval; | 
| @@ -721,20 +866,6 @@ int omap_request_gpio(int gpio) | |||
| 721 | __raw_writel(__raw_readl(reg) | (1 << get_gpio_index(gpio)), reg); | 866 | __raw_writel(__raw_readl(reg) | (1 << get_gpio_index(gpio)), reg); | 
| 722 | } | 867 | } | 
| 723 | #endif | 868 | #endif | 
| 724 | #ifdef CONFIG_ARCH_OMAP16XX | ||
| 725 | if (bank->method == METHOD_GPIO_1610) { | ||
| 726 | /* Enable wake-up during idle for dynamic tick */ | ||
| 727 | void __iomem *reg = bank->base + OMAP1610_GPIO_SET_WAKEUPENA; | ||
| 728 | __raw_writel(1 << get_gpio_index(gpio), reg); | ||
| 729 | } | ||
| 730 | #endif | ||
| 731 | #ifdef CONFIG_ARCH_OMAP24XX | ||
| 732 | if (bank->method == METHOD_GPIO_24XX) { | ||
| 733 | /* Enable wake-up during idle for dynamic tick */ | ||
| 734 | void __iomem *reg = bank->base + OMAP24XX_GPIO_SETWKUENA; | ||
| 735 | __raw_writel(1 << get_gpio_index(gpio), reg); | ||
| 736 | } | ||
| 737 | #endif | ||
| 738 | spin_unlock(&bank->lock); | 869 | spin_unlock(&bank->lock); | 
| 739 | 870 | ||
| 740 | return 0; | 871 | return 0; | 
| @@ -794,8 +925,10 @@ static void gpio_irq_handler(unsigned int irq, struct irq_desc *desc) | |||
| 794 | desc->chip->ack(irq); | 925 | desc->chip->ack(irq); | 
| 795 | 926 | ||
| 796 | bank = get_irq_data(irq); | 927 | bank = get_irq_data(irq); | 
| 928 | #ifdef CONFIG_ARCH_OMAP1 | ||
| 797 | if (bank->method == METHOD_MPUIO) | 929 | if (bank->method == METHOD_MPUIO) | 
| 798 | isr_reg = bank->base + OMAP_MPUIO_GPIO_INT; | 930 | isr_reg = bank->base + OMAP_MPUIO_GPIO_INT; | 
| 931 | #endif | ||
| 799 | #ifdef CONFIG_ARCH_OMAP15XX | 932 | #ifdef CONFIG_ARCH_OMAP15XX | 
| 800 | if (bank->method == METHOD_GPIO_1510) | 933 | if (bank->method == METHOD_GPIO_1510) | 
| 801 | isr_reg = bank->base + OMAP1510_GPIO_INT_STATUS; | 934 | isr_reg = bank->base + OMAP1510_GPIO_INT_STATUS; | 
| @@ -911,7 +1044,7 @@ static void gpio_irq_handler(unsigned int irq, struct irq_desc *desc) | |||
| 911 | static void gpio_irq_shutdown(unsigned int irq) | 1044 | static void gpio_irq_shutdown(unsigned int irq) | 
| 912 | { | 1045 | { | 
| 913 | unsigned int gpio = irq - IH_GPIO_BASE; | 1046 | unsigned int gpio = irq - IH_GPIO_BASE; | 
| 914 | struct gpio_bank *bank = get_gpio_bank(gpio); | 1047 | struct gpio_bank *bank = get_irq_chip_data(irq); | 
| 915 | 1048 | ||
| 916 | _reset_gpio(bank, gpio); | 1049 | _reset_gpio(bank, gpio); | 
| 917 | } | 1050 | } | 
| @@ -919,7 +1052,7 @@ static void gpio_irq_shutdown(unsigned int irq) | |||
| 919 | static void gpio_ack_irq(unsigned int irq) | 1052 | static void gpio_ack_irq(unsigned int irq) | 
| 920 | { | 1053 | { | 
| 921 | unsigned int gpio = irq - IH_GPIO_BASE; | 1054 | unsigned int gpio = irq - IH_GPIO_BASE; | 
| 922 | struct gpio_bank *bank = get_gpio_bank(gpio); | 1055 | struct gpio_bank *bank = get_irq_chip_data(irq); | 
| 923 | 1056 | ||
| 924 | _clear_gpio_irqstatus(bank, gpio); | 1057 | _clear_gpio_irqstatus(bank, gpio); | 
| 925 | } | 1058 | } | 
| @@ -927,7 +1060,7 @@ static void gpio_ack_irq(unsigned int irq) | |||
| 927 | static void gpio_mask_irq(unsigned int irq) | 1060 | static void gpio_mask_irq(unsigned int irq) | 
| 928 | { | 1061 | { | 
| 929 | unsigned int gpio = irq - IH_GPIO_BASE; | 1062 | unsigned int gpio = irq - IH_GPIO_BASE; | 
| 930 | struct gpio_bank *bank = get_gpio_bank(gpio); | 1063 | struct gpio_bank *bank = get_irq_chip_data(irq); | 
| 931 | 1064 | ||
| 932 | _set_gpio_irqenable(bank, gpio, 0); | 1065 | _set_gpio_irqenable(bank, gpio, 0); | 
| 933 | } | 1066 | } | 
| @@ -936,11 +1069,27 @@ static void gpio_unmask_irq(unsigned int irq) | |||
| 936 | { | 1069 | { | 
| 937 | unsigned int gpio = irq - IH_GPIO_BASE; | 1070 | unsigned int gpio = irq - IH_GPIO_BASE; | 
| 938 | unsigned int gpio_idx = get_gpio_index(gpio); | 1071 | unsigned int gpio_idx = get_gpio_index(gpio); | 
| 939 | struct gpio_bank *bank = get_gpio_bank(gpio); | 1072 | struct gpio_bank *bank = get_irq_chip_data(irq); | 
| 940 | 1073 | ||
| 941 | _set_gpio_irqenable(bank, gpio_idx, 1); | 1074 | _set_gpio_irqenable(bank, gpio_idx, 1); | 
| 942 | } | 1075 | } | 
| 943 | 1076 | ||
| 1077 | static struct irq_chip gpio_irq_chip = { | ||
| 1078 | .name = "GPIO", | ||
| 1079 | .shutdown = gpio_irq_shutdown, | ||
| 1080 | .ack = gpio_ack_irq, | ||
| 1081 | .mask = gpio_mask_irq, | ||
| 1082 | .unmask = gpio_unmask_irq, | ||
| 1083 | .set_type = gpio_irq_type, | ||
| 1084 | .set_wake = gpio_wake_enable, | ||
| 1085 | }; | ||
| 1086 | |||
| 1087 | /*---------------------------------------------------------------------*/ | ||
| 1088 | |||
| 1089 | #ifdef CONFIG_ARCH_OMAP1 | ||
| 1090 | |||
| 1091 | /* MPUIO uses the always-on 32k clock */ | ||
| 1092 | |||
| 944 | static void mpuio_ack_irq(unsigned int irq) | 1093 | static void mpuio_ack_irq(unsigned int irq) | 
| 945 | { | 1094 | { | 
| 946 | /* The ISR is reset automatically, so do nothing here. */ | 1095 | /* The ISR is reset automatically, so do nothing here. */ | 
| @@ -949,7 +1098,7 @@ static void mpuio_ack_irq(unsigned int irq) | |||
| 949 | static void mpuio_mask_irq(unsigned int irq) | 1098 | static void mpuio_mask_irq(unsigned int irq) | 
| 950 | { | 1099 | { | 
| 951 | unsigned int gpio = OMAP_MPUIO(irq - IH_MPUIO_BASE); | 1100 | unsigned int gpio = OMAP_MPUIO(irq - IH_MPUIO_BASE); | 
| 952 | struct gpio_bank *bank = get_gpio_bank(gpio); | 1101 | struct gpio_bank *bank = get_irq_chip_data(irq); | 
| 953 | 1102 | ||
| 954 | _set_gpio_irqenable(bank, gpio, 0); | 1103 | _set_gpio_irqenable(bank, gpio, 0); | 
| 955 | } | 1104 | } | 
| @@ -957,33 +1106,108 @@ static void mpuio_mask_irq(unsigned int irq) | |||
| 957 | static void mpuio_unmask_irq(unsigned int irq) | 1106 | static void mpuio_unmask_irq(unsigned int irq) | 
| 958 | { | 1107 | { | 
| 959 | unsigned int gpio = OMAP_MPUIO(irq - IH_MPUIO_BASE); | 1108 | unsigned int gpio = OMAP_MPUIO(irq - IH_MPUIO_BASE); | 
| 960 | struct gpio_bank *bank = get_gpio_bank(gpio); | 1109 | struct gpio_bank *bank = get_irq_chip_data(irq); | 
| 961 | 1110 | ||
| 962 | _set_gpio_irqenable(bank, gpio, 1); | 1111 | _set_gpio_irqenable(bank, gpio, 1); | 
| 963 | } | 1112 | } | 
| 964 | 1113 | ||
| 965 | static struct irq_chip gpio_irq_chip = { | 1114 | static struct irq_chip mpuio_irq_chip = { | 
| 966 | .name = "GPIO", | 1115 | .name = "MPUIO", | 
| 967 | .shutdown = gpio_irq_shutdown, | 1116 | .ack = mpuio_ack_irq, | 
| 968 | .ack = gpio_ack_irq, | 1117 | .mask = mpuio_mask_irq, | 
| 969 | .mask = gpio_mask_irq, | 1118 | .unmask = mpuio_unmask_irq, | 
| 970 | .unmask = gpio_unmask_irq, | ||
| 971 | .set_type = gpio_irq_type, | 1119 | .set_type = gpio_irq_type, | 
| 1120 | #ifdef CONFIG_ARCH_OMAP16XX | ||
| 1121 | /* REVISIT: assuming only 16xx supports MPUIO wake events */ | ||
| 972 | .set_wake = gpio_wake_enable, | 1122 | .set_wake = gpio_wake_enable, | 
| 1123 | #endif | ||
| 973 | }; | 1124 | }; | 
| 974 | 1125 | ||
| 975 | static struct irq_chip mpuio_irq_chip = { | 1126 | |
| 976 | .name = "MPUIO", | 1127 | #define bank_is_mpuio(bank) ((bank)->method == METHOD_MPUIO) | 
| 977 | .ack = mpuio_ack_irq, | 1128 | |
| 978 | .mask = mpuio_mask_irq, | 1129 | |
| 979 | .unmask = mpuio_unmask_irq, | 1130 | #ifdef CONFIG_ARCH_OMAP16XX | 
| 980 | .set_type = gpio_irq_type, | 1131 | |
| 1132 | #include <linux/platform_device.h> | ||
| 1133 | |||
| 1134 | static int omap_mpuio_suspend_late(struct platform_device *pdev, pm_message_t mesg) | ||
| 1135 | { | ||
| 1136 | struct gpio_bank *bank = platform_get_drvdata(pdev); | ||
| 1137 | void __iomem *mask_reg = bank->base + OMAP_MPUIO_GPIO_MASKIT; | ||
| 1138 | |||
| 1139 | spin_lock(&bank->lock); | ||
| 1140 | bank->saved_wakeup = __raw_readl(mask_reg); | ||
| 1141 | __raw_writel(0xffff & ~bank->suspend_wakeup, mask_reg); | ||
| 1142 | spin_unlock(&bank->lock); | ||
| 1143 | |||
| 1144 | return 0; | ||
| 1145 | } | ||
| 1146 | |||
| 1147 | static int omap_mpuio_resume_early(struct platform_device *pdev) | ||
| 1148 | { | ||
| 1149 | struct gpio_bank *bank = platform_get_drvdata(pdev); | ||
| 1150 | void __iomem *mask_reg = bank->base + OMAP_MPUIO_GPIO_MASKIT; | ||
| 1151 | |||
| 1152 | spin_lock(&bank->lock); | ||
| 1153 | __raw_writel(bank->saved_wakeup, mask_reg); | ||
| 1154 | spin_unlock(&bank->lock); | ||
| 1155 | |||
| 1156 | return 0; | ||
| 1157 | } | ||
| 1158 | |||
| 1159 | /* use platform_driver for this, now that there's no longer any | ||
| 1160 | * point to sys_device (other than not disturbing old code). | ||
| 1161 | */ | ||
| 1162 | static struct platform_driver omap_mpuio_driver = { | ||
| 1163 | .suspend_late = omap_mpuio_suspend_late, | ||
| 1164 | .resume_early = omap_mpuio_resume_early, | ||
| 1165 | .driver = { | ||
| 1166 | .name = "mpuio", | ||
| 1167 | }, | ||
| 1168 | }; | ||
| 1169 | |||
| 1170 | static struct platform_device omap_mpuio_device = { | ||
| 1171 | .name = "mpuio", | ||
| 1172 | .id = -1, | ||
| 1173 | .dev = { | ||
| 1174 | .driver = &omap_mpuio_driver.driver, | ||
| 1175 | } | ||
| 1176 | /* could list the /proc/iomem resources */ | ||
| 981 | }; | 1177 | }; | 
| 982 | 1178 | ||
| 1179 | static inline void mpuio_init(void) | ||
| 1180 | { | ||
| 1181 | platform_set_drvdata(&omap_mpuio_device, &gpio_bank_1610[0]); | ||
| 1182 | |||
| 1183 | if (platform_driver_register(&omap_mpuio_driver) == 0) | ||
| 1184 | (void) platform_device_register(&omap_mpuio_device); | ||
| 1185 | } | ||
| 1186 | |||
| 1187 | #else | ||
| 1188 | static inline void mpuio_init(void) {} | ||
| 1189 | #endif /* 16xx */ | ||
| 1190 | |||
| 1191 | #else | ||
| 1192 | |||
| 1193 | extern struct irq_chip mpuio_irq_chip; | ||
| 1194 | |||
| 1195 | #define bank_is_mpuio(bank) 0 | ||
| 1196 | static inline void mpuio_init(void) {} | ||
| 1197 | |||
| 1198 | #endif | ||
| 1199 | |||
| 1200 | /*---------------------------------------------------------------------*/ | ||
| 1201 | |||
| 983 | static int initialized; | 1202 | static int initialized; | 
| 984 | static struct clk * gpio_ick; | 1203 | static struct clk * gpio_ick; | 
| 985 | static struct clk * gpio_fck; | 1204 | static struct clk * gpio_fck; | 
| 986 | 1205 | ||
| 1206 | #ifdef CONFIG_ARCH_OMAP2430 | ||
| 1207 | static struct clk * gpio5_ick; | ||
| 1208 | static struct clk * gpio5_fck; | ||
| 1209 | #endif | ||
| 1210 | |||
| 987 | static int __init _omap_gpio_init(void) | 1211 | static int __init _omap_gpio_init(void) | 
| 988 | { | 1212 | { | 
| 989 | int i; | 1213 | int i; | 
| @@ -1009,7 +1233,25 @@ static int __init _omap_gpio_init(void) | |||
| 1009 | printk("Could not get gpios_fck\n"); | 1233 | printk("Could not get gpios_fck\n"); | 
| 1010 | else | 1234 | else | 
| 1011 | clk_enable(gpio_fck); | 1235 | clk_enable(gpio_fck); | 
| 1012 | } | 1236 | |
| 1237 | /* | ||
| 1238 | * On 2430 GPIO 5 uses CORE L4 ICLK | ||
| 1239 | */ | ||
| 1240 | #ifdef CONFIG_ARCH_OMAP2430 | ||
| 1241 | if (cpu_is_omap2430()) { | ||
| 1242 | gpio5_ick = clk_get(NULL, "gpio5_ick"); | ||
| 1243 | if (IS_ERR(gpio5_ick)) | ||
| 1244 | printk("Could not get gpio5_ick\n"); | ||
| 1245 | else | ||
| 1246 | clk_enable(gpio5_ick); | ||
| 1247 | gpio5_fck = clk_get(NULL, "gpio5_fck"); | ||
| 1248 | if (IS_ERR(gpio5_fck)) | ||
| 1249 | printk("Could not get gpio5_fck\n"); | ||
| 1250 | else | ||
| 1251 | clk_enable(gpio5_fck); | ||
| 1252 | } | ||
| 1253 | #endif | ||
| 1254 | } | ||
| 1013 | 1255 | ||
| 1014 | #ifdef CONFIG_ARCH_OMAP15XX | 1256 | #ifdef CONFIG_ARCH_OMAP15XX | 
| 1015 | if (cpu_is_omap15xx()) { | 1257 | if (cpu_is_omap15xx()) { | 
| @@ -1036,14 +1278,24 @@ static int __init _omap_gpio_init(void) | |||
| 1036 | gpio_bank = gpio_bank_730; | 1278 | gpio_bank = gpio_bank_730; | 
| 1037 | } | 1279 | } | 
| 1038 | #endif | 1280 | #endif | 
| 1281 | |||
| 1039 | #ifdef CONFIG_ARCH_OMAP24XX | 1282 | #ifdef CONFIG_ARCH_OMAP24XX | 
| 1040 | if (cpu_is_omap24xx()) { | 1283 | if (cpu_is_omap242x()) { | 
| 1041 | int rev; | 1284 | int rev; | 
| 1042 | 1285 | ||
| 1043 | gpio_bank_count = 4; | 1286 | gpio_bank_count = 4; | 
| 1044 | gpio_bank = gpio_bank_24xx; | 1287 | gpio_bank = gpio_bank_242x; | 
| 1288 | rev = omap_readl(gpio_bank[0].base + OMAP24XX_GPIO_REVISION); | ||
| 1289 | printk(KERN_INFO "OMAP242x GPIO hardware version %d.%d\n", | ||
| 1290 | (rev >> 4) & 0x0f, rev & 0x0f); | ||
| 1291 | } | ||
| 1292 | if (cpu_is_omap243x()) { | ||
| 1293 | int rev; | ||
| 1294 | |||
| 1295 | gpio_bank_count = 5; | ||
| 1296 | gpio_bank = gpio_bank_243x; | ||
| 1045 | rev = omap_readl(gpio_bank[0].base + OMAP24XX_GPIO_REVISION); | 1297 | rev = omap_readl(gpio_bank[0].base + OMAP24XX_GPIO_REVISION); | 
| 1046 | printk(KERN_INFO "OMAP24xx GPIO hardware version %d.%d\n", | 1298 | printk(KERN_INFO "OMAP243x GPIO hardware version %d.%d\n", | 
| 1047 | (rev >> 4) & 0x0f, rev & 0x0f); | 1299 | (rev >> 4) & 0x0f, rev & 0x0f); | 
| 1048 | } | 1300 | } | 
| 1049 | #endif | 1301 | #endif | 
| @@ -1054,9 +1306,8 @@ static int __init _omap_gpio_init(void) | |||
| 1054 | bank->reserved_map = 0; | 1306 | bank->reserved_map = 0; | 
| 1055 | bank->base = IO_ADDRESS(bank->base); | 1307 | bank->base = IO_ADDRESS(bank->base); | 
| 1056 | spin_lock_init(&bank->lock); | 1308 | spin_lock_init(&bank->lock); | 
| 1057 | if (bank->method == METHOD_MPUIO) { | 1309 | if (bank_is_mpuio(bank)) | 
| 1058 | omap_writew(0xFFFF, OMAP_MPUIO_BASE + OMAP_MPUIO_GPIO_MASKIT); | 1310 | omap_writew(0xFFFF, OMAP_MPUIO_BASE + OMAP_MPUIO_GPIO_MASKIT); | 
| 1059 | } | ||
| 1060 | #ifdef CONFIG_ARCH_OMAP15XX | 1311 | #ifdef CONFIG_ARCH_OMAP15XX | 
| 1061 | if (bank->method == METHOD_GPIO_1510) { | 1312 | if (bank->method == METHOD_GPIO_1510) { | 
| 1062 | __raw_writew(0xffff, bank->base + OMAP1510_GPIO_INT_MASK); | 1313 | __raw_writew(0xffff, bank->base + OMAP1510_GPIO_INT_MASK); | 
| @@ -1080,15 +1331,25 @@ static int __init _omap_gpio_init(void) | |||
| 1080 | #endif | 1331 | #endif | 
| 1081 | #ifdef CONFIG_ARCH_OMAP24XX | 1332 | #ifdef CONFIG_ARCH_OMAP24XX | 
| 1082 | if (bank->method == METHOD_GPIO_24XX) { | 1333 | if (bank->method == METHOD_GPIO_24XX) { | 
| 1334 | static const u32 non_wakeup_gpios[] = { | ||
| 1335 | 0xe203ffc0, 0x08700040 | ||
| 1336 | }; | ||
| 1337 | |||
| 1083 | __raw_writel(0x00000000, bank->base + OMAP24XX_GPIO_IRQENABLE1); | 1338 | __raw_writel(0x00000000, bank->base + OMAP24XX_GPIO_IRQENABLE1); | 
| 1084 | __raw_writel(0xffffffff, bank->base + OMAP24XX_GPIO_IRQSTATUS1); | 1339 | __raw_writel(0xffffffff, bank->base + OMAP24XX_GPIO_IRQSTATUS1); | 
| 1340 | __raw_writew(0x0015, bank->base + OMAP24XX_GPIO_SYSCONFIG); | ||
| 1085 | 1341 | ||
| 1342 | /* Initialize interface clock ungated, module enabled */ | ||
| 1343 | __raw_writel(0, bank->base + OMAP24XX_GPIO_CTRL); | ||
| 1344 | if (i < ARRAY_SIZE(non_wakeup_gpios)) | ||
| 1345 | bank->non_wakeup_gpios = non_wakeup_gpios[i]; | ||
| 1086 | gpio_count = 32; | 1346 | gpio_count = 32; | 
| 1087 | } | 1347 | } | 
| 1088 | #endif | 1348 | #endif | 
| 1089 | for (j = bank->virtual_irq_start; | 1349 | for (j = bank->virtual_irq_start; | 
| 1090 | j < bank->virtual_irq_start + gpio_count; j++) { | 1350 | j < bank->virtual_irq_start + gpio_count; j++) { | 
| 1091 | if (bank->method == METHOD_MPUIO) | 1351 | set_irq_chip_data(j, bank); | 
| 1352 | if (bank_is_mpuio(bank)) | ||
| 1092 | set_irq_chip(j, &mpuio_irq_chip); | 1353 | set_irq_chip(j, &mpuio_irq_chip); | 
| 1093 | else | 1354 | else | 
| 1094 | set_irq_chip(j, &gpio_irq_chip); | 1355 | set_irq_chip(j, &gpio_irq_chip); | 
| @@ -1104,6 +1365,12 @@ static int __init _omap_gpio_init(void) | |||
| 1104 | if (cpu_is_omap16xx()) | 1365 | if (cpu_is_omap16xx()) | 
| 1105 | omap_writel(omap_readl(ULPD_CAM_CLK_CTRL) | 0x04, ULPD_CAM_CLK_CTRL); | 1366 | omap_writel(omap_readl(ULPD_CAM_CLK_CTRL) | 0x04, ULPD_CAM_CLK_CTRL); | 
| 1106 | 1367 | ||
| 1368 | #ifdef CONFIG_ARCH_OMAP24XX | ||
| 1369 | /* Enable autoidle for the OCP interface */ | ||
| 1370 | if (cpu_is_omap24xx()) | ||
| 1371 | omap_writel(1 << 0, 0x48019010); | ||
| 1372 | #endif | ||
| 1373 | |||
| 1107 | return 0; | 1374 | return 0; | 
| 1108 | } | 1375 | } | 
| 1109 | 1376 | ||
| @@ -1122,16 +1389,20 @@ static int omap_gpio_suspend(struct sys_device *dev, pm_message_t mesg) | |||
| 1122 | void __iomem *wake_set; | 1389 | void __iomem *wake_set; | 
| 1123 | 1390 | ||
| 1124 | switch (bank->method) { | 1391 | switch (bank->method) { | 
| 1392 | #ifdef CONFIG_ARCH_OMAP16XX | ||
| 1125 | case METHOD_GPIO_1610: | 1393 | case METHOD_GPIO_1610: | 
| 1126 | wake_status = bank->base + OMAP1610_GPIO_WAKEUPENABLE; | 1394 | wake_status = bank->base + OMAP1610_GPIO_WAKEUPENABLE; | 
| 1127 | wake_clear = bank->base + OMAP1610_GPIO_CLEAR_WAKEUPENA; | 1395 | wake_clear = bank->base + OMAP1610_GPIO_CLEAR_WAKEUPENA; | 
| 1128 | wake_set = bank->base + OMAP1610_GPIO_SET_WAKEUPENA; | 1396 | wake_set = bank->base + OMAP1610_GPIO_SET_WAKEUPENA; | 
| 1129 | break; | 1397 | break; | 
| 1398 | #endif | ||
| 1399 | #ifdef CONFIG_ARCH_OMAP24XX | ||
| 1130 | case METHOD_GPIO_24XX: | 1400 | case METHOD_GPIO_24XX: | 
| 1131 | wake_status = bank->base + OMAP24XX_GPIO_SETWKUENA; | 1401 | wake_status = bank->base + OMAP24XX_GPIO_SETWKUENA; | 
| 1132 | wake_clear = bank->base + OMAP24XX_GPIO_CLEARWKUENA; | 1402 | wake_clear = bank->base + OMAP24XX_GPIO_CLEARWKUENA; | 
| 1133 | wake_set = bank->base + OMAP24XX_GPIO_SETWKUENA; | 1403 | wake_set = bank->base + OMAP24XX_GPIO_SETWKUENA; | 
| 1134 | break; | 1404 | break; | 
| 1405 | #endif | ||
| 1135 | default: | 1406 | default: | 
| 1136 | continue; | 1407 | continue; | 
| 1137 | } | 1408 | } | 
| @@ -1159,14 +1430,18 @@ static int omap_gpio_resume(struct sys_device *dev) | |||
| 1159 | void __iomem *wake_set; | 1430 | void __iomem *wake_set; | 
| 1160 | 1431 | ||
| 1161 | switch (bank->method) { | 1432 | switch (bank->method) { | 
| 1433 | #ifdef CONFIG_ARCH_OMAP16XX | ||
| 1162 | case METHOD_GPIO_1610: | 1434 | case METHOD_GPIO_1610: | 
| 1163 | wake_clear = bank->base + OMAP1610_GPIO_CLEAR_WAKEUPENA; | 1435 | wake_clear = bank->base + OMAP1610_GPIO_CLEAR_WAKEUPENA; | 
| 1164 | wake_set = bank->base + OMAP1610_GPIO_SET_WAKEUPENA; | 1436 | wake_set = bank->base + OMAP1610_GPIO_SET_WAKEUPENA; | 
| 1165 | break; | 1437 | break; | 
| 1438 | #endif | ||
| 1439 | #ifdef CONFIG_ARCH_OMAP24XX | ||
| 1166 | case METHOD_GPIO_24XX: | 1440 | case METHOD_GPIO_24XX: | 
| 1167 | wake_clear = bank->base + OMAP24XX_GPIO_CLEARWKUENA; | 1441 | wake_clear = bank->base + OMAP24XX_GPIO_CLEARWKUENA; | 
| 1168 | wake_set = bank->base + OMAP24XX_GPIO_SETWKUENA; | 1442 | wake_set = bank->base + OMAP24XX_GPIO_SETWKUENA; | 
| 1169 | break; | 1443 | break; | 
| 1444 | #endif | ||
| 1170 | default: | 1445 | default: | 
| 1171 | continue; | 1446 | continue; | 
| 1172 | } | 1447 | } | 
| @@ -1190,6 +1465,80 @@ static struct sys_device omap_gpio_device = { | |||
| 1190 | .id = 0, | 1465 | .id = 0, | 
| 1191 | .cls = &omap_gpio_sysclass, | 1466 | .cls = &omap_gpio_sysclass, | 
| 1192 | }; | 1467 | }; | 
| 1468 | |||
| 1469 | #endif | ||
| 1470 | |||
| 1471 | #ifdef CONFIG_ARCH_OMAP24XX | ||
| 1472 | |||
| 1473 | static int workaround_enabled; | ||
| 1474 | |||
| 1475 | void omap2_gpio_prepare_for_retention(void) | ||
| 1476 | { | ||
| 1477 | int i, c = 0; | ||
| 1478 | |||
| 1479 | /* Remove triggering for all non-wakeup GPIOs. Otherwise spurious | ||
| 1480 | * IRQs will be generated. See OMAP2420 Errata item 1.101. */ | ||
| 1481 | for (i = 0; i < gpio_bank_count; i++) { | ||
| 1482 | struct gpio_bank *bank = &gpio_bank[i]; | ||
| 1483 | u32 l1, l2; | ||
| 1484 | |||
| 1485 | if (!(bank->enabled_non_wakeup_gpios)) | ||
| 1486 | continue; | ||
| 1487 | bank->saved_datain = __raw_readl(bank->base + OMAP24XX_GPIO_DATAIN); | ||
| 1488 | l1 = __raw_readl(bank->base + OMAP24XX_GPIO_FALLINGDETECT); | ||
| 1489 | l2 = __raw_readl(bank->base + OMAP24XX_GPIO_RISINGDETECT); | ||
| 1490 | bank->saved_fallingdetect = l1; | ||
| 1491 | bank->saved_risingdetect = l2; | ||
| 1492 | l1 &= ~bank->enabled_non_wakeup_gpios; | ||
| 1493 | l2 &= ~bank->enabled_non_wakeup_gpios; | ||
| 1494 | __raw_writel(l1, bank->base + OMAP24XX_GPIO_FALLINGDETECT); | ||
| 1495 | __raw_writel(l2, bank->base + OMAP24XX_GPIO_RISINGDETECT); | ||
| 1496 | c++; | ||
| 1497 | } | ||
| 1498 | if (!c) { | ||
| 1499 | workaround_enabled = 0; | ||
| 1500 | return; | ||
| 1501 | } | ||
| 1502 | workaround_enabled = 1; | ||
| 1503 | } | ||
| 1504 | |||
| 1505 | void omap2_gpio_resume_after_retention(void) | ||
| 1506 | { | ||
| 1507 | int i; | ||
| 1508 | |||
| 1509 | if (!workaround_enabled) | ||
| 1510 | return; | ||
| 1511 | for (i = 0; i < gpio_bank_count; i++) { | ||
| 1512 | struct gpio_bank *bank = &gpio_bank[i]; | ||
| 1513 | u32 l; | ||
| 1514 | |||
| 1515 | if (!(bank->enabled_non_wakeup_gpios)) | ||
| 1516 | continue; | ||
| 1517 | __raw_writel(bank->saved_fallingdetect, | ||
| 1518 | bank->base + OMAP24XX_GPIO_FALLINGDETECT); | ||
| 1519 | __raw_writel(bank->saved_risingdetect, | ||
| 1520 | bank->base + OMAP24XX_GPIO_RISINGDETECT); | ||
| 1521 | /* Check if any of the non-wakeup interrupt GPIOs have changed | ||
| 1522 | * state. If so, generate an IRQ by software. This is | ||
| 1523 | * horribly racy, but it's the best we can do to work around | ||
| 1524 | * this silicon bug. */ | ||
| 1525 | l = __raw_readl(bank->base + OMAP24XX_GPIO_DATAIN); | ||
| 1526 | l ^= bank->saved_datain; | ||
| 1527 | l &= bank->non_wakeup_gpios; | ||
| 1528 | if (l) { | ||
| 1529 | u32 old0, old1; | ||
| 1530 | |||
| 1531 | old0 = __raw_readl(bank->base + OMAP24XX_GPIO_LEVELDETECT0); | ||
| 1532 | old1 = __raw_readl(bank->base + OMAP24XX_GPIO_LEVELDETECT1); | ||
| 1533 | __raw_writel(old0 | l, bank->base + OMAP24XX_GPIO_LEVELDETECT0); | ||
| 1534 | __raw_writel(old1 | l, bank->base + OMAP24XX_GPIO_LEVELDETECT1); | ||
| 1535 | __raw_writel(old0, bank->base + OMAP24XX_GPIO_LEVELDETECT0); | ||
| 1536 | __raw_writel(old1, bank->base + OMAP24XX_GPIO_LEVELDETECT1); | ||
| 1537 | } | ||
| 1538 | } | ||
| 1539 | |||
| 1540 | } | ||
| 1541 | |||
| 1193 | #endif | 1542 | #endif | 
| 1194 | 1543 | ||
| 1195 | /* | 1544 | /* | 
| @@ -1211,6 +1560,8 @@ static int __init omap_gpio_sysinit(void) | |||
| 1211 | if (!initialized) | 1560 | if (!initialized) | 
| 1212 | ret = _omap_gpio_init(); | 1561 | ret = _omap_gpio_init(); | 
| 1213 | 1562 | ||
| 1563 | mpuio_init(); | ||
| 1564 | |||
| 1214 | #if defined(CONFIG_ARCH_OMAP16XX) || defined(CONFIG_ARCH_OMAP24XX) | 1565 | #if defined(CONFIG_ARCH_OMAP16XX) || defined(CONFIG_ARCH_OMAP24XX) | 
| 1215 | if (cpu_is_omap16xx() || cpu_is_omap24xx()) { | 1566 | if (cpu_is_omap16xx() || cpu_is_omap24xx()) { | 
| 1216 | if (ret == 0) { | 1567 | if (ret == 0) { | 
| @@ -1231,3 +1582,128 @@ EXPORT_SYMBOL(omap_set_gpio_dataout); | |||
| 1231 | EXPORT_SYMBOL(omap_get_gpio_datain); | 1582 | EXPORT_SYMBOL(omap_get_gpio_datain); | 
| 1232 | 1583 | ||
| 1233 | arch_initcall(omap_gpio_sysinit); | 1584 | arch_initcall(omap_gpio_sysinit); | 
| 1585 | |||
| 1586 | |||
| 1587 | #ifdef CONFIG_DEBUG_FS | ||
| 1588 | |||
| 1589 | #include <linux/debugfs.h> | ||
| 1590 | #include <linux/seq_file.h> | ||
| 1591 | |||
| 1592 | static int gpio_is_input(struct gpio_bank *bank, int mask) | ||
| 1593 | { | ||
| 1594 | void __iomem *reg = bank->base; | ||
| 1595 | |||
| 1596 | switch (bank->method) { | ||
| 1597 | case METHOD_MPUIO: | ||
| 1598 | reg += OMAP_MPUIO_IO_CNTL; | ||
| 1599 | break; | ||
| 1600 | case METHOD_GPIO_1510: | ||
| 1601 | reg += OMAP1510_GPIO_DIR_CONTROL; | ||
| 1602 | break; | ||
| 1603 | case METHOD_GPIO_1610: | ||
| 1604 | reg += OMAP1610_GPIO_DIRECTION; | ||
| 1605 | break; | ||
| 1606 | case METHOD_GPIO_730: | ||
| 1607 | reg += OMAP730_GPIO_DIR_CONTROL; | ||
| 1608 | break; | ||
| 1609 | case METHOD_GPIO_24XX: | ||
| 1610 | reg += OMAP24XX_GPIO_OE; | ||
| 1611 | break; | ||
| 1612 | } | ||
| 1613 | return __raw_readl(reg) & mask; | ||
| 1614 | } | ||
| 1615 | |||
| 1616 | |||
| 1617 | static int dbg_gpio_show(struct seq_file *s, void *unused) | ||
| 1618 | { | ||
| 1619 | unsigned i, j, gpio; | ||
| 1620 | |||
| 1621 | for (i = 0, gpio = 0; i < gpio_bank_count; i++) { | ||
| 1622 | struct gpio_bank *bank = gpio_bank + i; | ||
| 1623 | unsigned bankwidth = 16; | ||
| 1624 | u32 mask = 1; | ||
| 1625 | |||
| 1626 | if (bank_is_mpuio(bank)) | ||
| 1627 | gpio = OMAP_MPUIO(0); | ||
| 1628 | else if (cpu_is_omap24xx() || cpu_is_omap730()) | ||
| 1629 | bankwidth = 32; | ||
| 1630 | |||
| 1631 | for (j = 0; j < bankwidth; j++, gpio++, mask <<= 1) { | ||
| 1632 | unsigned irq, value, is_in, irqstat; | ||
| 1633 | |||
| 1634 | if (!(bank->reserved_map & mask)) | ||
| 1635 | continue; | ||
| 1636 | |||
| 1637 | irq = bank->virtual_irq_start + j; | ||
| 1638 | value = omap_get_gpio_datain(gpio); | ||
| 1639 | is_in = gpio_is_input(bank, mask); | ||
| 1640 | |||
| 1641 | if (bank_is_mpuio(bank)) | ||
| 1642 | seq_printf(s, "MPUIO %2d: ", j); | ||
| 1643 | else | ||
| 1644 | seq_printf(s, "GPIO %3d: ", gpio); | ||
| 1645 | seq_printf(s, "%s %s", | ||
| 1646 | is_in ? "in " : "out", | ||
| 1647 | value ? "hi" : "lo"); | ||
| 1648 | |||
| 1649 | irqstat = irq_desc[irq].status; | ||
| 1650 | if (is_in && ((bank->suspend_wakeup & mask) | ||
| 1651 | || irqstat & IRQ_TYPE_SENSE_MASK)) { | ||
| 1652 | char *trigger = NULL; | ||
| 1653 | |||
| 1654 | switch (irqstat & IRQ_TYPE_SENSE_MASK) { | ||
| 1655 | case IRQ_TYPE_EDGE_FALLING: | ||
| 1656 | trigger = "falling"; | ||
| 1657 | break; | ||
| 1658 | case IRQ_TYPE_EDGE_RISING: | ||
| 1659 | trigger = "rising"; | ||
| 1660 | break; | ||
| 1661 | case IRQ_TYPE_EDGE_BOTH: | ||
| 1662 | trigger = "bothedge"; | ||
| 1663 | break; | ||
| 1664 | case IRQ_TYPE_LEVEL_LOW: | ||
| 1665 | trigger = "low"; | ||
| 1666 | break; | ||
| 1667 | case IRQ_TYPE_LEVEL_HIGH: | ||
| 1668 | trigger = "high"; | ||
| 1669 | break; | ||
| 1670 | case IRQ_TYPE_NONE: | ||
| 1671 | trigger = "(unspecified)"; | ||
| 1672 | break; | ||
| 1673 | } | ||
| 1674 | seq_printf(s, ", irq-%d %s%s", | ||
| 1675 | irq, trigger, | ||
| 1676 | (bank->suspend_wakeup & mask) | ||
| 1677 | ? " wakeup" : ""); | ||
| 1678 | } | ||
| 1679 | seq_printf(s, "\n"); | ||
| 1680 | } | ||
| 1681 | |||
| 1682 | if (bank_is_mpuio(bank)) { | ||
| 1683 | seq_printf(s, "\n"); | ||
| 1684 | gpio = 0; | ||
| 1685 | } | ||
| 1686 | } | ||
| 1687 | return 0; | ||
| 1688 | } | ||
| 1689 | |||
| 1690 | static int dbg_gpio_open(struct inode *inode, struct file *file) | ||
| 1691 | { | ||
| 1692 | return single_open(file, dbg_gpio_show, &inode->i_private); | ||
| 1693 | } | ||
| 1694 | |||
| 1695 | static const struct file_operations debug_fops = { | ||
| 1696 | .open = dbg_gpio_open, | ||
| 1697 | .read = seq_read, | ||
| 1698 | .llseek = seq_lseek, | ||
| 1699 | .release = single_release, | ||
| 1700 | }; | ||
| 1701 | |||
| 1702 | static int __init omap_gpio_debuginit(void) | ||
| 1703 | { | ||
| 1704 | (void) debugfs_create_file("omap_gpio", S_IRUGO, | ||
| 1705 | NULL, NULL, &debug_fops); | ||
| 1706 | return 0; | ||
| 1707 | } | ||
| 1708 | late_initcall(omap_gpio_debuginit); | ||
| 1709 | #endif | ||
| diff --git a/arch/arm/plat-omap/mcbsp.c b/arch/arm/plat-omap/mcbsp.c index b8d6f17ff58f..f7b9ccdaacbc 100644 --- a/arch/arm/plat-omap/mcbsp.c +++ b/arch/arm/plat-omap/mcbsp.c | |||
| @@ -225,11 +225,16 @@ static void omap_mcbsp_dsp_free(void) | |||
| 225 | #ifdef CONFIG_ARCH_OMAP2 | 225 | #ifdef CONFIG_ARCH_OMAP2 | 
| 226 | static void omap2_mcbsp2_mux_setup(void) | 226 | static void omap2_mcbsp2_mux_setup(void) | 
| 227 | { | 227 | { | 
| 228 | omap_cfg_reg(Y15_24XX_MCBSP2_CLKX); | 228 | if (cpu_is_omap2420()) { | 
| 229 | omap_cfg_reg(R14_24XX_MCBSP2_FSX); | 229 | omap_cfg_reg(Y15_24XX_MCBSP2_CLKX); | 
| 230 | omap_cfg_reg(W15_24XX_MCBSP2_DR); | 230 | omap_cfg_reg(R14_24XX_MCBSP2_FSX); | 
| 231 | omap_cfg_reg(V15_24XX_MCBSP2_DX); | 231 | omap_cfg_reg(W15_24XX_MCBSP2_DR); | 
| 232 | omap_cfg_reg(V14_24XX_GPIO117); | 232 | omap_cfg_reg(V15_24XX_MCBSP2_DX); | 
| 233 | omap_cfg_reg(V14_24XX_GPIO117); | ||
| 234 | } | ||
| 235 | /* | ||
| 236 | * Need to add MUX settings for OMAP 2430 SDP | ||
| 237 | */ | ||
| 233 | } | 238 | } | 
| 234 | #endif | 239 | #endif | 
| 235 | 240 | ||
| diff --git a/arch/arm/plat-omap/timer32k.c b/arch/arm/plat-omap/timer32k.c index 265310601161..114f87151d60 100644 --- a/arch/arm/plat-omap/timer32k.c +++ b/arch/arm/plat-omap/timer32k.c | |||
| @@ -42,6 +42,8 @@ | |||
| 42 | #include <linux/spinlock.h> | 42 | #include <linux/spinlock.h> | 
| 43 | #include <linux/err.h> | 43 | #include <linux/err.h> | 
| 44 | #include <linux/clk.h> | 44 | #include <linux/clk.h> | 
| 45 | #include <linux/clocksource.h> | ||
| 46 | #include <linux/clockchips.h> | ||
| 45 | 47 | ||
| 46 | #include <asm/system.h> | 48 | #include <asm/system.h> | 
| 47 | #include <asm/hardware.h> | 49 | #include <asm/hardware.h> | 
| @@ -80,13 +82,13 @@ struct sys_timer omap_timer; | |||
| 80 | #define OMAP1_32K_TIMER_TVR 0x00 | 82 | #define OMAP1_32K_TIMER_TVR 0x00 | 
| 81 | #define OMAP1_32K_TIMER_TCR 0x04 | 83 | #define OMAP1_32K_TIMER_TCR 0x04 | 
| 82 | 84 | ||
| 83 | #define OMAP_32K_TICKS_PER_HZ (32768 / HZ) | 85 | #define OMAP_32K_TICKS_PER_SEC (32768) | 
| 84 | 86 | ||
| 85 | /* | 87 | /* | 
| 86 | * TRM says 1 / HZ = ( TVR + 1) / 32768, so TRV = (32768 / HZ) - 1 | 88 | * TRM says 1 / HZ = ( TVR + 1) / 32768, so TRV = (32768 / HZ) - 1 | 
| 87 | * so with HZ = 128, TVR = 255. | 89 | * so with HZ = 128, TVR = 255. | 
| 88 | */ | 90 | */ | 
| 89 | #define OMAP_32K_TIMER_TICK_PERIOD ((32768 / HZ) - 1) | 91 | #define OMAP_32K_TIMER_TICK_PERIOD ((OMAP_32K_TICKS_PER_SEC / HZ) - 1) | 
| 90 | 92 | ||
| 91 | #define JIFFIES_TO_HW_TICKS(nr_jiffies, clock_rate) \ | 93 | #define JIFFIES_TO_HW_TICKS(nr_jiffies, clock_rate) \ | 
| 92 | (((nr_jiffies) * (clock_rate)) / HZ) | 94 | (((nr_jiffies) * (clock_rate)) / HZ) | 
| @@ -142,6 +144,28 @@ static inline void omap_32k_timer_ack_irq(void) | |||
| 142 | 144 | ||
| 143 | #endif | 145 | #endif | 
| 144 | 146 | ||
| 147 | static void omap_32k_timer_set_mode(enum clock_event_mode mode, | ||
| 148 | struct clock_event_device *evt) | ||
| 149 | { | ||
| 150 | switch (mode) { | ||
| 151 | case CLOCK_EVT_MODE_ONESHOT: | ||
| 152 | case CLOCK_EVT_MODE_PERIODIC: | ||
| 153 | omap_32k_timer_start(OMAP_32K_TIMER_TICK_PERIOD); | ||
| 154 | break; | ||
| 155 | case CLOCK_EVT_MODE_UNUSED: | ||
| 156 | case CLOCK_EVT_MODE_SHUTDOWN: | ||
| 157 | omap_32k_timer_stop(); | ||
| 158 | break; | ||
| 159 | } | ||
| 160 | } | ||
| 161 | |||
| 162 | static struct clock_event_device clockevent_32k_timer = { | ||
| 163 | .name = "32k-timer", | ||
| 164 | .features = CLOCK_EVT_FEAT_PERIODIC, | ||
| 165 | .shift = 32, | ||
| 166 | .set_mode = omap_32k_timer_set_mode, | ||
| 167 | }; | ||
| 168 | |||
| 145 | /* | 169 | /* | 
| 146 | * The 32KHz synchronized timer is an additional timer on 16xx. | 170 | * The 32KHz synchronized timer is an additional timer on 16xx. | 
| 147 | * It is always running. | 171 | * It is always running. | 
| @@ -171,15 +195,6 @@ omap_32k_ticks_to_nsecs(unsigned long ticks_32k) | |||
| 171 | static unsigned long omap_32k_last_tick = 0; | 195 | static unsigned long omap_32k_last_tick = 0; | 
| 172 | 196 | ||
| 173 | /* | 197 | /* | 
| 174 | * Returns elapsed usecs since last 32k timer interrupt | ||
| 175 | */ | ||
| 176 | static unsigned long omap_32k_timer_gettimeoffset(void) | ||
| 177 | { | ||
| 178 | unsigned long now = omap_32k_sync_timer_read(); | ||
| 179 | return omap_32k_ticks_to_usecs(now - omap_32k_last_tick); | ||
| 180 | } | ||
| 181 | |||
| 182 | /* | ||
| 183 | * Returns current time from boot in nsecs. It's OK for this to wrap | 198 | * Returns current time from boot in nsecs. It's OK for this to wrap | 
| 184 | * around for now, as it's just a relative time stamp. | 199 | * around for now, as it's just a relative time stamp. | 
| 185 | */ | 200 | */ | 
| @@ -188,95 +203,16 @@ unsigned long long sched_clock(void) | |||
| 188 | return omap_32k_ticks_to_nsecs(omap_32k_sync_timer_read()); | 203 | return omap_32k_ticks_to_nsecs(omap_32k_sync_timer_read()); | 
| 189 | } | 204 | } | 
| 190 | 205 | ||
| 191 | /* | ||
| 192 | * Timer interrupt for 32KHz timer. When dynamic tick is enabled, this | ||
| 193 | * function is also called from other interrupts to remove latency | ||
| 194 | * issues with dynamic tick. In the dynamic tick case, we need to lock | ||
| 195 | * with irqsave. | ||
| 196 | */ | ||
| 197 | static inline irqreturn_t _omap_32k_timer_interrupt(int irq, void *dev_id) | ||
| 198 | { | ||
| 199 | unsigned long now; | ||
| 200 | |||
| 201 | omap_32k_timer_ack_irq(); | ||
| 202 | now = omap_32k_sync_timer_read(); | ||
| 203 | |||
| 204 | while ((signed long)(now - omap_32k_last_tick) | ||
| 205 | >= OMAP_32K_TICKS_PER_HZ) { | ||
| 206 | omap_32k_last_tick += OMAP_32K_TICKS_PER_HZ; | ||
| 207 | timer_tick(); | ||
| 208 | } | ||
| 209 | |||
| 210 | /* Restart timer so we don't drift off due to modulo or dynamic tick. | ||
| 211 | * By default we program the next timer to be continuous to avoid | ||
| 212 | * latencies during high system load. During dynamic tick operation the | ||
| 213 | * continuous timer can be overridden from pm_idle to be longer. | ||
| 214 | */ | ||
| 215 | omap_32k_timer_start(omap_32k_last_tick + OMAP_32K_TICKS_PER_HZ - now); | ||
| 216 | |||
| 217 | return IRQ_HANDLED; | ||
| 218 | } | ||
| 219 | |||
| 220 | static irqreturn_t omap_32k_timer_handler(int irq, void *dev_id) | ||
| 221 | { | ||
| 222 | return _omap_32k_timer_interrupt(irq, dev_id); | ||
| 223 | } | ||
| 224 | |||
| 225 | static irqreturn_t omap_32k_timer_interrupt(int irq, void *dev_id) | 206 | static irqreturn_t omap_32k_timer_interrupt(int irq, void *dev_id) | 
| 226 | { | 207 | { | 
| 227 | unsigned long flags; | 208 | struct clock_event_device *evt = &clockevent_32k_timer; | 
| 209 | omap_32k_timer_ack_irq(); | ||
| 228 | 210 | ||
| 229 | write_seqlock_irqsave(&xtime_lock, flags); | 211 | evt->event_handler(evt); | 
| 230 | _omap_32k_timer_interrupt(irq, dev_id); | ||
| 231 | write_sequnlock_irqrestore(&xtime_lock, flags); | ||
| 232 | 212 | ||
| 233 | return IRQ_HANDLED; | 213 | return IRQ_HANDLED; | 
| 234 | } | 214 | } | 
| 235 | 215 | ||
| 236 | #ifdef CONFIG_NO_IDLE_HZ | ||
| 237 | /* | ||
| 238 | * Programs the next timer interrupt needed. Called when dynamic tick is | ||
| 239 | * enabled, and to reprogram the ticks to skip from pm_idle. Note that | ||
| 240 | * we can keep the timer continuous, and don't need to set it to run in | ||
| 241 | * one-shot mode. This is because the timer will get reprogrammed again | ||
| 242 | * after next interrupt. | ||
| 243 | */ | ||
| 244 | void omap_32k_timer_reprogram(unsigned long next_tick) | ||
| 245 | { | ||
| 246 | unsigned long ticks = JIFFIES_TO_HW_TICKS(next_tick, 32768) + 1; | ||
| 247 | unsigned long now = omap_32k_sync_timer_read(); | ||
| 248 | unsigned long idled = now - omap_32k_last_tick; | ||
| 249 | |||
| 250 | if (idled + 1 < ticks) | ||
| 251 | ticks -= idled; | ||
| 252 | else | ||
| 253 | ticks = 1; | ||
| 254 | omap_32k_timer_start(ticks); | ||
| 255 | } | ||
| 256 | |||
| 257 | static struct irqaction omap_32k_timer_irq; | ||
| 258 | extern struct timer_update_handler timer_update; | ||
| 259 | |||
| 260 | static int omap_32k_timer_enable_dyn_tick(void) | ||
| 261 | { | ||
| 262 | /* No need to reprogram timer, just use the next interrupt */ | ||
| 263 | return 0; | ||
| 264 | } | ||
| 265 | |||
| 266 | static int omap_32k_timer_disable_dyn_tick(void) | ||
| 267 | { | ||
| 268 | omap_32k_timer_start(OMAP_32K_TIMER_TICK_PERIOD); | ||
| 269 | return 0; | ||
| 270 | } | ||
| 271 | |||
| 272 | static struct dyn_tick_timer omap_dyn_tick_timer = { | ||
| 273 | .enable = omap_32k_timer_enable_dyn_tick, | ||
| 274 | .disable = omap_32k_timer_disable_dyn_tick, | ||
| 275 | .reprogram = omap_32k_timer_reprogram, | ||
| 276 | .handler = omap_32k_timer_handler, | ||
| 277 | }; | ||
| 278 | #endif /* CONFIG_NO_IDLE_HZ */ | ||
| 279 | |||
| 280 | static struct irqaction omap_32k_timer_irq = { | 216 | static struct irqaction omap_32k_timer_irq = { | 
| 281 | .name = "32KHz timer", | 217 | .name = "32KHz timer", | 
| 282 | .flags = IRQF_DISABLED | IRQF_TIMER, | 218 | .flags = IRQF_DISABLED | IRQF_TIMER, | 
| @@ -285,13 +221,8 @@ static struct irqaction omap_32k_timer_irq = { | |||
| 285 | 221 | ||
| 286 | static __init void omap_init_32k_timer(void) | 222 | static __init void omap_init_32k_timer(void) | 
| 287 | { | 223 | { | 
| 288 | #ifdef CONFIG_NO_IDLE_HZ | ||
| 289 | omap_timer.dyn_tick = &omap_dyn_tick_timer; | ||
| 290 | #endif | ||
| 291 | |||
| 292 | if (cpu_class_is_omap1()) | 224 | if (cpu_class_is_omap1()) | 
| 293 | setup_irq(INT_OS_TIMER, &omap_32k_timer_irq); | 225 | setup_irq(INT_OS_TIMER, &omap_32k_timer_irq); | 
| 294 | omap_timer.offset = omap_32k_timer_gettimeoffset; | ||
| 295 | omap_32k_last_tick = omap_32k_sync_timer_read(); | 226 | omap_32k_last_tick = omap_32k_sync_timer_read(); | 
| 296 | 227 | ||
| 297 | #ifdef CONFIG_ARCH_OMAP2 | 228 | #ifdef CONFIG_ARCH_OMAP2 | 
| @@ -308,7 +239,16 @@ static __init void omap_init_32k_timer(void) | |||
| 308 | } | 239 | } | 
| 309 | #endif | 240 | #endif | 
| 310 | 241 | ||
| 311 | omap_32k_timer_start(OMAP_32K_TIMER_TICK_PERIOD); | 242 | clockevent_32k_timer.mult = div_sc(OMAP_32K_TICKS_PER_SEC, | 
| 243 | NSEC_PER_SEC, | ||
| 244 | clockevent_32k_timer.shift); | ||
| 245 | clockevent_32k_timer.max_delta_ns = | ||
| 246 | clockevent_delta2ns(0xfffffffe, &clockevent_32k_timer); | ||
| 247 | clockevent_32k_timer.min_delta_ns = | ||
| 248 | clockevent_delta2ns(1, &clockevent_32k_timer); | ||
| 249 | |||
| 250 | clockevent_32k_timer.cpumask = cpumask_of_cpu(0); | ||
| 251 | clockevents_register_device(&clockevent_32k_timer); | ||
| 312 | } | 252 | } | 
| 313 | 253 | ||
| 314 | /* | 254 | /* | 
| @@ -326,5 +266,4 @@ static void __init omap_timer_init(void) | |||
| 326 | 266 | ||
| 327 | struct sys_timer omap_timer = { | 267 | struct sys_timer omap_timer = { | 
| 328 | .init = omap_timer_init, | 268 | .init = omap_timer_init, | 
| 329 | .offset = NULL, /* Initialized later */ | ||
| 330 | }; | 269 | }; | 
| diff --git a/arch/arm/plat-s3c24xx/clock.c b/arch/arm/plat-s3c24xx/clock.c index d3dc03a7383a..79cda0faec86 100644 --- a/arch/arm/plat-s3c24xx/clock.c +++ b/arch/arm/plat-s3c24xx/clock.c | |||
| @@ -404,6 +404,18 @@ int s3c24xx_register_clock(struct clk *clk) | |||
| 404 | return 0; | 404 | return 0; | 
| 405 | } | 405 | } | 
| 406 | 406 | ||
| 407 | int s3c24xx_register_clocks(struct clk **clks, int nr_clks) | ||
| 408 | { | ||
| 409 | int fails = 0; | ||
| 410 | |||
| 411 | for (; nr_clks > 0; nr_clks--, clks++) { | ||
| 412 | if (s3c24xx_register_clock(*clks) < 0) | ||
| 413 | fails++; | ||
| 414 | } | ||
| 415 | |||
| 416 | return fails; | ||
| 417 | } | ||
| 418 | |||
| 407 | /* initalise all the clocks */ | 419 | /* initalise all the clocks */ | 
| 408 | 420 | ||
| 409 | int __init s3c24xx_setup_clocks(unsigned long xtal, | 421 | int __init s3c24xx_setup_clocks(unsigned long xtal, | 
| diff --git a/arch/arm/plat-s3c24xx/cpu.c b/arch/arm/plat-s3c24xx/cpu.c index 6a2d1070e5a0..8ce4904d3131 100644 --- a/arch/arm/plat-s3c24xx/cpu.c +++ b/arch/arm/plat-s3c24xx/cpu.c | |||
| @@ -181,24 +181,6 @@ s3c_lookup_cpu(unsigned long idcode) | |||
| 181 | return NULL; | 181 | return NULL; | 
| 182 | } | 182 | } | 
| 183 | 183 | ||
| 184 | /* board information */ | ||
| 185 | |||
| 186 | static struct s3c24xx_board *board; | ||
| 187 | |||
| 188 | void s3c24xx_set_board(struct s3c24xx_board *b) | ||
| 189 | { | ||
| 190 | int i; | ||
| 191 | |||
| 192 | board = b; | ||
| 193 | |||
| 194 | if (b->clocks_count != 0) { | ||
| 195 | struct clk **ptr = b->clocks; | ||
| 196 | |||
| 197 | for (i = b->clocks_count; i > 0; i--, ptr++) | ||
| 198 | s3c24xx_register_clock(*ptr); | ||
| 199 | } | ||
| 200 | } | ||
| 201 | |||
| 202 | /* cpu information */ | 184 | /* cpu information */ | 
| 203 | 185 | ||
| 204 | static struct cpu_table *cpu; | 186 | static struct cpu_table *cpu; | 
| @@ -342,26 +324,6 @@ static int __init s3c_arch_init(void) | |||
| 342 | return ret; | 324 | return ret; | 
| 343 | 325 | ||
| 344 | ret = platform_add_devices(s3c24xx_uart_devs, nr_uarts); | 326 | ret = platform_add_devices(s3c24xx_uart_devs, nr_uarts); | 
| 345 | if (ret != 0) | ||
| 346 | return ret; | ||
| 347 | |||
| 348 | if (board != NULL) { | ||
| 349 | struct platform_device **ptr = board->devices; | ||
| 350 | int i; | ||
| 351 | |||
| 352 | for (i = 0; i < board->devices_count; i++, ptr++) { | ||
| 353 | ret = platform_device_register(*ptr); | ||
| 354 | |||
| 355 | if (ret) { | ||
| 356 | printk(KERN_ERR "s3c24xx: failed to add board device %s (%d) @%p\n", (*ptr)->name, ret, *ptr); | ||
| 357 | } | ||
| 358 | } | ||
| 359 | |||
| 360 | /* mask any error, we may not need all these board | ||
| 361 | * devices */ | ||
| 362 | ret = 0; | ||
| 363 | } | ||
| 364 | |||
| 365 | return ret; | 327 | return ret; | 
| 366 | } | 328 | } | 
| 367 | 329 | ||
| diff --git a/arch/arm/plat-s3c24xx/dma.c b/arch/arm/plat-s3c24xx/dma.c index 4540a806f522..6f03c9370979 100644 --- a/arch/arm/plat-s3c24xx/dma.c +++ b/arch/arm/plat-s3c24xx/dma.c | |||
| @@ -44,7 +44,7 @@ static struct kmem_cache *dma_kmem; | |||
| 44 | 44 | ||
| 45 | static int dma_channels; | 45 | static int dma_channels; | 
| 46 | 46 | ||
| 47 | struct s3c24xx_dma_selection dma_sel; | 47 | static struct s3c24xx_dma_selection dma_sel; | 
| 48 | 48 | ||
| 49 | /* dma channel state information */ | 49 | /* dma channel state information */ | 
| 50 | struct s3c2410_dma_chan s3c2410_chans[S3C2410_DMA_CHANNELS]; | 50 | struct s3c2410_dma_chan s3c2410_chans[S3C2410_DMA_CHANNELS]; | 
| @@ -880,7 +880,7 @@ static int s3c2410_dma_dostop(struct s3c2410_dma_chan *chan) | |||
| 880 | return 0; | 880 | return 0; | 
| 881 | } | 881 | } | 
| 882 | 882 | ||
| 883 | void s3c2410_dma_waitforstop(struct s3c2410_dma_chan *chan) | 883 | static void s3c2410_dma_waitforstop(struct s3c2410_dma_chan *chan) | 
| 884 | { | 884 | { | 
| 885 | unsigned long tmp; | 885 | unsigned long tmp; | 
| 886 | unsigned int timeout = 0x10000; | 886 | unsigned int timeout = 0x10000; | 
| @@ -957,8 +957,7 @@ static int s3c2410_dma_flush(struct s3c2410_dma_chan *chan) | |||
| 957 | return 0; | 957 | return 0; | 
| 958 | } | 958 | } | 
| 959 | 959 | ||
| 960 | int | 960 | static int s3c2410_dma_started(struct s3c2410_dma_chan *chan) | 
| 961 | s3c2410_dma_started(struct s3c2410_dma_chan *chan) | ||
| 962 | { | 961 | { | 
| 963 | unsigned long flags; | 962 | unsigned long flags; | 
| 964 | 963 | ||
| @@ -1280,7 +1279,7 @@ static void s3c2410_dma_cache_ctor(void *p, struct kmem_cache *c, unsigned long | |||
| 1280 | 1279 | ||
| 1281 | /* initialisation code */ | 1280 | /* initialisation code */ | 
| 1282 | 1281 | ||
| 1283 | int __init s3c24xx_dma_sysclass_init(void) | 1282 | static int __init s3c24xx_dma_sysclass_init(void) | 
| 1284 | { | 1283 | { | 
| 1285 | int ret = sysdev_class_register(&dma_sysclass); | 1284 | int ret = sysdev_class_register(&dma_sysclass); | 
| 1286 | 1285 | ||
| @@ -1292,7 +1291,7 @@ int __init s3c24xx_dma_sysclass_init(void) | |||
| 1292 | 1291 | ||
| 1293 | core_initcall(s3c24xx_dma_sysclass_init); | 1292 | core_initcall(s3c24xx_dma_sysclass_init); | 
| 1294 | 1293 | ||
| 1295 | int __init s3c24xx_dma_sysdev_register(void) | 1294 | static int __init s3c24xx_dma_sysdev_register(void) | 
| 1296 | { | 1295 | { | 
| 1297 | struct s3c2410_dma_chan *cp = s3c2410_chans; | 1296 | struct s3c2410_dma_chan *cp = s3c2410_chans; | 
| 1298 | int channel, ret; | 1297 | int channel, ret; | 
| @@ -1396,7 +1395,7 @@ static struct s3c24xx_dma_order *dma_order; | |||
| 1396 | * channel | 1395 | * channel | 
| 1397 | */ | 1396 | */ | 
| 1398 | 1397 | ||
| 1399 | struct s3c2410_dma_chan *s3c2410_dma_map_channel(int channel) | 1398 | static struct s3c2410_dma_chan *s3c2410_dma_map_channel(int channel) | 
| 1400 | { | 1399 | { | 
| 1401 | struct s3c24xx_dma_order_ch *ord = NULL; | 1400 | struct s3c24xx_dma_order_ch *ord = NULL; | 
| 1402 | struct s3c24xx_dma_map *ch_map; | 1401 | struct s3c24xx_dma_map *ch_map; | 
| diff --git a/arch/arm/vfp/vfpdouble.c b/arch/arm/vfp/vfpdouble.c index e44b9ed0f81f..74e89f8fb3ab 100644 --- a/arch/arm/vfp/vfpdouble.c +++ b/arch/arm/vfp/vfpdouble.c | |||
| @@ -34,7 +34,6 @@ | |||
| 34 | #include <linux/bitops.h> | 34 | #include <linux/bitops.h> | 
| 35 | 35 | ||
| 36 | #include <asm/div64.h> | 36 | #include <asm/div64.h> | 
| 37 | #include <asm/ptrace.h> | ||
| 38 | #include <asm/vfp.h> | 37 | #include <asm/vfp.h> | 
| 39 | 38 | ||
| 40 | #include "vfpinstr.h" | 39 | #include "vfpinstr.h" | 
| diff --git a/arch/arm/vfp/vfpsingle.c b/arch/arm/vfp/vfpsingle.c index 0221ba3bc799..b252631b406b 100644 --- a/arch/arm/vfp/vfpsingle.c +++ b/arch/arm/vfp/vfpsingle.c | |||
| @@ -34,7 +34,6 @@ | |||
| 34 | #include <linux/bitops.h> | 34 | #include <linux/bitops.h> | 
| 35 | 35 | ||
| 36 | #include <asm/div64.h> | 36 | #include <asm/div64.h> | 
| 37 | #include <asm/ptrace.h> | ||
| 38 | #include <asm/vfp.h> | 37 | #include <asm/vfp.h> | 
| 39 | 38 | ||
| 40 | #include "vfpinstr.h" | 39 | #include "vfpinstr.h" | 
| diff --git a/drivers/ata/Kconfig b/drivers/ata/Kconfig index 7bdbe5a914d0..77846dd0a4fa 100644 --- a/drivers/ata/Kconfig +++ b/drivers/ata/Kconfig | |||
| @@ -545,13 +545,21 @@ config PATA_WINBOND_VLB | |||
| 545 | 545 | ||
| 546 | config PATA_PLATFORM | 546 | config PATA_PLATFORM | 
| 547 | tristate "Generic platform device PATA support" | 547 | tristate "Generic platform device PATA support" | 
| 548 | depends on EMBEDDED | 548 | depends on EMBEDDED || ARCH_RPC | 
| 549 | help | 549 | help | 
| 550 | This option enables support for generic directly connected ATA | 550 | This option enables support for generic directly connected ATA | 
| 551 | devices commonly found on embedded systems. | 551 | devices commonly found on embedded systems. | 
| 552 | 552 | ||
| 553 | If unsure, say N. | 553 | If unsure, say N. | 
| 554 | 554 | ||
| 555 | config PATA_ICSIDE | ||
| 556 | tristate "Acorn ICS PATA support" | ||
| 557 | depends on ARM && ARCH_ACORN | ||
| 558 | help | ||
| 559 | On Acorn systems, say Y here if you wish to use the ICS PATA | ||
| 560 | interface card. This is not required for ICS partition support. | ||
| 561 | If you are unsure, say N to this. | ||
| 562 | |||
| 555 | config PATA_IXP4XX_CF | 563 | config PATA_IXP4XX_CF | 
| 556 | tristate "IXP4XX Compact Flash support" | 564 | tristate "IXP4XX Compact Flash support" | 
| 557 | depends on ARCH_IXP4XX | 565 | depends on ARCH_IXP4XX | 
| diff --git a/drivers/ata/Makefile b/drivers/ata/Makefile index 13d7397e0008..cc8798b1a54f 100644 --- a/drivers/ata/Makefile +++ b/drivers/ata/Makefile | |||
| @@ -61,6 +61,7 @@ obj-$(CONFIG_PATA_TRIFLEX) += pata_triflex.o | |||
| 61 | obj-$(CONFIG_PATA_IXP4XX_CF) += pata_ixp4xx_cf.o | 61 | obj-$(CONFIG_PATA_IXP4XX_CF) += pata_ixp4xx_cf.o | 
| 62 | obj-$(CONFIG_PATA_SCC) += pata_scc.o | 62 | obj-$(CONFIG_PATA_SCC) += pata_scc.o | 
| 63 | obj-$(CONFIG_PATA_PLATFORM) += pata_platform.o | 63 | obj-$(CONFIG_PATA_PLATFORM) += pata_platform.o | 
| 64 | obj-$(CONFIG_PATA_ICSIDE) += pata_icside.o | ||
| 64 | # Should be last but one libata driver | 65 | # Should be last but one libata driver | 
| 65 | obj-$(CONFIG_ATA_GENERIC) += ata_generic.o | 66 | obj-$(CONFIG_ATA_GENERIC) += ata_generic.o | 
| 66 | # Should be last libata driver | 67 | # Should be last libata driver | 
| diff --git a/drivers/ata/pata_icside.c b/drivers/ata/pata_icside.c new file mode 100644 index 000000000000..dbc8ee2adcf0 --- /dev/null +++ b/drivers/ata/pata_icside.c | |||
| @@ -0,0 +1,686 @@ | |||
| 1 | #include <linux/kernel.h> | ||
| 2 | #include <linux/module.h> | ||
| 3 | #include <linux/init.h> | ||
| 4 | #include <linux/blkdev.h> | ||
| 5 | #include <scsi/scsi_host.h> | ||
| 6 | #include <linux/ata.h> | ||
| 7 | #include <linux/libata.h> | ||
| 8 | |||
| 9 | #include <asm/dma.h> | ||
| 10 | #include <asm/ecard.h> | ||
| 11 | |||
| 12 | #define DRV_NAME "pata_icside" | ||
| 13 | |||
| 14 | #define ICS_IDENT_OFFSET 0x2280 | ||
| 15 | |||
| 16 | #define ICS_ARCIN_V5_INTRSTAT 0x0000 | ||
| 17 | #define ICS_ARCIN_V5_INTROFFSET 0x0004 | ||
| 18 | |||
| 19 | #define ICS_ARCIN_V6_INTROFFSET_1 0x2200 | ||
| 20 | #define ICS_ARCIN_V6_INTRSTAT_1 0x2290 | ||
| 21 | #define ICS_ARCIN_V6_INTROFFSET_2 0x3200 | ||
| 22 | #define ICS_ARCIN_V6_INTRSTAT_2 0x3290 | ||
| 23 | |||
| 24 | struct portinfo { | ||
| 25 | unsigned int dataoffset; | ||
| 26 | unsigned int ctrloffset; | ||
| 27 | unsigned int stepping; | ||
| 28 | }; | ||
| 29 | |||
| 30 | static const struct portinfo pata_icside_portinfo_v5 = { | ||
| 31 | .dataoffset = 0x2800, | ||
| 32 | .ctrloffset = 0x2b80, | ||
| 33 | .stepping = 6, | ||
| 34 | }; | ||
| 35 | |||
| 36 | static const struct portinfo pata_icside_portinfo_v6_1 = { | ||
| 37 | .dataoffset = 0x2000, | ||
| 38 | .ctrloffset = 0x2380, | ||
| 39 | .stepping = 6, | ||
| 40 | }; | ||
| 41 | |||
| 42 | static const struct portinfo pata_icside_portinfo_v6_2 = { | ||
| 43 | .dataoffset = 0x3000, | ||
| 44 | .ctrloffset = 0x3380, | ||
| 45 | .stepping = 6, | ||
| 46 | }; | ||
| 47 | |||
| 48 | #define PATA_ICSIDE_MAX_SG 128 | ||
| 49 | |||
| 50 | struct pata_icside_state { | ||
| 51 | void __iomem *irq_port; | ||
| 52 | void __iomem *ioc_base; | ||
| 53 | unsigned int type; | ||
| 54 | unsigned int dma; | ||
| 55 | struct { | ||
| 56 | u8 port_sel; | ||
| 57 | u8 disabled; | ||
| 58 | unsigned int speed[ATA_MAX_DEVICES]; | ||
| 59 | } port[2]; | ||
| 60 | struct scatterlist sg[PATA_ICSIDE_MAX_SG]; | ||
| 61 | }; | ||
| 62 | |||
| 63 | #define ICS_TYPE_A3IN 0 | ||
| 64 | #define ICS_TYPE_A3USER 1 | ||
| 65 | #define ICS_TYPE_V6 3 | ||
| 66 | #define ICS_TYPE_V5 15 | ||
| 67 | #define ICS_TYPE_NOTYPE ((unsigned int)-1) | ||
| 68 | |||
| 69 | /* ---------------- Version 5 PCB Support Functions --------------------- */ | ||
| 70 | /* Prototype: pata_icside_irqenable_arcin_v5 (struct expansion_card *ec, int irqnr) | ||
| 71 | * Purpose : enable interrupts from card | ||
| 72 | */ | ||
| 73 | static void pata_icside_irqenable_arcin_v5 (struct expansion_card *ec, int irqnr) | ||
| 74 | { | ||
| 75 | struct pata_icside_state *state = ec->irq_data; | ||
| 76 | |||
| 77 | writeb(0, state->irq_port + ICS_ARCIN_V5_INTROFFSET); | ||
| 78 | } | ||
| 79 | |||
| 80 | /* Prototype: pata_icside_irqdisable_arcin_v5 (struct expansion_card *ec, int irqnr) | ||
| 81 | * Purpose : disable interrupts from card | ||
| 82 | */ | ||
| 83 | static void pata_icside_irqdisable_arcin_v5 (struct expansion_card *ec, int irqnr) | ||
| 84 | { | ||
| 85 | struct pata_icside_state *state = ec->irq_data; | ||
| 86 | |||
| 87 | readb(state->irq_port + ICS_ARCIN_V5_INTROFFSET); | ||
| 88 | } | ||
| 89 | |||
| 90 | static const expansioncard_ops_t pata_icside_ops_arcin_v5 = { | ||
| 91 | .irqenable = pata_icside_irqenable_arcin_v5, | ||
| 92 | .irqdisable = pata_icside_irqdisable_arcin_v5, | ||
| 93 | }; | ||
| 94 | |||
| 95 | |||
| 96 | /* ---------------- Version 6 PCB Support Functions --------------------- */ | ||
| 97 | /* Prototype: pata_icside_irqenable_arcin_v6 (struct expansion_card *ec, int irqnr) | ||
| 98 | * Purpose : enable interrupts from card | ||
| 99 | */ | ||
| 100 | static void pata_icside_irqenable_arcin_v6 (struct expansion_card *ec, int irqnr) | ||
| 101 | { | ||
| 102 | struct pata_icside_state *state = ec->irq_data; | ||
| 103 | void __iomem *base = state->irq_port; | ||
| 104 | |||
| 105 | if (!state->port[0].disabled) | ||
| 106 | writeb(0, base + ICS_ARCIN_V6_INTROFFSET_1); | ||
| 107 | if (!state->port[1].disabled) | ||
| 108 | writeb(0, base + ICS_ARCIN_V6_INTROFFSET_2); | ||
| 109 | } | ||
| 110 | |||
| 111 | /* Prototype: pata_icside_irqdisable_arcin_v6 (struct expansion_card *ec, int irqnr) | ||
| 112 | * Purpose : disable interrupts from card | ||
| 113 | */ | ||
| 114 | static void pata_icside_irqdisable_arcin_v6 (struct expansion_card *ec, int irqnr) | ||
| 115 | { | ||
| 116 | struct pata_icside_state *state = ec->irq_data; | ||
| 117 | |||
| 118 | readb(state->irq_port + ICS_ARCIN_V6_INTROFFSET_1); | ||
| 119 | readb(state->irq_port + ICS_ARCIN_V6_INTROFFSET_2); | ||
| 120 | } | ||
| 121 | |||
| 122 | /* Prototype: pata_icside_irqprobe(struct expansion_card *ec) | ||
| 123 | * Purpose : detect an active interrupt from card | ||
| 124 | */ | ||
| 125 | static int pata_icside_irqpending_arcin_v6(struct expansion_card *ec) | ||
| 126 | { | ||
| 127 | struct pata_icside_state *state = ec->irq_data; | ||
| 128 | |||
| 129 | return readb(state->irq_port + ICS_ARCIN_V6_INTRSTAT_1) & 1 || | ||
| 130 | readb(state->irq_port + ICS_ARCIN_V6_INTRSTAT_2) & 1; | ||
| 131 | } | ||
| 132 | |||
| 133 | static const expansioncard_ops_t pata_icside_ops_arcin_v6 = { | ||
| 134 | .irqenable = pata_icside_irqenable_arcin_v6, | ||
| 135 | .irqdisable = pata_icside_irqdisable_arcin_v6, | ||
| 136 | .irqpending = pata_icside_irqpending_arcin_v6, | ||
| 137 | }; | ||
| 138 | |||
| 139 | |||
| 140 | /* | ||
| 141 | * SG-DMA support. | ||
| 142 | * | ||
| 143 | * Similar to the BM-DMA, but we use the RiscPCs IOMD DMA controllers. | ||
| 144 | * There is only one DMA controller per card, which means that only | ||
| 145 | * one drive can be accessed at one time. NOTE! We do not enforce that | ||
| 146 | * here, but we rely on the main IDE driver spotting that both | ||
| 147 | * interfaces use the same IRQ, which should guarantee this. | ||
| 148 | */ | ||
| 149 | |||
| 150 | /* | ||
| 151 | * Configure the IOMD to give the appropriate timings for the transfer | ||
| 152 | * mode being requested. We take the advice of the ATA standards, and | ||
| 153 | * calculate the cycle time based on the transfer mode, and the EIDE | ||
| 154 | * MW DMA specs that the drive provides in the IDENTIFY command. | ||
| 155 | * | ||
| 156 | * We have the following IOMD DMA modes to choose from: | ||
| 157 | * | ||
| 158 | * Type Active Recovery Cycle | ||
| 159 | * A 250 (250) 312 (550) 562 (800) | ||
| 160 | * B 187 (200) 250 (550) 437 (750) | ||
| 161 | * C 125 (125) 125 (375) 250 (500) | ||
| 162 | * D 62 (50) 125 (375) 187 (425) | ||
| 163 | * | ||
| 164 | * (figures in brackets are actual measured timings on DIOR/DIOW) | ||
| 165 | * | ||
| 166 | * However, we also need to take care of the read/write active and | ||
| 167 | * recovery timings: | ||
| 168 | * | ||
| 169 | * Read Write | ||
| 170 | * Mode Active -- Recovery -- Cycle IOMD type | ||
| 171 | * MW0 215 50 215 480 A | ||
| 172 | * MW1 80 50 50 150 C | ||
| 173 | * MW2 70 25 25 120 C | ||
| 174 | */ | ||
| 175 | static void pata_icside_set_dmamode(struct ata_port *ap, struct ata_device *adev) | ||
| 176 | { | ||
| 177 | struct pata_icside_state *state = ap->host->private_data; | ||
| 178 | struct ata_timing t; | ||
| 179 | unsigned int cycle; | ||
| 180 | char iomd_type; | ||
| 181 | |||
| 182 | /* | ||
| 183 | * DMA is based on a 16MHz clock | ||
| 184 | */ | ||
| 185 | if (ata_timing_compute(adev, adev->dma_mode, &t, 1000, 1)) | ||
| 186 | return; | ||
| 187 | |||
| 188 | /* | ||
| 189 | * Choose the IOMD cycle timing which ensure that the interface | ||
| 190 | * satisfies the measured active, recovery and cycle times. | ||
| 191 | */ | ||
| 192 | if (t.active <= 50 && t.recover <= 375 && t.cycle <= 425) | ||
| 193 | iomd_type = 'D', cycle = 187; | ||
| 194 | else if (t.active <= 125 && t.recover <= 375 && t.cycle <= 500) | ||
| 195 | iomd_type = 'C', cycle = 250; | ||
| 196 | else if (t.active <= 200 && t.recover <= 550 && t.cycle <= 750) | ||
| 197 | iomd_type = 'B', cycle = 437; | ||
| 198 | else | ||
| 199 | iomd_type = 'A', cycle = 562; | ||
| 200 | |||
| 201 | ata_dev_printk(adev, KERN_INFO, "timings: act %dns rec %dns cyc %dns (%c)\n", | ||
| 202 | t.active, t.recover, t.cycle, iomd_type); | ||
| 203 | |||
| 204 | state->port[ap->port_no].speed[adev->devno] = cycle; | ||
| 205 | } | ||
| 206 | |||
| 207 | static void pata_icside_bmdma_setup(struct ata_queued_cmd *qc) | ||
| 208 | { | ||
| 209 | struct ata_port *ap = qc->ap; | ||
| 210 | struct pata_icside_state *state = ap->host->private_data; | ||
| 211 | struct scatterlist *sg, *rsg = state->sg; | ||
| 212 | unsigned int write = qc->tf.flags & ATA_TFLAG_WRITE; | ||
| 213 | |||
| 214 | /* | ||
| 215 | * We are simplex; BUG if we try to fiddle with DMA | ||
| 216 | * while it's active. | ||
| 217 | */ | ||
| 218 | BUG_ON(dma_channel_active(state->dma)); | ||
| 219 | |||
| 220 | /* | ||
| 221 | * Copy ATAs scattered sg list into a contiguous array of sg | ||
| 222 | */ | ||
| 223 | ata_for_each_sg(sg, qc) { | ||
| 224 | memcpy(rsg, sg, sizeof(*sg)); | ||
| 225 | rsg++; | ||
| 226 | } | ||
| 227 | |||
| 228 | /* | ||
| 229 | * Route the DMA signals to the correct interface | ||
| 230 | */ | ||
| 231 | writeb(state->port[ap->port_no].port_sel, state->ioc_base); | ||
| 232 | |||
| 233 | set_dma_speed(state->dma, state->port[ap->port_no].speed[qc->dev->devno]); | ||
| 234 | set_dma_sg(state->dma, state->sg, rsg - state->sg); | ||
| 235 | set_dma_mode(state->dma, write ? DMA_MODE_WRITE : DMA_MODE_READ); | ||
| 236 | |||
| 237 | /* issue r/w command */ | ||
| 238 | ap->ops->exec_command(ap, &qc->tf); | ||
| 239 | } | ||
| 240 | |||
| 241 | static void pata_icside_bmdma_start(struct ata_queued_cmd *qc) | ||
| 242 | { | ||
| 243 | struct ata_port *ap = qc->ap; | ||
| 244 | struct pata_icside_state *state = ap->host->private_data; | ||
| 245 | |||
| 246 | BUG_ON(dma_channel_active(state->dma)); | ||
| 247 | enable_dma(state->dma); | ||
| 248 | } | ||
| 249 | |||
| 250 | static void pata_icside_bmdma_stop(struct ata_queued_cmd *qc) | ||
| 251 | { | ||
| 252 | struct ata_port *ap = qc->ap; | ||
| 253 | struct pata_icside_state *state = ap->host->private_data; | ||
| 254 | |||
| 255 | disable_dma(state->dma); | ||
| 256 | |||
| 257 | /* see ata_bmdma_stop */ | ||
| 258 | ata_altstatus(ap); | ||
| 259 | } | ||
| 260 | |||
| 261 | static u8 pata_icside_bmdma_status(struct ata_port *ap) | ||
| 262 | { | ||
| 263 | struct pata_icside_state *state = ap->host->private_data; | ||
| 264 | void __iomem *irq_port; | ||
| 265 | |||
| 266 | irq_port = state->irq_port + (ap->port_no ? ICS_ARCIN_V6_INTRSTAT_2 : | ||
| 267 | ICS_ARCIN_V6_INTRSTAT_1); | ||
| 268 | |||
| 269 | return readb(irq_port) & 1 ? ATA_DMA_INTR : 0; | ||
| 270 | } | ||
| 271 | |||
| 272 | static int icside_dma_init(struct ata_probe_ent *ae, struct expansion_card *ec) | ||
| 273 | { | ||
| 274 | struct pata_icside_state *state = ae->private_data; | ||
| 275 | int i; | ||
| 276 | |||
| 277 | for (i = 0; i < ATA_MAX_DEVICES; i++) { | ||
| 278 | state->port[0].speed[i] = 480; | ||
| 279 | state->port[1].speed[i] = 480; | ||
| 280 | } | ||
| 281 | |||
| 282 | if (ec->dma != NO_DMA && !request_dma(ec->dma, DRV_NAME)) { | ||
| 283 | state->dma = ec->dma; | ||
| 284 | ae->mwdma_mask = 0x07; /* MW0..2 */ | ||
| 285 | } | ||
| 286 | |||
| 287 | return 0; | ||
| 288 | } | ||
| 289 | |||
| 290 | |||
| 291 | static int pata_icside_port_start(struct ata_port *ap) | ||
| 292 | { | ||
| 293 | /* No PRD to alloc */ | ||
| 294 | return ata_pad_alloc(ap, ap->dev); | ||
| 295 | } | ||
| 296 | |||
| 297 | static struct scsi_host_template pata_icside_sht = { | ||
| 298 | .module = THIS_MODULE, | ||
| 299 | .name = DRV_NAME, | ||
| 300 | .ioctl = ata_scsi_ioctl, | ||
| 301 | .queuecommand = ata_scsi_queuecmd, | ||
| 302 | .can_queue = ATA_DEF_QUEUE, | ||
| 303 | .this_id = ATA_SHT_THIS_ID, | ||
| 304 | .sg_tablesize = PATA_ICSIDE_MAX_SG, | ||
| 305 | .cmd_per_lun = ATA_SHT_CMD_PER_LUN, | ||
| 306 | .emulated = ATA_SHT_EMULATED, | ||
| 307 | .use_clustering = ATA_SHT_USE_CLUSTERING, | ||
| 308 | .proc_name = DRV_NAME, | ||
| 309 | .dma_boundary = ~0, /* no dma boundaries */ | ||
| 310 | .slave_configure = ata_scsi_slave_config, | ||
| 311 | .slave_destroy = ata_scsi_slave_destroy, | ||
| 312 | .bios_param = ata_std_bios_param, | ||
| 313 | }; | ||
| 314 | |||
| 315 | /* wish this was exported from libata-core */ | ||
| 316 | static void ata_dummy_noret(struct ata_port *port) | ||
| 317 | { | ||
| 318 | } | ||
| 319 | |||
| 320 | /* | ||
| 321 | * We need to shut down unused ports to prevent spurious interrupts. | ||
| 322 | * FIXME: the libata core doesn't call this function for PATA interfaces. | ||
| 323 | */ | ||
| 324 | static void pata_icside_port_disable(struct ata_port *ap) | ||
| 325 | { | ||
| 326 | struct pata_icside_state *state = ap->host->private_data; | ||
| 327 | |||
| 328 | ata_port_printk(ap, KERN_ERR, "disabling icside port\n"); | ||
| 329 | |||
| 330 | ata_port_disable(ap); | ||
| 331 | |||
| 332 | state->port[ap->port_no].disabled = 1; | ||
| 333 | |||
| 334 | if (state->type == ICS_TYPE_V6) { | ||
| 335 | /* | ||
| 336 | * Disable interrupts from this port, otherwise we | ||
| 337 | * receive spurious interrupts from the floating | ||
| 338 | * interrupt line. | ||
| 339 | */ | ||
| 340 | void __iomem *irq_port = state->irq_port + | ||
| 341 | (ap->port_no ? ICS_ARCIN_V6_INTROFFSET_2 : ICS_ARCIN_V6_INTROFFSET_1); | ||
| 342 | readb(irq_port); | ||
| 343 | } | ||
| 344 | } | ||
| 345 | |||
| 346 | static u8 pata_icside_irq_ack(struct ata_port *ap, unsigned int chk_drq) | ||
| 347 | { | ||
| 348 | unsigned int bits = chk_drq ? ATA_BUSY | ATA_DRQ : ATA_BUSY; | ||
| 349 | u8 status; | ||
| 350 | |||
| 351 | status = ata_busy_wait(ap, bits, 1000); | ||
| 352 | if (status & bits) | ||
| 353 | if (ata_msg_err(ap)) | ||
| 354 | printk(KERN_ERR "abnormal status 0x%X\n", status); | ||
| 355 | |||
| 356 | if (ata_msg_intr(ap)) | ||
| 357 | printk(KERN_INFO "%s: irq ack: drv_stat 0x%X\n", | ||
| 358 | __FUNCTION__, status); | ||
| 359 | |||
| 360 | return status; | ||
| 361 | } | ||
| 362 | |||
| 363 | static struct ata_port_operations pata_icside_port_ops = { | ||
| 364 | .port_disable = pata_icside_port_disable, | ||
| 365 | |||
| 366 | .set_dmamode = pata_icside_set_dmamode, | ||
| 367 | |||
| 368 | .tf_load = ata_tf_load, | ||
| 369 | .tf_read = ata_tf_read, | ||
| 370 | .exec_command = ata_exec_command, | ||
| 371 | .check_status = ata_check_status, | ||
| 372 | .dev_select = ata_std_dev_select, | ||
| 373 | |||
| 374 | .bmdma_setup = pata_icside_bmdma_setup, | ||
| 375 | .bmdma_start = pata_icside_bmdma_start, | ||
| 376 | |||
| 377 | .data_xfer = ata_data_xfer_noirq, | ||
| 378 | |||
| 379 | /* no need to build any PRD tables for DMA */ | ||
| 380 | .qc_prep = ata_noop_qc_prep, | ||
| 381 | .qc_issue = ata_qc_issue_prot, | ||
| 382 | |||
| 383 | .freeze = ata_bmdma_freeze, | ||
| 384 | .thaw = ata_bmdma_thaw, | ||
| 385 | .error_handler = ata_bmdma_error_handler, | ||
| 386 | .post_internal_cmd = pata_icside_bmdma_stop, | ||
| 387 | |||
| 388 | .irq_handler = ata_interrupt, | ||
| 389 | .irq_clear = ata_dummy_noret, | ||
| 390 | .irq_on = ata_irq_on, | ||
| 391 | .irq_ack = pata_icside_irq_ack, | ||
| 392 | |||
| 393 | .port_start = pata_icside_port_start, | ||
| 394 | |||
| 395 | .bmdma_stop = pata_icside_bmdma_stop, | ||
| 396 | .bmdma_status = pata_icside_bmdma_status, | ||
| 397 | }; | ||
| 398 | |||
| 399 | static void | ||
| 400 | pata_icside_add_port(struct ata_probe_ent *ae, void __iomem *base, | ||
| 401 | const struct portinfo *info) | ||
| 402 | { | ||
| 403 | struct ata_ioports *ioaddr = &ae->port[ae->n_ports++]; | ||
| 404 | void __iomem *cmd = base + info->dataoffset; | ||
| 405 | |||
| 406 | ioaddr->cmd_addr = cmd; | ||
| 407 | ioaddr->data_addr = cmd + (ATA_REG_DATA << info->stepping); | ||
| 408 | ioaddr->error_addr = cmd + (ATA_REG_ERR << info->stepping); | ||
| 409 | ioaddr->feature_addr = cmd + (ATA_REG_FEATURE << info->stepping); | ||
| 410 | ioaddr->nsect_addr = cmd + (ATA_REG_NSECT << info->stepping); | ||
| 411 | ioaddr->lbal_addr = cmd + (ATA_REG_LBAL << info->stepping); | ||
| 412 | ioaddr->lbam_addr = cmd + (ATA_REG_LBAM << info->stepping); | ||
| 413 | ioaddr->lbah_addr = cmd + (ATA_REG_LBAH << info->stepping); | ||
| 414 | ioaddr->device_addr = cmd + (ATA_REG_DEVICE << info->stepping); | ||
| 415 | ioaddr->status_addr = cmd + (ATA_REG_STATUS << info->stepping); | ||
| 416 | ioaddr->command_addr = cmd + (ATA_REG_CMD << info->stepping); | ||
| 417 | |||
| 418 | ioaddr->ctl_addr = base + info->ctrloffset; | ||
| 419 | ioaddr->altstatus_addr = ioaddr->ctl_addr; | ||
| 420 | } | ||
| 421 | |||
| 422 | static int __init | ||
| 423 | pata_icside_register_v5(struct ata_probe_ent *ae, struct expansion_card *ec) | ||
| 424 | { | ||
| 425 | struct pata_icside_state *state = ae->private_data; | ||
| 426 | void __iomem *base; | ||
| 427 | |||
| 428 | base = ioremap(ecard_resource_start(ec, ECARD_RES_MEMC), | ||
| 429 | ecard_resource_len(ec, ECARD_RES_MEMC)); | ||
| 430 | if (!base) | ||
| 431 | return -ENOMEM; | ||
| 432 | |||
| 433 | state->irq_port = base; | ||
| 434 | |||
| 435 | ec->irqaddr = base + ICS_ARCIN_V5_INTRSTAT; | ||
| 436 | ec->irqmask = 1; | ||
| 437 | ec->irq_data = state; | ||
| 438 | ec->ops = &pata_icside_ops_arcin_v5; | ||
| 439 | |||
| 440 | /* | ||
| 441 | * Be on the safe side - disable interrupts | ||
| 442 | */ | ||
| 443 | ec->ops->irqdisable(ec, ec->irq); | ||
| 444 | |||
| 445 | pata_icside_add_port(ae, base, &pata_icside_portinfo_v5); | ||
| 446 | |||
| 447 | return 0; | ||
| 448 | } | ||
| 449 | |||
| 450 | static int __init | ||
| 451 | pata_icside_register_v6(struct ata_probe_ent *ae, struct expansion_card *ec) | ||
| 452 | { | ||
| 453 | struct pata_icside_state *state = ae->private_data; | ||
| 454 | void __iomem *ioc_base, *easi_base; | ||
| 455 | unsigned int sel = 0; | ||
| 456 | int ret; | ||
| 457 | |||
| 458 | ioc_base = ioremap(ecard_resource_start(ec, ECARD_RES_IOCFAST), | ||
| 459 | ecard_resource_len(ec, ECARD_RES_IOCFAST)); | ||
| 460 | if (!ioc_base) { | ||
| 461 | ret = -ENOMEM; | ||
| 462 | goto out; | ||
| 463 | } | ||
| 464 | |||
| 465 | easi_base = ioc_base; | ||
| 466 | |||
| 467 | if (ecard_resource_flags(ec, ECARD_RES_EASI)) { | ||
| 468 | easi_base = ioremap(ecard_resource_start(ec, ECARD_RES_EASI), | ||
| 469 | ecard_resource_len(ec, ECARD_RES_EASI)); | ||
| 470 | if (!easi_base) { | ||
| 471 | ret = -ENOMEM; | ||
| 472 | goto unmap_slot; | ||
| 473 | } | ||
| 474 | |||
| 475 | /* | ||
| 476 | * Enable access to the EASI region. | ||
| 477 | */ | ||
| 478 | sel = 1 << 5; | ||
| 479 | } | ||
| 480 | |||
| 481 | writeb(sel, ioc_base); | ||
| 482 | |||
| 483 | ec->irq_data = state; | ||
| 484 | ec->ops = &pata_icside_ops_arcin_v6; | ||
| 485 | |||
| 486 | state->irq_port = easi_base; | ||
| 487 | state->ioc_base = ioc_base; | ||
| 488 | state->port[0].port_sel = sel; | ||
| 489 | state->port[1].port_sel = sel | 1; | ||
| 490 | |||
| 491 | /* | ||
| 492 | * Be on the safe side - disable interrupts | ||
| 493 | */ | ||
| 494 | ec->ops->irqdisable(ec, ec->irq); | ||
| 495 | |||
| 496 | /* | ||
| 497 | * Find and register the interfaces. | ||
| 498 | */ | ||
| 499 | pata_icside_add_port(ae, easi_base, &pata_icside_portinfo_v6_1); | ||
| 500 | pata_icside_add_port(ae, easi_base, &pata_icside_portinfo_v6_2); | ||
| 501 | |||
| 502 | /* | ||
| 503 | * FIXME: work around libata's aversion to calling port_disable. | ||
| 504 | * This permanently disables interrupts on port 0 - bad luck if | ||
| 505 | * you have a drive on that port. | ||
| 506 | */ | ||
| 507 | state->port[0].disabled = 1; | ||
| 508 | |||
| 509 | return icside_dma_init(ae, ec); | ||
| 510 | |||
| 511 | unmap_slot: | ||
| 512 | iounmap(ioc_base); | ||
| 513 | out: | ||
| 514 | return ret; | ||
| 515 | } | ||
| 516 | |||
| 517 | static int __devinit | ||
| 518 | pata_icside_probe(struct expansion_card *ec, const struct ecard_id *id) | ||
| 519 | { | ||
| 520 | struct pata_icside_state *state; | ||
| 521 | struct ata_probe_ent ae; | ||
| 522 | void __iomem *idmem; | ||
| 523 | int ret; | ||
| 524 | |||
| 525 | ret = ecard_request_resources(ec); | ||
| 526 | if (ret) | ||
| 527 | goto out; | ||
| 528 | |||
| 529 | state = kzalloc(sizeof(struct pata_icside_state), GFP_KERNEL); | ||
| 530 | if (!state) { | ||
| 531 | ret = -ENOMEM; | ||
| 532 | goto release; | ||
| 533 | } | ||
| 534 | |||
| 535 | state->type = ICS_TYPE_NOTYPE; | ||
| 536 | state->dma = NO_DMA; | ||
| 537 | |||
| 538 | idmem = ioremap(ecard_resource_start(ec, ECARD_RES_IOCFAST), | ||
| 539 | ecard_resource_len(ec, ECARD_RES_IOCFAST)); | ||
| 540 | if (idmem) { | ||
| 541 | unsigned int type; | ||
| 542 | |||
| 543 | type = readb(idmem + ICS_IDENT_OFFSET) & 1; | ||
| 544 | type |= (readb(idmem + ICS_IDENT_OFFSET + 4) & 1) << 1; | ||
| 545 | type |= (readb(idmem + ICS_IDENT_OFFSET + 8) & 1) << 2; | ||
| 546 | type |= (readb(idmem + ICS_IDENT_OFFSET + 12) & 1) << 3; | ||
| 547 | iounmap(idmem); | ||
| 548 | |||
| 549 | state->type = type; | ||
| 550 | } | ||
| 551 | |||
| 552 | memset(&ae, 0, sizeof(ae)); | ||
| 553 | INIT_LIST_HEAD(&ae.node); | ||
| 554 | ae.dev = &ec->dev; | ||
| 555 | ae.port_ops = &pata_icside_port_ops; | ||
| 556 | ae.sht = &pata_icside_sht; | ||
| 557 | ae.pio_mask = 0x1f; | ||
| 558 | ae.irq = ec->irq; | ||
| 559 | ae.port_flags = ATA_FLAG_SLAVE_POSS | ATA_FLAG_SRST; | ||
| 560 | ae._host_flags = ATA_HOST_SIMPLEX; | ||
| 561 | ae.private_data = state; | ||
| 562 | |||
| 563 | switch (state->type) { | ||
| 564 | case ICS_TYPE_A3IN: | ||
| 565 | dev_warn(&ec->dev, "A3IN unsupported\n"); | ||
| 566 | ret = -ENODEV; | ||
| 567 | break; | ||
| 568 | |||
| 569 | case ICS_TYPE_A3USER: | ||
| 570 | dev_warn(&ec->dev, "A3USER unsupported\n"); | ||
| 571 | ret = -ENODEV; | ||
| 572 | break; | ||
| 573 | |||
| 574 | case ICS_TYPE_V5: | ||
| 575 | ret = pata_icside_register_v5(&ae, ec); | ||
| 576 | break; | ||
| 577 | |||
| 578 | case ICS_TYPE_V6: | ||
| 579 | ret = pata_icside_register_v6(&ae, ec); | ||
| 580 | break; | ||
| 581 | |||
| 582 | default: | ||
| 583 | dev_warn(&ec->dev, "unknown interface type\n"); | ||
| 584 | ret = -ENODEV; | ||
| 585 | break; | ||
| 586 | } | ||
| 587 | |||
| 588 | if (ret == 0) | ||
| 589 | ret = ata_device_add(&ae) == 0 ? -ENODEV : 0; | ||
| 590 | |||
| 591 | if (ret == 0) | ||
| 592 | goto out; | ||
| 593 | |||
| 594 | kfree(state); | ||
| 595 | release: | ||
| 596 | ecard_release_resources(ec); | ||
| 597 | out: | ||
| 598 | return ret; | ||
| 599 | } | ||
| 600 | |||
| 601 | static void pata_icside_shutdown(struct expansion_card *ec) | ||
| 602 | { | ||
| 603 | struct ata_host *host = ecard_get_drvdata(ec); | ||
| 604 | unsigned long flags; | ||
| 605 | |||
| 606 | /* | ||
| 607 | * Disable interrupts from this card. We need to do | ||
| 608 | * this before disabling EASI since we may be accessing | ||
| 609 | * this register via that region. | ||
| 610 | */ | ||
| 611 | local_irq_save(flags); | ||
| 612 | if (ec->ops) | ||
| 613 | ec->ops->irqdisable(ec, ec->irq); | ||
| 614 | local_irq_restore(flags); | ||
| 615 | |||
| 616 | /* | ||
| 617 | * Reset the ROM pointer so that we can read the ROM | ||
| 618 | * after a soft reboot. This also disables access to | ||
| 619 | * the IDE taskfile via the EASI region. | ||
| 620 | */ | ||
| 621 | if (host) { | ||
| 622 | struct pata_icside_state *state = host->private_data; | ||
| 623 | if (state->ioc_base) | ||
| 624 | writeb(0, state->ioc_base); | ||
| 625 | } | ||
| 626 | } | ||
| 627 | |||
| 628 | static void __devexit pata_icside_remove(struct expansion_card *ec) | ||
| 629 | { | ||
| 630 | struct ata_host *host = ecard_get_drvdata(ec); | ||
| 631 | struct pata_icside_state *state = host->private_data; | ||
| 632 | |||
| 633 | ata_host_detach(host); | ||
| 634 | |||
| 635 | pata_icside_shutdown(ec); | ||
| 636 | |||
| 637 | /* | ||
| 638 | * don't NULL out the drvdata - devres/libata wants it | ||
| 639 | * to free the ata_host structure. | ||
| 640 | */ | ||
| 641 | ec->ops = NULL; | ||
| 642 | ec->irq_data = NULL; | ||
| 643 | |||
| 644 | if (state->dma != NO_DMA) | ||
| 645 | free_dma(state->dma); | ||
| 646 | if (state->ioc_base) | ||
| 647 | iounmap(state->ioc_base); | ||
| 648 | if (state->ioc_base != state->irq_port) | ||
| 649 | iounmap(state->irq_port); | ||
| 650 | |||
| 651 | kfree(state); | ||
| 652 | ecard_release_resources(ec); | ||
| 653 | } | ||
| 654 | |||
| 655 | static const struct ecard_id pata_icside_ids[] = { | ||
| 656 | { MANU_ICS, PROD_ICS_IDE }, | ||
| 657 | { MANU_ICS2, PROD_ICS2_IDE }, | ||
| 658 | { 0xffff, 0xffff } | ||
| 659 | }; | ||
| 660 | |||
| 661 | static struct ecard_driver pata_icside_driver = { | ||
| 662 | .probe = pata_icside_probe, | ||
| 663 | .remove = __devexit_p(pata_icside_remove), | ||
| 664 | .shutdown = pata_icside_shutdown, | ||
| 665 | .id_table = pata_icside_ids, | ||
| 666 | .drv = { | ||
| 667 | .name = DRV_NAME, | ||
| 668 | }, | ||
| 669 | }; | ||
| 670 | |||
| 671 | static int __init pata_icside_init(void) | ||
| 672 | { | ||
| 673 | return ecard_register_driver(&pata_icside_driver); | ||
| 674 | } | ||
| 675 | |||
| 676 | static void __exit pata_icside_exit(void) | ||
| 677 | { | ||
| 678 | ecard_remove_driver(&pata_icside_driver); | ||
| 679 | } | ||
| 680 | |||
| 681 | MODULE_AUTHOR("Russell King <rmk@arm.linux.org.uk>"); | ||
| 682 | MODULE_LICENSE("GPL"); | ||
| 683 | MODULE_DESCRIPTION("ICS PATA driver"); | ||
| 684 | |||
| 685 | module_init(pata_icside_init); | ||
| 686 | module_exit(pata_icside_exit); | ||
| diff --git a/drivers/i2c/busses/i2c-pxa.c b/drivers/i2c/busses/i2c-pxa.c index 14e83d0aac8c..4443d3bb3fbf 100644 --- a/drivers/i2c/busses/i2c-pxa.c +++ b/drivers/i2c/busses/i2c-pxa.c | |||
| @@ -839,9 +839,7 @@ static int i2c_pxa_probe(struct platform_device *dev) | |||
| 839 | { | 839 | { | 
| 840 | struct pxa_i2c *i2c = &i2c_pxa; | 840 | struct pxa_i2c *i2c = &i2c_pxa; | 
| 841 | struct resource *res; | 841 | struct resource *res; | 
| 842 | #ifdef CONFIG_I2C_PXA_SLAVE | ||
| 843 | struct i2c_pxa_platform_data *plat = dev->dev.platform_data; | 842 | struct i2c_pxa_platform_data *plat = dev->dev.platform_data; | 
| 844 | #endif | ||
| 845 | int ret; | 843 | int ret; | 
| 846 | int irq; | 844 | int irq; | 
| 847 | 845 | ||
| @@ -889,14 +887,14 @@ static int i2c_pxa_probe(struct platform_device *dev) | |||
| 889 | pxa_gpio_mode(GPIO117_I2CSCL_MD); | 887 | pxa_gpio_mode(GPIO117_I2CSCL_MD); | 
| 890 | pxa_gpio_mode(GPIO118_I2CSDA_MD); | 888 | pxa_gpio_mode(GPIO118_I2CSDA_MD); | 
| 891 | #endif | 889 | #endif | 
| 892 | pxa_set_cken(CKEN14_I2C, 1); | 890 | pxa_set_cken(CKEN_I2C, 1); | 
| 893 | break; | 891 | break; | 
| 894 | #ifdef CONFIG_PXA27x | 892 | #ifdef CONFIG_PXA27x | 
| 895 | case 1: | 893 | case 1: | 
| 896 | local_irq_disable(); | 894 | local_irq_disable(); | 
| 897 | PCFR |= PCFR_PI2CEN; | 895 | PCFR |= PCFR_PI2CEN; | 
| 898 | local_irq_enable(); | 896 | local_irq_enable(); | 
| 899 | pxa_set_cken(CKEN15_PWRI2C, 1); | 897 | pxa_set_cken(CKEN_PWRI2C, 1); | 
| 900 | #endif | 898 | #endif | 
| 901 | } | 899 | } | 
| 902 | 900 | ||
| @@ -911,6 +909,10 @@ static int i2c_pxa_probe(struct platform_device *dev) | |||
| 911 | i2c->adap.algo_data = i2c; | 909 | i2c->adap.algo_data = i2c; | 
| 912 | i2c->adap.dev.parent = &dev->dev; | 910 | i2c->adap.dev.parent = &dev->dev; | 
| 913 | 911 | ||
| 912 | if (plat) { | ||
| 913 | i2c->adap.class = plat->class; | ||
| 914 | } | ||
| 915 | |||
| 914 | ret = i2c_add_adapter(&i2c->adap); | 916 | ret = i2c_add_adapter(&i2c->adap); | 
| 915 | if (ret < 0) { | 917 | if (ret < 0) { | 
| 916 | printk(KERN_INFO "I2C: Failed to add bus\n"); | 918 | printk(KERN_INFO "I2C: Failed to add bus\n"); | 
| @@ -933,11 +935,11 @@ eadapt: | |||
| 933 | ereqirq: | 935 | ereqirq: | 
| 934 | switch (dev->id) { | 936 | switch (dev->id) { | 
| 935 | case 0: | 937 | case 0: | 
| 936 | pxa_set_cken(CKEN14_I2C, 0); | 938 | pxa_set_cken(CKEN_I2C, 0); | 
| 937 | break; | 939 | break; | 
| 938 | #ifdef CONFIG_PXA27x | 940 | #ifdef CONFIG_PXA27x | 
| 939 | case 1: | 941 | case 1: | 
| 940 | pxa_set_cken(CKEN15_PWRI2C, 0); | 942 | pxa_set_cken(CKEN_PWRI2C, 0); | 
| 941 | local_irq_disable(); | 943 | local_irq_disable(); | 
| 942 | PCFR &= ~PCFR_PI2CEN; | 944 | PCFR &= ~PCFR_PI2CEN; | 
| 943 | local_irq_enable(); | 945 | local_irq_enable(); | 
| @@ -960,11 +962,11 @@ static int i2c_pxa_remove(struct platform_device *dev) | |||
| 960 | free_irq(i2c->irq, i2c); | 962 | free_irq(i2c->irq, i2c); | 
| 961 | switch (dev->id) { | 963 | switch (dev->id) { | 
| 962 | case 0: | 964 | case 0: | 
| 963 | pxa_set_cken(CKEN14_I2C, 0); | 965 | pxa_set_cken(CKEN_I2C, 0); | 
| 964 | break; | 966 | break; | 
| 965 | #ifdef CONFIG_PXA27x | 967 | #ifdef CONFIG_PXA27x | 
| 966 | case 1: | 968 | case 1: | 
| 967 | pxa_set_cken(CKEN15_PWRI2C, 0); | 969 | pxa_set_cken(CKEN_PWRI2C, 0); | 
| 968 | local_irq_disable(); | 970 | local_irq_disable(); | 
| 969 | PCFR &= ~PCFR_PI2CEN; | 971 | PCFR &= ~PCFR_PI2CEN; | 
| 970 | local_irq_enable(); | 972 | local_irq_enable(); | 
| diff --git a/drivers/mmc/pxamci.c b/drivers/mmc/pxamci.c index 9774fc68b61a..fca894e55f4a 100644 --- a/drivers/mmc/pxamci.c +++ b/drivers/mmc/pxamci.c | |||
| @@ -369,14 +369,14 @@ static void pxamci_set_ios(struct mmc_host *mmc, struct mmc_ios *ios) | |||
| 369 | if (CLOCKRATE / clk > ios->clock) | 369 | if (CLOCKRATE / clk > ios->clock) | 
| 370 | clk <<= 1; | 370 | clk <<= 1; | 
| 371 | host->clkrt = fls(clk) - 1; | 371 | host->clkrt = fls(clk) - 1; | 
| 372 | pxa_set_cken(CKEN12_MMC, 1); | 372 | pxa_set_cken(CKEN_MMC, 1); | 
| 373 | 373 | ||
| 374 | /* | 374 | /* | 
| 375 | * we write clkrt on the next command | 375 | * we write clkrt on the next command | 
| 376 | */ | 376 | */ | 
| 377 | } else { | 377 | } else { | 
| 378 | pxamci_stop_clock(host); | 378 | pxamci_stop_clock(host); | 
| 379 | pxa_set_cken(CKEN12_MMC, 0); | 379 | pxa_set_cken(CKEN_MMC, 0); | 
| 380 | } | 380 | } | 
| 381 | 381 | ||
| 382 | if (host->power_mode != ios->power_mode) { | 382 | if (host->power_mode != ios->power_mode) { | 
| diff --git a/drivers/net/irda/pxaficp_ir.c b/drivers/net/irda/pxaficp_ir.c index 2272156af31e..d6d5361f0936 100644 --- a/drivers/net/irda/pxaficp_ir.c +++ b/drivers/net/irda/pxaficp_ir.c | |||
| @@ -134,7 +134,7 @@ static int pxa_irda_set_speed(struct pxa_irda *si, int speed) | |||
| 134 | DCSR(si->rxdma) &= ~DCSR_RUN; | 134 | DCSR(si->rxdma) &= ~DCSR_RUN; | 
| 135 | /* disable FICP */ | 135 | /* disable FICP */ | 
| 136 | ICCR0 = 0; | 136 | ICCR0 = 0; | 
| 137 | pxa_set_cken(CKEN13_FICP, 0); | 137 | pxa_set_cken(CKEN_FICP, 0); | 
| 138 | 138 | ||
| 139 | /* set board transceiver to SIR mode */ | 139 | /* set board transceiver to SIR mode */ | 
| 140 | si->pdata->transceiver_mode(si->dev, IR_SIRMODE); | 140 | si->pdata->transceiver_mode(si->dev, IR_SIRMODE); | 
| @@ -144,7 +144,7 @@ static int pxa_irda_set_speed(struct pxa_irda *si, int speed) | |||
| 144 | pxa_gpio_mode(GPIO47_STTXD_MD); | 144 | pxa_gpio_mode(GPIO47_STTXD_MD); | 
| 145 | 145 | ||
| 146 | /* enable the STUART clock */ | 146 | /* enable the STUART clock */ | 
| 147 | pxa_set_cken(CKEN5_STUART, 1); | 147 | pxa_set_cken(CKEN_STUART, 1); | 
| 148 | } | 148 | } | 
| 149 | 149 | ||
| 150 | /* disable STUART first */ | 150 | /* disable STUART first */ | 
| @@ -169,7 +169,7 @@ static int pxa_irda_set_speed(struct pxa_irda *si, int speed) | |||
| 169 | /* disable STUART */ | 169 | /* disable STUART */ | 
| 170 | STIER = 0; | 170 | STIER = 0; | 
| 171 | STISR = 0; | 171 | STISR = 0; | 
| 172 | pxa_set_cken(CKEN5_STUART, 0); | 172 | pxa_set_cken(CKEN_STUART, 0); | 
| 173 | 173 | ||
| 174 | /* disable FICP first */ | 174 | /* disable FICP first */ | 
| 175 | ICCR0 = 0; | 175 | ICCR0 = 0; | 
| @@ -182,7 +182,7 @@ static int pxa_irda_set_speed(struct pxa_irda *si, int speed) | |||
| 182 | pxa_gpio_mode(GPIO47_ICPTXD_MD); | 182 | pxa_gpio_mode(GPIO47_ICPTXD_MD); | 
| 183 | 183 | ||
| 184 | /* enable the FICP clock */ | 184 | /* enable the FICP clock */ | 
| 185 | pxa_set_cken(CKEN13_FICP, 1); | 185 | pxa_set_cken(CKEN_FICP, 1); | 
| 186 | 186 | ||
| 187 | si->speed = speed; | 187 | si->speed = speed; | 
| 188 | pxa_irda_fir_dma_rx_start(si); | 188 | pxa_irda_fir_dma_rx_start(si); | 
| @@ -593,7 +593,7 @@ static void pxa_irda_shutdown(struct pxa_irda *si) | |||
| 593 | /* disable STUART SIR mode */ | 593 | /* disable STUART SIR mode */ | 
| 594 | STISR = 0; | 594 | STISR = 0; | 
| 595 | /* disable the STUART clock */ | 595 | /* disable the STUART clock */ | 
| 596 | pxa_set_cken(CKEN5_STUART, 0); | 596 | pxa_set_cken(CKEN_STUART, 0); | 
| 597 | 597 | ||
| 598 | /* disable DMA */ | 598 | /* disable DMA */ | 
| 599 | DCSR(si->txdma) &= ~DCSR_RUN; | 599 | DCSR(si->txdma) &= ~DCSR_RUN; | 
| @@ -601,7 +601,7 @@ static void pxa_irda_shutdown(struct pxa_irda *si) | |||
| 601 | /* disable FICP */ | 601 | /* disable FICP */ | 
| 602 | ICCR0 = 0; | 602 | ICCR0 = 0; | 
| 603 | /* disable the FICP clock */ | 603 | /* disable the FICP clock */ | 
| 604 | pxa_set_cken(CKEN13_FICP, 0); | 604 | pxa_set_cken(CKEN_FICP, 0); | 
| 605 | 605 | ||
| 606 | DRCMR17 = 0; | 606 | DRCMR17 = 0; | 
| 607 | DRCMR18 = 0; | 607 | DRCMR18 = 0; | 
| diff --git a/drivers/serial/amba-pl010.c b/drivers/serial/amba-pl010.c index f69bd097166e..1a9a24b82636 100644 --- a/drivers/serial/amba-pl010.c +++ b/drivers/serial/amba-pl010.c | |||
| @@ -48,6 +48,7 @@ | |||
| 48 | #include <linux/serial.h> | 48 | #include <linux/serial.h> | 
| 49 | #include <linux/amba/bus.h> | 49 | #include <linux/amba/bus.h> | 
| 50 | #include <linux/amba/serial.h> | 50 | #include <linux/amba/serial.h> | 
| 51 | #include <linux/clk.h> | ||
| 51 | 52 | ||
| 52 | #include <asm/io.h> | 53 | #include <asm/io.h> | 
| 53 | 54 | ||
| @@ -70,6 +71,7 @@ | |||
| 70 | */ | 71 | */ | 
| 71 | struct uart_amba_port { | 72 | struct uart_amba_port { | 
| 72 | struct uart_port port; | 73 | struct uart_port port; | 
| 74 | struct clk *clk; | ||
| 73 | struct amba_device *dev; | 75 | struct amba_device *dev; | 
| 74 | struct amba_pl010_data *data; | 76 | struct amba_pl010_data *data; | 
| 75 | unsigned int old_status; | 77 | unsigned int old_status; | 
| @@ -77,73 +79,77 @@ struct uart_amba_port { | |||
| 77 | 79 | ||
| 78 | static void pl010_stop_tx(struct uart_port *port) | 80 | static void pl010_stop_tx(struct uart_port *port) | 
| 79 | { | 81 | { | 
| 82 | struct uart_amba_port *uap = (struct uart_amba_port *)port; | ||
| 80 | unsigned int cr; | 83 | unsigned int cr; | 
| 81 | 84 | ||
| 82 | cr = readb(port->membase + UART010_CR); | 85 | cr = readb(uap->port.membase + UART010_CR); | 
| 83 | cr &= ~UART010_CR_TIE; | 86 | cr &= ~UART010_CR_TIE; | 
| 84 | writel(cr, port->membase + UART010_CR); | 87 | writel(cr, uap->port.membase + UART010_CR); | 
| 85 | } | 88 | } | 
| 86 | 89 | ||
| 87 | static void pl010_start_tx(struct uart_port *port) | 90 | static void pl010_start_tx(struct uart_port *port) | 
| 88 | { | 91 | { | 
| 92 | struct uart_amba_port *uap = (struct uart_amba_port *)port; | ||
| 89 | unsigned int cr; | 93 | unsigned int cr; | 
| 90 | 94 | ||
| 91 | cr = readb(port->membase + UART010_CR); | 95 | cr = readb(uap->port.membase + UART010_CR); | 
| 92 | cr |= UART010_CR_TIE; | 96 | cr |= UART010_CR_TIE; | 
| 93 | writel(cr, port->membase + UART010_CR); | 97 | writel(cr, uap->port.membase + UART010_CR); | 
| 94 | } | 98 | } | 
| 95 | 99 | ||
| 96 | static void pl010_stop_rx(struct uart_port *port) | 100 | static void pl010_stop_rx(struct uart_port *port) | 
| 97 | { | 101 | { | 
| 102 | struct uart_amba_port *uap = (struct uart_amba_port *)port; | ||
| 98 | unsigned int cr; | 103 | unsigned int cr; | 
| 99 | 104 | ||
| 100 | cr = readb(port->membase + UART010_CR); | 105 | cr = readb(uap->port.membase + UART010_CR); | 
| 101 | cr &= ~(UART010_CR_RIE | UART010_CR_RTIE); | 106 | cr &= ~(UART010_CR_RIE | UART010_CR_RTIE); | 
| 102 | writel(cr, port->membase + UART010_CR); | 107 | writel(cr, uap->port.membase + UART010_CR); | 
| 103 | } | 108 | } | 
| 104 | 109 | ||
| 105 | static void pl010_enable_ms(struct uart_port *port) | 110 | static void pl010_enable_ms(struct uart_port *port) | 
| 106 | { | 111 | { | 
| 112 | struct uart_amba_port *uap = (struct uart_amba_port *)port; | ||
| 107 | unsigned int cr; | 113 | unsigned int cr; | 
| 108 | 114 | ||
| 109 | cr = readb(port->membase + UART010_CR); | 115 | cr = readb(uap->port.membase + UART010_CR); | 
| 110 | cr |= UART010_CR_MSIE; | 116 | cr |= UART010_CR_MSIE; | 
| 111 | writel(cr, port->membase + UART010_CR); | 117 | writel(cr, uap->port.membase + UART010_CR); | 
| 112 | } | 118 | } | 
| 113 | 119 | ||
| 114 | static void pl010_rx_chars(struct uart_port *port) | 120 | static void pl010_rx_chars(struct uart_amba_port *uap) | 
| 115 | { | 121 | { | 
| 116 | struct tty_struct *tty = port->info->tty; | 122 | struct tty_struct *tty = uap->port.info->tty; | 
| 117 | unsigned int status, ch, flag, rsr, max_count = 256; | 123 | unsigned int status, ch, flag, rsr, max_count = 256; | 
| 118 | 124 | ||
| 119 | status = readb(port->membase + UART01x_FR); | 125 | status = readb(uap->port.membase + UART01x_FR); | 
| 120 | while (UART_RX_DATA(status) && max_count--) { | 126 | while (UART_RX_DATA(status) && max_count--) { | 
| 121 | ch = readb(port->membase + UART01x_DR); | 127 | ch = readb(uap->port.membase + UART01x_DR); | 
| 122 | flag = TTY_NORMAL; | 128 | flag = TTY_NORMAL; | 
| 123 | 129 | ||
| 124 | port->icount.rx++; | 130 | uap->port.icount.rx++; | 
| 125 | 131 | ||
| 126 | /* | 132 | /* | 
| 127 | * Note that the error handling code is | 133 | * Note that the error handling code is | 
| 128 | * out of the main execution path | 134 | * out of the main execution path | 
| 129 | */ | 135 | */ | 
| 130 | rsr = readb(port->membase + UART01x_RSR) | UART_DUMMY_RSR_RX; | 136 | rsr = readb(uap->port.membase + UART01x_RSR) | UART_DUMMY_RSR_RX; | 
| 131 | if (unlikely(rsr & UART01x_RSR_ANY)) { | 137 | if (unlikely(rsr & UART01x_RSR_ANY)) { | 
| 132 | writel(0, port->membase + UART01x_ECR); | 138 | writel(0, uap->port.membase + UART01x_ECR); | 
| 133 | 139 | ||
| 134 | if (rsr & UART01x_RSR_BE) { | 140 | if (rsr & UART01x_RSR_BE) { | 
| 135 | rsr &= ~(UART01x_RSR_FE | UART01x_RSR_PE); | 141 | rsr &= ~(UART01x_RSR_FE | UART01x_RSR_PE); | 
| 136 | port->icount.brk++; | 142 | uap->port.icount.brk++; | 
| 137 | if (uart_handle_break(port)) | 143 | if (uart_handle_break(&uap->port)) | 
| 138 | goto ignore_char; | 144 | goto ignore_char; | 
| 139 | } else if (rsr & UART01x_RSR_PE) | 145 | } else if (rsr & UART01x_RSR_PE) | 
| 140 | port->icount.parity++; | 146 | uap->port.icount.parity++; | 
| 141 | else if (rsr & UART01x_RSR_FE) | 147 | else if (rsr & UART01x_RSR_FE) | 
| 142 | port->icount.frame++; | 148 | uap->port.icount.frame++; | 
| 143 | if (rsr & UART01x_RSR_OE) | 149 | if (rsr & UART01x_RSR_OE) | 
| 144 | port->icount.overrun++; | 150 | uap->port.icount.overrun++; | 
| 145 | 151 | ||
| 146 | rsr &= port->read_status_mask; | 152 | rsr &= uap->port.read_status_mask; | 
| 147 | 153 | ||
| 148 | if (rsr & UART01x_RSR_BE) | 154 | if (rsr & UART01x_RSR_BE) | 
| 149 | flag = TTY_BREAK; | 155 | flag = TTY_BREAK; | 
| @@ -153,53 +159,52 @@ static void pl010_rx_chars(struct uart_port *port) | |||
| 153 | flag = TTY_FRAME; | 159 | flag = TTY_FRAME; | 
| 154 | } | 160 | } | 
| 155 | 161 | ||
| 156 | if (uart_handle_sysrq_char(port, ch)) | 162 | if (uart_handle_sysrq_char(&uap->port, ch)) | 
| 157 | goto ignore_char; | 163 | goto ignore_char; | 
| 158 | 164 | ||
| 159 | uart_insert_char(port, rsr, UART01x_RSR_OE, ch, flag); | 165 | uart_insert_char(&uap->port, rsr, UART01x_RSR_OE, ch, flag); | 
| 160 | 166 | ||
| 161 | ignore_char: | 167 | ignore_char: | 
| 162 | status = readb(port->membase + UART01x_FR); | 168 | status = readb(uap->port.membase + UART01x_FR); | 
| 163 | } | 169 | } | 
| 164 | tty_flip_buffer_push(tty); | 170 | tty_flip_buffer_push(tty); | 
| 165 | return; | 171 | return; | 
| 166 | } | 172 | } | 
| 167 | 173 | ||
| 168 | static void pl010_tx_chars(struct uart_port *port) | 174 | static void pl010_tx_chars(struct uart_amba_port *uap) | 
| 169 | { | 175 | { | 
| 170 | struct circ_buf *xmit = &port->info->xmit; | 176 | struct circ_buf *xmit = &uap->port.info->xmit; | 
| 171 | int count; | 177 | int count; | 
| 172 | 178 | ||
| 173 | if (port->x_char) { | 179 | if (uap->port.x_char) { | 
| 174 | writel(port->x_char, port->membase + UART01x_DR); | 180 | writel(uap->port.x_char, uap->port.membase + UART01x_DR); | 
| 175 | port->icount.tx++; | 181 | uap->port.icount.tx++; | 
| 176 | port->x_char = 0; | 182 | uap->port.x_char = 0; | 
| 177 | return; | 183 | return; | 
| 178 | } | 184 | } | 
| 179 | if (uart_circ_empty(xmit) || uart_tx_stopped(port)) { | 185 | if (uart_circ_empty(xmit) || uart_tx_stopped(&uap->port)) { | 
| 180 | pl010_stop_tx(port); | 186 | pl010_stop_tx(&uap->port); | 
| 181 | return; | 187 | return; | 
| 182 | } | 188 | } | 
| 183 | 189 | ||
| 184 | count = port->fifosize >> 1; | 190 | count = uap->port.fifosize >> 1; | 
| 185 | do { | 191 | do { | 
| 186 | writel(xmit->buf[xmit->tail], port->membase + UART01x_DR); | 192 | writel(xmit->buf[xmit->tail], uap->port.membase + UART01x_DR); | 
| 187 | xmit->tail = (xmit->tail + 1) & (UART_XMIT_SIZE - 1); | 193 | xmit->tail = (xmit->tail + 1) & (UART_XMIT_SIZE - 1); | 
| 188 | port->icount.tx++; | 194 | uap->port.icount.tx++; | 
| 189 | if (uart_circ_empty(xmit)) | 195 | if (uart_circ_empty(xmit)) | 
| 190 | break; | 196 | break; | 
| 191 | } while (--count > 0); | 197 | } while (--count > 0); | 
| 192 | 198 | ||
| 193 | if (uart_circ_chars_pending(xmit) < WAKEUP_CHARS) | 199 | if (uart_circ_chars_pending(xmit) < WAKEUP_CHARS) | 
| 194 | uart_write_wakeup(port); | 200 | uart_write_wakeup(&uap->port); | 
| 195 | 201 | ||
| 196 | if (uart_circ_empty(xmit)) | 202 | if (uart_circ_empty(xmit)) | 
| 197 | pl010_stop_tx(port); | 203 | pl010_stop_tx(&uap->port); | 
| 198 | } | 204 | } | 
| 199 | 205 | ||
| 200 | static void pl010_modem_status(struct uart_port *port) | 206 | static void pl010_modem_status(struct uart_amba_port *uap) | 
| 201 | { | 207 | { | 
| 202 | struct uart_amba_port *uap = (struct uart_amba_port *)port; | ||
| 203 | unsigned int status, delta; | 208 | unsigned int status, delta; | 
| 204 | 209 | ||
| 205 | writel(0, uap->port.membase + UART010_ICR); | 210 | writel(0, uap->port.membase + UART010_ICR); | 
| @@ -226,47 +231,50 @@ static void pl010_modem_status(struct uart_port *port) | |||
| 226 | 231 | ||
| 227 | static irqreturn_t pl010_int(int irq, void *dev_id) | 232 | static irqreturn_t pl010_int(int irq, void *dev_id) | 
| 228 | { | 233 | { | 
| 229 | struct uart_port *port = dev_id; | 234 | struct uart_amba_port *uap = dev_id; | 
| 230 | unsigned int status, pass_counter = AMBA_ISR_PASS_LIMIT; | 235 | unsigned int status, pass_counter = AMBA_ISR_PASS_LIMIT; | 
| 231 | int handled = 0; | 236 | int handled = 0; | 
| 232 | 237 | ||
| 233 | spin_lock(&port->lock); | 238 | spin_lock(&uap->port.lock); | 
| 234 | 239 | ||
| 235 | status = readb(port->membase + UART010_IIR); | 240 | status = readb(uap->port.membase + UART010_IIR); | 
| 236 | if (status) { | 241 | if (status) { | 
| 237 | do { | 242 | do { | 
| 238 | if (status & (UART010_IIR_RTIS | UART010_IIR_RIS)) | 243 | if (status & (UART010_IIR_RTIS | UART010_IIR_RIS)) | 
| 239 | pl010_rx_chars(port); | 244 | pl010_rx_chars(uap); | 
| 240 | if (status & UART010_IIR_MIS) | 245 | if (status & UART010_IIR_MIS) | 
| 241 | pl010_modem_status(port); | 246 | pl010_modem_status(uap); | 
| 242 | if (status & UART010_IIR_TIS) | 247 | if (status & UART010_IIR_TIS) | 
| 243 | pl010_tx_chars(port); | 248 | pl010_tx_chars(uap); | 
| 244 | 249 | ||
| 245 | if (pass_counter-- == 0) | 250 | if (pass_counter-- == 0) | 
| 246 | break; | 251 | break; | 
| 247 | 252 | ||
| 248 | status = readb(port->membase + UART010_IIR); | 253 | status = readb(uap->port.membase + UART010_IIR); | 
| 249 | } while (status & (UART010_IIR_RTIS | UART010_IIR_RIS | | 254 | } while (status & (UART010_IIR_RTIS | UART010_IIR_RIS | | 
| 250 | UART010_IIR_TIS)); | 255 | UART010_IIR_TIS)); | 
| 251 | handled = 1; | 256 | handled = 1; | 
| 252 | } | 257 | } | 
| 253 | 258 | ||
| 254 | spin_unlock(&port->lock); | 259 | spin_unlock(&uap->port.lock); | 
| 255 | 260 | ||
| 256 | return IRQ_RETVAL(handled); | 261 | return IRQ_RETVAL(handled); | 
| 257 | } | 262 | } | 
| 258 | 263 | ||
| 259 | static unsigned int pl010_tx_empty(struct uart_port *port) | 264 | static unsigned int pl010_tx_empty(struct uart_port *port) | 
| 260 | { | 265 | { | 
| 261 | return readb(port->membase + UART01x_FR) & UART01x_FR_BUSY ? 0 : TIOCSER_TEMT; | 266 | struct uart_amba_port *uap = (struct uart_amba_port *)port; | 
| 267 | unsigned int status = readb(uap->port.membase + UART01x_FR); | ||
| 268 | return status & UART01x_FR_BUSY ? 0 : TIOCSER_TEMT; | ||
| 262 | } | 269 | } | 
| 263 | 270 | ||
| 264 | static unsigned int pl010_get_mctrl(struct uart_port *port) | 271 | static unsigned int pl010_get_mctrl(struct uart_port *port) | 
| 265 | { | 272 | { | 
| 273 | struct uart_amba_port *uap = (struct uart_amba_port *)port; | ||
| 266 | unsigned int result = 0; | 274 | unsigned int result = 0; | 
| 267 | unsigned int status; | 275 | unsigned int status; | 
| 268 | 276 | ||
| 269 | status = readb(port->membase + UART01x_FR); | 277 | status = readb(uap->port.membase + UART01x_FR); | 
| 270 | if (status & UART01x_FR_DCD) | 278 | if (status & UART01x_FR_DCD) | 
| 271 | result |= TIOCM_CAR; | 279 | result |= TIOCM_CAR; | 
| 272 | if (status & UART01x_FR_DSR) | 280 | if (status & UART01x_FR_DSR) | 
| @@ -287,17 +295,18 @@ static void pl010_set_mctrl(struct uart_port *port, unsigned int mctrl) | |||
| 287 | 295 | ||
| 288 | static void pl010_break_ctl(struct uart_port *port, int break_state) | 296 | static void pl010_break_ctl(struct uart_port *port, int break_state) | 
| 289 | { | 297 | { | 
| 298 | struct uart_amba_port *uap = (struct uart_amba_port *)port; | ||
| 290 | unsigned long flags; | 299 | unsigned long flags; | 
| 291 | unsigned int lcr_h; | 300 | unsigned int lcr_h; | 
| 292 | 301 | ||
| 293 | spin_lock_irqsave(&port->lock, flags); | 302 | spin_lock_irqsave(&uap->port.lock, flags); | 
| 294 | lcr_h = readb(port->membase + UART010_LCRH); | 303 | lcr_h = readb(uap->port.membase + UART010_LCRH); | 
| 295 | if (break_state == -1) | 304 | if (break_state == -1) | 
| 296 | lcr_h |= UART01x_LCRH_BRK; | 305 | lcr_h |= UART01x_LCRH_BRK; | 
| 297 | else | 306 | else | 
| 298 | lcr_h &= ~UART01x_LCRH_BRK; | 307 | lcr_h &= ~UART01x_LCRH_BRK; | 
| 299 | writel(lcr_h, port->membase + UART010_LCRH); | 308 | writel(lcr_h, uap->port.membase + UART010_LCRH); | 
| 300 | spin_unlock_irqrestore(&port->lock, flags); | 309 | spin_unlock_irqrestore(&uap->port.lock, flags); | 
| 301 | } | 310 | } | 
| 302 | 311 | ||
| 303 | static int pl010_startup(struct uart_port *port) | 312 | static int pl010_startup(struct uart_port *port) | 
| @@ -306,48 +315,70 @@ static int pl010_startup(struct uart_port *port) | |||
| 306 | int retval; | 315 | int retval; | 
| 307 | 316 | ||
| 308 | /* | 317 | /* | 
| 318 | * Try to enable the clock producer. | ||
| 319 | */ | ||
| 320 | retval = clk_enable(uap->clk); | ||
| 321 | if (retval) | ||
| 322 | goto out; | ||
| 323 | |||
| 324 | uap->port.uartclk = clk_get_rate(uap->clk); | ||
| 325 | |||
| 326 | /* | ||
| 309 | * Allocate the IRQ | 327 | * Allocate the IRQ | 
| 310 | */ | 328 | */ | 
| 311 | retval = request_irq(port->irq, pl010_int, 0, "uart-pl010", port); | 329 | retval = request_irq(uap->port.irq, pl010_int, 0, "uart-pl010", uap); | 
| 312 | if (retval) | 330 | if (retval) | 
| 313 | return retval; | 331 | goto clk_dis; | 
| 314 | 332 | ||
| 315 | /* | 333 | /* | 
| 316 | * initialise the old status of the modem signals | 334 | * initialise the old status of the modem signals | 
| 317 | */ | 335 | */ | 
| 318 | uap->old_status = readb(port->membase + UART01x_FR) & UART01x_FR_MODEM_ANY; | 336 | uap->old_status = readb(uap->port.membase + UART01x_FR) & UART01x_FR_MODEM_ANY; | 
| 319 | 337 | ||
| 320 | /* | 338 | /* | 
| 321 | * Finally, enable interrupts | 339 | * Finally, enable interrupts | 
| 322 | */ | 340 | */ | 
| 323 | writel(UART01x_CR_UARTEN | UART010_CR_RIE | UART010_CR_RTIE, | 341 | writel(UART01x_CR_UARTEN | UART010_CR_RIE | UART010_CR_RTIE, | 
| 324 | port->membase + UART010_CR); | 342 | uap->port.membase + UART010_CR); | 
| 325 | 343 | ||
| 326 | return 0; | 344 | return 0; | 
| 345 | |||
| 346 | clk_dis: | ||
| 347 | clk_disable(uap->clk); | ||
| 348 | out: | ||
| 349 | return retval; | ||
| 327 | } | 350 | } | 
| 328 | 351 | ||
| 329 | static void pl010_shutdown(struct uart_port *port) | 352 | static void pl010_shutdown(struct uart_port *port) | 
| 330 | { | 353 | { | 
| 354 | struct uart_amba_port *uap = (struct uart_amba_port *)port; | ||
| 355 | |||
| 331 | /* | 356 | /* | 
| 332 | * Free the interrupt | 357 | * Free the interrupt | 
| 333 | */ | 358 | */ | 
| 334 | free_irq(port->irq, port); | 359 | free_irq(uap->port.irq, uap); | 
| 335 | 360 | ||
| 336 | /* | 361 | /* | 
| 337 | * disable all interrupts, disable the port | 362 | * disable all interrupts, disable the port | 
| 338 | */ | 363 | */ | 
| 339 | writel(0, port->membase + UART010_CR); | 364 | writel(0, uap->port.membase + UART010_CR); | 
| 340 | 365 | ||
| 341 | /* disable break condition and fifos */ | 366 | /* disable break condition and fifos */ | 
| 342 | writel(readb(port->membase + UART010_LCRH) & | 367 | writel(readb(uap->port.membase + UART010_LCRH) & | 
| 343 | ~(UART01x_LCRH_BRK | UART01x_LCRH_FEN), | 368 | ~(UART01x_LCRH_BRK | UART01x_LCRH_FEN), | 
| 344 | port->membase + UART010_LCRH); | 369 | uap->port.membase + UART010_LCRH); | 
| 370 | |||
| 371 | /* | ||
| 372 | * Shut down the clock producer | ||
| 373 | */ | ||
| 374 | clk_disable(uap->clk); | ||
| 345 | } | 375 | } | 
| 346 | 376 | ||
| 347 | static void | 377 | static void | 
| 348 | pl010_set_termios(struct uart_port *port, struct ktermios *termios, | 378 | pl010_set_termios(struct uart_port *port, struct ktermios *termios, | 
| 349 | struct ktermios *old) | 379 | struct ktermios *old) | 
| 350 | { | 380 | { | 
| 381 | struct uart_amba_port *uap = (struct uart_amba_port *)port; | ||
| 351 | unsigned int lcr_h, old_cr; | 382 | unsigned int lcr_h, old_cr; | 
| 352 | unsigned long flags; | 383 | unsigned long flags; | 
| 353 | unsigned int baud, quot; | 384 | unsigned int baud, quot; | 
| @@ -355,7 +386,7 @@ pl010_set_termios(struct uart_port *port, struct ktermios *termios, | |||
| 355 | /* | 386 | /* | 
| 356 | * Ask the core to calculate the divisor for us. | 387 | * Ask the core to calculate the divisor for us. | 
| 357 | */ | 388 | */ | 
| 358 | baud = uart_get_baud_rate(port, termios, old, 0, port->uartclk/16); | 389 | baud = uart_get_baud_rate(port, termios, old, 0, uap->port.uartclk/16); | 
| 359 | quot = uart_get_divisor(port, baud); | 390 | quot = uart_get_divisor(port, baud); | 
| 360 | 391 | ||
| 361 | switch (termios->c_cflag & CSIZE) { | 392 | switch (termios->c_cflag & CSIZE) { | 
| @@ -379,66 +410,66 @@ pl010_set_termios(struct uart_port *port, struct ktermios *termios, | |||
| 379 | if (!(termios->c_cflag & PARODD)) | 410 | if (!(termios->c_cflag & PARODD)) | 
| 380 | lcr_h |= UART01x_LCRH_EPS; | 411 | lcr_h |= UART01x_LCRH_EPS; | 
| 381 | } | 412 | } | 
| 382 | if (port->fifosize > 1) | 413 | if (uap->port.fifosize > 1) | 
| 383 | lcr_h |= UART01x_LCRH_FEN; | 414 | lcr_h |= UART01x_LCRH_FEN; | 
| 384 | 415 | ||
| 385 | spin_lock_irqsave(&port->lock, flags); | 416 | spin_lock_irqsave(&uap->port.lock, flags); | 
| 386 | 417 | ||
| 387 | /* | 418 | /* | 
| 388 | * Update the per-port timeout. | 419 | * Update the per-port timeout. | 
| 389 | */ | 420 | */ | 
| 390 | uart_update_timeout(port, termios->c_cflag, baud); | 421 | uart_update_timeout(port, termios->c_cflag, baud); | 
| 391 | 422 | ||
| 392 | port->read_status_mask = UART01x_RSR_OE; | 423 | uap->port.read_status_mask = UART01x_RSR_OE; | 
| 393 | if (termios->c_iflag & INPCK) | 424 | if (termios->c_iflag & INPCK) | 
| 394 | port->read_status_mask |= UART01x_RSR_FE | UART01x_RSR_PE; | 425 | uap->port.read_status_mask |= UART01x_RSR_FE | UART01x_RSR_PE; | 
| 395 | if (termios->c_iflag & (BRKINT | PARMRK)) | 426 | if (termios->c_iflag & (BRKINT | PARMRK)) | 
| 396 | port->read_status_mask |= UART01x_RSR_BE; | 427 | uap->port.read_status_mask |= UART01x_RSR_BE; | 
| 397 | 428 | ||
| 398 | /* | 429 | /* | 
| 399 | * Characters to ignore | 430 | * Characters to ignore | 
| 400 | */ | 431 | */ | 
| 401 | port->ignore_status_mask = 0; | 432 | uap->port.ignore_status_mask = 0; | 
| 402 | if (termios->c_iflag & IGNPAR) | 433 | if (termios->c_iflag & IGNPAR) | 
| 403 | port->ignore_status_mask |= UART01x_RSR_FE | UART01x_RSR_PE; | 434 | uap->port.ignore_status_mask |= UART01x_RSR_FE | UART01x_RSR_PE; | 
| 404 | if (termios->c_iflag & IGNBRK) { | 435 | if (termios->c_iflag & IGNBRK) { | 
| 405 | port->ignore_status_mask |= UART01x_RSR_BE; | 436 | uap->port.ignore_status_mask |= UART01x_RSR_BE; | 
| 406 | /* | 437 | /* | 
| 407 | * If we're ignoring parity and break indicators, | 438 | * If we're ignoring parity and break indicators, | 
| 408 | * ignore overruns too (for real raw support). | 439 | * ignore overruns too (for real raw support). | 
| 409 | */ | 440 | */ | 
| 410 | if (termios->c_iflag & IGNPAR) | 441 | if (termios->c_iflag & IGNPAR) | 
| 411 | port->ignore_status_mask |= UART01x_RSR_OE; | 442 | uap->port.ignore_status_mask |= UART01x_RSR_OE; | 
| 412 | } | 443 | } | 
| 413 | 444 | ||
| 414 | /* | 445 | /* | 
| 415 | * Ignore all characters if CREAD is not set. | 446 | * Ignore all characters if CREAD is not set. | 
| 416 | */ | 447 | */ | 
| 417 | if ((termios->c_cflag & CREAD) == 0) | 448 | if ((termios->c_cflag & CREAD) == 0) | 
| 418 | port->ignore_status_mask |= UART_DUMMY_RSR_RX; | 449 | uap->port.ignore_status_mask |= UART_DUMMY_RSR_RX; | 
| 419 | 450 | ||
| 420 | /* first, disable everything */ | 451 | /* first, disable everything */ | 
| 421 | old_cr = readb(port->membase + UART010_CR) & ~UART010_CR_MSIE; | 452 | old_cr = readb(uap->port.membase + UART010_CR) & ~UART010_CR_MSIE; | 
| 422 | 453 | ||
| 423 | if (UART_ENABLE_MS(port, termios->c_cflag)) | 454 | if (UART_ENABLE_MS(port, termios->c_cflag)) | 
| 424 | old_cr |= UART010_CR_MSIE; | 455 | old_cr |= UART010_CR_MSIE; | 
| 425 | 456 | ||
| 426 | writel(0, port->membase + UART010_CR); | 457 | writel(0, uap->port.membase + UART010_CR); | 
| 427 | 458 | ||
| 428 | /* Set baud rate */ | 459 | /* Set baud rate */ | 
| 429 | quot -= 1; | 460 | quot -= 1; | 
| 430 | writel((quot & 0xf00) >> 8, port->membase + UART010_LCRM); | 461 | writel((quot & 0xf00) >> 8, uap->port.membase + UART010_LCRM); | 
| 431 | writel(quot & 0xff, port->membase + UART010_LCRL); | 462 | writel(quot & 0xff, uap->port.membase + UART010_LCRL); | 
| 432 | 463 | ||
| 433 | /* | 464 | /* | 
| 434 | * ----------v----------v----------v----------v----- | 465 | * ----------v----------v----------v----------v----- | 
| 435 | * NOTE: MUST BE WRITTEN AFTER UARTLCR_M & UARTLCR_L | 466 | * NOTE: MUST BE WRITTEN AFTER UARTLCR_M & UARTLCR_L | 
| 436 | * ----------^----------^----------^----------^----- | 467 | * ----------^----------^----------^----------^----- | 
| 437 | */ | 468 | */ | 
| 438 | writel(lcr_h, port->membase + UART010_LCRH); | 469 | writel(lcr_h, uap->port.membase + UART010_LCRH); | 
| 439 | writel(old_cr, port->membase + UART010_CR); | 470 | writel(old_cr, uap->port.membase + UART010_CR); | 
| 440 | 471 | ||
| 441 | spin_unlock_irqrestore(&port->lock, flags); | 472 | spin_unlock_irqrestore(&uap->port.lock, flags); | 
| 442 | } | 473 | } | 
| 443 | 474 | ||
| 444 | static const char *pl010_type(struct uart_port *port) | 475 | static const char *pl010_type(struct uart_port *port) | 
| @@ -514,47 +545,52 @@ static struct uart_amba_port *amba_ports[UART_NR]; | |||
| 514 | 545 | ||
| 515 | static void pl010_console_putchar(struct uart_port *port, int ch) | 546 | static void pl010_console_putchar(struct uart_port *port, int ch) | 
| 516 | { | 547 | { | 
| 548 | struct uart_amba_port *uap = (struct uart_amba_port *)port; | ||
| 517 | unsigned int status; | 549 | unsigned int status; | 
| 518 | 550 | ||
| 519 | do { | 551 | do { | 
| 520 | status = readb(port->membase + UART01x_FR); | 552 | status = readb(uap->port.membase + UART01x_FR); | 
| 521 | barrier(); | 553 | barrier(); | 
| 522 | } while (!UART_TX_READY(status)); | 554 | } while (!UART_TX_READY(status)); | 
| 523 | writel(ch, port->membase + UART01x_DR); | 555 | writel(ch, uap->port.membase + UART01x_DR); | 
| 524 | } | 556 | } | 
| 525 | 557 | ||
| 526 | static void | 558 | static void | 
| 527 | pl010_console_write(struct console *co, const char *s, unsigned int count) | 559 | pl010_console_write(struct console *co, const char *s, unsigned int count) | 
| 528 | { | 560 | { | 
| 529 | struct uart_port *port = &amba_ports[co->index]->port; | 561 | struct uart_amba_port *uap = amba_ports[co->index]; | 
| 530 | unsigned int status, old_cr; | 562 | unsigned int status, old_cr; | 
| 531 | 563 | ||
| 564 | clk_enable(uap->clk); | ||
| 565 | |||
| 532 | /* | 566 | /* | 
| 533 | * First save the CR then disable the interrupts | 567 | * First save the CR then disable the interrupts | 
| 534 | */ | 568 | */ | 
| 535 | old_cr = readb(port->membase + UART010_CR); | 569 | old_cr = readb(uap->port.membase + UART010_CR); | 
| 536 | writel(UART01x_CR_UARTEN, port->membase + UART010_CR); | 570 | writel(UART01x_CR_UARTEN, uap->port.membase + UART010_CR); | 
| 537 | 571 | ||
| 538 | uart_console_write(port, s, count, pl010_console_putchar); | 572 | uart_console_write(&uap->port, s, count, pl010_console_putchar); | 
| 539 | 573 | ||
| 540 | /* | 574 | /* | 
| 541 | * Finally, wait for transmitter to become empty | 575 | * Finally, wait for transmitter to become empty | 
| 542 | * and restore the TCR | 576 | * and restore the TCR | 
| 543 | */ | 577 | */ | 
| 544 | do { | 578 | do { | 
| 545 | status = readb(port->membase + UART01x_FR); | 579 | status = readb(uap->port.membase + UART01x_FR); | 
| 546 | barrier(); | 580 | barrier(); | 
| 547 | } while (status & UART01x_FR_BUSY); | 581 | } while (status & UART01x_FR_BUSY); | 
| 548 | writel(old_cr, port->membase + UART010_CR); | 582 | writel(old_cr, uap->port.membase + UART010_CR); | 
| 583 | |||
| 584 | clk_disable(uap->clk); | ||
| 549 | } | 585 | } | 
| 550 | 586 | ||
| 551 | static void __init | 587 | static void __init | 
| 552 | pl010_console_get_options(struct uart_port *port, int *baud, | 588 | pl010_console_get_options(struct uart_amba_port *uap, int *baud, | 
| 553 | int *parity, int *bits) | 589 | int *parity, int *bits) | 
| 554 | { | 590 | { | 
| 555 | if (readb(port->membase + UART010_CR) & UART01x_CR_UARTEN) { | 591 | if (readb(uap->port.membase + UART010_CR) & UART01x_CR_UARTEN) { | 
| 556 | unsigned int lcr_h, quot; | 592 | unsigned int lcr_h, quot; | 
| 557 | lcr_h = readb(port->membase + UART010_LCRH); | 593 | lcr_h = readb(uap->port.membase + UART010_LCRH); | 
| 558 | 594 | ||
| 559 | *parity = 'n'; | 595 | *parity = 'n'; | 
| 560 | if (lcr_h & UART01x_LCRH_PEN) { | 596 | if (lcr_h & UART01x_LCRH_PEN) { | 
| @@ -569,14 +605,15 @@ pl010_console_get_options(struct uart_port *port, int *baud, | |||
| 569 | else | 605 | else | 
| 570 | *bits = 8; | 606 | *bits = 8; | 
| 571 | 607 | ||
| 572 | quot = readb(port->membase + UART010_LCRL) | readb(port->membase + UART010_LCRM) << 8; | 608 | quot = readb(uap->port.membase + UART010_LCRL) | | 
| 573 | *baud = port->uartclk / (16 * (quot + 1)); | 609 | readb(uap->port.membase + UART010_LCRM) << 8; | 
| 610 | *baud = uap->port.uartclk / (16 * (quot + 1)); | ||
| 574 | } | 611 | } | 
| 575 | } | 612 | } | 
| 576 | 613 | ||
| 577 | static int __init pl010_console_setup(struct console *co, char *options) | 614 | static int __init pl010_console_setup(struct console *co, char *options) | 
| 578 | { | 615 | { | 
| 579 | struct uart_port *port; | 616 | struct uart_amba_port *uap; | 
| 580 | int baud = 38400; | 617 | int baud = 38400; | 
| 581 | int bits = 8; | 618 | int bits = 8; | 
| 582 | int parity = 'n'; | 619 | int parity = 'n'; | 
| @@ -589,16 +626,18 @@ static int __init pl010_console_setup(struct console *co, char *options) | |||
| 589 | */ | 626 | */ | 
| 590 | if (co->index >= UART_NR) | 627 | if (co->index >= UART_NR) | 
| 591 | co->index = 0; | 628 | co->index = 0; | 
| 592 | if (!amba_ports[co->index]) | 629 | uap = amba_ports[co->index]; | 
| 630 | if (!uap) | ||
| 593 | return -ENODEV; | 631 | return -ENODEV; | 
| 594 | port = &amba_ports[co->index]->port; | 632 | |
| 633 | uap->port.uartclk = clk_get_rate(uap->clk); | ||
| 595 | 634 | ||
| 596 | if (options) | 635 | if (options) | 
| 597 | uart_parse_options(options, &baud, &parity, &bits, &flow); | 636 | uart_parse_options(options, &baud, &parity, &bits, &flow); | 
| 598 | else | 637 | else | 
| 599 | pl010_console_get_options(port, &baud, &parity, &bits); | 638 | pl010_console_get_options(uap, &baud, &parity, &bits); | 
| 600 | 639 | ||
| 601 | return uart_set_options(port, co, baud, parity, bits, flow); | 640 | return uart_set_options(&uap->port, co, baud, parity, bits, flow); | 
| 602 | } | 641 | } | 
| 603 | 642 | ||
| 604 | static struct uart_driver amba_reg; | 643 | static struct uart_driver amba_reg; | 
| @@ -629,7 +668,7 @@ static struct uart_driver amba_reg = { | |||
| 629 | 668 | ||
| 630 | static int pl010_probe(struct amba_device *dev, void *id) | 669 | static int pl010_probe(struct amba_device *dev, void *id) | 
| 631 | { | 670 | { | 
| 632 | struct uart_amba_port *port; | 671 | struct uart_amba_port *uap; | 
| 633 | void __iomem *base; | 672 | void __iomem *base; | 
| 634 | int i, ret; | 673 | int i, ret; | 
| 635 | 674 | ||
| @@ -642,8 +681,8 @@ static int pl010_probe(struct amba_device *dev, void *id) | |||
| 642 | goto out; | 681 | goto out; | 
| 643 | } | 682 | } | 
| 644 | 683 | ||
| 645 | port = kzalloc(sizeof(struct uart_amba_port), GFP_KERNEL); | 684 | uap = kzalloc(sizeof(struct uart_amba_port), GFP_KERNEL); | 
| 646 | if (!port) { | 685 | if (!uap) { | 
| 647 | ret = -ENOMEM; | 686 | ret = -ENOMEM; | 
| 648 | goto out; | 687 | goto out; | 
| 649 | } | 688 | } | 
| @@ -654,51 +693,57 @@ static int pl010_probe(struct amba_device *dev, void *id) | |||
| 654 | goto free; | 693 | goto free; | 
| 655 | } | 694 | } | 
| 656 | 695 | ||
| 657 | port->port.dev = &dev->dev; | 696 | uap->clk = clk_get(&dev->dev, "UARTCLK"); | 
| 658 | port->port.mapbase = dev->res.start; | 697 | if (IS_ERR(uap->clk)) { | 
| 659 | port->port.membase = base; | 698 | ret = PTR_ERR(uap->clk); | 
| 660 | port->port.iotype = UPIO_MEM; | 699 | goto unmap; | 
| 661 | port->port.irq = dev->irq[0]; | 700 | } | 
| 662 | port->port.uartclk = 14745600; | 701 | |
| 663 | port->port.fifosize = 16; | 702 | uap->port.dev = &dev->dev; | 
| 664 | port->port.ops = &amba_pl010_pops; | 703 | uap->port.mapbase = dev->res.start; | 
| 665 | port->port.flags = UPF_BOOT_AUTOCONF; | 704 | uap->port.membase = base; | 
| 666 | port->port.line = i; | 705 | uap->port.iotype = UPIO_MEM; | 
| 667 | port->dev = dev; | 706 | uap->port.irq = dev->irq[0]; | 
| 668 | port->data = dev->dev.platform_data; | 707 | uap->port.fifosize = 16; | 
| 669 | 708 | uap->port.ops = &amba_pl010_pops; | |
| 670 | amba_ports[i] = port; | 709 | uap->port.flags = UPF_BOOT_AUTOCONF; | 
| 671 | 710 | uap->port.line = i; | |
| 672 | amba_set_drvdata(dev, port); | 711 | uap->dev = dev; | 
| 673 | ret = uart_add_one_port(&amba_reg, &port->port); | 712 | uap->data = dev->dev.platform_data; | 
| 713 | |||
| 714 | amba_ports[i] = uap; | ||
| 715 | |||
| 716 | amba_set_drvdata(dev, uap); | ||
| 717 | ret = uart_add_one_port(&amba_reg, &uap->port); | ||
| 674 | if (ret) { | 718 | if (ret) { | 
| 675 | amba_set_drvdata(dev, NULL); | 719 | amba_set_drvdata(dev, NULL); | 
| 676 | amba_ports[i] = NULL; | 720 | amba_ports[i] = NULL; | 
| 721 | clk_put(uap->clk); | ||
| 722 | unmap: | ||
| 677 | iounmap(base); | 723 | iounmap(base); | 
| 678 | free: | 724 | free: | 
| 679 | kfree(port); | 725 | kfree(uap); | 
| 680 | } | 726 | } | 
| 681 | |||
| 682 | out: | 727 | out: | 
| 683 | return ret; | 728 | return ret; | 
| 684 | } | 729 | } | 
| 685 | 730 | ||
| 686 | static int pl010_remove(struct amba_device *dev) | 731 | static int pl010_remove(struct amba_device *dev) | 
| 687 | { | 732 | { | 
| 688 | struct uart_amba_port *port = amba_get_drvdata(dev); | 733 | struct uart_amba_port *uap = amba_get_drvdata(dev); | 
| 689 | int i; | 734 | int i; | 
| 690 | 735 | ||
| 691 | amba_set_drvdata(dev, NULL); | 736 | amba_set_drvdata(dev, NULL); | 
| 692 | 737 | ||
| 693 | uart_remove_one_port(&amba_reg, &port->port); | 738 | uart_remove_one_port(&amba_reg, &uap->port); | 
| 694 | 739 | ||
| 695 | for (i = 0; i < ARRAY_SIZE(amba_ports); i++) | 740 | for (i = 0; i < ARRAY_SIZE(amba_ports); i++) | 
| 696 | if (amba_ports[i] == port) | 741 | if (amba_ports[i] == uap) | 
| 697 | amba_ports[i] = NULL; | 742 | amba_ports[i] = NULL; | 
| 698 | 743 | ||
| 699 | iounmap(port->port.membase); | 744 | iounmap(uap->port.membase); | 
| 700 | kfree(port); | 745 | clk_put(uap->clk); | 
| 701 | 746 | kfree(uap); | |
| 702 | return 0; | 747 | return 0; | 
| 703 | } | 748 | } | 
| 704 | 749 | ||
| diff --git a/drivers/serial/atmel_serial.c b/drivers/serial/atmel_serial.c index 935f48fa501d..3320bcd92c0a 100644 --- a/drivers/serial/atmel_serial.c +++ b/drivers/serial/atmel_serial.c | |||
| @@ -484,11 +484,16 @@ static void atmel_set_termios(struct uart_port *port, struct ktermios * termios, | |||
| 484 | unsigned long flags; | 484 | unsigned long flags; | 
| 485 | unsigned int mode, imr, quot, baud; | 485 | unsigned int mode, imr, quot, baud; | 
| 486 | 486 | ||
| 487 | /* Get current mode register */ | ||
| 488 | mode = UART_GET_MR(port) & ~(ATMEL_US_USCLKS | ATMEL_US_CHRL | ATMEL_US_NBSTOP | ATMEL_US_PAR); | ||
| 489 | |||
| 487 | baud = uart_get_baud_rate(port, termios, old, 0, port->uartclk/16); | 490 | baud = uart_get_baud_rate(port, termios, old, 0, port->uartclk/16); | 
| 488 | quot = uart_get_divisor(port, baud); | 491 | quot = uart_get_divisor(port, baud); | 
| 489 | 492 | ||
| 490 | /* Get current mode register */ | 493 | if (quot > 65535) { /* BRGR is 16-bit, so switch to slower clock */ | 
| 491 | mode = UART_GET_MR(port) & ~(ATMEL_US_CHRL | ATMEL_US_NBSTOP | ATMEL_US_PAR); | 494 | quot /= 8; | 
| 495 | mode |= ATMEL_US_USCLKS_MCK_DIV8; | ||
| 496 | } | ||
| 492 | 497 | ||
| 493 | /* byte size */ | 498 | /* byte size */ | 
| 494 | switch (termios->c_cflag & CSIZE) { | 499 | switch (termios->c_cflag & CSIZE) { | 
| diff --git a/drivers/serial/atmel_serial.h b/drivers/serial/atmel_serial.h index 11b44360e108..e0141776517c 100644 --- a/drivers/serial/atmel_serial.h +++ b/drivers/serial/atmel_serial.h | |||
| @@ -46,6 +46,9 @@ | |||
| 46 | #define ATMEL_US_USMODE_ISO7816_T1 6 | 46 | #define ATMEL_US_USMODE_ISO7816_T1 6 | 
| 47 | #define ATMEL_US_USMODE_IRDA 8 | 47 | #define ATMEL_US_USMODE_IRDA 8 | 
| 48 | #define ATMEL_US_USCLKS (3 << 4) /* Clock Selection */ | 48 | #define ATMEL_US_USCLKS (3 << 4) /* Clock Selection */ | 
| 49 | #define ATMEL_US_USCLKS_MCK (0 << 4) | ||
| 50 | #define ATMEL_US_USCLKS_MCK_DIV8 (1 << 4) | ||
| 51 | #define ATMEL_US_USCLKS_SCK (3 << 4) | ||
| 49 | #define ATMEL_US_CHRL (3 << 6) /* Character Length */ | 52 | #define ATMEL_US_CHRL (3 << 6) /* Character Length */ | 
| 50 | #define ATMEL_US_CHRL_5 (0 << 6) | 53 | #define ATMEL_US_CHRL_5 (0 << 6) | 
| 51 | #define ATMEL_US_CHRL_6 (1 << 6) | 54 | #define ATMEL_US_CHRL_6 (1 << 6) | 
| diff --git a/drivers/serial/imx.c b/drivers/serial/imx.c index 04cc88cc528c..e42faa4e4282 100644 --- a/drivers/serial/imx.c +++ b/drivers/serial/imx.c | |||
| @@ -46,6 +46,122 @@ | |||
| 46 | #include <asm/hardware.h> | 46 | #include <asm/hardware.h> | 
| 47 | #include <asm/arch/imx-uart.h> | 47 | #include <asm/arch/imx-uart.h> | 
| 48 | 48 | ||
| 49 | /* Register definitions */ | ||
| 50 | #define URXD0 0x0 /* Receiver Register */ | ||
| 51 | #define URTX0 0x40 /* Transmitter Register */ | ||
| 52 | #define UCR1 0x80 /* Control Register 1 */ | ||
| 53 | #define UCR2 0x84 /* Control Register 2 */ | ||
| 54 | #define UCR3 0x88 /* Control Register 3 */ | ||
| 55 | #define UCR4 0x8c /* Control Register 4 */ | ||
| 56 | #define UFCR 0x90 /* FIFO Control Register */ | ||
| 57 | #define USR1 0x94 /* Status Register 1 */ | ||
| 58 | #define USR2 0x98 /* Status Register 2 */ | ||
| 59 | #define UESC 0x9c /* Escape Character Register */ | ||
| 60 | #define UTIM 0xa0 /* Escape Timer Register */ | ||
| 61 | #define UBIR 0xa4 /* BRM Incremental Register */ | ||
| 62 | #define UBMR 0xa8 /* BRM Modulator Register */ | ||
| 63 | #define UBRC 0xac /* Baud Rate Count Register */ | ||
| 64 | #define BIPR1 0xb0 /* Incremental Preset Register 1 */ | ||
| 65 | #define BIPR2 0xb4 /* Incremental Preset Register 2 */ | ||
| 66 | #define BIPR3 0xb8 /* Incremental Preset Register 3 */ | ||
| 67 | #define BIPR4 0xbc /* Incremental Preset Register 4 */ | ||
| 68 | #define BMPR1 0xc0 /* BRM Modulator Register 1 */ | ||
| 69 | #define BMPR2 0xc4 /* BRM Modulator Register 2 */ | ||
| 70 | #define BMPR3 0xc8 /* BRM Modulator Register 3 */ | ||
| 71 | #define BMPR4 0xcc /* BRM Modulator Register 4 */ | ||
| 72 | #define UTS 0xd0 /* UART Test Register */ | ||
| 73 | |||
| 74 | /* UART Control Register Bit Fields.*/ | ||
| 75 | #define URXD_CHARRDY (1<<15) | ||
| 76 | #define URXD_ERR (1<<14) | ||
| 77 | #define URXD_OVRRUN (1<<13) | ||
| 78 | #define URXD_FRMERR (1<<12) | ||
| 79 | #define URXD_BRK (1<<11) | ||
| 80 | #define URXD_PRERR (1<<10) | ||
| 81 | #define UCR1_ADEN (1<<15) /* Auto dectect interrupt */ | ||
| 82 | #define UCR1_ADBR (1<<14) /* Auto detect baud rate */ | ||
| 83 | #define UCR1_TRDYEN (1<<13) /* Transmitter ready interrupt enable */ | ||
| 84 | #define UCR1_IDEN (1<<12) /* Idle condition interrupt */ | ||
| 85 | #define UCR1_RRDYEN (1<<9) /* Recv ready interrupt enable */ | ||
| 86 | #define UCR1_RDMAEN (1<<8) /* Recv ready DMA enable */ | ||
| 87 | #define UCR1_IREN (1<<7) /* Infrared interface enable */ | ||
| 88 | #define UCR1_TXMPTYEN (1<<6) /* Transimitter empty interrupt enable */ | ||
| 89 | #define UCR1_RTSDEN (1<<5) /* RTS delta interrupt enable */ | ||
| 90 | #define UCR1_SNDBRK (1<<4) /* Send break */ | ||
| 91 | #define UCR1_TDMAEN (1<<3) /* Transmitter ready DMA enable */ | ||
| 92 | #define UCR1_UARTCLKEN (1<<2) /* UART clock enabled */ | ||
| 93 | #define UCR1_DOZE (1<<1) /* Doze */ | ||
| 94 | #define UCR1_UARTEN (1<<0) /* UART enabled */ | ||
| 95 | #define UCR2_ESCI (1<<15) /* Escape seq interrupt enable */ | ||
| 96 | #define UCR2_IRTS (1<<14) /* Ignore RTS pin */ | ||
| 97 | #define UCR2_CTSC (1<<13) /* CTS pin control */ | ||
| 98 | #define UCR2_CTS (1<<12) /* Clear to send */ | ||
| 99 | #define UCR2_ESCEN (1<<11) /* Escape enable */ | ||
| 100 | #define UCR2_PREN (1<<8) /* Parity enable */ | ||
| 101 | #define UCR2_PROE (1<<7) /* Parity odd/even */ | ||
| 102 | #define UCR2_STPB (1<<6) /* Stop */ | ||
| 103 | #define UCR2_WS (1<<5) /* Word size */ | ||
| 104 | #define UCR2_RTSEN (1<<4) /* Request to send interrupt enable */ | ||
| 105 | #define UCR2_TXEN (1<<2) /* Transmitter enabled */ | ||
| 106 | #define UCR2_RXEN (1<<1) /* Receiver enabled */ | ||
| 107 | #define UCR2_SRST (1<<0) /* SW reset */ | ||
| 108 | #define UCR3_DTREN (1<<13) /* DTR interrupt enable */ | ||
| 109 | #define UCR3_PARERREN (1<<12) /* Parity enable */ | ||
| 110 | #define UCR3_FRAERREN (1<<11) /* Frame error interrupt enable */ | ||
| 111 | #define UCR3_DSR (1<<10) /* Data set ready */ | ||
| 112 | #define UCR3_DCD (1<<9) /* Data carrier detect */ | ||
| 113 | #define UCR3_RI (1<<8) /* Ring indicator */ | ||
| 114 | #define UCR3_TIMEOUTEN (1<<7) /* Timeout interrupt enable */ | ||
| 115 | #define UCR3_RXDSEN (1<<6) /* Receive status interrupt enable */ | ||
| 116 | #define UCR3_AIRINTEN (1<<5) /* Async IR wake interrupt enable */ | ||
| 117 | #define UCR3_AWAKEN (1<<4) /* Async wake interrupt enable */ | ||
| 118 | #define UCR3_REF25 (1<<3) /* Ref freq 25 MHz */ | ||
| 119 | #define UCR3_REF30 (1<<2) /* Ref Freq 30 MHz */ | ||
| 120 | #define UCR3_INVT (1<<1) /* Inverted Infrared transmission */ | ||
| 121 | #define UCR3_BPEN (1<<0) /* Preset registers enable */ | ||
| 122 | #define UCR4_CTSTL_32 (32<<10) /* CTS trigger level (32 chars) */ | ||
| 123 | #define UCR4_INVR (1<<9) /* Inverted infrared reception */ | ||
| 124 | #define UCR4_ENIRI (1<<8) /* Serial infrared interrupt enable */ | ||
| 125 | #define UCR4_WKEN (1<<7) /* Wake interrupt enable */ | ||
| 126 | #define UCR4_REF16 (1<<6) /* Ref freq 16 MHz */ | ||
| 127 | #define UCR4_IRSC (1<<5) /* IR special case */ | ||
| 128 | #define UCR4_TCEN (1<<3) /* Transmit complete interrupt enable */ | ||
| 129 | #define UCR4_BKEN (1<<2) /* Break condition interrupt enable */ | ||
| 130 | #define UCR4_OREN (1<<1) /* Receiver overrun interrupt enable */ | ||
| 131 | #define UCR4_DREN (1<<0) /* Recv data ready interrupt enable */ | ||
| 132 | #define UFCR_RXTL_SHF 0 /* Receiver trigger level shift */ | ||
| 133 | #define UFCR_RFDIV (7<<7) /* Reference freq divider mask */ | ||
| 134 | #define UFCR_TXTL_SHF 10 /* Transmitter trigger level shift */ | ||
| 135 | #define USR1_PARITYERR (1<<15) /* Parity error interrupt flag */ | ||
| 136 | #define USR1_RTSS (1<<14) /* RTS pin status */ | ||
| 137 | #define USR1_TRDY (1<<13) /* Transmitter ready interrupt/dma flag */ | ||
| 138 | #define USR1_RTSD (1<<12) /* RTS delta */ | ||
| 139 | #define USR1_ESCF (1<<11) /* Escape seq interrupt flag */ | ||
| 140 | #define USR1_FRAMERR (1<<10) /* Frame error interrupt flag */ | ||
| 141 | #define USR1_RRDY (1<<9) /* Receiver ready interrupt/dma flag */ | ||
| 142 | #define USR1_TIMEOUT (1<<7) /* Receive timeout interrupt status */ | ||
| 143 | #define USR1_RXDS (1<<6) /* Receiver idle interrupt flag */ | ||
| 144 | #define USR1_AIRINT (1<<5) /* Async IR wake interrupt flag */ | ||
| 145 | #define USR1_AWAKE (1<<4) /* Aysnc wake interrupt flag */ | ||
| 146 | #define USR2_ADET (1<<15) /* Auto baud rate detect complete */ | ||
| 147 | #define USR2_TXFE (1<<14) /* Transmit buffer FIFO empty */ | ||
| 148 | #define USR2_DTRF (1<<13) /* DTR edge interrupt flag */ | ||
| 149 | #define USR2_IDLE (1<<12) /* Idle condition */ | ||
| 150 | #define USR2_IRINT (1<<8) /* Serial infrared interrupt flag */ | ||
| 151 | #define USR2_WAKE (1<<7) /* Wake */ | ||
| 152 | #define USR2_RTSF (1<<4) /* RTS edge interrupt flag */ | ||
| 153 | #define USR2_TXDC (1<<3) /* Transmitter complete */ | ||
| 154 | #define USR2_BRCD (1<<2) /* Break condition */ | ||
| 155 | #define USR2_ORE (1<<1) /* Overrun error */ | ||
| 156 | #define USR2_RDR (1<<0) /* Recv data ready */ | ||
| 157 | #define UTS_FRCPERR (1<<13) /* Force parity error */ | ||
| 158 | #define UTS_LOOP (1<<12) /* Loop tx and rx */ | ||
| 159 | #define UTS_TXEMPTY (1<<6) /* TxFIFO empty */ | ||
| 160 | #define UTS_RXEMPTY (1<<5) /* RxFIFO empty */ | ||
| 161 | #define UTS_TXFULL (1<<4) /* TxFIFO full */ | ||
| 162 | #define UTS_RXFULL (1<<3) /* RxFIFO full */ | ||
| 163 | #define UTS_SOFTRST (1<<0) /* Software reset */ | ||
| 164 | |||
| 49 | /* We've been assigned a range on the "Low-density serial ports" major */ | 165 | /* We've been assigned a range on the "Low-density serial ports" major */ | 
| 50 | #define SERIAL_IMX_MAJOR 204 | 166 | #define SERIAL_IMX_MAJOR 204 | 
| 51 | #define MINOR_START 41 | 167 | #define MINOR_START 41 | 
| @@ -128,7 +244,10 @@ static void imx_timeout(unsigned long data) | |||
| 128 | static void imx_stop_tx(struct uart_port *port) | 244 | static void imx_stop_tx(struct uart_port *port) | 
| 129 | { | 245 | { | 
| 130 | struct imx_port *sport = (struct imx_port *)port; | 246 | struct imx_port *sport = (struct imx_port *)port; | 
| 131 | UCR1((u32)sport->port.membase) &= ~UCR1_TXMPTYEN; | 247 | unsigned long temp; | 
| 248 | |||
| 249 | temp = readl(sport->port.membase + UCR1); | ||
| 250 | writel(temp & ~UCR1_TXMPTYEN, sport->port.membase + UCR1); | ||
| 132 | } | 251 | } | 
| 133 | 252 | ||
| 134 | /* | 253 | /* | 
| @@ -137,7 +256,10 @@ static void imx_stop_tx(struct uart_port *port) | |||
| 137 | static void imx_stop_rx(struct uart_port *port) | 256 | static void imx_stop_rx(struct uart_port *port) | 
| 138 | { | 257 | { | 
| 139 | struct imx_port *sport = (struct imx_port *)port; | 258 | struct imx_port *sport = (struct imx_port *)port; | 
| 140 | UCR2((u32)sport->port.membase) &= ~UCR2_RXEN; | 259 | unsigned long temp; | 
| 260 | |||
| 261 | temp = readl(sport->port.membase + UCR2); | ||
| 262 | writel(temp &~ UCR2_RXEN, sport->port.membase + UCR2); | ||
| 141 | } | 263 | } | 
| 142 | 264 | ||
| 143 | /* | 265 | /* | 
| @@ -154,10 +276,10 @@ static inline void imx_transmit_buffer(struct imx_port *sport) | |||
| 154 | { | 276 | { | 
| 155 | struct circ_buf *xmit = &sport->port.info->xmit; | 277 | struct circ_buf *xmit = &sport->port.info->xmit; | 
| 156 | 278 | ||
| 157 | while (!(UTS((u32)sport->port.membase) & UTS_TXFULL)) { | 279 | while (!(readl(sport->port.membase + UTS) & UTS_TXFULL)) { | 
| 158 | /* send xmit->buf[xmit->tail] | 280 | /* send xmit->buf[xmit->tail] | 
| 159 | * out the port here */ | 281 | * out the port here */ | 
| 160 | URTX0((u32)sport->port.membase) = xmit->buf[xmit->tail]; | 282 | writel(xmit->buf[xmit->tail], sport->port.membase + URTX0); | 
| 161 | xmit->tail = (xmit->tail + 1) & | 283 | xmit->tail = (xmit->tail + 1) & | 
| 162 | (UART_XMIT_SIZE - 1); | 284 | (UART_XMIT_SIZE - 1); | 
| 163 | sport->port.icount.tx++; | 285 | sport->port.icount.tx++; | 
| @@ -175,21 +297,24 @@ static inline void imx_transmit_buffer(struct imx_port *sport) | |||
| 175 | static void imx_start_tx(struct uart_port *port) | 297 | static void imx_start_tx(struct uart_port *port) | 
| 176 | { | 298 | { | 
| 177 | struct imx_port *sport = (struct imx_port *)port; | 299 | struct imx_port *sport = (struct imx_port *)port; | 
| 300 | unsigned long temp; | ||
| 178 | 301 | ||
| 179 | UCR1((u32)sport->port.membase) |= UCR1_TXMPTYEN; | 302 | temp = readl(sport->port.membase + UCR1); | 
| 303 | writel(temp | UCR1_TXMPTYEN, sport->port.membase + UCR1); | ||
| 180 | 304 | ||
| 181 | imx_transmit_buffer(sport); | 305 | if (readl(sport->port.membase + UTS) & UTS_TXEMPTY) | 
| 306 | imx_transmit_buffer(sport); | ||
| 182 | } | 307 | } | 
| 183 | 308 | ||
| 184 | static irqreturn_t imx_rtsint(int irq, void *dev_id) | 309 | static irqreturn_t imx_rtsint(int irq, void *dev_id) | 
| 185 | { | 310 | { | 
| 186 | struct imx_port *sport = (struct imx_port *)dev_id; | 311 | struct imx_port *sport = (struct imx_port *)dev_id; | 
| 187 | unsigned int val = USR1((u32)sport->port.membase)&USR1_RTSS; | 312 | unsigned int val = readl(sport->port.membase + USR1) & USR1_RTSS; | 
| 188 | unsigned long flags; | 313 | unsigned long flags; | 
| 189 | 314 | ||
| 190 | spin_lock_irqsave(&sport->port.lock, flags); | 315 | spin_lock_irqsave(&sport->port.lock, flags); | 
| 191 | 316 | ||
| 192 | USR1((u32)sport->port.membase) = USR1_RTSD; | 317 | writel(USR1_RTSD, sport->port.membase + USR1); | 
| 193 | uart_handle_cts_change(&sport->port, !!val); | 318 | uart_handle_cts_change(&sport->port, !!val); | 
| 194 | wake_up_interruptible(&sport->port.info->delta_msr_wait); | 319 | wake_up_interruptible(&sport->port.info->delta_msr_wait); | 
| 195 | 320 | ||
| @@ -207,7 +332,7 @@ static irqreturn_t imx_txint(int irq, void *dev_id) | |||
| 207 | if (sport->port.x_char) | 332 | if (sport->port.x_char) | 
| 208 | { | 333 | { | 
| 209 | /* Send next char */ | 334 | /* Send next char */ | 
| 210 | URTX0((u32)sport->port.membase) = sport->port.x_char; | 335 | writel(sport->port.x_char, sport->port.membase + URTX0); | 
| 211 | goto out; | 336 | goto out; | 
| 212 | } | 337 | } | 
| 213 | 338 | ||
| @@ -231,17 +356,18 @@ static irqreturn_t imx_rxint(int irq, void *dev_id) | |||
| 231 | struct imx_port *sport = dev_id; | 356 | struct imx_port *sport = dev_id; | 
| 232 | unsigned int rx,flg,ignored = 0; | 357 | unsigned int rx,flg,ignored = 0; | 
| 233 | struct tty_struct *tty = sport->port.info->tty; | 358 | struct tty_struct *tty = sport->port.info->tty; | 
| 234 | unsigned long flags; | 359 | unsigned long flags, temp; | 
| 235 | 360 | ||
| 236 | rx = URXD0((u32)sport->port.membase); | 361 | rx = readl(sport->port.membase + URXD0); | 
| 237 | spin_lock_irqsave(&sport->port.lock,flags); | 362 | spin_lock_irqsave(&sport->port.lock,flags); | 
| 238 | 363 | ||
| 239 | do { | 364 | do { | 
| 240 | flg = TTY_NORMAL; | 365 | flg = TTY_NORMAL; | 
| 241 | sport->port.icount.rx++; | 366 | sport->port.icount.rx++; | 
| 242 | 367 | ||
| 243 | if( USR2((u32)sport->port.membase) & USR2_BRCD ) { | 368 | temp = readl(sport->port.membase + USR2); | 
| 244 | USR2((u32)sport->port.membase) |= USR2_BRCD; | 369 | if( temp & USR2_BRCD ) { | 
| 370 | writel(temp | USR2_BRCD, sport->port.membase + USR2); | ||
| 245 | if(uart_handle_break(&sport->port)) | 371 | if(uart_handle_break(&sport->port)) | 
| 246 | goto ignore_char; | 372 | goto ignore_char; | 
| 247 | } | 373 | } | 
| @@ -257,7 +383,7 @@ static irqreturn_t imx_rxint(int irq, void *dev_id) | |||
| 257 | tty_insert_flip_char(tty, rx, flg); | 383 | tty_insert_flip_char(tty, rx, flg); | 
| 258 | 384 | ||
| 259 | ignore_char: | 385 | ignore_char: | 
| 260 | rx = URXD0((u32)sport->port.membase); | 386 | rx = readl(sport->port.membase + URXD0); | 
| 261 | } while(rx & URXD_CHARRDY); | 387 | } while(rx & URXD_CHARRDY); | 
| 262 | 388 | ||
| 263 | out: | 389 | out: | 
| @@ -301,7 +427,7 @@ static unsigned int imx_tx_empty(struct uart_port *port) | |||
| 301 | { | 427 | { | 
| 302 | struct imx_port *sport = (struct imx_port *)port; | 428 | struct imx_port *sport = (struct imx_port *)port; | 
| 303 | 429 | ||
| 304 | return USR2((u32)sport->port.membase) & USR2_TXDC ? TIOCSER_TEMT : 0; | 430 | return (readl(sport->port.membase + USR2) & USR2_TXDC) ? TIOCSER_TEMT : 0; | 
| 305 | } | 431 | } | 
| 306 | 432 | ||
| 307 | /* | 433 | /* | 
| @@ -312,10 +438,10 @@ static unsigned int imx_get_mctrl(struct uart_port *port) | |||
| 312 | struct imx_port *sport = (struct imx_port *)port; | 438 | struct imx_port *sport = (struct imx_port *)port; | 
| 313 | unsigned int tmp = TIOCM_DSR | TIOCM_CAR; | 439 | unsigned int tmp = TIOCM_DSR | TIOCM_CAR; | 
| 314 | 440 | ||
| 315 | if (USR1((u32)sport->port.membase) & USR1_RTSS) | 441 | if (readl(sport->port.membase + USR1) & USR1_RTSS) | 
| 316 | tmp |= TIOCM_CTS; | 442 | tmp |= TIOCM_CTS; | 
| 317 | 443 | ||
| 318 | if (UCR2((u32)sport->port.membase) & UCR2_CTS) | 444 | if (readl(sport->port.membase + UCR2) & UCR2_CTS) | 
| 319 | tmp |= TIOCM_RTS; | 445 | tmp |= TIOCM_RTS; | 
| 320 | 446 | ||
| 321 | return tmp; | 447 | return tmp; | 
| @@ -324,11 +450,14 @@ static unsigned int imx_get_mctrl(struct uart_port *port) | |||
| 324 | static void imx_set_mctrl(struct uart_port *port, unsigned int mctrl) | 450 | static void imx_set_mctrl(struct uart_port *port, unsigned int mctrl) | 
| 325 | { | 451 | { | 
| 326 | struct imx_port *sport = (struct imx_port *)port; | 452 | struct imx_port *sport = (struct imx_port *)port; | 
| 453 | unsigned long temp; | ||
| 454 | |||
| 455 | temp = readl(sport->port.membase + UCR2) & ~UCR2_CTS; | ||
| 327 | 456 | ||
| 328 | if (mctrl & TIOCM_RTS) | 457 | if (mctrl & TIOCM_RTS) | 
| 329 | UCR2((u32)sport->port.membase) |= UCR2_CTS; | 458 | temp |= UCR2_CTS; | 
| 330 | else | 459 | |
| 331 | UCR2((u32)sport->port.membase) &= ~UCR2_CTS; | 460 | writel(temp, sport->port.membase + UCR2); | 
| 332 | } | 461 | } | 
| 333 | 462 | ||
| 334 | /* | 463 | /* | 
| @@ -337,14 +466,16 @@ static void imx_set_mctrl(struct uart_port *port, unsigned int mctrl) | |||
| 337 | static void imx_break_ctl(struct uart_port *port, int break_state) | 466 | static void imx_break_ctl(struct uart_port *port, int break_state) | 
| 338 | { | 467 | { | 
| 339 | struct imx_port *sport = (struct imx_port *)port; | 468 | struct imx_port *sport = (struct imx_port *)port; | 
| 340 | unsigned long flags; | 469 | unsigned long flags, temp; | 
| 341 | 470 | ||
| 342 | spin_lock_irqsave(&sport->port.lock, flags); | 471 | spin_lock_irqsave(&sport->port.lock, flags); | 
| 343 | 472 | ||
| 473 | temp = readl(sport->port.membase + UCR1) & ~UCR1_SNDBRK; | ||
| 474 | |||
| 344 | if ( break_state != 0 ) | 475 | if ( break_state != 0 ) | 
| 345 | UCR1((u32)sport->port.membase) |= UCR1_SNDBRK; | 476 | temp |= UCR1_SNDBRK; | 
| 346 | else | 477 | |
| 347 | UCR1((u32)sport->port.membase) &= ~UCR1_SNDBRK; | 478 | writel(temp, sport->port.membase + UCR1); | 
| 348 | 479 | ||
| 349 | spin_unlock_irqrestore(&sport->port.lock, flags); | 480 | spin_unlock_irqrestore(&sport->port.lock, flags); | 
| 350 | } | 481 | } | 
| @@ -360,7 +491,7 @@ static int imx_setup_ufcr(struct imx_port *sport, unsigned int mode) | |||
| 360 | /* set receiver / transmitter trigger level. | 491 | /* set receiver / transmitter trigger level. | 
| 361 | * RFDIV is set such way to satisfy requested uartclk value | 492 | * RFDIV is set such way to satisfy requested uartclk value | 
| 362 | */ | 493 | */ | 
| 363 | val = TXTL<<10 | RXTL; | 494 | val = TXTL << 10 | RXTL; | 
| 364 | ufcr_rfdiv = (imx_get_perclk1() + sport->port.uartclk / 2) / sport->port.uartclk; | 495 | ufcr_rfdiv = (imx_get_perclk1() + sport->port.uartclk / 2) / sport->port.uartclk; | 
| 365 | 496 | ||
| 366 | if(!ufcr_rfdiv) | 497 | if(!ufcr_rfdiv) | 
| @@ -373,7 +504,7 @@ static int imx_setup_ufcr(struct imx_port *sport, unsigned int mode) | |||
| 373 | 504 | ||
| 374 | val |= UFCR_RFDIV & (ufcr_rfdiv << 7); | 505 | val |= UFCR_RFDIV & (ufcr_rfdiv << 7); | 
| 375 | 506 | ||
| 376 | UFCR((u32)sport->port.membase) = val; | 507 | writel(val, sport->port.membase + UFCR); | 
| 377 | 508 | ||
| 378 | return 0; | 509 | return 0; | 
| 379 | } | 510 | } | 
| @@ -382,14 +513,15 @@ static int imx_startup(struct uart_port *port) | |||
| 382 | { | 513 | { | 
| 383 | struct imx_port *sport = (struct imx_port *)port; | 514 | struct imx_port *sport = (struct imx_port *)port; | 
| 384 | int retval; | 515 | int retval; | 
| 385 | unsigned long flags; | 516 | unsigned long flags, temp; | 
| 386 | 517 | ||
| 387 | imx_setup_ufcr(sport, 0); | 518 | imx_setup_ufcr(sport, 0); | 
| 388 | 519 | ||
| 389 | /* disable the DREN bit (Data Ready interrupt enable) before | 520 | /* disable the DREN bit (Data Ready interrupt enable) before | 
| 390 | * requesting IRQs | 521 | * requesting IRQs | 
| 391 | */ | 522 | */ | 
| 392 | UCR4((u32)sport->port.membase) &= ~UCR4_DREN; | 523 | temp = readl(sport->port.membase + UCR4); | 
| 524 | writel(temp & ~UCR4_DREN, sport->port.membase + UCR4); | ||
| 393 | 525 | ||
| 394 | /* | 526 | /* | 
| 395 | * Allocate the IRQ | 527 | * Allocate the IRQ | 
| @@ -411,12 +543,16 @@ static int imx_startup(struct uart_port *port) | |||
| 411 | /* | 543 | /* | 
| 412 | * Finally, clear and enable interrupts | 544 | * Finally, clear and enable interrupts | 
| 413 | */ | 545 | */ | 
| 546 | writel(USR1_RTSD, sport->port.membase + USR1); | ||
| 547 | |||
| 548 | temp = readl(sport->port.membase + UCR1); | ||
| 549 | temp |= (UCR1_TXMPTYEN | UCR1_RRDYEN | UCR1_RTSDEN | UCR1_UARTEN); | ||
| 550 | writel(temp, sport->port.membase + UCR1); | ||
| 414 | 551 | ||
| 415 | USR1((u32)sport->port.membase) = USR1_RTSD; | 552 | temp = readl(sport->port.membase + UCR2); | 
| 416 | UCR1((u32)sport->port.membase) |= | 553 | temp |= (UCR2_RXEN | UCR2_TXEN); | 
| 417 | (UCR1_TXMPTYEN | UCR1_RRDYEN | UCR1_RTSDEN | UCR1_UARTEN); | 554 | writel(temp, sport->port.membase + UCR2); | 
| 418 | 555 | ||
| 419 | UCR2((u32)sport->port.membase) |= (UCR2_RXEN | UCR2_TXEN); | ||
| 420 | /* | 556 | /* | 
| 421 | * Enable modem status interrupts | 557 | * Enable modem status interrupts | 
| 422 | */ | 558 | */ | 
| @@ -437,6 +573,7 @@ error_out1: | |||
| 437 | static void imx_shutdown(struct uart_port *port) | 573 | static void imx_shutdown(struct uart_port *port) | 
| 438 | { | 574 | { | 
| 439 | struct imx_port *sport = (struct imx_port *)port; | 575 | struct imx_port *sport = (struct imx_port *)port; | 
| 576 | unsigned long temp; | ||
| 440 | 577 | ||
| 441 | /* | 578 | /* | 
| 442 | * Stop our timer. | 579 | * Stop our timer. | 
| @@ -454,8 +591,9 @@ static void imx_shutdown(struct uart_port *port) | |||
| 454 | * Disable all interrupts, port and break condition. | 591 | * Disable all interrupts, port and break condition. | 
| 455 | */ | 592 | */ | 
| 456 | 593 | ||
| 457 | UCR1((u32)sport->port.membase) &= | 594 | temp = readl(sport->port.membase + UCR1); | 
| 458 | ~(UCR1_TXMPTYEN | UCR1_RRDYEN | UCR1_RTSDEN | UCR1_UARTEN); | 595 | temp &= ~(UCR1_TXMPTYEN | UCR1_RRDYEN | UCR1_RTSDEN | UCR1_UARTEN); | 
| 596 | writel(temp, sport->port.membase + UCR1); | ||
| 459 | } | 597 | } | 
| 460 | 598 | ||
| 461 | static void | 599 | static void | 
| @@ -548,18 +686,18 @@ imx_set_termios(struct uart_port *port, struct ktermios *termios, | |||
| 548 | /* | 686 | /* | 
| 549 | * disable interrupts and drain transmitter | 687 | * disable interrupts and drain transmitter | 
| 550 | */ | 688 | */ | 
| 551 | old_ucr1 = UCR1((u32)sport->port.membase); | 689 | old_ucr1 = readl(sport->port.membase + UCR1); | 
| 552 | UCR1((u32)sport->port.membase) &= ~(UCR1_TXMPTYEN | UCR1_RRDYEN | UCR1_RTSDEN); | 690 | writel(old_ucr1 & ~(UCR1_TXMPTYEN | UCR1_RRDYEN | UCR1_RTSDEN), | 
| 691 | sport->port.membase + UCR1); | ||
| 553 | 692 | ||
| 554 | while ( !(USR2((u32)sport->port.membase) & USR2_TXDC)) | 693 | while ( !(readl(sport->port.membase + USR2) & USR2_TXDC)) | 
| 555 | barrier(); | 694 | barrier(); | 
| 556 | 695 | ||
| 557 | /* then, disable everything */ | 696 | /* then, disable everything */ | 
| 558 | old_txrxen = UCR2((u32)sport->port.membase) & ( UCR2_TXEN | UCR2_RXEN ); | 697 | old_txrxen = readl(sport->port.membase + UCR2); | 
| 559 | UCR2((u32)sport->port.membase) &= ~( UCR2_TXEN | UCR2_RXEN); | 698 | writel(old_txrxen & ~( UCR2_TXEN | UCR2_RXEN), | 
| 560 | 699 | sport->port.membase + UCR2); | |
| 561 | /* set the parity, stop bits and data size */ | 700 | old_txrxen &= (UCR2_TXEN | UCR2_RXEN); | 
| 562 | UCR2((u32)sport->port.membase) = ucr2; | ||
| 563 | 701 | ||
| 564 | /* set the baud rate. We assume uartclk = 16 MHz | 702 | /* set the baud rate. We assume uartclk = 16 MHz | 
| 565 | * | 703 | * | 
| @@ -567,11 +705,13 @@ imx_set_termios(struct uart_port *port, struct ktermios *termios, | |||
| 567 | * --------- = -------- | 705 | * --------- = -------- | 
| 568 | * uartclk UBMR - 1 | 706 | * uartclk UBMR - 1 | 
| 569 | */ | 707 | */ | 
| 570 | UBIR((u32)sport->port.membase) = (baud / 100) - 1; | 708 | writel((baud / 100) - 1, sport->port.membase + UBIR); | 
| 571 | UBMR((u32)sport->port.membase) = 10000 - 1; | 709 | writel(10000 - 1, sport->port.membase + UBMR); | 
| 710 | |||
| 711 | writel(old_ucr1, sport->port.membase + UCR1); | ||
| 572 | 712 | ||
| 573 | UCR1((u32)sport->port.membase) = old_ucr1; | 713 | /* set the parity, stop bits and data size */ | 
| 574 | UCR2((u32)sport->port.membase) |= old_txrxen; | 714 | writel(ucr2 | old_txrxen, sport->port.membase + UCR2); | 
| 575 | 715 | ||
| 576 | if (UART_ENABLE_MS(&sport->port, termios->c_cflag)) | 716 | if (UART_ENABLE_MS(&sport->port, termios->c_cflag)) | 
| 577 | imx_enable_ms(&sport->port); | 717 | imx_enable_ms(&sport->port); | 
| @@ -730,9 +870,11 @@ static void __init imx_init_ports(void) | |||
| 730 | static void imx_console_putchar(struct uart_port *port, int ch) | 870 | static void imx_console_putchar(struct uart_port *port, int ch) | 
| 731 | { | 871 | { | 
| 732 | struct imx_port *sport = (struct imx_port *)port; | 872 | struct imx_port *sport = (struct imx_port *)port; | 
| 733 | while ((UTS((u32)sport->port.membase) & UTS_TXFULL)) | 873 | |
| 874 | while (readl(sport->port.membase + UTS) & UTS_TXFULL) | ||
| 734 | barrier(); | 875 | barrier(); | 
| 735 | URTX0((u32)sport->port.membase) = ch; | 876 | |
| 877 | writel(ch, sport->port.membase + URTX0); | ||
| 736 | } | 878 | } | 
| 737 | 879 | ||
| 738 | /* | 880 | /* | 
| @@ -747,13 +889,14 @@ imx_console_write(struct console *co, const char *s, unsigned int count) | |||
| 747 | /* | 889 | /* | 
| 748 | * First, save UCR1/2 and then disable interrupts | 890 | * First, save UCR1/2 and then disable interrupts | 
| 749 | */ | 891 | */ | 
| 750 | old_ucr1 = UCR1((u32)sport->port.membase); | 892 | old_ucr1 = readl(sport->port.membase + UCR1); | 
| 751 | old_ucr2 = UCR2((u32)sport->port.membase); | 893 | old_ucr2 = readl(sport->port.membase + UCR2); | 
| 752 | 894 | ||
| 753 | UCR1((u32)sport->port.membase) = | 895 | writel((old_ucr1 | UCR1_UARTCLKEN | UCR1_UARTEN) & | 
| 754 | (old_ucr1 | UCR1_UARTCLKEN | UCR1_UARTEN) | 896 | ~(UCR1_TXMPTYEN | UCR1_RRDYEN | UCR1_RTSDEN), | 
| 755 | & ~(UCR1_TXMPTYEN | UCR1_RRDYEN | UCR1_RTSDEN); | 897 | sport->port.membase + UCR1); | 
| 756 | UCR2((u32)sport->port.membase) = old_ucr2 | UCR2_TXEN; | 898 | |
| 899 | writel(old_ucr2 | UCR2_TXEN, sport->port.membase + UCR2); | ||
| 757 | 900 | ||
| 758 | uart_console_write(&sport->port, s, count, imx_console_putchar); | 901 | uart_console_write(&sport->port, s, count, imx_console_putchar); | 
| 759 | 902 | ||
| @@ -761,10 +904,10 @@ imx_console_write(struct console *co, const char *s, unsigned int count) | |||
| 761 | * Finally, wait for transmitter to become empty | 904 | * Finally, wait for transmitter to become empty | 
| 762 | * and restore UCR1/2 | 905 | * and restore UCR1/2 | 
| 763 | */ | 906 | */ | 
| 764 | while (!(USR2((u32)sport->port.membase) & USR2_TXDC)); | 907 | while (!(readl(sport->port.membase + USR2) & USR2_TXDC)); | 
| 765 | 908 | ||
| 766 | UCR1((u32)sport->port.membase) = old_ucr1; | 909 | writel(old_ucr1, sport->port.membase + UCR1); | 
| 767 | UCR2((u32)sport->port.membase) = old_ucr2; | 910 | writel(old_ucr2, sport->port.membase + UCR2); | 
| 768 | } | 911 | } | 
| 769 | 912 | ||
| 770 | /* | 913 | /* | 
| @@ -776,13 +919,13 @@ imx_console_get_options(struct imx_port *sport, int *baud, | |||
| 776 | int *parity, int *bits) | 919 | int *parity, int *bits) | 
| 777 | { | 920 | { | 
| 778 | 921 | ||
| 779 | if ( UCR1((u32)sport->port.membase) | UCR1_UARTEN ) { | 922 | if ( readl(sport->port.membase + UCR1) | UCR1_UARTEN ) { | 
| 780 | /* ok, the port was enabled */ | 923 | /* ok, the port was enabled */ | 
| 781 | unsigned int ucr2, ubir,ubmr, uartclk; | 924 | unsigned int ucr2, ubir,ubmr, uartclk; | 
| 782 | unsigned int baud_raw; | 925 | unsigned int baud_raw; | 
| 783 | unsigned int ucfr_rfdiv; | 926 | unsigned int ucfr_rfdiv; | 
| 784 | 927 | ||
| 785 | ucr2 = UCR2((u32)sport->port.membase); | 928 | ucr2 = readl(sport->port.membase + UCR2); | 
| 786 | 929 | ||
| 787 | *parity = 'n'; | 930 | *parity = 'n'; | 
| 788 | if (ucr2 & UCR2_PREN) { | 931 | if (ucr2 & UCR2_PREN) { | 
| @@ -797,11 +940,10 @@ imx_console_get_options(struct imx_port *sport, int *baud, | |||
| 797 | else | 940 | else | 
| 798 | *bits = 7; | 941 | *bits = 7; | 
| 799 | 942 | ||
| 800 | ubir = UBIR((u32)sport->port.membase) & 0xffff; | 943 | ubir = readl(sport->port.membase + UBIR) & 0xffff; | 
| 801 | ubmr = UBMR((u32)sport->port.membase) & 0xffff; | 944 | ubmr = readl(sport->port.membase + UBMR) & 0xffff; | 
| 802 | |||
| 803 | 945 | ||
| 804 | ucfr_rfdiv = (UFCR((u32)sport->port.membase) & UFCR_RFDIV) >> 7; | 946 | ucfr_rfdiv = (readl(sport->port.membase + UFCR) & UFCR_RFDIV) >> 7; | 
| 805 | if (ucfr_rfdiv == 6) | 947 | if (ucfr_rfdiv == 6) | 
| 806 | ucfr_rfdiv = 7; | 948 | ucfr_rfdiv = 7; | 
| 807 | else | 949 | else | 
| diff --git a/drivers/serial/pxa.c b/drivers/serial/pxa.c index d403aaa55092..e9c6cb391a23 100644 --- a/drivers/serial/pxa.c +++ b/drivers/serial/pxa.c | |||
| @@ -717,7 +717,7 @@ struct uart_ops serial_pxa_pops = { | |||
| 717 | static struct uart_pxa_port serial_pxa_ports[] = { | 717 | static struct uart_pxa_port serial_pxa_ports[] = { | 
| 718 | { /* FFUART */ | 718 | { /* FFUART */ | 
| 719 | .name = "FFUART", | 719 | .name = "FFUART", | 
| 720 | .cken = CKEN6_FFUART, | 720 | .cken = CKEN_FFUART, | 
| 721 | .port = { | 721 | .port = { | 
| 722 | .type = PORT_PXA, | 722 | .type = PORT_PXA, | 
| 723 | .iotype = UPIO_MEM, | 723 | .iotype = UPIO_MEM, | 
| @@ -731,7 +731,7 @@ static struct uart_pxa_port serial_pxa_ports[] = { | |||
| 731 | }, | 731 | }, | 
| 732 | }, { /* BTUART */ | 732 | }, { /* BTUART */ | 
| 733 | .name = "BTUART", | 733 | .name = "BTUART", | 
| 734 | .cken = CKEN7_BTUART, | 734 | .cken = CKEN_BTUART, | 
| 735 | .port = { | 735 | .port = { | 
| 736 | .type = PORT_PXA, | 736 | .type = PORT_PXA, | 
| 737 | .iotype = UPIO_MEM, | 737 | .iotype = UPIO_MEM, | 
| @@ -745,7 +745,7 @@ static struct uart_pxa_port serial_pxa_ports[] = { | |||
| 745 | }, | 745 | }, | 
| 746 | }, { /* STUART */ | 746 | }, { /* STUART */ | 
| 747 | .name = "STUART", | 747 | .name = "STUART", | 
| 748 | .cken = CKEN5_STUART, | 748 | .cken = CKEN_STUART, | 
| 749 | .port = { | 749 | .port = { | 
| 750 | .type = PORT_PXA, | 750 | .type = PORT_PXA, | 
| 751 | .iotype = UPIO_MEM, | 751 | .iotype = UPIO_MEM, | 
| @@ -759,7 +759,7 @@ static struct uart_pxa_port serial_pxa_ports[] = { | |||
| 759 | }, | 759 | }, | 
| 760 | }, { /* HWUART */ | 760 | }, { /* HWUART */ | 
| 761 | .name = "HWUART", | 761 | .name = "HWUART", | 
| 762 | .cken = CKEN4_HWUART, | 762 | .cken = CKEN_HWUART, | 
| 763 | .port = { | 763 | .port = { | 
| 764 | .type = PORT_PXA, | 764 | .type = PORT_PXA, | 
| 765 | .iotype = UPIO_MEM, | 765 | .iotype = UPIO_MEM, | 
| diff --git a/drivers/usb/gadget/pxa2xx_udc.c b/drivers/usb/gadget/pxa2xx_udc.c index f01890dc8751..018b0d65765a 100644 --- a/drivers/usb/gadget/pxa2xx_udc.c +++ b/drivers/usb/gadget/pxa2xx_udc.c | |||
| @@ -1497,7 +1497,7 @@ static void udc_disable(struct pxa2xx_udc *dev) | |||
| 1497 | 1497 | ||
| 1498 | #ifdef CONFIG_ARCH_PXA | 1498 | #ifdef CONFIG_ARCH_PXA | 
| 1499 | /* Disable clock for USB device */ | 1499 | /* Disable clock for USB device */ | 
| 1500 | pxa_set_cken(CKEN11_USB, 0); | 1500 | pxa_set_cken(CKEN_USB, 0); | 
| 1501 | #endif | 1501 | #endif | 
| 1502 | 1502 | ||
| 1503 | ep0_idle (dev); | 1503 | ep0_idle (dev); | 
| @@ -1543,7 +1543,7 @@ static void udc_enable (struct pxa2xx_udc *dev) | |||
| 1543 | 1543 | ||
| 1544 | #ifdef CONFIG_ARCH_PXA | 1544 | #ifdef CONFIG_ARCH_PXA | 
| 1545 | /* Enable clock for USB device */ | 1545 | /* Enable clock for USB device */ | 
| 1546 | pxa_set_cken(CKEN11_USB, 1); | 1546 | pxa_set_cken(CKEN_USB, 1); | 
| 1547 | udelay(5); | 1547 | udelay(5); | 
| 1548 | #endif | 1548 | #endif | 
| 1549 | 1549 | ||
| diff --git a/drivers/usb/host/ohci-pxa27x.c b/drivers/usb/host/ohci-pxa27x.c index f1563dc319d3..23d2fe5a62f4 100644 --- a/drivers/usb/host/ohci-pxa27x.c +++ b/drivers/usb/host/ohci-pxa27x.c | |||
| @@ -80,7 +80,7 @@ static int pxa27x_start_hc(struct device *dev) | |||
| 80 | 80 | ||
| 81 | inf = dev->platform_data; | 81 | inf = dev->platform_data; | 
| 82 | 82 | ||
| 83 | pxa_set_cken(CKEN10_USBHOST, 1); | 83 | pxa_set_cken(CKEN_USBHOST, 1); | 
| 84 | 84 | ||
| 85 | UHCHR |= UHCHR_FHR; | 85 | UHCHR |= UHCHR_FHR; | 
| 86 | udelay(11); | 86 | udelay(11); | 
| @@ -123,7 +123,7 @@ static void pxa27x_stop_hc(struct device *dev) | |||
| 123 | UHCCOMS |= 1; | 123 | UHCCOMS |= 1; | 
| 124 | udelay(10); | 124 | udelay(10); | 
| 125 | 125 | ||
| 126 | pxa_set_cken(CKEN10_USBHOST, 0); | 126 | pxa_set_cken(CKEN_USBHOST, 0); | 
| 127 | } | 127 | } | 
| 128 | 128 | ||
| 129 | 129 | ||
| diff --git a/drivers/video/pxafb.c b/drivers/video/pxafb.c index b4947c810706..0b195f33f84f 100644 --- a/drivers/video/pxafb.c +++ b/drivers/video/pxafb.c | |||
| @@ -803,7 +803,7 @@ static void pxafb_enable_controller(struct pxafb_info *fbi) | |||
| 803 | pr_debug("reg_lccr3 0x%08x\n", (unsigned int) fbi->reg_lccr3); | 803 | pr_debug("reg_lccr3 0x%08x\n", (unsigned int) fbi->reg_lccr3); | 
| 804 | 804 | ||
| 805 | /* enable LCD controller clock */ | 805 | /* enable LCD controller clock */ | 
| 806 | pxa_set_cken(CKEN16_LCD, 1); | 806 | pxa_set_cken(CKEN_LCD, 1); | 
| 807 | 807 | ||
| 808 | /* Sequence from 11.7.10 */ | 808 | /* Sequence from 11.7.10 */ | 
| 809 | LCCR3 = fbi->reg_lccr3; | 809 | LCCR3 = fbi->reg_lccr3; | 
| @@ -840,7 +840,7 @@ static void pxafb_disable_controller(struct pxafb_info *fbi) | |||
| 840 | remove_wait_queue(&fbi->ctrlr_wait, &wait); | 840 | remove_wait_queue(&fbi->ctrlr_wait, &wait); | 
| 841 | 841 | ||
| 842 | /* disable LCD controller clock */ | 842 | /* disable LCD controller clock */ | 
| 843 | pxa_set_cken(CKEN16_LCD, 0); | 843 | pxa_set_cken(CKEN_LCD, 0); | 
| 844 | } | 844 | } | 
| 845 | 845 | ||
| 846 | /* | 846 | /* | 
| diff --git a/include/asm-arm/arch-at91/at91_adc.h b/include/asm-arm/arch-at91/at91_adc.h new file mode 100644 index 000000000000..1ed66eaaf83a --- /dev/null +++ b/include/asm-arm/arch-at91/at91_adc.h | |||
| @@ -0,0 +1,61 @@ | |||
| 1 | /* | ||
| 2 | * include/asm-arm/arch-at91/at91_adc.h | ||
| 3 | * | ||
| 4 | * Copyright (C) SAN People | ||
| 5 | * | ||
| 6 | * Analog-to-Digital Converter (ADC) registers. | ||
| 7 | * Based on AT91SAM9260 datasheet revision D. | ||
| 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 | |||
| 15 | #ifndef AT91_ADC_H | ||
| 16 | #define AT91_ADC_H | ||
| 17 | |||
| 18 | #define AT91_ADC_CR 0x00 /* Control Register */ | ||
| 19 | #define AT91_ADC_SWRST (1 << 0) /* Software Reset */ | ||
| 20 | #define AT91_ADC_START (1 << 1) /* Start Conversion */ | ||
| 21 | |||
| 22 | #define AT91_ADC_MR 0x04 /* Mode Register */ | ||
| 23 | #define AT91_ADC_TRGEN (1 << 0) /* Trigger Enable */ | ||
| 24 | #define AT91_ADC_TRGSEL (7 << 1) /* Trigger Selection */ | ||
| 25 | #define AT91_ADC_TRGSEL_TC0 (0 << 1) | ||
| 26 | #define AT91_ADC_TRGSEL_TC1 (1 << 1) | ||
| 27 | #define AT91_ADC_TRGSEL_TC2 (2 << 1) | ||
| 28 | #define AT91_ADC_TRGSEL_EXTERNAL (6 << 1) | ||
| 29 | #define AT91_ADC_LOWRES (1 << 4) /* Low Resolution */ | ||
| 30 | #define AT91_ADC_SLEEP (1 << 5) /* Sleep Mode */ | ||
| 31 | #define AT91_ADC_PRESCAL (0x3f << 8) /* Prescalar Rate Selection */ | ||
| 32 | #define AT91_ADC_PRESCAL_(x) ((x) << 8) | ||
| 33 | #define AT91_ADC_STARTUP (0x1f << 16) /* Startup Up Time */ | ||
| 34 | #define AT91_ADC_STARTUP_(x) ((x) << 16) | ||
| 35 | #define AT91_ADC_SHTIM (0xf << 24) /* Sample & Hold Time */ | ||
| 36 | #define AT91_ADC_SHTIM_(x) ((x) << 24) | ||
| 37 | |||
| 38 | #define AT91_ADC_CHER 0x10 /* Channel Enable Register */ | ||
| 39 | #define AT91_ADC_CHDR 0x14 /* Channel Disable Register */ | ||
| 40 | #define AT91_ADC_CHSR 0x18 /* Channel Status Register */ | ||
| 41 | #define AT91_ADC_CH(n) (1 << (n)) /* Channel Number */ | ||
| 42 | |||
| 43 | #define AT91_ADC_SR 0x1C /* Status Register */ | ||
| 44 | #define AT91_ADC_EOC(n) (1 << (n)) /* End of Conversion on Channel N */ | ||
| 45 | #define AT91_ADC_OVRE(n) (1 << ((n) + 8))/* Overrun Error on Channel N */ | ||
| 46 | #define AT91_ADC_DRDY (1 << 16) /* Data Ready */ | ||
| 47 | #define AT91_ADC_GOVRE (1 << 17) /* General Overrun Error */ | ||
| 48 | #define AT91_ADC_ENDRX (1 << 18) /* End of RX Buffer */ | ||
| 49 | #define AT91_ADC_RXFUFF (1 << 19) /* RX Buffer Full */ | ||
| 50 | |||
| 51 | #define AT91_ADC_LCDR 0x20 /* Last Converted Data Register */ | ||
| 52 | #define AT91_ADC_LDATA (0x3ff) | ||
| 53 | |||
| 54 | #define AT91_ADC_IER 0x24 /* Interrupt Enable Register */ | ||
| 55 | #define AT91_ADC_IDR 0x28 /* Interrupt Disable Register */ | ||
| 56 | #define AT91_ADC_IMR 0x2C /* Interrupt Mask Register */ | ||
| 57 | |||
| 58 | #define AT91_ADC_CHR(n) (0x30 + ((n) * 4) /* Channel Data Register N */ | ||
| 59 | #define AT91_ADC_DATA (0x3ff) | ||
| 60 | |||
| 61 | #endif | ||
| diff --git a/include/asm-arm/arch-at91/board.h b/include/asm-arm/arch-at91/board.h index 7b9903c2c447..7a34a5b1fed0 100644 --- a/include/asm-arm/arch-at91/board.h +++ b/include/asm-arm/arch-at91/board.h | |||
| @@ -62,7 +62,7 @@ struct at91_mmc_data { | |||
| 62 | }; | 62 | }; | 
| 63 | extern void __init at91_add_device_mmc(short mmc_id, struct at91_mmc_data *data); | 63 | extern void __init at91_add_device_mmc(short mmc_id, struct at91_mmc_data *data); | 
| 64 | 64 | ||
| 65 | /* Ethernet */ | 65 | /* Ethernet (EMAC & MACB) */ | 
| 66 | struct at91_eth_data { | 66 | struct at91_eth_data { | 
| 67 | u8 phy_irq_pin; /* PHY IRQ */ | 67 | u8 phy_irq_pin; /* PHY IRQ */ | 
| 68 | u8 is_rmii; /* using RMII interface? */ | 68 | u8 is_rmii; /* using RMII interface? */ | 
| @@ -114,6 +114,16 @@ struct atmel_uart_data { | |||
| 114 | }; | 114 | }; | 
| 115 | extern void __init at91_add_device_serial(void); | 115 | extern void __init at91_add_device_serial(void); | 
| 116 | 116 | ||
| 117 | /* LCD Controller */ | ||
| 118 | struct atmel_lcdfb_info; | ||
| 119 | extern void __init at91_add_device_lcdc(struct atmel_lcdfb_info *data); | ||
| 120 | |||
| 121 | /* AC97 */ | ||
| 122 | struct atmel_ac97_data { | ||
| 123 | u8 reset_pin; /* reset */ | ||
| 124 | } | ||
| 125 | extern void __init at91_add_device_ac97(struct atmel_ac97_data *data); | ||
| 126 | |||
| 117 | /* LEDs */ | 127 | /* LEDs */ | 
| 118 | extern u8 at91_leds_cpu; | 128 | extern u8 at91_leds_cpu; | 
| 119 | extern u8 at91_leds_timer; | 129 | extern u8 at91_leds_timer; | 
| diff --git a/include/asm-arm/arch-imx/imx-regs.h b/include/asm-arm/arch-imx/imx-regs.h index e56a4e247d62..de6494a4dc6b 100644 --- a/include/asm-arm/arch-imx/imx-regs.h +++ b/include/asm-arm/arch-imx/imx-regs.h | |||
| @@ -477,122 +477,4 @@ | |||
| 477 | #define LCDISR_EOF (1<<1) | 477 | #define LCDISR_EOF (1<<1) | 
| 478 | #define LCDISR_BOF (1<<0) | 478 | #define LCDISR_BOF (1<<0) | 
| 479 | 479 | ||
| 480 | /* | ||
| 481 | * UART Module. Takes the UART base address as argument | ||
| 482 | */ | ||
| 483 | #define URXD0(x) __REG( 0x0 + (x)) /* Receiver Register */ | ||
| 484 | #define URTX0(x) __REG( 0x40 + (x)) /* Transmitter Register */ | ||
| 485 | #define UCR1(x) __REG( 0x80 + (x)) /* Control Register 1 */ | ||
| 486 | #define UCR2(x) __REG( 0x84 + (x)) /* Control Register 2 */ | ||
| 487 | #define UCR3(x) __REG( 0x88 + (x)) /* Control Register 3 */ | ||
| 488 | #define UCR4(x) __REG( 0x8c + (x)) /* Control Register 4 */ | ||
| 489 | #define UFCR(x) __REG( 0x90 + (x)) /* FIFO Control Register */ | ||
| 490 | #define USR1(x) __REG( 0x94 + (x)) /* Status Register 1 */ | ||
| 491 | #define USR2(x) __REG( 0x98 + (x)) /* Status Register 2 */ | ||
| 492 | #define UESC(x) __REG( 0x9c + (x)) /* Escape Character Register */ | ||
| 493 | #define UTIM(x) __REG( 0xa0 + (x)) /* Escape Timer Register */ | ||
| 494 | #define UBIR(x) __REG( 0xa4 + (x)) /* BRM Incremental Register */ | ||
| 495 | #define UBMR(x) __REG( 0xa8 + (x)) /* BRM Modulator Register */ | ||
| 496 | #define UBRC(x) __REG( 0xac + (x)) /* Baud Rate Count Register */ | ||
| 497 | #define BIPR1(x) __REG( 0xb0 + (x)) /* Incremental Preset Register 1 */ | ||
| 498 | #define BIPR2(x) __REG( 0xb4 + (x)) /* Incremental Preset Register 2 */ | ||
| 499 | #define BIPR3(x) __REG( 0xb8 + (x)) /* Incremental Preset Register 3 */ | ||
| 500 | #define BIPR4(x) __REG( 0xbc + (x)) /* Incremental Preset Register 4 */ | ||
| 501 | #define BMPR1(x) __REG( 0xc0 + (x)) /* BRM Modulator Register 1 */ | ||
| 502 | #define BMPR2(x) __REG( 0xc4 + (x)) /* BRM Modulator Register 2 */ | ||
| 503 | #define BMPR3(x) __REG( 0xc8 + (x)) /* BRM Modulator Register 3 */ | ||
| 504 | #define BMPR4(x) __REG( 0xcc + (x)) /* BRM Modulator Register 4 */ | ||
| 505 | #define UTS(x) __REG( 0xd0 + (x)) /* UART Test Register */ | ||
| 506 | |||
| 507 | /* UART Control Register Bit Fields.*/ | ||
| 508 | #define URXD_CHARRDY (1<<15) | ||
| 509 | #define URXD_ERR (1<<14) | ||
| 510 | #define URXD_OVRRUN (1<<13) | ||
| 511 | #define URXD_FRMERR (1<<12) | ||
| 512 | #define URXD_BRK (1<<11) | ||
| 513 | #define URXD_PRERR (1<<10) | ||
| 514 | #define UCR1_ADEN (1<<15) /* Auto dectect interrupt */ | ||
| 515 | #define UCR1_ADBR (1<<14) /* Auto detect baud rate */ | ||
| 516 | #define UCR1_TRDYEN (1<<13) /* Transmitter ready interrupt enable */ | ||
| 517 | #define UCR1_IDEN (1<<12) /* Idle condition interrupt */ | ||
| 518 | #define UCR1_RRDYEN (1<<9) /* Recv ready interrupt enable */ | ||
| 519 | #define UCR1_RDMAEN (1<<8) /* Recv ready DMA enable */ | ||
| 520 | #define UCR1_IREN (1<<7) /* Infrared interface enable */ | ||
| 521 | #define UCR1_TXMPTYEN (1<<6) /* Transimitter empty interrupt enable */ | ||
| 522 | #define UCR1_RTSDEN (1<<5) /* RTS delta interrupt enable */ | ||
| 523 | #define UCR1_SNDBRK (1<<4) /* Send break */ | ||
| 524 | #define UCR1_TDMAEN (1<<3) /* Transmitter ready DMA enable */ | ||
| 525 | #define UCR1_UARTCLKEN (1<<2) /* UART clock enabled */ | ||
| 526 | #define UCR1_DOZE (1<<1) /* Doze */ | ||
| 527 | #define UCR1_UARTEN (1<<0) /* UART enabled */ | ||
| 528 | #define UCR2_ESCI (1<<15) /* Escape seq interrupt enable */ | ||
| 529 | #define UCR2_IRTS (1<<14) /* Ignore RTS pin */ | ||
| 530 | #define UCR2_CTSC (1<<13) /* CTS pin control */ | ||
| 531 | #define UCR2_CTS (1<<12) /* Clear to send */ | ||
| 532 | #define UCR2_ESCEN (1<<11) /* Escape enable */ | ||
| 533 | #define UCR2_PREN (1<<8) /* Parity enable */ | ||
| 534 | #define UCR2_PROE (1<<7) /* Parity odd/even */ | ||
| 535 | #define UCR2_STPB (1<<6) /* Stop */ | ||
| 536 | #define UCR2_WS (1<<5) /* Word size */ | ||
| 537 | #define UCR2_RTSEN (1<<4) /* Request to send interrupt enable */ | ||
| 538 | #define UCR2_TXEN (1<<2) /* Transmitter enabled */ | ||
| 539 | #define UCR2_RXEN (1<<1) /* Receiver enabled */ | ||
| 540 | #define UCR2_SRST (1<<0) /* SW reset */ | ||
| 541 | #define UCR3_DTREN (1<<13) /* DTR interrupt enable */ | ||
| 542 | #define UCR3_PARERREN (1<<12) /* Parity enable */ | ||
| 543 | #define UCR3_FRAERREN (1<<11) /* Frame error interrupt enable */ | ||
| 544 | #define UCR3_DSR (1<<10) /* Data set ready */ | ||
| 545 | #define UCR3_DCD (1<<9) /* Data carrier detect */ | ||
| 546 | #define UCR3_RI (1<<8) /* Ring indicator */ | ||
| 547 | #define UCR3_TIMEOUTEN (1<<7) /* Timeout interrupt enable */ | ||
| 548 | #define UCR3_RXDSEN (1<<6) /* Receive status interrupt enable */ | ||
| 549 | #define UCR3_AIRINTEN (1<<5) /* Async IR wake interrupt enable */ | ||
| 550 | #define UCR3_AWAKEN (1<<4) /* Async wake interrupt enable */ | ||
| 551 | #define UCR3_REF25 (1<<3) /* Ref freq 25 MHz */ | ||
| 552 | #define UCR3_REF30 (1<<2) /* Ref Freq 30 MHz */ | ||
| 553 | #define UCR3_INVT (1<<1) /* Inverted Infrared transmission */ | ||
| 554 | #define UCR3_BPEN (1<<0) /* Preset registers enable */ | ||
| 555 | #define UCR4_CTSTL_32 (32<<10) /* CTS trigger level (32 chars) */ | ||
| 556 | #define UCR4_INVR (1<<9) /* Inverted infrared reception */ | ||
| 557 | #define UCR4_ENIRI (1<<8) /* Serial infrared interrupt enable */ | ||
| 558 | #define UCR4_WKEN (1<<7) /* Wake interrupt enable */ | ||
| 559 | #define UCR4_REF16 (1<<6) /* Ref freq 16 MHz */ | ||
| 560 | #define UCR4_IRSC (1<<5) /* IR special case */ | ||
| 561 | #define UCR4_TCEN (1<<3) /* Transmit complete interrupt enable */ | ||
| 562 | #define UCR4_BKEN (1<<2) /* Break condition interrupt enable */ | ||
| 563 | #define UCR4_OREN (1<<1) /* Receiver overrun interrupt enable */ | ||
| 564 | #define UCR4_DREN (1<<0) /* Recv data ready interrupt enable */ | ||
| 565 | #define UFCR_RXTL_SHF 0 /* Receiver trigger level shift */ | ||
| 566 | #define UFCR_RFDIV (7<<7) /* Reference freq divider mask */ | ||
| 567 | #define UFCR_TXTL_SHF 10 /* Transmitter trigger level shift */ | ||
| 568 | #define USR1_PARITYERR (1<<15) /* Parity error interrupt flag */ | ||
| 569 | #define USR1_RTSS (1<<14) /* RTS pin status */ | ||
| 570 | #define USR1_TRDY (1<<13) /* Transmitter ready interrupt/dma flag */ | ||
| 571 | #define USR1_RTSD (1<<12) /* RTS delta */ | ||
| 572 | #define USR1_ESCF (1<<11) /* Escape seq interrupt flag */ | ||
| 573 | #define USR1_FRAMERR (1<<10) /* Frame error interrupt flag */ | ||
| 574 | #define USR1_RRDY (1<<9) /* Receiver ready interrupt/dma flag */ | ||
| 575 | #define USR1_TIMEOUT (1<<7) /* Receive timeout interrupt status */ | ||
| 576 | #define USR1_RXDS (1<<6) /* Receiver idle interrupt flag */ | ||
| 577 | #define USR1_AIRINT (1<<5) /* Async IR wake interrupt flag */ | ||
| 578 | #define USR1_AWAKE (1<<4) /* Aysnc wake interrupt flag */ | ||
| 579 | #define USR2_ADET (1<<15) /* Auto baud rate detect complete */ | ||
| 580 | #define USR2_TXFE (1<<14) /* Transmit buffer FIFO empty */ | ||
| 581 | #define USR2_DTRF (1<<13) /* DTR edge interrupt flag */ | ||
| 582 | #define USR2_IDLE (1<<12) /* Idle condition */ | ||
| 583 | #define USR2_IRINT (1<<8) /* Serial infrared interrupt flag */ | ||
| 584 | #define USR2_WAKE (1<<7) /* Wake */ | ||
| 585 | #define USR2_RTSF (1<<4) /* RTS edge interrupt flag */ | ||
| 586 | #define USR2_TXDC (1<<3) /* Transmitter complete */ | ||
| 587 | #define USR2_BRCD (1<<2) /* Break condition */ | ||
| 588 | #define USR2_ORE (1<<1) /* Overrun error */ | ||
| 589 | #define USR2_RDR (1<<0) /* Recv data ready */ | ||
| 590 | #define UTS_FRCPERR (1<<13) /* Force parity error */ | ||
| 591 | #define UTS_LOOP (1<<12) /* Loop tx and rx */ | ||
| 592 | #define UTS_TXEMPTY (1<<6) /* TxFIFO empty */ | ||
| 593 | #define UTS_RXEMPTY (1<<5) /* RxFIFO empty */ | ||
| 594 | #define UTS_TXFULL (1<<4) /* TxFIFO full */ | ||
| 595 | #define UTS_RXFULL (1<<3) /* RxFIFO full */ | ||
| 596 | #define UTS_SOFTRST (1<<0) /* Software reset */ | ||
| 597 | |||
| 598 | #endif // _IMX_REGS_H | 480 | #endif // _IMX_REGS_H | 
| diff --git a/include/asm-arm/arch-iop13xx/iop13xx.h b/include/asm-arm/arch-iop13xx/iop13xx.h index d26b755a9879..85707e9c3325 100644 --- a/include/asm-arm/arch-iop13xx/iop13xx.h +++ b/include/asm-arm/arch-iop13xx/iop13xx.h | |||
| @@ -8,6 +8,7 @@ extern u32 iop13xx_atue_pmmr_offset; | |||
| 8 | void iop13xx_init_irq(void); | 8 | void iop13xx_init_irq(void); | 
| 9 | void iop13xx_map_io(void); | 9 | void iop13xx_map_io(void); | 
| 10 | void iop13xx_platform_init(void); | 10 | void iop13xx_platform_init(void); | 
| 11 | void iop13xx_add_tpmi_devices(void); | ||
| 11 | void iop13xx_init_irq(void); | 12 | void iop13xx_init_irq(void); | 
| 12 | 13 | ||
| 13 | /* CPUID CP6 R0 Page 0 */ | 14 | /* CPUID CP6 R0 Page 0 */ | 
| @@ -27,19 +28,24 @@ static inline int iop13xx_cpu_id(void) | |||
| 27 | #define IOP13XX_PCI_OFFSET IOP13XX_MAX_RAM_SIZE | 28 | #define IOP13XX_PCI_OFFSET IOP13XX_MAX_RAM_SIZE | 
| 28 | 29 | ||
| 29 | /* PCI MAP | 30 | /* PCI MAP | 
| 30 | * 0x0000.0000 - 0x8000.0000 1:1 mapping with Physical RAM | 31 | * bus range cpu phys cpu virt note | 
| 31 | * 0x8000.0000 - 0x8800.0000 PCIX/PCIE memory window (128MB) | 32 | * 0x0000.0000 + 2GB (n/a) (n/a) inbound, 1:1 mapping with Physical RAM | 
| 32 | */ | 33 | * 0x8000.0000 + 928M 0x1.8000.0000 (ioremap) PCIX outbound memory window | 
| 34 | * 0x8000.0000 + 928M 0x2.8000.0000 (ioremap) PCIE outbound memory window | ||
| 35 | * | ||
| 36 | * IO MAP | ||
| 37 | * 0x1000 + 64K 0x0.fffb.1000 0xfec6.1000 PCIX outbound i/o window | ||
| 38 | * 0x1000 + 64K 0x0.fffd.1000 0xfed7.1000 PCIE outbound i/o window | ||
| 39 | */ | ||
| 33 | #define IOP13XX_PCIX_IO_WINDOW_SIZE 0x10000UL | 40 | #define IOP13XX_PCIX_IO_WINDOW_SIZE 0x10000UL | 
| 34 | #define IOP13XX_PCIX_LOWER_IO_PA 0xfffb0000UL | 41 | #define IOP13XX_PCIX_LOWER_IO_PA 0xfffb0000UL | 
| 35 | #define IOP13XX_PCIX_LOWER_IO_VA 0xfec60000UL | 42 | #define IOP13XX_PCIX_LOWER_IO_VA 0xfec60000UL | 
| 36 | #define IOP13XX_PCIX_LOWER_IO_BA 0x0fff0000UL | 43 | #define IOP13XX_PCIX_LOWER_IO_BA 0x0UL /* OIOTVR */ | 
| 44 | #define IOP13XX_PCIX_IO_BUS_OFFSET 0x1000UL | ||
| 37 | #define IOP13XX_PCIX_UPPER_IO_PA (IOP13XX_PCIX_LOWER_IO_PA +\ | 45 | #define IOP13XX_PCIX_UPPER_IO_PA (IOP13XX_PCIX_LOWER_IO_PA +\ | 
| 38 | IOP13XX_PCIX_IO_WINDOW_SIZE - 1) | 46 | IOP13XX_PCIX_IO_WINDOW_SIZE - 1) | 
| 39 | #define IOP13XX_PCIX_UPPER_IO_VA (IOP13XX_PCIX_LOWER_IO_VA +\ | 47 | #define IOP13XX_PCIX_UPPER_IO_VA (IOP13XX_PCIX_LOWER_IO_VA +\ | 
| 40 | IOP13XX_PCIX_IO_WINDOW_SIZE - 1) | 48 | IOP13XX_PCIX_IO_WINDOW_SIZE - 1) | 
| 41 | #define IOP13XX_PCIX_IO_OFFSET (IOP13XX_PCIX_LOWER_IO_VA -\ | ||
| 42 | IOP13XX_PCIX_LOWER_IO_BA) | ||
| 43 | #define IOP13XX_PCIX_IO_PHYS_TO_VIRT(addr) (u32) ((u32) addr -\ | 49 | #define IOP13XX_PCIX_IO_PHYS_TO_VIRT(addr) (u32) ((u32) addr -\ | 
| 44 | (IOP13XX_PCIX_LOWER_IO_PA\ | 50 | (IOP13XX_PCIX_LOWER_IO_PA\ | 
| 45 | - IOP13XX_PCIX_LOWER_IO_VA)) | 51 | - IOP13XX_PCIX_LOWER_IO_VA)) | 
| @@ -65,15 +71,14 @@ static inline int iop13xx_cpu_id(void) | |||
| 65 | #define IOP13XX_PCIE_IO_WINDOW_SIZE 0x10000UL | 71 | #define IOP13XX_PCIE_IO_WINDOW_SIZE 0x10000UL | 
| 66 | #define IOP13XX_PCIE_LOWER_IO_PA 0xfffd0000UL | 72 | #define IOP13XX_PCIE_LOWER_IO_PA 0xfffd0000UL | 
| 67 | #define IOP13XX_PCIE_LOWER_IO_VA 0xfed70000UL | 73 | #define IOP13XX_PCIE_LOWER_IO_VA 0xfed70000UL | 
| 68 | #define IOP13XX_PCIE_LOWER_IO_BA 0x0fff0000UL | 74 | #define IOP13XX_PCIE_LOWER_IO_BA 0x0UL /* OIOTVR */ | 
| 75 | #define IOP13XX_PCIE_IO_BUS_OFFSET 0x1000UL | ||
| 69 | #define IOP13XX_PCIE_UPPER_IO_PA (IOP13XX_PCIE_LOWER_IO_PA +\ | 76 | #define IOP13XX_PCIE_UPPER_IO_PA (IOP13XX_PCIE_LOWER_IO_PA +\ | 
| 70 | IOP13XX_PCIE_IO_WINDOW_SIZE - 1) | 77 | IOP13XX_PCIE_IO_WINDOW_SIZE - 1) | 
| 71 | #define IOP13XX_PCIE_UPPER_IO_VA (IOP13XX_PCIE_LOWER_IO_VA +\ | 78 | #define IOP13XX_PCIE_UPPER_IO_VA (IOP13XX_PCIE_LOWER_IO_VA +\ | 
| 72 | IOP13XX_PCIE_IO_WINDOW_SIZE - 1) | 79 | IOP13XX_PCIE_IO_WINDOW_SIZE - 1) | 
| 73 | #define IOP13XX_PCIE_UPPER_IO_BA (IOP13XX_PCIE_LOWER_IO_BA +\ | 80 | #define IOP13XX_PCIE_UPPER_IO_BA (IOP13XX_PCIE_LOWER_IO_BA +\ | 
| 74 | IOP13XX_PCIE_IO_WINDOW_SIZE - 1) | 81 | IOP13XX_PCIE_IO_WINDOW_SIZE - 1) | 
| 75 | #define IOP13XX_PCIE_IO_OFFSET (IOP13XX_PCIE_LOWER_IO_VA -\ | ||
| 76 | IOP13XX_PCIE_LOWER_IO_BA) | ||
| 77 | #define IOP13XX_PCIE_IO_PHYS_TO_VIRT(addr) (u32) ((u32) addr -\ | 82 | #define IOP13XX_PCIE_IO_PHYS_TO_VIRT(addr) (u32) ((u32) addr -\ | 
| 78 | (IOP13XX_PCIE_LOWER_IO_PA\ | 83 | (IOP13XX_PCIE_LOWER_IO_PA\ | 
| 79 | - IOP13XX_PCIE_LOWER_IO_VA)) | 84 | - IOP13XX_PCIE_LOWER_IO_VA)) | 
| @@ -451,4 +456,5 @@ static inline int iop13xx_cpu_id(void) | |||
| 451 | #define IOP13XX_PBI_BAR1 IOP13XX_PBI_OFFSET(0x10) | 456 | #define IOP13XX_PBI_BAR1 IOP13XX_PBI_OFFSET(0x10) | 
| 452 | #define IOP13XX_PBI_LR1 IOP13XX_PBI_OFFSET(0x14) | 457 | #define IOP13XX_PBI_LR1 IOP13XX_PBI_OFFSET(0x14) | 
| 453 | 458 | ||
| 459 | #define IOP13XX_PROCESSOR_FREQ IOP13XX_REG_ADDR32(0x2180) | ||
| 454 | #endif /* _IOP13XX_HW_H_ */ | 460 | #endif /* _IOP13XX_HW_H_ */ | 
| diff --git a/include/asm-arm/arch-iop13xx/time.h b/include/asm-arm/arch-iop13xx/time.h index 77a837a02dec..49213d9d7cad 100644 --- a/include/asm-arm/arch-iop13xx/time.h +++ b/include/asm-arm/arch-iop13xx/time.h | |||
| @@ -7,9 +7,65 @@ | |||
| 7 | #define IOP_TMR_PRIVILEGED 0x08 | 7 | #define IOP_TMR_PRIVILEGED 0x08 | 
| 8 | #define IOP_TMR_RATIO_1_1 0x00 | 8 | #define IOP_TMR_RATIO_1_1 0x00 | 
| 9 | 9 | ||
| 10 | #define IOP13XX_XSI_FREQ_RATIO_MASK (3 << 19) | ||
| 11 | #define IOP13XX_XSI_FREQ_RATIO_2 (0 << 19) | ||
| 12 | #define IOP13XX_XSI_FREQ_RATIO_3 (1 << 19) | ||
| 13 | #define IOP13XX_XSI_FREQ_RATIO_4 (2 << 19) | ||
| 14 | #define IOP13XX_CORE_FREQ_MASK (7 << 16) | ||
| 15 | #define IOP13XX_CORE_FREQ_600 (0 << 16) | ||
| 16 | #define IOP13XX_CORE_FREQ_667 (1 << 16) | ||
| 17 | #define IOP13XX_CORE_FREQ_800 (2 << 16) | ||
| 18 | #define IOP13XX_CORE_FREQ_933 (3 << 16) | ||
| 19 | #define IOP13XX_CORE_FREQ_1000 (4 << 16) | ||
| 20 | #define IOP13XX_CORE_FREQ_1200 (5 << 16) | ||
| 21 | |||
| 10 | void iop_init_time(unsigned long tickrate); | 22 | void iop_init_time(unsigned long tickrate); | 
| 11 | unsigned long iop_gettimeoffset(void); | 23 | unsigned long iop_gettimeoffset(void); | 
| 12 | 24 | ||
| 25 | static inline unsigned long iop13xx_core_freq(void) | ||
| 26 | { | ||
| 27 | unsigned long freq = __raw_readl(IOP13XX_PROCESSOR_FREQ); | ||
| 28 | freq &= IOP13XX_CORE_FREQ_MASK; | ||
| 29 | switch (freq) { | ||
| 30 | case IOP13XX_CORE_FREQ_600: | ||
| 31 | return 600000000; | ||
| 32 | case IOP13XX_CORE_FREQ_667: | ||
| 33 | return 667000000; | ||
| 34 | case IOP13XX_CORE_FREQ_800: | ||
| 35 | return 800000000; | ||
| 36 | case IOP13XX_CORE_FREQ_933: | ||
| 37 | return 933000000; | ||
| 38 | case IOP13XX_CORE_FREQ_1000: | ||
| 39 | return 1000000000; | ||
| 40 | case IOP13XX_CORE_FREQ_1200: | ||
| 41 | return 1200000000; | ||
| 42 | default: | ||
| 43 | printk("%s: warning unknown frequency, defaulting to 800Mhz\n", | ||
| 44 | __FUNCTION__); | ||
| 45 | } | ||
| 46 | |||
| 47 | return 800000000; | ||
| 48 | } | ||
| 49 | |||
| 50 | static inline unsigned long iop13xx_xsi_bus_ratio(void) | ||
| 51 | { | ||
| 52 | unsigned long ratio = __raw_readl(IOP13XX_PROCESSOR_FREQ); | ||
| 53 | ratio &= IOP13XX_XSI_FREQ_RATIO_MASK; | ||
| 54 | switch (ratio) { | ||
| 55 | case IOP13XX_XSI_FREQ_RATIO_2: | ||
| 56 | return 2; | ||
| 57 | case IOP13XX_XSI_FREQ_RATIO_3: | ||
| 58 | return 3; | ||
| 59 | case IOP13XX_XSI_FREQ_RATIO_4: | ||
| 60 | return 4; | ||
| 61 | default: | ||
| 62 | printk("%s: warning unknown ratio, defaulting to 2\n", | ||
| 63 | __FUNCTION__); | ||
| 64 | } | ||
| 65 | |||
| 66 | return 2; | ||
| 67 | } | ||
| 68 | |||
| 13 | static inline void write_tmr0(u32 val) | 69 | static inline void write_tmr0(u32 val) | 
| 14 | { | 70 | { | 
| 15 | asm volatile("mcr p6, 0, %0, c0, c9, 0" : : "r" (val)); | 71 | asm volatile("mcr p6, 0, %0, c0, c9, 0" : : "r" (val)); | 
| diff --git a/include/asm-arm/arch-iop32x/iop32x.h b/include/asm-arm/arch-iop32x/iop32x.h index 2e9469047eb1..0d8af57221a1 100644 --- a/include/asm-arm/arch-iop32x/iop32x.h +++ b/include/asm-arm/arch-iop32x/iop32x.h | |||
| @@ -24,5 +24,14 @@ | |||
| 24 | 24 | ||
| 25 | #include <asm/hardware/iop3xx.h> | 25 | #include <asm/hardware/iop3xx.h> | 
| 26 | 26 | ||
| 27 | /* ATU Parameters | ||
| 28 | * set up a 1:1 bus to physical ram relationship | ||
| 29 | * w/ physical ram on top of pci in the memory map | ||
| 30 | */ | ||
| 31 | #define IOP32X_MAX_RAM_SIZE 0x40000000UL | ||
| 32 | #define IOP3XX_MAX_RAM_SIZE IOP32X_MAX_RAM_SIZE | ||
| 33 | #define IOP3XX_PCI_LOWER_MEM_BA 0x80000000 | ||
| 34 | #define IOP32X_PCI_MEM_WINDOW_SIZE 0x04000000 | ||
| 35 | #define IOP3XX_PCI_MEM_WINDOW_SIZE IOP32X_PCI_MEM_WINDOW_SIZE | ||
| 27 | 36 | ||
| 28 | #endif | 37 | #endif | 
| diff --git a/include/asm-arm/arch-iop32x/memory.h b/include/asm-arm/arch-iop32x/memory.h index 764cd3f0d416..c51072af214e 100644 --- a/include/asm-arm/arch-iop32x/memory.h +++ b/include/asm-arm/arch-iop32x/memory.h | |||
| @@ -19,8 +19,8 @@ | |||
| 19 | * bus_to_virt: Used to convert an address for DMA operations | 19 | * bus_to_virt: Used to convert an address for DMA operations | 
| 20 | * to an address that the kernel can use. | 20 | * to an address that the kernel can use. | 
| 21 | */ | 21 | */ | 
| 22 | #define __virt_to_bus(x) (((__virt_to_phys(x)) & ~(*IOP3XX_IATVR2)) | ((*IOP3XX_IABAR2) & 0xfffffff0)) | 22 | #define __virt_to_bus(x) (__virt_to_phys(x)) | 
| 23 | #define __bus_to_virt(x) (__phys_to_virt(((x) & ~(*IOP3XX_IALR2)) | ( *IOP3XX_IATVR2))) | 23 | #define __bus_to_virt(x) (__phys_to_virt(x)) | 
| 24 | 24 | ||
| 25 | 25 | ||
| 26 | #endif | 26 | #endif | 
| diff --git a/include/asm-arm/arch-iop33x/iop33x.h b/include/asm-arm/arch-iop33x/iop33x.h index 7ac6e93db5ff..766985b9a723 100644 --- a/include/asm-arm/arch-iop33x/iop33x.h +++ b/include/asm-arm/arch-iop33x/iop33x.h | |||
| @@ -29,5 +29,15 @@ | |||
| 29 | #define IOP33X_UART1_PHYS (IOP3XX_PERIPHERAL_PHYS_BASE + 0x1740) | 29 | #define IOP33X_UART1_PHYS (IOP3XX_PERIPHERAL_PHYS_BASE + 0x1740) | 
| 30 | #define IOP33X_UART1_VIRT (IOP3XX_PERIPHERAL_VIRT_BASE + 0x1740) | 30 | #define IOP33X_UART1_VIRT (IOP3XX_PERIPHERAL_VIRT_BASE + 0x1740) | 
| 31 | 31 | ||
| 32 | /* ATU Parameters | ||
| 33 | * set up a 1:1 bus to physical ram relationship | ||
| 34 | * w/ pci on top of physical ram in memory map | ||
| 35 | */ | ||
| 36 | #define IOP33X_MAX_RAM_SIZE 0x80000000UL | ||
| 37 | #define IOP3XX_MAX_RAM_SIZE IOP33X_MAX_RAM_SIZE | ||
| 38 | #define IOP3XX_PCI_LOWER_MEM_BA (PHYS_OFFSET + IOP33X_MAX_RAM_SIZE) | ||
| 39 | #define IOP33X_PCI_MEM_WINDOW_SIZE 0x08000000 | ||
| 40 | #define IOP3XX_PCI_MEM_WINDOW_SIZE IOP33X_PCI_MEM_WINDOW_SIZE | ||
| 41 | |||
| 32 | 42 | ||
| 33 | #endif | 43 | #endif | 
| diff --git a/include/asm-arm/arch-iop33x/memory.h b/include/asm-arm/arch-iop33x/memory.h index 0d39139b241e..c8749127d6ab 100644 --- a/include/asm-arm/arch-iop33x/memory.h +++ b/include/asm-arm/arch-iop33x/memory.h | |||
| @@ -19,8 +19,8 @@ | |||
| 19 | * bus_to_virt: Used to convert an address for DMA operations | 19 | * bus_to_virt: Used to convert an address for DMA operations | 
| 20 | * to an address that the kernel can use. | 20 | * to an address that the kernel can use. | 
| 21 | */ | 21 | */ | 
| 22 | #define __virt_to_bus(x) (((__virt_to_phys(x)) & ~(*IOP3XX_IATVR2)) | ((*IOP3XX_IABAR2) & 0xfffffff0)) | 22 | #define __virt_to_bus(x) (__virt_to_phys(x)) | 
| 23 | #define __bus_to_virt(x) (__phys_to_virt(((x) & ~(*IOP3XX_IALR2)) | ( *IOP3XX_IATVR2))) | 23 | #define __bus_to_virt(x) (__phys_to_virt(x)) | 
| 24 | 24 | ||
| 25 | 25 | ||
| 26 | #endif | 26 | #endif | 
| diff --git a/include/asm-arm/arch-netx/netx-regs.h b/include/asm-arm/arch-netx/netx-regs.h index 8ab45bea83ca..fc9aa21f360c 100644 --- a/include/asm-arm/arch-netx/netx-regs.h +++ b/include/asm-arm/arch-netx/netx-regs.h | |||
| @@ -121,8 +121,8 @@ | |||
| 121 | #define NETX_SYSTEM_IOC_MR NETX_SYSTEM_REG(0x08) | 121 | #define NETX_SYSTEM_IOC_MR NETX_SYSTEM_REG(0x08) | 
| 122 | 122 | ||
| 123 | /* FIXME: Docs are not consistent */ | 123 | /* FIXME: Docs are not consistent */ | 
| 124 | #define NETX_SYSTEM_RES_CR NETX_SYSTEM_REG(0x08) | 124 | /* #define NETX_SYSTEM_RES_CR NETX_SYSTEM_REG(0x08) */ | 
| 125 | /* #define NETX_SYSTEM_RES_CR NETX_SYSTEM_REG(0x0c) */ | 125 | #define NETX_SYSTEM_RES_CR NETX_SYSTEM_REG(0x0c) | 
| 126 | 126 | ||
| 127 | #define NETX_SYSTEM_PHY_CONTROL NETX_SYSTEM_REG(0x10) | 127 | #define NETX_SYSTEM_PHY_CONTROL NETX_SYSTEM_REG(0x10) | 
| 128 | #define NETX_SYSTEM_REV NETX_SYSTEM_REG(0x34) | 128 | #define NETX_SYSTEM_REV NETX_SYSTEM_REG(0x34) | 
| diff --git a/include/asm-arm/arch-ns9xxx/board.h b/include/asm-arm/arch-ns9xxx/board.h index 91dc8fb1027f..716f34fdb716 100644 --- a/include/asm-arm/arch-ns9xxx/board.h +++ b/include/asm-arm/arch-ns9xxx/board.h | |||
| @@ -15,4 +15,6 @@ | |||
| 15 | 15 | ||
| 16 | #define board_is_a9m9750dev() (machine_is_cc9p9360dev()) | 16 | #define board_is_a9m9750dev() (machine_is_cc9p9360dev()) | 
| 17 | 17 | ||
| 18 | #define board_is_jscc9p9360() (machine_is_cc9p9360js()) | ||
| 19 | |||
| 18 | #endif /* ifndef __ASM_ARCH_BOARD_H */ | 20 | #endif /* ifndef __ASM_ARCH_BOARD_H */ | 
| diff --git a/include/asm-arm/arch-ns9xxx/clock.h b/include/asm-arm/arch-ns9xxx/clock.h index a7c5ab3d9011..bf30cbdcc2bf 100644 --- a/include/asm-arm/arch-ns9xxx/clock.h +++ b/include/asm-arm/arch-ns9xxx/clock.h | |||
| @@ -11,13 +11,43 @@ | |||
| 11 | #ifndef __ASM_ARCH_CLOCK_H | 11 | #ifndef __ASM_ARCH_CLOCK_H | 
| 12 | #define __ASM_ARCH_CLOCK_H | 12 | #define __ASM_ARCH_CLOCK_H | 
| 13 | 13 | ||
| 14 | #include <asm/arch-ns9xxx/regs-sys.h> | ||
| 15 | |||
| 16 | #define CRYSTAL 29491200 /* Hz */ | ||
| 17 | |||
| 18 | /* The HRM calls this value f_vco */ | ||
| 14 | static inline u32 ns9xxx_systemclock(void) __attribute__((const)); | 19 | static inline u32 ns9xxx_systemclock(void) __attribute__((const)); | 
| 15 | static inline u32 ns9xxx_systemclock(void) | 20 | static inline u32 ns9xxx_systemclock(void) | 
| 16 | { | 21 | { | 
| 22 | u32 pll = SYS_PLL; | ||
| 23 | |||
| 17 | /* | 24 | /* | 
| 18 | * This should be a multiple of HZ * TIMERCLOCKSELECT (in time.c) | 25 | * The system clock should be a multiple of HZ * TIMERCLOCKSELECT (in | 
| 26 | * time.c). | ||
| 27 | * | ||
| 28 | * The following values are given: | ||
| 29 | * - TIMERCLOCKSELECT == 2^i for an i in {0 .. 6} | ||
| 30 | * - CRYSTAL == 29491200 == 2^17 * 3^2 * 5^2 | ||
| 31 | * - ND in {0 .. 31} | ||
| 32 | * - FS in {0 .. 3} | ||
| 33 | * | ||
| 34 | * Assuming the worst, we consider: | ||
| 35 | * - TIMERCLOCKSELECT == 64 | ||
| 36 | * - ND == 0 | ||
| 37 | * - FS == 3 | ||
| 38 | * | ||
| 39 | * So HZ should be a divisor of: | ||
| 40 | * (CRYSTAL * (ND + 1) >> FS) / TIMERCLOCKSELECT | ||
| 41 | * == (2^17 * 3^2 * 5^2 * 1 >> 3) / 64 | ||
| 42 | * == 2^8 * 3^2 * 5^2 | ||
| 43 | * == 57600 | ||
| 44 | * | ||
| 45 | * Currently HZ is defined to be 100 for this platform. | ||
| 46 | * | ||
| 47 | * Fine. | ||
| 19 | */ | 48 | */ | 
| 20 | return 353894400; | 49 | return CRYSTAL * (REGGET(pll, SYS_PLL, ND) + 1) | 
| 50 | >> REGGET(pll, SYS_PLL, FS); | ||
| 21 | } | 51 | } | 
| 22 | 52 | ||
| 23 | static inline u32 ns9xxx_cpuclock(void) __attribute__((const)); | 53 | static inline u32 ns9xxx_cpuclock(void) __attribute__((const)); | 
| diff --git a/include/asm-arm/arch-ns9xxx/hardware.h b/include/asm-arm/arch-ns9xxx/hardware.h index 6819da7c48d4..25600554c4fe 100644 --- a/include/asm-arm/arch-ns9xxx/hardware.h +++ b/include/asm-arm/arch-ns9xxx/hardware.h | |||
| @@ -51,8 +51,9 @@ | |||
| 51 | ~(__REGVAL(reg ## _ ## field, value)))) \ | 51 | ~(__REGVAL(reg ## _ ## field, value)))) \ | 
| 52 | | (__REGVAL(reg ## _ ## field, value)))) | 52 | | (__REGVAL(reg ## _ ## field, value)))) | 
| 53 | 53 | ||
| 54 | # define REGGET(reg, field) \ | 54 | # define REGGET(var, reg, field) \ | 
| 55 | ((reg & (reg ## _ ## field)) / (field & (-field))) | 55 | ((var & (reg ## _ ## field)) / \ | 
| 56 | ((reg ## _ ## field) & (-(reg ## _ ## field)))) | ||
| 56 | 57 | ||
| 57 | #else | 58 | #else | 
| 58 | 59 | ||
| diff --git a/include/asm-arm/arch-ns9xxx/processor.h b/include/asm-arm/arch-ns9xxx/processor.h index 716c106ac0bf..223e51b8e104 100644 --- a/include/asm-arm/arch-ns9xxx/processor.h +++ b/include/asm-arm/arch-ns9xxx/processor.h | |||
| @@ -13,6 +13,7 @@ | |||
| 13 | 13 | ||
| 14 | #include <asm/mach-types.h> | 14 | #include <asm/mach-types.h> | 
| 15 | 15 | ||
| 16 | #define processor_is_ns9360() (machine_is_cc9p9360dev()) | 16 | #define processor_is_ns9360() (machine_is_cc9p9360dev() \ | 
| 17 | || machine_is_cc9p9360js()) | ||
| 17 | 18 | ||
| 18 | #endif /* ifndef __ASM_ARCH_PROCESSOR_H */ | 19 | #endif /* ifndef __ASM_ARCH_PROCESSOR_H */ | 
| diff --git a/include/asm-arm/arch-ns9xxx/regs-sys.h b/include/asm-arm/arch-ns9xxx/regs-sys.h index 8162a50bb273..a42546aeb92a 100644 --- a/include/asm-arm/arch-ns9xxx/regs-sys.h +++ b/include/asm-arm/arch-ns9xxx/regs-sys.h | |||
| @@ -48,6 +48,12 @@ | |||
| 48 | /* PLL Configuration register */ | 48 | /* PLL Configuration register */ | 
| 49 | #define SYS_PLL __REG(0xa0900188) | 49 | #define SYS_PLL __REG(0xa0900188) | 
| 50 | 50 | ||
| 51 | /* PLL FS status */ | ||
| 52 | #define SYS_PLL_FS __REGBITS(24, 23) | ||
| 53 | |||
| 54 | /* PLL ND status */ | ||
| 55 | #define SYS_PLL_ND __REGBITS(20, 16) | ||
| 56 | |||
| 51 | /* PLL Configuration register: PLL SW change */ | 57 | /* PLL Configuration register: PLL SW change */ | 
| 52 | #define SYS_PLL_SWC __REGBIT(15) | 58 | #define SYS_PLL_SWC __REGBIT(15) | 
| 53 | #define SYS_PLL_SWC_NO __REGVAL(SYS_PLL_SWC, 0) | 59 | #define SYS_PLL_SWC_NO __REGVAL(SYS_PLL_SWC, 0) | 
| diff --git a/include/asm-arm/arch-pxa/i2c.h b/include/asm-arm/arch-pxa/i2c.h index 46ec2243974a..e404b233d8a8 100644 --- a/include/asm-arm/arch-pxa/i2c.h +++ b/include/asm-arm/arch-pxa/i2c.h | |||
| @@ -64,6 +64,7 @@ struct i2c_slave_client; | |||
| 64 | struct i2c_pxa_platform_data { | 64 | struct i2c_pxa_platform_data { | 
| 65 | unsigned int slave_addr; | 65 | unsigned int slave_addr; | 
| 66 | struct i2c_slave_client *slave; | 66 | struct i2c_slave_client *slave; | 
| 67 | unsigned int class; | ||
| 67 | }; | 68 | }; | 
| 68 | 69 | ||
| 69 | extern void pxa_set_i2c_info(struct i2c_pxa_platform_data *info); | 70 | extern void pxa_set_i2c_info(struct i2c_pxa_platform_data *info); | 
| diff --git a/include/asm-arm/arch-pxa/pxa-regs.h b/include/asm-arm/arch-pxa/pxa-regs.h index 139c9d954818..dbcc9298b0c8 100644 --- a/include/asm-arm/arch-pxa/pxa-regs.h +++ b/include/asm-arm/arch-pxa/pxa-regs.h | |||
| @@ -1801,35 +1801,35 @@ | |||
| 1801 | #define CCCR_M_MASK 0x0060 /* Memory Frequency to Run Mode Frequency Multiplier */ | 1801 | #define CCCR_M_MASK 0x0060 /* Memory Frequency to Run Mode Frequency Multiplier */ | 
| 1802 | #define CCCR_L_MASK 0x001f /* Crystal Frequency to Memory Frequency Multiplier */ | 1802 | #define CCCR_L_MASK 0x001f /* Crystal Frequency to Memory Frequency Multiplier */ | 
| 1803 | 1803 | ||
| 1804 | #define CKEN24_CAMERA (1 << 24) /* Camera Interface Clock Enable */ | 1804 | #define CKEN_CAMERA (24) /* Camera Interface Clock Enable */ | 
| 1805 | #define CKEN23_SSP1 (1 << 23) /* SSP1 Unit Clock Enable */ | 1805 | #define CKEN_SSP1 (23) /* SSP1 Unit Clock Enable */ | 
| 1806 | #define CKEN22_MEMC (1 << 22) /* Memory Controller Clock Enable */ | 1806 | #define CKEN_MEMC (22) /* Memory Controller Clock Enable */ | 
| 1807 | #define CKEN21_MEMSTK (1 << 21) /* Memory Stick Host Controller */ | 1807 | #define CKEN_MEMSTK (21) /* Memory Stick Host Controller */ | 
| 1808 | #define CKEN20_IM (1 << 20) /* Internal Memory Clock Enable */ | 1808 | #define CKEN_IM (20) /* Internal Memory Clock Enable */ | 
| 1809 | #define CKEN19_KEYPAD (1 << 19) /* Keypad Interface Clock Enable */ | 1809 | #define CKEN_KEYPAD (19) /* Keypad Interface Clock Enable */ | 
| 1810 | #define CKEN18_USIM (1 << 18) /* USIM Unit Clock Enable */ | 1810 | #define CKEN_USIM (18) /* USIM Unit Clock Enable */ | 
| 1811 | #define CKEN17_MSL (1 << 17) /* MSL Unit Clock Enable */ | 1811 | #define CKEN_MSL (17) /* MSL Unit Clock Enable */ | 
| 1812 | #define CKEN16_LCD (1 << 16) /* LCD Unit Clock Enable */ | 1812 | #define CKEN_LCD (16) /* LCD Unit Clock Enable */ | 
| 1813 | #define CKEN15_PWRI2C (1 << 15) /* PWR I2C Unit Clock Enable */ | 1813 | #define CKEN_PWRI2C (15) /* PWR I2C Unit Clock Enable */ | 
| 1814 | #define CKEN14_I2C (1 << 14) /* I2C Unit Clock Enable */ | 1814 | #define CKEN_I2C (14) /* I2C Unit Clock Enable */ | 
| 1815 | #define CKEN13_FICP (1 << 13) /* FICP Unit Clock Enable */ | 1815 | #define CKEN_FICP (13) /* FICP Unit Clock Enable */ | 
| 1816 | #define CKEN12_MMC (1 << 12) /* MMC Unit Clock Enable */ | 1816 | #define CKEN_MMC (12) /* MMC Unit Clock Enable */ | 
| 1817 | #define CKEN11_USB (1 << 11) /* USB Unit Clock Enable */ | 1817 | #define CKEN_USB (11) /* USB Unit Clock Enable */ | 
| 1818 | #define CKEN10_ASSP (1 << 10) /* ASSP (SSP3) Clock Enable */ | 1818 | #define CKEN_ASSP (10) /* ASSP (SSP3) Clock Enable */ | 
| 1819 | #define CKEN10_USBHOST (1 << 10) /* USB Host Unit Clock Enable */ | 1819 | #define CKEN_USBHOST (10) /* USB Host Unit Clock Enable */ | 
| 1820 | #define CKEN9_OSTIMER (1 << 9) /* OS Timer Unit Clock Enable */ | 1820 | #define CKEN_OSTIMER (9) /* OS Timer Unit Clock Enable */ | 
| 1821 | #define CKEN9_NSSP (1 << 9) /* NSSP (SSP2) Clock Enable */ | 1821 | #define CKEN_NSSP (9) /* NSSP (SSP2) Clock Enable */ | 
| 1822 | #define CKEN8_I2S (1 << 8) /* I2S Unit Clock Enable */ | 1822 | #define CKEN_I2S (8) /* I2S Unit Clock Enable */ | 
| 1823 | #define CKEN7_BTUART (1 << 7) /* BTUART Unit Clock Enable */ | 1823 | #define CKEN_BTUART (7) /* BTUART Unit Clock Enable */ | 
| 1824 | #define CKEN6_FFUART (1 << 6) /* FFUART Unit Clock Enable */ | 1824 | #define CKEN_FFUART (6) /* FFUART Unit Clock Enable */ | 
| 1825 | #define CKEN5_STUART (1 << 5) /* STUART Unit Clock Enable */ | 1825 | #define CKEN_STUART (5) /* STUART Unit Clock Enable */ | 
| 1826 | #define CKEN4_HWUART (1 << 4) /* HWUART Unit Clock Enable */ | 1826 | #define CKEN_HWUART (4) /* HWUART Unit Clock Enable */ | 
| 1827 | #define CKEN4_SSP3 (1 << 4) /* SSP3 Unit Clock Enable */ | 1827 | #define CKEN_SSP3 (4) /* SSP3 Unit Clock Enable */ | 
| 1828 | #define CKEN3_SSP (1 << 3) /* SSP Unit Clock Enable */ | 1828 | #define CKEN_SSP (3) /* SSP Unit Clock Enable */ | 
| 1829 | #define CKEN3_SSP2 (1 << 3) /* SSP2 Unit Clock Enable */ | 1829 | #define CKEN_SSP2 (3) /* SSP2 Unit Clock Enable */ | 
| 1830 | #define CKEN2_AC97 (1 << 2) /* AC97 Unit Clock Enable */ | 1830 | #define CKEN_AC97 (2) /* AC97 Unit Clock Enable */ | 
| 1831 | #define CKEN1_PWM1 (1 << 1) /* PWM1 Clock Enable */ | 1831 | #define CKEN_PWM1 (1) /* PWM1 Clock Enable */ | 
| 1832 | #define CKEN0_PWM0 (1 << 0) /* PWM0 Clock Enable */ | 1832 | #define CKEN_PWM0 (0) /* PWM0 Clock Enable */ | 
| 1833 | 1833 | ||
| 1834 | #define OSCC_OON (1 << 1) /* 32.768kHz OON (write-once only bit) */ | 1834 | #define OSCC_OON (1 << 1) /* 32.768kHz OON (write-once only bit) */ | 
| 1835 | #define OSCC_OOK (1 << 0) /* 32.768kHz OOK (read-only bit) */ | 1835 | #define OSCC_OOK (1 << 0) /* 32.768kHz OOK (read-only bit) */ | 
| diff --git a/include/asm-arm/arch-s3c2410/regs-ac97.h b/include/asm-arm/arch-s3c2410/regs-ac97.h index bdd6a4f93d7f..b004dee6bcaf 100644 --- a/include/asm-arm/arch-s3c2410/regs-ac97.h +++ b/include/asm-arm/arch-s3c2410/regs-ac97.h | |||
| @@ -13,11 +13,55 @@ | |||
| 13 | #ifndef __ASM_ARCH_REGS_AC97_H | 13 | #ifndef __ASM_ARCH_REGS_AC97_H | 
| 14 | #define __ASM_ARCH_REGS_AC97_H __FILE__ | 14 | #define __ASM_ARCH_REGS_AC97_H __FILE__ | 
| 15 | 15 | ||
| 16 | #define S3C_AC97_GLBCTRL (0x00) | 16 | #define S3C_AC97_GLBCTRL (0x00) | 
| 17 | #define S3C_AC97_GLBSTAT (0x04) | 17 | |
| 18 | #define S3C_AC97_CODEC_CMD (0x08) | 18 | #define S3C_AC97_GLBCTRL_CODECREADYIE (1<<22) | 
| 19 | #define S3C_AC97_PCM_ADDR (0x10) | 19 | #define S3C_AC97_GLBCTRL_PCMOUTURIE (1<<21) | 
| 20 | #define S3C_AC97_PCM_DATA (0x18) | 20 | #define S3C_AC97_GLBCTRL_PCMINORIE (1<<20) | 
| 21 | #define S3C_AC97_MIC_DATA (0x1C) | 21 | #define S3C_AC97_GLBCTRL_MICINORIE (1<<19) | 
| 22 | #define S3C_AC97_GLBCTRL_PCMOUTTIE (1<<18) | ||
| 23 | #define S3C_AC97_GLBCTRL_PCMINTIE (1<<17) | ||
| 24 | #define S3C_AC97_GLBCTRL_MICINTIE (1<<16) | ||
| 25 | #define S3C_AC97_GLBCTRL_PCMOUTTM_OFF (0<<12) | ||
| 26 | #define S3C_AC97_GLBCTRL_PCMOUTTM_PIO (1<<12) | ||
| 27 | #define S3C_AC97_GLBCTRL_PCMOUTTM_DMA (2<<12) | ||
| 28 | #define S3C_AC97_GLBCTRL_PCMOUTTM_MASK (3<<12) | ||
| 29 | #define S3C_AC97_GLBCTRL_PCMINTM_OFF (0<<10) | ||
| 30 | #define S3C_AC97_GLBCTRL_PCMINTM_PIO (1<<10) | ||
| 31 | #define S3C_AC97_GLBCTRL_PCMINTM_DMA (2<<10) | ||
| 32 | #define S3C_AC97_GLBCTRL_PCMINTM_MASK (3<<10) | ||
| 33 | #define S3C_AC97_GLBCTRL_MICINTM_OFF (0<<8) | ||
| 34 | #define S3C_AC97_GLBCTRL_MICINTM_PIO (1<<8) | ||
| 35 | #define S3C_AC97_GLBCTRL_MICINTM_DMA (2<<8) | ||
| 36 | #define S3C_AC97_GLBCTRL_MICINTM_MASK (3<<8) | ||
| 37 | #define S3C_AC97_GLBCTRL_TRANSFERDATAENABLE (1<<3) | ||
| 38 | #define S3C_AC97_GLBCTRL_ACLINKON (1<<2) | ||
| 39 | #define S3C_AC97_GLBCTRL_WARMRESET (1<<1) | ||
| 40 | #define S3C_AC97_GLBCTRL_COLDRESET (1<<0) | ||
| 41 | |||
| 42 | #define S3C_AC97_GLBSTAT (0x04) | ||
| 43 | |||
| 44 | #define S3C_AC97_GLBSTAT_CODECREADY (1<<22) | ||
| 45 | #define S3C_AC97_GLBSTAT_PCMOUTUR (1<<21) | ||
| 46 | #define S3C_AC97_GLBSTAT_PCMINORI (1<<20) | ||
| 47 | #define S3C_AC97_GLBSTAT_MICINORI (1<<19) | ||
| 48 | #define S3C_AC97_GLBSTAT_PCMOUTTI (1<<18) | ||
| 49 | #define S3C_AC97_GLBSTAT_PCMINTI (1<<17) | ||
| 50 | #define S3C_AC97_GLBSTAT_MICINTI (1<<16) | ||
| 51 | #define S3C_AC97_GLBSTAT_MAINSTATE_IDLE (0<<0) | ||
| 52 | #define S3C_AC97_GLBSTAT_MAINSTATE_INIT (1<<0) | ||
| 53 | #define S3C_AC97_GLBSTAT_MAINSTATE_READY (2<<0) | ||
| 54 | #define S3C_AC97_GLBSTAT_MAINSTATE_ACTIVE (3<<0) | ||
| 55 | #define S3C_AC97_GLBSTAT_MAINSTATE_LP (4<<0) | ||
| 56 | #define S3C_AC97_GLBSTAT_MAINSTATE_WARM (5<<0) | ||
| 57 | |||
| 58 | #define S3C_AC97_CODEC_CMD (0x08) | ||
| 59 | |||
| 60 | #define S3C_AC97_CODEC_CMD_READ (1<<23) | ||
| 61 | |||
| 62 | #define S3C_AC97_STAT (0x0c) | ||
| 63 | #define S3C_AC97_PCM_ADDR (0x10) | ||
| 64 | #define S3C_AC97_PCM_DATA (0x18) | ||
| 65 | #define S3C_AC97_MIC_DATA (0x1C) | ||
| 22 | 66 | ||
| 23 | #endif /* __ASM_ARCH_REGS_AC97_H */ | 67 | #endif /* __ASM_ARCH_REGS_AC97_H */ | 
| diff --git a/include/asm-arm/arch-s3c2410/regs-udc.h b/include/asm-arm/arch-s3c2410/regs-udc.h index 3c8354619b60..e1e9805d2d9a 100644 --- a/include/asm-arm/arch-s3c2410/regs-udc.h +++ b/include/asm-arm/arch-s3c2410/regs-udc.h | |||
| @@ -75,7 +75,7 @@ | |||
| 75 | #define S3C2410_UDC_OUT_FIFO_CNT1_REG S3C2410_USBDREG(0x0198) | 75 | #define S3C2410_UDC_OUT_FIFO_CNT1_REG S3C2410_USBDREG(0x0198) | 
| 76 | #define S3C2410_UDC_OUT_FIFO_CNT2_REG S3C2410_USBDREG(0x019c) | 76 | #define S3C2410_UDC_OUT_FIFO_CNT2_REG S3C2410_USBDREG(0x019c) | 
| 77 | 77 | ||
| 78 | 78 | #define S3C2410_UDC_FUNCADDR_UPDATE (1<<7) | |
| 79 | 79 | ||
| 80 | #define S3C2410_UDC_PWR_ISOUP (1<<7) // R/W | 80 | #define S3C2410_UDC_PWR_ISOUP (1<<7) // R/W | 
| 81 | #define S3C2410_UDC_PWR_RESET (1<<3) // R | 81 | #define S3C2410_UDC_PWR_RESET (1<<3) // R | 
| @@ -135,10 +135,6 @@ | |||
| 135 | #define S3C2410_UDC_OCSR2_ISO (1<<6) // R/W | 135 | #define S3C2410_UDC_OCSR2_ISO (1<<6) // R/W | 
| 136 | #define S3C2410_UDC_OCSR2_DMAIEN (1<<5) // R/W | 136 | #define S3C2410_UDC_OCSR2_DMAIEN (1<<5) // R/W | 
| 137 | 137 | ||
| 138 | #define S3C2410_UDC_SETIX(base,x) \ | ||
| 139 | writel(S3C2410_UDC_INDEX_ ## x, base+S3C2410_UDC_INDEX_REG); | ||
| 140 | |||
| 141 | |||
| 142 | #define S3C2410_UDC_EP0_CSR_OPKRDY (1<<0) | 138 | #define S3C2410_UDC_EP0_CSR_OPKRDY (1<<0) | 
| 143 | #define S3C2410_UDC_EP0_CSR_IPKRDY (1<<1) | 139 | #define S3C2410_UDC_EP0_CSR_IPKRDY (1<<1) | 
| 144 | #define S3C2410_UDC_EP0_CSR_SENTSTL (1<<2) | 140 | #define S3C2410_UDC_EP0_CSR_SENTSTL (1<<2) | 
| diff --git a/include/asm-arm/ecard.h b/include/asm-arm/ecard.h index a0ae2b954d29..3a6d3eb27622 100644 --- a/include/asm-arm/ecard.h +++ b/include/asm-arm/ecard.h | |||
| @@ -160,6 +160,7 @@ struct expansion_card { | |||
| 160 | unsigned char irqmask; /* IRQ mask */ | 160 | unsigned char irqmask; /* IRQ mask */ | 
| 161 | unsigned char fiqmask; /* FIQ mask */ | 161 | unsigned char fiqmask; /* FIQ mask */ | 
| 162 | unsigned char claimed; /* Card claimed? */ | 162 | unsigned char claimed; /* Card claimed? */ | 
| 163 | unsigned char easi; /* EASI card */ | ||
| 163 | 164 | ||
| 164 | void *irq_data; /* Data for use for IRQ by card */ | 165 | void *irq_data; /* Data for use for IRQ by card */ | 
| 165 | void *fiq_data; /* Data for use for FIQ by card */ | 166 | void *fiq_data; /* Data for use for FIQ by card */ | 
| @@ -169,7 +170,6 @@ struct expansion_card { | |||
| 169 | CONST unsigned int dma; /* DMA number (for request_dma) */ | 170 | CONST unsigned int dma; /* DMA number (for request_dma) */ | 
| 170 | CONST unsigned int irq; /* IRQ number (for request_irq) */ | 171 | CONST unsigned int irq; /* IRQ number (for request_irq) */ | 
| 171 | CONST unsigned int fiq; /* FIQ number (for request_irq) */ | 172 | CONST unsigned int fiq; /* FIQ number (for request_irq) */ | 
| 172 | CONST card_type_t type; /* Type of card */ | ||
| 173 | CONST struct in_ecid cid; /* Card Identification */ | 173 | CONST struct in_ecid cid; /* Card Identification */ | 
| 174 | 174 | ||
| 175 | /* Private internal data */ | 175 | /* Private internal data */ | 
| @@ -224,56 +224,6 @@ ecard_address(struct expansion_card *ec, card_type_t type, card_speed_t speed) | |||
| 224 | extern int ecard_request_resources(struct expansion_card *ec); | 224 | extern int ecard_request_resources(struct expansion_card *ec); | 
| 225 | extern void ecard_release_resources(struct expansion_card *ec); | 225 | extern void ecard_release_resources(struct expansion_card *ec); | 
| 226 | 226 | ||
| 227 | #ifdef ECARD_C | ||
| 228 | /* Definitions internal to ecard.c - for it's use only!! | ||
| 229 | * | ||
| 230 | * External expansion card header as read from the card | ||
| 231 | */ | ||
| 232 | struct ex_ecid { | ||
| 233 | unsigned char r_irq:1; | ||
| 234 | unsigned char r_zero:1; | ||
| 235 | unsigned char r_fiq:1; | ||
| 236 | unsigned char r_id:4; | ||
| 237 | unsigned char r_a:1; | ||
| 238 | |||
| 239 | unsigned char r_cd:1; | ||
| 240 | unsigned char r_is:1; | ||
| 241 | unsigned char r_w:2; | ||
| 242 | unsigned char r_r1:4; | ||
| 243 | |||
| 244 | unsigned char r_r2:8; | ||
| 245 | |||
| 246 | unsigned char r_prod[2]; | ||
| 247 | |||
| 248 | unsigned char r_manu[2]; | ||
| 249 | |||
| 250 | unsigned char r_country; | ||
| 251 | |||
| 252 | unsigned char r_fiqmask; | ||
| 253 | unsigned char r_fiqoff[3]; | ||
| 254 | |||
| 255 | unsigned char r_irqmask; | ||
| 256 | unsigned char r_irqoff[3]; | ||
| 257 | }; | ||
| 258 | |||
| 259 | /* | ||
| 260 | * Chunk directory entry as read from the card | ||
| 261 | */ | ||
| 262 | struct ex_chunk_dir { | ||
| 263 | unsigned char r_id; | ||
| 264 | unsigned char r_len[3]; | ||
| 265 | unsigned long r_start; | ||
| 266 | union { | ||
| 267 | char string[256]; | ||
| 268 | char data[1]; | ||
| 269 | } d; | ||
| 270 | #define c_id(x) ((x)->r_id) | ||
| 271 | #define c_len(x) ((x)->r_len[0]|((x)->r_len[1]<<8)|((x)->r_len[2]<<16)) | ||
| 272 | #define c_start(x) ((x)->r_start) | ||
| 273 | }; | ||
| 274 | |||
| 275 | #endif | ||
| 276 | |||
| 277 | extern struct bus_type ecard_bus_type; | 227 | extern struct bus_type ecard_bus_type; | 
| 278 | 228 | ||
| 279 | #define ECARD_DEV(_d) container_of((_d), struct expansion_card, dev) | 229 | #define ECARD_DEV(_d) container_of((_d), struct expansion_card, dev) | 
| diff --git a/include/asm-arm/hardware/iop3xx.h b/include/asm-arm/hardware/iop3xx.h index 15141a9caca8..63feceb7ede5 100644 --- a/include/asm-arm/hardware/iop3xx.h +++ b/include/asm-arm/hardware/iop3xx.h | |||
| @@ -28,6 +28,7 @@ | |||
| 28 | extern void gpio_line_config(int line, int direction); | 28 | extern void gpio_line_config(int line, int direction); | 
| 29 | extern int gpio_line_get(int line); | 29 | extern int gpio_line_get(int line); | 
| 30 | extern void gpio_line_set(int line, int value); | 30 | extern void gpio_line_set(int line, int value); | 
| 31 | extern int init_atu; | ||
| 31 | #endif | 32 | #endif | 
| 32 | 33 | ||
| 33 | 34 | ||
| @@ -41,7 +42,7 @@ extern void gpio_line_set(int line, int value); | |||
| 41 | IOP3XX_PERIPHERAL_SIZE - 1) | 42 | IOP3XX_PERIPHERAL_SIZE - 1) | 
| 42 | #define IOP3XX_PERIPHERAL_UPPER_VA (IOP3XX_PERIPHERAL_VIRT_BASE +\ | 43 | #define IOP3XX_PERIPHERAL_UPPER_VA (IOP3XX_PERIPHERAL_VIRT_BASE +\ | 
| 43 | IOP3XX_PERIPHERAL_SIZE - 1) | 44 | IOP3XX_PERIPHERAL_SIZE - 1) | 
| 44 | #define IOP3XX_PMMR_PHYS_TO_VIRT(addr) (u32) ((u32) addr -\ | 45 | #define IOP3XX_PMMR_PHYS_TO_VIRT(addr) (u32) ((u32) (addr) -\ | 
| 45 | (IOP3XX_PERIPHERAL_PHYS_BASE\ | 46 | (IOP3XX_PERIPHERAL_PHYS_BASE\ | 
| 46 | - IOP3XX_PERIPHERAL_VIRT_BASE)) | 47 | - IOP3XX_PERIPHERAL_VIRT_BASE)) | 
| 47 | #define IOP3XX_REG_ADDR(reg) (IOP3XX_PERIPHERAL_VIRT_BASE + (reg)) | 48 | #define IOP3XX_REG_ADDR(reg) (IOP3XX_PERIPHERAL_VIRT_BASE + (reg)) | 
| @@ -103,6 +104,21 @@ extern void gpio_line_set(int line, int value); | |||
| 103 | #define IOP3XX_PCIXCMD (volatile u16 *)IOP3XX_REG_ADDR(0x01e2) | 104 | #define IOP3XX_PCIXCMD (volatile u16 *)IOP3XX_REG_ADDR(0x01e2) | 
| 104 | #define IOP3XX_PCIXSR (volatile u32 *)IOP3XX_REG_ADDR(0x01e4) | 105 | #define IOP3XX_PCIXSR (volatile u32 *)IOP3XX_REG_ADDR(0x01e4) | 
| 105 | #define IOP3XX_PCIIRSR (volatile u32 *)IOP3XX_REG_ADDR(0x01ec) | 106 | #define IOP3XX_PCIIRSR (volatile u32 *)IOP3XX_REG_ADDR(0x01ec) | 
| 107 | #define IOP3XX_PCSR_OUT_Q_BUSY (1 << 15) | ||
| 108 | #define IOP3XX_PCSR_IN_Q_BUSY (1 << 14) | ||
| 109 | #define IOP3XX_ATUCR_OUT_EN (1 << 1) | ||
| 110 | |||
| 111 | #define IOP3XX_INIT_ATU_DEFAULT 0 | ||
| 112 | #define IOP3XX_INIT_ATU_DISABLE -1 | ||
| 113 | #define IOP3XX_INIT_ATU_ENABLE 1 | ||
| 114 | |||
| 115 | #ifdef CONFIG_IOP3XX_ATU | ||
| 116 | #define iop3xx_get_init_atu(x) (init_atu == IOP3XX_INIT_ATU_DEFAULT ?\ | ||
| 117 | IOP3XX_INIT_ATU_ENABLE : init_atu) | ||
| 118 | #else | ||
| 119 | #define iop3xx_get_init_atu(x) (init_atu == IOP3XX_INIT_ATU_DEFAULT ?\ | ||
| 120 | IOP3XX_INIT_ATU_DISABLE : init_atu) | ||
| 121 | #endif | ||
| 106 | 122 | ||
| 107 | /* Messaging Unit */ | 123 | /* Messaging Unit */ | 
| 108 | #define IOP3XX_IMR0 (volatile u32 *)IOP3XX_REG_ADDR(0x0310) | 124 | #define IOP3XX_IMR0 (volatile u32 *)IOP3XX_REG_ADDR(0x0310) | 
| @@ -253,14 +269,12 @@ extern void gpio_line_set(int line, int value); | |||
| 253 | /* | 269 | /* | 
| 254 | * IOP3XX I/O and Mem space regions for PCI autoconfiguration | 270 | * IOP3XX I/O and Mem space regions for PCI autoconfiguration | 
| 255 | */ | 271 | */ | 
| 256 | #define IOP3XX_PCI_MEM_WINDOW_SIZE 0x04000000 | 272 | #define IOP3XX_PCI_LOWER_MEM_PA 0x80000000 | 
| 257 | #define IOP3XX_PCI_LOWER_MEM_PA 0x80000000 | ||
| 258 | #define IOP3XX_PCI_LOWER_MEM_BA (*IOP3XX_OMWTVR0) | ||
| 259 | 273 | ||
| 260 | #define IOP3XX_PCI_IO_WINDOW_SIZE 0x00010000 | 274 | #define IOP3XX_PCI_IO_WINDOW_SIZE 0x00010000 | 
| 261 | #define IOP3XX_PCI_LOWER_IO_PA 0x90000000 | 275 | #define IOP3XX_PCI_LOWER_IO_PA 0x90000000 | 
| 262 | #define IOP3XX_PCI_LOWER_IO_VA 0xfe000000 | 276 | #define IOP3XX_PCI_LOWER_IO_VA 0xfe000000 | 
| 263 | #define IOP3XX_PCI_LOWER_IO_BA (*IOP3XX_OIOWTVR) | 277 | #define IOP3XX_PCI_LOWER_IO_BA 0x90000000 | 
| 264 | #define IOP3XX_PCI_UPPER_IO_PA (IOP3XX_PCI_LOWER_IO_PA +\ | 278 | #define IOP3XX_PCI_UPPER_IO_PA (IOP3XX_PCI_LOWER_IO_PA +\ | 
| 265 | IOP3XX_PCI_IO_WINDOW_SIZE - 1) | 279 | IOP3XX_PCI_IO_WINDOW_SIZE - 1) | 
| 266 | #define IOP3XX_PCI_UPPER_IO_VA (IOP3XX_PCI_LOWER_IO_VA +\ | 280 | #define IOP3XX_PCI_UPPER_IO_VA (IOP3XX_PCI_LOWER_IO_VA +\ | 
| diff --git a/include/asm-arm/plat-s3c24xx/clock.h b/include/asm-arm/plat-s3c24xx/clock.h index f6135dbb9fa9..235b753cd877 100644 --- a/include/asm-arm/plat-s3c24xx/clock.h +++ b/include/asm-arm/plat-s3c24xx/clock.h | |||
| @@ -56,6 +56,7 @@ extern struct mutex clocks_mutex; | |||
| 56 | extern int s3c2410_clkcon_enable(struct clk *clk, int enable); | 56 | extern int s3c2410_clkcon_enable(struct clk *clk, int enable); | 
| 57 | 57 | ||
| 58 | extern int s3c24xx_register_clock(struct clk *clk); | 58 | extern int s3c24xx_register_clock(struct clk *clk); | 
| 59 | extern int s3c24xx_register_clocks(struct clk **clk, int nr_clks); | ||
| 59 | 60 | ||
| 60 | extern int s3c24xx_setup_clocks(unsigned long xtal, | 61 | extern int s3c24xx_setup_clocks(unsigned long xtal, | 
| 61 | unsigned long fclk, | 62 | unsigned long fclk, | 
| diff --git a/include/asm-arm/plat-s3c24xx/cpu.h b/include/asm-arm/plat-s3c24xx/cpu.h index 15dd18810905..23e420e8bd5b 100644 --- a/include/asm-arm/plat-s3c24xx/cpu.h +++ b/include/asm-arm/plat-s3c24xx/cpu.h | |||
| @@ -40,22 +40,6 @@ extern void s3c24xx_init_uartdevs(char *name, | |||
| 40 | struct s3c24xx_uart_resources *res, | 40 | struct s3c24xx_uart_resources *res, | 
| 41 | struct s3c2410_uartcfg *cfg, int no); | 41 | struct s3c2410_uartcfg *cfg, int no); | 
| 42 | 42 | ||
| 43 | /* the board structure is used at first initialsation time | ||
| 44 | * to get info such as the devices to register for this | ||
| 45 | * board. This is done because platfrom_add_devices() cannot | ||
| 46 | * be called from the map_io entry. | ||
| 47 | */ | ||
| 48 | |||
| 49 | struct s3c24xx_board { | ||
| 50 | struct platform_device **devices; | ||
| 51 | unsigned int devices_count; | ||
| 52 | |||
| 53 | struct clk **clocks; | ||
| 54 | unsigned int clocks_count; | ||
| 55 | }; | ||
| 56 | |||
| 57 | extern void s3c24xx_set_board(struct s3c24xx_board *board); | ||
| 58 | |||
| 59 | /* timer for 2410/2440 */ | 43 | /* timer for 2410/2440 */ | 
| 60 | 44 | ||
| 61 | struct sys_timer; | 45 | struct sys_timer; | 
| diff --git a/include/asm-arm/ptrace.h b/include/asm-arm/ptrace.h index 5a8ef787dbf8..2d0dad8c10ac 100644 --- a/include/asm-arm/ptrace.h +++ b/include/asm-arm/ptrace.h | |||
| @@ -10,23 +10,19 @@ | |||
| 10 | #ifndef __ASM_ARM_PTRACE_H | 10 | #ifndef __ASM_ARM_PTRACE_H | 
| 11 | #define __ASM_ARM_PTRACE_H | 11 | #define __ASM_ARM_PTRACE_H | 
| 12 | 12 | ||
| 13 | |||
| 14 | #define PTRACE_GETREGS 12 | 13 | #define PTRACE_GETREGS 12 | 
| 15 | #define PTRACE_SETREGS 13 | 14 | #define PTRACE_SETREGS 13 | 
| 16 | #define PTRACE_GETFPREGS 14 | 15 | #define PTRACE_GETFPREGS 14 | 
| 17 | #define PTRACE_SETFPREGS 15 | 16 | #define PTRACE_SETFPREGS 15 | 
| 18 | 17 | /* PTRACE_ATTACH is 16 */ | |
| 18 | /* PTRACE_DETACH is 17 */ | ||
| 19 | #define PTRACE_GETWMMXREGS 18 | 19 | #define PTRACE_GETWMMXREGS 18 | 
| 20 | #define PTRACE_SETWMMXREGS 19 | 20 | #define PTRACE_SETWMMXREGS 19 | 
| 21 | 21 | /* 20 is unused */ | |
| 22 | #define PTRACE_OLDSETOPTIONS 21 | 22 | #define PTRACE_OLDSETOPTIONS 21 | 
| 23 | |||
| 24 | #define PTRACE_GET_THREAD_AREA 22 | 23 | #define PTRACE_GET_THREAD_AREA 22 | 
| 25 | |||
| 26 | #define PTRACE_SET_SYSCALL 23 | 24 | #define PTRACE_SET_SYSCALL 23 | 
| 27 | |||
| 28 | /* PTRACE_SYSCALL is 24 */ | 25 | /* PTRACE_SYSCALL is 24 */ | 
| 29 | |||
| 30 | #define PTRACE_GETCRUNCHREGS 25 | 26 | #define PTRACE_GETCRUNCHREGS 25 | 
| 31 | #define PTRACE_SETCRUNCHREGS 26 | 27 | #define PTRACE_SETCRUNCHREGS 26 | 
| 32 | 28 | ||
| diff --git a/include/asm-arm/thread_info.h b/include/asm-arm/thread_info.h index 5014794f9eb3..eae85b09db2e 100644 --- a/include/asm-arm/thread_info.h +++ b/include/asm-arm/thread_info.h | |||
| @@ -57,6 +57,7 @@ struct thread_info { | |||
| 57 | __u32 cpu; /* cpu */ | 57 | __u32 cpu; /* cpu */ | 
| 58 | __u32 cpu_domain; /* cpu domain */ | 58 | __u32 cpu_domain; /* cpu domain */ | 
| 59 | struct cpu_context_save cpu_context; /* cpu context */ | 59 | struct cpu_context_save cpu_context; /* cpu context */ | 
| 60 | __u32 syscall; /* syscall number */ | ||
| 60 | __u8 used_cp[16]; /* thread used copro */ | 61 | __u8 used_cp[16]; /* thread used copro */ | 
| 61 | unsigned long tp_value; | 62 | unsigned long tp_value; | 
| 62 | struct crunch_state crunchstate; | 63 | struct crunch_state crunchstate; | 
| diff --git a/sound/arm/pxa2xx-ac97.c b/sound/arm/pxa2xx-ac97.c index 28db4be7a16f..19c65a8d86a7 100644 --- a/sound/arm/pxa2xx-ac97.c +++ b/sound/arm/pxa2xx-ac97.c | |||
| @@ -260,7 +260,7 @@ static int pxa2xx_ac97_do_suspend(struct snd_card *card, pm_message_t state) | |||
| 260 | if (platform_ops && platform_ops->suspend) | 260 | if (platform_ops && platform_ops->suspend) | 
| 261 | platform_ops->suspend(platform_ops->priv); | 261 | platform_ops->suspend(platform_ops->priv); | 
| 262 | GCR |= GCR_ACLINK_OFF; | 262 | GCR |= GCR_ACLINK_OFF; | 
| 263 | pxa_set_cken(CKEN2_AC97, 0); | 263 | pxa_set_cken(CKEN_AC97, 0); | 
| 264 | 264 | ||
| 265 | return 0; | 265 | return 0; | 
| 266 | } | 266 | } | 
| @@ -269,7 +269,7 @@ static int pxa2xx_ac97_do_resume(struct snd_card *card) | |||
| 269 | { | 269 | { | 
| 270 | pxa2xx_audio_ops_t *platform_ops = card->dev->platform_data; | 270 | pxa2xx_audio_ops_t *platform_ops = card->dev->platform_data; | 
| 271 | 271 | ||
| 272 | pxa_set_cken(CKEN2_AC97, 1); | 272 | pxa_set_cken(CKEN_AC97, 1); | 
| 273 | if (platform_ops && platform_ops->resume) | 273 | if (platform_ops && platform_ops->resume) | 
| 274 | platform_ops->resume(platform_ops->priv); | 274 | platform_ops->resume(platform_ops->priv); | 
| 275 | snd_ac97_resume(pxa2xx_ac97_ac97); | 275 | snd_ac97_resume(pxa2xx_ac97_ac97); | 
| @@ -337,7 +337,7 @@ static int __devinit pxa2xx_ac97_probe(struct platform_device *dev) | |||
| 337 | /* Use GPIO 113 as AC97 Reset on Bulverde */ | 337 | /* Use GPIO 113 as AC97 Reset on Bulverde */ | 
| 338 | pxa_gpio_mode(113 | GPIO_ALT_FN_2_OUT); | 338 | pxa_gpio_mode(113 | GPIO_ALT_FN_2_OUT); | 
| 339 | #endif | 339 | #endif | 
| 340 | pxa_set_cken(CKEN2_AC97, 1); | 340 | pxa_set_cken(CKEN_AC97, 1); | 
| 341 | 341 | ||
| 342 | ret = snd_ac97_bus(card, 0, &pxa2xx_ac97_ops, NULL, &ac97_bus); | 342 | ret = snd_ac97_bus(card, 0, &pxa2xx_ac97_ops, NULL, &ac97_bus); | 
| 343 | if (ret) | 343 | if (ret) | 
| @@ -361,10 +361,10 @@ static int __devinit pxa2xx_ac97_probe(struct platform_device *dev) | |||
| 361 | err: | 361 | err: | 
| 362 | if (card) | 362 | if (card) | 
| 363 | snd_card_free(card); | 363 | snd_card_free(card); | 
| 364 | if (CKEN & CKEN2_AC97) { | 364 | if (CKEN & CKEN_AC97) { | 
| 365 | GCR |= GCR_ACLINK_OFF; | 365 | GCR |= GCR_ACLINK_OFF; | 
| 366 | free_irq(IRQ_AC97, NULL); | 366 | free_irq(IRQ_AC97, NULL); | 
| 367 | pxa_set_cken(CKEN2_AC97, 0); | 367 | pxa_set_cken(CKEN_AC97, 0); | 
| 368 | } | 368 | } | 
| 369 | return ret; | 369 | return ret; | 
| 370 | } | 370 | } | 
| @@ -378,7 +378,7 @@ static int __devexit pxa2xx_ac97_remove(struct platform_device *dev) | |||
| 378 | platform_set_drvdata(dev, NULL); | 378 | platform_set_drvdata(dev, NULL); | 
| 379 | GCR |= GCR_ACLINK_OFF; | 379 | GCR |= GCR_ACLINK_OFF; | 
| 380 | free_irq(IRQ_AC97, NULL); | 380 | free_irq(IRQ_AC97, NULL); | 
| 381 | pxa_set_cken(CKEN2_AC97, 0); | 381 | pxa_set_cken(CKEN_AC97, 0); | 
| 382 | } | 382 | } | 
| 383 | 383 | ||
| 384 | return 0; | 384 | return 0; | 
| diff --git a/sound/soc/pxa/pxa2xx-ac97.c b/sound/soc/pxa/pxa2xx-ac97.c index 1bbbeff84ef0..b222755763e7 100644 --- a/sound/soc/pxa/pxa2xx-ac97.c +++ b/sound/soc/pxa/pxa2xx-ac97.c | |||
| @@ -256,7 +256,7 @@ static int pxa2xx_ac97_suspend(struct platform_device *pdev, | |||
| 256 | struct snd_soc_cpu_dai *dai) | 256 | struct snd_soc_cpu_dai *dai) | 
| 257 | { | 257 | { | 
| 258 | GCR |= GCR_ACLINK_OFF; | 258 | GCR |= GCR_ACLINK_OFF; | 
| 259 | pxa_set_cken(CKEN2_AC97, 0); | 259 | pxa_set_cken(CKEN_AC97, 0); | 
| 260 | return 0; | 260 | return 0; | 
| 261 | } | 261 | } | 
| 262 | 262 | ||
| @@ -271,7 +271,7 @@ static int pxa2xx_ac97_resume(struct platform_device *pdev, | |||
| 271 | /* Use GPIO 113 as AC97 Reset on Bulverde */ | 271 | /* Use GPIO 113 as AC97 Reset on Bulverde */ | 
| 272 | pxa_gpio_mode(113 | GPIO_ALT_FN_2_OUT); | 272 | pxa_gpio_mode(113 | GPIO_ALT_FN_2_OUT); | 
| 273 | #endif | 273 | #endif | 
| 274 | pxa_set_cken(CKEN2_AC97, 1); | 274 | pxa_set_cken(CKEN_AC97, 1); | 
| 275 | return 0; | 275 | return 0; | 
| 276 | } | 276 | } | 
| 277 | 277 | ||
| @@ -296,14 +296,14 @@ static int pxa2xx_ac97_probe(struct platform_device *pdev) | |||
| 296 | /* Use GPIO 113 as AC97 Reset on Bulverde */ | 296 | /* Use GPIO 113 as AC97 Reset on Bulverde */ | 
| 297 | pxa_gpio_mode(113 | GPIO_ALT_FN_2_OUT); | 297 | pxa_gpio_mode(113 | GPIO_ALT_FN_2_OUT); | 
| 298 | #endif | 298 | #endif | 
| 299 | pxa_set_cken(CKEN2_AC97, 1); | 299 | pxa_set_cken(CKEN_AC97, 1); | 
| 300 | return 0; | 300 | return 0; | 
| 301 | 301 | ||
| 302 | err: | 302 | err: | 
| 303 | if (CKEN & CKEN2_AC97) { | 303 | if (CKEN & CKEN_AC97) { | 
| 304 | GCR |= GCR_ACLINK_OFF; | 304 | GCR |= GCR_ACLINK_OFF; | 
| 305 | free_irq(IRQ_AC97, NULL); | 305 | free_irq(IRQ_AC97, NULL); | 
| 306 | pxa_set_cken(CKEN2_AC97, 0); | 306 | pxa_set_cken(CKEN_AC97, 0); | 
| 307 | } | 307 | } | 
| 308 | return ret; | 308 | return ret; | 
| 309 | } | 309 | } | 
| @@ -312,7 +312,7 @@ static void pxa2xx_ac97_remove(struct platform_device *pdev) | |||
| 312 | { | 312 | { | 
| 313 | GCR |= GCR_ACLINK_OFF; | 313 | GCR |= GCR_ACLINK_OFF; | 
| 314 | free_irq(IRQ_AC97, NULL); | 314 | free_irq(IRQ_AC97, NULL); | 
| 315 | pxa_set_cken(CKEN2_AC97, 0); | 315 | pxa_set_cken(CKEN_AC97, 0); | 
| 316 | } | 316 | } | 
| 317 | 317 | ||
| 318 | static int pxa2xx_ac97_hw_params(struct snd_pcm_substream *substream, | 318 | static int pxa2xx_ac97_hw_params(struct snd_pcm_substream *substream, | 
| diff --git a/sound/soc/pxa/pxa2xx-i2s.c b/sound/soc/pxa/pxa2xx-i2s.c index 575a6137c040..50c5c83f67db 100644 --- a/sound/soc/pxa/pxa2xx-i2s.c +++ b/sound/soc/pxa/pxa2xx-i2s.c | |||
| @@ -149,7 +149,7 @@ static int pxa2xx_i2s_hw_params(struct snd_pcm_substream *substream, | |||
| 149 | pxa_gpio_mode(gpio_bus[pxa_i2s.master].tx); | 149 | pxa_gpio_mode(gpio_bus[pxa_i2s.master].tx); | 
| 150 | pxa_gpio_mode(gpio_bus[pxa_i2s.master].frm); | 150 | pxa_gpio_mode(gpio_bus[pxa_i2s.master].frm); | 
| 151 | pxa_gpio_mode(gpio_bus[pxa_i2s.master].clk); | 151 | pxa_gpio_mode(gpio_bus[pxa_i2s.master].clk); | 
| 152 | pxa_set_cken(CKEN8_I2S, 1); | 152 | pxa_set_cken(CKEN_I2S, 1); | 
| 153 | pxa_i2s_wait(); | 153 | pxa_i2s_wait(); | 
| 154 | 154 | ||
| 155 | if (substream->stream == SNDRV_PCM_STREAM_PLAYBACK) | 155 | if (substream->stream == SNDRV_PCM_STREAM_PLAYBACK) | 
| @@ -234,7 +234,7 @@ static void pxa2xx_i2s_shutdown(struct snd_pcm_substream *substream) | |||
| 234 | if (SACR1 & (SACR1_DREC | SACR1_DRPL)) { | 234 | if (SACR1 & (SACR1_DREC | SACR1_DRPL)) { | 
| 235 | SACR0 &= ~SACR0_ENB; | 235 | SACR0 &= ~SACR0_ENB; | 
| 236 | pxa_i2s_wait(); | 236 | pxa_i2s_wait(); | 
| 237 | pxa_set_cken(CKEN8_I2S, 0); | 237 | pxa_set_cken(CKEN_I2S, 0); | 
| 238 | } | 238 | } | 
| 239 | } | 239 | } | 
| 240 | 240 | ||
