diff options
author | Paul Mundt <lethal@linux-sh.org> | 2009-05-12 06:54:36 -0400 |
---|---|---|
committer | Paul Mundt <lethal@linux-sh.org> | 2009-05-12 06:54:36 -0400 |
commit | fd5b12458b25a88eb6f6b56464846d98a45e8928 (patch) | |
tree | 916107480879f131b504652af4f74524b2f327b3 /arch | |
parent | 9fe5ee0efb1b1d4a0939bc4252a8427e3337d96a (diff) | |
parent | 8be5f1a68f2c14082939dd54e7037dcee2eb54f8 (diff) |
Merge branch 'master' into sh/clkfwk
Diffstat (limited to 'arch')
22 files changed, 2359 insertions, 557 deletions
diff --git a/arch/sh/Kconfig b/arch/sh/Kconfig index a9dee13ddd8b..fb75c2d1928d 100644 --- a/arch/sh/Kconfig +++ b/arch/sh/Kconfig | |||
@@ -302,6 +302,7 @@ config CPU_SUBTYPE_SH7720 | |||
302 | bool "Support SH7720 processor" | 302 | bool "Support SH7720 processor" |
303 | select CPU_SH3 | 303 | select CPU_SH3 |
304 | select CPU_HAS_DSP | 304 | select CPU_HAS_DSP |
305 | select SYS_SUPPORTS_CMT | ||
305 | help | 306 | help |
306 | Select SH7720 if you have a SH3-DSP SH7720 CPU. | 307 | Select SH7720 if you have a SH3-DSP SH7720 CPU. |
307 | 308 | ||
@@ -309,6 +310,7 @@ config CPU_SUBTYPE_SH7721 | |||
309 | bool "Support SH7721 processor" | 310 | bool "Support SH7721 processor" |
310 | select CPU_SH3 | 311 | select CPU_SH3 |
311 | select CPU_HAS_DSP | 312 | select CPU_HAS_DSP |
313 | select SYS_SUPPORTS_CMT | ||
312 | help | 314 | help |
313 | Select SH7721 if you have a SH3-DSP SH7721 CPU. | 315 | Select SH7721 if you have a SH3-DSP SH7721 CPU. |
314 | 316 | ||
@@ -471,16 +473,9 @@ source "arch/sh/boards/Kconfig" | |||
471 | 473 | ||
472 | menu "Timer and clock configuration" | 474 | menu "Timer and clock configuration" |
473 | 475 | ||
474 | config SH_TMU | ||
475 | bool "TMU timer support" | ||
476 | depends on CPU_SH3 || CPU_SH4 | ||
477 | default y | ||
478 | help | ||
479 | This enables the use of the TMU as the system timer. | ||
480 | |||
481 | config SH_TIMER_TMU | 476 | config SH_TIMER_TMU |
482 | bool "TMU timer driver" | 477 | bool "TMU timer driver" |
483 | depends on !SH_TMU && SYS_SUPPORTS_TMU | 478 | depends on SYS_SUPPORTS_TMU |
484 | default y | 479 | default y |
485 | help | 480 | help |
486 | This enables the build of the TMU timer driver. | 481 | This enables the build of the TMU timer driver. |
@@ -499,17 +494,6 @@ config SH_TIMER_MTU2 | |||
499 | help | 494 | help |
500 | This enables build of the MTU2 timer driver. | 495 | This enables build of the MTU2 timer driver. |
501 | 496 | ||
502 | config SH_TIMER_IRQ | ||
503 | int | ||
504 | default "28" if CPU_SUBTYPE_SH7780 || CPU_SUBTYPE_SH7785 || \ | ||
505 | CPU_SUBTYPE_SH7763 | ||
506 | default "86" if CPU_SUBTYPE_SH7619 | ||
507 | default "140" if CPU_SUBTYPE_SH7206 | ||
508 | default "142" if CPU_SUBTYPE_SH7203 && SH_CMT | ||
509 | default "153" if CPU_SUBTYPE_SH7203 && SH_MTU2 | ||
510 | default "238" if CPU_SUBTYPE_MXG | ||
511 | default "16" | ||
512 | |||
513 | config SH_PCLK_FREQ | 497 | config SH_PCLK_FREQ |
514 | int "Peripheral clock frequency (in Hz)" | 498 | int "Peripheral clock frequency (in Hz)" |
515 | default "27000000" if CPU_SUBTYPE_SH7343 | 499 | default "27000000" if CPU_SUBTYPE_SH7343 |
diff --git a/arch/sh/configs/sh7770_generic_defconfig b/arch/sh/configs/sh7770_generic_defconfig new file mode 100644 index 000000000000..d6489b46ca5b --- /dev/null +++ b/arch/sh/configs/sh7770_generic_defconfig | |||
@@ -0,0 +1,700 @@ | |||
1 | # | ||
2 | # Automatically generated make config: don't edit | ||
3 | # Linux kernel version: 2.6.30-rc4 | ||
4 | # Tue May 12 14:48:21 2009 | ||
5 | # | ||
6 | CONFIG_SUPERH=y | ||
7 | CONFIG_SUPERH32=y | ||
8 | # CONFIG_SUPERH64 is not set | ||
9 | CONFIG_ARCH_DEFCONFIG="arch/sh/configs/shx3_defconfig" | ||
10 | CONFIG_RWSEM_GENERIC_SPINLOCK=y | ||
11 | CONFIG_GENERIC_BUG=y | ||
12 | CONFIG_GENERIC_FIND_NEXT_BIT=y | ||
13 | CONFIG_GENERIC_HWEIGHT=y | ||
14 | CONFIG_GENERIC_HARDIRQS=y | ||
15 | CONFIG_GENERIC_HARDIRQS_NO__DO_IRQ=y | ||
16 | CONFIG_GENERIC_IRQ_PROBE=y | ||
17 | # CONFIG_GENERIC_GPIO is not set | ||
18 | CONFIG_GENERIC_TIME=y | ||
19 | CONFIG_GENERIC_CLOCKEVENTS=y | ||
20 | # CONFIG_ARCH_SUSPEND_POSSIBLE is not set | ||
21 | CONFIG_ARCH_HIBERNATION_POSSIBLE=y | ||
22 | CONFIG_SYS_SUPPORTS_TMU=y | ||
23 | CONFIG_STACKTRACE_SUPPORT=y | ||
24 | CONFIG_LOCKDEP_SUPPORT=y | ||
25 | CONFIG_HAVE_LATENCYTOP_SUPPORT=y | ||
26 | # CONFIG_ARCH_HAS_ILOG2_U32 is not set | ||
27 | # CONFIG_ARCH_HAS_ILOG2_U64 is not set | ||
28 | CONFIG_ARCH_NO_VIRT_TO_BUS=y | ||
29 | CONFIG_ARCH_HAS_DEFAULT_IDLE=y | ||
30 | CONFIG_DEFCONFIG_LIST="/lib/modules/$UNAME_RELEASE/.config" | ||
31 | |||
32 | # | ||
33 | # General setup | ||
34 | # | ||
35 | CONFIG_EXPERIMENTAL=y | ||
36 | CONFIG_BROKEN_ON_SMP=y | ||
37 | CONFIG_INIT_ENV_ARG_LIMIT=32 | ||
38 | CONFIG_LOCALVERSION="" | ||
39 | # CONFIG_LOCALVERSION_AUTO is not set | ||
40 | CONFIG_SWAP=y | ||
41 | CONFIG_SYSVIPC=y | ||
42 | CONFIG_SYSVIPC_SYSCTL=y | ||
43 | # CONFIG_BSD_PROCESS_ACCT is not set | ||
44 | |||
45 | # | ||
46 | # RCU Subsystem | ||
47 | # | ||
48 | # CONFIG_CLASSIC_RCU is not set | ||
49 | CONFIG_TREE_RCU=y | ||
50 | # CONFIG_PREEMPT_RCU is not set | ||
51 | # CONFIG_RCU_TRACE is not set | ||
52 | CONFIG_RCU_FANOUT=32 | ||
53 | # CONFIG_RCU_FANOUT_EXACT is not set | ||
54 | # CONFIG_TREE_RCU_TRACE is not set | ||
55 | # CONFIG_PREEMPT_RCU_TRACE is not set | ||
56 | # CONFIG_IKCONFIG is not set | ||
57 | CONFIG_LOG_BUF_SHIFT=17 | ||
58 | CONFIG_GROUP_SCHED=y | ||
59 | CONFIG_FAIR_GROUP_SCHED=y | ||
60 | CONFIG_RT_GROUP_SCHED=y | ||
61 | CONFIG_USER_SCHED=y | ||
62 | # CONFIG_CGROUP_SCHED is not set | ||
63 | CONFIG_CGROUPS=y | ||
64 | # CONFIG_CGROUP_DEBUG is not set | ||
65 | # CONFIG_CGROUP_NS is not set | ||
66 | # CONFIG_CGROUP_FREEZER is not set | ||
67 | # CONFIG_CGROUP_DEVICE is not set | ||
68 | # CONFIG_CPUSETS is not set | ||
69 | # CONFIG_CGROUP_CPUACCT is not set | ||
70 | # CONFIG_RESOURCE_COUNTERS is not set | ||
71 | # CONFIG_RELAY is not set | ||
72 | # CONFIG_NAMESPACES is not set | ||
73 | # CONFIG_BLK_DEV_INITRD is not set | ||
74 | CONFIG_CC_OPTIMIZE_FOR_SIZE=y | ||
75 | CONFIG_SYSCTL=y | ||
76 | CONFIG_ANON_INODES=y | ||
77 | CONFIG_EMBEDDED=y | ||
78 | # CONFIG_UID16 is not set | ||
79 | CONFIG_SYSCTL_SYSCALL=y | ||
80 | CONFIG_KALLSYMS=y | ||
81 | # CONFIG_KALLSYMS_EXTRA_PASS is not set | ||
82 | # CONFIG_STRIP_ASM_SYMS is not set | ||
83 | CONFIG_HOTPLUG=y | ||
84 | CONFIG_PRINTK=y | ||
85 | CONFIG_BUG=y | ||
86 | CONFIG_ELF_CORE=y | ||
87 | CONFIG_BASE_FULL=y | ||
88 | CONFIG_FUTEX=y | ||
89 | CONFIG_EPOLL=y | ||
90 | CONFIG_SIGNALFD=y | ||
91 | CONFIG_TIMERFD=y | ||
92 | CONFIG_EVENTFD=y | ||
93 | CONFIG_SHMEM=y | ||
94 | CONFIG_AIO=y | ||
95 | CONFIG_VM_EVENT_COUNTERS=y | ||
96 | # CONFIG_COMPAT_BRK is not set | ||
97 | # CONFIG_SLAB is not set | ||
98 | CONFIG_SLUB=y | ||
99 | # CONFIG_SLOB is not set | ||
100 | CONFIG_PROFILING=y | ||
101 | CONFIG_TRACEPOINTS=y | ||
102 | # CONFIG_MARKERS is not set | ||
103 | CONFIG_OPROFILE=y | ||
104 | CONFIG_HAVE_OPROFILE=y | ||
105 | CONFIG_HAVE_IOREMAP_PROT=y | ||
106 | CONFIG_HAVE_KPROBES=y | ||
107 | CONFIG_HAVE_KRETPROBES=y | ||
108 | CONFIG_HAVE_ARCH_TRACEHOOK=y | ||
109 | CONFIG_HAVE_CLK=y | ||
110 | CONFIG_HAVE_DMA_API_DEBUG=y | ||
111 | # CONFIG_SLOW_WORK is not set | ||
112 | CONFIG_HAVE_GENERIC_DMA_COHERENT=y | ||
113 | CONFIG_RT_MUTEXES=y | ||
114 | CONFIG_BASE_SMALL=0 | ||
115 | # CONFIG_MODULES is not set | ||
116 | CONFIG_BLOCK=y | ||
117 | # CONFIG_LBD is not set | ||
118 | # CONFIG_BLK_DEV_BSG is not set | ||
119 | # CONFIG_BLK_DEV_INTEGRITY is not set | ||
120 | |||
121 | # | ||
122 | # IO Schedulers | ||
123 | # | ||
124 | CONFIG_IOSCHED_NOOP=y | ||
125 | CONFIG_IOSCHED_AS=y | ||
126 | CONFIG_IOSCHED_DEADLINE=y | ||
127 | CONFIG_IOSCHED_CFQ=y | ||
128 | CONFIG_DEFAULT_AS=y | ||
129 | # CONFIG_DEFAULT_DEADLINE is not set | ||
130 | # CONFIG_DEFAULT_CFQ is not set | ||
131 | # CONFIG_DEFAULT_NOOP is not set | ||
132 | CONFIG_DEFAULT_IOSCHED="anticipatory" | ||
133 | CONFIG_FREEZER=y | ||
134 | |||
135 | # | ||
136 | # System type | ||
137 | # | ||
138 | CONFIG_CPU_SH4=y | ||
139 | CONFIG_CPU_SH4A=y | ||
140 | # CONFIG_CPU_SUBTYPE_SH7619 is not set | ||
141 | # CONFIG_CPU_SUBTYPE_SH7201 is not set | ||
142 | # CONFIG_CPU_SUBTYPE_SH7203 is not set | ||
143 | # CONFIG_CPU_SUBTYPE_SH7206 is not set | ||
144 | # CONFIG_CPU_SUBTYPE_SH7263 is not set | ||
145 | # CONFIG_CPU_SUBTYPE_MXG is not set | ||
146 | # CONFIG_CPU_SUBTYPE_SH7705 is not set | ||
147 | # CONFIG_CPU_SUBTYPE_SH7706 is not set | ||
148 | # CONFIG_CPU_SUBTYPE_SH7707 is not set | ||
149 | # CONFIG_CPU_SUBTYPE_SH7708 is not set | ||
150 | # CONFIG_CPU_SUBTYPE_SH7709 is not set | ||
151 | # CONFIG_CPU_SUBTYPE_SH7710 is not set | ||
152 | # CONFIG_CPU_SUBTYPE_SH7712 is not set | ||
153 | # CONFIG_CPU_SUBTYPE_SH7720 is not set | ||
154 | # CONFIG_CPU_SUBTYPE_SH7721 is not set | ||
155 | # CONFIG_CPU_SUBTYPE_SH7750 is not set | ||
156 | # CONFIG_CPU_SUBTYPE_SH7091 is not set | ||
157 | # CONFIG_CPU_SUBTYPE_SH7750R is not set | ||
158 | # CONFIG_CPU_SUBTYPE_SH7750S is not set | ||
159 | # CONFIG_CPU_SUBTYPE_SH7751 is not set | ||
160 | # CONFIG_CPU_SUBTYPE_SH7751R is not set | ||
161 | # CONFIG_CPU_SUBTYPE_SH7760 is not set | ||
162 | # CONFIG_CPU_SUBTYPE_SH4_202 is not set | ||
163 | # CONFIG_CPU_SUBTYPE_SH7723 is not set | ||
164 | # CONFIG_CPU_SUBTYPE_SH7724 is not set | ||
165 | # CONFIG_CPU_SUBTYPE_SH7763 is not set | ||
166 | CONFIG_CPU_SUBTYPE_SH7770=y | ||
167 | # CONFIG_CPU_SUBTYPE_SH7780 is not set | ||
168 | # CONFIG_CPU_SUBTYPE_SH7785 is not set | ||
169 | # CONFIG_CPU_SUBTYPE_SH7786 is not set | ||
170 | # CONFIG_CPU_SUBTYPE_SHX3 is not set | ||
171 | # CONFIG_CPU_SUBTYPE_SH7343 is not set | ||
172 | # CONFIG_CPU_SUBTYPE_SH7722 is not set | ||
173 | # CONFIG_CPU_SUBTYPE_SH7366 is not set | ||
174 | |||
175 | # | ||
176 | # Memory management options | ||
177 | # | ||
178 | CONFIG_QUICKLIST=y | ||
179 | CONFIG_MMU=y | ||
180 | CONFIG_PAGE_OFFSET=0x80000000 | ||
181 | CONFIG_MEMORY_START=0x08000000 | ||
182 | CONFIG_MEMORY_SIZE=0x04000000 | ||
183 | CONFIG_29BIT=y | ||
184 | CONFIG_VSYSCALL=y | ||
185 | CONFIG_ARCH_FLATMEM_ENABLE=y | ||
186 | CONFIG_ARCH_SPARSEMEM_ENABLE=y | ||
187 | CONFIG_ARCH_SPARSEMEM_DEFAULT=y | ||
188 | CONFIG_MAX_ACTIVE_REGIONS=1 | ||
189 | CONFIG_ARCH_POPULATES_NODE_MAP=y | ||
190 | CONFIG_ARCH_SELECT_MEMORY_MODEL=y | ||
191 | CONFIG_ARCH_ENABLE_MEMORY_HOTPLUG=y | ||
192 | CONFIG_ARCH_ENABLE_MEMORY_HOTREMOVE=y | ||
193 | CONFIG_PAGE_SIZE_4KB=y | ||
194 | # CONFIG_PAGE_SIZE_8KB is not set | ||
195 | # CONFIG_PAGE_SIZE_16KB is not set | ||
196 | # CONFIG_PAGE_SIZE_64KB is not set | ||
197 | CONFIG_SELECT_MEMORY_MODEL=y | ||
198 | # CONFIG_FLATMEM_MANUAL is not set | ||
199 | # CONFIG_DISCONTIGMEM_MANUAL is not set | ||
200 | CONFIG_SPARSEMEM_MANUAL=y | ||
201 | CONFIG_SPARSEMEM=y | ||
202 | CONFIG_HAVE_MEMORY_PRESENT=y | ||
203 | CONFIG_SPARSEMEM_STATIC=y | ||
204 | |||
205 | # | ||
206 | # Memory hotplug is currently incompatible with Software Suspend | ||
207 | # | ||
208 | CONFIG_PAGEFLAGS_EXTENDED=y | ||
209 | CONFIG_SPLIT_PTLOCK_CPUS=4 | ||
210 | CONFIG_MIGRATION=y | ||
211 | # CONFIG_PHYS_ADDR_T_64BIT is not set | ||
212 | CONFIG_ZONE_DMA_FLAG=0 | ||
213 | CONFIG_NR_QUICK=2 | ||
214 | CONFIG_UNEVICTABLE_LRU=y | ||
215 | CONFIG_HAVE_MLOCK=y | ||
216 | CONFIG_HAVE_MLOCKED_PAGE_BIT=y | ||
217 | |||
218 | # | ||
219 | # Cache configuration | ||
220 | # | ||
221 | CONFIG_CACHE_WRITEBACK=y | ||
222 | # CONFIG_CACHE_WRITETHROUGH is not set | ||
223 | # CONFIG_CACHE_OFF is not set | ||
224 | |||
225 | # | ||
226 | # Processor features | ||
227 | # | ||
228 | CONFIG_CPU_LITTLE_ENDIAN=y | ||
229 | # CONFIG_CPU_BIG_ENDIAN is not set | ||
230 | CONFIG_SH_FPU=y | ||
231 | # CONFIG_SH_STORE_QUEUES is not set | ||
232 | CONFIG_CPU_HAS_INTEVT=y | ||
233 | CONFIG_CPU_HAS_SR_RB=y | ||
234 | CONFIG_CPU_HAS_FPU=y | ||
235 | |||
236 | # | ||
237 | # Board support | ||
238 | # | ||
239 | |||
240 | # | ||
241 | # Timer and clock configuration | ||
242 | # | ||
243 | CONFIG_SH_TMU=y | ||
244 | CONFIG_SH_TIMER_IRQ=16 | ||
245 | CONFIG_SH_PCLK_FREQ=41666666 | ||
246 | CONFIG_TICK_ONESHOT=y | ||
247 | CONFIG_NO_HZ=y | ||
248 | CONFIG_HIGH_RES_TIMERS=y | ||
249 | CONFIG_GENERIC_CLOCKEVENTS_BUILD=y | ||
250 | |||
251 | # | ||
252 | # CPU Frequency scaling | ||
253 | # | ||
254 | CONFIG_CPU_FREQ=y | ||
255 | CONFIG_CPU_FREQ_TABLE=y | ||
256 | # CONFIG_CPU_FREQ_DEBUG is not set | ||
257 | CONFIG_CPU_FREQ_STAT=y | ||
258 | # CONFIG_CPU_FREQ_STAT_DETAILS is not set | ||
259 | CONFIG_CPU_FREQ_DEFAULT_GOV_PERFORMANCE=y | ||
260 | # CONFIG_CPU_FREQ_DEFAULT_GOV_POWERSAVE is not set | ||
261 | # CONFIG_CPU_FREQ_DEFAULT_GOV_USERSPACE is not set | ||
262 | # CONFIG_CPU_FREQ_DEFAULT_GOV_ONDEMAND is not set | ||
263 | # CONFIG_CPU_FREQ_DEFAULT_GOV_CONSERVATIVE is not set | ||
264 | CONFIG_CPU_FREQ_GOV_PERFORMANCE=y | ||
265 | # CONFIG_CPU_FREQ_GOV_POWERSAVE is not set | ||
266 | # CONFIG_CPU_FREQ_GOV_USERSPACE is not set | ||
267 | # CONFIG_CPU_FREQ_GOV_ONDEMAND is not set | ||
268 | # CONFIG_CPU_FREQ_GOV_CONSERVATIVE is not set | ||
269 | CONFIG_SH_CPU_FREQ=y | ||
270 | |||
271 | # | ||
272 | # DMA support | ||
273 | # | ||
274 | # CONFIG_SH_DMA is not set | ||
275 | |||
276 | # | ||
277 | # Companion Chips | ||
278 | # | ||
279 | |||
280 | # | ||
281 | # Additional SuperH Device Drivers | ||
282 | # | ||
283 | # CONFIG_HEARTBEAT is not set | ||
284 | # CONFIG_PUSH_SWITCH is not set | ||
285 | |||
286 | # | ||
287 | # Kernel features | ||
288 | # | ||
289 | # CONFIG_HZ_100 is not set | ||
290 | CONFIG_HZ_250=y | ||
291 | # CONFIG_HZ_300 is not set | ||
292 | # CONFIG_HZ_1000 is not set | ||
293 | CONFIG_HZ=250 | ||
294 | CONFIG_SCHED_HRTICK=y | ||
295 | CONFIG_KEXEC=y | ||
296 | # CONFIG_CRASH_DUMP is not set | ||
297 | CONFIG_KEXEC_JUMP=y | ||
298 | CONFIG_PREEMPT_NONE=y | ||
299 | # CONFIG_PREEMPT_VOLUNTARY is not set | ||
300 | # CONFIG_PREEMPT is not set | ||
301 | CONFIG_GUSA=y | ||
302 | |||
303 | # | ||
304 | # Boot options | ||
305 | # | ||
306 | CONFIG_ZERO_PAGE_OFFSET=0x00001000 | ||
307 | CONFIG_BOOT_LINK_OFFSET=0x00800000 | ||
308 | CONFIG_ENTRY_OFFSET=0x00001000 | ||
309 | # CONFIG_CMDLINE_BOOL is not set | ||
310 | |||
311 | # | ||
312 | # Bus options | ||
313 | # | ||
314 | # CONFIG_ARCH_SUPPORTS_MSI is not set | ||
315 | # CONFIG_PCCARD is not set | ||
316 | |||
317 | # | ||
318 | # Executable file formats | ||
319 | # | ||
320 | CONFIG_BINFMT_ELF=y | ||
321 | # CONFIG_CORE_DUMP_DEFAULT_ELF_HEADERS is not set | ||
322 | # CONFIG_HAVE_AOUT is not set | ||
323 | # CONFIG_BINFMT_MISC is not set | ||
324 | |||
325 | # | ||
326 | # Power management options (EXPERIMENTAL) | ||
327 | # | ||
328 | CONFIG_PM=y | ||
329 | # CONFIG_PM_DEBUG is not set | ||
330 | CONFIG_PM_SLEEP=y | ||
331 | CONFIG_HIBERNATION=y | ||
332 | CONFIG_PM_STD_PARTITION="" | ||
333 | CONFIG_CPU_IDLE=y | ||
334 | CONFIG_CPU_IDLE_GOV_LADDER=y | ||
335 | CONFIG_CPU_IDLE_GOV_MENU=y | ||
336 | # CONFIG_NET is not set | ||
337 | |||
338 | # | ||
339 | # Device Drivers | ||
340 | # | ||
341 | |||
342 | # | ||
343 | # Generic Driver Options | ||
344 | # | ||
345 | CONFIG_UEVENT_HELPER_PATH="/sbin/hotplug" | ||
346 | CONFIG_STANDALONE=y | ||
347 | # CONFIG_PREVENT_FIRMWARE_BUILD is not set | ||
348 | CONFIG_FW_LOADER=y | ||
349 | CONFIG_FIRMWARE_IN_KERNEL=y | ||
350 | CONFIG_EXTRA_FIRMWARE="" | ||
351 | # CONFIG_SYS_HYPERVISOR is not set | ||
352 | # CONFIG_MTD is not set | ||
353 | # CONFIG_PARPORT is not set | ||
354 | CONFIG_BLK_DEV=y | ||
355 | # CONFIG_BLK_DEV_COW_COMMON is not set | ||
356 | # CONFIG_BLK_DEV_LOOP is not set | ||
357 | # CONFIG_BLK_DEV_RAM is not set | ||
358 | # CONFIG_CDROM_PKTCDVD is not set | ||
359 | # CONFIG_BLK_DEV_HD is not set | ||
360 | # CONFIG_MISC_DEVICES is not set | ||
361 | CONFIG_HAVE_IDE=y | ||
362 | # CONFIG_IDE is not set | ||
363 | |||
364 | # | ||
365 | # SCSI device support | ||
366 | # | ||
367 | # CONFIG_RAID_ATTRS is not set | ||
368 | # CONFIG_SCSI is not set | ||
369 | # CONFIG_SCSI_DMA is not set | ||
370 | # CONFIG_SCSI_NETLINK is not set | ||
371 | # CONFIG_ATA is not set | ||
372 | # CONFIG_MD is not set | ||
373 | # CONFIG_PHONE is not set | ||
374 | |||
375 | # | ||
376 | # Input device support | ||
377 | # | ||
378 | # CONFIG_INPUT is not set | ||
379 | |||
380 | # | ||
381 | # Hardware I/O ports | ||
382 | # | ||
383 | # CONFIG_SERIO is not set | ||
384 | # CONFIG_GAMEPORT is not set | ||
385 | |||
386 | # | ||
387 | # Character devices | ||
388 | # | ||
389 | # CONFIG_VT is not set | ||
390 | # CONFIG_DEVKMEM is not set | ||
391 | # CONFIG_SERIAL_NONSTANDARD is not set | ||
392 | |||
393 | # | ||
394 | # Serial drivers | ||
395 | # | ||
396 | # CONFIG_SERIAL_8250 is not set | ||
397 | |||
398 | # | ||
399 | # Non-8250 serial port support | ||
400 | # | ||
401 | CONFIG_SERIAL_SH_SCI=y | ||
402 | CONFIG_SERIAL_SH_SCI_NR_UARTS=6 | ||
403 | CONFIG_SERIAL_SH_SCI_CONSOLE=y | ||
404 | CONFIG_SERIAL_CORE=y | ||
405 | CONFIG_SERIAL_CORE_CONSOLE=y | ||
406 | # CONFIG_UNIX98_PTYS is not set | ||
407 | # CONFIG_LEGACY_PTYS is not set | ||
408 | # CONFIG_IPMI_HANDLER is not set | ||
409 | # CONFIG_HW_RANDOM is not set | ||
410 | # CONFIG_R3964 is not set | ||
411 | # CONFIG_RAW_DRIVER is not set | ||
412 | # CONFIG_TCG_TPM is not set | ||
413 | CONFIG_I2C=y | ||
414 | CONFIG_I2C_BOARDINFO=y | ||
415 | CONFIG_I2C_CHARDEV=y | ||
416 | CONFIG_I2C_HELPER_AUTO=y | ||
417 | |||
418 | # | ||
419 | # I2C Hardware Bus support | ||
420 | # | ||
421 | |||
422 | # | ||
423 | # I2C system bus drivers (mostly embedded / system-on-chip) | ||
424 | # | ||
425 | # CONFIG_I2C_OCORES is not set | ||
426 | CONFIG_I2C_SH_MOBILE=y | ||
427 | # CONFIG_I2C_SIMTEC is not set | ||
428 | |||
429 | # | ||
430 | # External I2C/SMBus adapter drivers | ||
431 | # | ||
432 | # CONFIG_I2C_PARPORT_LIGHT is not set | ||
433 | # CONFIG_I2C_TAOS_EVM is not set | ||
434 | |||
435 | # | ||
436 | # Other I2C/SMBus bus drivers | ||
437 | # | ||
438 | # CONFIG_I2C_PCA_PLATFORM is not set | ||
439 | |||
440 | # | ||
441 | # Miscellaneous I2C Chip support | ||
442 | # | ||
443 | # CONFIG_DS1682 is not set | ||
444 | # CONFIG_SENSORS_PCF8574 is not set | ||
445 | # CONFIG_PCF8575 is not set | ||
446 | # CONFIG_SENSORS_PCA9539 is not set | ||
447 | # CONFIG_SENSORS_MAX6875 is not set | ||
448 | # CONFIG_SENSORS_TSL2550 is not set | ||
449 | # CONFIG_I2C_DEBUG_CORE is not set | ||
450 | # CONFIG_I2C_DEBUG_ALGO is not set | ||
451 | # CONFIG_I2C_DEBUG_BUS is not set | ||
452 | # CONFIG_I2C_DEBUG_CHIP is not set | ||
453 | # CONFIG_SPI is not set | ||
454 | # CONFIG_W1 is not set | ||
455 | # CONFIG_POWER_SUPPLY is not set | ||
456 | # CONFIG_HWMON is not set | ||
457 | # CONFIG_THERMAL is not set | ||
458 | # CONFIG_THERMAL_HWMON is not set | ||
459 | # CONFIG_WATCHDOG is not set | ||
460 | CONFIG_SSB_POSSIBLE=y | ||
461 | |||
462 | # | ||
463 | # Sonics Silicon Backplane | ||
464 | # | ||
465 | # CONFIG_SSB is not set | ||
466 | |||
467 | # | ||
468 | # Multifunction device drivers | ||
469 | # | ||
470 | # CONFIG_MFD_CORE is not set | ||
471 | # CONFIG_MFD_SM501 is not set | ||
472 | # CONFIG_HTC_PASIC3 is not set | ||
473 | # CONFIG_TWL4030_CORE is not set | ||
474 | # CONFIG_MFD_TMIO is not set | ||
475 | # CONFIG_PMIC_DA903X is not set | ||
476 | # CONFIG_MFD_WM8400 is not set | ||
477 | # CONFIG_MFD_WM8350_I2C is not set | ||
478 | # CONFIG_MFD_PCF50633 is not set | ||
479 | # CONFIG_REGULATOR is not set | ||
480 | |||
481 | # | ||
482 | # Multimedia devices | ||
483 | # | ||
484 | |||
485 | # | ||
486 | # Multimedia core support | ||
487 | # | ||
488 | # CONFIG_VIDEO_DEV is not set | ||
489 | # CONFIG_VIDEO_MEDIA is not set | ||
490 | |||
491 | # | ||
492 | # Multimedia drivers | ||
493 | # | ||
494 | # CONFIG_DAB is not set | ||
495 | |||
496 | # | ||
497 | # Graphics support | ||
498 | # | ||
499 | # CONFIG_VGASTATE is not set | ||
500 | # CONFIG_VIDEO_OUTPUT_CONTROL is not set | ||
501 | # CONFIG_FB is not set | ||
502 | # CONFIG_BACKLIGHT_LCD_SUPPORT is not set | ||
503 | |||
504 | # | ||
505 | # Display device support | ||
506 | # | ||
507 | # CONFIG_DISPLAY_SUPPORT is not set | ||
508 | # CONFIG_SOUND is not set | ||
509 | # CONFIG_USB_SUPPORT is not set | ||
510 | # CONFIG_MMC is not set | ||
511 | # CONFIG_MEMSTICK is not set | ||
512 | # CONFIG_NEW_LEDS is not set | ||
513 | # CONFIG_ACCESSIBILITY is not set | ||
514 | CONFIG_RTC_LIB=y | ||
515 | CONFIG_RTC_CLASS=y | ||
516 | CONFIG_RTC_HCTOSYS=y | ||
517 | CONFIG_RTC_HCTOSYS_DEVICE="rtc0" | ||
518 | # CONFIG_RTC_DEBUG is not set | ||
519 | |||
520 | # | ||
521 | # RTC interfaces | ||
522 | # | ||
523 | CONFIG_RTC_INTF_DEV=y | ||
524 | # CONFIG_RTC_INTF_DEV_UIE_EMUL is not set | ||
525 | # CONFIG_RTC_DRV_TEST is not set | ||
526 | |||
527 | # | ||
528 | # I2C RTC drivers | ||
529 | # | ||
530 | # CONFIG_RTC_DRV_DS1307 is not set | ||
531 | # CONFIG_RTC_DRV_DS1374 is not set | ||
532 | # CONFIG_RTC_DRV_DS1672 is not set | ||
533 | # CONFIG_RTC_DRV_MAX6900 is not set | ||
534 | # CONFIG_RTC_DRV_RS5C372 is not set | ||
535 | # CONFIG_RTC_DRV_ISL1208 is not set | ||
536 | # CONFIG_RTC_DRV_X1205 is not set | ||
537 | # CONFIG_RTC_DRV_PCF8563 is not set | ||
538 | # CONFIG_RTC_DRV_PCF8583 is not set | ||
539 | # CONFIG_RTC_DRV_M41T80 is not set | ||
540 | # CONFIG_RTC_DRV_S35390A is not set | ||
541 | # CONFIG_RTC_DRV_FM3130 is not set | ||
542 | # CONFIG_RTC_DRV_RX8581 is not set | ||
543 | |||
544 | # | ||
545 | # SPI RTC drivers | ||
546 | # | ||
547 | |||
548 | # | ||
549 | # Platform RTC drivers | ||
550 | # | ||
551 | # CONFIG_RTC_DRV_DS1286 is not set | ||
552 | # CONFIG_RTC_DRV_DS1511 is not set | ||
553 | # CONFIG_RTC_DRV_DS1553 is not set | ||
554 | # CONFIG_RTC_DRV_DS1742 is not set | ||
555 | # CONFIG_RTC_DRV_STK17TA8 is not set | ||
556 | # CONFIG_RTC_DRV_M48T86 is not set | ||
557 | # CONFIG_RTC_DRV_M48T35 is not set | ||
558 | # CONFIG_RTC_DRV_M48T59 is not set | ||
559 | # CONFIG_RTC_DRV_BQ4802 is not set | ||
560 | # CONFIG_RTC_DRV_V3020 is not set | ||
561 | |||
562 | # | ||
563 | # on-CPU RTC drivers | ||
564 | # | ||
565 | CONFIG_RTC_DRV_SH=y | ||
566 | # CONFIG_RTC_DRV_GENERIC is not set | ||
567 | # CONFIG_DMADEVICES is not set | ||
568 | # CONFIG_AUXDISPLAY is not set | ||
569 | CONFIG_UIO=y | ||
570 | # CONFIG_UIO_PDRV is not set | ||
571 | CONFIG_UIO_PDRV_GENIRQ=y | ||
572 | # CONFIG_UIO_SMX is not set | ||
573 | # CONFIG_UIO_SERCOS3 is not set | ||
574 | # CONFIG_STAGING is not set | ||
575 | |||
576 | # | ||
577 | # File systems | ||
578 | # | ||
579 | # CONFIG_EXT2_FS is not set | ||
580 | # CONFIG_EXT3_FS is not set | ||
581 | # CONFIG_EXT4_FS is not set | ||
582 | # CONFIG_REISERFS_FS is not set | ||
583 | # CONFIG_JFS_FS is not set | ||
584 | # CONFIG_FS_POSIX_ACL is not set | ||
585 | CONFIG_FILE_LOCKING=y | ||
586 | # CONFIG_XFS_FS is not set | ||
587 | # CONFIG_BTRFS_FS is not set | ||
588 | # CONFIG_DNOTIFY is not set | ||
589 | # CONFIG_INOTIFY is not set | ||
590 | # CONFIG_QUOTA is not set | ||
591 | # CONFIG_AUTOFS_FS is not set | ||
592 | # CONFIG_AUTOFS4_FS is not set | ||
593 | # CONFIG_FUSE_FS is not set | ||
594 | |||
595 | # | ||
596 | # Caches | ||
597 | # | ||
598 | # CONFIG_FSCACHE is not set | ||
599 | |||
600 | # | ||
601 | # CD-ROM/DVD Filesystems | ||
602 | # | ||
603 | # CONFIG_ISO9660_FS is not set | ||
604 | # CONFIG_UDF_FS is not set | ||
605 | |||
606 | # | ||
607 | # DOS/FAT/NT Filesystems | ||
608 | # | ||
609 | # CONFIG_MSDOS_FS is not set | ||
610 | # CONFIG_VFAT_FS is not set | ||
611 | # CONFIG_NTFS_FS is not set | ||
612 | |||
613 | # | ||
614 | # Pseudo filesystems | ||
615 | # | ||
616 | # CONFIG_PROC_FS is not set | ||
617 | # CONFIG_SYSFS is not set | ||
618 | # CONFIG_TMPFS is not set | ||
619 | # CONFIG_HUGETLBFS is not set | ||
620 | # CONFIG_HUGETLB_PAGE is not set | ||
621 | # CONFIG_MISC_FILESYSTEMS is not set | ||
622 | |||
623 | # | ||
624 | # Partition Types | ||
625 | # | ||
626 | # CONFIG_PARTITION_ADVANCED is not set | ||
627 | CONFIG_MSDOS_PARTITION=y | ||
628 | # CONFIG_NLS is not set | ||
629 | |||
630 | # | ||
631 | # Kernel hacking | ||
632 | # | ||
633 | CONFIG_TRACE_IRQFLAGS_SUPPORT=y | ||
634 | # CONFIG_PRINTK_TIME is not set | ||
635 | # CONFIG_ENABLE_WARN_DEPRECATED is not set | ||
636 | # CONFIG_ENABLE_MUST_CHECK is not set | ||
637 | CONFIG_FRAME_WARN=1024 | ||
638 | # CONFIG_MAGIC_SYSRQ is not set | ||
639 | # CONFIG_UNUSED_SYMBOLS is not set | ||
640 | CONFIG_DEBUG_FS=y | ||
641 | # CONFIG_HEADERS_CHECK is not set | ||
642 | # CONFIG_DEBUG_KERNEL is not set | ||
643 | CONFIG_STACKTRACE=y | ||
644 | # CONFIG_DEBUG_BUGVERBOSE is not set | ||
645 | # CONFIG_DEBUG_MEMORY_INIT is not set | ||
646 | # CONFIG_RCU_CPU_STALL_DETECTOR is not set | ||
647 | # CONFIG_LATENCYTOP is not set | ||
648 | # CONFIG_SYSCTL_SYSCALL_CHECK is not set | ||
649 | CONFIG_NOP_TRACER=y | ||
650 | CONFIG_HAVE_FUNCTION_TRACER=y | ||
651 | CONFIG_HAVE_DYNAMIC_FTRACE=y | ||
652 | CONFIG_HAVE_FTRACE_MCOUNT_RECORD=y | ||
653 | CONFIG_RING_BUFFER=y | ||
654 | CONFIG_TRACING=y | ||
655 | CONFIG_TRACING_SUPPORT=y | ||
656 | |||
657 | # | ||
658 | # Tracers | ||
659 | # | ||
660 | # CONFIG_FUNCTION_TRACER is not set | ||
661 | # CONFIG_IRQSOFF_TRACER is not set | ||
662 | # CONFIG_SCHED_TRACER is not set | ||
663 | # CONFIG_CONTEXT_SWITCH_TRACER is not set | ||
664 | # CONFIG_EVENT_TRACER is not set | ||
665 | # CONFIG_BOOT_TRACER is not set | ||
666 | # CONFIG_TRACE_BRANCH_PROFILING is not set | ||
667 | # CONFIG_STACK_TRACER is not set | ||
668 | # CONFIG_KMEMTRACE is not set | ||
669 | # CONFIG_WORKQUEUE_TRACER is not set | ||
670 | # CONFIG_FTRACE_STARTUP_TEST is not set | ||
671 | # CONFIG_DYNAMIC_DEBUG is not set | ||
672 | # CONFIG_DMA_API_DEBUG is not set | ||
673 | # CONFIG_SAMPLES is not set | ||
674 | CONFIG_HAVE_ARCH_KGDB=y | ||
675 | # CONFIG_SH_STANDARD_BIOS is not set | ||
676 | # CONFIG_EARLY_SCIF_CONSOLE is not set | ||
677 | |||
678 | # | ||
679 | # Security options | ||
680 | # | ||
681 | # CONFIG_KEYS is not set | ||
682 | # CONFIG_SECURITYFS is not set | ||
683 | # CONFIG_SECURITY_FILE_CAPABILITIES is not set | ||
684 | # CONFIG_CRYPTO is not set | ||
685 | CONFIG_BINARY_PRINTF=y | ||
686 | |||
687 | # | ||
688 | # Library routines | ||
689 | # | ||
690 | CONFIG_GENERIC_FIND_LAST_BIT=y | ||
691 | # CONFIG_CRC_CCITT is not set | ||
692 | # CONFIG_CRC16 is not set | ||
693 | # CONFIG_CRC_T10DIF is not set | ||
694 | # CONFIG_CRC_ITU_T is not set | ||
695 | # CONFIG_CRC32 is not set | ||
696 | # CONFIG_CRC7 is not set | ||
697 | # CONFIG_LIBCRC32C is not set | ||
698 | CONFIG_HAS_IOMEM=y | ||
699 | CONFIG_HAS_IOPORT=y | ||
700 | CONFIG_HAS_DMA=y | ||
diff --git a/arch/sh/include/asm/timer.h b/arch/sh/include/asm/timer.h deleted file mode 100644 index 6c0851188c00..000000000000 --- a/arch/sh/include/asm/timer.h +++ /dev/null | |||
@@ -1,29 +0,0 @@ | |||
1 | #ifndef __ASM_SH_TIMER_H | ||
2 | #define __ASM_SH_TIMER_H | ||
3 | |||
4 | #include <linux/sysdev.h> | ||
5 | #include <linux/clocksource.h> | ||
6 | #include <cpu/timer.h> | ||
7 | |||
8 | struct sys_timer_ops { | ||
9 | int (*init)(void); | ||
10 | int (*start)(void); | ||
11 | int (*stop)(void); | ||
12 | }; | ||
13 | |||
14 | struct sys_timer { | ||
15 | const char *name; | ||
16 | |||
17 | struct sys_device dev; | ||
18 | struct sys_timer_ops *ops; | ||
19 | }; | ||
20 | |||
21 | extern struct sys_timer tmu_timer; | ||
22 | extern struct sys_timer *sys_timer; | ||
23 | |||
24 | /* arch/sh/kernel/timers/timer.c */ | ||
25 | struct sys_timer *get_sys_timer(void); | ||
26 | |||
27 | extern struct clocksource clocksource_sh; | ||
28 | |||
29 | #endif /* __ASM_SH_TIMER_H */ | ||
diff --git a/arch/sh/include/cpu-sh3/cpu/timer.h b/arch/sh/include/cpu-sh3/cpu/timer.h deleted file mode 100644 index 793acf12aa08..000000000000 --- a/arch/sh/include/cpu-sh3/cpu/timer.h +++ /dev/null | |||
@@ -1,67 +0,0 @@ | |||
1 | /* | ||
2 | * include/asm-sh/cpu-sh3/timer.h | ||
3 | * | ||
4 | * Copyright (C) 2004 Lineo Solutions, Inc. | ||
5 | * | ||
6 | * This file is subject to the terms and conditions of the GNU General Public | ||
7 | * License. See the file "COPYING" in the main directory of this archive | ||
8 | * for more details. | ||
9 | */ | ||
10 | #ifndef __ASM_CPU_SH3_TIMER_H | ||
11 | #define __ASM_CPU_SH3_TIMER_H | ||
12 | |||
13 | /* | ||
14 | * --------------------------------------------------------------------------- | ||
15 | * TMU Common definitions for SH3 processors | ||
16 | * SH7706 | ||
17 | * SH7709S | ||
18 | * SH7727 | ||
19 | * SH7729R | ||
20 | * SH7710 | ||
21 | * SH7720 | ||
22 | * SH7710 | ||
23 | * --------------------------------------------------------------------------- | ||
24 | */ | ||
25 | |||
26 | #if !defined(CONFIG_CPU_SUBTYPE_SH7720) && !defined(CONFIG_CPU_SUBTYPE_SH7721) | ||
27 | #define TMU_TOCR 0xfffffe90 /* Byte access */ | ||
28 | #endif | ||
29 | |||
30 | #if defined(CONFIG_CPU_SUBTYPE_SH7710) || \ | ||
31 | defined(CONFIG_CPU_SUBTYPE_SH7720) || \ | ||
32 | defined(CONFIG_CPU_SUBTYPE_SH7721) | ||
33 | #define TMU_012_TSTR 0xa412fe92 /* Byte access */ | ||
34 | |||
35 | #define TMU0_TCOR 0xa412fe94 /* Long access */ | ||
36 | #define TMU0_TCNT 0xa412fe98 /* Long access */ | ||
37 | #define TMU0_TCR 0xa412fe9c /* Word access */ | ||
38 | |||
39 | #define TMU1_TCOR 0xa412fea0 /* Long access */ | ||
40 | #define TMU1_TCNT 0xa412fea4 /* Long access */ | ||
41 | #define TMU1_TCR 0xa412fea8 /* Word access */ | ||
42 | |||
43 | #define TMU2_TCOR 0xa412feac /* Long access */ | ||
44 | #define TMU2_TCNT 0xa412feb0 /* Long access */ | ||
45 | #define TMU2_TCR 0xa412feb4 /* Word access */ | ||
46 | |||
47 | #else | ||
48 | #define TMU_012_TSTR 0xfffffe92 /* Byte access */ | ||
49 | |||
50 | #define TMU0_TCOR 0xfffffe94 /* Long access */ | ||
51 | #define TMU0_TCNT 0xfffffe98 /* Long access */ | ||
52 | #define TMU0_TCR 0xfffffe9c /* Word access */ | ||
53 | |||
54 | #define TMU1_TCOR 0xfffffea0 /* Long access */ | ||
55 | #define TMU1_TCNT 0xfffffea4 /* Long access */ | ||
56 | #define TMU1_TCR 0xfffffea8 /* Word access */ | ||
57 | |||
58 | #define TMU2_TCOR 0xfffffeac /* Long access */ | ||
59 | #define TMU2_TCNT 0xfffffeb0 /* Long access */ | ||
60 | #define TMU2_TCR 0xfffffeb4 /* Word access */ | ||
61 | #if !defined(CONFIG_CPU_SUBTYPE_SH7720) && !defined(CONFIG_CPU_SUBTYPE_SH7721) | ||
62 | #define TMU2_TCPR2 0xfffffeb8 /* Long access */ | ||
63 | #endif | ||
64 | #endif | ||
65 | |||
66 | #endif /* __ASM_CPU_SH3_TIMER_H */ | ||
67 | |||
diff --git a/arch/sh/include/cpu-sh4/cpu/timer.h b/arch/sh/include/cpu-sh4/cpu/timer.h deleted file mode 100644 index d1e796b96888..000000000000 --- a/arch/sh/include/cpu-sh4/cpu/timer.h +++ /dev/null | |||
@@ -1,60 +0,0 @@ | |||
1 | /* | ||
2 | * include/asm-sh/cpu-sh4/timer.h | ||
3 | * | ||
4 | * Copyright (C) 2004 Lineo Solutions, Inc. | ||
5 | * | ||
6 | * This file is subject to the terms and conditions of the GNU General Public | ||
7 | * License. See the file "COPYING" in the main directory of this archive | ||
8 | * for more details. | ||
9 | */ | ||
10 | #ifndef __ASM_CPU_SH4_TIMER_H | ||
11 | #define __ASM_CPU_SH4_TIMER_H | ||
12 | |||
13 | /* | ||
14 | * --------------------------------------------------------------------------- | ||
15 | * TMU Common definitions for SH4 processors | ||
16 | * SH7750S/SH7750R | ||
17 | * SH7751/SH7751R | ||
18 | * SH7760 | ||
19 | * SH-X3 | ||
20 | * --------------------------------------------------------------------------- | ||
21 | */ | ||
22 | #ifdef CONFIG_CPU_SUBTYPE_SHX3 | ||
23 | #define TMU_012_BASE 0xffc10000 | ||
24 | #define TMU_345_BASE 0xffc20000 | ||
25 | #else | ||
26 | #define TMU_012_BASE 0xffd80000 | ||
27 | #define TMU_345_BASE 0xfe100000 | ||
28 | #endif | ||
29 | |||
30 | #define TMU_TOCR TMU_012_BASE /* Not supported on all CPUs */ | ||
31 | |||
32 | #define TMU_012_TSTR (TMU_012_BASE + 0x04) | ||
33 | #define TMU_345_TSTR (TMU_345_BASE + 0x04) | ||
34 | |||
35 | #define TMU0_TCOR (TMU_012_BASE + 0x08) | ||
36 | #define TMU0_TCNT (TMU_012_BASE + 0x0c) | ||
37 | #define TMU0_TCR (TMU_012_BASE + 0x10) | ||
38 | |||
39 | #define TMU1_TCOR (TMU_012_BASE + 0x14) | ||
40 | #define TMU1_TCNT (TMU_012_BASE + 0x18) | ||
41 | #define TMU1_TCR (TMU_012_BASE + 0x1c) | ||
42 | |||
43 | #define TMU2_TCOR (TMU_012_BASE + 0x20) | ||
44 | #define TMU2_TCNT (TMU_012_BASE + 0x24) | ||
45 | #define TMU2_TCR (TMU_012_BASE + 0x28) | ||
46 | #define TMU2_TCPR (TMU_012_BASE + 0x2c) | ||
47 | |||
48 | #define TMU3_TCOR (TMU_345_BASE + 0x08) | ||
49 | #define TMU3_TCNT (TMU_345_BASE + 0x0c) | ||
50 | #define TMU3_TCR (TMU_345_BASE + 0x10) | ||
51 | |||
52 | #define TMU4_TCOR (TMU_345_BASE + 0x14) | ||
53 | #define TMU4_TCNT (TMU_345_BASE + 0x18) | ||
54 | #define TMU4_TCR (TMU_345_BASE + 0x1c) | ||
55 | |||
56 | #define TMU5_TCOR (TMU_345_BASE + 0x20) | ||
57 | #define TMU5_TCNT (TMU_345_BASE + 0x24) | ||
58 | #define TMU5_TCR (TMU_345_BASE + 0x28) | ||
59 | |||
60 | #endif /* __ASM_CPU_SH4_TIMER_H */ | ||
diff --git a/arch/sh/kernel/Makefile_32 b/arch/sh/kernel/Makefile_32 index aee08afe5ff7..9411e3e31e68 100644 --- a/arch/sh/kernel/Makefile_32 +++ b/arch/sh/kernel/Makefile_32 | |||
@@ -14,7 +14,7 @@ obj-y := debugtraps.o idle.o io.o io_generic.o irq.o \ | |||
14 | sys_sh.o sys_sh32.o syscalls_32.o time.o topology.o \ | 14 | sys_sh.o sys_sh32.o syscalls_32.o time.o topology.o \ |
15 | traps.o traps_32.o | 15 | traps.o traps_32.o |
16 | 16 | ||
17 | obj-y += cpu/ timers/ | 17 | obj-y += cpu/ |
18 | obj-$(CONFIG_VSYSCALL) += vsyscall/ | 18 | obj-$(CONFIG_VSYSCALL) += vsyscall/ |
19 | obj-$(CONFIG_SMP) += smp.o | 19 | obj-$(CONFIG_SMP) += smp.o |
20 | obj-$(CONFIG_SH_STANDARD_BIOS) += sh_bios.o | 20 | obj-$(CONFIG_SH_STANDARD_BIOS) += sh_bios.o |
diff --git a/arch/sh/kernel/Makefile_64 b/arch/sh/kernel/Makefile_64 index c845a0d61979..67b9f6c6326b 100644 --- a/arch/sh/kernel/Makefile_64 +++ b/arch/sh/kernel/Makefile_64 | |||
@@ -4,7 +4,7 @@ obj-y := debugtraps.o idle.o io.o io_generic.o irq.o machvec.o process_64.o \ | |||
4 | ptrace_64.o setup.o signal_64.o sys_sh.o sys_sh64.o \ | 4 | ptrace_64.o setup.o signal_64.o sys_sh.o sys_sh64.o \ |
5 | syscalls_64.o time.o topology.o traps.o traps_64.o | 5 | syscalls_64.o time.o topology.o traps.o traps_64.o |
6 | 6 | ||
7 | obj-y += cpu/ timers/ | 7 | obj-y += cpu/ |
8 | obj-$(CONFIG_SMP) += smp.o | 8 | obj-$(CONFIG_SMP) += smp.o |
9 | obj-$(CONFIG_SH_CPU_FREQ) += cpufreq.o | 9 | obj-$(CONFIG_SH_CPU_FREQ) += cpufreq.o |
10 | obj-$(CONFIG_MODULES) += sh_ksyms_64.o module.o | 10 | obj-$(CONFIG_MODULES) += sh_ksyms_64.o module.o |
diff --git a/arch/sh/kernel/cpu/clock.c b/arch/sh/kernel/cpu/clock.c index f833843a194a..61ff227561dc 100644 --- a/arch/sh/kernel/cpu/clock.c +++ b/arch/sh/kernel/cpu/clock.c | |||
@@ -30,7 +30,6 @@ | |||
30 | #include <linux/platform_device.h> | 30 | #include <linux/platform_device.h> |
31 | #include <linux/proc_fs.h> | 31 | #include <linux/proc_fs.h> |
32 | #include <asm/clock.h> | 32 | #include <asm/clock.h> |
33 | #include <asm/timer.h> | ||
34 | 33 | ||
35 | static LIST_HEAD(clock_list); | 34 | static LIST_HEAD(clock_list); |
36 | static DEFINE_SPINLOCK(clock_lock); | 35 | static DEFINE_SPINLOCK(clock_lock); |
diff --git a/arch/sh/kernel/cpu/sh3/setup-sh7705.c b/arch/sh/kernel/cpu/sh3/setup-sh7705.c index 63b67badd67e..39513664d5d7 100644 --- a/arch/sh/kernel/cpu/sh3/setup-sh7705.c +++ b/arch/sh/kernel/cpu/sh3/setup-sh7705.c | |||
@@ -13,6 +13,7 @@ | |||
13 | #include <linux/irq.h> | 13 | #include <linux/irq.h> |
14 | #include <linux/serial.h> | 14 | #include <linux/serial.h> |
15 | #include <linux/serial_sci.h> | 15 | #include <linux/serial_sci.h> |
16 | #include <linux/sh_timer.h> | ||
16 | #include <asm/rtc.h> | 17 | #include <asm/rtc.h> |
17 | 18 | ||
18 | enum { | 19 | enum { |
@@ -116,7 +117,102 @@ static struct platform_device rtc_device = { | |||
116 | }, | 117 | }, |
117 | }; | 118 | }; |
118 | 119 | ||
120 | static struct sh_timer_config tmu0_platform_data = { | ||
121 | .name = "TMU0", | ||
122 | .channel_offset = 0x02, | ||
123 | .timer_bit = 0, | ||
124 | .clk = "module_clk", | ||
125 | .clockevent_rating = 200, | ||
126 | }; | ||
127 | |||
128 | static struct resource tmu0_resources[] = { | ||
129 | [0] = { | ||
130 | .name = "TMU0", | ||
131 | .start = 0xfffffe94, | ||
132 | .end = 0xfffffe9f, | ||
133 | .flags = IORESOURCE_MEM, | ||
134 | }, | ||
135 | [1] = { | ||
136 | .start = 16, | ||
137 | .flags = IORESOURCE_IRQ, | ||
138 | }, | ||
139 | }; | ||
140 | |||
141 | static struct platform_device tmu0_device = { | ||
142 | .name = "sh_tmu", | ||
143 | .id = 0, | ||
144 | .dev = { | ||
145 | .platform_data = &tmu0_platform_data, | ||
146 | }, | ||
147 | .resource = tmu0_resources, | ||
148 | .num_resources = ARRAY_SIZE(tmu0_resources), | ||
149 | }; | ||
150 | |||
151 | static struct sh_timer_config tmu1_platform_data = { | ||
152 | .name = "TMU1", | ||
153 | .channel_offset = 0xe, | ||
154 | .timer_bit = 1, | ||
155 | .clk = "module_clk", | ||
156 | .clocksource_rating = 200, | ||
157 | }; | ||
158 | |||
159 | static struct resource tmu1_resources[] = { | ||
160 | [0] = { | ||
161 | .name = "TMU1", | ||
162 | .start = 0xfffffea0, | ||
163 | .end = 0xfffffeab, | ||
164 | .flags = IORESOURCE_MEM, | ||
165 | }, | ||
166 | [1] = { | ||
167 | .start = 17, | ||
168 | .flags = IORESOURCE_IRQ, | ||
169 | }, | ||
170 | }; | ||
171 | |||
172 | static struct platform_device tmu1_device = { | ||
173 | .name = "sh_tmu", | ||
174 | .id = 1, | ||
175 | .dev = { | ||
176 | .platform_data = &tmu1_platform_data, | ||
177 | }, | ||
178 | .resource = tmu1_resources, | ||
179 | .num_resources = ARRAY_SIZE(tmu1_resources), | ||
180 | }; | ||
181 | |||
182 | static struct sh_timer_config tmu2_platform_data = { | ||
183 | .name = "TMU2", | ||
184 | .channel_offset = 0x1a, | ||
185 | .timer_bit = 2, | ||
186 | .clk = "module_clk", | ||
187 | }; | ||
188 | |||
189 | static struct resource tmu2_resources[] = { | ||
190 | [0] = { | ||
191 | .name = "TMU2", | ||
192 | .start = 0xfffffeac, | ||
193 | .end = 0xfffffebb, | ||
194 | .flags = IORESOURCE_MEM, | ||
195 | }, | ||
196 | [1] = { | ||
197 | .start = 18, | ||
198 | .flags = IORESOURCE_IRQ, | ||
199 | }, | ||
200 | }; | ||
201 | |||
202 | static struct platform_device tmu2_device = { | ||
203 | .name = "sh_tmu", | ||
204 | .id = 2, | ||
205 | .dev = { | ||
206 | .platform_data = &tmu2_platform_data, | ||
207 | }, | ||
208 | .resource = tmu2_resources, | ||
209 | .num_resources = ARRAY_SIZE(tmu2_resources), | ||
210 | }; | ||
211 | |||
119 | static struct platform_device *sh7705_devices[] __initdata = { | 212 | static struct platform_device *sh7705_devices[] __initdata = { |
213 | &tmu0_device, | ||
214 | &tmu1_device, | ||
215 | &tmu2_device, | ||
120 | &sci_device, | 216 | &sci_device, |
121 | &rtc_device, | 217 | &rtc_device, |
122 | }; | 218 | }; |
@@ -128,6 +224,18 @@ static int __init sh7705_devices_setup(void) | |||
128 | } | 224 | } |
129 | __initcall(sh7705_devices_setup); | 225 | __initcall(sh7705_devices_setup); |
130 | 226 | ||
227 | static struct platform_device *sh7705_early_devices[] __initdata = { | ||
228 | &tmu0_device, | ||
229 | &tmu1_device, | ||
230 | &tmu2_device, | ||
231 | }; | ||
232 | |||
233 | void __init plat_early_device_setup(void) | ||
234 | { | ||
235 | early_platform_add_devices(sh7705_early_devices, | ||
236 | ARRAY_SIZE(sh7705_early_devices)); | ||
237 | } | ||
238 | |||
131 | void __init plat_irq_setup(void) | 239 | void __init plat_irq_setup(void) |
132 | { | 240 | { |
133 | register_intc_controller(&intc_desc); | 241 | register_intc_controller(&intc_desc); |
diff --git a/arch/sh/kernel/cpu/sh3/setup-sh770x.c b/arch/sh/kernel/cpu/sh3/setup-sh770x.c index a74f960b5e79..9412d915b84e 100644 --- a/arch/sh/kernel/cpu/sh3/setup-sh770x.c +++ b/arch/sh/kernel/cpu/sh3/setup-sh770x.c | |||
@@ -18,6 +18,7 @@ | |||
18 | #include <linux/platform_device.h> | 18 | #include <linux/platform_device.h> |
19 | #include <linux/serial.h> | 19 | #include <linux/serial.h> |
20 | #include <linux/serial_sci.h> | 20 | #include <linux/serial_sci.h> |
21 | #include <linux/sh_timer.h> | ||
21 | 22 | ||
22 | enum { | 23 | enum { |
23 | UNUSED = 0, | 24 | UNUSED = 0, |
@@ -144,7 +145,102 @@ static struct platform_device sci_device = { | |||
144 | }, | 145 | }, |
145 | }; | 146 | }; |
146 | 147 | ||
148 | static struct sh_timer_config tmu0_platform_data = { | ||
149 | .name = "TMU0", | ||
150 | .channel_offset = 0x02, | ||
151 | .timer_bit = 0, | ||
152 | .clk = "module_clk", | ||
153 | .clockevent_rating = 200, | ||
154 | }; | ||
155 | |||
156 | static struct resource tmu0_resources[] = { | ||
157 | [0] = { | ||
158 | .name = "TMU0", | ||
159 | .start = 0xfffffe94, | ||
160 | .end = 0xfffffe9f, | ||
161 | .flags = IORESOURCE_MEM, | ||
162 | }, | ||
163 | [1] = { | ||
164 | .start = 16, | ||
165 | .flags = IORESOURCE_IRQ, | ||
166 | }, | ||
167 | }; | ||
168 | |||
169 | static struct platform_device tmu0_device = { | ||
170 | .name = "sh_tmu", | ||
171 | .id = 0, | ||
172 | .dev = { | ||
173 | .platform_data = &tmu0_platform_data, | ||
174 | }, | ||
175 | .resource = tmu0_resources, | ||
176 | .num_resources = ARRAY_SIZE(tmu0_resources), | ||
177 | }; | ||
178 | |||
179 | static struct sh_timer_config tmu1_platform_data = { | ||
180 | .name = "TMU1", | ||
181 | .channel_offset = 0xe, | ||
182 | .timer_bit = 1, | ||
183 | .clk = "module_clk", | ||
184 | .clocksource_rating = 200, | ||
185 | }; | ||
186 | |||
187 | static struct resource tmu1_resources[] = { | ||
188 | [0] = { | ||
189 | .name = "TMU1", | ||
190 | .start = 0xfffffea0, | ||
191 | .end = 0xfffffeab, | ||
192 | .flags = IORESOURCE_MEM, | ||
193 | }, | ||
194 | [1] = { | ||
195 | .start = 17, | ||
196 | .flags = IORESOURCE_IRQ, | ||
197 | }, | ||
198 | }; | ||
199 | |||
200 | static struct platform_device tmu1_device = { | ||
201 | .name = "sh_tmu", | ||
202 | .id = 1, | ||
203 | .dev = { | ||
204 | .platform_data = &tmu1_platform_data, | ||
205 | }, | ||
206 | .resource = tmu1_resources, | ||
207 | .num_resources = ARRAY_SIZE(tmu1_resources), | ||
208 | }; | ||
209 | |||
210 | static struct sh_timer_config tmu2_platform_data = { | ||
211 | .name = "TMU2", | ||
212 | .channel_offset = 0x1a, | ||
213 | .timer_bit = 2, | ||
214 | .clk = "module_clk", | ||
215 | }; | ||
216 | |||
217 | static struct resource tmu2_resources[] = { | ||
218 | [0] = { | ||
219 | .name = "TMU2", | ||
220 | .start = 0xfffffeac, | ||
221 | .end = 0xfffffebb, | ||
222 | .flags = IORESOURCE_MEM, | ||
223 | }, | ||
224 | [1] = { | ||
225 | .start = 18, | ||
226 | .flags = IORESOURCE_IRQ, | ||
227 | }, | ||
228 | }; | ||
229 | |||
230 | static struct platform_device tmu2_device = { | ||
231 | .name = "sh_tmu", | ||
232 | .id = 2, | ||
233 | .dev = { | ||
234 | .platform_data = &tmu2_platform_data, | ||
235 | }, | ||
236 | .resource = tmu2_resources, | ||
237 | .num_resources = ARRAY_SIZE(tmu2_resources), | ||
238 | }; | ||
239 | |||
147 | static struct platform_device *sh770x_devices[] __initdata = { | 240 | static struct platform_device *sh770x_devices[] __initdata = { |
241 | &tmu0_device, | ||
242 | &tmu1_device, | ||
243 | &tmu2_device, | ||
148 | &sci_device, | 244 | &sci_device, |
149 | &rtc_device, | 245 | &rtc_device, |
150 | }; | 246 | }; |
@@ -156,6 +252,18 @@ static int __init sh770x_devices_setup(void) | |||
156 | } | 252 | } |
157 | __initcall(sh770x_devices_setup); | 253 | __initcall(sh770x_devices_setup); |
158 | 254 | ||
255 | static struct platform_device *sh770x_early_devices[] __initdata = { | ||
256 | &tmu0_device, | ||
257 | &tmu1_device, | ||
258 | &tmu2_device, | ||
259 | }; | ||
260 | |||
261 | void __init plat_early_device_setup(void) | ||
262 | { | ||
263 | early_platform_add_devices(sh770x_early_devices, | ||
264 | ARRAY_SIZE(sh770x_early_devices)); | ||
265 | } | ||
266 | |||
159 | void __init plat_irq_setup(void) | 267 | void __init plat_irq_setup(void) |
160 | { | 268 | { |
161 | register_intc_controller(&intc_desc); | 269 | register_intc_controller(&intc_desc); |
diff --git a/arch/sh/kernel/cpu/sh3/setup-sh7710.c b/arch/sh/kernel/cpu/sh3/setup-sh7710.c index 335098b66e2f..07ff38d055a7 100644 --- a/arch/sh/kernel/cpu/sh3/setup-sh7710.c +++ b/arch/sh/kernel/cpu/sh3/setup-sh7710.c | |||
@@ -13,6 +13,7 @@ | |||
13 | #include <linux/irq.h> | 13 | #include <linux/irq.h> |
14 | #include <linux/serial.h> | 14 | #include <linux/serial.h> |
15 | #include <linux/serial_sci.h> | 15 | #include <linux/serial_sci.h> |
16 | #include <linux/sh_timer.h> | ||
16 | #include <asm/rtc.h> | 17 | #include <asm/rtc.h> |
17 | 18 | ||
18 | enum { | 19 | enum { |
@@ -120,7 +121,102 @@ static struct platform_device sci_device = { | |||
120 | }, | 121 | }, |
121 | }; | 122 | }; |
122 | 123 | ||
124 | static struct sh_timer_config tmu0_platform_data = { | ||
125 | .name = "TMU0", | ||
126 | .channel_offset = 0x02, | ||
127 | .timer_bit = 0, | ||
128 | .clk = "module_clk", | ||
129 | .clockevent_rating = 200, | ||
130 | }; | ||
131 | |||
132 | static struct resource tmu0_resources[] = { | ||
133 | [0] = { | ||
134 | .name = "TMU0", | ||
135 | .start = 0xa412fe94, | ||
136 | .end = 0xa412fe9f, | ||
137 | .flags = IORESOURCE_MEM, | ||
138 | }, | ||
139 | [1] = { | ||
140 | .start = 16, | ||
141 | .flags = IORESOURCE_IRQ, | ||
142 | }, | ||
143 | }; | ||
144 | |||
145 | static struct platform_device tmu0_device = { | ||
146 | .name = "sh_tmu", | ||
147 | .id = 0, | ||
148 | .dev = { | ||
149 | .platform_data = &tmu0_platform_data, | ||
150 | }, | ||
151 | .resource = tmu0_resources, | ||
152 | .num_resources = ARRAY_SIZE(tmu0_resources), | ||
153 | }; | ||
154 | |||
155 | static struct sh_timer_config tmu1_platform_data = { | ||
156 | .name = "TMU1", | ||
157 | .channel_offset = 0xe, | ||
158 | .timer_bit = 1, | ||
159 | .clk = "module_clk", | ||
160 | .clocksource_rating = 200, | ||
161 | }; | ||
162 | |||
163 | static struct resource tmu1_resources[] = { | ||
164 | [0] = { | ||
165 | .name = "TMU1", | ||
166 | .start = 0xa412fea0, | ||
167 | .end = 0xa412feab, | ||
168 | .flags = IORESOURCE_MEM, | ||
169 | }, | ||
170 | [1] = { | ||
171 | .start = 17, | ||
172 | .flags = IORESOURCE_IRQ, | ||
173 | }, | ||
174 | }; | ||
175 | |||
176 | static struct platform_device tmu1_device = { | ||
177 | .name = "sh_tmu", | ||
178 | .id = 1, | ||
179 | .dev = { | ||
180 | .platform_data = &tmu1_platform_data, | ||
181 | }, | ||
182 | .resource = tmu1_resources, | ||
183 | .num_resources = ARRAY_SIZE(tmu1_resources), | ||
184 | }; | ||
185 | |||
186 | static struct sh_timer_config tmu2_platform_data = { | ||
187 | .name = "TMU2", | ||
188 | .channel_offset = 0x1a, | ||
189 | .timer_bit = 2, | ||
190 | .clk = "module_clk", | ||
191 | }; | ||
192 | |||
193 | static struct resource tmu2_resources[] = { | ||
194 | [0] = { | ||
195 | .name = "TMU2", | ||
196 | .start = 0xa412feac, | ||
197 | .end = 0xa412feb5, | ||
198 | .flags = IORESOURCE_MEM, | ||
199 | }, | ||
200 | [1] = { | ||
201 | .start = 18, | ||
202 | .flags = IORESOURCE_IRQ, | ||
203 | }, | ||
204 | }; | ||
205 | |||
206 | static struct platform_device tmu2_device = { | ||
207 | .name = "sh_tmu", | ||
208 | .id = 2, | ||
209 | .dev = { | ||
210 | .platform_data = &tmu2_platform_data, | ||
211 | }, | ||
212 | .resource = tmu2_resources, | ||
213 | .num_resources = ARRAY_SIZE(tmu2_resources), | ||
214 | }; | ||
215 | |||
123 | static struct platform_device *sh7710_devices[] __initdata = { | 216 | static struct platform_device *sh7710_devices[] __initdata = { |
217 | &tmu0_device, | ||
218 | &tmu1_device, | ||
219 | &tmu2_device, | ||
124 | &sci_device, | 220 | &sci_device, |
125 | &rtc_device, | 221 | &rtc_device, |
126 | }; | 222 | }; |
@@ -132,6 +228,18 @@ static int __init sh7710_devices_setup(void) | |||
132 | } | 228 | } |
133 | __initcall(sh7710_devices_setup); | 229 | __initcall(sh7710_devices_setup); |
134 | 230 | ||
231 | static struct platform_device *sh7710_early_devices[] __initdata = { | ||
232 | &tmu0_device, | ||
233 | &tmu1_device, | ||
234 | &tmu2_device, | ||
235 | }; | ||
236 | |||
237 | void __init plat_early_device_setup(void) | ||
238 | { | ||
239 | early_platform_add_devices(sh7710_early_devices, | ||
240 | ARRAY_SIZE(sh7710_early_devices)); | ||
241 | } | ||
242 | |||
135 | void __init plat_irq_setup(void) | 243 | void __init plat_irq_setup(void) |
136 | { | 244 | { |
137 | register_intc_controller(&intc_desc); | 245 | register_intc_controller(&intc_desc); |
diff --git a/arch/sh/kernel/cpu/sh3/setup-sh7720.c b/arch/sh/kernel/cpu/sh3/setup-sh7720.c index 003874a2fd2a..d8b46f5dff60 100644 --- a/arch/sh/kernel/cpu/sh3/setup-sh7720.c +++ b/arch/sh/kernel/cpu/sh3/setup-sh7720.c | |||
@@ -18,6 +18,7 @@ | |||
18 | #include <linux/serial.h> | 18 | #include <linux/serial.h> |
19 | #include <linux/io.h> | 19 | #include <linux/io.h> |
20 | #include <linux/serial_sci.h> | 20 | #include <linux/serial_sci.h> |
21 | #include <linux/sh_timer.h> | ||
21 | #include <asm/rtc.h> | 22 | #include <asm/rtc.h> |
22 | 23 | ||
23 | static struct resource rtc_resources[] = { | 24 | static struct resource rtc_resources[] = { |
@@ -123,7 +124,259 @@ static struct platform_device usbf_device = { | |||
123 | .resource = usbf_resources, | 124 | .resource = usbf_resources, |
124 | }; | 125 | }; |
125 | 126 | ||
127 | static struct sh_timer_config cmt0_platform_data = { | ||
128 | .name = "CMT0", | ||
129 | .channel_offset = 0x10, | ||
130 | .timer_bit = 0, | ||
131 | .clk = "module_clk", | ||
132 | .clockevent_rating = 125, | ||
133 | .clocksource_rating = 125, | ||
134 | }; | ||
135 | |||
136 | static struct resource cmt0_resources[] = { | ||
137 | [0] = { | ||
138 | .name = "CMT0", | ||
139 | .start = 0x044a0010, | ||
140 | .end = 0x044a001b, | ||
141 | .flags = IORESOURCE_MEM, | ||
142 | }, | ||
143 | [1] = { | ||
144 | .start = 104, | ||
145 | .flags = IORESOURCE_IRQ, | ||
146 | }, | ||
147 | }; | ||
148 | |||
149 | static struct platform_device cmt0_device = { | ||
150 | .name = "sh_cmt", | ||
151 | .id = 0, | ||
152 | .dev = { | ||
153 | .platform_data = &cmt0_platform_data, | ||
154 | }, | ||
155 | .resource = cmt0_resources, | ||
156 | .num_resources = ARRAY_SIZE(cmt0_resources), | ||
157 | }; | ||
158 | |||
159 | static struct sh_timer_config cmt1_platform_data = { | ||
160 | .name = "CMT1", | ||
161 | .channel_offset = 0x20, | ||
162 | .timer_bit = 1, | ||
163 | .clk = "module_clk", | ||
164 | }; | ||
165 | |||
166 | static struct resource cmt1_resources[] = { | ||
167 | [0] = { | ||
168 | .name = "CMT1", | ||
169 | .start = 0x044a0020, | ||
170 | .end = 0x044a002b, | ||
171 | .flags = IORESOURCE_MEM, | ||
172 | }, | ||
173 | [1] = { | ||
174 | .start = 104, | ||
175 | .flags = IORESOURCE_IRQ, | ||
176 | }, | ||
177 | }; | ||
178 | |||
179 | static struct platform_device cmt1_device = { | ||
180 | .name = "sh_cmt", | ||
181 | .id = 1, | ||
182 | .dev = { | ||
183 | .platform_data = &cmt1_platform_data, | ||
184 | }, | ||
185 | .resource = cmt1_resources, | ||
186 | .num_resources = ARRAY_SIZE(cmt1_resources), | ||
187 | }; | ||
188 | |||
189 | static struct sh_timer_config cmt2_platform_data = { | ||
190 | .name = "CMT2", | ||
191 | .channel_offset = 0x30, | ||
192 | .timer_bit = 2, | ||
193 | .clk = "module_clk", | ||
194 | }; | ||
195 | |||
196 | static struct resource cmt2_resources[] = { | ||
197 | [0] = { | ||
198 | .name = "CMT2", | ||
199 | .start = 0x044a0030, | ||
200 | .end = 0x044a003b, | ||
201 | .flags = IORESOURCE_MEM, | ||
202 | }, | ||
203 | [1] = { | ||
204 | .start = 104, | ||
205 | .flags = IORESOURCE_IRQ, | ||
206 | }, | ||
207 | }; | ||
208 | |||
209 | static struct platform_device cmt2_device = { | ||
210 | .name = "sh_cmt", | ||
211 | .id = 2, | ||
212 | .dev = { | ||
213 | .platform_data = &cmt2_platform_data, | ||
214 | }, | ||
215 | .resource = cmt2_resources, | ||
216 | .num_resources = ARRAY_SIZE(cmt2_resources), | ||
217 | }; | ||
218 | |||
219 | static struct sh_timer_config cmt3_platform_data = { | ||
220 | .name = "CMT3", | ||
221 | .channel_offset = 0x40, | ||
222 | .timer_bit = 3, | ||
223 | .clk = "module_clk", | ||
224 | }; | ||
225 | |||
226 | static struct resource cmt3_resources[] = { | ||
227 | [0] = { | ||
228 | .name = "CMT3", | ||
229 | .start = 0x044a0040, | ||
230 | .end = 0x044a004b, | ||
231 | .flags = IORESOURCE_MEM, | ||
232 | }, | ||
233 | [1] = { | ||
234 | .start = 104, | ||
235 | .flags = IORESOURCE_IRQ, | ||
236 | }, | ||
237 | }; | ||
238 | |||
239 | static struct platform_device cmt3_device = { | ||
240 | .name = "sh_cmt", | ||
241 | .id = 3, | ||
242 | .dev = { | ||
243 | .platform_data = &cmt3_platform_data, | ||
244 | }, | ||
245 | .resource = cmt3_resources, | ||
246 | .num_resources = ARRAY_SIZE(cmt3_resources), | ||
247 | }; | ||
248 | |||
249 | static struct sh_timer_config cmt4_platform_data = { | ||
250 | .name = "CMT4", | ||
251 | .channel_offset = 0x50, | ||
252 | .timer_bit = 4, | ||
253 | .clk = "module_clk", | ||
254 | }; | ||
255 | |||
256 | static struct resource cmt4_resources[] = { | ||
257 | [0] = { | ||
258 | .name = "CMT4", | ||
259 | .start = 0x044a0050, | ||
260 | .end = 0x044a005b, | ||
261 | .flags = IORESOURCE_MEM, | ||
262 | }, | ||
263 | [1] = { | ||
264 | .start = 104, | ||
265 | .flags = IORESOURCE_IRQ, | ||
266 | }, | ||
267 | }; | ||
268 | |||
269 | static struct platform_device cmt4_device = { | ||
270 | .name = "sh_cmt", | ||
271 | .id = 4, | ||
272 | .dev = { | ||
273 | .platform_data = &cmt4_platform_data, | ||
274 | }, | ||
275 | .resource = cmt4_resources, | ||
276 | .num_resources = ARRAY_SIZE(cmt4_resources), | ||
277 | }; | ||
278 | |||
279 | static struct sh_timer_config tmu0_platform_data = { | ||
280 | .name = "TMU0", | ||
281 | .channel_offset = 0x02, | ||
282 | .timer_bit = 0, | ||
283 | .clk = "module_clk", | ||
284 | .clockevent_rating = 200, | ||
285 | }; | ||
286 | |||
287 | static struct resource tmu0_resources[] = { | ||
288 | [0] = { | ||
289 | .name = "TMU0", | ||
290 | .start = 0xa412fe94, | ||
291 | .end = 0xa412fe9f, | ||
292 | .flags = IORESOURCE_MEM, | ||
293 | }, | ||
294 | [1] = { | ||
295 | .start = 16, | ||
296 | .flags = IORESOURCE_IRQ, | ||
297 | }, | ||
298 | }; | ||
299 | |||
300 | static struct platform_device tmu0_device = { | ||
301 | .name = "sh_tmu", | ||
302 | .id = 0, | ||
303 | .dev = { | ||
304 | .platform_data = &tmu0_platform_data, | ||
305 | }, | ||
306 | .resource = tmu0_resources, | ||
307 | .num_resources = ARRAY_SIZE(tmu0_resources), | ||
308 | }; | ||
309 | |||
310 | static struct sh_timer_config tmu1_platform_data = { | ||
311 | .name = "TMU1", | ||
312 | .channel_offset = 0xe, | ||
313 | .timer_bit = 1, | ||
314 | .clk = "module_clk", | ||
315 | .clocksource_rating = 200, | ||
316 | }; | ||
317 | |||
318 | static struct resource tmu1_resources[] = { | ||
319 | [0] = { | ||
320 | .name = "TMU1", | ||
321 | .start = 0xa412fea0, | ||
322 | .end = 0xa412feab, | ||
323 | .flags = IORESOURCE_MEM, | ||
324 | }, | ||
325 | [1] = { | ||
326 | .start = 17, | ||
327 | .flags = IORESOURCE_IRQ, | ||
328 | }, | ||
329 | }; | ||
330 | |||
331 | static struct platform_device tmu1_device = { | ||
332 | .name = "sh_tmu", | ||
333 | .id = 1, | ||
334 | .dev = { | ||
335 | .platform_data = &tmu1_platform_data, | ||
336 | }, | ||
337 | .resource = tmu1_resources, | ||
338 | .num_resources = ARRAY_SIZE(tmu1_resources), | ||
339 | }; | ||
340 | |||
341 | static struct sh_timer_config tmu2_platform_data = { | ||
342 | .name = "TMU2", | ||
343 | .channel_offset = 0x1a, | ||
344 | .timer_bit = 2, | ||
345 | .clk = "module_clk", | ||
346 | }; | ||
347 | |||
348 | static struct resource tmu2_resources[] = { | ||
349 | [0] = { | ||
350 | .name = "TMU2", | ||
351 | .start = 0xa412feac, | ||
352 | .end = 0xa412feb5, | ||
353 | .flags = IORESOURCE_MEM, | ||
354 | }, | ||
355 | [1] = { | ||
356 | .start = 18, | ||
357 | .flags = IORESOURCE_IRQ, | ||
358 | }, | ||
359 | }; | ||
360 | |||
361 | static struct platform_device tmu2_device = { | ||
362 | .name = "sh_tmu", | ||
363 | .id = 2, | ||
364 | .dev = { | ||
365 | .platform_data = &tmu2_platform_data, | ||
366 | }, | ||
367 | .resource = tmu2_resources, | ||
368 | .num_resources = ARRAY_SIZE(tmu2_resources), | ||
369 | }; | ||
370 | |||
126 | static struct platform_device *sh7720_devices[] __initdata = { | 371 | static struct platform_device *sh7720_devices[] __initdata = { |
372 | &cmt0_device, | ||
373 | &cmt1_device, | ||
374 | &cmt2_device, | ||
375 | &cmt3_device, | ||
376 | &cmt4_device, | ||
377 | &tmu0_device, | ||
378 | &tmu1_device, | ||
379 | &tmu2_device, | ||
127 | &rtc_device, | 380 | &rtc_device, |
128 | &sci_device, | 381 | &sci_device, |
129 | &usb_ohci_device, | 382 | &usb_ohci_device, |
@@ -137,6 +390,23 @@ static int __init sh7720_devices_setup(void) | |||
137 | } | 390 | } |
138 | __initcall(sh7720_devices_setup); | 391 | __initcall(sh7720_devices_setup); |
139 | 392 | ||
393 | static struct platform_device *sh7720_early_devices[] __initdata = { | ||
394 | &cmt0_device, | ||
395 | &cmt1_device, | ||
396 | &cmt2_device, | ||
397 | &cmt3_device, | ||
398 | &cmt4_device, | ||
399 | &tmu0_device, | ||
400 | &tmu1_device, | ||
401 | &tmu2_device, | ||
402 | }; | ||
403 | |||
404 | void __init plat_early_device_setup(void) | ||
405 | { | ||
406 | early_platform_add_devices(sh7720_early_devices, | ||
407 | ARRAY_SIZE(sh7720_early_devices)); | ||
408 | } | ||
409 | |||
140 | enum { | 410 | enum { |
141 | UNUSED = 0, | 411 | UNUSED = 0, |
142 | 412 | ||
diff --git a/arch/sh/kernel/cpu/sh4/setup-sh4-202.c b/arch/sh/kernel/cpu/sh4/setup-sh4-202.c index 7371abf64f80..be79fa136255 100644 --- a/arch/sh/kernel/cpu/sh4/setup-sh4-202.c +++ b/arch/sh/kernel/cpu/sh4/setup-sh4-202.c | |||
@@ -2,6 +2,7 @@ | |||
2 | * SH4-202 Setup | 2 | * SH4-202 Setup |
3 | * | 3 | * |
4 | * Copyright (C) 2006 Paul Mundt | 4 | * Copyright (C) 2006 Paul Mundt |
5 | * Copyright (C) 2009 Magnus Damm | ||
5 | * | 6 | * |
6 | * This file is subject to the terms and conditions of the GNU General Public | 7 | * This file is subject to the terms and conditions of the GNU General Public |
7 | * License. See the file "COPYING" in the main directory of this archive | 8 | * License. See the file "COPYING" in the main directory of this archive |
@@ -11,6 +12,8 @@ | |||
11 | #include <linux/init.h> | 12 | #include <linux/init.h> |
12 | #include <linux/serial.h> | 13 | #include <linux/serial.h> |
13 | #include <linux/serial_sci.h> | 14 | #include <linux/serial_sci.h> |
15 | #include <linux/sh_timer.h> | ||
16 | #include <linux/io.h> | ||
14 | 17 | ||
15 | static struct plat_sci_port sci_platform_data[] = { | 18 | static struct plat_sci_port sci_platform_data[] = { |
16 | { | 19 | { |
@@ -31,8 +34,103 @@ static struct platform_device sci_device = { | |||
31 | }, | 34 | }, |
32 | }; | 35 | }; |
33 | 36 | ||
37 | static struct sh_timer_config tmu0_platform_data = { | ||
38 | .name = "TMU0", | ||
39 | .channel_offset = 0x04, | ||
40 | .timer_bit = 0, | ||
41 | .clk = "module_clk", | ||
42 | .clockevent_rating = 200, | ||
43 | }; | ||
44 | |||
45 | static struct resource tmu0_resources[] = { | ||
46 | [0] = { | ||
47 | .name = "TMU0", | ||
48 | .start = 0xffd80008, | ||
49 | .end = 0xffd80013, | ||
50 | .flags = IORESOURCE_MEM, | ||
51 | }, | ||
52 | [1] = { | ||
53 | .start = 16, | ||
54 | .flags = IORESOURCE_IRQ, | ||
55 | }, | ||
56 | }; | ||
57 | |||
58 | static struct platform_device tmu0_device = { | ||
59 | .name = "sh_tmu", | ||
60 | .id = 0, | ||
61 | .dev = { | ||
62 | .platform_data = &tmu0_platform_data, | ||
63 | }, | ||
64 | .resource = tmu0_resources, | ||
65 | .num_resources = ARRAY_SIZE(tmu0_resources), | ||
66 | }; | ||
67 | |||
68 | static struct sh_timer_config tmu1_platform_data = { | ||
69 | .name = "TMU1", | ||
70 | .channel_offset = 0x10, | ||
71 | .timer_bit = 1, | ||
72 | .clk = "module_clk", | ||
73 | .clocksource_rating = 200, | ||
74 | }; | ||
75 | |||
76 | static struct resource tmu1_resources[] = { | ||
77 | [0] = { | ||
78 | .name = "TMU1", | ||
79 | .start = 0xffd80014, | ||
80 | .end = 0xffd8001f, | ||
81 | .flags = IORESOURCE_MEM, | ||
82 | }, | ||
83 | [1] = { | ||
84 | .start = 17, | ||
85 | .flags = IORESOURCE_IRQ, | ||
86 | }, | ||
87 | }; | ||
88 | |||
89 | static struct platform_device tmu1_device = { | ||
90 | .name = "sh_tmu", | ||
91 | .id = 1, | ||
92 | .dev = { | ||
93 | .platform_data = &tmu1_platform_data, | ||
94 | }, | ||
95 | .resource = tmu1_resources, | ||
96 | .num_resources = ARRAY_SIZE(tmu1_resources), | ||
97 | }; | ||
98 | |||
99 | static struct sh_timer_config tmu2_platform_data = { | ||
100 | .name = "TMU2", | ||
101 | .channel_offset = 0x1c, | ||
102 | .timer_bit = 2, | ||
103 | .clk = "module_clk", | ||
104 | }; | ||
105 | |||
106 | static struct resource tmu2_resources[] = { | ||
107 | [0] = { | ||
108 | .name = "TMU2", | ||
109 | .start = 0xffd80020, | ||
110 | .end = 0xffd8002f, | ||
111 | .flags = IORESOURCE_MEM, | ||
112 | }, | ||
113 | [1] = { | ||
114 | .start = 18, | ||
115 | .flags = IORESOURCE_IRQ, | ||
116 | }, | ||
117 | }; | ||
118 | |||
119 | static struct platform_device tmu2_device = { | ||
120 | .name = "sh_tmu", | ||
121 | .id = 2, | ||
122 | .dev = { | ||
123 | .platform_data = &tmu2_platform_data, | ||
124 | }, | ||
125 | .resource = tmu2_resources, | ||
126 | .num_resources = ARRAY_SIZE(tmu2_resources), | ||
127 | }; | ||
128 | |||
34 | static struct platform_device *sh4202_devices[] __initdata = { | 129 | static struct platform_device *sh4202_devices[] __initdata = { |
35 | &sci_device, | 130 | &sci_device, |
131 | &tmu0_device, | ||
132 | &tmu1_device, | ||
133 | &tmu2_device, | ||
36 | }; | 134 | }; |
37 | 135 | ||
38 | static int __init sh4202_devices_setup(void) | 136 | static int __init sh4202_devices_setup(void) |
@@ -42,7 +140,71 @@ static int __init sh4202_devices_setup(void) | |||
42 | } | 140 | } |
43 | __initcall(sh4202_devices_setup); | 141 | __initcall(sh4202_devices_setup); |
44 | 142 | ||
143 | static struct platform_device *sh4202_early_devices[] __initdata = { | ||
144 | &tmu0_device, | ||
145 | &tmu1_device, | ||
146 | &tmu2_device, | ||
147 | }; | ||
148 | |||
149 | void __init plat_early_device_setup(void) | ||
150 | { | ||
151 | early_platform_add_devices(sh4202_early_devices, | ||
152 | ARRAY_SIZE(sh4202_early_devices)); | ||
153 | } | ||
154 | |||
155 | enum { | ||
156 | UNUSED = 0, | ||
157 | |||
158 | /* interrupt sources */ | ||
159 | IRL0, IRL1, IRL2, IRL3, /* only IRLM mode supported */ | ||
160 | HUDI, TMU0, TMU1, TMU2, RTC, SCIF, WDT, | ||
161 | }; | ||
162 | |||
163 | static struct intc_vect vectors[] __initdata = { | ||
164 | INTC_VECT(HUDI, 0x600), | ||
165 | INTC_VECT(TMU0, 0x400), INTC_VECT(TMU1, 0x420), | ||
166 | INTC_VECT(TMU2, 0x440), INTC_VECT(TMU2, 0x460), | ||
167 | INTC_VECT(RTC, 0x480), INTC_VECT(RTC, 0x4a0), | ||
168 | INTC_VECT(RTC, 0x4c0), | ||
169 | INTC_VECT(SCIF, 0x700), INTC_VECT(SCIF, 0x720), | ||
170 | INTC_VECT(SCIF, 0x740), INTC_VECT(SCIF, 0x760), | ||
171 | INTC_VECT(WDT, 0x560), | ||
172 | }; | ||
173 | |||
174 | static struct intc_prio_reg prio_registers[] __initdata = { | ||
175 | { 0xffd00004, 0, 16, 4, /* IPRA */ { TMU0, TMU1, TMU2, RTC } }, | ||
176 | { 0xffd00008, 0, 16, 4, /* IPRB */ { WDT, 0, 0, 0 } }, | ||
177 | { 0xffd0000c, 0, 16, 4, /* IPRC */ { 0, 0, SCIF, HUDI } }, | ||
178 | { 0xffd00010, 0, 16, 4, /* IPRD */ { IRL0, IRL1, IRL2, IRL3 } }, | ||
179 | }; | ||
180 | |||
181 | static DECLARE_INTC_DESC(intc_desc, "sh4-202", vectors, NULL, | ||
182 | NULL, prio_registers, NULL); | ||
183 | |||
184 | static struct intc_vect vectors_irlm[] __initdata = { | ||
185 | INTC_VECT(IRL0, 0x240), INTC_VECT(IRL1, 0x2a0), | ||
186 | INTC_VECT(IRL2, 0x300), INTC_VECT(IRL3, 0x360), | ||
187 | }; | ||
188 | |||
189 | static DECLARE_INTC_DESC(intc_desc_irlm, "sh4-202_irlm", vectors_irlm, NULL, | ||
190 | NULL, prio_registers, NULL); | ||
191 | |||
45 | void __init plat_irq_setup(void) | 192 | void __init plat_irq_setup(void) |
46 | { | 193 | { |
47 | /* do nothing - all IRL interrupts are handled by the board code */ | 194 | register_intc_controller(&intc_desc); |
195 | } | ||
196 | |||
197 | #define INTC_ICR 0xffd00000UL | ||
198 | #define INTC_ICR_IRLM (1<<7) | ||
199 | |||
200 | void __init plat_irq_setup_pins(int mode) | ||
201 | { | ||
202 | switch (mode) { | ||
203 | case IRQ_MODE_IRQ: /* individual interrupt mode for IRL3-0 */ | ||
204 | ctrl_outw(ctrl_inw(INTC_ICR) | INTC_ICR_IRLM, INTC_ICR); | ||
205 | register_intc_controller(&intc_desc_irlm); | ||
206 | break; | ||
207 | default: | ||
208 | BUG(); | ||
209 | } | ||
48 | } | 210 | } |
diff --git a/arch/sh/kernel/cpu/sh4a/setup-sh7343.c b/arch/sh/kernel/cpu/sh4a/setup-sh7343.c index 42ce5fcbd735..6307e087c864 100644 --- a/arch/sh/kernel/cpu/sh4a/setup-sh7343.c +++ b/arch/sh/kernel/cpu/sh4a/setup-sh7343.c | |||
@@ -173,6 +173,98 @@ static struct platform_device cmt_device = { | |||
173 | .num_resources = ARRAY_SIZE(cmt_resources), | 173 | .num_resources = ARRAY_SIZE(cmt_resources), |
174 | }; | 174 | }; |
175 | 175 | ||
176 | static struct sh_timer_config tmu0_platform_data = { | ||
177 | .name = "TMU0", | ||
178 | .channel_offset = 0x04, | ||
179 | .timer_bit = 0, | ||
180 | .clk = "tmu0", | ||
181 | .clockevent_rating = 200, | ||
182 | }; | ||
183 | |||
184 | static struct resource tmu0_resources[] = { | ||
185 | [0] = { | ||
186 | .name = "TMU0", | ||
187 | .start = 0xffd80008, | ||
188 | .end = 0xffd80013, | ||
189 | .flags = IORESOURCE_MEM, | ||
190 | }, | ||
191 | [1] = { | ||
192 | .start = 16, | ||
193 | .flags = IORESOURCE_IRQ, | ||
194 | }, | ||
195 | }; | ||
196 | |||
197 | static struct platform_device tmu0_device = { | ||
198 | .name = "sh_tmu", | ||
199 | .id = 0, | ||
200 | .dev = { | ||
201 | .platform_data = &tmu0_platform_data, | ||
202 | }, | ||
203 | .resource = tmu0_resources, | ||
204 | .num_resources = ARRAY_SIZE(tmu0_resources), | ||
205 | }; | ||
206 | |||
207 | static struct sh_timer_config tmu1_platform_data = { | ||
208 | .name = "TMU1", | ||
209 | .channel_offset = 0x10, | ||
210 | .timer_bit = 1, | ||
211 | .clk = "tmu0", | ||
212 | .clocksource_rating = 200, | ||
213 | }; | ||
214 | |||
215 | static struct resource tmu1_resources[] = { | ||
216 | [0] = { | ||
217 | .name = "TMU1", | ||
218 | .start = 0xffd80014, | ||
219 | .end = 0xffd8001f, | ||
220 | .flags = IORESOURCE_MEM, | ||
221 | }, | ||
222 | [1] = { | ||
223 | .start = 17, | ||
224 | .flags = IORESOURCE_IRQ, | ||
225 | }, | ||
226 | }; | ||
227 | |||
228 | static struct platform_device tmu1_device = { | ||
229 | .name = "sh_tmu", | ||
230 | .id = 1, | ||
231 | .dev = { | ||
232 | .platform_data = &tmu1_platform_data, | ||
233 | }, | ||
234 | .resource = tmu1_resources, | ||
235 | .num_resources = ARRAY_SIZE(tmu1_resources), | ||
236 | }; | ||
237 | |||
238 | static struct sh_timer_config tmu2_platform_data = { | ||
239 | .name = "TMU2", | ||
240 | .channel_offset = 0x1c, | ||
241 | .timer_bit = 2, | ||
242 | .clk = "tmu0", | ||
243 | }; | ||
244 | |||
245 | static struct resource tmu2_resources[] = { | ||
246 | [0] = { | ||
247 | .name = "TMU2", | ||
248 | .start = 0xffd80020, | ||
249 | .end = 0xffd8002b, | ||
250 | .flags = IORESOURCE_MEM, | ||
251 | }, | ||
252 | [1] = { | ||
253 | .start = 18, | ||
254 | .flags = IORESOURCE_IRQ, | ||
255 | }, | ||
256 | }; | ||
257 | |||
258 | static struct platform_device tmu2_device = { | ||
259 | .name = "sh_tmu", | ||
260 | .id = 2, | ||
261 | .dev = { | ||
262 | .platform_data = &tmu2_platform_data, | ||
263 | }, | ||
264 | .resource = tmu2_resources, | ||
265 | .num_resources = ARRAY_SIZE(tmu2_resources), | ||
266 | }; | ||
267 | |||
176 | static struct plat_sci_port sci_platform_data[] = { | 268 | static struct plat_sci_port sci_platform_data[] = { |
177 | { | 269 | { |
178 | .mapbase = 0xffe00000, | 270 | .mapbase = 0xffe00000, |
@@ -213,6 +305,9 @@ static struct platform_device sci_device = { | |||
213 | 305 | ||
214 | static struct platform_device *sh7343_devices[] __initdata = { | 306 | static struct platform_device *sh7343_devices[] __initdata = { |
215 | &cmt_device, | 307 | &cmt_device, |
308 | &tmu0_device, | ||
309 | &tmu1_device, | ||
310 | &tmu2_device, | ||
216 | &iic0_device, | 311 | &iic0_device, |
217 | &iic1_device, | 312 | &iic1_device, |
218 | &sci_device, | 313 | &sci_device, |
@@ -234,6 +329,9 @@ __initcall(sh7343_devices_setup); | |||
234 | 329 | ||
235 | static struct platform_device *sh7343_early_devices[] __initdata = { | 330 | static struct platform_device *sh7343_early_devices[] __initdata = { |
236 | &cmt_device, | 331 | &cmt_device, |
332 | &tmu0_device, | ||
333 | &tmu1_device, | ||
334 | &tmu2_device, | ||
237 | }; | 335 | }; |
238 | 336 | ||
239 | void __init plat_early_device_setup(void) | 337 | void __init plat_early_device_setup(void) |
diff --git a/arch/sh/kernel/cpu/sh4a/setup-sh7366.c b/arch/sh/kernel/cpu/sh4a/setup-sh7366.c index d0172afa0b5d..318516f6bfad 100644 --- a/arch/sh/kernel/cpu/sh4a/setup-sh7366.c +++ b/arch/sh/kernel/cpu/sh4a/setup-sh7366.c | |||
@@ -180,6 +180,98 @@ static struct platform_device cmt_device = { | |||
180 | .num_resources = ARRAY_SIZE(cmt_resources), | 180 | .num_resources = ARRAY_SIZE(cmt_resources), |
181 | }; | 181 | }; |
182 | 182 | ||
183 | static struct sh_timer_config tmu0_platform_data = { | ||
184 | .name = "TMU0", | ||
185 | .channel_offset = 0x04, | ||
186 | .timer_bit = 0, | ||
187 | .clk = "tmu0", | ||
188 | .clockevent_rating = 200, | ||
189 | }; | ||
190 | |||
191 | static struct resource tmu0_resources[] = { | ||
192 | [0] = { | ||
193 | .name = "TMU0", | ||
194 | .start = 0xffd80008, | ||
195 | .end = 0xffd80013, | ||
196 | .flags = IORESOURCE_MEM, | ||
197 | }, | ||
198 | [1] = { | ||
199 | .start = 16, | ||
200 | .flags = IORESOURCE_IRQ, | ||
201 | }, | ||
202 | }; | ||
203 | |||
204 | static struct platform_device tmu0_device = { | ||
205 | .name = "sh_tmu", | ||
206 | .id = 0, | ||
207 | .dev = { | ||
208 | .platform_data = &tmu0_platform_data, | ||
209 | }, | ||
210 | .resource = tmu0_resources, | ||
211 | .num_resources = ARRAY_SIZE(tmu0_resources), | ||
212 | }; | ||
213 | |||
214 | static struct sh_timer_config tmu1_platform_data = { | ||
215 | .name = "TMU1", | ||
216 | .channel_offset = 0x10, | ||
217 | .timer_bit = 1, | ||
218 | .clk = "tmu0", | ||
219 | .clocksource_rating = 200, | ||
220 | }; | ||
221 | |||
222 | static struct resource tmu1_resources[] = { | ||
223 | [0] = { | ||
224 | .name = "TMU1", | ||
225 | .start = 0xffd80014, | ||
226 | .end = 0xffd8001f, | ||
227 | .flags = IORESOURCE_MEM, | ||
228 | }, | ||
229 | [1] = { | ||
230 | .start = 17, | ||
231 | .flags = IORESOURCE_IRQ, | ||
232 | }, | ||
233 | }; | ||
234 | |||
235 | static struct platform_device tmu1_device = { | ||
236 | .name = "sh_tmu", | ||
237 | .id = 1, | ||
238 | .dev = { | ||
239 | .platform_data = &tmu1_platform_data, | ||
240 | }, | ||
241 | .resource = tmu1_resources, | ||
242 | .num_resources = ARRAY_SIZE(tmu1_resources), | ||
243 | }; | ||
244 | |||
245 | static struct sh_timer_config tmu2_platform_data = { | ||
246 | .name = "TMU2", | ||
247 | .channel_offset = 0x1c, | ||
248 | .timer_bit = 2, | ||
249 | .clk = "tmu0", | ||
250 | }; | ||
251 | |||
252 | static struct resource tmu2_resources[] = { | ||
253 | [0] = { | ||
254 | .name = "TMU2", | ||
255 | .start = 0xffd80020, | ||
256 | .end = 0xffd8002b, | ||
257 | .flags = IORESOURCE_MEM, | ||
258 | }, | ||
259 | [1] = { | ||
260 | .start = 18, | ||
261 | .flags = IORESOURCE_IRQ, | ||
262 | }, | ||
263 | }; | ||
264 | |||
265 | static struct platform_device tmu2_device = { | ||
266 | .name = "sh_tmu", | ||
267 | .id = 2, | ||
268 | .dev = { | ||
269 | .platform_data = &tmu2_platform_data, | ||
270 | }, | ||
271 | .resource = tmu2_resources, | ||
272 | .num_resources = ARRAY_SIZE(tmu2_resources), | ||
273 | }; | ||
274 | |||
183 | static struct plat_sci_port sci_platform_data[] = { | 275 | static struct plat_sci_port sci_platform_data[] = { |
184 | { | 276 | { |
185 | .mapbase = 0xffe00000, | 277 | .mapbase = 0xffe00000, |
@@ -202,6 +294,9 @@ static struct platform_device sci_device = { | |||
202 | 294 | ||
203 | static struct platform_device *sh7366_devices[] __initdata = { | 295 | static struct platform_device *sh7366_devices[] __initdata = { |
204 | &cmt_device, | 296 | &cmt_device, |
297 | &tmu0_device, | ||
298 | &tmu1_device, | ||
299 | &tmu2_device, | ||
205 | &iic_device, | 300 | &iic_device, |
206 | &sci_device, | 301 | &sci_device, |
207 | &usb_host_device, | 302 | &usb_host_device, |
@@ -223,6 +318,9 @@ __initcall(sh7366_devices_setup); | |||
223 | 318 | ||
224 | static struct platform_device *sh7366_early_devices[] __initdata = { | 319 | static struct platform_device *sh7366_early_devices[] __initdata = { |
225 | &cmt_device, | 320 | &cmt_device, |
321 | &tmu0_device, | ||
322 | &tmu1_device, | ||
323 | &tmu2_device, | ||
226 | }; | 324 | }; |
227 | 325 | ||
228 | void __init plat_early_device_setup(void) | 326 | void __init plat_early_device_setup(void) |
diff --git a/arch/sh/kernel/cpu/sh4a/setup-sh7724.c b/arch/sh/kernel/cpu/sh4a/setup-sh7724.c index 080f541ae08d..191f0e2a7e08 100644 --- a/arch/sh/kernel/cpu/sh4a/setup-sh7724.c +++ b/arch/sh/kernel/cpu/sh4a/setup-sh7724.c | |||
@@ -268,8 +268,197 @@ static struct platform_device cmt_device = { | |||
268 | .num_resources = ARRAY_SIZE(cmt_resources), | 268 | .num_resources = ARRAY_SIZE(cmt_resources), |
269 | }; | 269 | }; |
270 | 270 | ||
271 | static struct sh_timer_config tmu0_platform_data = { | ||
272 | .name = "TMU0", | ||
273 | .channel_offset = 0x04, | ||
274 | .timer_bit = 0, | ||
275 | .clk = "tmu0", | ||
276 | .clockevent_rating = 200, | ||
277 | }; | ||
278 | |||
279 | static struct resource tmu0_resources[] = { | ||
280 | [0] = { | ||
281 | .name = "TMU0", | ||
282 | .start = 0xffd80008, | ||
283 | .end = 0xffd80013, | ||
284 | .flags = IORESOURCE_MEM, | ||
285 | }, | ||
286 | [1] = { | ||
287 | .start = 16, | ||
288 | .flags = IORESOURCE_IRQ, | ||
289 | }, | ||
290 | }; | ||
291 | |||
292 | static struct platform_device tmu0_device = { | ||
293 | .name = "sh_tmu", | ||
294 | .id = 0, | ||
295 | .dev = { | ||
296 | .platform_data = &tmu0_platform_data, | ||
297 | }, | ||
298 | .resource = tmu0_resources, | ||
299 | .num_resources = ARRAY_SIZE(tmu0_resources), | ||
300 | }; | ||
301 | |||
302 | static struct sh_timer_config tmu1_platform_data = { | ||
303 | .name = "TMU1", | ||
304 | .channel_offset = 0x10, | ||
305 | .timer_bit = 1, | ||
306 | .clk = "tmu0", | ||
307 | .clocksource_rating = 200, | ||
308 | }; | ||
309 | |||
310 | static struct resource tmu1_resources[] = { | ||
311 | [0] = { | ||
312 | .name = "TMU1", | ||
313 | .start = 0xffd80014, | ||
314 | .end = 0xffd8001f, | ||
315 | .flags = IORESOURCE_MEM, | ||
316 | }, | ||
317 | [1] = { | ||
318 | .start = 17, | ||
319 | .flags = IORESOURCE_IRQ, | ||
320 | }, | ||
321 | }; | ||
322 | |||
323 | static struct platform_device tmu1_device = { | ||
324 | .name = "sh_tmu", | ||
325 | .id = 1, | ||
326 | .dev = { | ||
327 | .platform_data = &tmu1_platform_data, | ||
328 | }, | ||
329 | .resource = tmu1_resources, | ||
330 | .num_resources = ARRAY_SIZE(tmu1_resources), | ||
331 | }; | ||
332 | |||
333 | static struct sh_timer_config tmu2_platform_data = { | ||
334 | .name = "TMU2", | ||
335 | .channel_offset = 0x1c, | ||
336 | .timer_bit = 2, | ||
337 | .clk = "tmu0", | ||
338 | }; | ||
339 | |||
340 | static struct resource tmu2_resources[] = { | ||
341 | [0] = { | ||
342 | .name = "TMU2", | ||
343 | .start = 0xffd80020, | ||
344 | .end = 0xffd8002b, | ||
345 | .flags = IORESOURCE_MEM, | ||
346 | }, | ||
347 | [1] = { | ||
348 | .start = 18, | ||
349 | .flags = IORESOURCE_IRQ, | ||
350 | }, | ||
351 | }; | ||
352 | |||
353 | static struct platform_device tmu2_device = { | ||
354 | .name = "sh_tmu", | ||
355 | .id = 2, | ||
356 | .dev = { | ||
357 | .platform_data = &tmu2_platform_data, | ||
358 | }, | ||
359 | .resource = tmu2_resources, | ||
360 | .num_resources = ARRAY_SIZE(tmu2_resources), | ||
361 | }; | ||
362 | |||
363 | |||
364 | static struct sh_timer_config tmu3_platform_data = { | ||
365 | .name = "TMU3", | ||
366 | .channel_offset = 0x04, | ||
367 | .timer_bit = 0, | ||
368 | .clk = "tmu1", | ||
369 | }; | ||
370 | |||
371 | static struct resource tmu3_resources[] = { | ||
372 | [0] = { | ||
373 | .name = "TMU3", | ||
374 | .start = 0xffd90008, | ||
375 | .end = 0xffd90013, | ||
376 | .flags = IORESOURCE_MEM, | ||
377 | }, | ||
378 | [1] = { | ||
379 | .start = 57, | ||
380 | .flags = IORESOURCE_IRQ, | ||
381 | }, | ||
382 | }; | ||
383 | |||
384 | static struct platform_device tmu3_device = { | ||
385 | .name = "sh_tmu", | ||
386 | .id = 3, | ||
387 | .dev = { | ||
388 | .platform_data = &tmu3_platform_data, | ||
389 | }, | ||
390 | .resource = tmu3_resources, | ||
391 | .num_resources = ARRAY_SIZE(tmu3_resources), | ||
392 | }; | ||
393 | |||
394 | static struct sh_timer_config tmu4_platform_data = { | ||
395 | .name = "TMU4", | ||
396 | .channel_offset = 0x10, | ||
397 | .timer_bit = 1, | ||
398 | .clk = "tmu1", | ||
399 | }; | ||
400 | |||
401 | static struct resource tmu4_resources[] = { | ||
402 | [0] = { | ||
403 | .name = "TMU4", | ||
404 | .start = 0xffd90014, | ||
405 | .end = 0xffd9001f, | ||
406 | .flags = IORESOURCE_MEM, | ||
407 | }, | ||
408 | [1] = { | ||
409 | .start = 58, | ||
410 | .flags = IORESOURCE_IRQ, | ||
411 | }, | ||
412 | }; | ||
413 | |||
414 | static struct platform_device tmu4_device = { | ||
415 | .name = "sh_tmu", | ||
416 | .id = 4, | ||
417 | .dev = { | ||
418 | .platform_data = &tmu4_platform_data, | ||
419 | }, | ||
420 | .resource = tmu4_resources, | ||
421 | .num_resources = ARRAY_SIZE(tmu4_resources), | ||
422 | }; | ||
423 | |||
424 | static struct sh_timer_config tmu5_platform_data = { | ||
425 | .name = "TMU5", | ||
426 | .channel_offset = 0x1c, | ||
427 | .timer_bit = 2, | ||
428 | .clk = "tmu1", | ||
429 | }; | ||
430 | |||
431 | static struct resource tmu5_resources[] = { | ||
432 | [0] = { | ||
433 | .name = "TMU5", | ||
434 | .start = 0xffd90020, | ||
435 | .end = 0xffd9002b, | ||
436 | .flags = IORESOURCE_MEM, | ||
437 | }, | ||
438 | [1] = { | ||
439 | .start = 57, | ||
440 | .flags = IORESOURCE_IRQ, | ||
441 | }, | ||
442 | }; | ||
443 | |||
444 | static struct platform_device tmu5_device = { | ||
445 | .name = "sh_tmu", | ||
446 | .id = 5, | ||
447 | .dev = { | ||
448 | .platform_data = &tmu5_platform_data, | ||
449 | }, | ||
450 | .resource = tmu5_resources, | ||
451 | .num_resources = ARRAY_SIZE(tmu5_resources), | ||
452 | }; | ||
453 | |||
271 | static struct platform_device *sh7724_devices[] __initdata = { | 454 | static struct platform_device *sh7724_devices[] __initdata = { |
272 | &cmt_device, | 455 | &cmt_device, |
456 | &tmu0_device, | ||
457 | &tmu1_device, | ||
458 | &tmu2_device, | ||
459 | &tmu3_device, | ||
460 | &tmu4_device, | ||
461 | &tmu5_device, | ||
273 | &sci_device, | 462 | &sci_device, |
274 | &rtc_device, | 463 | &rtc_device, |
275 | &iic0_device, | 464 | &iic0_device, |
@@ -292,6 +481,12 @@ device_initcall(sh7724_devices_setup); | |||
292 | 481 | ||
293 | static struct platform_device *sh7724_early_devices[] __initdata = { | 482 | static struct platform_device *sh7724_early_devices[] __initdata = { |
294 | &cmt_device, | 483 | &cmt_device, |
484 | &tmu0_device, | ||
485 | &tmu1_device, | ||
486 | &tmu2_device, | ||
487 | &tmu3_device, | ||
488 | &tmu4_device, | ||
489 | &tmu5_device, | ||
295 | }; | 490 | }; |
296 | 491 | ||
297 | void __init plat_early_device_setup(void) | 492 | void __init plat_early_device_setup(void) |
diff --git a/arch/sh/kernel/cpu/sh4a/setup-sh7763.c b/arch/sh/kernel/cpu/sh4a/setup-sh7763.c index bdf0f61ae1ed..c91f34c9aa83 100644 --- a/arch/sh/kernel/cpu/sh4a/setup-sh7763.c +++ b/arch/sh/kernel/cpu/sh4a/setup-sh7763.c | |||
@@ -12,6 +12,7 @@ | |||
12 | #include <linux/platform_device.h> | 12 | #include <linux/platform_device.h> |
13 | #include <linux/init.h> | 13 | #include <linux/init.h> |
14 | #include <linux/serial.h> | 14 | #include <linux/serial.h> |
15 | #include <linux/sh_timer.h> | ||
15 | #include <linux/io.h> | 16 | #include <linux/io.h> |
16 | #include <linux/serial_sci.h> | 17 | #include <linux/serial_sci.h> |
17 | 18 | ||
@@ -113,7 +114,195 @@ static struct platform_device usbf_device = { | |||
113 | .resource = usbf_resources, | 114 | .resource = usbf_resources, |
114 | }; | 115 | }; |
115 | 116 | ||
117 | static struct sh_timer_config tmu0_platform_data = { | ||
118 | .name = "TMU0", | ||
119 | .channel_offset = 0x04, | ||
120 | .timer_bit = 0, | ||
121 | .clk = "module_clk", | ||
122 | .clockevent_rating = 200, | ||
123 | }; | ||
124 | |||
125 | static struct resource tmu0_resources[] = { | ||
126 | [0] = { | ||
127 | .name = "TMU0", | ||
128 | .start = 0xffd80008, | ||
129 | .end = 0xffd80013, | ||
130 | .flags = IORESOURCE_MEM, | ||
131 | }, | ||
132 | [1] = { | ||
133 | .start = 28, | ||
134 | .flags = IORESOURCE_IRQ, | ||
135 | }, | ||
136 | }; | ||
137 | |||
138 | static struct platform_device tmu0_device = { | ||
139 | .name = "sh_tmu", | ||
140 | .id = 0, | ||
141 | .dev = { | ||
142 | .platform_data = &tmu0_platform_data, | ||
143 | }, | ||
144 | .resource = tmu0_resources, | ||
145 | .num_resources = ARRAY_SIZE(tmu0_resources), | ||
146 | }; | ||
147 | |||
148 | static struct sh_timer_config tmu1_platform_data = { | ||
149 | .name = "TMU1", | ||
150 | .channel_offset = 0x10, | ||
151 | .timer_bit = 1, | ||
152 | .clk = "module_clk", | ||
153 | .clocksource_rating = 200, | ||
154 | }; | ||
155 | |||
156 | static struct resource tmu1_resources[] = { | ||
157 | [0] = { | ||
158 | .name = "TMU1", | ||
159 | .start = 0xffd80014, | ||
160 | .end = 0xffd8001f, | ||
161 | .flags = IORESOURCE_MEM, | ||
162 | }, | ||
163 | [1] = { | ||
164 | .start = 29, | ||
165 | .flags = IORESOURCE_IRQ, | ||
166 | }, | ||
167 | }; | ||
168 | |||
169 | static struct platform_device tmu1_device = { | ||
170 | .name = "sh_tmu", | ||
171 | .id = 1, | ||
172 | .dev = { | ||
173 | .platform_data = &tmu1_platform_data, | ||
174 | }, | ||
175 | .resource = tmu1_resources, | ||
176 | .num_resources = ARRAY_SIZE(tmu1_resources), | ||
177 | }; | ||
178 | |||
179 | static struct sh_timer_config tmu2_platform_data = { | ||
180 | .name = "TMU2", | ||
181 | .channel_offset = 0x1c, | ||
182 | .timer_bit = 2, | ||
183 | .clk = "module_clk", | ||
184 | }; | ||
185 | |||
186 | static struct resource tmu2_resources[] = { | ||
187 | [0] = { | ||
188 | .name = "TMU2", | ||
189 | .start = 0xffd80020, | ||
190 | .end = 0xffd8002f, | ||
191 | .flags = IORESOURCE_MEM, | ||
192 | }, | ||
193 | [1] = { | ||
194 | .start = 30, | ||
195 | .flags = IORESOURCE_IRQ, | ||
196 | }, | ||
197 | }; | ||
198 | |||
199 | static struct platform_device tmu2_device = { | ||
200 | .name = "sh_tmu", | ||
201 | .id = 2, | ||
202 | .dev = { | ||
203 | .platform_data = &tmu2_platform_data, | ||
204 | }, | ||
205 | .resource = tmu2_resources, | ||
206 | .num_resources = ARRAY_SIZE(tmu2_resources), | ||
207 | }; | ||
208 | |||
209 | static struct sh_timer_config tmu3_platform_data = { | ||
210 | .name = "TMU3", | ||
211 | .channel_offset = 0x04, | ||
212 | .timer_bit = 0, | ||
213 | .clk = "module_clk", | ||
214 | }; | ||
215 | |||
216 | static struct resource tmu3_resources[] = { | ||
217 | [0] = { | ||
218 | .name = "TMU3", | ||
219 | .start = 0xffd88008, | ||
220 | .end = 0xffd88013, | ||
221 | .flags = IORESOURCE_MEM, | ||
222 | }, | ||
223 | [1] = { | ||
224 | .start = 96, | ||
225 | .flags = IORESOURCE_IRQ, | ||
226 | }, | ||
227 | }; | ||
228 | |||
229 | static struct platform_device tmu3_device = { | ||
230 | .name = "sh_tmu", | ||
231 | .id = 3, | ||
232 | .dev = { | ||
233 | .platform_data = &tmu3_platform_data, | ||
234 | }, | ||
235 | .resource = tmu3_resources, | ||
236 | .num_resources = ARRAY_SIZE(tmu3_resources), | ||
237 | }; | ||
238 | |||
239 | static struct sh_timer_config tmu4_platform_data = { | ||
240 | .name = "TMU4", | ||
241 | .channel_offset = 0x10, | ||
242 | .timer_bit = 1, | ||
243 | .clk = "module_clk", | ||
244 | }; | ||
245 | |||
246 | static struct resource tmu4_resources[] = { | ||
247 | [0] = { | ||
248 | .name = "TMU4", | ||
249 | .start = 0xffd88014, | ||
250 | .end = 0xffd8801f, | ||
251 | .flags = IORESOURCE_MEM, | ||
252 | }, | ||
253 | [1] = { | ||
254 | .start = 97, | ||
255 | .flags = IORESOURCE_IRQ, | ||
256 | }, | ||
257 | }; | ||
258 | |||
259 | static struct platform_device tmu4_device = { | ||
260 | .name = "sh_tmu", | ||
261 | .id = 4, | ||
262 | .dev = { | ||
263 | .platform_data = &tmu4_platform_data, | ||
264 | }, | ||
265 | .resource = tmu4_resources, | ||
266 | .num_resources = ARRAY_SIZE(tmu4_resources), | ||
267 | }; | ||
268 | |||
269 | static struct sh_timer_config tmu5_platform_data = { | ||
270 | .name = "TMU5", | ||
271 | .channel_offset = 0x1c, | ||
272 | .timer_bit = 2, | ||
273 | .clk = "module_clk", | ||
274 | }; | ||
275 | |||
276 | static struct resource tmu5_resources[] = { | ||
277 | [0] = { | ||
278 | .name = "TMU5", | ||
279 | .start = 0xffd88020, | ||
280 | .end = 0xffd8802b, | ||
281 | .flags = IORESOURCE_MEM, | ||
282 | }, | ||
283 | [1] = { | ||
284 | .start = 98, | ||
285 | .flags = IORESOURCE_IRQ, | ||
286 | }, | ||
287 | }; | ||
288 | |||
289 | static struct platform_device tmu5_device = { | ||
290 | .name = "sh_tmu", | ||
291 | .id = 5, | ||
292 | .dev = { | ||
293 | .platform_data = &tmu5_platform_data, | ||
294 | }, | ||
295 | .resource = tmu5_resources, | ||
296 | .num_resources = ARRAY_SIZE(tmu5_resources), | ||
297 | }; | ||
298 | |||
116 | static struct platform_device *sh7763_devices[] __initdata = { | 299 | static struct platform_device *sh7763_devices[] __initdata = { |
300 | &tmu0_device, | ||
301 | &tmu1_device, | ||
302 | &tmu2_device, | ||
303 | &tmu3_device, | ||
304 | &tmu4_device, | ||
305 | &tmu5_device, | ||
117 | &rtc_device, | 306 | &rtc_device, |
118 | &sci_device, | 307 | &sci_device, |
119 | &usb_ohci_device, | 308 | &usb_ohci_device, |
@@ -127,6 +316,21 @@ static int __init sh7763_devices_setup(void) | |||
127 | } | 316 | } |
128 | __initcall(sh7763_devices_setup); | 317 | __initcall(sh7763_devices_setup); |
129 | 318 | ||
319 | static struct platform_device *sh7763_early_devices[] __initdata = { | ||
320 | &tmu0_device, | ||
321 | &tmu1_device, | ||
322 | &tmu2_device, | ||
323 | &tmu3_device, | ||
324 | &tmu4_device, | ||
325 | &tmu5_device, | ||
326 | }; | ||
327 | |||
328 | void __init plat_early_device_setup(void) | ||
329 | { | ||
330 | early_platform_add_devices(sh7763_early_devices, | ||
331 | ARRAY_SIZE(sh7763_early_devices)); | ||
332 | } | ||
333 | |||
130 | enum { | 334 | enum { |
131 | UNUSED = 0, | 335 | UNUSED = 0, |
132 | 336 | ||
diff --git a/arch/sh/kernel/cpu/sh4a/setup-sh7770.c b/arch/sh/kernel/cpu/sh4a/setup-sh7770.c index b73578ee295d..b61d6143aaaa 100644 --- a/arch/sh/kernel/cpu/sh4a/setup-sh7770.c +++ b/arch/sh/kernel/cpu/sh4a/setup-sh7770.c | |||
@@ -11,6 +11,7 @@ | |||
11 | #include <linux/init.h> | 11 | #include <linux/init.h> |
12 | #include <linux/serial.h> | 12 | #include <linux/serial.h> |
13 | #include <linux/serial_sci.h> | 13 | #include <linux/serial_sci.h> |
14 | #include <linux/sh_timer.h> | ||
14 | 15 | ||
15 | static struct plat_sci_port sci_platform_data[] = { | 16 | static struct plat_sci_port sci_platform_data[] = { |
16 | { | 17 | { |
@@ -76,7 +77,288 @@ static struct platform_device sci_device = { | |||
76 | }, | 77 | }, |
77 | }; | 78 | }; |
78 | 79 | ||
80 | static struct sh_timer_config tmu0_platform_data = { | ||
81 | .name = "TMU0", | ||
82 | .channel_offset = 0x04, | ||
83 | .timer_bit = 0, | ||
84 | .clk = "module_clk", | ||
85 | .clockevent_rating = 200, | ||
86 | }; | ||
87 | |||
88 | static struct resource tmu0_resources[] = { | ||
89 | [0] = { | ||
90 | .name = "TMU0", | ||
91 | .start = 0xffd80008, | ||
92 | .end = 0xffd80013, | ||
93 | .flags = IORESOURCE_MEM, | ||
94 | }, | ||
95 | [1] = { | ||
96 | .start = 16, | ||
97 | .flags = IORESOURCE_IRQ, | ||
98 | }, | ||
99 | }; | ||
100 | |||
101 | static struct platform_device tmu0_device = { | ||
102 | .name = "sh_tmu", | ||
103 | .id = 0, | ||
104 | .dev = { | ||
105 | .platform_data = &tmu0_platform_data, | ||
106 | }, | ||
107 | .resource = tmu0_resources, | ||
108 | .num_resources = ARRAY_SIZE(tmu0_resources), | ||
109 | }; | ||
110 | |||
111 | static struct sh_timer_config tmu1_platform_data = { | ||
112 | .name = "TMU1", | ||
113 | .channel_offset = 0x10, | ||
114 | .timer_bit = 1, | ||
115 | .clk = "module_clk", | ||
116 | .clocksource_rating = 200, | ||
117 | }; | ||
118 | |||
119 | static struct resource tmu1_resources[] = { | ||
120 | [0] = { | ||
121 | .name = "TMU1", | ||
122 | .start = 0xffd80014, | ||
123 | .end = 0xffd8001f, | ||
124 | .flags = IORESOURCE_MEM, | ||
125 | }, | ||
126 | [1] = { | ||
127 | .start = 17, | ||
128 | .flags = IORESOURCE_IRQ, | ||
129 | }, | ||
130 | }; | ||
131 | |||
132 | static struct platform_device tmu1_device = { | ||
133 | .name = "sh_tmu", | ||
134 | .id = 1, | ||
135 | .dev = { | ||
136 | .platform_data = &tmu1_platform_data, | ||
137 | }, | ||
138 | .resource = tmu1_resources, | ||
139 | .num_resources = ARRAY_SIZE(tmu1_resources), | ||
140 | }; | ||
141 | |||
142 | static struct sh_timer_config tmu2_platform_data = { | ||
143 | .name = "TMU2", | ||
144 | .channel_offset = 0x1c, | ||
145 | .timer_bit = 2, | ||
146 | .clk = "module_clk", | ||
147 | }; | ||
148 | |||
149 | static struct resource tmu2_resources[] = { | ||
150 | [0] = { | ||
151 | .name = "TMU2", | ||
152 | .start = 0xffd80020, | ||
153 | .end = 0xffd8002f, | ||
154 | .flags = IORESOURCE_MEM, | ||
155 | }, | ||
156 | [1] = { | ||
157 | .start = 18, | ||
158 | .flags = IORESOURCE_IRQ, | ||
159 | }, | ||
160 | }; | ||
161 | |||
162 | static struct platform_device tmu2_device = { | ||
163 | .name = "sh_tmu", | ||
164 | .id = 2, | ||
165 | .dev = { | ||
166 | .platform_data = &tmu2_platform_data, | ||
167 | }, | ||
168 | .resource = tmu2_resources, | ||
169 | .num_resources = ARRAY_SIZE(tmu2_resources), | ||
170 | }; | ||
171 | |||
172 | static struct sh_timer_config tmu3_platform_data = { | ||
173 | .name = "TMU3", | ||
174 | .channel_offset = 0x04, | ||
175 | .timer_bit = 0, | ||
176 | .clk = "module_clk", | ||
177 | }; | ||
178 | |||
179 | static struct resource tmu3_resources[] = { | ||
180 | [0] = { | ||
181 | .name = "TMU3", | ||
182 | .start = 0xffd81008, | ||
183 | .end = 0xffd81013, | ||
184 | .flags = IORESOURCE_MEM, | ||
185 | }, | ||
186 | [1] = { | ||
187 | .start = 19, | ||
188 | .flags = IORESOURCE_IRQ, | ||
189 | }, | ||
190 | }; | ||
191 | |||
192 | static struct platform_device tmu3_device = { | ||
193 | .name = "sh_tmu", | ||
194 | .id = 3, | ||
195 | .dev = { | ||
196 | .platform_data = &tmu3_platform_data, | ||
197 | }, | ||
198 | .resource = tmu3_resources, | ||
199 | .num_resources = ARRAY_SIZE(tmu3_resources), | ||
200 | }; | ||
201 | |||
202 | static struct sh_timer_config tmu4_platform_data = { | ||
203 | .name = "TMU4", | ||
204 | .channel_offset = 0x10, | ||
205 | .timer_bit = 1, | ||
206 | .clk = "module_clk", | ||
207 | }; | ||
208 | |||
209 | static struct resource tmu4_resources[] = { | ||
210 | [0] = { | ||
211 | .name = "TMU4", | ||
212 | .start = 0xffd81014, | ||
213 | .end = 0xffd8101f, | ||
214 | .flags = IORESOURCE_MEM, | ||
215 | }, | ||
216 | [1] = { | ||
217 | .start = 20, | ||
218 | .flags = IORESOURCE_IRQ, | ||
219 | }, | ||
220 | }; | ||
221 | |||
222 | static struct platform_device tmu4_device = { | ||
223 | .name = "sh_tmu", | ||
224 | .id = 4, | ||
225 | .dev = { | ||
226 | .platform_data = &tmu4_platform_data, | ||
227 | }, | ||
228 | .resource = tmu4_resources, | ||
229 | .num_resources = ARRAY_SIZE(tmu4_resources), | ||
230 | }; | ||
231 | |||
232 | static struct sh_timer_config tmu5_platform_data = { | ||
233 | .name = "TMU5", | ||
234 | .channel_offset = 0x1c, | ||
235 | .timer_bit = 2, | ||
236 | .clk = "module_clk", | ||
237 | }; | ||
238 | |||
239 | static struct resource tmu5_resources[] = { | ||
240 | [0] = { | ||
241 | .name = "TMU5", | ||
242 | .start = 0xffd81020, | ||
243 | .end = 0xffd8102f, | ||
244 | .flags = IORESOURCE_MEM, | ||
245 | }, | ||
246 | [1] = { | ||
247 | .start = 21, | ||
248 | .flags = IORESOURCE_IRQ, | ||
249 | }, | ||
250 | }; | ||
251 | |||
252 | static struct platform_device tmu5_device = { | ||
253 | .name = "sh_tmu", | ||
254 | .id = 5, | ||
255 | .dev = { | ||
256 | .platform_data = &tmu5_platform_data, | ||
257 | }, | ||
258 | .resource = tmu5_resources, | ||
259 | .num_resources = ARRAY_SIZE(tmu5_resources), | ||
260 | }; | ||
261 | |||
262 | static struct sh_timer_config tmu6_platform_data = { | ||
263 | .name = "TMU6", | ||
264 | .channel_offset = 0x04, | ||
265 | .timer_bit = 0, | ||
266 | .clk = "module_clk", | ||
267 | }; | ||
268 | |||
269 | static struct resource tmu6_resources[] = { | ||
270 | [0] = { | ||
271 | .name = "TMU6", | ||
272 | .start = 0xffd82008, | ||
273 | .end = 0xffd82013, | ||
274 | .flags = IORESOURCE_MEM, | ||
275 | }, | ||
276 | [1] = { | ||
277 | .start = 22, | ||
278 | .flags = IORESOURCE_IRQ, | ||
279 | }, | ||
280 | }; | ||
281 | |||
282 | static struct platform_device tmu6_device = { | ||
283 | .name = "sh_tmu", | ||
284 | .id = 6, | ||
285 | .dev = { | ||
286 | .platform_data = &tmu6_platform_data, | ||
287 | }, | ||
288 | .resource = tmu6_resources, | ||
289 | .num_resources = ARRAY_SIZE(tmu6_resources), | ||
290 | }; | ||
291 | |||
292 | static struct sh_timer_config tmu7_platform_data = { | ||
293 | .name = "TMU7", | ||
294 | .channel_offset = 0x10, | ||
295 | .timer_bit = 1, | ||
296 | .clk = "module_clk", | ||
297 | }; | ||
298 | |||
299 | static struct resource tmu7_resources[] = { | ||
300 | [0] = { | ||
301 | .name = "TMU7", | ||
302 | .start = 0xffd82014, | ||
303 | .end = 0xffd8201f, | ||
304 | .flags = IORESOURCE_MEM, | ||
305 | }, | ||
306 | [1] = { | ||
307 | .start = 23, | ||
308 | .flags = IORESOURCE_IRQ, | ||
309 | }, | ||
310 | }; | ||
311 | |||
312 | static struct platform_device tmu7_device = { | ||
313 | .name = "sh_tmu", | ||
314 | .id = 7, | ||
315 | .dev = { | ||
316 | .platform_data = &tmu7_platform_data, | ||
317 | }, | ||
318 | .resource = tmu7_resources, | ||
319 | .num_resources = ARRAY_SIZE(tmu7_resources), | ||
320 | }; | ||
321 | |||
322 | static struct sh_timer_config tmu8_platform_data = { | ||
323 | .name = "TMU8", | ||
324 | .channel_offset = 0x1c, | ||
325 | .timer_bit = 2, | ||
326 | .clk = "module_clk", | ||
327 | }; | ||
328 | |||
329 | static struct resource tmu8_resources[] = { | ||
330 | [0] = { | ||
331 | .name = "TMU8", | ||
332 | .start = 0xffd82020, | ||
333 | .end = 0xffd8202b, | ||
334 | .flags = IORESOURCE_MEM, | ||
335 | }, | ||
336 | [1] = { | ||
337 | .start = 24, | ||
338 | .flags = IORESOURCE_IRQ, | ||
339 | }, | ||
340 | }; | ||
341 | |||
342 | static struct platform_device tmu8_device = { | ||
343 | .name = "sh_tmu", | ||
344 | .id = 8, | ||
345 | .dev = { | ||
346 | .platform_data = &tmu8_platform_data, | ||
347 | }, | ||
348 | .resource = tmu8_resources, | ||
349 | .num_resources = ARRAY_SIZE(tmu8_resources), | ||
350 | }; | ||
351 | |||
79 | static struct platform_device *sh7770_devices[] __initdata = { | 352 | static struct platform_device *sh7770_devices[] __initdata = { |
353 | &tmu0_device, | ||
354 | &tmu1_device, | ||
355 | &tmu2_device, | ||
356 | &tmu3_device, | ||
357 | &tmu4_device, | ||
358 | &tmu5_device, | ||
359 | &tmu6_device, | ||
360 | &tmu7_device, | ||
361 | &tmu8_device, | ||
80 | &sci_device, | 362 | &sci_device, |
81 | }; | 363 | }; |
82 | 364 | ||
@@ -87,6 +369,24 @@ static int __init sh7770_devices_setup(void) | |||
87 | } | 369 | } |
88 | __initcall(sh7770_devices_setup); | 370 | __initcall(sh7770_devices_setup); |
89 | 371 | ||
372 | static struct platform_device *sh7770_early_devices[] __initdata = { | ||
373 | &tmu0_device, | ||
374 | &tmu1_device, | ||
375 | &tmu2_device, | ||
376 | &tmu3_device, | ||
377 | &tmu4_device, | ||
378 | &tmu5_device, | ||
379 | &tmu6_device, | ||
380 | &tmu7_device, | ||
381 | &tmu8_device, | ||
382 | }; | ||
383 | |||
384 | void __init plat_early_device_setup(void) | ||
385 | { | ||
386 | early_platform_add_devices(sh7770_early_devices, | ||
387 | ARRAY_SIZE(sh7770_early_devices)); | ||
388 | } | ||
389 | |||
90 | void __init plat_irq_setup(void) | 390 | void __init plat_irq_setup(void) |
91 | { | 391 | { |
92 | } | 392 | } |
diff --git a/arch/sh/kernel/time.c b/arch/sh/kernel/time.c index a77838f539f8..2edde32c764b 100644 --- a/arch/sh/kernel/time.c +++ b/arch/sh/kernel/time.c | |||
@@ -22,9 +22,6 @@ | |||
22 | #include <linux/rtc.h> | 22 | #include <linux/rtc.h> |
23 | #include <asm/clock.h> | 23 | #include <asm/clock.h> |
24 | #include <asm/rtc.h> | 24 | #include <asm/rtc.h> |
25 | #include <asm/timer.h> | ||
26 | |||
27 | struct sys_timer *sys_timer; | ||
28 | 25 | ||
29 | /* Dummy RTC ops */ | 26 | /* Dummy RTC ops */ |
30 | static void null_rtc_get_time(struct timespec *tv) | 27 | static void null_rtc_get_time(struct timespec *tv) |
@@ -94,20 +91,9 @@ module_init(rtc_generic_init); | |||
94 | 91 | ||
95 | void (*board_time_init)(void); | 92 | void (*board_time_init)(void); |
96 | 93 | ||
97 | struct clocksource clocksource_sh = { | ||
98 | .name = "SuperH", | ||
99 | }; | ||
100 | |||
101 | unsigned long long sched_clock(void) | 94 | unsigned long long sched_clock(void) |
102 | { | 95 | { |
103 | unsigned long long cycles; | 96 | return (jiffies_64 - INITIAL_JIFFIES) * (NSEC_PER_SEC / HZ); |
104 | |||
105 | /* jiffies based sched_clock if no clocksource is installed */ | ||
106 | if (!clocksource_sh.rating) | ||
107 | return (jiffies_64 - INITIAL_JIFFIES) * (NSEC_PER_SEC / HZ); | ||
108 | |||
109 | cycles = clocksource_sh.read(&clocksource_sh); | ||
110 | return cyc2ns(&clocksource_sh, cycles); | ||
111 | } | 97 | } |
112 | 98 | ||
113 | static void __init sh_late_time_init(void) | 99 | static void __init sh_late_time_init(void) |
@@ -117,18 +103,7 @@ static void __init sh_late_time_init(void) | |||
117 | * Run probe() for one "earlytimer" device. | 103 | * Run probe() for one "earlytimer" device. |
118 | */ | 104 | */ |
119 | early_platform_driver_register_all("earlytimer"); | 105 | early_platform_driver_register_all("earlytimer"); |
120 | if (early_platform_driver_probe("earlytimer", 1, 0)) | 106 | early_platform_driver_probe("earlytimer", 1, 0); |
121 | return; | ||
122 | |||
123 | /* | ||
124 | * Find the timer to use as the system timer, it will be | ||
125 | * initialized for us. | ||
126 | */ | ||
127 | sys_timer = get_sys_timer(); | ||
128 | if (unlikely(!sys_timer)) | ||
129 | panic("System timer missing.\n"); | ||
130 | |||
131 | printk(KERN_INFO "Using %s for system timer\n", sys_timer->name); | ||
132 | } | 107 | } |
133 | 108 | ||
134 | void __init time_init(void) | 109 | void __init time_init(void) |
diff --git a/arch/sh/kernel/timers/Makefile b/arch/sh/kernel/timers/Makefile deleted file mode 100644 index 8bceba59e76f..000000000000 --- a/arch/sh/kernel/timers/Makefile +++ /dev/null | |||
@@ -1,7 +0,0 @@ | |||
1 | # | ||
2 | # Makefile for the various Linux/SuperH timers | ||
3 | # | ||
4 | |||
5 | obj-y := timer.o | ||
6 | |||
7 | obj-$(CONFIG_SH_TMU) += timer-tmu.o | ||
diff --git a/arch/sh/kernel/timers/timer-tmu.c b/arch/sh/kernel/timers/timer-tmu.c deleted file mode 100644 index a693dcdbe13e..000000000000 --- a/arch/sh/kernel/timers/timer-tmu.c +++ /dev/null | |||
@@ -1,295 +0,0 @@ | |||
1 | /* | ||
2 | * arch/sh/kernel/timers/timer-tmu.c - TMU Timer Support | ||
3 | * | ||
4 | * Copyright (C) 2005 - 2007 Paul Mundt | ||
5 | * | ||
6 | * TMU handling code hacked out of arch/sh/kernel/time.c | ||
7 | * | ||
8 | * Copyright (C) 1999 Tetsuya Okada & Niibe Yutaka | ||
9 | * Copyright (C) 2000 Philipp Rumpf <prumpf@tux.org> | ||
10 | * Copyright (C) 2002, 2003, 2004 Paul Mundt | ||
11 | * Copyright (C) 2002 M. R. Brown <mrbrown@linux-sh.org> | ||
12 | * | ||
13 | * This file is subject to the terms and conditions of the GNU General Public | ||
14 | * License. See the file "COPYING" in the main directory of this archive | ||
15 | * for more details. | ||
16 | */ | ||
17 | #include <linux/init.h> | ||
18 | #include <linux/kernel.h> | ||
19 | #include <linux/interrupt.h> | ||
20 | #include <linux/seqlock.h> | ||
21 | #include <linux/clockchips.h> | ||
22 | #include <asm/timer.h> | ||
23 | #include <asm/rtc.h> | ||
24 | #include <asm/io.h> | ||
25 | #include <asm/irq.h> | ||
26 | #include <asm/clock.h> | ||
27 | |||
28 | #define TMU_TOCR_INIT 0x00 | ||
29 | #define TMU_TCR_INIT 0x0020 | ||
30 | |||
31 | #define TMU0 (0) | ||
32 | #define TMU1 (1) | ||
33 | |||
34 | static inline void _tmu_start(int tmu_num) | ||
35 | { | ||
36 | ctrl_outb(ctrl_inb(TMU_012_TSTR) | (0x1<<tmu_num), TMU_012_TSTR); | ||
37 | } | ||
38 | |||
39 | static inline void _tmu_set_irq(int tmu_num, int enabled) | ||
40 | { | ||
41 | register unsigned long tmu_tcr = TMU0_TCR + (0xc*tmu_num); | ||
42 | ctrl_outw( (enabled ? ctrl_inw(tmu_tcr) | (1<<5) : ctrl_inw(tmu_tcr) & ~(1<<5)), tmu_tcr); | ||
43 | } | ||
44 | |||
45 | static inline void _tmu_stop(int tmu_num) | ||
46 | { | ||
47 | ctrl_outb(ctrl_inb(TMU_012_TSTR) & ~(0x1<<tmu_num), TMU_012_TSTR); | ||
48 | } | ||
49 | |||
50 | static inline void _tmu_clear_status(int tmu_num) | ||
51 | { | ||
52 | register unsigned long tmu_tcr = TMU0_TCR + (0xc*tmu_num); | ||
53 | /* Clear UNF bit */ | ||
54 | ctrl_outw(ctrl_inw(tmu_tcr) & ~0x100, tmu_tcr); | ||
55 | } | ||
56 | |||
57 | static inline unsigned long _tmu_read(int tmu_num) | ||
58 | { | ||
59 | return ctrl_inl(TMU0_TCNT+0xC*tmu_num); | ||
60 | } | ||
61 | |||
62 | static int tmu_timer_start(void) | ||
63 | { | ||
64 | _tmu_start(TMU0); | ||
65 | _tmu_start(TMU1); | ||
66 | _tmu_set_irq(TMU0,1); | ||
67 | return 0; | ||
68 | } | ||
69 | |||
70 | static int tmu_timer_stop(void) | ||
71 | { | ||
72 | _tmu_stop(TMU0); | ||
73 | _tmu_stop(TMU1); | ||
74 | _tmu_clear_status(TMU0); | ||
75 | return 0; | ||
76 | } | ||
77 | |||
78 | /* | ||
79 | * also when the module_clk is scaled the TMU1 | ||
80 | * will show the same frequency | ||
81 | */ | ||
82 | static int tmus_are_scaled; | ||
83 | |||
84 | static cycle_t tmu_timer_read(struct clocksource *cs) | ||
85 | { | ||
86 | return ((cycle_t)(~_tmu_read(TMU1)))<<tmus_are_scaled; | ||
87 | } | ||
88 | |||
89 | |||
90 | static unsigned long tmu_latest_interval[3]; | ||
91 | static void tmu_timer_set_interval(int tmu_num, unsigned long interval, unsigned int reload) | ||
92 | { | ||
93 | unsigned long tmu_tcnt = TMU0_TCNT + tmu_num*0xC; | ||
94 | unsigned long tmu_tcor = TMU0_TCOR + tmu_num*0xC; | ||
95 | |||
96 | _tmu_stop(tmu_num); | ||
97 | |||
98 | ctrl_outl(interval, tmu_tcnt); | ||
99 | tmu_latest_interval[tmu_num] = interval; | ||
100 | |||
101 | /* | ||
102 | * TCNT reloads from TCOR on underflow, clear it if we don't | ||
103 | * intend to auto-reload | ||
104 | */ | ||
105 | ctrl_outl( reload ? interval : 0 , tmu_tcor); | ||
106 | |||
107 | _tmu_start(tmu_num); | ||
108 | } | ||
109 | |||
110 | static int tmu_set_next_event(unsigned long cycles, | ||
111 | struct clock_event_device *evt) | ||
112 | { | ||
113 | tmu_timer_set_interval(TMU0,cycles, evt->mode == CLOCK_EVT_MODE_PERIODIC); | ||
114 | _tmu_set_irq(TMU0,1); | ||
115 | return 0; | ||
116 | } | ||
117 | |||
118 | static void tmu_set_mode(enum clock_event_mode mode, | ||
119 | struct clock_event_device *evt) | ||
120 | { | ||
121 | switch (mode) { | ||
122 | case CLOCK_EVT_MODE_PERIODIC: | ||
123 | ctrl_outl(tmu_latest_interval[TMU0], TMU0_TCOR); | ||
124 | break; | ||
125 | case CLOCK_EVT_MODE_ONESHOT: | ||
126 | ctrl_outl(0, TMU0_TCOR); | ||
127 | break; | ||
128 | case CLOCK_EVT_MODE_UNUSED: | ||
129 | case CLOCK_EVT_MODE_SHUTDOWN: | ||
130 | case CLOCK_EVT_MODE_RESUME: | ||
131 | break; | ||
132 | } | ||
133 | } | ||
134 | |||
135 | static struct clock_event_device tmu0_clockevent = { | ||
136 | .name = "tmu0", | ||
137 | .shift = 32, | ||
138 | .features = CLOCK_EVT_FEAT_PERIODIC | CLOCK_EVT_FEAT_ONESHOT, | ||
139 | .set_mode = tmu_set_mode, | ||
140 | .set_next_event = tmu_set_next_event, | ||
141 | }; | ||
142 | |||
143 | static irqreturn_t tmu_timer_interrupt(int irq, void *dummy) | ||
144 | { | ||
145 | struct clock_event_device *evt = &tmu0_clockevent; | ||
146 | _tmu_clear_status(TMU0); | ||
147 | _tmu_set_irq(TMU0,tmu0_clockevent.mode != CLOCK_EVT_MODE_ONESHOT); | ||
148 | |||
149 | switch (tmu0_clockevent.mode) { | ||
150 | case CLOCK_EVT_MODE_ONESHOT: | ||
151 | case CLOCK_EVT_MODE_PERIODIC: | ||
152 | evt->event_handler(evt); | ||
153 | break; | ||
154 | default: | ||
155 | break; | ||
156 | } | ||
157 | |||
158 | return IRQ_HANDLED; | ||
159 | } | ||
160 | |||
161 | static struct irqaction tmu0_irq = { | ||
162 | .name = "periodic/oneshot timer", | ||
163 | .handler = tmu_timer_interrupt, | ||
164 | .flags = IRQF_DISABLED | IRQF_TIMER | IRQF_IRQPOLL, | ||
165 | }; | ||
166 | |||
167 | static void __init tmu_clk_init(struct clk *clk) | ||
168 | { | ||
169 | u8 divisor = TMU_TCR_INIT & 0x7; | ||
170 | int tmu_num = clk->name[3]-'0'; | ||
171 | ctrl_outw(TMU_TCR_INIT, TMU0_TCR+(tmu_num*0xC)); | ||
172 | clk->rate = clk_get_rate(clk->parent) / (4 << (divisor << 1)); | ||
173 | } | ||
174 | |||
175 | static unsigned long tmu_clk_recalc(struct clk *clk) | ||
176 | { | ||
177 | int tmu_num = clk->name[3]-'0'; | ||
178 | unsigned long new_rate; | ||
179 | unsigned long flags; | ||
180 | u8 divisor = ctrl_inw(TMU0_TCR+tmu_num*0xC) & 0x7; | ||
181 | |||
182 | new_rate = clk_get_rate(clk->parent) / (4 << (divisor << 1)); | ||
183 | if (clk->rate == new_rate || tmu_num) | ||
184 | return clk->rate; /* No more work on TMU1 */ | ||
185 | |||
186 | local_irq_save(flags); | ||
187 | tmus_are_scaled = (clk->rate > new_rate); | ||
188 | |||
189 | _tmu_stop(TMU0); | ||
190 | |||
191 | tmu0_clockevent.mult = div_sc(clk->rate, NSEC_PER_SEC, | ||
192 | tmu0_clockevent.shift); | ||
193 | tmu0_clockevent.max_delta_ns = | ||
194 | clockevent_delta2ns(-1, &tmu0_clockevent); | ||
195 | tmu0_clockevent.min_delta_ns = | ||
196 | clockevent_delta2ns(1, &tmu0_clockevent); | ||
197 | |||
198 | if (tmus_are_scaled) | ||
199 | tmu_latest_interval[TMU0] >>= 1; | ||
200 | else | ||
201 | tmu_latest_interval[TMU0] <<= 1; | ||
202 | |||
203 | tmu_timer_set_interval(TMU0, | ||
204 | tmu_latest_interval[TMU0], | ||
205 | tmu0_clockevent.mode == CLOCK_EVT_MODE_PERIODIC); | ||
206 | |||
207 | _tmu_start(TMU0); | ||
208 | |||
209 | local_irq_restore(flags); | ||
210 | return new_rate; | ||
211 | } | ||
212 | |||
213 | static struct clk_ops tmu_clk_ops = { | ||
214 | .init = tmu_clk_init, | ||
215 | .recalc = tmu_clk_recalc, | ||
216 | }; | ||
217 | |||
218 | static struct clk tmu0_clk = { | ||
219 | .name = "tmu0_clk", | ||
220 | .ops = &tmu_clk_ops, | ||
221 | }; | ||
222 | |||
223 | static struct clk tmu1_clk = { | ||
224 | .name = "tmu1_clk", | ||
225 | .ops = &tmu_clk_ops, | ||
226 | }; | ||
227 | |||
228 | static int tmu_timer_init(void) | ||
229 | { | ||
230 | unsigned long interval; | ||
231 | unsigned long frequency; | ||
232 | |||
233 | setup_irq(CONFIG_SH_TIMER_IRQ, &tmu0_irq); | ||
234 | |||
235 | tmu0_clk.parent = clk_get(NULL, "module_clk"); | ||
236 | tmu1_clk.parent = clk_get(NULL, "module_clk"); | ||
237 | |||
238 | tmu_timer_stop(); | ||
239 | |||
240 | #if !defined(CONFIG_CPU_SUBTYPE_SH7720) && \ | ||
241 | !defined(CONFIG_CPU_SUBTYPE_SH7721) && \ | ||
242 | !defined(CONFIG_CPU_SUBTYPE_SH7760) && \ | ||
243 | !defined(CONFIG_CPU_SUBTYPE_SH7785) && \ | ||
244 | !defined(CONFIG_CPU_SUBTYPE_SH7786) && \ | ||
245 | !defined(CONFIG_CPU_SUBTYPE_SHX3) | ||
246 | ctrl_outb(TMU_TOCR_INIT, TMU_TOCR); | ||
247 | #endif | ||
248 | |||
249 | clk_register(&tmu0_clk); | ||
250 | clk_register(&tmu1_clk); | ||
251 | clk_enable(&tmu0_clk); | ||
252 | clk_enable(&tmu1_clk); | ||
253 | |||
254 | frequency = clk_get_rate(&tmu0_clk); | ||
255 | interval = (frequency + HZ / 2) / HZ; | ||
256 | |||
257 | tmu_timer_set_interval(TMU0,interval, 1); | ||
258 | tmu_timer_set_interval(TMU1,~0,1); | ||
259 | |||
260 | _tmu_start(TMU1); | ||
261 | |||
262 | clocksource_sh.rating = 200; | ||
263 | clocksource_sh.mask = CLOCKSOURCE_MASK(32); | ||
264 | clocksource_sh.read = tmu_timer_read; | ||
265 | clocksource_sh.shift = 10; | ||
266 | clocksource_sh.mult = clocksource_hz2mult(clk_get_rate(&tmu1_clk), | ||
267 | clocksource_sh.shift); | ||
268 | clocksource_sh.flags = CLOCK_SOURCE_IS_CONTINUOUS; | ||
269 | clocksource_register(&clocksource_sh); | ||
270 | |||
271 | tmu0_clockevent.mult = div_sc(frequency, NSEC_PER_SEC, | ||
272 | tmu0_clockevent.shift); | ||
273 | tmu0_clockevent.max_delta_ns = | ||
274 | clockevent_delta2ns(-1, &tmu0_clockevent); | ||
275 | tmu0_clockevent.min_delta_ns = | ||
276 | clockevent_delta2ns(1, &tmu0_clockevent); | ||
277 | |||
278 | tmu0_clockevent.cpumask = cpumask_of(0); | ||
279 | tmu0_clockevent.rating = 100; | ||
280 | |||
281 | clockevents_register_device(&tmu0_clockevent); | ||
282 | |||
283 | return 0; | ||
284 | } | ||
285 | |||
286 | static struct sys_timer_ops tmu_timer_ops = { | ||
287 | .init = tmu_timer_init, | ||
288 | .start = tmu_timer_start, | ||
289 | .stop = tmu_timer_stop, | ||
290 | }; | ||
291 | |||
292 | struct sys_timer tmu_timer = { | ||
293 | .name = "tmu", | ||
294 | .ops = &tmu_timer_ops, | ||
295 | }; | ||
diff --git a/arch/sh/kernel/timers/timer.c b/arch/sh/kernel/timers/timer.c deleted file mode 100644 index 920891acb779..000000000000 --- a/arch/sh/kernel/timers/timer.c +++ /dev/null | |||
@@ -1,49 +0,0 @@ | |||
1 | /* | ||
2 | * arch/sh/kernel/timers/timer.c - Common timer code | ||
3 | * | ||
4 | * Copyright (C) 2005 Paul Mundt | ||
5 | * | ||
6 | * This file is subject to the terms and conditions of the GNU General Public | ||
7 | * License. See the file "COPYING" in the main directory of this archive | ||
8 | * for more details. | ||
9 | */ | ||
10 | #include <linux/kernel.h> | ||
11 | #include <linux/init.h> | ||
12 | #include <linux/timer.h> | ||
13 | #include <linux/string.h> | ||
14 | #include <asm/timer.h> | ||
15 | |||
16 | static struct sys_timer *sys_timers[] = { | ||
17 | #ifdef CONFIG_SH_TMU | ||
18 | &tmu_timer, | ||
19 | #endif | ||
20 | NULL, | ||
21 | }; | ||
22 | |||
23 | static char timer_override[10]; | ||
24 | static int __init timer_setup(char *str) | ||
25 | { | ||
26 | if (str) | ||
27 | strlcpy(timer_override, str, sizeof(timer_override)); | ||
28 | return 1; | ||
29 | } | ||
30 | __setup("timer=", timer_setup); | ||
31 | |||
32 | struct sys_timer *get_sys_timer(void) | ||
33 | { | ||
34 | int i; | ||
35 | |||
36 | for (i = 0; i < ARRAY_SIZE(sys_timers); i++) { | ||
37 | struct sys_timer *t = sys_timers[i]; | ||
38 | |||
39 | if (unlikely(!t)) | ||
40 | break; | ||
41 | if (unlikely(timer_override[0])) | ||
42 | if ((strcmp(timer_override, t->name) != 0)) | ||
43 | continue; | ||
44 | if (likely(t->ops->init() == 0)) | ||
45 | return t; | ||
46 | } | ||
47 | |||
48 | return NULL; | ||
49 | } | ||