diff options
Diffstat (limited to 'arch')
204 files changed, 3927 insertions, 2232 deletions
diff --git a/arch/arm/configs/zylonite_defconfig b/arch/arm/configs/zylonite_defconfig new file mode 100644 index 000000000000..7949d04a3602 --- /dev/null +++ b/arch/arm/configs/zylonite_defconfig | |||
@@ -0,0 +1,736 @@ | |||
1 | # | ||
2 | # Automatically generated make config: don't edit | ||
3 | # Linux kernel version: 2.6.23 | ||
4 | # Tue Oct 23 13:33:20 2007 | ||
5 | # | ||
6 | CONFIG_ARM=y | ||
7 | CONFIG_SYS_SUPPORTS_APM_EMULATION=y | ||
8 | CONFIG_GENERIC_GPIO=y | ||
9 | CONFIG_GENERIC_TIME=y | ||
10 | CONFIG_GENERIC_CLOCKEVENTS=y | ||
11 | CONFIG_MMU=y | ||
12 | # CONFIG_NO_IOPORT is not set | ||
13 | CONFIG_GENERIC_HARDIRQS=y | ||
14 | CONFIG_STACKTRACE_SUPPORT=y | ||
15 | CONFIG_LOCKDEP_SUPPORT=y | ||
16 | CONFIG_TRACE_IRQFLAGS_SUPPORT=y | ||
17 | CONFIG_HARDIRQS_SW_RESEND=y | ||
18 | CONFIG_GENERIC_IRQ_PROBE=y | ||
19 | CONFIG_RWSEM_GENERIC_SPINLOCK=y | ||
20 | # CONFIG_ARCH_HAS_ILOG2_U32 is not set | ||
21 | # CONFIG_ARCH_HAS_ILOG2_U64 is not set | ||
22 | CONFIG_GENERIC_HWEIGHT=y | ||
23 | CONFIG_GENERIC_CALIBRATE_DELAY=y | ||
24 | CONFIG_ZONE_DMA=y | ||
25 | CONFIG_ARCH_MTD_XIP=y | ||
26 | CONFIG_VECTORS_BASE=0xffff0000 | ||
27 | CONFIG_DEFCONFIG_LIST="/lib/modules/$UNAME_RELEASE/.config" | ||
28 | |||
29 | # | ||
30 | # General setup | ||
31 | # | ||
32 | CONFIG_EXPERIMENTAL=y | ||
33 | CONFIG_BROKEN_ON_SMP=y | ||
34 | CONFIG_INIT_ENV_ARG_LIMIT=32 | ||
35 | CONFIG_LOCALVERSION="" | ||
36 | CONFIG_LOCALVERSION_AUTO=y | ||
37 | CONFIG_SWAP=y | ||
38 | CONFIG_SYSVIPC=y | ||
39 | CONFIG_SYSVIPC_SYSCTL=y | ||
40 | # CONFIG_POSIX_MQUEUE is not set | ||
41 | # CONFIG_BSD_PROCESS_ACCT is not set | ||
42 | # CONFIG_TASKSTATS is not set | ||
43 | # CONFIG_USER_NS is not set | ||
44 | # CONFIG_AUDIT is not set | ||
45 | # CONFIG_IKCONFIG is not set | ||
46 | CONFIG_LOG_BUF_SHIFT=18 | ||
47 | # CONFIG_CGROUPS is not set | ||
48 | CONFIG_FAIR_GROUP_SCHED=y | ||
49 | CONFIG_FAIR_USER_SCHED=y | ||
50 | # CONFIG_FAIR_CGROUP_SCHED is not set | ||
51 | CONFIG_SYSFS_DEPRECATED=y | ||
52 | # CONFIG_RELAY is not set | ||
53 | # CONFIG_BLK_DEV_INITRD is not set | ||
54 | # CONFIG_CC_OPTIMIZE_FOR_SIZE is not set | ||
55 | CONFIG_SYSCTL=y | ||
56 | # CONFIG_EMBEDDED is not set | ||
57 | CONFIG_UID16=y | ||
58 | CONFIG_SYSCTL_SYSCALL=y | ||
59 | CONFIG_KALLSYMS=y | ||
60 | # CONFIG_KALLSYMS_EXTRA_PASS is not set | ||
61 | CONFIG_HOTPLUG=y | ||
62 | CONFIG_PRINTK=y | ||
63 | CONFIG_BUG=y | ||
64 | CONFIG_ELF_CORE=y | ||
65 | CONFIG_BASE_FULL=y | ||
66 | CONFIG_FUTEX=y | ||
67 | CONFIG_ANON_INODES=y | ||
68 | CONFIG_EPOLL=y | ||
69 | CONFIG_SIGNALFD=y | ||
70 | CONFIG_EVENTFD=y | ||
71 | CONFIG_SHMEM=y | ||
72 | CONFIG_VM_EVENT_COUNTERS=y | ||
73 | CONFIG_SLUB_DEBUG=y | ||
74 | # CONFIG_SLAB is not set | ||
75 | CONFIG_SLUB=y | ||
76 | # CONFIG_SLOB is not set | ||
77 | CONFIG_RT_MUTEXES=y | ||
78 | # CONFIG_TINY_SHMEM is not set | ||
79 | CONFIG_BASE_SMALL=0 | ||
80 | CONFIG_MODULES=y | ||
81 | # CONFIG_MODULE_UNLOAD is not set | ||
82 | # CONFIG_MODVERSIONS is not set | ||
83 | # CONFIG_MODULE_SRCVERSION_ALL is not set | ||
84 | # CONFIG_KMOD is not set | ||
85 | CONFIG_BLOCK=y | ||
86 | # CONFIG_LBD is not set | ||
87 | # CONFIG_BLK_DEV_IO_TRACE is not set | ||
88 | # CONFIG_LSF is not set | ||
89 | # CONFIG_BLK_DEV_BSG is not set | ||
90 | |||
91 | # | ||
92 | # IO Schedulers | ||
93 | # | ||
94 | CONFIG_IOSCHED_NOOP=y | ||
95 | CONFIG_IOSCHED_AS=y | ||
96 | CONFIG_IOSCHED_DEADLINE=y | ||
97 | CONFIG_IOSCHED_CFQ=y | ||
98 | # CONFIG_DEFAULT_AS is not set | ||
99 | # CONFIG_DEFAULT_DEADLINE is not set | ||
100 | CONFIG_DEFAULT_CFQ=y | ||
101 | # CONFIG_DEFAULT_NOOP is not set | ||
102 | CONFIG_DEFAULT_IOSCHED="cfq" | ||
103 | |||
104 | # | ||
105 | # System Type | ||
106 | # | ||
107 | # CONFIG_ARCH_AAEC2000 is not set | ||
108 | # CONFIG_ARCH_INTEGRATOR is not set | ||
109 | # CONFIG_ARCH_REALVIEW is not set | ||
110 | # CONFIG_ARCH_VERSATILE is not set | ||
111 | # CONFIG_ARCH_AT91 is not set | ||
112 | # CONFIG_ARCH_CLPS7500 is not set | ||
113 | # CONFIG_ARCH_CLPS711X is not set | ||
114 | # CONFIG_ARCH_CO285 is not set | ||
115 | # CONFIG_ARCH_EBSA110 is not set | ||
116 | # CONFIG_ARCH_EP93XX is not set | ||
117 | # CONFIG_ARCH_FOOTBRIDGE is not set | ||
118 | # CONFIG_ARCH_NETX is not set | ||
119 | # CONFIG_ARCH_H720X is not set | ||
120 | # CONFIG_ARCH_IMX is not set | ||
121 | # CONFIG_ARCH_IOP13XX is not set | ||
122 | # CONFIG_ARCH_IOP32X is not set | ||
123 | # CONFIG_ARCH_IOP33X is not set | ||
124 | # CONFIG_ARCH_IXP23XX is not set | ||
125 | # CONFIG_ARCH_IXP2000 is not set | ||
126 | # CONFIG_ARCH_IXP4XX is not set | ||
127 | # CONFIG_ARCH_L7200 is not set | ||
128 | # CONFIG_ARCH_KS8695 is not set | ||
129 | # CONFIG_ARCH_NS9XXX is not set | ||
130 | # CONFIG_ARCH_MXC is not set | ||
131 | # CONFIG_ARCH_PNX4008 is not set | ||
132 | CONFIG_ARCH_PXA=y | ||
133 | # CONFIG_ARCH_RPC is not set | ||
134 | # CONFIG_ARCH_SA1100 is not set | ||
135 | # CONFIG_ARCH_S3C2410 is not set | ||
136 | # CONFIG_ARCH_SHARK is not set | ||
137 | # CONFIG_ARCH_LH7A40X is not set | ||
138 | # CONFIG_ARCH_DAVINCI is not set | ||
139 | # CONFIG_ARCH_OMAP is not set | ||
140 | |||
141 | # | ||
142 | # Intel PXA2xx/PXA3xx Implementations | ||
143 | # | ||
144 | |||
145 | # | ||
146 | # Supported PXA3xx Processor Variants | ||
147 | # | ||
148 | CONFIG_CPU_PXA300=y | ||
149 | CONFIG_CPU_PXA310=y | ||
150 | CONFIG_CPU_PXA320=y | ||
151 | # CONFIG_ARCH_LUBBOCK is not set | ||
152 | # CONFIG_MACH_LOGICPD_PXA270 is not set | ||
153 | # CONFIG_MACH_MAINSTONE is not set | ||
154 | # CONFIG_ARCH_PXA_IDP is not set | ||
155 | # CONFIG_PXA_SHARPSL is not set | ||
156 | # CONFIG_MACH_TRIZEPS4 is not set | ||
157 | # CONFIG_MACH_EM_X270 is not set | ||
158 | CONFIG_MACH_ZYLONITE=y | ||
159 | # CONFIG_MACH_ARMCORE is not set | ||
160 | CONFIG_PXA3xx=y | ||
161 | |||
162 | # | ||
163 | # Boot options | ||
164 | # | ||
165 | |||
166 | # | ||
167 | # Power management | ||
168 | # | ||
169 | |||
170 | # | ||
171 | # Processor Type | ||
172 | # | ||
173 | CONFIG_CPU_32=y | ||
174 | CONFIG_CPU_XSC3=y | ||
175 | CONFIG_CPU_32v5=y | ||
176 | CONFIG_CPU_ABRT_EV5T=y | ||
177 | CONFIG_CPU_CACHE_VIVT=y | ||
178 | CONFIG_CPU_TLB_V4WBI=y | ||
179 | CONFIG_CPU_CP15=y | ||
180 | CONFIG_CPU_CP15_MMU=y | ||
181 | CONFIG_IO_36=y | ||
182 | |||
183 | # | ||
184 | # Processor Features | ||
185 | # | ||
186 | # CONFIG_ARM_THUMB is not set | ||
187 | # CONFIG_CPU_DCACHE_DISABLE is not set | ||
188 | # CONFIG_CPU_BPREDICT_DISABLE is not set | ||
189 | # CONFIG_OUTER_CACHE is not set | ||
190 | CONFIG_IWMMXT=y | ||
191 | |||
192 | # | ||
193 | # Bus support | ||
194 | # | ||
195 | # CONFIG_PCI_SYSCALL is not set | ||
196 | # CONFIG_ARCH_SUPPORTS_MSI is not set | ||
197 | # CONFIG_PCCARD is not set | ||
198 | |||
199 | # | ||
200 | # Kernel Features | ||
201 | # | ||
202 | # CONFIG_TICK_ONESHOT is not set | ||
203 | # CONFIG_NO_HZ is not set | ||
204 | # CONFIG_HIGH_RES_TIMERS is not set | ||
205 | CONFIG_GENERIC_CLOCKEVENTS_BUILD=y | ||
206 | # CONFIG_PREEMPT is not set | ||
207 | CONFIG_HZ=100 | ||
208 | CONFIG_AEABI=y | ||
209 | CONFIG_OABI_COMPAT=y | ||
210 | # CONFIG_ARCH_DISCONTIGMEM_ENABLE is not set | ||
211 | CONFIG_SELECT_MEMORY_MODEL=y | ||
212 | CONFIG_FLATMEM_MANUAL=y | ||
213 | # CONFIG_DISCONTIGMEM_MANUAL is not set | ||
214 | # CONFIG_SPARSEMEM_MANUAL is not set | ||
215 | CONFIG_FLATMEM=y | ||
216 | CONFIG_FLAT_NODE_MEM_MAP=y | ||
217 | # CONFIG_SPARSEMEM_STATIC is not set | ||
218 | # CONFIG_SPARSEMEM_VMEMMAP_ENABLE is not set | ||
219 | CONFIG_SPLIT_PTLOCK_CPUS=4096 | ||
220 | # CONFIG_RESOURCES_64BIT is not set | ||
221 | CONFIG_ZONE_DMA_FLAG=1 | ||
222 | CONFIG_BOUNCE=y | ||
223 | CONFIG_VIRT_TO_BUS=y | ||
224 | CONFIG_ALIGNMENT_TRAP=y | ||
225 | |||
226 | # | ||
227 | # Boot options | ||
228 | # | ||
229 | CONFIG_ZBOOT_ROM_TEXT=0x0 | ||
230 | CONFIG_ZBOOT_ROM_BSS=0x0 | ||
231 | CONFIG_CMDLINE="root=/dev/nfs rootfstype=nfs nfsroot=192.168.1.100:/nfs/rootfs/ ip=192.168.1.101:192.168.1.100::255.255.255.0::eth0:on console=ttyS0,38400 mem=64M debug" | ||
232 | # CONFIG_XIP_KERNEL is not set | ||
233 | # CONFIG_KEXEC is not set | ||
234 | |||
235 | # | ||
236 | # Floating point emulation | ||
237 | # | ||
238 | |||
239 | # | ||
240 | # At least one emulation must be selected | ||
241 | # | ||
242 | CONFIG_FPE_NWFPE=y | ||
243 | # CONFIG_FPE_NWFPE_XP is not set | ||
244 | # CONFIG_FPE_FASTFPE is not set | ||
245 | |||
246 | # | ||
247 | # Userspace binary formats | ||
248 | # | ||
249 | CONFIG_BINFMT_ELF=y | ||
250 | # CONFIG_BINFMT_AOUT is not set | ||
251 | # CONFIG_BINFMT_MISC is not set | ||
252 | |||
253 | # | ||
254 | # Power management options | ||
255 | # | ||
256 | # CONFIG_PM is not set | ||
257 | CONFIG_SUSPEND_UP_POSSIBLE=y | ||
258 | |||
259 | # | ||
260 | # Networking | ||
261 | # | ||
262 | CONFIG_NET=y | ||
263 | |||
264 | # | ||
265 | # Networking options | ||
266 | # | ||
267 | CONFIG_PACKET=y | ||
268 | # CONFIG_PACKET_MMAP is not set | ||
269 | CONFIG_UNIX=y | ||
270 | # CONFIG_NET_KEY is not set | ||
271 | CONFIG_INET=y | ||
272 | # CONFIG_IP_MULTICAST is not set | ||
273 | # CONFIG_IP_ADVANCED_ROUTER is not set | ||
274 | CONFIG_IP_FIB_HASH=y | ||
275 | CONFIG_IP_PNP=y | ||
276 | CONFIG_IP_PNP_DHCP=y | ||
277 | CONFIG_IP_PNP_BOOTP=y | ||
278 | CONFIG_IP_PNP_RARP=y | ||
279 | # CONFIG_NET_IPIP is not set | ||
280 | # CONFIG_NET_IPGRE is not set | ||
281 | # CONFIG_ARPD is not set | ||
282 | # CONFIG_SYN_COOKIES is not set | ||
283 | # CONFIG_INET_AH is not set | ||
284 | # CONFIG_INET_ESP is not set | ||
285 | # CONFIG_INET_IPCOMP is not set | ||
286 | # CONFIG_INET_XFRM_TUNNEL is not set | ||
287 | # CONFIG_INET_TUNNEL is not set | ||
288 | # CONFIG_INET_XFRM_MODE_TRANSPORT is not set | ||
289 | # CONFIG_INET_XFRM_MODE_TUNNEL is not set | ||
290 | # CONFIG_INET_XFRM_MODE_BEET is not set | ||
291 | # CONFIG_INET_LRO is not set | ||
292 | # CONFIG_INET_DIAG is not set | ||
293 | # CONFIG_TCP_CONG_ADVANCED is not set | ||
294 | CONFIG_TCP_CONG_CUBIC=y | ||
295 | CONFIG_DEFAULT_TCP_CONG="cubic" | ||
296 | # CONFIG_TCP_MD5SIG is not set | ||
297 | # CONFIG_IPV6 is not set | ||
298 | # CONFIG_INET6_XFRM_TUNNEL is not set | ||
299 | # CONFIG_INET6_TUNNEL is not set | ||
300 | # CONFIG_NETWORK_SECMARK is not set | ||
301 | # CONFIG_NETFILTER is not set | ||
302 | # CONFIG_IP_DCCP is not set | ||
303 | # CONFIG_IP_SCTP is not set | ||
304 | # CONFIG_TIPC is not set | ||
305 | # CONFIG_ATM is not set | ||
306 | # CONFIG_BRIDGE is not set | ||
307 | # CONFIG_VLAN_8021Q is not set | ||
308 | # CONFIG_DECNET is not set | ||
309 | # CONFIG_LLC2 is not set | ||
310 | # CONFIG_IPX is not set | ||
311 | # CONFIG_ATALK is not set | ||
312 | # CONFIG_X25 is not set | ||
313 | # CONFIG_LAPB is not set | ||
314 | # CONFIG_ECONET is not set | ||
315 | # CONFIG_WAN_ROUTER is not set | ||
316 | # CONFIG_NET_SCHED is not set | ||
317 | |||
318 | # | ||
319 | # Network testing | ||
320 | # | ||
321 | # CONFIG_NET_PKTGEN is not set | ||
322 | # CONFIG_HAMRADIO is not set | ||
323 | # CONFIG_IRDA is not set | ||
324 | # CONFIG_BT is not set | ||
325 | # CONFIG_AF_RXRPC is not set | ||
326 | |||
327 | # | ||
328 | # Wireless | ||
329 | # | ||
330 | # CONFIG_CFG80211 is not set | ||
331 | # CONFIG_WIRELESS_EXT is not set | ||
332 | # CONFIG_MAC80211 is not set | ||
333 | # CONFIG_IEEE80211 is not set | ||
334 | # CONFIG_RFKILL is not set | ||
335 | # CONFIG_NET_9P is not set | ||
336 | |||
337 | # | ||
338 | # Device Drivers | ||
339 | # | ||
340 | |||
341 | # | ||
342 | # Generic Driver Options | ||
343 | # | ||
344 | CONFIG_UEVENT_HELPER_PATH="/sbin/hotplug" | ||
345 | CONFIG_STANDALONE=y | ||
346 | CONFIG_PREVENT_FIRMWARE_BUILD=y | ||
347 | CONFIG_FW_LOADER=y | ||
348 | # CONFIG_SYS_HYPERVISOR is not set | ||
349 | # CONFIG_CONNECTOR is not set | ||
350 | # CONFIG_MTD is not set | ||
351 | # CONFIG_PARPORT is not set | ||
352 | # CONFIG_BLK_DEV is not set | ||
353 | # CONFIG_MISC_DEVICES is not set | ||
354 | # CONFIG_IDE is not set | ||
355 | |||
356 | # | ||
357 | # SCSI device support | ||
358 | # | ||
359 | # CONFIG_RAID_ATTRS is not set | ||
360 | # CONFIG_SCSI is not set | ||
361 | # CONFIG_SCSI_DMA is not set | ||
362 | # CONFIG_SCSI_NETLINK is not set | ||
363 | # CONFIG_ATA is not set | ||
364 | # CONFIG_MD is not set | ||
365 | CONFIG_NETDEVICES=y | ||
366 | # CONFIG_NETDEVICES_MULTIQUEUE is not set | ||
367 | # CONFIG_DUMMY is not set | ||
368 | # CONFIG_BONDING is not set | ||
369 | # CONFIG_MACVLAN is not set | ||
370 | # CONFIG_EQUALIZER is not set | ||
371 | # CONFIG_TUN is not set | ||
372 | # CONFIG_VETH is not set | ||
373 | # CONFIG_PHYLIB is not set | ||
374 | CONFIG_NET_ETHERNET=y | ||
375 | CONFIG_MII=y | ||
376 | # CONFIG_AX88796 is not set | ||
377 | CONFIG_SMC91X=y | ||
378 | # CONFIG_DM9000 is not set | ||
379 | # CONFIG_SMC911X is not set | ||
380 | # CONFIG_IBM_NEW_EMAC_ZMII is not set | ||
381 | # CONFIG_IBM_NEW_EMAC_RGMII is not set | ||
382 | # CONFIG_IBM_NEW_EMAC_TAH is not set | ||
383 | # CONFIG_IBM_NEW_EMAC_EMAC4 is not set | ||
384 | # CONFIG_B44 is not set | ||
385 | # CONFIG_NETDEV_1000 is not set | ||
386 | # CONFIG_NETDEV_10000 is not set | ||
387 | |||
388 | # | ||
389 | # Wireless LAN | ||
390 | # | ||
391 | # CONFIG_WLAN_PRE80211 is not set | ||
392 | # CONFIG_WLAN_80211 is not set | ||
393 | # CONFIG_WAN is not set | ||
394 | # CONFIG_PPP is not set | ||
395 | # CONFIG_SLIP is not set | ||
396 | # CONFIG_SHAPER is not set | ||
397 | # CONFIG_NETCONSOLE is not set | ||
398 | # CONFIG_NETPOLL is not set | ||
399 | # CONFIG_NET_POLL_CONTROLLER is not set | ||
400 | # CONFIG_ISDN is not set | ||
401 | |||
402 | # | ||
403 | # Input device support | ||
404 | # | ||
405 | CONFIG_INPUT=y | ||
406 | # CONFIG_INPUT_FF_MEMLESS is not set | ||
407 | # CONFIG_INPUT_POLLDEV is not set | ||
408 | |||
409 | # | ||
410 | # Userland interfaces | ||
411 | # | ||
412 | CONFIG_INPUT_MOUSEDEV=y | ||
413 | # CONFIG_INPUT_MOUSEDEV_PSAUX is not set | ||
414 | CONFIG_INPUT_MOUSEDEV_SCREEN_X=1024 | ||
415 | CONFIG_INPUT_MOUSEDEV_SCREEN_Y=768 | ||
416 | # CONFIG_INPUT_JOYDEV is not set | ||
417 | # CONFIG_INPUT_EVDEV is not set | ||
418 | # CONFIG_INPUT_EVBUG is not set | ||
419 | |||
420 | # | ||
421 | # Input Device Drivers | ||
422 | # | ||
423 | # CONFIG_INPUT_KEYBOARD is not set | ||
424 | # CONFIG_INPUT_MOUSE is not set | ||
425 | # CONFIG_INPUT_JOYSTICK is not set | ||
426 | # CONFIG_INPUT_TABLET is not set | ||
427 | # CONFIG_INPUT_TOUCHSCREEN is not set | ||
428 | # CONFIG_INPUT_MISC is not set | ||
429 | |||
430 | # | ||
431 | # Hardware I/O ports | ||
432 | # | ||
433 | # CONFIG_SERIO is not set | ||
434 | # CONFIG_GAMEPORT is not set | ||
435 | |||
436 | # | ||
437 | # Character devices | ||
438 | # | ||
439 | CONFIG_VT=y | ||
440 | CONFIG_VT_CONSOLE=y | ||
441 | CONFIG_HW_CONSOLE=y | ||
442 | # CONFIG_VT_HW_CONSOLE_BINDING is not set | ||
443 | # CONFIG_SERIAL_NONSTANDARD is not set | ||
444 | |||
445 | # | ||
446 | # Serial drivers | ||
447 | # | ||
448 | # CONFIG_SERIAL_8250 is not set | ||
449 | |||
450 | # | ||
451 | # Non-8250 serial port support | ||
452 | # | ||
453 | CONFIG_SERIAL_PXA=y | ||
454 | CONFIG_SERIAL_PXA_CONSOLE=y | ||
455 | CONFIG_SERIAL_CORE=y | ||
456 | CONFIG_SERIAL_CORE_CONSOLE=y | ||
457 | CONFIG_UNIX98_PTYS=y | ||
458 | # CONFIG_LEGACY_PTYS is not set | ||
459 | # CONFIG_IPMI_HANDLER is not set | ||
460 | # CONFIG_HW_RANDOM is not set | ||
461 | # CONFIG_NVRAM is not set | ||
462 | # CONFIG_R3964 is not set | ||
463 | # CONFIG_RAW_DRIVER is not set | ||
464 | # CONFIG_TCG_TPM is not set | ||
465 | # CONFIG_I2C is not set | ||
466 | |||
467 | # | ||
468 | # SPI support | ||
469 | # | ||
470 | # CONFIG_SPI is not set | ||
471 | # CONFIG_SPI_MASTER is not set | ||
472 | # CONFIG_W1 is not set | ||
473 | # CONFIG_POWER_SUPPLY is not set | ||
474 | # CONFIG_HWMON is not set | ||
475 | |||
476 | # | ||
477 | # Sonics Silicon Backplane | ||
478 | # | ||
479 | CONFIG_SSB_POSSIBLE=y | ||
480 | # CONFIG_SSB is not set | ||
481 | |||
482 | # | ||
483 | # Multifunction device drivers | ||
484 | # | ||
485 | # CONFIG_MFD_SM501 is not set | ||
486 | |||
487 | # | ||
488 | # Multimedia devices | ||
489 | # | ||
490 | # CONFIG_VIDEO_DEV is not set | ||
491 | # CONFIG_DVB_CORE is not set | ||
492 | # CONFIG_DAB is not set | ||
493 | |||
494 | # | ||
495 | # Graphics support | ||
496 | # | ||
497 | # CONFIG_VGASTATE is not set | ||
498 | # CONFIG_VIDEO_OUTPUT_CONTROL is not set | ||
499 | CONFIG_FB=y | ||
500 | # CONFIG_FIRMWARE_EDID is not set | ||
501 | # CONFIG_FB_DDC is not set | ||
502 | CONFIG_FB_CFB_FILLRECT=y | ||
503 | CONFIG_FB_CFB_COPYAREA=y | ||
504 | CONFIG_FB_CFB_IMAGEBLIT=y | ||
505 | # CONFIG_FB_CFB_REV_PIXELS_IN_BYTE is not set | ||
506 | # CONFIG_FB_SYS_FILLRECT is not set | ||
507 | # CONFIG_FB_SYS_COPYAREA is not set | ||
508 | # CONFIG_FB_SYS_IMAGEBLIT is not set | ||
509 | # CONFIG_FB_SYS_FOPS is not set | ||
510 | CONFIG_FB_DEFERRED_IO=y | ||
511 | # CONFIG_FB_SVGALIB is not set | ||
512 | # CONFIG_FB_MACMODES is not set | ||
513 | # CONFIG_FB_BACKLIGHT is not set | ||
514 | # CONFIG_FB_MODE_HELPERS is not set | ||
515 | # CONFIG_FB_TILEBLITTING is not set | ||
516 | |||
517 | # | ||
518 | # Frame buffer hardware drivers | ||
519 | # | ||
520 | # CONFIG_FB_S1D13XXX is not set | ||
521 | CONFIG_FB_PXA=y | ||
522 | # CONFIG_FB_PXA_PARAMETERS is not set | ||
523 | # CONFIG_FB_MBX is not set | ||
524 | # CONFIG_FB_VIRTUAL is not set | ||
525 | # CONFIG_BACKLIGHT_LCD_SUPPORT is not set | ||
526 | |||
527 | # | ||
528 | # Display device support | ||
529 | # | ||
530 | # CONFIG_DISPLAY_SUPPORT is not set | ||
531 | |||
532 | # | ||
533 | # Console display driver support | ||
534 | # | ||
535 | # CONFIG_VGA_CONSOLE is not set | ||
536 | CONFIG_DUMMY_CONSOLE=y | ||
537 | CONFIG_FRAMEBUFFER_CONSOLE=y | ||
538 | CONFIG_FRAMEBUFFER_CONSOLE_DETECT_PRIMARY=y | ||
539 | # CONFIG_FRAMEBUFFER_CONSOLE_ROTATION is not set | ||
540 | CONFIG_FONTS=y | ||
541 | # CONFIG_FONT_8x8 is not set | ||
542 | # CONFIG_FONT_8x16 is not set | ||
543 | CONFIG_FONT_6x11=y | ||
544 | # CONFIG_FONT_7x14 is not set | ||
545 | # CONFIG_FONT_PEARL_8x8 is not set | ||
546 | # CONFIG_FONT_ACORN_8x8 is not set | ||
547 | # CONFIG_FONT_MINI_4x6 is not set | ||
548 | # CONFIG_FONT_SUN8x16 is not set | ||
549 | # CONFIG_FONT_SUN12x22 is not set | ||
550 | # CONFIG_FONT_10x18 is not set | ||
551 | CONFIG_LOGO=y | ||
552 | CONFIG_LOGO_LINUX_MONO=y | ||
553 | CONFIG_LOGO_LINUX_VGA16=y | ||
554 | CONFIG_LOGO_LINUX_CLUT224=y | ||
555 | |||
556 | # | ||
557 | # Sound | ||
558 | # | ||
559 | # CONFIG_SOUND is not set | ||
560 | # CONFIG_HID_SUPPORT is not set | ||
561 | # CONFIG_USB_SUPPORT is not set | ||
562 | # CONFIG_MMC is not set | ||
563 | # CONFIG_NEW_LEDS is not set | ||
564 | CONFIG_RTC_LIB=y | ||
565 | # CONFIG_RTC_CLASS is not set | ||
566 | |||
567 | # | ||
568 | # File systems | ||
569 | # | ||
570 | # CONFIG_EXT2_FS is not set | ||
571 | # CONFIG_EXT3_FS is not set | ||
572 | # CONFIG_EXT4DEV_FS is not set | ||
573 | # CONFIG_REISERFS_FS is not set | ||
574 | # CONFIG_JFS_FS is not set | ||
575 | CONFIG_FS_POSIX_ACL=y | ||
576 | # CONFIG_XFS_FS is not set | ||
577 | # CONFIG_GFS2_FS is not set | ||
578 | # CONFIG_OCFS2_FS is not set | ||
579 | # CONFIG_MINIX_FS is not set | ||
580 | # CONFIG_ROMFS_FS is not set | ||
581 | # CONFIG_INOTIFY is not set | ||
582 | # CONFIG_QUOTA is not set | ||
583 | CONFIG_DNOTIFY=y | ||
584 | # CONFIG_AUTOFS_FS is not set | ||
585 | # CONFIG_AUTOFS4_FS is not set | ||
586 | # CONFIG_FUSE_FS is not set | ||
587 | |||
588 | # | ||
589 | # CD-ROM/DVD Filesystems | ||
590 | # | ||
591 | # CONFIG_ISO9660_FS is not set | ||
592 | # CONFIG_UDF_FS is not set | ||
593 | |||
594 | # | ||
595 | # DOS/FAT/NT Filesystems | ||
596 | # | ||
597 | # CONFIG_MSDOS_FS is not set | ||
598 | # CONFIG_VFAT_FS is not set | ||
599 | # CONFIG_NTFS_FS is not set | ||
600 | |||
601 | # | ||
602 | # Pseudo filesystems | ||
603 | # | ||
604 | CONFIG_PROC_FS=y | ||
605 | CONFIG_PROC_SYSCTL=y | ||
606 | CONFIG_SYSFS=y | ||
607 | # CONFIG_TMPFS is not set | ||
608 | # CONFIG_HUGETLB_PAGE is not set | ||
609 | # CONFIG_CONFIGFS_FS is not set | ||
610 | |||
611 | # | ||
612 | # Miscellaneous filesystems | ||
613 | # | ||
614 | # CONFIG_ADFS_FS is not set | ||
615 | # CONFIG_AFFS_FS is not set | ||
616 | # CONFIG_HFS_FS is not set | ||
617 | # CONFIG_HFSPLUS_FS is not set | ||
618 | # CONFIG_BEFS_FS is not set | ||
619 | # CONFIG_BFS_FS is not set | ||
620 | # CONFIG_EFS_FS is not set | ||
621 | # CONFIG_CRAMFS is not set | ||
622 | # CONFIG_VXFS_FS is not set | ||
623 | # CONFIG_HPFS_FS is not set | ||
624 | # CONFIG_QNX4FS_FS is not set | ||
625 | # CONFIG_SYSV_FS is not set | ||
626 | # CONFIG_UFS_FS is not set | ||
627 | CONFIG_NETWORK_FILESYSTEMS=y | ||
628 | CONFIG_NFS_FS=y | ||
629 | CONFIG_NFS_V3=y | ||
630 | CONFIG_NFS_V3_ACL=y | ||
631 | CONFIG_NFS_V4=y | ||
632 | CONFIG_NFS_DIRECTIO=y | ||
633 | # CONFIG_NFSD is not set | ||
634 | CONFIG_ROOT_NFS=y | ||
635 | CONFIG_LOCKD=y | ||
636 | CONFIG_LOCKD_V4=y | ||
637 | CONFIG_NFS_ACL_SUPPORT=y | ||
638 | CONFIG_NFS_COMMON=y | ||
639 | CONFIG_SUNRPC=y | ||
640 | CONFIG_SUNRPC_GSS=y | ||
641 | # CONFIG_SUNRPC_BIND34 is not set | ||
642 | CONFIG_RPCSEC_GSS_KRB5=y | ||
643 | # CONFIG_RPCSEC_GSS_SPKM3 is not set | ||
644 | # CONFIG_SMB_FS is not set | ||
645 | # CONFIG_CIFS is not set | ||
646 | # CONFIG_NCP_FS is not set | ||
647 | # CONFIG_CODA_FS is not set | ||
648 | # CONFIG_AFS_FS is not set | ||
649 | |||
650 | # | ||
651 | # Partition Types | ||
652 | # | ||
653 | # CONFIG_PARTITION_ADVANCED is not set | ||
654 | CONFIG_MSDOS_PARTITION=y | ||
655 | # CONFIG_NLS is not set | ||
656 | # CONFIG_DLM is not set | ||
657 | # CONFIG_INSTRUMENTATION is not set | ||
658 | |||
659 | # | ||
660 | # Kernel hacking | ||
661 | # | ||
662 | # CONFIG_PRINTK_TIME is not set | ||
663 | CONFIG_ENABLE_MUST_CHECK=y | ||
664 | # CONFIG_MAGIC_SYSRQ is not set | ||
665 | # CONFIG_UNUSED_SYMBOLS is not set | ||
666 | # CONFIG_DEBUG_FS is not set | ||
667 | # CONFIG_HEADERS_CHECK is not set | ||
668 | # CONFIG_DEBUG_KERNEL is not set | ||
669 | # CONFIG_SLUB_DEBUG_ON is not set | ||
670 | CONFIG_DEBUG_BUGVERBOSE=y | ||
671 | CONFIG_FRAME_POINTER=y | ||
672 | # CONFIG_SAMPLES is not set | ||
673 | CONFIG_DEBUG_USER=y | ||
674 | |||
675 | # | ||
676 | # Security options | ||
677 | # | ||
678 | # CONFIG_KEYS is not set | ||
679 | # CONFIG_SECURITY is not set | ||
680 | # CONFIG_SECURITY_FILE_CAPABILITIES is not set | ||
681 | CONFIG_CRYPTO=y | ||
682 | CONFIG_CRYPTO_ALGAPI=y | ||
683 | CONFIG_CRYPTO_BLKCIPHER=y | ||
684 | CONFIG_CRYPTO_MANAGER=y | ||
685 | # CONFIG_CRYPTO_HMAC is not set | ||
686 | # CONFIG_CRYPTO_XCBC is not set | ||
687 | # CONFIG_CRYPTO_NULL is not set | ||
688 | # CONFIG_CRYPTO_MD4 is not set | ||
689 | CONFIG_CRYPTO_MD5=y | ||
690 | # CONFIG_CRYPTO_SHA1 is not set | ||
691 | # CONFIG_CRYPTO_SHA256 is not set | ||
692 | # CONFIG_CRYPTO_SHA512 is not set | ||
693 | # CONFIG_CRYPTO_WP512 is not set | ||
694 | # CONFIG_CRYPTO_TGR192 is not set | ||
695 | # CONFIG_CRYPTO_GF128MUL is not set | ||
696 | # CONFIG_CRYPTO_ECB is not set | ||
697 | CONFIG_CRYPTO_CBC=y | ||
698 | # CONFIG_CRYPTO_PCBC is not set | ||
699 | # CONFIG_CRYPTO_LRW is not set | ||
700 | # CONFIG_CRYPTO_XTS is not set | ||
701 | # CONFIG_CRYPTO_CRYPTD is not set | ||
702 | CONFIG_CRYPTO_DES=y | ||
703 | # CONFIG_CRYPTO_FCRYPT is not set | ||
704 | # CONFIG_CRYPTO_BLOWFISH is not set | ||
705 | # CONFIG_CRYPTO_TWOFISH is not set | ||
706 | # CONFIG_CRYPTO_SERPENT is not set | ||
707 | # CONFIG_CRYPTO_AES is not set | ||
708 | # CONFIG_CRYPTO_CAST5 is not set | ||
709 | # CONFIG_CRYPTO_CAST6 is not set | ||
710 | # CONFIG_CRYPTO_TEA is not set | ||
711 | # CONFIG_CRYPTO_ARC4 is not set | ||
712 | # CONFIG_CRYPTO_KHAZAD is not set | ||
713 | # CONFIG_CRYPTO_ANUBIS is not set | ||
714 | # CONFIG_CRYPTO_SEED is not set | ||
715 | # CONFIG_CRYPTO_DEFLATE is not set | ||
716 | # CONFIG_CRYPTO_MICHAEL_MIC is not set | ||
717 | # CONFIG_CRYPTO_CRC32C is not set | ||
718 | # CONFIG_CRYPTO_CAMELLIA is not set | ||
719 | # CONFIG_CRYPTO_TEST is not set | ||
720 | # CONFIG_CRYPTO_AUTHENC is not set | ||
721 | # CONFIG_CRYPTO_HW is not set | ||
722 | |||
723 | # | ||
724 | # Library routines | ||
725 | # | ||
726 | CONFIG_BITREVERSE=y | ||
727 | # CONFIG_CRC_CCITT is not set | ||
728 | # CONFIG_CRC16 is not set | ||
729 | # CONFIG_CRC_ITU_T is not set | ||
730 | CONFIG_CRC32=y | ||
731 | # CONFIG_CRC7 is not set | ||
732 | # CONFIG_LIBCRC32C is not set | ||
733 | CONFIG_PLIST=y | ||
734 | CONFIG_HAS_IOMEM=y | ||
735 | CONFIG_HAS_IOPORT=y | ||
736 | CONFIG_HAS_DMA=y | ||
diff --git a/arch/arm/mach-ixp2000/Kconfig b/arch/arm/mach-ixp2000/Kconfig index 86f53f8ccbf5..08d2707f6ca8 100644 --- a/arch/arm/mach-ixp2000/Kconfig +++ b/arch/arm/mach-ixp2000/Kconfig | |||
@@ -14,7 +14,7 @@ config ARCH_ENP2611 | |||
14 | help | 14 | help |
15 | Say 'Y' here if you want your kernel to support the Radisys | 15 | Say 'Y' here if you want your kernel to support the Radisys |
16 | ENP2611 PCI network processing card. For more information on | 16 | ENP2611 PCI network processing card. For more information on |
17 | this card, see <file:Documentation/arm/ENP2611>. | 17 | this card, see <file:Documentation/arm/IXP2000>. |
18 | 18 | ||
19 | config ARCH_IXDP2400 | 19 | config ARCH_IXDP2400 |
20 | bool "Support Intel IXDP2400" | 20 | bool "Support Intel IXDP2400" |
diff --git a/arch/arm/mach-netx/xc.c b/arch/arm/mach-netx/xc.c index 172a058ddd66..bd5184fe177c 100644 --- a/arch/arm/mach-netx/xc.c +++ b/arch/arm/mach-netx/xc.c | |||
@@ -190,15 +190,15 @@ struct xc *request_xc(int xcno, struct device *dev) | |||
190 | goto exit; | 190 | goto exit; |
191 | 191 | ||
192 | if (!request_mem_region | 192 | if (!request_mem_region |
193 | (NETX_PA_XPEC(xcno), XPEC_MEM_SIZE, dev->kobj.name)) | 193 | (NETX_PA_XPEC(xcno), XPEC_MEM_SIZE, kobject_name(dev->kobj))) |
194 | goto exit_free; | 194 | goto exit_free; |
195 | 195 | ||
196 | if (!request_mem_region | 196 | if (!request_mem_region |
197 | (NETX_PA_XMAC(xcno), XMAC_MEM_SIZE, dev->kobj.name)) | 197 | (NETX_PA_XMAC(xcno), XMAC_MEM_SIZE, kobject_name(dev->kobj))) |
198 | goto exit_release_1; | 198 | goto exit_release_1; |
199 | 199 | ||
200 | if (!request_mem_region | 200 | if (!request_mem_region |
201 | (SRAM_INTERNAL_PHYS(xcno), SRAM_MEM_SIZE, dev->kobj.name)) | 201 | (SRAM_INTERNAL_PHYS(xcno), SRAM_MEM_SIZE, kobject_name(dev->kobj))) |
202 | goto exit_release_2; | 202 | goto exit_release_2; |
203 | 203 | ||
204 | x->xpec_base = (void * __iomem)io_p2v(NETX_PA_XPEC(xcno)); | 204 | x->xpec_base = (void * __iomem)io_p2v(NETX_PA_XPEC(xcno)); |
diff --git a/arch/arm/mach-omap1/board-h2.c b/arch/arm/mach-omap1/board-h2.c index b0921622566f..130681201c19 100644 --- a/arch/arm/mach-omap1/board-h2.c +++ b/arch/arm/mach-omap1/board-h2.c | |||
@@ -343,6 +343,7 @@ static struct platform_device *h2_devices[] __initdata = { | |||
343 | &h2_mcbsp1_device, | 343 | &h2_mcbsp1_device, |
344 | }; | 344 | }; |
345 | 345 | ||
346 | #ifdef CONFIG_I2C_BOARDINFO | ||
346 | static struct i2c_board_info __initdata h2_i2c_board_info[] = { | 347 | static struct i2c_board_info __initdata h2_i2c_board_info[] = { |
347 | { | 348 | { |
348 | I2C_BOARD_INFO("tps65010", 0x48), | 349 | I2C_BOARD_INFO("tps65010", 0x48), |
@@ -356,6 +357,7 @@ static struct i2c_board_info __initdata h2_i2c_board_info[] = { | |||
356 | * - ... etc | 357 | * - ... etc |
357 | */ | 358 | */ |
358 | }; | 359 | }; |
360 | #endif | ||
359 | 361 | ||
360 | static void __init h2_init_smc91x(void) | 362 | static void __init h2_init_smc91x(void) |
361 | { | 363 | { |
@@ -467,8 +469,10 @@ static void __init h2_init(void) | |||
467 | if (gpio_request(58, "tps65010") == 0) | 469 | if (gpio_request(58, "tps65010") == 0) |
468 | gpio_direction_input(58); | 470 | gpio_direction_input(58); |
469 | 471 | ||
472 | #ifdef CONFIG_I2C_BOARDINFO | ||
470 | i2c_register_board_info(1, h2_i2c_board_info, | 473 | i2c_register_board_info(1, h2_i2c_board_info, |
471 | ARRAY_SIZE(h2_i2c_board_info)); | 474 | ARRAY_SIZE(h2_i2c_board_info)); |
475 | #endif | ||
472 | } | 476 | } |
473 | 477 | ||
474 | static void __init h2_map_io(void) | 478 | static void __init h2_map_io(void) |
diff --git a/arch/arm/mach-omap2/clock.c b/arch/arm/mach-omap2/clock.c index d9af4367f8bb..e6e85b7b097b 100644 --- a/arch/arm/mach-omap2/clock.c +++ b/arch/arm/mach-omap2/clock.c | |||
@@ -651,7 +651,7 @@ static u32 omap2_get_clksel(u32 *div_sel, u32 *field_mask, | |||
651 | break; | 651 | break; |
652 | case CM_SYSCLKOUT_SEL1: | 652 | case CM_SYSCLKOUT_SEL1: |
653 | div_addr = (u32)&PRCM_CLKOUT_CTRL; | 653 | div_addr = (u32)&PRCM_CLKOUT_CTRL; |
654 | if ((div_off == 3) || (div_off = 11)) | 654 | if ((div_off == 3) || (div_off == 11)) |
655 | mask= 0x3; | 655 | mask= 0x3; |
656 | break; | 656 | break; |
657 | case CM_CORE_SEL1: | 657 | case CM_CORE_SEL1: |
diff --git a/arch/arm/mach-pxa/mfp.c b/arch/arm/mach-pxa/mfp.c index 5cd3cadbbd10..436f96574964 100644 --- a/arch/arm/mach-pxa/mfp.c +++ b/arch/arm/mach-pxa/mfp.c | |||
@@ -5,7 +5,7 @@ | |||
5 | * | 5 | * |
6 | * Copyright (C) 2007 Marvell Internation Ltd. | 6 | * Copyright (C) 2007 Marvell Internation Ltd. |
7 | * | 7 | * |
8 | * 2007-08-21: eric miao <eric.y.miao@gmail.com> | 8 | * 2007-08-21: eric miao <eric.miao@marvell.com> |
9 | * initial version | 9 | * initial version |
10 | * | 10 | * |
11 | * This program is free software; you can redistribute it and/or modify | 11 | * This program is free software; you can redistribute it and/or modify |
diff --git a/arch/arm/mach-pxa/pxa300.c b/arch/arm/mach-pxa/pxa300.c index 7a34231f3172..0a0d3877f212 100644 --- a/arch/arm/mach-pxa/pxa300.c +++ b/arch/arm/mach-pxa/pxa300.c | |||
@@ -5,7 +5,7 @@ | |||
5 | * | 5 | * |
6 | * Copyright (C) 2007 Marvell Internation Ltd. | 6 | * Copyright (C) 2007 Marvell Internation Ltd. |
7 | * | 7 | * |
8 | * 2007-08-21: eric miao <eric.y.miao@gmail.com> | 8 | * 2007-08-21: eric miao <eric.miao@marvell.com> |
9 | * initial version | 9 | * initial version |
10 | * | 10 | * |
11 | * This program is free software; you can redistribute it and/or modify | 11 | * This program is free software; you can redistribute it and/or modify |
diff --git a/arch/arm/mach-pxa/pxa320.c b/arch/arm/mach-pxa/pxa320.c index cd9eba5b3df9..1010f77d977a 100644 --- a/arch/arm/mach-pxa/pxa320.c +++ b/arch/arm/mach-pxa/pxa320.c | |||
@@ -5,7 +5,7 @@ | |||
5 | * | 5 | * |
6 | * Copyright (C) 2007 Marvell Internation Ltd. | 6 | * Copyright (C) 2007 Marvell Internation Ltd. |
7 | * | 7 | * |
8 | * 2007-08-21: eric miao <eric.y.miao@gmail.com> | 8 | * 2007-08-21: eric miao <eric.miao@marvell.com> |
9 | * initial version | 9 | * initial version |
10 | * | 10 | * |
11 | * This program is free software; you can redistribute it and/or modify | 11 | * This program is free software; you can redistribute it and/or modify |
diff --git a/arch/arm/mach-pxa/pxa3xx.c b/arch/arm/mach-pxa/pxa3xx.c index 39f0de8c189e..5da798282a54 100644 --- a/arch/arm/mach-pxa/pxa3xx.c +++ b/arch/arm/mach-pxa/pxa3xx.c | |||
@@ -5,7 +5,7 @@ | |||
5 | * | 5 | * |
6 | * Copyright (C) 2006 Marvell International Ltd. | 6 | * Copyright (C) 2006 Marvell International Ltd. |
7 | * | 7 | * |
8 | * 2007-09-02: eric miao <eric.y.miao@gmail.com> | 8 | * 2007-09-02: eric miao <eric.miao@marvell.com> |
9 | * initial version | 9 | * initial version |
10 | * | 10 | * |
11 | * This program is free software; you can redistribute it and/or modify | 11 | * This program is free software; you can redistribute it and/or modify |
diff --git a/arch/arm/mach-pxa/time.c b/arch/arm/mach-pxa/time.c index ec4286c7931c..a2d45d742ce4 100644 --- a/arch/arm/mach-pxa/time.c +++ b/arch/arm/mach-pxa/time.c | |||
@@ -151,6 +151,9 @@ pxa_osmr0_set_mode(enum clock_event_mode mode, struct clock_event_device *dev) | |||
151 | OIER &= ~OIER_E0; | 151 | OIER &= ~OIER_E0; |
152 | raw_local_irq_restore(irqflags); | 152 | raw_local_irq_restore(irqflags); |
153 | break; | 153 | break; |
154 | |||
155 | case CLOCK_EVT_MODE_RESUME: | ||
156 | break; | ||
154 | } | 157 | } |
155 | } | 158 | } |
156 | 159 | ||
diff --git a/arch/arm/mach-pxa/zylonite.c b/arch/arm/mach-pxa/zylonite.c index 3f18d760dd1b..743a87b2faa1 100644 --- a/arch/arm/mach-pxa/zylonite.c +++ b/arch/arm/mach-pxa/zylonite.c | |||
@@ -5,7 +5,7 @@ | |||
5 | * | 5 | * |
6 | * Copyright (C) 2006 Marvell International Ltd. | 6 | * Copyright (C) 2006 Marvell International Ltd. |
7 | * | 7 | * |
8 | * 2007-09-04: eric miao <eric.y.miao@gmail.com> | 8 | * 2007-09-04: eric miao <eric.miao@marvell.com> |
9 | * rewrite to align with latest kernel | 9 | * rewrite to align with latest kernel |
10 | * | 10 | * |
11 | * This program is free software; you can redistribute it and/or modify | 11 | * This program is free software; you can redistribute it and/or modify |
diff --git a/arch/arm/mach-pxa/zylonite_pxa300.c b/arch/arm/mach-pxa/zylonite_pxa300.c index b5fbd2f4c693..1832bc316501 100644 --- a/arch/arm/mach-pxa/zylonite_pxa300.c +++ b/arch/arm/mach-pxa/zylonite_pxa300.c | |||
@@ -5,7 +5,7 @@ | |||
5 | * PXA3xx Development Platform (aka Zylonite) | 5 | * PXA3xx Development Platform (aka Zylonite) |
6 | * | 6 | * |
7 | * Copyright (C) 2007 Marvell Internation Ltd. | 7 | * Copyright (C) 2007 Marvell Internation Ltd. |
8 | * 2007-08-21: eric miao <eric.y.miao@gmail.com> | 8 | * 2007-08-21: eric miao <eric.miao@marvell.com> |
9 | * initial version | 9 | * initial version |
10 | * | 10 | * |
11 | * This program is free software; you can redistribute it and/or modify | 11 | * This program is free software; you can redistribute it and/or modify |
diff --git a/arch/arm/mach-pxa/zylonite_pxa320.c b/arch/arm/mach-pxa/zylonite_pxa320.c index 63cb36be086b..94c715808b59 100644 --- a/arch/arm/mach-pxa/zylonite_pxa320.c +++ b/arch/arm/mach-pxa/zylonite_pxa320.c | |||
@@ -5,7 +5,7 @@ | |||
5 | * PXA3xx Development Platform (aka Zylonite) | 5 | * PXA3xx Development Platform (aka Zylonite) |
6 | * | 6 | * |
7 | * Copyright (C) 2007 Marvell Internation Ltd. | 7 | * Copyright (C) 2007 Marvell Internation Ltd. |
8 | * 2007-08-21: eric miao <eric.y.miao@gmail.com> | 8 | * 2007-08-21: eric miao <eric.miao@marvell.com> |
9 | * initial version | 9 | * initial version |
10 | * | 10 | * |
11 | * This program is free software; you can redistribute it and/or modify | 11 | * This program is free software; you can redistribute it and/or modify |
diff --git a/arch/arm/mm/proc-arm926.S b/arch/arm/mm/proc-arm926.S index 5b80b6bdd0cb..194ef48968e6 100644 --- a/arch/arm/mm/proc-arm926.S +++ b/arch/arm/mm/proc-arm926.S | |||
@@ -105,9 +105,13 @@ ENTRY(cpu_arm926_do_idle) | |||
105 | mrc p15, 0, r1, c1, c0, 0 @ Read control register | 105 | mrc p15, 0, r1, c1, c0, 0 @ Read control register |
106 | mcr p15, 0, r0, c7, c10, 4 @ Drain write buffer | 106 | mcr p15, 0, r0, c7, c10, 4 @ Drain write buffer |
107 | bic r2, r1, #1 << 12 | 107 | bic r2, r1, #1 << 12 |
108 | mrs r3, cpsr @ Disable FIQs while Icache | ||
109 | orr ip, r3, #PSR_F_BIT @ is disabled | ||
110 | msr cpsr_c, ip | ||
108 | mcr p15, 0, r2, c1, c0, 0 @ Disable I cache | 111 | mcr p15, 0, r2, c1, c0, 0 @ Disable I cache |
109 | mcr p15, 0, r0, c7, c0, 4 @ Wait for interrupt | 112 | mcr p15, 0, r0, c7, c0, 4 @ Wait for interrupt |
110 | mcr p15, 0, r1, c1, c0, 0 @ Restore ICache enable | 113 | mcr p15, 0, r1, c1, c0, 0 @ Restore ICache enable |
114 | msr cpsr_c, r3 @ Restore FIQ state | ||
111 | mov pc, lr | 115 | mov pc, lr |
112 | 116 | ||
113 | /* | 117 | /* |
diff --git a/arch/blackfin/Kconfig b/arch/blackfin/Kconfig index 7888551ed939..9f9de3e95826 100644 --- a/arch/blackfin/Kconfig +++ b/arch/blackfin/Kconfig | |||
@@ -295,6 +295,12 @@ config PNAV10 | |||
295 | help | 295 | help |
296 | PNAV 1.0 board Support. | 296 | PNAV 1.0 board Support. |
297 | 297 | ||
298 | config H8606_HVSISTEMAS | ||
299 | bool "HV Sistemas H8606" | ||
300 | depends on (BF532) | ||
301 | help | ||
302 | HV Sistemas H8606 board support. | ||
303 | |||
298 | config GENERIC_BOARD | 304 | config GENERIC_BOARD |
299 | bool "Custom" | 305 | bool "Custom" |
300 | depends on (BF537 || BF536 \ | 306 | depends on (BF537 || BF536 \ |
@@ -317,7 +323,8 @@ config MEM_MT48LC64M4A2FB_7E | |||
317 | config MEM_MT48LC16M16A2TG_75 | 323 | config MEM_MT48LC16M16A2TG_75 |
318 | bool | 324 | bool |
319 | depends on (BFIN533_EZKIT || BFIN561_EZKIT \ | 325 | depends on (BFIN533_EZKIT || BFIN561_EZKIT \ |
320 | || BFIN533_BLUETECHNIX_CM || BFIN537_BLUETECHNIX_CM) | 326 | || BFIN533_BLUETECHNIX_CM || BFIN537_BLUETECHNIX_CM \ |
327 | || H8606_HVSISTEMAS) | ||
321 | default y | 328 | default y |
322 | 329 | ||
323 | config MEM_MT48LC32M8A2_75 | 330 | config MEM_MT48LC32M8A2_75 |
@@ -366,7 +373,7 @@ config CLKIN_HZ | |||
366 | int "Crystal Frequency in Hz" | 373 | int "Crystal Frequency in Hz" |
367 | default "11059200" if BFIN533_STAMP | 374 | default "11059200" if BFIN533_STAMP |
368 | default "27000000" if BFIN533_EZKIT | 375 | default "27000000" if BFIN533_EZKIT |
369 | default "25000000" if (BFIN537_STAMP || BFIN527_EZKIT) | 376 | default "25000000" if (BFIN537_STAMP || BFIN527_EZKIT || H8606_HVSISTEMAS) |
370 | default "30000000" if BFIN561_EZKIT | 377 | default "30000000" if BFIN561_EZKIT |
371 | default "24576000" if PNAV10 | 378 | default "24576000" if PNAV10 |
372 | help | 379 | help |
@@ -404,6 +411,7 @@ config VCO_MULT | |||
404 | default "20" if BFIN537_BLUETECHNIX_CM | 411 | default "20" if BFIN537_BLUETECHNIX_CM |
405 | default "20" if BFIN561_BLUETECHNIX_CM | 412 | default "20" if BFIN561_BLUETECHNIX_CM |
406 | default "20" if BFIN561_EZKIT | 413 | default "20" if BFIN561_EZKIT |
414 | default "16" if H8606_HVSISTEMAS | ||
407 | help | 415 | help |
408 | This controls the frequency of the on-chip PLL. This can be between 1 and 64. | 416 | This controls the frequency of the on-chip PLL. This can be between 1 and 64. |
409 | PLL Frequency = (Crystal Frequency) * (this setting) | 417 | PLL Frequency = (Crystal Frequency) * (this setting) |
@@ -440,6 +448,7 @@ config SCLK_DIV | |||
440 | default 4 if BFIN537_BLUETECHNIX_CM | 448 | default 4 if BFIN537_BLUETECHNIX_CM |
441 | default 4 if BFIN561_BLUETECHNIX_CM | 449 | default 4 if BFIN561_BLUETECHNIX_CM |
442 | default 5 if BFIN561_EZKIT | 450 | default 5 if BFIN561_EZKIT |
451 | default 3 if H8606_HVSISTEMAS | ||
443 | help | 452 | help |
444 | This sets the frequency of the system clock (including SDRAM or DDR). | 453 | This sets the frequency of the system clock (including SDRAM or DDR). |
445 | This can be between 1 and 15 | 454 | This can be between 1 and 15 |
@@ -492,11 +501,13 @@ config MEM_SIZE | |||
492 | default 64 if BFIN561_EZKIT | 501 | default 64 if BFIN561_EZKIT |
493 | default 128 if BFIN533_STAMP | 502 | default 128 if BFIN533_STAMP |
494 | default 64 if PNAV10 | 503 | default 64 if PNAV10 |
504 | default 32 if H8606_HVSISTEMAS | ||
495 | 505 | ||
496 | config MEM_ADD_WIDTH | 506 | config MEM_ADD_WIDTH |
497 | int "SDRAM Memory Address Width" | 507 | int "SDRAM Memory Address Width" |
498 | default 9 if BFIN533_EZKIT | 508 | default 9 if BFIN533_EZKIT |
499 | default 9 if BFIN561_EZKIT | 509 | default 9 if BFIN561_EZKIT |
510 | default 9 if H8606_HVSISTEMAS | ||
500 | default 10 if BFIN527_EZKIT | 511 | default 10 if BFIN527_EZKIT |
501 | default 10 if BFIN537_STAMP | 512 | default 10 if BFIN537_STAMP |
502 | default 11 if BFIN533_STAMP | 513 | default 11 if BFIN533_STAMP |
diff --git a/arch/blackfin/configs/BF527-EZKIT_defconfig b/arch/blackfin/configs/BF527-EZKIT_defconfig index df974e785ee2..1f6a93df6b32 100644 --- a/arch/blackfin/configs/BF527-EZKIT_defconfig +++ b/arch/blackfin/configs/BF527-EZKIT_defconfig | |||
@@ -244,7 +244,7 @@ CONFIG_CLKIN_HZ=25000000 | |||
244 | # CONFIG_BFIN_KERNEL_CLOCK is not set | 244 | # CONFIG_BFIN_KERNEL_CLOCK is not set |
245 | CONFIG_MAX_VCO_HZ=600000000 | 245 | CONFIG_MAX_VCO_HZ=600000000 |
246 | CONFIG_MIN_VCO_HZ=50000000 | 246 | CONFIG_MIN_VCO_HZ=50000000 |
247 | CONFIG_MAX_SCLK_HZ=133000000 | 247 | CONFIG_MAX_SCLK_HZ=133333333 |
248 | CONFIG_MIN_SCLK_HZ=27000000 | 248 | CONFIG_MIN_SCLK_HZ=27000000 |
249 | 249 | ||
250 | # | 250 | # |
diff --git a/arch/blackfin/configs/BF533-EZKIT_defconfig b/arch/blackfin/configs/BF533-EZKIT_defconfig index 57f58d5cd47a..9e9b420342d1 100644 --- a/arch/blackfin/configs/BF533-EZKIT_defconfig +++ b/arch/blackfin/configs/BF533-EZKIT_defconfig | |||
@@ -198,7 +198,7 @@ CONFIG_CLKIN_HZ=27000000 | |||
198 | # CONFIG_BFIN_KERNEL_CLOCK is not set | 198 | # CONFIG_BFIN_KERNEL_CLOCK is not set |
199 | CONFIG_MAX_VCO_HZ=750000000 | 199 | CONFIG_MAX_VCO_HZ=750000000 |
200 | CONFIG_MIN_VCO_HZ=50000000 | 200 | CONFIG_MIN_VCO_HZ=50000000 |
201 | CONFIG_MAX_SCLK_HZ=133000000 | 201 | CONFIG_MAX_SCLK_HZ=133333333 |
202 | CONFIG_MIN_SCLK_HZ=27000000 | 202 | CONFIG_MIN_SCLK_HZ=27000000 |
203 | 203 | ||
204 | # | 204 | # |
diff --git a/arch/blackfin/configs/BF533-STAMP_defconfig b/arch/blackfin/configs/BF533-STAMP_defconfig index 306302baff06..f59ade980109 100644 --- a/arch/blackfin/configs/BF533-STAMP_defconfig +++ b/arch/blackfin/configs/BF533-STAMP_defconfig | |||
@@ -199,7 +199,7 @@ CONFIG_CLKIN_HZ=11059200 | |||
199 | # CONFIG_BFIN_KERNEL_CLOCK is not set | 199 | # CONFIG_BFIN_KERNEL_CLOCK is not set |
200 | CONFIG_MAX_VCO_HZ=750000000 | 200 | CONFIG_MAX_VCO_HZ=750000000 |
201 | CONFIG_MIN_VCO_HZ=50000000 | 201 | CONFIG_MIN_VCO_HZ=50000000 |
202 | CONFIG_MAX_SCLK_HZ=133000000 | 202 | CONFIG_MAX_SCLK_HZ=133333333 |
203 | CONFIG_MIN_SCLK_HZ=27000000 | 203 | CONFIG_MIN_SCLK_HZ=27000000 |
204 | 204 | ||
205 | # | 205 | # |
diff --git a/arch/blackfin/configs/BF537-STAMP_defconfig b/arch/blackfin/configs/BF537-STAMP_defconfig index 828b604438eb..07eb63dc25e0 100644 --- a/arch/blackfin/configs/BF537-STAMP_defconfig +++ b/arch/blackfin/configs/BF537-STAMP_defconfig | |||
@@ -206,7 +206,7 @@ CONFIG_CLKIN_HZ=25000000 | |||
206 | # CONFIG_BFIN_KERNEL_CLOCK is not set | 206 | # CONFIG_BFIN_KERNEL_CLOCK is not set |
207 | CONFIG_MAX_VCO_HZ=600000000 | 207 | CONFIG_MAX_VCO_HZ=600000000 |
208 | CONFIG_MIN_VCO_HZ=50000000 | 208 | CONFIG_MIN_VCO_HZ=50000000 |
209 | CONFIG_MAX_SCLK_HZ=133000000 | 209 | CONFIG_MAX_SCLK_HZ=133333333 |
210 | CONFIG_MIN_SCLK_HZ=27000000 | 210 | CONFIG_MIN_SCLK_HZ=27000000 |
211 | 211 | ||
212 | # | 212 | # |
diff --git a/arch/blackfin/configs/BF548-EZKIT_defconfig b/arch/blackfin/configs/BF548-EZKIT_defconfig index d8569888a1c8..0dd3d2253dc2 100644 --- a/arch/blackfin/configs/BF548-EZKIT_defconfig +++ b/arch/blackfin/configs/BF548-EZKIT_defconfig | |||
@@ -1,6 +1,7 @@ | |||
1 | # | 1 | # |
2 | # Automatically generated make config: don't edit | 2 | # Automatically generated make config: don't edit |
3 | # Linux kernel version: 2.6.22.6 | 3 | # Linux kernel version: 2.6.22.10 |
4 | # Sat Oct 27 02:34:07 2007 | ||
4 | # | 5 | # |
5 | # CONFIG_MMU is not set | 6 | # CONFIG_MMU is not set |
6 | # CONFIG_FPU is not set | 7 | # CONFIG_FPU is not set |
@@ -64,7 +65,6 @@ CONFIG_FUTEX=y | |||
64 | CONFIG_ANON_INODES=y | 65 | CONFIG_ANON_INODES=y |
65 | CONFIG_EPOLL=y | 66 | CONFIG_EPOLL=y |
66 | CONFIG_SIGNALFD=y | 67 | CONFIG_SIGNALFD=y |
67 | CONFIG_TIMERFD=y | ||
68 | CONFIG_EVENTFD=y | 68 | CONFIG_EVENTFD=y |
69 | CONFIG_VM_EVENT_COUNTERS=y | 69 | CONFIG_VM_EVENT_COUNTERS=y |
70 | CONFIG_BIG_ORDER_ALLOC_NOFAIL_MAGIC=3 | 70 | CONFIG_BIG_ORDER_ALLOC_NOFAIL_MAGIC=3 |
@@ -117,6 +117,9 @@ CONFIG_PREEMPT_VOLUNTARY=y | |||
117 | # | 117 | # |
118 | # Processor and Board Settings | 118 | # Processor and Board Settings |
119 | # | 119 | # |
120 | # CONFIG_BF522 is not set | ||
121 | # CONFIG_BF525 is not set | ||
122 | # CONFIG_BF527 is not set | ||
120 | # CONFIG_BF531 is not set | 123 | # CONFIG_BF531 is not set |
121 | # CONFIG_BF532 is not set | 124 | # CONFIG_BF532 is not set |
122 | # CONFIG_BF533 is not set | 125 | # CONFIG_BF533 is not set |
@@ -129,6 +132,7 @@ CONFIG_PREEMPT_VOLUNTARY=y | |||
129 | CONFIG_BF549=y | 132 | CONFIG_BF549=y |
130 | # CONFIG_BF561 is not set | 133 | # CONFIG_BF561 is not set |
131 | CONFIG_BF_REV_0_0=y | 134 | CONFIG_BF_REV_0_0=y |
135 | # CONFIG_BF_REV_0_1 is not set | ||
132 | # CONFIG_BF_REV_0_2 is not set | 136 | # CONFIG_BF_REV_0_2 is not set |
133 | # CONFIG_BF_REV_0_3 is not set | 137 | # CONFIG_BF_REV_0_3 is not set |
134 | # CONFIG_BF_REV_0_4 is not set | 138 | # CONFIG_BF_REV_0_4 is not set |
@@ -137,6 +141,7 @@ CONFIG_BF_REV_0_0=y | |||
137 | # CONFIG_BF_REV_NONE is not set | 141 | # CONFIG_BF_REV_NONE is not set |
138 | CONFIG_BF54x=y | 142 | CONFIG_BF54x=y |
139 | CONFIG_BFIN_SINGLE_CORE=y | 143 | CONFIG_BFIN_SINGLE_CORE=y |
144 | # CONFIG_BFIN527_EZKIT is not set | ||
140 | # CONFIG_BFIN533_EZKIT is not set | 145 | # CONFIG_BFIN533_EZKIT is not set |
141 | # CONFIG_BFIN533_STAMP is not set | 146 | # CONFIG_BFIN533_STAMP is not set |
142 | # CONFIG_BFIN537_STAMP is not set | 147 | # CONFIG_BFIN537_STAMP is not set |
@@ -147,8 +152,23 @@ CONFIG_BFIN548_EZKIT=y | |||
147 | # CONFIG_BFIN561_EZKIT is not set | 152 | # CONFIG_BFIN561_EZKIT is not set |
148 | # CONFIG_BFIN561_TEPLA is not set | 153 | # CONFIG_BFIN561_TEPLA is not set |
149 | # CONFIG_PNAV10 is not set | 154 | # CONFIG_PNAV10 is not set |
155 | # CONFIG_H8606_HVSISTEMAS is not set | ||
150 | # CONFIG_GENERIC_BOARD is not set | 156 | # CONFIG_GENERIC_BOARD is not set |
151 | CONFIG_IRQ_PLL_WAKEUP=7 | 157 | CONFIG_IRQ_PLL_WAKEUP=7 |
158 | CONFIG_IRQ_RTC=8 | ||
159 | CONFIG_IRQ_SPORT0_RX=9 | ||
160 | CONFIG_IRQ_SPORT0_TX=9 | ||
161 | CONFIG_IRQ_SPORT1_RX=9 | ||
162 | CONFIG_IRQ_SPORT1_TX=9 | ||
163 | CONFIG_IRQ_UART0_RX=10 | ||
164 | CONFIG_IRQ_UART0_TX=10 | ||
165 | CONFIG_IRQ_UART1_RX=10 | ||
166 | CONFIG_IRQ_UART1_TX=10 | ||
167 | CONFIG_IRQ_CNT=8 | ||
168 | CONFIG_IRQ_USB_INT0=11 | ||
169 | CONFIG_IRQ_USB_INT1=11 | ||
170 | CONFIG_IRQ_USB_INT2=11 | ||
171 | CONFIG_IRQ_USB_DMA=11 | ||
152 | CONFIG_IRQ_TIMER0=11 | 172 | CONFIG_IRQ_TIMER0=11 |
153 | CONFIG_IRQ_TIMER1=11 | 173 | CONFIG_IRQ_TIMER1=11 |
154 | CONFIG_IRQ_TIMER2=11 | 174 | CONFIG_IRQ_TIMER2=11 |
@@ -160,15 +180,6 @@ CONFIG_IRQ_TIMER7=11 | |||
160 | CONFIG_IRQ_TIMER8=11 | 180 | CONFIG_IRQ_TIMER8=11 |
161 | CONFIG_IRQ_TIMER9=11 | 181 | CONFIG_IRQ_TIMER9=11 |
162 | CONFIG_IRQ_TIMER10=11 | 182 | CONFIG_IRQ_TIMER10=11 |
163 | CONFIG_IRQ_RTC=8 | ||
164 | CONFIG_IRQ_SPORT0_RX=9 | ||
165 | CONFIG_IRQ_SPORT0_TX=9 | ||
166 | CONFIG_IRQ_SPORT1_RX=9 | ||
167 | CONFIG_IRQ_SPORT1_TX=9 | ||
168 | CONFIG_IRQ_UART0_RX=10 | ||
169 | CONFIG_IRQ_UART0_TX=10 | ||
170 | CONFIG_IRQ_UART1_RX=10 | ||
171 | CONFIG_IRQ_UART1_TX=10 | ||
172 | 183 | ||
173 | # | 184 | # |
174 | # BF548 Specific Configuration | 185 | # BF548 Specific Configuration |
@@ -236,16 +247,11 @@ CONFIG_IRQ_PIXC_IN0=8 | |||
236 | CONFIG_IRQ_PIXC_IN1=8 | 247 | CONFIG_IRQ_PIXC_IN1=8 |
237 | CONFIG_IRQ_PIXC_OUT=8 | 248 | CONFIG_IRQ_PIXC_OUT=8 |
238 | CONFIG_IRQ_SDH=8 | 249 | CONFIG_IRQ_SDH=8 |
239 | CONFIG_IRQ_CNT=8 | ||
240 | CONFIG_IRQ_KEY=8 | 250 | CONFIG_IRQ_KEY=8 |
241 | CONFIG_IRQ_CAN1_RX=11 | 251 | CONFIG_IRQ_CAN1_RX=11 |
242 | CONFIG_IRQ_CAN1_TX=11 | 252 | CONFIG_IRQ_CAN1_TX=11 |
243 | CONFIG_IRQ_SDH_MASK0=11 | 253 | CONFIG_IRQ_SDH_MASK0=11 |
244 | CONFIG_IRQ_SDH_MASK1=11 | 254 | CONFIG_IRQ_SDH_MASK1=11 |
245 | CONFIG_IRQ_USB_INT0=11 | ||
246 | CONFIG_IRQ_USB_INT1=11 | ||
247 | CONFIG_IRQ_USB_INT2=11 | ||
248 | CONFIG_IRQ_USB_DMA=11 | ||
249 | CONFIG_IRQ_OTPSEC=11 | 255 | CONFIG_IRQ_OTPSEC=11 |
250 | CONFIG_IRQ_PINT2=11 | 256 | CONFIG_IRQ_PINT2=11 |
251 | CONFIG_IRQ_PINT3=11 | 257 | CONFIG_IRQ_PINT3=11 |
@@ -273,9 +279,9 @@ CONFIG_PINT3_ASSIGN=0x02020303 | |||
273 | # | 279 | # |
274 | CONFIG_CLKIN_HZ=25000000 | 280 | CONFIG_CLKIN_HZ=25000000 |
275 | # CONFIG_BFIN_KERNEL_CLOCK is not set | 281 | # CONFIG_BFIN_KERNEL_CLOCK is not set |
276 | CONFIG_MAX_VCO_HZ=533000000 | 282 | CONFIG_MAX_VCO_HZ=533333333 |
277 | CONFIG_MIN_VCO_HZ=50000000 | 283 | CONFIG_MIN_VCO_HZ=50000000 |
278 | CONFIG_MAX_SCLK_HZ=133000000 | 284 | CONFIG_MAX_SCLK_HZ=133333333 |
279 | CONFIG_MIN_SCLK_HZ=27000000 | 285 | CONFIG_MIN_SCLK_HZ=27000000 |
280 | 286 | ||
281 | # | 287 | # |
@@ -332,9 +338,10 @@ CONFIG_SPLIT_PTLOCK_CPUS=4 | |||
332 | # CONFIG_RESOURCES_64BIT is not set | 338 | # CONFIG_RESOURCES_64BIT is not set |
333 | CONFIG_ZONE_DMA_FLAG=1 | 339 | CONFIG_ZONE_DMA_FLAG=1 |
334 | CONFIG_LARGE_ALLOCS=y | 340 | CONFIG_LARGE_ALLOCS=y |
341 | # CONFIG_BFIN_GPTIMERS is not set | ||
335 | CONFIG_BFIN_DMA_5XX=y | 342 | CONFIG_BFIN_DMA_5XX=y |
336 | # CONFIG_DMA_UNCACHED_2M is not set | 343 | CONFIG_DMA_UNCACHED_2M=y |
337 | CONFIG_DMA_UNCACHED_1M=y | 344 | # CONFIG_DMA_UNCACHED_1M is not set |
338 | # CONFIG_DMA_UNCACHED_NONE is not set | 345 | # CONFIG_DMA_UNCACHED_NONE is not set |
339 | 346 | ||
340 | # | 347 | # |
@@ -353,7 +360,7 @@ CONFIG_L1_MAX_PIECE=16 | |||
353 | # | 360 | # |
354 | 361 | ||
355 | # | 362 | # |
356 | # EBIU_AMBCTL Global Control | 363 | # EBIU_AMGCTL Global Control |
357 | # | 364 | # |
358 | CONFIG_C_AMCKEN=y | 365 | CONFIG_C_AMCKEN=y |
359 | # CONFIG_C_AMBEN is not set | 366 | # CONFIG_C_AMBEN is not set |
@@ -722,7 +729,7 @@ CONFIG_NETDEV_10000=y | |||
722 | # | 729 | # |
723 | # Input device support | 730 | # Input device support |
724 | # | 731 | # |
725 | CONFIG_INPUT=y | 732 | CONFIG_INPUT=m |
726 | # CONFIG_INPUT_FF_MEMLESS is not set | 733 | # CONFIG_INPUT_FF_MEMLESS is not set |
727 | # CONFIG_INPUT_POLLDEV is not set | 734 | # CONFIG_INPUT_POLLDEV is not set |
728 | 735 | ||
@@ -731,18 +738,39 @@ CONFIG_INPUT=y | |||
731 | # | 738 | # |
732 | # CONFIG_INPUT_MOUSEDEV is not set | 739 | # CONFIG_INPUT_MOUSEDEV is not set |
733 | # CONFIG_INPUT_JOYDEV is not set | 740 | # CONFIG_INPUT_JOYDEV is not set |
734 | # CONFIG_INPUT_TSDEV is not set | 741 | CONFIG_INPUT_TSDEV=m |
735 | # CONFIG_INPUT_EVDEV is not set | 742 | CONFIG_INPUT_TSDEV_SCREEN_X=240 |
736 | # CONFIG_INPUT_EVBUG is not set | 743 | CONFIG_INPUT_TSDEV_SCREEN_Y=320 |
744 | CONFIG_INPUT_EVDEV=m | ||
745 | CONFIG_INPUT_EVBUG=m | ||
737 | 746 | ||
738 | # | 747 | # |
739 | # Input Device Drivers | 748 | # Input Device Drivers |
740 | # | 749 | # |
741 | # CONFIG_INPUT_KEYBOARD is not set | 750 | CONFIG_INPUT_KEYBOARD=y |
751 | # CONFIG_KEYBOARD_ATKBD is not set | ||
752 | # CONFIG_KEYBOARD_SUNKBD is not set | ||
753 | # CONFIG_KEYBOARD_LKKBD is not set | ||
754 | # CONFIG_KEYBOARD_XTKBD is not set | ||
755 | # CONFIG_KEYBOARD_NEWTON is not set | ||
756 | # CONFIG_KEYBOARD_STOWAWAY is not set | ||
757 | # CONFIG_KEYBOARD_GPIO is not set | ||
758 | CONFIG_KEYBOARD_BFIN=m | ||
742 | # CONFIG_INPUT_MOUSE is not set | 759 | # CONFIG_INPUT_MOUSE is not set |
743 | # CONFIG_INPUT_JOYSTICK is not set | 760 | # CONFIG_INPUT_JOYSTICK is not set |
744 | # CONFIG_INPUT_TABLET is not set | 761 | # CONFIG_INPUT_TABLET is not set |
745 | # CONFIG_INPUT_TOUCHSCREEN is not set | 762 | CONFIG_INPUT_TOUCHSCREEN=y |
763 | # CONFIG_TOUCHSCREEN_ADS7846 is not set | ||
764 | CONFIG_TOUCHSCREEN_AD7877=m | ||
765 | # CONFIG_TOUCHSCREEN_GUNZE is not set | ||
766 | # CONFIG_TOUCHSCREEN_ELO is not set | ||
767 | # CONFIG_TOUCHSCREEN_MTOUCH is not set | ||
768 | # CONFIG_TOUCHSCREEN_MK712 is not set | ||
769 | # CONFIG_TOUCHSCREEN_PENMOUNT is not set | ||
770 | # CONFIG_TOUCHSCREEN_TOUCHRIGHT is not set | ||
771 | # CONFIG_TOUCHSCREEN_TOUCHWIN is not set | ||
772 | # CONFIG_TOUCHSCREEN_UCB1400 is not set | ||
773 | # CONFIG_TOUCHSCREEN_USB_COMPOSITE is not set | ||
746 | CONFIG_INPUT_MISC=y | 774 | CONFIG_INPUT_MISC=y |
747 | # CONFIG_INPUT_ATI_REMOTE is not set | 775 | # CONFIG_INPUT_ATI_REMOTE is not set |
748 | # CONFIG_INPUT_ATI_REMOTE2 is not set | 776 | # CONFIG_INPUT_ATI_REMOTE2 is not set |
@@ -764,9 +792,9 @@ CONFIG_INPUT_MISC=y | |||
764 | # | 792 | # |
765 | # CONFIG_AD9960 is not set | 793 | # CONFIG_AD9960 is not set |
766 | # CONFIG_SPI_ADC_BF533 is not set | 794 | # CONFIG_SPI_ADC_BF533 is not set |
767 | # CONFIG_BFIN_PFLAGS is not set | 795 | # CONFIG_BF5xx_PFLAGS is not set |
768 | # CONFIG_BF5xx_PPIFCD is not set | 796 | # CONFIG_BF5xx_PPIFCD is not set |
769 | # CONFIG_BF5xx_TIMERS is not set | 797 | # CONFIG_BFIN_SIMPLE_TIMER is not set |
770 | # CONFIG_BF5xx_PPI is not set | 798 | # CONFIG_BF5xx_PPI is not set |
771 | # CONFIG_BFIN_SPORT is not set | 799 | # CONFIG_BFIN_SPORT is not set |
772 | # CONFIG_BFIN_TIMER_LATENCY is not set | 800 | # CONFIG_BFIN_TIMER_LATENCY is not set |
@@ -958,17 +986,92 @@ CONFIG_DAB=y | |||
958 | # | 986 | # |
959 | # CONFIG_DISPLAY_SUPPORT is not set | 987 | # CONFIG_DISPLAY_SUPPORT is not set |
960 | # CONFIG_VGASTATE is not set | 988 | # CONFIG_VGASTATE is not set |
961 | # CONFIG_FB is not set | 989 | CONFIG_FB=m |
990 | CONFIG_FIRMWARE_EDID=y | ||
991 | # CONFIG_FB_DDC is not set | ||
992 | CONFIG_FB_CFB_FILLRECT=m | ||
993 | CONFIG_FB_CFB_COPYAREA=m | ||
994 | CONFIG_FB_CFB_IMAGEBLIT=m | ||
995 | # CONFIG_FB_SYS_FILLRECT is not set | ||
996 | # CONFIG_FB_SYS_COPYAREA is not set | ||
997 | # CONFIG_FB_SYS_IMAGEBLIT is not set | ||
998 | # CONFIG_FB_SYS_FOPS is not set | ||
999 | CONFIG_FB_DEFERRED_IO=y | ||
1000 | # CONFIG_FB_SVGALIB is not set | ||
1001 | # CONFIG_FB_MACMODES is not set | ||
1002 | # CONFIG_FB_BACKLIGHT is not set | ||
1003 | # CONFIG_FB_MODE_HELPERS is not set | ||
1004 | # CONFIG_FB_TILEBLITTING is not set | ||
1005 | |||
1006 | # | ||
1007 | # Frame buffer hardware drivers | ||
1008 | # | ||
1009 | # CONFIG_FB_BFIN_7171 is not set | ||
1010 | # CONFIG_FB_BFIN_7393 is not set | ||
1011 | CONFIG_FB_BF54X_LQ043=m | ||
1012 | # CONFIG_FB_BFIN_T350MCQB is not set | ||
1013 | # CONFIG_FB_S1D13XXX is not set | ||
1014 | # CONFIG_FB_VIRTUAL is not set | ||
1015 | # CONFIG_LOGO is not set | ||
962 | 1016 | ||
963 | # | 1017 | # |
964 | # Sound | 1018 | # Sound |
965 | # | 1019 | # |
966 | # CONFIG_SOUND is not set | 1020 | CONFIG_SOUND=y |
1021 | |||
1022 | # | ||
1023 | # Advanced Linux Sound Architecture | ||
1024 | # | ||
1025 | CONFIG_SND=y | ||
1026 | CONFIG_SND_TIMER=y | ||
1027 | CONFIG_SND_PCM=y | ||
1028 | # CONFIG_SND_SEQUENCER is not set | ||
1029 | CONFIG_SND_OSSEMUL=y | ||
1030 | CONFIG_SND_MIXER_OSS=y | ||
1031 | CONFIG_SND_PCM_OSS=y | ||
1032 | CONFIG_SND_PCM_OSS_PLUGINS=y | ||
1033 | # CONFIG_SND_DYNAMIC_MINORS is not set | ||
1034 | CONFIG_SND_SUPPORT_OLD_API=y | ||
1035 | CONFIG_SND_VERBOSE_PROCFS=y | ||
1036 | # CONFIG_SND_VERBOSE_PRINTK is not set | ||
1037 | # CONFIG_SND_DEBUG is not set | ||
1038 | |||
1039 | # | ||
1040 | # Generic devices | ||
1041 | # | ||
1042 | # CONFIG_SND_DUMMY is not set | ||
1043 | # CONFIG_SND_MTPAV is not set | ||
1044 | # CONFIG_SND_SERIAL_U16550 is not set | ||
1045 | # CONFIG_SND_MPU401 is not set | ||
1046 | |||
1047 | # | ||
1048 | # ALSA Blackfin devices | ||
1049 | # | ||
1050 | # CONFIG_SND_BLACKFIN_AD1836 is not set | ||
1051 | # CONFIG_SND_BFIN_AD73311 is not set | ||
1052 | |||
1053 | # | ||
1054 | # System on Chip audio support | ||
1055 | # | ||
1056 | CONFIG_SND_SOC_AC97_BUS=y | ||
1057 | CONFIG_SND_SOC=y | ||
1058 | CONFIG_SND_BF5XX_SOC=y | ||
1059 | CONFIG_SND_BF5XX_SOC_AC97=y | ||
1060 | CONFIG_SND_BF5XX_SOC_BF548_EZKIT=y | ||
1061 | CONFIG_SND_BF5XX_SPORT_NUM=0 | ||
1062 | # CONFIG_SND_BF5XX_HAVE_COLD_RESET is not set | ||
1063 | CONFIG_SND_SOC_AD1980=y | ||
1064 | |||
1065 | # | ||
1066 | # Open Sound System | ||
1067 | # | ||
1068 | # CONFIG_SOUND_PRIME is not set | ||
1069 | CONFIG_AC97_BUS=y | ||
967 | 1070 | ||
968 | # | 1071 | # |
969 | # HID Devices | 1072 | # HID Devices |
970 | # | 1073 | # |
971 | CONFIG_HID=y | 1074 | CONFIG_HID=m |
972 | # CONFIG_HID_DEBUG is not set | 1075 | # CONFIG_HID_DEBUG is not set |
973 | 1076 | ||
974 | # | 1077 | # |
@@ -1101,8 +1204,13 @@ CONFIG_EXT2_FS=y | |||
1101 | CONFIG_EXT2_FS_XATTR=y | 1204 | CONFIG_EXT2_FS_XATTR=y |
1102 | # CONFIG_EXT2_FS_POSIX_ACL is not set | 1205 | # CONFIG_EXT2_FS_POSIX_ACL is not set |
1103 | # CONFIG_EXT2_FS_SECURITY is not set | 1206 | # CONFIG_EXT2_FS_SECURITY is not set |
1104 | # CONFIG_EXT3_FS is not set | 1207 | CONFIG_EXT3_FS=y |
1208 | CONFIG_EXT3_FS_XATTR=y | ||
1209 | # CONFIG_EXT3_FS_POSIX_ACL is not set | ||
1210 | # CONFIG_EXT3_FS_SECURITY is not set | ||
1105 | # CONFIG_EXT4DEV_FS is not set | 1211 | # CONFIG_EXT4DEV_FS is not set |
1212 | CONFIG_JBD=y | ||
1213 | # CONFIG_JBD_DEBUG is not set | ||
1106 | CONFIG_FS_MBCACHE=y | 1214 | CONFIG_FS_MBCACHE=y |
1107 | # CONFIG_REISERFS_FS is not set | 1215 | # CONFIG_REISERFS_FS is not set |
1108 | # CONFIG_JFS_FS is not set | 1216 | # CONFIG_JFS_FS is not set |
@@ -1123,15 +1231,22 @@ CONFIG_DNOTIFY=y | |||
1123 | # | 1231 | # |
1124 | # CD-ROM/DVD Filesystems | 1232 | # CD-ROM/DVD Filesystems |
1125 | # | 1233 | # |
1126 | # CONFIG_ISO9660_FS is not set | 1234 | CONFIG_ISO9660_FS=m |
1235 | CONFIG_JOLIET=y | ||
1236 | CONFIG_ZISOFS=y | ||
1127 | # CONFIG_UDF_FS is not set | 1237 | # CONFIG_UDF_FS is not set |
1128 | 1238 | ||
1129 | # | 1239 | # |
1130 | # DOS/FAT/NT Filesystems | 1240 | # DOS/FAT/NT Filesystems |
1131 | # | 1241 | # |
1132 | # CONFIG_MSDOS_FS is not set | 1242 | CONFIG_FAT_FS=m |
1133 | # CONFIG_VFAT_FS is not set | 1243 | CONFIG_MSDOS_FS=m |
1134 | # CONFIG_NTFS_FS is not set | 1244 | CONFIG_VFAT_FS=m |
1245 | CONFIG_FAT_DEFAULT_CODEPAGE=437 | ||
1246 | CONFIG_FAT_DEFAULT_IOCHARSET="iso8859-1" | ||
1247 | CONFIG_NTFS_FS=m | ||
1248 | # CONFIG_NTFS_DEBUG is not set | ||
1249 | CONFIG_NTFS_RW=y | ||
1135 | 1250 | ||
1136 | # | 1251 | # |
1137 | # Pseudo filesystems | 1252 | # Pseudo filesystems |
@@ -1183,10 +1298,33 @@ CONFIG_JFFS2_RTIME=y | |||
1183 | # | 1298 | # |
1184 | # Network File Systems | 1299 | # Network File Systems |
1185 | # | 1300 | # |
1186 | # CONFIG_NFS_FS is not set | 1301 | CONFIG_NFS_FS=m |
1187 | # CONFIG_NFSD is not set | 1302 | CONFIG_NFS_V3=y |
1188 | # CONFIG_SMB_FS is not set | 1303 | # CONFIG_NFS_V3_ACL is not set |
1189 | # CONFIG_CIFS is not set | 1304 | # CONFIG_NFS_V4 is not set |
1305 | # CONFIG_NFS_DIRECTIO is not set | ||
1306 | CONFIG_NFSD=m | ||
1307 | CONFIG_NFSD_V3=y | ||
1308 | # CONFIG_NFSD_V3_ACL is not set | ||
1309 | # CONFIG_NFSD_V4 is not set | ||
1310 | CONFIG_NFSD_TCP=y | ||
1311 | CONFIG_LOCKD=m | ||
1312 | CONFIG_LOCKD_V4=y | ||
1313 | CONFIG_EXPORTFS=m | ||
1314 | CONFIG_NFS_COMMON=y | ||
1315 | CONFIG_SUNRPC=m | ||
1316 | # CONFIG_SUNRPC_BIND34 is not set | ||
1317 | # CONFIG_RPCSEC_GSS_KRB5 is not set | ||
1318 | # CONFIG_RPCSEC_GSS_SPKM3 is not set | ||
1319 | CONFIG_SMB_FS=m | ||
1320 | CONFIG_SMB_NLS_DEFAULT=y | ||
1321 | CONFIG_SMB_NLS_REMOTE="cp437" | ||
1322 | CONFIG_CIFS=y | ||
1323 | # CONFIG_CIFS_STATS is not set | ||
1324 | # CONFIG_CIFS_WEAK_PW_HASH is not set | ||
1325 | # CONFIG_CIFS_XATTR is not set | ||
1326 | # CONFIG_CIFS_DEBUG2 is not set | ||
1327 | # CONFIG_CIFS_EXPERIMENTAL is not set | ||
1190 | # CONFIG_NCP_FS is not set | 1328 | # CONFIG_NCP_FS is not set |
1191 | # CONFIG_CODA_FS is not set | 1329 | # CONFIG_CODA_FS is not set |
1192 | # CONFIG_AFS_FS is not set | 1330 | # CONFIG_AFS_FS is not set |
@@ -1195,13 +1333,68 @@ CONFIG_JFFS2_RTIME=y | |||
1195 | # | 1333 | # |
1196 | # Partition Types | 1334 | # Partition Types |
1197 | # | 1335 | # |
1198 | # CONFIG_PARTITION_ADVANCED is not set | 1336 | CONFIG_PARTITION_ADVANCED=y |
1337 | # CONFIG_ACORN_PARTITION is not set | ||
1338 | # CONFIG_OSF_PARTITION is not set | ||
1339 | # CONFIG_AMIGA_PARTITION is not set | ||
1340 | # CONFIG_ATARI_PARTITION is not set | ||
1341 | # CONFIG_MAC_PARTITION is not set | ||
1199 | CONFIG_MSDOS_PARTITION=y | 1342 | CONFIG_MSDOS_PARTITION=y |
1343 | # CONFIG_BSD_DISKLABEL is not set | ||
1344 | # CONFIG_MINIX_SUBPARTITION is not set | ||
1345 | # CONFIG_SOLARIS_X86_PARTITION is not set | ||
1346 | # CONFIG_UNIXWARE_DISKLABEL is not set | ||
1347 | # CONFIG_LDM_PARTITION is not set | ||
1348 | # CONFIG_SGI_PARTITION is not set | ||
1349 | # CONFIG_ULTRIX_PARTITION is not set | ||
1350 | # CONFIG_SUN_PARTITION is not set | ||
1351 | # CONFIG_KARMA_PARTITION is not set | ||
1352 | # CONFIG_EFI_PARTITION is not set | ||
1353 | # CONFIG_SYSV68_PARTITION is not set | ||
1200 | 1354 | ||
1201 | # | 1355 | # |
1202 | # Native Language Support | 1356 | # Native Language Support |
1203 | # | 1357 | # |
1204 | # CONFIG_NLS is not set | 1358 | CONFIG_NLS=y |
1359 | CONFIG_NLS_DEFAULT="iso8859-1" | ||
1360 | CONFIG_NLS_CODEPAGE_437=m | ||
1361 | CONFIG_NLS_CODEPAGE_737=m | ||
1362 | CONFIG_NLS_CODEPAGE_775=m | ||
1363 | CONFIG_NLS_CODEPAGE_850=m | ||
1364 | CONFIG_NLS_CODEPAGE_852=m | ||
1365 | CONFIG_NLS_CODEPAGE_855=m | ||
1366 | CONFIG_NLS_CODEPAGE_857=m | ||
1367 | CONFIG_NLS_CODEPAGE_860=m | ||
1368 | CONFIG_NLS_CODEPAGE_861=m | ||
1369 | CONFIG_NLS_CODEPAGE_862=m | ||
1370 | CONFIG_NLS_CODEPAGE_863=m | ||
1371 | CONFIG_NLS_CODEPAGE_864=m | ||
1372 | CONFIG_NLS_CODEPAGE_865=m | ||
1373 | CONFIG_NLS_CODEPAGE_866=m | ||
1374 | CONFIG_NLS_CODEPAGE_869=m | ||
1375 | CONFIG_NLS_CODEPAGE_936=m | ||
1376 | CONFIG_NLS_CODEPAGE_950=m | ||
1377 | CONFIG_NLS_CODEPAGE_932=m | ||
1378 | CONFIG_NLS_CODEPAGE_949=m | ||
1379 | CONFIG_NLS_CODEPAGE_874=m | ||
1380 | CONFIG_NLS_ISO8859_8=m | ||
1381 | CONFIG_NLS_CODEPAGE_1250=m | ||
1382 | CONFIG_NLS_CODEPAGE_1251=m | ||
1383 | CONFIG_NLS_ASCII=m | ||
1384 | CONFIG_NLS_ISO8859_1=m | ||
1385 | CONFIG_NLS_ISO8859_2=m | ||
1386 | CONFIG_NLS_ISO8859_3=m | ||
1387 | CONFIG_NLS_ISO8859_4=m | ||
1388 | CONFIG_NLS_ISO8859_5=m | ||
1389 | CONFIG_NLS_ISO8859_6=m | ||
1390 | CONFIG_NLS_ISO8859_7=m | ||
1391 | CONFIG_NLS_ISO8859_9=m | ||
1392 | CONFIG_NLS_ISO8859_13=m | ||
1393 | CONFIG_NLS_ISO8859_14=m | ||
1394 | CONFIG_NLS_ISO8859_15=m | ||
1395 | CONFIG_NLS_KOI8_R=m | ||
1396 | CONFIG_NLS_KOI8_U=m | ||
1397 | CONFIG_NLS_UTF8=m | ||
1205 | 1398 | ||
1206 | # | 1399 | # |
1207 | # Distributed Lock Manager | 1400 | # Distributed Lock Manager |
diff --git a/arch/blackfin/configs/BF561-EZKIT_defconfig b/arch/blackfin/configs/BF561-EZKIT_defconfig index 85e647f87759..277d72dac0f9 100644 --- a/arch/blackfin/configs/BF561-EZKIT_defconfig +++ b/arch/blackfin/configs/BF561-EZKIT_defconfig | |||
@@ -243,7 +243,7 @@ CONFIG_CLKIN_HZ=30000000 | |||
243 | # CONFIG_BFIN_KERNEL_CLOCK is not set | 243 | # CONFIG_BFIN_KERNEL_CLOCK is not set |
244 | CONFIG_MAX_VCO_HZ=600000000 | 244 | CONFIG_MAX_VCO_HZ=600000000 |
245 | CONFIG_MIN_VCO_HZ=50000000 | 245 | CONFIG_MIN_VCO_HZ=50000000 |
246 | CONFIG_MAX_SCLK_HZ=133000000 | 246 | CONFIG_MAX_SCLK_HZ=133333333 |
247 | CONFIG_MIN_SCLK_HZ=27000000 | 247 | CONFIG_MIN_SCLK_HZ=27000000 |
248 | 248 | ||
249 | # | 249 | # |
diff --git a/arch/blackfin/configs/PNAV-10_defconfig b/arch/blackfin/configs/PNAV-10_defconfig index 15e36aaf2186..3d403e0b82c2 100644 --- a/arch/blackfin/configs/PNAV-10_defconfig +++ b/arch/blackfin/configs/PNAV-10_defconfig | |||
@@ -204,7 +204,7 @@ CONFIG_CLKIN_HZ=24576000 | |||
204 | # CONFIG_BFIN_KERNEL_CLOCK is not set | 204 | # CONFIG_BFIN_KERNEL_CLOCK is not set |
205 | CONFIG_MAX_VCO_HZ=600000000 | 205 | CONFIG_MAX_VCO_HZ=600000000 |
206 | CONFIG_MIN_VCO_HZ=50000000 | 206 | CONFIG_MIN_VCO_HZ=50000000 |
207 | CONFIG_MAX_SCLK_HZ=133000000 | 207 | CONFIG_MAX_SCLK_HZ=133333333 |
208 | CONFIG_MIN_SCLK_HZ=27000000 | 208 | CONFIG_MIN_SCLK_HZ=27000000 |
209 | 209 | ||
210 | # | 210 | # |
diff --git a/arch/blackfin/kernel/dma-mapping.c b/arch/blackfin/kernel/dma-mapping.c index a16cb03c5291..d6b61d56b656 100644 --- a/arch/blackfin/kernel/dma-mapping.c +++ b/arch/blackfin/kernel/dma-mapping.c | |||
@@ -35,6 +35,7 @@ | |||
35 | #include <linux/device.h> | 35 | #include <linux/device.h> |
36 | #include <linux/dma-mapping.h> | 36 | #include <linux/dma-mapping.h> |
37 | #include <linux/io.h> | 37 | #include <linux/io.h> |
38 | #include <linux/scatterlist.h> | ||
38 | #include <asm/cacheflush.h> | 39 | #include <asm/cacheflush.h> |
39 | #include <asm/bfin-global.h> | 40 | #include <asm/bfin-global.h> |
40 | 41 | ||
diff --git a/arch/blackfin/kernel/entry.S b/arch/blackfin/kernel/entry.S index 65c5ba4260b0..65f4e67a65c4 100644 --- a/arch/blackfin/kernel/entry.S +++ b/arch/blackfin/kernel/entry.S | |||
@@ -54,9 +54,11 @@ ENTRY(_ret_from_fork) | |||
54 | [sp + PT_IPEND] = r0; | 54 | [sp + PT_IPEND] = r0; |
55 | /* do a 'fake' RTI by jumping to [RETI] | 55 | /* do a 'fake' RTI by jumping to [RETI] |
56 | * to avoid clearing supervisor mode in child | 56 | * to avoid clearing supervisor mode in child |
57 | */ | 57 | */ |
58 | r0 = [sp + PT_PC]; | ||
59 | [sp + PT_P0] = r0; | ||
60 | |||
58 | RESTORE_ALL_SYS | 61 | RESTORE_ALL_SYS |
59 | p0 = reti; | ||
60 | jump (p0); | 62 | jump (p0); |
61 | ENDPROC(_ret_from_fork) | 63 | ENDPROC(_ret_from_fork) |
62 | 64 | ||
diff --git a/arch/blackfin/kernel/fixed_code.S b/arch/blackfin/kernel/fixed_code.S index d8b1ebc70996..90262691b11a 100644 --- a/arch/blackfin/kernel/fixed_code.S +++ b/arch/blackfin/kernel/fixed_code.S | |||
@@ -129,4 +129,18 @@ ENTRY(_atomic_xor32) | |||
129 | rts; | 129 | rts; |
130 | ENDPROC (_atomic_ior32) | 130 | ENDPROC (_atomic_ior32) |
131 | 131 | ||
132 | .align 16 | ||
133 | /* | ||
134 | * safe_user_instruction | ||
135 | * Four NOPS are enough to allow the pipeline to speculativily load | ||
136 | * execute anything it wants. After that, things have gone bad, and | ||
137 | * we are stuck - so panic. Since we might be in user space, we can't | ||
138 | * call panic, so just cause a unhandled exception, this should cause | ||
139 | * a dump of the trace buffer so we can tell were we are, and a reboot | ||
140 | */ | ||
141 | ENTRY(_safe_user_instruction) | ||
142 | NOP; NOP; NOP; NOP; | ||
143 | EXCPT 0x4; | ||
144 | ENDPROC(_safe_user_instruction) | ||
145 | |||
132 | ENTRY(_fixed_code_end) | 146 | ENTRY(_fixed_code_end) |
diff --git a/arch/blackfin/kernel/gptimers.c b/arch/blackfin/kernel/gptimers.c index cb7ba9bfc79c..5cf4bdb1df3b 100644 --- a/arch/blackfin/kernel/gptimers.c +++ b/arch/blackfin/kernel/gptimers.c | |||
@@ -20,8 +20,7 @@ | |||
20 | #else | 20 | #else |
21 | # define tassert(expr) \ | 21 | # define tassert(expr) \ |
22 | if (!(expr)) \ | 22 | if (!(expr)) \ |
23 | printk(KERN_DEBUG "%s:%s:%i: Assertion failed: " #expr "\n", \ | 23 | printk(KERN_DEBUG "%s:%s:%i: Assertion failed: " #expr "\n", __FILE__, __func__, __LINE__); |
24 | __FILE__, __func__, __LINE__); | ||
25 | #endif | 24 | #endif |
26 | 25 | ||
27 | #define BFIN_TIMER_NUM_GROUP (BFIN_TIMER_OCTET(MAX_BLACKFIN_GPTIMERS - 1) + 1) | 26 | #define BFIN_TIMER_NUM_GROUP (BFIN_TIMER_OCTET(MAX_BLACKFIN_GPTIMERS - 1) + 1) |
@@ -70,7 +69,7 @@ static volatile GPTIMER_group_regs *const group_regs[BFIN_TIMER_NUM_GROUP] = | |||
70 | #endif | 69 | #endif |
71 | }; | 70 | }; |
72 | 71 | ||
73 | static uint32_t const dis_mask[MAX_BLACKFIN_GPTIMERS] = | 72 | static uint32_t const trun_mask[MAX_BLACKFIN_GPTIMERS] = |
74 | { | 73 | { |
75 | TIMER_STATUS_TRUN0, | 74 | TIMER_STATUS_TRUN0, |
76 | TIMER_STATUS_TRUN1, | 75 | TIMER_STATUS_TRUN1, |
@@ -90,7 +89,27 @@ static uint32_t const dis_mask[MAX_BLACKFIN_GPTIMERS] = | |||
90 | #endif | 89 | #endif |
91 | }; | 90 | }; |
92 | 91 | ||
93 | static uint32_t const irq_mask[MAX_BLACKFIN_GPTIMERS] = | 92 | static uint32_t const tovf_mask[MAX_BLACKFIN_GPTIMERS] = |
93 | { | ||
94 | TIMER_STATUS_TOVF0, | ||
95 | TIMER_STATUS_TOVF1, | ||
96 | TIMER_STATUS_TOVF2, | ||
97 | #if (MAX_BLACKFIN_GPTIMERS > 3) | ||
98 | TIMER_STATUS_TOVF3, | ||
99 | TIMER_STATUS_TOVF4, | ||
100 | TIMER_STATUS_TOVF5, | ||
101 | TIMER_STATUS_TOVF6, | ||
102 | TIMER_STATUS_TOVF7, | ||
103 | #endif | ||
104 | #if (MAX_BLACKFIN_GPTIMERS > 8) | ||
105 | TIMER_STATUS_TOVF8, | ||
106 | TIMER_STATUS_TOVF9, | ||
107 | TIMER_STATUS_TOVF10, | ||
108 | TIMER_STATUS_TOVF11, | ||
109 | #endif | ||
110 | }; | ||
111 | |||
112 | static uint32_t const timil_mask[MAX_BLACKFIN_GPTIMERS] = | ||
94 | { | 113 | { |
95 | TIMER_STATUS_TIMIL0, | 114 | TIMER_STATUS_TIMIL0, |
96 | TIMER_STATUS_TIMIL1, | 115 | TIMER_STATUS_TIMIL1, |
@@ -165,17 +184,31 @@ EXPORT_SYMBOL(set_gptimer_status); | |||
165 | uint16_t get_gptimer_intr(int timer_id) | 184 | uint16_t get_gptimer_intr(int timer_id) |
166 | { | 185 | { |
167 | tassert(timer_id < MAX_BLACKFIN_GPTIMERS); | 186 | tassert(timer_id < MAX_BLACKFIN_GPTIMERS); |
168 | return (group_regs[BFIN_TIMER_OCTET(timer_id)]->status & irq_mask[timer_id]) ? 1 : 0; | 187 | return (group_regs[BFIN_TIMER_OCTET(timer_id)]->status & timil_mask[timer_id]) ? 1 : 0; |
169 | } | 188 | } |
170 | EXPORT_SYMBOL(get_gptimer_intr); | 189 | EXPORT_SYMBOL(get_gptimer_intr); |
171 | 190 | ||
172 | void clear_gptimer_intr(int timer_id) | 191 | void clear_gptimer_intr(int timer_id) |
173 | { | 192 | { |
174 | tassert(timer_id < MAX_BLACKFIN_GPTIMERS); | 193 | tassert(timer_id < MAX_BLACKFIN_GPTIMERS); |
175 | group_regs[BFIN_TIMER_OCTET(timer_id)]->status = irq_mask[timer_id]; | 194 | group_regs[BFIN_TIMER_OCTET(timer_id)]->status = timil_mask[timer_id]; |
176 | } | 195 | } |
177 | EXPORT_SYMBOL(clear_gptimer_intr); | 196 | EXPORT_SYMBOL(clear_gptimer_intr); |
178 | 197 | ||
198 | uint16_t get_gptimer_over(int timer_id) | ||
199 | { | ||
200 | tassert(timer_id < MAX_BLACKFIN_GPTIMERS); | ||
201 | return (group_regs[BFIN_TIMER_OCTET(timer_id)]->status & tovf_mask[timer_id]) ? 1 : 0; | ||
202 | } | ||
203 | EXPORT_SYMBOL(get_gptimer_over); | ||
204 | |||
205 | void clear_gptimer_over(int timer_id) | ||
206 | { | ||
207 | tassert(timer_id < MAX_BLACKFIN_GPTIMERS); | ||
208 | group_regs[BFIN_TIMER_OCTET(timer_id)]->status = tovf_mask[timer_id]; | ||
209 | } | ||
210 | EXPORT_SYMBOL(clear_gptimer_over); | ||
211 | |||
179 | void set_gptimer_config(int timer_id, uint16_t config) | 212 | void set_gptimer_config(int timer_id, uint16_t config) |
180 | { | 213 | { |
181 | tassert(timer_id < MAX_BLACKFIN_GPTIMERS); | 214 | tassert(timer_id < MAX_BLACKFIN_GPTIMERS); |
@@ -214,7 +247,7 @@ void disable_gptimers(uint16_t mask) | |||
214 | } | 247 | } |
215 | for (i = 0; i < MAX_BLACKFIN_GPTIMERS; ++i) | 248 | for (i = 0; i < MAX_BLACKFIN_GPTIMERS; ++i) |
216 | if (mask & (1 << i)) | 249 | if (mask & (1 << i)) |
217 | group_regs[BFIN_TIMER_OCTET(i)]->status |= dis_mask[i]; | 250 | group_regs[BFIN_TIMER_OCTET(i)]->status |= trun_mask[i]; |
218 | SSYNC(); | 251 | SSYNC(); |
219 | } | 252 | } |
220 | EXPORT_SYMBOL(disable_gptimers); | 253 | EXPORT_SYMBOL(disable_gptimers); |
diff --git a/arch/blackfin/kernel/setup.c b/arch/blackfin/kernel/setup.c index f1b059e5a06c..934234f43839 100644 --- a/arch/blackfin/kernel/setup.c +++ b/arch/blackfin/kernel/setup.c | |||
@@ -316,6 +316,15 @@ void __init setup_arch(char **cmdline_p) | |||
316 | 316 | ||
317 | init_leds(); | 317 | init_leds(); |
318 | 318 | ||
319 | _bfin_swrst = bfin_read_SWRST(); | ||
320 | |||
321 | if (_bfin_swrst & RESET_DOUBLE) | ||
322 | printk(KERN_INFO "Recovering from Double Fault event\n"); | ||
323 | else if (_bfin_swrst & RESET_WDOG) | ||
324 | printk(KERN_INFO "Recovering from Watchdog event\n"); | ||
325 | else if (_bfin_swrst & RESET_SOFTWARE) | ||
326 | printk(KERN_NOTICE "Reset caused by Software reset\n"); | ||
327 | |||
319 | printk(KERN_INFO "Blackfin support (C) 2004-2007 Analog Devices, Inc.\n"); | 328 | printk(KERN_INFO "Blackfin support (C) 2004-2007 Analog Devices, Inc.\n"); |
320 | if (bfin_compiled_revid() == 0xffff) | 329 | if (bfin_compiled_revid() == 0xffff) |
321 | printk(KERN_INFO "Compiled for ADSP-%s Rev any\n", CPU); | 330 | printk(KERN_INFO "Compiled for ADSP-%s Rev any\n", CPU); |
@@ -402,8 +411,6 @@ void __init setup_arch(char **cmdline_p) | |||
402 | if (l1_length > L1_DATA_A_LENGTH) | 411 | if (l1_length > L1_DATA_A_LENGTH) |
403 | panic("L1 data memory overflow\n"); | 412 | panic("L1 data memory overflow\n"); |
404 | 413 | ||
405 | _bfin_swrst = bfin_read_SWRST(); | ||
406 | |||
407 | /* Copy atomic sequences to their fixed location, and sanity check that | 414 | /* Copy atomic sequences to their fixed location, and sanity check that |
408 | these locations are the ones that we advertise to userspace. */ | 415 | these locations are the ones that we advertise to userspace. */ |
409 | memcpy((void *)FIXED_CODE_START, &fixed_code_start, | 416 | memcpy((void *)FIXED_CODE_START, &fixed_code_start, |
@@ -424,6 +431,8 @@ void __init setup_arch(char **cmdline_p) | |||
424 | != ATOMIC_AND32 - FIXED_CODE_START); | 431 | != ATOMIC_AND32 - FIXED_CODE_START); |
425 | BUG_ON((char *)&atomic_xor32 - (char *)&fixed_code_start | 432 | BUG_ON((char *)&atomic_xor32 - (char *)&fixed_code_start |
426 | != ATOMIC_XOR32 - FIXED_CODE_START); | 433 | != ATOMIC_XOR32 - FIXED_CODE_START); |
434 | BUG_ON((char *)&safe_user_instruction - (char *)&fixed_code_start | ||
435 | != SAFE_USER_INSTRUCTION - FIXED_CODE_START); | ||
427 | 436 | ||
428 | init_exception_vectors(); | 437 | init_exception_vectors(); |
429 | bf53x_cache_init(); | 438 | bf53x_cache_init(); |
diff --git a/arch/blackfin/kernel/traps.c b/arch/blackfin/kernel/traps.c index afd044e78af6..cfa05436c972 100644 --- a/arch/blackfin/kernel/traps.c +++ b/arch/blackfin/kernel/traps.c | |||
@@ -37,10 +37,24 @@ | |||
37 | #include <asm/blackfin.h> | 37 | #include <asm/blackfin.h> |
38 | #include <asm/irq_handler.h> | 38 | #include <asm/irq_handler.h> |
39 | #include <asm/trace.h> | 39 | #include <asm/trace.h> |
40 | #include <asm/fixed_code.h> | ||
40 | 41 | ||
41 | #ifdef CONFIG_KGDB | 42 | #ifdef CONFIG_KGDB |
42 | # include <linux/debugger.h> | 43 | # include <linux/debugger.h> |
43 | # include <linux/kgdb.h> | 44 | # include <linux/kgdb.h> |
45 | |||
46 | # define CHK_DEBUGGER_TRAP() \ | ||
47 | do { \ | ||
48 | CHK_DEBUGGER(trapnr, sig, info.si_code, fp, ); \ | ||
49 | } while (0) | ||
50 | # define CHK_DEBUGGER_TRAP_MAYBE() \ | ||
51 | do { \ | ||
52 | if (kgdb_connected) \ | ||
53 | CHK_DEBUGGER_TRAP(); \ | ||
54 | } while (0) | ||
55 | #else | ||
56 | # define CHK_DEBUGGER_TRAP() do { } while (0) | ||
57 | # define CHK_DEBUGGER_TRAP_MAYBE() do { } while (0) | ||
44 | #endif | 58 | #endif |
45 | 59 | ||
46 | /* Initiate the event table handler */ | 60 | /* Initiate the event table handler */ |
@@ -53,13 +67,13 @@ void __init trap_init(void) | |||
53 | 67 | ||
54 | int kstack_depth_to_print = 48; | 68 | int kstack_depth_to_print = 48; |
55 | 69 | ||
56 | #ifdef CONFIG_DEBUG_BFIN_HWTRACE_ON | 70 | static void decode_address(char *buf, unsigned long address) |
57 | static int printk_address(unsigned long address) | ||
58 | { | 71 | { |
59 | struct vm_list_struct *vml; | 72 | struct vm_list_struct *vml; |
60 | struct task_struct *p; | 73 | struct task_struct *p; |
61 | struct mm_struct *mm; | 74 | struct mm_struct *mm; |
62 | unsigned long offset; | 75 | unsigned long flags, offset; |
76 | unsigned int in_exception = bfin_read_IPEND() & 0x10; | ||
63 | 77 | ||
64 | #ifdef CONFIG_KALLSYMS | 78 | #ifdef CONFIG_KALLSYMS |
65 | unsigned long symsize; | 79 | unsigned long symsize; |
@@ -75,20 +89,33 @@ static int printk_address(unsigned long address) | |||
75 | /* yeah! kernel space! */ | 89 | /* yeah! kernel space! */ |
76 | if (!modname) | 90 | if (!modname) |
77 | modname = delim = ""; | 91 | modname = delim = ""; |
78 | return printk("<0x%p> { %s%s%s%s + 0x%lx }", | 92 | sprintf(buf, "<0x%p> { %s%s%s%s + 0x%lx }", |
79 | (void *)address, delim, modname, delim, symname, | 93 | (void *)address, delim, modname, delim, symname, |
80 | (unsigned long)offset); | 94 | (unsigned long)offset); |
95 | return; | ||
81 | 96 | ||
82 | } | 97 | } |
83 | #endif | 98 | #endif |
84 | 99 | ||
100 | /* Problem in fixed code section? */ | ||
101 | if (address >= FIXED_CODE_START && address < FIXED_CODE_END) { | ||
102 | sprintf(buf, "<0x%p> /* Maybe fixed code section */", (void *)address); | ||
103 | return; | ||
104 | } | ||
105 | |||
106 | /* Problem somewhere before the kernel start address */ | ||
107 | if (address < CONFIG_BOOT_LOAD) { | ||
108 | sprintf(buf, "<0x%p> /* Maybe null pointer? */", (void *)address); | ||
109 | return; | ||
110 | } | ||
111 | |||
85 | /* looks like we're off in user-land, so let's walk all the | 112 | /* looks like we're off in user-land, so let's walk all the |
86 | * mappings of all our processes and see if we can't be a whee | 113 | * mappings of all our processes and see if we can't be a whee |
87 | * bit more specific | 114 | * bit more specific |
88 | */ | 115 | */ |
89 | write_lock_irq(&tasklist_lock); | 116 | write_lock_irqsave(&tasklist_lock, flags); |
90 | for_each_process(p) { | 117 | for_each_process(p) { |
91 | mm = get_task_mm(p); | 118 | mm = (in_exception ? p->mm : get_task_mm(p)); |
92 | if (!mm) | 119 | if (!mm) |
93 | continue; | 120 | continue; |
94 | 121 | ||
@@ -117,25 +144,30 @@ static int printk_address(unsigned long address) | |||
117 | else | 144 | else |
118 | offset = (address - vma->vm_start) + (vma->vm_pgoff << PAGE_SHIFT); | 145 | offset = (address - vma->vm_start) + (vma->vm_pgoff << PAGE_SHIFT); |
119 | 146 | ||
120 | write_unlock_irq(&tasklist_lock); | 147 | sprintf(buf, "<0x%p> [ %s + 0x%lx ]", |
121 | mmput(mm); | 148 | (void *)address, name, offset); |
122 | return printk("<0x%p> [ %s + 0x%lx ]", | 149 | if (!in_exception) |
123 | (void *)address, name, offset); | 150 | mmput(mm); |
151 | goto done; | ||
124 | } | 152 | } |
125 | 153 | ||
126 | vml = vml->next; | 154 | vml = vml->next; |
127 | } | 155 | } |
128 | mmput(mm); | 156 | if (!in_exception) |
157 | mmput(mm); | ||
129 | } | 158 | } |
130 | write_unlock_irq(&tasklist_lock); | ||
131 | 159 | ||
132 | /* we were unable to find this address anywhere */ | 160 | /* we were unable to find this address anywhere */ |
133 | return printk("[<0x%p>]", (void *)address); | 161 | sprintf(buf, "[<0x%p>]", (void *)address); |
162 | |||
163 | done: | ||
164 | write_unlock_irqrestore(&tasklist_lock, flags); | ||
134 | } | 165 | } |
135 | #endif | ||
136 | 166 | ||
137 | asmlinkage void double_fault_c(struct pt_regs *fp) | 167 | asmlinkage void double_fault_c(struct pt_regs *fp) |
138 | { | 168 | { |
169 | console_verbose(); | ||
170 | oops_in_progress = 1; | ||
139 | printk(KERN_EMERG "\n" KERN_EMERG "Double Fault\n"); | 171 | printk(KERN_EMERG "\n" KERN_EMERG "Double Fault\n"); |
140 | dump_bfin_regs(fp, (void *)fp->retx); | 172 | dump_bfin_regs(fp, (void *)fp->retx); |
141 | panic("Double Fault - unrecoverable event\n"); | 173 | panic("Double Fault - unrecoverable event\n"); |
@@ -151,22 +183,29 @@ asmlinkage void trap_c(struct pt_regs *fp) | |||
151 | siginfo_t info; | 183 | siginfo_t info; |
152 | unsigned long trapnr = fp->seqstat & SEQSTAT_EXCAUSE; | 184 | unsigned long trapnr = fp->seqstat & SEQSTAT_EXCAUSE; |
153 | 185 | ||
186 | trace_buffer_save(j); | ||
187 | |||
188 | /* Important - be very careful dereferncing pointers - will lead to | ||
189 | * double faults if the stack has become corrupt | ||
190 | */ | ||
191 | |||
192 | /* If the fault was caused by a kernel thread, or interrupt handler | ||
193 | * we will kernel panic, so the system reboots. | ||
194 | * If KGDB is enabled, don't set this for kernel breakpoints | ||
195 | */ | ||
196 | if ((bfin_read_IPEND() & 0xFFC0) | ||
154 | #ifdef CONFIG_KGDB | 197 | #ifdef CONFIG_KGDB |
155 | # define CHK_DEBUGGER_TRAP() \ | 198 | && trapnr != VEC_EXCPT02 |
156 | do { \ | ||
157 | CHK_DEBUGGER(trapnr, sig, info.si_code, fp, ); \ | ||
158 | } while (0) | ||
159 | # define CHK_DEBUGGER_TRAP_MAYBE() \ | ||
160 | do { \ | ||
161 | if (kgdb_connected) \ | ||
162 | CHK_DEBUGGER_TRAP(); \ | ||
163 | } while (0) | ||
164 | #else | ||
165 | # define CHK_DEBUGGER_TRAP() do { } while (0) | ||
166 | # define CHK_DEBUGGER_TRAP_MAYBE() do { } while (0) | ||
167 | #endif | 199 | #endif |
168 | 200 | ){ | |
169 | trace_buffer_save(j); | 201 | console_verbose(); |
202 | oops_in_progress = 1; | ||
203 | } else if (current) { | ||
204 | if (current->mm == NULL) { | ||
205 | console_verbose(); | ||
206 | oops_in_progress = 1; | ||
207 | } | ||
208 | } | ||
170 | 209 | ||
171 | /* trap_c() will be called for exceptions. During exceptions | 210 | /* trap_c() will be called for exceptions. During exceptions |
172 | * processing, the pc value should be set with retx value. | 211 | * processing, the pc value should be set with retx value. |
@@ -211,7 +250,7 @@ asmlinkage void trap_c(struct pt_regs *fp) | |||
211 | case VEC_EXCPT03: | 250 | case VEC_EXCPT03: |
212 | info.si_code = SEGV_STACKFLOW; | 251 | info.si_code = SEGV_STACKFLOW; |
213 | sig = SIGSEGV; | 252 | sig = SIGSEGV; |
214 | printk(KERN_EMERG EXC_0x03); | 253 | printk(KERN_NOTICE EXC_0x03); |
215 | CHK_DEBUGGER_TRAP(); | 254 | CHK_DEBUGGER_TRAP(); |
216 | break; | 255 | break; |
217 | /* 0x04 - User Defined, Caught by default */ | 256 | /* 0x04 - User Defined, Caught by default */ |
@@ -240,7 +279,7 @@ asmlinkage void trap_c(struct pt_regs *fp) | |||
240 | case VEC_OVFLOW: | 279 | case VEC_OVFLOW: |
241 | info.si_code = TRAP_TRACEFLOW; | 280 | info.si_code = TRAP_TRACEFLOW; |
242 | sig = SIGTRAP; | 281 | sig = SIGTRAP; |
243 | printk(KERN_EMERG EXC_0x11); | 282 | printk(KERN_NOTICE EXC_0x11); |
244 | CHK_DEBUGGER_TRAP(); | 283 | CHK_DEBUGGER_TRAP(); |
245 | break; | 284 | break; |
246 | /* 0x12 - Reserved, Caught by default */ | 285 | /* 0x12 - Reserved, Caught by default */ |
@@ -262,14 +301,14 @@ asmlinkage void trap_c(struct pt_regs *fp) | |||
262 | case VEC_UNDEF_I: | 301 | case VEC_UNDEF_I: |
263 | info.si_code = ILL_ILLOPC; | 302 | info.si_code = ILL_ILLOPC; |
264 | sig = SIGILL; | 303 | sig = SIGILL; |
265 | printk(KERN_EMERG EXC_0x21); | 304 | printk(KERN_NOTICE EXC_0x21); |
266 | CHK_DEBUGGER_TRAP(); | 305 | CHK_DEBUGGER_TRAP(); |
267 | break; | 306 | break; |
268 | /* 0x22 - Illegal Instruction Combination, handled here */ | 307 | /* 0x22 - Illegal Instruction Combination, handled here */ |
269 | case VEC_ILGAL_I: | 308 | case VEC_ILGAL_I: |
270 | info.si_code = ILL_ILLPARAOP; | 309 | info.si_code = ILL_ILLPARAOP; |
271 | sig = SIGILL; | 310 | sig = SIGILL; |
272 | printk(KERN_EMERG EXC_0x22); | 311 | printk(KERN_NOTICE EXC_0x22); |
273 | CHK_DEBUGGER_TRAP(); | 312 | CHK_DEBUGGER_TRAP(); |
274 | break; | 313 | break; |
275 | /* 0x23 - Data CPLB Protection Violation, | 314 | /* 0x23 - Data CPLB Protection Violation, |
@@ -277,21 +316,21 @@ asmlinkage void trap_c(struct pt_regs *fp) | |||
277 | case VEC_CPLB_VL: | 316 | case VEC_CPLB_VL: |
278 | info.si_code = ILL_CPLB_VI; | 317 | info.si_code = ILL_CPLB_VI; |
279 | sig = SIGILL; | 318 | sig = SIGILL; |
280 | printk(KERN_EMERG EXC_0x23); | 319 | printk(KERN_NOTICE EXC_0x23); |
281 | CHK_DEBUGGER_TRAP(); | 320 | CHK_DEBUGGER_TRAP(); |
282 | break; | 321 | break; |
283 | /* 0x24 - Data access misaligned, handled here */ | 322 | /* 0x24 - Data access misaligned, handled here */ |
284 | case VEC_MISALI_D: | 323 | case VEC_MISALI_D: |
285 | info.si_code = BUS_ADRALN; | 324 | info.si_code = BUS_ADRALN; |
286 | sig = SIGBUS; | 325 | sig = SIGBUS; |
287 | printk(KERN_EMERG EXC_0x24); | 326 | printk(KERN_NOTICE EXC_0x24); |
288 | CHK_DEBUGGER_TRAP(); | 327 | CHK_DEBUGGER_TRAP(); |
289 | break; | 328 | break; |
290 | /* 0x25 - Unrecoverable Event, handled here */ | 329 | /* 0x25 - Unrecoverable Event, handled here */ |
291 | case VEC_UNCOV: | 330 | case VEC_UNCOV: |
292 | info.si_code = ILL_ILLEXCPT; | 331 | info.si_code = ILL_ILLEXCPT; |
293 | sig = SIGILL; | 332 | sig = SIGILL; |
294 | printk(KERN_EMERG EXC_0x25); | 333 | printk(KERN_NOTICE EXC_0x25); |
295 | CHK_DEBUGGER_TRAP(); | 334 | CHK_DEBUGGER_TRAP(); |
296 | break; | 335 | break; |
297 | /* 0x26 - Data CPLB Miss, normal case is handled in _cplb_hdr, | 336 | /* 0x26 - Data CPLB Miss, normal case is handled in _cplb_hdr, |
@@ -299,7 +338,7 @@ asmlinkage void trap_c(struct pt_regs *fp) | |||
299 | case VEC_CPLB_M: | 338 | case VEC_CPLB_M: |
300 | info.si_code = BUS_ADRALN; | 339 | info.si_code = BUS_ADRALN; |
301 | sig = SIGBUS; | 340 | sig = SIGBUS; |
302 | printk(KERN_EMERG EXC_0x26); | 341 | printk(KERN_NOTICE EXC_0x26); |
303 | CHK_DEBUGGER_TRAP(); | 342 | CHK_DEBUGGER_TRAP(); |
304 | break; | 343 | break; |
305 | /* 0x27 - Data CPLB Multiple Hits - Linux Trap Zero, handled here */ | 344 | /* 0x27 - Data CPLB Multiple Hits - Linux Trap Zero, handled here */ |
@@ -307,11 +346,10 @@ asmlinkage void trap_c(struct pt_regs *fp) | |||
307 | info.si_code = ILL_CPLB_MULHIT; | 346 | info.si_code = ILL_CPLB_MULHIT; |
308 | #ifdef CONFIG_DEBUG_HUNT_FOR_ZERO | 347 | #ifdef CONFIG_DEBUG_HUNT_FOR_ZERO |
309 | sig = SIGSEGV; | 348 | sig = SIGSEGV; |
310 | printk(KERN_EMERG "\n" | 349 | printk(KERN_NOTICE "NULL pointer access (probably)\n"); |
311 | KERN_EMERG "NULL pointer access (probably)\n"); | ||
312 | #else | 350 | #else |
313 | sig = SIGILL; | 351 | sig = SIGILL; |
314 | printk(KERN_EMERG EXC_0x27); | 352 | printk(KERN_NOTICE EXC_0x27); |
315 | #endif | 353 | #endif |
316 | CHK_DEBUGGER_TRAP(); | 354 | CHK_DEBUGGER_TRAP(); |
317 | break; | 355 | break; |
@@ -331,7 +369,7 @@ asmlinkage void trap_c(struct pt_regs *fp) | |||
331 | case VEC_ISTRU_VL: /* ADSP-BF535 only (MH) */ | 369 | case VEC_ISTRU_VL: /* ADSP-BF535 only (MH) */ |
332 | info.si_code = BUS_OPFETCH; | 370 | info.si_code = BUS_OPFETCH; |
333 | sig = SIGBUS; | 371 | sig = SIGBUS; |
334 | printk(KERN_EMERG "BF535: VEC_ISTRU_VL\n"); | 372 | printk(KERN_NOTICE "BF535: VEC_ISTRU_VL\n"); |
335 | CHK_DEBUGGER_TRAP(); | 373 | CHK_DEBUGGER_TRAP(); |
336 | break; | 374 | break; |
337 | #else | 375 | #else |
@@ -341,7 +379,7 @@ asmlinkage void trap_c(struct pt_regs *fp) | |||
341 | case VEC_MISALI_I: | 379 | case VEC_MISALI_I: |
342 | info.si_code = BUS_ADRALN; | 380 | info.si_code = BUS_ADRALN; |
343 | sig = SIGBUS; | 381 | sig = SIGBUS; |
344 | printk(KERN_EMERG EXC_0x2A); | 382 | printk(KERN_NOTICE EXC_0x2A); |
345 | CHK_DEBUGGER_TRAP(); | 383 | CHK_DEBUGGER_TRAP(); |
346 | break; | 384 | break; |
347 | /* 0x2B - Instruction CPLB protection Violation, | 385 | /* 0x2B - Instruction CPLB protection Violation, |
@@ -349,14 +387,14 @@ asmlinkage void trap_c(struct pt_regs *fp) | |||
349 | case VEC_CPLB_I_VL: | 387 | case VEC_CPLB_I_VL: |
350 | info.si_code = ILL_CPLB_VI; | 388 | info.si_code = ILL_CPLB_VI; |
351 | sig = SIGILL; | 389 | sig = SIGILL; |
352 | printk(KERN_EMERG EXC_0x2B); | 390 | printk(KERN_NOTICE EXC_0x2B); |
353 | CHK_DEBUGGER_TRAP(); | 391 | CHK_DEBUGGER_TRAP(); |
354 | break; | 392 | break; |
355 | /* 0x2C - Instruction CPLB miss, handled in _cplb_hdr */ | 393 | /* 0x2C - Instruction CPLB miss, handled in _cplb_hdr */ |
356 | case VEC_CPLB_I_M: | 394 | case VEC_CPLB_I_M: |
357 | info.si_code = ILL_CPLB_MISS; | 395 | info.si_code = ILL_CPLB_MISS; |
358 | sig = SIGBUS; | 396 | sig = SIGBUS; |
359 | printk(KERN_EMERG EXC_0x2C); | 397 | printk(KERN_NOTICE EXC_0x2C); |
360 | CHK_DEBUGGER_TRAP(); | 398 | CHK_DEBUGGER_TRAP(); |
361 | break; | 399 | break; |
362 | /* 0x2D - Instruction CPLB Multiple Hits, handled here */ | 400 | /* 0x2D - Instruction CPLB Multiple Hits, handled here */ |
@@ -364,10 +402,10 @@ asmlinkage void trap_c(struct pt_regs *fp) | |||
364 | info.si_code = ILL_CPLB_MULHIT; | 402 | info.si_code = ILL_CPLB_MULHIT; |
365 | #ifdef CONFIG_DEBUG_HUNT_FOR_ZERO | 403 | #ifdef CONFIG_DEBUG_HUNT_FOR_ZERO |
366 | sig = SIGSEGV; | 404 | sig = SIGSEGV; |
367 | printk(KERN_EMERG "\n\nJump to address 0 - 0x0fff\n"); | 405 | printk(KERN_NOTICE "Jump to address 0 - 0x0fff\n"); |
368 | #else | 406 | #else |
369 | sig = SIGILL; | 407 | sig = SIGILL; |
370 | printk(KERN_EMERG EXC_0x2D); | 408 | printk(KERN_NOTICE EXC_0x2D); |
371 | #endif | 409 | #endif |
372 | CHK_DEBUGGER_TRAP(); | 410 | CHK_DEBUGGER_TRAP(); |
373 | break; | 411 | break; |
@@ -375,7 +413,7 @@ asmlinkage void trap_c(struct pt_regs *fp) | |||
375 | case VEC_ILL_RES: | 413 | case VEC_ILL_RES: |
376 | info.si_code = ILL_PRVOPC; | 414 | info.si_code = ILL_PRVOPC; |
377 | sig = SIGILL; | 415 | sig = SIGILL; |
378 | printk(KERN_EMERG EXC_0x2E); | 416 | printk(KERN_NOTICE EXC_0x2E); |
379 | CHK_DEBUGGER_TRAP(); | 417 | CHK_DEBUGGER_TRAP(); |
380 | break; | 418 | break; |
381 | /* 0x2F - Reserved, Caught by default */ | 419 | /* 0x2F - Reserved, Caught by default */ |
@@ -404,38 +442,40 @@ asmlinkage void trap_c(struct pt_regs *fp) | |||
404 | break; | 442 | break; |
405 | } | 443 | } |
406 | 444 | ||
407 | if (sig != 0 && sig != SIGTRAP) { | 445 | BUG_ON(sig == 0); |
446 | |||
447 | if (sig != SIGTRAP) { | ||
408 | unsigned long stack; | 448 | unsigned long stack; |
409 | dump_bfin_regs(fp, (void *)fp->retx); | 449 | dump_bfin_regs(fp, (void *)fp->retx); |
410 | dump_bfin_trace_buffer(); | 450 | |
451 | /* Print out the trace buffer if it makes sense */ | ||
452 | #ifndef CONFIG_DEBUG_BFIN_NO_KERN_HWTRACE | ||
453 | if (trapnr == VEC_CPLB_I_M || trapnr == VEC_CPLB_M) | ||
454 | printk(KERN_NOTICE "No trace since you do not have " | ||
455 | "CONFIG_DEBUG_BFIN_NO_KERN_HWTRACE enabled\n" | ||
456 | KERN_NOTICE "\n"); | ||
457 | else | ||
458 | #endif | ||
459 | dump_bfin_trace_buffer(); | ||
411 | show_stack(current, &stack); | 460 | show_stack(current, &stack); |
412 | if (current->mm == NULL) | 461 | if (oops_in_progress) { |
462 | #ifndef CONFIG_ACCESS_CHECK | ||
463 | printk(KERN_EMERG "Hey - dork - please turn on " | ||
464 | "CONFIG_ACCESS_CHECK\n"); | ||
465 | #endif | ||
413 | panic("Kernel exception"); | 466 | panic("Kernel exception"); |
467 | } | ||
468 | |||
469 | /* Ensure that bad return addresses don't end up in an infinite | ||
470 | * loop, due to speculative loads/reads | ||
471 | */ | ||
472 | fp->pc = SAFE_USER_INSTRUCTION; | ||
414 | } | 473 | } |
415 | info.si_signo = sig; | 474 | info.si_signo = sig; |
416 | info.si_errno = 0; | 475 | info.si_errno = 0; |
417 | info.si_addr = (void *)fp->pc; | 476 | info.si_addr = (void *)fp->pc; |
418 | force_sig_info(sig, &info, current); | 477 | force_sig_info(sig, &info, current); |
419 | 478 | ||
420 | /* if the address that we are about to return to is not valid, set it | ||
421 | * to a valid address, if we have a current application or panic | ||
422 | */ | ||
423 | if (!(fp->pc <= physical_mem_end | ||
424 | #if L1_CODE_LENGTH != 0 | ||
425 | || (fp->pc >= L1_CODE_START && | ||
426 | fp->pc <= (L1_CODE_START + L1_CODE_LENGTH)) | ||
427 | #endif | ||
428 | )) { | ||
429 | if (current->mm) { | ||
430 | fp->pc = current->mm->start_code; | ||
431 | } else { | ||
432 | printk(KERN_EMERG | ||
433 | "I can't return to memory that doesn't exist" | ||
434 | " - bad things happen\n"); | ||
435 | panic("Help - I've fallen and can't get up\n"); | ||
436 | } | ||
437 | } | ||
438 | |||
439 | trace_buffer_restore(j); | 479 | trace_buffer_restore(j); |
440 | return; | 480 | return; |
441 | } | 481 | } |
@@ -448,21 +488,21 @@ void dump_bfin_trace_buffer(void) | |||
448 | { | 488 | { |
449 | #ifdef CONFIG_DEBUG_BFIN_HWTRACE_ON | 489 | #ifdef CONFIG_DEBUG_BFIN_HWTRACE_ON |
450 | int tflags, i = 0; | 490 | int tflags, i = 0; |
491 | char buf[150]; | ||
451 | #ifdef CONFIG_DEBUG_BFIN_HWTRACE_EXPAND | 492 | #ifdef CONFIG_DEBUG_BFIN_HWTRACE_EXPAND |
452 | int j, index; | 493 | int j, index; |
453 | #endif | 494 | #endif |
454 | 495 | ||
455 | trace_buffer_save(tflags); | 496 | trace_buffer_save(tflags); |
456 | 497 | ||
457 | printk(KERN_EMERG "Hardware Trace:\n"); | 498 | printk(KERN_NOTICE "Hardware Trace:\n"); |
458 | 499 | ||
459 | if (likely(bfin_read_TBUFSTAT() & TBUFCNT)) { | 500 | if (likely(bfin_read_TBUFSTAT() & TBUFCNT)) { |
460 | for (; bfin_read_TBUFSTAT() & TBUFCNT; i++) { | 501 | for (; bfin_read_TBUFSTAT() & TBUFCNT; i++) { |
461 | printk(KERN_EMERG "%4i Target : ", i); | 502 | decode_address(buf, (unsigned long)bfin_read_TBUF()); |
462 | printk_address((unsigned long)bfin_read_TBUF()); | 503 | printk(KERN_NOTICE "%4i Target : %s\n", i, buf); |
463 | printk("\n" KERN_EMERG " Source : "); | 504 | decode_address(buf, (unsigned long)bfin_read_TBUF()); |
464 | printk_address((unsigned long)bfin_read_TBUF()); | 505 | printk(KERN_NOTICE " Source : %s\n", buf); |
465 | printk("\n"); | ||
466 | } | 506 | } |
467 | } | 507 | } |
468 | 508 | ||
@@ -474,17 +514,16 @@ void dump_bfin_trace_buffer(void) | |||
474 | 514 | ||
475 | j = (1 << CONFIG_DEBUG_BFIN_HWTRACE_EXPAND_LEN) * 128; | 515 | j = (1 << CONFIG_DEBUG_BFIN_HWTRACE_EXPAND_LEN) * 128; |
476 | while (j) { | 516 | while (j) { |
477 | printk(KERN_EMERG "%4i Target : ", i); | 517 | decode_address(buf, software_trace_buff[index]); |
478 | printk_address(software_trace_buff[index]); | 518 | printk(KERN_NOTICE "%4i Target : %s\n", i, buf); |
479 | index -= 1; | 519 | index -= 1; |
480 | if (index < 0 ) | 520 | if (index < 0 ) |
481 | index = EXPAND_LEN; | 521 | index = EXPAND_LEN; |
482 | printk("\n" KERN_EMERG " Source : "); | 522 | decode_address(buf, software_trace_buff[index]); |
483 | printk_address(software_trace_buff[index]); | 523 | printk(KERN_NOTICE " Source : %s\n", buf); |
484 | index -= 1; | 524 | index -= 1; |
485 | if (index < 0) | 525 | if (index < 0) |
486 | index = EXPAND_LEN; | 526 | index = EXPAND_LEN; |
487 | printk("\n"); | ||
488 | j--; | 527 | j--; |
489 | i++; | 528 | i++; |
490 | } | 529 | } |
@@ -499,10 +538,7 @@ static void show_trace(struct task_struct *tsk, unsigned long *sp) | |||
499 | { | 538 | { |
500 | unsigned long addr; | 539 | unsigned long addr; |
501 | 540 | ||
502 | printk("\nCall Trace:"); | 541 | printk(KERN_NOTICE "\n" KERN_NOTICE "Call Trace:\n"); |
503 | #ifdef CONFIG_KALLSYMS | ||
504 | printk("\n"); | ||
505 | #endif | ||
506 | 542 | ||
507 | while (!kstack_end(sp)) { | 543 | while (!kstack_end(sp)) { |
508 | addr = *sp++; | 544 | addr = *sp++; |
@@ -518,7 +554,7 @@ static void show_trace(struct task_struct *tsk, unsigned long *sp) | |||
518 | print_ip_sym(addr); | 554 | print_ip_sym(addr); |
519 | } | 555 | } |
520 | 556 | ||
521 | printk("\n"); | 557 | printk(KERN_NOTICE "\n"); |
522 | } | 558 | } |
523 | 559 | ||
524 | void show_stack(struct task_struct *task, unsigned long *stack) | 560 | void show_stack(struct task_struct *task, unsigned long *stack) |
@@ -540,14 +576,15 @@ void show_stack(struct task_struct *task, unsigned long *stack) | |||
540 | addr = (unsigned long)stack; | 576 | addr = (unsigned long)stack; |
541 | endstack = (unsigned long *)PAGE_ALIGN(addr); | 577 | endstack = (unsigned long *)PAGE_ALIGN(addr); |
542 | 578 | ||
543 | printk(KERN_EMERG "Stack from %08lx:", (unsigned long)stack); | 579 | printk(KERN_NOTICE "Stack from %08lx:", (unsigned long)stack); |
544 | for (i = 0; i < kstack_depth_to_print; i++) { | 580 | for (i = 0; i < kstack_depth_to_print; i++) { |
545 | if (stack + 1 > endstack) | 581 | if (stack + 1 > endstack) |
546 | break; | 582 | break; |
547 | if (i % 8 == 0) | 583 | if (i % 8 == 0) |
548 | printk("\n" KERN_EMERG " "); | 584 | printk("\n" KERN_NOTICE " "); |
549 | printk(" %08lx", *stack++); | 585 | printk(" %08lx", *stack++); |
550 | } | 586 | } |
587 | printk("\n"); | ||
551 | 588 | ||
552 | show_trace(task, stack); | 589 | show_trace(task, stack); |
553 | } | 590 | } |
@@ -568,33 +605,34 @@ EXPORT_SYMBOL(dump_stack); | |||
568 | 605 | ||
569 | void dump_bfin_regs(struct pt_regs *fp, void *retaddr) | 606 | void dump_bfin_regs(struct pt_regs *fp, void *retaddr) |
570 | { | 607 | { |
571 | if (current->pid) { | 608 | char buf [150]; |
572 | printk(KERN_EMERG "\n" KERN_EMERG "CURRENT PROCESS:\n" | 609 | |
573 | KERN_EMERG "\n"); | 610 | if (!oops_in_progress) { |
574 | printk(KERN_EMERG "COMM=%s PID=%d\n", | 611 | if (current->pid && current->mm) { |
575 | current->comm, current->pid); | 612 | printk(KERN_NOTICE "\n" KERN_NOTICE "CURRENT PROCESS:\n"); |
613 | printk(KERN_NOTICE "COMM=%s PID=%d\n", | ||
614 | current->comm, current->pid); | ||
615 | |||
616 | printk(KERN_NOTICE "TEXT = 0x%p-0x%p DATA = 0x%p-0x%p\n" | ||
617 | KERN_NOTICE "BSS = 0x%p-0x%p USER-STACK = 0x%p\n" | ||
618 | KERN_NOTICE "\n", | ||
619 | (void *)current->mm->start_code, | ||
620 | (void *)current->mm->end_code, | ||
621 | (void *)current->mm->start_data, | ||
622 | (void *)current->mm->end_data, | ||
623 | (void *)current->mm->end_data, | ||
624 | (void *)current->mm->brk, | ||
625 | (void *)current->mm->start_stack); | ||
626 | } else { | ||
627 | printk (KERN_NOTICE "\n" KERN_NOTICE | ||
628 | "No Valid pid - Either things are really messed up," | ||
629 | " or you are in the kernel\n"); | ||
630 | } | ||
576 | } else { | 631 | } else { |
577 | printk | 632 | printk(KERN_NOTICE "Kernel or interrupt exception\n"); |
578 | (KERN_EMERG "\n" KERN_EMERG | ||
579 | "No Valid pid - Either things are really messed up," | ||
580 | " or you are in the kernel\n"); | ||
581 | } | ||
582 | |||
583 | if (current->mm) { | ||
584 | printk(KERN_EMERG "TEXT = 0x%p-0x%p DATA = 0x%p-0x%p\n" | ||
585 | KERN_EMERG "BSS = 0x%p-0x%p USER-STACK = 0x%p\n" | ||
586 | KERN_EMERG "\n", | ||
587 | (void *)current->mm->start_code, | ||
588 | (void *)current->mm->end_code, | ||
589 | (void *)current->mm->start_data, | ||
590 | (void *)current->mm->end_data, | ||
591 | (void *)current->mm->end_data, | ||
592 | (void *)current->mm->brk, | ||
593 | (void *)current->mm->start_stack); | ||
594 | } | 633 | } |
595 | 634 | ||
596 | printk(KERN_EMERG "return address: [0x%p]; contents of:", retaddr); | 635 | if (retaddr >= (void *)FIXED_CODE_START && retaddr < (void *)physical_mem_end |
597 | if (retaddr != 0 && retaddr <= (void *)physical_mem_end | ||
598 | #if L1_CODE_LENGTH != 0 | 636 | #if L1_CODE_LENGTH != 0 |
599 | /* FIXME: Copy the code out of L1 Instruction SRAM through dma | 637 | /* FIXME: Copy the code out of L1 Instruction SRAM through dma |
600 | memcpy. */ | 638 | memcpy. */ |
@@ -604,18 +642,20 @@ void dump_bfin_regs(struct pt_regs *fp, void *retaddr) | |||
604 | ) { | 642 | ) { |
605 | int i = ((unsigned int)retaddr & 0xFFFFFFF0) - 32; | 643 | int i = ((unsigned int)retaddr & 0xFFFFFFF0) - 32; |
606 | unsigned short x = 0; | 644 | unsigned short x = 0; |
645 | printk(KERN_NOTICE "return address: [0x%p]; contents of:", retaddr); | ||
607 | for (; i < ((unsigned int)retaddr & 0xFFFFFFF0) + 32; i += 2) { | 646 | for (; i < ((unsigned int)retaddr & 0xFFFFFFF0) + 32; i += 2) { |
608 | if (!(i & 0xF)) | 647 | if (!(i & 0xF)) |
609 | printk("\n" KERN_EMERG "0x%08x: ", i); | 648 | printk("\n" KERN_NOTICE "0x%08x: ", i); |
610 | 649 | ||
611 | if (get_user(x, (unsigned short *)i)) | 650 | if (get_user(x, (unsigned short *)i)) |
612 | break; | 651 | break; |
613 | #ifndef CONFIG_DEBUG_HWERR | 652 | #ifndef CONFIG_DEBUG_HWERR |
614 | /* If one of the last few instructions was a STI | 653 | /* If one of the last few instructions was a STI |
615 | * it is likely that the error occured awhile ago | 654 | * it is likely that the error occured awhile ago |
616 | * and we just noticed | 655 | * and we just noticed. This only happens in kernel |
656 | * context, which should mean an oops is happening | ||
617 | */ | 657 | */ |
618 | if (x >= 0x0040 && x <= 0x0047 && i <= 0) | 658 | if (oops_in_progress && x >= 0x0040 && x <= 0x0047 && i <= 0) |
619 | panic("\n\nWARNING : You should reconfigure" | 659 | panic("\n\nWARNING : You should reconfigure" |
620 | " the kernel to turn on\n" | 660 | " the kernel to turn on\n" |
621 | " 'Hardware error interrupt" | 661 | " 'Hardware error interrupt" |
@@ -628,56 +668,60 @@ void dump_bfin_regs(struct pt_regs *fp, void *retaddr) | |||
628 | else | 668 | else |
629 | printk(" %04x ", x); | 669 | printk(" %04x ", x); |
630 | } | 670 | } |
631 | printk("\n" KERN_EMERG "\n"); | 671 | printk("\n"); |
632 | } else | 672 | } else |
633 | printk(KERN_EMERG | 673 | printk("\n" KERN_NOTICE |
634 | "Cannot look at the [PC] for it is" | 674 | "Cannot look at the [PC] for it is" |
635 | "in unreadable L1 SRAM - sorry\n"); | 675 | " in unreadable memory - sorry\n"); |
676 | |||
677 | printk(KERN_NOTICE "\n" KERN_NOTICE "SEQUENCER STATUS:\n"); | ||
678 | printk(KERN_NOTICE " SEQSTAT: %08lx IPEND: %04lx SYSCFG: %04lx\n", | ||
679 | (long)fp->seqstat, fp->ipend, fp->syscfg); | ||
636 | 680 | ||
681 | decode_address(buf, fp->rete); | ||
682 | printk(KERN_NOTICE " RETE: %s\n", buf); | ||
683 | decode_address(buf, fp->retn); | ||
684 | printk(KERN_NOTICE " RETN: %s\n", buf); | ||
685 | decode_address(buf, fp->retx); | ||
686 | printk(KERN_NOTICE " RETX: %s\n", buf); | ||
687 | decode_address(buf, fp->rets); | ||
688 | printk(KERN_NOTICE " RETS: %s\n", buf); | ||
637 | 689 | ||
638 | printk(KERN_EMERG | 690 | if ((long)fp->seqstat & SEQSTAT_EXCAUSE) { |
639 | "RETE: %08lx RETN: %08lx RETX: %08lx RETS: %08lx\n", | 691 | decode_address(buf, bfin_read_DCPLB_FAULT_ADDR()); |
640 | fp->rete, fp->retn, fp->retx, fp->rets); | 692 | printk(KERN_NOTICE "DCPLB_FAULT_ADDR: %s\n", buf); |
641 | printk(KERN_EMERG "IPEND: %04lx SYSCFG: %04lx\n", | 693 | decode_address(buf, bfin_read_ICPLB_FAULT_ADDR()); |
642 | fp->ipend, fp->syscfg); | 694 | printk(KERN_NOTICE "ICPLB_FAULT_ADDR: %s\n", buf); |
643 | printk(KERN_EMERG "SEQSTAT: %08lx SP: %08lx\n", | 695 | } |
644 | (long)fp->seqstat, (long)fp); | 696 | |
645 | printk(KERN_EMERG "R0: %08lx R1: %08lx R2: %08lx R3: %08lx\n", | 697 | printk(KERN_NOTICE "\n" KERN_NOTICE "PROCESSOR STATE:\n"); |
698 | printk(KERN_NOTICE " R0 : %08lx R1 : %08lx R2 : %08lx R3 : %08lx\n", | ||
646 | fp->r0, fp->r1, fp->r2, fp->r3); | 699 | fp->r0, fp->r1, fp->r2, fp->r3); |
647 | printk(KERN_EMERG "R4: %08lx R5: %08lx R6: %08lx R7: %08lx\n", | 700 | printk(KERN_NOTICE " R4 : %08lx R5 : %08lx R6 : %08lx R7 : %08lx\n", |
648 | fp->r4, fp->r5, fp->r6, fp->r7); | 701 | fp->r4, fp->r5, fp->r6, fp->r7); |
649 | printk(KERN_EMERG "P0: %08lx P1: %08lx P2: %08lx P3: %08lx\n", | 702 | printk(KERN_NOTICE " P0 : %08lx P1 : %08lx P2 : %08lx P3 : %08lx\n", |
650 | fp->p0, fp->p1, fp->p2, fp->p3); | 703 | fp->p0, fp->p1, fp->p2, fp->p3); |
651 | printk(KERN_EMERG | 704 | printk(KERN_NOTICE " P4 : %08lx P5 : %08lx FP : %08lx SP : %08lx\n", |
652 | "P4: %08lx P5: %08lx FP: %08lx\n", | 705 | fp->p4, fp->p5, fp->fp, (long)fp); |
653 | fp->p4, fp->p5, fp->fp); | 706 | printk(KERN_NOTICE " LB0: %08lx LT0: %08lx LC0: %08lx\n", |
654 | printk(KERN_EMERG | ||
655 | "A0.w: %08lx A0.x: %08lx A1.w: %08lx A1.x: %08lx\n", | ||
656 | fp->a0w, fp->a0x, fp->a1w, fp->a1x); | ||
657 | |||
658 | printk(KERN_EMERG "LB0: %08lx LT0: %08lx LC0: %08lx\n", | ||
659 | fp->lb0, fp->lt0, fp->lc0); | 707 | fp->lb0, fp->lt0, fp->lc0); |
660 | printk(KERN_EMERG "LB1: %08lx LT1: %08lx LC1: %08lx\n", | 708 | printk(KERN_NOTICE " LB1: %08lx LT1: %08lx LC1: %08lx\n", |
661 | fp->lb1, fp->lt1, fp->lc1); | 709 | fp->lb1, fp->lt1, fp->lc1); |
662 | printk(KERN_EMERG "B0: %08lx L0: %08lx M0: %08lx I0: %08lx\n", | 710 | printk(KERN_NOTICE " B0 : %08lx L0 : %08lx M0 : %08lx I0 : %08lx\n", |
663 | fp->b0, fp->l0, fp->m0, fp->i0); | 711 | fp->b0, fp->l0, fp->m0, fp->i0); |
664 | printk(KERN_EMERG "B1: %08lx L1: %08lx M1: %08lx I1: %08lx\n", | 712 | printk(KERN_NOTICE " B1 : %08lx L1 : %08lx M1 : %08lx I1 : %08lx\n", |
665 | fp->b1, fp->l1, fp->m1, fp->i1); | 713 | fp->b1, fp->l1, fp->m1, fp->i1); |
666 | printk(KERN_EMERG "B2: %08lx L2: %08lx M2: %08lx I2: %08lx\n", | 714 | printk(KERN_NOTICE " B2 : %08lx L2 : %08lx M2 : %08lx I2 : %08lx\n", |
667 | fp->b2, fp->l2, fp->m2, fp->i2); | 715 | fp->b2, fp->l2, fp->m2, fp->i2); |
668 | printk(KERN_EMERG "B3: %08lx L3: %08lx M3: %08lx I3: %08lx\n", | 716 | printk(KERN_NOTICE " B3 : %08lx L3 : %08lx M3 : %08lx I3 : %08lx\n", |
669 | fp->b3, fp->l3, fp->m3, fp->i3); | 717 | fp->b3, fp->l3, fp->m3, fp->i3); |
718 | printk(KERN_NOTICE "A0.w: %08lx A0.x: %08lx A1.w: %08lx A1.x: %08lx\n", | ||
719 | fp->a0w, fp->a0x, fp->a1w, fp->a1x); | ||
670 | 720 | ||
671 | printk(KERN_EMERG "\n" KERN_EMERG "USP: %08lx ASTAT: %08lx\n", | 721 | printk(KERN_NOTICE "USP : %08lx ASTAT: %08lx\n", |
672 | rdusp(), fp->astat); | 722 | rdusp(), fp->astat); |
673 | if ((long)fp->seqstat & SEQSTAT_EXCAUSE) { | ||
674 | printk(KERN_EMERG "DCPLB_FAULT_ADDR=%p\n", | ||
675 | (void *)bfin_read_DCPLB_FAULT_ADDR()); | ||
676 | printk(KERN_EMERG "ICPLB_FAULT_ADDR=%p\n", | ||
677 | (void *)bfin_read_ICPLB_FAULT_ADDR()); | ||
678 | } | ||
679 | 723 | ||
680 | printk("\n\n"); | 724 | printk(KERN_NOTICE "\n"); |
681 | } | 725 | } |
682 | 726 | ||
683 | #ifdef CONFIG_SYS_BFIN_SPINLOCK_L1 | 727 | #ifdef CONFIG_SYS_BFIN_SPINLOCK_L1 |
@@ -752,6 +796,8 @@ void panic_cplb_error(int cplb_panic, struct pt_regs *fp) | |||
752 | break; | 796 | break; |
753 | } | 797 | } |
754 | 798 | ||
799 | oops_in_progress = 1; | ||
800 | |||
755 | printk(KERN_EMERG "DCPLB_FAULT_ADDR=%p\n", (void *)bfin_read_DCPLB_FAULT_ADDR()); | 801 | printk(KERN_EMERG "DCPLB_FAULT_ADDR=%p\n", (void *)bfin_read_DCPLB_FAULT_ADDR()); |
756 | printk(KERN_EMERG "ICPLB_FAULT_ADDR=%p\n", (void *)bfin_read_ICPLB_FAULT_ADDR()); | 802 | printk(KERN_EMERG "ICPLB_FAULT_ADDR=%p\n", (void *)bfin_read_ICPLB_FAULT_ADDR()); |
757 | dump_bfin_regs(fp, (void *)fp->retx); | 803 | dump_bfin_regs(fp, (void *)fp->retx); |
diff --git a/arch/blackfin/kernel/vmlinux.lds.S b/arch/blackfin/kernel/vmlinux.lds.S index eec43674a465..9b75bc83c71f 100644 --- a/arch/blackfin/kernel/vmlinux.lds.S +++ b/arch/blackfin/kernel/vmlinux.lds.S | |||
@@ -172,9 +172,14 @@ SECTIONS | |||
172 | __ebss_b_l1 = .; | 172 | __ebss_b_l1 = .; |
173 | } | 173 | } |
174 | 174 | ||
175 | ___init_end = LOADADDR(.data_b_l1) + SIZEOF(.data_b_l1); | 175 | /* Force trailing alignment of our init section so that when we |
176 | 176 | * free our init memory, we don't leave behind a partial page. | |
177 | .bss LOADADDR(.data_b_l1) + SIZEOF(.data_b_l1) : | 177 | */ |
178 | . = LOADADDR(.data_b_l1) + SIZEOF(.data_b_l1); | ||
179 | . = ALIGN(PAGE_SIZE); | ||
180 | ___init_end = .; | ||
181 | |||
182 | .bss : | ||
178 | { | 183 | { |
179 | . = ALIGN(4); | 184 | . = ALIGN(4); |
180 | ___bss_start = .; | 185 | ___bss_start = .; |
diff --git a/arch/blackfin/mach-bf527/boards/ezkit.c b/arch/blackfin/mach-bf527/boards/ezkit.c index 3e884f3a8182..bf1bedcc8868 100644 --- a/arch/blackfin/mach-bf527/boards/ezkit.c +++ b/arch/blackfin/mach-bf527/boards/ezkit.c | |||
@@ -41,9 +41,11 @@ | |||
41 | #include <linux/irq.h> | 41 | #include <linux/irq.h> |
42 | #include <linux/interrupt.h> | 42 | #include <linux/interrupt.h> |
43 | #include <linux/usb_sl811.h> | 43 | #include <linux/usb_sl811.h> |
44 | #include <asm/cplb.h> | ||
44 | #include <asm/dma.h> | 45 | #include <asm/dma.h> |
45 | #include <asm/bfin5xx_spi.h> | 46 | #include <asm/bfin5xx_spi.h> |
46 | #include <asm/reboot.h> | 47 | #include <asm/reboot.h> |
48 | #include <asm/nand.h> | ||
47 | #include <linux/spi/ad7877.h> | 49 | #include <linux/spi/ad7877.h> |
48 | 50 | ||
49 | /* | 51 | /* |
@@ -102,6 +104,53 @@ void __exit bfin_isp1761_exit(void) | |||
102 | arch_initcall(bfin_isp1761_init); | 104 | arch_initcall(bfin_isp1761_init); |
103 | #endif | 105 | #endif |
104 | 106 | ||
107 | #if defined(CONFIG_MTD_NAND_BF5XX) || defined(CONFIG_MTD_NAND_BF5XX_MODULE) | ||
108 | static struct mtd_partition partition_info[] = { | ||
109 | { | ||
110 | .name = "Linux Kernel", | ||
111 | .offset = 0, | ||
112 | .size = 4 * SIZE_1M, | ||
113 | }, | ||
114 | { | ||
115 | .name = "File System", | ||
116 | .offset = 4 * SIZE_1M, | ||
117 | .size = (256 - 4) * SIZE_1M, | ||
118 | }, | ||
119 | }; | ||
120 | |||
121 | static struct bf5xx_nand_platform bf5xx_nand_platform = { | ||
122 | .page_size = NFC_PG_SIZE_256, | ||
123 | .data_width = NFC_NWIDTH_8, | ||
124 | .partitions = partition_info, | ||
125 | .nr_partitions = ARRAY_SIZE(partition_info), | ||
126 | .rd_dly = 3, | ||
127 | .wr_dly = 3, | ||
128 | }; | ||
129 | |||
130 | static struct resource bf5xx_nand_resources[] = { | ||
131 | { | ||
132 | .start = NFC_CTL, | ||
133 | .end = NFC_DATA_RD + 2, | ||
134 | .flags = IORESOURCE_MEM, | ||
135 | }, | ||
136 | { | ||
137 | .start = CH_NFC, | ||
138 | .end = CH_NFC, | ||
139 | .flags = IORESOURCE_IRQ, | ||
140 | }, | ||
141 | }; | ||
142 | |||
143 | static struct platform_device bf5xx_nand_device = { | ||
144 | .name = "bf5xx-nand", | ||
145 | .id = 0, | ||
146 | .num_resources = ARRAY_SIZE(bf5xx_nand_resources), | ||
147 | .resource = bf5xx_nand_resources, | ||
148 | .dev = { | ||
149 | .platform_data = &bf5xx_nand_platform, | ||
150 | }, | ||
151 | }; | ||
152 | #endif | ||
153 | |||
105 | #if defined(CONFIG_BFIN_CFPCMCIA) || defined(CONFIG_BFIN_CFPCMCIA_MODULE) | 154 | #if defined(CONFIG_BFIN_CFPCMCIA) || defined(CONFIG_BFIN_CFPCMCIA_MODULE) |
106 | static struct resource bfin_pcmcia_cf_resources[] = { | 155 | static struct resource bfin_pcmcia_cf_resources[] = { |
107 | { | 156 | { |
@@ -650,6 +699,10 @@ static struct platform_device bfin_pata_device = { | |||
650 | #endif | 699 | #endif |
651 | 700 | ||
652 | static struct platform_device *stamp_devices[] __initdata = { | 701 | static struct platform_device *stamp_devices[] __initdata = { |
702 | #if defined(CONFIG_MTD_NAND_BF5XX) || defined(CONFIG_MTD_NAND_BF5XX_MODULE) | ||
703 | &bf5xx_nand_device, | ||
704 | #endif | ||
705 | |||
653 | #if defined(CONFIG_BFIN_CFPCMCIA) || defined(CONFIG_BFIN_CFPCMCIA_MODULE) | 706 | #if defined(CONFIG_BFIN_CFPCMCIA) || defined(CONFIG_BFIN_CFPCMCIA_MODULE) |
654 | &bfin_pcmcia_cf_device, | 707 | &bfin_pcmcia_cf_device, |
655 | #endif | 708 | #endif |
diff --git a/arch/blackfin/mach-bf533/boards/H8606.c b/arch/blackfin/mach-bf533/boards/H8606.c new file mode 100644 index 000000000000..b941550f9568 --- /dev/null +++ b/arch/blackfin/mach-bf533/boards/H8606.c | |||
@@ -0,0 +1,345 @@ | |||
1 | /* | ||
2 | * File: arch/blackfin/mach-bf533/H8606.c | ||
3 | * Based on: arch/blackfin/mach-bf533/stamp.c | ||
4 | * Author: Javier Herrero <jherrero@hvsistemas.es> | ||
5 | * | ||
6 | * Created: 2007 | ||
7 | * Description: Board Info File for the HV Sistemas H8606 board | ||
8 | * | ||
9 | * Modified: | ||
10 | * Copyright 2005 National ICT Australia (NICTA) | ||
11 | * Copyright 2004-2006 Analog Devices Inc | ||
12 | * Copyright 2007 HV Sistemas S.L. | ||
13 | * | ||
14 | * Bugs: Enter bugs at http://blackfin.uclinux.org/ | ||
15 | * | ||
16 | * This program is free software; you can redistribute it and/or modify | ||
17 | * it under the terms of the GNU General Public License as published by | ||
18 | * the Free Software Foundation; either version 2 of the License, or | ||
19 | * (at your option) any later version. | ||
20 | * | ||
21 | * This program is distributed in the hope that it will be useful, | ||
22 | * but WITHOUT ANY WARRANTY; without even the implied warranty of | ||
23 | * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the | ||
24 | * GNU General Public License for more details. | ||
25 | * | ||
26 | * You should have received a copy of the GNU General Public License | ||
27 | * along with this program; if not, see the file COPYING, or write | ||
28 | * to the Free Software Foundation, Inc., | ||
29 | * 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA | ||
30 | */ | ||
31 | |||
32 | #include <linux/device.h> | ||
33 | #include <linux/platform_device.h> | ||
34 | #include <linux/mtd/mtd.h> | ||
35 | #include <linux/mtd/partitions.h> | ||
36 | #include <linux/spi/spi.h> | ||
37 | #include <linux/spi/flash.h> | ||
38 | #if defined(CONFIG_USB_ISP1362_HCD) || defined(CONFIG_USB_ISP1362_HCD_MODULE) | ||
39 | #include <linux/usb_isp1362.h> | ||
40 | #endif | ||
41 | #include <linux/pata_platform.h> | ||
42 | #include <linux/irq.h> | ||
43 | #include <asm/dma.h> | ||
44 | #include <asm/bfin5xx_spi.h> | ||
45 | #include <asm/reboot.h> | ||
46 | |||
47 | /* | ||
48 | * Name the Board for the /proc/cpuinfo | ||
49 | */ | ||
50 | const char bfin_board_name[] = "HV Sistemas H8606"; | ||
51 | |||
52 | #if defined(CONFIG_RTC_DRV_BFIN) || defined(CONFIG_RTC_BFIN_MODULE) | ||
53 | static struct platform_device rtc_device = { | ||
54 | .name = "rtc-bfin", | ||
55 | .id = -1, | ||
56 | }; | ||
57 | #endif | ||
58 | |||
59 | /* | ||
60 | * Driver needs to know address, irq and flag pin. | ||
61 | */ | ||
62 | #if defined(CONFIG_DM9000) || defined(CONFIG_DM9000_MODULE) | ||
63 | static struct resource dm9000_resources[] = { | ||
64 | [0] = { | ||
65 | .start = 0x20300000, | ||
66 | .end = 0x20300000 + 8, | ||
67 | .flags = IORESOURCE_MEM, | ||
68 | }, | ||
69 | [1] = { | ||
70 | .start = IRQ_PF10, | ||
71 | .end = IRQ_PF10, | ||
72 | .flags = (IORESOURCE_IRQ | IORESOURCE_IRQ_HIGHEDGE), | ||
73 | }, | ||
74 | }; | ||
75 | |||
76 | static struct platform_device dm9000_device = { | ||
77 | .id = 0, | ||
78 | .name = "dm9000", | ||
79 | .resource = dm9000_resources, | ||
80 | .num_resources = ARRAY_SIZE(dm9000_resources), | ||
81 | }; | ||
82 | #endif | ||
83 | |||
84 | #if defined(CONFIG_SMC91X) || defined(CONFIG_SMC91X_MODULE) | ||
85 | static struct resource smc91x_resources[] = { | ||
86 | { | ||
87 | .name = "smc91x-regs", | ||
88 | .start = 0x20300300, | ||
89 | .end = 0x20300300 + 16, | ||
90 | .flags = IORESOURCE_MEM, | ||
91 | }, { | ||
92 | .start = IRQ_PROG_INTB, | ||
93 | .end = IRQ_PROG_INTB, | ||
94 | .flags = IORESOURCE_IRQ | IORESOURCE_IRQ_HIGHLEVEL, | ||
95 | }, { | ||
96 | /* | ||
97 | * denotes the flag pin and is used directly if | ||
98 | * CONFIG_IRQCHIP_DEMUX_GPIO is defined. | ||
99 | */ | ||
100 | .start = IRQ_PF7, | ||
101 | .end = IRQ_PF7, | ||
102 | .flags = IORESOURCE_IRQ | IORESOURCE_IRQ_HIGHLEVEL, | ||
103 | }, | ||
104 | }; | ||
105 | |||
106 | static struct platform_device smc91x_device = { | ||
107 | .name = "smc91x", | ||
108 | .id = 0, | ||
109 | .num_resources = ARRAY_SIZE(smc91x_resources), | ||
110 | .resource = smc91x_resources, | ||
111 | }; | ||
112 | #endif | ||
113 | |||
114 | #if defined(CONFIG_USB_NET2272) || defined(CONFIG_USB_NET2272_MODULE) | ||
115 | static struct resource net2272_bfin_resources[] = { | ||
116 | { | ||
117 | .start = 0x20300000, | ||
118 | .end = 0x20300000 + 0x100, | ||
119 | .flags = IORESOURCE_MEM, | ||
120 | }, { | ||
121 | .start = IRQ_PF10, | ||
122 | .end = IRQ_PF10, | ||
123 | .flags = IORESOURCE_IRQ | IORESOURCE_IRQ_HIGHLEVEL, | ||
124 | }, | ||
125 | }; | ||
126 | |||
127 | static struct platform_device net2272_bfin_device = { | ||
128 | .name = "net2272", | ||
129 | .id = -1, | ||
130 | .num_resources = ARRAY_SIZE(net2272_bfin_resources), | ||
131 | .resource = net2272_bfin_resources, | ||
132 | }; | ||
133 | #endif | ||
134 | |||
135 | #if defined(CONFIG_SPI_BFIN) || defined(CONFIG_SPI_BFIN_MODULE) | ||
136 | /* all SPI peripherals info goes here */ | ||
137 | |||
138 | #if defined(CONFIG_MTD_M25P80) || defined(CONFIG_MTD_M25P80_MODULE) | ||
139 | static struct mtd_partition bfin_spi_flash_partitions[] = { | ||
140 | { | ||
141 | .name = "bootloader", | ||
142 | .size = 0x00060000, | ||
143 | .offset = 0, | ||
144 | .mask_flags = MTD_CAP_ROM | ||
145 | }, { | ||
146 | .name = "kernel", | ||
147 | .size = 0x100000, | ||
148 | .offset = 0x60000 | ||
149 | }, { | ||
150 | .name = "file system", | ||
151 | .size = 0x6a0000, | ||
152 | .offset = 0x00160000, | ||
153 | } | ||
154 | }; | ||
155 | |||
156 | static struct flash_platform_data bfin_spi_flash_data = { | ||
157 | .name = "m25p80", | ||
158 | .parts = bfin_spi_flash_partitions, | ||
159 | .nr_parts = ARRAY_SIZE(bfin_spi_flash_partitions), | ||
160 | .type = "m25p64", | ||
161 | }; | ||
162 | |||
163 | /* SPI flash chip (m25p64) */ | ||
164 | static struct bfin5xx_spi_chip spi_flash_chip_info = { | ||
165 | .enable_dma = 0, /* use dma transfer with this chip*/ | ||
166 | .bits_per_word = 8, | ||
167 | }; | ||
168 | #endif | ||
169 | |||
170 | #if defined(CONFIG_SPI_ADC_BF533) || defined(CONFIG_SPI_ADC_BF533_MODULE) | ||
171 | /* SPI ADC chip */ | ||
172 | static struct bfin5xx_spi_chip spi_adc_chip_info = { | ||
173 | .ctl_reg = 0x1000, | ||
174 | .enable_dma = 1, /* use dma transfer with this chip*/ | ||
175 | .bits_per_word = 16, | ||
176 | }; | ||
177 | #endif | ||
178 | |||
179 | #if defined(CONFIG_SND_BLACKFIN_AD1836) || defined(CONFIG_SND_BLACKFIN_AD1836_MODULE) | ||
180 | static struct bfin5xx_spi_chip ad1836_spi_chip_info = { | ||
181 | .ctl_reg = 0x1000, | ||
182 | .enable_dma = 0, | ||
183 | .bits_per_word = 16, | ||
184 | }; | ||
185 | #endif | ||
186 | |||
187 | #if defined(CONFIG_PBX) | ||
188 | static struct bfin5xx_spi_chip spi_si3xxx_chip_info = { | ||
189 | .ctl_reg = 0x1c04, | ||
190 | .enable_dma = 0, | ||
191 | .bits_per_word = 8, | ||
192 | .cs_change_per_word = 1, | ||
193 | }; | ||
194 | #endif | ||
195 | |||
196 | /* Notice: for blackfin, the speed_hz is the value of register | ||
197 | * SPI_BAUD, not the real baudrate */ | ||
198 | static struct spi_board_info bfin_spi_board_info[] __initdata = { | ||
199 | #if defined(CONFIG_MTD_M25P80) || defined(CONFIG_MTD_M25P80_MODULE) | ||
200 | { | ||
201 | /* the modalias must be the same as spi device driver name */ | ||
202 | .modalias = "m25p80", /* Name of spi_driver for this device */ | ||
203 | /* this value is the baudrate divisor */ | ||
204 | .max_speed_hz = 50000000, /* actual baudrate is SCLK/(2xspeed_hz) */ | ||
205 | .bus_num = 0, /* Framework bus number */ | ||
206 | .chip_select = 2, /* Framework chip select. On STAMP537 it is SPISSEL2*/ | ||
207 | .platform_data = &bfin_spi_flash_data, | ||
208 | .controller_data = &spi_flash_chip_info, | ||
209 | .mode = SPI_MODE_3, | ||
210 | }, | ||
211 | #endif | ||
212 | |||
213 | #if defined(CONFIG_SPI_ADC_BF533) || defined(CONFIG_SPI_ADC_BF533_MODULE) | ||
214 | { | ||
215 | .modalias = "bfin_spi_adc", /* Name of spi_driver for this device */ | ||
216 | .max_speed_hz = 4, /* actual baudrate is SCLK/(2xspeed_hz) */ | ||
217 | .bus_num = 1, /* Framework bus number */ | ||
218 | .chip_select = 1, /* Framework chip select. */ | ||
219 | .platform_data = NULL, /* No spi_driver specific config */ | ||
220 | .controller_data = &spi_adc_chip_info, | ||
221 | }, | ||
222 | #endif | ||
223 | |||
224 | #if defined(CONFIG_SND_BLACKFIN_AD1836) || defined(CONFIG_SND_BLACKFIN_AD1836_MODULE) | ||
225 | { | ||
226 | .modalias = "ad1836-spi", | ||
227 | .max_speed_hz = 16, | ||
228 | .bus_num = 1, | ||
229 | .chip_select = CONFIG_SND_BLACKFIN_SPI_PFBIT, | ||
230 | .controller_data = &ad1836_spi_chip_info, | ||
231 | }, | ||
232 | #endif | ||
233 | |||
234 | #if defined(CONFIG_PBX) | ||
235 | { | ||
236 | .modalias = "fxs-spi", | ||
237 | .max_speed_hz = 4, | ||
238 | .bus_num = 1, | ||
239 | .chip_select = 3, | ||
240 | .controller_data = &spi_si3xxx_chip_info, | ||
241 | }, | ||
242 | |||
243 | { | ||
244 | .modalias = "fxo-spi", | ||
245 | .max_speed_hz = 4, | ||
246 | .bus_num = 1, | ||
247 | .chip_select = 2, | ||
248 | .controller_data = &spi_si3xxx_chip_info, | ||
249 | }, | ||
250 | #endif | ||
251 | }; | ||
252 | |||
253 | /* SPI (0) */ | ||
254 | static struct resource bfin_spi0_resource[] = { | ||
255 | [0] = { | ||
256 | .start = SPI0_REGBASE, | ||
257 | .end = SPI0_REGBASE + 0xFF, | ||
258 | .flags = IORESOURCE_MEM, | ||
259 | }, | ||
260 | [1] = { | ||
261 | .start = CH_SPI, | ||
262 | .end = CH_SPI, | ||
263 | .flags = IORESOURCE_IRQ, | ||
264 | } | ||
265 | }; | ||
266 | |||
267 | |||
268 | /* SPI controller data */ | ||
269 | static struct bfin5xx_spi_master bfin_spi0_info = { | ||
270 | .num_chipselect = 8, | ||
271 | .enable_dma = 1, /* master has the ability to do dma transfer */ | ||
272 | }; | ||
273 | |||
274 | static struct platform_device bfin_spi0_device = { | ||
275 | .name = "bfin-spi", | ||
276 | .id = 0, /* Bus number */ | ||
277 | .num_resources = ARRAY_SIZE(bfin_spi0_resource), | ||
278 | .resource = bfin_spi0_resource, | ||
279 | .dev = { | ||
280 | .platform_data = &bfin_spi0_info, /* Passed to driver */ | ||
281 | }, | ||
282 | }; | ||
283 | #endif /* spi master and devices */ | ||
284 | |||
285 | #if defined(CONFIG_FB_BF537_LQ035) || defined(CONFIG_FB_BF537_LQ035_MODULE) | ||
286 | static struct platform_device bfin_fb_device = { | ||
287 | .name = "bf537-fb", | ||
288 | }; | ||
289 | #endif | ||
290 | |||
291 | #if defined(CONFIG_SERIAL_BFIN) || defined(CONFIG_SERIAL_BFIN_MODULE) | ||
292 | static struct resource bfin_uart_resources[] = { | ||
293 | { | ||
294 | .start = 0xFFC00400, | ||
295 | .end = 0xFFC004FF, | ||
296 | .flags = IORESOURCE_MEM, | ||
297 | }, | ||
298 | }; | ||
299 | |||
300 | static struct platform_device bfin_uart_device = { | ||
301 | .name = "bfin-uart", | ||
302 | .id = 1, | ||
303 | .num_resources = ARRAY_SIZE(bfin_uart_resources), | ||
304 | .resource = bfin_uart_resources, | ||
305 | }; | ||
306 | #endif | ||
307 | |||
308 | static struct platform_device *stamp_devices[] __initdata = { | ||
309 | #if defined(CONFIG_RTC_DRV_BFIN) || defined(CONFIG_RTC_DRV_BFIN_MODULE) | ||
310 | &rtc_device, | ||
311 | #endif | ||
312 | |||
313 | #if defined(CONFIG_DM9000) || defined(CONFIG_DM9000_MODULE) | ||
314 | &dm9000_device, | ||
315 | #endif | ||
316 | |||
317 | #if defined(CONFIG_SMC91X) || defined(CONFIG_SMC91X_MODULE) | ||
318 | &smc91x_device, | ||
319 | #endif | ||
320 | |||
321 | #if defined(CONFIG_USB_NET2272) || defined(CONFIG_USB_NET2272_MODULE) | ||
322 | &net2272_bfin_device, | ||
323 | #endif | ||
324 | |||
325 | #if defined(CONFIG_SPI_BFIN) || defined(CONFIG_SPI_BFIN_MODULE) | ||
326 | &bfin_spi0_device, | ||
327 | #endif | ||
328 | |||
329 | #if defined(CONFIG_SERIAL_BFIN) || defined(CONFIG_SERIAL_BFIN_MODULE) | ||
330 | &bfin_uart_device, | ||
331 | #endif | ||
332 | }; | ||
333 | |||
334 | static int __init H8606_init(void) | ||
335 | { | ||
336 | printk(KERN_INFO "HV Sistemas H8606 board support by http://www.hvsistemas.com\n"); | ||
337 | printk(KERN_INFO "%s(): registering device resources\n", __FUNCTION__); | ||
338 | platform_add_devices(stamp_devices, ARRAY_SIZE(stamp_devices)); | ||
339 | #if defined(CONFIG_SPI_BFIN) || defined(CONFIG_SPI_BFIN_MODULE) | ||
340 | spi_register_board_info(bfin_spi_board_info, ARRAY_SIZE(bfin_spi_board_info)); | ||
341 | #endif | ||
342 | return 0; | ||
343 | } | ||
344 | |||
345 | arch_initcall(H8606_init); \ No newline at end of file | ||
diff --git a/arch/blackfin/mach-bf533/boards/Makefile b/arch/blackfin/mach-bf533/boards/Makefile index 12a631ab389d..2452b456ccbd 100644 --- a/arch/blackfin/mach-bf533/boards/Makefile +++ b/arch/blackfin/mach-bf533/boards/Makefile | |||
@@ -6,3 +6,4 @@ obj-$(CONFIG_GENERIC_BOARD) += generic_board.o | |||
6 | obj-$(CONFIG_BFIN533_STAMP) += stamp.o | 6 | obj-$(CONFIG_BFIN533_STAMP) += stamp.o |
7 | obj-$(CONFIG_BFIN533_EZKIT) += ezkit.o | 7 | obj-$(CONFIG_BFIN533_EZKIT) += ezkit.o |
8 | obj-$(CONFIG_BFIN533_BLUETECHNIX_CM) += cm_bf533.o | 8 | obj-$(CONFIG_BFIN533_BLUETECHNIX_CM) += cm_bf533.o |
9 | obj-$(CONFIG_H8606_HVSISTEMAS) += H8606.o | ||
diff --git a/arch/blackfin/mach-bf533/boards/cm_bf533.c b/arch/blackfin/mach-bf533/boards/cm_bf533.c index 1c5a86adfab7..a863522a4467 100644 --- a/arch/blackfin/mach-bf533/boards/cm_bf533.c +++ b/arch/blackfin/mach-bf533/boards/cm_bf533.c | |||
@@ -46,7 +46,7 @@ const char bfin_board_name[] = "Bluetechnix CM BF533"; | |||
46 | 46 | ||
47 | #if defined(CONFIG_SPI_BFIN) || defined(CONFIG_SPI_BFIN_MODULE) | 47 | #if defined(CONFIG_SPI_BFIN) || defined(CONFIG_SPI_BFIN_MODULE) |
48 | /* all SPI peripherals info goes here */ | 48 | /* all SPI peripherals info goes here */ |
49 | 49 | #if defined(CONFIG_MTD_M25P80) || defined(CONFIG_MTD_M25P80_MODULE) | |
50 | static struct mtd_partition bfin_spi_flash_partitions[] = { | 50 | static struct mtd_partition bfin_spi_flash_partitions[] = { |
51 | { | 51 | { |
52 | .name = "bootloader", | 52 | .name = "bootloader", |
@@ -76,12 +76,15 @@ static struct bfin5xx_spi_chip spi_flash_chip_info = { | |||
76 | .enable_dma = 0, /* use dma transfer with this chip*/ | 76 | .enable_dma = 0, /* use dma transfer with this chip*/ |
77 | .bits_per_word = 8, | 77 | .bits_per_word = 8, |
78 | }; | 78 | }; |
79 | #endif | ||
79 | 80 | ||
80 | /* SPI ADC chip */ | 81 | /* SPI ADC chip */ |
82 | #if defined(CONFIG_SPI_ADC_BF533) || defined(CONFIG_SPI_ADC_BF533_MODULE) | ||
81 | static struct bfin5xx_spi_chip spi_adc_chip_info = { | 83 | static struct bfin5xx_spi_chip spi_adc_chip_info = { |
82 | .enable_dma = 1, /* use dma transfer with this chip*/ | 84 | .enable_dma = 1, /* use dma transfer with this chip*/ |
83 | .bits_per_word = 16, | 85 | .bits_per_word = 16, |
84 | }; | 86 | }; |
87 | #endif | ||
85 | 88 | ||
86 | #if defined(CONFIG_SND_BLACKFIN_AD1836) || defined(CONFIG_SND_BLACKFIN_AD1836_MODULE) | 89 | #if defined(CONFIG_SND_BLACKFIN_AD1836) || defined(CONFIG_SND_BLACKFIN_AD1836_MODULE) |
87 | static struct bfin5xx_spi_chip ad1836_spi_chip_info = { | 90 | static struct bfin5xx_spi_chip ad1836_spi_chip_info = { |
@@ -90,7 +93,15 @@ static struct bfin5xx_spi_chip ad1836_spi_chip_info = { | |||
90 | }; | 93 | }; |
91 | #endif | 94 | #endif |
92 | 95 | ||
96 | #if defined(CONFIG_SPI_MMC) || defined(CONFIG_SPI_MMC_MODULE) | ||
97 | static struct bfin5xx_spi_chip spi_mmc_chip_info = { | ||
98 | .enable_dma = 1, | ||
99 | .bits_per_word = 8, | ||
100 | }; | ||
101 | #endif | ||
102 | |||
93 | static struct spi_board_info bfin_spi_board_info[] __initdata = { | 103 | static struct spi_board_info bfin_spi_board_info[] __initdata = { |
104 | #if defined(CONFIG_MTD_M25P80) || defined(CONFIG_MTD_M25P80_MODULE) | ||
94 | { | 105 | { |
95 | /* the modalias must be the same as spi device driver name */ | 106 | /* the modalias must be the same as spi device driver name */ |
96 | .modalias = "m25p80", /* Name of spi_driver for this device */ | 107 | .modalias = "m25p80", /* Name of spi_driver for this device */ |
@@ -100,7 +111,11 @@ static struct spi_board_info bfin_spi_board_info[] __initdata = { | |||
100 | .platform_data = &bfin_spi_flash_data, | 111 | .platform_data = &bfin_spi_flash_data, |
101 | .controller_data = &spi_flash_chip_info, | 112 | .controller_data = &spi_flash_chip_info, |
102 | .mode = SPI_MODE_3, | 113 | .mode = SPI_MODE_3, |
103 | }, { | 114 | }, |
115 | #endif | ||
116 | |||
117 | #if defined(CONFIG_SPI_ADC_BF533) || defined(CONFIG_SPI_ADC_BF533_MODULE) | ||
118 | { | ||
104 | .modalias = "bfin_spi_adc", /* Name of spi_driver for this device */ | 119 | .modalias = "bfin_spi_adc", /* Name of spi_driver for this device */ |
105 | .max_speed_hz = 6250000, /* max spi clock (SCK) speed in HZ */ | 120 | .max_speed_hz = 6250000, /* max spi clock (SCK) speed in HZ */ |
106 | .bus_num = 0, /* Framework bus number */ | 121 | .bus_num = 0, /* Framework bus number */ |
@@ -108,6 +123,8 @@ static struct spi_board_info bfin_spi_board_info[] __initdata = { | |||
108 | .platform_data = NULL, /* No spi_driver specific config */ | 123 | .platform_data = NULL, /* No spi_driver specific config */ |
109 | .controller_data = &spi_adc_chip_info, | 124 | .controller_data = &spi_adc_chip_info, |
110 | }, | 125 | }, |
126 | #endif | ||
127 | |||
111 | #if defined(CONFIG_SND_BLACKFIN_AD1836) || defined(CONFIG_SND_BLACKFIN_AD1836_MODULE) | 128 | #if defined(CONFIG_SND_BLACKFIN_AD1836) || defined(CONFIG_SND_BLACKFIN_AD1836_MODULE) |
112 | { | 129 | { |
113 | .modalias = "ad1836-spi", | 130 | .modalias = "ad1836-spi", |
@@ -117,6 +134,27 @@ static struct spi_board_info bfin_spi_board_info[] __initdata = { | |||
117 | .controller_data = &ad1836_spi_chip_info, | 134 | .controller_data = &ad1836_spi_chip_info, |
118 | }, | 135 | }, |
119 | #endif | 136 | #endif |
137 | |||
138 | #if defined(CONFIG_SPI_MMC) || defined(CONFIG_SPI_MMC_MODULE) | ||
139 | { | ||
140 | .modalias = "spi_mmc_dummy", | ||
141 | .max_speed_hz = 25000000, /* max spi clock (SCK) speed in HZ */ | ||
142 | .bus_num = 0, | ||
143 | .chip_select = 0, | ||
144 | .platform_data = NULL, | ||
145 | .controller_data = &spi_mmc_chip_info, | ||
146 | .mode = SPI_MODE_3, | ||
147 | }, | ||
148 | { | ||
149 | .modalias = "spi_mmc", | ||
150 | .max_speed_hz = 25000000, /* max spi clock (SCK) speed in HZ */ | ||
151 | .bus_num = 0, | ||
152 | .chip_select = CONFIG_SPI_MMC_CS_CHAN, | ||
153 | .platform_data = NULL, | ||
154 | .controller_data = &spi_mmc_chip_info, | ||
155 | .mode = SPI_MODE_3, | ||
156 | }, | ||
157 | #endif | ||
120 | }; | 158 | }; |
121 | 159 | ||
122 | /* SPI (0) */ | 160 | /* SPI (0) */ |
diff --git a/arch/blackfin/mach-bf533/boards/stamp.c b/arch/blackfin/mach-bf533/boards/stamp.c index f84be4eabfd1..62ffa500420f 100644 --- a/arch/blackfin/mach-bf533/boards/stamp.c +++ b/arch/blackfin/mach-bf533/boards/stamp.c | |||
@@ -218,7 +218,7 @@ static struct spi_board_info bfin_spi_board_info[] __initdata = { | |||
218 | #if defined(CONFIG_SPI_MMC) || defined(CONFIG_SPI_MMC_MODULE) | 218 | #if defined(CONFIG_SPI_MMC) || defined(CONFIG_SPI_MMC_MODULE) |
219 | { | 219 | { |
220 | .modalias = "spi_mmc_dummy", | 220 | .modalias = "spi_mmc_dummy", |
221 | .max_speed_hz = 25000000, /* max spi clock (SCK) speed in HZ */ | 221 | .max_speed_hz = 20000000, /* max spi clock (SCK) speed in HZ */ |
222 | .bus_num = 0, | 222 | .bus_num = 0, |
223 | .chip_select = 0, | 223 | .chip_select = 0, |
224 | .platform_data = NULL, | 224 | .platform_data = NULL, |
@@ -227,7 +227,7 @@ static struct spi_board_info bfin_spi_board_info[] __initdata = { | |||
227 | }, | 227 | }, |
228 | { | 228 | { |
229 | .modalias = "spi_mmc", | 229 | .modalias = "spi_mmc", |
230 | .max_speed_hz = 25000000, /* max spi clock (SCK) speed in HZ */ | 230 | .max_speed_hz = 20000000, /* max spi clock (SCK) speed in HZ */ |
231 | .bus_num = 0, | 231 | .bus_num = 0, |
232 | .chip_select = CONFIG_SPI_MMC_CS_CHAN, | 232 | .chip_select = CONFIG_SPI_MMC_CS_CHAN, |
233 | .platform_data = NULL, | 233 | .platform_data = NULL, |
diff --git a/arch/blackfin/mach-bf537/boards/cm_bf537.c b/arch/blackfin/mach-bf537/boards/cm_bf537.c index 52e2320307de..2915931045e3 100644 --- a/arch/blackfin/mach-bf537/boards/cm_bf537.c +++ b/arch/blackfin/mach-bf537/boards/cm_bf537.c | |||
@@ -281,8 +281,8 @@ static struct resource net2272_bfin_resources[] = { | |||
281 | .end = 0x20200000 + 0x100, | 281 | .end = 0x20200000 + 0x100, |
282 | .flags = IORESOURCE_MEM, | 282 | .flags = IORESOURCE_MEM, |
283 | }, { | 283 | }, { |
284 | .start = IRQ_PF7, | 284 | .start = IRQ_PH14, |
285 | .end = IRQ_PF7, | 285 | .end = IRQ_PH14, |
286 | .flags = IORESOURCE_IRQ | IORESOURCE_IRQ_HIGHLEVEL, | 286 | .flags = IORESOURCE_IRQ | IORESOURCE_IRQ_HIGHLEVEL, |
287 | }, | 287 | }, |
288 | }; | 288 | }; |
diff --git a/arch/blackfin/mach-bf537/boards/stamp.c b/arch/blackfin/mach-bf537/boards/stamp.c index cc41f6c2ef4f..5f7b91fbafe8 100644 --- a/arch/blackfin/mach-bf537/boards/stamp.c +++ b/arch/blackfin/mach-bf537/boards/stamp.c | |||
@@ -450,7 +450,7 @@ static struct spi_board_info bfin_spi_board_info[] __initdata = { | |||
450 | #if defined(CONFIG_SPI_MMC) || defined(CONFIG_SPI_MMC_MODULE) | 450 | #if defined(CONFIG_SPI_MMC) || defined(CONFIG_SPI_MMC_MODULE) |
451 | { | 451 | { |
452 | .modalias = "spi_mmc_dummy", | 452 | .modalias = "spi_mmc_dummy", |
453 | .max_speed_hz = 25000000, /* max spi clock (SCK) speed in HZ */ | 453 | .max_speed_hz = 20000000, /* max spi clock (SCK) speed in HZ */ |
454 | .bus_num = 0, | 454 | .bus_num = 0, |
455 | .chip_select = 0, | 455 | .chip_select = 0, |
456 | .platform_data = NULL, | 456 | .platform_data = NULL, |
@@ -459,7 +459,7 @@ static struct spi_board_info bfin_spi_board_info[] __initdata = { | |||
459 | }, | 459 | }, |
460 | { | 460 | { |
461 | .modalias = "spi_mmc", | 461 | .modalias = "spi_mmc", |
462 | .max_speed_hz = 25000000, /* max spi clock (SCK) speed in HZ */ | 462 | .max_speed_hz = 20000000, /* max spi clock (SCK) speed in HZ */ |
463 | .bus_num = 0, | 463 | .bus_num = 0, |
464 | .chip_select = CONFIG_SPI_MMC_CS_CHAN, | 464 | .chip_select = CONFIG_SPI_MMC_CS_CHAN, |
465 | .platform_data = NULL, | 465 | .platform_data = NULL, |
@@ -612,7 +612,7 @@ static struct platform_device bfin_sport1_uart_device = { | |||
612 | 612 | ||
613 | static struct pata_platform_info bfin_pata_platform_data = { | 613 | static struct pata_platform_info bfin_pata_platform_data = { |
614 | .ioport_shift = 1, | 614 | .ioport_shift = 1, |
615 | .irq_type = IRQF_TRIGGER_HIGH | IRQF_DISABLED, | 615 | .irq_flags = IRQF_TRIGGER_HIGH | IRQF_DISABLED, |
616 | }; | 616 | }; |
617 | 617 | ||
618 | static struct resource bfin_pata_resources[] = { | 618 | static struct resource bfin_pata_resources[] = { |
diff --git a/arch/blackfin/mach-common/entry.S b/arch/blackfin/mach-common/entry.S index e3ad5802868a..1b13fa470977 100644 --- a/arch/blackfin/mach-common/entry.S +++ b/arch/blackfin/mach-common/entry.S | |||
@@ -917,7 +917,7 @@ ENTRY(_ex_table) | |||
917 | .long _ex_soft_bp /* 0x01 - User Defined - Software breakpoint */ | 917 | .long _ex_soft_bp /* 0x01 - User Defined - Software breakpoint */ |
918 | .long _ex_replaceable /* 0x02 - User Defined */ | 918 | .long _ex_replaceable /* 0x02 - User Defined */ |
919 | .long _ex_trap_c /* 0x03 - User Defined - userspace stack overflow */ | 919 | .long _ex_trap_c /* 0x03 - User Defined - userspace stack overflow */ |
920 | .long _ex_replaceable /* 0x04 - User Defined */ | 920 | .long _ex_trap_c /* 0x04 - User Defined - dump trace buffer */ |
921 | .long _ex_replaceable /* 0x05 - User Defined */ | 921 | .long _ex_replaceable /* 0x05 - User Defined */ |
922 | .long _ex_replaceable /* 0x06 - User Defined */ | 922 | .long _ex_replaceable /* 0x06 - User Defined */ |
923 | .long _ex_replaceable /* 0x07 - User Defined */ | 923 | .long _ex_replaceable /* 0x07 - User Defined */ |
diff --git a/arch/frv/mb93090-mb00/pci-dma.c b/arch/frv/mb93090-mb00/pci-dma.c index 671ce1e8434f..662f7b12d005 100644 --- a/arch/frv/mb93090-mb00/pci-dma.c +++ b/arch/frv/mb93090-mb00/pci-dma.c | |||
@@ -15,6 +15,7 @@ | |||
15 | #include <linux/list.h> | 15 | #include <linux/list.h> |
16 | #include <linux/pci.h> | 16 | #include <linux/pci.h> |
17 | #include <linux/highmem.h> | 17 | #include <linux/highmem.h> |
18 | #include <linux/scatterlist.h> | ||
18 | #include <asm/io.h> | 19 | #include <asm/io.h> |
19 | 20 | ||
20 | void *dma_alloc_coherent(struct device *hwdev, size_t size, dma_addr_t *dma_handle, gfp_t gfp) | 21 | void *dma_alloc_coherent(struct device *hwdev, size_t size, dma_addr_t *dma_handle, gfp_t gfp) |
@@ -86,7 +87,7 @@ int dma_map_sg(struct device *dev, struct scatterlist *sg, int nents, | |||
86 | dampr2 = __get_DAMPR(2); | 87 | dampr2 = __get_DAMPR(2); |
87 | 88 | ||
88 | for (i = 0; i < nents; i++) { | 89 | for (i = 0; i < nents; i++) { |
89 | vaddr = kmap_atomic(sg[i].page, __KM_CACHE); | 90 | vaddr = kmap_atomic(sg_page(&sg[i]), __KM_CACHE); |
90 | 91 | ||
91 | frv_dcache_writeback((unsigned long) vaddr, | 92 | frv_dcache_writeback((unsigned long) vaddr, |
92 | (unsigned long) vaddr + PAGE_SIZE); | 93 | (unsigned long) vaddr + PAGE_SIZE); |
diff --git a/arch/h8300/Kconfig b/arch/h8300/Kconfig index e2e9f57abe2e..ff6a8712bd6d 100644 --- a/arch/h8300/Kconfig +++ b/arch/h8300/Kconfig | |||
@@ -1,6 +1,6 @@ | |||
1 | # | 1 | # |
2 | # For a description of the syntax of this configuration file, | 2 | # For a description of the syntax of this configuration file, |
3 | # see Documentation/kbuild/config-language.txt. | 3 | # see Documentation/kbuild/kconfig-language.txt. |
4 | # | 4 | # |
5 | 5 | ||
6 | mainmenu "uClinux/h8300 (w/o MMU) Kernel Configuration" | 6 | mainmenu "uClinux/h8300 (w/o MMU) Kernel Configuration" |
diff --git a/arch/i386/.gitignore b/arch/i386/.gitignore deleted file mode 100644 index 36ef4c374d25..000000000000 --- a/arch/i386/.gitignore +++ /dev/null | |||
@@ -1 +0,0 @@ | |||
1 | boot | ||
diff --git a/arch/ia64/configs/sn2_defconfig b/arch/ia64/configs/sn2_defconfig index 75fd90dc76a3..7f6b2377d13f 100644 --- a/arch/ia64/configs/sn2_defconfig +++ b/arch/ia64/configs/sn2_defconfig | |||
@@ -1,7 +1,7 @@ | |||
1 | # | 1 | # |
2 | # Automatically generated make config: don't edit | 2 | # Automatically generated make config: don't edit |
3 | # Linux kernel version: 2.6.23-rc6 | 3 | # Linux kernel version: 2.6.23 |
4 | # Tue Sep 18 11:24:01 2007 | 4 | # Thu Oct 18 16:03:40 2007 |
5 | # | 5 | # |
6 | CONFIG_DEFCONFIG_LIST="/lib/modules/$UNAME_RELEASE/.config" | 6 | CONFIG_DEFCONFIG_LIST="/lib/modules/$UNAME_RELEASE/.config" |
7 | 7 | ||
@@ -28,6 +28,8 @@ CONFIG_TASK_IO_ACCOUNTING=y | |||
28 | CONFIG_LOG_BUF_SHIFT=20 | 28 | CONFIG_LOG_BUF_SHIFT=20 |
29 | CONFIG_CGROUPS=y | 29 | CONFIG_CGROUPS=y |
30 | CONFIG_CPUSETS=y | 30 | CONFIG_CPUSETS=y |
31 | CONFIG_FAIR_GROUP_SCHED=y | ||
32 | CONFIG_FAIR_USER_SCHED=y | ||
31 | CONFIG_SYSFS_DEPRECATED=y | 33 | CONFIG_SYSFS_DEPRECATED=y |
32 | CONFIG_RELAY=y | 34 | CONFIG_RELAY=y |
33 | CONFIG_BLK_DEV_INITRD=y | 35 | CONFIG_BLK_DEV_INITRD=y |
@@ -48,7 +50,6 @@ CONFIG_FUTEX=y | |||
48 | CONFIG_ANON_INODES=y | 50 | CONFIG_ANON_INODES=y |
49 | CONFIG_EPOLL=y | 51 | CONFIG_EPOLL=y |
50 | CONFIG_SIGNALFD=y | 52 | CONFIG_SIGNALFD=y |
51 | CONFIG_TIMERFD=y | ||
52 | CONFIG_EVENTFD=y | 53 | CONFIG_EVENTFD=y |
53 | CONFIG_SHMEM=y | 54 | CONFIG_SHMEM=y |
54 | CONFIG_VM_EVENT_COUNTERS=y | 55 | CONFIG_VM_EVENT_COUNTERS=y |
@@ -69,6 +70,7 @@ CONFIG_STOP_MACHINE=y | |||
69 | CONFIG_BLOCK=y | 70 | CONFIG_BLOCK=y |
70 | # CONFIG_BLK_DEV_IO_TRACE is not set | 71 | # CONFIG_BLK_DEV_IO_TRACE is not set |
71 | CONFIG_BLK_DEV_BSG=y | 72 | CONFIG_BLK_DEV_BSG=y |
73 | CONFIG_BLOCK_COMPAT=y | ||
72 | 74 | ||
73 | # | 75 | # |
74 | # IO Schedulers | 76 | # IO Schedulers |
@@ -93,6 +95,7 @@ CONFIG_MMU=y | |||
93 | CONFIG_RWSEM_XCHGADD_ALGORITHM=y | 95 | CONFIG_RWSEM_XCHGADD_ALGORITHM=y |
94 | # CONFIG_ARCH_HAS_ILOG2_U32 is not set | 96 | # CONFIG_ARCH_HAS_ILOG2_U32 is not set |
95 | # CONFIG_ARCH_HAS_ILOG2_U64 is not set | 97 | # CONFIG_ARCH_HAS_ILOG2_U64 is not set |
98 | CONFIG_HUGETLB_PAGE_SIZE_VARIABLE=y | ||
96 | CONFIG_GENERIC_FIND_NEXT_BIT=y | 99 | CONFIG_GENERIC_FIND_NEXT_BIT=y |
97 | CONFIG_GENERIC_CALIBRATE_DELAY=y | 100 | CONFIG_GENERIC_CALIBRATE_DELAY=y |
98 | CONFIG_GENERIC_TIME=y | 101 | CONFIG_GENERIC_TIME=y |
@@ -113,10 +116,10 @@ CONFIG_IA64_SGI_SN2=y | |||
113 | CONFIG_MCKINLEY=y | 116 | CONFIG_MCKINLEY=y |
114 | # CONFIG_IA64_PAGE_SIZE_4KB is not set | 117 | # CONFIG_IA64_PAGE_SIZE_4KB is not set |
115 | # CONFIG_IA64_PAGE_SIZE_8KB is not set | 118 | # CONFIG_IA64_PAGE_SIZE_8KB is not set |
116 | CONFIG_IA64_PAGE_SIZE_16KB=y | 119 | # CONFIG_IA64_PAGE_SIZE_16KB is not set |
117 | # CONFIG_IA64_PAGE_SIZE_64KB is not set | 120 | CONFIG_IA64_PAGE_SIZE_64KB=y |
118 | # CONFIG_PGTABLE_3 is not set | 121 | CONFIG_PGTABLE_3=y |
119 | CONFIG_PGTABLE_4=y | 122 | # CONFIG_PGTABLE_4 is not set |
120 | # CONFIG_HZ_100 is not set | 123 | # CONFIG_HZ_100 is not set |
121 | CONFIG_HZ_250=y | 124 | CONFIG_HZ_250=y |
122 | # CONFIG_HZ_300 is not set | 125 | # CONFIG_HZ_300 is not set |
@@ -131,6 +134,7 @@ CONFIG_SMP=y | |||
131 | CONFIG_NR_CPUS=1024 | 134 | CONFIG_NR_CPUS=1024 |
132 | # CONFIG_HOTPLUG_CPU is not set | 135 | # CONFIG_HOTPLUG_CPU is not set |
133 | CONFIG_ARCH_ENABLE_MEMORY_HOTPLUG=y | 136 | CONFIG_ARCH_ENABLE_MEMORY_HOTPLUG=y |
137 | CONFIG_ARCH_ENABLE_MEMORY_HOTREMOVE=y | ||
134 | CONFIG_SCHED_SMT=y | 138 | CONFIG_SCHED_SMT=y |
135 | CONFIG_PREEMPT_NONE=y | 139 | CONFIG_PREEMPT_NONE=y |
136 | # CONFIG_PREEMPT_VOLUNTARY is not set | 140 | # CONFIG_PREEMPT_VOLUNTARY is not set |
@@ -144,6 +148,7 @@ CONFIG_DISCONTIGMEM=y | |||
144 | CONFIG_FLAT_NODE_MEM_MAP=y | 148 | CONFIG_FLAT_NODE_MEM_MAP=y |
145 | CONFIG_NEED_MULTIPLE_NODES=y | 149 | CONFIG_NEED_MULTIPLE_NODES=y |
146 | # CONFIG_SPARSEMEM_STATIC is not set | 150 | # CONFIG_SPARSEMEM_STATIC is not set |
151 | CONFIG_SPARSEMEM_VMEMMAP_ENABLE=y | ||
147 | CONFIG_SPLIT_PTLOCK_CPUS=4 | 152 | CONFIG_SPLIT_PTLOCK_CPUS=4 |
148 | CONFIG_MIGRATION=y | 153 | CONFIG_MIGRATION=y |
149 | CONFIG_RESOURCES_64BIT=y | 154 | CONFIG_RESOURCES_64BIT=y |
@@ -171,6 +176,7 @@ CONFIG_IA64_PALINFO=y | |||
171 | CONFIG_IA64_MC_ERR_INJECT=y | 176 | CONFIG_IA64_MC_ERR_INJECT=y |
172 | CONFIG_SGI_SN=y | 177 | CONFIG_SGI_SN=y |
173 | # CONFIG_IA64_ESI is not set | 178 | # CONFIG_IA64_ESI is not set |
179 | # CONFIG_IA64_HP_AML_NFW is not set | ||
174 | 180 | ||
175 | # | 181 | # |
176 | # SN Devices | 182 | # SN Devices |
@@ -220,7 +226,6 @@ CONFIG_PCI_DOMAINS=y | |||
220 | CONFIG_PCI_SYSCALL=y | 226 | CONFIG_PCI_SYSCALL=y |
221 | CONFIG_PCIEPORTBUS=y | 227 | CONFIG_PCIEPORTBUS=y |
222 | CONFIG_HOTPLUG_PCI_PCIE=y | 228 | CONFIG_HOTPLUG_PCI_PCIE=y |
223 | # CONFIG_HOTPLUG_PCI_PCIE_POLL_EVENT_MODE is not set | ||
224 | CONFIG_PCIEAER=y | 229 | CONFIG_PCIEAER=y |
225 | CONFIG_ARCH_SUPPORTS_MSI=y | 230 | CONFIG_ARCH_SUPPORTS_MSI=y |
226 | # CONFIG_PCI_MSI is not set | 231 | # CONFIG_PCI_MSI is not set |
@@ -231,10 +236,6 @@ CONFIG_HOTPLUG_PCI=y | |||
231 | # CONFIG_HOTPLUG_PCI_CPCI is not set | 236 | # CONFIG_HOTPLUG_PCI_CPCI is not set |
232 | # CONFIG_HOTPLUG_PCI_SHPC is not set | 237 | # CONFIG_HOTPLUG_PCI_SHPC is not set |
233 | CONFIG_HOTPLUG_PCI_SGI=y | 238 | CONFIG_HOTPLUG_PCI_SGI=y |
234 | |||
235 | # | ||
236 | # PCCARD (PCMCIA/CardBus) support | ||
237 | # | ||
238 | # CONFIG_PCCARD is not set | 239 | # CONFIG_PCCARD is not set |
239 | 240 | ||
240 | # | 241 | # |
@@ -271,6 +272,7 @@ CONFIG_INET_TUNNEL=m | |||
271 | CONFIG_INET_XFRM_MODE_TRANSPORT=y | 272 | CONFIG_INET_XFRM_MODE_TRANSPORT=y |
272 | CONFIG_INET_XFRM_MODE_TUNNEL=y | 273 | CONFIG_INET_XFRM_MODE_TUNNEL=y |
273 | CONFIG_INET_XFRM_MODE_BEET=y | 274 | CONFIG_INET_XFRM_MODE_BEET=y |
275 | CONFIG_INET_LRO=y | ||
274 | CONFIG_INET_DIAG=m | 276 | CONFIG_INET_DIAG=m |
275 | CONFIG_INET_TCP_DIAG=m | 277 | CONFIG_INET_TCP_DIAG=m |
276 | # CONFIG_TCP_CONG_ADVANCED is not set | 278 | # CONFIG_TCP_CONG_ADVANCED is not set |
@@ -342,6 +344,7 @@ CONFIG_IPV6_SIT=m | |||
342 | # | 344 | # |
343 | # Generic Driver Options | 345 | # Generic Driver Options |
344 | # | 346 | # |
347 | CONFIG_UEVENT_HELPER_PATH="/sbin/hotplug" | ||
345 | CONFIG_STANDALONE=y | 348 | CONFIG_STANDALONE=y |
346 | CONFIG_PREVENT_FIRMWARE_BUILD=y | 349 | CONFIG_PREVENT_FIRMWARE_BUILD=y |
347 | CONFIG_FW_LOADER=y | 350 | CONFIG_FW_LOADER=y |
@@ -402,7 +405,12 @@ CONFIG_IDE_PROC_FS=y | |||
402 | # IDE chipset support/bugfixes | 405 | # IDE chipset support/bugfixes |
403 | # | 406 | # |
404 | CONFIG_IDE_GENERIC=y | 407 | CONFIG_IDE_GENERIC=y |
408 | # CONFIG_BLK_DEV_PLATFORM is not set | ||
405 | # CONFIG_BLK_DEV_IDEPNP is not set | 409 | # CONFIG_BLK_DEV_IDEPNP is not set |
410 | |||
411 | # | ||
412 | # PCI IDE chipsets support | ||
413 | # | ||
406 | CONFIG_BLK_DEV_IDEPCI=y | 414 | CONFIG_BLK_DEV_IDEPCI=y |
407 | CONFIG_IDEPCI_SHARE_IRQ=y | 415 | CONFIG_IDEPCI_SHARE_IRQ=y |
408 | CONFIG_IDEPCI_PCIBUS_ORDER=y | 416 | CONFIG_IDEPCI_PCIBUS_ORDER=y |
@@ -410,8 +418,6 @@ CONFIG_IDEPCI_PCIBUS_ORDER=y | |||
410 | # CONFIG_BLK_DEV_GENERIC is not set | 418 | # CONFIG_BLK_DEV_GENERIC is not set |
411 | # CONFIG_BLK_DEV_OPTI621 is not set | 419 | # CONFIG_BLK_DEV_OPTI621 is not set |
412 | CONFIG_BLK_DEV_IDEDMA_PCI=y | 420 | CONFIG_BLK_DEV_IDEDMA_PCI=y |
413 | # CONFIG_BLK_DEV_IDEDMA_FORCED is not set | ||
414 | # CONFIG_IDEDMA_ONLYDISK is not set | ||
415 | # CONFIG_BLK_DEV_AEC62XX is not set | 421 | # CONFIG_BLK_DEV_AEC62XX is not set |
416 | # CONFIG_BLK_DEV_ALI15X3 is not set | 422 | # CONFIG_BLK_DEV_ALI15X3 is not set |
417 | # CONFIG_BLK_DEV_AMD74XX is not set | 423 | # CONFIG_BLK_DEV_AMD74XX is not set |
@@ -439,7 +445,6 @@ CONFIG_BLK_DEV_SGIIOC4=y | |||
439 | # CONFIG_BLK_DEV_TC86C001 is not set | 445 | # CONFIG_BLK_DEV_TC86C001 is not set |
440 | # CONFIG_IDE_ARM is not set | 446 | # CONFIG_IDE_ARM is not set |
441 | CONFIG_BLK_DEV_IDEDMA=y | 447 | CONFIG_BLK_DEV_IDEDMA=y |
442 | # CONFIG_IDEDMA_IVB is not set | ||
443 | # CONFIG_BLK_DEV_HD is not set | 448 | # CONFIG_BLK_DEV_HD is not set |
444 | 449 | ||
445 | # | 450 | # |
@@ -482,6 +487,7 @@ CONFIG_SCSI_SAS_ATTRS=y | |||
482 | CONFIG_SCSI_SAS_LIBSAS=y | 487 | CONFIG_SCSI_SAS_LIBSAS=y |
483 | # CONFIG_SCSI_SAS_ATA is not set | 488 | # CONFIG_SCSI_SAS_ATA is not set |
484 | # CONFIG_SCSI_SAS_LIBSAS_DEBUG is not set | 489 | # CONFIG_SCSI_SAS_LIBSAS_DEBUG is not set |
490 | CONFIG_SCSI_SRP_ATTRS=y | ||
485 | CONFIG_SCSI_LOWLEVEL=y | 491 | CONFIG_SCSI_LOWLEVEL=y |
486 | CONFIG_ISCSI_TCP=m | 492 | CONFIG_ISCSI_TCP=m |
487 | # CONFIG_BLK_DEV_3W_XXXX_RAID is not set | 493 | # CONFIG_BLK_DEV_3W_XXXX_RAID is not set |
@@ -492,6 +498,7 @@ CONFIG_ISCSI_TCP=m | |||
492 | # CONFIG_SCSI_AIC7XXX_OLD is not set | 498 | # CONFIG_SCSI_AIC7XXX_OLD is not set |
493 | # CONFIG_SCSI_AIC79XX is not set | 499 | # CONFIG_SCSI_AIC79XX is not set |
494 | # CONFIG_SCSI_AIC94XX is not set | 500 | # CONFIG_SCSI_AIC94XX is not set |
501 | # CONFIG_SCSI_ADVANSYS is not set | ||
495 | # CONFIG_SCSI_ARCMSR is not set | 502 | # CONFIG_SCSI_ARCMSR is not set |
496 | # CONFIG_MEGARAID_NEWGEN is not set | 503 | # CONFIG_MEGARAID_NEWGEN is not set |
497 | # CONFIG_MEGARAID_LEGACY is not set | 504 | # CONFIG_MEGARAID_LEGACY is not set |
@@ -532,6 +539,7 @@ CONFIG_ATA_ACPI=y | |||
532 | # CONFIG_SATA_VIA is not set | 539 | # CONFIG_SATA_VIA is not set |
533 | CONFIG_SATA_VITESSE=y | 540 | CONFIG_SATA_VITESSE=y |
534 | # CONFIG_SATA_INIC162X is not set | 541 | # CONFIG_SATA_INIC162X is not set |
542 | # CONFIG_PATA_ACPI is not set | ||
535 | # CONFIG_PATA_ALI is not set | 543 | # CONFIG_PATA_ALI is not set |
536 | # CONFIG_PATA_AMD is not set | 544 | # CONFIG_PATA_AMD is not set |
537 | # CONFIG_PATA_ARTOP is not set | 545 | # CONFIG_PATA_ARTOP is not set |
@@ -556,6 +564,7 @@ CONFIG_SATA_VITESSE=y | |||
556 | # CONFIG_PATA_OLDPIIX is not set | 564 | # CONFIG_PATA_OLDPIIX is not set |
557 | # CONFIG_PATA_NETCELL is not set | 565 | # CONFIG_PATA_NETCELL is not set |
558 | # CONFIG_PATA_NS87410 is not set | 566 | # CONFIG_PATA_NS87410 is not set |
567 | # CONFIG_PATA_NS87415 is not set | ||
559 | # CONFIG_PATA_OPTI is not set | 568 | # CONFIG_PATA_OPTI is not set |
560 | # CONFIG_PATA_OPTIDMA is not set | 569 | # CONFIG_PATA_OPTIDMA is not set |
561 | # CONFIG_PATA_PDC_OLD is not set | 570 | # CONFIG_PATA_PDC_OLD is not set |
@@ -588,10 +597,6 @@ CONFIG_DM_MULTIPATH=m | |||
588 | CONFIG_DM_MULTIPATH_EMC=m | 597 | CONFIG_DM_MULTIPATH_EMC=m |
589 | # CONFIG_DM_MULTIPATH_RDAC is not set | 598 | # CONFIG_DM_MULTIPATH_RDAC is not set |
590 | # CONFIG_DM_DELAY is not set | 599 | # CONFIG_DM_DELAY is not set |
591 | |||
592 | # | ||
593 | # Fusion MPT device support | ||
594 | # | ||
595 | CONFIG_FUSION=y | 600 | CONFIG_FUSION=y |
596 | CONFIG_FUSION_SPI=y | 601 | CONFIG_FUSION_SPI=y |
597 | CONFIG_FUSION_FC=y | 602 | CONFIG_FUSION_FC=y |
@@ -613,13 +618,16 @@ CONFIG_NETDEVICES=y | |||
613 | # CONFIG_MACVLAN is not set | 618 | # CONFIG_MACVLAN is not set |
614 | # CONFIG_EQUALIZER is not set | 619 | # CONFIG_EQUALIZER is not set |
615 | # CONFIG_TUN is not set | 620 | # CONFIG_TUN is not set |
621 | # CONFIG_VETH is not set | ||
616 | # CONFIG_NET_SB1000 is not set | 622 | # CONFIG_NET_SB1000 is not set |
623 | # CONFIG_IP1000 is not set | ||
617 | # CONFIG_ARCNET is not set | 624 | # CONFIG_ARCNET is not set |
618 | # CONFIG_NET_ETHERNET is not set | 625 | # CONFIG_NET_ETHERNET is not set |
619 | CONFIG_NETDEV_1000=y | 626 | CONFIG_NETDEV_1000=y |
620 | # CONFIG_ACENIC is not set | 627 | # CONFIG_ACENIC is not set |
621 | # CONFIG_DL2K is not set | 628 | # CONFIG_DL2K is not set |
622 | # CONFIG_E1000 is not set | 629 | # CONFIG_E1000 is not set |
630 | # CONFIG_E1000E is not set | ||
623 | # CONFIG_NS83820 is not set | 631 | # CONFIG_NS83820 is not set |
624 | # CONFIG_HAMACHI is not set | 632 | # CONFIG_HAMACHI is not set |
625 | # CONFIG_YELLOWFIN is not set | 633 | # CONFIG_YELLOWFIN is not set |
@@ -638,12 +646,15 @@ CONFIG_CHELSIO_T1=m | |||
638 | CONFIG_CHELSIO_T1_1G=y | 646 | CONFIG_CHELSIO_T1_1G=y |
639 | # CONFIG_CHELSIO_T1_NAPI is not set | 647 | # CONFIG_CHELSIO_T1_NAPI is not set |
640 | CONFIG_CHELSIO_T3=m | 648 | CONFIG_CHELSIO_T3=m |
649 | CONFIG_IXGBE=m | ||
641 | # CONFIG_IXGB is not set | 650 | # CONFIG_IXGB is not set |
642 | CONFIG_S2IO=m | 651 | CONFIG_S2IO=m |
643 | # CONFIG_S2IO_NAPI is not set | 652 | # CONFIG_S2IO_NAPI is not set |
644 | # CONFIG_MYRI10GE is not set | 653 | # CONFIG_MYRI10GE is not set |
645 | # CONFIG_NETXEN_NIC is not set | 654 | # CONFIG_NETXEN_NIC is not set |
655 | # CONFIG_NIU is not set | ||
646 | # CONFIG_MLX4_CORE is not set | 656 | # CONFIG_MLX4_CORE is not set |
657 | # CONFIG_TEHUTI is not set | ||
647 | # CONFIG_TR is not set | 658 | # CONFIG_TR is not set |
648 | 659 | ||
649 | # | 660 | # |
@@ -669,6 +680,7 @@ CONFIG_S2IO=m | |||
669 | # CONFIG_NET_FC is not set | 680 | # CONFIG_NET_FC is not set |
670 | # CONFIG_SHAPER is not set | 681 | # CONFIG_SHAPER is not set |
671 | CONFIG_NETCONSOLE=y | 682 | CONFIG_NETCONSOLE=y |
683 | # CONFIG_NETCONSOLE_DYNAMIC is not set | ||
672 | CONFIG_NETPOLL=y | 684 | CONFIG_NETPOLL=y |
673 | # CONFIG_NETPOLL_TRAP is not set | 685 | # CONFIG_NETPOLL_TRAP is not set |
674 | CONFIG_NET_POLL_CONTROLLER=y | 686 | CONFIG_NET_POLL_CONTROLLER=y |
@@ -690,7 +702,6 @@ CONFIG_INPUT_MOUSEDEV=y | |||
690 | CONFIG_INPUT_MOUSEDEV_SCREEN_X=1024 | 702 | CONFIG_INPUT_MOUSEDEV_SCREEN_X=1024 |
691 | CONFIG_INPUT_MOUSEDEV_SCREEN_Y=768 | 703 | CONFIG_INPUT_MOUSEDEV_SCREEN_Y=768 |
692 | # CONFIG_INPUT_JOYDEV is not set | 704 | # CONFIG_INPUT_JOYDEV is not set |
693 | # CONFIG_INPUT_TSDEV is not set | ||
694 | # CONFIG_INPUT_EVDEV is not set | 705 | # CONFIG_INPUT_EVDEV is not set |
695 | # CONFIG_INPUT_EVBUG is not set | 706 | # CONFIG_INPUT_EVBUG is not set |
696 | 707 | ||
@@ -714,6 +725,7 @@ CONFIG_INPUT_MOUSEDEV_SCREEN_Y=768 | |||
714 | # Character devices | 725 | # Character devices |
715 | # | 726 | # |
716 | CONFIG_VT=y | 727 | CONFIG_VT=y |
728 | # CONFIG_VT_UNICODE is not set | ||
717 | CONFIG_VT_CONSOLE=y | 729 | CONFIG_VT_CONSOLE=y |
718 | CONFIG_HW_CONSOLE=y | 730 | CONFIG_HW_CONSOLE=y |
719 | # CONFIG_VT_HW_CONSOLE_BINDING is not set | 731 | # CONFIG_VT_HW_CONSOLE_BINDING is not set |
@@ -760,9 +772,6 @@ CONFIG_LEGACY_PTY_COUNT=256 | |||
760 | CONFIG_EFI_RTC=y | 772 | CONFIG_EFI_RTC=y |
761 | # CONFIG_R3964 is not set | 773 | # CONFIG_R3964 is not set |
762 | # CONFIG_APPLICOM is not set | 774 | # CONFIG_APPLICOM is not set |
763 | CONFIG_AGP=y | ||
764 | CONFIG_AGP_SGI_TIOCA=y | ||
765 | # CONFIG_DRM is not set | ||
766 | CONFIG_RAW_DRIVER=m | 775 | CONFIG_RAW_DRIVER=m |
767 | CONFIG_MAX_RAW_DEVS=256 | 776 | CONFIG_MAX_RAW_DEVS=256 |
768 | # CONFIG_HPET is not set | 777 | # CONFIG_HPET is not set |
@@ -782,6 +791,12 @@ CONFIG_DEVPORT=y | |||
782 | # CONFIG_HWMON is not set | 791 | # CONFIG_HWMON is not set |
783 | 792 | ||
784 | # | 793 | # |
794 | # Sonics Silicon Backplane | ||
795 | # | ||
796 | CONFIG_SSB_POSSIBLE=y | ||
797 | # CONFIG_SSB is not set | ||
798 | |||
799 | # | ||
785 | # Multifunction device drivers | 800 | # Multifunction device drivers |
786 | # | 801 | # |
787 | # CONFIG_MFD_SM501 is not set | 802 | # CONFIG_MFD_SM501 is not set |
@@ -796,15 +811,18 @@ CONFIG_DEVPORT=y | |||
796 | # | 811 | # |
797 | # Graphics support | 812 | # Graphics support |
798 | # | 813 | # |
814 | CONFIG_AGP=y | ||
815 | CONFIG_AGP_SGI_TIOCA=y | ||
816 | # CONFIG_DRM is not set | ||
817 | # CONFIG_VGASTATE is not set | ||
818 | CONFIG_VIDEO_OUTPUT_CONTROL=m | ||
819 | # CONFIG_FB is not set | ||
799 | # CONFIG_BACKLIGHT_LCD_SUPPORT is not set | 820 | # CONFIG_BACKLIGHT_LCD_SUPPORT is not set |
800 | 821 | ||
801 | # | 822 | # |
802 | # Display device support | 823 | # Display device support |
803 | # | 824 | # |
804 | # CONFIG_DISPLAY_SUPPORT is not set | 825 | # CONFIG_DISPLAY_SUPPORT is not set |
805 | # CONFIG_VGASTATE is not set | ||
806 | CONFIG_VIDEO_OUTPUT_CONTROL=m | ||
807 | # CONFIG_FB is not set | ||
808 | 826 | ||
809 | # | 827 | # |
810 | # Console display driver support | 828 | # Console display driver support |
@@ -820,6 +838,7 @@ CONFIG_DUMMY_CONSOLE=y | |||
820 | CONFIG_HID_SUPPORT=y | 838 | CONFIG_HID_SUPPORT=y |
821 | CONFIG_HID=y | 839 | CONFIG_HID=y |
822 | CONFIG_HID_DEBUG=y | 840 | CONFIG_HID_DEBUG=y |
841 | # CONFIG_HIDRAW is not set | ||
823 | 842 | ||
824 | # | 843 | # |
825 | # USB Input Devices | 844 | # USB Input Devices |
@@ -951,19 +970,6 @@ CONFIG_INFINIBAND_SRP=m | |||
951 | # CONFIG_RTC_CLASS is not set | 970 | # CONFIG_RTC_CLASS is not set |
952 | 971 | ||
953 | # | 972 | # |
954 | # DMA Engine support | ||
955 | # | ||
956 | # CONFIG_DMA_ENGINE is not set | ||
957 | |||
958 | # | ||
959 | # DMA Clients | ||
960 | # | ||
961 | |||
962 | # | ||
963 | # DMA Devices | ||
964 | # | ||
965 | |||
966 | # | ||
967 | # Userspace I/O | 973 | # Userspace I/O |
968 | # | 974 | # |
969 | # CONFIG_UIO is not set | 975 | # CONFIG_UIO is not set |
@@ -1005,6 +1011,8 @@ CONFIG_XFS_RT=y | |||
1005 | CONFIG_INOTIFY=y | 1011 | CONFIG_INOTIFY=y |
1006 | CONFIG_INOTIFY_USER=y | 1012 | CONFIG_INOTIFY_USER=y |
1007 | CONFIG_QUOTA=y | 1013 | CONFIG_QUOTA=y |
1014 | CONFIG_QUOTA_NETLINK_INTERFACE=y | ||
1015 | CONFIG_PRINT_QUOTA_WARNING=y | ||
1008 | # CONFIG_QFMT_V1 is not set | 1016 | # CONFIG_QFMT_V1 is not set |
1009 | # CONFIG_QFMT_V2 is not set | 1017 | # CONFIG_QFMT_V2 is not set |
1010 | CONFIG_QUOTACTL=y | 1018 | CONFIG_QUOTACTL=y |
@@ -1043,7 +1051,6 @@ CONFIG_TMPFS=y | |||
1043 | # CONFIG_TMPFS_POSIX_ACL is not set | 1051 | # CONFIG_TMPFS_POSIX_ACL is not set |
1044 | CONFIG_HUGETLBFS=y | 1052 | CONFIG_HUGETLBFS=y |
1045 | CONFIG_HUGETLB_PAGE=y | 1053 | CONFIG_HUGETLB_PAGE=y |
1046 | CONFIG_RAMFS=y | ||
1047 | # CONFIG_CONFIGFS_FS is not set | 1054 | # CONFIG_CONFIGFS_FS is not set |
1048 | 1055 | ||
1049 | # | 1056 | # |
@@ -1062,10 +1069,7 @@ CONFIG_RAMFS=y | |||
1062 | # CONFIG_QNX4FS_FS is not set | 1069 | # CONFIG_QNX4FS_FS is not set |
1063 | # CONFIG_SYSV_FS is not set | 1070 | # CONFIG_SYSV_FS is not set |
1064 | # CONFIG_UFS_FS is not set | 1071 | # CONFIG_UFS_FS is not set |
1065 | 1072 | CONFIG_NETWORK_FILESYSTEMS=y | |
1066 | # | ||
1067 | # Network File Systems | ||
1068 | # | ||
1069 | CONFIG_NFS_FS=m | 1073 | CONFIG_NFS_FS=m |
1070 | CONFIG_NFS_V3=y | 1074 | CONFIG_NFS_V3=y |
1071 | # CONFIG_NFS_V3_ACL is not set | 1075 | # CONFIG_NFS_V3_ACL is not set |
@@ -1082,6 +1086,7 @@ CONFIG_EXPORTFS=m | |||
1082 | CONFIG_NFS_COMMON=y | 1086 | CONFIG_NFS_COMMON=y |
1083 | CONFIG_SUNRPC=m | 1087 | CONFIG_SUNRPC=m |
1084 | CONFIG_SUNRPC_GSS=m | 1088 | CONFIG_SUNRPC_GSS=m |
1089 | CONFIG_SUNRPC_XPRT_RDMA=m | ||
1085 | # CONFIG_SUNRPC_BIND34 is not set | 1090 | # CONFIG_SUNRPC_BIND34 is not set |
1086 | CONFIG_RPCSEC_GSS_KRB5=m | 1091 | CONFIG_RPCSEC_GSS_KRB5=m |
1087 | # CONFIG_RPCSEC_GSS_SPKM3 is not set | 1092 | # CONFIG_RPCSEC_GSS_SPKM3 is not set |
@@ -1118,10 +1123,6 @@ CONFIG_SGI_PARTITION=y | |||
1118 | # CONFIG_KARMA_PARTITION is not set | 1123 | # CONFIG_KARMA_PARTITION is not set |
1119 | CONFIG_EFI_PARTITION=y | 1124 | CONFIG_EFI_PARTITION=y |
1120 | # CONFIG_SYSV68_PARTITION is not set | 1125 | # CONFIG_SYSV68_PARTITION is not set |
1121 | |||
1122 | # | ||
1123 | # Native Language Support | ||
1124 | # | ||
1125 | CONFIG_NLS=y | 1126 | CONFIG_NLS=y |
1126 | CONFIG_NLS_DEFAULT="iso8859-1" | 1127 | CONFIG_NLS_DEFAULT="iso8859-1" |
1127 | CONFIG_NLS_CODEPAGE_437=y | 1128 | CONFIG_NLS_CODEPAGE_437=y |
@@ -1162,10 +1163,6 @@ CONFIG_NLS_ISO8859_1=y | |||
1162 | # CONFIG_NLS_KOI8_R is not set | 1163 | # CONFIG_NLS_KOI8_R is not set |
1163 | # CONFIG_NLS_KOI8_U is not set | 1164 | # CONFIG_NLS_KOI8_U is not set |
1164 | CONFIG_NLS_UTF8=y | 1165 | CONFIG_NLS_UTF8=y |
1165 | |||
1166 | # | ||
1167 | # Distributed Lock Manager | ||
1168 | # | ||
1169 | # CONFIG_DLM is not set | 1166 | # CONFIG_DLM is not set |
1170 | 1167 | ||
1171 | # | 1168 | # |
@@ -1223,6 +1220,7 @@ CONFIG_DEBUG_INFO=y | |||
1223 | # CONFIG_DEBUG_VM is not set | 1220 | # CONFIG_DEBUG_VM is not set |
1224 | # CONFIG_DEBUG_LIST is not set | 1221 | # CONFIG_DEBUG_LIST is not set |
1225 | CONFIG_FORCED_INLINING=y | 1222 | CONFIG_FORCED_INLINING=y |
1223 | # CONFIG_BOOT_PRINTK_DELAY is not set | ||
1226 | # CONFIG_RCU_TORTURE_TEST is not set | 1224 | # CONFIG_RCU_TORTURE_TEST is not set |
1227 | # CONFIG_FAULT_INJECTION is not set | 1225 | # CONFIG_FAULT_INJECTION is not set |
1228 | CONFIG_IA64_GRANULE_16MB=y | 1226 | CONFIG_IA64_GRANULE_16MB=y |
@@ -1238,6 +1236,7 @@ CONFIG_SYSVIPC_COMPAT=y | |||
1238 | # | 1236 | # |
1239 | # CONFIG_KEYS is not set | 1237 | # CONFIG_KEYS is not set |
1240 | # CONFIG_SECURITY is not set | 1238 | # CONFIG_SECURITY is not set |
1239 | # CONFIG_SECURITY_FILE_CAPABILITIES is not set | ||
1241 | CONFIG_XOR_BLOCKS=y | 1240 | CONFIG_XOR_BLOCKS=y |
1242 | CONFIG_ASYNC_CORE=y | 1241 | CONFIG_ASYNC_CORE=y |
1243 | CONFIG_ASYNC_MEMCPY=y | 1242 | CONFIG_ASYNC_MEMCPY=y |
@@ -1262,6 +1261,7 @@ CONFIG_CRYPTO_ECB=m | |||
1262 | CONFIG_CRYPTO_CBC=m | 1261 | CONFIG_CRYPTO_CBC=m |
1263 | CONFIG_CRYPTO_PCBC=m | 1262 | CONFIG_CRYPTO_PCBC=m |
1264 | # CONFIG_CRYPTO_LRW is not set | 1263 | # CONFIG_CRYPTO_LRW is not set |
1264 | # CONFIG_CRYPTO_XTS is not set | ||
1265 | # CONFIG_CRYPTO_CRYPTD is not set | 1265 | # CONFIG_CRYPTO_CRYPTD is not set |
1266 | CONFIG_CRYPTO_DES=m | 1266 | CONFIG_CRYPTO_DES=m |
1267 | # CONFIG_CRYPTO_FCRYPT is not set | 1267 | # CONFIG_CRYPTO_FCRYPT is not set |
@@ -1275,9 +1275,11 @@ CONFIG_CRYPTO_DES=m | |||
1275 | # CONFIG_CRYPTO_ARC4 is not set | 1275 | # CONFIG_CRYPTO_ARC4 is not set |
1276 | # CONFIG_CRYPTO_KHAZAD is not set | 1276 | # CONFIG_CRYPTO_KHAZAD is not set |
1277 | # CONFIG_CRYPTO_ANUBIS is not set | 1277 | # CONFIG_CRYPTO_ANUBIS is not set |
1278 | # CONFIG_CRYPTO_SEED is not set | ||
1278 | CONFIG_CRYPTO_DEFLATE=m | 1279 | CONFIG_CRYPTO_DEFLATE=m |
1279 | # CONFIG_CRYPTO_MICHAEL_MIC is not set | 1280 | # CONFIG_CRYPTO_MICHAEL_MIC is not set |
1280 | CONFIG_CRYPTO_CRC32C=m | 1281 | CONFIG_CRYPTO_CRC32C=m |
1281 | # CONFIG_CRYPTO_CAMELLIA is not set | 1282 | # CONFIG_CRYPTO_CAMELLIA is not set |
1282 | # CONFIG_CRYPTO_TEST is not set | 1283 | # CONFIG_CRYPTO_TEST is not set |
1284 | # CONFIG_CRYPTO_AUTHENC is not set | ||
1283 | # CONFIG_CRYPTO_HW is not set | 1285 | # CONFIG_CRYPTO_HW is not set |
diff --git a/arch/ia64/kernel/efi.c b/arch/ia64/kernel/efi.c index 3f7ea13358e9..6216eba2e38f 100644 --- a/arch/ia64/kernel/efi.c +++ b/arch/ia64/kernel/efi.c | |||
@@ -1231,7 +1231,7 @@ kdump_find_rsvd_region (unsigned long size, | |||
1231 | 1231 | ||
1232 | #ifdef CONFIG_PROC_VMCORE | 1232 | #ifdef CONFIG_PROC_VMCORE |
1233 | /* locate the size find a the descriptor at a certain address */ | 1233 | /* locate the size find a the descriptor at a certain address */ |
1234 | unsigned long | 1234 | unsigned long __init |
1235 | vmcore_find_descriptor_size (unsigned long address) | 1235 | vmcore_find_descriptor_size (unsigned long address) |
1236 | { | 1236 | { |
1237 | void *efi_map_start, *efi_map_end, *p; | 1237 | void *efi_map_start, *efi_map_end, *p; |
diff --git a/arch/ia64/kernel/gate.lds.S b/arch/ia64/kernel/gate.lds.S index 44817d97ab43..454d7a7dfa9d 100644 --- a/arch/ia64/kernel/gate.lds.S +++ b/arch/ia64/kernel/gate.lds.S | |||
@@ -20,6 +20,8 @@ SECTIONS | |||
20 | .gnu.version_d : { *(.gnu.version_d) } | 20 | .gnu.version_d : { *(.gnu.version_d) } |
21 | .gnu.version_r : { *(.gnu.version_r) } | 21 | .gnu.version_r : { *(.gnu.version_r) } |
22 | 22 | ||
23 | .note : { *(.note*) } :readable :note | ||
24 | |||
23 | .dynamic : { *(.dynamic) } :readable :dynamic | 25 | .dynamic : { *(.dynamic) } :readable :dynamic |
24 | 26 | ||
25 | /* | 27 | /* |
@@ -83,6 +85,7 @@ PHDRS | |||
83 | epc PT_LOAD FILEHDR PHDRS FLAGS(1); /* PF_X */ | 85 | epc PT_LOAD FILEHDR PHDRS FLAGS(1); /* PF_X */ |
84 | #endif | 86 | #endif |
85 | dynamic PT_DYNAMIC FLAGS(4); /* PF_R */ | 87 | dynamic PT_DYNAMIC FLAGS(4); /* PF_R */ |
88 | note PT_NOTE FLAGS(4); /* PF_R */ | ||
86 | unwind PT_IA_64_UNWIND; | 89 | unwind PT_IA_64_UNWIND; |
87 | } | 90 | } |
88 | 91 | ||
diff --git a/arch/ia64/kernel/msi_ia64.c b/arch/ia64/kernel/msi_ia64.c index 2fdbd5c3f213..e86d02959794 100644 --- a/arch/ia64/kernel/msi_ia64.c +++ b/arch/ia64/kernel/msi_ia64.c | |||
@@ -109,7 +109,7 @@ int ia64_setup_msi_irq(struct pci_dev *pdev, struct msi_desc *desc) | |||
109 | write_msi_msg(irq, &msg); | 109 | write_msi_msg(irq, &msg); |
110 | set_irq_chip_and_handler(irq, &ia64_msi_chip, handle_edge_irq); | 110 | set_irq_chip_and_handler(irq, &ia64_msi_chip, handle_edge_irq); |
111 | 111 | ||
112 | return irq; | 112 | return 0; |
113 | } | 113 | } |
114 | 114 | ||
115 | void ia64_teardown_msi_irq(unsigned int irq) | 115 | void ia64_teardown_msi_irq(unsigned int irq) |
diff --git a/arch/ia64/kernel/setup.c b/arch/ia64/kernel/setup.c index ae6c3c02e117..2b3751eef5ce 100644 --- a/arch/ia64/kernel/setup.c +++ b/arch/ia64/kernel/setup.c | |||
@@ -417,34 +417,6 @@ mark_bsp_online (void) | |||
417 | #endif | 417 | #endif |
418 | } | 418 | } |
419 | 419 | ||
420 | #ifdef CONFIG_SMP | ||
421 | static void __init | ||
422 | check_for_logical_procs (void) | ||
423 | { | ||
424 | pal_logical_to_physical_t info; | ||
425 | s64 status; | ||
426 | |||
427 | status = ia64_pal_logical_to_phys(0, &info); | ||
428 | if (status == -1) { | ||
429 | printk(KERN_INFO "No logical to physical processor mapping " | ||
430 | "available\n"); | ||
431 | return; | ||
432 | } | ||
433 | if (status) { | ||
434 | printk(KERN_ERR "ia64_pal_logical_to_phys failed with %ld\n", | ||
435 | status); | ||
436 | return; | ||
437 | } | ||
438 | /* | ||
439 | * Total number of siblings that BSP has. Though not all of them | ||
440 | * may have booted successfully. The correct number of siblings | ||
441 | * booted is in info.overview_num_log. | ||
442 | */ | ||
443 | smp_num_siblings = info.overview_tpc; | ||
444 | smp_num_cpucores = info.overview_cpp; | ||
445 | } | ||
446 | #endif | ||
447 | |||
448 | static __initdata int nomca; | 420 | static __initdata int nomca; |
449 | static __init int setup_nomca(char *s) | 421 | static __init int setup_nomca(char *s) |
450 | { | 422 | { |
@@ -540,15 +512,6 @@ setup_arch (char **cmdline_p) | |||
540 | 512 | ||
541 | #ifdef CONFIG_SMP | 513 | #ifdef CONFIG_SMP |
542 | cpu_physical_id(0) = hard_smp_processor_id(); | 514 | cpu_physical_id(0) = hard_smp_processor_id(); |
543 | check_for_logical_procs(); | ||
544 | if (smp_num_cpucores > 1) | ||
545 | printk(KERN_INFO | ||
546 | "cpu package is Multi-Core capable: number of cores=%d\n", | ||
547 | smp_num_cpucores); | ||
548 | if (smp_num_siblings > 1) | ||
549 | printk(KERN_INFO | ||
550 | "cpu package is Multi-Threading capable: number of siblings=%d\n", | ||
551 | smp_num_siblings); | ||
552 | #endif | 515 | #endif |
553 | 516 | ||
554 | cpu_init(); /* initialize the bootstrap CPU */ | 517 | cpu_init(); /* initialize the bootstrap CPU */ |
@@ -661,12 +624,13 @@ show_cpuinfo (struct seq_file *m, void *v) | |||
661 | lpj*HZ/500000, (lpj*HZ/5000) % 100); | 624 | lpj*HZ/500000, (lpj*HZ/5000) % 100); |
662 | #ifdef CONFIG_SMP | 625 | #ifdef CONFIG_SMP |
663 | seq_printf(m, "siblings : %u\n", cpus_weight(cpu_core_map[cpunum])); | 626 | seq_printf(m, "siblings : %u\n", cpus_weight(cpu_core_map[cpunum])); |
627 | if (c->socket_id != -1) | ||
628 | seq_printf(m, "physical id: %u\n", c->socket_id); | ||
664 | if (c->threads_per_core > 1 || c->cores_per_socket > 1) | 629 | if (c->threads_per_core > 1 || c->cores_per_socket > 1) |
665 | seq_printf(m, | 630 | seq_printf(m, |
666 | "physical id: %u\n" | 631 | "core id : %u\n" |
667 | "core id : %u\n" | 632 | "thread id : %u\n", |
668 | "thread id : %u\n", | 633 | c->core_id, c->thread_id); |
669 | c->socket_id, c->core_id, c->thread_id); | ||
670 | #endif | 634 | #endif |
671 | seq_printf(m,"\n"); | 635 | seq_printf(m,"\n"); |
672 | 636 | ||
@@ -778,6 +742,9 @@ identify_cpu (struct cpuinfo_ia64 *c) | |||
778 | c->socket_id = -1; | 742 | c->socket_id = -1; |
779 | 743 | ||
780 | identify_siblings(c); | 744 | identify_siblings(c); |
745 | |||
746 | if (c->threads_per_core > smp_num_siblings) | ||
747 | smp_num_siblings = c->threads_per_core; | ||
781 | #endif | 748 | #endif |
782 | c->ppn = cpuid.field.ppn; | 749 | c->ppn = cpuid.field.ppn; |
783 | c->number = cpuid.field.number; | 750 | c->number = cpuid.field.number; |
diff --git a/arch/ia64/kernel/smpboot.c b/arch/ia64/kernel/smpboot.c index c57dbce25c12..f0fc4d8465ad 100644 --- a/arch/ia64/kernel/smpboot.c +++ b/arch/ia64/kernel/smpboot.c | |||
@@ -142,7 +142,6 @@ DEFINE_PER_CPU_SHARED_ALIGNED(cpumask_t, cpu_sibling_map); | |||
142 | EXPORT_PER_CPU_SYMBOL(cpu_sibling_map); | 142 | EXPORT_PER_CPU_SYMBOL(cpu_sibling_map); |
143 | 143 | ||
144 | int smp_num_siblings = 1; | 144 | int smp_num_siblings = 1; |
145 | int smp_num_cpucores = 1; | ||
146 | 145 | ||
147 | /* which logical CPU number maps to which CPU (physical APIC ID) */ | 146 | /* which logical CPU number maps to which CPU (physical APIC ID) */ |
148 | volatile int ia64_cpu_to_sapicid[NR_CPUS]; | 147 | volatile int ia64_cpu_to_sapicid[NR_CPUS]; |
@@ -886,13 +885,17 @@ identify_siblings(struct cpuinfo_ia64 *c) | |||
886 | u16 pltid; | 885 | u16 pltid; |
887 | pal_logical_to_physical_t info; | 886 | pal_logical_to_physical_t info; |
888 | 887 | ||
889 | if (smp_num_cpucores == 1 && smp_num_siblings == 1) | ||
890 | return; | ||
891 | |||
892 | if ((status = ia64_pal_logical_to_phys(-1, &info)) != PAL_STATUS_SUCCESS) { | 888 | if ((status = ia64_pal_logical_to_phys(-1, &info)) != PAL_STATUS_SUCCESS) { |
893 | printk(KERN_ERR "ia64_pal_logical_to_phys failed with %ld\n", | 889 | if (status != PAL_STATUS_UNIMPLEMENTED) { |
894 | status); | 890 | printk(KERN_ERR |
895 | return; | 891 | "ia64_pal_logical_to_phys failed with %ld\n", |
892 | status); | ||
893 | return; | ||
894 | } | ||
895 | |||
896 | info.overview_ppid = 0; | ||
897 | info.overview_cpp = 1; | ||
898 | info.overview_tpc = 1; | ||
896 | } | 899 | } |
897 | if ((status = ia64_sal_physical_id_info(&pltid)) != PAL_STATUS_SUCCESS) { | 900 | if ((status = ia64_sal_physical_id_info(&pltid)) != PAL_STATUS_SUCCESS) { |
898 | printk(KERN_ERR "ia64_sal_pltid failed with %ld\n", status); | 901 | printk(KERN_ERR "ia64_sal_pltid failed with %ld\n", status); |
@@ -900,6 +903,10 @@ identify_siblings(struct cpuinfo_ia64 *c) | |||
900 | } | 903 | } |
901 | 904 | ||
902 | c->socket_id = (pltid << 8) | info.overview_ppid; | 905 | c->socket_id = (pltid << 8) | info.overview_ppid; |
906 | |||
907 | if (info.overview_cpp == 1 && info.overview_tpc == 1) | ||
908 | return; | ||
909 | |||
903 | c->cores_per_socket = info.overview_cpp; | 910 | c->cores_per_socket = info.overview_cpp; |
904 | c->threads_per_core = info.overview_tpc; | 911 | c->threads_per_core = info.overview_tpc; |
905 | c->num_log = info.overview_num_log; | 912 | c->num_log = info.overview_num_log; |
diff --git a/arch/ia64/mm/init.c b/arch/ia64/mm/init.c index c6c19bf11bec..25aef6211a54 100644 --- a/arch/ia64/mm/init.c +++ b/arch/ia64/mm/init.c | |||
@@ -472,7 +472,7 @@ struct memmap_init_callback_data { | |||
472 | unsigned long zone; | 472 | unsigned long zone; |
473 | }; | 473 | }; |
474 | 474 | ||
475 | static int | 475 | static int __meminit |
476 | virtual_memmap_init (u64 start, u64 end, void *arg) | 476 | virtual_memmap_init (u64 start, u64 end, void *arg) |
477 | { | 477 | { |
478 | struct memmap_init_callback_data *args; | 478 | struct memmap_init_callback_data *args; |
@@ -503,7 +503,7 @@ virtual_memmap_init (u64 start, u64 end, void *arg) | |||
503 | return 0; | 503 | return 0; |
504 | } | 504 | } |
505 | 505 | ||
506 | void | 506 | void __meminit |
507 | memmap_init (unsigned long size, int nid, unsigned long zone, | 507 | memmap_init (unsigned long size, int nid, unsigned long zone, |
508 | unsigned long start_pfn) | 508 | unsigned long start_pfn) |
509 | { | 509 | { |
diff --git a/arch/ia64/scripts/check-segrel.lds b/arch/ia64/scripts/check-segrel.lds index 1c2f13e181d0..85a0d54fb5ab 100644 --- a/arch/ia64/scripts/check-segrel.lds +++ b/arch/ia64/scripts/check-segrel.lds | |||
@@ -1,6 +1,7 @@ | |||
1 | SECTIONS { | 1 | SECTIONS { |
2 | . = SIZEOF_HEADERS; | 2 | . = SIZEOF_HEADERS; |
3 | .rodata : { *(.rodata) } :ro | 3 | .rodata : { *(.rodata) } :ro |
4 | .note : { *(.note*) } | ||
4 | . = 0xa0000; | 5 | . = 0xa0000; |
5 | .data : { *(.data) } :dat | 6 | .data : { *(.data) } :dat |
6 | /DISCARD/ : { *(*) } | 7 | /DISCARD/ : { *(*) } |
diff --git a/arch/ia64/sn/kernel/mca.c b/arch/ia64/sn/kernel/mca.c index 3db62f24596c..868c9aa64fe2 100644 --- a/arch/ia64/sn/kernel/mca.c +++ b/arch/ia64/sn/kernel/mca.c | |||
@@ -98,6 +98,7 @@ sn_platform_plat_specific_err_print(const u8 * sect_header, u8 ** oemdata, | |||
98 | while (*sn_oemdata_size > sn_oemdata_bufsize) { | 98 | while (*sn_oemdata_size > sn_oemdata_bufsize) { |
99 | u8 *newbuf = vmalloc(*sn_oemdata_size); | 99 | u8 *newbuf = vmalloc(*sn_oemdata_size); |
100 | if (!newbuf) { | 100 | if (!newbuf) { |
101 | mutex_unlock(&sn_oemdata_mutex); | ||
101 | printk(KERN_ERR "%s: unable to extend sn_oemdata\n", | 102 | printk(KERN_ERR "%s: unable to extend sn_oemdata\n", |
102 | __FUNCTION__); | 103 | __FUNCTION__); |
103 | return 1; | 104 | return 1; |
diff --git a/arch/m68k/kernel/dma.c b/arch/m68k/kernel/dma.c index ef490e1ce600..6f8c080dd9f9 100644 --- a/arch/m68k/kernel/dma.c +++ b/arch/m68k/kernel/dma.c | |||
@@ -9,10 +9,10 @@ | |||
9 | #include <linux/dma-mapping.h> | 9 | #include <linux/dma-mapping.h> |
10 | #include <linux/device.h> | 10 | #include <linux/device.h> |
11 | #include <linux/kernel.h> | 11 | #include <linux/kernel.h> |
12 | #include <linux/scatterlist.h> | ||
12 | #include <linux/vmalloc.h> | 13 | #include <linux/vmalloc.h> |
13 | 14 | ||
14 | #include <asm/pgalloc.h> | 15 | #include <asm/pgalloc.h> |
15 | #include <asm/scatterlist.h> | ||
16 | 16 | ||
17 | void *dma_alloc_coherent(struct device *dev, size_t size, | 17 | void *dma_alloc_coherent(struct device *dev, size_t size, |
18 | dma_addr_t *handle, gfp_t flag) | 18 | dma_addr_t *handle, gfp_t flag) |
diff --git a/arch/mips/Kconfig b/arch/mips/Kconfig index 61262c5f9c62..2c7d6c240b73 100644 --- a/arch/mips/Kconfig +++ b/arch/mips/Kconfig | |||
@@ -546,6 +546,7 @@ config SIBYTE_BIGSUR | |||
546 | select SWAP_IO_SPACE | 546 | select SWAP_IO_SPACE |
547 | select SYS_HAS_CPU_SB1 | 547 | select SYS_HAS_CPU_SB1 |
548 | select SYS_SUPPORTS_BIG_ENDIAN | 548 | select SYS_SUPPORTS_BIG_ENDIAN |
549 | select SYS_SUPPORTS_HIGHMEM | ||
549 | select SYS_SUPPORTS_LITTLE_ENDIAN | 550 | select SYS_SUPPORTS_LITTLE_ENDIAN |
550 | 551 | ||
551 | config SNI_RM | 552 | config SNI_RM |
@@ -583,6 +584,7 @@ config SNI_RM | |||
583 | 584 | ||
584 | config TOSHIBA_JMR3927 | 585 | config TOSHIBA_JMR3927 |
585 | bool "Toshiba JMR-TX3927 board" | 586 | bool "Toshiba JMR-TX3927 board" |
587 | select CEVT_TXX9 | ||
586 | select DMA_NONCOHERENT | 588 | select DMA_NONCOHERENT |
587 | select HW_HAS_PCI | 589 | select HW_HAS_PCI |
588 | select MIPS_TX3927 | 590 | select MIPS_TX3927 |
@@ -597,6 +599,7 @@ config TOSHIBA_JMR3927 | |||
597 | config TOSHIBA_RBTX4927 | 599 | config TOSHIBA_RBTX4927 |
598 | bool "Toshiba RBTX49[23]7 board" | 600 | bool "Toshiba RBTX49[23]7 board" |
599 | select CEVT_R4K | 601 | select CEVT_R4K |
602 | select CEVT_TXX9 | ||
600 | select DMA_NONCOHERENT | 603 | select DMA_NONCOHERENT |
601 | select HAS_TXX9_SERIAL | 604 | select HAS_TXX9_SERIAL |
602 | select HW_HAS_PCI | 605 | select HW_HAS_PCI |
@@ -618,6 +621,7 @@ config TOSHIBA_RBTX4927 | |||
618 | config TOSHIBA_RBTX4938 | 621 | config TOSHIBA_RBTX4938 |
619 | bool "Toshiba RBTX4938 board" | 622 | bool "Toshiba RBTX4938 board" |
620 | select CEVT_R4K | 623 | select CEVT_R4K |
624 | select CEVT_TXX9 | ||
621 | select DMA_NONCOHERENT | 625 | select DMA_NONCOHERENT |
622 | select HAS_TXX9_SERIAL | 626 | select HAS_TXX9_SERIAL |
623 | select HW_HAS_PCI | 627 | select HW_HAS_PCI |
@@ -730,12 +734,27 @@ config ARCH_MAY_HAVE_PC_FDC | |||
730 | config BOOT_RAW | 734 | config BOOT_RAW |
731 | bool | 735 | bool |
732 | 736 | ||
737 | config CEVT_BCM1480 | ||
738 | bool | ||
739 | |||
733 | config CEVT_GT641XX | 740 | config CEVT_GT641XX |
734 | bool | 741 | bool |
735 | 742 | ||
736 | config CEVT_R4K | 743 | config CEVT_R4K |
737 | bool | 744 | bool |
738 | 745 | ||
746 | config CEVT_SB1250 | ||
747 | bool | ||
748 | |||
749 | config CEVT_TXX9 | ||
750 | bool | ||
751 | |||
752 | config CSRC_BCM1480 | ||
753 | bool | ||
754 | |||
755 | config CSRC_SB1250 | ||
756 | bool | ||
757 | |||
739 | config CFE | 758 | config CFE |
740 | bool | 759 | bool |
741 | 760 | ||
diff --git a/arch/mips/au1000/common/irq.c b/arch/mips/au1000/common/irq.c index 59e932a928d2..ddfb7f0a17a6 100644 --- a/arch/mips/au1000/common/irq.c +++ b/arch/mips/au1000/common/irq.c | |||
@@ -318,38 +318,6 @@ static struct irq_chip level_irq_type = { | |||
318 | .end = end_irq, | 318 | .end = end_irq, |
319 | }; | 319 | }; |
320 | 320 | ||
321 | #ifdef CONFIG_PM | ||
322 | void startup_match20_interrupt(irq_handler_t handler) | ||
323 | { | ||
324 | struct irq_desc *desc = &irq_desc[AU1000_TOY_MATCH2_INT]; | ||
325 | |||
326 | static struct irqaction action; | ||
327 | memset(&action, 0, sizeof(struct irqaction)); | ||
328 | |||
329 | /* | ||
330 | * This is a big problem.... since we didn't use request_irq | ||
331 | * when kernel/irq.c calls probe_irq_xxx this interrupt will | ||
332 | * be probed for usage. This will end up disabling the device :( | ||
333 | * Give it a bogus "action" pointer -- this will keep it from | ||
334 | * getting auto-probed! | ||
335 | * | ||
336 | * By setting the status to match that of request_irq() we | ||
337 | * can avoid it. --cgray | ||
338 | */ | ||
339 | action.dev_id = handler; | ||
340 | action.flags = IRQF_DISABLED; | ||
341 | cpus_clear(action.mask); | ||
342 | action.name = "Au1xxx TOY"; | ||
343 | action.handler = handler; | ||
344 | action.next = NULL; | ||
345 | |||
346 | desc->action = &action; | ||
347 | desc->status &= ~(IRQ_DISABLED | IRQ_AUTODETECT | IRQ_WAITING | IRQ_INPROGRESS); | ||
348 | |||
349 | local_enable_irq(AU1000_TOY_MATCH2_INT); | ||
350 | } | ||
351 | #endif | ||
352 | |||
353 | static void __init setup_local_irq(unsigned int irq_nr, int type, int int_req) | 321 | static void __init setup_local_irq(unsigned int irq_nr, int type, int int_req) |
354 | { | 322 | { |
355 | unsigned int bit = irq_nr - AU1000_INTC0_INT_BASE; | 323 | unsigned int bit = irq_nr - AU1000_INTC0_INT_BASE; |
diff --git a/arch/mips/au1000/common/time.c b/arch/mips/au1000/common/time.c index 2556399708ba..f113b512d7b1 100644 --- a/arch/mips/au1000/common/time.c +++ b/arch/mips/au1000/common/time.c | |||
@@ -67,7 +67,7 @@ static DEFINE_SPINLOCK(time_lock); | |||
67 | unsigned long wtimer; | 67 | unsigned long wtimer; |
68 | 68 | ||
69 | #ifdef CONFIG_PM | 69 | #ifdef CONFIG_PM |
70 | irqreturn_t counter0_irq(int irq, void *dev_id) | 70 | static irqreturn_t counter0_irq(int irq, void *dev_id) |
71 | { | 71 | { |
72 | unsigned long pc0; | 72 | unsigned long pc0; |
73 | int time_elapsed; | 73 | int time_elapsed; |
@@ -117,6 +117,13 @@ irqreturn_t counter0_irq(int irq, void *dev_id) | |||
117 | return IRQ_HANDLED; | 117 | return IRQ_HANDLED; |
118 | } | 118 | } |
119 | 119 | ||
120 | struct irqaction counter0_action = { | ||
121 | .handler = counter0_irq, | ||
122 | .flags = IRQF_DISABLED, | ||
123 | .name = "alchemy-toy", | ||
124 | .dev_id = NULL, | ||
125 | }; | ||
126 | |||
120 | /* When we wakeup from sleep, we have to "catch up" on all of the | 127 | /* When we wakeup from sleep, we have to "catch up" on all of the |
121 | * timer ticks we have missed. | 128 | * timer ticks we have missed. |
122 | */ | 129 | */ |
@@ -221,7 +228,7 @@ unsigned long cal_r4koff(void) | |||
221 | return (cpu_speed / HZ); | 228 | return (cpu_speed / HZ); |
222 | } | 229 | } |
223 | 230 | ||
224 | void __init plat_timer_setup(struct irqaction *irq) | 231 | void __init plat_time_init(void) |
225 | { | 232 | { |
226 | unsigned int est_freq; | 233 | unsigned int est_freq; |
227 | 234 | ||
@@ -255,15 +262,10 @@ void __init plat_timer_setup(struct irqaction *irq) | |||
255 | * we do this. | 262 | * we do this. |
256 | */ | 263 | */ |
257 | if (no_au1xxx_32khz) { | 264 | if (no_au1xxx_32khz) { |
258 | unsigned int c0_status; | ||
259 | |||
260 | printk("WARNING: no 32KHz clock found.\n"); | 265 | printk("WARNING: no 32KHz clock found.\n"); |
261 | 266 | ||
262 | /* Ensure we get CPO_COUNTER interrupts. | 267 | /* Ensure we get CPO_COUNTER interrupts. */ |
263 | */ | 268 | set_c0_status(IE_IRQ5); |
264 | c0_status = read_c0_status(); | ||
265 | c0_status |= IE_IRQ5; | ||
266 | write_c0_status(c0_status); | ||
267 | } | 269 | } |
268 | else { | 270 | else { |
269 | while (au_readl(SYS_COUNTER_CNTRL) & SYS_CNTRL_C0S); | 271 | while (au_readl(SYS_COUNTER_CNTRL) & SYS_CNTRL_C0S); |
@@ -280,7 +282,7 @@ void __init plat_timer_setup(struct irqaction *irq) | |||
280 | au_writel(last_match20 + MATCH20_INC, SYS_TOYMATCH2); | 282 | au_writel(last_match20 + MATCH20_INC, SYS_TOYMATCH2); |
281 | au_sync(); | 283 | au_sync(); |
282 | while (au_readl(SYS_COUNTER_CNTRL) & SYS_CNTRL_M20); | 284 | while (au_readl(SYS_COUNTER_CNTRL) & SYS_CNTRL_M20); |
283 | startup_match20_interrupt(counter0_irq); | 285 | setup_irq(AU1000_TOY_MATCH2_INT, &counter0_action); |
284 | 286 | ||
285 | /* We can use the real 'wait' instruction. | 287 | /* We can use the real 'wait' instruction. |
286 | */ | 288 | */ |
diff --git a/arch/mips/au1000/mtx-1/Makefile b/arch/mips/au1000/mtx-1/Makefile index 764bf9f7e281..85a90941de4f 100644 --- a/arch/mips/au1000/mtx-1/Makefile +++ b/arch/mips/au1000/mtx-1/Makefile | |||
@@ -8,3 +8,6 @@ | |||
8 | # | 8 | # |
9 | 9 | ||
10 | lib-y := init.o board_setup.o irqmap.o | 10 | lib-y := init.o board_setup.o irqmap.o |
11 | obj-y := platform.o | ||
12 | |||
13 | EXTRA_CFLAGS += -Werror | ||
diff --git a/arch/mips/au1000/mtx-1/platform.c b/arch/mips/au1000/mtx-1/platform.c new file mode 100644 index 000000000000..49c0fb409fea --- /dev/null +++ b/arch/mips/au1000/mtx-1/platform.c | |||
@@ -0,0 +1,77 @@ | |||
1 | /* | ||
2 | * MTX-1 platform devices registration | ||
3 | * | ||
4 | * Copyright (C) 2007, Florian Fainelli <florian@openwrt.org> | ||
5 | * | ||
6 | * This program is free software; you can redistribute it and/or modify | ||
7 | * it under the terms of the GNU General Public License as published by | ||
8 | * the Free Software Foundation; either version 2 of the License, or | ||
9 | * (at your option) any later version. | ||
10 | * | ||
11 | * This program is distributed in the hope that it will be useful, | ||
12 | * but WITHOUT ANY WARRANTY; without even the implied warranty of | ||
13 | * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the | ||
14 | * GNU General Public License for more details. | ||
15 | * | ||
16 | * You should have received a copy of the GNU General Public License | ||
17 | * along with this program; if not, write to the Free Software | ||
18 | * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA | ||
19 | */ | ||
20 | |||
21 | #include <linux/init.h> | ||
22 | #include <linux/types.h> | ||
23 | #include <linux/platform_device.h> | ||
24 | #include <linux/leds.h> | ||
25 | |||
26 | #include <asm/gpio.h> | ||
27 | |||
28 | static struct resource mtx1_wdt_res[] = { | ||
29 | [0] = { | ||
30 | .start = 15, | ||
31 | .end = 15, | ||
32 | .name = "mtx1-wdt-gpio", | ||
33 | .flags = IORESOURCE_IRQ, | ||
34 | } | ||
35 | }; | ||
36 | |||
37 | static struct platform_device mtx1_wdt = { | ||
38 | .name = "mtx1-wdt", | ||
39 | .id = 0, | ||
40 | .num_resources = ARRAY_SIZE(mtx1_wdt_res), | ||
41 | .resource = mtx1_wdt_res, | ||
42 | }; | ||
43 | |||
44 | static struct gpio_led default_leds[] = { | ||
45 | { | ||
46 | .name = "mtx1:green", | ||
47 | .gpio = 211, | ||
48 | }, { | ||
49 | .name = "mtx1:red", | ||
50 | .gpio = 212, | ||
51 | }, | ||
52 | }; | ||
53 | |||
54 | static struct gpio_led_platform_data mtx1_led_data = { | ||
55 | .num_leds = ARRAY_SIZE(default_leds), | ||
56 | .leds = default_leds, | ||
57 | }; | ||
58 | |||
59 | static struct platform_device mtx1_gpio_leds = { | ||
60 | .name = "leds-gpio", | ||
61 | .id = -1, | ||
62 | .dev = { | ||
63 | .platform_data = &mtx1_led_data, | ||
64 | } | ||
65 | }; | ||
66 | |||
67 | static struct __initdata platform_device * mtx1_devs[] = { | ||
68 | &mtx1_gpio_leds, | ||
69 | &mtx1_wdt | ||
70 | }; | ||
71 | |||
72 | static int __init mtx1_register_devices(void) | ||
73 | { | ||
74 | return platform_add_devices(mtx1_devs, ARRAY_SIZE(mtx1_devs)); | ||
75 | } | ||
76 | |||
77 | arch_initcall(mtx1_register_devices); | ||
diff --git a/arch/mips/au1000/pb1200/Makefile b/arch/mips/au1000/pb1200/Makefile index 22b673cf55af..970b1b1d5cda 100644 --- a/arch/mips/au1000/pb1200/Makefile +++ b/arch/mips/au1000/pb1200/Makefile | |||
@@ -3,3 +3,5 @@ | |||
3 | # | 3 | # |
4 | 4 | ||
5 | lib-y := init.o board_setup.o irqmap.o | 5 | lib-y := init.o board_setup.o irqmap.o |
6 | |||
7 | EXTRA_CFLAGS += -Werror | ||
diff --git a/arch/mips/au1000/pb1200/board_setup.c b/arch/mips/au1000/pb1200/board_setup.c index 5dbc9868f598..b98bebfa87c6 100644 --- a/arch/mips/au1000/pb1200/board_setup.c +++ b/arch/mips/au1000/pb1200/board_setup.c | |||
@@ -68,9 +68,11 @@ void board_reset(void) | |||
68 | void __init board_setup(void) | 68 | void __init board_setup(void) |
69 | { | 69 | { |
70 | char *argptr = NULL; | 70 | char *argptr = NULL; |
71 | u32 pin_func; | ||
72 | 71 | ||
73 | #if 0 | 72 | #if 0 |
73 | { | ||
74 | u32 pin_func; | ||
75 | |||
74 | /* Enable PSC1 SYNC for AC97. Normaly done in audio driver, | 76 | /* Enable PSC1 SYNC for AC97. Normaly done in audio driver, |
75 | * but it is board specific code, so put it here. | 77 | * but it is board specific code, so put it here. |
76 | */ | 78 | */ |
@@ -81,11 +83,13 @@ void __init board_setup(void) | |||
81 | 83 | ||
82 | au_writel(0, (u32)bcsr|0x10); /* turn off pcmcia power */ | 84 | au_writel(0, (u32)bcsr|0x10); /* turn off pcmcia power */ |
83 | au_sync(); | 85 | au_sync(); |
86 | } | ||
84 | #endif | 87 | #endif |
85 | 88 | ||
86 | #if defined(CONFIG_I2C_AU1550) | 89 | #if defined(CONFIG_I2C_AU1550) |
87 | { | 90 | { |
88 | u32 freq0, clksrc; | 91 | u32 freq0, clksrc; |
92 | u32 pin_func; | ||
89 | 93 | ||
90 | /* Select SMBUS in CPLD */ | 94 | /* Select SMBUS in CPLD */ |
91 | bcsr->resets &= ~(BCSR_RESETS_PCS0MUX); | 95 | bcsr->resets &= ~(BCSR_RESETS_PCS0MUX); |
diff --git a/arch/mips/au1000/pb1200/irqmap.c b/arch/mips/au1000/pb1200/irqmap.c index bdf00e2a35e4..c096be4ed4e7 100644 --- a/arch/mips/au1000/pb1200/irqmap.c +++ b/arch/mips/au1000/pb1200/irqmap.c | |||
@@ -94,51 +94,41 @@ inline void pb1200_disable_irq(unsigned int irq_nr) | |||
94 | bcsr->intclr = 1<<(irq_nr - PB1200_INT_BEGIN); | 94 | bcsr->intclr = 1<<(irq_nr - PB1200_INT_BEGIN); |
95 | } | 95 | } |
96 | 96 | ||
97 | static unsigned int pb1200_startup_irq( unsigned int irq_nr ) | 97 | static unsigned int pb1200_setup_cascade(void) |
98 | { | 98 | { |
99 | if (++pb1200_cascade_en == 1) | 99 | int err; |
100 | { | 100 | |
101 | request_irq(AU1000_GPIO_7, &pb1200_cascade_handler, | 101 | err = request_irq(AU1000_GPIO_7, &pb1200_cascade_handler, |
102 | 0, "Pb1200 Cascade", (void *)&pb1200_cascade_handler ); | 102 | 0, "Pb1200 Cascade", &pb1200_cascade_handler); |
103 | #ifdef CONFIG_MIPS_PB1200 | 103 | if (err) |
104 | /* We have a problem with CPLD rev3. Enable a workaround */ | 104 | return err; |
105 | if( ((bcsr->whoami & BCSR_WHOAMI_CPLD)>>4) <= 3) | 105 | |
106 | { | ||
107 | printk("\nWARNING!!!\n"); | ||
108 | printk("\nWARNING!!!\n"); | ||
109 | printk("\nWARNING!!!\n"); | ||
110 | printk("\nWARNING!!!\n"); | ||
111 | printk("\nWARNING!!!\n"); | ||
112 | printk("\nWARNING!!!\n"); | ||
113 | printk("Pb1200 must be at CPLD rev4. Please have Pb1200\n"); | ||
114 | printk("updated to latest revision. This software will not\n"); | ||
115 | printk("work on anything less than CPLD rev4\n"); | ||
116 | printk("\nWARNING!!!\n"); | ||
117 | printk("\nWARNING!!!\n"); | ||
118 | printk("\nWARNING!!!\n"); | ||
119 | printk("\nWARNING!!!\n"); | ||
120 | printk("\nWARNING!!!\n"); | ||
121 | printk("\nWARNING!!!\n"); | ||
122 | while(1); | ||
123 | } | ||
124 | #endif | ||
125 | } | ||
126 | pb1200_enable_irq(irq_nr); | ||
127 | return 0; | 106 | return 0; |
128 | } | 107 | } |
129 | 108 | ||
130 | static void pb1200_shutdown_irq( unsigned int irq_nr ) | 109 | static unsigned int pb1200_startup_irq(unsigned int irq) |
131 | { | 110 | { |
132 | pb1200_disable_irq(irq_nr); | 111 | if (++pb1200_cascade_en == 1) { |
133 | if (--pb1200_cascade_en == 0) | 112 | int res; |
134 | { | 113 | |
135 | free_irq(AU1000_GPIO_7, &pb1200_cascade_handler ); | 114 | res = pb1200_setup_cascade(); |
115 | if (res) | ||
116 | return res; | ||
136 | } | 117 | } |
137 | return; | 118 | |
119 | pb1200_enable_irq(irq); | ||
120 | |||
121 | return 0; | ||
138 | } | 122 | } |
139 | 123 | ||
140 | static struct irq_chip external_irq_type = | 124 | static void pb1200_shutdown_irq(unsigned int irq) |
141 | { | 125 | { |
126 | pb1200_disable_irq(irq); | ||
127 | if (--pb1200_cascade_en == 0) | ||
128 | free_irq(AU1000_GPIO_7, &pb1200_cascade_handler); | ||
129 | } | ||
130 | |||
131 | static struct irq_chip external_irq_type = { | ||
142 | #ifdef CONFIG_MIPS_PB1200 | 132 | #ifdef CONFIG_MIPS_PB1200 |
143 | .name = "Pb1200 Ext", | 133 | .name = "Pb1200 Ext", |
144 | #endif | 134 | #endif |
@@ -155,16 +145,38 @@ static struct irq_chip external_irq_type = | |||
155 | 145 | ||
156 | void _board_init_irq(void) | 146 | void _board_init_irq(void) |
157 | { | 147 | { |
158 | int irq_nr; | 148 | unsigned int irq; |
159 | 149 | ||
160 | for (irq_nr = PB1200_INT_BEGIN; irq_nr <= PB1200_INT_END; irq_nr++) | 150 | #ifdef CONFIG_MIPS_PB1200 |
161 | { | 151 | /* We have a problem with CPLD rev3. Enable a workaround */ |
162 | set_irq_chip_and_handler(irq_nr, &external_irq_type, | 152 | if (((bcsr->whoami & BCSR_WHOAMI_CPLD) >> 4) <= 3) { |
153 | printk("\nWARNING!!!\n"); | ||
154 | printk("\nWARNING!!!\n"); | ||
155 | printk("\nWARNING!!!\n"); | ||
156 | printk("\nWARNING!!!\n"); | ||
157 | printk("\nWARNING!!!\n"); | ||
158 | printk("\nWARNING!!!\n"); | ||
159 | printk("Pb1200 must be at CPLD rev4. Please have Pb1200\n"); | ||
160 | printk("updated to latest revision. This software will not\n"); | ||
161 | printk("work on anything less than CPLD rev4\n"); | ||
162 | printk("\nWARNING!!!\n"); | ||
163 | printk("\nWARNING!!!\n"); | ||
164 | printk("\nWARNING!!!\n"); | ||
165 | printk("\nWARNING!!!\n"); | ||
166 | printk("\nWARNING!!!\n"); | ||
167 | printk("\nWARNING!!!\n"); | ||
168 | panic("Game over. Your score is 0."); | ||
169 | } | ||
170 | #endif | ||
171 | |||
172 | for (irq = PB1200_INT_BEGIN; irq <= PB1200_INT_END; irq++) { | ||
173 | set_irq_chip_and_handler(irq, &external_irq_type, | ||
163 | handle_level_irq); | 174 | handle_level_irq); |
164 | pb1200_disable_irq(irq_nr); | 175 | pb1200_disable_irq(irq); |
165 | } | 176 | } |
166 | 177 | ||
167 | /* GPIO_7 can not be hooked here, so it is hooked upon first | 178 | /* |
168 | request of any source attached to the cascade */ | 179 | * GPIO_7 can not be hooked here, so it is hooked upon first |
180 | * request of any source attached to the cascade | ||
181 | */ | ||
169 | } | 182 | } |
170 | |||
diff --git a/arch/mips/basler/excite/excite_setup.c b/arch/mips/basler/excite/excite_setup.c index 404ca9284b30..6dd8f0d46d09 100644 --- a/arch/mips/basler/excite/excite_setup.c +++ b/arch/mips/basler/excite/excite_setup.c | |||
@@ -68,24 +68,23 @@ DEFINE_SPINLOCK(titan_lock); | |||
68 | int titan_irqflags; | 68 | int titan_irqflags; |
69 | 69 | ||
70 | 70 | ||
71 | /* | ||
72 | * The eXcite platform uses the alternate timer interrupt | ||
73 | * | ||
74 | * Fixme: At the time of this writing cevt-r4k.c doesn't yet know about how | ||
75 | * to handle the alternate timer interrupt of the RM9000. | ||
76 | */ | ||
71 | void __init plat_time_init(void) | 77 | void __init plat_time_init(void) |
72 | { | 78 | { |
73 | const u32 modebit5 = ocd_readl(0x00e4); | 79 | const u32 modebit5 = ocd_readl(0x00e4); |
74 | unsigned int | 80 | unsigned int mult = ((modebit5 >> 11) & 0x1f) + 2; |
75 | mult = ((modebit5 >> 11) & 0x1f) + 2, | 81 | unsigned int div = ((modebit5 >> 16) & 0x1f) + 2; |
76 | div = ((modebit5 >> 16) & 0x1f) + 2; | ||
77 | 82 | ||
78 | if (div == 33) div = 1; | 83 | if (div == 33) |
84 | div = 1; | ||
79 | mips_hpt_frequency = EXCITE_CPU_EXT_CLOCK * mult / div / 2; | 85 | mips_hpt_frequency = EXCITE_CPU_EXT_CLOCK * mult / div / 2; |
80 | } | 86 | } |
81 | 87 | ||
82 | void __init plat_timer_setup(struct irqaction *irq) | ||
83 | { | ||
84 | /* The eXcite platform uses the alternate timer interrupt */ | ||
85 | set_c0_intcontrol(0x80); | ||
86 | setup_irq(TIMER_IRQ, irq); | ||
87 | } | ||
88 | |||
89 | static int __init excite_init_console(void) | 88 | static int __init excite_init_console(void) |
90 | { | 89 | { |
91 | #if defined(CONFIG_SERIAL_8250) | 90 | #if defined(CONFIG_SERIAL_8250) |
diff --git a/arch/mips/configs/db1000_defconfig b/arch/mips/configs/db1000_defconfig index 885b633647e9..5a8b7acb7dd7 100644 --- a/arch/mips/configs/db1000_defconfig +++ b/arch/mips/configs/db1000_defconfig | |||
@@ -738,7 +738,6 @@ CONFIG_HW_CONSOLE=y | |||
738 | CONFIG_VT_HW_CONSOLE_BINDING=y | 738 | CONFIG_VT_HW_CONSOLE_BINDING=y |
739 | # CONFIG_SERIAL_NONSTANDARD is not set | 739 | # CONFIG_SERIAL_NONSTANDARD is not set |
740 | # CONFIG_AU1X00_GPIO is not set | 740 | # CONFIG_AU1X00_GPIO is not set |
741 | # CONFIG_TS_AU1X00_ADS7846 is not set | ||
742 | 741 | ||
743 | # | 742 | # |
744 | # Serial drivers | 743 | # Serial drivers |
diff --git a/arch/mips/configs/db1100_defconfig b/arch/mips/configs/db1100_defconfig index e3c3a07e8a7c..d4ed90bca269 100644 --- a/arch/mips/configs/db1100_defconfig +++ b/arch/mips/configs/db1100_defconfig | |||
@@ -714,7 +714,6 @@ CONFIG_HW_CONSOLE=y | |||
714 | CONFIG_VT_HW_CONSOLE_BINDING=y | 714 | CONFIG_VT_HW_CONSOLE_BINDING=y |
715 | # CONFIG_SERIAL_NONSTANDARD is not set | 715 | # CONFIG_SERIAL_NONSTANDARD is not set |
716 | # CONFIG_AU1X00_GPIO is not set | 716 | # CONFIG_AU1X00_GPIO is not set |
717 | # CONFIG_TS_AU1X00_ADS7846 is not set | ||
718 | 717 | ||
719 | # | 718 | # |
720 | # Serial drivers | 719 | # Serial drivers |
diff --git a/arch/mips/configs/db1200_defconfig b/arch/mips/configs/db1200_defconfig index 9aa7c3ebfa3f..a055657e6983 100644 --- a/arch/mips/configs/db1200_defconfig +++ b/arch/mips/configs/db1200_defconfig | |||
@@ -775,7 +775,6 @@ CONFIG_HW_CONSOLE=y | |||
775 | CONFIG_VT_HW_CONSOLE_BINDING=y | 775 | CONFIG_VT_HW_CONSOLE_BINDING=y |
776 | # CONFIG_SERIAL_NONSTANDARD is not set | 776 | # CONFIG_SERIAL_NONSTANDARD is not set |
777 | # CONFIG_AU1X00_GPIO is not set | 777 | # CONFIG_AU1X00_GPIO is not set |
778 | # CONFIG_TS_AU1X00_ADS7846 is not set | ||
779 | 778 | ||
780 | # | 779 | # |
781 | # Serial drivers | 780 | # Serial drivers |
diff --git a/arch/mips/configs/db1500_defconfig b/arch/mips/configs/db1500_defconfig index 99240668bca1..0ad08cf446ec 100644 --- a/arch/mips/configs/db1500_defconfig +++ b/arch/mips/configs/db1500_defconfig | |||
@@ -811,7 +811,6 @@ CONFIG_SERIO_RAW=m | |||
811 | # CONFIG_VT is not set | 811 | # CONFIG_VT is not set |
812 | # CONFIG_SERIAL_NONSTANDARD is not set | 812 | # CONFIG_SERIAL_NONSTANDARD is not set |
813 | # CONFIG_AU1X00_GPIO is not set | 813 | # CONFIG_AU1X00_GPIO is not set |
814 | # CONFIG_TS_AU1X00_ADS7846 is not set | ||
815 | 814 | ||
816 | # | 815 | # |
817 | # Serial drivers | 816 | # Serial drivers |
diff --git a/arch/mips/configs/db1550_defconfig b/arch/mips/configs/db1550_defconfig index 19992f76c60d..057c7d429c80 100644 --- a/arch/mips/configs/db1550_defconfig +++ b/arch/mips/configs/db1550_defconfig | |||
@@ -856,7 +856,6 @@ CONFIG_SERIO_RAW=m | |||
856 | # CONFIG_VT is not set | 856 | # CONFIG_VT is not set |
857 | # CONFIG_SERIAL_NONSTANDARD is not set | 857 | # CONFIG_SERIAL_NONSTANDARD is not set |
858 | # CONFIG_AU1X00_GPIO is not set | 858 | # CONFIG_AU1X00_GPIO is not set |
859 | # CONFIG_TS_AU1X00_ADS7846 is not set | ||
860 | 859 | ||
861 | # | 860 | # |
862 | # Serial drivers | 861 | # Serial drivers |
diff --git a/arch/mips/configs/pb1100_defconfig b/arch/mips/configs/pb1100_defconfig index d53fa8f8e099..703d28db05b9 100644 --- a/arch/mips/configs/pb1100_defconfig +++ b/arch/mips/configs/pb1100_defconfig | |||
@@ -731,7 +731,6 @@ CONFIG_HW_CONSOLE=y | |||
731 | CONFIG_VT_HW_CONSOLE_BINDING=y | 731 | CONFIG_VT_HW_CONSOLE_BINDING=y |
732 | # CONFIG_SERIAL_NONSTANDARD is not set | 732 | # CONFIG_SERIAL_NONSTANDARD is not set |
733 | # CONFIG_AU1X00_GPIO is not set | 733 | # CONFIG_AU1X00_GPIO is not set |
734 | # CONFIG_TS_AU1X00_ADS7846 is not set | ||
735 | 734 | ||
736 | # | 735 | # |
737 | # Serial drivers | 736 | # Serial drivers |
diff --git a/arch/mips/configs/pb1500_defconfig b/arch/mips/configs/pb1500_defconfig index dc4aa0c66847..82f0c5cee0dc 100644 --- a/arch/mips/configs/pb1500_defconfig +++ b/arch/mips/configs/pb1500_defconfig | |||
@@ -849,7 +849,6 @@ CONFIG_SERIO_RAW=m | |||
849 | # CONFIG_VT is not set | 849 | # CONFIG_VT is not set |
850 | # CONFIG_SERIAL_NONSTANDARD is not set | 850 | # CONFIG_SERIAL_NONSTANDARD is not set |
851 | # CONFIG_AU1X00_GPIO is not set | 851 | # CONFIG_AU1X00_GPIO is not set |
852 | # CONFIG_TS_AU1X00_ADS7846 is not set | ||
853 | 852 | ||
854 | # | 853 | # |
855 | # Serial drivers | 854 | # Serial drivers |
diff --git a/arch/mips/configs/pb1550_defconfig b/arch/mips/configs/pb1550_defconfig index 24428e13002b..147a4fc7fdd8 100644 --- a/arch/mips/configs/pb1550_defconfig +++ b/arch/mips/configs/pb1550_defconfig | |||
@@ -842,7 +842,6 @@ CONFIG_SERIO_RAW=m | |||
842 | # CONFIG_VT is not set | 842 | # CONFIG_VT is not set |
843 | # CONFIG_SERIAL_NONSTANDARD is not set | 843 | # CONFIG_SERIAL_NONSTANDARD is not set |
844 | # CONFIG_AU1X00_GPIO is not set | 844 | # CONFIG_AU1X00_GPIO is not set |
845 | # CONFIG_TS_AU1X00_ADS7846 is not set | ||
846 | 845 | ||
847 | # | 846 | # |
848 | # Serial drivers | 847 | # Serial drivers |
diff --git a/arch/mips/configs/sb1250-swarm_defconfig b/arch/mips/configs/sb1250-swarm_defconfig index 49dfcef2518c..c2798229cbfb 100644 --- a/arch/mips/configs/sb1250-swarm_defconfig +++ b/arch/mips/configs/sb1250-swarm_defconfig | |||
@@ -468,7 +468,7 @@ CONFIG_BLK_DEV_IDEFLOPPY=y | |||
468 | # | 468 | # |
469 | CONFIG_IDE_GENERIC=y | 469 | CONFIG_IDE_GENERIC=y |
470 | # CONFIG_BLK_DEV_IDEPCI is not set | 470 | # CONFIG_BLK_DEV_IDEPCI is not set |
471 | # CONFIG_BLK_DEV_IDE_SWARM is not set | 471 | CONFIG_BLK_DEV_IDE_SWARM=y |
472 | # CONFIG_IDE_ARM is not set | 472 | # CONFIG_IDE_ARM is not set |
473 | # CONFIG_BLK_DEV_IDEDMA is not set | 473 | # CONFIG_BLK_DEV_IDEDMA is not set |
474 | # CONFIG_IDEDMA_AUTO is not set | 474 | # CONFIG_IDEDMA_AUTO is not set |
diff --git a/arch/mips/gt64120/wrppmc/time.c b/arch/mips/gt64120/wrppmc/time.c index b207e7f1417a..668dbd5f12c5 100644 --- a/arch/mips/gt64120/wrppmc/time.c +++ b/arch/mips/gt64120/wrppmc/time.c | |||
@@ -19,12 +19,6 @@ | |||
19 | 19 | ||
20 | #define WRPPMC_CPU_CLK_FREQ 40000000 /* 40MHZ */ | 20 | #define WRPPMC_CPU_CLK_FREQ 40000000 /* 40MHZ */ |
21 | 21 | ||
22 | void __init plat_timer_setup(struct irqaction *irq) | ||
23 | { | ||
24 | /* Install ISR for timer interrupt */ | ||
25 | setup_irq(WRPPMC_MIPS_TIMER_IRQ, irq); | ||
26 | } | ||
27 | |||
28 | /* | 22 | /* |
29 | * Estimate CPU frequency. Sets mips_hpt_frequency as a side-effect | 23 | * Estimate CPU frequency. Sets mips_hpt_frequency as a side-effect |
30 | * | 24 | * |
diff --git a/arch/mips/jazz/irq.c b/arch/mips/jazz/irq.c index ae25b480723e..d7f8a782aae4 100644 --- a/arch/mips/jazz/irq.c +++ b/arch/mips/jazz/irq.c | |||
@@ -97,9 +97,10 @@ asmlinkage void plat_irq_dispatch(void) | |||
97 | if (pending & IE_IRQ4) { | 97 | if (pending & IE_IRQ4) { |
98 | r4030_read_reg32(JAZZ_TIMER_REGISTER); | 98 | r4030_read_reg32(JAZZ_TIMER_REGISTER); |
99 | do_IRQ(JAZZ_TIMER_IRQ); | 99 | do_IRQ(JAZZ_TIMER_IRQ); |
100 | } else if (pending & IE_IRQ2) | 100 | } else if (pending & IE_IRQ2) { |
101 | do_IRQ(r4030_read_reg32(JAZZ_EISA_IRQ_ACK)); | 101 | irq = *(volatile u8 *)JAZZ_EISA_IRQ_ACK; |
102 | else if (pending & IE_IRQ1) { | 102 | do_IRQ(irq); |
103 | } else if (pending & IE_IRQ1) { | ||
103 | irq = *(volatile u8 *)JAZZ_IO_IRQ_SOURCE >> 2; | 104 | irq = *(volatile u8 *)JAZZ_IO_IRQ_SOURCE >> 2; |
104 | if (likely(irq > 0)) | 105 | if (likely(irq > 0)) |
105 | do_IRQ(irq + JAZZ_IRQ_START - 1); | 106 | do_IRQ(irq + JAZZ_IRQ_START - 1); |
@@ -117,16 +118,16 @@ static void r4030_set_mode(enum clock_event_mode mode, | |||
117 | struct clock_event_device r4030_clockevent = { | 118 | struct clock_event_device r4030_clockevent = { |
118 | .name = "r4030", | 119 | .name = "r4030", |
119 | .features = CLOCK_EVT_FEAT_PERIODIC, | 120 | .features = CLOCK_EVT_FEAT_PERIODIC, |
120 | .rating = 100, | 121 | .rating = 300, |
121 | .irq = JAZZ_TIMER_IRQ, | 122 | .irq = JAZZ_TIMER_IRQ, |
122 | .cpumask = CPU_MASK_CPU0, | ||
123 | .set_mode = r4030_set_mode, | 123 | .set_mode = r4030_set_mode, |
124 | }; | 124 | }; |
125 | 125 | ||
126 | static irqreturn_t r4030_timer_interrupt(int irq, void *dev_id) | 126 | static irqreturn_t r4030_timer_interrupt(int irq, void *dev_id) |
127 | { | 127 | { |
128 | r4030_clockevent.event_handler(&r4030_clockevent); | 128 | struct clock_event_device *cd = dev_id; |
129 | 129 | ||
130 | cd->event_handler(cd); | ||
130 | return IRQ_HANDLED; | 131 | return IRQ_HANDLED; |
131 | } | 132 | } |
132 | 133 | ||
@@ -134,15 +135,22 @@ static struct irqaction r4030_timer_irqaction = { | |||
134 | .handler = r4030_timer_interrupt, | 135 | .handler = r4030_timer_interrupt, |
135 | .flags = IRQF_DISABLED, | 136 | .flags = IRQF_DISABLED, |
136 | .mask = CPU_MASK_CPU0, | 137 | .mask = CPU_MASK_CPU0, |
137 | .name = "timer", | 138 | .name = "R4030 timer", |
138 | }; | 139 | }; |
139 | 140 | ||
140 | void __init plat_time_init(void) | 141 | void __init plat_time_init(void) |
141 | { | 142 | { |
142 | struct irqaction *irq = &r4030_timer_irqaction; | 143 | struct clock_event_device *cd = &r4030_clockevent; |
144 | struct irqaction *action = &r4030_timer_irqaction; | ||
145 | unsigned int cpu = smp_processor_id(); | ||
143 | 146 | ||
144 | BUG_ON(HZ != 100); | 147 | BUG_ON(HZ != 100); |
145 | 148 | ||
149 | cd->cpumask = cpumask_of_cpu(cpu); | ||
150 | clockevents_register_device(cd); | ||
151 | action->dev_id = cd; | ||
152 | setup_irq(JAZZ_TIMER_IRQ, action); | ||
153 | |||
146 | /* | 154 | /* |
147 | * Set clock to 100Hz. | 155 | * Set clock to 100Hz. |
148 | * | 156 | * |
@@ -150,8 +158,5 @@ void __init plat_time_init(void) | |||
150 | * a programmable 4-bit divider. This makes it fairly inflexible. | 158 | * a programmable 4-bit divider. This makes it fairly inflexible. |
151 | */ | 159 | */ |
152 | r4030_write_reg32(JAZZ_TIMER_INTERVAL, 9); | 160 | r4030_write_reg32(JAZZ_TIMER_INTERVAL, 9); |
153 | setup_irq(JAZZ_TIMER_IRQ, irq); | ||
154 | |||
155 | clockevents_register_device(&r4030_clockevent); | ||
156 | setup_pit_timer(); | 161 | setup_pit_timer(); |
157 | } | 162 | } |
diff --git a/arch/mips/jmr3927/rbhma3100/setup.c b/arch/mips/jmr3927/rbhma3100/setup.c index edb9e59248ec..06e01c8f4e3a 100644 --- a/arch/mips/jmr3927/rbhma3100/setup.c +++ b/arch/mips/jmr3927/rbhma3100/setup.c | |||
@@ -27,17 +27,13 @@ | |||
27 | * Copyright (C) 2007 Ralf Baechle (ralf@linux-mips.org) | 27 | * Copyright (C) 2007 Ralf Baechle (ralf@linux-mips.org) |
28 | */ | 28 | */ |
29 | 29 | ||
30 | #include <linux/clockchips.h> | ||
31 | #include <linux/init.h> | 30 | #include <linux/init.h> |
32 | #include <linux/kernel.h> | 31 | #include <linux/kernel.h> |
33 | #include <linux/kdev_t.h> | 32 | #include <linux/kdev_t.h> |
34 | #include <linux/types.h> | 33 | #include <linux/types.h> |
35 | #include <linux/sched.h> | ||
36 | #include <linux/pci.h> | 34 | #include <linux/pci.h> |
37 | #include <linux/ide.h> | 35 | #include <linux/ide.h> |
38 | #include <linux/irq.h> | ||
39 | #include <linux/ioport.h> | 36 | #include <linux/ioport.h> |
40 | #include <linux/param.h> /* for HZ */ | ||
41 | #include <linux/delay.h> | 37 | #include <linux/delay.h> |
42 | #include <linux/pm.h> | 38 | #include <linux/pm.h> |
43 | #include <linux/platform_device.h> | 39 | #include <linux/platform_device.h> |
@@ -48,17 +44,13 @@ | |||
48 | #endif | 44 | #endif |
49 | 45 | ||
50 | #include <asm/addrspace.h> | 46 | #include <asm/addrspace.h> |
51 | #include <asm/time.h> | 47 | #include <asm/txx9tmr.h> |
52 | #include <asm/reboot.h> | 48 | #include <asm/reboot.h> |
53 | #include <asm/jmr3927/jmr3927.h> | 49 | #include <asm/jmr3927/jmr3927.h> |
54 | #include <asm/mipsregs.h> | 50 | #include <asm/mipsregs.h> |
55 | 51 | ||
56 | extern void puts(const char *cp); | 52 | extern void puts(const char *cp); |
57 | 53 | ||
58 | /* Tick Timer divider */ | ||
59 | #define JMR3927_TIMER_CCD 0 /* 1/2 */ | ||
60 | #define JMR3927_TIMER_CLK (JMR3927_IMCLK / (2 << JMR3927_TIMER_CCD)) | ||
61 | |||
62 | /* don't enable - see errata */ | 54 | /* don't enable - see errata */ |
63 | static int jmr3927_ccfg_toeon; | 55 | static int jmr3927_ccfg_toeon; |
64 | 56 | ||
@@ -93,66 +85,12 @@ static void jmr3927_machine_power_off(void) | |||
93 | while (1); | 85 | while (1); |
94 | } | 86 | } |
95 | 87 | ||
96 | static cycle_t jmr3927_hpt_read(void) | ||
97 | { | ||
98 | /* We assume this function is called xtime_lock held. */ | ||
99 | return jiffies * (JMR3927_TIMER_CLK / HZ) + jmr3927_tmrptr->trr; | ||
100 | } | ||
101 | |||
102 | static void jmr3927_set_mode(enum clock_event_mode mode, | ||
103 | struct clock_event_device *evt) | ||
104 | { | ||
105 | /* Nothing to do here */ | ||
106 | } | ||
107 | |||
108 | struct clock_event_device jmr3927_clock_event_device = { | ||
109 | .name = "MIPS", | ||
110 | .features = CLOCK_EVT_FEAT_PERIODIC, | ||
111 | .shift = 32, | ||
112 | .rating = 300, | ||
113 | .cpumask = CPU_MASK_CPU0, | ||
114 | .irq = JMR3927_IRQ_TICK, | ||
115 | .set_mode = jmr3927_set_mode, | ||
116 | }; | ||
117 | |||
118 | static irqreturn_t jmr3927_timer_interrupt(int irq, void *dev_id) | ||
119 | { | ||
120 | struct clock_event_device *cd = &jmr3927_clock_event_device; | ||
121 | |||
122 | jmr3927_tmrptr->tisr = 0; /* ack interrupt */ | ||
123 | |||
124 | cd->event_handler(cd); | ||
125 | |||
126 | return IRQ_HANDLED; | ||
127 | } | ||
128 | |||
129 | static struct irqaction jmr3927_timer_irqaction = { | ||
130 | .handler = jmr3927_timer_interrupt, | ||
131 | .flags = IRQF_DISABLED | IRQF_PERCPU, | ||
132 | .name = "jmr3927-timer", | ||
133 | }; | ||
134 | |||
135 | void __init plat_time_init(void) | 88 | void __init plat_time_init(void) |
136 | { | 89 | { |
137 | struct clock_event_device *cd; | 90 | txx9_clockevent_init(TX3927_TMR_REG(0), |
138 | 91 | TXX9_IRQ_BASE + JMR3927_IRQ_IRC_TMR(0), | |
139 | clocksource_mips.read = jmr3927_hpt_read; | 92 | JMR3927_IMCLK); |
140 | mips_hpt_frequency = JMR3927_TIMER_CLK; | 93 | txx9_clocksource_init(TX3927_TMR_REG(1), JMR3927_IMCLK); |
141 | |||
142 | jmr3927_tmrptr->cpra = JMR3927_TIMER_CLK / HZ; | ||
143 | jmr3927_tmrptr->itmr = TXx927_TMTITMR_TIIE | TXx927_TMTITMR_TZCE; | ||
144 | jmr3927_tmrptr->ccdr = JMR3927_TIMER_CCD; | ||
145 | jmr3927_tmrptr->tcr = | ||
146 | TXx927_TMTCR_TCE | TXx927_TMTCR_CCDE | TXx927_TMTCR_TMODE_ITVL; | ||
147 | |||
148 | cd = &jmr3927_clock_event_device; | ||
149 | /* Calculate the min / max delta */ | ||
150 | cd->mult = div_sc((unsigned long) JMR3927_IMCLK, NSEC_PER_SEC, 32); | ||
151 | cd->max_delta_ns = clockevent_delta2ns(0x7fffffff, cd); | ||
152 | cd->min_delta_ns = clockevent_delta2ns(0x300, cd); | ||
153 | clockevents_register_device(cd); | ||
154 | |||
155 | setup_irq(JMR3927_IRQ_TICK, &jmr3927_timer_irqaction); | ||
156 | } | 94 | } |
157 | 95 | ||
158 | #define DO_WRITE_THROUGH | 96 | #define DO_WRITE_THROUGH |
@@ -317,15 +255,8 @@ static void __init tx3927_setup(void) | |||
317 | tx3927_ccfgptr->ccfg, tx3927_ccfgptr->pcfg); | 255 | tx3927_ccfgptr->ccfg, tx3927_ccfgptr->pcfg); |
318 | 256 | ||
319 | /* TMR */ | 257 | /* TMR */ |
320 | /* disable all timers */ | 258 | for (i = 0; i < TX3927_NR_TMR; i++) |
321 | for (i = 0; i < TX3927_NR_TMR; i++) { | 259 | txx9_tmr_init(TX3927_TMR_REG(i)); |
322 | tx3927_tmrptr(i)->tcr = TXx927_TMTCR_CRE; | ||
323 | tx3927_tmrptr(i)->tisr = 0; | ||
324 | tx3927_tmrptr(i)->cpra = 0xffffffff; | ||
325 | tx3927_tmrptr(i)->itmr = 0; | ||
326 | tx3927_tmrptr(i)->ccdr = 0; | ||
327 | tx3927_tmrptr(i)->pgmr = 0; | ||
328 | } | ||
329 | 260 | ||
330 | /* DMA */ | 261 | /* DMA */ |
331 | tx3927_dmaptr->mcr = 0; | 262 | tx3927_dmaptr->mcr = 0; |
diff --git a/arch/mips/kernel/Makefile b/arch/mips/kernel/Makefile index d7745c8976f6..b551535b7e48 100644 --- a/arch/mips/kernel/Makefile +++ b/arch/mips/kernel/Makefile | |||
@@ -8,8 +8,13 @@ obj-y += cpu-probe.o branch.o entry.o genex.o irq.o process.o \ | |||
8 | ptrace.o reset.o semaphore.o setup.o signal.o syscall.o \ | 8 | ptrace.o reset.o semaphore.o setup.o signal.o syscall.o \ |
9 | time.o topology.o traps.o unaligned.o | 9 | time.o topology.o traps.o unaligned.o |
10 | 10 | ||
11 | obj-$(CONFIG_CEVT_BCM1480) += cevt-bcm1480.o | ||
11 | obj-$(CONFIG_CEVT_R4K) += cevt-r4k.o | 12 | obj-$(CONFIG_CEVT_R4K) += cevt-r4k.o |
12 | obj-$(CONFIG_CEVT_GT641XX) += cevt-gt641xx.o | 13 | obj-$(CONFIG_CEVT_GT641XX) += cevt-gt641xx.o |
14 | obj-$(CONFIG_CEVT_SB1250) += cevt-sb1250.o | ||
15 | obj-$(CONFIG_CEVT_TXX9) += cevt-txx9.o | ||
16 | obj-$(CONFIG_CSRC_BCM1480) += csrc-bcm1480.o | ||
17 | obj-$(CONFIG_CSRC_SB1250) += csrc-sb1250.o | ||
13 | 18 | ||
14 | binfmt_irix-objs := irixelf.o irixinv.o irixioctl.o irixsig.o \ | 19 | binfmt_irix-objs := irixelf.o irixinv.o irixioctl.o irixsig.o \ |
15 | irix5sys.o sysirix.o | 20 | irix5sys.o sysirix.o |
diff --git a/arch/mips/kernel/cevt-bcm1480.c b/arch/mips/kernel/cevt-bcm1480.c new file mode 100644 index 000000000000..21e6d63eb4d1 --- /dev/null +++ b/arch/mips/kernel/cevt-bcm1480.c | |||
@@ -0,0 +1,149 @@ | |||
1 | /* | ||
2 | * Copyright (C) 2000,2001,2004 Broadcom Corporation | ||
3 | * | ||
4 | * This program is free software; you can redistribute it and/or | ||
5 | * modify it under the terms of the GNU General Public License | ||
6 | * as published by the Free Software Foundation; either version 2 | ||
7 | * of the License, or (at your option) any later version. | ||
8 | * | ||
9 | * This program is distributed in the hope that it will be useful, | ||
10 | * but WITHOUT ANY WARRANTY; without even the implied warranty of | ||
11 | * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the | ||
12 | * GNU General Public License for more details. | ||
13 | * | ||
14 | * You should have received a copy of the GNU General Public License | ||
15 | * along with this program; if not, write to the Free Software | ||
16 | * Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. | ||
17 | */ | ||
18 | #include <linux/clockchips.h> | ||
19 | #include <linux/interrupt.h> | ||
20 | #include <linux/percpu.h> | ||
21 | |||
22 | #include <asm/addrspace.h> | ||
23 | #include <asm/io.h> | ||
24 | #include <asm/time.h> | ||
25 | |||
26 | #include <asm/sibyte/bcm1480_regs.h> | ||
27 | #include <asm/sibyte/sb1250_regs.h> | ||
28 | #include <asm/sibyte/bcm1480_int.h> | ||
29 | #include <asm/sibyte/bcm1480_scd.h> | ||
30 | |||
31 | #include <asm/sibyte/sb1250.h> | ||
32 | |||
33 | #define IMR_IP2_VAL K_BCM1480_INT_MAP_I0 | ||
34 | #define IMR_IP3_VAL K_BCM1480_INT_MAP_I1 | ||
35 | #define IMR_IP4_VAL K_BCM1480_INT_MAP_I2 | ||
36 | |||
37 | /* | ||
38 | * The general purpose timer ticks at 1MHz independent if | ||
39 | * the rest of the system | ||
40 | */ | ||
41 | static void sibyte_set_mode(enum clock_event_mode mode, | ||
42 | struct clock_event_device *evt) | ||
43 | { | ||
44 | unsigned int cpu = smp_processor_id(); | ||
45 | void __iomem *cfg, *init; | ||
46 | |||
47 | cfg = IOADDR(A_SCD_TIMER_REGISTER(cpu, R_SCD_TIMER_CFG)); | ||
48 | init = IOADDR(A_SCD_TIMER_REGISTER(cpu, R_SCD_TIMER_INIT)); | ||
49 | |||
50 | switch (mode) { | ||
51 | case CLOCK_EVT_MODE_PERIODIC: | ||
52 | __raw_writeq(0, cfg); | ||
53 | __raw_writeq((V_SCD_TIMER_FREQ / HZ) - 1, init); | ||
54 | __raw_writeq(M_SCD_TIMER_ENABLE | M_SCD_TIMER_MODE_CONTINUOUS, | ||
55 | cfg); | ||
56 | break; | ||
57 | |||
58 | case CLOCK_EVT_MODE_ONESHOT: | ||
59 | /* Stop the timer until we actually program a shot */ | ||
60 | case CLOCK_EVT_MODE_SHUTDOWN: | ||
61 | __raw_writeq(0, cfg); | ||
62 | break; | ||
63 | |||
64 | case CLOCK_EVT_MODE_UNUSED: /* shuddup gcc */ | ||
65 | case CLOCK_EVT_MODE_RESUME: | ||
66 | ; | ||
67 | } | ||
68 | } | ||
69 | |||
70 | static int sibyte_next_event(unsigned long delta, struct clock_event_device *cd) | ||
71 | { | ||
72 | unsigned int cpu = smp_processor_id(); | ||
73 | void __iomem *cfg, *init; | ||
74 | |||
75 | cfg = IOADDR(A_SCD_TIMER_REGISTER(cpu, R_SCD_TIMER_CFG)); | ||
76 | init = IOADDR(A_SCD_TIMER_REGISTER(cpu, R_SCD_TIMER_INIT)); | ||
77 | |||
78 | __raw_writeq(delta - 1, init); | ||
79 | __raw_writeq(M_SCD_TIMER_ENABLE, cfg); | ||
80 | |||
81 | return 0; | ||
82 | } | ||
83 | |||
84 | static irqreturn_t sibyte_counter_handler(int irq, void *dev_id) | ||
85 | { | ||
86 | unsigned int cpu = smp_processor_id(); | ||
87 | struct clock_event_device *cd = dev_id; | ||
88 | void __iomem *cfg; | ||
89 | unsigned long tmode; | ||
90 | |||
91 | if (cd->mode == CLOCK_EVT_MODE_PERIODIC) | ||
92 | tmode = M_SCD_TIMER_ENABLE | M_SCD_TIMER_MODE_CONTINUOUS; | ||
93 | else | ||
94 | tmode = 0; | ||
95 | |||
96 | /* ACK interrupt */ | ||
97 | cfg = IOADDR(A_SCD_TIMER_REGISTER(cpu, R_SCD_TIMER_CFG)); | ||
98 | ____raw_writeq(tmode, cfg); | ||
99 | |||
100 | cd->event_handler(cd); | ||
101 | |||
102 | return IRQ_HANDLED; | ||
103 | } | ||
104 | |||
105 | static DEFINE_PER_CPU(struct clock_event_device, sibyte_hpt_clockevent); | ||
106 | static DEFINE_PER_CPU(struct irqaction, sibyte_hpt_irqaction); | ||
107 | static DEFINE_PER_CPU(char [18], sibyte_hpt_name); | ||
108 | |||
109 | void __cpuinit sb1480_clockevent_init(void) | ||
110 | { | ||
111 | unsigned int cpu = smp_processor_id(); | ||
112 | unsigned int irq = K_BCM1480_INT_TIMER_0 + cpu; | ||
113 | struct irqaction *action = &per_cpu(sibyte_hpt_irqaction, cpu); | ||
114 | struct clock_event_device *cd = &per_cpu(sibyte_hpt_clockevent, cpu); | ||
115 | unsigned char *name = per_cpu(sibyte_hpt_name, cpu); | ||
116 | |||
117 | BUG_ON(cpu > 3); /* Only have 4 general purpose timers */ | ||
118 | |||
119 | sprintf(name, "bcm1480-counter-%d", cpu); | ||
120 | cd->name = name; | ||
121 | cd->features = CLOCK_EVT_FEAT_PERIODIC | | ||
122 | CLOCK_EVT_FEAT_ONESHOT; | ||
123 | clockevent_set_clock(cd, V_SCD_TIMER_FREQ); | ||
124 | cd->max_delta_ns = clockevent_delta2ns(0x7fffff, cd); | ||
125 | cd->min_delta_ns = clockevent_delta2ns(1, cd); | ||
126 | cd->rating = 200; | ||
127 | cd->irq = irq; | ||
128 | cd->cpumask = cpumask_of_cpu(cpu); | ||
129 | cd->set_next_event = sibyte_next_event; | ||
130 | cd->set_mode = sibyte_set_mode; | ||
131 | clockevents_register_device(cd); | ||
132 | |||
133 | bcm1480_mask_irq(cpu, irq); | ||
134 | |||
135 | /* | ||
136 | * Map the timer interrupt to IP[4] of this cpu | ||
137 | */ | ||
138 | __raw_writeq(IMR_IP4_VAL, | ||
139 | IOADDR(A_BCM1480_IMR_REGISTER(cpu, | ||
140 | R_BCM1480_IMR_INTERRUPT_MAP_BASE_H) + (irq << 3))); | ||
141 | |||
142 | bcm1480_unmask_irq(cpu, irq); | ||
143 | |||
144 | action->handler = sibyte_counter_handler; | ||
145 | action->flags = IRQF_DISABLED | IRQF_PERCPU; | ||
146 | action->name = name; | ||
147 | action->dev_id = cd; | ||
148 | setup_irq(irq, action); | ||
149 | } | ||
diff --git a/arch/mips/kernel/cevt-gt641xx.c b/arch/mips/kernel/cevt-gt641xx.c index 4c651b2680f9..c36772631fe0 100644 --- a/arch/mips/kernel/cevt-gt641xx.c +++ b/arch/mips/kernel/cevt-gt641xx.c | |||
@@ -49,10 +49,9 @@ int gt641xx_timer0_state(void) | |||
49 | static int gt641xx_timer0_set_next_event(unsigned long delta, | 49 | static int gt641xx_timer0_set_next_event(unsigned long delta, |
50 | struct clock_event_device *evt) | 50 | struct clock_event_device *evt) |
51 | { | 51 | { |
52 | unsigned long flags; | ||
53 | u32 ctrl; | 52 | u32 ctrl; |
54 | 53 | ||
55 | spin_lock_irqsave(>641xx_timer_lock, flags); | 54 | spin_lock(>641xx_timer_lock); |
56 | 55 | ||
57 | ctrl = GT_READ(GT_TC_CONTROL_OFS); | 56 | ctrl = GT_READ(GT_TC_CONTROL_OFS); |
58 | ctrl &= ~(GT_TC_CONTROL_ENTC0_MSK | GT_TC_CONTROL_SELTC0_MSK); | 57 | ctrl &= ~(GT_TC_CONTROL_ENTC0_MSK | GT_TC_CONTROL_SELTC0_MSK); |
@@ -61,7 +60,7 @@ static int gt641xx_timer0_set_next_event(unsigned long delta, | |||
61 | GT_WRITE(GT_TC0_OFS, delta); | 60 | GT_WRITE(GT_TC0_OFS, delta); |
62 | GT_WRITE(GT_TC_CONTROL_OFS, ctrl); | 61 | GT_WRITE(GT_TC_CONTROL_OFS, ctrl); |
63 | 62 | ||
64 | spin_unlock_irqrestore(>641xx_timer_lock, flags); | 63 | spin_unlock(>641xx_timer_lock); |
65 | 64 | ||
66 | return 0; | 65 | return 0; |
67 | } | 66 | } |
@@ -69,10 +68,9 @@ static int gt641xx_timer0_set_next_event(unsigned long delta, | |||
69 | static void gt641xx_timer0_set_mode(enum clock_event_mode mode, | 68 | static void gt641xx_timer0_set_mode(enum clock_event_mode mode, |
70 | struct clock_event_device *evt) | 69 | struct clock_event_device *evt) |
71 | { | 70 | { |
72 | unsigned long flags; | ||
73 | u32 ctrl; | 71 | u32 ctrl; |
74 | 72 | ||
75 | spin_lock_irqsave(>641xx_timer_lock, flags); | 73 | spin_lock(>641xx_timer_lock); |
76 | 74 | ||
77 | ctrl = GT_READ(GT_TC_CONTROL_OFS); | 75 | ctrl = GT_READ(GT_TC_CONTROL_OFS); |
78 | ctrl &= ~(GT_TC_CONTROL_ENTC0_MSK | GT_TC_CONTROL_SELTC0_MSK); | 76 | ctrl &= ~(GT_TC_CONTROL_ENTC0_MSK | GT_TC_CONTROL_SELTC0_MSK); |
@@ -90,7 +88,7 @@ static void gt641xx_timer0_set_mode(enum clock_event_mode mode, | |||
90 | 88 | ||
91 | GT_WRITE(GT_TC_CONTROL_OFS, ctrl); | 89 | GT_WRITE(GT_TC_CONTROL_OFS, ctrl); |
92 | 90 | ||
93 | spin_unlock_irqrestore(>641xx_timer_lock, flags); | 91 | spin_unlock(>641xx_timer_lock); |
94 | } | 92 | } |
95 | 93 | ||
96 | static void gt641xx_timer0_event_handler(struct clock_event_device *dev) | 94 | static void gt641xx_timer0_event_handler(struct clock_event_device *dev) |
@@ -133,9 +131,9 @@ static int __init gt641xx_timer0_clockevent_init(void) | |||
133 | 131 | ||
134 | cd = >641xx_timer0_clockevent; | 132 | cd = >641xx_timer0_clockevent; |
135 | cd->rating = 200 + gt641xx_base_clock / 10000000; | 133 | cd->rating = 200 + gt641xx_base_clock / 10000000; |
134 | clockevent_set_clock(cd, gt641xx_base_clock); | ||
136 | cd->max_delta_ns = clockevent_delta2ns(0x7fffffff, cd); | 135 | cd->max_delta_ns = clockevent_delta2ns(0x7fffffff, cd); |
137 | cd->min_delta_ns = clockevent_delta2ns(0x300, cd); | 136 | cd->min_delta_ns = clockevent_delta2ns(0x300, cd); |
138 | clockevent_set_clock(cd, gt641xx_base_clock); | ||
139 | 137 | ||
140 | clockevents_register_device(>641xx_timer0_clockevent); | 138 | clockevents_register_device(>641xx_timer0_clockevent); |
141 | 139 | ||
diff --git a/arch/mips/kernel/cevt-r4k.c b/arch/mips/kernel/cevt-r4k.c index ae2984fff580..bab935a3d74b 100644 --- a/arch/mips/kernel/cevt-r4k.c +++ b/arch/mips/kernel/cevt-r4k.c | |||
@@ -28,7 +28,7 @@ static int mips_next_event(unsigned long delta, | |||
28 | cnt = read_c0_count(); | 28 | cnt = read_c0_count(); |
29 | cnt += delta; | 29 | cnt += delta; |
30 | write_c0_compare(cnt); | 30 | write_c0_compare(cnt); |
31 | res = ((long)(read_c0_count() - cnt ) > 0) ? -ETIME : 0; | 31 | res = ((int)(read_c0_count() - cnt) > 0) ? -ETIME : 0; |
32 | #ifdef CONFIG_MIPS_MT_SMTC | 32 | #ifdef CONFIG_MIPS_MT_SMTC |
33 | evpe(vpflags); | 33 | evpe(vpflags); |
34 | local_irq_restore(flags); | 34 | local_irq_restore(flags); |
@@ -179,7 +179,7 @@ static int c0_compare_int_pending(void) | |||
179 | 179 | ||
180 | static int c0_compare_int_usable(void) | 180 | static int c0_compare_int_usable(void) |
181 | { | 181 | { |
182 | const unsigned int delta = 0x300000; | 182 | unsigned int delta; |
183 | unsigned int cnt; | 183 | unsigned int cnt; |
184 | 184 | ||
185 | /* | 185 | /* |
@@ -192,11 +192,17 @@ static int c0_compare_int_usable(void) | |||
192 | return 0; | 192 | return 0; |
193 | } | 193 | } |
194 | 194 | ||
195 | cnt = read_c0_count(); | 195 | for (delta = 0x10; delta <= 0x400000; delta <<= 1) { |
196 | cnt += delta; | 196 | cnt = read_c0_count(); |
197 | write_c0_compare(cnt); | 197 | cnt += delta; |
198 | write_c0_compare(cnt); | ||
199 | irq_disable_hazard(); | ||
200 | if ((int)(read_c0_count() - cnt) < 0) | ||
201 | break; | ||
202 | /* increase delta if the timer was already expired */ | ||
203 | } | ||
198 | 204 | ||
199 | while ((long)(read_c0_count() - cnt) <= 0) | 205 | while ((int)(read_c0_count() - cnt) <= 0) |
200 | ; /* Wait for expiry */ | 206 | ; /* Wait for expiry */ |
201 | 207 | ||
202 | if (!c0_compare_int_pending()) | 208 | if (!c0_compare_int_pending()) |
@@ -218,9 +224,9 @@ void __cpuinit mips_clockevent_init(void) | |||
218 | uint64_t mips_freq = mips_hpt_frequency; | 224 | uint64_t mips_freq = mips_hpt_frequency; |
219 | unsigned int cpu = smp_processor_id(); | 225 | unsigned int cpu = smp_processor_id(); |
220 | struct clock_event_device *cd; | 226 | struct clock_event_device *cd; |
221 | unsigned int irq = MIPS_CPU_IRQ_BASE + 7; | 227 | unsigned int irq; |
222 | 228 | ||
223 | if (!cpu_has_counter) | 229 | if (!cpu_has_counter || !mips_hpt_frequency) |
224 | return; | 230 | return; |
225 | 231 | ||
226 | #ifdef CONFIG_MIPS_MT_SMTC | 232 | #ifdef CONFIG_MIPS_MT_SMTC |
@@ -237,6 +243,15 @@ void __cpuinit mips_clockevent_init(void) | |||
237 | if (!c0_compare_int_usable()) | 243 | if (!c0_compare_int_usable()) |
238 | return; | 244 | return; |
239 | 245 | ||
246 | /* | ||
247 | * With vectored interrupts things are getting platform specific. | ||
248 | * get_c0_compare_int is a hook to allow a platform to return the | ||
249 | * interrupt number of it's liking. | ||
250 | */ | ||
251 | irq = MIPS_CPU_IRQ_BASE + cp0_compare_irq; | ||
252 | if (get_c0_compare_int) | ||
253 | irq = get_c0_compare_int(); | ||
254 | |||
240 | cd = &per_cpu(mips_clockevent_device, cpu); | 255 | cd = &per_cpu(mips_clockevent_device, cpu); |
241 | 256 | ||
242 | cd->name = "MIPS"; | 257 | cd->name = "MIPS"; |
@@ -261,13 +276,15 @@ void __cpuinit mips_clockevent_init(void) | |||
261 | 276 | ||
262 | clockevents_register_device(cd); | 277 | clockevents_register_device(cd); |
263 | 278 | ||
264 | if (!cp0_timer_irq_installed) { | 279 | if (!cp0_timer_irq_installed) |
280 | return; | ||
281 | |||
282 | cp0_timer_irq_installed = 1; | ||
283 | |||
265 | #ifdef CONFIG_MIPS_MT_SMTC | 284 | #ifdef CONFIG_MIPS_MT_SMTC |
266 | #define CPUCTR_IMASKBIT (0x100 << cp0_compare_irq) | 285 | #define CPUCTR_IMASKBIT (0x100 << cp0_compare_irq) |
267 | setup_irq_smtc(irq, &c0_compare_irqaction, CPUCTR_IMASKBIT); | 286 | setup_irq_smtc(irq, &c0_compare_irqaction, CPUCTR_IMASKBIT); |
268 | #else | 287 | #else |
269 | setup_irq(irq, &c0_compare_irqaction); | 288 | setup_irq(irq, &c0_compare_irqaction); |
270 | #endif /* CONFIG_MIPS_MT_SMTC */ | 289 | #endif |
271 | cp0_timer_irq_installed = 1; | ||
272 | } | ||
273 | } | 290 | } |
diff --git a/arch/mips/kernel/cevt-sb1250.c b/arch/mips/kernel/cevt-sb1250.c new file mode 100644 index 000000000000..e2029d0fc39b --- /dev/null +++ b/arch/mips/kernel/cevt-sb1250.c | |||
@@ -0,0 +1,148 @@ | |||
1 | /* | ||
2 | * Copyright (C) 2000, 2001 Broadcom Corporation | ||
3 | * | ||
4 | * This program is free software; you can redistribute it and/or | ||
5 | * modify it under the terms of the GNU General Public License | ||
6 | * as published by the Free Software Foundation; either version 2 | ||
7 | * of the License, or (at your option) any later version. | ||
8 | * | ||
9 | * This program is distributed in the hope that it will be useful, | ||
10 | * but WITHOUT ANY WARRANTY; without even the implied warranty of | ||
11 | * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the | ||
12 | * GNU General Public License for more details. | ||
13 | * | ||
14 | * You should have received a copy of the GNU General Public License | ||
15 | * along with this program; if not, write to the Free Software | ||
16 | * Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. | ||
17 | */ | ||
18 | #include <linux/clockchips.h> | ||
19 | #include <linux/interrupt.h> | ||
20 | #include <linux/percpu.h> | ||
21 | |||
22 | #include <asm/addrspace.h> | ||
23 | #include <asm/io.h> | ||
24 | #include <asm/time.h> | ||
25 | |||
26 | #include <asm/sibyte/sb1250.h> | ||
27 | #include <asm/sibyte/sb1250_regs.h> | ||
28 | #include <asm/sibyte/sb1250_int.h> | ||
29 | #include <asm/sibyte/sb1250_scd.h> | ||
30 | |||
31 | #define IMR_IP2_VAL K_INT_MAP_I0 | ||
32 | #define IMR_IP3_VAL K_INT_MAP_I1 | ||
33 | #define IMR_IP4_VAL K_INT_MAP_I2 | ||
34 | |||
35 | /* | ||
36 | * The general purpose timer ticks at 1MHz independent if | ||
37 | * the rest of the system | ||
38 | */ | ||
39 | static void sibyte_set_mode(enum clock_event_mode mode, | ||
40 | struct clock_event_device *evt) | ||
41 | { | ||
42 | unsigned int cpu = smp_processor_id(); | ||
43 | void __iomem *cfg, *init; | ||
44 | |||
45 | cfg = IOADDR(A_SCD_TIMER_REGISTER(cpu, R_SCD_TIMER_CFG)); | ||
46 | init = IOADDR(A_SCD_TIMER_REGISTER(cpu, R_SCD_TIMER_INIT)); | ||
47 | |||
48 | switch (mode) { | ||
49 | case CLOCK_EVT_MODE_PERIODIC: | ||
50 | __raw_writeq(0, cfg); | ||
51 | __raw_writeq((V_SCD_TIMER_FREQ / HZ) - 1, init); | ||
52 | __raw_writeq(M_SCD_TIMER_ENABLE | M_SCD_TIMER_MODE_CONTINUOUS, | ||
53 | cfg); | ||
54 | break; | ||
55 | |||
56 | case CLOCK_EVT_MODE_ONESHOT: | ||
57 | /* Stop the timer until we actually program a shot */ | ||
58 | case CLOCK_EVT_MODE_SHUTDOWN: | ||
59 | __raw_writeq(0, cfg); | ||
60 | break; | ||
61 | |||
62 | case CLOCK_EVT_MODE_UNUSED: /* shuddup gcc */ | ||
63 | case CLOCK_EVT_MODE_RESUME: | ||
64 | ; | ||
65 | } | ||
66 | } | ||
67 | |||
68 | static int sibyte_next_event(unsigned long delta, struct clock_event_device *cd) | ||
69 | { | ||
70 | unsigned int cpu = smp_processor_id(); | ||
71 | void __iomem *cfg, *init; | ||
72 | |||
73 | cfg = IOADDR(A_SCD_TIMER_REGISTER(cpu, R_SCD_TIMER_CFG)); | ||
74 | init = IOADDR(A_SCD_TIMER_REGISTER(cpu, R_SCD_TIMER_INIT)); | ||
75 | |||
76 | __raw_writeq(delta - 1, init); | ||
77 | __raw_writeq(M_SCD_TIMER_ENABLE, cfg); | ||
78 | |||
79 | return 0; | ||
80 | } | ||
81 | |||
82 | static irqreturn_t sibyte_counter_handler(int irq, void *dev_id) | ||
83 | { | ||
84 | unsigned int cpu = smp_processor_id(); | ||
85 | struct clock_event_device *cd = dev_id; | ||
86 | void __iomem *cfg; | ||
87 | unsigned long tmode; | ||
88 | |||
89 | if (cd->mode == CLOCK_EVT_MODE_PERIODIC) | ||
90 | tmode = M_SCD_TIMER_ENABLE | M_SCD_TIMER_MODE_CONTINUOUS; | ||
91 | else | ||
92 | tmode = 0; | ||
93 | |||
94 | /* ACK interrupt */ | ||
95 | cfg = IOADDR(A_SCD_TIMER_REGISTER(cpu, R_SCD_TIMER_CFG)); | ||
96 | ____raw_writeq(tmode, cfg); | ||
97 | |||
98 | cd->event_handler(cd); | ||
99 | |||
100 | return IRQ_HANDLED; | ||
101 | } | ||
102 | |||
103 | static DEFINE_PER_CPU(struct clock_event_device, sibyte_hpt_clockevent); | ||
104 | static DEFINE_PER_CPU(struct irqaction, sibyte_hpt_irqaction); | ||
105 | static DEFINE_PER_CPU(char [18], sibyte_hpt_name); | ||
106 | |||
107 | void __cpuinit sb1250_clockevent_init(void) | ||
108 | { | ||
109 | unsigned int cpu = smp_processor_id(); | ||
110 | unsigned int irq = K_INT_TIMER_0 + cpu; | ||
111 | struct irqaction *action = &per_cpu(sibyte_hpt_irqaction, cpu); | ||
112 | struct clock_event_device *cd = &per_cpu(sibyte_hpt_clockevent, cpu); | ||
113 | unsigned char *name = per_cpu(sibyte_hpt_name, cpu); | ||
114 | |||
115 | /* Only have 4 general purpose timers, and we use last one as hpt */ | ||
116 | BUG_ON(cpu > 2); | ||
117 | |||
118 | sprintf(name, "sb1250-counter-%d", cpu); | ||
119 | cd->name = name; | ||
120 | cd->features = CLOCK_EVT_FEAT_PERIODIC | | ||
121 | CLOCK_EVT_FEAT_ONESHOT; | ||
122 | clockevent_set_clock(cd, V_SCD_TIMER_FREQ); | ||
123 | cd->max_delta_ns = clockevent_delta2ns(0x7fffff, cd); | ||
124 | cd->min_delta_ns = clockevent_delta2ns(1, cd); | ||
125 | cd->rating = 200; | ||
126 | cd->irq = irq; | ||
127 | cd->cpumask = cpumask_of_cpu(cpu); | ||
128 | cd->set_next_event = sibyte_next_event; | ||
129 | cd->set_mode = sibyte_set_mode; | ||
130 | clockevents_register_device(cd); | ||
131 | |||
132 | sb1250_mask_irq(cpu, irq); | ||
133 | |||
134 | /* | ||
135 | * Map the timer interrupt to IP[4] of this cpu | ||
136 | */ | ||
137 | __raw_writeq(IMR_IP4_VAL, | ||
138 | IOADDR(A_IMR_REGISTER(cpu, R_IMR_INTERRUPT_MAP_BASE) + | ||
139 | (irq << 3))); | ||
140 | |||
141 | sb1250_unmask_irq(cpu, irq); | ||
142 | |||
143 | action->handler = sibyte_counter_handler; | ||
144 | action->flags = IRQF_DISABLED | IRQF_PERCPU; | ||
145 | action->name = name; | ||
146 | action->dev_id = cd; | ||
147 | setup_irq(irq, action); | ||
148 | } | ||
diff --git a/arch/mips/kernel/cevt-txx9.c b/arch/mips/kernel/cevt-txx9.c new file mode 100644 index 000000000000..795cb8fb0d74 --- /dev/null +++ b/arch/mips/kernel/cevt-txx9.c | |||
@@ -0,0 +1,171 @@ | |||
1 | /* | ||
2 | * This file is subject to the terms and conditions of the GNU General Public | ||
3 | * License. See the file "COPYING" in the main directory of this archive | ||
4 | * for more details. | ||
5 | * | ||
6 | * Based on linux/arch/mips/kernel/cevt-r4k.c, | ||
7 | * linux/arch/mips/jmr3927/rbhma3100/setup.c | ||
8 | * | ||
9 | * Copyright 2001 MontaVista Software Inc. | ||
10 | * Copyright (C) 2000-2001 Toshiba Corporation | ||
11 | * Copyright (C) 2007 MIPS Technologies, Inc. | ||
12 | * Copyright (C) 2007 Ralf Baechle <ralf@linux-mips.org> | ||
13 | */ | ||
14 | #include <linux/init.h> | ||
15 | #include <linux/interrupt.h> | ||
16 | #include <asm/time.h> | ||
17 | #include <asm/txx9tmr.h> | ||
18 | |||
19 | #define TCR_BASE (TXx9_TMTCR_CCDE | TXx9_TMTCR_CRE | TXx9_TMTCR_TMODE_ITVL) | ||
20 | #define TIMER_CCD 0 /* 1/2 */ | ||
21 | #define TIMER_CLK(imclk) ((imclk) / (2 << TIMER_CCD)) | ||
22 | |||
23 | static struct txx9_tmr_reg __iomem *txx9_cs_tmrptr; | ||
24 | |||
25 | static cycle_t txx9_cs_read(void) | ||
26 | { | ||
27 | return __raw_readl(&txx9_cs_tmrptr->trr); | ||
28 | } | ||
29 | |||
30 | /* Use 1 bit smaller width to use full bits in that width */ | ||
31 | #define TXX9_CLOCKSOURCE_BITS (TXX9_TIMER_BITS - 1) | ||
32 | |||
33 | static struct clocksource txx9_clocksource = { | ||
34 | .name = "TXx9", | ||
35 | .rating = 200, | ||
36 | .read = txx9_cs_read, | ||
37 | .mask = CLOCKSOURCE_MASK(TXX9_CLOCKSOURCE_BITS), | ||
38 | .flags = CLOCK_SOURCE_IS_CONTINUOUS, | ||
39 | }; | ||
40 | |||
41 | void __init txx9_clocksource_init(unsigned long baseaddr, | ||
42 | unsigned int imbusclk) | ||
43 | { | ||
44 | struct txx9_tmr_reg __iomem *tmrptr; | ||
45 | |||
46 | clocksource_set_clock(&txx9_clocksource, TIMER_CLK(imbusclk)); | ||
47 | clocksource_register(&txx9_clocksource); | ||
48 | |||
49 | tmrptr = ioremap(baseaddr, sizeof(struct txx9_tmr_reg)); | ||
50 | __raw_writel(TCR_BASE, &tmrptr->tcr); | ||
51 | __raw_writel(0, &tmrptr->tisr); | ||
52 | __raw_writel(TIMER_CCD, &tmrptr->ccdr); | ||
53 | __raw_writel(TXx9_TMITMR_TZCE, &tmrptr->itmr); | ||
54 | __raw_writel(1 << TXX9_CLOCKSOURCE_BITS, &tmrptr->cpra); | ||
55 | __raw_writel(TCR_BASE | TXx9_TMTCR_TCE, &tmrptr->tcr); | ||
56 | txx9_cs_tmrptr = tmrptr; | ||
57 | } | ||
58 | |||
59 | static struct txx9_tmr_reg __iomem *txx9_tmrptr; | ||
60 | |||
61 | static void txx9tmr_stop_and_clear(struct txx9_tmr_reg __iomem *tmrptr) | ||
62 | { | ||
63 | /* stop and reset counter */ | ||
64 | __raw_writel(TCR_BASE, &tmrptr->tcr); | ||
65 | /* clear pending interrupt */ | ||
66 | __raw_writel(0, &tmrptr->tisr); | ||
67 | } | ||
68 | |||
69 | static void txx9tmr_set_mode(enum clock_event_mode mode, | ||
70 | struct clock_event_device *evt) | ||
71 | { | ||
72 | struct txx9_tmr_reg __iomem *tmrptr = txx9_tmrptr; | ||
73 | |||
74 | txx9tmr_stop_and_clear(tmrptr); | ||
75 | switch (mode) { | ||
76 | case CLOCK_EVT_MODE_PERIODIC: | ||
77 | __raw_writel(TXx9_TMITMR_TIIE | TXx9_TMITMR_TZCE, | ||
78 | &tmrptr->itmr); | ||
79 | /* start timer */ | ||
80 | __raw_writel(((u64)(NSEC_PER_SEC / HZ) * evt->mult) >> | ||
81 | evt->shift, | ||
82 | &tmrptr->cpra); | ||
83 | __raw_writel(TCR_BASE | TXx9_TMTCR_TCE, &tmrptr->tcr); | ||
84 | break; | ||
85 | case CLOCK_EVT_MODE_SHUTDOWN: | ||
86 | case CLOCK_EVT_MODE_UNUSED: | ||
87 | __raw_writel(0, &tmrptr->itmr); | ||
88 | break; | ||
89 | case CLOCK_EVT_MODE_ONESHOT: | ||
90 | __raw_writel(TXx9_TMITMR_TIIE, &tmrptr->itmr); | ||
91 | break; | ||
92 | case CLOCK_EVT_MODE_RESUME: | ||
93 | __raw_writel(TIMER_CCD, &tmrptr->ccdr); | ||
94 | __raw_writel(0, &tmrptr->itmr); | ||
95 | break; | ||
96 | } | ||
97 | } | ||
98 | |||
99 | static int txx9tmr_set_next_event(unsigned long delta, | ||
100 | struct clock_event_device *evt) | ||
101 | { | ||
102 | struct txx9_tmr_reg __iomem *tmrptr = txx9_tmrptr; | ||
103 | |||
104 | txx9tmr_stop_and_clear(tmrptr); | ||
105 | /* start timer */ | ||
106 | __raw_writel(delta, &tmrptr->cpra); | ||
107 | __raw_writel(TCR_BASE | TXx9_TMTCR_TCE, &tmrptr->tcr); | ||
108 | return 0; | ||
109 | } | ||
110 | |||
111 | static struct clock_event_device txx9tmr_clock_event_device = { | ||
112 | .name = "TXx9", | ||
113 | .features = CLOCK_EVT_FEAT_PERIODIC | CLOCK_EVT_FEAT_ONESHOT, | ||
114 | .rating = 200, | ||
115 | .cpumask = CPU_MASK_CPU0, | ||
116 | .set_mode = txx9tmr_set_mode, | ||
117 | .set_next_event = txx9tmr_set_next_event, | ||
118 | }; | ||
119 | |||
120 | static irqreturn_t txx9tmr_interrupt(int irq, void *dev_id) | ||
121 | { | ||
122 | struct clock_event_device *cd = &txx9tmr_clock_event_device; | ||
123 | struct txx9_tmr_reg __iomem *tmrptr = txx9_tmrptr; | ||
124 | |||
125 | __raw_writel(0, &tmrptr->tisr); /* ack interrupt */ | ||
126 | cd->event_handler(cd); | ||
127 | return IRQ_HANDLED; | ||
128 | } | ||
129 | |||
130 | static struct irqaction txx9tmr_irq = { | ||
131 | .handler = txx9tmr_interrupt, | ||
132 | .flags = IRQF_DISABLED | IRQF_PERCPU, | ||
133 | .name = "txx9tmr", | ||
134 | }; | ||
135 | |||
136 | void __init txx9_clockevent_init(unsigned long baseaddr, int irq, | ||
137 | unsigned int imbusclk) | ||
138 | { | ||
139 | struct clock_event_device *cd = &txx9tmr_clock_event_device; | ||
140 | struct txx9_tmr_reg __iomem *tmrptr; | ||
141 | |||
142 | tmrptr = ioremap(baseaddr, sizeof(struct txx9_tmr_reg)); | ||
143 | txx9tmr_stop_and_clear(tmrptr); | ||
144 | __raw_writel(TIMER_CCD, &tmrptr->ccdr); | ||
145 | __raw_writel(0, &tmrptr->itmr); | ||
146 | txx9_tmrptr = tmrptr; | ||
147 | |||
148 | clockevent_set_clock(cd, TIMER_CLK(imbusclk)); | ||
149 | cd->max_delta_ns = | ||
150 | clockevent_delta2ns(0xffffffff >> (32 - TXX9_TIMER_BITS), cd); | ||
151 | cd->min_delta_ns = clockevent_delta2ns(0xf, cd); | ||
152 | cd->irq = irq; | ||
153 | clockevents_register_device(cd); | ||
154 | setup_irq(irq, &txx9tmr_irq); | ||
155 | printk(KERN_INFO "TXx9: clockevent device at 0x%lx, irq %d\n", | ||
156 | baseaddr, irq); | ||
157 | } | ||
158 | |||
159 | void __init txx9_tmr_init(unsigned long baseaddr) | ||
160 | { | ||
161 | struct txx9_tmr_reg __iomem *tmrptr; | ||
162 | |||
163 | tmrptr = ioremap(baseaddr, sizeof(struct txx9_tmr_reg)); | ||
164 | __raw_writel(TXx9_TMTCR_CRE, &tmrptr->tcr); | ||
165 | __raw_writel(0, &tmrptr->tisr); | ||
166 | __raw_writel(0xffffffff, &tmrptr->cpra); | ||
167 | __raw_writel(0, &tmrptr->itmr); | ||
168 | __raw_writel(0, &tmrptr->ccdr); | ||
169 | __raw_writel(0, &tmrptr->pgmr); | ||
170 | iounmap(tmrptr); | ||
171 | } | ||
diff --git a/arch/mips/kernel/csrc-bcm1480.c b/arch/mips/kernel/csrc-bcm1480.c new file mode 100644 index 000000000000..868745e7184b --- /dev/null +++ b/arch/mips/kernel/csrc-bcm1480.c | |||
@@ -0,0 +1,54 @@ | |||
1 | /* | ||
2 | * Copyright (C) 2000,2001,2004 Broadcom Corporation | ||
3 | * | ||
4 | * This program is free software; you can redistribute it and/or | ||
5 | * modify it under the terms of the GNU General Public License | ||
6 | * as published by the Free Software Foundation; either version 2 | ||
7 | * of the License, or (at your option) any later version. | ||
8 | * | ||
9 | * This program is distributed in the hope that it will be useful, | ||
10 | * but WITHOUT ANY WARRANTY; without even the implied warranty of | ||
11 | * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the | ||
12 | * GNU General Public License for more details. | ||
13 | * | ||
14 | * You should have received a copy of the GNU General Public License | ||
15 | * along with this program; if not, write to the Free Software | ||
16 | * Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. | ||
17 | */ | ||
18 | #include <linux/clocksource.h> | ||
19 | |||
20 | #include <asm/addrspace.h> | ||
21 | #include <asm/io.h> | ||
22 | #include <asm/time.h> | ||
23 | |||
24 | #include <asm/sibyte/bcm1480_regs.h> | ||
25 | #include <asm/sibyte/sb1250_regs.h> | ||
26 | #include <asm/sibyte/bcm1480_int.h> | ||
27 | #include <asm/sibyte/bcm1480_scd.h> | ||
28 | |||
29 | #include <asm/sibyte/sb1250.h> | ||
30 | |||
31 | static cycle_t bcm1480_hpt_read(void) | ||
32 | { | ||
33 | return (cycle_t) __raw_readq(IOADDR(A_SCD_ZBBUS_CYCLE_COUNT)); | ||
34 | } | ||
35 | |||
36 | struct clocksource bcm1480_clocksource = { | ||
37 | .name = "zbbus-cycles", | ||
38 | .rating = 200, | ||
39 | .read = bcm1480_hpt_read, | ||
40 | .mask = CLOCKSOURCE_MASK(64), | ||
41 | .flags = CLOCK_SOURCE_IS_CONTINUOUS, | ||
42 | }; | ||
43 | |||
44 | void __init sb1480_clocksource_init(void) | ||
45 | { | ||
46 | struct clocksource *cs = &bcm1480_clocksource; | ||
47 | unsigned int plldiv; | ||
48 | unsigned long zbbus; | ||
49 | |||
50 | plldiv = G_BCM1480_SYS_PLL_DIV(__raw_readq(IOADDR(A_SCD_SYSTEM_CFG))); | ||
51 | zbbus = ((plldiv >> 1) * 50000000) + ((plldiv & 1) * 25000000); | ||
52 | clocksource_set_clock(cs, zbbus); | ||
53 | clocksource_register(cs); | ||
54 | } | ||
diff --git a/arch/mips/kernel/csrc-sb1250.c b/arch/mips/kernel/csrc-sb1250.c new file mode 100644 index 000000000000..ebb16e668877 --- /dev/null +++ b/arch/mips/kernel/csrc-sb1250.c | |||
@@ -0,0 +1,70 @@ | |||
1 | /* | ||
2 | * Copyright (C) 2000, 2001 Broadcom Corporation | ||
3 | * | ||
4 | * This program is free software; you can redistribute it and/or | ||
5 | * modify it under the terms of the GNU General Public License | ||
6 | * as published by the Free Software Foundation; either version 2 | ||
7 | * of the License, or (at your option) any later version. | ||
8 | * | ||
9 | * This program is distributed in the hope that it will be useful, | ||
10 | * but WITHOUT ANY WARRANTY; without even the implied warranty of | ||
11 | * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the | ||
12 | * GNU General Public License for more details. | ||
13 | * | ||
14 | * You should have received a copy of the GNU General Public License | ||
15 | * along with this program; if not, write to the Free Software | ||
16 | * Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. | ||
17 | */ | ||
18 | #include <linux/clocksource.h> | ||
19 | |||
20 | #include <asm/addrspace.h> | ||
21 | #include <asm/io.h> | ||
22 | #include <asm/time.h> | ||
23 | |||
24 | #include <asm/sibyte/sb1250.h> | ||
25 | #include <asm/sibyte/sb1250_regs.h> | ||
26 | #include <asm/sibyte/sb1250_int.h> | ||
27 | #include <asm/sibyte/sb1250_scd.h> | ||
28 | |||
29 | #define SB1250_HPT_NUM 3 | ||
30 | #define SB1250_HPT_VALUE M_SCD_TIMER_CNT /* max value */ | ||
31 | |||
32 | /* | ||
33 | * The HPT is free running from SB1250_HPT_VALUE down to 0 then starts over | ||
34 | * again. | ||
35 | */ | ||
36 | static cycle_t sb1250_hpt_read(void) | ||
37 | { | ||
38 | unsigned int count; | ||
39 | |||
40 | count = G_SCD_TIMER_CNT(__raw_readq(IOADDR(A_SCD_TIMER_REGISTER(SB1250_HPT_NUM, R_SCD_TIMER_CNT)))); | ||
41 | |||
42 | return SB1250_HPT_VALUE - count; | ||
43 | } | ||
44 | |||
45 | struct clocksource bcm1250_clocksource = { | ||
46 | .name = "MIPS", | ||
47 | .rating = 200, | ||
48 | .read = sb1250_hpt_read, | ||
49 | .mask = CLOCKSOURCE_MASK(23), | ||
50 | .flags = CLOCK_SOURCE_IS_CONTINUOUS, | ||
51 | }; | ||
52 | |||
53 | void __init sb1250_clocksource_init(void) | ||
54 | { | ||
55 | struct clocksource *cs = &bcm1250_clocksource; | ||
56 | |||
57 | /* Setup hpt using timer #3 but do not enable irq for it */ | ||
58 | __raw_writeq(0, | ||
59 | IOADDR(A_SCD_TIMER_REGISTER(SB1250_HPT_NUM, | ||
60 | R_SCD_TIMER_CFG))); | ||
61 | __raw_writeq(SB1250_HPT_VALUE, | ||
62 | IOADDR(A_SCD_TIMER_REGISTER(SB1250_HPT_NUM, | ||
63 | R_SCD_TIMER_INIT))); | ||
64 | __raw_writeq(M_SCD_TIMER_ENABLE | M_SCD_TIMER_MODE_CONTINUOUS, | ||
65 | IOADDR(A_SCD_TIMER_REGISTER(SB1250_HPT_NUM, | ||
66 | R_SCD_TIMER_CFG))); | ||
67 | |||
68 | clocksource_set_clock(cs, V_SCD_TIMER_FREQ); | ||
69 | clocksource_register(cs); | ||
70 | } | ||
diff --git a/arch/mips/kernel/i8253.c b/arch/mips/kernel/i8253.c index 5d9830df3595..c2d497ceffdd 100644 --- a/arch/mips/kernel/i8253.c +++ b/arch/mips/kernel/i8253.c | |||
@@ -12,8 +12,9 @@ | |||
12 | #include <asm/delay.h> | 12 | #include <asm/delay.h> |
13 | #include <asm/i8253.h> | 13 | #include <asm/i8253.h> |
14 | #include <asm/io.h> | 14 | #include <asm/io.h> |
15 | #include <asm/time.h> | ||
15 | 16 | ||
16 | static DEFINE_SPINLOCK(i8253_lock); | 17 | DEFINE_SPINLOCK(i8253_lock); |
17 | 18 | ||
18 | /* | 19 | /* |
19 | * Initialize the PIT timer. | 20 | * Initialize the PIT timer. |
@@ -87,11 +88,10 @@ struct clock_event_device pit_clockevent = { | |||
87 | .features = CLOCK_EVT_FEAT_PERIODIC | CLOCK_EVT_FEAT_ONESHOT, | 88 | .features = CLOCK_EVT_FEAT_PERIODIC | CLOCK_EVT_FEAT_ONESHOT, |
88 | .set_mode = init_pit_timer, | 89 | .set_mode = init_pit_timer, |
89 | .set_next_event = pit_next_event, | 90 | .set_next_event = pit_next_event, |
90 | .shift = 32, | ||
91 | .irq = 0, | 91 | .irq = 0, |
92 | }; | 92 | }; |
93 | 93 | ||
94 | irqreturn_t timer_interrupt(int irq, void *dev_id) | 94 | static irqreturn_t timer_interrupt(int irq, void *dev_id) |
95 | { | 95 | { |
96 | pit_clockevent.event_handler(&pit_clockevent); | 96 | pit_clockevent.event_handler(&pit_clockevent); |
97 | 97 | ||
@@ -111,19 +111,20 @@ static struct irqaction irq0 = { | |||
111 | */ | 111 | */ |
112 | void __init setup_pit_timer(void) | 112 | void __init setup_pit_timer(void) |
113 | { | 113 | { |
114 | struct clock_event_device *cd = &pit_clockevent; | ||
115 | unsigned int cpu = smp_processor_id(); | ||
116 | |||
114 | /* | 117 | /* |
115 | * Start pit with the boot cpu mask and make it global after the | 118 | * Start pit with the boot cpu mask and make it global after the |
116 | * IO_APIC has been initialized. | 119 | * IO_APIC has been initialized. |
117 | */ | 120 | */ |
118 | pit_clockevent.cpumask = cpumask_of_cpu(0); | 121 | cd->cpumask = cpumask_of_cpu(cpu); |
119 | pit_clockevent.mult = div_sc(CLOCK_TICK_RATE, NSEC_PER_SEC, 32); | 122 | clockevent_set_clock(cd, CLOCK_TICK_RATE); |
120 | pit_clockevent.max_delta_ns = | 123 | cd->max_delta_ns = clockevent_delta2ns(0x7FFF, cd); |
121 | clockevent_delta2ns(0x7FFF, &pit_clockevent); | 124 | cd->min_delta_ns = clockevent_delta2ns(0xF, cd); |
122 | pit_clockevent.min_delta_ns = | 125 | clockevents_register_device(cd); |
123 | clockevent_delta2ns(0xF, &pit_clockevent); | 126 | |
124 | clockevents_register_device(&pit_clockevent); | 127 | irq0.mask = cpumask_of_cpu(cpu); |
125 | |||
126 | irq0.mask = cpumask_of_cpu(0); | ||
127 | setup_irq(0, &irq0); | 128 | setup_irq(0, &irq0); |
128 | } | 129 | } |
129 | 130 | ||
diff --git a/arch/mips/kernel/irixsig.c b/arch/mips/kernel/irixsig.c index a0a91056fda7..33506ff25910 100644 --- a/arch/mips/kernel/irixsig.c +++ b/arch/mips/kernel/irixsig.c | |||
@@ -24,8 +24,12 @@ | |||
24 | 24 | ||
25 | #define _BLOCKABLE (~(_S(SIGKILL) | _S(SIGSTOP))) | 25 | #define _BLOCKABLE (~(_S(SIGKILL) | _S(SIGSTOP))) |
26 | 26 | ||
27 | #define _IRIX_NSIG 128 | ||
28 | #define _IRIX_NSIG_BPW BITS_PER_LONG | ||
29 | #define _IRIX_NSIG_WORDS (_IRIX_NSIG / _IRIX_NSIG_BPW) | ||
30 | |||
27 | typedef struct { | 31 | typedef struct { |
28 | unsigned long sig[4]; | 32 | unsigned long sig[_IRIX_NSIG_WORDS]; |
29 | } irix_sigset_t; | 33 | } irix_sigset_t; |
30 | 34 | ||
31 | struct sigctx_irix5 { | 35 | struct sigctx_irix5 { |
@@ -527,7 +531,7 @@ asmlinkage int irix_sigpoll_sys(unsigned long __user *set, | |||
527 | 531 | ||
528 | expire = schedule_timeout_interruptible(expire); | 532 | expire = schedule_timeout_interruptible(expire); |
529 | 533 | ||
530 | for (i=0; i<=4; i++) | 534 | for (i=0; i < _IRIX_NSIG_WORDS; i++) |
531 | tmp |= (current->pending.signal.sig[i] & kset.sig[i]); | 535 | tmp |= (current->pending.signal.sig[i] & kset.sig[i]); |
532 | 536 | ||
533 | if (tmp) | 537 | if (tmp) |
diff --git a/arch/mips/kernel/ptrace.c b/arch/mips/kernel/ptrace.c index 999f7853de26..35234b92b9a5 100644 --- a/arch/mips/kernel/ptrace.c +++ b/arch/mips/kernel/ptrace.c | |||
@@ -65,13 +65,13 @@ int ptrace_getregs(struct task_struct *child, __s64 __user *data) | |||
65 | regs = task_pt_regs(child); | 65 | regs = task_pt_regs(child); |
66 | 66 | ||
67 | for (i = 0; i < 32; i++) | 67 | for (i = 0; i < 32; i++) |
68 | __put_user(regs->regs[i], data + i); | 68 | __put_user((long)regs->regs[i], data + i); |
69 | __put_user(regs->lo, data + EF_LO - EF_R0); | 69 | __put_user((long)regs->lo, data + EF_LO - EF_R0); |
70 | __put_user(regs->hi, data + EF_HI - EF_R0); | 70 | __put_user((long)regs->hi, data + EF_HI - EF_R0); |
71 | __put_user(regs->cp0_epc, data + EF_CP0_EPC - EF_R0); | 71 | __put_user((long)regs->cp0_epc, data + EF_CP0_EPC - EF_R0); |
72 | __put_user(regs->cp0_badvaddr, data + EF_CP0_BADVADDR - EF_R0); | 72 | __put_user((long)regs->cp0_badvaddr, data + EF_CP0_BADVADDR - EF_R0); |
73 | __put_user(regs->cp0_status, data + EF_CP0_STATUS - EF_R0); | 73 | __put_user((long)regs->cp0_status, data + EF_CP0_STATUS - EF_R0); |
74 | __put_user(regs->cp0_cause, data + EF_CP0_CAUSE - EF_R0); | 74 | __put_user((long)regs->cp0_cause, data + EF_CP0_CAUSE - EF_R0); |
75 | 75 | ||
76 | return 0; | 76 | return 0; |
77 | } | 77 | } |
@@ -390,11 +390,11 @@ long arch_ptrace(struct task_struct *child, long request, long addr, long data) | |||
390 | } | 390 | } |
391 | 391 | ||
392 | case PTRACE_GETREGS: | 392 | case PTRACE_GETREGS: |
393 | ret = ptrace_getregs(child, (__u64 __user *) data); | 393 | ret = ptrace_getregs(child, (__s64 __user *) data); |
394 | break; | 394 | break; |
395 | 395 | ||
396 | case PTRACE_SETREGS: | 396 | case PTRACE_SETREGS: |
397 | ret = ptrace_setregs(child, (__u64 __user *) data); | 397 | ret = ptrace_setregs(child, (__s64 __user *) data); |
398 | break; | 398 | break; |
399 | 399 | ||
400 | case PTRACE_GETFPREGS: | 400 | case PTRACE_GETFPREGS: |
diff --git a/arch/mips/kernel/ptrace32.c b/arch/mips/kernel/ptrace32.c index f2bffed94fa3..76818be6ba7c 100644 --- a/arch/mips/kernel/ptrace32.c +++ b/arch/mips/kernel/ptrace32.c | |||
@@ -346,11 +346,11 @@ asmlinkage int sys32_ptrace(int request, int pid, int addr, int data) | |||
346 | } | 346 | } |
347 | 347 | ||
348 | case PTRACE_GETREGS: | 348 | case PTRACE_GETREGS: |
349 | ret = ptrace_getregs(child, (__u64 __user *) (__u64) data); | 349 | ret = ptrace_getregs(child, (__s64 __user *) (__u64) data); |
350 | break; | 350 | break; |
351 | 351 | ||
352 | case PTRACE_SETREGS: | 352 | case PTRACE_SETREGS: |
353 | ret = ptrace_setregs(child, (__u64 __user *) (__u64) data); | 353 | ret = ptrace_setregs(child, (__s64 __user *) (__u64) data); |
354 | break; | 354 | break; |
355 | 355 | ||
356 | case PTRACE_GETFPREGS: | 356 | case PTRACE_GETFPREGS: |
diff --git a/arch/mips/kernel/smtc.c b/arch/mips/kernel/smtc.c index a8c1a698d588..9c92d42996cb 100644 --- a/arch/mips/kernel/smtc.c +++ b/arch/mips/kernel/smtc.c | |||
@@ -88,11 +88,19 @@ unsigned int smtc_status = 0; | |||
88 | 88 | ||
89 | /* Boot command line configuration overrides */ | 89 | /* Boot command line configuration overrides */ |
90 | 90 | ||
91 | static int vpe0limit; | ||
91 | static int ipibuffers = 0; | 92 | static int ipibuffers = 0; |
92 | static int nostlb = 0; | 93 | static int nostlb = 0; |
93 | static int asidmask = 0; | 94 | static int asidmask = 0; |
94 | unsigned long smtc_asid_mask = 0xff; | 95 | unsigned long smtc_asid_mask = 0xff; |
95 | 96 | ||
97 | static int __init vpe0tcs(char *str) | ||
98 | { | ||
99 | get_option(&str, &vpe0limit); | ||
100 | |||
101 | return 1; | ||
102 | } | ||
103 | |||
96 | static int __init ipibufs(char *str) | 104 | static int __init ipibufs(char *str) |
97 | { | 105 | { |
98 | get_option(&str, &ipibuffers); | 106 | get_option(&str, &ipibuffers); |
@@ -125,6 +133,7 @@ static int __init asidmask_set(char *str) | |||
125 | return 1; | 133 | return 1; |
126 | } | 134 | } |
127 | 135 | ||
136 | __setup("vpe0tcs=", vpe0tcs); | ||
128 | __setup("ipibufs=", ipibufs); | 137 | __setup("ipibufs=", ipibufs); |
129 | __setup("nostlb", stlb_disable); | 138 | __setup("nostlb", stlb_disable); |
130 | __setup("asidmask=", asidmask_set); | 139 | __setup("asidmask=", asidmask_set); |
@@ -340,7 +349,7 @@ static void smtc_tc_setup(int vpe, int tc, int cpu) | |||
340 | 349 | ||
341 | void mipsmt_prepare_cpus(void) | 350 | void mipsmt_prepare_cpus(void) |
342 | { | 351 | { |
343 | int i, vpe, tc, ntc, nvpe, tcpervpe, slop, cpu; | 352 | int i, vpe, tc, ntc, nvpe, tcpervpe[NR_CPUS], slop, cpu; |
344 | unsigned long flags; | 353 | unsigned long flags; |
345 | unsigned long val; | 354 | unsigned long val; |
346 | int nipi; | 355 | int nipi; |
@@ -401,8 +410,39 @@ void mipsmt_prepare_cpus(void) | |||
401 | ntc = NR_CPUS; | 410 | ntc = NR_CPUS; |
402 | if (tclimit > 0 && ntc > tclimit) | 411 | if (tclimit > 0 && ntc > tclimit) |
403 | ntc = tclimit; | 412 | ntc = tclimit; |
404 | tcpervpe = ntc / nvpe; | 413 | slop = ntc % nvpe; |
405 | slop = ntc % nvpe; /* Residual TCs, < NVPE */ | 414 | for (i = 0; i < nvpe; i++) { |
415 | tcpervpe[i] = ntc / nvpe; | ||
416 | if (slop) { | ||
417 | if((slop - i) > 0) tcpervpe[i]++; | ||
418 | } | ||
419 | } | ||
420 | /* Handle command line override for VPE0 */ | ||
421 | if (vpe0limit > ntc) vpe0limit = ntc; | ||
422 | if (vpe0limit > 0) { | ||
423 | int slopslop; | ||
424 | if (vpe0limit < tcpervpe[0]) { | ||
425 | /* Reducing TC count - distribute to others */ | ||
426 | slop = tcpervpe[0] - vpe0limit; | ||
427 | slopslop = slop % (nvpe - 1); | ||
428 | tcpervpe[0] = vpe0limit; | ||
429 | for (i = 1; i < nvpe; i++) { | ||
430 | tcpervpe[i] += slop / (nvpe - 1); | ||
431 | if(slopslop && ((slopslop - (i - 1) > 0))) | ||
432 | tcpervpe[i]++; | ||
433 | } | ||
434 | } else if (vpe0limit > tcpervpe[0]) { | ||
435 | /* Increasing TC count - steal from others */ | ||
436 | slop = vpe0limit - tcpervpe[0]; | ||
437 | slopslop = slop % (nvpe - 1); | ||
438 | tcpervpe[0] = vpe0limit; | ||
439 | for (i = 1; i < nvpe; i++) { | ||
440 | tcpervpe[i] -= slop / (nvpe - 1); | ||
441 | if(slopslop && ((slopslop - (i - 1) > 0))) | ||
442 | tcpervpe[i]--; | ||
443 | } | ||
444 | } | ||
445 | } | ||
406 | 446 | ||
407 | /* Set up shared TLB */ | 447 | /* Set up shared TLB */ |
408 | smtc_configure_tlb(); | 448 | smtc_configure_tlb(); |
@@ -416,7 +456,7 @@ void mipsmt_prepare_cpus(void) | |||
416 | if (vpe != 0) | 456 | if (vpe != 0) |
417 | printk(", "); | 457 | printk(", "); |
418 | printk("VPE %d: TC", vpe); | 458 | printk("VPE %d: TC", vpe); |
419 | for (i = 0; i < tcpervpe; i++) { | 459 | for (i = 0; i < tcpervpe[vpe]; i++) { |
420 | /* | 460 | /* |
421 | * TC 0 is bound to VPE 0 at reset, | 461 | * TC 0 is bound to VPE 0 at reset, |
422 | * and is presumably executing this | 462 | * and is presumably executing this |
@@ -429,15 +469,6 @@ void mipsmt_prepare_cpus(void) | |||
429 | printk(" %d", tc); | 469 | printk(" %d", tc); |
430 | tc++; | 470 | tc++; |
431 | } | 471 | } |
432 | if (slop) { | ||
433 | if (tc != 0) { | ||
434 | smtc_tc_setup(vpe, tc, cpu); | ||
435 | cpu++; | ||
436 | } | ||
437 | printk(" %d", tc); | ||
438 | tc++; | ||
439 | slop--; | ||
440 | } | ||
441 | if (vpe != 0) { | 472 | if (vpe != 0) { |
442 | /* | 473 | /* |
443 | * Clear any stale software interrupts from VPE's Cause | 474 | * Clear any stale software interrupts from VPE's Cause |
diff --git a/arch/mips/kernel/syscall.c b/arch/mips/kernel/syscall.c index b95fe93dd646..af1bdc897488 100644 --- a/arch/mips/kernel/syscall.c +++ b/arch/mips/kernel/syscall.c | |||
@@ -73,7 +73,14 @@ unsigned long arch_get_unmapped_area(struct file *filp, unsigned long addr, | |||
73 | 73 | ||
74 | task_size = STACK_TOP; | 74 | task_size = STACK_TOP; |
75 | 75 | ||
76 | if (len > task_size) | ||
77 | return -ENOMEM; | ||
78 | |||
76 | if (flags & MAP_FIXED) { | 79 | if (flags & MAP_FIXED) { |
80 | /* Even MAP_FIXED mappings must reside within task_size. */ | ||
81 | if (task_size - len < addr) | ||
82 | return -EINVAL; | ||
83 | |||
77 | /* | 84 | /* |
78 | * We do not accept a shared mapping if it would violate | 85 | * We do not accept a shared mapping if it would violate |
79 | * cache aliasing constraints. | 86 | * cache aliasing constraints. |
@@ -83,8 +90,6 @@ unsigned long arch_get_unmapped_area(struct file *filp, unsigned long addr, | |||
83 | return addr; | 90 | return addr; |
84 | } | 91 | } |
85 | 92 | ||
86 | if (len > task_size) | ||
87 | return -ENOMEM; | ||
88 | do_color_align = 0; | 93 | do_color_align = 0; |
89 | if (filp || (flags & MAP_SHARED)) | 94 | if (filp || (flags & MAP_SHARED)) |
90 | do_color_align = 1; | 95 | do_color_align = 1; |
diff --git a/arch/mips/kernel/time.c b/arch/mips/kernel/time.c index 6c6849a8f136..3284b9b4ecac 100644 --- a/arch/mips/kernel/time.c +++ b/arch/mips/kernel/time.c | |||
@@ -3,42 +3,31 @@ | |||
3 | * Author: Jun Sun, jsun@mvista.com or jsun@junsun.net | 3 | * Author: Jun Sun, jsun@mvista.com or jsun@junsun.net |
4 | * Copyright (c) 2003, 2004 Maciej W. Rozycki | 4 | * Copyright (c) 2003, 2004 Maciej W. Rozycki |
5 | * | 5 | * |
6 | * Common time service routines for MIPS machines. See | 6 | * Common time service routines for MIPS machines. |
7 | * Documentation/mips/time.README. | ||
8 | * | 7 | * |
9 | * This program is free software; you can redistribute it and/or modify it | 8 | * This program is free software; you can redistribute it and/or modify it |
10 | * under the terms of the GNU General Public License as published by the | 9 | * under the terms of the GNU General Public License as published by the |
11 | * Free Software Foundation; either version 2 of the License, or (at your | 10 | * Free Software Foundation; either version 2 of the License, or (at your |
12 | * option) any later version. | 11 | * option) any later version. |
13 | */ | 12 | */ |
13 | #include <linux/bug.h> | ||
14 | #include <linux/clockchips.h> | 14 | #include <linux/clockchips.h> |
15 | #include <linux/types.h> | 15 | #include <linux/types.h> |
16 | #include <linux/kernel.h> | 16 | #include <linux/kernel.h> |
17 | #include <linux/init.h> | 17 | #include <linux/init.h> |
18 | #include <linux/sched.h> | 18 | #include <linux/sched.h> |
19 | #include <linux/param.h> | 19 | #include <linux/param.h> |
20 | #include <linux/profile.h> | ||
21 | #include <linux/time.h> | 20 | #include <linux/time.h> |
22 | #include <linux/timex.h> | 21 | #include <linux/timex.h> |
23 | #include <linux/smp.h> | 22 | #include <linux/smp.h> |
24 | #include <linux/kernel_stat.h> | ||
25 | #include <linux/spinlock.h> | 23 | #include <linux/spinlock.h> |
26 | #include <linux/interrupt.h> | ||
27 | #include <linux/module.h> | 24 | #include <linux/module.h> |
28 | #include <linux/kallsyms.h> | ||
29 | 25 | ||
30 | #include <asm/bootinfo.h> | ||
31 | #include <asm/cache.h> | ||
32 | #include <asm/compiler.h> | ||
33 | #include <asm/cpu.h> | ||
34 | #include <asm/cpu-features.h> | 26 | #include <asm/cpu-features.h> |
35 | #include <asm/div64.h> | 27 | #include <asm/div64.h> |
36 | #include <asm/sections.h> | ||
37 | #include <asm/smtc_ipi.h> | 28 | #include <asm/smtc_ipi.h> |
38 | #include <asm/time.h> | 29 | #include <asm/time.h> |
39 | 30 | ||
40 | #include <irq.h> | ||
41 | |||
42 | /* | 31 | /* |
43 | * forward reference | 32 | * forward reference |
44 | */ | 33 | */ |
@@ -62,14 +51,6 @@ int update_persistent_clock(struct timespec now) | |||
62 | } | 51 | } |
63 | 52 | ||
64 | /* | 53 | /* |
65 | * Null high precision timer functions for systems lacking one. | ||
66 | */ | ||
67 | static cycle_t null_hpt_read(void) | ||
68 | { | ||
69 | return 0; | ||
70 | } | ||
71 | |||
72 | /* | ||
73 | * High precision timer functions for a R4k-compatible timer. | 54 | * High precision timer functions for a R4k-compatible timer. |
74 | */ | 55 | */ |
75 | static cycle_t c0_hpt_read(void) | 56 | static cycle_t c0_hpt_read(void) |
@@ -79,22 +60,6 @@ static cycle_t c0_hpt_read(void) | |||
79 | 60 | ||
80 | int (*mips_timer_state)(void); | 61 | int (*mips_timer_state)(void); |
81 | 62 | ||
82 | /* | ||
83 | * local_timer_interrupt() does profiling and process accounting | ||
84 | * on a per-CPU basis. | ||
85 | * | ||
86 | * In UP mode, it is invoked from the (global) timer_interrupt. | ||
87 | * | ||
88 | * In SMP mode, it might invoked by per-CPU timer interrupt, or | ||
89 | * a broadcasted inter-processor interrupt which itself is triggered | ||
90 | * by the global timer interrupt. | ||
91 | */ | ||
92 | void local_timer_interrupt(int irq, void *dev_id) | ||
93 | { | ||
94 | profile_tick(CPU_PROFILING); | ||
95 | update_process_times(user_mode(get_irq_regs())); | ||
96 | } | ||
97 | |||
98 | int null_perf_irq(void) | 63 | int null_perf_irq(void) |
99 | { | 64 | { |
100 | return 0; | 65 | return 0; |
@@ -115,14 +80,17 @@ EXPORT_SYMBOL(perf_irq); | |||
115 | * (only needed if you intended to use cpu counter as timer interrupt | 80 | * (only needed if you intended to use cpu counter as timer interrupt |
116 | * source) | 81 | * source) |
117 | * 2) calculate a couple of cached variables for later usage | 82 | * 2) calculate a couple of cached variables for later usage |
118 | * 3) plat_timer_setup() - | ||
119 | * a) (optional) over-write any choices made above by time_init(). | ||
120 | * b) machine specific code should setup the timer irqaction. | ||
121 | * c) enable the timer interrupt | ||
122 | */ | 83 | */ |
123 | 84 | ||
124 | unsigned int mips_hpt_frequency; | 85 | unsigned int mips_hpt_frequency; |
125 | 86 | ||
87 | static struct clocksource clocksource_mips = { | ||
88 | .name = "MIPS", | ||
89 | .read = c0_hpt_read, | ||
90 | .mask = CLOCKSOURCE_MASK(32), | ||
91 | .flags = CLOCK_SOURCE_IS_CONTINUOUS, | ||
92 | }; | ||
93 | |||
126 | static unsigned int __init calibrate_hpt(void) | 94 | static unsigned int __init calibrate_hpt(void) |
127 | { | 95 | { |
128 | cycle_t frequency, hpt_start, hpt_end, hpt_count, hz; | 96 | cycle_t frequency, hpt_start, hpt_end, hpt_count, hz; |
@@ -165,12 +133,6 @@ static unsigned int __init calibrate_hpt(void) | |||
165 | return frequency >> log_2_loops; | 133 | return frequency >> log_2_loops; |
166 | } | 134 | } |
167 | 135 | ||
168 | struct clocksource clocksource_mips = { | ||
169 | .name = "MIPS", | ||
170 | .mask = CLOCKSOURCE_MASK(32), | ||
171 | .flags = CLOCK_SOURCE_IS_CONTINUOUS, | ||
172 | }; | ||
173 | |||
174 | void __init clocksource_set_clock(struct clocksource *cs, unsigned int clock) | 136 | void __init clocksource_set_clock(struct clocksource *cs, unsigned int clock) |
175 | { | 137 | { |
176 | u64 temp; | 138 | u64 temp; |
@@ -206,9 +168,6 @@ void __cpuinit clockevent_set_clock(struct clock_event_device *cd, | |||
206 | 168 | ||
207 | static void __init init_mips_clocksource(void) | 169 | static void __init init_mips_clocksource(void) |
208 | { | 170 | { |
209 | if (!mips_hpt_frequency || clocksource_mips.read == null_hpt_read) | ||
210 | return; | ||
211 | |||
212 | /* Calclate a somewhat reasonable rating value */ | 171 | /* Calclate a somewhat reasonable rating value */ |
213 | clocksource_mips.rating = 200 + mips_hpt_frequency / 10000000; | 172 | clocksource_mips.rating = 200 + mips_hpt_frequency / 10000000; |
214 | 173 | ||
@@ -221,29 +180,26 @@ void __init __weak plat_time_init(void) | |||
221 | { | 180 | { |
222 | } | 181 | } |
223 | 182 | ||
224 | void __init __weak plat_timer_setup(struct irqaction *irq) | 183 | /* |
184 | * This function exists in order to cause an error due to a duplicate | ||
185 | * definition if platform code should have its own implementation. The hook | ||
186 | * to use instead is plat_time_init. plat_time_init does not receive the | ||
187 | * irqaction pointer argument anymore. This is because any function which | ||
188 | * initializes an interrupt timer now takes care of its own request_irq rsp. | ||
189 | * setup_irq calls and each clock_event_device should use its own | ||
190 | * struct irqrequest. | ||
191 | */ | ||
192 | void __init plat_timer_setup(void) | ||
225 | { | 193 | { |
194 | BUG(); | ||
226 | } | 195 | } |
227 | 196 | ||
228 | void __init time_init(void) | 197 | void __init time_init(void) |
229 | { | 198 | { |
230 | plat_time_init(); | 199 | plat_time_init(); |
231 | 200 | ||
232 | /* Choose appropriate high precision timer routines. */ | 201 | if (cpu_has_counter && (mips_hpt_frequency || mips_timer_state)) { |
233 | if (!cpu_has_counter && !clocksource_mips.read) | ||
234 | /* No high precision timer -- sorry. */ | ||
235 | clocksource_mips.read = null_hpt_read; | ||
236 | else if (!mips_hpt_frequency && !mips_timer_state) { | ||
237 | /* A high precision timer of unknown frequency. */ | ||
238 | if (!clocksource_mips.read) | ||
239 | /* No external high precision timer -- use R4k. */ | ||
240 | clocksource_mips.read = c0_hpt_read; | ||
241 | } else { | ||
242 | /* We know counter frequency. Or we can get it. */ | 202 | /* We know counter frequency. Or we can get it. */ |
243 | if (!clocksource_mips.read) { | ||
244 | /* No external high precision timer -- use R4k. */ | ||
245 | clocksource_mips.read = c0_hpt_read; | ||
246 | } | ||
247 | if (!mips_hpt_frequency) | 203 | if (!mips_hpt_frequency) |
248 | mips_hpt_frequency = calibrate_hpt(); | 204 | mips_hpt_frequency = calibrate_hpt(); |
249 | 205 | ||
@@ -251,8 +207,8 @@ void __init time_init(void) | |||
251 | printk("Using %u.%03u MHz high precision timer.\n", | 207 | printk("Using %u.%03u MHz high precision timer.\n", |
252 | ((mips_hpt_frequency + 500) / 1000) / 1000, | 208 | ((mips_hpt_frequency + 500) / 1000) / 1000, |
253 | ((mips_hpt_frequency + 500) / 1000) % 1000); | 209 | ((mips_hpt_frequency + 500) / 1000) % 1000); |
210 | init_mips_clocksource(); | ||
254 | } | 211 | } |
255 | 212 | ||
256 | init_mips_clocksource(); | ||
257 | mips_clockevent_init(); | 213 | mips_clockevent_init(); |
258 | } | 214 | } |
diff --git a/arch/mips/kernel/vmlinux.lds.S b/arch/mips/kernel/vmlinux.lds.S index 2781cff1485e..5fc2398bdb76 100644 --- a/arch/mips/kernel/vmlinux.lds.S +++ b/arch/mips/kernel/vmlinux.lds.S | |||
@@ -63,21 +63,23 @@ SECTIONS | |||
63 | 63 | ||
64 | /* writeable */ | 64 | /* writeable */ |
65 | .data : { /* Data */ | 65 | .data : { /* Data */ |
66 | . = . + DATAOFFSET; /* for CONFIG_MAPPED_KERNEL */ | 66 | . = . + DATAOFFSET; /* for CONFIG_MAPPED_KERNEL */ |
67 | /* | 67 | /* |
68 | * This ALIGN is needed as a workaround for a bug a gcc bug upto 4.1 which | 68 | * This ALIGN is needed as a workaround for a bug a |
69 | * limits the maximum alignment to at most 32kB and results in the following | 69 | * gcc bug upto 4.1 which limits the maximum alignment |
70 | * warning: | 70 | * to at most 32kB and results in the following |
71 | * | 71 | * warning: |
72 | * CC arch/mips/kernel/init_task.o | 72 | * |
73 | * arch/mips/kernel/init_task.c:30: warning: alignment of ‘init_thread_union’ | 73 | * CC arch/mips/kernel/init_task.o |
74 | * is greater than maximum object file alignment. Using 32768 | 74 | * arch/mips/kernel/init_task.c:30: warning: alignment |
75 | */ | 75 | * of ‘init_thread_union’ is greater than maximum |
76 | . = ALIGN(_PAGE_SIZE); | 76 | * object file alignment. Using 32768 |
77 | *(.data.init_task) | 77 | */ |
78 | 78 | . = ALIGN(_PAGE_SIZE); | |
79 | DATA_DATA | 79 | *(.data.init_task) |
80 | CONSTRUCTORS | 80 | |
81 | DATA_DATA | ||
82 | CONSTRUCTORS | ||
81 | } | 83 | } |
82 | _gp = . + 0x8000; | 84 | _gp = . + 0x8000; |
83 | .lit8 : { | 85 | .lit8 : { |
diff --git a/arch/mips/kernel/vpe.c b/arch/mips/kernel/vpe.c index df8cbe4c7c0d..436a64ff3989 100644 --- a/arch/mips/kernel/vpe.c +++ b/arch/mips/kernel/vpe.c | |||
@@ -942,8 +942,8 @@ static int vpe_elfload(struct vpe * v) | |||
942 | if (phdr->p_type != PT_LOAD) | 942 | if (phdr->p_type != PT_LOAD) |
943 | continue; | 943 | continue; |
944 | 944 | ||
945 | memcpy((void *)phdr->p_vaddr, (char *)hdr + phdr->p_offset, phdr->p_filesz); | 945 | memcpy((void *)phdr->p_paddr, (char *)hdr + phdr->p_offset, phdr->p_filesz); |
946 | memset((void *)phdr->p_vaddr + phdr->p_filesz, 0, phdr->p_memsz - phdr->p_filesz); | 946 | memset((void *)phdr->p_paddr + phdr->p_filesz, 0, phdr->p_memsz - phdr->p_filesz); |
947 | phdr++; | 947 | phdr++; |
948 | } | 948 | } |
949 | 949 | ||
diff --git a/arch/mips/lasat/setup.c b/arch/mips/lasat/setup.c index 54827d0174bf..e072da4ff3b3 100644 --- a/arch/mips/lasat/setup.c +++ b/arch/mips/lasat/setup.c | |||
@@ -117,14 +117,11 @@ static struct notifier_block lasat_panic_block[] = | |||
117 | } | 117 | } |
118 | }; | 118 | }; |
119 | 119 | ||
120 | void plat_time_init(void) | 120 | void __init plat_time_init(void) |
121 | { | 121 | { |
122 | mips_hpt_frequency = lasat_board_info.li_cpu_hz / 2; | 122 | mips_hpt_frequency = lasat_board_info.li_cpu_hz / 2; |
123 | } | ||
124 | 123 | ||
125 | void __init plat_timer_setup(struct irqaction *irq) | 124 | change_c0_status(ST0_IM, IE_IRQ0); |
126 | { | ||
127 | change_c0_status(ST0_IM, IE_IRQ0 | IE_IRQ5); | ||
128 | } | 125 | } |
129 | 126 | ||
130 | void __init plat_mem_setup(void) | 127 | void __init plat_mem_setup(void) |
diff --git a/arch/mips/mips-boards/generic/time.c b/arch/mips/mips-boards/generic/time.c index 9d6243a8c15a..f02ce6308e51 100644 --- a/arch/mips/mips-boards/generic/time.c +++ b/arch/mips/mips-boards/generic/time.c | |||
@@ -127,26 +127,6 @@ unsigned long read_persistent_clock(void) | |||
127 | return mc146818_get_cmos_time(); | 127 | return mc146818_get_cmos_time(); |
128 | } | 128 | } |
129 | 129 | ||
130 | void __init plat_time_init(void) | ||
131 | { | ||
132 | unsigned int est_freq; | ||
133 | |||
134 | /* Set Data mode - binary. */ | ||
135 | CMOS_WRITE(CMOS_READ(RTC_CONTROL) | RTC_DM_BINARY, RTC_CONTROL); | ||
136 | |||
137 | est_freq = estimate_cpu_frequency(); | ||
138 | |||
139 | printk("CPU frequency %d.%02d MHz\n", est_freq/1000000, | ||
140 | (est_freq%1000000)*100/1000000); | ||
141 | |||
142 | cpu_khz = est_freq / 1000; | ||
143 | |||
144 | mips_scroll_message(); | ||
145 | #ifdef CONFIG_I8253 /* Only Malta has a PIT */ | ||
146 | setup_pit_timer(); | ||
147 | #endif | ||
148 | } | ||
149 | |||
150 | void __init plat_perf_setup(void) | 130 | void __init plat_perf_setup(void) |
151 | { | 131 | { |
152 | cp0_perfcount_irq = -1; | 132 | cp0_perfcount_irq = -1; |
@@ -166,14 +146,13 @@ void __init plat_perf_setup(void) | |||
166 | } | 146 | } |
167 | } | 147 | } |
168 | 148 | ||
169 | void __init plat_timer_setup(struct irqaction *irq) | 149 | unsigned int __init get_c0_compare_int(void) |
170 | { | 150 | { |
171 | #ifdef MSC01E_INT_BASE | 151 | #ifdef MSC01E_INT_BASE |
172 | if (cpu_has_veic) { | 152 | if (cpu_has_veic) { |
173 | set_vi_handler(MSC01E_INT_CPUCTR, mips_timer_dispatch); | 153 | set_vi_handler(MSC01E_INT_CPUCTR, mips_timer_dispatch); |
174 | mips_cpu_timer_irq = MSC01E_INT_BASE + MSC01E_INT_CPUCTR; | 154 | mips_cpu_timer_irq = MSC01E_INT_BASE + MSC01E_INT_CPUCTR; |
175 | } | 155 | } else |
176 | else | ||
177 | #endif | 156 | #endif |
178 | { | 157 | { |
179 | if (cpu_has_vint) | 158 | if (cpu_has_vint) |
@@ -181,13 +160,26 @@ void __init plat_timer_setup(struct irqaction *irq) | |||
181 | mips_cpu_timer_irq = MIPS_CPU_IRQ_BASE + cp0_compare_irq; | 160 | mips_cpu_timer_irq = MIPS_CPU_IRQ_BASE + cp0_compare_irq; |
182 | } | 161 | } |
183 | 162 | ||
184 | #ifdef CONFIG_MIPS_MT_SMTC | 163 | return mips_cpu_timer_irq; |
185 | setup_irq_smtc(mips_cpu_timer_irq, irq, 0x100 << cp0_compare_irq); | 164 | } |
186 | #else | 165 | |
187 | setup_irq(mips_cpu_timer_irq, irq); | 166 | void __init plat_time_init(void) |
188 | #endif /* CONFIG_MIPS_MT_SMTC */ | 167 | { |
189 | #ifdef CONFIG_SMP | 168 | unsigned int est_freq; |
190 | set_irq_handler(mips_cpu_timer_irq, handle_percpu_irq); | 169 | |
170 | /* Set Data mode - binary. */ | ||
171 | CMOS_WRITE(CMOS_READ(RTC_CONTROL) | RTC_DM_BINARY, RTC_CONTROL); | ||
172 | |||
173 | est_freq = estimate_cpu_frequency(); | ||
174 | |||
175 | printk("CPU frequency %d.%02d MHz\n", est_freq/1000000, | ||
176 | (est_freq%1000000)*100/1000000); | ||
177 | |||
178 | cpu_khz = est_freq / 1000; | ||
179 | |||
180 | mips_scroll_message(); | ||
181 | #ifdef CONFIG_I8253 /* Only Malta has a PIT */ | ||
182 | setup_pit_timer(); | ||
191 | #endif | 183 | #endif |
192 | 184 | ||
193 | plat_perf_setup(); | 185 | plat_perf_setup(); |
diff --git a/arch/mips/mipssim/sim_time.c b/arch/mips/mipssim/sim_time.c index e7fa0d1078a3..bfaafa38846f 100644 --- a/arch/mips/mipssim/sim_time.c +++ b/arch/mips/mipssim/sim_time.c | |||
@@ -75,25 +75,6 @@ static unsigned int __init estimate_cpu_frequency(void) | |||
75 | return count; | 75 | return count; |
76 | } | 76 | } |
77 | 77 | ||
78 | void __init plat_time_init(void) | ||
79 | { | ||
80 | unsigned int est_freq, flags; | ||
81 | |||
82 | local_irq_save(flags); | ||
83 | |||
84 | /* Set Data mode - binary. */ | ||
85 | CMOS_WRITE(CMOS_READ(RTC_CONTROL) | RTC_DM_BINARY, RTC_CONTROL); | ||
86 | |||
87 | est_freq = estimate_cpu_frequency(); | ||
88 | |||
89 | printk(KERN_INFO "CPU frequency %d.%02d MHz\n", est_freq / 1000000, | ||
90 | (est_freq % 1000000) * 100 / 1000000); | ||
91 | |||
92 | cpu_khz = est_freq / 1000; | ||
93 | |||
94 | local_irq_restore(flags); | ||
95 | } | ||
96 | |||
97 | static int mips_cpu_timer_irq; | 78 | static int mips_cpu_timer_irq; |
98 | 79 | ||
99 | static void mips_timer_dispatch(void) | 80 | static void mips_timer_dispatch(void) |
@@ -102,26 +83,37 @@ static void mips_timer_dispatch(void) | |||
102 | } | 83 | } |
103 | 84 | ||
104 | 85 | ||
105 | void __init plat_timer_setup(struct irqaction *irq) | 86 | unsigned __init get_c0_compare_int(void) |
106 | { | 87 | { |
88 | #ifdef MSC01E_INT_BASE | ||
107 | if (cpu_has_veic) { | 89 | if (cpu_has_veic) { |
108 | set_vi_handler(MSC01E_INT_CPUCTR, mips_timer_dispatch); | 90 | set_vi_handler(MSC01E_INT_CPUCTR, mips_timer_dispatch); |
109 | mips_cpu_timer_irq = MSC01E_INT_BASE + MSC01E_INT_CPUCTR; | 91 | mips_cpu_timer_irq = MSC01E_INT_BASE + MSC01E_INT_CPUCTR; |
110 | } else { | 92 | } else { |
93 | #endif | ||
111 | if (cpu_has_vint) | 94 | if (cpu_has_vint) |
112 | set_vi_handler(cp0_compare_irq, mips_timer_dispatch); | 95 | set_vi_handler(cp0_compare_irq, mips_timer_dispatch); |
113 | mips_cpu_timer_irq = MIPS_CPU_IRQ_BASE + cp0_compare_irq; | 96 | mips_cpu_timer_irq = MIPS_CPU_IRQ_BASE + cp0_compare_irq; |
114 | } | 97 | } |
115 | 98 | ||
116 | /* we are using the cpu counter for timer interrupts */ | 99 | return mips_cpu_timer_irq; |
117 | setup_irq(mips_cpu_timer_irq, irq); | 100 | } |
118 | 101 | ||
119 | #ifdef CONFIG_SMP | 102 | void __init plat_time_init(void) |
120 | /* irq_desc(riptor) is a global resource, when the interrupt overlaps | 103 | { |
121 | on seperate cpu's the first one tries to handle the second interrupt. | 104 | unsigned int est_freq, flags; |
122 | The effect is that the int remains disabled on the second cpu. | 105 | |
123 | Mark the interrupt with IRQ_PER_CPU to avoid any confusion */ | 106 | local_irq_save(flags); |
124 | irq_desc[mips_cpu_timer_irq].flags |= IRQ_PER_CPU; | 107 | |
125 | set_irq_handler(mips_cpu_timer_irq, handle_percpu_irq); | 108 | /* Set Data mode - binary. */ |
126 | #endif | 109 | CMOS_WRITE(CMOS_READ(RTC_CONTROL) | RTC_DM_BINARY, RTC_CONTROL); |
110 | |||
111 | est_freq = estimate_cpu_frequency(); | ||
112 | |||
113 | printk(KERN_INFO "CPU frequency %d.%02d MHz\n", est_freq / 1000000, | ||
114 | (est_freq % 1000000) * 100 / 1000000); | ||
115 | |||
116 | cpu_khz = est_freq / 1000; | ||
117 | |||
118 | local_irq_restore(flags); | ||
127 | } | 119 | } |
diff --git a/arch/mips/mm/c-r3k.c b/arch/mips/mm/c-r3k.c index c55312f6fd3a..562abb77d1d5 100644 --- a/arch/mips/mm/c-r3k.c +++ b/arch/mips/mm/c-r3k.c | |||
@@ -7,7 +7,7 @@ | |||
7 | * Tx39XX R4k style caches added. HK | 7 | * Tx39XX R4k style caches added. HK |
8 | * Copyright (C) 1998, 1999, 2000 Harald Koerfgen | 8 | * Copyright (C) 1998, 1999, 2000 Harald Koerfgen |
9 | * Copyright (C) 1998 Gleb Raiko & Vladimir Roganov | 9 | * Copyright (C) 1998 Gleb Raiko & Vladimir Roganov |
10 | * Copyright (C) 2001, 2004 Maciej W. Rozycki | 10 | * Copyright (C) 2001, 2004, 2007 Maciej W. Rozycki |
11 | */ | 11 | */ |
12 | #include <linux/init.h> | 12 | #include <linux/init.h> |
13 | #include <linux/kernel.h> | 13 | #include <linux/kernel.h> |
@@ -26,8 +26,6 @@ | |||
26 | static unsigned long icache_size, dcache_size; /* Size in bytes */ | 26 | static unsigned long icache_size, dcache_size; /* Size in bytes */ |
27 | static unsigned long icache_lsize, dcache_lsize; /* Size in bytes */ | 27 | static unsigned long icache_lsize, dcache_lsize; /* Size in bytes */ |
28 | 28 | ||
29 | #undef DEBUG_CACHE | ||
30 | |||
31 | unsigned long __init r3k_cache_size(unsigned long ca_flags) | 29 | unsigned long __init r3k_cache_size(unsigned long ca_flags) |
32 | { | 30 | { |
33 | unsigned long flags, status, dummy, size; | 31 | unsigned long flags, status, dummy, size; |
@@ -217,26 +215,6 @@ static void r3k_flush_dcache_range(unsigned long start, unsigned long end) | |||
217 | write_c0_status(flags); | 215 | write_c0_status(flags); |
218 | } | 216 | } |
219 | 217 | ||
220 | static inline unsigned long get_phys_page(unsigned long addr, | ||
221 | struct mm_struct *mm) | ||
222 | { | ||
223 | pgd_t *pgd; | ||
224 | pud_t *pud; | ||
225 | pmd_t *pmd; | ||
226 | pte_t *pte; | ||
227 | unsigned long physpage; | ||
228 | |||
229 | pgd = pgd_offset(mm, addr); | ||
230 | pud = pud_offset(pgd, addr); | ||
231 | pmd = pmd_offset(pud, addr); | ||
232 | pte = pte_offset(pmd, addr); | ||
233 | |||
234 | if ((physpage = pte_val(*pte)) & _PAGE_VALID) | ||
235 | return KSEG0ADDR(physpage & PAGE_MASK); | ||
236 | |||
237 | return 0; | ||
238 | } | ||
239 | |||
240 | static inline void r3k_flush_cache_all(void) | 218 | static inline void r3k_flush_cache_all(void) |
241 | { | 219 | { |
242 | } | 220 | } |
@@ -252,12 +230,40 @@ static void r3k_flush_cache_mm(struct mm_struct *mm) | |||
252 | } | 230 | } |
253 | 231 | ||
254 | static void r3k_flush_cache_range(struct vm_area_struct *vma, | 232 | static void r3k_flush_cache_range(struct vm_area_struct *vma, |
255 | unsigned long start, unsigned long end) | 233 | unsigned long start, unsigned long end) |
256 | { | 234 | { |
257 | } | 235 | } |
258 | 236 | ||
259 | static void r3k_flush_cache_page(struct vm_area_struct *vma, unsigned long page, unsigned long pfn) | 237 | static void r3k_flush_cache_page(struct vm_area_struct *vma, |
238 | unsigned long addr, unsigned long pfn) | ||
260 | { | 239 | { |
240 | unsigned long kaddr = KSEG0ADDR(pfn << PAGE_SHIFT); | ||
241 | int exec = vma->vm_flags & VM_EXEC; | ||
242 | struct mm_struct *mm = vma->vm_mm; | ||
243 | pgd_t *pgdp; | ||
244 | pud_t *pudp; | ||
245 | pmd_t *pmdp; | ||
246 | pte_t *ptep; | ||
247 | |||
248 | pr_debug("cpage[%08lx,%08lx]\n", | ||
249 | cpu_context(smp_processor_id(), mm), addr); | ||
250 | |||
251 | /* No ASID => no such page in the cache. */ | ||
252 | if (cpu_context(smp_processor_id(), mm) == 0) | ||
253 | return; | ||
254 | |||
255 | pgdp = pgd_offset(mm, addr); | ||
256 | pudp = pud_offset(pgdp, addr); | ||
257 | pmdp = pmd_offset(pudp, addr); | ||
258 | ptep = pte_offset(pmdp, addr); | ||
259 | |||
260 | /* Invalid => no such page in the cache. */ | ||
261 | if (!(pte_val(*ptep) & _PAGE_PRESENT)) | ||
262 | return; | ||
263 | |||
264 | r3k_flush_dcache_range(kaddr, kaddr + PAGE_SIZE); | ||
265 | if (exec) | ||
266 | r3k_flush_icache_range(kaddr, kaddr + PAGE_SIZE); | ||
261 | } | 267 | } |
262 | 268 | ||
263 | static void local_r3k_flush_data_cache_page(void *addr) | 269 | static void local_r3k_flush_data_cache_page(void *addr) |
@@ -272,9 +278,7 @@ static void r3k_flush_cache_sigtramp(unsigned long addr) | |||
272 | { | 278 | { |
273 | unsigned long flags; | 279 | unsigned long flags; |
274 | 280 | ||
275 | #ifdef DEBUG_CACHE | 281 | pr_debug("csigtramp[%08lx]\n", addr); |
276 | printk("csigtramp[%08lx]", addr); | ||
277 | #endif | ||
278 | 282 | ||
279 | flags = read_c0_status(); | 283 | flags = read_c0_status(); |
280 | 284 | ||
diff --git a/arch/mips/mm/c-r4k.c b/arch/mips/mm/c-r4k.c index d7088331fb0f..6806d58211b2 100644 --- a/arch/mips/mm/c-r4k.c +++ b/arch/mips/mm/c-r4k.c | |||
@@ -345,11 +345,26 @@ static void r4k___flush_cache_all(void) | |||
345 | r4k_on_each_cpu(local_r4k___flush_cache_all, NULL, 1, 1); | 345 | r4k_on_each_cpu(local_r4k___flush_cache_all, NULL, 1, 1); |
346 | } | 346 | } |
347 | 347 | ||
348 | static inline int has_valid_asid(const struct mm_struct *mm) | ||
349 | { | ||
350 | #if defined(CONFIG_MIPS_MT_SMP) || defined(CONFIG_MIPS_MT_SMTC) | ||
351 | int i; | ||
352 | |||
353 | for_each_online_cpu(i) | ||
354 | if (cpu_context(i, mm)) | ||
355 | return 1; | ||
356 | |||
357 | return 0; | ||
358 | #else | ||
359 | return cpu_context(smp_processor_id(), mm); | ||
360 | #endif | ||
361 | } | ||
362 | |||
348 | static inline void local_r4k_flush_cache_range(void * args) | 363 | static inline void local_r4k_flush_cache_range(void * args) |
349 | { | 364 | { |
350 | struct vm_area_struct *vma = args; | 365 | struct vm_area_struct *vma = args; |
351 | 366 | ||
352 | if (!(cpu_context(smp_processor_id(), vma->vm_mm))) | 367 | if (!(has_valid_asid(vma->vm_mm))) |
353 | return; | 368 | return; |
354 | 369 | ||
355 | r4k_blast_dcache(); | 370 | r4k_blast_dcache(); |
@@ -368,7 +383,7 @@ static inline void local_r4k_flush_cache_mm(void * args) | |||
368 | { | 383 | { |
369 | struct mm_struct *mm = args; | 384 | struct mm_struct *mm = args; |
370 | 385 | ||
371 | if (!cpu_context(smp_processor_id(), mm)) | 386 | if (!has_valid_asid(mm)) |
372 | return; | 387 | return; |
373 | 388 | ||
374 | /* | 389 | /* |
@@ -420,7 +435,7 @@ static inline void local_r4k_flush_cache_page(void *args) | |||
420 | * If ownes no valid ASID yet, cannot possibly have gotten | 435 | * If ownes no valid ASID yet, cannot possibly have gotten |
421 | * this page into the cache. | 436 | * this page into the cache. |
422 | */ | 437 | */ |
423 | if (cpu_context(smp_processor_id(), mm) == 0) | 438 | if (!has_valid_asid(mm)) |
424 | return; | 439 | return; |
425 | 440 | ||
426 | addr &= PAGE_MASK; | 441 | addr &= PAGE_MASK; |
diff --git a/arch/mips/mm/dma-default.c b/arch/mips/mm/dma-default.c index b1b40527658b..33519ce49540 100644 --- a/arch/mips/mm/dma-default.c +++ b/arch/mips/mm/dma-default.c | |||
@@ -12,8 +12,8 @@ | |||
12 | #include <linux/dma-mapping.h> | 12 | #include <linux/dma-mapping.h> |
13 | #include <linux/mm.h> | 13 | #include <linux/mm.h> |
14 | #include <linux/module.h> | 14 | #include <linux/module.h> |
15 | #include <linux/string.h> | ||
16 | #include <linux/scatterlist.h> | 15 | #include <linux/scatterlist.h> |
16 | #include <linux/string.h> | ||
17 | 17 | ||
18 | #include <asm/cache.h> | 18 | #include <asm/cache.h> |
19 | #include <asm/io.h> | 19 | #include <asm/io.h> |
diff --git a/arch/mips/pci/fixup-pmcmsp.c b/arch/mips/pci/fixup-pmcmsp.c index 00261211dbfa..65735b1b7665 100644 --- a/arch/mips/pci/fixup-pmcmsp.c +++ b/arch/mips/pci/fixup-pmcmsp.c | |||
@@ -202,7 +202,7 @@ int pcibios_plat_dev_init(struct pci_dev *dev) | |||
202 | * RETURNS: IRQ number | 202 | * RETURNS: IRQ number |
203 | * | 203 | * |
204 | ****************************************************************************/ | 204 | ****************************************************************************/ |
205 | int __init pcibios_map_irq(struct pci_dev *dev, u8 slot, u8 pin) | 205 | int __init pcibios_map_irq(const struct pci_dev *dev, u8 slot, u8 pin) |
206 | { | 206 | { |
207 | #if !defined(CONFIG_PMC_MSP7120_GW) && !defined(CONFIG_PMC_MSP7120_EVAL) | 207 | #if !defined(CONFIG_PMC_MSP7120_GW) && !defined(CONFIG_PMC_MSP7120_EVAL) |
208 | printk(KERN_WARNING "PCI: unknown board, no PCI IRQs assigned.\n"); | 208 | printk(KERN_WARNING "PCI: unknown board, no PCI IRQs assigned.\n"); |
diff --git a/arch/mips/pci/fixup-tb0219.c b/arch/mips/pci/fixup-tb0219.c index 720a2b720c5c..ed87733f6796 100644 --- a/arch/mips/pci/fixup-tb0219.c +++ b/arch/mips/pci/fixup-tb0219.c | |||
@@ -2,7 +2,7 @@ | |||
2 | * fixup-tb0219.c, The TANBAC TB0219 specific PCI fixups. | 2 | * fixup-tb0219.c, The TANBAC TB0219 specific PCI fixups. |
3 | * | 3 | * |
4 | * Copyright (C) 2003 Megasolution Inc. <matsu@megasolution.jp> | 4 | * Copyright (C) 2003 Megasolution Inc. <matsu@megasolution.jp> |
5 | * Copyright (C) 2004 Yoichi Yuasa <yoichi_yuasa@tripeaks.co.jp> | 5 | * Copyright (C) 2004-2005 Yoichi Yuasa <yoichi_yuasa@tripeaks.co.jp> |
6 | * | 6 | * |
7 | * This program is free software; you can redistribute it and/or modify | 7 | * This program is free software; you can redistribute it and/or modify |
8 | * it under the terms of the GNU General Public License as published by | 8 | * it under the terms of the GNU General Public License as published by |
diff --git a/arch/mips/pci/ops-pmcmsp.c b/arch/mips/pci/ops-pmcmsp.c index 059eade96f2e..109c95ca698b 100644 --- a/arch/mips/pci/ops-pmcmsp.c +++ b/arch/mips/pci/ops-pmcmsp.c | |||
@@ -404,7 +404,7 @@ int msp_pcibios_config_access(unsigned char access_type, | |||
404 | if (pciirqflag == 0) { | 404 | if (pciirqflag == 0) { |
405 | request_irq(MSP_INT_PCI,/* Hardcoded internal MSP7120 wiring */ | 405 | request_irq(MSP_INT_PCI,/* Hardcoded internal MSP7120 wiring */ |
406 | bpci_interrupt, | 406 | bpci_interrupt, |
407 | SA_SHIRQ | SA_INTERRUPT, | 407 | IRQF_SHARED | IRQF_DISABLED, |
408 | "PMC MSP PCI Host", | 408 | "PMC MSP PCI Host", |
409 | preg); | 409 | preg); |
410 | pciirqflag = ~0; | 410 | pciirqflag = ~0; |
diff --git a/arch/mips/pmc-sierra/msp71xx/msp_serial.c b/arch/mips/pmc-sierra/msp71xx/msp_serial.c index 15e7b8000b4c..9de34302e5f4 100644 --- a/arch/mips/pmc-sierra/msp71xx/msp_serial.c +++ b/arch/mips/pmc-sierra/msp71xx/msp_serial.c | |||
@@ -122,7 +122,7 @@ void __init msp_serial_setup(void) | |||
122 | up.uartclk = uartclk; | 122 | up.uartclk = uartclk; |
123 | up.regshift = 2; | 123 | up.regshift = 2; |
124 | up.iotype = UPIO_DWAPB; /* UPIO_MEM like */ | 124 | up.iotype = UPIO_DWAPB; /* UPIO_MEM like */ |
125 | up.flags = STD_COM_FLAGS; | 125 | up.flags = ASYNC_BOOT_AUTOCONF | ASYNC_SKIP_TEST; |
126 | up.type = PORT_16550A; | 126 | up.type = PORT_16550A; |
127 | up.line = 0; | 127 | up.line = 0; |
128 | up.private_data = (void*)UART0_STATUS_REG; | 128 | up.private_data = (void*)UART0_STATUS_REG; |
diff --git a/arch/mips/qemu/q-irq.c b/arch/mips/qemu/q-irq.c index 4681757460a1..11f984767880 100644 --- a/arch/mips/qemu/q-irq.c +++ b/arch/mips/qemu/q-irq.c | |||
@@ -1,4 +1,5 @@ | |||
1 | #include <linux/init.h> | 1 | #include <linux/init.h> |
2 | #include <linux/interrupt.h> | ||
2 | #include <linux/linkage.h> | 3 | #include <linux/linkage.h> |
3 | 4 | ||
4 | #include <asm/i8259.h> | 5 | #include <asm/i8259.h> |
diff --git a/arch/mips/sgi-ip27/ip27-timer.c b/arch/mips/sgi-ip27/ip27-timer.c index f5dccf01da11..08d45369be45 100644 --- a/arch/mips/sgi-ip27/ip27-timer.c +++ b/arch/mips/sgi-ip27/ip27-timer.c | |||
@@ -131,12 +131,12 @@ static struct irq_chip rt_irq_type = { | |||
131 | static int rt_next_event(unsigned long delta, struct clock_event_device *evt) | 131 | static int rt_next_event(unsigned long delta, struct clock_event_device *evt) |
132 | { | 132 | { |
133 | unsigned int cpu = smp_processor_id(); | 133 | unsigned int cpu = smp_processor_id(); |
134 | int slice = cputoslice(cpu) == 0; | 134 | int slice = cputoslice(cpu); |
135 | unsigned long cnt; | 135 | unsigned long cnt; |
136 | 136 | ||
137 | cnt = LOCAL_HUB_L(PI_RT_COUNT); | 137 | cnt = LOCAL_HUB_L(PI_RT_COUNT); |
138 | cnt += delta; | 138 | cnt += delta; |
139 | LOCAL_HUB_S(slice ? PI_RT_COMPARE_A : PI_RT_COMPARE_B, cnt); | 139 | LOCAL_HUB_S(PI_RT_COMPARE_A + PI_COUNT_OFFSET * slice, cnt); |
140 | 140 | ||
141 | return LOCAL_HUB_L(PI_RT_COUNT) >= cnt ? -ETIME : 0; | 141 | return LOCAL_HUB_L(PI_RT_COUNT) >= cnt ? -ETIME : 0; |
142 | } | 142 | } |
@@ -164,9 +164,12 @@ static irqreturn_t hub_rt_counter_handler(int irq, void *dev_id) | |||
164 | { | 164 | { |
165 | struct clock_event_device *cd = dev_id; | 165 | struct clock_event_device *cd = dev_id; |
166 | unsigned int cpu = smp_processor_id(); | 166 | unsigned int cpu = smp_processor_id(); |
167 | int slice = cputoslice(cpu) == 0; | 167 | int slice = cputoslice(cpu); |
168 | 168 | ||
169 | LOCAL_HUB_S(slice ? PI_RT_PEND_A : PI_RT_PEND_B, 0); /* Ack */ | 169 | /* |
170 | * Ack | ||
171 | */ | ||
172 | LOCAL_HUB_S(PI_RT_PEND_A + PI_COUNT_OFFSET * slice, 0); | ||
170 | cd->event_handler(cd); | 173 | cd->event_handler(cd); |
171 | 174 | ||
172 | return IRQ_HANDLED; | 175 | return IRQ_HANDLED; |
diff --git a/arch/mips/sgi-ip32/ip32-irq.c b/arch/mips/sgi-ip32/ip32-irq.c index 7e8094f617bf..aab17ddd2f30 100644 --- a/arch/mips/sgi-ip32/ip32-irq.c +++ b/arch/mips/sgi-ip32/ip32-irq.c | |||
@@ -40,13 +40,6 @@ static void inline flush_mace_bus(void) | |||
40 | mace->perif.ctrl.misc; | 40 | mace->perif.ctrl.misc; |
41 | } | 41 | } |
42 | 42 | ||
43 | #undef DEBUG_IRQ | ||
44 | #ifdef DEBUG_IRQ | ||
45 | #define DBG(x...) printk(x) | ||
46 | #else | ||
47 | #define DBG(x...) | ||
48 | #endif | ||
49 | |||
50 | /* | 43 | /* |
51 | * O2 irq map | 44 | * O2 irq map |
52 | * | 45 | * |
@@ -125,6 +118,7 @@ struct irqaction memerr_irq = { | |||
125 | .mask = CPU_MASK_NONE, | 118 | .mask = CPU_MASK_NONE, |
126 | .name = "CRIME memory error", | 119 | .name = "CRIME memory error", |
127 | }; | 120 | }; |
121 | |||
128 | struct irqaction cpuerr_irq = { | 122 | struct irqaction cpuerr_irq = { |
129 | .handler = crime_cpuerr_intr, | 123 | .handler = crime_cpuerr_intr, |
130 | .flags = IRQF_DISABLED, | 124 | .flags = IRQF_DISABLED, |
@@ -139,46 +133,70 @@ struct irqaction cpuerr_irq = { | |||
139 | 133 | ||
140 | static uint64_t crime_mask; | 134 | static uint64_t crime_mask; |
141 | 135 | ||
142 | static void enable_crime_irq(unsigned int irq) | 136 | static inline void crime_enable_irq(unsigned int irq) |
143 | { | 137 | { |
144 | crime_mask |= 1 << (irq - 1); | 138 | unsigned int bit = irq - CRIME_IRQ_BASE; |
139 | |||
140 | crime_mask |= 1 << bit; | ||
145 | crime->imask = crime_mask; | 141 | crime->imask = crime_mask; |
146 | } | 142 | } |
147 | 143 | ||
148 | static void disable_crime_irq(unsigned int irq) | 144 | static inline void crime_disable_irq(unsigned int irq) |
149 | { | 145 | { |
150 | crime_mask &= ~(1 << (irq - 1)); | 146 | unsigned int bit = irq - CRIME_IRQ_BASE; |
147 | |||
148 | crime_mask &= ~(1 << bit); | ||
151 | crime->imask = crime_mask; | 149 | crime->imask = crime_mask; |
152 | flush_crime_bus(); | 150 | flush_crime_bus(); |
153 | } | 151 | } |
154 | 152 | ||
155 | static void mask_and_ack_crime_irq(unsigned int irq) | 153 | static void crime_level_mask_and_ack_irq(unsigned int irq) |
154 | { | ||
155 | crime_disable_irq(irq); | ||
156 | } | ||
157 | |||
158 | static void crime_level_end_irq(unsigned int irq) | ||
159 | { | ||
160 | if (!(irq_desc[irq].status & (IRQ_DISABLED | IRQ_INPROGRESS))) | ||
161 | crime_enable_irq(irq); | ||
162 | } | ||
163 | |||
164 | static struct irq_chip crime_level_interrupt = { | ||
165 | .name = "IP32 CRIME", | ||
166 | .ack = crime_level_mask_and_ack_irq, | ||
167 | .mask = crime_disable_irq, | ||
168 | .mask_ack = crime_level_mask_and_ack_irq, | ||
169 | .unmask = crime_enable_irq, | ||
170 | .end = crime_level_end_irq, | ||
171 | }; | ||
172 | |||
173 | static void crime_edge_mask_and_ack_irq(unsigned int irq) | ||
156 | { | 174 | { |
175 | unsigned int bit = irq - CRIME_IRQ_BASE; | ||
176 | uint64_t crime_int; | ||
177 | |||
157 | /* Edge triggered interrupts must be cleared. */ | 178 | /* Edge triggered interrupts must be cleared. */ |
158 | if ((irq >= CRIME_GBE0_IRQ && irq <= CRIME_GBE3_IRQ) | 179 | |
159 | || (irq >= CRIME_RE_EMPTY_E_IRQ && irq <= CRIME_RE_IDLE_E_IRQ) | 180 | crime_int = crime->hard_int; |
160 | || (irq >= CRIME_SOFT0_IRQ && irq <= CRIME_SOFT2_IRQ)) { | 181 | crime_int &= ~(1 << bit); |
161 | uint64_t crime_int; | 182 | crime->hard_int = crime_int; |
162 | crime_int = crime->hard_int; | 183 | |
163 | crime_int &= ~(1 << (irq - 1)); | 184 | crime_disable_irq(irq); |
164 | crime->hard_int = crime_int; | ||
165 | } | ||
166 | disable_crime_irq(irq); | ||
167 | } | 185 | } |
168 | 186 | ||
169 | static void end_crime_irq(unsigned int irq) | 187 | static void crime_edge_end_irq(unsigned int irq) |
170 | { | 188 | { |
171 | if (!(irq_desc[irq].status & (IRQ_DISABLED | IRQ_INPROGRESS))) | 189 | if (!(irq_desc[irq].status & (IRQ_DISABLED | IRQ_INPROGRESS))) |
172 | enable_crime_irq(irq); | 190 | crime_enable_irq(irq); |
173 | } | 191 | } |
174 | 192 | ||
175 | static struct irq_chip ip32_crime_interrupt = { | 193 | static struct irq_chip crime_edge_interrupt = { |
176 | .name = "IP32 CRIME", | 194 | .name = "IP32 CRIME", |
177 | .ack = mask_and_ack_crime_irq, | 195 | .ack = crime_edge_mask_and_ack_irq, |
178 | .mask = disable_crime_irq, | 196 | .mask = crime_disable_irq, |
179 | .mask_ack = mask_and_ack_crime_irq, | 197 | .mask_ack = crime_edge_mask_and_ack_irq, |
180 | .unmask = enable_crime_irq, | 198 | .unmask = crime_enable_irq, |
181 | .end = end_crime_irq, | 199 | .end = crime_edge_end_irq, |
182 | }; | 200 | }; |
183 | 201 | ||
184 | /* | 202 | /* |
@@ -265,7 +283,7 @@ static void enable_maceisa_irq(unsigned int irq) | |||
265 | { | 283 | { |
266 | unsigned int crime_int = 0; | 284 | unsigned int crime_int = 0; |
267 | 285 | ||
268 | DBG("maceisa enable: %u\n", irq); | 286 | pr_debug("maceisa enable: %u\n", irq); |
269 | 287 | ||
270 | switch (irq) { | 288 | switch (irq) { |
271 | case MACEISA_AUDIO_SW_IRQ ... MACEISA_AUDIO3_MERR_IRQ: | 289 | case MACEISA_AUDIO_SW_IRQ ... MACEISA_AUDIO3_MERR_IRQ: |
@@ -278,7 +296,7 @@ static void enable_maceisa_irq(unsigned int irq) | |||
278 | crime_int = MACE_SUPERIO_INT; | 296 | crime_int = MACE_SUPERIO_INT; |
279 | break; | 297 | break; |
280 | } | 298 | } |
281 | DBG("crime_int %08x enabled\n", crime_int); | 299 | pr_debug("crime_int %08x enabled\n", crime_int); |
282 | crime_mask |= crime_int; | 300 | crime_mask |= crime_int; |
283 | crime->imask = crime_mask; | 301 | crime->imask = crime_mask; |
284 | maceisa_mask |= 1 << (irq - 33); | 302 | maceisa_mask |= 1 << (irq - 33); |
@@ -290,11 +308,11 @@ static void disable_maceisa_irq(unsigned int irq) | |||
290 | unsigned int crime_int = 0; | 308 | unsigned int crime_int = 0; |
291 | 309 | ||
292 | maceisa_mask &= ~(1 << (irq - 33)); | 310 | maceisa_mask &= ~(1 << (irq - 33)); |
293 | if(!(maceisa_mask & MACEISA_AUDIO_INT)) | 311 | if (!(maceisa_mask & MACEISA_AUDIO_INT)) |
294 | crime_int |= MACE_AUDIO_INT; | 312 | crime_int |= MACE_AUDIO_INT; |
295 | if(!(maceisa_mask & MACEISA_MISC_INT)) | 313 | if (!(maceisa_mask & MACEISA_MISC_INT)) |
296 | crime_int |= MACE_MISC_INT; | 314 | crime_int |= MACE_MISC_INT; |
297 | if(!(maceisa_mask & MACEISA_SUPERIO_INT)) | 315 | if (!(maceisa_mask & MACEISA_SUPERIO_INT)) |
298 | crime_int |= MACE_SUPERIO_INT; | 316 | crime_int |= MACE_SUPERIO_INT; |
299 | crime_mask &= ~crime_int; | 317 | crime_mask &= ~crime_int; |
300 | crime->imask = crime_mask; | 318 | crime->imask = crime_mask; |
@@ -327,12 +345,12 @@ static void end_maceisa_irq(unsigned irq) | |||
327 | } | 345 | } |
328 | 346 | ||
329 | static struct irq_chip ip32_maceisa_interrupt = { | 347 | static struct irq_chip ip32_maceisa_interrupt = { |
330 | .name = "IP32 MACE ISA", | 348 | .name = "IP32 MACE ISA", |
331 | .ack = mask_and_ack_maceisa_irq, | 349 | .ack = mask_and_ack_maceisa_irq, |
332 | .mask = disable_maceisa_irq, | 350 | .mask = disable_maceisa_irq, |
333 | .mask_ack = mask_and_ack_maceisa_irq, | 351 | .mask_ack = mask_and_ack_maceisa_irq, |
334 | .unmask = enable_maceisa_irq, | 352 | .unmask = enable_maceisa_irq, |
335 | .end = end_maceisa_irq, | 353 | .end = end_maceisa_irq, |
336 | }; | 354 | }; |
337 | 355 | ||
338 | /* This is used for regular non-ISA, non-PCI MACE interrupts. That means | 356 | /* This is used for regular non-ISA, non-PCI MACE interrupts. That means |
@@ -411,7 +429,7 @@ static void ip32_irq0(void) | |||
411 | irq = __ffs(mace_int & maceisa_mask) + MACEISA_AUDIO_SW_IRQ; | 429 | irq = __ffs(mace_int & maceisa_mask) + MACEISA_AUDIO_SW_IRQ; |
412 | } | 430 | } |
413 | 431 | ||
414 | DBG("*irq %u*\n", irq); | 432 | pr_debug("*irq %u*\n", irq); |
415 | do_IRQ(irq); | 433 | do_IRQ(irq); |
416 | } | 434 | } |
417 | 435 | ||
@@ -472,23 +490,31 @@ void __init arch_init_irq(void) | |||
472 | 490 | ||
473 | mips_cpu_irq_init(); | 491 | mips_cpu_irq_init(); |
474 | for (irq = MIPS_CPU_IRQ_BASE + 8; irq <= IP32_IRQ_MAX; irq++) { | 492 | for (irq = MIPS_CPU_IRQ_BASE + 8; irq <= IP32_IRQ_MAX; irq++) { |
475 | struct irq_chip *chip; | ||
476 | |||
477 | switch (irq) { | 493 | switch (irq) { |
478 | case MACE_VID_IN1_IRQ ... MACE_PCI_BRIDGE_IRQ: | 494 | case MACE_VID_IN1_IRQ ... MACE_PCI_BRIDGE_IRQ: |
479 | chip = &ip32_mace_interrupt; | 495 | set_irq_chip(irq, &ip32_mace_interrupt); |
480 | break; | 496 | break; |
481 | case MACEPCI_SCSI0_IRQ ... MACEPCI_SHARED2_IRQ: | 497 | case MACEPCI_SCSI0_IRQ ... MACEPCI_SHARED2_IRQ: |
482 | chip = &ip32_macepci_interrupt; | 498 | set_irq_chip(irq, &ip32_macepci_interrupt); |
499 | break; | ||
500 | case CRIME_GBE0_IRQ ... CRIME_GBE3_IRQ: | ||
501 | set_irq_chip(irq, &crime_edge_interrupt); | ||
502 | break; | ||
503 | case CRIME_CPUERR_IRQ: | ||
504 | case CRIME_MEMERR_IRQ: | ||
505 | set_irq_chip(irq, &crime_level_interrupt); | ||
483 | break; | 506 | break; |
484 | case CRIME_GBE0_IRQ ... CRIME_VICE_IRQ: | 507 | case CRIME_RE_EMPTY_E_IRQ ... CRIME_RE_IDLE_E_IRQ: |
485 | chip = &ip32_crime_interrupt; | 508 | case CRIME_SOFT0_IRQ ... CRIME_SOFT2_IRQ: |
509 | set_irq_chip(irq, &crime_edge_interrupt); | ||
510 | break; | ||
511 | case CRIME_VICE_IRQ: | ||
512 | set_irq_chip(irq, &crime_edge_interrupt); | ||
486 | break; | 513 | break; |
487 | default: | 514 | default: |
488 | chip = &ip32_maceisa_interrupt; | 515 | set_irq_chip(irq, &ip32_maceisa_interrupt); |
516 | break; | ||
489 | } | 517 | } |
490 | |||
491 | set_irq_chip(irq, chip); | ||
492 | } | 518 | } |
493 | setup_irq(CRIME_MEMERR_IRQ, &memerr_irq); | 519 | setup_irq(CRIME_MEMERR_IRQ, &memerr_irq); |
494 | setup_irq(CRIME_CPUERR_IRQ, &cpuerr_irq); | 520 | setup_irq(CRIME_CPUERR_IRQ, &cpuerr_irq); |
diff --git a/arch/mips/sgi-ip32/ip32-platform.c b/arch/mips/sgi-ip32/ip32-platform.c index 7309e48d163d..77febd68fcd4 100644 --- a/arch/mips/sgi-ip32/ip32-platform.c +++ b/arch/mips/sgi-ip32/ip32-platform.c | |||
@@ -42,7 +42,7 @@ static struct platform_device uart8250_device = { | |||
42 | static int __init uart8250_init(void) | 42 | static int __init uart8250_init(void) |
43 | { | 43 | { |
44 | uart8250_data[0].membase = (void __iomem *) &mace->isa.serial1; | 44 | uart8250_data[0].membase = (void __iomem *) &mace->isa.serial1; |
45 | uart8250_data[1].membase = (void __iomem *) &mace->isa.serial1; | 45 | uart8250_data[1].membase = (void __iomem *) &mace->isa.serial2; |
46 | 46 | ||
47 | return platform_device_register(&uart8250_device); | 47 | return platform_device_register(&uart8250_device); |
48 | } | 48 | } |
diff --git a/arch/mips/sibyte/Kconfig b/arch/mips/sibyte/Kconfig index e8fb880272bd..366b19d33f77 100644 --- a/arch/mips/sibyte/Kconfig +++ b/arch/mips/sibyte/Kconfig | |||
@@ -1,5 +1,7 @@ | |||
1 | config SIBYTE_SB1250 | 1 | config SIBYTE_SB1250 |
2 | bool | 2 | bool |
3 | select CEVT_SB1250 | ||
4 | select CSRC_SB1250 | ||
3 | select HW_HAS_PCI | 5 | select HW_HAS_PCI |
4 | select IRQ_CPU | 6 | select IRQ_CPU |
5 | select SIBYTE_ENABLE_LDT_IF_PCI | 7 | select SIBYTE_ENABLE_LDT_IF_PCI |
@@ -9,6 +11,8 @@ config SIBYTE_SB1250 | |||
9 | 11 | ||
10 | config SIBYTE_BCM1120 | 12 | config SIBYTE_BCM1120 |
11 | bool | 13 | bool |
14 | select CEVT_SB1250 | ||
15 | select CSRC_SB1250 | ||
12 | select IRQ_CPU | 16 | select IRQ_CPU |
13 | select SIBYTE_BCM112X | 17 | select SIBYTE_BCM112X |
14 | select SIBYTE_HAS_ZBUS_PROFILING | 18 | select SIBYTE_HAS_ZBUS_PROFILING |
@@ -16,6 +20,8 @@ config SIBYTE_BCM1120 | |||
16 | 20 | ||
17 | config SIBYTE_BCM1125 | 21 | config SIBYTE_BCM1125 |
18 | bool | 22 | bool |
23 | select CEVT_SB1250 | ||
24 | select CSRC_SB1250 | ||
19 | select HW_HAS_PCI | 25 | select HW_HAS_PCI |
20 | select IRQ_CPU | 26 | select IRQ_CPU |
21 | select SIBYTE_BCM112X | 27 | select SIBYTE_BCM112X |
@@ -24,6 +30,8 @@ config SIBYTE_BCM1125 | |||
24 | 30 | ||
25 | config SIBYTE_BCM1125H | 31 | config SIBYTE_BCM1125H |
26 | bool | 32 | bool |
33 | select CEVT_SB1250 | ||
34 | select CSRC_SB1250 | ||
27 | select HW_HAS_PCI | 35 | select HW_HAS_PCI |
28 | select IRQ_CPU | 36 | select IRQ_CPU |
29 | select SIBYTE_BCM112X | 37 | select SIBYTE_BCM112X |
@@ -33,12 +41,16 @@ config SIBYTE_BCM1125H | |||
33 | 41 | ||
34 | config SIBYTE_BCM112X | 42 | config SIBYTE_BCM112X |
35 | bool | 43 | bool |
44 | select CEVT_SB1250 | ||
45 | select CSRC_SB1250 | ||
36 | select IRQ_CPU | 46 | select IRQ_CPU |
37 | select SIBYTE_SB1xxx_SOC | 47 | select SIBYTE_SB1xxx_SOC |
38 | select SIBYTE_HAS_ZBUS_PROFILING | 48 | select SIBYTE_HAS_ZBUS_PROFILING |
39 | 49 | ||
40 | config SIBYTE_BCM1x80 | 50 | config SIBYTE_BCM1x80 |
41 | bool | 51 | bool |
52 | select CEVT_BCM1480 | ||
53 | select CSRC_BCM1480 | ||
42 | select HW_HAS_PCI | 54 | select HW_HAS_PCI |
43 | select IRQ_CPU | 55 | select IRQ_CPU |
44 | select SIBYTE_HAS_ZBUS_PROFILING | 56 | select SIBYTE_HAS_ZBUS_PROFILING |
@@ -47,6 +59,8 @@ config SIBYTE_BCM1x80 | |||
47 | 59 | ||
48 | config SIBYTE_BCM1x55 | 60 | config SIBYTE_BCM1x55 |
49 | bool | 61 | bool |
62 | select CEVT_BCM1480 | ||
63 | select CSRC_BCM1480 | ||
50 | select HW_HAS_PCI | 64 | select HW_HAS_PCI |
51 | select IRQ_CPU | 65 | select IRQ_CPU |
52 | select SIBYTE_SB1xxx_SOC | 66 | select SIBYTE_SB1xxx_SOC |
diff --git a/arch/mips/sibyte/bcm1480/irq.c b/arch/mips/sibyte/bcm1480/irq.c index 10299bafeab7..e28d626255a3 100644 --- a/arch/mips/sibyte/bcm1480/irq.c +++ b/arch/mips/sibyte/bcm1480/irq.c | |||
@@ -265,42 +265,6 @@ void __init init_bcm1480_irqs(void) | |||
265 | } | 265 | } |
266 | } | 266 | } |
267 | 267 | ||
268 | |||
269 | static irqreturn_t bcm1480_dummy_handler(int irq, void *dev_id) | ||
270 | { | ||
271 | return IRQ_NONE; | ||
272 | } | ||
273 | |||
274 | static struct irqaction bcm1480_dummy_action = { | ||
275 | .handler = bcm1480_dummy_handler, | ||
276 | .flags = 0, | ||
277 | .mask = CPU_MASK_NONE, | ||
278 | .name = "bcm1480-private", | ||
279 | .next = NULL, | ||
280 | .dev_id = 0 | ||
281 | }; | ||
282 | |||
283 | int bcm1480_steal_irq(int irq) | ||
284 | { | ||
285 | struct irq_desc *desc = irq_desc + irq; | ||
286 | unsigned long flags; | ||
287 | int retval = 0; | ||
288 | |||
289 | if (irq >= BCM1480_NR_IRQS) | ||
290 | return -EINVAL; | ||
291 | |||
292 | spin_lock_irqsave(&desc->lock, flags); | ||
293 | /* Don't allow sharing at all for these */ | ||
294 | if (desc->action != NULL) | ||
295 | retval = -EBUSY; | ||
296 | else { | ||
297 | desc->action = &bcm1480_dummy_action; | ||
298 | desc->depth = 0; | ||
299 | } | ||
300 | spin_unlock_irqrestore(&desc->lock, flags); | ||
301 | return 0; | ||
302 | } | ||
303 | |||
304 | /* | 268 | /* |
305 | * init_IRQ is called early in the boot sequence from init/main.c. It | 269 | * init_IRQ is called early in the boot sequence from init/main.c. It |
306 | * is responsible for setting up the interrupt mapper and installing the | 270 | * is responsible for setting up the interrupt mapper and installing the |
@@ -329,7 +293,6 @@ int bcm1480_steal_irq(int irq) | |||
329 | 293 | ||
330 | void __init arch_init_irq(void) | 294 | void __init arch_init_irq(void) |
331 | { | 295 | { |
332 | |||
333 | unsigned int i, cpu; | 296 | unsigned int i, cpu; |
334 | u64 tmp; | 297 | u64 tmp; |
335 | unsigned int imask = STATUSF_IP4 | STATUSF_IP3 | STATUSF_IP2 | | 298 | unsigned int imask = STATUSF_IP4 | STATUSF_IP3 | STATUSF_IP2 | |
@@ -386,8 +349,6 @@ void __init arch_init_irq(void) | |||
386 | __raw_writeq(tmp, IOADDR(A_BCM1480_IMR_REGISTER(cpu, R_BCM1480_IMR_INTERRUPT_MASK_L))); | 349 | __raw_writeq(tmp, IOADDR(A_BCM1480_IMR_REGISTER(cpu, R_BCM1480_IMR_INTERRUPT_MASK_L))); |
387 | } | 350 | } |
388 | 351 | ||
389 | bcm1480_steal_irq(K_BCM1480_INT_MBOX_0_0); | ||
390 | |||
391 | /* | 352 | /* |
392 | * Note that the timer interrupts are also mapped, but this is | 353 | * Note that the timer interrupts are also mapped, but this is |
393 | * done in bcm1480_time_init(). Also, the profiling driver | 354 | * done in bcm1480_time_init(). Also, the profiling driver |
@@ -411,7 +372,6 @@ void __init arch_init_irq(void) | |||
411 | /* QQQ FIXME */ | 372 | /* QQQ FIXME */ |
412 | __raw_writeq(M_DUART_IMR_BRK, IO_SPACE_BASE + A_DUART_IMRREG(kgdb_port)); | 373 | __raw_writeq(M_DUART_IMR_BRK, IO_SPACE_BASE + A_DUART_IMRREG(kgdb_port)); |
413 | 374 | ||
414 | bcm1480_steal_irq(kgdb_irq); | ||
415 | __raw_writeq(IMR_IP6_VAL, | 375 | __raw_writeq(IMR_IP6_VAL, |
416 | IO_SPACE_BASE + A_BCM1480_IMR_REGISTER(0, R_BCM1480_IMR_INTERRUPT_MAP_BASE_H) + | 376 | IO_SPACE_BASE + A_BCM1480_IMR_REGISTER(0, R_BCM1480_IMR_INTERRUPT_MAP_BASE_H) + |
417 | (kgdb_irq<<3)); | 377 | (kgdb_irq<<3)); |
diff --git a/arch/mips/sibyte/bcm1480/time.c b/arch/mips/sibyte/bcm1480/time.c index 610f0253954d..1680a68952ae 100644 --- a/arch/mips/sibyte/bcm1480/time.c +++ b/arch/mips/sibyte/bcm1480/time.c | |||
@@ -15,166 +15,10 @@ | |||
15 | * along with this program; if not, write to the Free Software | 15 | * along with this program; if not, write to the Free Software |
16 | * Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. | 16 | * Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. |
17 | */ | 17 | */ |
18 | #include <linux/clockchips.h> | 18 | #include <linux/init.h> |
19 | #include <linux/interrupt.h> | ||
20 | #include <linux/irq.h> | ||
21 | #include <linux/percpu.h> | ||
22 | #include <linux/spinlock.h> | ||
23 | 19 | ||
24 | #include <asm/addrspace.h> | 20 | extern void sb1480_clockevent_init(void); |
25 | #include <asm/time.h> | 21 | extern void sb1480_clocksource_init(void); |
26 | #include <asm/io.h> | ||
27 | |||
28 | #include <asm/sibyte/bcm1480_regs.h> | ||
29 | #include <asm/sibyte/sb1250_regs.h> | ||
30 | #include <asm/sibyte/bcm1480_int.h> | ||
31 | #include <asm/sibyte/bcm1480_scd.h> | ||
32 | |||
33 | #include <asm/sibyte/sb1250.h> | ||
34 | |||
35 | |||
36 | #define IMR_IP2_VAL K_BCM1480_INT_MAP_I0 | ||
37 | #define IMR_IP3_VAL K_BCM1480_INT_MAP_I1 | ||
38 | #define IMR_IP4_VAL K_BCM1480_INT_MAP_I2 | ||
39 | |||
40 | extern int bcm1480_steal_irq(int irq); | ||
41 | |||
42 | /* | ||
43 | * The general purpose timer ticks at 1MHz independent if | ||
44 | * the rest of the system | ||
45 | */ | ||
46 | static void sibyte_set_mode(enum clock_event_mode mode, | ||
47 | struct clock_event_device *evt) | ||
48 | { | ||
49 | unsigned int cpu = smp_processor_id(); | ||
50 | void __iomem *timer_cfg, *timer_init; | ||
51 | |||
52 | timer_cfg = IOADDR(A_SCD_TIMER_REGISTER(cpu, R_SCD_TIMER_CFG)); | ||
53 | timer_init = IOADDR(A_SCD_TIMER_REGISTER(cpu, R_SCD_TIMER_INIT)); | ||
54 | |||
55 | switch (mode) { | ||
56 | case CLOCK_EVT_MODE_PERIODIC: | ||
57 | __raw_writeq(0, timer_cfg); | ||
58 | __raw_writeq((V_SCD_TIMER_FREQ / HZ) - 1, timer_init); | ||
59 | __raw_writeq(M_SCD_TIMER_ENABLE | M_SCD_TIMER_MODE_CONTINUOUS, | ||
60 | timer_cfg); | ||
61 | break; | ||
62 | |||
63 | case CLOCK_EVT_MODE_ONESHOT: | ||
64 | /* Stop the timer until we actually program a shot */ | ||
65 | case CLOCK_EVT_MODE_SHUTDOWN: | ||
66 | __raw_writeq(0, timer_cfg); | ||
67 | break; | ||
68 | |||
69 | case CLOCK_EVT_MODE_UNUSED: /* shuddup gcc */ | ||
70 | case CLOCK_EVT_MODE_RESUME: | ||
71 | ; | ||
72 | } | ||
73 | } | ||
74 | |||
75 | static int sibyte_next_event(unsigned long delta, struct clock_event_device *cd) | ||
76 | { | ||
77 | unsigned int cpu = smp_processor_id(); | ||
78 | void __iomem *timer_init; | ||
79 | unsigned int cnt; | ||
80 | int res; | ||
81 | |||
82 | timer_init = IOADDR(A_SCD_TIMER_REGISTER(cpu, R_SCD_TIMER_INIT)); | ||
83 | cnt = __raw_readq(timer_init); | ||
84 | cnt += delta; | ||
85 | __raw_writeq(cnt, timer_init); | ||
86 | res = ((long)(__raw_readq(timer_init) - cnt ) > 0) ? -ETIME : 0; | ||
87 | |||
88 | return res; | ||
89 | } | ||
90 | |||
91 | static irqreturn_t sibyte_counter_handler(int irq, void *dev_id) | ||
92 | { | ||
93 | unsigned int cpu = smp_processor_id(); | ||
94 | struct clock_event_device *cd = dev_id; | ||
95 | void __iomem *timer_cfg; | ||
96 | |||
97 | timer_cfg = IOADDR(A_SCD_TIMER_REGISTER(cpu, R_SCD_TIMER_CFG)); | ||
98 | |||
99 | /* Reset the timer */ | ||
100 | __raw_writeq(M_SCD_TIMER_ENABLE | M_SCD_TIMER_MODE_CONTINUOUS, | ||
101 | timer_cfg); | ||
102 | cd->event_handler(cd); | ||
103 | |||
104 | return IRQ_HANDLED; | ||
105 | } | ||
106 | |||
107 | static DEFINE_PER_CPU(struct clock_event_device, sibyte_hpt_clockevent); | ||
108 | static DEFINE_PER_CPU(struct irqaction, sibyte_hpt_irqaction); | ||
109 | static DEFINE_PER_CPU(char [18], sibyte_hpt_name); | ||
110 | |||
111 | void __cpuinit sb1480_clockevent_init(void) | ||
112 | { | ||
113 | unsigned int cpu = smp_processor_id(); | ||
114 | unsigned int irq = K_BCM1480_INT_TIMER_0 + cpu; | ||
115 | struct irqaction *action = &per_cpu(sibyte_hpt_irqaction, cpu); | ||
116 | struct clock_event_device *cd = &per_cpu(sibyte_hpt_clockevent, cpu); | ||
117 | unsigned char *name = per_cpu(sibyte_hpt_name, cpu); | ||
118 | |||
119 | BUG_ON(cpu > 3); /* Only have 4 general purpose timers */ | ||
120 | |||
121 | sprintf(name, "bcm1480-counter %d", cpu); | ||
122 | cd->name = name; | ||
123 | cd->features = CLOCK_EVT_FEAT_PERIODIC | | ||
124 | CLOCK_EVT_MODE_ONESHOT; | ||
125 | clockevent_set_clock(cd, V_SCD_TIMER_FREQ); | ||
126 | cd->max_delta_ns = clockevent_delta2ns(0x7fffff, cd); | ||
127 | cd->min_delta_ns = clockevent_delta2ns(1, cd); | ||
128 | cd->rating = 200; | ||
129 | cd->irq = irq; | ||
130 | cd->cpumask = cpumask_of_cpu(cpu); | ||
131 | cd->set_next_event = sibyte_next_event; | ||
132 | cd->set_mode = sibyte_set_mode; | ||
133 | clockevents_register_device(cd); | ||
134 | |||
135 | bcm1480_mask_irq(cpu, irq); | ||
136 | |||
137 | /* | ||
138 | * Map timer interrupt to IP[4] of this cpu | ||
139 | */ | ||
140 | __raw_writeq(IMR_IP4_VAL, | ||
141 | IOADDR(A_BCM1480_IMR_REGISTER(cpu, | ||
142 | R_BCM1480_IMR_INTERRUPT_MAP_BASE_H) + (irq << 3))); | ||
143 | |||
144 | bcm1480_unmask_irq(cpu, irq); | ||
145 | bcm1480_steal_irq(irq); | ||
146 | |||
147 | action->handler = sibyte_counter_handler; | ||
148 | action->flags = IRQF_DISABLED | IRQF_PERCPU; | ||
149 | action->name = name; | ||
150 | action->dev_id = cd; | ||
151 | setup_irq(irq, action); | ||
152 | } | ||
153 | |||
154 | static cycle_t bcm1480_hpt_read(void) | ||
155 | { | ||
156 | return (cycle_t) __raw_readq(IOADDR(A_SCD_ZBBUS_CYCLE_COUNT)); | ||
157 | } | ||
158 | |||
159 | struct clocksource bcm1480_clocksource = { | ||
160 | .name = "zbbus-cycles", | ||
161 | .rating = 200, | ||
162 | .read = bcm1480_hpt_read, | ||
163 | .mask = CLOCKSOURCE_MASK(64), | ||
164 | .flags = CLOCK_SOURCE_IS_CONTINUOUS, | ||
165 | }; | ||
166 | |||
167 | void __init sb1480_clocksource_init(void) | ||
168 | { | ||
169 | struct clocksource *cs = &bcm1480_clocksource; | ||
170 | unsigned int plldiv; | ||
171 | unsigned long zbbus; | ||
172 | |||
173 | plldiv = G_BCM1480_SYS_PLL_DIV(__raw_readq(IOADDR(A_SCD_SYSTEM_CFG))); | ||
174 | zbbus = ((plldiv >> 1) * 50000000) + ((plldiv & 1) * 25000000); | ||
175 | clocksource_set_clock(cs, zbbus); | ||
176 | clocksource_register(cs); | ||
177 | } | ||
178 | 22 | ||
179 | void __init plat_time_init(void) | 23 | void __init plat_time_init(void) |
180 | { | 24 | { |
diff --git a/arch/mips/sibyte/sb1250/irq.c b/arch/mips/sibyte/sb1250/irq.c index 53780a179d1d..eac9065ffe0c 100644 --- a/arch/mips/sibyte/sb1250/irq.c +++ b/arch/mips/sibyte/sb1250/irq.c | |||
@@ -236,41 +236,6 @@ void __init init_sb1250_irqs(void) | |||
236 | } | 236 | } |
237 | 237 | ||
238 | 238 | ||
239 | static irqreturn_t sb1250_dummy_handler(int irq, void *dev_id) | ||
240 | { | ||
241 | return IRQ_NONE; | ||
242 | } | ||
243 | |||
244 | static struct irqaction sb1250_dummy_action = { | ||
245 | .handler = sb1250_dummy_handler, | ||
246 | .flags = 0, | ||
247 | .mask = CPU_MASK_NONE, | ||
248 | .name = "sb1250-private", | ||
249 | .next = NULL, | ||
250 | .dev_id = 0 | ||
251 | }; | ||
252 | |||
253 | int sb1250_steal_irq(int irq) | ||
254 | { | ||
255 | struct irq_desc *desc = irq_desc + irq; | ||
256 | unsigned long flags; | ||
257 | int retval = 0; | ||
258 | |||
259 | if (irq >= SB1250_NR_IRQS) | ||
260 | return -EINVAL; | ||
261 | |||
262 | spin_lock_irqsave(&desc->lock, flags); | ||
263 | /* Don't allow sharing at all for these */ | ||
264 | if (desc->action != NULL) | ||
265 | retval = -EBUSY; | ||
266 | else { | ||
267 | desc->action = &sb1250_dummy_action; | ||
268 | desc->depth = 0; | ||
269 | } | ||
270 | spin_unlock_irqrestore(&desc->lock, flags); | ||
271 | return 0; | ||
272 | } | ||
273 | |||
274 | /* | 239 | /* |
275 | * arch_init_irq is called early in the boot sequence from init/main.c via | 240 | * arch_init_irq is called early in the boot sequence from init/main.c via |
276 | * init_IRQ. It is responsible for setting up the interrupt mapper and | 241 | * init_IRQ. It is responsible for setting up the interrupt mapper and |
@@ -342,8 +307,6 @@ void __init arch_init_irq(void) | |||
342 | __raw_writeq(tmp, IOADDR(A_IMR_REGISTER(0, R_IMR_INTERRUPT_MASK))); | 307 | __raw_writeq(tmp, IOADDR(A_IMR_REGISTER(0, R_IMR_INTERRUPT_MASK))); |
343 | __raw_writeq(tmp, IOADDR(A_IMR_REGISTER(1, R_IMR_INTERRUPT_MASK))); | 308 | __raw_writeq(tmp, IOADDR(A_IMR_REGISTER(1, R_IMR_INTERRUPT_MASK))); |
344 | 309 | ||
345 | sb1250_steal_irq(K_INT_MBOX_0); | ||
346 | |||
347 | /* | 310 | /* |
348 | * Note that the timer interrupts are also mapped, but this is | 311 | * Note that the timer interrupts are also mapped, but this is |
349 | * done in sb1250_time_init(). Also, the profiling driver | 312 | * done in sb1250_time_init(). Also, the profiling driver |
@@ -367,7 +330,6 @@ void __init arch_init_irq(void) | |||
367 | __raw_writeq(M_DUART_IMR_BRK, | 330 | __raw_writeq(M_DUART_IMR_BRK, |
368 | IOADDR(A_DUART_IMRREG(kgdb_port))); | 331 | IOADDR(A_DUART_IMRREG(kgdb_port))); |
369 | 332 | ||
370 | sb1250_steal_irq(kgdb_irq); | ||
371 | __raw_writeq(IMR_IP6_VAL, | 333 | __raw_writeq(IMR_IP6_VAL, |
372 | IOADDR(A_IMR_REGISTER(0, | 334 | IOADDR(A_IMR_REGISTER(0, |
373 | R_IMR_INTERRUPT_MAP_BASE) + | 335 | R_IMR_INTERRUPT_MAP_BASE) + |
diff --git a/arch/mips/sibyte/sb1250/time.c b/arch/mips/sibyte/sb1250/time.c index a41e908bc218..68337bf7a5aa 100644 --- a/arch/mips/sibyte/sb1250/time.c +++ b/arch/mips/sibyte/sb1250/time.c | |||
@@ -15,198 +15,10 @@ | |||
15 | * along with this program; if not, write to the Free Software | 15 | * along with this program; if not, write to the Free Software |
16 | * Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. | 16 | * Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. |
17 | */ | 17 | */ |
18 | #include <linux/init.h> | ||
18 | 19 | ||
19 | /* | 20 | extern void sb1250_clocksource_init(void); |
20 | * These are routines to set up and handle interrupts from the | 21 | extern void sb1250_clockevent_init(void); |
21 | * sb1250 general purpose timer 0. We're using the timer as a | ||
22 | * system clock, so we set it up to run at 100 Hz. On every | ||
23 | * interrupt, we update our idea of what the time of day is, | ||
24 | * then call do_timer() in the architecture-independent kernel | ||
25 | * code to do general bookkeeping (e.g. update jiffies, run | ||
26 | * bottom halves, etc.) | ||
27 | */ | ||
28 | #include <linux/clockchips.h> | ||
29 | #include <linux/interrupt.h> | ||
30 | #include <linux/sched.h> | ||
31 | #include <linux/spinlock.h> | ||
32 | #include <linux/kernel_stat.h> | ||
33 | |||
34 | #include <asm/irq.h> | ||
35 | #include <asm/addrspace.h> | ||
36 | #include <asm/time.h> | ||
37 | #include <asm/io.h> | ||
38 | |||
39 | #include <asm/sibyte/sb1250.h> | ||
40 | #include <asm/sibyte/sb1250_regs.h> | ||
41 | #include <asm/sibyte/sb1250_int.h> | ||
42 | #include <asm/sibyte/sb1250_scd.h> | ||
43 | |||
44 | |||
45 | #define IMR_IP2_VAL K_INT_MAP_I0 | ||
46 | #define IMR_IP3_VAL K_INT_MAP_I1 | ||
47 | #define IMR_IP4_VAL K_INT_MAP_I2 | ||
48 | |||
49 | #define SB1250_HPT_NUM 3 | ||
50 | #define SB1250_HPT_VALUE M_SCD_TIMER_CNT /* max value */ | ||
51 | |||
52 | |||
53 | extern int sb1250_steal_irq(int irq); | ||
54 | |||
55 | /* | ||
56 | * The general purpose timer ticks at 1 Mhz independent if | ||
57 | * the rest of the system | ||
58 | */ | ||
59 | static void sibyte_set_mode(enum clock_event_mode mode, | ||
60 | struct clock_event_device *evt) | ||
61 | { | ||
62 | unsigned int cpu = smp_processor_id(); | ||
63 | void __iomem *timer_cfg, *timer_init; | ||
64 | |||
65 | timer_cfg = IOADDR(A_SCD_TIMER_REGISTER(cpu, R_SCD_TIMER_CFG)); | ||
66 | timer_init = IOADDR(A_SCD_TIMER_REGISTER(cpu, R_SCD_TIMER_INIT)); | ||
67 | |||
68 | switch(mode) { | ||
69 | case CLOCK_EVT_MODE_PERIODIC: | ||
70 | __raw_writeq(0, timer_cfg); | ||
71 | __raw_writeq((V_SCD_TIMER_FREQ / HZ) - 1, timer_init); | ||
72 | __raw_writeq(M_SCD_TIMER_ENABLE | M_SCD_TIMER_MODE_CONTINUOUS, | ||
73 | timer_cfg); | ||
74 | break; | ||
75 | |||
76 | case CLOCK_EVT_MODE_ONESHOT: | ||
77 | /* Stop the timer until we actually program a shot */ | ||
78 | case CLOCK_EVT_MODE_SHUTDOWN: | ||
79 | __raw_writeq(0, timer_cfg); | ||
80 | break; | ||
81 | |||
82 | case CLOCK_EVT_MODE_UNUSED: /* shuddup gcc */ | ||
83 | case CLOCK_EVT_MODE_RESUME: | ||
84 | ; | ||
85 | } | ||
86 | } | ||
87 | |||
88 | static int | ||
89 | sibyte_next_event(unsigned long delta, struct clock_event_device *evt) | ||
90 | { | ||
91 | unsigned int cpu = smp_processor_id(); | ||
92 | void __iomem *timer_cfg, *timer_init; | ||
93 | |||
94 | timer_cfg = IOADDR(A_SCD_TIMER_REGISTER(cpu, R_SCD_TIMER_CFG)); | ||
95 | timer_init = IOADDR(A_SCD_TIMER_REGISTER(cpu, R_SCD_TIMER_INIT)); | ||
96 | |||
97 | __raw_writeq(0, timer_cfg); | ||
98 | __raw_writeq(delta, timer_init); | ||
99 | __raw_writeq(M_SCD_TIMER_ENABLE, timer_cfg); | ||
100 | |||
101 | return 0; | ||
102 | } | ||
103 | |||
104 | static irqreturn_t sibyte_counter_handler(int irq, void *dev_id) | ||
105 | { | ||
106 | unsigned int cpu = smp_processor_id(); | ||
107 | struct clock_event_device *cd = dev_id; | ||
108 | |||
109 | /* ACK interrupt */ | ||
110 | ____raw_writeq(M_SCD_TIMER_ENABLE | M_SCD_TIMER_MODE_CONTINUOUS, | ||
111 | IOADDR(A_SCD_TIMER_REGISTER(cpu, R_SCD_TIMER_CFG))); | ||
112 | |||
113 | cd->event_handler(cd); | ||
114 | |||
115 | return IRQ_HANDLED; | ||
116 | } | ||
117 | |||
118 | static struct irqaction sibyte_irqaction = { | ||
119 | .handler = sibyte_counter_handler, | ||
120 | .flags = IRQF_DISABLED | IRQF_PERCPU, | ||
121 | .name = "timer", | ||
122 | }; | ||
123 | |||
124 | static DEFINE_PER_CPU(struct clock_event_device, sibyte_hpt_clockevent); | ||
125 | static DEFINE_PER_CPU(struct irqaction, sibyte_hpt_irqaction); | ||
126 | static DEFINE_PER_CPU(char [18], sibyte_hpt_name); | ||
127 | |||
128 | void __cpuinit sb1250_clockevent_init(void) | ||
129 | { | ||
130 | unsigned int cpu = smp_processor_id(); | ||
131 | unsigned int irq = K_INT_TIMER_0 + cpu; | ||
132 | struct irqaction *action = &per_cpu(sibyte_hpt_irqaction, cpu); | ||
133 | struct clock_event_device *cd = &per_cpu(sibyte_hpt_clockevent, cpu); | ||
134 | unsigned char *name = per_cpu(sibyte_hpt_name, cpu); | ||
135 | |||
136 | /* Only have 4 general purpose timers, and we use last one as hpt */ | ||
137 | BUG_ON(cpu > 2); | ||
138 | |||
139 | sprintf(name, "bcm1480-counter %d", cpu); | ||
140 | cd->name = name; | ||
141 | cd->features = CLOCK_EVT_FEAT_PERIODIC | | ||
142 | CLOCK_EVT_MODE_ONESHOT; | ||
143 | clockevent_set_clock(cd, V_SCD_TIMER_FREQ); | ||
144 | cd->max_delta_ns = clockevent_delta2ns(0x7fffff, cd); | ||
145 | cd->min_delta_ns = clockevent_delta2ns(1, cd); | ||
146 | cd->rating = 200; | ||
147 | cd->irq = irq; | ||
148 | cd->cpumask = cpumask_of_cpu(cpu); | ||
149 | cd->set_next_event = sibyte_next_event; | ||
150 | cd->set_mode = sibyte_set_mode; | ||
151 | clockevents_register_device(cd); | ||
152 | |||
153 | sb1250_mask_irq(cpu, irq); | ||
154 | |||
155 | /* Map the timer interrupt to ip[4] of this cpu */ | ||
156 | __raw_writeq(IMR_IP4_VAL, | ||
157 | IOADDR(A_IMR_REGISTER(cpu, R_IMR_INTERRUPT_MAP_BASE) + | ||
158 | (irq << 3))); | ||
159 | cd->cpumask = cpumask_of_cpu(0); | ||
160 | |||
161 | sb1250_unmask_irq(cpu, irq); | ||
162 | sb1250_steal_irq(irq); | ||
163 | |||
164 | action->handler = sibyte_counter_handler; | ||
165 | action->flags = IRQF_DISABLED | IRQF_PERCPU; | ||
166 | action->name = name; | ||
167 | action->dev_id = cd; | ||
168 | setup_irq(irq, &sibyte_irqaction); | ||
169 | } | ||
170 | |||
171 | /* | ||
172 | * The HPT is free running from SB1250_HPT_VALUE down to 0 then starts over | ||
173 | * again. | ||
174 | */ | ||
175 | static cycle_t sb1250_hpt_read(void) | ||
176 | { | ||
177 | unsigned int count; | ||
178 | |||
179 | count = G_SCD_TIMER_CNT(__raw_readq(IOADDR(A_SCD_TIMER_REGISTER(SB1250_HPT_NUM, R_SCD_TIMER_CNT)))); | ||
180 | |||
181 | return SB1250_HPT_VALUE - count; | ||
182 | } | ||
183 | |||
184 | struct clocksource bcm1250_clocksource = { | ||
185 | .name = "MIPS", | ||
186 | .rating = 200, | ||
187 | .read = sb1250_hpt_read, | ||
188 | .mask = CLOCKSOURCE_MASK(23), | ||
189 | .flags = CLOCK_SOURCE_IS_CONTINUOUS, | ||
190 | }; | ||
191 | |||
192 | void __init sb1250_clocksource_init(void) | ||
193 | { | ||
194 | struct clocksource *cs = &bcm1250_clocksource; | ||
195 | |||
196 | /* Setup hpt using timer #3 but do not enable irq for it */ | ||
197 | __raw_writeq(0, | ||
198 | IOADDR(A_SCD_TIMER_REGISTER(SB1250_HPT_NUM, | ||
199 | R_SCD_TIMER_CFG))); | ||
200 | __raw_writeq(SB1250_HPT_VALUE, | ||
201 | IOADDR(A_SCD_TIMER_REGISTER(SB1250_HPT_NUM, | ||
202 | R_SCD_TIMER_INIT))); | ||
203 | __raw_writeq(M_SCD_TIMER_ENABLE | M_SCD_TIMER_MODE_CONTINUOUS, | ||
204 | IOADDR(A_SCD_TIMER_REGISTER(SB1250_HPT_NUM, | ||
205 | R_SCD_TIMER_CFG))); | ||
206 | |||
207 | clocksource_set_clock(cs, V_SCD_TIMER_FREQ); | ||
208 | clocksource_register(cs); | ||
209 | } | ||
210 | 22 | ||
211 | void __init plat_time_init(void) | 23 | void __init plat_time_init(void) |
212 | { | 24 | { |
diff --git a/arch/mips/sni/time.c b/arch/mips/sni/time.c index 0910b35cb71f..6f339af08d22 100644 --- a/arch/mips/sni/time.c +++ b/arch/mips/sni/time.c | |||
@@ -1,6 +1,7 @@ | |||
1 | #include <linux/types.h> | 1 | #include <linux/types.h> |
2 | #include <linux/interrupt.h> | 2 | #include <linux/interrupt.h> |
3 | #include <linux/time.h> | 3 | #include <linux/time.h> |
4 | #include <linux/clockchips.h> | ||
4 | 5 | ||
5 | #include <asm/i8253.h> | 6 | #include <asm/i8253.h> |
6 | #include <asm/sni.h> | 7 | #include <asm/sni.h> |
@@ -11,27 +12,78 @@ | |||
11 | #define SNI_COUNTER2_DIV 64 | 12 | #define SNI_COUNTER2_DIV 64 |
12 | #define SNI_COUNTER0_DIV ((SNI_CLOCK_TICK_RATE / SNI_COUNTER2_DIV) / HZ) | 13 | #define SNI_COUNTER0_DIV ((SNI_CLOCK_TICK_RATE / SNI_COUNTER2_DIV) / HZ) |
13 | 14 | ||
14 | static void sni_a20r_timer_ack(void) | 15 | static void a20r_set_mode(enum clock_event_mode mode, |
16 | struct clock_event_device *evt) | ||
15 | { | 17 | { |
16 | *(volatile u8 *)A20R_PT_TIM0_ACK = 0x0; wmb(); | 18 | switch (mode) { |
19 | case CLOCK_EVT_MODE_PERIODIC: | ||
20 | *(volatile u8 *)(A20R_PT_CLOCK_BASE + 12) = 0x34; | ||
21 | wmb(); | ||
22 | *(volatile u8 *)(A20R_PT_CLOCK_BASE + 0) = SNI_COUNTER0_DIV; | ||
23 | wmb(); | ||
24 | *(volatile u8 *)(A20R_PT_CLOCK_BASE + 0) = SNI_COUNTER0_DIV >> 8; | ||
25 | wmb(); | ||
26 | |||
27 | *(volatile u8 *)(A20R_PT_CLOCK_BASE + 12) = 0xb4; | ||
28 | wmb(); | ||
29 | *(volatile u8 *)(A20R_PT_CLOCK_BASE + 8) = SNI_COUNTER2_DIV; | ||
30 | wmb(); | ||
31 | *(volatile u8 *)(A20R_PT_CLOCK_BASE + 8) = SNI_COUNTER2_DIV >> 8; | ||
32 | wmb(); | ||
33 | |||
34 | break; | ||
35 | case CLOCK_EVT_MODE_ONESHOT: | ||
36 | case CLOCK_EVT_MODE_UNUSED: | ||
37 | case CLOCK_EVT_MODE_SHUTDOWN: | ||
38 | break; | ||
39 | case CLOCK_EVT_MODE_RESUME: | ||
40 | break; | ||
41 | } | ||
17 | } | 42 | } |
18 | 43 | ||
44 | static struct clock_event_device a20r_clockevent_device = { | ||
45 | .name = "a20r-timer", | ||
46 | .features = CLOCK_EVT_FEAT_PERIODIC, | ||
47 | |||
48 | /* .mult, .shift, .max_delta_ns and .min_delta_ns left uninitialized */ | ||
49 | |||
50 | .rating = 300, | ||
51 | .irq = SNI_A20R_IRQ_TIMER, | ||
52 | .set_mode = a20r_set_mode, | ||
53 | }; | ||
54 | |||
55 | static irqreturn_t a20r_interrupt(int irq, void *dev_id) | ||
56 | { | ||
57 | struct clock_event_device *cd = dev_id; | ||
58 | |||
59 | *(volatile u8 *)A20R_PT_TIM0_ACK = 0; | ||
60 | wmb(); | ||
61 | |||
62 | cd->event_handler(cd); | ||
63 | |||
64 | return IRQ_HANDLED; | ||
65 | } | ||
66 | |||
67 | static struct irqaction a20r_irqaction = { | ||
68 | .handler = a20r_interrupt, | ||
69 | .flags = IRQF_DISABLED | IRQF_PERCPU, | ||
70 | .name = "a20r-timer", | ||
71 | }; | ||
72 | |||
19 | /* | 73 | /* |
20 | * a20r platform uses 2 counters to divide the input frequency. | 74 | * a20r platform uses 2 counters to divide the input frequency. |
21 | * Counter 2 output is connected to Counter 0 & 1 input. | 75 | * Counter 2 output is connected to Counter 0 & 1 input. |
22 | */ | 76 | */ |
23 | static void __init sni_a20r_timer_setup(struct irqaction *irq) | 77 | static void __init sni_a20r_timer_setup(void) |
24 | { | 78 | { |
25 | *(volatile u8 *)(A20R_PT_CLOCK_BASE + 12) = 0x34; wmb(); | 79 | struct clock_event_device *cd = &a20r_clockevent_device; |
26 | *(volatile u8 *)(A20R_PT_CLOCK_BASE + 0) = (SNI_COUNTER0_DIV) & 0xff; wmb(); | 80 | struct irqaction *action = &a20r_irqaction; |
27 | *(volatile u8 *)(A20R_PT_CLOCK_BASE + 0) = (SNI_COUNTER0_DIV >> 8) & 0xff; wmb(); | 81 | unsigned int cpu = smp_processor_id(); |
28 | 82 | ||
29 | *(volatile u8 *)(A20R_PT_CLOCK_BASE + 12) = 0xb4; wmb(); | 83 | cd->cpumask = cpumask_of_cpu(cpu); |
30 | *(volatile u8 *)(A20R_PT_CLOCK_BASE + 8) = (SNI_COUNTER2_DIV) & 0xff; wmb(); | 84 | clockevents_register_device(cd); |
31 | *(volatile u8 *)(A20R_PT_CLOCK_BASE + 8) = (SNI_COUNTER2_DIV >> 8) & 0xff; wmb(); | 85 | action->dev_id = cd; |
32 | 86 | setup_irq(SNI_A20R_IRQ_TIMER, &a20r_irqaction); | |
33 | setup_irq(SNI_A20R_IRQ_TIMER, irq); | ||
34 | mips_timer_ack = sni_a20r_timer_ack; | ||
35 | } | 87 | } |
36 | 88 | ||
37 | #define SNI_8254_TICK_RATE 1193182UL | 89 | #define SNI_8254_TICK_RATE 1193182UL |
@@ -118,18 +170,13 @@ void __init plat_time_init(void) | |||
118 | 170 | ||
119 | mips_hpt_frequency = r4k_tick * HZ; | 171 | mips_hpt_frequency = r4k_tick * HZ; |
120 | 172 | ||
121 | setup_pit_timer(); | ||
122 | } | ||
123 | |||
124 | void __init plat_timer_setup(struct irqaction *irq) | ||
125 | { | ||
126 | switch (sni_brd_type) { | 173 | switch (sni_brd_type) { |
127 | case SNI_BRD_10: | 174 | case SNI_BRD_10: |
128 | case SNI_BRD_10NEW: | 175 | case SNI_BRD_10NEW: |
129 | case SNI_BRD_TOWER_OASIC: | 176 | case SNI_BRD_TOWER_OASIC: |
130 | case SNI_BRD_MINITOWER: | 177 | case SNI_BRD_MINITOWER: |
131 | sni_a20r_timer_setup(irq); | 178 | sni_a20r_timer_setup(); |
132 | break; | 179 | break; |
133 | } | 180 | } |
134 | } | 181 | } |
135 | 182 | ||
diff --git a/arch/mips/tx4927/toshiba_rbtx4927/toshiba_rbtx4927_setup.c b/arch/mips/tx4927/toshiba_rbtx4927/toshiba_rbtx4927_setup.c index c7470fba6180..0299595ce1c4 100644 --- a/arch/mips/tx4927/toshiba_rbtx4927/toshiba_rbtx4927_setup.c +++ b/arch/mips/tx4927/toshiba_rbtx4927/toshiba_rbtx4927_setup.c | |||
@@ -63,6 +63,7 @@ | |||
63 | #include <asm/processor.h> | 63 | #include <asm/processor.h> |
64 | #include <asm/reboot.h> | 64 | #include <asm/reboot.h> |
65 | #include <asm/time.h> | 65 | #include <asm/time.h> |
66 | #include <asm/txx9tmr.h> | ||
66 | #include <linux/bootmem.h> | 67 | #include <linux/bootmem.h> |
67 | #include <linux/blkdev.h> | 68 | #include <linux/blkdev.h> |
68 | #ifdef CONFIG_TOSHIBA_FPCIB0 | 69 | #ifdef CONFIG_TOSHIBA_FPCIB0 |
@@ -93,7 +94,6 @@ | |||
93 | 94 | ||
94 | #define TOSHIBA_RBTX4927_SETUP_EFWFU ( 1 << 3 ) | 95 | #define TOSHIBA_RBTX4927_SETUP_EFWFU ( 1 << 3 ) |
95 | #define TOSHIBA_RBTX4927_SETUP_SETUP ( 1 << 4 ) | 96 | #define TOSHIBA_RBTX4927_SETUP_SETUP ( 1 << 4 ) |
96 | #define TOSHIBA_RBTX4927_SETUP_TIME_INIT ( 1 << 5 ) | ||
97 | #define TOSHIBA_RBTX4927_SETUP_PCIBIOS ( 1 << 7 ) | 97 | #define TOSHIBA_RBTX4927_SETUP_PCIBIOS ( 1 << 7 ) |
98 | #define TOSHIBA_RBTX4927_SETUP_PCI1 ( 1 << 8 ) | 98 | #define TOSHIBA_RBTX4927_SETUP_PCI1 ( 1 << 8 ) |
99 | #define TOSHIBA_RBTX4927_SETUP_PCI2 ( 1 << 9 ) | 99 | #define TOSHIBA_RBTX4927_SETUP_PCI2 ( 1 << 9 ) |
@@ -130,7 +130,6 @@ extern void toshiba_rbtx4927_power_off(void); | |||
130 | 130 | ||
131 | int tx4927_using_backplane = 0; | 131 | int tx4927_using_backplane = 0; |
132 | 132 | ||
133 | extern void gt64120_time_init(void); | ||
134 | extern void toshiba_rbtx4927_irq_setup(void); | 133 | extern void toshiba_rbtx4927_irq_setup(void); |
135 | 134 | ||
136 | char *prom_getcmdline(void); | 135 | char *prom_getcmdline(void); |
@@ -721,6 +720,7 @@ void toshiba_rbtx4927_power_off(void) | |||
721 | 720 | ||
722 | void __init toshiba_rbtx4927_setup(void) | 721 | void __init toshiba_rbtx4927_setup(void) |
723 | { | 722 | { |
723 | int i; | ||
724 | u32 cp0_config; | 724 | u32 cp0_config; |
725 | char *argptr; | 725 | char *argptr; |
726 | 726 | ||
@@ -764,6 +764,9 @@ void __init toshiba_rbtx4927_setup(void) | |||
764 | _machine_halt = toshiba_rbtx4927_halt; | 764 | _machine_halt = toshiba_rbtx4927_halt; |
765 | pm_power_off = toshiba_rbtx4927_power_off; | 765 | pm_power_off = toshiba_rbtx4927_power_off; |
766 | 766 | ||
767 | for (i = 0; i < TX4927_NR_TMR; i++) | ||
768 | txx9_tmr_init(TX4927_TMR_REG(0) & 0xfffffffffULL); | ||
769 | |||
767 | #ifdef CONFIG_PCI | 770 | #ifdef CONFIG_PCI |
768 | 771 | ||
769 | /* PCIC */ | 772 | /* PCIC */ |
@@ -892,7 +895,6 @@ void __init toshiba_rbtx4927_setup(void) | |||
892 | #ifdef CONFIG_SERIAL_TXX9 | 895 | #ifdef CONFIG_SERIAL_TXX9 |
893 | { | 896 | { |
894 | extern int early_serial_txx9_setup(struct uart_port *port); | 897 | extern int early_serial_txx9_setup(struct uart_port *port); |
895 | int i; | ||
896 | struct uart_port req; | 898 | struct uart_port req; |
897 | for(i = 0; i < 2; i++) { | 899 | for(i = 0; i < 2; i++) { |
898 | memset(&req, 0, sizeof(req)); | 900 | memset(&req, 0, sizeof(req)); |
@@ -937,12 +939,11 @@ void __init toshiba_rbtx4927_setup(void) | |||
937 | void __init | 939 | void __init |
938 | toshiba_rbtx4927_time_init(void) | 940 | toshiba_rbtx4927_time_init(void) |
939 | { | 941 | { |
940 | TOSHIBA_RBTX4927_SETUP_DPRINTK(TOSHIBA_RBTX4927_SETUP_TIME_INIT, "-\n"); | ||
941 | |||
942 | mips_hpt_frequency = tx4927_cpu_clock / 2; | 942 | mips_hpt_frequency = tx4927_cpu_clock / 2; |
943 | 943 | if (tx4927_ccfgptr->ccfg & TX4927_CCFG_TINTDIS) | |
944 | TOSHIBA_RBTX4927_SETUP_DPRINTK(TOSHIBA_RBTX4927_SETUP_TIME_INIT, "+\n"); | 944 | txx9_clockevent_init(TX4927_TMR_REG(0) & 0xfffffffffULL, |
945 | 945 | TXX9_IRQ_BASE + 17, | |
946 | 50000000); | ||
946 | } | 947 | } |
947 | 948 | ||
948 | static int __init toshiba_rbtx4927_rtc_init(void) | 949 | static int __init toshiba_rbtx4927_rtc_init(void) |
diff --git a/arch/mips/tx4938/toshiba_rbtx4938/setup.c b/arch/mips/tx4938/toshiba_rbtx4938/setup.c index ceecaf498957..4a8152375efe 100644 --- a/arch/mips/tx4938/toshiba_rbtx4938/setup.c +++ b/arch/mips/tx4938/toshiba_rbtx4938/setup.c | |||
@@ -26,6 +26,7 @@ | |||
26 | #include <asm/reboot.h> | 26 | #include <asm/reboot.h> |
27 | #include <asm/irq.h> | 27 | #include <asm/irq.h> |
28 | #include <asm/time.h> | 28 | #include <asm/time.h> |
29 | #include <asm/txx9tmr.h> | ||
29 | #include <asm/uaccess.h> | 30 | #include <asm/uaccess.h> |
30 | #include <asm/io.h> | 31 | #include <asm/io.h> |
31 | #include <asm/bootinfo.h> | 32 | #include <asm/bootinfo.h> |
@@ -773,15 +774,8 @@ void __init tx4938_board_setup(void) | |||
773 | } | 774 | } |
774 | 775 | ||
775 | /* TMR */ | 776 | /* TMR */ |
776 | /* disable all timers */ | 777 | for (i = 0; i < TX4938_NR_TMR; i++) |
777 | for (i = 0; i < TX4938_NR_TMR; i++) { | 778 | txx9_tmr_init(TX4938_TMR_REG(i) & 0xfffffffffULL); |
778 | tx4938_tmrptr(i)->tcr = 0x00000020; | ||
779 | tx4938_tmrptr(i)->tisr = 0; | ||
780 | tx4938_tmrptr(i)->cpra = 0xffffffff; | ||
781 | tx4938_tmrptr(i)->itmr = 0; | ||
782 | tx4938_tmrptr(i)->ccdr = 0; | ||
783 | tx4938_tmrptr(i)->pgmr = 0; | ||
784 | } | ||
785 | 779 | ||
786 | /* enable DMA */ | 780 | /* enable DMA */ |
787 | TX4938_WR64(0xff1fb150, TX4938_DMA_MCR_MSTEN); | 781 | TX4938_WR64(0xff1fb150, TX4938_DMA_MCR_MSTEN); |
@@ -852,12 +846,13 @@ void tx4938_report_pcic_status(void) | |||
852 | 846 | ||
853 | #endif /* CONFIG_PCI */ | 847 | #endif /* CONFIG_PCI */ |
854 | 848 | ||
855 | /* We use onchip r4k counter or TMR timer as our system wide timer | ||
856 | * interrupt running at 100HZ. */ | ||
857 | |||
858 | void __init plat_time_init(void) | 849 | void __init plat_time_init(void) |
859 | { | 850 | { |
860 | mips_hpt_frequency = txx9_cpu_clock / 2; | 851 | mips_hpt_frequency = txx9_cpu_clock / 2; |
852 | if (tx4938_ccfgptr->ccfg & TX4938_CCFG_TINTDIS) | ||
853 | txx9_clockevent_init(TX4938_TMR_REG(0) & 0xfffffffffULL, | ||
854 | TXX9_IRQ_BASE + TX4938_IR_TMR(0), | ||
855 | txx9_gbus_clock / 2); | ||
861 | } | 856 | } |
862 | 857 | ||
863 | void __init toshiba_rbtx4938_setup(void) | 858 | void __init toshiba_rbtx4938_setup(void) |
diff --git a/arch/s390/Kconfig b/arch/s390/Kconfig index 4ec716d8c1a6..1330061020ab 100644 --- a/arch/s390/Kconfig +++ b/arch/s390/Kconfig | |||
@@ -513,7 +513,7 @@ config ZFCPDUMP | |||
513 | default n | 513 | default n |
514 | help | 514 | help |
515 | Select this option if you want to build an zfcpdump enabled kernel. | 515 | Select this option if you want to build an zfcpdump enabled kernel. |
516 | Refer to "Documentation/s390/zfcpdump.txt" for more details on this. | 516 | Refer to <file:Documentation/s390/zfcpdump.txt> for more details on this. |
517 | 517 | ||
518 | endmenu | 518 | endmenu |
519 | 519 | ||
diff --git a/arch/sh/Kconfig b/arch/sh/Kconfig index 247f8a65e733..22a3eb38438b 100644 --- a/arch/sh/Kconfig +++ b/arch/sh/Kconfig | |||
@@ -182,9 +182,7 @@ config CPU_HAS_IPR_IRQ | |||
182 | bool | 182 | bool |
183 | 183 | ||
184 | config CPU_HAS_SR_RB | 184 | config CPU_HAS_SR_RB |
185 | bool "CPU has SR.RB" | 185 | bool |
186 | depends on CPU_SH3 || CPU_SH4 | ||
187 | default y | ||
188 | help | 186 | help |
189 | This will enable the use of SR.RB register bank usage. Processors | 187 | This will enable the use of SR.RB register bank usage. Processors |
190 | that are lacking this bit must have another method in place for | 188 | that are lacking this bit must have another method in place for |
@@ -291,9 +289,7 @@ config SH_DREAMCAST | |||
291 | depends on CPU_SUBTYPE_SH7091 | 289 | depends on CPU_SUBTYPE_SH7091 |
292 | help | 290 | help |
293 | Select Dreamcast if configuring for a SEGA Dreamcast. | 291 | Select Dreamcast if configuring for a SEGA Dreamcast. |
294 | More information at | 292 | More information at <http://www.linux-sh.org> |
295 | <http://www.m17n.org/linux-sh/dreamcast/>. There is a | ||
296 | Dreamcast project is at <http://linuxdc.sourceforge.net/>. | ||
297 | 293 | ||
298 | config SH_MPC1211 | 294 | config SH_MPC1211 |
299 | bool "Interface MPC1211" | 295 | bool "Interface MPC1211" |
diff --git a/arch/sh/Kconfig.debug b/arch/sh/Kconfig.debug index b507b501f0cf..ab2f9f3c354c 100644 --- a/arch/sh/Kconfig.debug +++ b/arch/sh/Kconfig.debug | |||
@@ -86,6 +86,14 @@ config 4KSTACKS | |||
86 | on the VM subsystem for higher order allocations. This option | 86 | on the VM subsystem for higher order allocations. This option |
87 | will also use IRQ stacks to compensate for the reduced stackspace. | 87 | will also use IRQ stacks to compensate for the reduced stackspace. |
88 | 88 | ||
89 | config IRQSTACKS | ||
90 | bool "Use separate kernel stacks when processing interrupts" | ||
91 | depends on DEBUG_KERNEL | ||
92 | help | ||
93 | If you say Y here the kernel will use separate kernel stacks | ||
94 | for handling hard and soft interrupts. This can help avoid | ||
95 | overflowing the process kernel stacks. | ||
96 | |||
89 | config SH_KGDB | 97 | config SH_KGDB |
90 | bool "Include KGDB kernel debugger" | 98 | bool "Include KGDB kernel debugger" |
91 | select FRAME_POINTER | 99 | select FRAME_POINTER |
diff --git a/arch/sh/Makefile b/arch/sh/Makefile index 408342b175c8..e189fae8b60c 100644 --- a/arch/sh/Makefile +++ b/arch/sh/Makefile | |||
@@ -66,7 +66,7 @@ cflags-y += $(isaflags-y) -ffreestanding | |||
66 | cflags-$(CONFIG_MORE_COMPILE_OPTIONS) += \ | 66 | cflags-$(CONFIG_MORE_COMPILE_OPTIONS) += \ |
67 | $(shell echo $(CONFIG_COMPILE_OPTIONS) | sed -e 's/"//g') | 67 | $(shell echo $(CONFIG_COMPILE_OPTIONS) | sed -e 's/"//g') |
68 | 68 | ||
69 | OBJCOPYFLAGS := -O binary -R .note -R .comment -R .stab -R .stabstr -S | 69 | OBJCOPYFLAGS := -O binary -R .note -R .note.gnu.build-id -R .comment -R .stab -R .stabstr -S |
70 | 70 | ||
71 | # | 71 | # |
72 | # arch/sh/defconfig doesn't reflect any real hardware, and as such should | 72 | # arch/sh/defconfig doesn't reflect any real hardware, and as such should |
diff --git a/arch/sh/boards/renesas/r7780rp/setup.c b/arch/sh/boards/renesas/r7780rp/setup.c index afe9de73666a..0fdc0bc19145 100644 --- a/arch/sh/boards/renesas/r7780rp/setup.c +++ b/arch/sh/boards/renesas/r7780rp/setup.c | |||
@@ -16,6 +16,8 @@ | |||
16 | #include <linux/init.h> | 16 | #include <linux/init.h> |
17 | #include <linux/platform_device.h> | 17 | #include <linux/platform_device.h> |
18 | #include <linux/pata_platform.h> | 18 | #include <linux/pata_platform.h> |
19 | #include <linux/types.h> | ||
20 | #include <net/ax88796.h> | ||
19 | #include <asm/machvec.h> | 21 | #include <asm/machvec.h> |
20 | #include <asm/r7780rp.h> | 22 | #include <asm/r7780rp.h> |
21 | #include <asm/clock.h> | 23 | #include <asm/clock.h> |
@@ -136,11 +138,50 @@ static struct platform_device heartbeat_device = { | |||
136 | .resource = heartbeat_resources, | 138 | .resource = heartbeat_resources, |
137 | }; | 139 | }; |
138 | 140 | ||
141 | static struct ax_plat_data ax88796_platdata = { | ||
142 | .flags = AXFLG_HAS_93CX6, | ||
143 | .wordlength = 2, | ||
144 | .dcr_val = 0x1, | ||
145 | .rcr_val = 0x40, | ||
146 | }; | ||
147 | |||
148 | static struct resource ax88796_resources[] = { | ||
149 | { | ||
150 | #ifdef CONFIG_SH_R7780RP | ||
151 | .start = 0xa5800400, | ||
152 | .end = 0xa5800400 + (0x20 * 0x2) - 1, | ||
153 | #else | ||
154 | .start = 0xa4100400, | ||
155 | .end = 0xa4100400 + (0x20 * 0x2) - 1, | ||
156 | #endif | ||
157 | .flags = IORESOURCE_MEM, | ||
158 | }, | ||
159 | { | ||
160 | .start = IRQ_AX88796, | ||
161 | .end = IRQ_AX88796, | ||
162 | .flags = IORESOURCE_IRQ, | ||
163 | }, | ||
164 | }; | ||
165 | |||
166 | static struct platform_device ax88796_device = { | ||
167 | .name = "ax88796", | ||
168 | .id = 0, | ||
169 | |||
170 | .dev = { | ||
171 | .platform_data = &ax88796_platdata, | ||
172 | }, | ||
173 | |||
174 | .num_resources = ARRAY_SIZE(ax88796_resources), | ||
175 | .resource = ax88796_resources, | ||
176 | }; | ||
177 | |||
178 | |||
139 | static struct platform_device *r7780rp_devices[] __initdata = { | 179 | static struct platform_device *r7780rp_devices[] __initdata = { |
140 | &r8a66597_usb_host_device, | 180 | &r8a66597_usb_host_device, |
141 | &m66592_usb_peripheral_device, | 181 | &m66592_usb_peripheral_device, |
142 | &cf_ide_device, | 182 | &cf_ide_device, |
143 | &heartbeat_device, | 183 | &heartbeat_device, |
184 | &ax88796_device, | ||
144 | }; | 185 | }; |
145 | 186 | ||
146 | static int __init r7780rp_devices_setup(void) | 187 | static int __init r7780rp_devices_setup(void) |
@@ -183,6 +224,34 @@ static void r7780rp_power_off(void) | |||
183 | ctrl_outw(0x0001, PA_POFF); | 224 | ctrl_outw(0x0001, PA_POFF); |
184 | } | 225 | } |
185 | 226 | ||
227 | static inline unsigned char is_ide_ioaddr(unsigned long addr) | ||
228 | { | ||
229 | return ((cf_ide_resources[0].start <= addr && | ||
230 | addr <= cf_ide_resources[0].end) || | ||
231 | (cf_ide_resources[1].start <= addr && | ||
232 | addr <= cf_ide_resources[1].end)); | ||
233 | } | ||
234 | |||
235 | void highlander_writeb(u8 b, void __iomem *addr) | ||
236 | { | ||
237 | unsigned long tmp = (unsigned long __force)addr; | ||
238 | |||
239 | if (is_ide_ioaddr(tmp)) | ||
240 | ctrl_outw((u16)b, tmp); | ||
241 | else | ||
242 | ctrl_outb(b, tmp); | ||
243 | } | ||
244 | |||
245 | u8 highlander_readb(void __iomem *addr) | ||
246 | { | ||
247 | unsigned long tmp = (unsigned long __force)addr; | ||
248 | |||
249 | if (is_ide_ioaddr(tmp)) | ||
250 | return ctrl_inw(tmp) & 0xff; | ||
251 | else | ||
252 | return ctrl_inb(tmp); | ||
253 | } | ||
254 | |||
186 | /* | 255 | /* |
187 | * Initialize the board | 256 | * Initialize the board |
188 | */ | 257 | */ |
@@ -267,4 +336,6 @@ static struct sh_machine_vector mv_highlander __initmv = { | |||
267 | .mv_setup = highlander_setup, | 336 | .mv_setup = highlander_setup, |
268 | .mv_init_irq = highlander_init_irq, | 337 | .mv_init_irq = highlander_init_irq, |
269 | .mv_irq_demux = highlander_irq_demux, | 338 | .mv_irq_demux = highlander_irq_demux, |
339 | .mv_readb = highlander_readb, | ||
340 | .mv_writeb = highlander_writeb, | ||
270 | }; | 341 | }; |
diff --git a/arch/sh/boards/se/7722/setup.c b/arch/sh/boards/se/7722/setup.c index 03b63457e178..20f064083cc2 100644 --- a/arch/sh/boards/se/7722/setup.c +++ b/arch/sh/boards/se/7722/setup.c | |||
@@ -103,8 +103,8 @@ static void __init se7722_setup(char **cmdline_p) | |||
103 | 103 | ||
104 | ctrl_outl(0x00051001, MSTPCR0); | 104 | ctrl_outl(0x00051001, MSTPCR0); |
105 | ctrl_outl(0x00000000, MSTPCR1); | 105 | ctrl_outl(0x00000000, MSTPCR1); |
106 | /* KEYSC, VOU, BEU, CEU, VEU, VPU, LCDC */ | 106 | /* KEYSC, VOU, BEU, CEU, VEU, VPU, LCDC, USB */ |
107 | ctrl_outl(0xffffbfC0, MSTPCR2); | 107 | ctrl_outl(0xffffb7c0, MSTPCR2); |
108 | 108 | ||
109 | ctrl_outw(0x0000, PORT_PECR); /* PORT E 1 = IRQ5 ,E 0 = BS */ | 109 | ctrl_outw(0x0000, PORT_PECR); /* PORT E 1 = IRQ5 ,E 0 = BS */ |
110 | ctrl_outw(0x1000, PORT_PJCR); /* PORT J 1 = IRQ1,J 0 =IRQ0 */ | 110 | ctrl_outw(0x1000, PORT_PJCR); /* PORT J 1 = IRQ1,J 0 =IRQ0 */ |
diff --git a/arch/sh/configs/r7785rp_defconfig b/arch/sh/configs/r7785rp_defconfig index 5c29338532da..158e03f0b1ef 100644 --- a/arch/sh/configs/r7785rp_defconfig +++ b/arch/sh/configs/r7785rp_defconfig | |||
@@ -1,7 +1,7 @@ | |||
1 | # | 1 | # |
2 | # Automatically generated make config: don't edit | 2 | # Automatically generated make config: don't edit |
3 | # Linux kernel version: 2.6.22-rc4 | 3 | # Linux kernel version: 2.6.24-rc1 |
4 | # Thu Jul 12 12:33:15 2007 | 4 | # Fri Nov 2 14:30:49 2007 |
5 | # | 5 | # |
6 | CONFIG_SUPERH=y | 6 | CONFIG_SUPERH=y |
7 | CONFIG_RWSEM_GENERIC_SPINLOCK=y | 7 | CONFIG_RWSEM_GENERIC_SPINLOCK=y |
@@ -13,39 +13,40 @@ CONFIG_GENERIC_IRQ_PROBE=y | |||
13 | CONFIG_GENERIC_CALIBRATE_DELAY=y | 13 | CONFIG_GENERIC_CALIBRATE_DELAY=y |
14 | CONFIG_GENERIC_TIME=y | 14 | CONFIG_GENERIC_TIME=y |
15 | CONFIG_GENERIC_CLOCKEVENTS=y | 15 | CONFIG_GENERIC_CLOCKEVENTS=y |
16 | CONFIG_SYS_SUPPORTS_NUMA=y | ||
16 | CONFIG_SYS_SUPPORTS_PCI=y | 17 | CONFIG_SYS_SUPPORTS_PCI=y |
17 | CONFIG_STACKTRACE_SUPPORT=y | 18 | CONFIG_STACKTRACE_SUPPORT=y |
18 | CONFIG_LOCKDEP_SUPPORT=y | 19 | CONFIG_LOCKDEP_SUPPORT=y |
19 | # CONFIG_ARCH_HAS_ILOG2_U32 is not set | 20 | # CONFIG_ARCH_HAS_ILOG2_U32 is not set |
20 | # CONFIG_ARCH_HAS_ILOG2_U64 is not set | 21 | # CONFIG_ARCH_HAS_ILOG2_U64 is not set |
22 | CONFIG_ARCH_NO_VIRT_TO_BUS=y | ||
21 | CONFIG_DEFCONFIG_LIST="/lib/modules/$UNAME_RELEASE/.config" | 23 | CONFIG_DEFCONFIG_LIST="/lib/modules/$UNAME_RELEASE/.config" |
22 | 24 | ||
23 | # | 25 | # |
24 | # Code maturity level options | 26 | # General setup |
25 | # | 27 | # |
26 | CONFIG_EXPERIMENTAL=y | 28 | CONFIG_EXPERIMENTAL=y |
27 | CONFIG_BROKEN_ON_SMP=y | 29 | CONFIG_BROKEN_ON_SMP=y |
28 | CONFIG_LOCK_KERNEL=y | 30 | CONFIG_LOCK_KERNEL=y |
29 | CONFIG_INIT_ENV_ARG_LIMIT=32 | 31 | CONFIG_INIT_ENV_ARG_LIMIT=32 |
30 | |||
31 | # | ||
32 | # General setup | ||
33 | # | ||
34 | CONFIG_LOCALVERSION="" | 32 | CONFIG_LOCALVERSION="" |
35 | CONFIG_LOCALVERSION_AUTO=y | 33 | CONFIG_LOCALVERSION_AUTO=y |
36 | CONFIG_SWAP=y | 34 | CONFIG_SWAP=y |
37 | CONFIG_SYSVIPC=y | 35 | CONFIG_SYSVIPC=y |
38 | # CONFIG_IPC_NS is not set | ||
39 | CONFIG_SYSVIPC_SYSCTL=y | 36 | CONFIG_SYSVIPC_SYSCTL=y |
40 | # CONFIG_POSIX_MQUEUE is not set | 37 | # CONFIG_POSIX_MQUEUE is not set |
41 | CONFIG_BSD_PROCESS_ACCT=y | 38 | CONFIG_BSD_PROCESS_ACCT=y |
42 | # CONFIG_BSD_PROCESS_ACCT_V3 is not set | 39 | # CONFIG_BSD_PROCESS_ACCT_V3 is not set |
43 | # CONFIG_TASKSTATS is not set | 40 | # CONFIG_TASKSTATS is not set |
44 | # CONFIG_UTS_NS is not set | 41 | # CONFIG_USER_NS is not set |
45 | # CONFIG_AUDIT is not set | 42 | # CONFIG_AUDIT is not set |
46 | CONFIG_IKCONFIG=y | 43 | CONFIG_IKCONFIG=y |
47 | CONFIG_IKCONFIG_PROC=y | 44 | CONFIG_IKCONFIG_PROC=y |
48 | CONFIG_LOG_BUF_SHIFT=14 | 45 | CONFIG_LOG_BUF_SHIFT=14 |
46 | # CONFIG_CGROUPS is not set | ||
47 | CONFIG_FAIR_GROUP_SCHED=y | ||
48 | CONFIG_FAIR_USER_SCHED=y | ||
49 | # CONFIG_FAIR_CGROUP_SCHED is not set | ||
49 | # CONFIG_SYSFS_DEPRECATED is not set | 50 | # CONFIG_SYSFS_DEPRECATED is not set |
50 | # CONFIG_RELAY is not set | 51 | # CONFIG_RELAY is not set |
51 | # CONFIG_BLK_DEV_INITRD is not set | 52 | # CONFIG_BLK_DEV_INITRD is not set |
@@ -66,7 +67,6 @@ CONFIG_BASE_FULL=y | |||
66 | CONFIG_ANON_INODES=y | 67 | CONFIG_ANON_INODES=y |
67 | # CONFIG_EPOLL is not set | 68 | # CONFIG_EPOLL is not set |
68 | CONFIG_SIGNALFD=y | 69 | CONFIG_SIGNALFD=y |
69 | CONFIG_TIMERFD=y | ||
70 | CONFIG_EVENTFD=y | 70 | CONFIG_EVENTFD=y |
71 | CONFIG_SHMEM=y | 71 | CONFIG_SHMEM=y |
72 | CONFIG_VM_EVENT_COUNTERS=y | 72 | CONFIG_VM_EVENT_COUNTERS=y |
@@ -75,24 +75,17 @@ CONFIG_SLAB=y | |||
75 | # CONFIG_SLOB is not set | 75 | # CONFIG_SLOB is not set |
76 | # CONFIG_TINY_SHMEM is not set | 76 | # CONFIG_TINY_SHMEM is not set |
77 | CONFIG_BASE_SMALL=0 | 77 | CONFIG_BASE_SMALL=0 |
78 | |||
79 | # | ||
80 | # Loadable module support | ||
81 | # | ||
82 | CONFIG_MODULES=y | 78 | CONFIG_MODULES=y |
83 | CONFIG_MODULE_UNLOAD=y | 79 | CONFIG_MODULE_UNLOAD=y |
84 | # CONFIG_MODULE_FORCE_UNLOAD is not set | 80 | # CONFIG_MODULE_FORCE_UNLOAD is not set |
85 | # CONFIG_MODVERSIONS is not set | 81 | # CONFIG_MODVERSIONS is not set |
86 | # CONFIG_MODULE_SRCVERSION_ALL is not set | 82 | # CONFIG_MODULE_SRCVERSION_ALL is not set |
87 | CONFIG_KMOD=y | 83 | CONFIG_KMOD=y |
88 | |||
89 | # | ||
90 | # Block layer | ||
91 | # | ||
92 | CONFIG_BLOCK=y | 84 | CONFIG_BLOCK=y |
93 | # CONFIG_LBD is not set | 85 | # CONFIG_LBD is not set |
94 | # CONFIG_BLK_DEV_IO_TRACE is not set | 86 | # CONFIG_BLK_DEV_IO_TRACE is not set |
95 | # CONFIG_LSF is not set | 87 | # CONFIG_LSF is not set |
88 | # CONFIG_BLK_DEV_BSG is not set | ||
96 | 89 | ||
97 | # | 90 | # |
98 | # IO Schedulers | 91 | # IO Schedulers |
@@ -115,7 +108,6 @@ CONFIG_CPU_SH4A=y | |||
115 | CONFIG_CPU_SHX2=y | 108 | CONFIG_CPU_SHX2=y |
116 | # CONFIG_CPU_SUBTYPE_SH7619 is not set | 109 | # CONFIG_CPU_SUBTYPE_SH7619 is not set |
117 | # CONFIG_CPU_SUBTYPE_SH7206 is not set | 110 | # CONFIG_CPU_SUBTYPE_SH7206 is not set |
118 | # CONFIG_CPU_SUBTYPE_SH7300 is not set | ||
119 | # CONFIG_CPU_SUBTYPE_SH7705 is not set | 111 | # CONFIG_CPU_SUBTYPE_SH7705 is not set |
120 | # CONFIG_CPU_SUBTYPE_SH7706 is not set | 112 | # CONFIG_CPU_SUBTYPE_SH7706 is not set |
121 | # CONFIG_CPU_SUBTYPE_SH7707 is not set | 113 | # CONFIG_CPU_SUBTYPE_SH7707 is not set |
@@ -123,6 +115,7 @@ CONFIG_CPU_SHX2=y | |||
123 | # CONFIG_CPU_SUBTYPE_SH7709 is not set | 115 | # CONFIG_CPU_SUBTYPE_SH7709 is not set |
124 | # CONFIG_CPU_SUBTYPE_SH7710 is not set | 116 | # CONFIG_CPU_SUBTYPE_SH7710 is not set |
125 | # CONFIG_CPU_SUBTYPE_SH7712 is not set | 117 | # CONFIG_CPU_SUBTYPE_SH7712 is not set |
118 | # CONFIG_CPU_SUBTYPE_SH7720 is not set | ||
126 | # CONFIG_CPU_SUBTYPE_SH7750 is not set | 119 | # CONFIG_CPU_SUBTYPE_SH7750 is not set |
127 | # CONFIG_CPU_SUBTYPE_SH7091 is not set | 120 | # CONFIG_CPU_SUBTYPE_SH7091 is not set |
128 | # CONFIG_CPU_SUBTYPE_SH7750R is not set | 121 | # CONFIG_CPU_SUBTYPE_SH7750R is not set |
@@ -137,7 +130,6 @@ CONFIG_CPU_SHX2=y | |||
137 | # CONFIG_CPU_SUBTYPE_SH7780 is not set | 130 | # CONFIG_CPU_SUBTYPE_SH7780 is not set |
138 | CONFIG_CPU_SUBTYPE_SH7785=y | 131 | CONFIG_CPU_SUBTYPE_SH7785=y |
139 | # CONFIG_CPU_SUBTYPE_SHX3 is not set | 132 | # CONFIG_CPU_SUBTYPE_SHX3 is not set |
140 | # CONFIG_CPU_SUBTYPE_SH73180 is not set | ||
141 | # CONFIG_CPU_SUBTYPE_SH7343 is not set | 133 | # CONFIG_CPU_SUBTYPE_SH7343 is not set |
142 | # CONFIG_CPU_SUBTYPE_SH7722 is not set | 134 | # CONFIG_CPU_SUBTYPE_SH7722 is not set |
143 | 135 | ||
@@ -149,15 +141,17 @@ CONFIG_MMU=y | |||
149 | CONFIG_PAGE_OFFSET=0x80000000 | 141 | CONFIG_PAGE_OFFSET=0x80000000 |
150 | CONFIG_MEMORY_START=0x08000000 | 142 | CONFIG_MEMORY_START=0x08000000 |
151 | CONFIG_MEMORY_SIZE=0x08000000 | 143 | CONFIG_MEMORY_SIZE=0x08000000 |
152 | CONFIG_32BIT=y | 144 | # CONFIG_32BIT is not set |
153 | # CONFIG_X2TLB is not set | 145 | # CONFIG_X2TLB is not set |
154 | CONFIG_VSYSCALL=y | 146 | CONFIG_VSYSCALL=y |
147 | # CONFIG_NUMA is not set | ||
155 | CONFIG_ARCH_FLATMEM_ENABLE=y | 148 | CONFIG_ARCH_FLATMEM_ENABLE=y |
156 | CONFIG_ARCH_SPARSEMEM_ENABLE=y | 149 | CONFIG_ARCH_SPARSEMEM_ENABLE=y |
157 | CONFIG_ARCH_SPARSEMEM_DEFAULT=y | 150 | CONFIG_ARCH_SPARSEMEM_DEFAULT=y |
158 | CONFIG_MAX_ACTIVE_REGIONS=1 | 151 | CONFIG_MAX_ACTIVE_REGIONS=2 |
159 | CONFIG_ARCH_POPULATES_NODE_MAP=y | 152 | CONFIG_ARCH_POPULATES_NODE_MAP=y |
160 | CONFIG_ARCH_SELECT_MEMORY_MODEL=y | 153 | CONFIG_ARCH_SELECT_MEMORY_MODEL=y |
154 | CONFIG_ARCH_ENABLE_MEMORY_HOTPLUG=y | ||
161 | CONFIG_PAGE_SIZE_4KB=y | 155 | CONFIG_PAGE_SIZE_4KB=y |
162 | # CONFIG_PAGE_SIZE_8KB is not set | 156 | # CONFIG_PAGE_SIZE_8KB is not set |
163 | # CONFIG_PAGE_SIZE_64KB is not set | 157 | # CONFIG_PAGE_SIZE_64KB is not set |
@@ -167,12 +161,14 @@ CONFIG_HUGETLB_PAGE_SIZE_1MB=y | |||
167 | # CONFIG_HUGETLB_PAGE_SIZE_4MB is not set | 161 | # CONFIG_HUGETLB_PAGE_SIZE_4MB is not set |
168 | # CONFIG_HUGETLB_PAGE_SIZE_64MB is not set | 162 | # CONFIG_HUGETLB_PAGE_SIZE_64MB is not set |
169 | CONFIG_SELECT_MEMORY_MODEL=y | 163 | CONFIG_SELECT_MEMORY_MODEL=y |
170 | CONFIG_FLATMEM_MANUAL=y | 164 | # CONFIG_FLATMEM_MANUAL is not set |
171 | # CONFIG_DISCONTIGMEM_MANUAL is not set | 165 | # CONFIG_DISCONTIGMEM_MANUAL is not set |
172 | # CONFIG_SPARSEMEM_MANUAL is not set | 166 | CONFIG_SPARSEMEM_MANUAL=y |
173 | CONFIG_FLATMEM=y | 167 | CONFIG_SPARSEMEM=y |
174 | CONFIG_FLAT_NODE_MEM_MAP=y | 168 | CONFIG_HAVE_MEMORY_PRESENT=y |
175 | CONFIG_SPARSEMEM_STATIC=y | 169 | CONFIG_SPARSEMEM_STATIC=y |
170 | # CONFIG_SPARSEMEM_VMEMMAP_ENABLE is not set | ||
171 | # CONFIG_MEMORY_HOTPLUG is not set | ||
176 | CONFIG_SPLIT_PTLOCK_CPUS=4 | 172 | CONFIG_SPLIT_PTLOCK_CPUS=4 |
177 | # CONFIG_RESOURCES_64BIT is not set | 173 | # CONFIG_RESOURCES_64BIT is not set |
178 | CONFIG_ZONE_DMA_FLAG=0 | 174 | CONFIG_ZONE_DMA_FLAG=0 |
@@ -182,7 +178,9 @@ CONFIG_NR_QUICK=2 | |||
182 | # Cache configuration | 178 | # Cache configuration |
183 | # | 179 | # |
184 | # CONFIG_SH_DIRECT_MAPPED is not set | 180 | # CONFIG_SH_DIRECT_MAPPED is not set |
185 | # CONFIG_SH_WRITETHROUGH is not set | 181 | CONFIG_CACHE_WRITEBACK=y |
182 | # CONFIG_CACHE_WRITETHROUGH is not set | ||
183 | # CONFIG_CACHE_OFF is not set | ||
186 | 184 | ||
187 | # | 185 | # |
188 | # Processor features | 186 | # Processor features |
@@ -190,12 +188,11 @@ CONFIG_NR_QUICK=2 | |||
190 | CONFIG_CPU_LITTLE_ENDIAN=y | 188 | CONFIG_CPU_LITTLE_ENDIAN=y |
191 | # CONFIG_CPU_BIG_ENDIAN is not set | 189 | # CONFIG_CPU_BIG_ENDIAN is not set |
192 | CONFIG_SH_FPU=y | 190 | CONFIG_SH_FPU=y |
193 | # CONFIG_SH_DSP is not set | ||
194 | CONFIG_SH_STORE_QUEUES=y | 191 | CONFIG_SH_STORE_QUEUES=y |
195 | CONFIG_CPU_HAS_INTEVT=y | 192 | CONFIG_CPU_HAS_INTEVT=y |
196 | CONFIG_CPU_HAS_INTC2_IRQ=y | ||
197 | CONFIG_CPU_HAS_SR_RB=y | 193 | CONFIG_CPU_HAS_SR_RB=y |
198 | CONFIG_CPU_HAS_PTEA=y | 194 | CONFIG_CPU_HAS_PTEA=y |
195 | CONFIG_CPU_HAS_FPU=y | ||
199 | 196 | ||
200 | # | 197 | # |
201 | # Board support | 198 | # Board support |
@@ -214,6 +211,7 @@ CONFIG_SH_PCLK_FREQ=50000000 | |||
214 | # CONFIG_TICK_ONESHOT is not set | 211 | # CONFIG_TICK_ONESHOT is not set |
215 | # CONFIG_NO_HZ is not set | 212 | # CONFIG_NO_HZ is not set |
216 | # CONFIG_HIGH_RES_TIMERS is not set | 213 | # CONFIG_HIGH_RES_TIMERS is not set |
214 | CONFIG_GENERIC_CLOCKEVENTS_BUILD=y | ||
217 | 215 | ||
218 | # | 216 | # |
219 | # CPU Frequency scaling | 217 | # CPU Frequency scaling |
@@ -249,6 +247,7 @@ CONFIG_KEXEC=y | |||
249 | # CONFIG_PREEMPT_VOLUNTARY is not set | 247 | # CONFIG_PREEMPT_VOLUNTARY is not set |
250 | CONFIG_PREEMPT=y | 248 | CONFIG_PREEMPT=y |
251 | CONFIG_PREEMPT_BKL=y | 249 | CONFIG_PREEMPT_BKL=y |
250 | CONFIG_GUSA=y | ||
252 | 251 | ||
253 | # | 252 | # |
254 | # Boot options | 253 | # Boot options |
@@ -268,10 +267,6 @@ CONFIG_PCI_AUTO=y | |||
268 | CONFIG_PCI_AUTO_UPDATE_RESOURCES=y | 267 | CONFIG_PCI_AUTO_UPDATE_RESOURCES=y |
269 | # CONFIG_ARCH_SUPPORTS_MSI is not set | 268 | # CONFIG_ARCH_SUPPORTS_MSI is not set |
270 | # CONFIG_PCI_DEBUG is not set | 269 | # CONFIG_PCI_DEBUG is not set |
271 | |||
272 | # | ||
273 | # PCCARD (PCMCIA/CardBus) support | ||
274 | # | ||
275 | # CONFIG_PCCARD is not set | 270 | # CONFIG_PCCARD is not set |
276 | # CONFIG_HOTPLUG_PCI is not set | 271 | # CONFIG_HOTPLUG_PCI is not set |
277 | 272 | ||
@@ -322,6 +317,7 @@ CONFIG_IP_PNP_DHCP=y | |||
322 | CONFIG_INET_XFRM_MODE_TRANSPORT=y | 317 | CONFIG_INET_XFRM_MODE_TRANSPORT=y |
323 | CONFIG_INET_XFRM_MODE_TUNNEL=y | 318 | CONFIG_INET_XFRM_MODE_TUNNEL=y |
324 | CONFIG_INET_XFRM_MODE_BEET=y | 319 | CONFIG_INET_XFRM_MODE_BEET=y |
320 | # CONFIG_INET_LRO is not set | ||
325 | CONFIG_INET_DIAG=y | 321 | CONFIG_INET_DIAG=y |
326 | CONFIG_INET_TCP_DIAG=y | 322 | CONFIG_INET_TCP_DIAG=y |
327 | # CONFIG_TCP_CONG_ADVANCED is not set | 323 | # CONFIG_TCP_CONG_ADVANCED is not set |
@@ -348,10 +344,6 @@ CONFIG_LLC=m | |||
348 | # CONFIG_LAPB is not set | 344 | # CONFIG_LAPB is not set |
349 | # CONFIG_ECONET is not set | 345 | # CONFIG_ECONET is not set |
350 | # CONFIG_WAN_ROUTER is not set | 346 | # CONFIG_WAN_ROUTER is not set |
351 | |||
352 | # | ||
353 | # QoS and/or fair queueing | ||
354 | # | ||
355 | # CONFIG_NET_SCHED is not set | 347 | # CONFIG_NET_SCHED is not set |
356 | 348 | ||
357 | # | 349 | # |
@@ -371,6 +363,7 @@ CONFIG_WIRELESS_EXT=y | |||
371 | # CONFIG_MAC80211 is not set | 363 | # CONFIG_MAC80211 is not set |
372 | # CONFIG_IEEE80211 is not set | 364 | # CONFIG_IEEE80211 is not set |
373 | # CONFIG_RFKILL is not set | 365 | # CONFIG_RFKILL is not set |
366 | # CONFIG_NET_9P is not set | ||
374 | 367 | ||
375 | # | 368 | # |
376 | # Device Drivers | 369 | # Device Drivers |
@@ -379,33 +372,17 @@ CONFIG_WIRELESS_EXT=y | |||
379 | # | 372 | # |
380 | # Generic Driver Options | 373 | # Generic Driver Options |
381 | # | 374 | # |
375 | CONFIG_UEVENT_HELPER_PATH="/sbin/hotplug" | ||
382 | CONFIG_STANDALONE=y | 376 | CONFIG_STANDALONE=y |
383 | CONFIG_PREVENT_FIRMWARE_BUILD=y | 377 | CONFIG_PREVENT_FIRMWARE_BUILD=y |
384 | CONFIG_FW_LOADER=m | 378 | CONFIG_FW_LOADER=m |
385 | # CONFIG_DEBUG_DRIVER is not set | 379 | # CONFIG_DEBUG_DRIVER is not set |
386 | # CONFIG_DEBUG_DEVRES is not set | 380 | # CONFIG_DEBUG_DEVRES is not set |
387 | # CONFIG_SYS_HYPERVISOR is not set | 381 | # CONFIG_SYS_HYPERVISOR is not set |
388 | |||
389 | # | ||
390 | # Connector - unified userspace <-> kernelspace linker | ||
391 | # | ||
392 | # CONFIG_CONNECTOR is not set | 382 | # CONFIG_CONNECTOR is not set |
393 | # CONFIG_MTD is not set | 383 | # CONFIG_MTD is not set |
394 | |||
395 | # | ||
396 | # Parallel port support | ||
397 | # | ||
398 | # CONFIG_PARPORT is not set | 384 | # CONFIG_PARPORT is not set |
399 | 385 | CONFIG_BLK_DEV=y | |
400 | # | ||
401 | # Plug and Play support | ||
402 | # | ||
403 | # CONFIG_PNPACPI is not set | ||
404 | |||
405 | # | ||
406 | # Block devices | ||
407 | # | ||
408 | # CONFIG_BLK_CPQ_DA is not set | ||
409 | # CONFIG_BLK_CPQ_CISS_DA is not set | 386 | # CONFIG_BLK_CPQ_CISS_DA is not set |
410 | # CONFIG_BLK_DEV_DAC960 is not set | 387 | # CONFIG_BLK_DEV_DAC960 is not set |
411 | # CONFIG_BLK_DEV_UMEM is not set | 388 | # CONFIG_BLK_DEV_UMEM is not set |
@@ -419,14 +396,11 @@ CONFIG_BLK_DEV_RAM_SIZE=4096 | |||
419 | CONFIG_BLK_DEV_RAM_BLOCKSIZE=1024 | 396 | CONFIG_BLK_DEV_RAM_BLOCKSIZE=1024 |
420 | # CONFIG_CDROM_PKTCDVD is not set | 397 | # CONFIG_CDROM_PKTCDVD is not set |
421 | # CONFIG_ATA_OVER_ETH is not set | 398 | # CONFIG_ATA_OVER_ETH is not set |
422 | 399 | CONFIG_MISC_DEVICES=y | |
423 | # | ||
424 | # Misc devices | ||
425 | # | ||
426 | # CONFIG_PHANTOM is not set | 400 | # CONFIG_PHANTOM is not set |
401 | CONFIG_EEPROM_93CX6=y | ||
427 | # CONFIG_SGI_IOC4 is not set | 402 | # CONFIG_SGI_IOC4 is not set |
428 | # CONFIG_TIFM_CORE is not set | 403 | # CONFIG_TIFM_CORE is not set |
429 | # CONFIG_BLINK is not set | ||
430 | # CONFIG_IDE is not set | 404 | # CONFIG_IDE is not set |
431 | 405 | ||
432 | # | 406 | # |
@@ -434,6 +408,7 @@ CONFIG_BLK_DEV_RAM_BLOCKSIZE=1024 | |||
434 | # | 408 | # |
435 | # CONFIG_RAID_ATTRS is not set | 409 | # CONFIG_RAID_ATTRS is not set |
436 | CONFIG_SCSI=y | 410 | CONFIG_SCSI=y |
411 | CONFIG_SCSI_DMA=y | ||
437 | # CONFIG_SCSI_TGT is not set | 412 | # CONFIG_SCSI_TGT is not set |
438 | # CONFIG_SCSI_NETLINK is not set | 413 | # CONFIG_SCSI_NETLINK is not set |
439 | CONFIG_SCSI_PROC_FS=y | 414 | CONFIG_SCSI_PROC_FS=y |
@@ -463,12 +438,9 @@ CONFIG_SCSI_WAIT_SCAN=m | |||
463 | # CONFIG_SCSI_SPI_ATTRS is not set | 438 | # CONFIG_SCSI_SPI_ATTRS is not set |
464 | # CONFIG_SCSI_FC_ATTRS is not set | 439 | # CONFIG_SCSI_FC_ATTRS is not set |
465 | # CONFIG_SCSI_ISCSI_ATTRS is not set | 440 | # CONFIG_SCSI_ISCSI_ATTRS is not set |
466 | # CONFIG_SCSI_SAS_ATTRS is not set | ||
467 | # CONFIG_SCSI_SAS_LIBSAS is not set | 441 | # CONFIG_SCSI_SAS_LIBSAS is not set |
468 | 442 | # CONFIG_SCSI_SRP_ATTRS is not set | |
469 | # | 443 | CONFIG_SCSI_LOWLEVEL=y |
470 | # SCSI low-level drivers | ||
471 | # | ||
472 | # CONFIG_ISCSI_TCP is not set | 444 | # CONFIG_ISCSI_TCP is not set |
473 | # CONFIG_BLK_DEV_3W_XXXX_RAID is not set | 445 | # CONFIG_BLK_DEV_3W_XXXX_RAID is not set |
474 | # CONFIG_SCSI_3W_9XXX is not set | 446 | # CONFIG_SCSI_3W_9XXX is not set |
@@ -478,7 +450,6 @@ CONFIG_SCSI_WAIT_SCAN=m | |||
478 | # CONFIG_SCSI_AIC7XXX_OLD is not set | 450 | # CONFIG_SCSI_AIC7XXX_OLD is not set |
479 | # CONFIG_SCSI_AIC79XX is not set | 451 | # CONFIG_SCSI_AIC79XX is not set |
480 | # CONFIG_SCSI_AIC94XX is not set | 452 | # CONFIG_SCSI_AIC94XX is not set |
481 | # CONFIG_SCSI_DPT_I2O is not set | ||
482 | # CONFIG_SCSI_ARCMSR is not set | 453 | # CONFIG_SCSI_ARCMSR is not set |
483 | # CONFIG_MEGARAID_NEWGEN is not set | 454 | # CONFIG_MEGARAID_NEWGEN is not set |
484 | # CONFIG_MEGARAID_LEGACY is not set | 455 | # CONFIG_MEGARAID_LEGACY is not set |
@@ -543,6 +514,7 @@ CONFIG_SATA_SIL=y | |||
543 | # CONFIG_PATA_OLDPIIX is not set | 514 | # CONFIG_PATA_OLDPIIX is not set |
544 | # CONFIG_PATA_NETCELL is not set | 515 | # CONFIG_PATA_NETCELL is not set |
545 | # CONFIG_PATA_NS87410 is not set | 516 | # CONFIG_PATA_NS87410 is not set |
517 | # CONFIG_PATA_NS87415 is not set | ||
546 | # CONFIG_PATA_OPTI is not set | 518 | # CONFIG_PATA_OPTI is not set |
547 | # CONFIG_PATA_OPTIDMA is not set | 519 | # CONFIG_PATA_OPTIDMA is not set |
548 | # CONFIG_PATA_PDC_OLD is not set | 520 | # CONFIG_PATA_PDC_OLD is not set |
@@ -556,45 +528,26 @@ CONFIG_SATA_SIL=y | |||
556 | # CONFIG_PATA_VIA is not set | 528 | # CONFIG_PATA_VIA is not set |
557 | # CONFIG_PATA_WINBOND is not set | 529 | # CONFIG_PATA_WINBOND is not set |
558 | CONFIG_PATA_PLATFORM=y | 530 | CONFIG_PATA_PLATFORM=y |
559 | |||
560 | # | ||
561 | # Multi-device support (RAID and LVM) | ||
562 | # | ||
563 | # CONFIG_MD is not set | 531 | # CONFIG_MD is not set |
564 | |||
565 | # | ||
566 | # Fusion MPT device support | ||
567 | # | ||
568 | # CONFIG_FUSION is not set | 532 | # CONFIG_FUSION is not set |
569 | # CONFIG_FUSION_SPI is not set | ||
570 | # CONFIG_FUSION_FC is not set | ||
571 | # CONFIG_FUSION_SAS is not set | ||
572 | 533 | ||
573 | # | 534 | # |
574 | # IEEE 1394 (FireWire) support | 535 | # IEEE 1394 (FireWire) support |
575 | # | 536 | # |
576 | # CONFIG_FIREWIRE is not set | 537 | # CONFIG_FIREWIRE is not set |
577 | # CONFIG_IEEE1394 is not set | 538 | # CONFIG_IEEE1394 is not set |
578 | |||
579 | # | ||
580 | # I2O device support | ||
581 | # | ||
582 | # CONFIG_I2O is not set | 539 | # CONFIG_I2O is not set |
583 | |||
584 | # | ||
585 | # Network device support | ||
586 | # | ||
587 | CONFIG_NETDEVICES=y | 540 | CONFIG_NETDEVICES=y |
541 | # CONFIG_NETDEVICES_MULTIQUEUE is not set | ||
588 | # CONFIG_DUMMY is not set | 542 | # CONFIG_DUMMY is not set |
589 | # CONFIG_BONDING is not set | 543 | # CONFIG_BONDING is not set |
544 | # CONFIG_MACVLAN is not set | ||
590 | # CONFIG_EQUALIZER is not set | 545 | # CONFIG_EQUALIZER is not set |
591 | # CONFIG_TUN is not set | 546 | # CONFIG_TUN is not set |
547 | # CONFIG_VETH is not set | ||
548 | # CONFIG_IP1000 is not set | ||
592 | # CONFIG_ARCNET is not set | 549 | # CONFIG_ARCNET is not set |
593 | # CONFIG_PHYLIB is not set | 550 | # CONFIG_PHYLIB is not set |
594 | |||
595 | # | ||
596 | # Ethernet (10 or 100Mbit) | ||
597 | # | ||
598 | CONFIG_NET_ETHERNET=y | 551 | CONFIG_NET_ETHERNET=y |
599 | CONFIG_MII=y | 552 | CONFIG_MII=y |
600 | # CONFIG_STNIC is not set | 553 | # CONFIG_STNIC is not set |
@@ -603,17 +556,20 @@ CONFIG_MII=y | |||
603 | # CONFIG_CASSINI is not set | 556 | # CONFIG_CASSINI is not set |
604 | # CONFIG_NET_VENDOR_3COM is not set | 557 | # CONFIG_NET_VENDOR_3COM is not set |
605 | # CONFIG_SMC91X is not set | 558 | # CONFIG_SMC91X is not set |
606 | 559 | # CONFIG_SMC911X is not set | |
607 | # | ||
608 | # Tulip family network device support | ||
609 | # | ||
610 | # CONFIG_NET_TULIP is not set | 560 | # CONFIG_NET_TULIP is not set |
611 | # CONFIG_HP100 is not set | 561 | # CONFIG_HP100 is not set |
562 | # CONFIG_IBM_NEW_EMAC_ZMII is not set | ||
563 | # CONFIG_IBM_NEW_EMAC_RGMII is not set | ||
564 | # CONFIG_IBM_NEW_EMAC_TAH is not set | ||
565 | # CONFIG_IBM_NEW_EMAC_EMAC4 is not set | ||
612 | # CONFIG_NET_PCI is not set | 566 | # CONFIG_NET_PCI is not set |
567 | # CONFIG_B44 is not set | ||
613 | CONFIG_NETDEV_1000=y | 568 | CONFIG_NETDEV_1000=y |
614 | # CONFIG_ACENIC is not set | 569 | # CONFIG_ACENIC is not set |
615 | # CONFIG_DL2K is not set | 570 | # CONFIG_DL2K is not set |
616 | # CONFIG_E1000 is not set | 571 | # CONFIG_E1000 is not set |
572 | # CONFIG_E1000E is not set | ||
617 | # CONFIG_NS83820 is not set | 573 | # CONFIG_NS83820 is not set |
618 | # CONFIG_HAMACHI is not set | 574 | # CONFIG_HAMACHI is not set |
619 | # CONFIG_YELLOWFIN is not set | 575 | # CONFIG_YELLOWFIN is not set |
@@ -631,11 +587,14 @@ CONFIG_R8169=y | |||
631 | CONFIG_NETDEV_10000=y | 587 | CONFIG_NETDEV_10000=y |
632 | # CONFIG_CHELSIO_T1 is not set | 588 | # CONFIG_CHELSIO_T1 is not set |
633 | # CONFIG_CHELSIO_T3 is not set | 589 | # CONFIG_CHELSIO_T3 is not set |
590 | # CONFIG_IXGBE is not set | ||
634 | # CONFIG_IXGB is not set | 591 | # CONFIG_IXGB is not set |
635 | # CONFIG_S2IO is not set | 592 | # CONFIG_S2IO is not set |
636 | # CONFIG_MYRI10GE is not set | 593 | # CONFIG_MYRI10GE is not set |
637 | # CONFIG_NETXEN_NIC is not set | 594 | # CONFIG_NETXEN_NIC is not set |
595 | # CONFIG_NIU is not set | ||
638 | # CONFIG_MLX4_CORE is not set | 596 | # CONFIG_MLX4_CORE is not set |
597 | # CONFIG_TEHUTI is not set | ||
639 | # CONFIG_TR is not set | 598 | # CONFIG_TR is not set |
640 | 599 | ||
641 | # | 600 | # |
@@ -653,15 +612,7 @@ CONFIG_NETDEV_10000=y | |||
653 | # CONFIG_NETCONSOLE is not set | 612 | # CONFIG_NETCONSOLE is not set |
654 | # CONFIG_NETPOLL is not set | 613 | # CONFIG_NETPOLL is not set |
655 | # CONFIG_NET_POLL_CONTROLLER is not set | 614 | # CONFIG_NET_POLL_CONTROLLER is not set |
656 | |||
657 | # | ||
658 | # ISDN subsystem | ||
659 | # | ||
660 | # CONFIG_ISDN is not set | 615 | # CONFIG_ISDN is not set |
661 | |||
662 | # | ||
663 | # Telephony Support | ||
664 | # | ||
665 | # CONFIG_PHONE is not set | 616 | # CONFIG_PHONE is not set |
666 | 617 | ||
667 | # | 618 | # |
@@ -669,6 +620,7 @@ CONFIG_NETDEV_10000=y | |||
669 | # | 620 | # |
670 | CONFIG_INPUT=y | 621 | CONFIG_INPUT=y |
671 | # CONFIG_INPUT_FF_MEMLESS is not set | 622 | # CONFIG_INPUT_FF_MEMLESS is not set |
623 | # CONFIG_INPUT_POLLDEV is not set | ||
672 | 624 | ||
673 | # | 625 | # |
674 | # Userland interfaces | 626 | # Userland interfaces |
@@ -678,7 +630,6 @@ CONFIG_INPUT_MOUSEDEV=y | |||
678 | CONFIG_INPUT_MOUSEDEV_SCREEN_X=1024 | 630 | CONFIG_INPUT_MOUSEDEV_SCREEN_X=1024 |
679 | CONFIG_INPUT_MOUSEDEV_SCREEN_Y=768 | 631 | CONFIG_INPUT_MOUSEDEV_SCREEN_Y=768 |
680 | # CONFIG_INPUT_JOYDEV is not set | 632 | # CONFIG_INPUT_JOYDEV is not set |
681 | # CONFIG_INPUT_TSDEV is not set | ||
682 | # CONFIG_INPUT_EVDEV is not set | 633 | # CONFIG_INPUT_EVDEV is not set |
683 | # CONFIG_INPUT_EVBUG is not set | 634 | # CONFIG_INPUT_EVBUG is not set |
684 | 635 | ||
@@ -732,21 +683,11 @@ CONFIG_SERIAL_CORE_CONSOLE=y | |||
732 | CONFIG_UNIX98_PTYS=y | 683 | CONFIG_UNIX98_PTYS=y |
733 | CONFIG_LEGACY_PTYS=y | 684 | CONFIG_LEGACY_PTYS=y |
734 | CONFIG_LEGACY_PTY_COUNT=256 | 685 | CONFIG_LEGACY_PTY_COUNT=256 |
735 | |||
736 | # | ||
737 | # IPMI | ||
738 | # | ||
739 | # CONFIG_IPMI_HANDLER is not set | 686 | # CONFIG_IPMI_HANDLER is not set |
740 | # CONFIG_WATCHDOG is not set | ||
741 | CONFIG_HW_RANDOM=y | 687 | CONFIG_HW_RANDOM=y |
742 | # CONFIG_R3964 is not set | 688 | # CONFIG_R3964 is not set |
743 | # CONFIG_APPLICOM is not set | 689 | # CONFIG_APPLICOM is not set |
744 | # CONFIG_DRM is not set | ||
745 | # CONFIG_RAW_DRIVER is not set | 690 | # CONFIG_RAW_DRIVER is not set |
746 | |||
747 | # | ||
748 | # TPM devices | ||
749 | # | ||
750 | # CONFIG_TCG_TPM is not set | 691 | # CONFIG_TCG_TPM is not set |
751 | CONFIG_DEVPORT=y | 692 | CONFIG_DEVPORT=y |
752 | # CONFIG_I2C is not set | 693 | # CONFIG_I2C is not set |
@@ -756,21 +697,31 @@ CONFIG_DEVPORT=y | |||
756 | # | 697 | # |
757 | # CONFIG_SPI is not set | 698 | # CONFIG_SPI is not set |
758 | # CONFIG_SPI_MASTER is not set | 699 | # CONFIG_SPI_MASTER is not set |
759 | |||
760 | # | ||
761 | # Dallas's 1-wire bus | ||
762 | # | ||
763 | # CONFIG_W1 is not set | 700 | # CONFIG_W1 is not set |
701 | # CONFIG_POWER_SUPPLY is not set | ||
764 | CONFIG_HWMON=y | 702 | CONFIG_HWMON=y |
765 | # CONFIG_HWMON_VID is not set | 703 | # CONFIG_HWMON_VID is not set |
766 | # CONFIG_SENSORS_ABITUGURU is not set | ||
767 | # CONFIG_SENSORS_F71805F is not set | 704 | # CONFIG_SENSORS_F71805F is not set |
705 | # CONFIG_SENSORS_F71882FG is not set | ||
706 | # CONFIG_SENSORS_IT87 is not set | ||
707 | # CONFIG_SENSORS_PC87360 is not set | ||
768 | # CONFIG_SENSORS_PC87427 is not set | 708 | # CONFIG_SENSORS_PC87427 is not set |
709 | # CONFIG_SENSORS_SIS5595 is not set | ||
769 | # CONFIG_SENSORS_SMSC47M1 is not set | 710 | # CONFIG_SENSORS_SMSC47M1 is not set |
770 | # CONFIG_SENSORS_SMSC47B397 is not set | 711 | # CONFIG_SENSORS_SMSC47B397 is not set |
712 | # CONFIG_SENSORS_VIA686A is not set | ||
771 | # CONFIG_SENSORS_VT1211 is not set | 713 | # CONFIG_SENSORS_VT1211 is not set |
714 | # CONFIG_SENSORS_VT8231 is not set | ||
772 | # CONFIG_SENSORS_W83627HF is not set | 715 | # CONFIG_SENSORS_W83627HF is not set |
716 | # CONFIG_SENSORS_W83627EHF is not set | ||
773 | # CONFIG_HWMON_DEBUG_CHIP is not set | 717 | # CONFIG_HWMON_DEBUG_CHIP is not set |
718 | # CONFIG_WATCHDOG is not set | ||
719 | |||
720 | # | ||
721 | # Sonics Silicon Backplane | ||
722 | # | ||
723 | CONFIG_SSB_POSSIBLE=y | ||
724 | # CONFIG_SSB is not set | ||
774 | 725 | ||
775 | # | 726 | # |
776 | # Multifunction device drivers | 727 | # Multifunction device drivers |
@@ -787,19 +738,16 @@ CONFIG_HWMON=y | |||
787 | # | 738 | # |
788 | # Graphics support | 739 | # Graphics support |
789 | # | 740 | # |
790 | # CONFIG_BACKLIGHT_LCD_SUPPORT is not set | 741 | # CONFIG_DRM is not set |
791 | |||
792 | # | ||
793 | # Display device support | ||
794 | # | ||
795 | # CONFIG_DISPLAY_SUPPORT is not set | ||
796 | # CONFIG_VGASTATE is not set | 742 | # CONFIG_VGASTATE is not set |
743 | # CONFIG_VIDEO_OUTPUT_CONTROL is not set | ||
797 | CONFIG_FB=y | 744 | CONFIG_FB=y |
798 | # CONFIG_FIRMWARE_EDID is not set | 745 | # CONFIG_FIRMWARE_EDID is not set |
799 | # CONFIG_FB_DDC is not set | 746 | # CONFIG_FB_DDC is not set |
800 | # CONFIG_FB_CFB_FILLRECT is not set | 747 | # CONFIG_FB_CFB_FILLRECT is not set |
801 | # CONFIG_FB_CFB_COPYAREA is not set | 748 | # CONFIG_FB_CFB_COPYAREA is not set |
802 | # CONFIG_FB_CFB_IMAGEBLIT is not set | 749 | # CONFIG_FB_CFB_IMAGEBLIT is not set |
750 | # CONFIG_FB_CFB_REV_PIXELS_IN_BYTE is not set | ||
803 | # CONFIG_FB_SYS_FILLRECT is not set | 751 | # CONFIG_FB_SYS_FILLRECT is not set |
804 | # CONFIG_FB_SYS_COPYAREA is not set | 752 | # CONFIG_FB_SYS_COPYAREA is not set |
805 | # CONFIG_FB_SYS_IMAGEBLIT is not set | 753 | # CONFIG_FB_SYS_IMAGEBLIT is not set |
@@ -819,7 +767,6 @@ CONFIG_FB_DEFERRED_IO=y | |||
819 | # CONFIG_FB_CYBER2000 is not set | 767 | # CONFIG_FB_CYBER2000 is not set |
820 | # CONFIG_FB_ASILIANT is not set | 768 | # CONFIG_FB_ASILIANT is not set |
821 | # CONFIG_FB_IMSTT is not set | 769 | # CONFIG_FB_IMSTT is not set |
822 | # CONFIG_FB_EPSON1355 is not set | ||
823 | # CONFIG_FB_S1D13XXX is not set | 770 | # CONFIG_FB_S1D13XXX is not set |
824 | # CONFIG_FB_NVIDIA is not set | 771 | # CONFIG_FB_NVIDIA is not set |
825 | # CONFIG_FB_RIVA is not set | 772 | # CONFIG_FB_RIVA is not set |
@@ -839,6 +786,12 @@ CONFIG_FB_DEFERRED_IO=y | |||
839 | # CONFIG_FB_ARK is not set | 786 | # CONFIG_FB_ARK is not set |
840 | # CONFIG_FB_PM3 is not set | 787 | # CONFIG_FB_PM3 is not set |
841 | # CONFIG_FB_VIRTUAL is not set | 788 | # CONFIG_FB_VIRTUAL is not set |
789 | # CONFIG_BACKLIGHT_LCD_SUPPORT is not set | ||
790 | |||
791 | # | ||
792 | # Display device support | ||
793 | # | ||
794 | # CONFIG_DISPLAY_SUPPORT is not set | ||
842 | # CONFIG_LOGO is not set | 795 | # CONFIG_LOGO is not set |
843 | 796 | ||
844 | # | 797 | # |
@@ -855,20 +808,14 @@ CONFIG_SOUND=m | |||
855 | # Open Sound System | 808 | # Open Sound System |
856 | # | 809 | # |
857 | CONFIG_SOUND_PRIME=m | 810 | CONFIG_SOUND_PRIME=m |
858 | # CONFIG_OSS_OBSOLETE is not set | ||
859 | # CONFIG_SOUND_TRIDENT is not set | 811 | # CONFIG_SOUND_TRIDENT is not set |
860 | # CONFIG_SOUND_MSNDCLAS is not set | 812 | # CONFIG_SOUND_MSNDCLAS is not set |
861 | # CONFIG_SOUND_MSNDPIN is not set | 813 | # CONFIG_SOUND_MSNDPIN is not set |
862 | 814 | CONFIG_HID_SUPPORT=y | |
863 | # | ||
864 | # HID Devices | ||
865 | # | ||
866 | CONFIG_HID=y | 815 | CONFIG_HID=y |
867 | # CONFIG_HID_DEBUG is not set | 816 | # CONFIG_HID_DEBUG is not set |
868 | 817 | # CONFIG_HIDRAW is not set | |
869 | # | 818 | CONFIG_USB_SUPPORT=y |
870 | # USB support | ||
871 | # | ||
872 | CONFIG_USB_ARCH_HAS_HCD=y | 819 | CONFIG_USB_ARCH_HAS_HCD=y |
873 | CONFIG_USB_ARCH_HAS_OHCI=y | 820 | CONFIG_USB_ARCH_HAS_OHCI=y |
874 | CONFIG_USB_ARCH_HAS_EHCI=y | 821 | CONFIG_USB_ARCH_HAS_EHCI=y |
@@ -883,32 +830,8 @@ CONFIG_USB_ARCH_HAS_EHCI=y | |||
883 | # | 830 | # |
884 | # CONFIG_USB_GADGET is not set | 831 | # CONFIG_USB_GADGET is not set |
885 | # CONFIG_MMC is not set | 832 | # CONFIG_MMC is not set |
886 | |||
887 | # | ||
888 | # LED devices | ||
889 | # | ||
890 | # CONFIG_NEW_LEDS is not set | 833 | # CONFIG_NEW_LEDS is not set |
891 | |||
892 | # | ||
893 | # LED drivers | ||
894 | # | ||
895 | |||
896 | # | ||
897 | # LED Triggers | ||
898 | # | ||
899 | |||
900 | # | ||
901 | # InfiniBand support | ||
902 | # | ||
903 | # CONFIG_INFINIBAND is not set | 834 | # CONFIG_INFINIBAND is not set |
904 | |||
905 | # | ||
906 | # EDAC - error detection and reporting (RAS) (EXPERIMENTAL) | ||
907 | # | ||
908 | |||
909 | # | ||
910 | # Real Time Clock | ||
911 | # | ||
912 | CONFIG_RTC_LIB=y | 835 | CONFIG_RTC_LIB=y |
913 | CONFIG_RTC_CLASS=y | 836 | CONFIG_RTC_CLASS=y |
914 | CONFIG_RTC_HCTOSYS=y | 837 | CONFIG_RTC_HCTOSYS=y |
@@ -925,10 +848,6 @@ CONFIG_RTC_INTF_DEV=y | |||
925 | # CONFIG_RTC_DRV_TEST is not set | 848 | # CONFIG_RTC_DRV_TEST is not set |
926 | 849 | ||
927 | # | 850 | # |
928 | # I2C RTC drivers | ||
929 | # | ||
930 | |||
931 | # | ||
932 | # SPI RTC drivers | 851 | # SPI RTC drivers |
933 | # | 852 | # |
934 | 853 | ||
@@ -936,8 +855,10 @@ CONFIG_RTC_INTF_DEV=y | |||
936 | # Platform RTC drivers | 855 | # Platform RTC drivers |
937 | # | 856 | # |
938 | # CONFIG_RTC_DRV_DS1553 is not set | 857 | # CONFIG_RTC_DRV_DS1553 is not set |
858 | # CONFIG_RTC_DRV_STK17TA8 is not set | ||
939 | # CONFIG_RTC_DRV_DS1742 is not set | 859 | # CONFIG_RTC_DRV_DS1742 is not set |
940 | # CONFIG_RTC_DRV_M48T86 is not set | 860 | # CONFIG_RTC_DRV_M48T86 is not set |
861 | # CONFIG_RTC_DRV_M48T59 is not set | ||
941 | # CONFIG_RTC_DRV_V3020 is not set | 862 | # CONFIG_RTC_DRV_V3020 is not set |
942 | 863 | ||
943 | # | 864 | # |
@@ -946,17 +867,9 @@ CONFIG_RTC_INTF_DEV=y | |||
946 | CONFIG_RTC_DRV_SH=y | 867 | CONFIG_RTC_DRV_SH=y |
947 | 868 | ||
948 | # | 869 | # |
949 | # DMA Engine support | 870 | # Userspace I/O |
950 | # | ||
951 | # CONFIG_DMA_ENGINE is not set | ||
952 | |||
953 | # | ||
954 | # DMA Clients | ||
955 | # | ||
956 | |||
957 | # | ||
958 | # DMA Devices | ||
959 | # | 871 | # |
872 | # CONFIG_UIO is not set | ||
960 | 873 | ||
961 | # | 874 | # |
962 | # File systems | 875 | # File systems |
@@ -1017,7 +930,6 @@ CONFIG_TMPFS=y | |||
1017 | # CONFIG_TMPFS_POSIX_ACL is not set | 930 | # CONFIG_TMPFS_POSIX_ACL is not set |
1018 | CONFIG_HUGETLBFS=y | 931 | CONFIG_HUGETLBFS=y |
1019 | CONFIG_HUGETLB_PAGE=y | 932 | CONFIG_HUGETLB_PAGE=y |
1020 | CONFIG_RAMFS=y | ||
1021 | CONFIG_CONFIGFS_FS=m | 933 | CONFIG_CONFIGFS_FS=m |
1022 | 934 | ||
1023 | # | 935 | # |
@@ -1036,10 +948,7 @@ CONFIG_CONFIGFS_FS=m | |||
1036 | # CONFIG_QNX4FS_FS is not set | 948 | # CONFIG_QNX4FS_FS is not set |
1037 | # CONFIG_SYSV_FS is not set | 949 | # CONFIG_SYSV_FS is not set |
1038 | # CONFIG_UFS_FS is not set | 950 | # CONFIG_UFS_FS is not set |
1039 | 951 | CONFIG_NETWORK_FILESYSTEMS=y | |
1040 | # | ||
1041 | # Network File Systems | ||
1042 | # | ||
1043 | CONFIG_NFS_FS=y | 952 | CONFIG_NFS_FS=y |
1044 | CONFIG_NFS_V3=y | 953 | CONFIG_NFS_V3=y |
1045 | # CONFIG_NFS_V3_ACL is not set | 954 | # CONFIG_NFS_V3_ACL is not set |
@@ -1065,17 +974,12 @@ CONFIG_RPCSEC_GSS_KRB5=y | |||
1065 | # CONFIG_NCP_FS is not set | 974 | # CONFIG_NCP_FS is not set |
1066 | # CONFIG_CODA_FS is not set | 975 | # CONFIG_CODA_FS is not set |
1067 | # CONFIG_AFS_FS is not set | 976 | # CONFIG_AFS_FS is not set |
1068 | # CONFIG_9P_FS is not set | ||
1069 | 977 | ||
1070 | # | 978 | # |
1071 | # Partition Types | 979 | # Partition Types |
1072 | # | 980 | # |
1073 | # CONFIG_PARTITION_ADVANCED is not set | 981 | # CONFIG_PARTITION_ADVANCED is not set |
1074 | CONFIG_MSDOS_PARTITION=y | 982 | CONFIG_MSDOS_PARTITION=y |
1075 | |||
1076 | # | ||
1077 | # Native Language Support | ||
1078 | # | ||
1079 | CONFIG_NLS=y | 983 | CONFIG_NLS=y |
1080 | CONFIG_NLS_DEFAULT="iso8859-1" | 984 | CONFIG_NLS_DEFAULT="iso8859-1" |
1081 | CONFIG_NLS_CODEPAGE_437=y | 985 | CONFIG_NLS_CODEPAGE_437=y |
@@ -1116,23 +1020,18 @@ CONFIG_NLS_ISO8859_1=y | |||
1116 | # CONFIG_NLS_KOI8_R is not set | 1020 | # CONFIG_NLS_KOI8_R is not set |
1117 | # CONFIG_NLS_KOI8_U is not set | 1021 | # CONFIG_NLS_KOI8_U is not set |
1118 | # CONFIG_NLS_UTF8 is not set | 1022 | # CONFIG_NLS_UTF8 is not set |
1119 | |||
1120 | # | ||
1121 | # Distributed Lock Manager | ||
1122 | # | ||
1123 | # CONFIG_DLM is not set | 1023 | # CONFIG_DLM is not set |
1124 | 1024 | CONFIG_INSTRUMENTATION=y | |
1125 | # | ||
1126 | # Profiling support | ||
1127 | # | ||
1128 | CONFIG_PROFILING=y | 1025 | CONFIG_PROFILING=y |
1129 | CONFIG_OPROFILE=m | 1026 | CONFIG_OPROFILE=m |
1027 | # CONFIG_MARKERS is not set | ||
1130 | 1028 | ||
1131 | # | 1029 | # |
1132 | # Kernel hacking | 1030 | # Kernel hacking |
1133 | # | 1031 | # |
1134 | CONFIG_TRACE_IRQFLAGS_SUPPORT=y | 1032 | CONFIG_TRACE_IRQFLAGS_SUPPORT=y |
1135 | # CONFIG_PRINTK_TIME is not set | 1033 | # CONFIG_PRINTK_TIME is not set |
1034 | CONFIG_ENABLE_WARN_DEPRECATED=y | ||
1136 | CONFIG_ENABLE_MUST_CHECK=y | 1035 | CONFIG_ENABLE_MUST_CHECK=y |
1137 | CONFIG_MAGIC_SYSRQ=y | 1036 | CONFIG_MAGIC_SYSRQ=y |
1138 | # CONFIG_UNUSED_SYMBOLS is not set | 1037 | # CONFIG_UNUSED_SYMBOLS is not set |
@@ -1141,6 +1040,7 @@ CONFIG_DEBUG_FS=y | |||
1141 | CONFIG_DEBUG_KERNEL=y | 1040 | CONFIG_DEBUG_KERNEL=y |
1142 | # CONFIG_DEBUG_SHIRQ is not set | 1041 | # CONFIG_DEBUG_SHIRQ is not set |
1143 | # CONFIG_DETECT_SOFTLOCKUP is not set | 1042 | # CONFIG_DETECT_SOFTLOCKUP is not set |
1043 | CONFIG_SCHED_DEBUG=y | ||
1144 | # CONFIG_SCHEDSTATS is not set | 1044 | # CONFIG_SCHEDSTATS is not set |
1145 | # CONFIG_TIMER_STATS is not set | 1045 | # CONFIG_TIMER_STATS is not set |
1146 | # CONFIG_DEBUG_SLAB is not set | 1046 | # CONFIG_DEBUG_SLAB is not set |
@@ -1150,6 +1050,7 @@ CONFIG_DEBUG_MUTEXES=y | |||
1150 | CONFIG_DEBUG_LOCK_ALLOC=y | 1050 | CONFIG_DEBUG_LOCK_ALLOC=y |
1151 | # CONFIG_PROVE_LOCKING is not set | 1051 | # CONFIG_PROVE_LOCKING is not set |
1152 | CONFIG_LOCKDEP=y | 1052 | CONFIG_LOCKDEP=y |
1053 | # CONFIG_LOCK_STAT is not set | ||
1153 | # CONFIG_DEBUG_LOCKDEP is not set | 1054 | # CONFIG_DEBUG_LOCKDEP is not set |
1154 | # CONFIG_DEBUG_SPINLOCK_SLEEP is not set | 1055 | # CONFIG_DEBUG_SPINLOCK_SLEEP is not set |
1155 | CONFIG_DEBUG_LOCKING_API_SELFTESTS=y | 1056 | CONFIG_DEBUG_LOCKING_API_SELFTESTS=y |
@@ -1159,17 +1060,21 @@ CONFIG_DEBUG_BUGVERBOSE=y | |||
1159 | CONFIG_DEBUG_INFO=y | 1060 | CONFIG_DEBUG_INFO=y |
1160 | # CONFIG_DEBUG_VM is not set | 1061 | # CONFIG_DEBUG_VM is not set |
1161 | # CONFIG_DEBUG_LIST is not set | 1062 | # CONFIG_DEBUG_LIST is not set |
1063 | # CONFIG_DEBUG_SG is not set | ||
1162 | CONFIG_FRAME_POINTER=y | 1064 | CONFIG_FRAME_POINTER=y |
1163 | CONFIG_FORCED_INLINING=y | 1065 | CONFIG_FORCED_INLINING=y |
1066 | # CONFIG_BOOT_PRINTK_DELAY is not set | ||
1164 | # CONFIG_RCU_TORTURE_TEST is not set | 1067 | # CONFIG_RCU_TORTURE_TEST is not set |
1165 | # CONFIG_FAULT_INJECTION is not set | 1068 | # CONFIG_FAULT_INJECTION is not set |
1069 | # CONFIG_SAMPLES is not set | ||
1166 | CONFIG_SH_STANDARD_BIOS=y | 1070 | CONFIG_SH_STANDARD_BIOS=y |
1167 | # CONFIG_EARLY_SCIF_CONSOLE is not set | 1071 | # CONFIG_EARLY_SCIF_CONSOLE is not set |
1168 | CONFIG_EARLY_PRINTK=y | 1072 | CONFIG_EARLY_PRINTK=y |
1169 | # CONFIG_DEBUG_BOOTMEM is not set | 1073 | # CONFIG_DEBUG_BOOTMEM is not set |
1170 | CONFIG_DEBUG_STACKOVERFLOW=y | 1074 | CONFIG_DEBUG_STACKOVERFLOW=y |
1171 | CONFIG_DEBUG_STACK_USAGE=y | 1075 | CONFIG_DEBUG_STACK_USAGE=y |
1172 | # CONFIG_4KSTACKS is not set | 1076 | CONFIG_4KSTACKS=y |
1077 | # CONFIG_IRQSTACKS is not set | ||
1173 | # CONFIG_SH_KGDB is not set | 1078 | # CONFIG_SH_KGDB is not set |
1174 | 1079 | ||
1175 | # | 1080 | # |
@@ -1177,10 +1082,7 @@ CONFIG_DEBUG_STACK_USAGE=y | |||
1177 | # | 1082 | # |
1178 | # CONFIG_KEYS is not set | 1083 | # CONFIG_KEYS is not set |
1179 | # CONFIG_SECURITY is not set | 1084 | # CONFIG_SECURITY is not set |
1180 | 1085 | # CONFIG_SECURITY_FILE_CAPABILITIES is not set | |
1181 | # | ||
1182 | # Cryptographic options | ||
1183 | # | ||
1184 | CONFIG_CRYPTO=y | 1086 | CONFIG_CRYPTO=y |
1185 | CONFIG_CRYPTO_ALGAPI=y | 1087 | CONFIG_CRYPTO_ALGAPI=y |
1186 | CONFIG_CRYPTO_BLKCIPHER=y | 1088 | CONFIG_CRYPTO_BLKCIPHER=y |
@@ -1201,6 +1103,7 @@ CONFIG_CRYPTO_ECB=m | |||
1201 | CONFIG_CRYPTO_CBC=y | 1103 | CONFIG_CRYPTO_CBC=y |
1202 | CONFIG_CRYPTO_PCBC=m | 1104 | CONFIG_CRYPTO_PCBC=m |
1203 | # CONFIG_CRYPTO_LRW is not set | 1105 | # CONFIG_CRYPTO_LRW is not set |
1106 | # CONFIG_CRYPTO_XTS is not set | ||
1204 | # CONFIG_CRYPTO_CRYPTD is not set | 1107 | # CONFIG_CRYPTO_CRYPTD is not set |
1205 | CONFIG_CRYPTO_DES=y | 1108 | CONFIG_CRYPTO_DES=y |
1206 | # CONFIG_CRYPTO_FCRYPT is not set | 1109 | # CONFIG_CRYPTO_FCRYPT is not set |
@@ -1214,15 +1117,14 @@ CONFIG_CRYPTO_DES=y | |||
1214 | # CONFIG_CRYPTO_ARC4 is not set | 1117 | # CONFIG_CRYPTO_ARC4 is not set |
1215 | # CONFIG_CRYPTO_KHAZAD is not set | 1118 | # CONFIG_CRYPTO_KHAZAD is not set |
1216 | # CONFIG_CRYPTO_ANUBIS is not set | 1119 | # CONFIG_CRYPTO_ANUBIS is not set |
1120 | # CONFIG_CRYPTO_SEED is not set | ||
1217 | # CONFIG_CRYPTO_DEFLATE is not set | 1121 | # CONFIG_CRYPTO_DEFLATE is not set |
1218 | # CONFIG_CRYPTO_MICHAEL_MIC is not set | 1122 | # CONFIG_CRYPTO_MICHAEL_MIC is not set |
1219 | # CONFIG_CRYPTO_CRC32C is not set | 1123 | # CONFIG_CRYPTO_CRC32C is not set |
1220 | # CONFIG_CRYPTO_CAMELLIA is not set | 1124 | # CONFIG_CRYPTO_CAMELLIA is not set |
1221 | # CONFIG_CRYPTO_TEST is not set | 1125 | # CONFIG_CRYPTO_TEST is not set |
1222 | 1126 | # CONFIG_CRYPTO_AUTHENC is not set | |
1223 | # | 1127 | CONFIG_CRYPTO_HW=y |
1224 | # Hardware crypto devices | ||
1225 | # | ||
1226 | 1128 | ||
1227 | # | 1129 | # |
1228 | # Library routines | 1130 | # Library routines |
@@ -1232,6 +1134,7 @@ CONFIG_BITREVERSE=y | |||
1232 | # CONFIG_CRC16 is not set | 1134 | # CONFIG_CRC16 is not set |
1233 | # CONFIG_CRC_ITU_T is not set | 1135 | # CONFIG_CRC_ITU_T is not set |
1234 | CONFIG_CRC32=y | 1136 | CONFIG_CRC32=y |
1137 | # CONFIG_CRC7 is not set | ||
1235 | # CONFIG_LIBCRC32C is not set | 1138 | # CONFIG_LIBCRC32C is not set |
1236 | CONFIG_HAS_IOMEM=y | 1139 | CONFIG_HAS_IOMEM=y |
1237 | CONFIG_HAS_IOPORT=y | 1140 | CONFIG_HAS_IOPORT=y |
diff --git a/arch/sh/drivers/pci/pci-st40.c b/arch/sh/drivers/pci/pci-st40.c index 1502a14386b6..0814a5afe9b7 100644 --- a/arch/sh/drivers/pci/pci-st40.c +++ b/arch/sh/drivers/pci/pci-st40.c | |||
@@ -114,7 +114,7 @@ static struct pci_err int_error[]={ | |||
114 | { INT_MWPDI, "MWPDI: PERR from target at data write"}, | 114 | { INT_MWPDI, "MWPDI: PERR from target at data write"}, |
115 | { INT_MRDPEI, "MRDPEI: Master read data parity error"} | 115 | { INT_MRDPEI, "MRDPEI: Master read data parity error"} |
116 | }; | 116 | }; |
117 | #define NUM_PCI_INT_ERRS (sizeof(int_error)/sizeof(struct pci_err)) | 117 | #define NUM_PCI_INT_ERRS ARRAY_SIZE(int_error) |
118 | 118 | ||
119 | static struct pci_err aint_error[]={ | 119 | static struct pci_err aint_error[]={ |
120 | { AINT_MBI, "MBI: Master broken"}, | 120 | { AINT_MBI, "MBI: Master broken"}, |
@@ -126,7 +126,7 @@ static struct pci_err aint_error[]={ | |||
126 | { AINT_WDPE, "WDPE: Write data parity"} | 126 | { AINT_WDPE, "WDPE: Write data parity"} |
127 | }; | 127 | }; |
128 | 128 | ||
129 | #define NUM_PCI_AINT_ERRS (sizeof(aint_error)/sizeof(struct pci_err)) | 129 | #define NUM_PCI_AINT_ERRS ARRAY_SIZE(aint_error) |
130 | 130 | ||
131 | static void print_pci_errors(unsigned reg,struct pci_err *error,int num_errors) | 131 | static void print_pci_errors(unsigned reg,struct pci_err *error,int num_errors) |
132 | { | 132 | { |
diff --git a/arch/sh/kernel/cpu/irq/ipr.c b/arch/sh/kernel/cpu/irq/ipr.c index 5da325414880..56ea7b269b59 100644 --- a/arch/sh/kernel/cpu/irq/ipr.c +++ b/arch/sh/kernel/cpu/irq/ipr.c | |||
@@ -49,7 +49,6 @@ static void enable_ipr_irq(unsigned int irq) | |||
49 | * bits/4. This is to make it easier to read the value directly from the | 49 | * bits/4. This is to make it easier to read the value directly from the |
50 | * datasheets. The IPR address is calculated using the ipr_offset table. | 50 | * datasheets. The IPR address is calculated using the ipr_offset table. |
51 | */ | 51 | */ |
52 | |||
53 | void register_ipr_controller(struct ipr_desc *desc) | 52 | void register_ipr_controller(struct ipr_desc *desc) |
54 | { | 53 | { |
55 | int i; | 54 | int i; |
@@ -71,12 +70,4 @@ void register_ipr_controller(struct ipr_desc *desc) | |||
71 | disable_ipr_irq(p->irq); | 70 | disable_ipr_irq(p->irq); |
72 | } | 71 | } |
73 | } | 72 | } |
74 | |||
75 | EXPORT_SYMBOL(register_ipr_controller); | 73 | EXPORT_SYMBOL(register_ipr_controller); |
76 | |||
77 | #if !defined(CONFIG_CPU_HAS_PINT_IRQ) | ||
78 | int ipr_irq_demux(int irq) | ||
79 | { | ||
80 | return irq; | ||
81 | } | ||
82 | #endif | ||
diff --git a/arch/sh/kernel/cpu/sh4a/setup-sh7722.c b/arch/sh/kernel/cpu/sh4a/setup-sh7722.c index 55f66104431d..b9c6547c4a90 100644 --- a/arch/sh/kernel/cpu/sh4a/setup-sh7722.c +++ b/arch/sh/kernel/cpu/sh4a/setup-sh7722.c | |||
@@ -14,6 +14,32 @@ | |||
14 | #include <asm/mmzone.h> | 14 | #include <asm/mmzone.h> |
15 | #include <asm/sci.h> | 15 | #include <asm/sci.h> |
16 | 16 | ||
17 | static struct resource usbf_resources[] = { | ||
18 | [0] = { | ||
19 | .name = "m66592_udc", | ||
20 | .start = 0xA4480000, | ||
21 | .end = 0xA44800FF, | ||
22 | .flags = IORESOURCE_MEM, | ||
23 | }, | ||
24 | [1] = { | ||
25 | .name = "m66592_udc", | ||
26 | .start = 65, | ||
27 | .end = 65, | ||
28 | .flags = IORESOURCE_IRQ, | ||
29 | }, | ||
30 | }; | ||
31 | |||
32 | static struct platform_device usbf_device = { | ||
33 | .name = "m66592_udc", | ||
34 | .id = -1, | ||
35 | .dev = { | ||
36 | .dma_mask = NULL, | ||
37 | .coherent_dma_mask = 0xffffffff, | ||
38 | }, | ||
39 | .num_resources = ARRAY_SIZE(usbf_resources), | ||
40 | .resource = usbf_resources, | ||
41 | }; | ||
42 | |||
17 | static struct plat_sci_port sci_platform_data[] = { | 43 | static struct plat_sci_port sci_platform_data[] = { |
18 | { | 44 | { |
19 | .mapbase = 0xffe00000, | 45 | .mapbase = 0xffe00000, |
@@ -47,6 +73,7 @@ static struct platform_device sci_device = { | |||
47 | }; | 73 | }; |
48 | 74 | ||
49 | static struct platform_device *sh7722_devices[] __initdata = { | 75 | static struct platform_device *sh7722_devices[] __initdata = { |
76 | &usbf_device, | ||
50 | &sci_device, | 77 | &sci_device, |
51 | }; | 78 | }; |
52 | 79 | ||
diff --git a/arch/sh/kernel/irq.c b/arch/sh/kernel/irq.c index 4b49d03ffbd2..348da194ec99 100644 --- a/arch/sh/kernel/irq.c +++ b/arch/sh/kernel/irq.c | |||
@@ -69,7 +69,7 @@ unlock: | |||
69 | } | 69 | } |
70 | #endif | 70 | #endif |
71 | 71 | ||
72 | #ifdef CONFIG_4KSTACKS | 72 | #ifdef CONFIG_IRQSTACKS |
73 | /* | 73 | /* |
74 | * per-CPU IRQ handling contexts (thread information and stack) | 74 | * per-CPU IRQ handling contexts (thread information and stack) |
75 | */ | 75 | */ |
@@ -85,7 +85,7 @@ static union irq_ctx *softirq_ctx[NR_CPUS] __read_mostly; | |||
85 | asmlinkage int do_IRQ(unsigned int irq, struct pt_regs *regs) | 85 | asmlinkage int do_IRQ(unsigned int irq, struct pt_regs *regs) |
86 | { | 86 | { |
87 | struct pt_regs *old_regs = set_irq_regs(regs); | 87 | struct pt_regs *old_regs = set_irq_regs(regs); |
88 | #ifdef CONFIG_4KSTACKS | 88 | #ifdef CONFIG_IRQSTACKS |
89 | union irq_ctx *curctx, *irqctx; | 89 | union irq_ctx *curctx, *irqctx; |
90 | #endif | 90 | #endif |
91 | 91 | ||
@@ -109,7 +109,7 @@ asmlinkage int do_IRQ(unsigned int irq, struct pt_regs *regs) | |||
109 | 109 | ||
110 | irq = irq_demux(evt2irq(irq)); | 110 | irq = irq_demux(evt2irq(irq)); |
111 | 111 | ||
112 | #ifdef CONFIG_4KSTACKS | 112 | #ifdef CONFIG_IRQSTACKS |
113 | curctx = (union irq_ctx *)current_thread_info(); | 113 | curctx = (union irq_ctx *)current_thread_info(); |
114 | irqctx = hardirq_ctx[smp_processor_id()]; | 114 | irqctx = hardirq_ctx[smp_processor_id()]; |
115 | 115 | ||
@@ -157,7 +157,7 @@ asmlinkage int do_IRQ(unsigned int irq, struct pt_regs *regs) | |||
157 | return 1; | 157 | return 1; |
158 | } | 158 | } |
159 | 159 | ||
160 | #ifdef CONFIG_4KSTACKS | 160 | #ifdef CONFIG_IRQSTACKS |
161 | static char softirq_stack[NR_CPUS * THREAD_SIZE] | 161 | static char softirq_stack[NR_CPUS * THREAD_SIZE] |
162 | __attribute__((__section__(".bss.page_aligned"))); | 162 | __attribute__((__section__(".bss.page_aligned"))); |
163 | 163 | ||
diff --git a/arch/sh/kernel/setup.c b/arch/sh/kernel/setup.c index b749403f6b38..0b8c45d53a47 100644 --- a/arch/sh/kernel/setup.c +++ b/arch/sh/kernel/setup.c | |||
@@ -32,12 +32,6 @@ | |||
32 | #include <asm/clock.h> | 32 | #include <asm/clock.h> |
33 | #include <asm/mmu_context.h> | 33 | #include <asm/mmu_context.h> |
34 | 34 | ||
35 | extern void * __rd_start, * __rd_end; | ||
36 | |||
37 | /* | ||
38 | * Machine setup.. | ||
39 | */ | ||
40 | |||
41 | /* | 35 | /* |
42 | * Initialize loops_per_jiffy as 10000000 (1000MIPS). | 36 | * Initialize loops_per_jiffy as 10000000 (1000MIPS). |
43 | * This value will be used at the very early stage of serial setup. | 37 | * This value will be used at the very early stage of serial setup. |
@@ -63,33 +57,25 @@ struct screen_info screen_info; | |||
63 | 57 | ||
64 | extern int root_mountflags; | 58 | extern int root_mountflags; |
65 | 59 | ||
66 | /* | ||
67 | * This is set up by the setup-routine at boot-time | ||
68 | */ | ||
69 | #define PARAM ((unsigned char *)empty_zero_page) | ||
70 | |||
71 | #define MOUNT_ROOT_RDONLY (*(unsigned long *) (PARAM+0x000)) | ||
72 | #define RAMDISK_FLAGS (*(unsigned long *) (PARAM+0x004)) | ||
73 | #define ORIG_ROOT_DEV (*(unsigned long *) (PARAM+0x008)) | ||
74 | #define LOADER_TYPE (*(unsigned long *) (PARAM+0x00c)) | ||
75 | #define INITRD_START (*(unsigned long *) (PARAM+0x010)) | ||
76 | #define INITRD_SIZE (*(unsigned long *) (PARAM+0x014)) | ||
77 | /* ... */ | ||
78 | #define COMMAND_LINE ((char *) (PARAM+0x100)) | ||
79 | |||
80 | #define RAMDISK_IMAGE_START_MASK 0x07FF | 60 | #define RAMDISK_IMAGE_START_MASK 0x07FF |
81 | #define RAMDISK_PROMPT_FLAG 0x8000 | 61 | #define RAMDISK_PROMPT_FLAG 0x8000 |
82 | #define RAMDISK_LOAD_FLAG 0x4000 | 62 | #define RAMDISK_LOAD_FLAG 0x4000 |
83 | 63 | ||
84 | static char __initdata command_line[COMMAND_LINE_SIZE] = { 0, }; | 64 | static char __initdata command_line[COMMAND_LINE_SIZE] = { 0, }; |
85 | 65 | ||
86 | static struct resource code_resource = { .name = "Kernel code", }; | 66 | static struct resource code_resource = { |
87 | static struct resource data_resource = { .name = "Kernel data", }; | 67 | .name = "Kernel code", |
68 | .flags = IORESOURCE_BUSY | IORESOURCE_MEM, | ||
69 | }; | ||
70 | |||
71 | static struct resource data_resource = { | ||
72 | .name = "Kernel data", | ||
73 | .flags = IORESOURCE_BUSY | IORESOURCE_MEM, | ||
74 | }; | ||
88 | 75 | ||
89 | unsigned long memory_start; | 76 | unsigned long memory_start; |
90 | EXPORT_SYMBOL(memory_start); | 77 | EXPORT_SYMBOL(memory_start); |
91 | 78 | unsigned long memory_end = 0; | |
92 | unsigned long memory_end; | ||
93 | EXPORT_SYMBOL(memory_end); | 79 | EXPORT_SYMBOL(memory_end); |
94 | 80 | ||
95 | static int __init early_parse_mem(char *p) | 81 | static int __init early_parse_mem(char *p) |
@@ -195,14 +181,7 @@ void __init setup_bootmem_allocator(unsigned long free_pfn) | |||
195 | sparse_memory_present_with_active_regions(0); | 181 | sparse_memory_present_with_active_regions(0); |
196 | 182 | ||
197 | #ifdef CONFIG_BLK_DEV_INITRD | 183 | #ifdef CONFIG_BLK_DEV_INITRD |
198 | ROOT_DEV = MKDEV(RAMDISK_MAJOR, 0); | 184 | ROOT_DEV = Root_RAM0; |
199 | if (&__rd_start != &__rd_end) { | ||
200 | LOADER_TYPE = 1; | ||
201 | INITRD_START = PHYSADDR((unsigned long)&__rd_start) - | ||
202 | __MEMORY_START; | ||
203 | INITRD_SIZE = (unsigned long)&__rd_end - | ||
204 | (unsigned long)&__rd_start; | ||
205 | } | ||
206 | 185 | ||
207 | if (LOADER_TYPE && INITRD_START) { | 186 | if (LOADER_TYPE && INITRD_START) { |
208 | if (INITRD_START + INITRD_SIZE <= (max_low_pfn << PAGE_SHIFT)) { | 187 | if (INITRD_START + INITRD_SIZE <= (max_low_pfn << PAGE_SHIFT)) { |
@@ -265,7 +244,8 @@ void __init setup_arch(char **cmdline_p) | |||
265 | data_resource.end = virt_to_phys(_edata)-1; | 244 | data_resource.end = virt_to_phys(_edata)-1; |
266 | 245 | ||
267 | memory_start = (unsigned long)PAGE_OFFSET+__MEMORY_START; | 246 | memory_start = (unsigned long)PAGE_OFFSET+__MEMORY_START; |
268 | memory_end = memory_start + __MEMORY_SIZE; | 247 | if (!memory_end) |
248 | memory_end = memory_start + __MEMORY_SIZE; | ||
269 | 249 | ||
270 | #ifdef CONFIG_CMDLINE_BOOL | 250 | #ifdef CONFIG_CMDLINE_BOOL |
271 | strlcpy(command_line, CONFIG_CMDLINE, sizeof(command_line)); | 251 | strlcpy(command_line, CONFIG_CMDLINE, sizeof(command_line)); |
diff --git a/arch/sh/kernel/vmlinux.lds.S b/arch/sh/kernel/vmlinux.lds.S index 6d5abba2ee27..0956fb3681a3 100644 --- a/arch/sh/kernel/vmlinux.lds.S +++ b/arch/sh/kernel/vmlinux.lds.S | |||
@@ -1,4 +1,4 @@ | |||
1 | /* $Id: vmlinux.lds.S,v 1.8 2003/05/16 17:18:14 lethal Exp $ | 1 | /* |
2 | * ld script to make SuperH Linux kernel | 2 | * ld script to make SuperH Linux kernel |
3 | * Written by Niibe Yutaka | 3 | * Written by Niibe Yutaka |
4 | */ | 4 | */ |
@@ -15,121 +15,124 @@ OUTPUT_ARCH(sh) | |||
15 | ENTRY(_start) | 15 | ENTRY(_start) |
16 | SECTIONS | 16 | SECTIONS |
17 | { | 17 | { |
18 | . = CONFIG_PAGE_OFFSET + CONFIG_MEMORY_START + CONFIG_ZERO_PAGE_OFFSET; | 18 | . = CONFIG_PAGE_OFFSET + CONFIG_MEMORY_START + CONFIG_ZERO_PAGE_OFFSET; |
19 | _text = .; /* Text and read-only data */ | 19 | _text = .; /* Text and read-only data */ |
20 | text = .; /* Text and read-only data */ | 20 | |
21 | .empty_zero_page : { | 21 | .empty_zero_page : { |
22 | *(.empty_zero_page) | 22 | *(.empty_zero_page) |
23 | } = 0 | 23 | } = 0 |
24 | .text : { | 24 | |
25 | *(.text.head) | 25 | .text : { |
26 | TEXT_TEXT | 26 | *(.text.head) |
27 | SCHED_TEXT | 27 | TEXT_TEXT |
28 | LOCK_TEXT | 28 | SCHED_TEXT |
29 | *(.fixup) | 29 | LOCK_TEXT |
30 | *(.gnu.warning) | 30 | KPROBES_TEXT |
31 | *(.fixup) | ||
32 | *(.gnu.warning) | ||
31 | } = 0x0009 | 33 | } = 0x0009 |
32 | 34 | ||
33 | . = ALIGN(16); /* Exception table */ | 35 | . = ALIGN(16); /* Exception table */ |
34 | __start___ex_table = .; | 36 | __start___ex_table = .; |
35 | __ex_table : { *(__ex_table) } | 37 | __ex_table : { *(__ex_table) } |
36 | __stop___ex_table = .; | 38 | __stop___ex_table = .; |
39 | |||
40 | _etext = .; /* End of text section */ | ||
37 | 41 | ||
38 | _etext = .; /* End of text section */ | 42 | BUG_TABLE |
43 | NOTES | ||
44 | RO_DATA(PAGE_SIZE) | ||
39 | 45 | ||
40 | RODATA | 46 | . = ALIGN(THREAD_SIZE); |
47 | .data : { /* Data */ | ||
48 | *(.data.init_task) | ||
41 | 49 | ||
42 | BUG_TABLE | 50 | . = ALIGN(L1_CACHE_BYTES); |
51 | *(.data.cacheline_aligned) | ||
43 | 52 | ||
44 | .data : { /* Data */ | 53 | . = ALIGN(L1_CACHE_BYTES); |
45 | DATA_DATA | 54 | *(.data.read_mostly) |
46 | 55 | ||
47 | /* Align the initial ramdisk image (INITRD) on page boundaries. */ | 56 | . = ALIGN(PAGE_SIZE); |
48 | . = ALIGN(PAGE_SIZE); | 57 | *(.data.page_aligned) |
49 | __rd_start = .; | ||
50 | *(.initrd) | ||
51 | . = ALIGN(PAGE_SIZE); | ||
52 | __rd_end = .; | ||
53 | 58 | ||
54 | CONSTRUCTORS | 59 | __nosave_begin = .; |
60 | *(.data.nosave) | ||
61 | . = ALIGN(PAGE_SIZE); | ||
62 | __nosave_end = .; | ||
63 | |||
64 | DATA_DATA | ||
65 | CONSTRUCTORS | ||
55 | } | 66 | } |
56 | 67 | ||
57 | . = ALIGN(PAGE_SIZE); | 68 | _edata = .; /* End of data section */ |
58 | .data.page_aligned : { *(.data.page_aligned) } | ||
59 | __nosave_begin = .; | ||
60 | .data_nosave : { *(.data.nosave) } | ||
61 | . = ALIGN(PAGE_SIZE); | ||
62 | __nosave_end = .; | ||
63 | |||
64 | PERCPU(PAGE_SIZE) | ||
65 | |||
66 | . = ALIGN(L1_CACHE_BYTES); | ||
67 | .data.cacheline_aligned : { *(.data.cacheline_aligned) } | ||
68 | |||
69 | _edata = .; /* End of data section */ | ||
70 | |||
71 | . = ALIGN(THREAD_SIZE); /* init_task */ | ||
72 | .data.init_task : { *(.data.init_task) } | ||
73 | |||
74 | . = ALIGN(PAGE_SIZE); /* Init code and data */ | ||
75 | __init_begin = .; | ||
76 | _sinittext = .; | ||
77 | .init.text : { *(.init.text) } | ||
78 | _einittext = .; | ||
79 | .init.data : { *(.init.data) } | ||
80 | . = ALIGN(16); | ||
81 | __setup_start = .; | ||
82 | .init.setup : { *(.init.setup) } | ||
83 | __setup_end = .; | ||
84 | __initcall_start = .; | ||
85 | .initcall.init : { | ||
86 | INITCALLS | ||
87 | } | ||
88 | __initcall_end = .; | ||
89 | __con_initcall_start = .; | ||
90 | .con_initcall.init : { *(.con_initcall.init) } | ||
91 | __con_initcall_end = .; | ||
92 | SECURITY_INIT | ||
93 | |||
94 | /* .exit.text is discarded at runtime, not link time, to deal with | ||
95 | references from .rodata */ | ||
96 | .exit.text : { *(.exit.text) } | ||
97 | .exit.data : { *(.exit.data) } | ||
98 | 69 | ||
99 | #ifdef CONFIG_BLK_DEV_INITRD | 70 | . = ALIGN(PAGE_SIZE); /* Init code and data */ |
100 | . = ALIGN(PAGE_SIZE); | 71 | __init_begin = .; |
72 | _sinittext = .; | ||
73 | .init.text : { *(.init.text) } | ||
74 | _einittext = .; | ||
75 | .init.data : { *(.init.data) } | ||
76 | |||
77 | . = ALIGN(16); | ||
78 | __setup_start = .; | ||
79 | .init.setup : { *(.init.setup) } | ||
80 | __setup_end = .; | ||
101 | 81 | ||
102 | __initramfs_start = .; | 82 | __initcall_start = .; |
103 | .init.ramfs : { *(.init.ramfs) } | 83 | .initcall.init : { |
104 | __initramfs_end = .; | 84 | INITCALLS |
85 | } | ||
86 | __initcall_end = .; | ||
87 | __con_initcall_start = .; | ||
88 | .con_initcall.init : { *(.con_initcall.init) } | ||
89 | __con_initcall_end = .; | ||
90 | |||
91 | SECURITY_INIT | ||
92 | |||
93 | #ifdef CONFIG_BLK_DEV_INITRD | ||
94 | . = ALIGN(PAGE_SIZE); | ||
95 | __initramfs_start = .; | ||
96 | .init.ramfs : { *(.init.ramfs) } | ||
97 | __initramfs_end = .; | ||
105 | #endif | 98 | #endif |
106 | 99 | ||
107 | . = ALIGN(4); | ||
108 | __machvec_start = .; | ||
109 | .machvec.init : { *(.machvec.init) } | ||
110 | __machvec_end = .; | ||
111 | |||
112 | . = ALIGN(PAGE_SIZE); | ||
113 | .bss : { | ||
114 | __init_end = .; | ||
115 | __bss_start = .; /* BSS */ | ||
116 | *(.bss.page_aligned) | ||
117 | *(.bss) | ||
118 | . = ALIGN(4); | 100 | . = ALIGN(4); |
119 | _ebss = .; /* uClinux MTD sucks */ | 101 | __machvec_start = .; |
120 | _end = . ; | 102 | .machvec.init : { *(.machvec.init) } |
121 | } | 103 | __machvec_end = .; |
122 | 104 | ||
123 | /* When something in the kernel is NOT compiled as a module, the | 105 | PERCPU(PAGE_SIZE) |
124 | * module cleanup code and data are put into these segments. Both | 106 | |
125 | * can then be thrown away, as cleanup code is never called unless | 107 | /* |
126 | * it's a module. | 108 | * .exit.text is discarded at runtime, not link time, to deal with |
127 | */ | 109 | * references from __bug_table |
128 | /DISCARD/ : { | 110 | */ |
129 | *(.exitcall.exit) | 111 | .exit.text : { *(.exit.text) } |
112 | .exit.data : { *(.exit.data) } | ||
113 | |||
114 | . = ALIGN(PAGE_SIZE); | ||
115 | .bss : { | ||
116 | __init_end = .; | ||
117 | __bss_start = .; /* BSS */ | ||
118 | *(.bss.page_aligned) | ||
119 | *(.bss) | ||
120 | *(COMMON) | ||
121 | . = ALIGN(4); | ||
122 | _ebss = .; /* uClinux MTD sucks */ | ||
123 | _end = . ; | ||
130 | } | 124 | } |
131 | 125 | ||
132 | STABS_DEBUG | 126 | /* |
127 | * When something in the kernel is NOT compiled as a module, the | ||
128 | * module cleanup code and data are put into these segments. Both | ||
129 | * can then be thrown away, as cleanup code is never called unless | ||
130 | * it's a module. | ||
131 | */ | ||
132 | /DISCARD/ : { | ||
133 | *(.exitcall.exit) | ||
134 | } | ||
133 | 135 | ||
134 | DWARF_DEBUG | 136 | STABS_DEBUG |
137 | DWARF_DEBUG | ||
135 | } | 138 | } |
diff --git a/arch/sh/kernel/vsyscall/vsyscall.lds.S b/arch/sh/kernel/vsyscall/vsyscall.lds.S index c9bf2af35d35..6d59ee7c23dd 100644 --- a/arch/sh/kernel/vsyscall/vsyscall.lds.S +++ b/arch/sh/kernel/vsyscall/vsyscall.lds.S | |||
@@ -38,7 +38,10 @@ SECTIONS | |||
38 | .text : { *(.text) } :text =0x90909090 | 38 | .text : { *(.text) } :text =0x90909090 |
39 | .note : { *(.note.*) } :text :note | 39 | .note : { *(.note.*) } :text :note |
40 | .eh_frame_hdr : { *(.eh_frame_hdr ) } :text :eh_frame_hdr | 40 | .eh_frame_hdr : { *(.eh_frame_hdr ) } :text :eh_frame_hdr |
41 | .eh_frame : { KEEP (*(.eh_frame)) } :text | 41 | .eh_frame : { |
42 | KEEP (*(.eh_frame)) | ||
43 | LONG (0) | ||
44 | } :text | ||
42 | .dynamic : { *(.dynamic) } :text :dynamic | 45 | .dynamic : { *(.dynamic) } :text :dynamic |
43 | .useless : { | 46 | .useless : { |
44 | *(.got.plt) *(.got) | 47 | *(.got.plt) *(.got) |
diff --git a/arch/sh/mm/copy_page.S b/arch/sh/mm/copy_page.S index a81dbdb05596..3d8409daa4be 100644 --- a/arch/sh/mm/copy_page.S +++ b/arch/sh/mm/copy_page.S | |||
@@ -255,7 +255,11 @@ EX( mov.l @r5+,r8 ) | |||
255 | EX( mov.l @r5+,r9 ) | 255 | EX( mov.l @r5+,r9 ) |
256 | EX( mov.l @r5+,r10 ) | 256 | EX( mov.l @r5+,r10 ) |
257 | EX( mov.l @r5+,r11 ) | 257 | EX( mov.l @r5+,r11 ) |
258 | #ifdef CONFIG_CPU_SH4 | ||
258 | EX( movca.l r0,@r4 ) | 259 | EX( movca.l r0,@r4 ) |
260 | #else | ||
261 | EX( mov.l r0,@r4 ) | ||
262 | #endif | ||
259 | add #-32, r6 | 263 | add #-32, r6 |
260 | EX( mov.l r1,@(4,r4) ) | 264 | EX( mov.l r1,@(4,r4) ) |
261 | mov #32, r0 | 265 | mov #32, r0 |
diff --git a/arch/sh/oprofile/op_model_sh7750.c b/arch/sh/oprofile/op_model_sh7750.c index ebee7e24ede9..6b9a98e07004 100644 --- a/arch/sh/oprofile/op_model_sh7750.c +++ b/arch/sh/oprofile/op_model_sh7750.c | |||
@@ -16,7 +16,6 @@ | |||
16 | #include <linux/errno.h> | 16 | #include <linux/errno.h> |
17 | #include <linux/interrupt.h> | 17 | #include <linux/interrupt.h> |
18 | #include <linux/fs.h> | 18 | #include <linux/fs.h> |
19 | #include <linux/notifier.h> | ||
20 | #include <asm/uaccess.h> | 19 | #include <asm/uaccess.h> |
21 | #include <asm/io.h> | 20 | #include <asm/io.h> |
22 | 21 | ||
@@ -44,8 +43,6 @@ | |||
44 | */ | 43 | */ |
45 | #define NR_CNTRS 2 | 44 | #define NR_CNTRS 2 |
46 | 45 | ||
47 | extern const char *get_cpu_subtype(void); | ||
48 | |||
49 | struct op_counter_config { | 46 | struct op_counter_config { |
50 | unsigned long enabled; | 47 | unsigned long enabled; |
51 | unsigned long event; | 48 | unsigned long event; |
@@ -111,17 +108,12 @@ static struct op_counter_config ctr[NR_CNTRS]; | |||
111 | * behavior. | 108 | * behavior. |
112 | */ | 109 | */ |
113 | 110 | ||
114 | static int sh7750_timer_notify(struct notifier_block *self, | 111 | static int sh7750_timer_notify(struct pt_regs *regs) |
115 | unsigned long val, void *regs) | ||
116 | { | 112 | { |
117 | oprofile_add_sample((struct pt_regs *)regs, 0); | 113 | oprofile_add_sample(regs, 0); |
118 | return 0; | 114 | return 0; |
119 | } | 115 | } |
120 | 116 | ||
121 | static struct notifier_block sh7750_timer_notifier = { | ||
122 | .notifier_call = sh7750_timer_notify, | ||
123 | }; | ||
124 | |||
125 | static u64 sh7750_read_counter(int counter) | 117 | static u64 sh7750_read_counter(int counter) |
126 | { | 118 | { |
127 | u32 hi, lo; | 119 | u32 hi, lo; |
@@ -240,7 +232,7 @@ static int sh7750_perf_counter_start(void) | |||
240 | ctrl_outw(pmcr | PMCR_ENABLE, PMCR2); | 232 | ctrl_outw(pmcr | PMCR_ENABLE, PMCR2); |
241 | } | 233 | } |
242 | 234 | ||
243 | return register_profile_notifier(&sh7750_timer_notifier); | 235 | return register_timer_hook(sh7750_timer_notify); |
244 | } | 236 | } |
245 | 237 | ||
246 | static void sh7750_perf_counter_stop(void) | 238 | static void sh7750_perf_counter_stop(void) |
@@ -248,7 +240,7 @@ static void sh7750_perf_counter_stop(void) | |||
248 | ctrl_outw(ctrl_inw(PMCR1) & ~PMCR_PMEN, PMCR1); | 240 | ctrl_outw(ctrl_inw(PMCR1) & ~PMCR_PMEN, PMCR1); |
249 | ctrl_outw(ctrl_inw(PMCR2) & ~PMCR_PMEN, PMCR2); | 241 | ctrl_outw(ctrl_inw(PMCR2) & ~PMCR_PMEN, PMCR2); |
250 | 242 | ||
251 | unregister_profile_notifier(&sh7750_timer_notifier); | 243 | unregister_timer_hook(sh7750_timer_notify); |
252 | } | 244 | } |
253 | 245 | ||
254 | static struct oprofile_operations sh7750_perf_counter_ops = { | 246 | static struct oprofile_operations sh7750_perf_counter_ops = { |
@@ -257,13 +249,13 @@ static struct oprofile_operations sh7750_perf_counter_ops = { | |||
257 | .stop = sh7750_perf_counter_stop, | 249 | .stop = sh7750_perf_counter_stop, |
258 | }; | 250 | }; |
259 | 251 | ||
260 | int __init oprofile_arch_init(struct oprofile_operations **ops) | 252 | int __init oprofile_arch_init(struct oprofile_operations *ops) |
261 | { | 253 | { |
262 | if (!(current_cpu_data.flags & CPU_HAS_PERF_COUNTER)) | 254 | if (!(current_cpu_data.flags & CPU_HAS_PERF_COUNTER)) |
263 | return -ENODEV; | 255 | return -ENODEV; |
264 | 256 | ||
265 | sh7750_perf_counter_ops.cpu_type = (char *)get_cpu_subtype(); | 257 | ops = &sh7750_perf_counter_ops; |
266 | *ops = &sh7750_perf_counter_ops; | 258 | ops->cpu_type = (char *)get_cpu_subtype(¤t_cpu_data); |
267 | 259 | ||
268 | printk(KERN_INFO "oprofile: using SH-4 (%s) performance monitoring.\n", | 260 | printk(KERN_INFO "oprofile: using SH-4 (%s) performance monitoring.\n", |
269 | sh7750_perf_counter_ops.cpu_type); | 261 | sh7750_perf_counter_ops.cpu_type); |
diff --git a/arch/sh/tools/mach-types b/arch/sh/tools/mach-types index 439bfe3d29af..ff071693325c 100644 --- a/arch/sh/tools/mach-types +++ b/arch/sh/tools/mach-types | |||
@@ -1,26 +1,35 @@ | |||
1 | # | 1 | # |
2 | # List of boards. | 2 | # MACH_<xxx> CONFIG_<xxx> |
3 | # | 3 | # |
4 | 4 | ||
5 | # | 5 | # |
6 | # MACH_<xxx> CONFIG_<xxx> | 6 | # List of board groups. |
7 | # | 7 | # |
8 | SE SH_SOLUTION_ENGINE | 8 | SE SH_SOLUTION_ENGINE |
9 | 7751SE SH_7751_SOLUTION_ENGINE | 9 | HIGHLANDER SH_HIGHLANDER |
10 | 7722SE SH_7722_SOLUTION_ENGINE | 10 | RTS7751R2D SH_RTS7751R2D |
11 | 7343SE SH_7343_SOLUTION_ENGINE | 11 | |
12 | # | ||
13 | # List of companion chips / MFDs. | ||
14 | # | ||
15 | HD64461 HD64461 | ||
16 | HD64465 HD64465 | ||
17 | |||
18 | # | ||
19 | # List of boards. | ||
20 | # | ||
12 | 7206SE SH_7206_SOLUTION_ENGINE | 21 | 7206SE SH_7206_SOLUTION_ENGINE |
22 | 7343SE SH_7343_SOLUTION_ENGINE | ||
13 | 7619SE SH_7619_SOLUTION_ENGINE | 23 | 7619SE SH_7619_SOLUTION_ENGINE |
24 | 7722SE SH_7722_SOLUTION_ENGINE | ||
25 | 7751SE SH_7751_SOLUTION_ENGINE | ||
14 | 7780SE SH_7780_SOLUTION_ENGINE | 26 | 7780SE SH_7780_SOLUTION_ENGINE |
15 | 7751SYSTEMH SH_7751_SYSTEMH | 27 | 7751SYSTEMH SH_7751_SYSTEMH |
16 | HP6XX SH_HP6XX | 28 | HP6XX SH_HP6XX |
17 | HD64461 HD64461 | ||
18 | HD64465 HD64465 | ||
19 | DREAMCAST SH_DREAMCAST | 29 | DREAMCAST SH_DREAMCAST |
20 | MPC1211 SH_MPC1211 | 30 | MPC1211 SH_MPC1211 |
21 | SNAPGEAR SH_SECUREEDGE5410 | 31 | SNAPGEAR SH_SECUREEDGE5410 |
22 | HS7751RVOIP SH_HS7751RVOIP | 32 | HS7751RVOIP SH_HS7751RVOIP |
23 | RTS7751R2D SH_RTS7751R2D | ||
24 | EDOSK7705 SH_EDOSK7705 | 33 | EDOSK7705 SH_EDOSK7705 |
25 | SH4202_MICRODEV SH_SH4202_MICRODEV | 34 | SH4202_MICRODEV SH_SH4202_MICRODEV |
26 | SH03 SH_SH03 | 35 | SH03 SH_SH03 |
@@ -32,3 +41,7 @@ TITAN SH_TITAN | |||
32 | SHMIN SH_SHMIN | 41 | SHMIN SH_SHMIN |
33 | 7710VOIPGW SH_7710VOIPGW | 42 | 7710VOIPGW SH_7710VOIPGW |
34 | LBOXRE2 SH_LBOX_RE2 | 43 | LBOXRE2 SH_LBOX_RE2 |
44 | X3PROTO SH_X3PROTO | ||
45 | MAGICPANELR2 SH_MAGIC_PANEL_R2 | ||
46 | R2D_PLUS RTS7751R2D_PLUS | ||
47 | R2D_1 RTS7751R2D_1 | ||
diff --git a/arch/sh64/Kconfig b/arch/sh64/Kconfig index ba204bac49df..6884d5a518ad 100644 --- a/arch/sh64/Kconfig +++ b/arch/sh64/Kconfig | |||
@@ -1,6 +1,6 @@ | |||
1 | # | 1 | # |
2 | # For a description of the syntax of this configuration file, | 2 | # For a description of the syntax of this configuration file, |
3 | # see Documentation/kbuild/config-language.txt. | 3 | # see Documentation/kbuild/kconfig-language.txt. |
4 | # | 4 | # |
5 | 5 | ||
6 | mainmenu "Linux/SH64 Kernel Configuration" | 6 | mainmenu "Linux/SH64 Kernel Configuration" |
diff --git a/arch/sh64/configs/cayman_defconfig b/arch/sh64/configs/cayman_defconfig index 91b59118c1b1..75552bb01405 100644 --- a/arch/sh64/configs/cayman_defconfig +++ b/arch/sh64/configs/cayman_defconfig | |||
@@ -1,7 +1,7 @@ | |||
1 | # | 1 | # |
2 | # Automatically generated make config: don't edit | 2 | # Automatically generated make config: don't edit |
3 | # Linux kernel version: 2.6.23-rc8 | 3 | # Linux kernel version: 2.6.24-rc1 |
4 | # Tue Oct 9 15:37:16 2007 | 4 | # Fri Nov 2 14:35:27 2007 |
5 | # | 5 | # |
6 | CONFIG_SUPERH=y | 6 | CONFIG_SUPERH=y |
7 | CONFIG_SUPERH64=y | 7 | CONFIG_SUPERH64=y |
@@ -36,6 +36,10 @@ CONFIG_POSIX_MQUEUE=y | |||
36 | # CONFIG_AUDIT is not set | 36 | # CONFIG_AUDIT is not set |
37 | # CONFIG_IKCONFIG is not set | 37 | # CONFIG_IKCONFIG is not set |
38 | CONFIG_LOG_BUF_SHIFT=14 | 38 | CONFIG_LOG_BUF_SHIFT=14 |
39 | # CONFIG_CGROUPS is not set | ||
40 | CONFIG_FAIR_GROUP_SCHED=y | ||
41 | CONFIG_FAIR_USER_SCHED=y | ||
42 | # CONFIG_FAIR_CGROUP_SCHED is not set | ||
39 | CONFIG_SYSFS_DEPRECATED=y | 43 | CONFIG_SYSFS_DEPRECATED=y |
40 | # CONFIG_RELAY is not set | 44 | # CONFIG_RELAY is not set |
41 | # CONFIG_BLK_DEV_INITRD is not set | 45 | # CONFIG_BLK_DEV_INITRD is not set |
@@ -148,6 +152,7 @@ CONFIG_FLATMEM_MANUAL=y | |||
148 | CONFIG_FLATMEM=y | 152 | CONFIG_FLATMEM=y |
149 | CONFIG_FLAT_NODE_MEM_MAP=y | 153 | CONFIG_FLAT_NODE_MEM_MAP=y |
150 | # CONFIG_SPARSEMEM_STATIC is not set | 154 | # CONFIG_SPARSEMEM_STATIC is not set |
155 | # CONFIG_SPARSEMEM_VMEMMAP_ENABLE is not set | ||
151 | CONFIG_SPLIT_PTLOCK_CPUS=4 | 156 | CONFIG_SPLIT_PTLOCK_CPUS=4 |
152 | # CONFIG_RESOURCES_64BIT is not set | 157 | # CONFIG_RESOURCES_64BIT is not set |
153 | CONFIG_ZONE_DMA_FLAG=0 | 158 | CONFIG_ZONE_DMA_FLAG=0 |
@@ -160,10 +165,6 @@ CONFIG_PCI=y | |||
160 | CONFIG_SH_PCIDMA_NONCOHERENT=y | 165 | CONFIG_SH_PCIDMA_NONCOHERENT=y |
161 | # CONFIG_ARCH_SUPPORTS_MSI is not set | 166 | # CONFIG_ARCH_SUPPORTS_MSI is not set |
162 | # CONFIG_PCI_DEBUG is not set | 167 | # CONFIG_PCI_DEBUG is not set |
163 | |||
164 | # | ||
165 | # PCCARD (PCMCIA/CardBus) support | ||
166 | # | ||
167 | # CONFIG_PCCARD is not set | 168 | # CONFIG_PCCARD is not set |
168 | # CONFIG_HOTPLUG_PCI is not set | 169 | # CONFIG_HOTPLUG_PCI is not set |
169 | 170 | ||
@@ -209,6 +210,7 @@ CONFIG_IP_PNP=y | |||
209 | CONFIG_INET_XFRM_MODE_TRANSPORT=y | 210 | CONFIG_INET_XFRM_MODE_TRANSPORT=y |
210 | CONFIG_INET_XFRM_MODE_TUNNEL=y | 211 | CONFIG_INET_XFRM_MODE_TUNNEL=y |
211 | CONFIG_INET_XFRM_MODE_BEET=y | 212 | CONFIG_INET_XFRM_MODE_BEET=y |
213 | # CONFIG_INET_LRO is not set | ||
212 | CONFIG_INET_DIAG=y | 214 | CONFIG_INET_DIAG=y |
213 | CONFIG_INET_TCP_DIAG=y | 215 | CONFIG_INET_TCP_DIAG=y |
214 | # CONFIG_TCP_CONG_ADVANCED is not set | 216 | # CONFIG_TCP_CONG_ADVANCED is not set |
@@ -234,10 +236,6 @@ CONFIG_DEFAULT_TCP_CONG="cubic" | |||
234 | # CONFIG_LAPB is not set | 236 | # CONFIG_LAPB is not set |
235 | # CONFIG_ECONET is not set | 237 | # CONFIG_ECONET is not set |
236 | # CONFIG_WAN_ROUTER is not set | 238 | # CONFIG_WAN_ROUTER is not set |
237 | |||
238 | # | ||
239 | # QoS and/or fair queueing | ||
240 | # | ||
241 | # CONFIG_NET_SCHED is not set | 239 | # CONFIG_NET_SCHED is not set |
242 | 240 | ||
243 | # | 241 | # |
@@ -266,6 +264,7 @@ CONFIG_DEFAULT_TCP_CONG="cubic" | |||
266 | # | 264 | # |
267 | # Generic Driver Options | 265 | # Generic Driver Options |
268 | # | 266 | # |
267 | CONFIG_UEVENT_HELPER_PATH="/sbin/hotplug" | ||
269 | CONFIG_STANDALONE=y | 268 | CONFIG_STANDALONE=y |
270 | CONFIG_PREVENT_FIRMWARE_BUILD=y | 269 | CONFIG_PREVENT_FIRMWARE_BUILD=y |
271 | # CONFIG_FW_LOADER is not set | 270 | # CONFIG_FW_LOADER is not set |
@@ -333,6 +332,7 @@ CONFIG_SCSI_SPI_ATTRS=y | |||
333 | # CONFIG_SCSI_FC_ATTRS is not set | 332 | # CONFIG_SCSI_FC_ATTRS is not set |
334 | # CONFIG_SCSI_ISCSI_ATTRS is not set | 333 | # CONFIG_SCSI_ISCSI_ATTRS is not set |
335 | # CONFIG_SCSI_SAS_LIBSAS is not set | 334 | # CONFIG_SCSI_SAS_LIBSAS is not set |
335 | # CONFIG_SCSI_SRP_ATTRS is not set | ||
336 | CONFIG_SCSI_LOWLEVEL=y | 336 | CONFIG_SCSI_LOWLEVEL=y |
337 | # CONFIG_ISCSI_TCP is not set | 337 | # CONFIG_ISCSI_TCP is not set |
338 | # CONFIG_BLK_DEV_3W_XXXX_RAID is not set | 338 | # CONFIG_BLK_DEV_3W_XXXX_RAID is not set |
@@ -370,14 +370,7 @@ CONFIG_SCSI_SYM53C8XX_MMIO=y | |||
370 | # CONFIG_SCSI_SRP is not set | 370 | # CONFIG_SCSI_SRP is not set |
371 | # CONFIG_ATA is not set | 371 | # CONFIG_ATA is not set |
372 | # CONFIG_MD is not set | 372 | # CONFIG_MD is not set |
373 | |||
374 | # | ||
375 | # Fusion MPT device support | ||
376 | # | ||
377 | # CONFIG_FUSION is not set | 373 | # CONFIG_FUSION is not set |
378 | # CONFIG_FUSION_SPI is not set | ||
379 | # CONFIG_FUSION_FC is not set | ||
380 | # CONFIG_FUSION_SAS is not set | ||
381 | 374 | ||
382 | # | 375 | # |
383 | # IEEE 1394 (FireWire) support | 376 | # IEEE 1394 (FireWire) support |
@@ -392,6 +385,8 @@ CONFIG_NETDEVICES=y | |||
392 | # CONFIG_MACVLAN is not set | 385 | # CONFIG_MACVLAN is not set |
393 | # CONFIG_EQUALIZER is not set | 386 | # CONFIG_EQUALIZER is not set |
394 | # CONFIG_TUN is not set | 387 | # CONFIG_TUN is not set |
388 | # CONFIG_VETH is not set | ||
389 | # CONFIG_IP1000 is not set | ||
395 | # CONFIG_ARCNET is not set | 390 | # CONFIG_ARCNET is not set |
396 | # CONFIG_PHYLIB is not set | 391 | # CONFIG_PHYLIB is not set |
397 | CONFIG_NET_ETHERNET=y | 392 | CONFIG_NET_ETHERNET=y |
@@ -402,6 +397,7 @@ CONFIG_NET_ETHERNET=y | |||
402 | # CONFIG_CASSINI is not set | 397 | # CONFIG_CASSINI is not set |
403 | # CONFIG_NET_VENDOR_3COM is not set | 398 | # CONFIG_NET_VENDOR_3COM is not set |
404 | # CONFIG_SMC91X is not set | 399 | # CONFIG_SMC91X is not set |
400 | # CONFIG_SMC911X is not set | ||
405 | CONFIG_NET_TULIP=y | 401 | CONFIG_NET_TULIP=y |
406 | # CONFIG_DE2104X is not set | 402 | # CONFIG_DE2104X is not set |
407 | CONFIG_TULIP=y | 403 | CONFIG_TULIP=y |
@@ -413,13 +409,16 @@ CONFIG_TULIP=y | |||
413 | # CONFIG_DM9102 is not set | 409 | # CONFIG_DM9102 is not set |
414 | # CONFIG_ULI526X is not set | 410 | # CONFIG_ULI526X is not set |
415 | # CONFIG_HP100 is not set | 411 | # CONFIG_HP100 is not set |
412 | # CONFIG_IBM_NEW_EMAC_ZMII is not set | ||
413 | # CONFIG_IBM_NEW_EMAC_RGMII is not set | ||
414 | # CONFIG_IBM_NEW_EMAC_TAH is not set | ||
415 | # CONFIG_IBM_NEW_EMAC_EMAC4 is not set | ||
416 | CONFIG_NET_PCI=y | 416 | CONFIG_NET_PCI=y |
417 | # CONFIG_PCNET32 is not set | 417 | # CONFIG_PCNET32 is not set |
418 | # CONFIG_AMD8111_ETH is not set | 418 | # CONFIG_AMD8111_ETH is not set |
419 | # CONFIG_ADAPTEC_STARFIRE is not set | 419 | # CONFIG_ADAPTEC_STARFIRE is not set |
420 | # CONFIG_B44 is not set | 420 | # CONFIG_B44 is not set |
421 | # CONFIG_FORCEDETH is not set | 421 | # CONFIG_FORCEDETH is not set |
422 | # CONFIG_DGRS is not set | ||
423 | # CONFIG_EEPRO100 is not set | 422 | # CONFIG_EEPRO100 is not set |
424 | # CONFIG_E100 is not set | 423 | # CONFIG_E100 is not set |
425 | # CONFIG_FEALNX is not set | 424 | # CONFIG_FEALNX is not set |
@@ -437,6 +436,7 @@ CONFIG_NETDEV_1000=y | |||
437 | # CONFIG_ACENIC is not set | 436 | # CONFIG_ACENIC is not set |
438 | # CONFIG_DL2K is not set | 437 | # CONFIG_DL2K is not set |
439 | # CONFIG_E1000 is not set | 438 | # CONFIG_E1000 is not set |
439 | # CONFIG_E1000E is not set | ||
440 | # CONFIG_NS83820 is not set | 440 | # CONFIG_NS83820 is not set |
441 | # CONFIG_HAMACHI is not set | 441 | # CONFIG_HAMACHI is not set |
442 | # CONFIG_YELLOWFIN is not set | 442 | # CONFIG_YELLOWFIN is not set |
@@ -453,11 +453,14 @@ CONFIG_NETDEV_1000=y | |||
453 | CONFIG_NETDEV_10000=y | 453 | CONFIG_NETDEV_10000=y |
454 | # CONFIG_CHELSIO_T1 is not set | 454 | # CONFIG_CHELSIO_T1 is not set |
455 | # CONFIG_CHELSIO_T3 is not set | 455 | # CONFIG_CHELSIO_T3 is not set |
456 | # CONFIG_IXGBE is not set | ||
456 | # CONFIG_IXGB is not set | 457 | # CONFIG_IXGB is not set |
457 | # CONFIG_S2IO is not set | 458 | # CONFIG_S2IO is not set |
458 | # CONFIG_MYRI10GE is not set | 459 | # CONFIG_MYRI10GE is not set |
459 | # CONFIG_NETXEN_NIC is not set | 460 | # CONFIG_NETXEN_NIC is not set |
461 | # CONFIG_NIU is not set | ||
460 | # CONFIG_MLX4_CORE is not set | 462 | # CONFIG_MLX4_CORE is not set |
463 | # CONFIG_TEHUTI is not set | ||
461 | # CONFIG_TR is not set | 464 | # CONFIG_TR is not set |
462 | 465 | ||
463 | # | 466 | # |
@@ -493,7 +496,6 @@ CONFIG_INPUT_MOUSEDEV_PSAUX=y | |||
493 | CONFIG_INPUT_MOUSEDEV_SCREEN_X=1024 | 496 | CONFIG_INPUT_MOUSEDEV_SCREEN_X=1024 |
494 | CONFIG_INPUT_MOUSEDEV_SCREEN_Y=768 | 497 | CONFIG_INPUT_MOUSEDEV_SCREEN_Y=768 |
495 | # CONFIG_INPUT_JOYDEV is not set | 498 | # CONFIG_INPUT_JOYDEV is not set |
496 | # CONFIG_INPUT_TSDEV is not set | ||
497 | # CONFIG_INPUT_EVDEV is not set | 499 | # CONFIG_INPUT_EVDEV is not set |
498 | # CONFIG_INPUT_EVBUG is not set | 500 | # CONFIG_INPUT_EVBUG is not set |
499 | 501 | ||
@@ -561,23 +563,9 @@ CONFIG_UNIX98_PTYS=y | |||
561 | CONFIG_LEGACY_PTYS=y | 563 | CONFIG_LEGACY_PTYS=y |
562 | CONFIG_LEGACY_PTY_COUNT=256 | 564 | CONFIG_LEGACY_PTY_COUNT=256 |
563 | # CONFIG_IPMI_HANDLER is not set | 565 | # CONFIG_IPMI_HANDLER is not set |
564 | CONFIG_WATCHDOG=y | ||
565 | # CONFIG_WATCHDOG_NOWAYOUT is not set | ||
566 | |||
567 | # | ||
568 | # Watchdog Device Drivers | ||
569 | # | ||
570 | # CONFIG_SOFT_WATCHDOG is not set | ||
571 | |||
572 | # | ||
573 | # PCI-based Watchdog Cards | ||
574 | # | ||
575 | # CONFIG_PCIPCWATCHDOG is not set | ||
576 | # CONFIG_WDTPCI is not set | ||
577 | CONFIG_HW_RANDOM=y | 566 | CONFIG_HW_RANDOM=y |
578 | # CONFIG_R3964 is not set | 567 | # CONFIG_R3964 is not set |
579 | # CONFIG_APPLICOM is not set | 568 | # CONFIG_APPLICOM is not set |
580 | # CONFIG_DRM is not set | ||
581 | # CONFIG_RAW_DRIVER is not set | 569 | # CONFIG_RAW_DRIVER is not set |
582 | # CONFIG_TCG_TPM is not set | 570 | # CONFIG_TCG_TPM is not set |
583 | CONFIG_DEVPORT=y | 571 | CONFIG_DEVPORT=y |
@@ -644,8 +632,6 @@ CONFIG_I2C_BOARDINFO=y | |||
644 | # CONFIG_POWER_SUPPLY is not set | 632 | # CONFIG_POWER_SUPPLY is not set |
645 | CONFIG_HWMON=y | 633 | CONFIG_HWMON=y |
646 | # CONFIG_HWMON_VID is not set | 634 | # CONFIG_HWMON_VID is not set |
647 | # CONFIG_SENSORS_ABITUGURU is not set | ||
648 | # CONFIG_SENSORS_ABITUGURU3 is not set | ||
649 | # CONFIG_SENSORS_AD7418 is not set | 635 | # CONFIG_SENSORS_AD7418 is not set |
650 | # CONFIG_SENSORS_ADM1021 is not set | 636 | # CONFIG_SENSORS_ADM1021 is not set |
651 | # CONFIG_SENSORS_ADM1025 is not set | 637 | # CONFIG_SENSORS_ADM1025 is not set |
@@ -653,12 +639,12 @@ CONFIG_HWMON=y | |||
653 | # CONFIG_SENSORS_ADM1029 is not set | 639 | # CONFIG_SENSORS_ADM1029 is not set |
654 | # CONFIG_SENSORS_ADM1031 is not set | 640 | # CONFIG_SENSORS_ADM1031 is not set |
655 | # CONFIG_SENSORS_ADM9240 is not set | 641 | # CONFIG_SENSORS_ADM9240 is not set |
656 | # CONFIG_SENSORS_ASB100 is not set | 642 | # CONFIG_SENSORS_ADT7470 is not set |
657 | # CONFIG_SENSORS_ATXP1 is not set | 643 | # CONFIG_SENSORS_ATXP1 is not set |
658 | # CONFIG_SENSORS_DS1621 is not set | 644 | # CONFIG_SENSORS_DS1621 is not set |
659 | # CONFIG_SENSORS_F71805F is not set | 645 | # CONFIG_SENSORS_F71805F is not set |
660 | # CONFIG_SENSORS_FSCHER is not set | 646 | # CONFIG_SENSORS_F71882FG is not set |
661 | # CONFIG_SENSORS_FSCPOS is not set | 647 | # CONFIG_SENSORS_F75375S is not set |
662 | # CONFIG_SENSORS_GL518SM is not set | 648 | # CONFIG_SENSORS_GL518SM is not set |
663 | # CONFIG_SENSORS_GL520SM is not set | 649 | # CONFIG_SENSORS_GL520SM is not set |
664 | # CONFIG_SENSORS_IT87 is not set | 650 | # CONFIG_SENSORS_IT87 is not set |
@@ -694,6 +680,25 @@ CONFIG_HWMON=y | |||
694 | # CONFIG_SENSORS_W83627HF is not set | 680 | # CONFIG_SENSORS_W83627HF is not set |
695 | # CONFIG_SENSORS_W83627EHF is not set | 681 | # CONFIG_SENSORS_W83627EHF is not set |
696 | # CONFIG_HWMON_DEBUG_CHIP is not set | 682 | # CONFIG_HWMON_DEBUG_CHIP is not set |
683 | CONFIG_WATCHDOG=y | ||
684 | # CONFIG_WATCHDOG_NOWAYOUT is not set | ||
685 | |||
686 | # | ||
687 | # Watchdog Device Drivers | ||
688 | # | ||
689 | # CONFIG_SOFT_WATCHDOG is not set | ||
690 | |||
691 | # | ||
692 | # PCI-based Watchdog Cards | ||
693 | # | ||
694 | # CONFIG_PCIPCWATCHDOG is not set | ||
695 | # CONFIG_WDTPCI is not set | ||
696 | |||
697 | # | ||
698 | # Sonics Silicon Backplane | ||
699 | # | ||
700 | CONFIG_SSB_POSSIBLE=y | ||
701 | # CONFIG_SSB is not set | ||
697 | 702 | ||
698 | # | 703 | # |
699 | # Multifunction device drivers | 704 | # Multifunction device drivers |
@@ -713,11 +718,11 @@ CONFIG_VIDEO_HELPER_CHIPS_AUTO=y | |||
713 | # CONFIG_VIDEO_VIVI is not set | 718 | # CONFIG_VIDEO_VIVI is not set |
714 | # CONFIG_VIDEO_SAA5246A is not set | 719 | # CONFIG_VIDEO_SAA5246A is not set |
715 | # CONFIG_VIDEO_SAA5249 is not set | 720 | # CONFIG_VIDEO_SAA5249 is not set |
716 | # CONFIG_TUNER_TEA5761 is not set | ||
717 | # CONFIG_VIDEO_SAA7134 is not set | 721 | # CONFIG_VIDEO_SAA7134 is not set |
718 | # CONFIG_VIDEO_HEXIUM_ORION is not set | 722 | # CONFIG_VIDEO_HEXIUM_ORION is not set |
719 | # CONFIG_VIDEO_HEXIUM_GEMINI is not set | 723 | # CONFIG_VIDEO_HEXIUM_GEMINI is not set |
720 | # CONFIG_VIDEO_CX88 is not set | 724 | # CONFIG_VIDEO_CX88 is not set |
725 | # CONFIG_VIDEO_CX23885 is not set | ||
721 | # CONFIG_VIDEO_CAFE_CCIC is not set | 726 | # CONFIG_VIDEO_CAFE_CCIC is not set |
722 | # CONFIG_RADIO_ADAPTERS is not set | 727 | # CONFIG_RADIO_ADAPTERS is not set |
723 | CONFIG_DVB_CORE=y | 728 | CONFIG_DVB_CORE=y |
@@ -796,6 +801,7 @@ CONFIG_DVB_CAPTURE_DRIVERS=y | |||
796 | # CONFIG_DVB_OR51132 is not set | 801 | # CONFIG_DVB_OR51132 is not set |
797 | # CONFIG_DVB_BCM3510 is not set | 802 | # CONFIG_DVB_BCM3510 is not set |
798 | # CONFIG_DVB_LGDT330X is not set | 803 | # CONFIG_DVB_LGDT330X is not set |
804 | # CONFIG_DVB_S5H1409 is not set | ||
799 | 805 | ||
800 | # | 806 | # |
801 | # Tuners/PLL support | 807 | # Tuners/PLL support |
@@ -805,6 +811,9 @@ CONFIG_DVB_CAPTURE_DRIVERS=y | |||
805 | # CONFIG_DVB_TDA827X is not set | 811 | # CONFIG_DVB_TDA827X is not set |
806 | # CONFIG_DVB_TUNER_QT1010 is not set | 812 | # CONFIG_DVB_TUNER_QT1010 is not set |
807 | # CONFIG_DVB_TUNER_MT2060 is not set | 813 | # CONFIG_DVB_TUNER_MT2060 is not set |
814 | # CONFIG_DVB_TUNER_MT2266 is not set | ||
815 | # CONFIG_DVB_TUNER_MT2131 is not set | ||
816 | # CONFIG_DVB_TUNER_DIB0070 is not set | ||
808 | 817 | ||
809 | # | 818 | # |
810 | # Miscellaneous devices | 819 | # Miscellaneous devices |
@@ -817,12 +826,7 @@ CONFIG_DAB=y | |||
817 | # | 826 | # |
818 | # Graphics support | 827 | # Graphics support |
819 | # | 828 | # |
820 | # CONFIG_BACKLIGHT_LCD_SUPPORT is not set | 829 | # CONFIG_DRM is not set |
821 | |||
822 | # | ||
823 | # Display device support | ||
824 | # | ||
825 | # CONFIG_DISPLAY_SUPPORT is not set | ||
826 | # CONFIG_VGASTATE is not set | 830 | # CONFIG_VGASTATE is not set |
827 | CONFIG_VIDEO_OUTPUT_CONTROL=y | 831 | CONFIG_VIDEO_OUTPUT_CONTROL=y |
828 | CONFIG_FB=y | 832 | CONFIG_FB=y |
@@ -831,6 +835,7 @@ CONFIG_FIRMWARE_EDID=y | |||
831 | CONFIG_FB_CFB_FILLRECT=y | 835 | CONFIG_FB_CFB_FILLRECT=y |
832 | CONFIG_FB_CFB_COPYAREA=y | 836 | CONFIG_FB_CFB_COPYAREA=y |
833 | CONFIG_FB_CFB_IMAGEBLIT=y | 837 | CONFIG_FB_CFB_IMAGEBLIT=y |
838 | # CONFIG_FB_CFB_REV_PIXELS_IN_BYTE is not set | ||
834 | # CONFIG_FB_SYS_FILLRECT is not set | 839 | # CONFIG_FB_SYS_FILLRECT is not set |
835 | # CONFIG_FB_SYS_COPYAREA is not set | 840 | # CONFIG_FB_SYS_COPYAREA is not set |
836 | # CONFIG_FB_SYS_IMAGEBLIT is not set | 841 | # CONFIG_FB_SYS_IMAGEBLIT is not set |
@@ -869,6 +874,12 @@ CONFIG_FB_KYRO=y | |||
869 | # CONFIG_FB_ARK is not set | 874 | # CONFIG_FB_ARK is not set |
870 | # CONFIG_FB_PM3 is not set | 875 | # CONFIG_FB_PM3 is not set |
871 | # CONFIG_FB_VIRTUAL is not set | 876 | # CONFIG_FB_VIRTUAL is not set |
877 | # CONFIG_BACKLIGHT_LCD_SUPPORT is not set | ||
878 | |||
879 | # | ||
880 | # Display device support | ||
881 | # | ||
882 | # CONFIG_DISPLAY_SUPPORT is not set | ||
872 | 883 | ||
873 | # | 884 | # |
874 | # Console display driver support | 885 | # Console display driver support |
@@ -903,6 +914,7 @@ CONFIG_LOGO_SUPERH_CLUT224=y | |||
903 | CONFIG_HID_SUPPORT=y | 914 | CONFIG_HID_SUPPORT=y |
904 | CONFIG_HID=y | 915 | CONFIG_HID=y |
905 | # CONFIG_HID_DEBUG is not set | 916 | # CONFIG_HID_DEBUG is not set |
917 | # CONFIG_HIDRAW is not set | ||
906 | CONFIG_USB_SUPPORT=y | 918 | CONFIG_USB_SUPPORT=y |
907 | CONFIG_USB_ARCH_HAS_HCD=y | 919 | CONFIG_USB_ARCH_HAS_HCD=y |
908 | CONFIG_USB_ARCH_HAS_OHCI=y | 920 | CONFIG_USB_ARCH_HAS_OHCI=y |
@@ -923,19 +935,6 @@ CONFIG_USB_ARCH_HAS_EHCI=y | |||
923 | # CONFIG_RTC_CLASS is not set | 935 | # CONFIG_RTC_CLASS is not set |
924 | 936 | ||
925 | # | 937 | # |
926 | # DMA Engine support | ||
927 | # | ||
928 | # CONFIG_DMA_ENGINE is not set | ||
929 | |||
930 | # | ||
931 | # DMA Clients | ||
932 | # | ||
933 | |||
934 | # | ||
935 | # DMA Devices | ||
936 | # | ||
937 | |||
938 | # | ||
939 | # Userspace I/O | 938 | # Userspace I/O |
940 | # | 939 | # |
941 | # CONFIG_UIO is not set | 940 | # CONFIG_UIO is not set |
@@ -994,7 +993,6 @@ CONFIG_TMPFS=y | |||
994 | # CONFIG_TMPFS_POSIX_ACL is not set | 993 | # CONFIG_TMPFS_POSIX_ACL is not set |
995 | CONFIG_HUGETLBFS=y | 994 | CONFIG_HUGETLBFS=y |
996 | CONFIG_HUGETLB_PAGE=y | 995 | CONFIG_HUGETLB_PAGE=y |
997 | CONFIG_RAMFS=y | ||
998 | # CONFIG_CONFIGFS_FS is not set | 996 | # CONFIG_CONFIGFS_FS is not set |
999 | 997 | ||
1000 | # | 998 | # |
@@ -1013,10 +1011,7 @@ CONFIG_RAMFS=y | |||
1013 | # CONFIG_QNX4FS_FS is not set | 1011 | # CONFIG_QNX4FS_FS is not set |
1014 | # CONFIG_SYSV_FS is not set | 1012 | # CONFIG_SYSV_FS is not set |
1015 | # CONFIG_UFS_FS is not set | 1013 | # CONFIG_UFS_FS is not set |
1016 | 1014 | CONFIG_NETWORK_FILESYSTEMS=y | |
1017 | # | ||
1018 | # Network File Systems | ||
1019 | # | ||
1020 | CONFIG_NFS_FS=y | 1015 | CONFIG_NFS_FS=y |
1021 | CONFIG_NFS_V3=y | 1016 | CONFIG_NFS_V3=y |
1022 | # CONFIG_NFS_V3_ACL is not set | 1017 | # CONFIG_NFS_V3_ACL is not set |
@@ -1058,26 +1053,17 @@ CONFIG_MSDOS_PARTITION=y | |||
1058 | # CONFIG_KARMA_PARTITION is not set | 1053 | # CONFIG_KARMA_PARTITION is not set |
1059 | # CONFIG_EFI_PARTITION is not set | 1054 | # CONFIG_EFI_PARTITION is not set |
1060 | # CONFIG_SYSV68_PARTITION is not set | 1055 | # CONFIG_SYSV68_PARTITION is not set |
1061 | |||
1062 | # | ||
1063 | # Native Language Support | ||
1064 | # | ||
1065 | # CONFIG_NLS is not set | 1056 | # CONFIG_NLS is not set |
1066 | |||
1067 | # | ||
1068 | # Distributed Lock Manager | ||
1069 | # | ||
1070 | # CONFIG_DLM is not set | 1057 | # CONFIG_DLM is not set |
1071 | 1058 | CONFIG_INSTRUMENTATION=y | |
1072 | # | ||
1073 | # Profiling support | ||
1074 | # | ||
1075 | # CONFIG_PROFILING is not set | 1059 | # CONFIG_PROFILING is not set |
1060 | # CONFIG_MARKERS is not set | ||
1076 | 1061 | ||
1077 | # | 1062 | # |
1078 | # Kernel hacking | 1063 | # Kernel hacking |
1079 | # | 1064 | # |
1080 | # CONFIG_PRINTK_TIME is not set | 1065 | # CONFIG_PRINTK_TIME is not set |
1066 | CONFIG_ENABLE_WARN_DEPRECATED=y | ||
1081 | CONFIG_ENABLE_MUST_CHECK=y | 1067 | CONFIG_ENABLE_MUST_CHECK=y |
1082 | CONFIG_MAGIC_SYSRQ=y | 1068 | CONFIG_MAGIC_SYSRQ=y |
1083 | # CONFIG_UNUSED_SYMBOLS is not set | 1069 | # CONFIG_UNUSED_SYMBOLS is not set |
@@ -1101,10 +1087,13 @@ CONFIG_DEBUG_BUGVERBOSE=y | |||
1101 | # CONFIG_DEBUG_INFO is not set | 1087 | # CONFIG_DEBUG_INFO is not set |
1102 | # CONFIG_DEBUG_VM is not set | 1088 | # CONFIG_DEBUG_VM is not set |
1103 | # CONFIG_DEBUG_LIST is not set | 1089 | # CONFIG_DEBUG_LIST is not set |
1090 | # CONFIG_DEBUG_SG is not set | ||
1104 | CONFIG_FRAME_POINTER=y | 1091 | CONFIG_FRAME_POINTER=y |
1105 | CONFIG_FORCED_INLINING=y | 1092 | CONFIG_FORCED_INLINING=y |
1093 | # CONFIG_BOOT_PRINTK_DELAY is not set | ||
1106 | # CONFIG_RCU_TORTURE_TEST is not set | 1094 | # CONFIG_RCU_TORTURE_TEST is not set |
1107 | # CONFIG_FAULT_INJECTION is not set | 1095 | # CONFIG_FAULT_INJECTION is not set |
1096 | # CONFIG_SAMPLES is not set | ||
1108 | # CONFIG_EARLY_PRINTK is not set | 1097 | # CONFIG_EARLY_PRINTK is not set |
1109 | CONFIG_SH64_PROC_TLB=y | 1098 | CONFIG_SH64_PROC_TLB=y |
1110 | CONFIG_SH64_PROC_ASIDS=y | 1099 | CONFIG_SH64_PROC_ASIDS=y |
@@ -1118,6 +1107,7 @@ CONFIG_SH64_SR_WATCH=y | |||
1118 | # | 1107 | # |
1119 | # CONFIG_KEYS is not set | 1108 | # CONFIG_KEYS is not set |
1120 | # CONFIG_SECURITY is not set | 1109 | # CONFIG_SECURITY is not set |
1110 | # CONFIG_SECURITY_FILE_CAPABILITIES is not set | ||
1121 | # CONFIG_CRYPTO is not set | 1111 | # CONFIG_CRYPTO is not set |
1122 | 1112 | ||
1123 | # | 1113 | # |
diff --git a/arch/sh64/configs/harp_defconfig b/arch/sh64/configs/harp_defconfig index e4b84b51baf8..ba302cd0c285 100644 --- a/arch/sh64/configs/harp_defconfig +++ b/arch/sh64/configs/harp_defconfig | |||
@@ -1,7 +1,7 @@ | |||
1 | # | 1 | # |
2 | # Automatically generated make config: don't edit | 2 | # Automatically generated make config: don't edit |
3 | # Linux kernel version: 2.6.23-rc8 | 3 | # Linux kernel version: 2.6.24-rc1 |
4 | # Mon Oct 1 18:01:38 2007 | 4 | # Fri Nov 2 14:35:57 2007 |
5 | # | 5 | # |
6 | CONFIG_SUPERH=y | 6 | CONFIG_SUPERH=y |
7 | CONFIG_SUPERH64=y | 7 | CONFIG_SUPERH64=y |
@@ -36,6 +36,10 @@ CONFIG_POSIX_MQUEUE=y | |||
36 | # CONFIG_AUDIT is not set | 36 | # CONFIG_AUDIT is not set |
37 | # CONFIG_IKCONFIG is not set | 37 | # CONFIG_IKCONFIG is not set |
38 | CONFIG_LOG_BUF_SHIFT=14 | 38 | CONFIG_LOG_BUF_SHIFT=14 |
39 | # CONFIG_CGROUPS is not set | ||
40 | CONFIG_FAIR_GROUP_SCHED=y | ||
41 | CONFIG_FAIR_USER_SCHED=y | ||
42 | # CONFIG_FAIR_CGROUP_SCHED is not set | ||
39 | CONFIG_SYSFS_DEPRECATED=y | 43 | CONFIG_SYSFS_DEPRECATED=y |
40 | # CONFIG_RELAY is not set | 44 | # CONFIG_RELAY is not set |
41 | # CONFIG_BLK_DEV_INITRD is not set | 45 | # CONFIG_BLK_DEV_INITRD is not set |
@@ -141,6 +145,7 @@ CONFIG_FLATMEM_MANUAL=y | |||
141 | CONFIG_FLATMEM=y | 145 | CONFIG_FLATMEM=y |
142 | CONFIG_FLAT_NODE_MEM_MAP=y | 146 | CONFIG_FLAT_NODE_MEM_MAP=y |
143 | # CONFIG_SPARSEMEM_STATIC is not set | 147 | # CONFIG_SPARSEMEM_STATIC is not set |
148 | # CONFIG_SPARSEMEM_VMEMMAP_ENABLE is not set | ||
144 | CONFIG_SPLIT_PTLOCK_CPUS=4 | 149 | CONFIG_SPLIT_PTLOCK_CPUS=4 |
145 | # CONFIG_RESOURCES_64BIT is not set | 150 | # CONFIG_RESOURCES_64BIT is not set |
146 | CONFIG_ZONE_DMA_FLAG=0 | 151 | CONFIG_ZONE_DMA_FLAG=0 |
@@ -150,10 +155,6 @@ CONFIG_NR_QUICK=1 | |||
150 | # Bus options (PCI, PCMCIA, EISA, MCA, ISA) | 155 | # Bus options (PCI, PCMCIA, EISA, MCA, ISA) |
151 | # | 156 | # |
152 | # CONFIG_ARCH_SUPPORTS_MSI is not set | 157 | # CONFIG_ARCH_SUPPORTS_MSI is not set |
153 | |||
154 | # | ||
155 | # PCCARD (PCMCIA/CardBus) support | ||
156 | # | ||
157 | # CONFIG_PCCARD is not set | 158 | # CONFIG_PCCARD is not set |
158 | 159 | ||
159 | # | 160 | # |
@@ -198,6 +199,7 @@ CONFIG_IP_PNP=y | |||
198 | CONFIG_INET_XFRM_MODE_TRANSPORT=y | 199 | CONFIG_INET_XFRM_MODE_TRANSPORT=y |
199 | CONFIG_INET_XFRM_MODE_TUNNEL=y | 200 | CONFIG_INET_XFRM_MODE_TUNNEL=y |
200 | CONFIG_INET_XFRM_MODE_BEET=y | 201 | CONFIG_INET_XFRM_MODE_BEET=y |
202 | # CONFIG_INET_LRO is not set | ||
201 | CONFIG_INET_DIAG=y | 203 | CONFIG_INET_DIAG=y |
202 | CONFIG_INET_TCP_DIAG=y | 204 | CONFIG_INET_TCP_DIAG=y |
203 | # CONFIG_TCP_CONG_ADVANCED is not set | 205 | # CONFIG_TCP_CONG_ADVANCED is not set |
@@ -223,10 +225,6 @@ CONFIG_DEFAULT_TCP_CONG="cubic" | |||
223 | # CONFIG_LAPB is not set | 225 | # CONFIG_LAPB is not set |
224 | # CONFIG_ECONET is not set | 226 | # CONFIG_ECONET is not set |
225 | # CONFIG_WAN_ROUTER is not set | 227 | # CONFIG_WAN_ROUTER is not set |
226 | |||
227 | # | ||
228 | # QoS and/or fair queueing | ||
229 | # | ||
230 | # CONFIG_NET_SCHED is not set | 228 | # CONFIG_NET_SCHED is not set |
231 | 229 | ||
232 | # | 230 | # |
@@ -255,6 +253,7 @@ CONFIG_DEFAULT_TCP_CONG="cubic" | |||
255 | # | 253 | # |
256 | # Generic Driver Options | 254 | # Generic Driver Options |
257 | # | 255 | # |
256 | CONFIG_UEVENT_HELPER_PATH="/sbin/hotplug" | ||
258 | CONFIG_STANDALONE=y | 257 | CONFIG_STANDALONE=y |
259 | CONFIG_PREVENT_FIRMWARE_BUILD=y | 258 | CONFIG_PREVENT_FIRMWARE_BUILD=y |
260 | # CONFIG_FW_LOADER is not set | 259 | # CONFIG_FW_LOADER is not set |
@@ -314,6 +313,7 @@ CONFIG_SCSI_SPI_ATTRS=y | |||
314 | # CONFIG_SCSI_FC_ATTRS is not set | 313 | # CONFIG_SCSI_FC_ATTRS is not set |
315 | # CONFIG_SCSI_ISCSI_ATTRS is not set | 314 | # CONFIG_SCSI_ISCSI_ATTRS is not set |
316 | # CONFIG_SCSI_SAS_LIBSAS is not set | 315 | # CONFIG_SCSI_SAS_LIBSAS is not set |
316 | # CONFIG_SCSI_SRP_ATTRS is not set | ||
317 | CONFIG_SCSI_LOWLEVEL=y | 317 | CONFIG_SCSI_LOWLEVEL=y |
318 | # CONFIG_ISCSI_TCP is not set | 318 | # CONFIG_ISCSI_TCP is not set |
319 | # CONFIG_SCSI_DEBUG is not set | 319 | # CONFIG_SCSI_DEBUG is not set |
@@ -326,11 +326,18 @@ CONFIG_NETDEVICES=y | |||
326 | # CONFIG_MACVLAN is not set | 326 | # CONFIG_MACVLAN is not set |
327 | # CONFIG_EQUALIZER is not set | 327 | # CONFIG_EQUALIZER is not set |
328 | # CONFIG_TUN is not set | 328 | # CONFIG_TUN is not set |
329 | # CONFIG_VETH is not set | ||
329 | # CONFIG_PHYLIB is not set | 330 | # CONFIG_PHYLIB is not set |
330 | CONFIG_NET_ETHERNET=y | 331 | CONFIG_NET_ETHERNET=y |
331 | # CONFIG_MII is not set | 332 | # CONFIG_MII is not set |
332 | # CONFIG_STNIC is not set | 333 | # CONFIG_STNIC is not set |
333 | # CONFIG_SMC91X is not set | 334 | # CONFIG_SMC91X is not set |
335 | # CONFIG_SMC911X is not set | ||
336 | # CONFIG_IBM_NEW_EMAC_ZMII is not set | ||
337 | # CONFIG_IBM_NEW_EMAC_RGMII is not set | ||
338 | # CONFIG_IBM_NEW_EMAC_TAH is not set | ||
339 | # CONFIG_IBM_NEW_EMAC_EMAC4 is not set | ||
340 | # CONFIG_B44 is not set | ||
334 | CONFIG_NETDEV_1000=y | 341 | CONFIG_NETDEV_1000=y |
335 | CONFIG_NETDEV_10000=y | 342 | CONFIG_NETDEV_10000=y |
336 | 343 | ||
@@ -364,7 +371,6 @@ CONFIG_INPUT_MOUSEDEV=y | |||
364 | CONFIG_INPUT_MOUSEDEV_SCREEN_X=1024 | 371 | CONFIG_INPUT_MOUSEDEV_SCREEN_X=1024 |
365 | CONFIG_INPUT_MOUSEDEV_SCREEN_Y=768 | 372 | CONFIG_INPUT_MOUSEDEV_SCREEN_Y=768 |
366 | # CONFIG_INPUT_JOYDEV is not set | 373 | # CONFIG_INPUT_JOYDEV is not set |
367 | # CONFIG_INPUT_TSDEV is not set | ||
368 | # CONFIG_INPUT_EVDEV is not set | 374 | # CONFIG_INPUT_EVDEV is not set |
369 | # CONFIG_INPUT_EVBUG is not set | 375 | # CONFIG_INPUT_EVBUG is not set |
370 | 376 | ||
@@ -410,13 +416,6 @@ CONFIG_UNIX98_PTYS=y | |||
410 | CONFIG_LEGACY_PTYS=y | 416 | CONFIG_LEGACY_PTYS=y |
411 | CONFIG_LEGACY_PTY_COUNT=256 | 417 | CONFIG_LEGACY_PTY_COUNT=256 |
412 | # CONFIG_IPMI_HANDLER is not set | 418 | # CONFIG_IPMI_HANDLER is not set |
413 | CONFIG_WATCHDOG=y | ||
414 | # CONFIG_WATCHDOG_NOWAYOUT is not set | ||
415 | |||
416 | # | ||
417 | # Watchdog Device Drivers | ||
418 | # | ||
419 | # CONFIG_SOFT_WATCHDOG is not set | ||
420 | CONFIG_HW_RANDOM=y | 419 | CONFIG_HW_RANDOM=y |
421 | # CONFIG_R3964 is not set | 420 | # CONFIG_R3964 is not set |
422 | # CONFIG_RAW_DRIVER is not set | 421 | # CONFIG_RAW_DRIVER is not set |
@@ -432,9 +431,8 @@ CONFIG_HW_RANDOM=y | |||
432 | # CONFIG_POWER_SUPPLY is not set | 431 | # CONFIG_POWER_SUPPLY is not set |
433 | CONFIG_HWMON=y | 432 | CONFIG_HWMON=y |
434 | # CONFIG_HWMON_VID is not set | 433 | # CONFIG_HWMON_VID is not set |
435 | # CONFIG_SENSORS_ABITUGURU is not set | ||
436 | # CONFIG_SENSORS_ABITUGURU3 is not set | ||
437 | # CONFIG_SENSORS_F71805F is not set | 434 | # CONFIG_SENSORS_F71805F is not set |
435 | # CONFIG_SENSORS_F71882FG is not set | ||
438 | # CONFIG_SENSORS_IT87 is not set | 436 | # CONFIG_SENSORS_IT87 is not set |
439 | # CONFIG_SENSORS_PC87360 is not set | 437 | # CONFIG_SENSORS_PC87360 is not set |
440 | # CONFIG_SENSORS_PC87427 is not set | 438 | # CONFIG_SENSORS_PC87427 is not set |
@@ -444,6 +442,19 @@ CONFIG_HWMON=y | |||
444 | # CONFIG_SENSORS_W83627HF is not set | 442 | # CONFIG_SENSORS_W83627HF is not set |
445 | # CONFIG_SENSORS_W83627EHF is not set | 443 | # CONFIG_SENSORS_W83627EHF is not set |
446 | # CONFIG_HWMON_DEBUG_CHIP is not set | 444 | # CONFIG_HWMON_DEBUG_CHIP is not set |
445 | CONFIG_WATCHDOG=y | ||
446 | # CONFIG_WATCHDOG_NOWAYOUT is not set | ||
447 | |||
448 | # | ||
449 | # Watchdog Device Drivers | ||
450 | # | ||
451 | # CONFIG_SOFT_WATCHDOG is not set | ||
452 | |||
453 | # | ||
454 | # Sonics Silicon Backplane | ||
455 | # | ||
456 | CONFIG_SSB_POSSIBLE=y | ||
457 | # CONFIG_SSB is not set | ||
447 | 458 | ||
448 | # | 459 | # |
449 | # Multifunction device drivers | 460 | # Multifunction device drivers |
@@ -460,12 +471,6 @@ CONFIG_DAB=y | |||
460 | # | 471 | # |
461 | # Graphics support | 472 | # Graphics support |
462 | # | 473 | # |
463 | # CONFIG_BACKLIGHT_LCD_SUPPORT is not set | ||
464 | |||
465 | # | ||
466 | # Display device support | ||
467 | # | ||
468 | # CONFIG_DISPLAY_SUPPORT is not set | ||
469 | # CONFIG_VGASTATE is not set | 474 | # CONFIG_VGASTATE is not set |
470 | CONFIG_VIDEO_OUTPUT_CONTROL=y | 475 | CONFIG_VIDEO_OUTPUT_CONTROL=y |
471 | CONFIG_FB=y | 476 | CONFIG_FB=y |
@@ -474,6 +479,7 @@ CONFIG_FIRMWARE_EDID=y | |||
474 | # CONFIG_FB_CFB_FILLRECT is not set | 479 | # CONFIG_FB_CFB_FILLRECT is not set |
475 | # CONFIG_FB_CFB_COPYAREA is not set | 480 | # CONFIG_FB_CFB_COPYAREA is not set |
476 | # CONFIG_FB_CFB_IMAGEBLIT is not set | 481 | # CONFIG_FB_CFB_IMAGEBLIT is not set |
482 | # CONFIG_FB_CFB_REV_PIXELS_IN_BYTE is not set | ||
477 | # CONFIG_FB_SYS_FILLRECT is not set | 483 | # CONFIG_FB_SYS_FILLRECT is not set |
478 | # CONFIG_FB_SYS_COPYAREA is not set | 484 | # CONFIG_FB_SYS_COPYAREA is not set |
479 | # CONFIG_FB_SYS_IMAGEBLIT is not set | 485 | # CONFIG_FB_SYS_IMAGEBLIT is not set |
@@ -490,6 +496,12 @@ CONFIG_FB_MODE_HELPERS=y | |||
490 | # | 496 | # |
491 | # CONFIG_FB_S1D13XXX is not set | 497 | # CONFIG_FB_S1D13XXX is not set |
492 | # CONFIG_FB_VIRTUAL is not set | 498 | # CONFIG_FB_VIRTUAL is not set |
499 | # CONFIG_BACKLIGHT_LCD_SUPPORT is not set | ||
500 | |||
501 | # | ||
502 | # Display device support | ||
503 | # | ||
504 | # CONFIG_DISPLAY_SUPPORT is not set | ||
493 | 505 | ||
494 | # | 506 | # |
495 | # Console display driver support | 507 | # Console display driver support |
@@ -524,6 +536,7 @@ CONFIG_LOGO_SUPERH_CLUT224=y | |||
524 | CONFIG_HID_SUPPORT=y | 536 | CONFIG_HID_SUPPORT=y |
525 | CONFIG_HID=y | 537 | CONFIG_HID=y |
526 | # CONFIG_HID_DEBUG is not set | 538 | # CONFIG_HID_DEBUG is not set |
539 | # CONFIG_HIDRAW is not set | ||
527 | CONFIG_USB_SUPPORT=y | 540 | CONFIG_USB_SUPPORT=y |
528 | CONFIG_USB_ARCH_HAS_HCD=y | 541 | CONFIG_USB_ARCH_HAS_HCD=y |
529 | # CONFIG_USB_ARCH_HAS_OHCI is not set | 542 | # CONFIG_USB_ARCH_HAS_OHCI is not set |
@@ -543,19 +556,6 @@ CONFIG_USB_ARCH_HAS_HCD=y | |||
543 | # CONFIG_RTC_CLASS is not set | 556 | # CONFIG_RTC_CLASS is not set |
544 | 557 | ||
545 | # | 558 | # |
546 | # DMA Engine support | ||
547 | # | ||
548 | # CONFIG_DMA_ENGINE is not set | ||
549 | |||
550 | # | ||
551 | # DMA Clients | ||
552 | # | ||
553 | |||
554 | # | ||
555 | # DMA Devices | ||
556 | # | ||
557 | |||
558 | # | ||
559 | # Userspace I/O | 559 | # Userspace I/O |
560 | # | 560 | # |
561 | # CONFIG_UIO is not set | 561 | # CONFIG_UIO is not set |
@@ -614,7 +614,6 @@ CONFIG_TMPFS=y | |||
614 | # CONFIG_TMPFS_POSIX_ACL is not set | 614 | # CONFIG_TMPFS_POSIX_ACL is not set |
615 | CONFIG_HUGETLBFS=y | 615 | CONFIG_HUGETLBFS=y |
616 | CONFIG_HUGETLB_PAGE=y | 616 | CONFIG_HUGETLB_PAGE=y |
617 | CONFIG_RAMFS=y | ||
618 | # CONFIG_CONFIGFS_FS is not set | 617 | # CONFIG_CONFIGFS_FS is not set |
619 | 618 | ||
620 | # | 619 | # |
@@ -633,10 +632,7 @@ CONFIG_RAMFS=y | |||
633 | # CONFIG_QNX4FS_FS is not set | 632 | # CONFIG_QNX4FS_FS is not set |
634 | # CONFIG_SYSV_FS is not set | 633 | # CONFIG_SYSV_FS is not set |
635 | # CONFIG_UFS_FS is not set | 634 | # CONFIG_UFS_FS is not set |
636 | 635 | CONFIG_NETWORK_FILESYSTEMS=y | |
637 | # | ||
638 | # Network File Systems | ||
639 | # | ||
640 | CONFIG_NFS_FS=y | 636 | CONFIG_NFS_FS=y |
641 | CONFIG_NFS_V3=y | 637 | CONFIG_NFS_V3=y |
642 | # CONFIG_NFS_V3_ACL is not set | 638 | # CONFIG_NFS_V3_ACL is not set |
@@ -678,26 +674,17 @@ CONFIG_MSDOS_PARTITION=y | |||
678 | # CONFIG_KARMA_PARTITION is not set | 674 | # CONFIG_KARMA_PARTITION is not set |
679 | # CONFIG_EFI_PARTITION is not set | 675 | # CONFIG_EFI_PARTITION is not set |
680 | # CONFIG_SYSV68_PARTITION is not set | 676 | # CONFIG_SYSV68_PARTITION is not set |
681 | |||
682 | # | ||
683 | # Native Language Support | ||
684 | # | ||
685 | # CONFIG_NLS is not set | 677 | # CONFIG_NLS is not set |
686 | |||
687 | # | ||
688 | # Distributed Lock Manager | ||
689 | # | ||
690 | # CONFIG_DLM is not set | 678 | # CONFIG_DLM is not set |
691 | 679 | CONFIG_INSTRUMENTATION=y | |
692 | # | ||
693 | # Profiling support | ||
694 | # | ||
695 | # CONFIG_PROFILING is not set | 680 | # CONFIG_PROFILING is not set |
681 | # CONFIG_MARKERS is not set | ||
696 | 682 | ||
697 | # | 683 | # |
698 | # Kernel hacking | 684 | # Kernel hacking |
699 | # | 685 | # |
700 | # CONFIG_PRINTK_TIME is not set | 686 | # CONFIG_PRINTK_TIME is not set |
687 | CONFIG_ENABLE_WARN_DEPRECATED=y | ||
701 | CONFIG_ENABLE_MUST_CHECK=y | 688 | CONFIG_ENABLE_MUST_CHECK=y |
702 | CONFIG_MAGIC_SYSRQ=y | 689 | CONFIG_MAGIC_SYSRQ=y |
703 | # CONFIG_UNUSED_SYMBOLS is not set | 690 | # CONFIG_UNUSED_SYMBOLS is not set |
@@ -721,16 +708,17 @@ CONFIG_DEBUG_BUGVERBOSE=y | |||
721 | # CONFIG_DEBUG_INFO is not set | 708 | # CONFIG_DEBUG_INFO is not set |
722 | # CONFIG_DEBUG_VM is not set | 709 | # CONFIG_DEBUG_VM is not set |
723 | # CONFIG_DEBUG_LIST is not set | 710 | # CONFIG_DEBUG_LIST is not set |
711 | # CONFIG_DEBUG_SG is not set | ||
724 | CONFIG_FRAME_POINTER=y | 712 | CONFIG_FRAME_POINTER=y |
725 | CONFIG_FORCED_INLINING=y | 713 | CONFIG_FORCED_INLINING=y |
714 | # CONFIG_BOOT_PRINTK_DELAY is not set | ||
726 | # CONFIG_FAULT_INJECTION is not set | 715 | # CONFIG_FAULT_INJECTION is not set |
716 | # CONFIG_SAMPLES is not set | ||
727 | # CONFIG_EARLY_PRINTK is not set | 717 | # CONFIG_EARLY_PRINTK is not set |
728 | # CONFIG_DEBUG_KERNEL_WITH_GDB_STUB is not set | ||
729 | CONFIG_SH64_PROC_TLB=y | 718 | CONFIG_SH64_PROC_TLB=y |
730 | CONFIG_SH64_PROC_ASIDS=y | 719 | CONFIG_SH64_PROC_ASIDS=y |
731 | CONFIG_SH64_SR_WATCH=y | 720 | CONFIG_SH64_SR_WATCH=y |
732 | # CONFIG_POOR_MANS_STRACE is not set | 721 | # CONFIG_POOR_MANS_STRACE is not set |
733 | # CONFIG_SH_ALPHANUMERIC is not set | ||
734 | # CONFIG_SH_NO_BSS_INIT is not set | 722 | # CONFIG_SH_NO_BSS_INIT is not set |
735 | 723 | ||
736 | # | 724 | # |
@@ -738,6 +726,7 @@ CONFIG_SH64_SR_WATCH=y | |||
738 | # | 726 | # |
739 | # CONFIG_KEYS is not set | 727 | # CONFIG_KEYS is not set |
740 | # CONFIG_SECURITY is not set | 728 | # CONFIG_SECURITY is not set |
729 | # CONFIG_SECURITY_FILE_CAPABILITIES is not set | ||
741 | # CONFIG_CRYPTO is not set | 730 | # CONFIG_CRYPTO is not set |
742 | 731 | ||
743 | # | 732 | # |
diff --git a/arch/sh64/configs/sim_defconfig b/arch/sh64/configs/sim_defconfig index f83bae659dc3..18476cc522c3 100644 --- a/arch/sh64/configs/sim_defconfig +++ b/arch/sh64/configs/sim_defconfig | |||
@@ -1,7 +1,7 @@ | |||
1 | # | 1 | # |
2 | # Automatically generated make config: don't edit | 2 | # Automatically generated make config: don't edit |
3 | # Linux kernel version: 2.6.23-rc8 | 3 | # Linux kernel version: 2.6.24-rc1 |
4 | # Mon Oct 1 17:50:35 2007 | 4 | # Fri Nov 2 14:36:08 2007 |
5 | # | 5 | # |
6 | CONFIG_SUPERH=y | 6 | CONFIG_SUPERH=y |
7 | CONFIG_SUPERH64=y | 7 | CONFIG_SUPERH64=y |
@@ -33,6 +33,10 @@ CONFIG_SWAP=y | |||
33 | # CONFIG_USER_NS is not set | 33 | # CONFIG_USER_NS is not set |
34 | # CONFIG_IKCONFIG is not set | 34 | # CONFIG_IKCONFIG is not set |
35 | CONFIG_LOG_BUF_SHIFT=14 | 35 | CONFIG_LOG_BUF_SHIFT=14 |
36 | # CONFIG_CGROUPS is not set | ||
37 | CONFIG_FAIR_GROUP_SCHED=y | ||
38 | CONFIG_FAIR_USER_SCHED=y | ||
39 | # CONFIG_FAIR_CGROUP_SCHED is not set | ||
36 | CONFIG_SYSFS_DEPRECATED=y | 40 | CONFIG_SYSFS_DEPRECATED=y |
37 | # CONFIG_RELAY is not set | 41 | # CONFIG_RELAY is not set |
38 | # CONFIG_BLK_DEV_INITRD is not set | 42 | # CONFIG_BLK_DEV_INITRD is not set |
@@ -138,6 +142,7 @@ CONFIG_FLATMEM_MANUAL=y | |||
138 | CONFIG_FLATMEM=y | 142 | CONFIG_FLATMEM=y |
139 | CONFIG_FLAT_NODE_MEM_MAP=y | 143 | CONFIG_FLAT_NODE_MEM_MAP=y |
140 | # CONFIG_SPARSEMEM_STATIC is not set | 144 | # CONFIG_SPARSEMEM_STATIC is not set |
145 | # CONFIG_SPARSEMEM_VMEMMAP_ENABLE is not set | ||
141 | CONFIG_SPLIT_PTLOCK_CPUS=4 | 146 | CONFIG_SPLIT_PTLOCK_CPUS=4 |
142 | # CONFIG_RESOURCES_64BIT is not set | 147 | # CONFIG_RESOURCES_64BIT is not set |
143 | CONFIG_ZONE_DMA_FLAG=0 | 148 | CONFIG_ZONE_DMA_FLAG=0 |
@@ -147,10 +152,6 @@ CONFIG_NR_QUICK=1 | |||
147 | # Bus options (PCI, PCMCIA, EISA, MCA, ISA) | 152 | # Bus options (PCI, PCMCIA, EISA, MCA, ISA) |
148 | # | 153 | # |
149 | # CONFIG_ARCH_SUPPORTS_MSI is not set | 154 | # CONFIG_ARCH_SUPPORTS_MSI is not set |
150 | |||
151 | # | ||
152 | # PCCARD (PCMCIA/CardBus) support | ||
153 | # | ||
154 | # CONFIG_PCCARD is not set | 155 | # CONFIG_PCCARD is not set |
155 | 156 | ||
156 | # | 157 | # |
@@ -171,6 +172,7 @@ CONFIG_BINFMT_ELF=y | |||
171 | # | 172 | # |
172 | # Generic Driver Options | 173 | # Generic Driver Options |
173 | # | 174 | # |
175 | CONFIG_UEVENT_HELPER_PATH="/sbin/hotplug" | ||
174 | CONFIG_STANDALONE=y | 176 | CONFIG_STANDALONE=y |
175 | CONFIG_PREVENT_FIRMWARE_BUILD=y | 177 | CONFIG_PREVENT_FIRMWARE_BUILD=y |
176 | # CONFIG_FW_LOADER is not set | 178 | # CONFIG_FW_LOADER is not set |
@@ -217,6 +219,7 @@ CONFIG_SCSI_MULTI_LUN=y | |||
217 | CONFIG_SCSI_SPI_ATTRS=y | 219 | CONFIG_SCSI_SPI_ATTRS=y |
218 | # CONFIG_SCSI_FC_ATTRS is not set | 220 | # CONFIG_SCSI_FC_ATTRS is not set |
219 | # CONFIG_SCSI_SAS_LIBSAS is not set | 221 | # CONFIG_SCSI_SAS_LIBSAS is not set |
222 | # CONFIG_SCSI_SRP_ATTRS is not set | ||
220 | CONFIG_SCSI_LOWLEVEL=y | 223 | CONFIG_SCSI_LOWLEVEL=y |
221 | # CONFIG_SCSI_DEBUG is not set | 224 | # CONFIG_SCSI_DEBUG is not set |
222 | # CONFIG_ATA is not set | 225 | # CONFIG_ATA is not set |
@@ -238,7 +241,6 @@ CONFIG_INPUT_MOUSEDEV=y | |||
238 | CONFIG_INPUT_MOUSEDEV_SCREEN_X=1024 | 241 | CONFIG_INPUT_MOUSEDEV_SCREEN_X=1024 |
239 | CONFIG_INPUT_MOUSEDEV_SCREEN_Y=768 | 242 | CONFIG_INPUT_MOUSEDEV_SCREEN_Y=768 |
240 | # CONFIG_INPUT_JOYDEV is not set | 243 | # CONFIG_INPUT_JOYDEV is not set |
241 | # CONFIG_INPUT_TSDEV is not set | ||
242 | # CONFIG_INPUT_EVDEV is not set | 244 | # CONFIG_INPUT_EVDEV is not set |
243 | # CONFIG_INPUT_EVBUG is not set | 245 | # CONFIG_INPUT_EVBUG is not set |
244 | 246 | ||
@@ -283,7 +285,6 @@ CONFIG_SERIAL_CORE_CONSOLE=y | |||
283 | CONFIG_UNIX98_PTYS=y | 285 | CONFIG_UNIX98_PTYS=y |
284 | # CONFIG_LEGACY_PTYS is not set | 286 | # CONFIG_LEGACY_PTYS is not set |
285 | # CONFIG_IPMI_HANDLER is not set | 287 | # CONFIG_IPMI_HANDLER is not set |
286 | # CONFIG_WATCHDOG is not set | ||
287 | # CONFIG_HW_RANDOM is not set | 288 | # CONFIG_HW_RANDOM is not set |
288 | # CONFIG_R3964 is not set | 289 | # CONFIG_R3964 is not set |
289 | # CONFIG_RAW_DRIVER is not set | 290 | # CONFIG_RAW_DRIVER is not set |
@@ -298,6 +299,13 @@ CONFIG_UNIX98_PTYS=y | |||
298 | # CONFIG_W1 is not set | 299 | # CONFIG_W1 is not set |
299 | # CONFIG_POWER_SUPPLY is not set | 300 | # CONFIG_POWER_SUPPLY is not set |
300 | # CONFIG_HWMON is not set | 301 | # CONFIG_HWMON is not set |
302 | # CONFIG_WATCHDOG is not set | ||
303 | |||
304 | # | ||
305 | # Sonics Silicon Backplane | ||
306 | # | ||
307 | CONFIG_SSB_POSSIBLE=y | ||
308 | # CONFIG_SSB is not set | ||
301 | 309 | ||
302 | # | 310 | # |
303 | # Multifunction device drivers | 311 | # Multifunction device drivers |
@@ -313,12 +321,6 @@ CONFIG_DAB=y | |||
313 | # | 321 | # |
314 | # Graphics support | 322 | # Graphics support |
315 | # | 323 | # |
316 | # CONFIG_BACKLIGHT_LCD_SUPPORT is not set | ||
317 | |||
318 | # | ||
319 | # Display device support | ||
320 | # | ||
321 | # CONFIG_DISPLAY_SUPPORT is not set | ||
322 | # CONFIG_VGASTATE is not set | 324 | # CONFIG_VGASTATE is not set |
323 | CONFIG_VIDEO_OUTPUT_CONTROL=y | 325 | CONFIG_VIDEO_OUTPUT_CONTROL=y |
324 | CONFIG_FB=y | 326 | CONFIG_FB=y |
@@ -327,6 +329,7 @@ CONFIG_FIRMWARE_EDID=y | |||
327 | # CONFIG_FB_CFB_FILLRECT is not set | 329 | # CONFIG_FB_CFB_FILLRECT is not set |
328 | # CONFIG_FB_CFB_COPYAREA is not set | 330 | # CONFIG_FB_CFB_COPYAREA is not set |
329 | # CONFIG_FB_CFB_IMAGEBLIT is not set | 331 | # CONFIG_FB_CFB_IMAGEBLIT is not set |
332 | # CONFIG_FB_CFB_REV_PIXELS_IN_BYTE is not set | ||
330 | # CONFIG_FB_SYS_FILLRECT is not set | 333 | # CONFIG_FB_SYS_FILLRECT is not set |
331 | # CONFIG_FB_SYS_COPYAREA is not set | 334 | # CONFIG_FB_SYS_COPYAREA is not set |
332 | # CONFIG_FB_SYS_IMAGEBLIT is not set | 335 | # CONFIG_FB_SYS_IMAGEBLIT is not set |
@@ -343,6 +346,12 @@ CONFIG_FB_MODE_HELPERS=y | |||
343 | # | 346 | # |
344 | # CONFIG_FB_S1D13XXX is not set | 347 | # CONFIG_FB_S1D13XXX is not set |
345 | # CONFIG_FB_VIRTUAL is not set | 348 | # CONFIG_FB_VIRTUAL is not set |
349 | # CONFIG_BACKLIGHT_LCD_SUPPORT is not set | ||
350 | |||
351 | # | ||
352 | # Display device support | ||
353 | # | ||
354 | # CONFIG_DISPLAY_SUPPORT is not set | ||
346 | 355 | ||
347 | # | 356 | # |
348 | # Console display driver support | 357 | # Console display driver support |
@@ -381,19 +390,6 @@ CONFIG_LOGO_SUPERH_CLUT224=y | |||
381 | # CONFIG_RTC_CLASS is not set | 390 | # CONFIG_RTC_CLASS is not set |
382 | 391 | ||
383 | # | 392 | # |
384 | # DMA Engine support | ||
385 | # | ||
386 | # CONFIG_DMA_ENGINE is not set | ||
387 | |||
388 | # | ||
389 | # DMA Clients | ||
390 | # | ||
391 | |||
392 | # | ||
393 | # DMA Devices | ||
394 | # | ||
395 | |||
396 | # | ||
397 | # Userspace I/O | 393 | # Userspace I/O |
398 | # | 394 | # |
399 | # CONFIG_UIO is not set | 395 | # CONFIG_UIO is not set |
@@ -451,7 +447,6 @@ CONFIG_TMPFS=y | |||
451 | # CONFIG_TMPFS_POSIX_ACL is not set | 447 | # CONFIG_TMPFS_POSIX_ACL is not set |
452 | CONFIG_HUGETLBFS=y | 448 | CONFIG_HUGETLBFS=y |
453 | CONFIG_HUGETLB_PAGE=y | 449 | CONFIG_HUGETLB_PAGE=y |
454 | CONFIG_RAMFS=y | ||
455 | # CONFIG_CONFIGFS_FS is not set | 450 | # CONFIG_CONFIGFS_FS is not set |
456 | 451 | ||
457 | # | 452 | # |
@@ -492,22 +487,17 @@ CONFIG_MSDOS_PARTITION=y | |||
492 | # CONFIG_KARMA_PARTITION is not set | 487 | # CONFIG_KARMA_PARTITION is not set |
493 | # CONFIG_EFI_PARTITION is not set | 488 | # CONFIG_EFI_PARTITION is not set |
494 | # CONFIG_SYSV68_PARTITION is not set | 489 | # CONFIG_SYSV68_PARTITION is not set |
495 | |||
496 | # | ||
497 | # Native Language Support | ||
498 | # | ||
499 | # CONFIG_NLS is not set | 490 | # CONFIG_NLS is not set |
500 | 491 | CONFIG_INSTRUMENTATION=y | |
501 | # | ||
502 | # Profiling support | ||
503 | # | ||
504 | CONFIG_PROFILING=y | 492 | CONFIG_PROFILING=y |
505 | # CONFIG_OPROFILE is not set | 493 | # CONFIG_OPROFILE is not set |
494 | # CONFIG_MARKERS is not set | ||
506 | 495 | ||
507 | # | 496 | # |
508 | # Kernel hacking | 497 | # Kernel hacking |
509 | # | 498 | # |
510 | # CONFIG_PRINTK_TIME is not set | 499 | # CONFIG_PRINTK_TIME is not set |
500 | CONFIG_ENABLE_WARN_DEPRECATED=y | ||
511 | CONFIG_ENABLE_MUST_CHECK=y | 501 | CONFIG_ENABLE_MUST_CHECK=y |
512 | CONFIG_MAGIC_SYSRQ=y | 502 | CONFIG_MAGIC_SYSRQ=y |
513 | # CONFIG_UNUSED_SYMBOLS is not set | 503 | # CONFIG_UNUSED_SYMBOLS is not set |
@@ -531,16 +521,17 @@ CONFIG_DEBUG_BUGVERBOSE=y | |||
531 | # CONFIG_DEBUG_INFO is not set | 521 | # CONFIG_DEBUG_INFO is not set |
532 | # CONFIG_DEBUG_VM is not set | 522 | # CONFIG_DEBUG_VM is not set |
533 | # CONFIG_DEBUG_LIST is not set | 523 | # CONFIG_DEBUG_LIST is not set |
524 | # CONFIG_DEBUG_SG is not set | ||
534 | CONFIG_FRAME_POINTER=y | 525 | CONFIG_FRAME_POINTER=y |
535 | CONFIG_FORCED_INLINING=y | 526 | CONFIG_FORCED_INLINING=y |
527 | # CONFIG_BOOT_PRINTK_DELAY is not set | ||
536 | # CONFIG_FAULT_INJECTION is not set | 528 | # CONFIG_FAULT_INJECTION is not set |
529 | # CONFIG_SAMPLES is not set | ||
537 | # CONFIG_EARLY_PRINTK is not set | 530 | # CONFIG_EARLY_PRINTK is not set |
538 | # CONFIG_DEBUG_KERNEL_WITH_GDB_STUB is not set | ||
539 | CONFIG_SH64_PROC_TLB=y | 531 | CONFIG_SH64_PROC_TLB=y |
540 | CONFIG_SH64_PROC_ASIDS=y | 532 | CONFIG_SH64_PROC_ASIDS=y |
541 | CONFIG_SH64_SR_WATCH=y | 533 | CONFIG_SH64_SR_WATCH=y |
542 | # CONFIG_POOR_MANS_STRACE is not set | 534 | # CONFIG_POOR_MANS_STRACE is not set |
543 | # CONFIG_SH_ALPHANUMERIC is not set | ||
544 | CONFIG_SH_NO_BSS_INIT=y | 535 | CONFIG_SH_NO_BSS_INIT=y |
545 | 536 | ||
546 | # | 537 | # |
@@ -548,6 +539,7 @@ CONFIG_SH_NO_BSS_INIT=y | |||
548 | # | 539 | # |
549 | # CONFIG_KEYS is not set | 540 | # CONFIG_KEYS is not set |
550 | # CONFIG_SECURITY is not set | 541 | # CONFIG_SECURITY is not set |
542 | # CONFIG_SECURITY_FILE_CAPABILITIES is not set | ||
551 | # CONFIG_CRYPTO is not set | 543 | # CONFIG_CRYPTO is not set |
552 | 544 | ||
553 | # | 545 | # |
diff --git a/arch/sparc/kernel/pcic.c b/arch/sparc/kernel/pcic.c index f2eae457fc9a..f2d432edc92d 100644 --- a/arch/sparc/kernel/pcic.c +++ b/arch/sparc/kernel/pcic.c | |||
@@ -753,7 +753,7 @@ void __init pci_time_init(void) | |||
753 | local_irq_enable(); | 753 | local_irq_enable(); |
754 | } | 754 | } |
755 | 755 | ||
756 | static __inline__ unsigned long do_gettimeoffset(void) | 756 | static inline unsigned long do_gettimeoffset(void) |
757 | { | 757 | { |
758 | /* | 758 | /* |
759 | * We divide all by 100 | 759 | * We divide all by 100 |
diff --git a/arch/sparc/kernel/process.c b/arch/sparc/kernel/process.c index 33f7a3ddb104..77460e316a03 100644 --- a/arch/sparc/kernel/process.c +++ b/arch/sparc/kernel/process.c | |||
@@ -1,7 +1,6 @@ | |||
1 | /* $Id: process.c,v 1.161 2002/01/23 11:27:32 davem Exp $ | 1 | /* linux/arch/sparc/kernel/process.c |
2 | * linux/arch/sparc/kernel/process.c | ||
3 | * | 2 | * |
4 | * Copyright (C) 1995 David S. Miller (davem@caip.rutgers.edu) | 3 | * Copyright (C) 1995 David S. Miller (davem@davemloft.net) |
5 | * Copyright (C) 1996 Eddie C. Dost (ecd@skynet.be) | 4 | * Copyright (C) 1996 Eddie C. Dost (ecd@skynet.be) |
6 | */ | 5 | */ |
7 | 6 | ||
@@ -397,7 +396,7 @@ void flush_thread(void) | |||
397 | } | 396 | } |
398 | } | 397 | } |
399 | 398 | ||
400 | static __inline__ struct sparc_stackf __user * | 399 | static inline struct sparc_stackf __user * |
401 | clone_stackframe(struct sparc_stackf __user *dst, | 400 | clone_stackframe(struct sparc_stackf __user *dst, |
402 | struct sparc_stackf __user *src) | 401 | struct sparc_stackf __user *src) |
403 | { | 402 | { |
diff --git a/arch/sparc/kernel/time.c b/arch/sparc/kernel/time.c index 4bf78a5e8e0f..45cb7c5286d7 100644 --- a/arch/sparc/kernel/time.c +++ b/arch/sparc/kernel/time.c | |||
@@ -1,7 +1,6 @@ | |||
1 | /* $Id: time.c,v 1.60 2002/01/23 14:33:55 davem Exp $ | 1 | /* linux/arch/sparc/kernel/time.c |
2 | * linux/arch/sparc/kernel/time.c | ||
3 | * | 2 | * |
4 | * Copyright (C) 1995 David S. Miller (davem@caip.rutgers.edu) | 3 | * Copyright (C) 1995 David S. Miller (davem@davemloft.net) |
5 | * Copyright (C) 1996 Thomas K. Dyas (tdyas@eden.rutgers.edu) | 4 | * Copyright (C) 1996 Thomas K. Dyas (tdyas@eden.rutgers.edu) |
6 | * | 5 | * |
7 | * Chris Davis (cdavis@cois.on.ca) 03/27/1998 | 6 | * Chris Davis (cdavis@cois.on.ca) 03/27/1998 |
@@ -210,7 +209,7 @@ static void __devinit kick_start_clock(void) | |||
210 | } | 209 | } |
211 | 210 | ||
212 | /* Return nonzero if the clock chip battery is low. */ | 211 | /* Return nonzero if the clock chip battery is low. */ |
213 | static __inline__ int has_low_battery(void) | 212 | static inline int has_low_battery(void) |
214 | { | 213 | { |
215 | struct mostek48t02 *regs = (struct mostek48t02 *)mstk48t02_regs; | 214 | struct mostek48t02 *regs = (struct mostek48t02 *)mstk48t02_regs; |
216 | unsigned char data1, data2; | 215 | unsigned char data1, data2; |
@@ -252,7 +251,7 @@ static void __devinit mostek_set_system_time(void) | |||
252 | } | 251 | } |
253 | 252 | ||
254 | /* Probe for the real time clock chip on Sun4 */ | 253 | /* Probe for the real time clock chip on Sun4 */ |
255 | static __inline__ void sun4_clock_probe(void) | 254 | static inline void sun4_clock_probe(void) |
256 | { | 255 | { |
257 | #ifdef CONFIG_SUN4 | 256 | #ifdef CONFIG_SUN4 |
258 | int temp; | 257 | int temp; |
diff --git a/arch/sparc/mm/btfixup.c b/arch/sparc/mm/btfixup.c index ec4231c2855a..a312d127d47a 100644 --- a/arch/sparc/mm/btfixup.c +++ b/arch/sparc/mm/btfixup.c | |||
@@ -1,5 +1,4 @@ | |||
1 | /* $Id: btfixup.c,v 1.10 2000/05/09 17:40:13 davem Exp $ | 1 | /* btfixup.c: Boot time code fixup and relocator, so that |
2 | * btfixup.c: Boot time code fixup and relocator, so that | ||
3 | * we can get rid of most indirect calls to achieve single | 2 | * we can get rid of most indirect calls to achieve single |
4 | * image sun4c and srmmu kernel. | 3 | * image sun4c and srmmu kernel. |
5 | * | 4 | * |
@@ -69,7 +68,7 @@ static void __init set_addr(unsigned int *addr, unsigned int q1, int fmangled, u | |||
69 | } | 68 | } |
70 | } | 69 | } |
71 | #else | 70 | #else |
72 | static __inline__ void set_addr(unsigned int *addr, unsigned int q1, int fmangled, unsigned int value) | 71 | static inline void set_addr(unsigned int *addr, unsigned int q1, int fmangled, unsigned int value) |
73 | { | 72 | { |
74 | *addr = value; | 73 | *addr = value; |
75 | } | 74 | } |
diff --git a/arch/sparc/mm/io-unit.c b/arch/sparc/mm/io-unit.c index 1666087c5b80..b86dfce8eee4 100644 --- a/arch/sparc/mm/io-unit.c +++ b/arch/sparc/mm/io-unit.c | |||
@@ -144,7 +144,7 @@ static void iounit_get_scsi_sgl(struct scatterlist *sg, int sz, struct sbus_bus | |||
144 | spin_lock_irqsave(&iounit->lock, flags); | 144 | spin_lock_irqsave(&iounit->lock, flags); |
145 | while (sz != 0) { | 145 | while (sz != 0) { |
146 | --sz; | 146 | --sz; |
147 | sg->dvma_address = iounit_get_area(iounit, sg_virt(sg), sg->length); | 147 | sg->dvma_address = iounit_get_area(iounit, (unsigned long) sg_virt(sg), sg->length); |
148 | sg->dvma_length = sg->length; | 148 | sg->dvma_length = sg->length; |
149 | sg = sg_next(sg); | 149 | sg = sg_next(sg); |
150 | } | 150 | } |
diff --git a/arch/sparc/mm/sun4c.c b/arch/sparc/mm/sun4c.c index a2cc141291c7..0729305f2f59 100644 --- a/arch/sparc/mm/sun4c.c +++ b/arch/sparc/mm/sun4c.c | |||
@@ -1,7 +1,6 @@ | |||
1 | /* $Id: sun4c.c,v 1.212 2001/12/21 04:56:15 davem Exp $ | 1 | /* sun4c.c: Doing in software what should be done in hardware. |
2 | * sun4c.c: Doing in software what should be done in hardware. | ||
3 | * | 2 | * |
4 | * Copyright (C) 1996 David S. Miller (davem@caip.rutgers.edu) | 3 | * Copyright (C) 1996 David S. Miller (davem@davemloft.net) |
5 | * Copyright (C) 1996 Eddie C. Dost (ecd@skynet.be) | 4 | * Copyright (C) 1996 Eddie C. Dost (ecd@skynet.be) |
6 | * Copyright (C) 1996 Andrew Tridgell (Andrew.Tridgell@anu.edu.au) | 5 | * Copyright (C) 1996 Andrew Tridgell (Andrew.Tridgell@anu.edu.au) |
7 | * Copyright (C) 1997-2000 Anton Blanchard (anton@samba.org) | 6 | * Copyright (C) 1997-2000 Anton Blanchard (anton@samba.org) |
@@ -719,7 +718,7 @@ static void add_ring(struct sun4c_mmu_ring *ring, | |||
719 | ring->num_entries++; | 718 | ring->num_entries++; |
720 | } | 719 | } |
721 | 720 | ||
722 | static __inline__ void add_lru(struct sun4c_mmu_entry *entry) | 721 | static inline void add_lru(struct sun4c_mmu_entry *entry) |
723 | { | 722 | { |
724 | struct sun4c_mmu_ring *ring = &sun4c_ulru_ring; | 723 | struct sun4c_mmu_ring *ring = &sun4c_ulru_ring; |
725 | struct sun4c_mmu_entry *head = &ring->ringhd; | 724 | struct sun4c_mmu_entry *head = &ring->ringhd; |
@@ -746,7 +745,7 @@ static void add_ring_ordered(struct sun4c_mmu_ring *ring, | |||
746 | add_lru(entry); | 745 | add_lru(entry); |
747 | } | 746 | } |
748 | 747 | ||
749 | static __inline__ void remove_ring(struct sun4c_mmu_ring *ring, | 748 | static inline void remove_ring(struct sun4c_mmu_ring *ring, |
750 | struct sun4c_mmu_entry *entry) | 749 | struct sun4c_mmu_entry *entry) |
751 | { | 750 | { |
752 | struct sun4c_mmu_entry *next = entry->next; | 751 | struct sun4c_mmu_entry *next = entry->next; |
@@ -1836,7 +1835,7 @@ static unsigned long sun4c_pte_to_pgoff(pte_t pte) | |||
1836 | } | 1835 | } |
1837 | 1836 | ||
1838 | 1837 | ||
1839 | static __inline__ unsigned long sun4c_pmd_page_v(pmd_t pmd) | 1838 | static inline unsigned long sun4c_pmd_page_v(pmd_t pmd) |
1840 | { | 1839 | { |
1841 | return (pmd_val(pmd) & PAGE_MASK); | 1840 | return (pmd_val(pmd) & PAGE_MASK); |
1842 | } | 1841 | } |
@@ -1922,7 +1921,7 @@ static void sun4c_free_pgd_fast(pgd_t *pgd) | |||
1922 | } | 1921 | } |
1923 | 1922 | ||
1924 | 1923 | ||
1925 | static __inline__ pte_t * | 1924 | static inline pte_t * |
1926 | sun4c_pte_alloc_one_fast(struct mm_struct *mm, unsigned long address) | 1925 | sun4c_pte_alloc_one_fast(struct mm_struct *mm, unsigned long address) |
1927 | { | 1926 | { |
1928 | unsigned long *ret; | 1927 | unsigned long *ret; |
@@ -1956,7 +1955,7 @@ static struct page *sun4c_pte_alloc_one(struct mm_struct *mm, unsigned long addr | |||
1956 | return virt_to_page(pte); | 1955 | return virt_to_page(pte); |
1957 | } | 1956 | } |
1958 | 1957 | ||
1959 | static __inline__ void sun4c_free_pte_fast(pte_t *pte) | 1958 | static inline void sun4c_free_pte_fast(pte_t *pte) |
1960 | { | 1959 | { |
1961 | *(unsigned long *)pte = (unsigned long) pte_quicklist; | 1960 | *(unsigned long *)pte = (unsigned long) pte_quicklist; |
1962 | pte_quicklist = (unsigned long *) pte; | 1961 | pte_quicklist = (unsigned long *) pte; |
diff --git a/arch/sparc64/Kconfig b/arch/sparc64/Kconfig index bd59ab0760b3..10b212a1f9f5 100644 --- a/arch/sparc64/Kconfig +++ b/arch/sparc64/Kconfig | |||
@@ -408,7 +408,7 @@ config SUNOS_EMUL | |||
408 | 408 | ||
409 | config SOLARIS_EMUL | 409 | config SOLARIS_EMUL |
410 | tristate "Solaris binary emulation (EXPERIMENTAL)" | 410 | tristate "Solaris binary emulation (EXPERIMENTAL)" |
411 | depends on SPARC32_COMPAT && EXPERIMENTAL | 411 | depends on SPARC32_COMPAT && NET && EXPERIMENTAL |
412 | help | 412 | help |
413 | This is experimental code which will enable you to run (many) | 413 | This is experimental code which will enable you to run (many) |
414 | Solaris binaries on your SPARC Linux machine. | 414 | Solaris binaries on your SPARC Linux machine. |
diff --git a/arch/sparc64/defconfig b/arch/sparc64/defconfig index e023d4b2fef4..22734ac08c8a 100644 --- a/arch/sparc64/defconfig +++ b/arch/sparc64/defconfig | |||
@@ -1,7 +1,7 @@ | |||
1 | # | 1 | # |
2 | # Automatically generated make config: don't edit | 2 | # Automatically generated make config: don't edit |
3 | # Linux kernel version: 2.6.23 | 3 | # Linux kernel version: 2.6.24-rc1 |
4 | # Sun Oct 21 19:57:44 2007 | 4 | # Wed Oct 31 15:36:47 2007 |
5 | # | 5 | # |
6 | CONFIG_SPARC=y | 6 | CONFIG_SPARC=y |
7 | CONFIG_SPARC64=y | 7 | CONFIG_SPARC64=y |
@@ -19,6 +19,7 @@ CONFIG_ARCH_MAY_HAVE_PC_FDC=y | |||
19 | CONFIG_AUDIT_ARCH=y | 19 | CONFIG_AUDIT_ARCH=y |
20 | CONFIG_ARCH_NO_VIRT_TO_BUS=y | 20 | CONFIG_ARCH_NO_VIRT_TO_BUS=y |
21 | CONFIG_OF=y | 21 | CONFIG_OF=y |
22 | CONFIG_GENERIC_HARDIRQS_NO__DO_IRQ=y | ||
22 | CONFIG_SPARC64_PAGE_SIZE_8KB=y | 23 | CONFIG_SPARC64_PAGE_SIZE_8KB=y |
23 | # CONFIG_SPARC64_PAGE_SIZE_64KB is not set | 24 | # CONFIG_SPARC64_PAGE_SIZE_64KB is not set |
24 | # CONFIG_SPARC64_PAGE_SIZE_512KB is not set | 25 | # CONFIG_SPARC64_PAGE_SIZE_512KB is not set |
@@ -55,7 +56,8 @@ CONFIG_FAIR_USER_SCHED=y | |||
55 | # CONFIG_FAIR_CGROUP_SCHED is not set | 56 | # CONFIG_FAIR_CGROUP_SCHED is not set |
56 | CONFIG_SYSFS_DEPRECATED=y | 57 | CONFIG_SYSFS_DEPRECATED=y |
57 | CONFIG_RELAY=y | 58 | CONFIG_RELAY=y |
58 | # CONFIG_BLK_DEV_INITRD is not set | 59 | CONFIG_BLK_DEV_INITRD=y |
60 | CONFIG_INITRAMFS_SOURCE="" | ||
59 | CONFIG_CC_OPTIMIZE_FOR_SIZE=y | 61 | CONFIG_CC_OPTIMIZE_FOR_SIZE=y |
60 | CONFIG_SYSCTL=y | 62 | CONFIG_SYSCTL=y |
61 | # CONFIG_EMBEDDED is not set | 63 | # CONFIG_EMBEDDED is not set |
@@ -117,22 +119,7 @@ CONFIG_NO_HZ=y | |||
117 | CONFIG_HIGH_RES_TIMERS=y | 119 | CONFIG_HIGH_RES_TIMERS=y |
118 | CONFIG_GENERIC_CLOCKEVENTS_BUILD=y | 120 | CONFIG_GENERIC_CLOCKEVENTS_BUILD=y |
119 | # CONFIG_SMP is not set | 121 | # CONFIG_SMP is not set |
120 | CONFIG_CPU_FREQ=y | 122 | # CONFIG_CPU_FREQ is not set |
121 | CONFIG_CPU_FREQ_TABLE=m | ||
122 | # CONFIG_CPU_FREQ_DEBUG is not set | ||
123 | CONFIG_CPU_FREQ_STAT=m | ||
124 | CONFIG_CPU_FREQ_STAT_DETAILS=y | ||
125 | CONFIG_CPU_FREQ_DEFAULT_GOV_PERFORMANCE=y | ||
126 | # CONFIG_CPU_FREQ_DEFAULT_GOV_USERSPACE is not set | ||
127 | # CONFIG_CPU_FREQ_DEFAULT_GOV_ONDEMAND is not set | ||
128 | # CONFIG_CPU_FREQ_DEFAULT_GOV_CONSERVATIVE is not set | ||
129 | CONFIG_CPU_FREQ_GOV_PERFORMANCE=y | ||
130 | CONFIG_CPU_FREQ_GOV_POWERSAVE=m | ||
131 | CONFIG_CPU_FREQ_GOV_USERSPACE=m | ||
132 | CONFIG_CPU_FREQ_GOV_ONDEMAND=m | ||
133 | CONFIG_CPU_FREQ_GOV_CONSERVATIVE=m | ||
134 | CONFIG_US3_FREQ=m | ||
135 | CONFIG_US2E_FREQ=m | ||
136 | CONFIG_RWSEM_XCHGADD_ALGORITHM=y | 123 | CONFIG_RWSEM_XCHGADD_ALGORITHM=y |
137 | CONFIG_GENERIC_FIND_NEXT_BIT=y | 124 | CONFIG_GENERIC_FIND_NEXT_BIT=y |
138 | CONFIG_GENERIC_HWEIGHT=y | 125 | CONFIG_GENERIC_HWEIGHT=y |
@@ -161,7 +148,7 @@ CONFIG_SBUS=y | |||
161 | CONFIG_SBUSCHAR=y | 148 | CONFIG_SBUSCHAR=y |
162 | CONFIG_SUN_AUXIO=y | 149 | CONFIG_SUN_AUXIO=y |
163 | CONFIG_SUN_IO=y | 150 | CONFIG_SUN_IO=y |
164 | # CONFIG_SUN_LDOMS is not set | 151 | CONFIG_SUN_LDOMS=y |
165 | CONFIG_PCI=y | 152 | CONFIG_PCI=y |
166 | CONFIG_PCI_DOMAINS=y | 153 | CONFIG_PCI_DOMAINS=y |
167 | CONFIG_PCI_SYSCALL=y | 154 | CONFIG_PCI_SYSCALL=y |
@@ -338,6 +325,7 @@ CONFIG_CDROM_PKTCDVD=m | |||
338 | CONFIG_CDROM_PKTCDVD_BUFFERS=8 | 325 | CONFIG_CDROM_PKTCDVD_BUFFERS=8 |
339 | CONFIG_CDROM_PKTCDVD_WCACHE=y | 326 | CONFIG_CDROM_PKTCDVD_WCACHE=y |
340 | CONFIG_ATA_OVER_ETH=m | 327 | CONFIG_ATA_OVER_ETH=m |
328 | CONFIG_SUNVDC=m | ||
341 | CONFIG_MISC_DEVICES=y | 329 | CONFIG_MISC_DEVICES=y |
342 | # CONFIG_PHANTOM is not set | 330 | # CONFIG_PHANTOM is not set |
343 | # CONFIG_EEPROM_93CX6 is not set | 331 | # CONFIG_EEPROM_93CX6 is not set |
@@ -440,12 +428,12 @@ CONFIG_SCSI_WAIT_SCAN=m | |||
440 | # | 428 | # |
441 | CONFIG_SCSI_SPI_ATTRS=y | 429 | CONFIG_SCSI_SPI_ATTRS=y |
442 | CONFIG_SCSI_FC_ATTRS=y | 430 | CONFIG_SCSI_FC_ATTRS=y |
443 | CONFIG_SCSI_ISCSI_ATTRS=m | 431 | # CONFIG_SCSI_ISCSI_ATTRS is not set |
444 | # CONFIG_SCSI_SAS_ATTRS is not set | 432 | # CONFIG_SCSI_SAS_ATTRS is not set |
445 | # CONFIG_SCSI_SAS_LIBSAS is not set | 433 | # CONFIG_SCSI_SAS_LIBSAS is not set |
446 | # CONFIG_SCSI_SRP_ATTRS is not set | 434 | # CONFIG_SCSI_SRP_ATTRS is not set |
447 | CONFIG_SCSI_LOWLEVEL=y | 435 | CONFIG_SCSI_LOWLEVEL=y |
448 | CONFIG_ISCSI_TCP=m | 436 | # CONFIG_ISCSI_TCP is not set |
449 | # CONFIG_BLK_DEV_3W_XXXX_RAID is not set | 437 | # CONFIG_BLK_DEV_3W_XXXX_RAID is not set |
450 | # CONFIG_SCSI_3W_9XXX is not set | 438 | # CONFIG_SCSI_3W_9XXX is not set |
451 | # CONFIG_SCSI_ACARD is not set | 439 | # CONFIG_SCSI_ACARD is not set |
@@ -506,7 +494,7 @@ CONFIG_DM_ZERO=m | |||
506 | # CONFIG_I2O is not set | 494 | # CONFIG_I2O is not set |
507 | CONFIG_NETDEVICES=y | 495 | CONFIG_NETDEVICES=y |
508 | # CONFIG_NETDEVICES_MULTIQUEUE is not set | 496 | # CONFIG_NETDEVICES_MULTIQUEUE is not set |
509 | CONFIG_DUMMY=m | 497 | # CONFIG_DUMMY is not set |
510 | # CONFIG_BONDING is not set | 498 | # CONFIG_BONDING is not set |
511 | # CONFIG_MACVLAN is not set | 499 | # CONFIG_MACVLAN is not set |
512 | # CONFIG_EQUALIZER is not set | 500 | # CONFIG_EQUALIZER is not set |
@@ -523,6 +511,7 @@ CONFIG_MII=m | |||
523 | # CONFIG_SUNQE is not set | 511 | # CONFIG_SUNQE is not set |
524 | # CONFIG_SUNGEM is not set | 512 | # CONFIG_SUNGEM is not set |
525 | CONFIG_CASSINI=m | 513 | CONFIG_CASSINI=m |
514 | CONFIG_SUNVNET=m | ||
526 | # CONFIG_NET_VENDOR_3COM is not set | 515 | # CONFIG_NET_VENDOR_3COM is not set |
527 | # CONFIG_NET_TULIP is not set | 516 | # CONFIG_NET_TULIP is not set |
528 | # CONFIG_HP100 is not set | 517 | # CONFIG_HP100 is not set |
@@ -577,7 +566,7 @@ CONFIG_NETDEV_10000=y | |||
577 | # CONFIG_S2IO is not set | 566 | # CONFIG_S2IO is not set |
578 | # CONFIG_MYRI10GE is not set | 567 | # CONFIG_MYRI10GE is not set |
579 | # CONFIG_NETXEN_NIC is not set | 568 | # CONFIG_NETXEN_NIC is not set |
580 | # CONFIG_NIU is not set | 569 | CONFIG_NIU=m |
581 | # CONFIG_MLX4_CORE is not set | 570 | # CONFIG_MLX4_CORE is not set |
582 | # CONFIG_TEHUTI is not set | 571 | # CONFIG_TEHUTI is not set |
583 | # CONFIG_TR is not set | 572 | # CONFIG_TR is not set |
@@ -702,7 +691,8 @@ CONFIG_SERIAL_SUNCORE=y | |||
702 | # CONFIG_SERIAL_SUNZILOG is not set | 691 | # CONFIG_SERIAL_SUNZILOG is not set |
703 | CONFIG_SERIAL_SUNSU=y | 692 | CONFIG_SERIAL_SUNSU=y |
704 | CONFIG_SERIAL_SUNSU_CONSOLE=y | 693 | CONFIG_SERIAL_SUNSU_CONSOLE=y |
705 | CONFIG_SERIAL_SUNSAB=m | 694 | CONFIG_SERIAL_SUNSAB=y |
695 | CONFIG_SERIAL_SUNSAB_CONSOLE=y | ||
706 | CONFIG_SERIAL_SUNHV=y | 696 | CONFIG_SERIAL_SUNHV=y |
707 | CONFIG_SERIAL_CORE=y | 697 | CONFIG_SERIAL_CORE=y |
708 | CONFIG_SERIAL_CORE_CONSOLE=y | 698 | CONFIG_SERIAL_CORE_CONSOLE=y |
@@ -880,9 +870,17 @@ CONFIG_FB_TILEBLITTING=y | |||
880 | # CONFIG_FB_ASILIANT is not set | 870 | # CONFIG_FB_ASILIANT is not set |
881 | # CONFIG_FB_IMSTT is not set | 871 | # CONFIG_FB_IMSTT is not set |
882 | # CONFIG_FB_UVESA is not set | 872 | # CONFIG_FB_UVESA is not set |
883 | # CONFIG_FB_SBUS is not set | 873 | CONFIG_FB_SBUS=y |
884 | # CONFIG_FB_XVR500 is not set | 874 | # CONFIG_FB_BW2 is not set |
885 | # CONFIG_FB_XVR2500 is not set | 875 | # CONFIG_FB_CG3 is not set |
876 | CONFIG_FB_CG6=y | ||
877 | CONFIG_FB_FFB=y | ||
878 | # CONFIG_FB_TCX is not set | ||
879 | # CONFIG_FB_CG14 is not set | ||
880 | # CONFIG_FB_P9100 is not set | ||
881 | # CONFIG_FB_LEO is not set | ||
882 | CONFIG_FB_XVR500=y | ||
883 | CONFIG_FB_XVR2500=y | ||
886 | # CONFIG_FB_S1D13XXX is not set | 884 | # CONFIG_FB_S1D13XXX is not set |
887 | # CONFIG_FB_NVIDIA is not set | 885 | # CONFIG_FB_NVIDIA is not set |
888 | # CONFIG_FB_RIVA is not set | 886 | # CONFIG_FB_RIVA is not set |
@@ -892,7 +890,11 @@ CONFIG_FB_RADEON_I2C=y | |||
892 | # CONFIG_FB_RADEON_BACKLIGHT is not set | 890 | # CONFIG_FB_RADEON_BACKLIGHT is not set |
893 | # CONFIG_FB_RADEON_DEBUG is not set | 891 | # CONFIG_FB_RADEON_DEBUG is not set |
894 | # CONFIG_FB_ATY128 is not set | 892 | # CONFIG_FB_ATY128 is not set |
895 | # CONFIG_FB_ATY is not set | 893 | CONFIG_FB_ATY=y |
894 | CONFIG_FB_ATY_CT=y | ||
895 | # CONFIG_FB_ATY_GENERIC_LCD is not set | ||
896 | CONFIG_FB_ATY_GX=y | ||
897 | # CONFIG_FB_ATY_BACKLIGHT is not set | ||
896 | # CONFIG_FB_S3 is not set | 898 | # CONFIG_FB_S3 is not set |
897 | # CONFIG_FB_SAVAGE is not set | 899 | # CONFIG_FB_SAVAGE is not set |
898 | # CONFIG_FB_SIS is not set | 900 | # CONFIG_FB_SIS is not set |
@@ -1191,7 +1193,7 @@ CONFIG_USB_STORAGE=m | |||
1191 | # | 1193 | # |
1192 | # Misc Linux/SPARC drivers | 1194 | # Misc Linux/SPARC drivers |
1193 | # | 1195 | # |
1194 | CONFIG_SUN_OPENPROMIO=m | 1196 | CONFIG_SUN_OPENPROMIO=y |
1195 | # CONFIG_OBP_FLASH is not set | 1197 | # CONFIG_OBP_FLASH is not set |
1196 | # CONFIG_SUN_BPP is not set | 1198 | # CONFIG_SUN_BPP is not set |
1197 | # CONFIG_BBC_I2C is not set | 1199 | # CONFIG_BBC_I2C is not set |
@@ -1199,11 +1201,6 @@ CONFIG_SUN_OPENPROMIO=m | |||
1199 | # CONFIG_DISPLAY7SEG is not set | 1201 | # CONFIG_DISPLAY7SEG is not set |
1200 | 1202 | ||
1201 | # | 1203 | # |
1202 | # Fibre Channel support | ||
1203 | # | ||
1204 | # CONFIG_FC4 is not set | ||
1205 | |||
1206 | # | ||
1207 | # File systems | 1204 | # File systems |
1208 | # | 1205 | # |
1209 | CONFIG_EXT2_FS=y | 1206 | CONFIG_EXT2_FS=y |
@@ -1345,6 +1342,7 @@ CONFIG_KPROBES=y | |||
1345 | # | 1342 | # |
1346 | CONFIG_TRACE_IRQFLAGS_SUPPORT=y | 1343 | CONFIG_TRACE_IRQFLAGS_SUPPORT=y |
1347 | CONFIG_PRINTK_TIME=y | 1344 | CONFIG_PRINTK_TIME=y |
1345 | # CONFIG_ENABLE_WARN_DEPRECATED is not set | ||
1348 | CONFIG_ENABLE_MUST_CHECK=y | 1346 | CONFIG_ENABLE_MUST_CHECK=y |
1349 | CONFIG_MAGIC_SYSRQ=y | 1347 | CONFIG_MAGIC_SYSRQ=y |
1350 | # CONFIG_UNUSED_SYMBOLS is not set | 1348 | # CONFIG_UNUSED_SYMBOLS is not set |
@@ -1371,6 +1369,7 @@ CONFIG_DEBUG_BUGVERBOSE=y | |||
1371 | # CONFIG_DEBUG_INFO is not set | 1369 | # CONFIG_DEBUG_INFO is not set |
1372 | # CONFIG_DEBUG_VM is not set | 1370 | # CONFIG_DEBUG_VM is not set |
1373 | # CONFIG_DEBUG_LIST is not set | 1371 | # CONFIG_DEBUG_LIST is not set |
1372 | # CONFIG_DEBUG_SG is not set | ||
1374 | CONFIG_FORCED_INLINING=y | 1373 | CONFIG_FORCED_INLINING=y |
1375 | # CONFIG_BOOT_PRINTK_DELAY is not set | 1374 | # CONFIG_BOOT_PRINTK_DELAY is not set |
1376 | # CONFIG_RCU_TORTURE_TEST is not set | 1375 | # CONFIG_RCU_TORTURE_TEST is not set |
diff --git a/arch/sparc64/kernel/binfmt_elf32.c b/arch/sparc64/kernel/binfmt_elf32.c index 9ad84ff10a17..1587a29a4b0e 100644 --- a/arch/sparc64/kernel/binfmt_elf32.c +++ b/arch/sparc64/kernel/binfmt_elf32.c | |||
@@ -1,7 +1,7 @@ | |||
1 | /* | 1 | /* |
2 | * binfmt_elf32.c: Support 32-bit Sparc ELF binaries on Ultra. | 2 | * binfmt_elf32.c: Support 32-bit Sparc ELF binaries on Ultra. |
3 | * | 3 | * |
4 | * Copyright (C) 1995, 1996, 1997, 1998 David S. Miller (davem@redhat.com) | 4 | * Copyright (C) 1995, 1996, 1997, 1998 David S. Miller (davem@davemloft.net) |
5 | * Copyright (C) 1995, 1996, 1997, 1998 Jakub Jelinek (jj@ultra.linux.cz) | 5 | * Copyright (C) 1995, 1996, 1997, 1998 Jakub Jelinek (jj@ultra.linux.cz) |
6 | */ | 6 | */ |
7 | 7 | ||
@@ -133,7 +133,7 @@ struct elf_prpsinfo32 | |||
133 | 133 | ||
134 | #undef cputime_to_timeval | 134 | #undef cputime_to_timeval |
135 | #define cputime_to_timeval cputime_to_compat_timeval | 135 | #define cputime_to_timeval cputime_to_compat_timeval |
136 | static __inline__ void | 136 | static inline void |
137 | cputime_to_compat_timeval(const cputime_t cputime, struct compat_timeval *value) | 137 | cputime_to_compat_timeval(const cputime_t cputime, struct compat_timeval *value) |
138 | { | 138 | { |
139 | unsigned long jiffies = cputime_to_jiffies(cputime); | 139 | unsigned long jiffies = cputime_to_jiffies(cputime); |
diff --git a/arch/sparc64/kernel/central.c b/arch/sparc64/kernel/central.c index 8230099f0d8a..b61b8dfb09cf 100644 --- a/arch/sparc64/kernel/central.c +++ b/arch/sparc64/kernel/central.c | |||
@@ -1,7 +1,6 @@ | |||
1 | /* $Id: central.c,v 1.15 2001/12/19 00:29:51 davem Exp $ | 1 | /* central.c: Central FHC driver for Sunfire/Starfire/Wildfire. |
2 | * central.c: Central FHC driver for Sunfire/Starfire/Wildfire. | ||
3 | * | 2 | * |
4 | * Copyright (C) 1997, 1999 David S. Miller (davem@redhat.com) | 3 | * Copyright (C) 1997, 1999 David S. Miller (davem@davemloft.net) |
5 | */ | 4 | */ |
6 | 5 | ||
7 | #include <linux/kernel.h> | 6 | #include <linux/kernel.h> |
@@ -385,7 +384,7 @@ void __init central_probe(void) | |||
385 | init_all_fhc_hw(); | 384 | init_all_fhc_hw(); |
386 | } | 385 | } |
387 | 386 | ||
388 | static __inline__ void fhc_ledblink(struct linux_fhc *fhc, int on) | 387 | static inline void fhc_ledblink(struct linux_fhc *fhc, int on) |
389 | { | 388 | { |
390 | u32 tmp; | 389 | u32 tmp; |
391 | 390 | ||
@@ -402,7 +401,7 @@ static __inline__ void fhc_ledblink(struct linux_fhc *fhc, int on) | |||
402 | upa_readl(fhc->fhc_regs.pregs + FHC_PREGS_CTRL); | 401 | upa_readl(fhc->fhc_regs.pregs + FHC_PREGS_CTRL); |
403 | } | 402 | } |
404 | 403 | ||
405 | static __inline__ void central_ledblink(struct linux_central *central, int on) | 404 | static inline void central_ledblink(struct linux_central *central, int on) |
406 | { | 405 | { |
407 | u8 tmp; | 406 | u8 tmp; |
408 | 407 | ||
diff --git a/arch/sparc64/kernel/iommu_common.c b/arch/sparc64/kernel/iommu_common.c index b70324e0d83d..efd5dff85f60 100644 --- a/arch/sparc64/kernel/iommu_common.c +++ b/arch/sparc64/kernel/iommu_common.c | |||
@@ -234,7 +234,7 @@ unsigned long prepare_sg(struct scatterlist *sg, int nents) | |||
234 | dma_sg->dma_length = dent_len; | 234 | dma_sg->dma_length = dent_len; |
235 | 235 | ||
236 | if (dma_sg != sg) { | 236 | if (dma_sg != sg) { |
237 | dma_sg = next_sg(dma_sg); | 237 | dma_sg = sg_next(dma_sg); |
238 | dma_sg->dma_length = 0; | 238 | dma_sg->dma_length = 0; |
239 | } | 239 | } |
240 | 240 | ||
diff --git a/arch/sparc64/kernel/ldc.c b/arch/sparc64/kernel/ldc.c index c8313cb60f0a..217478a94128 100644 --- a/arch/sparc64/kernel/ldc.c +++ b/arch/sparc64/kernel/ldc.c | |||
@@ -2121,7 +2121,7 @@ int ldc_map_sg(struct ldc_channel *lp, | |||
2121 | state.nc = 0; | 2121 | state.nc = 0; |
2122 | 2122 | ||
2123 | for (i = 0; i < num_sg; i++) | 2123 | for (i = 0; i < num_sg; i++) |
2124 | fill_cookies(&state, page_to_pfn(sg[i].page) << PAGE_SHIFT, | 2124 | fill_cookies(&state, page_to_pfn(sg_page(&sg[i])) << PAGE_SHIFT, |
2125 | sg[i].offset, sg[i].length); | 2125 | sg[i].offset, sg[i].length); |
2126 | 2126 | ||
2127 | return state.nc; | 2127 | return state.nc; |
diff --git a/arch/sparc64/kernel/semaphore.c b/arch/sparc64/kernel/semaphore.c index a809e63f03ef..9974a6899551 100644 --- a/arch/sparc64/kernel/semaphore.c +++ b/arch/sparc64/kernel/semaphore.c | |||
@@ -1,5 +1,4 @@ | |||
1 | /* $Id: semaphore.c,v 1.9 2001/11/18 00:12:56 davem Exp $ | 1 | /* semaphore.c: Sparc64 semaphore implementation. |
2 | * semaphore.c: Sparc64 semaphore implementation. | ||
3 | * | 2 | * |
4 | * This is basically the PPC semaphore scheme ported to use | 3 | * This is basically the PPC semaphore scheme ported to use |
5 | * the sparc64 atomic instructions, so see the PPC code for | 4 | * the sparc64 atomic instructions, so see the PPC code for |
@@ -19,7 +18,7 @@ | |||
19 | * sem->count = tmp; | 18 | * sem->count = tmp; |
20 | * return old_count; | 19 | * return old_count; |
21 | */ | 20 | */ |
22 | static __inline__ int __sem_update_count(struct semaphore *sem, int incr) | 21 | static inline int __sem_update_count(struct semaphore *sem, int incr) |
23 | { | 22 | { |
24 | int old_count, tmp; | 23 | int old_count, tmp; |
25 | 24 | ||
diff --git a/arch/sparc64/kernel/smp.c b/arch/sparc64/kernel/smp.c index 407d74a8a542..7cd8d94df0dc 100644 --- a/arch/sparc64/kernel/smp.c +++ b/arch/sparc64/kernel/smp.c | |||
@@ -459,7 +459,7 @@ again: | |||
459 | } | 459 | } |
460 | } | 460 | } |
461 | 461 | ||
462 | static __inline__ void spitfire_xcall_deliver(u64 data0, u64 data1, u64 data2, cpumask_t mask) | 462 | static inline void spitfire_xcall_deliver(u64 data0, u64 data1, u64 data2, cpumask_t mask) |
463 | { | 463 | { |
464 | u64 pstate; | 464 | u64 pstate; |
465 | int i; | 465 | int i; |
@@ -906,7 +906,7 @@ extern atomic_t dcpage_flushes; | |||
906 | extern atomic_t dcpage_flushes_xcall; | 906 | extern atomic_t dcpage_flushes_xcall; |
907 | #endif | 907 | #endif |
908 | 908 | ||
909 | static __inline__ void __local_flush_dcache_page(struct page *page) | 909 | static inline void __local_flush_dcache_page(struct page *page) |
910 | { | 910 | { |
911 | #ifdef DCACHE_ALIASING_POSSIBLE | 911 | #ifdef DCACHE_ALIASING_POSSIBLE |
912 | __flush_dcache_page(page_address(page), | 912 | __flush_dcache_page(page_address(page), |
diff --git a/arch/sparc64/kernel/sparc64_ksyms.c b/arch/sparc64/kernel/sparc64_ksyms.c index 23fad7ebdd0d..60765e314bd8 100644 --- a/arch/sparc64/kernel/sparc64_ksyms.c +++ b/arch/sparc64/kernel/sparc64_ksyms.c | |||
@@ -221,7 +221,7 @@ EXPORT_SYMBOL(pci_dma_supported); | |||
221 | /* I/O device mmaping on Sparc64. */ | 221 | /* I/O device mmaping on Sparc64. */ |
222 | EXPORT_SYMBOL(io_remap_pfn_range); | 222 | EXPORT_SYMBOL(io_remap_pfn_range); |
223 | 223 | ||
224 | #ifdef CONFIG_COMPAT | 224 | #if defined(CONFIG_COMPAT) && defined(CONFIG_NET) |
225 | /* Solaris/SunOS binary compatibility */ | 225 | /* Solaris/SunOS binary compatibility */ |
226 | EXPORT_SYMBOL(verify_compat_iovec); | 226 | EXPORT_SYMBOL(verify_compat_iovec); |
227 | #endif | 227 | #endif |
diff --git a/arch/sparc64/kernel/sys_sparc.c b/arch/sparc64/kernel/sys_sparc.c index 560cb1edb1d0..c56573a10eee 100644 --- a/arch/sparc64/kernel/sys_sparc.c +++ b/arch/sparc64/kernel/sys_sparc.c | |||
@@ -318,7 +318,7 @@ unsigned long get_fb_unmapped_area(struct file *filp, unsigned long orig_addr, u | |||
318 | 318 | ||
319 | if (flags & MAP_FIXED) { | 319 | if (flags & MAP_FIXED) { |
320 | /* Ok, don't mess with it. */ | 320 | /* Ok, don't mess with it. */ |
321 | return get_unmapped_area(NULL, addr, len, pgoff, flags); | 321 | return get_unmapped_area(NULL, orig_addr, len, pgoff, flags); |
322 | } | 322 | } |
323 | flags &= ~MAP_SHARED; | 323 | flags &= ~MAP_SHARED; |
324 | 324 | ||
diff --git a/arch/sparc64/kernel/time.c b/arch/sparc64/kernel/time.c index cd8c740cba1d..a2cf955294c1 100644 --- a/arch/sparc64/kernel/time.c +++ b/arch/sparc64/kernel/time.c | |||
@@ -1070,7 +1070,7 @@ static int set_rtc_mmss(unsigned long nowtime) | |||
1070 | * Not having a register set can lead to trouble. | 1070 | * Not having a register set can lead to trouble. |
1071 | * Also starfire doesn't have a tod clock. | 1071 | * Also starfire doesn't have a tod clock. |
1072 | */ | 1072 | */ |
1073 | if (!mregs && !dregs & !bregs) | 1073 | if (!mregs && !dregs && !bregs) |
1074 | return -1; | 1074 | return -1; |
1075 | 1075 | ||
1076 | if (mregs) { | 1076 | if (mregs) { |
diff --git a/arch/sparc64/kernel/traps.c b/arch/sparc64/kernel/traps.c index e9c7e4f07abf..04998388259f 100644 --- a/arch/sparc64/kernel/traps.c +++ b/arch/sparc64/kernel/traps.c | |||
@@ -1,7 +1,6 @@ | |||
1 | /* $Id: traps.c,v 1.85 2002/02/09 19:49:31 davem Exp $ | 1 | /* arch/sparc64/kernel/traps.c |
2 | * arch/sparc64/kernel/traps.c | ||
3 | * | 2 | * |
4 | * Copyright (C) 1995,1997 David S. Miller (davem@caip.rutgers.edu) | 3 | * Copyright (C) 1995,1997 David S. Miller (davem@davemloft.net) |
5 | * Copyright (C) 1997,1999,2000 Jakub Jelinek (jakub@redhat.com) | 4 | * Copyright (C) 1997,1999,2000 Jakub Jelinek (jakub@redhat.com) |
6 | */ | 5 | */ |
7 | 6 | ||
@@ -765,7 +764,7 @@ static unsigned long cheetah_afsr_errors; | |||
765 | */ | 764 | */ |
766 | struct cheetah_err_info *cheetah_error_log; | 765 | struct cheetah_err_info *cheetah_error_log; |
767 | 766 | ||
768 | static __inline__ struct cheetah_err_info *cheetah_get_error_log(unsigned long afsr) | 767 | static inline struct cheetah_err_info *cheetah_get_error_log(unsigned long afsr) |
769 | { | 768 | { |
770 | struct cheetah_err_info *p; | 769 | struct cheetah_err_info *p; |
771 | int cpu = smp_processor_id(); | 770 | int cpu = smp_processor_id(); |
@@ -1085,7 +1084,7 @@ static unsigned char cheetah_mtag_syntab[] = { | |||
1085 | }; | 1084 | }; |
1086 | 1085 | ||
1087 | /* Return the highest priority error conditon mentioned. */ | 1086 | /* Return the highest priority error conditon mentioned. */ |
1088 | static __inline__ unsigned long cheetah_get_hipri(unsigned long afsr) | 1087 | static inline unsigned long cheetah_get_hipri(unsigned long afsr) |
1089 | { | 1088 | { |
1090 | unsigned long tmp = 0; | 1089 | unsigned long tmp = 0; |
1091 | int i; | 1090 | int i; |
diff --git a/arch/sparc64/mm/init.c b/arch/sparc64/mm/init.c index 100c4456ed1e..e18ccf85224f 100644 --- a/arch/sparc64/mm/init.c +++ b/arch/sparc64/mm/init.c | |||
@@ -201,7 +201,7 @@ inline void flush_dcache_page_impl(struct page *page) | |||
201 | #define dcache_dirty_cpu(page) \ | 201 | #define dcache_dirty_cpu(page) \ |
202 | (((page)->flags >> PG_dcache_cpu_shift) & PG_dcache_cpu_mask) | 202 | (((page)->flags >> PG_dcache_cpu_shift) & PG_dcache_cpu_mask) |
203 | 203 | ||
204 | static __inline__ void set_dcache_dirty(struct page *page, int this_cpu) | 204 | static inline void set_dcache_dirty(struct page *page, int this_cpu) |
205 | { | 205 | { |
206 | unsigned long mask = this_cpu; | 206 | unsigned long mask = this_cpu; |
207 | unsigned long non_cpu_bits; | 207 | unsigned long non_cpu_bits; |
@@ -223,7 +223,7 @@ static __inline__ void set_dcache_dirty(struct page *page, int this_cpu) | |||
223 | : "g1", "g7"); | 223 | : "g1", "g7"); |
224 | } | 224 | } |
225 | 225 | ||
226 | static __inline__ void clear_dcache_dirty_cpu(struct page *page, unsigned long cpu) | 226 | static inline void clear_dcache_dirty_cpu(struct page *page, unsigned long cpu) |
227 | { | 227 | { |
228 | unsigned long mask = (1UL << PG_dcache_dirty); | 228 | unsigned long mask = (1UL << PG_dcache_dirty); |
229 | 229 | ||
diff --git a/arch/sparc64/mm/tsb.c b/arch/sparc64/mm/tsb.c index 7ff0a02f5813..a3e6e4b635b3 100644 --- a/arch/sparc64/mm/tsb.c +++ b/arch/sparc64/mm/tsb.c | |||
@@ -182,7 +182,9 @@ static void setup_tsb_params(struct mm_struct *mm, unsigned long tsb_idx, unsign | |||
182 | break; | 182 | break; |
183 | 183 | ||
184 | default: | 184 | default: |
185 | BUG(); | 185 | printk(KERN_ERR "TSB[%s:%d]: Impossible TSB size %lu, killing process.\n", |
186 | current->comm, current->pid, tsb_bytes); | ||
187 | do_exit(SIGSEGV); | ||
186 | }; | 188 | }; |
187 | tte |= pte_sz_bits(page_sz); | 189 | tte |= pte_sz_bits(page_sz); |
188 | 190 | ||
diff --git a/arch/sparc64/mm/ultra.S b/arch/sparc64/mm/ultra.S index 737c26923c09..2865c105b6a4 100644 --- a/arch/sparc64/mm/ultra.S +++ b/arch/sparc64/mm/ultra.S | |||
@@ -120,13 +120,6 @@ __spitfire_flush_tlb_mm_slow: | |||
120 | /* | 120 | /* |
121 | * The following code flushes one page_size worth. | 121 | * The following code flushes one page_size worth. |
122 | */ | 122 | */ |
123 | #if (PAGE_SHIFT == 13) | ||
124 | #define ITAG_MASK 0xfe | ||
125 | #elif (PAGE_SHIFT == 16) | ||
126 | #define ITAG_MASK 0x7fe | ||
127 | #else | ||
128 | #error unsupported PAGE_SIZE | ||
129 | #endif | ||
130 | .section .kprobes.text, "ax" | 123 | .section .kprobes.text, "ax" |
131 | .align 32 | 124 | .align 32 |
132 | .globl __flush_icache_page | 125 | .globl __flush_icache_page |
diff --git a/arch/sparc64/prom/console.c b/arch/sparc64/prom/console.c index 3fafa9a8b50b..e1c3fc87484d 100644 --- a/arch/sparc64/prom/console.c +++ b/arch/sparc64/prom/console.c | |||
@@ -1,8 +1,7 @@ | |||
1 | /* $Id: console.c,v 1.9 1997/10/29 07:41:43 ecd Exp $ | 1 | /* console.c: Routines that deal with sending and receiving IO |
2 | * console.c: Routines that deal with sending and receiving IO | ||
3 | * to/from the current console device using the PROM. | 2 | * to/from the current console device using the PROM. |
4 | * | 3 | * |
5 | * Copyright (C) 1995 David S. Miller (davem@caip.rutgers.edu) | 4 | * Copyright (C) 1995 David S. Miller (davem@davemloft.net) |
6 | * Copyright (C) 1996,1997 Jakub Jelinek (jj@sunsite.mff.cuni.cz) | 5 | * Copyright (C) 1996,1997 Jakub Jelinek (jj@sunsite.mff.cuni.cz) |
7 | */ | 6 | */ |
8 | 7 | ||
@@ -19,7 +18,7 @@ extern int prom_stdin, prom_stdout; | |||
19 | /* Non blocking get character from console input device, returns -1 | 18 | /* Non blocking get character from console input device, returns -1 |
20 | * if no input was taken. This can be used for polling. | 19 | * if no input was taken. This can be used for polling. |
21 | */ | 20 | */ |
22 | __inline__ int | 21 | inline int |
23 | prom_nbgetchar(void) | 22 | prom_nbgetchar(void) |
24 | { | 23 | { |
25 | char inc; | 24 | char inc; |
@@ -35,7 +34,7 @@ prom_nbgetchar(void) | |||
35 | /* Non blocking put character to console device, returns -1 if | 34 | /* Non blocking put character to console device, returns -1 if |
36 | * unsuccessful. | 35 | * unsuccessful. |
37 | */ | 36 | */ |
38 | __inline__ int | 37 | inline int |
39 | prom_nbputchar(char c) | 38 | prom_nbputchar(char c) |
40 | { | 39 | { |
41 | char outc; | 40 | char outc; |
diff --git a/arch/sparc64/prom/tree.c b/arch/sparc64/prom/tree.c index b2c5b12c9818..a99ccd7fb1b0 100644 --- a/arch/sparc64/prom/tree.c +++ b/arch/sparc64/prom/tree.c | |||
@@ -18,14 +18,12 @@ | |||
18 | /* Return the child of node 'node' or zero if no this node has no | 18 | /* Return the child of node 'node' or zero if no this node has no |
19 | * direct descendent. | 19 | * direct descendent. |
20 | */ | 20 | */ |
21 | __inline__ int | 21 | inline int __prom_getchild(int node) |
22 | __prom_getchild(int node) | ||
23 | { | 22 | { |
24 | return p1275_cmd ("child", P1275_INOUT(1, 1), node); | 23 | return p1275_cmd ("child", P1275_INOUT(1, 1), node); |
25 | } | 24 | } |
26 | 25 | ||
27 | __inline__ int | 26 | inline int prom_getchild(int node) |
28 | prom_getchild(int node) | ||
29 | { | 27 | { |
30 | int cnode; | 28 | int cnode; |
31 | 29 | ||
@@ -35,8 +33,7 @@ prom_getchild(int node) | |||
35 | return (int)cnode; | 33 | return (int)cnode; |
36 | } | 34 | } |
37 | 35 | ||
38 | __inline__ int | 36 | inline int prom_getparent(int node) |
39 | prom_getparent(int node) | ||
40 | { | 37 | { |
41 | int cnode; | 38 | int cnode; |
42 | 39 | ||
@@ -49,14 +46,12 @@ prom_getparent(int node) | |||
49 | /* Return the next sibling of node 'node' or zero if no more siblings | 46 | /* Return the next sibling of node 'node' or zero if no more siblings |
50 | * at this level of depth in the tree. | 47 | * at this level of depth in the tree. |
51 | */ | 48 | */ |
52 | __inline__ int | 49 | inline int __prom_getsibling(int node) |
53 | __prom_getsibling(int node) | ||
54 | { | 50 | { |
55 | return p1275_cmd(prom_peer_name, P1275_INOUT(1, 1), node); | 51 | return p1275_cmd(prom_peer_name, P1275_INOUT(1, 1), node); |
56 | } | 52 | } |
57 | 53 | ||
58 | __inline__ int | 54 | inline int prom_getsibling(int node) |
59 | prom_getsibling(int node) | ||
60 | { | 55 | { |
61 | int sibnode; | 56 | int sibnode; |
62 | 57 | ||
@@ -72,8 +67,7 @@ prom_getsibling(int node) | |||
72 | /* Return the length in bytes of property 'prop' at node 'node'. | 67 | /* Return the length in bytes of property 'prop' at node 'node'. |
73 | * Return -1 on error. | 68 | * Return -1 on error. |
74 | */ | 69 | */ |
75 | __inline__ int | 70 | inline int prom_getproplen(int node, const char *prop) |
76 | prom_getproplen(int node, const char *prop) | ||
77 | { | 71 | { |
78 | if((!node) || (!prop)) return -1; | 72 | if((!node) || (!prop)) return -1; |
79 | return p1275_cmd ("getproplen", | 73 | return p1275_cmd ("getproplen", |
@@ -86,8 +80,8 @@ prom_getproplen(int node, const char *prop) | |||
86 | * 'buffer' which has a size of 'bufsize'. If the acquisition | 80 | * 'buffer' which has a size of 'bufsize'. If the acquisition |
87 | * was successful the length will be returned, else -1 is returned. | 81 | * was successful the length will be returned, else -1 is returned. |
88 | */ | 82 | */ |
89 | __inline__ int | 83 | inline int prom_getproperty(int node, const char *prop, |
90 | prom_getproperty(int node, const char *prop, char *buffer, int bufsize) | 84 | char *buffer, int bufsize) |
91 | { | 85 | { |
92 | int plen; | 86 | int plen; |
93 | 87 | ||
@@ -107,8 +101,7 @@ prom_getproperty(int node, const char *prop, char *buffer, int bufsize) | |||
107 | /* Acquire an integer property and return its value. Returns -1 | 101 | /* Acquire an integer property and return its value. Returns -1 |
108 | * on failure. | 102 | * on failure. |
109 | */ | 103 | */ |
110 | __inline__ int | 104 | inline int prom_getint(int node, const char *prop) |
111 | prom_getint(int node, const char *prop) | ||
112 | { | 105 | { |
113 | int intprop; | 106 | int intprop; |
114 | 107 | ||
@@ -122,8 +115,7 @@ prom_getint(int node, const char *prop) | |||
122 | * integer. | 115 | * integer. |
123 | */ | 116 | */ |
124 | 117 | ||
125 | int | 118 | int prom_getintdefault(int node, const char *property, int deflt) |
126 | prom_getintdefault(int node, const char *property, int deflt) | ||
127 | { | 119 | { |
128 | int retval; | 120 | int retval; |
129 | 121 | ||
@@ -134,8 +126,7 @@ prom_getintdefault(int node, const char *property, int deflt) | |||
134 | } | 126 | } |
135 | 127 | ||
136 | /* Acquire a boolean property, 1=TRUE 0=FALSE. */ | 128 | /* Acquire a boolean property, 1=TRUE 0=FALSE. */ |
137 | int | 129 | int prom_getbool(int node, const char *prop) |
138 | prom_getbool(int node, const char *prop) | ||
139 | { | 130 | { |
140 | int retval; | 131 | int retval; |
141 | 132 | ||
@@ -148,8 +139,7 @@ prom_getbool(int node, const char *prop) | |||
148 | * string on error. The char pointer is the user supplied string | 139 | * string on error. The char pointer is the user supplied string |
149 | * buffer. | 140 | * buffer. |
150 | */ | 141 | */ |
151 | void | 142 | void prom_getstring(int node, const char *prop, char *user_buf, int ubuf_size) |
152 | prom_getstring(int node, const char *prop, char *user_buf, int ubuf_size) | ||
153 | { | 143 | { |
154 | int len; | 144 | int len; |
155 | 145 | ||
@@ -163,8 +153,7 @@ prom_getstring(int node, const char *prop, char *user_buf, int ubuf_size) | |||
163 | /* Does the device at node 'node' have name 'name'? | 153 | /* Does the device at node 'node' have name 'name'? |
164 | * YES = 1 NO = 0 | 154 | * YES = 1 NO = 0 |
165 | */ | 155 | */ |
166 | int | 156 | int prom_nodematch(int node, const char *name) |
167 | prom_nodematch(int node, const char *name) | ||
168 | { | 157 | { |
169 | char namebuf[128]; | 158 | char namebuf[128]; |
170 | prom_getproperty(node, "name", namebuf, sizeof(namebuf)); | 159 | prom_getproperty(node, "name", namebuf, sizeof(namebuf)); |
@@ -175,8 +164,7 @@ prom_nodematch(int node, const char *name) | |||
175 | /* Search siblings at 'node_start' for a node with name | 164 | /* Search siblings at 'node_start' for a node with name |
176 | * 'nodename'. Return node if successful, zero if not. | 165 | * 'nodename'. Return node if successful, zero if not. |
177 | */ | 166 | */ |
178 | int | 167 | int prom_searchsiblings(int node_start, const char *nodename) |
179 | prom_searchsiblings(int node_start, const char *nodename) | ||
180 | { | 168 | { |
181 | 169 | ||
182 | int thisnode, error; | 170 | int thisnode, error; |
@@ -197,8 +185,7 @@ prom_searchsiblings(int node_start, const char *nodename) | |||
197 | /* Return the first property type for node 'node'. | 185 | /* Return the first property type for node 'node'. |
198 | * buffer should be at least 32B in length | 186 | * buffer should be at least 32B in length |
199 | */ | 187 | */ |
200 | __inline__ char * | 188 | inline char *prom_firstprop(int node, char *buffer) |
201 | prom_firstprop(int node, char *buffer) | ||
202 | { | 189 | { |
203 | *buffer = 0; | 190 | *buffer = 0; |
204 | if(node == -1) return buffer; | 191 | if(node == -1) return buffer; |
@@ -212,8 +199,7 @@ prom_firstprop(int node, char *buffer) | |||
212 | * at node 'node' . Returns NULL string if no more | 199 | * at node 'node' . Returns NULL string if no more |
213 | * property types for this node. | 200 | * property types for this node. |
214 | */ | 201 | */ |
215 | __inline__ char * | 202 | inline char *prom_nextprop(int node, const char *oprop, char *buffer) |
216 | prom_nextprop(int node, const char *oprop, char *buffer) | ||
217 | { | 203 | { |
218 | char buf[32]; | 204 | char buf[32]; |
219 | 205 | ||
@@ -279,8 +265,7 @@ prom_setprop(int node, const char *pname, char *value, int size) | |||
279 | node, pname, value, P1275_SIZE(size)); | 265 | node, pname, value, P1275_SIZE(size)); |
280 | } | 266 | } |
281 | 267 | ||
282 | __inline__ int | 268 | inline int prom_inst2pkg(int inst) |
283 | prom_inst2pkg(int inst) | ||
284 | { | 269 | { |
285 | int node; | 270 | int node; |
286 | 271 | ||
diff --git a/arch/um/Kconfig.i386 b/arch/um/Kconfig.i386 index 9876d80d85dd..e0ac74e5d4c4 100644 --- a/arch/um/Kconfig.i386 +++ b/arch/um/Kconfig.i386 | |||
@@ -1,6 +1,6 @@ | |||
1 | menu "Host processor type and features" | 1 | menu "Host processor type and features" |
2 | 2 | ||
3 | source "arch/i386/Kconfig.cpu" | 3 | source "arch/x86/Kconfig.cpu" |
4 | 4 | ||
5 | endmenu | 5 | endmenu |
6 | 6 | ||
diff --git a/arch/um/Makefile-i386 b/arch/um/Makefile-i386 index 0178df306939..b01dfb00e5f8 100644 --- a/arch/um/Makefile-i386 +++ b/arch/um/Makefile-i386 | |||
@@ -9,6 +9,7 @@ ELF_ARCH := $(SUBARCH) | |||
9 | ELF_FORMAT := elf32-$(SUBARCH) | 9 | ELF_FORMAT := elf32-$(SUBARCH) |
10 | OBJCOPYFLAGS := -O binary -R .note -R .comment -S | 10 | OBJCOPYFLAGS := -O binary -R .note -R .comment -S |
11 | HEADER_ARCH := x86 | 11 | HEADER_ARCH := x86 |
12 | CHECKFLAGS += -D__i386__ | ||
12 | 13 | ||
13 | ifeq ("$(origin SUBARCH)", "command line") | 14 | ifeq ("$(origin SUBARCH)", "command line") |
14 | ifneq ("$(shell uname -m | sed -e s/i.86/i386/)", "$(SUBARCH)") | 15 | ifneq ("$(shell uname -m | sed -e s/i.86/i386/)", "$(SUBARCH)") |
@@ -26,10 +27,8 @@ AFLAGS += -DCONFIG_X86_32 | |||
26 | CONFIG_X86_32 := y | 27 | CONFIG_X86_32 := y |
27 | export CONFIG_X86_32 | 28 | export CONFIG_X86_32 |
28 | 29 | ||
29 | ARCH_KERNEL_DEFINES += -U__$(SUBARCH)__ -U$(SUBARCH) | ||
30 | |||
31 | # First of all, tune CFLAGS for the specific CPU. This actually sets cflags-y. | 30 | # First of all, tune CFLAGS for the specific CPU. This actually sets cflags-y. |
32 | include $(srctree)/arch/i386/Makefile.cpu | 31 | include $(srctree)/arch/x86/Makefile_32.cpu |
33 | 32 | ||
34 | # prevent gcc from keeping the stack 16 byte aligned. Taken from i386. | 33 | # prevent gcc from keeping the stack 16 byte aligned. Taken from i386. |
35 | cflags-y += $(call cc-option,-mpreferred-stack-boundary=2) | 34 | cflags-y += $(call cc-option,-mpreferred-stack-boundary=2) |
diff --git a/arch/um/Makefile-x86_64 b/arch/um/Makefile-x86_64 index fe5316f0c6a5..8ed362f93582 100644 --- a/arch/um/Makefile-x86_64 +++ b/arch/um/Makefile-x86_64 | |||
@@ -6,12 +6,9 @@ START := 0x60000000 | |||
6 | 6 | ||
7 | _extra_flags_ = -fno-builtin -m64 | 7 | _extra_flags_ = -fno-builtin -m64 |
8 | 8 | ||
9 | #We #undef __x86_64__ for kernelspace, not for userspace where | ||
10 | #it's needed for headers to work! | ||
11 | ARCH_KERNEL_DEFINES = -U__$(SUBARCH)__ | ||
12 | KBUILD_CFLAGS += $(_extra_flags_) | 9 | KBUILD_CFLAGS += $(_extra_flags_) |
13 | 10 | ||
14 | CHECKFLAGS += -m64 | 11 | CHECKFLAGS += -m64 -D__x86_64__ |
15 | KBUILD_AFLAGS += -m64 | 12 | KBUILD_AFLAGS += -m64 |
16 | LDFLAGS += -m elf_x86_64 | 13 | LDFLAGS += -m elf_x86_64 |
17 | KBUILD_CPPFLAGS += -m64 | 14 | KBUILD_CPPFLAGS += -m64 |
diff --git a/arch/um/drivers/ubd_kern.c b/arch/um/drivers/ubd_kern.c index 3a8cd3dfb51c..e184b44b1011 100644 --- a/arch/um/drivers/ubd_kern.c +++ b/arch/um/drivers/ubd_kern.c | |||
@@ -35,6 +35,7 @@ | |||
35 | #include "linux/genhd.h" | 35 | #include "linux/genhd.h" |
36 | #include "linux/spinlock.h" | 36 | #include "linux/spinlock.h" |
37 | #include "linux/platform_device.h" | 37 | #include "linux/platform_device.h" |
38 | #include "linux/scatterlist.h" | ||
38 | #include "asm/segment.h" | 39 | #include "asm/segment.h" |
39 | #include "asm/uaccess.h" | 40 | #include "asm/uaccess.h" |
40 | #include "asm/irq.h" | 41 | #include "asm/irq.h" |
@@ -704,6 +705,7 @@ static int ubd_add(int n, char **error_out) | |||
704 | ubd_dev->size = ROUND_BLOCK(ubd_dev->size); | 705 | ubd_dev->size = ROUND_BLOCK(ubd_dev->size); |
705 | 706 | ||
706 | INIT_LIST_HEAD(&ubd_dev->restart); | 707 | INIT_LIST_HEAD(&ubd_dev->restart); |
708 | sg_init_table(&ubd_dev->sg, MAX_SG); | ||
707 | 709 | ||
708 | err = -ENOMEM; | 710 | err = -ENOMEM; |
709 | ubd_dev->queue = blk_init_queue(do_ubd_request, &ubd_dev->lock); | 711 | ubd_dev->queue = blk_init_queue(do_ubd_request, &ubd_dev->lock); |
diff --git a/arch/um/kernel/mem.c b/arch/um/kernel/mem.c index 8456397f5f4d..59822dee438a 100644 --- a/arch/um/kernel/mem.c +++ b/arch/um/kernel/mem.c | |||
@@ -165,7 +165,7 @@ static void __init kmap_init(void) | |||
165 | kmap_prot = PAGE_KERNEL; | 165 | kmap_prot = PAGE_KERNEL; |
166 | } | 166 | } |
167 | 167 | ||
168 | static void init_highmem(void) | 168 | static void __init init_highmem(void) |
169 | { | 169 | { |
170 | pgd_t *pgd; | 170 | pgd_t *pgd; |
171 | pud_t *pud; | 171 | pud_t *pud; |
diff --git a/arch/um/sys-i386/ptrace.c b/arch/um/sys-i386/ptrace.c index 9657c89fdf31..bd3da8a61f64 100644 --- a/arch/um/sys-i386/ptrace.c +++ b/arch/um/sys-i386/ptrace.c | |||
@@ -155,7 +155,7 @@ int get_fpregs(struct user_i387_struct __user *buf, struct task_struct *child) | |||
155 | if (err) | 155 | if (err) |
156 | return err; | 156 | return err; |
157 | 157 | ||
158 | n = copy_to_user((void *) buf, fpregs, sizeof(fpregs)); | 158 | n = copy_to_user(buf, fpregs, sizeof(fpregs)); |
159 | if(n > 0) | 159 | if(n > 0) |
160 | return -EFAULT; | 160 | return -EFAULT; |
161 | 161 | ||
@@ -168,7 +168,7 @@ int set_fpregs(struct user_i387_struct __user *buf, struct task_struct *child) | |||
168 | long fpregs[HOST_FP_SIZE]; | 168 | long fpregs[HOST_FP_SIZE]; |
169 | 169 | ||
170 | BUG_ON(sizeof(*buf) != sizeof(fpregs)); | 170 | BUG_ON(sizeof(*buf) != sizeof(fpregs)); |
171 | n = copy_from_user(fpregs, (void *) buf, sizeof(fpregs)); | 171 | n = copy_from_user(fpregs, buf, sizeof(fpregs)); |
172 | if (n > 0) | 172 | if (n > 0) |
173 | return -EFAULT; | 173 | return -EFAULT; |
174 | 174 | ||
@@ -185,7 +185,7 @@ int get_fpxregs(struct user_fxsr_struct __user *buf, struct task_struct *child) | |||
185 | if (err) | 185 | if (err) |
186 | return err; | 186 | return err; |
187 | 187 | ||
188 | n = copy_to_user((void *) buf, fpregs, sizeof(fpregs)); | 188 | n = copy_to_user(buf, fpregs, sizeof(fpregs)); |
189 | if(n > 0) | 189 | if(n > 0) |
190 | return -EFAULT; | 190 | return -EFAULT; |
191 | 191 | ||
@@ -198,7 +198,7 @@ int set_fpxregs(struct user_fxsr_struct __user *buf, struct task_struct *child) | |||
198 | long fpregs[HOST_XFP_SIZE]; | 198 | long fpregs[HOST_XFP_SIZE]; |
199 | 199 | ||
200 | BUG_ON(sizeof(*buf) != sizeof(fpregs)); | 200 | BUG_ON(sizeof(*buf) != sizeof(fpregs)); |
201 | n = copy_from_user(fpregs, (void *) buf, sizeof(fpregs)); | 201 | n = copy_from_user(fpregs, buf, sizeof(fpregs)); |
202 | if (n > 0) | 202 | if (n > 0) |
203 | return -EFAULT; | 203 | return -EFAULT; |
204 | 204 | ||
diff --git a/arch/um/sys-x86_64/ptrace.c b/arch/um/sys-x86_64/ptrace.c index a3cfeed17af4..b7631b0e9ddc 100644 --- a/arch/um/sys-x86_64/ptrace.c +++ b/arch/um/sys-x86_64/ptrace.c | |||
@@ -154,7 +154,7 @@ int get_fpregs(struct user_i387_struct __user *buf, struct task_struct *child) | |||
154 | if (err) | 154 | if (err) |
155 | return err; | 155 | return err; |
156 | 156 | ||
157 | n = copy_to_user((void *) buf, fpregs, sizeof(fpregs)); | 157 | n = copy_to_user(buf, fpregs, sizeof(fpregs)); |
158 | if(n > 0) | 158 | if(n > 0) |
159 | return -EFAULT; | 159 | return -EFAULT; |
160 | 160 | ||
@@ -167,7 +167,7 @@ int set_fpregs(struct user_i387_struct __user *buf, struct task_struct *child) | |||
167 | long fpregs[HOST_FP_SIZE]; | 167 | long fpregs[HOST_FP_SIZE]; |
168 | 168 | ||
169 | BUG_ON(sizeof(*buf) != sizeof(fpregs)); | 169 | BUG_ON(sizeof(*buf) != sizeof(fpregs)); |
170 | n = copy_from_user(fpregs, (void *) buf, sizeof(fpregs)); | 170 | n = copy_from_user(fpregs, buf, sizeof(fpregs)); |
171 | if (n > 0) | 171 | if (n > 0) |
172 | return -EFAULT; | 172 | return -EFAULT; |
173 | 173 | ||
diff --git a/arch/i386/Kconfig.cpu b/arch/x86/Kconfig.cpu index 0e2adadf5905..0e2adadf5905 100644 --- a/arch/i386/Kconfig.cpu +++ b/arch/x86/Kconfig.cpu | |||
diff --git a/arch/i386/Kconfig.debug b/arch/x86/Kconfig.debug index f03531eacdfb..761ca7b5f120 100644 --- a/arch/i386/Kconfig.debug +++ b/arch/x86/Kconfig.debug | |||
@@ -1,13 +1,12 @@ | |||
1 | menu "Kernel hacking" | 1 | menu "Kernel hacking" |
2 | 2 | ||
3 | config TRACE_IRQFLAGS_SUPPORT | 3 | config TRACE_IRQFLAGS_SUPPORT |
4 | bool | 4 | def_bool y |
5 | default y | ||
6 | 5 | ||
7 | source "lib/Kconfig.debug" | 6 | source "lib/Kconfig.debug" |
8 | 7 | ||
9 | config EARLY_PRINTK | 8 | config EARLY_PRINTK |
10 | bool "Early printk" if EMBEDDED && DEBUG_KERNEL | 9 | bool "Early printk" if EMBEDDED && DEBUG_KERNEL && X86_32 |
11 | default y | 10 | default y |
12 | help | 11 | help |
13 | Write kernel log output directly into the VGA buffer or to a serial | 12 | Write kernel log output directly into the VGA buffer or to a serial |
@@ -37,10 +36,12 @@ config DEBUG_STACK_USAGE | |||
37 | 36 | ||
38 | comment "Page alloc debug is incompatible with Software Suspend on i386" | 37 | comment "Page alloc debug is incompatible with Software Suspend on i386" |
39 | depends on DEBUG_KERNEL && HIBERNATION | 38 | depends on DEBUG_KERNEL && HIBERNATION |
39 | depends on X86_32 | ||
40 | 40 | ||
41 | config DEBUG_PAGEALLOC | 41 | config DEBUG_PAGEALLOC |
42 | bool "Debug page memory allocations" | 42 | bool "Debug page memory allocations" |
43 | depends on DEBUG_KERNEL && !HIBERNATION && !HUGETLBFS | 43 | depends on DEBUG_KERNEL && !HIBERNATION && !HUGETLBFS |
44 | depends on X86_32 | ||
44 | help | 45 | help |
45 | Unmap pages from the kernel linear mapping after free_pages(). | 46 | Unmap pages from the kernel linear mapping after free_pages(). |
46 | This results in a large slowdown, but helps to find certain types | 47 | This results in a large slowdown, but helps to find certain types |
@@ -59,6 +60,7 @@ config DEBUG_RODATA | |||
59 | config 4KSTACKS | 60 | config 4KSTACKS |
60 | bool "Use 4Kb for kernel stacks instead of 8Kb" | 61 | bool "Use 4Kb for kernel stacks instead of 8Kb" |
61 | depends on DEBUG_KERNEL | 62 | depends on DEBUG_KERNEL |
63 | depends on X86_32 | ||
62 | help | 64 | help |
63 | If you say Y here the kernel will use a 4Kb stacksize for the | 65 | If you say Y here the kernel will use a 4Kb stacksize for the |
64 | kernel stack attached to each process/thread. This facilitates | 66 | kernel stack attached to each process/thread. This facilitates |
@@ -67,22 +69,47 @@ config 4KSTACKS | |||
67 | will also use IRQ stacks to compensate for the reduced stackspace. | 69 | will also use IRQ stacks to compensate for the reduced stackspace. |
68 | 70 | ||
69 | config X86_FIND_SMP_CONFIG | 71 | config X86_FIND_SMP_CONFIG |
70 | bool | 72 | def_bool y |
71 | depends on X86_LOCAL_APIC || X86_VOYAGER | 73 | depends on X86_LOCAL_APIC || X86_VOYAGER |
72 | default y | 74 | depends on X86_32 |
73 | 75 | ||
74 | config X86_MPPARSE | 76 | config X86_MPPARSE |
75 | bool | 77 | def_bool y |
76 | depends on X86_LOCAL_APIC && !X86_VISWS | 78 | depends on X86_LOCAL_APIC && !X86_VISWS |
77 | default y | 79 | depends on X86_32 |
78 | 80 | ||
79 | config DOUBLEFAULT | 81 | config DOUBLEFAULT |
80 | default y | 82 | default y |
81 | bool "Enable doublefault exception handler" if EMBEDDED | 83 | bool "Enable doublefault exception handler" if EMBEDDED |
84 | depends on X86_32 | ||
85 | help | ||
86 | This option allows trapping of rare doublefault exceptions that | ||
87 | would otherwise cause a system to silently reboot. Disabling this | ||
88 | option saves about 4k and might cause you much additional grey | ||
89 | hair. | ||
90 | |||
91 | config IOMMU_DEBUG | ||
92 | bool "Enable IOMMU debugging" | ||
93 | depends on GART_IOMMU && DEBUG_KERNEL | ||
94 | depends on X86_64 | ||
95 | help | ||
96 | Force the IOMMU to on even when you have less than 4GB of | ||
97 | memory and add debugging code. On overflow always panic. And | ||
98 | allow to enable IOMMU leak tracing. Can be disabled at boot | ||
99 | time with iommu=noforce. This will also enable scatter gather | ||
100 | list merging. Currently not recommended for production | ||
101 | code. When you use it make sure you have a big enough | ||
102 | IOMMU/AGP aperture. Most of the options enabled by this can | ||
103 | be set more finegrained using the iommu= command line | ||
104 | options. See Documentation/x86_64/boot-options.txt for more | ||
105 | details. | ||
106 | |||
107 | config IOMMU_LEAK | ||
108 | bool "IOMMU leak tracing" | ||
109 | depends on DEBUG_KERNEL | ||
110 | depends on IOMMU_DEBUG | ||
82 | help | 111 | help |
83 | This option allows trapping of rare doublefault exceptions that | 112 | Add a simple leak tracer to the IOMMU code. This is useful when you |
84 | would otherwise cause a system to silently reboot. Disabling this | 113 | are debugging a buggy device driver that leaks IOMMU mappings. |
85 | option saves about 4k and might cause you much additional grey | ||
86 | hair. | ||
87 | 114 | ||
88 | endmenu | 115 | endmenu |
diff --git a/arch/i386/Kconfig b/arch/x86/Kconfig.i386 index b4437ce0f973..7331efe891a7 100644 --- a/arch/i386/Kconfig +++ b/arch/x86/Kconfig.i386 | |||
@@ -287,7 +287,7 @@ config ES7000_CLUSTERED_APIC | |||
287 | default y | 287 | default y |
288 | depends on SMP && X86_ES7000 && MPENTIUMIII | 288 | depends on SMP && X86_ES7000 && MPENTIUMIII |
289 | 289 | ||
290 | source "arch/i386/Kconfig.cpu" | 290 | source "arch/x86/Kconfig.cpu" |
291 | 291 | ||
292 | config HPET_TIMER | 292 | config HPET_TIMER |
293 | bool "HPET Timer Support" | 293 | bool "HPET Timer Support" |
@@ -1272,7 +1272,7 @@ source "fs/Kconfig" | |||
1272 | 1272 | ||
1273 | source "kernel/Kconfig.instrumentation" | 1273 | source "kernel/Kconfig.instrumentation" |
1274 | 1274 | ||
1275 | source "arch/i386/Kconfig.debug" | 1275 | source "arch/x86/Kconfig.debug" |
1276 | 1276 | ||
1277 | source "security/Kconfig" | 1277 | source "security/Kconfig" |
1278 | 1278 | ||
diff --git a/arch/x86_64/Kconfig b/arch/x86/Kconfig.x86_64 index 308970aa5382..cc468ea61240 100644 --- a/arch/x86_64/Kconfig +++ b/arch/x86/Kconfig.x86_64 | |||
@@ -97,10 +97,6 @@ config X86_CMPXCHG | |||
97 | bool | 97 | bool |
98 | default y | 98 | default y |
99 | 99 | ||
100 | config EARLY_PRINTK | ||
101 | bool | ||
102 | default y | ||
103 | |||
104 | config GENERIC_ISA_DMA | 100 | config GENERIC_ISA_DMA |
105 | bool | 101 | bool |
106 | default y | 102 | default y |
@@ -479,8 +475,8 @@ config HPET_EMULATE_RTC | |||
479 | 475 | ||
480 | # Mark as embedded because too many people got it wrong. | 476 | # Mark as embedded because too many people got it wrong. |
481 | # The code disables itself when not needed. | 477 | # The code disables itself when not needed. |
482 | config IOMMU | 478 | config GART_IOMMU |
483 | bool "IOMMU support" if EMBEDDED | 479 | bool "GART IOMMU support" if EMBEDDED |
484 | default y | 480 | default y |
485 | select SWIOTLB | 481 | select SWIOTLB |
486 | select AGP | 482 | select AGP |
@@ -687,7 +683,7 @@ source kernel/Kconfig.hz | |||
687 | 683 | ||
688 | config K8_NB | 684 | config K8_NB |
689 | def_bool y | 685 | def_bool y |
690 | depends on AGP_AMD64 || IOMMU || (PCI && NUMA) | 686 | depends on AGP_AMD64 || GART_IOMMU || (PCI && NUMA) |
691 | 687 | ||
692 | endmenu | 688 | endmenu |
693 | 689 | ||
@@ -753,7 +749,6 @@ config PCI_DOMAINS | |||
753 | config DMAR | 749 | config DMAR |
754 | bool "Support for DMA Remapping Devices (EXPERIMENTAL)" | 750 | bool "Support for DMA Remapping Devices (EXPERIMENTAL)" |
755 | depends on PCI_MSI && ACPI && EXPERIMENTAL | 751 | depends on PCI_MSI && ACPI && EXPERIMENTAL |
756 | default y | ||
757 | help | 752 | help |
758 | DMA remapping (DMAR) devices support enables independent address | 753 | DMA remapping (DMAR) devices support enables independent address |
759 | translations for Direct Memory Access (DMA) from devices. | 754 | translations for Direct Memory Access (DMA) from devices. |
@@ -835,7 +830,7 @@ source fs/Kconfig | |||
835 | 830 | ||
836 | source "kernel/Kconfig.instrumentation" | 831 | source "kernel/Kconfig.instrumentation" |
837 | 832 | ||
838 | source "arch/x86_64/Kconfig.debug" | 833 | source "arch/x86/Kconfig.debug" |
839 | 834 | ||
840 | source "security/Kconfig" | 835 | source "security/Kconfig" |
841 | 836 | ||
diff --git a/arch/x86/Makefile b/arch/x86/Makefile new file mode 100644 index 000000000000..309597386a77 --- /dev/null +++ b/arch/x86/Makefile | |||
@@ -0,0 +1,16 @@ | |||
1 | # Unified Makefile for i386 and x86_64 | ||
2 | |||
3 | # select defconfig based on actual architecture | ||
4 | KBUILD_DEFCONFIG := $(ARCH)_defconfig | ||
5 | |||
6 | # # No need to remake these files | ||
7 | $(srctree)/arch/x86/Makefile%: ; | ||
8 | |||
9 | ifeq ($(ARCH),i386) | ||
10 | include $(srctree)/arch/x86/Makefile_32 | ||
11 | else | ||
12 | include $(srctree)/arch/x86/Makefile_64 | ||
13 | endif | ||
14 | |||
15 | |||
16 | |||
diff --git a/arch/i386/Makefile b/arch/x86/Makefile_32 index f5b9a37def8b..346ac0766875 100644 --- a/arch/i386/Makefile +++ b/arch/x86/Makefile_32 | |||
@@ -1,5 +1,5 @@ | |||
1 | # | 1 | # |
2 | # i386/Makefile | 2 | # i386 Makefile |
3 | # | 3 | # |
4 | # This file is included by the global makefile so that you can add your own | 4 | # This file is included by the global makefile so that you can add your own |
5 | # architecture-specific flags and dependencies. Remember to do have actions | 5 | # architecture-specific flags and dependencies. Remember to do have actions |
@@ -17,9 +17,6 @@ | |||
17 | # 20050320 Kianusch Sayah Karadji <kianusch@sk-tech.net> | 17 | # 20050320 Kianusch Sayah Karadji <kianusch@sk-tech.net> |
18 | # Added support for GEODE CPU | 18 | # Added support for GEODE CPU |
19 | 19 | ||
20 | # Fill in SRCARCH | ||
21 | SRCARCH := x86 | ||
22 | |||
23 | # BITS is used as extension for files which are available in a 32 bit | 20 | # BITS is used as extension for files which are available in a 32 bit |
24 | # and a 64 bit version to simplify shared Makefiles. | 21 | # and a 64 bit version to simplify shared Makefiles. |
25 | # e.g.: obj-y += foo_$(BITS).o | 22 | # e.g.: obj-y += foo_$(BITS).o |
@@ -46,7 +43,7 @@ KBUILD_CFLAGS += -pipe -msoft-float -mregparm=3 -freg-struct-return | |||
46 | KBUILD_CFLAGS += $(call cc-option,-mpreferred-stack-boundary=2) | 43 | KBUILD_CFLAGS += $(call cc-option,-mpreferred-stack-boundary=2) |
47 | 44 | ||
48 | # CPU-specific tuning. Anything which can be shared with UML should go here. | 45 | # CPU-specific tuning. Anything which can be shared with UML should go here. |
49 | include $(srctree)/arch/i386/Makefile.cpu | 46 | include $(srctree)/arch/x86/Makefile_32.cpu |
50 | 47 | ||
51 | # temporary until string.h is fixed | 48 | # temporary until string.h is fixed |
52 | cflags-y += -ffreestanding | 49 | cflags-y += -ffreestanding |
diff --git a/arch/i386/Makefile.cpu b/arch/x86/Makefile_32.cpu index e372b584e919..e372b584e919 100644 --- a/arch/i386/Makefile.cpu +++ b/arch/x86/Makefile_32.cpu | |||
diff --git a/arch/x86_64/Makefile b/arch/x86/Makefile_64 index 20eb69bd5a6d..57e714a47af7 100644 --- a/arch/x86_64/Makefile +++ b/arch/x86/Makefile_64 | |||
@@ -1,5 +1,5 @@ | |||
1 | # | 1 | # |
2 | # x86_64/Makefile | 2 | # x86_64 Makefile |
3 | # | 3 | # |
4 | # This file is included by the global makefile so that you can add your own | 4 | # This file is included by the global makefile so that you can add your own |
5 | # architecture-specific flags and dependencies. Remember to do have actions | 5 | # architecture-specific flags and dependencies. Remember to do have actions |
@@ -21,9 +21,6 @@ | |||
21 | # | 21 | # |
22 | # $Id: Makefile,v 1.31 2002/03/22 15:56:07 ak Exp $ | 22 | # $Id: Makefile,v 1.31 2002/03/22 15:56:07 ak Exp $ |
23 | 23 | ||
24 | # Fill in SRCARCH | ||
25 | SRCARCH := x86 | ||
26 | |||
27 | # BITS is used as extension for files which are available in a 32 bit | 24 | # BITS is used as extension for files which are available in a 32 bit |
28 | # and a 64 bit version to simplify shared Makefiles. | 25 | # and a 64 bit version to simplify shared Makefiles. |
29 | # e.g.: obj-y += foo_$(BITS).o | 26 | # e.g.: obj-y += foo_$(BITS).o |
diff --git a/arch/x86/boot/boot.h b/arch/x86/boot/boot.h index 5f9a2e72a731..d2b5adf46512 100644 --- a/arch/x86/boot/boot.h +++ b/arch/x86/boot/boot.h | |||
@@ -17,6 +17,8 @@ | |||
17 | #ifndef BOOT_BOOT_H | 17 | #ifndef BOOT_BOOT_H |
18 | #define BOOT_BOOT_H | 18 | #define BOOT_BOOT_H |
19 | 19 | ||
20 | #define STACK_SIZE 512 /* Minimum number of bytes for stack */ | ||
21 | |||
20 | #ifndef __ASSEMBLY__ | 22 | #ifndef __ASSEMBLY__ |
21 | 23 | ||
22 | #include <stdarg.h> | 24 | #include <stdarg.h> |
@@ -198,8 +200,6 @@ static inline int isdigit(int ch) | |||
198 | } | 200 | } |
199 | 201 | ||
200 | /* Heap -- available for dynamic lists. */ | 202 | /* Heap -- available for dynamic lists. */ |
201 | #define STACK_SIZE 512 /* Minimum number of bytes for stack */ | ||
202 | |||
203 | extern char _end[]; | 203 | extern char _end[]; |
204 | extern char *HEAP; | 204 | extern char *HEAP; |
205 | extern char *heap_end; | 205 | extern char *heap_end; |
@@ -216,9 +216,9 @@ static inline char *__get_heap(size_t s, size_t a, size_t n) | |||
216 | #define GET_HEAP(type, n) \ | 216 | #define GET_HEAP(type, n) \ |
217 | ((type *)__get_heap(sizeof(type),__alignof__(type),(n))) | 217 | ((type *)__get_heap(sizeof(type),__alignof__(type),(n))) |
218 | 218 | ||
219 | static inline int heap_free(void) | 219 | static inline bool heap_free(size_t n) |
220 | { | 220 | { |
221 | return heap_end-HEAP; | 221 | return (int)(heap_end-HEAP) >= (int)n; |
222 | } | 222 | } |
223 | 223 | ||
224 | /* copy.S */ | 224 | /* copy.S */ |
diff --git a/arch/x86/boot/compressed/head_32.S b/arch/x86/boot/compressed/head_32.S index a0ae2e7f6cec..036e635f18a3 100644 --- a/arch/x86/boot/compressed/head_32.S +++ b/arch/x86/boot/compressed/head_32.S | |||
@@ -33,24 +33,20 @@ | |||
33 | .globl startup_32 | 33 | .globl startup_32 |
34 | 34 | ||
35 | startup_32: | 35 | startup_32: |
36 | /* check to see if KEEP_SEGMENTS flag is meaningful */ | 36 | cld |
37 | cmpw $0x207, BP_version(%esi) | ||
38 | jb 1f | ||
39 | |||
40 | /* test KEEP_SEGMENTS flag to see if the bootloader is asking | 37 | /* test KEEP_SEGMENTS flag to see if the bootloader is asking |
41 | * us to not reload segments */ | 38 | * us to not reload segments */ |
42 | testb $(1<<6), BP_loadflags(%esi) | 39 | testb $(1<<6), BP_loadflags(%esi) |
43 | jnz 2f | 40 | jnz 1f |
44 | 41 | ||
45 | 1: cli | 42 | cli |
46 | movl $(__BOOT_DS),%eax | 43 | movl $(__BOOT_DS),%eax |
47 | movl %eax,%ds | 44 | movl %eax,%ds |
48 | movl %eax,%es | 45 | movl %eax,%es |
49 | movl %eax,%fs | 46 | movl %eax,%fs |
50 | movl %eax,%gs | 47 | movl %eax,%gs |
51 | movl %eax,%ss | 48 | movl %eax,%ss |
52 | 49 | 1: | |
53 | 2: cld | ||
54 | 50 | ||
55 | /* Calculate the delta between where we were compiled to run | 51 | /* Calculate the delta between where we were compiled to run |
56 | * at and where we were actually loaded at. This can only be done | 52 | * at and where we were actually loaded at. This can only be done |
diff --git a/arch/x86/boot/compressed/head_64.S b/arch/x86/boot/compressed/head_64.S index 49467640751f..1ccb38a7f0d2 100644 --- a/arch/x86/boot/compressed/head_64.S +++ b/arch/x86/boot/compressed/head_64.S | |||
@@ -29,6 +29,7 @@ | |||
29 | #include <asm/pgtable.h> | 29 | #include <asm/pgtable.h> |
30 | #include <asm/page.h> | 30 | #include <asm/page.h> |
31 | #include <asm/msr.h> | 31 | #include <asm/msr.h> |
32 | #include <asm/asm-offsets.h> | ||
32 | 33 | ||
33 | .section ".text.head" | 34 | .section ".text.head" |
34 | .code32 | 35 | .code32 |
@@ -36,11 +37,17 @@ | |||
36 | 37 | ||
37 | startup_32: | 38 | startup_32: |
38 | cld | 39 | cld |
40 | /* test KEEP_SEGMENTS flag to see if the bootloader is asking | ||
41 | * us to not reload segments */ | ||
42 | testb $(1<<6), BP_loadflags(%esi) | ||
43 | jnz 1f | ||
44 | |||
39 | cli | 45 | cli |
40 | movl $(__KERNEL_DS), %eax | 46 | movl $(__KERNEL_DS), %eax |
41 | movl %eax, %ds | 47 | movl %eax, %ds |
42 | movl %eax, %es | 48 | movl %eax, %es |
43 | movl %eax, %ss | 49 | movl %eax, %ss |
50 | 1: | ||
44 | 51 | ||
45 | /* Calculate the delta between where we were compiled to run | 52 | /* Calculate the delta between where we were compiled to run |
46 | * at and where we were actually loaded at. This can only be done | 53 | * at and where we were actually loaded at. This can only be done |
diff --git a/arch/x86/boot/header.S b/arch/x86/boot/header.S index 8353c81c41c0..6ef5a060fa11 100644 --- a/arch/x86/boot/header.S +++ b/arch/x86/boot/header.S | |||
@@ -173,7 +173,8 @@ ramdisk_size: .long 0 # its size in bytes | |||
173 | bootsect_kludge: | 173 | bootsect_kludge: |
174 | .long 0 # obsolete | 174 | .long 0 # obsolete |
175 | 175 | ||
176 | heap_end_ptr: .word _end+1024 # (Header version 0x0201 or later) | 176 | heap_end_ptr: .word _end+STACK_SIZE-512 |
177 | # (Header version 0x0201 or later) | ||
177 | # space from here (exclusive) down to | 178 | # space from here (exclusive) down to |
178 | # end of setup code can be used by setup | 179 | # end of setup code can be used by setup |
179 | # for local heap purposes. | 180 | # for local heap purposes. |
@@ -230,28 +231,53 @@ start_of_setup: | |||
230 | int $0x13 | 231 | int $0x13 |
231 | #endif | 232 | #endif |
232 | 233 | ||
233 | # We will have entered with %cs = %ds+0x20, normalize %cs so | ||
234 | # it is on par with the other segments. | ||
235 | pushw %ds | ||
236 | pushw $setup2 | ||
237 | lretw | ||
238 | |||
239 | setup2: | ||
240 | # Force %es = %ds | 234 | # Force %es = %ds |
241 | movw %ds, %ax | 235 | movw %ds, %ax |
242 | movw %ax, %es | 236 | movw %ax, %es |
243 | cld | 237 | cld |
244 | 238 | ||
245 | # Stack paranoia: align the stack and make sure it is good | 239 | # Apparently some ancient versions of LILO invoked the kernel |
246 | # for both 16- and 32-bit references. In particular, if we | 240 | # with %ss != %ds, which happened to work by accident for the |
247 | # were meant to have been using the full 16-bit segment, the | 241 | # old code. If the CAN_USE_HEAP flag is set in loadflags, or |
248 | # caller might have set %sp to zero, which breaks %esp-based | 242 | # %ss != %ds, then adjust the stack pointer. |
249 | # references. | 243 | |
250 | andw $~3, %sp # dword align (might as well...) | 244 | # Smallest possible stack we can tolerate |
251 | jnz 1f | 245 | movw $(_end+STACK_SIZE), %cx |
252 | movw $0xfffc, %sp # Make sure we're not zero | 246 | |
253 | 1: movzwl %sp, %esp # Clear upper half of %esp | 247 | movw heap_end_ptr, %dx |
254 | sti | 248 | addw $512, %dx |
249 | jnc 1f | ||
250 | xorw %dx, %dx # Wraparound - whole segment available | ||
251 | 1: testb $CAN_USE_HEAP, loadflags | ||
252 | jnz 2f | ||
253 | |||
254 | # No CAN_USE_HEAP | ||
255 | movw %ss, %dx | ||
256 | cmpw %ax, %dx # %ds == %ss? | ||
257 | movw %sp, %dx | ||
258 | # If so, assume %sp is reasonably set, otherwise use | ||
259 | # the smallest possible stack. | ||
260 | jne 4f # -> Smallest possible stack... | ||
261 | |||
262 | # Make sure the stack is at least minimum size. Take a value | ||
263 | # of zero to mean "full segment." | ||
264 | 2: | ||
265 | andw $~3, %dx # dword align (might as well...) | ||
266 | jnz 3f | ||
267 | movw $0xfffc, %dx # Make sure we're not zero | ||
268 | 3: cmpw %cx, %dx | ||
269 | jnb 5f | ||
270 | 4: movw %cx, %dx # Minimum value we can possibly use | ||
271 | 5: movw %ax, %ss | ||
272 | movzwl %dx, %esp # Clear upper half of %esp | ||
273 | sti # Now we should have a working stack | ||
274 | |||
275 | # We will have entered with %cs = %ds+0x20, normalize %cs so | ||
276 | # it is on par with the other segments. | ||
277 | pushw %ds | ||
278 | pushw $6f | ||
279 | lretw | ||
280 | 6: | ||
255 | 281 | ||
256 | # Check signature at end of setup | 282 | # Check signature at end of setup |
257 | cmpl $0x5a5aaa55, setup_sig | 283 | cmpl $0x5a5aaa55, setup_sig |
diff --git a/arch/x86/boot/video-bios.c b/arch/x86/boot/video-bios.c index 68e65d95cdfd..ed0672a81870 100644 --- a/arch/x86/boot/video-bios.c +++ b/arch/x86/boot/video-bios.c | |||
@@ -79,7 +79,7 @@ static int bios_probe(void) | |||
79 | video_bios.modes = GET_HEAP(struct mode_info, 0); | 79 | video_bios.modes = GET_HEAP(struct mode_info, 0); |
80 | 80 | ||
81 | for (mode = 0x14; mode <= 0x7f; mode++) { | 81 | for (mode = 0x14; mode <= 0x7f; mode++) { |
82 | if (heap_free() < sizeof(struct mode_info)) | 82 | if (!heap_free(sizeof(struct mode_info))) |
83 | break; | 83 | break; |
84 | 84 | ||
85 | if (mode_defined(VIDEO_FIRST_BIOS+mode)) | 85 | if (mode_defined(VIDEO_FIRST_BIOS+mode)) |
diff --git a/arch/x86/boot/video-vesa.c b/arch/x86/boot/video-vesa.c index 192190710710..4716b9a96357 100644 --- a/arch/x86/boot/video-vesa.c +++ b/arch/x86/boot/video-vesa.c | |||
@@ -57,7 +57,7 @@ static int vesa_probe(void) | |||
57 | while ((mode = rdfs16(mode_ptr)) != 0xffff) { | 57 | while ((mode = rdfs16(mode_ptr)) != 0xffff) { |
58 | mode_ptr += 2; | 58 | mode_ptr += 2; |
59 | 59 | ||
60 | if (heap_free() < sizeof(struct mode_info)) | 60 | if (!heap_free(sizeof(struct mode_info))) |
61 | break; /* Heap full, can't save mode info */ | 61 | break; /* Heap full, can't save mode info */ |
62 | 62 | ||
63 | if (mode & ~0x1ff) | 63 | if (mode & ~0x1ff) |
diff --git a/arch/x86/boot/video.c b/arch/x86/boot/video.c index e4ba897bf9a3..ad9712f01739 100644 --- a/arch/x86/boot/video.c +++ b/arch/x86/boot/video.c | |||
@@ -371,7 +371,7 @@ static void save_screen(void) | |||
371 | saved.curx = boot_params.screen_info.orig_x; | 371 | saved.curx = boot_params.screen_info.orig_x; |
372 | saved.cury = boot_params.screen_info.orig_y; | 372 | saved.cury = boot_params.screen_info.orig_y; |
373 | 373 | ||
374 | if (heap_free() < saved.x*saved.y*sizeof(u16)+512) | 374 | if (!heap_free(saved.x*saved.y*sizeof(u16)+512)) |
375 | return; /* Not enough heap to save the screen */ | 375 | return; /* Not enough heap to save the screen */ |
376 | 376 | ||
377 | saved.data = GET_HEAP(u16, saved.x*saved.y); | 377 | saved.data = GET_HEAP(u16, saved.x*saved.y); |
diff --git a/arch/i386/defconfig b/arch/x86/configs/i386_defconfig index 54ee1764fdae..54ee1764fdae 100644 --- a/arch/i386/defconfig +++ b/arch/x86/configs/i386_defconfig | |||
diff --git a/arch/x86_64/defconfig b/arch/x86/configs/x86_64_defconfig index b091c5e35558..38a83f9c966f 100644 --- a/arch/x86_64/defconfig +++ b/arch/x86/configs/x86_64_defconfig | |||
@@ -170,7 +170,7 @@ CONFIG_HOTPLUG_CPU=y | |||
170 | CONFIG_ARCH_ENABLE_MEMORY_HOTPLUG=y | 170 | CONFIG_ARCH_ENABLE_MEMORY_HOTPLUG=y |
171 | CONFIG_HPET_TIMER=y | 171 | CONFIG_HPET_TIMER=y |
172 | CONFIG_HPET_EMULATE_RTC=y | 172 | CONFIG_HPET_EMULATE_RTC=y |
173 | CONFIG_IOMMU=y | 173 | CONFIG_GART_IOMMU=y |
174 | # CONFIG_CALGARY_IOMMU is not set | 174 | # CONFIG_CALGARY_IOMMU is not set |
175 | CONFIG_SWIOTLB=y | 175 | CONFIG_SWIOTLB=y |
176 | CONFIG_X86_MCE=y | 176 | CONFIG_X86_MCE=y |
diff --git a/arch/x86/kernel/Makefile_64 b/arch/x86/kernel/Makefile_64 index 466337ae9a1e..24671c3838b3 100644 --- a/arch/x86/kernel/Makefile_64 +++ b/arch/x86/kernel/Makefile_64 | |||
@@ -25,7 +25,7 @@ obj-$(CONFIG_CRASH_DUMP) += crash_dump_64.o | |||
25 | obj-$(CONFIG_PM) += suspend_64.o | 25 | obj-$(CONFIG_PM) += suspend_64.o |
26 | obj-$(CONFIG_HIBERNATION) += suspend_asm_64.o | 26 | obj-$(CONFIG_HIBERNATION) += suspend_asm_64.o |
27 | obj-$(CONFIG_EARLY_PRINTK) += early_printk.o | 27 | obj-$(CONFIG_EARLY_PRINTK) += early_printk.o |
28 | obj-$(CONFIG_IOMMU) += pci-gart_64.o aperture_64.o | 28 | obj-$(CONFIG_GART_IOMMU) += pci-gart_64.o aperture_64.o |
29 | obj-$(CONFIG_CALGARY_IOMMU) += pci-calgary_64.o tce_64.o | 29 | obj-$(CONFIG_CALGARY_IOMMU) += pci-calgary_64.o tce_64.o |
30 | obj-$(CONFIG_SWIOTLB) += pci-swiotlb_64.o | 30 | obj-$(CONFIG_SWIOTLB) += pci-swiotlb_64.o |
31 | obj-$(CONFIG_KPROBES) += kprobes_64.o | 31 | obj-$(CONFIG_KPROBES) += kprobes_64.o |
diff --git a/arch/x86/kernel/acpi/processor.c b/arch/x86/kernel/acpi/processor.c index 2ed0a4ce62f0..f63e5ff0aca1 100644 --- a/arch/x86/kernel/acpi/processor.c +++ b/arch/x86/kernel/acpi/processor.c | |||
@@ -62,8 +62,7 @@ static void init_intel_pdc(struct acpi_processor *pr, struct cpuinfo_x86 *c) | |||
62 | /* Initialize _PDC data based on the CPU vendor */ | 62 | /* Initialize _PDC data based on the CPU vendor */ |
63 | void arch_acpi_processor_init_pdc(struct acpi_processor *pr) | 63 | void arch_acpi_processor_init_pdc(struct acpi_processor *pr) |
64 | { | 64 | { |
65 | unsigned int cpu = pr->id; | 65 | struct cpuinfo_x86 *c = &cpu_data(pr->id); |
66 | struct cpuinfo_x86 *c = &cpu_data(cpu); | ||
67 | 66 | ||
68 | pr->pdc = NULL; | 67 | pr->pdc = NULL; |
69 | if (c->x86_vendor == X86_VENDOR_INTEL) | 68 | if (c->x86_vendor == X86_VENDOR_INTEL) |
diff --git a/arch/x86/kernel/aperture_64.c b/arch/x86/kernel/aperture_64.c index 8f681cae7bf7..5b6992799c9d 100644 --- a/arch/x86/kernel/aperture_64.c +++ b/arch/x86/kernel/aperture_64.c | |||
@@ -20,14 +20,14 @@ | |||
20 | #include <linux/ioport.h> | 20 | #include <linux/ioport.h> |
21 | #include <asm/e820.h> | 21 | #include <asm/e820.h> |
22 | #include <asm/io.h> | 22 | #include <asm/io.h> |
23 | #include <asm/iommu.h> | 23 | #include <asm/gart.h> |
24 | #include <asm/pci-direct.h> | 24 | #include <asm/pci-direct.h> |
25 | #include <asm/dma.h> | 25 | #include <asm/dma.h> |
26 | #include <asm/k8.h> | 26 | #include <asm/k8.h> |
27 | 27 | ||
28 | int iommu_aperture; | 28 | int gart_iommu_aperture; |
29 | int iommu_aperture_disabled __initdata = 0; | 29 | int gart_iommu_aperture_disabled __initdata = 0; |
30 | int iommu_aperture_allowed __initdata = 0; | 30 | int gart_iommu_aperture_allowed __initdata = 0; |
31 | 31 | ||
32 | int fallback_aper_order __initdata = 1; /* 64MB */ | 32 | int fallback_aper_order __initdata = 1; /* 64MB */ |
33 | int fallback_aper_force __initdata = 0; | 33 | int fallback_aper_force __initdata = 0; |
@@ -204,14 +204,15 @@ static __u32 __init search_agp_bridge(u32 *order, int *valid_agp) | |||
204 | return 0; | 204 | return 0; |
205 | } | 205 | } |
206 | 206 | ||
207 | void __init iommu_hole_init(void) | 207 | void __init gart_iommu_hole_init(void) |
208 | { | 208 | { |
209 | int fix, num; | 209 | int fix, num; |
210 | u32 aper_size, aper_alloc = 0, aper_order = 0, last_aper_order = 0; | 210 | u32 aper_size, aper_alloc = 0, aper_order = 0, last_aper_order = 0; |
211 | u64 aper_base, last_aper_base = 0; | 211 | u64 aper_base, last_aper_base = 0; |
212 | int valid_agp = 0; | 212 | int valid_agp = 0; |
213 | 213 | ||
214 | if (iommu_aperture_disabled || !fix_aperture || !early_pci_allowed()) | 214 | if (gart_iommu_aperture_disabled || !fix_aperture || |
215 | !early_pci_allowed()) | ||
215 | return; | 216 | return; |
216 | 217 | ||
217 | printk(KERN_INFO "Checking aperture...\n"); | 218 | printk(KERN_INFO "Checking aperture...\n"); |
@@ -222,7 +223,7 @@ void __init iommu_hole_init(void) | |||
222 | continue; | 223 | continue; |
223 | 224 | ||
224 | iommu_detected = 1; | 225 | iommu_detected = 1; |
225 | iommu_aperture = 1; | 226 | gart_iommu_aperture = 1; |
226 | 227 | ||
227 | aper_order = (read_pci_config(0, num, 3, 0x90) >> 1) & 7; | 228 | aper_order = (read_pci_config(0, num, 3, 0x90) >> 1) & 7; |
228 | aper_size = (32 * 1024 * 1024) << aper_order; | 229 | aper_size = (32 * 1024 * 1024) << aper_order; |
diff --git a/arch/x86/kernel/asm-offsets_64.c b/arch/x86/kernel/asm-offsets_64.c index 7e50bda565b4..d1b6ed98774e 100644 --- a/arch/x86/kernel/asm-offsets_64.c +++ b/arch/x86/kernel/asm-offsets_64.c | |||
@@ -15,12 +15,16 @@ | |||
15 | #include <asm/segment.h> | 15 | #include <asm/segment.h> |
16 | #include <asm/thread_info.h> | 16 | #include <asm/thread_info.h> |
17 | #include <asm/ia32.h> | 17 | #include <asm/ia32.h> |
18 | #include <asm/bootparam.h> | ||
18 | 19 | ||
19 | #define DEFINE(sym, val) \ | 20 | #define DEFINE(sym, val) \ |
20 | asm volatile("\n->" #sym " %0 " #val : : "i" (val)) | 21 | asm volatile("\n->" #sym " %0 " #val : : "i" (val)) |
21 | 22 | ||
22 | #define BLANK() asm volatile("\n->" : : ) | 23 | #define BLANK() asm volatile("\n->" : : ) |
23 | 24 | ||
25 | #define OFFSET(sym, str, mem) \ | ||
26 | DEFINE(sym, offsetof(struct str, mem)) | ||
27 | |||
24 | #define __NO_STUBS 1 | 28 | #define __NO_STUBS 1 |
25 | #undef __SYSCALL | 29 | #undef __SYSCALL |
26 | #undef _ASM_X86_64_UNISTD_H_ | 30 | #undef _ASM_X86_64_UNISTD_H_ |
@@ -109,5 +113,11 @@ int main(void) | |||
109 | DEFINE(crypto_tfm_ctx_offset, offsetof(struct crypto_tfm, __crt_ctx)); | 113 | DEFINE(crypto_tfm_ctx_offset, offsetof(struct crypto_tfm, __crt_ctx)); |
110 | BLANK(); | 114 | BLANK(); |
111 | DEFINE(__NR_syscall_max, sizeof(syscalls) - 1); | 115 | DEFINE(__NR_syscall_max, sizeof(syscalls) - 1); |
116 | |||
117 | BLANK(); | ||
118 | OFFSET(BP_scratch, boot_params, scratch); | ||
119 | OFFSET(BP_loadflags, boot_params, hdr.loadflags); | ||
120 | OFFSET(BP_hardware_subarch, boot_params, hdr.hardware_subarch); | ||
121 | OFFSET(BP_version, boot_params, hdr.version); | ||
112 | return 0; | 122 | return 0; |
113 | } | 123 | } |
diff --git a/arch/x86/kernel/cpu/proc.c b/arch/x86/kernel/cpu/proc.c index 2d42b414b777..066f8c6af4df 100644 --- a/arch/x86/kernel/cpu/proc.c +++ b/arch/x86/kernel/cpu/proc.c | |||
@@ -49,7 +49,7 @@ static int show_cpuinfo(struct seq_file *m, void *v) | |||
49 | /* Intel-defined (#2) */ | 49 | /* Intel-defined (#2) */ |
50 | "pni", NULL, NULL, "monitor", "ds_cpl", "vmx", "smx", "est", | 50 | "pni", NULL, NULL, "monitor", "ds_cpl", "vmx", "smx", "est", |
51 | "tm2", "ssse3", "cid", NULL, NULL, "cx16", "xtpr", NULL, | 51 | "tm2", "ssse3", "cid", NULL, NULL, "cx16", "xtpr", NULL, |
52 | NULL, NULL, "dca", NULL, NULL, NULL, NULL, "popcnt", | 52 | NULL, NULL, "dca", "sse4_1", "sse4_2", NULL, NULL, "popcnt", |
53 | NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, | 53 | NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, |
54 | 54 | ||
55 | /* VIA/Cyrix/Centaur-defined */ | 55 | /* VIA/Cyrix/Centaur-defined */ |
@@ -59,10 +59,10 @@ static int show_cpuinfo(struct seq_file *m, void *v) | |||
59 | NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, | 59 | NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, |
60 | 60 | ||
61 | /* AMD-defined (#2) */ | 61 | /* AMD-defined (#2) */ |
62 | "lahf_lm", "cmp_legacy", "svm", "extapic", "cr8_legacy", | 62 | "lahf_lm", "cmp_legacy", "svm", "extapic", |
63 | "altmovcr8", "abm", "sse4a", | 63 | "cr8_legacy", "abm", "sse4a", "misalignsse", |
64 | "misalignsse", "3dnowprefetch", | 64 | "3dnowprefetch", "osvw", "ibs", "sse5", |
65 | "osvw", "ibs", NULL, NULL, NULL, NULL, | 65 | "skinit", "wdt", NULL, NULL, |
66 | NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, | 66 | NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, |
67 | NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, | 67 | NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, |
68 | 68 | ||
diff --git a/arch/x86/kernel/crash.c b/arch/x86/kernel/crash.c index af0253f94a9a..8bb482ff091b 100644 --- a/arch/x86/kernel/crash.c +++ b/arch/x86/kernel/crash.c | |||
@@ -25,7 +25,7 @@ | |||
25 | #include <linux/kdebug.h> | 25 | #include <linux/kdebug.h> |
26 | #include <asm/smp.h> | 26 | #include <asm/smp.h> |
27 | 27 | ||
28 | #ifdef X86_32 | 28 | #ifdef CONFIG_X86_32 |
29 | #include <mach_ipi.h> | 29 | #include <mach_ipi.h> |
30 | #else | 30 | #else |
31 | #include <asm/mach_apic.h> | 31 | #include <asm/mach_apic.h> |
@@ -41,7 +41,7 @@ static int crash_nmi_callback(struct notifier_block *self, | |||
41 | unsigned long val, void *data) | 41 | unsigned long val, void *data) |
42 | { | 42 | { |
43 | struct pt_regs *regs; | 43 | struct pt_regs *regs; |
44 | #ifdef X86_32 | 44 | #ifdef CONFIG_X86_32 |
45 | struct pt_regs fixed_regs; | 45 | struct pt_regs fixed_regs; |
46 | #endif | 46 | #endif |
47 | int cpu; | 47 | int cpu; |
@@ -60,7 +60,7 @@ static int crash_nmi_callback(struct notifier_block *self, | |||
60 | return NOTIFY_STOP; | 60 | return NOTIFY_STOP; |
61 | local_irq_disable(); | 61 | local_irq_disable(); |
62 | 62 | ||
63 | #ifdef X86_32 | 63 | #ifdef CONFIG_X86_32 |
64 | if (!user_mode_vm(regs)) { | 64 | if (!user_mode_vm(regs)) { |
65 | crash_fixup_ss_esp(&fixed_regs, regs); | 65 | crash_fixup_ss_esp(&fixed_regs, regs); |
66 | regs = &fixed_regs; | 66 | regs = &fixed_regs; |
diff --git a/arch/x86/kernel/early-quirks.c b/arch/x86/kernel/early-quirks.c index dc34acbd54aa..88bb83ec895f 100644 --- a/arch/x86/kernel/early-quirks.c +++ b/arch/x86/kernel/early-quirks.c | |||
@@ -17,30 +17,32 @@ | |||
17 | #include <asm/io_apic.h> | 17 | #include <asm/io_apic.h> |
18 | #include <asm/apic.h> | 18 | #include <asm/apic.h> |
19 | 19 | ||
20 | #ifdef CONFIG_IOMMU | 20 | #ifdef CONFIG_GART_IOMMU |
21 | #include <asm/iommu.h> | 21 | #include <asm/gart.h> |
22 | #endif | 22 | #endif |
23 | 23 | ||
24 | static void __init via_bugs(void) | 24 | static void __init via_bugs(void) |
25 | { | 25 | { |
26 | #ifdef CONFIG_IOMMU | 26 | #ifdef CONFIG_GART_IOMMU |
27 | if ((end_pfn > MAX_DMA32_PFN || force_iommu) && | 27 | if ((end_pfn > MAX_DMA32_PFN || force_iommu) && |
28 | !iommu_aperture_allowed) { | 28 | !gart_iommu_aperture_allowed) { |
29 | printk(KERN_INFO | 29 | printk(KERN_INFO |
30 | "Looks like a VIA chipset. Disabling IOMMU." | 30 | "Looks like a VIA chipset. Disabling IOMMU." |
31 | " Override with iommu=allowed\n"); | 31 | " Override with iommu=allowed\n"); |
32 | iommu_aperture_disabled = 1; | 32 | gart_iommu_aperture_disabled = 1; |
33 | } | 33 | } |
34 | #endif | 34 | #endif |
35 | } | 35 | } |
36 | 36 | ||
37 | #ifdef CONFIG_ACPI | 37 | #ifdef CONFIG_ACPI |
38 | #ifdef CONFIG_X86_IO_APIC | ||
38 | 39 | ||
39 | static int __init nvidia_hpet_check(struct acpi_table_header *header) | 40 | static int __init nvidia_hpet_check(struct acpi_table_header *header) |
40 | { | 41 | { |
41 | return 0; | 42 | return 0; |
42 | } | 43 | } |
43 | #endif | 44 | #endif /* CONFIG_X86_IO_APIC */ |
45 | #endif /* CONFIG_ACPI */ | ||
44 | 46 | ||
45 | static void __init nvidia_bugs(void) | 47 | static void __init nvidia_bugs(void) |
46 | { | 48 | { |
diff --git a/arch/x86/kernel/machine_kexec_64.c b/arch/x86/kernel/machine_kexec_64.c index 0d8577f05422..aa3d2c8f7737 100644 --- a/arch/x86/kernel/machine_kexec_64.c +++ b/arch/x86/kernel/machine_kexec_64.c | |||
@@ -233,6 +233,8 @@ NORET_TYPE void machine_kexec(struct kimage *image) | |||
233 | 233 | ||
234 | void arch_crash_save_vmcoreinfo(void) | 234 | void arch_crash_save_vmcoreinfo(void) |
235 | { | 235 | { |
236 | VMCOREINFO_SYMBOL(init_level4_pgt); | ||
237 | |||
236 | #ifdef CONFIG_ARCH_DISCONTIGMEM_ENABLE | 238 | #ifdef CONFIG_ARCH_DISCONTIGMEM_ENABLE |
237 | VMCOREINFO_SYMBOL(node_data); | 239 | VMCOREINFO_SYMBOL(node_data); |
238 | VMCOREINFO_LENGTH(node_data, MAX_NUMNODES); | 240 | VMCOREINFO_LENGTH(node_data, MAX_NUMNODES); |
diff --git a/arch/x86/kernel/pci-calgary_64.c b/arch/x86/kernel/pci-calgary_64.c index 1a20fe31338b..6bf1f716909d 100644 --- a/arch/x86/kernel/pci-calgary_64.c +++ b/arch/x86/kernel/pci-calgary_64.c | |||
@@ -36,7 +36,7 @@ | |||
36 | #include <linux/pci.h> | 36 | #include <linux/pci.h> |
37 | #include <linux/delay.h> | 37 | #include <linux/delay.h> |
38 | #include <linux/scatterlist.h> | 38 | #include <linux/scatterlist.h> |
39 | #include <asm/iommu.h> | 39 | #include <asm/gart.h> |
40 | #include <asm/calgary.h> | 40 | #include <asm/calgary.h> |
41 | #include <asm/tce.h> | 41 | #include <asm/tce.h> |
42 | #include <asm/pci-direct.h> | 42 | #include <asm/pci-direct.h> |
diff --git a/arch/x86/kernel/pci-dma_64.c b/arch/x86/kernel/pci-dma_64.c index 393e2725a6e3..aa805b11b24f 100644 --- a/arch/x86/kernel/pci-dma_64.c +++ b/arch/x86/kernel/pci-dma_64.c | |||
@@ -9,7 +9,7 @@ | |||
9 | #include <linux/module.h> | 9 | #include <linux/module.h> |
10 | #include <linux/dmar.h> | 10 | #include <linux/dmar.h> |
11 | #include <asm/io.h> | 11 | #include <asm/io.h> |
12 | #include <asm/iommu.h> | 12 | #include <asm/gart.h> |
13 | #include <asm/calgary.h> | 13 | #include <asm/calgary.h> |
14 | 14 | ||
15 | int iommu_merge __read_mostly = 1; | 15 | int iommu_merge __read_mostly = 1; |
@@ -275,7 +275,7 @@ __init int iommu_setup(char *p) | |||
275 | swiotlb = 1; | 275 | swiotlb = 1; |
276 | #endif | 276 | #endif |
277 | 277 | ||
278 | #ifdef CONFIG_IOMMU | 278 | #ifdef CONFIG_GART_IOMMU |
279 | gart_parse_options(p); | 279 | gart_parse_options(p); |
280 | #endif | 280 | #endif |
281 | 281 | ||
@@ -298,8 +298,8 @@ void __init pci_iommu_alloc(void) | |||
298 | * The order of these functions is important for | 298 | * The order of these functions is important for |
299 | * fall-back/fail-over reasons | 299 | * fall-back/fail-over reasons |
300 | */ | 300 | */ |
301 | #ifdef CONFIG_IOMMU | 301 | #ifdef CONFIG_GART_IOMMU |
302 | iommu_hole_init(); | 302 | gart_iommu_hole_init(); |
303 | #endif | 303 | #endif |
304 | 304 | ||
305 | #ifdef CONFIG_CALGARY_IOMMU | 305 | #ifdef CONFIG_CALGARY_IOMMU |
@@ -321,7 +321,7 @@ static int __init pci_iommu_init(void) | |||
321 | 321 | ||
322 | intel_iommu_init(); | 322 | intel_iommu_init(); |
323 | 323 | ||
324 | #ifdef CONFIG_IOMMU | 324 | #ifdef CONFIG_GART_IOMMU |
325 | gart_iommu_init(); | 325 | gart_iommu_init(); |
326 | #endif | 326 | #endif |
327 | 327 | ||
diff --git a/arch/x86/kernel/pci-gart_64.c b/arch/x86/kernel/pci-gart_64.c index c56e9ee64964..06bcba536045 100644 --- a/arch/x86/kernel/pci-gart_64.c +++ b/arch/x86/kernel/pci-gart_64.c | |||
@@ -30,17 +30,17 @@ | |||
30 | #include <asm/mtrr.h> | 30 | #include <asm/mtrr.h> |
31 | #include <asm/pgtable.h> | 31 | #include <asm/pgtable.h> |
32 | #include <asm/proto.h> | 32 | #include <asm/proto.h> |
33 | #include <asm/iommu.h> | 33 | #include <asm/gart.h> |
34 | #include <asm/cacheflush.h> | 34 | #include <asm/cacheflush.h> |
35 | #include <asm/swiotlb.h> | 35 | #include <asm/swiotlb.h> |
36 | #include <asm/dma.h> | 36 | #include <asm/dma.h> |
37 | #include <asm/k8.h> | 37 | #include <asm/k8.h> |
38 | 38 | ||
39 | unsigned long iommu_bus_base; /* GART remapping area (physical) */ | 39 | static unsigned long iommu_bus_base; /* GART remapping area (physical) */ |
40 | static unsigned long iommu_size; /* size of remapping area bytes */ | 40 | static unsigned long iommu_size; /* size of remapping area bytes */ |
41 | static unsigned long iommu_pages; /* .. and in pages */ | 41 | static unsigned long iommu_pages; /* .. and in pages */ |
42 | 42 | ||
43 | u32 *iommu_gatt_base; /* Remapping table */ | 43 | static u32 *iommu_gatt_base; /* Remapping table */ |
44 | 44 | ||
45 | /* If this is disabled the IOMMU will use an optimized flushing strategy | 45 | /* If this is disabled the IOMMU will use an optimized flushing strategy |
46 | of only flushing when an mapping is reused. With it true the GART is flushed | 46 | of only flushing when an mapping is reused. With it true the GART is flushed |
@@ -135,8 +135,8 @@ static void flush_gart(void) | |||
135 | /* Debugging aid for drivers that don't free their IOMMU tables */ | 135 | /* Debugging aid for drivers that don't free their IOMMU tables */ |
136 | static void **iommu_leak_tab; | 136 | static void **iommu_leak_tab; |
137 | static int leak_trace; | 137 | static int leak_trace; |
138 | int iommu_leak_pages = 20; | 138 | static int iommu_leak_pages = 20; |
139 | void dump_leak(void) | 139 | static void dump_leak(void) |
140 | { | 140 | { |
141 | int i; | 141 | int i; |
142 | static int dump; | 142 | static int dump; |
@@ -338,7 +338,6 @@ static int __dma_map_cont(struct scatterlist *start, int nelems, | |||
338 | 338 | ||
339 | BUG_ON(s != start && s->offset); | 339 | BUG_ON(s != start && s->offset); |
340 | if (s == start) { | 340 | if (s == start) { |
341 | *sout = *s; | ||
342 | sout->dma_address = iommu_bus_base; | 341 | sout->dma_address = iommu_bus_base; |
343 | sout->dma_address += iommu_page*PAGE_SIZE + s->offset; | 342 | sout->dma_address += iommu_page*PAGE_SIZE + s->offset; |
344 | sout->dma_length = s->length; | 343 | sout->dma_length = s->length; |
@@ -365,7 +364,7 @@ static inline int dma_map_cont(struct scatterlist *start, int nelems, | |||
365 | { | 364 | { |
366 | if (!need) { | 365 | if (!need) { |
367 | BUG_ON(nelems != 1); | 366 | BUG_ON(nelems != 1); |
368 | *sout = *start; | 367 | sout->dma_address = start->dma_address; |
369 | sout->dma_length = start->length; | 368 | sout->dma_length = start->length; |
370 | return 0; | 369 | return 0; |
371 | } | 370 | } |
@@ -436,7 +435,7 @@ static int gart_map_sg(struct device *dev, struct scatterlist *sg, int nents, | |||
436 | 435 | ||
437 | error: | 436 | error: |
438 | flush_gart(); | 437 | flush_gart(); |
439 | gart_unmap_sg(dev, sg, nents, dir); | 438 | gart_unmap_sg(dev, sg, out, dir); |
440 | /* When it was forced or merged try again in a dumb way */ | 439 | /* When it was forced or merged try again in a dumb way */ |
441 | if (force_iommu || iommu_merge) { | 440 | if (force_iommu || iommu_merge) { |
442 | out = dma_map_sg_nonforce(dev, sg, nents, dir); | 441 | out = dma_map_sg_nonforce(dev, sg, nents, dir); |
@@ -628,12 +627,12 @@ void __init gart_iommu_init(void) | |||
628 | return; | 627 | return; |
629 | 628 | ||
630 | /* Did we detect a different HW IOMMU? */ | 629 | /* Did we detect a different HW IOMMU? */ |
631 | if (iommu_detected && !iommu_aperture) | 630 | if (iommu_detected && !gart_iommu_aperture) |
632 | return; | 631 | return; |
633 | 632 | ||
634 | if (no_iommu || | 633 | if (no_iommu || |
635 | (!force_iommu && end_pfn <= MAX_DMA32_PFN) || | 634 | (!force_iommu && end_pfn <= MAX_DMA32_PFN) || |
636 | !iommu_aperture || | 635 | !gart_iommu_aperture || |
637 | (no_agp && init_k8_gatt(&info) < 0)) { | 636 | (no_agp && init_k8_gatt(&info) < 0)) { |
638 | if (end_pfn > MAX_DMA32_PFN) { | 637 | if (end_pfn > MAX_DMA32_PFN) { |
639 | printk(KERN_ERR "WARNING more than 4GB of memory " | 638 | printk(KERN_ERR "WARNING more than 4GB of memory " |
@@ -734,9 +733,9 @@ void __init gart_parse_options(char *p) | |||
734 | fix_aperture = 0; | 733 | fix_aperture = 0; |
735 | /* duplicated from pci-dma.c */ | 734 | /* duplicated from pci-dma.c */ |
736 | if (!strncmp(p,"force",5)) | 735 | if (!strncmp(p,"force",5)) |
737 | iommu_aperture_allowed = 1; | 736 | gart_iommu_aperture_allowed = 1; |
738 | if (!strncmp(p,"allowed",7)) | 737 | if (!strncmp(p,"allowed",7)) |
739 | iommu_aperture_allowed = 1; | 738 | gart_iommu_aperture_allowed = 1; |
740 | if (!strncmp(p, "memaper", 7)) { | 739 | if (!strncmp(p, "memaper", 7)) { |
741 | fallback_aper_force = 1; | 740 | fallback_aper_force = 1; |
742 | p += 7; | 741 | p += 7; |
diff --git a/arch/x86/kernel/pci-nommu_64.c b/arch/x86/kernel/pci-nommu_64.c index faf70bdca335..ab08e1832228 100644 --- a/arch/x86/kernel/pci-nommu_64.c +++ b/arch/x86/kernel/pci-nommu_64.c | |||
@@ -7,7 +7,7 @@ | |||
7 | #include <linux/dma-mapping.h> | 7 | #include <linux/dma-mapping.h> |
8 | #include <linux/scatterlist.h> | 8 | #include <linux/scatterlist.h> |
9 | 9 | ||
10 | #include <asm/iommu.h> | 10 | #include <asm/gart.h> |
11 | #include <asm/processor.h> | 11 | #include <asm/processor.h> |
12 | #include <asm/dma.h> | 12 | #include <asm/dma.h> |
13 | 13 | ||
diff --git a/arch/x86/kernel/pci-swiotlb_64.c b/arch/x86/kernel/pci-swiotlb_64.c index b2f405ea7c85..102866d729a5 100644 --- a/arch/x86/kernel/pci-swiotlb_64.c +++ b/arch/x86/kernel/pci-swiotlb_64.c | |||
@@ -5,7 +5,7 @@ | |||
5 | #include <linux/module.h> | 5 | #include <linux/module.h> |
6 | #include <linux/dma-mapping.h> | 6 | #include <linux/dma-mapping.h> |
7 | 7 | ||
8 | #include <asm/iommu.h> | 8 | #include <asm/gart.h> |
9 | #include <asm/swiotlb.h> | 9 | #include <asm/swiotlb.h> |
10 | #include <asm/dma.h> | 10 | #include <asm/dma.h> |
11 | 11 | ||
diff --git a/arch/x86/kernel/reboot_64.c b/arch/x86/kernel/reboot_64.c index 776eb06b6512..71b13c5f5817 100644 --- a/arch/x86/kernel/reboot_64.c +++ b/arch/x86/kernel/reboot_64.c | |||
@@ -17,7 +17,7 @@ | |||
17 | #include <asm/pgtable.h> | 17 | #include <asm/pgtable.h> |
18 | #include <asm/tlbflush.h> | 18 | #include <asm/tlbflush.h> |
19 | #include <asm/apic.h> | 19 | #include <asm/apic.h> |
20 | #include <asm/iommu.h> | 20 | #include <asm/gart.h> |
21 | 21 | ||
22 | /* | 22 | /* |
23 | * Power off function, if any | 23 | * Power off function, if any |
diff --git a/arch/x86/kernel/setup_32.c b/arch/x86/kernel/setup_32.c index cc0e91447b76..e1e18c34c821 100644 --- a/arch/x86/kernel/setup_32.c +++ b/arch/x86/kernel/setup_32.c | |||
@@ -86,9 +86,6 @@ unsigned long mmu_cr4_features; | |||
86 | 86 | ||
87 | /* for MCA, but anyone else can use it if they want */ | 87 | /* for MCA, but anyone else can use it if they want */ |
88 | unsigned int machine_id; | 88 | unsigned int machine_id; |
89 | #ifdef CONFIG_MCA | ||
90 | EXPORT_SYMBOL(machine_id); | ||
91 | #endif | ||
92 | unsigned int machine_submodel_id; | 89 | unsigned int machine_submodel_id; |
93 | unsigned int BIOS_revision; | 90 | unsigned int BIOS_revision; |
94 | unsigned int mca_pentium_flag; | 91 | unsigned int mca_pentium_flag; |
diff --git a/arch/x86/kernel/setup_64.c b/arch/x86/kernel/setup_64.c index e7a9e36bd52d..238633d3d09a 100644 --- a/arch/x86/kernel/setup_64.c +++ b/arch/x86/kernel/setup_64.c | |||
@@ -1040,7 +1040,7 @@ static int show_cpuinfo(struct seq_file *m, void *v) | |||
1040 | /* Intel-defined (#2) */ | 1040 | /* Intel-defined (#2) */ |
1041 | "pni", NULL, NULL, "monitor", "ds_cpl", "vmx", "smx", "est", | 1041 | "pni", NULL, NULL, "monitor", "ds_cpl", "vmx", "smx", "est", |
1042 | "tm2", "ssse3", "cid", NULL, NULL, "cx16", "xtpr", NULL, | 1042 | "tm2", "ssse3", "cid", NULL, NULL, "cx16", "xtpr", NULL, |
1043 | NULL, NULL, "dca", NULL, NULL, NULL, NULL, "popcnt", | 1043 | NULL, NULL, "dca", "sse4_1", "sse4_2", NULL, NULL, "popcnt", |
1044 | NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, | 1044 | NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, |
1045 | 1045 | ||
1046 | /* VIA/Cyrix/Centaur-defined */ | 1046 | /* VIA/Cyrix/Centaur-defined */ |
@@ -1050,10 +1050,10 @@ static int show_cpuinfo(struct seq_file *m, void *v) | |||
1050 | NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, | 1050 | NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, |
1051 | 1051 | ||
1052 | /* AMD-defined (#2) */ | 1052 | /* AMD-defined (#2) */ |
1053 | "lahf_lm", "cmp_legacy", "svm", "extapic", "cr8_legacy", | 1053 | "lahf_lm", "cmp_legacy", "svm", "extapic", |
1054 | "altmovcr8", "abm", "sse4a", | 1054 | "cr8_legacy", "abm", "sse4a", "misalignsse", |
1055 | "misalignsse", "3dnowprefetch", | 1055 | "3dnowprefetch", "osvw", "ibs", "sse5", |
1056 | "osvw", "ibs", NULL, NULL, NULL, NULL, | 1056 | "skinit", "wdt", NULL, NULL, |
1057 | NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, | 1057 | NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, |
1058 | NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, | 1058 | NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, |
1059 | 1059 | ||
diff --git a/arch/x86/kernel/smp_32.c b/arch/x86/kernel/smp_32.c index f32115308399..fcaa026eb807 100644 --- a/arch/x86/kernel/smp_32.c +++ b/arch/x86/kernel/smp_32.c | |||
@@ -708,10 +708,4 @@ struct smp_ops smp_ops = { | |||
708 | .smp_send_reschedule = native_smp_send_reschedule, | 708 | .smp_send_reschedule = native_smp_send_reschedule, |
709 | .smp_call_function_mask = native_smp_call_function_mask, | 709 | .smp_call_function_mask = native_smp_call_function_mask, |
710 | }; | 710 | }; |
711 | 711 | EXPORT_SYMBOL_GPL(smp_ops); | |
712 | int smp_call_function_mask(cpumask_t mask, void (*func) (void *info), | ||
713 | void *info, int wait) | ||
714 | { | ||
715 | return smp_ops.smp_call_function_mask(mask, func, info, wait); | ||
716 | } | ||
717 | EXPORT_SYMBOL(smp_call_function_mask); | ||
diff --git a/arch/x86/lguest/boot.c b/arch/x86/lguest/boot.c index d2235db4085f..a55b0902f9d3 100644 --- a/arch/x86/lguest/boot.c +++ b/arch/x86/lguest/boot.c | |||
@@ -56,6 +56,7 @@ | |||
56 | #include <linux/lguest.h> | 56 | #include <linux/lguest.h> |
57 | #include <linux/lguest_launcher.h> | 57 | #include <linux/lguest_launcher.h> |
58 | #include <linux/virtio_console.h> | 58 | #include <linux/virtio_console.h> |
59 | #include <linux/pm.h> | ||
59 | #include <asm/paravirt.h> | 60 | #include <asm/paravirt.h> |
60 | #include <asm/param.h> | 61 | #include <asm/param.h> |
61 | #include <asm/page.h> | 62 | #include <asm/page.h> |
@@ -98,7 +99,7 @@ static cycle_t clock_base; | |||
98 | * When lazy_mode is set, it means we're allowed to defer all hypercalls and do | 99 | * When lazy_mode is set, it means we're allowed to defer all hypercalls and do |
99 | * them as a batch when lazy_mode is eventually turned off. Because hypercalls | 100 | * them as a batch when lazy_mode is eventually turned off. Because hypercalls |
100 | * are reasonably expensive, batching them up makes sense. For example, a | 101 | * are reasonably expensive, batching them up makes sense. For example, a |
101 | * large mmap might update dozens of page table entries: that code calls | 102 | * large munmap might update dozens of page table entries: that code calls |
102 | * paravirt_enter_lazy_mmu(), does the dozen updates, then calls | 103 | * paravirt_enter_lazy_mmu(), does the dozen updates, then calls |
103 | * lguest_leave_lazy_mode(). | 104 | * lguest_leave_lazy_mode(). |
104 | * | 105 | * |
@@ -163,8 +164,8 @@ void async_hcall(unsigned long call, | |||
163 | /*:*/ | 164 | /*:*/ |
164 | 165 | ||
165 | /*G:033 | 166 | /*G:033 |
166 | * Here are our first native-instruction replacements: four functions for | 167 | * After that diversion we return to our first native-instruction |
167 | * interrupt control. | 168 | * replacements: four functions for interrupt control. |
168 | * | 169 | * |
169 | * The simplest way of implementing these would be to have "turn interrupts | 170 | * The simplest way of implementing these would be to have "turn interrupts |
170 | * off" and "turn interrupts on" hypercalls. Unfortunately, this is too slow: | 171 | * off" and "turn interrupts on" hypercalls. Unfortunately, this is too slow: |
@@ -183,7 +184,7 @@ static unsigned long save_fl(void) | |||
183 | return lguest_data.irq_enabled; | 184 | return lguest_data.irq_enabled; |
184 | } | 185 | } |
185 | 186 | ||
186 | /* "restore_flags" just sets the flags back to the value given. */ | 187 | /* restore_flags() just sets the flags back to the value given. */ |
187 | static void restore_fl(unsigned long flags) | 188 | static void restore_fl(unsigned long flags) |
188 | { | 189 | { |
189 | lguest_data.irq_enabled = flags; | 190 | lguest_data.irq_enabled = flags; |
@@ -356,7 +357,7 @@ static void lguest_cpuid(unsigned int *eax, unsigned int *ebx, | |||
356 | * it. The Host needs to know when the Guest wants to change them, so we have | 357 | * it. The Host needs to know when the Guest wants to change them, so we have |
357 | * a whole series of functions like read_cr0() and write_cr0(). | 358 | * a whole series of functions like read_cr0() and write_cr0(). |
358 | * | 359 | * |
359 | * We start with CR0. CR0 allows you to turn on and off all kinds of basic | 360 | * We start with cr0. cr0 allows you to turn on and off all kinds of basic |
360 | * features, but Linux only really cares about one: the horrifically-named Task | 361 | * features, but Linux only really cares about one: the horrifically-named Task |
361 | * Switched (TS) bit at bit 3 (ie. 8) | 362 | * Switched (TS) bit at bit 3 (ie. 8) |
362 | * | 363 | * |
@@ -371,8 +372,7 @@ static void lguest_cpuid(unsigned int *eax, unsigned int *ebx, | |||
371 | static unsigned long current_cr0, current_cr3; | 372 | static unsigned long current_cr0, current_cr3; |
372 | static void lguest_write_cr0(unsigned long val) | 373 | static void lguest_write_cr0(unsigned long val) |
373 | { | 374 | { |
374 | /* 8 == TS bit. */ | 375 | lazy_hcall(LHCALL_TS, val & X86_CR0_TS, 0, 0); |
375 | lazy_hcall(LHCALL_TS, val & 8, 0, 0); | ||
376 | current_cr0 = val; | 376 | current_cr0 = val; |
377 | } | 377 | } |
378 | 378 | ||
@@ -387,10 +387,10 @@ static unsigned long lguest_read_cr0(void) | |||
387 | static void lguest_clts(void) | 387 | static void lguest_clts(void) |
388 | { | 388 | { |
389 | lazy_hcall(LHCALL_TS, 0, 0, 0); | 389 | lazy_hcall(LHCALL_TS, 0, 0, 0); |
390 | current_cr0 &= ~8U; | 390 | current_cr0 &= ~X86_CR0_TS; |
391 | } | 391 | } |
392 | 392 | ||
393 | /* CR2 is the virtual address of the last page fault, which the Guest only ever | 393 | /* cr2 is the virtual address of the last page fault, which the Guest only ever |
394 | * reads. The Host kindly writes this into our "struct lguest_data", so we | 394 | * reads. The Host kindly writes this into our "struct lguest_data", so we |
395 | * just read it out of there. */ | 395 | * just read it out of there. */ |
396 | static unsigned long lguest_read_cr2(void) | 396 | static unsigned long lguest_read_cr2(void) |
@@ -398,7 +398,7 @@ static unsigned long lguest_read_cr2(void) | |||
398 | return lguest_data.cr2; | 398 | return lguest_data.cr2; |
399 | } | 399 | } |
400 | 400 | ||
401 | /* CR3 is the current toplevel pagetable page: the principle is the same as | 401 | /* cr3 is the current toplevel pagetable page: the principle is the same as |
402 | * cr0. Keep a local copy, and tell the Host when it changes. */ | 402 | * cr0. Keep a local copy, and tell the Host when it changes. */ |
403 | static void lguest_write_cr3(unsigned long cr3) | 403 | static void lguest_write_cr3(unsigned long cr3) |
404 | { | 404 | { |
@@ -411,7 +411,7 @@ static unsigned long lguest_read_cr3(void) | |||
411 | return current_cr3; | 411 | return current_cr3; |
412 | } | 412 | } |
413 | 413 | ||
414 | /* CR4 is used to enable and disable PGE, but we don't care. */ | 414 | /* cr4 is used to enable and disable PGE, but we don't care. */ |
415 | static unsigned long lguest_read_cr4(void) | 415 | static unsigned long lguest_read_cr4(void) |
416 | { | 416 | { |
417 | return 0; | 417 | return 0; |
@@ -432,7 +432,7 @@ static void lguest_write_cr4(unsigned long val) | |||
432 | * maps virtual addresses to physical addresses using "page tables". We could | 432 | * maps virtual addresses to physical addresses using "page tables". We could |
433 | * use one huge index of 1 million entries: each address is 4 bytes, so that's | 433 | * use one huge index of 1 million entries: each address is 4 bytes, so that's |
434 | * 1024 pages just to hold the page tables. But since most virtual addresses | 434 | * 1024 pages just to hold the page tables. But since most virtual addresses |
435 | * are unused, we use a two level index which saves space. The CR3 register | 435 | * are unused, we use a two level index which saves space. The cr3 register |
436 | * contains the physical address of the top level "page directory" page, which | 436 | * contains the physical address of the top level "page directory" page, which |
437 | * contains physical addresses of up to 1024 second-level pages. Each of these | 437 | * contains physical addresses of up to 1024 second-level pages. Each of these |
438 | * second level pages contains up to 1024 physical addresses of actual pages, | 438 | * second level pages contains up to 1024 physical addresses of actual pages, |
@@ -440,7 +440,7 @@ static void lguest_write_cr4(unsigned long val) | |||
440 | * | 440 | * |
441 | * Here's a diagram, where arrows indicate physical addresses: | 441 | * Here's a diagram, where arrows indicate physical addresses: |
442 | * | 442 | * |
443 | * CR3 ---> +---------+ | 443 | * cr3 ---> +---------+ |
444 | * | --------->+---------+ | 444 | * | --------->+---------+ |
445 | * | | | PADDR1 | | 445 | * | | | PADDR1 | |
446 | * Top-level | | PADDR2 | | 446 | * Top-level | | PADDR2 | |
@@ -498,8 +498,7 @@ static void lguest_set_pmd(pmd_t *pmdp, pmd_t pmdval) | |||
498 | * | 498 | * |
499 | * ... except in early boot when the kernel sets up the initial pagetables, | 499 | * ... except in early boot when the kernel sets up the initial pagetables, |
500 | * which makes booting astonishingly slow. So we don't even tell the Host | 500 | * which makes booting astonishingly slow. So we don't even tell the Host |
501 | * anything changed until we've done the first page table switch. | 501 | * anything changed until we've done the first page table switch. */ |
502 | */ | ||
503 | static void lguest_set_pte(pte_t *ptep, pte_t pteval) | 502 | static void lguest_set_pte(pte_t *ptep, pte_t pteval) |
504 | { | 503 | { |
505 | *ptep = pteval; | 504 | *ptep = pteval; |
@@ -720,10 +719,10 @@ static void lguest_time_init(void) | |||
720 | /* Set up the timer interrupt (0) to go to our simple timer routine */ | 719 | /* Set up the timer interrupt (0) to go to our simple timer routine */ |
721 | set_irq_handler(0, lguest_time_irq); | 720 | set_irq_handler(0, lguest_time_irq); |
722 | 721 | ||
723 | /* Our clock structure look like arch/i386/kernel/tsc.c if we can use | 722 | /* Our clock structure looks like arch/x86/kernel/tsc_32.c if we can |
724 | * the TSC, otherwise it's a dumb nanosecond-resolution clock. Either | 723 | * use the TSC, otherwise it's a dumb nanosecond-resolution clock. |
725 | * way, the "rating" is initialized so high that it's always chosen | 724 | * Either way, the "rating" is set so high that it's always chosen over |
726 | * over any other clocksource. */ | 725 | * any other clocksource. */ |
727 | if (lguest_data.tsc_khz) | 726 | if (lguest_data.tsc_khz) |
728 | lguest_clock.mult = clocksource_khz2mult(lguest_data.tsc_khz, | 727 | lguest_clock.mult = clocksource_khz2mult(lguest_data.tsc_khz, |
729 | lguest_clock.shift); | 728 | lguest_clock.shift); |
@@ -749,7 +748,7 @@ static void lguest_time_init(void) | |||
749 | * to work. They're pretty simple. | 748 | * to work. They're pretty simple. |
750 | */ | 749 | */ |
751 | 750 | ||
752 | /* The Guest needs to tell the host what stack it expects traps to use. For | 751 | /* The Guest needs to tell the Host what stack it expects traps to use. For |
753 | * native hardware, this is part of the Task State Segment mentioned above in | 752 | * native hardware, this is part of the Task State Segment mentioned above in |
754 | * lguest_load_tr_desc(), but to help hypervisors there's this special call. | 753 | * lguest_load_tr_desc(), but to help hypervisors there's this special call. |
755 | * | 754 | * |
@@ -850,13 +849,16 @@ static __init char *lguest_memory_setup(void) | |||
850 | return "LGUEST"; | 849 | return "LGUEST"; |
851 | } | 850 | } |
852 | 851 | ||
853 | /* Before virtqueues are set up, we use LHCALL_NOTIFY on normal memory to | 852 | /* We will eventually use the virtio console device to produce console output, |
854 | * produce console output. */ | 853 | * but before that is set up we use LHCALL_NOTIFY on normal memory to produce |
854 | * console output. */ | ||
855 | static __init int early_put_chars(u32 vtermno, const char *buf, int count) | 855 | static __init int early_put_chars(u32 vtermno, const char *buf, int count) |
856 | { | 856 | { |
857 | char scratch[17]; | 857 | char scratch[17]; |
858 | unsigned int len = count; | 858 | unsigned int len = count; |
859 | 859 | ||
860 | /* We use a nul-terminated string, so we have to make a copy. Icky, | ||
861 | * huh? */ | ||
860 | if (len > sizeof(scratch) - 1) | 862 | if (len > sizeof(scratch) - 1) |
861 | len = sizeof(scratch) - 1; | 863 | len = sizeof(scratch) - 1; |
862 | scratch[len] = '\0'; | 864 | scratch[len] = '\0'; |
@@ -883,7 +885,7 @@ static __init int early_put_chars(u32 vtermno, const char *buf, int count) | |||
883 | * Our current solution is to allow the paravirt back end to optionally patch | 885 | * Our current solution is to allow the paravirt back end to optionally patch |
884 | * over the indirect calls to replace them with something more efficient. We | 886 | * over the indirect calls to replace them with something more efficient. We |
885 | * patch the four most commonly called functions: disable interrupts, enable | 887 | * patch the four most commonly called functions: disable interrupts, enable |
886 | * interrupts, restore interrupts and save interrupts. We usually have 10 | 888 | * interrupts, restore interrupts and save interrupts. We usually have 6 or 10 |
887 | * bytes to patch into: the Guest versions of these operations are small enough | 889 | * bytes to patch into: the Guest versions of these operations are small enough |
888 | * that we can fit comfortably. | 890 | * that we can fit comfortably. |
889 | * | 891 | * |
@@ -1015,7 +1017,7 @@ __init void lguest_init(void) | |||
1015 | asm volatile ("mov %0, %%fs" : : "r" (__KERNEL_DS) : "memory"); | 1017 | asm volatile ("mov %0, %%fs" : : "r" (__KERNEL_DS) : "memory"); |
1016 | 1018 | ||
1017 | /* The Host uses the top of the Guest's virtual address space for the | 1019 | /* The Host uses the top of the Guest's virtual address space for the |
1018 | * Host<->Guest Switcher, and it tells us how much it needs in | 1020 | * Host<->Guest Switcher, and it tells us how big that is in |
1019 | * lguest_data.reserve_mem, set up on the LGUEST_INIT hypercall. */ | 1021 | * lguest_data.reserve_mem, set up on the LGUEST_INIT hypercall. */ |
1020 | reserve_top_address(lguest_data.reserve_mem); | 1022 | reserve_top_address(lguest_data.reserve_mem); |
1021 | 1023 | ||
@@ -1065,6 +1067,6 @@ __init void lguest_init(void) | |||
1065 | /* | 1067 | /* |
1066 | * This marks the end of stage II of our journey, The Guest. | 1068 | * This marks the end of stage II of our journey, The Guest. |
1067 | * | 1069 | * |
1068 | * It is now time for us to explore the nooks and crannies of the three Guest | 1070 | * It is now time for us to explore the layer of virtual drivers and complete |
1069 | * devices and complete our understanding of the Guest in "make Drivers". | 1071 | * our understanding of the Guest in "make Drivers". |
1070 | */ | 1072 | */ |
diff --git a/arch/x86/lguest/i386_head.S b/arch/x86/lguest/i386_head.S index ebc6ac733899..95b6fbcded63 100644 --- a/arch/x86/lguest/i386_head.S +++ b/arch/x86/lguest/i386_head.S | |||
@@ -6,7 +6,7 @@ | |||
6 | #include <asm/processor-flags.h> | 6 | #include <asm/processor-flags.h> |
7 | 7 | ||
8 | /*G:020 This is where we begin: head.S notes that the boot header's platform | 8 | /*G:020 This is where we begin: head.S notes that the boot header's platform |
9 | * type field is "1" (lguest), so calls us here. The boot header is in %esi. | 9 | * type field is "1" (lguest), so calls us here. |
10 | * | 10 | * |
11 | * WARNING: be very careful here! We're running at addresses equal to physical | 11 | * WARNING: be very careful here! We're running at addresses equal to physical |
12 | * addesses (around 0), not above PAGE_OFFSET as most code expectes | 12 | * addesses (around 0), not above PAGE_OFFSET as most code expectes |
@@ -17,13 +17,15 @@ | |||
17 | * boot. */ | 17 | * boot. */ |
18 | .section .init.text, "ax", @progbits | 18 | .section .init.text, "ax", @progbits |
19 | ENTRY(lguest_entry) | 19 | ENTRY(lguest_entry) |
20 | /* Make initial hypercall now, so we can set up the pagetables. */ | 20 | /* We make the "initialization" hypercall now to tell the Host about |
21 | * us, and also find out where it put our page tables. */ | ||
21 | movl $LHCALL_LGUEST_INIT, %eax | 22 | movl $LHCALL_LGUEST_INIT, %eax |
22 | movl $lguest_data - __PAGE_OFFSET, %edx | 23 | movl $lguest_data - __PAGE_OFFSET, %edx |
23 | int $LGUEST_TRAP_ENTRY | 24 | int $LGUEST_TRAP_ENTRY |
24 | 25 | ||
25 | /* The Host put the toplevel pagetable in lguest_data.pgdir. The movsl | 26 | /* The Host put the toplevel pagetable in lguest_data.pgdir. The movsl |
26 | * instruction uses %esi implicitly. */ | 27 | * instruction uses %esi implicitly as the source for the copy we' |
28 | * about to do. */ | ||
27 | movl lguest_data - __PAGE_OFFSET + LGUEST_DATA_pgdir, %esi | 29 | movl lguest_data - __PAGE_OFFSET + LGUEST_DATA_pgdir, %esi |
28 | 30 | ||
29 | /* Copy first 32 entries of page directory to __PAGE_OFFSET entries. | 31 | /* Copy first 32 entries of page directory to __PAGE_OFFSET entries. |
diff --git a/arch/x86/mach-voyager/voyager_smp.c b/arch/x86/mach-voyager/voyager_smp.c index 361ac5107b33..69371434b0cf 100644 --- a/arch/x86/mach-voyager/voyager_smp.c +++ b/arch/x86/mach-voyager/voyager_smp.c | |||
@@ -29,14 +29,14 @@ | |||
29 | #include <asm/arch_hooks.h> | 29 | #include <asm/arch_hooks.h> |
30 | 30 | ||
31 | /* TLB state -- visible externally, indexed physically */ | 31 | /* TLB state -- visible externally, indexed physically */ |
32 | DEFINE_PER_CPU(struct tlb_state, cpu_tlbstate) ____cacheline_aligned = { &init_mm, 0 }; | 32 | DEFINE_PER_CPU_SHARED_ALIGNED(struct tlb_state, cpu_tlbstate) = { &init_mm, 0 }; |
33 | 33 | ||
34 | /* CPU IRQ affinity -- set to all ones initially */ | 34 | /* CPU IRQ affinity -- set to all ones initially */ |
35 | static unsigned long cpu_irq_affinity[NR_CPUS] __cacheline_aligned = { [0 ... NR_CPUS-1] = ~0UL }; | 35 | static unsigned long cpu_irq_affinity[NR_CPUS] __cacheline_aligned = { [0 ... NR_CPUS-1] = ~0UL }; |
36 | 36 | ||
37 | /* per CPU data structure (for /proc/cpuinfo et al), visible externally | 37 | /* per CPU data structure (for /proc/cpuinfo et al), visible externally |
38 | * indexed physically */ | 38 | * indexed physically */ |
39 | DEFINE_PER_CPU(cpuinfo_x86, cpu_info) __cacheline_aligned; | 39 | DEFINE_PER_CPU_SHARED_ALIGNED(struct cpuinfo_x86, cpu_info); |
40 | EXPORT_PER_CPU_SYMBOL(cpu_info); | 40 | EXPORT_PER_CPU_SYMBOL(cpu_info); |
41 | 41 | ||
42 | /* physical ID of the CPU used to boot the system */ | 42 | /* physical ID of the CPU used to boot the system */ |
diff --git a/arch/x86/mm/discontig_32.c b/arch/x86/mm/discontig_32.c index fe608a45ffb6..13a474d3c6e9 100644 --- a/arch/x86/mm/discontig_32.c +++ b/arch/x86/mm/discontig_32.c | |||
@@ -40,7 +40,7 @@ | |||
40 | 40 | ||
41 | struct pglist_data *node_data[MAX_NUMNODES] __read_mostly; | 41 | struct pglist_data *node_data[MAX_NUMNODES] __read_mostly; |
42 | EXPORT_SYMBOL(node_data); | 42 | EXPORT_SYMBOL(node_data); |
43 | bootmem_data_t node0_bdata; | 43 | static bootmem_data_t node0_bdata; |
44 | 44 | ||
45 | /* | 45 | /* |
46 | * numa interface - we expect the numa architecture specific code to have | 46 | * numa interface - we expect the numa architecture specific code to have |
@@ -404,7 +404,7 @@ void __init set_highmem_pages_init(int bad_ppro) | |||
404 | } | 404 | } |
405 | 405 | ||
406 | #ifdef CONFIG_MEMORY_HOTPLUG | 406 | #ifdef CONFIG_MEMORY_HOTPLUG |
407 | int paddr_to_nid(u64 addr) | 407 | static int paddr_to_nid(u64 addr) |
408 | { | 408 | { |
409 | int nid; | 409 | int nid; |
410 | unsigned long pfn = PFN_DOWN(addr); | 410 | unsigned long pfn = PFN_DOWN(addr); |
diff --git a/arch/x86/mm/fault_32.c b/arch/x86/mm/fault_32.c index 2e542e89a3e2..a2273d44aa27 100644 --- a/arch/x86/mm/fault_32.c +++ b/arch/x86/mm/fault_32.c | |||
@@ -555,7 +555,7 @@ no_context: | |||
555 | page &= PAGE_MASK; | 555 | page &= PAGE_MASK; |
556 | page = ((__typeof__(page) *) __va(page))[(address >> PMD_SHIFT) | 556 | page = ((__typeof__(page) *) __va(page))[(address >> PMD_SHIFT) |
557 | & (PTRS_PER_PMD - 1)]; | 557 | & (PTRS_PER_PMD - 1)]; |
558 | printk(KERN_ALERT "*pde = %016Lx ", page); | 558 | printk(KERN_CONT "*pde = %016Lx ", page); |
559 | page &= ~_PAGE_NX; | 559 | page &= ~_PAGE_NX; |
560 | } | 560 | } |
561 | #else | 561 | #else |
diff --git a/arch/x86/mm/init_64.c b/arch/x86/mm/init_64.c index 1e3862e41065..a7308b2cd058 100644 --- a/arch/x86/mm/init_64.c +++ b/arch/x86/mm/init_64.c | |||
@@ -728,12 +728,6 @@ int in_gate_area_no_task(unsigned long addr) | |||
728 | return (addr >= VSYSCALL_START) && (addr < VSYSCALL_END); | 728 | return (addr >= VSYSCALL_START) && (addr < VSYSCALL_END); |
729 | } | 729 | } |
730 | 730 | ||
731 | void * __init alloc_bootmem_high_node(pg_data_t *pgdat, unsigned long size) | ||
732 | { | ||
733 | return __alloc_bootmem_core(pgdat->bdata, size, | ||
734 | SMP_CACHE_BYTES, (4UL*1024*1024*1024), 0); | ||
735 | } | ||
736 | |||
737 | const char *arch_vma_name(struct vm_area_struct *vma) | 731 | const char *arch_vma_name(struct vm_area_struct *vma) |
738 | { | 732 | { |
739 | if (vma->vm_mm && vma->vm_start == (long)vma->vm_mm->context.vdso) | 733 | if (vma->vm_mm && vma->vm_start == (long)vma->vm_mm->context.vdso) |
diff --git a/arch/x86_64/.gitignore b/arch/x86_64/.gitignore deleted file mode 100644 index 36ef4c374d25..000000000000 --- a/arch/x86_64/.gitignore +++ /dev/null | |||
@@ -1 +0,0 @@ | |||
1 | boot | ||
diff --git a/arch/x86_64/Kconfig.debug b/arch/x86_64/Kconfig.debug deleted file mode 100644 index 775d211a5cf9..000000000000 --- a/arch/x86_64/Kconfig.debug +++ /dev/null | |||
@@ -1,61 +0,0 @@ | |||
1 | menu "Kernel hacking" | ||
2 | |||
3 | config TRACE_IRQFLAGS_SUPPORT | ||
4 | bool | ||
5 | default y | ||
6 | |||
7 | source "lib/Kconfig.debug" | ||
8 | |||
9 | config DEBUG_RODATA | ||
10 | bool "Write protect kernel read-only data structures" | ||
11 | depends on DEBUG_KERNEL | ||
12 | help | ||
13 | Mark the kernel read-only data as write-protected in the pagetables, | ||
14 | in order to catch accidental (and incorrect) writes to such const data. | ||
15 | This option may have a slight performance impact because a portion | ||
16 | of the kernel code won't be covered by a 2MB TLB anymore. | ||
17 | If in doubt, say "N". | ||
18 | |||
19 | config IOMMU_DEBUG | ||
20 | depends on IOMMU && DEBUG_KERNEL | ||
21 | bool "Enable IOMMU debugging" | ||
22 | help | ||
23 | Force the IOMMU to on even when you have less than 4GB of | ||
24 | memory and add debugging code. On overflow always panic. And | ||
25 | allow to enable IOMMU leak tracing. Can be disabled at boot | ||
26 | time with iommu=noforce. This will also enable scatter gather | ||
27 | list merging. Currently not recommended for production | ||
28 | code. When you use it make sure you have a big enough | ||
29 | IOMMU/AGP aperture. Most of the options enabled by this can | ||
30 | be set more finegrained using the iommu= command line | ||
31 | options. See Documentation/x86_64/boot-options.txt for more | ||
32 | details. | ||
33 | |||
34 | config IOMMU_LEAK | ||
35 | bool "IOMMU leak tracing" | ||
36 | depends on DEBUG_KERNEL | ||
37 | depends on IOMMU_DEBUG | ||
38 | help | ||
39 | Add a simple leak tracer to the IOMMU code. This is useful when you | ||
40 | are debugging a buggy device driver that leaks IOMMU mappings. | ||
41 | |||
42 | config DEBUG_STACKOVERFLOW | ||
43 | bool "Check for stack overflows" | ||
44 | depends on DEBUG_KERNEL | ||
45 | help | ||
46 | This option will cause messages to be printed if free stack space | ||
47 | drops below a certain limit. | ||
48 | |||
49 | config DEBUG_STACK_USAGE | ||
50 | bool "Stack utilization instrumentation" | ||
51 | depends on DEBUG_KERNEL | ||
52 | help | ||
53 | Enables the display of the minimum amount of free stack which each | ||
54 | task has ever had available in the sysrq-T and sysrq-P debug output. | ||
55 | |||
56 | This option will slow down process creation somewhat. | ||
57 | |||
58 | #config X86_REMOTE_DEBUG | ||
59 | # bool "kgdb debugging stub" | ||
60 | |||
61 | endmenu | ||
diff --git a/arch/xtensa/Kconfig b/arch/xtensa/Kconfig index 85ffbb491490..d3cb3d6af4c8 100644 --- a/arch/xtensa/Kconfig +++ b/arch/xtensa/Kconfig | |||
@@ -1,5 +1,5 @@ | |||
1 | # For a description of the syntax of this configuration file, | 1 | # For a description of the syntax of this configuration file, |
2 | # see Documentation/kbuild/config-language.txt. | 2 | # see Documentation/kbuild/kconfig-language.txt. |
3 | 3 | ||
4 | mainmenu "Linux/Xtensa Kernel Configuration" | 4 | mainmenu "Linux/Xtensa Kernel Configuration" |
5 | 5 | ||