diff options
94 files changed, 841 insertions, 721 deletions
diff --git a/Documentation/feature-removal-schedule.txt b/Documentation/feature-removal-schedule.txt index ed511af0f79a..05df0b7514b6 100644 --- a/Documentation/feature-removal-schedule.txt +++ b/Documentation/feature-removal-schedule.txt | |||
| @@ -589,3 +589,26 @@ Why: Useful in 2003, implementation is a hack. | |||
| 589 | Generally invoked by accident today. | 589 | Generally invoked by accident today. |
| 590 | Seen as doing more harm than good. | 590 | Seen as doing more harm than good. |
| 591 | Who: Len Brown <len.brown@intel.com> | 591 | Who: Len Brown <len.brown@intel.com> |
| 592 | |||
| 593 | ---------------------------- | ||
| 594 | |||
| 595 | What: video4linux /dev/vtx teletext API support | ||
| 596 | When: 2.6.35 | ||
| 597 | Files: drivers/media/video/saa5246a.c drivers/media/video/saa5249.c | ||
| 598 | include/linux/videotext.h | ||
| 599 | Why: The vtx device nodes have been superseded by vbi device nodes | ||
| 600 | for many years. No applications exist that use the vtx support. | ||
| 601 | Of the two i2c drivers that actually support this API the saa5249 | ||
| 602 | has been impossible to use for a year now and no known hardware | ||
| 603 | that supports this device exists. The saa5246a is theoretically | ||
| 604 | supported by the old mxb boards, but it never actually worked. | ||
| 605 | |||
| 606 | In summary: there is no hardware that can use this API and there | ||
| 607 | are no applications actually implementing this API. | ||
| 608 | |||
| 609 | The vtx support still reserves minors 192-223 and we would really | ||
| 610 | like to reuse those for upcoming new functionality. In the unlikely | ||
| 611 | event that new hardware appears that wants to use the functionality | ||
| 612 | provided by the vtx API, then that functionality should be build | ||
| 613 | around the sliced VBI API instead. | ||
| 614 | Who: Hans Verkuil <hverkuil@xs4all.nl> | ||
diff --git a/arch/arm/boot/compressed/head.S b/arch/arm/boot/compressed/head.S index 6ab6b337a913..c5191b1532e8 100644 --- a/arch/arm/boot/compressed/head.S +++ b/arch/arm/boot/compressed/head.S | |||
| @@ -685,8 +685,8 @@ proc_types: | |||
| 685 | W(b) __armv4_mmu_cache_off | 685 | W(b) __armv4_mmu_cache_off |
| 686 | W(b) __armv4_mmu_cache_flush | 686 | W(b) __armv4_mmu_cache_flush |
| 687 | 687 | ||
| 688 | .word 0x56056930 | 688 | .word 0x56056900 |
| 689 | .word 0xff0ffff0 @ PXA935 | 689 | .word 0xffffff00 @ PXA9xx |
| 690 | W(b) __armv4_mmu_cache_on | 690 | W(b) __armv4_mmu_cache_on |
| 691 | W(b) __armv4_mmu_cache_off | 691 | W(b) __armv4_mmu_cache_off |
| 692 | W(b) __armv4_mmu_cache_flush | 692 | W(b) __armv4_mmu_cache_flush |
| @@ -697,12 +697,6 @@ proc_types: | |||
| 697 | W(b) __armv4_mmu_cache_off | 697 | W(b) __armv4_mmu_cache_off |
| 698 | W(b) __armv5tej_mmu_cache_flush | 698 | W(b) __armv5tej_mmu_cache_flush |
| 699 | 699 | ||
| 700 | .word 0x56056930 | ||
| 701 | .word 0xff0ffff0 @ PXA935 | ||
| 702 | W(b) __armv4_mmu_cache_on | ||
| 703 | W(b) __armv4_mmu_cache_off | ||
| 704 | W(b) __armv4_mmu_cache_flush | ||
| 705 | |||
| 706 | .word 0x56050000 @ Feroceon | 700 | .word 0x56050000 @ Feroceon |
| 707 | .word 0xff0f0000 | 701 | .word 0xff0f0000 |
| 708 | W(b) __armv4_mmu_cache_on | 702 | W(b) __armv4_mmu_cache_on |
diff --git a/arch/arm/configs/imote2_defconfig b/arch/arm/configs/imote2_defconfig index 95d2becfc664..21f2bff8a363 100644 --- a/arch/arm/configs/imote2_defconfig +++ b/arch/arm/configs/imote2_defconfig | |||
| @@ -1,13 +1,14 @@ | |||
| 1 | # | 1 | # |
| 2 | # Automatically generated make config: don't edit | 2 | # Automatically generated make config: don't edit |
| 3 | # Linux kernel version: 2.6.33-rc8 | 3 | # Linux kernel version: 2.6.34-rc2 |
| 4 | # Sat Feb 13 21:48:53 2010 | 4 | # Thu Apr 8 14:49:08 2010 |
| 5 | # | 5 | # |
| 6 | CONFIG_ARM=y | 6 | CONFIG_ARM=y |
| 7 | CONFIG_SYS_SUPPORTS_APM_EMULATION=y | 7 | CONFIG_SYS_SUPPORTS_APM_EMULATION=y |
| 8 | CONFIG_GENERIC_GPIO=y | 8 | CONFIG_GENERIC_GPIO=y |
| 9 | CONFIG_GENERIC_TIME=y | 9 | CONFIG_GENERIC_TIME=y |
| 10 | CONFIG_GENERIC_CLOCKEVENTS=y | 10 | CONFIG_GENERIC_CLOCKEVENTS=y |
| 11 | CONFIG_HAVE_PROC_CPU=y | ||
| 11 | CONFIG_GENERIC_HARDIRQS=y | 12 | CONFIG_GENERIC_HARDIRQS=y |
| 12 | CONFIG_STACKTRACE_SUPPORT=y | 13 | CONFIG_STACKTRACE_SUPPORT=y |
| 13 | CONFIG_HAVE_LATENCYTOP_SUPPORT=y | 14 | CONFIG_HAVE_LATENCYTOP_SUPPORT=y |
| @@ -19,6 +20,7 @@ CONFIG_RWSEM_GENERIC_SPINLOCK=y | |||
| 19 | CONFIG_ARCH_HAS_CPUFREQ=y | 20 | CONFIG_ARCH_HAS_CPUFREQ=y |
| 20 | CONFIG_GENERIC_HWEIGHT=y | 21 | CONFIG_GENERIC_HWEIGHT=y |
| 21 | CONFIG_GENERIC_CALIBRATE_DELAY=y | 22 | CONFIG_GENERIC_CALIBRATE_DELAY=y |
| 23 | CONFIG_NEED_DMA_MAP_STATE=y | ||
| 22 | CONFIG_ARCH_MTD_XIP=y | 24 | CONFIG_ARCH_MTD_XIP=y |
| 23 | CONFIG_GENERIC_HARDIRQS_NO__DO_IRQ=y | 25 | CONFIG_GENERIC_HARDIRQS_NO__DO_IRQ=y |
| 24 | CONFIG_VECTORS_BASE=0xffff0000 | 26 | CONFIG_VECTORS_BASE=0xffff0000 |
| @@ -60,11 +62,6 @@ CONFIG_RCU_FANOUT=32 | |||
| 60 | # CONFIG_TREE_RCU_TRACE is not set | 62 | # CONFIG_TREE_RCU_TRACE is not set |
| 61 | # CONFIG_IKCONFIG is not set | 63 | # CONFIG_IKCONFIG is not set |
| 62 | CONFIG_LOG_BUF_SHIFT=14 | 64 | CONFIG_LOG_BUF_SHIFT=14 |
| 63 | CONFIG_GROUP_SCHED=y | ||
| 64 | CONFIG_FAIR_GROUP_SCHED=y | ||
| 65 | # CONFIG_RT_GROUP_SCHED is not set | ||
| 66 | CONFIG_USER_SCHED=y | ||
| 67 | # CONFIG_CGROUP_SCHED is not set | ||
| 68 | # CONFIG_CGROUPS is not set | 65 | # CONFIG_CGROUPS is not set |
| 69 | CONFIG_SYSFS_DEPRECATED=y | 66 | CONFIG_SYSFS_DEPRECATED=y |
| 70 | CONFIG_SYSFS_DEPRECATED_V2=y | 67 | CONFIG_SYSFS_DEPRECATED_V2=y |
| @@ -97,10 +94,14 @@ CONFIG_TIMERFD=y | |||
| 97 | CONFIG_EVENTFD=y | 94 | CONFIG_EVENTFD=y |
| 98 | CONFIG_SHMEM=y | 95 | CONFIG_SHMEM=y |
| 99 | CONFIG_AIO=y | 96 | CONFIG_AIO=y |
| 97 | CONFIG_HAVE_PERF_EVENTS=y | ||
| 98 | CONFIG_PERF_USE_VMALLOC=y | ||
| 100 | 99 | ||
| 101 | # | 100 | # |
| 102 | # Kernel Performance Events And Counters | 101 | # Kernel Performance Events And Counters |
| 103 | # | 102 | # |
| 103 | # CONFIG_PERF_EVENTS is not set | ||
| 104 | # CONFIG_PERF_COUNTERS is not set | ||
| 104 | CONFIG_VM_EVENT_COUNTERS=y | 105 | CONFIG_VM_EVENT_COUNTERS=y |
| 105 | # CONFIG_COMPAT_BRK is not set | 106 | # CONFIG_COMPAT_BRK is not set |
| 106 | CONFIG_SLAB=y | 107 | CONFIG_SLAB=y |
| @@ -184,6 +185,7 @@ CONFIG_MMU=y | |||
| 184 | # CONFIG_ARCH_REALVIEW is not set | 185 | # CONFIG_ARCH_REALVIEW is not set |
| 185 | # CONFIG_ARCH_VERSATILE is not set | 186 | # CONFIG_ARCH_VERSATILE is not set |
| 186 | # CONFIG_ARCH_AT91 is not set | 187 | # CONFIG_ARCH_AT91 is not set |
| 188 | # CONFIG_ARCH_BCMRING is not set | ||
| 187 | # CONFIG_ARCH_CLPS711X is not set | 189 | # CONFIG_ARCH_CLPS711X is not set |
| 188 | # CONFIG_ARCH_GEMINI is not set | 190 | # CONFIG_ARCH_GEMINI is not set |
| 189 | # CONFIG_ARCH_EBSA110 is not set | 191 | # CONFIG_ARCH_EBSA110 is not set |
| @@ -193,7 +195,6 @@ CONFIG_MMU=y | |||
| 193 | # CONFIG_ARCH_STMP3XXX is not set | 195 | # CONFIG_ARCH_STMP3XXX is not set |
| 194 | # CONFIG_ARCH_NETX is not set | 196 | # CONFIG_ARCH_NETX is not set |
| 195 | # CONFIG_ARCH_H720X is not set | 197 | # CONFIG_ARCH_H720X is not set |
| 196 | # CONFIG_ARCH_NOMADIK is not set | ||
| 197 | # CONFIG_ARCH_IOP13XX is not set | 198 | # CONFIG_ARCH_IOP13XX is not set |
| 198 | # CONFIG_ARCH_IOP32X is not set | 199 | # CONFIG_ARCH_IOP32X is not set |
| 199 | # CONFIG_ARCH_IOP33X is not set | 200 | # CONFIG_ARCH_IOP33X is not set |
| @@ -210,21 +211,26 @@ CONFIG_MMU=y | |||
| 210 | # CONFIG_ARCH_KS8695 is not set | 211 | # CONFIG_ARCH_KS8695 is not set |
| 211 | # CONFIG_ARCH_NS9XXX is not set | 212 | # CONFIG_ARCH_NS9XXX is not set |
| 212 | # CONFIG_ARCH_W90X900 is not set | 213 | # CONFIG_ARCH_W90X900 is not set |
| 214 | # CONFIG_ARCH_NUC93X is not set | ||
| 213 | # CONFIG_ARCH_PNX4008 is not set | 215 | # CONFIG_ARCH_PNX4008 is not set |
| 214 | CONFIG_ARCH_PXA=y | 216 | CONFIG_ARCH_PXA=y |
| 215 | # CONFIG_ARCH_MSM is not set | 217 | # CONFIG_ARCH_MSM is not set |
| 218 | # CONFIG_ARCH_SHMOBILE is not set | ||
| 216 | # CONFIG_ARCH_RPC is not set | 219 | # CONFIG_ARCH_RPC is not set |
| 217 | # CONFIG_ARCH_SA1100 is not set | 220 | # CONFIG_ARCH_SA1100 is not set |
| 218 | # CONFIG_ARCH_S3C2410 is not set | 221 | # CONFIG_ARCH_S3C2410 is not set |
| 219 | # CONFIG_ARCH_S3C64XX is not set | 222 | # CONFIG_ARCH_S3C64XX is not set |
| 223 | # CONFIG_ARCH_S5P6440 is not set | ||
| 224 | # CONFIG_ARCH_S5P6442 is not set | ||
| 220 | # CONFIG_ARCH_S5PC1XX is not set | 225 | # CONFIG_ARCH_S5PC1XX is not set |
| 226 | # CONFIG_ARCH_S5PV210 is not set | ||
| 221 | # CONFIG_ARCH_SHARK is not set | 227 | # CONFIG_ARCH_SHARK is not set |
| 222 | # CONFIG_ARCH_LH7A40X is not set | 228 | # CONFIG_ARCH_LH7A40X is not set |
| 223 | # CONFIG_ARCH_U300 is not set | 229 | # CONFIG_ARCH_U300 is not set |
| 230 | # CONFIG_ARCH_U8500 is not set | ||
| 231 | # CONFIG_ARCH_NOMADIK is not set | ||
| 224 | # CONFIG_ARCH_DAVINCI is not set | 232 | # CONFIG_ARCH_DAVINCI is not set |
| 225 | # CONFIG_ARCH_OMAP is not set | 233 | # CONFIG_ARCH_OMAP is not set |
| 226 | # CONFIG_ARCH_BCMRING is not set | ||
| 227 | # CONFIG_ARCH_U8500 is not set | ||
| 228 | 234 | ||
| 229 | # | 235 | # |
| 230 | # Intel PXA2xx/PXA3xx Implementations | 236 | # Intel PXA2xx/PXA3xx Implementations |
| @@ -253,6 +259,7 @@ CONFIG_ARCH_PXA=y | |||
| 253 | # CONFIG_MACH_EM_X270 is not set | 259 | # CONFIG_MACH_EM_X270 is not set |
| 254 | # CONFIG_MACH_EXEDA is not set | 260 | # CONFIG_MACH_EXEDA is not set |
| 255 | # CONFIG_MACH_CM_X300 is not set | 261 | # CONFIG_MACH_CM_X300 is not set |
| 262 | # CONFIG_MACH_CAPC7117 is not set | ||
| 256 | # CONFIG_ARCH_GUMSTIX is not set | 263 | # CONFIG_ARCH_GUMSTIX is not set |
| 257 | CONFIG_MACH_INTELMOTE2=y | 264 | CONFIG_MACH_INTELMOTE2=y |
| 258 | # CONFIG_MACH_STARGATE2 is not set | 265 | # CONFIG_MACH_STARGATE2 is not set |
| @@ -275,7 +282,11 @@ CONFIG_MACH_INTELMOTE2=y | |||
| 275 | # CONFIG_PXA_EZX is not set | 282 | # CONFIG_PXA_EZX is not set |
| 276 | # CONFIG_MACH_MP900C is not set | 283 | # CONFIG_MACH_MP900C is not set |
| 277 | # CONFIG_ARCH_PXA_PALM is not set | 284 | # CONFIG_ARCH_PXA_PALM is not set |
| 285 | # CONFIG_MACH_RAUMFELD_RC is not set | ||
| 286 | # CONFIG_MACH_RAUMFELD_CONNECTOR is not set | ||
| 287 | # CONFIG_MACH_RAUMFELD_SPEAKER is not set | ||
| 278 | # CONFIG_PXA_SHARPSL is not set | 288 | # CONFIG_PXA_SHARPSL is not set |
| 289 | # CONFIG_MACH_ICONTROL is not set | ||
| 279 | # CONFIG_ARCH_PXA_ESERIES is not set | 290 | # CONFIG_ARCH_PXA_ESERIES is not set |
| 280 | CONFIG_PXA27x=y | 291 | CONFIG_PXA27x=y |
| 281 | CONFIG_PXA_SSP=y | 292 | CONFIG_PXA_SSP=y |
| @@ -302,6 +313,7 @@ CONFIG_ARM_THUMB=y | |||
| 302 | CONFIG_ARM_L1_CACHE_SHIFT=5 | 313 | CONFIG_ARM_L1_CACHE_SHIFT=5 |
| 303 | CONFIG_IWMMXT=y | 314 | CONFIG_IWMMXT=y |
| 304 | CONFIG_XSCALE_PMU=y | 315 | CONFIG_XSCALE_PMU=y |
| 316 | CONFIG_CPU_HAS_PMU=y | ||
| 305 | CONFIG_COMMON_CLKDEV=y | 317 | CONFIG_COMMON_CLKDEV=y |
| 306 | 318 | ||
| 307 | # | 319 | # |
| @@ -352,7 +364,7 @@ CONFIG_ALIGNMENT_TRAP=y | |||
| 352 | # | 364 | # |
| 353 | CONFIG_ZBOOT_ROM_TEXT=0x0 | 365 | CONFIG_ZBOOT_ROM_TEXT=0x0 |
| 354 | CONFIG_ZBOOT_ROM_BSS=0x0 | 366 | CONFIG_ZBOOT_ROM_BSS=0x0 |
| 355 | CONFIG_CMDLINE="console=tty1 root=/dev/mmcblk0p2 rootfstype=ext2 rootdelay=3 ip=192.168.0.202:192.168.0.200:192.168.0.200:255.255.255.0 debug" | 367 | CONFIG_CMDLINE="root=/dev/mtdblock2 rootfstype=jffs2 console=ttyS2,115200 mem=32M" |
| 356 | # CONFIG_XIP_KERNEL is not set | 368 | # CONFIG_XIP_KERNEL is not set |
| 357 | CONFIG_KEXEC=y | 369 | CONFIG_KEXEC=y |
| 358 | CONFIG_ATAGS_PROC=y | 370 | CONFIG_ATAGS_PROC=y |
| @@ -360,24 +372,8 @@ CONFIG_ATAGS_PROC=y | |||
| 360 | # | 372 | # |
| 361 | # CPU Power Management | 373 | # CPU Power Management |
| 362 | # | 374 | # |
| 363 | CONFIG_CPU_FREQ=y | 375 | # CONFIG_CPU_FREQ is not set |
| 364 | CONFIG_CPU_FREQ_TABLE=y | 376 | # CONFIG_CPU_IDLE is not set |
| 365 | CONFIG_CPU_FREQ_DEBUG=y | ||
| 366 | CONFIG_CPU_FREQ_STAT=y | ||
| 367 | # CONFIG_CPU_FREQ_STAT_DETAILS is not set | ||
| 368 | CONFIG_CPU_FREQ_DEFAULT_GOV_PERFORMANCE=y | ||
| 369 | # CONFIG_CPU_FREQ_DEFAULT_GOV_POWERSAVE is not set | ||
| 370 | # CONFIG_CPU_FREQ_DEFAULT_GOV_USERSPACE is not set | ||
| 371 | # CONFIG_CPU_FREQ_DEFAULT_GOV_ONDEMAND is not set | ||
| 372 | # CONFIG_CPU_FREQ_DEFAULT_GOV_CONSERVATIVE is not set | ||
| 373 | CONFIG_CPU_FREQ_GOV_PERFORMANCE=y | ||
| 374 | CONFIG_CPU_FREQ_GOV_POWERSAVE=m | ||
| 375 | CONFIG_CPU_FREQ_GOV_USERSPACE=m | ||
| 376 | CONFIG_CPU_FREQ_GOV_ONDEMAND=m | ||
| 377 | CONFIG_CPU_FREQ_GOV_CONSERVATIVE=m | ||
| 378 | CONFIG_CPU_IDLE=y | ||
| 379 | CONFIG_CPU_IDLE_GOV_LADDER=y | ||
| 380 | CONFIG_CPU_IDLE_GOV_MENU=y | ||
| 381 | 377 | ||
| 382 | # | 378 | # |
| 383 | # Floating point emulation | 379 | # Floating point emulation |
| @@ -409,6 +405,7 @@ CONFIG_SUSPEND=y | |||
| 409 | CONFIG_SUSPEND_FREEZER=y | 405 | CONFIG_SUSPEND_FREEZER=y |
| 410 | CONFIG_APM_EMULATION=y | 406 | CONFIG_APM_EMULATION=y |
| 411 | CONFIG_PM_RUNTIME=y | 407 | CONFIG_PM_RUNTIME=y |
| 408 | CONFIG_PM_OPS=y | ||
| 412 | CONFIG_ARCH_SUSPEND_POSSIBLE=y | 409 | CONFIG_ARCH_SUSPEND_POSSIBLE=y |
| 413 | CONFIG_NET=y | 410 | CONFIG_NET=y |
| 414 | 411 | ||
| @@ -416,7 +413,6 @@ CONFIG_NET=y | |||
| 416 | # Networking options | 413 | # Networking options |
| 417 | # | 414 | # |
| 418 | CONFIG_PACKET=y | 415 | CONFIG_PACKET=y |
| 419 | CONFIG_PACKET_MMAP=y | ||
| 420 | CONFIG_UNIX=y | 416 | CONFIG_UNIX=y |
| 421 | CONFIG_XFRM=y | 417 | CONFIG_XFRM=y |
| 422 | # CONFIG_XFRM_USER is not set | 418 | # CONFIG_XFRM_USER is not set |
| @@ -506,6 +502,7 @@ CONFIG_NF_CT_NETLINK=m | |||
| 506 | CONFIG_NETFILTER_XTABLES=m | 502 | CONFIG_NETFILTER_XTABLES=m |
| 507 | CONFIG_NETFILTER_XT_TARGET_CLASSIFY=m | 503 | CONFIG_NETFILTER_XT_TARGET_CLASSIFY=m |
| 508 | # CONFIG_NETFILTER_XT_TARGET_CONNMARK is not set | 504 | # CONFIG_NETFILTER_XT_TARGET_CONNMARK is not set |
| 505 | # CONFIG_NETFILTER_XT_TARGET_CT is not set | ||
| 509 | # CONFIG_NETFILTER_XT_TARGET_DSCP is not set | 506 | # CONFIG_NETFILTER_XT_TARGET_DSCP is not set |
| 510 | CONFIG_NETFILTER_XT_TARGET_HL=m | 507 | CONFIG_NETFILTER_XT_TARGET_HL=m |
| 511 | CONFIG_NETFILTER_XT_TARGET_LED=m | 508 | CONFIG_NETFILTER_XT_TARGET_LED=m |
| @@ -622,6 +619,7 @@ CONFIG_IP6_NF_RAW=m | |||
| 622 | # CONFIG_ATM is not set | 619 | # CONFIG_ATM is not set |
| 623 | CONFIG_STP=m | 620 | CONFIG_STP=m |
| 624 | CONFIG_BRIDGE=m | 621 | CONFIG_BRIDGE=m |
| 622 | # CONFIG_BRIDGE_IGMP_SNOOPING is not set | ||
| 625 | # CONFIG_NET_DSA is not set | 623 | # CONFIG_NET_DSA is not set |
| 626 | # CONFIG_VLAN_8021Q is not set | 624 | # CONFIG_VLAN_8021Q is not set |
| 627 | # CONFIG_DECNET is not set | 625 | # CONFIG_DECNET is not set |
| @@ -646,32 +644,7 @@ CONFIG_NET_CLS_ROUTE=y | |||
| 646 | # CONFIG_HAMRADIO is not set | 644 | # CONFIG_HAMRADIO is not set |
| 647 | # CONFIG_CAN is not set | 645 | # CONFIG_CAN is not set |
| 648 | # CONFIG_IRDA is not set | 646 | # CONFIG_IRDA is not set |
| 649 | CONFIG_BT=y | 647 | # CONFIG_BT is not set |
| 650 | CONFIG_BT_L2CAP=y | ||
| 651 | CONFIG_BT_SCO=y | ||
| 652 | CONFIG_BT_RFCOMM=y | ||
| 653 | CONFIG_BT_RFCOMM_TTY=y | ||
| 654 | CONFIG_BT_BNEP=y | ||
| 655 | CONFIG_BT_BNEP_MC_FILTER=y | ||
| 656 | CONFIG_BT_BNEP_PROTO_FILTER=y | ||
| 657 | CONFIG_BT_HIDP=y | ||
| 658 | |||
| 659 | # | ||
| 660 | # Bluetooth device drivers | ||
| 661 | # | ||
| 662 | CONFIG_BT_HCIBTUSB=m | ||
| 663 | CONFIG_BT_HCIBTSDIO=m | ||
| 664 | CONFIG_BT_HCIUART=y | ||
| 665 | CONFIG_BT_HCIUART_H4=y | ||
| 666 | # CONFIG_BT_HCIUART_BCSP is not set | ||
| 667 | # CONFIG_BT_HCIUART_LL is not set | ||
| 668 | CONFIG_BT_HCIBCM203X=m | ||
| 669 | CONFIG_BT_HCIBPA10X=m | ||
| 670 | CONFIG_BT_HCIBFUSB=m | ||
| 671 | CONFIG_BT_HCIVHCI=m | ||
| 672 | CONFIG_BT_MRVL=m | ||
| 673 | CONFIG_BT_MRVL_SDIO=m | ||
| 674 | # CONFIG_BT_ATH3K is not set | ||
| 675 | # CONFIG_AF_RXRPC is not set | 648 | # CONFIG_AF_RXRPC is not set |
| 676 | CONFIG_FIB_RULES=y | 649 | CONFIG_FIB_RULES=y |
| 677 | # CONFIG_WIRELESS is not set | 650 | # CONFIG_WIRELESS is not set |
| @@ -687,7 +660,8 @@ CONFIG_FIB_RULES=y | |||
| 687 | # Generic Driver Options | 660 | # Generic Driver Options |
| 688 | # | 661 | # |
| 689 | CONFIG_UEVENT_HELPER_PATH="/sbin/hotplug" | 662 | CONFIG_UEVENT_HELPER_PATH="/sbin/hotplug" |
| 690 | # CONFIG_DEVTMPFS is not set | 663 | CONFIG_DEVTMPFS=y |
| 664 | CONFIG_DEVTMPFS_MOUNT=y | ||
| 691 | CONFIG_STANDALONE=y | 665 | CONFIG_STANDALONE=y |
| 692 | CONFIG_PREVENT_FIRMWARE_BUILD=y | 666 | CONFIG_PREVENT_FIRMWARE_BUILD=y |
| 693 | CONFIG_FW_LOADER=m | 667 | CONFIG_FW_LOADER=m |
| @@ -703,9 +677,9 @@ CONFIG_MTD=y | |||
| 703 | # CONFIG_MTD_CONCAT is not set | 677 | # CONFIG_MTD_CONCAT is not set |
| 704 | CONFIG_MTD_PARTITIONS=y | 678 | CONFIG_MTD_PARTITIONS=y |
| 705 | # CONFIG_MTD_REDBOOT_PARTS is not set | 679 | # CONFIG_MTD_REDBOOT_PARTS is not set |
| 706 | # CONFIG_MTD_CMDLINE_PARTS is not set | 680 | CONFIG_MTD_CMDLINE_PARTS=y |
| 707 | # CONFIG_MTD_AFS_PARTS is not set | 681 | CONFIG_MTD_AFS_PARTS=y |
| 708 | # CONFIG_MTD_AR7_PARTS is not set | 682 | CONFIG_MTD_AR7_PARTS=y |
| 709 | 683 | ||
| 710 | # | 684 | # |
| 711 | # User Modules And Translation Layers | 685 | # User Modules And Translation Layers |
| @@ -812,6 +786,7 @@ CONFIG_HAVE_IDE=y | |||
| 812 | # | 786 | # |
| 813 | # SCSI device support | 787 | # SCSI device support |
| 814 | # | 788 | # |
| 789 | CONFIG_SCSI_MOD=y | ||
| 815 | # CONFIG_RAID_ATTRS is not set | 790 | # CONFIG_RAID_ATTRS is not set |
| 816 | # CONFIG_SCSI is not set | 791 | # CONFIG_SCSI is not set |
| 817 | # CONFIG_SCSI_DMA is not set | 792 | # CONFIG_SCSI_DMA is not set |
| @@ -965,6 +940,7 @@ CONFIG_SERIAL_PXA=y | |||
| 965 | CONFIG_SERIAL_PXA_CONSOLE=y | 940 | CONFIG_SERIAL_PXA_CONSOLE=y |
| 966 | CONFIG_SERIAL_CORE=y | 941 | CONFIG_SERIAL_CORE=y |
| 967 | CONFIG_SERIAL_CORE_CONSOLE=y | 942 | CONFIG_SERIAL_CORE_CONSOLE=y |
| 943 | # CONFIG_SERIAL_TIMBERDALE is not set | ||
| 968 | CONFIG_UNIX98_PTYS=y | 944 | CONFIG_UNIX98_PTYS=y |
| 969 | # CONFIG_DEVPTS_MULTIPLE_INSTANCES is not set | 945 | # CONFIG_DEVPTS_MULTIPLE_INSTANCES is not set |
| 970 | CONFIG_LEGACY_PTYS=y | 946 | CONFIG_LEGACY_PTYS=y |
| @@ -993,6 +969,7 @@ CONFIG_I2C_HELPER_AUTO=y | |||
| 993 | CONFIG_I2C_PXA=y | 969 | CONFIG_I2C_PXA=y |
| 994 | # CONFIG_I2C_PXA_SLAVE is not set | 970 | # CONFIG_I2C_PXA_SLAVE is not set |
| 995 | # CONFIG_I2C_SIMTEC is not set | 971 | # CONFIG_I2C_SIMTEC is not set |
| 972 | # CONFIG_I2C_XILINX is not set | ||
| 996 | 973 | ||
| 997 | # | 974 | # |
| 998 | # External I2C/SMBus adapter drivers | 975 | # External I2C/SMBus adapter drivers |
| @@ -1006,15 +983,9 @@ CONFIG_I2C_PXA=y | |||
| 1006 | # | 983 | # |
| 1007 | # CONFIG_I2C_PCA_PLATFORM is not set | 984 | # CONFIG_I2C_PCA_PLATFORM is not set |
| 1008 | # CONFIG_I2C_STUB is not set | 985 | # CONFIG_I2C_STUB is not set |
| 1009 | |||
| 1010 | # | ||
| 1011 | # Miscellaneous I2C Chip support | ||
| 1012 | # | ||
| 1013 | # CONFIG_SENSORS_TSL2550 is not set | ||
| 1014 | # CONFIG_I2C_DEBUG_CORE is not set | 986 | # CONFIG_I2C_DEBUG_CORE is not set |
| 1015 | # CONFIG_I2C_DEBUG_ALGO is not set | 987 | # CONFIG_I2C_DEBUG_ALGO is not set |
| 1016 | # CONFIG_I2C_DEBUG_BUS is not set | 988 | # CONFIG_I2C_DEBUG_BUS is not set |
| 1017 | # CONFIG_I2C_DEBUG_CHIP is not set | ||
| 1018 | CONFIG_SPI=y | 989 | CONFIG_SPI=y |
| 1019 | # CONFIG_SPI_DEBUG is not set | 990 | # CONFIG_SPI_DEBUG is not set |
| 1020 | CONFIG_SPI_MASTER=y | 991 | CONFIG_SPI_MASTER=y |
| @@ -1046,10 +1017,12 @@ CONFIG_GPIO_SYSFS=y | |||
| 1046 | # | 1017 | # |
| 1047 | # Memory mapped GPIO expanders: | 1018 | # Memory mapped GPIO expanders: |
| 1048 | # | 1019 | # |
| 1020 | # CONFIG_GPIO_IT8761E is not set | ||
| 1049 | 1021 | ||
| 1050 | # | 1022 | # |
| 1051 | # I2C GPIO expanders: | 1023 | # I2C GPIO expanders: |
| 1052 | # | 1024 | # |
| 1025 | # CONFIG_GPIO_MAX7300 is not set | ||
| 1053 | # CONFIG_GPIO_MAX732X is not set | 1026 | # CONFIG_GPIO_MAX732X is not set |
| 1054 | # CONFIG_GPIO_PCA953X is not set | 1027 | # CONFIG_GPIO_PCA953X is not set |
| 1055 | # CONFIG_GPIO_PCF857X is not set | 1028 | # CONFIG_GPIO_PCF857X is not set |
| @@ -1093,10 +1066,12 @@ CONFIG_SSB_POSSIBLE=y | |||
| 1093 | # Multifunction device drivers | 1066 | # Multifunction device drivers |
| 1094 | # | 1067 | # |
| 1095 | # CONFIG_MFD_CORE is not set | 1068 | # CONFIG_MFD_CORE is not set |
| 1069 | # CONFIG_MFD_88PM860X is not set | ||
| 1096 | # CONFIG_MFD_SM501 is not set | 1070 | # CONFIG_MFD_SM501 is not set |
| 1097 | # CONFIG_MFD_ASIC3 is not set | 1071 | # CONFIG_MFD_ASIC3 is not set |
| 1098 | # CONFIG_HTC_EGPIO is not set | 1072 | # CONFIG_HTC_EGPIO is not set |
| 1099 | # CONFIG_HTC_PASIC3 is not set | 1073 | # CONFIG_HTC_PASIC3 is not set |
| 1074 | # CONFIG_HTC_I2CPLD is not set | ||
| 1100 | # CONFIG_TPS65010 is not set | 1075 | # CONFIG_TPS65010 is not set |
| 1101 | # CONFIG_TWL4030_CORE is not set | 1076 | # CONFIG_TWL4030_CORE is not set |
| 1102 | # CONFIG_MFD_TMIO is not set | 1077 | # CONFIG_MFD_TMIO is not set |
| @@ -1105,22 +1080,25 @@ CONFIG_SSB_POSSIBLE=y | |||
| 1105 | # CONFIG_MFD_TC6393XB is not set | 1080 | # CONFIG_MFD_TC6393XB is not set |
| 1106 | CONFIG_PMIC_DA903X=y | 1081 | CONFIG_PMIC_DA903X=y |
| 1107 | # CONFIG_PMIC_ADP5520 is not set | 1082 | # CONFIG_PMIC_ADP5520 is not set |
| 1083 | # CONFIG_MFD_MAX8925 is not set | ||
| 1108 | # CONFIG_MFD_WM8400 is not set | 1084 | # CONFIG_MFD_WM8400 is not set |
| 1109 | # CONFIG_MFD_WM831X is not set | 1085 | # CONFIG_MFD_WM831X is not set |
| 1110 | # CONFIG_MFD_WM8350_I2C is not set | 1086 | # CONFIG_MFD_WM8350_I2C is not set |
| 1087 | # CONFIG_MFD_WM8994 is not set | ||
| 1111 | # CONFIG_MFD_PCF50633 is not set | 1088 | # CONFIG_MFD_PCF50633 is not set |
| 1112 | # CONFIG_MFD_MC13783 is not set | 1089 | # CONFIG_MFD_MC13783 is not set |
| 1113 | # CONFIG_AB3100_CORE is not set | 1090 | # CONFIG_AB3100_CORE is not set |
| 1114 | # CONFIG_EZX_PCAP is not set | 1091 | # CONFIG_EZX_PCAP is not set |
| 1115 | # CONFIG_MFD_88PM8607 is not set | ||
| 1116 | # CONFIG_AB4500_CORE is not set | 1092 | # CONFIG_AB4500_CORE is not set |
| 1117 | CONFIG_REGULATOR=y | 1093 | CONFIG_REGULATOR=y |
| 1118 | CONFIG_REGULATOR_DEBUG=y | 1094 | CONFIG_REGULATOR_DEBUG=y |
| 1095 | # CONFIG_REGULATOR_DUMMY is not set | ||
| 1119 | # CONFIG_REGULATOR_FIXED_VOLTAGE is not set | 1096 | # CONFIG_REGULATOR_FIXED_VOLTAGE is not set |
| 1120 | CONFIG_REGULATOR_VIRTUAL_CONSUMER=y | 1097 | CONFIG_REGULATOR_VIRTUAL_CONSUMER=y |
| 1121 | CONFIG_REGULATOR_USERSPACE_CONSUMER=y | 1098 | CONFIG_REGULATOR_USERSPACE_CONSUMER=y |
| 1122 | # CONFIG_REGULATOR_BQ24022 is not set | 1099 | # CONFIG_REGULATOR_BQ24022 is not set |
| 1123 | # CONFIG_REGULATOR_MAX1586 is not set | 1100 | # CONFIG_REGULATOR_MAX1586 is not set |
| 1101 | # CONFIG_REGULATOR_MAX8649 is not set | ||
| 1124 | # CONFIG_REGULATOR_MAX8660 is not set | 1102 | # CONFIG_REGULATOR_MAX8660 is not set |
| 1125 | CONFIG_REGULATOR_DA903X=y | 1103 | CONFIG_REGULATOR_DA903X=y |
| 1126 | # CONFIG_REGULATOR_LP3971 is not set | 1104 | # CONFIG_REGULATOR_LP3971 is not set |
| @@ -1218,6 +1196,7 @@ CONFIG_VIDEO_IR_I2C=y | |||
| 1218 | # CONFIG_VIDEO_SAA7191 is not set | 1196 | # CONFIG_VIDEO_SAA7191 is not set |
| 1219 | # CONFIG_VIDEO_TVP514X is not set | 1197 | # CONFIG_VIDEO_TVP514X is not set |
| 1220 | # CONFIG_VIDEO_TVP5150 is not set | 1198 | # CONFIG_VIDEO_TVP5150 is not set |
| 1199 | # CONFIG_VIDEO_TVP7002 is not set | ||
| 1221 | # CONFIG_VIDEO_VPX3220 is not set | 1200 | # CONFIG_VIDEO_VPX3220 is not set |
| 1222 | 1201 | ||
| 1223 | # | 1202 | # |
| @@ -1264,15 +1243,7 @@ CONFIG_SOC_CAMERA_MT9M111=y | |||
| 1264 | CONFIG_VIDEO_PXA27x=y | 1243 | CONFIG_VIDEO_PXA27x=y |
| 1265 | # CONFIG_VIDEO_SH_MOBILE_CEU is not set | 1244 | # CONFIG_VIDEO_SH_MOBILE_CEU is not set |
| 1266 | # CONFIG_V4L_USB_DRIVERS is not set | 1245 | # CONFIG_V4L_USB_DRIVERS is not set |
| 1267 | CONFIG_RADIO_ADAPTERS=y | 1246 | # CONFIG_RADIO_ADAPTERS is not set |
| 1268 | # CONFIG_I2C_SI4713 is not set | ||
| 1269 | # CONFIG_RADIO_SI4713 is not set | ||
| 1270 | # CONFIG_USB_DSBR is not set | ||
| 1271 | # CONFIG_RADIO_SI470X is not set | ||
| 1272 | # CONFIG_USB_MR800 is not set | ||
| 1273 | CONFIG_RADIO_TEA5764=y | ||
| 1274 | CONFIG_RADIO_TEA5764_XTAL=y | ||
| 1275 | # CONFIG_RADIO_TEF6862 is not set | ||
| 1276 | # CONFIG_DAB is not set | 1247 | # CONFIG_DAB is not set |
| 1277 | 1248 | ||
| 1278 | # | 1249 | # |
| @@ -1398,8 +1369,6 @@ CONFIG_HID=y | |||
| 1398 | # | 1369 | # |
| 1399 | # Special HID drivers | 1370 | # Special HID drivers |
| 1400 | # | 1371 | # |
| 1401 | CONFIG_HID_APPLE=m | ||
| 1402 | # CONFIG_HID_WACOM is not set | ||
| 1403 | CONFIG_USB_SUPPORT=y | 1372 | CONFIG_USB_SUPPORT=y |
| 1404 | CONFIG_USB_ARCH_HAS_HCD=y | 1373 | CONFIG_USB_ARCH_HAS_HCD=y |
| 1405 | CONFIG_USB_ARCH_HAS_OHCI=y | 1374 | CONFIG_USB_ARCH_HAS_OHCI=y |
| @@ -1477,7 +1446,6 @@ CONFIG_USB_OHCI_LITTLE_ENDIAN=y | |||
| 1477 | # CONFIG_USB_RIO500 is not set | 1446 | # CONFIG_USB_RIO500 is not set |
| 1478 | # CONFIG_USB_LEGOTOWER is not set | 1447 | # CONFIG_USB_LEGOTOWER is not set |
| 1479 | # CONFIG_USB_LCD is not set | 1448 | # CONFIG_USB_LCD is not set |
| 1480 | # CONFIG_USB_BERRY_CHARGE is not set | ||
| 1481 | # CONFIG_USB_LED is not set | 1449 | # CONFIG_USB_LED is not set |
| 1482 | # CONFIG_USB_CYPRESS_CY7C63 is not set | 1450 | # CONFIG_USB_CYPRESS_CY7C63 is not set |
| 1483 | # CONFIG_USB_CYTHERM is not set | 1451 | # CONFIG_USB_CYTHERM is not set |
| @@ -1489,7 +1457,6 @@ CONFIG_USB_OHCI_LITTLE_ENDIAN=y | |||
| 1489 | # CONFIG_USB_IOWARRIOR is not set | 1457 | # CONFIG_USB_IOWARRIOR is not set |
| 1490 | # CONFIG_USB_TEST is not set | 1458 | # CONFIG_USB_TEST is not set |
| 1491 | # CONFIG_USB_ISIGHTFW is not set | 1459 | # CONFIG_USB_ISIGHTFW is not set |
| 1492 | # CONFIG_USB_VST is not set | ||
| 1493 | CONFIG_USB_GADGET=y | 1460 | CONFIG_USB_GADGET=y |
| 1494 | # CONFIG_USB_GADGET_DEBUG is not set | 1461 | # CONFIG_USB_GADGET_DEBUG is not set |
| 1495 | # CONFIG_USB_GADGET_DEBUG_FILES is not set | 1462 | # CONFIG_USB_GADGET_DEBUG_FILES is not set |
| @@ -1529,6 +1496,7 @@ CONFIG_USB_ETH=y | |||
| 1529 | # CONFIG_USB_MIDI_GADGET is not set | 1496 | # CONFIG_USB_MIDI_GADGET is not set |
| 1530 | # CONFIG_USB_G_PRINTER is not set | 1497 | # CONFIG_USB_G_PRINTER is not set |
| 1531 | # CONFIG_USB_CDC_COMPOSITE is not set | 1498 | # CONFIG_USB_CDC_COMPOSITE is not set |
| 1499 | # CONFIG_USB_G_NOKIA is not set | ||
| 1532 | # CONFIG_USB_G_MULTI is not set | 1500 | # CONFIG_USB_G_MULTI is not set |
| 1533 | 1501 | ||
| 1534 | # | 1502 | # |
| @@ -1555,8 +1523,6 @@ CONFIG_SDIO_UART=m | |||
| 1555 | # | 1523 | # |
| 1556 | CONFIG_MMC_PXA=y | 1524 | CONFIG_MMC_PXA=y |
| 1557 | # CONFIG_MMC_SDHCI is not set | 1525 | # CONFIG_MMC_SDHCI is not set |
| 1558 | # CONFIG_MMC_AT91 is not set | ||
| 1559 | # CONFIG_MMC_ATMELMCI is not set | ||
| 1560 | CONFIG_MMC_SPI=y | 1526 | CONFIG_MMC_SPI=y |
| 1561 | # CONFIG_MEMSTICK is not set | 1527 | # CONFIG_MEMSTICK is not set |
| 1562 | CONFIG_NEW_LEDS=y | 1528 | CONFIG_NEW_LEDS=y |
| @@ -1574,11 +1540,11 @@ CONFIG_LEDS_LP3944=y | |||
| 1574 | # CONFIG_LEDS_REGULATOR is not set | 1540 | # CONFIG_LEDS_REGULATOR is not set |
| 1575 | # CONFIG_LEDS_BD2802 is not set | 1541 | # CONFIG_LEDS_BD2802 is not set |
| 1576 | # CONFIG_LEDS_LT3593 is not set | 1542 | # CONFIG_LEDS_LT3593 is not set |
| 1543 | CONFIG_LEDS_TRIGGERS=y | ||
| 1577 | 1544 | ||
| 1578 | # | 1545 | # |
| 1579 | # LED Triggers | 1546 | # LED Triggers |
| 1580 | # | 1547 | # |
| 1581 | CONFIG_LEDS_TRIGGERS=y | ||
| 1582 | CONFIG_LEDS_TRIGGER_TIMER=y | 1548 | CONFIG_LEDS_TRIGGER_TIMER=y |
| 1583 | CONFIG_LEDS_TRIGGER_HEARTBEAT=y | 1549 | CONFIG_LEDS_TRIGGER_HEARTBEAT=y |
| 1584 | CONFIG_LEDS_TRIGGER_BACKLIGHT=y | 1550 | CONFIG_LEDS_TRIGGER_BACKLIGHT=y |
| @@ -1656,7 +1622,7 @@ CONFIG_RTC_INTF_DEV=y | |||
| 1656 | # on-CPU RTC drivers | 1622 | # on-CPU RTC drivers |
| 1657 | # | 1623 | # |
| 1658 | # CONFIG_RTC_DRV_SA1100 is not set | 1624 | # CONFIG_RTC_DRV_SA1100 is not set |
| 1659 | # CONFIG_RTC_DRV_PXA is not set | 1625 | CONFIG_RTC_DRV_PXA=y |
| 1660 | # CONFIG_DMADEVICES is not set | 1626 | # CONFIG_DMADEVICES is not set |
| 1661 | # CONFIG_AUXDISPLAY is not set | 1627 | # CONFIG_AUXDISPLAY is not set |
| 1662 | # CONFIG_UIO is not set | 1628 | # CONFIG_UIO is not set |
| @@ -1681,19 +1647,10 @@ CONFIG_EXT3_FS_XATTR=y | |||
| 1681 | CONFIG_JBD=m | 1647 | CONFIG_JBD=m |
| 1682 | # CONFIG_JBD_DEBUG is not set | 1648 | # CONFIG_JBD_DEBUG is not set |
| 1683 | CONFIG_FS_MBCACHE=m | 1649 | CONFIG_FS_MBCACHE=m |
| 1684 | CONFIG_REISERFS_FS=m | 1650 | # CONFIG_REISERFS_FS is not set |
| 1685 | # CONFIG_REISERFS_CHECK is not set | ||
| 1686 | # CONFIG_REISERFS_PROC_INFO is not set | ||
| 1687 | CONFIG_REISERFS_FS_XATTR=y | ||
| 1688 | CONFIG_REISERFS_FS_POSIX_ACL=y | ||
| 1689 | CONFIG_REISERFS_FS_SECURITY=y | ||
| 1690 | # CONFIG_JFS_FS is not set | 1651 | # CONFIG_JFS_FS is not set |
| 1691 | CONFIG_FS_POSIX_ACL=y | 1652 | CONFIG_FS_POSIX_ACL=y |
| 1692 | CONFIG_XFS_FS=m | 1653 | # CONFIG_XFS_FS is not set |
| 1693 | # CONFIG_XFS_QUOTA is not set | ||
| 1694 | # CONFIG_XFS_POSIX_ACL is not set | ||
| 1695 | # CONFIG_XFS_RT is not set | ||
| 1696 | # CONFIG_XFS_DEBUG is not set | ||
| 1697 | # CONFIG_OCFS2_FS is not set | 1654 | # CONFIG_OCFS2_FS is not set |
| 1698 | # CONFIG_BTRFS_FS is not set | 1655 | # CONFIG_BTRFS_FS is not set |
| 1699 | # CONFIG_NILFS2_FS is not set | 1656 | # CONFIG_NILFS2_FS is not set |
| @@ -1716,9 +1673,7 @@ CONFIG_CUSE=m | |||
| 1716 | # | 1673 | # |
| 1717 | # CD-ROM/DVD Filesystems | 1674 | # CD-ROM/DVD Filesystems |
| 1718 | # | 1675 | # |
| 1719 | CONFIG_ISO9660_FS=m | 1676 | # CONFIG_ISO9660_FS is not set |
| 1720 | CONFIG_JOLIET=y | ||
| 1721 | CONFIG_ZISOFS=y | ||
| 1722 | # CONFIG_UDF_FS is not set | 1677 | # CONFIG_UDF_FS is not set |
| 1723 | 1678 | ||
| 1724 | # | 1679 | # |
| @@ -1750,12 +1705,14 @@ CONFIG_MISC_FILESYSTEMS=y | |||
| 1750 | # CONFIG_BEFS_FS is not set | 1705 | # CONFIG_BEFS_FS is not set |
| 1751 | # CONFIG_BFS_FS is not set | 1706 | # CONFIG_BFS_FS is not set |
| 1752 | # CONFIG_EFS_FS is not set | 1707 | # CONFIG_EFS_FS is not set |
| 1753 | CONFIG_JFFS2_FS=m | 1708 | CONFIG_JFFS2_FS=y |
| 1754 | CONFIG_JFFS2_FS_DEBUG=0 | 1709 | CONFIG_JFFS2_FS_DEBUG=0 |
| 1755 | CONFIG_JFFS2_FS_WRITEBUFFER=y | 1710 | CONFIG_JFFS2_FS_WRITEBUFFER=y |
| 1756 | # CONFIG_JFFS2_FS_WBUF_VERIFY is not set | 1711 | CONFIG_JFFS2_FS_WBUF_VERIFY=y |
| 1757 | # CONFIG_JFFS2_SUMMARY is not set | 1712 | CONFIG_JFFS2_SUMMARY=y |
| 1758 | # CONFIG_JFFS2_FS_XATTR is not set | 1713 | CONFIG_JFFS2_FS_XATTR=y |
| 1714 | CONFIG_JFFS2_FS_POSIX_ACL=y | ||
| 1715 | CONFIG_JFFS2_FS_SECURITY=y | ||
| 1759 | CONFIG_JFFS2_COMPRESSION_OPTIONS=y | 1716 | CONFIG_JFFS2_COMPRESSION_OPTIONS=y |
| 1760 | CONFIG_JFFS2_ZLIB=y | 1717 | CONFIG_JFFS2_ZLIB=y |
| 1761 | CONFIG_JFFS2_LZO=y | 1718 | CONFIG_JFFS2_LZO=y |
| @@ -1765,6 +1722,7 @@ CONFIG_JFFS2_RUBIN=y | |||
| 1765 | CONFIG_JFFS2_CMODE_PRIORITY=y | 1722 | CONFIG_JFFS2_CMODE_PRIORITY=y |
| 1766 | # CONFIG_JFFS2_CMODE_SIZE is not set | 1723 | # CONFIG_JFFS2_CMODE_SIZE is not set |
| 1767 | # CONFIG_JFFS2_CMODE_FAVOURLZO is not set | 1724 | # CONFIG_JFFS2_CMODE_FAVOURLZO is not set |
| 1725 | # CONFIG_LOGFS is not set | ||
| 1768 | CONFIG_CRAMFS=m | 1726 | CONFIG_CRAMFS=m |
| 1769 | CONFIG_SQUASHFS=m | 1727 | CONFIG_SQUASHFS=m |
| 1770 | # CONFIG_SQUASHFS_EMBEDDED is not set | 1728 | # CONFIG_SQUASHFS_EMBEDDED is not set |
| @@ -1802,6 +1760,7 @@ CONFIG_SUNRPC=y | |||
| 1802 | # CONFIG_RPCSEC_GSS_SPKM3 is not set | 1760 | # CONFIG_RPCSEC_GSS_SPKM3 is not set |
| 1803 | CONFIG_SMB_FS=m | 1761 | CONFIG_SMB_FS=m |
| 1804 | # CONFIG_SMB_NLS_DEFAULT is not set | 1762 | # CONFIG_SMB_NLS_DEFAULT is not set |
| 1763 | # CONFIG_CEPH_FS is not set | ||
| 1805 | CONFIG_CIFS=m | 1764 | CONFIG_CIFS=m |
| 1806 | CONFIG_CIFS_STATS=y | 1765 | CONFIG_CIFS_STATS=y |
| 1807 | # CONFIG_CIFS_STATS2 is not set | 1766 | # CONFIG_CIFS_STATS2 is not set |
| @@ -1895,6 +1854,7 @@ CONFIG_DEBUG_SPINLOCK=y | |||
| 1895 | CONFIG_DEBUG_MUTEXES=y | 1854 | CONFIG_DEBUG_MUTEXES=y |
| 1896 | CONFIG_DEBUG_LOCK_ALLOC=y | 1855 | CONFIG_DEBUG_LOCK_ALLOC=y |
| 1897 | CONFIG_PROVE_LOCKING=y | 1856 | CONFIG_PROVE_LOCKING=y |
| 1857 | # CONFIG_PROVE_RCU is not set | ||
| 1898 | CONFIG_LOCKDEP=y | 1858 | CONFIG_LOCKDEP=y |
| 1899 | # CONFIG_LOCK_STAT is not set | 1859 | # CONFIG_LOCK_STAT is not set |
| 1900 | # CONFIG_DEBUG_LOCKDEP is not set | 1860 | # CONFIG_DEBUG_LOCKDEP is not set |
| @@ -1918,6 +1878,7 @@ CONFIG_DEBUG_BUGVERBOSE=y | |||
| 1918 | # CONFIG_BACKTRACE_SELF_TEST is not set | 1878 | # CONFIG_BACKTRACE_SELF_TEST is not set |
| 1919 | # CONFIG_DEBUG_BLOCK_EXT_DEVT is not set | 1879 | # CONFIG_DEBUG_BLOCK_EXT_DEVT is not set |
| 1920 | # CONFIG_DEBUG_FORCE_WEAK_PER_CPU is not set | 1880 | # CONFIG_DEBUG_FORCE_WEAK_PER_CPU is not set |
| 1881 | # CONFIG_LKDTM is not set | ||
| 1921 | # CONFIG_FAULT_INJECTION is not set | 1882 | # CONFIG_FAULT_INJECTION is not set |
| 1922 | # CONFIG_LATENCYTOP is not set | 1883 | # CONFIG_LATENCYTOP is not set |
| 1923 | # CONFIG_SYSCTL_SYSCALL_CHECK is not set | 1884 | # CONFIG_SYSCTL_SYSCALL_CHECK is not set |
| @@ -2061,9 +2022,9 @@ CONFIG_CRC32=y | |||
| 2061 | CONFIG_CRC7=y | 2022 | CONFIG_CRC7=y |
| 2062 | CONFIG_LIBCRC32C=m | 2023 | CONFIG_LIBCRC32C=m |
| 2063 | CONFIG_ZLIB_INFLATE=y | 2024 | CONFIG_ZLIB_INFLATE=y |
| 2064 | CONFIG_ZLIB_DEFLATE=m | 2025 | CONFIG_ZLIB_DEFLATE=y |
| 2065 | CONFIG_LZO_COMPRESS=m | 2026 | CONFIG_LZO_COMPRESS=y |
| 2066 | CONFIG_LZO_DECOMPRESS=m | 2027 | CONFIG_LZO_DECOMPRESS=y |
| 2067 | CONFIG_DECOMPRESS_GZIP=y | 2028 | CONFIG_DECOMPRESS_GZIP=y |
| 2068 | CONFIG_DECOMPRESS_BZIP2=y | 2029 | CONFIG_DECOMPRESS_BZIP2=y |
| 2069 | CONFIG_DECOMPRESS_LZMA=y | 2030 | CONFIG_DECOMPRESS_LZMA=y |
| @@ -2075,3 +2036,4 @@ CONFIG_HAS_IOMEM=y | |||
| 2075 | CONFIG_HAS_IOPORT=y | 2036 | CONFIG_HAS_IOPORT=y |
| 2076 | CONFIG_HAS_DMA=y | 2037 | CONFIG_HAS_DMA=y |
| 2077 | CONFIG_NLATTR=y | 2038 | CONFIG_NLATTR=y |
| 2039 | CONFIG_GENERIC_ATOMIC64=y | ||
diff --git a/arch/arm/include/asm/elf.h b/arch/arm/include/asm/elf.h index bff056489cc1..51662feb9f1d 100644 --- a/arch/arm/include/asm/elf.h +++ b/arch/arm/include/asm/elf.h | |||
| @@ -9,6 +9,8 @@ | |||
| 9 | #include <asm/ptrace.h> | 9 | #include <asm/ptrace.h> |
| 10 | #include <asm/user.h> | 10 | #include <asm/user.h> |
| 11 | 11 | ||
| 12 | struct task_struct; | ||
| 13 | |||
| 12 | typedef unsigned long elf_greg_t; | 14 | typedef unsigned long elf_greg_t; |
| 13 | typedef unsigned long elf_freg_t[3]; | 15 | typedef unsigned long elf_freg_t[3]; |
| 14 | 16 | ||
diff --git a/arch/arm/kernel/entry-armv.S b/arch/arm/kernel/entry-armv.S index e6a0fb0f392e..7ee48e7f8f31 100644 --- a/arch/arm/kernel/entry-armv.S +++ b/arch/arm/kernel/entry-armv.S | |||
| @@ -676,10 +676,10 @@ do_fpe: | |||
| 676 | * lr = unrecognised FP instruction return address | 676 | * lr = unrecognised FP instruction return address |
| 677 | */ | 677 | */ |
| 678 | 678 | ||
| 679 | .data | 679 | .pushsection .data |
| 680 | ENTRY(fp_enter) | 680 | ENTRY(fp_enter) |
| 681 | .word no_fp | 681 | .word no_fp |
| 682 | .text | 682 | .popsection |
| 683 | 683 | ||
| 684 | ENTRY(no_fp) | 684 | ENTRY(no_fp) |
| 685 | mov pc, lr | 685 | mov pc, lr |
diff --git a/arch/arm/kernel/smp.c b/arch/arm/kernel/smp.c index 577543f3857f..a01194e583ff 100644 --- a/arch/arm/kernel/smp.c +++ b/arch/arm/kernel/smp.c | |||
| @@ -86,6 +86,12 @@ int __cpuinit __cpu_up(unsigned int cpu) | |||
| 86 | return PTR_ERR(idle); | 86 | return PTR_ERR(idle); |
| 87 | } | 87 | } |
| 88 | ci->idle = idle; | 88 | ci->idle = idle; |
| 89 | } else { | ||
| 90 | /* | ||
| 91 | * Since this idle thread is being re-used, call | ||
| 92 | * init_idle() to reinitialize the thread structure. | ||
| 93 | */ | ||
| 94 | init_idle(idle, cpu); | ||
| 89 | } | 95 | } |
| 90 | 96 | ||
| 91 | /* | 97 | /* |
diff --git a/arch/arm/mach-mx5/clock-mx51.c b/arch/arm/mach-mx5/clock-mx51.c index 8f85f73b83a8..1ee6ce4087b8 100644 --- a/arch/arm/mach-mx5/clock-mx51.c +++ b/arch/arm/mach-mx5/clock-mx51.c | |||
| @@ -16,6 +16,7 @@ | |||
| 16 | #include <linux/io.h> | 16 | #include <linux/io.h> |
| 17 | 17 | ||
| 18 | #include <asm/clkdev.h> | 18 | #include <asm/clkdev.h> |
| 19 | #include <asm/div64.h> | ||
| 19 | 20 | ||
| 20 | #include <mach/hardware.h> | 21 | #include <mach/hardware.h> |
| 21 | #include <mach/common.h> | 22 | #include <mach/common.h> |
diff --git a/arch/arm/mach-pxa/include/mach/colibri.h b/arch/arm/mach-pxa/include/mach/colibri.h index 811743c56147..5f2ba8d9015c 100644 --- a/arch/arm/mach-pxa/include/mach/colibri.h +++ b/arch/arm/mach-pxa/include/mach/colibri.h | |||
| @@ -2,6 +2,7 @@ | |||
| 2 | #define _COLIBRI_H_ | 2 | #define _COLIBRI_H_ |
| 3 | 3 | ||
| 4 | #include <net/ax88796.h> | 4 | #include <net/ax88796.h> |
| 5 | #include <mach/mfp.h> | ||
| 5 | 6 | ||
| 6 | /* | 7 | /* |
| 7 | * common settings for all modules | 8 | * common settings for all modules |
diff --git a/arch/arm/mach-pxa/include/mach/hardware.h b/arch/arm/mach-pxa/include/mach/hardware.h index 7515757d6911..3d8d8cb09685 100644 --- a/arch/arm/mach-pxa/include/mach/hardware.h +++ b/arch/arm/mach-pxa/include/mach/hardware.h | |||
| @@ -202,7 +202,7 @@ | |||
| 202 | #define __cpu_is_pxa950(id) \ | 202 | #define __cpu_is_pxa950(id) \ |
| 203 | ({ \ | 203 | ({ \ |
| 204 | unsigned int _id = (id) >> 4 & 0xfff; \ | 204 | unsigned int _id = (id) >> 4 & 0xfff; \ |
| 205 | id == 0x697; \ | 205 | _id == 0x697; \ |
| 206 | }) | 206 | }) |
| 207 | #else | 207 | #else |
| 208 | #define __cpu_is_pxa950(id) (0) | 208 | #define __cpu_is_pxa950(id) (0) |
diff --git a/arch/arm/mach-pxa/include/mach/regs-u2d.h b/arch/arm/mach-pxa/include/mach/regs-u2d.h index 44b0b20b69a4..c15c0c57de08 100644 --- a/arch/arm/mach-pxa/include/mach/regs-u2d.h +++ b/arch/arm/mach-pxa/include/mach/regs-u2d.h | |||
| @@ -166,7 +166,8 @@ | |||
| 166 | #define U2DMACSR_BUSERRTYPE (7 << 10) /* PX Bus Error Type */ | 166 | #define U2DMACSR_BUSERRTYPE (7 << 10) /* PX Bus Error Type */ |
| 167 | #define U2DMACSR_EORINTR (1 << 9) /* End Of Receive */ | 167 | #define U2DMACSR_EORINTR (1 << 9) /* End Of Receive */ |
| 168 | #define U2DMACSR_REQPEND (1 << 8) /* Request Pending */ | 168 | #define U2DMACSR_REQPEND (1 << 8) /* Request Pending */ |
| 169 | #define U2DMACSR_RASINTR (1 << 4) /* Request After Channel Stopped (read / write 1 clear) */#define U2DMACSR_STOPINTR (1 << 3) /* Stop Interrupt (read only) */ | 169 | #define U2DMACSR_RASINTR (1 << 4) /* Request After Channel Stopped (read / write 1 clear) */ |
| 170 | #define U2DMACSR_STOPINTR (1 << 3) /* Stop Interrupt (read only) */ | ||
| 170 | #define U2DMACSR_ENDINTR (1 << 2) /* End Interrupt (read / write 1 clear) */ | 171 | #define U2DMACSR_ENDINTR (1 << 2) /* End Interrupt (read / write 1 clear) */ |
| 171 | #define U2DMACSR_STARTINTR (1 << 1) /* Start Interrupt (read / write 1 clear) */ | 172 | #define U2DMACSR_STARTINTR (1 << 1) /* Start Interrupt (read / write 1 clear) */ |
| 172 | #define U2DMACSR_BUSERRINTR (1 << 0) /* Bus Error Interrupt (read / write 1 clear) */ | 173 | #define U2DMACSR_BUSERRINTR (1 << 0) /* Bus Error Interrupt (read / write 1 clear) */ |
diff --git a/arch/arm/mach-pxa/raumfeld.c b/arch/arm/mach-pxa/raumfeld.c index 44bb675e47f1..d12667bd9ebe 100644 --- a/arch/arm/mach-pxa/raumfeld.c +++ b/arch/arm/mach-pxa/raumfeld.c | |||
| @@ -983,7 +983,7 @@ static void __init raumfeld_common_init(void) | |||
| 983 | int i; | 983 | int i; |
| 984 | 984 | ||
| 985 | for (i = 0; i < ARRAY_SIZE(gpio_keys_button); i++) | 985 | for (i = 0; i < ARRAY_SIZE(gpio_keys_button); i++) |
| 986 | if (!strcmp(gpio_keys_button[i].desc, "on/off button")) | 986 | if (!strcmp(gpio_keys_button[i].desc, "on_off button")) |
| 987 | gpio_keys_button[i].active_low = 1; | 987 | gpio_keys_button[i].active_low = 1; |
| 988 | } | 988 | } |
| 989 | 989 | ||
| @@ -1009,8 +1009,7 @@ static void __init raumfeld_common_init(void) | |||
| 1009 | gpio_direction_output(GPIO_W2W_PDN, 0); | 1009 | gpio_direction_output(GPIO_W2W_PDN, 0); |
| 1010 | 1010 | ||
| 1011 | /* this can be used to switch off the device */ | 1011 | /* this can be used to switch off the device */ |
| 1012 | ret = gpio_request(GPIO_SHUTDOWN_SUPPLY, | 1012 | ret = gpio_request(GPIO_SHUTDOWN_SUPPLY, "supply shutdown"); |
| 1013 | "supply shutdown"); | ||
| 1014 | if (ret < 0) | 1013 | if (ret < 0) |
| 1015 | pr_warning("Unable to request GPIO_SHUTDOWN_SUPPLY\n"); | 1014 | pr_warning("Unable to request GPIO_SHUTDOWN_SUPPLY\n"); |
| 1016 | else | 1015 | else |
diff --git a/arch/arm/mach-pxa/spitz.c b/arch/arm/mach-pxa/spitz.c index 19b5109d9808..01bdd7500df4 100644 --- a/arch/arm/mach-pxa/spitz.c +++ b/arch/arm/mach-pxa/spitz.c | |||
| @@ -363,7 +363,7 @@ static struct gpio_keys_button spitz_gpio_keys[] = { | |||
| 363 | .type = EV_PWR, | 363 | .type = EV_PWR, |
| 364 | .code = KEY_SUSPEND, | 364 | .code = KEY_SUSPEND, |
| 365 | .gpio = SPITZ_GPIO_ON_KEY, | 365 | .gpio = SPITZ_GPIO_ON_KEY, |
| 366 | .desc = "On/Off", | 366 | .desc = "On Off", |
| 367 | .wakeup = 1, | 367 | .wakeup = 1, |
| 368 | }, | 368 | }, |
| 369 | /* Two buttons detecting the lid state */ | 369 | /* Two buttons detecting the lid state */ |
diff --git a/arch/arm/mach-pxa/viper.c b/arch/arm/mach-pxa/viper.c index 9e0c5c3988a1..e90114a7e246 100644 --- a/arch/arm/mach-pxa/viper.c +++ b/arch/arm/mach-pxa/viper.c | |||
| @@ -34,6 +34,7 @@ | |||
| 34 | #include <linux/pm.h> | 34 | #include <linux/pm.h> |
| 35 | #include <linux/sched.h> | 35 | #include <linux/sched.h> |
| 36 | #include <linux/gpio.h> | 36 | #include <linux/gpio.h> |
| 37 | #include <linux/jiffies.h> | ||
| 37 | #include <linux/i2c-gpio.h> | 38 | #include <linux/i2c-gpio.h> |
| 38 | #include <linux/serial_8250.h> | 39 | #include <linux/serial_8250.h> |
| 39 | #include <linux/smc91x.h> | 40 | #include <linux/smc91x.h> |
| @@ -454,7 +455,7 @@ static struct i2c_gpio_platform_data i2c_bus_data = { | |||
| 454 | .sda_pin = VIPER_RTC_I2C_SDA_GPIO, | 455 | .sda_pin = VIPER_RTC_I2C_SDA_GPIO, |
| 455 | .scl_pin = VIPER_RTC_I2C_SCL_GPIO, | 456 | .scl_pin = VIPER_RTC_I2C_SCL_GPIO, |
| 456 | .udelay = 10, | 457 | .udelay = 10, |
| 457 | .timeout = 100, | 458 | .timeout = HZ, |
| 458 | }; | 459 | }; |
| 459 | 460 | ||
| 460 | static struct platform_device i2c_bus_device = { | 461 | static struct platform_device i2c_bus_device = { |
| @@ -779,7 +780,7 @@ static void __init viper_tpm_init(void) | |||
| 779 | .sda_pin = VIPER_TPM_I2C_SDA_GPIO, | 780 | .sda_pin = VIPER_TPM_I2C_SDA_GPIO, |
| 780 | .scl_pin = VIPER_TPM_I2C_SCL_GPIO, | 781 | .scl_pin = VIPER_TPM_I2C_SCL_GPIO, |
| 781 | .udelay = 10, | 782 | .udelay = 10, |
| 782 | .timeout = 100, | 783 | .timeout = HZ, |
| 783 | }; | 784 | }; |
| 784 | char *errstr; | 785 | char *errstr; |
| 785 | 786 | ||
diff --git a/arch/arm/mach-sa1100/Kconfig b/arch/arm/mach-sa1100/Kconfig index b17d52f7cc48..fd4c52b7ccb6 100644 --- a/arch/arm/mach-sa1100/Kconfig +++ b/arch/arm/mach-sa1100/Kconfig | |||
| @@ -57,7 +57,7 @@ config SA1100_COLLIE | |||
| 57 | config SA1100_H3100 | 57 | config SA1100_H3100 |
| 58 | bool "Compaq iPAQ H3100" | 58 | bool "Compaq iPAQ H3100" |
| 59 | select HTC_EGPIO | 59 | select HTC_EGPIO |
| 60 | select CPU_FREQ_SA1100 | 60 | select CPU_FREQ_SA1110 |
| 61 | help | 61 | help |
| 62 | Say Y here if you intend to run this kernel on the Compaq iPAQ | 62 | Say Y here if you intend to run this kernel on the Compaq iPAQ |
| 63 | H3100 handheld computer. Information about this machine and the | 63 | H3100 handheld computer. Information about this machine and the |
| @@ -68,7 +68,7 @@ config SA1100_H3100 | |||
| 68 | config SA1100_H3600 | 68 | config SA1100_H3600 |
| 69 | bool "Compaq iPAQ H3600/H3700" | 69 | bool "Compaq iPAQ H3600/H3700" |
| 70 | select HTC_EGPIO | 70 | select HTC_EGPIO |
| 71 | select CPU_FREQ_SA1100 | 71 | select CPU_FREQ_SA1110 |
| 72 | help | 72 | help |
| 73 | Say Y here if you intend to run this kernel on the Compaq iPAQ | 73 | Say Y here if you intend to run this kernel on the Compaq iPAQ |
| 74 | H3600 handheld computer. Information about this machine and the | 74 | H3600 handheld computer. Information about this machine and the |
diff --git a/arch/arm/mach-sa1100/cpu-sa1110.c b/arch/arm/mach-sa1100/cpu-sa1110.c index 63b32b68b296..7252874d328b 100644 --- a/arch/arm/mach-sa1100/cpu-sa1110.c +++ b/arch/arm/mach-sa1100/cpu-sa1110.c | |||
| @@ -363,6 +363,9 @@ static int __init sa1110_clk_init(void) | |||
| 363 | struct sdram_params *sdram; | 363 | struct sdram_params *sdram; |
| 364 | const char *name = sdram_name; | 364 | const char *name = sdram_name; |
| 365 | 365 | ||
| 366 | if (!cpu_is_sa1110()) | ||
| 367 | return -ENODEV; | ||
| 368 | |||
| 366 | if (!name[0]) { | 369 | if (!name[0]) { |
| 367 | if (machine_is_assabet()) | 370 | if (machine_is_assabet()) |
| 368 | name = "TC59SM716-CL3"; | 371 | name = "TC59SM716-CL3"; |
diff --git a/arch/arm/mm/init.c b/arch/arm/mm/init.c index 83db12a68d56..0ed29bfeba1c 100644 --- a/arch/arm/mm/init.c +++ b/arch/arm/mm/init.c | |||
| @@ -86,9 +86,6 @@ void show_mem(void) | |||
| 86 | printk("Mem-info:\n"); | 86 | printk("Mem-info:\n"); |
| 87 | show_free_areas(); | 87 | show_free_areas(); |
| 88 | for_each_online_node(node) { | 88 | for_each_online_node(node) { |
| 89 | pg_data_t *n = NODE_DATA(node); | ||
| 90 | struct page *map = pgdat_page_nr(n, 0) - n->node_start_pfn; | ||
| 91 | |||
| 92 | for_each_nodebank (i,mi,node) { | 89 | for_each_nodebank (i,mi,node) { |
| 93 | struct membank *bank = &mi->bank[i]; | 90 | struct membank *bank = &mi->bank[i]; |
| 94 | unsigned int pfn1, pfn2; | 91 | unsigned int pfn1, pfn2; |
| @@ -97,8 +94,8 @@ void show_mem(void) | |||
| 97 | pfn1 = bank_pfn_start(bank); | 94 | pfn1 = bank_pfn_start(bank); |
| 98 | pfn2 = bank_pfn_end(bank); | 95 | pfn2 = bank_pfn_end(bank); |
| 99 | 96 | ||
| 100 | page = map + pfn1; | 97 | page = pfn_to_page(pfn1); |
| 101 | end = map + pfn2; | 98 | end = pfn_to_page(pfn2 - 1) + 1; |
| 102 | 99 | ||
| 103 | do { | 100 | do { |
| 104 | total++; | 101 | total++; |
| @@ -603,9 +600,6 @@ void __init mem_init(void) | |||
| 603 | reserved_pages = free_pages = 0; | 600 | reserved_pages = free_pages = 0; |
| 604 | 601 | ||
| 605 | for_each_online_node(node) { | 602 | for_each_online_node(node) { |
| 606 | pg_data_t *n = NODE_DATA(node); | ||
| 607 | struct page *map = pgdat_page_nr(n, 0) - n->node_start_pfn; | ||
| 608 | |||
| 609 | for_each_nodebank(i, &meminfo, node) { | 603 | for_each_nodebank(i, &meminfo, node) { |
| 610 | struct membank *bank = &meminfo.bank[i]; | 604 | struct membank *bank = &meminfo.bank[i]; |
| 611 | unsigned int pfn1, pfn2; | 605 | unsigned int pfn1, pfn2; |
| @@ -614,8 +608,8 @@ void __init mem_init(void) | |||
| 614 | pfn1 = bank_pfn_start(bank); | 608 | pfn1 = bank_pfn_start(bank); |
| 615 | pfn2 = bank_pfn_end(bank); | 609 | pfn2 = bank_pfn_end(bank); |
| 616 | 610 | ||
| 617 | page = map + pfn1; | 611 | page = pfn_to_page(pfn1); |
| 618 | end = map + pfn2; | 612 | end = pfn_to_page(pfn2 - 1) + 1; |
| 619 | 613 | ||
| 620 | do { | 614 | do { |
| 621 | if (PageReserved(page)) | 615 | if (PageReserved(page)) |
diff --git a/arch/arm/plat-mxc/include/mach/dma-mx1-mx2.h b/arch/arm/plat-mxc/include/mach/dma-mx1-mx2.h index 07be8ad7ec37..7c4870bd5a21 100644 --- a/arch/arm/plat-mxc/include/mach/dma-mx1-mx2.h +++ b/arch/arm/plat-mxc/include/mach/dma-mx1-mx2.h | |||
| @@ -31,7 +31,13 @@ | |||
| 31 | #define DMA_MODE_WRITE 1 | 31 | #define DMA_MODE_WRITE 1 |
| 32 | #define DMA_MODE_MASK 1 | 32 | #define DMA_MODE_MASK 1 |
| 33 | 33 | ||
| 34 | #define DMA_BASE IO_ADDRESS(DMA_BASE_ADDR) | 34 | #define MX1_DMA_REG(offset) MX1_IO_ADDRESS(MX1_DMA_BASE_ADDR + (offset)) |
| 35 | |||
| 36 | /* DMA Interrupt Mask Register */ | ||
| 37 | #define MX1_DMA_DIMR MX1_DMA_REG(0x08) | ||
| 38 | |||
| 39 | /* Channel Control Register */ | ||
| 40 | #define MX1_DMA_CCR(x) MX1_DMA_REG(0x8c + ((x) << 6)) | ||
| 35 | 41 | ||
| 36 | #define IMX_DMA_MEMSIZE_32 (0 << 4) | 42 | #define IMX_DMA_MEMSIZE_32 (0 << 4) |
| 37 | #define IMX_DMA_MEMSIZE_8 (1 << 4) | 43 | #define IMX_DMA_MEMSIZE_8 (1 << 4) |
diff --git a/arch/arm/plat-pxa/dma.c b/arch/arm/plat-pxa/dma.c index 742350e0f2a7..2d3c19d7c7b1 100644 --- a/arch/arm/plat-pxa/dma.c +++ b/arch/arm/plat-pxa/dma.c | |||
| @@ -245,7 +245,7 @@ static void pxa_dma_init_debugfs(void) | |||
| 245 | 245 | ||
| 246 | dbgfs_chan = kmalloc(sizeof(*dbgfs_state) * num_dma_channels, | 246 | dbgfs_chan = kmalloc(sizeof(*dbgfs_state) * num_dma_channels, |
| 247 | GFP_KERNEL); | 247 | GFP_KERNEL); |
| 248 | if (!dbgfs_state) | 248 | if (!dbgfs_chan) |
| 249 | goto err_alloc; | 249 | goto err_alloc; |
| 250 | 250 | ||
| 251 | chandir = debugfs_create_dir("channels", dbgfs_root); | 251 | chandir = debugfs_create_dir("channels", dbgfs_root); |
diff --git a/arch/arm/tools/mach-types b/arch/arm/tools/mach-types index 1536f1784cac..8f10d24ae625 100644 --- a/arch/arm/tools/mach-types +++ b/arch/arm/tools/mach-types | |||
| @@ -12,7 +12,7 @@ | |||
| 12 | # | 12 | # |
| 13 | # http://www.arm.linux.org.uk/developer/machines/?action=new | 13 | # http://www.arm.linux.org.uk/developer/machines/?action=new |
| 14 | # | 14 | # |
| 15 | # Last update: Sat Mar 20 15:35:41 2010 | 15 | # Last update: Sat May 1 10:36:42 2010 |
| 16 | # | 16 | # |
| 17 | # machine_is_xxx CONFIG_xxxx MACH_TYPE_xxx number | 17 | # machine_is_xxx CONFIG_xxxx MACH_TYPE_xxx number |
| 18 | # | 18 | # |
| @@ -2749,3 +2749,58 @@ stamp9g45 MACH_STAMP9G45 STAMP9G45 2761 | |||
| 2749 | h6053 MACH_H6053 H6053 2762 | 2749 | h6053 MACH_H6053 H6053 2762 |
| 2750 | smint01 MACH_SMINT01 SMINT01 2763 | 2750 | smint01 MACH_SMINT01 SMINT01 2763 |
| 2751 | prtlvt2 MACH_PRTLVT2 PRTLVT2 2764 | 2751 | prtlvt2 MACH_PRTLVT2 PRTLVT2 2764 |
| 2752 | ap420 MACH_AP420 AP420 2765 | ||
| 2753 | htcshift MACH_HTCSHIFT HTCSHIFT 2766 | ||
| 2754 | davinci_dm365_fc MACH_DAVINCI_DM365_FC DAVINCI_DM365_FC 2767 | ||
| 2755 | msm8x55_surf MACH_MSM8X55_SURF MSM8X55_SURF 2768 | ||
| 2756 | msm8x55_ffa MACH_MSM8X55_FFA MSM8X55_FFA 2769 | ||
| 2757 | esl_vamana MACH_ESL_VAMANA ESL_VAMANA 2770 | ||
| 2758 | sbc35 MACH_SBC35 SBC35 2771 | ||
| 2759 | mpx6446 MACH_MPX6446 MPX6446 2772 | ||
| 2760 | oreo_controller MACH_OREO_CONTROLLER OREO_CONTROLLER 2773 | ||
| 2761 | kopin_models MACH_KOPIN_MODELS KOPIN_MODELS 2774 | ||
| 2762 | ttc_vision2 MACH_TTC_VISION2 TTC_VISION2 2775 | ||
| 2763 | cns3420vb MACH_CNS3420VB CNS3420VB 2776 | ||
| 2764 | lpc2 MACH_LPC2 LPC2 2777 | ||
| 2765 | olympus MACH_OLYMPUS OLYMPUS 2778 | ||
| 2766 | vortex MACH_VORTEX VORTEX 2779 | ||
| 2767 | s5pc200 MACH_S5PC200 S5PC200 2780 | ||
| 2768 | ecucore_9263 MACH_ECUCORE_9263 ECUCORE_9263 2781 | ||
| 2769 | smdkc200 MACH_SMDKC200 SMDKC200 2782 | ||
| 2770 | emsiso_sx27 MACH_EMSISO_SX27 EMSISO_SX27 2783 | ||
| 2771 | apx_som9g45_ek MACH_APX_SOM9G45_EK APX_SOM9G45_EK 2784 | ||
| 2772 | songshan MACH_SONGSHAN SONGSHAN 2785 | ||
| 2773 | tianshan MACH_TIANSHAN TIANSHAN 2786 | ||
| 2774 | vpx500 MACH_VPX500 VPX500 2787 | ||
| 2775 | am3517sam MACH_AM3517SAM AM3517SAM 2788 | ||
| 2776 | skat91_sim508 MACH_SKAT91_SIM508 SKAT91_SIM508 2789 | ||
| 2777 | skat91_s3e MACH_SKAT91_S3E SKAT91_S3E 2790 | ||
| 2778 | omap4_panda MACH_OMAP4_PANDA OMAP4_PANDA 2791 | ||
| 2779 | df7220 MACH_DF7220 DF7220 2792 | ||
| 2780 | nemini MACH_NEMINI NEMINI 2793 | ||
| 2781 | t8200 MACH_T8200 T8200 2794 | ||
| 2782 | apf51 MACH_APF51 APF51 2795 | ||
| 2783 | dr_rc_unit MACH_DR_RC_UNIT DR_RC_UNIT 2796 | ||
| 2784 | bordeaux MACH_BORDEAUX BORDEAUX 2797 | ||
| 2785 | catania_b MACH_CATANIA_B CATANIA_B 2798 | ||
| 2786 | mx51_ocean MACH_MX51_OCEAN MX51_OCEAN 2799 | ||
| 2787 | ti8168evm MACH_TI8168EVM TI8168EVM 2800 | ||
| 2788 | neocoreomap MACH_NEOCOREOMAP NEOCOREOMAP 2801 | ||
| 2789 | withings_wbp MACH_WITHINGS_WBP WITHINGS_WBP 2802 | ||
| 2790 | dbps MACH_DBPS DBPS 2803 | ||
| 2791 | sbc9261 MACH_SBC9261 SBC9261 2804 | ||
| 2792 | pcbfp0001 MACH_PCBFP0001 PCBFP0001 2805 | ||
| 2793 | speedy MACH_SPEEDY SPEEDY 2806 | ||
| 2794 | chrysaor MACH_CHRYSAOR CHRYSAOR 2807 | ||
| 2795 | tango MACH_TANGO TANGO 2808 | ||
| 2796 | synology_dsx11 MACH_SYNOLOGY_DSX11 SYNOLOGY_DSX11 2809 | ||
| 2797 | hanlin_v3ext MACH_HANLIN_V3EXT HANLIN_V3EXT 2810 | ||
| 2798 | hanlin_v5 MACH_HANLIN_V5 HANLIN_V5 2811 | ||
| 2799 | hanlin_v3plus MACH_HANLIN_V3PLUS HANLIN_V3PLUS 2812 | ||
| 2800 | iriver_story MACH_IRIVER_STORY IRIVER_STORY 2813 | ||
| 2801 | irex_iliad MACH_IREX_ILIAD IREX_ILIAD 2814 | ||
| 2802 | irex_dr1000 MACH_IREX_DR1000 IREX_DR1000 2815 | ||
| 2803 | teton_bga MACH_TETON_BGA TETON_BGA 2816 | ||
| 2804 | snapper9g45 MACH_SNAPPER9G45 SNAPPER9G45 2817 | ||
| 2805 | tam3517 MACH_TAM3517 TAM3517 2818 | ||
| 2806 | pdc100 MACH_PDC100 PDC100 2819 | ||
diff --git a/arch/microblaze/configs/mmu_defconfig b/arch/microblaze/configs/mmu_defconfig index 6fced1fe3bf0..3c91cf6192c6 100644 --- a/arch/microblaze/configs/mmu_defconfig +++ b/arch/microblaze/configs/mmu_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.33-rc6 | 3 | # Linux kernel version: 2.6.34-rc6 |
| 4 | # Wed Feb 3 10:02:59 2010 | 4 | # Thu May 6 11:22:14 2010 |
| 5 | # | 5 | # |
| 6 | CONFIG_MICROBLAZE=y | 6 | CONFIG_MICROBLAZE=y |
| 7 | # CONFIG_SWAP is not set | 7 | # CONFIG_SWAP is not set |
| @@ -22,8 +22,6 @@ CONFIG_GENERIC_CSUM=y | |||
| 22 | CONFIG_STACKTRACE_SUPPORT=y | 22 | CONFIG_STACKTRACE_SUPPORT=y |
| 23 | CONFIG_LOCKDEP_SUPPORT=y | 23 | CONFIG_LOCKDEP_SUPPORT=y |
| 24 | CONFIG_HAVE_LATENCYTOP_SUPPORT=y | 24 | CONFIG_HAVE_LATENCYTOP_SUPPORT=y |
| 25 | # CONFIG_PCI is not set | ||
| 26 | CONFIG_NO_DMA=y | ||
| 27 | CONFIG_DTC=y | 25 | CONFIG_DTC=y |
| 28 | CONFIG_DEFCONFIG_LIST="/lib/modules/$UNAME_RELEASE/.config" | 26 | CONFIG_DEFCONFIG_LIST="/lib/modules/$UNAME_RELEASE/.config" |
| 29 | CONFIG_CONSTRUCTORS=y | 27 | CONFIG_CONSTRUCTORS=y |
| @@ -56,7 +54,6 @@ CONFIG_RCU_FANOUT=32 | |||
| 56 | CONFIG_IKCONFIG=y | 54 | CONFIG_IKCONFIG=y |
| 57 | CONFIG_IKCONFIG_PROC=y | 55 | CONFIG_IKCONFIG_PROC=y |
| 58 | CONFIG_LOG_BUF_SHIFT=17 | 56 | CONFIG_LOG_BUF_SHIFT=17 |
| 59 | # CONFIG_GROUP_SCHED is not set | ||
| 60 | # CONFIG_CGROUPS is not set | 57 | # CONFIG_CGROUPS is not set |
| 61 | CONFIG_SYSFS_DEPRECATED=y | 58 | CONFIG_SYSFS_DEPRECATED=y |
| 62 | CONFIG_SYSFS_DEPRECATED_V2=y | 59 | CONFIG_SYSFS_DEPRECATED_V2=y |
| @@ -106,6 +103,8 @@ CONFIG_SLAB=y | |||
| 106 | # CONFIG_SLOB is not set | 103 | # CONFIG_SLOB is not set |
| 107 | # CONFIG_PROFILING is not set | 104 | # CONFIG_PROFILING is not set |
| 108 | CONFIG_HAVE_OPROFILE=y | 105 | CONFIG_HAVE_OPROFILE=y |
| 106 | CONFIG_HAVE_DMA_ATTRS=y | ||
| 107 | CONFIG_HAVE_DMA_API_DEBUG=y | ||
| 109 | 108 | ||
| 110 | # | 109 | # |
| 111 | # GCOV-based kernel profiling | 110 | # GCOV-based kernel profiling |
| @@ -245,13 +244,20 @@ CONFIG_BINFMT_ELF=y | |||
| 245 | # CONFIG_CORE_DUMP_DEFAULT_ELF_HEADERS is not set | 244 | # CONFIG_CORE_DUMP_DEFAULT_ELF_HEADERS is not set |
| 246 | # CONFIG_HAVE_AOUT is not set | 245 | # CONFIG_HAVE_AOUT is not set |
| 247 | # CONFIG_BINFMT_MISC is not set | 246 | # CONFIG_BINFMT_MISC is not set |
| 247 | |||
| 248 | # | ||
| 249 | # Bus Options | ||
| 250 | # | ||
| 251 | # CONFIG_PCI is not set | ||
| 252 | # CONFIG_PCI_DOMAINS is not set | ||
| 253 | # CONFIG_PCI_SYSCALL is not set | ||
| 254 | # CONFIG_ARCH_SUPPORTS_MSI is not set | ||
| 248 | CONFIG_NET=y | 255 | CONFIG_NET=y |
| 249 | 256 | ||
| 250 | # | 257 | # |
| 251 | # Networking options | 258 | # Networking options |
| 252 | # | 259 | # |
| 253 | CONFIG_PACKET=y | 260 | CONFIG_PACKET=y |
| 254 | # CONFIG_PACKET_MMAP is not set | ||
| 255 | CONFIG_UNIX=y | 261 | CONFIG_UNIX=y |
| 256 | CONFIG_XFRM=y | 262 | CONFIG_XFRM=y |
| 257 | # CONFIG_XFRM_USER is not set | 263 | # CONFIG_XFRM_USER is not set |
| @@ -341,7 +347,9 @@ CONFIG_PREVENT_FIRMWARE_BUILD=y | |||
| 341 | # CONFIG_SYS_HYPERVISOR is not set | 347 | # CONFIG_SYS_HYPERVISOR is not set |
| 342 | # CONFIG_CONNECTOR is not set | 348 | # CONFIG_CONNECTOR is not set |
| 343 | # CONFIG_MTD is not set | 349 | # CONFIG_MTD is not set |
| 350 | CONFIG_OF_FLATTREE=y | ||
| 344 | CONFIG_OF_DEVICE=y | 351 | CONFIG_OF_DEVICE=y |
| 352 | CONFIG_OF_MDIO=y | ||
| 345 | # CONFIG_PARPORT is not set | 353 | # CONFIG_PARPORT is not set |
| 346 | CONFIG_BLK_DEV=y | 354 | CONFIG_BLK_DEV=y |
| 347 | # CONFIG_BLK_DEV_COW_COMMON is not set | 355 | # CONFIG_BLK_DEV_COW_COMMON is not set |
| @@ -370,6 +378,7 @@ CONFIG_MISC_DEVICES=y | |||
| 370 | # | 378 | # |
| 371 | # SCSI device support | 379 | # SCSI device support |
| 372 | # | 380 | # |
| 381 | CONFIG_SCSI_MOD=y | ||
| 373 | # CONFIG_RAID_ATTRS is not set | 382 | # CONFIG_RAID_ATTRS is not set |
| 374 | # CONFIG_SCSI is not set | 383 | # CONFIG_SCSI is not set |
| 375 | # CONFIG_SCSI_DMA is not set | 384 | # CONFIG_SCSI_DMA is not set |
| @@ -383,9 +392,30 @@ CONFIG_NETDEVICES=y | |||
| 383 | # CONFIG_EQUALIZER is not set | 392 | # CONFIG_EQUALIZER is not set |
| 384 | # CONFIG_TUN is not set | 393 | # CONFIG_TUN is not set |
| 385 | # CONFIG_VETH is not set | 394 | # CONFIG_VETH is not set |
| 386 | # CONFIG_PHYLIB is not set | 395 | CONFIG_PHYLIB=y |
| 396 | |||
| 397 | # | ||
| 398 | # MII PHY device drivers | ||
| 399 | # | ||
| 400 | # CONFIG_MARVELL_PHY is not set | ||
| 401 | # CONFIG_DAVICOM_PHY is not set | ||
| 402 | # CONFIG_QSEMI_PHY is not set | ||
| 403 | # CONFIG_LXT_PHY is not set | ||
| 404 | # CONFIG_CICADA_PHY is not set | ||
| 405 | # CONFIG_VITESSE_PHY is not set | ||
| 406 | # CONFIG_SMSC_PHY is not set | ||
| 407 | # CONFIG_BROADCOM_PHY is not set | ||
| 408 | # CONFIG_ICPLUS_PHY is not set | ||
| 409 | # CONFIG_REALTEK_PHY is not set | ||
| 410 | # CONFIG_NATIONAL_PHY is not set | ||
| 411 | # CONFIG_STE10XP is not set | ||
| 412 | # CONFIG_LSI_ET1011C_PHY is not set | ||
| 413 | # CONFIG_MICREL_PHY is not set | ||
| 414 | # CONFIG_FIXED_PHY is not set | ||
| 415 | # CONFIG_MDIO_BITBANG is not set | ||
| 387 | CONFIG_NET_ETHERNET=y | 416 | CONFIG_NET_ETHERNET=y |
| 388 | # CONFIG_MII is not set | 417 | # CONFIG_MII is not set |
| 418 | # CONFIG_ETHOC is not set | ||
| 389 | # CONFIG_DNET is not set | 419 | # CONFIG_DNET is not set |
| 390 | # CONFIG_IBM_NEW_EMAC_ZMII is not set | 420 | # CONFIG_IBM_NEW_EMAC_ZMII is not set |
| 391 | # CONFIG_IBM_NEW_EMAC_RGMII is not set | 421 | # CONFIG_IBM_NEW_EMAC_RGMII is not set |
| @@ -394,6 +424,7 @@ CONFIG_NET_ETHERNET=y | |||
| 394 | # CONFIG_IBM_NEW_EMAC_NO_FLOW_CTRL is not set | 424 | # CONFIG_IBM_NEW_EMAC_NO_FLOW_CTRL is not set |
| 395 | # CONFIG_IBM_NEW_EMAC_MAL_CLR_ICINTSTAT is not set | 425 | # CONFIG_IBM_NEW_EMAC_MAL_CLR_ICINTSTAT is not set |
| 396 | # CONFIG_IBM_NEW_EMAC_MAL_COMMON_ERR is not set | 426 | # CONFIG_IBM_NEW_EMAC_MAL_COMMON_ERR is not set |
| 427 | # CONFIG_B44 is not set | ||
| 397 | # CONFIG_KS8842 is not set | 428 | # CONFIG_KS8842 is not set |
| 398 | # CONFIG_KS8851_MLL is not set | 429 | # CONFIG_KS8851_MLL is not set |
| 399 | CONFIG_XILINX_EMACLITE=y | 430 | CONFIG_XILINX_EMACLITE=y |
| @@ -444,6 +475,7 @@ CONFIG_SERIAL_UARTLITE=y | |||
| 444 | CONFIG_SERIAL_UARTLITE_CONSOLE=y | 475 | CONFIG_SERIAL_UARTLITE_CONSOLE=y |
| 445 | CONFIG_SERIAL_CORE=y | 476 | CONFIG_SERIAL_CORE=y |
| 446 | CONFIG_SERIAL_CORE_CONSOLE=y | 477 | CONFIG_SERIAL_CORE_CONSOLE=y |
| 478 | # CONFIG_SERIAL_TIMBERDALE is not set | ||
| 447 | # CONFIG_SERIAL_GRLIB_GAISLER_APBUART is not set | 479 | # CONFIG_SERIAL_GRLIB_GAISLER_APBUART is not set |
| 448 | CONFIG_UNIX98_PTYS=y | 480 | CONFIG_UNIX98_PTYS=y |
| 449 | # CONFIG_DEVPTS_MULTIPLE_INSTANCES is not set | 481 | # CONFIG_DEVPTS_MULTIPLE_INSTANCES is not set |
| @@ -471,6 +503,12 @@ CONFIG_ARCH_WANT_OPTIONAL_GPIOLIB=y | |||
| 471 | # CONFIG_HWMON is not set | 503 | # CONFIG_HWMON is not set |
| 472 | # CONFIG_THERMAL is not set | 504 | # CONFIG_THERMAL is not set |
| 473 | # CONFIG_WATCHDOG is not set | 505 | # CONFIG_WATCHDOG is not set |
| 506 | CONFIG_SSB_POSSIBLE=y | ||
| 507 | |||
| 508 | # | ||
| 509 | # Sonics Silicon Backplane | ||
| 510 | # | ||
| 511 | # CONFIG_SSB is not set | ||
| 474 | 512 | ||
| 475 | # | 513 | # |
| 476 | # Multifunction device drivers | 514 | # Multifunction device drivers |
| @@ -502,6 +540,7 @@ CONFIG_USB_ARCH_HAS_EHCI=y | |||
| 502 | # CONFIG_NEW_LEDS is not set | 540 | # CONFIG_NEW_LEDS is not set |
| 503 | # CONFIG_ACCESSIBILITY is not set | 541 | # CONFIG_ACCESSIBILITY is not set |
| 504 | # CONFIG_RTC_CLASS is not set | 542 | # CONFIG_RTC_CLASS is not set |
| 543 | # CONFIG_DMADEVICES is not set | ||
| 505 | # CONFIG_AUXDISPLAY is not set | 544 | # CONFIG_AUXDISPLAY is not set |
| 506 | # CONFIG_UIO is not set | 545 | # CONFIG_UIO is not set |
| 507 | 546 | ||
| @@ -572,6 +611,7 @@ CONFIG_MISC_FILESYSTEMS=y | |||
| 572 | # CONFIG_BEFS_FS is not set | 611 | # CONFIG_BEFS_FS is not set |
| 573 | # CONFIG_BFS_FS is not set | 612 | # CONFIG_BFS_FS is not set |
| 574 | # CONFIG_EFS_FS is not set | 613 | # CONFIG_EFS_FS is not set |
| 614 | # CONFIG_LOGFS is not set | ||
| 575 | # CONFIG_CRAMFS is not set | 615 | # CONFIG_CRAMFS is not set |
| 576 | # CONFIG_SQUASHFS is not set | 616 | # CONFIG_SQUASHFS is not set |
| 577 | # CONFIG_VXFS_FS is not set | 617 | # CONFIG_VXFS_FS is not set |
| @@ -595,6 +635,7 @@ CONFIG_SUNRPC=y | |||
| 595 | # CONFIG_RPCSEC_GSS_KRB5 is not set | 635 | # CONFIG_RPCSEC_GSS_KRB5 is not set |
| 596 | # CONFIG_RPCSEC_GSS_SPKM3 is not set | 636 | # CONFIG_RPCSEC_GSS_SPKM3 is not set |
| 597 | # CONFIG_SMB_FS is not set | 637 | # CONFIG_SMB_FS is not set |
| 638 | # CONFIG_CEPH_FS is not set | ||
| 598 | CONFIG_CIFS=y | 639 | CONFIG_CIFS=y |
| 599 | CONFIG_CIFS_STATS=y | 640 | CONFIG_CIFS_STATS=y |
| 600 | CONFIG_CIFS_STATS2=y | 641 | CONFIG_CIFS_STATS2=y |
| @@ -696,6 +737,7 @@ CONFIG_SCHED_DEBUG=y | |||
| 696 | # CONFIG_DEBUG_OBJECTS is not set | 737 | # CONFIG_DEBUG_OBJECTS is not set |
| 697 | CONFIG_DEBUG_SLAB=y | 738 | CONFIG_DEBUG_SLAB=y |
| 698 | # CONFIG_DEBUG_SLAB_LEAK is not set | 739 | # CONFIG_DEBUG_SLAB_LEAK is not set |
| 740 | # CONFIG_DEBUG_KMEMLEAK is not set | ||
| 699 | CONFIG_DEBUG_SPINLOCK=y | 741 | CONFIG_DEBUG_SPINLOCK=y |
| 700 | # CONFIG_DEBUG_MUTEXES is not set | 742 | # CONFIG_DEBUG_MUTEXES is not set |
| 701 | # CONFIG_DEBUG_LOCK_ALLOC is not set | 743 | # CONFIG_DEBUG_LOCK_ALLOC is not set |
| @@ -741,6 +783,7 @@ CONFIG_BRANCH_PROFILE_NONE=y | |||
| 741 | # CONFIG_KMEMTRACE is not set | 783 | # CONFIG_KMEMTRACE is not set |
| 742 | # CONFIG_WORKQUEUE_TRACER is not set | 784 | # CONFIG_WORKQUEUE_TRACER is not set |
| 743 | # CONFIG_BLK_DEV_IO_TRACE is not set | 785 | # CONFIG_BLK_DEV_IO_TRACE is not set |
| 786 | # CONFIG_DMA_API_DEBUG is not set | ||
| 744 | # CONFIG_SAMPLES is not set | 787 | # CONFIG_SAMPLES is not set |
| 745 | CONFIG_EARLY_PRINTK=y | 788 | CONFIG_EARLY_PRINTK=y |
| 746 | # CONFIG_HEART_BEAT is not set | 789 | # CONFIG_HEART_BEAT is not set |
| @@ -862,5 +905,6 @@ CONFIG_ZLIB_INFLATE=y | |||
| 862 | CONFIG_DECOMPRESS_GZIP=y | 905 | CONFIG_DECOMPRESS_GZIP=y |
| 863 | CONFIG_HAS_IOMEM=y | 906 | CONFIG_HAS_IOMEM=y |
| 864 | CONFIG_HAS_IOPORT=y | 907 | CONFIG_HAS_IOPORT=y |
| 908 | CONFIG_HAS_DMA=y | ||
| 865 | CONFIG_HAVE_LMB=y | 909 | CONFIG_HAVE_LMB=y |
| 866 | CONFIG_NLATTR=y | 910 | CONFIG_NLATTR=y |
diff --git a/arch/microblaze/configs/nommu_defconfig b/arch/microblaze/configs/nommu_defconfig index ce2da535246a..dd3a494257f4 100644 --- a/arch/microblaze/configs/nommu_defconfig +++ b/arch/microblaze/configs/nommu_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.33-rc6 | 3 | # Linux kernel version: 2.6.34-rc6 |
| 4 | # Wed Feb 3 10:03:21 2010 | 4 | # Thu May 6 11:25:12 2010 |
| 5 | # | 5 | # |
| 6 | CONFIG_MICROBLAZE=y | 6 | CONFIG_MICROBLAZE=y |
| 7 | # CONFIG_SWAP is not set | 7 | # CONFIG_SWAP is not set |
| @@ -22,8 +22,6 @@ CONFIG_GENERIC_CSUM=y | |||
| 22 | CONFIG_STACKTRACE_SUPPORT=y | 22 | CONFIG_STACKTRACE_SUPPORT=y |
| 23 | CONFIG_LOCKDEP_SUPPORT=y | 23 | CONFIG_LOCKDEP_SUPPORT=y |
| 24 | CONFIG_HAVE_LATENCYTOP_SUPPORT=y | 24 | CONFIG_HAVE_LATENCYTOP_SUPPORT=y |
| 25 | # CONFIG_PCI is not set | ||
| 26 | CONFIG_NO_DMA=y | ||
| 27 | CONFIG_DTC=y | 25 | CONFIG_DTC=y |
| 28 | CONFIG_DEFCONFIG_LIST="/lib/modules/$UNAME_RELEASE/.config" | 26 | CONFIG_DEFCONFIG_LIST="/lib/modules/$UNAME_RELEASE/.config" |
| 29 | CONFIG_CONSTRUCTORS=y | 27 | CONFIG_CONSTRUCTORS=y |
| @@ -58,7 +56,6 @@ CONFIG_RCU_FANOUT=32 | |||
| 58 | CONFIG_IKCONFIG=y | 56 | CONFIG_IKCONFIG=y |
| 59 | CONFIG_IKCONFIG_PROC=y | 57 | CONFIG_IKCONFIG_PROC=y |
| 60 | CONFIG_LOG_BUF_SHIFT=17 | 58 | CONFIG_LOG_BUF_SHIFT=17 |
| 61 | # CONFIG_GROUP_SCHED is not set | ||
| 62 | # CONFIG_CGROUPS is not set | 59 | # CONFIG_CGROUPS is not set |
| 63 | CONFIG_SYSFS_DEPRECATED=y | 60 | CONFIG_SYSFS_DEPRECATED=y |
| 64 | CONFIG_SYSFS_DEPRECATED_V2=y | 61 | CONFIG_SYSFS_DEPRECATED_V2=y |
| @@ -96,6 +93,8 @@ CONFIG_SLAB=y | |||
| 96 | # CONFIG_MMAP_ALLOW_UNINITIALIZED is not set | 93 | # CONFIG_MMAP_ALLOW_UNINITIALIZED is not set |
| 97 | # CONFIG_PROFILING is not set | 94 | # CONFIG_PROFILING is not set |
| 98 | CONFIG_HAVE_OPROFILE=y | 95 | CONFIG_HAVE_OPROFILE=y |
| 96 | CONFIG_HAVE_DMA_ATTRS=y | ||
| 97 | CONFIG_HAVE_DMA_API_DEBUG=y | ||
| 99 | 98 | ||
| 100 | # | 99 | # |
| 101 | # GCOV-based kernel profiling | 100 | # GCOV-based kernel profiling |
| @@ -209,11 +208,14 @@ CONFIG_PROC_DEVICETREE=y | |||
| 209 | # | 208 | # |
| 210 | # Advanced setup | 209 | # Advanced setup |
| 211 | # | 210 | # |
| 211 | # CONFIG_ADVANCED_OPTIONS is not set | ||
| 212 | 212 | ||
| 213 | # | 213 | # |
| 214 | # Default settings for advanced configuration options are used | 214 | # Default settings for advanced configuration options are used |
| 215 | # | 215 | # |
| 216 | CONFIG_LOWMEM_SIZE=0x30000000 | ||
| 216 | CONFIG_KERNEL_START=0x90000000 | 217 | CONFIG_KERNEL_START=0x90000000 |
| 218 | CONFIG_TASK_SIZE=0x80000000 | ||
| 217 | CONFIG_SELECT_MEMORY_MODEL=y | 219 | CONFIG_SELECT_MEMORY_MODEL=y |
| 218 | CONFIG_FLATMEM_MANUAL=y | 220 | CONFIG_FLATMEM_MANUAL=y |
| 219 | # CONFIG_DISCONTIGMEM_MANUAL is not set | 221 | # CONFIG_DISCONTIGMEM_MANUAL is not set |
| @@ -235,13 +237,20 @@ CONFIG_BINFMT_FLAT=y | |||
| 235 | # CONFIG_BINFMT_SHARED_FLAT is not set | 237 | # CONFIG_BINFMT_SHARED_FLAT is not set |
| 236 | # CONFIG_HAVE_AOUT is not set | 238 | # CONFIG_HAVE_AOUT is not set |
| 237 | # CONFIG_BINFMT_MISC is not set | 239 | # CONFIG_BINFMT_MISC is not set |
| 240 | |||
| 241 | # | ||
| 242 | # Bus Options | ||
| 243 | # | ||
| 244 | # CONFIG_PCI is not set | ||
| 245 | # CONFIG_PCI_DOMAINS is not set | ||
| 246 | # CONFIG_PCI_SYSCALL is not set | ||
| 247 | # CONFIG_ARCH_SUPPORTS_MSI is not set | ||
| 238 | CONFIG_NET=y | 248 | CONFIG_NET=y |
| 239 | 249 | ||
| 240 | # | 250 | # |
| 241 | # Networking options | 251 | # Networking options |
| 242 | # | 252 | # |
| 243 | CONFIG_PACKET=y | 253 | CONFIG_PACKET=y |
| 244 | # CONFIG_PACKET_MMAP is not set | ||
| 245 | CONFIG_UNIX=y | 254 | CONFIG_UNIX=y |
| 246 | CONFIG_XFRM=y | 255 | CONFIG_XFRM=y |
| 247 | # CONFIG_XFRM_USER is not set | 256 | # CONFIG_XFRM_USER is not set |
| @@ -413,6 +422,7 @@ CONFIG_MTD_UCLINUX=y | |||
| 413 | # UBI - Unsorted block images | 422 | # UBI - Unsorted block images |
| 414 | # | 423 | # |
| 415 | # CONFIG_MTD_UBI is not set | 424 | # CONFIG_MTD_UBI is not set |
| 425 | CONFIG_OF_FLATTREE=y | ||
| 416 | CONFIG_OF_DEVICE=y | 426 | CONFIG_OF_DEVICE=y |
| 417 | # CONFIG_PARPORT is not set | 427 | # CONFIG_PARPORT is not set |
| 418 | CONFIG_BLK_DEV=y | 428 | CONFIG_BLK_DEV=y |
| @@ -442,6 +452,7 @@ CONFIG_MISC_DEVICES=y | |||
| 442 | # | 452 | # |
| 443 | # SCSI device support | 453 | # SCSI device support |
| 444 | # | 454 | # |
| 455 | CONFIG_SCSI_MOD=y | ||
| 445 | # CONFIG_RAID_ATTRS is not set | 456 | # CONFIG_RAID_ATTRS is not set |
| 446 | # CONFIG_SCSI is not set | 457 | # CONFIG_SCSI is not set |
| 447 | # CONFIG_SCSI_DMA is not set | 458 | # CONFIG_SCSI_DMA is not set |
| @@ -458,6 +469,7 @@ CONFIG_NETDEVICES=y | |||
| 458 | # CONFIG_PHYLIB is not set | 469 | # CONFIG_PHYLIB is not set |
| 459 | CONFIG_NET_ETHERNET=y | 470 | CONFIG_NET_ETHERNET=y |
| 460 | # CONFIG_MII is not set | 471 | # CONFIG_MII is not set |
| 472 | # CONFIG_ETHOC is not set | ||
| 461 | # CONFIG_DNET is not set | 473 | # CONFIG_DNET is not set |
| 462 | # CONFIG_IBM_NEW_EMAC_ZMII is not set | 474 | # CONFIG_IBM_NEW_EMAC_ZMII is not set |
| 463 | # CONFIG_IBM_NEW_EMAC_RGMII is not set | 475 | # CONFIG_IBM_NEW_EMAC_RGMII is not set |
| @@ -466,6 +478,7 @@ CONFIG_NET_ETHERNET=y | |||
| 466 | # CONFIG_IBM_NEW_EMAC_NO_FLOW_CTRL is not set | 478 | # CONFIG_IBM_NEW_EMAC_NO_FLOW_CTRL is not set |
| 467 | # CONFIG_IBM_NEW_EMAC_MAL_CLR_ICINTSTAT is not set | 479 | # CONFIG_IBM_NEW_EMAC_MAL_CLR_ICINTSTAT is not set |
| 468 | # CONFIG_IBM_NEW_EMAC_MAL_COMMON_ERR is not set | 480 | # CONFIG_IBM_NEW_EMAC_MAL_COMMON_ERR is not set |
| 481 | # CONFIG_B44 is not set | ||
| 469 | # CONFIG_KS8842 is not set | 482 | # CONFIG_KS8842 is not set |
| 470 | # CONFIG_KS8851_MLL is not set | 483 | # CONFIG_KS8851_MLL is not set |
| 471 | # CONFIG_XILINX_EMACLITE is not set | 484 | # CONFIG_XILINX_EMACLITE is not set |
| @@ -516,6 +529,7 @@ CONFIG_SERIAL_UARTLITE=y | |||
| 516 | CONFIG_SERIAL_UARTLITE_CONSOLE=y | 529 | CONFIG_SERIAL_UARTLITE_CONSOLE=y |
| 517 | CONFIG_SERIAL_CORE=y | 530 | CONFIG_SERIAL_CORE=y |
| 518 | CONFIG_SERIAL_CORE_CONSOLE=y | 531 | CONFIG_SERIAL_CORE_CONSOLE=y |
| 532 | # CONFIG_SERIAL_TIMBERDALE is not set | ||
| 519 | # CONFIG_SERIAL_GRLIB_GAISLER_APBUART is not set | 533 | # CONFIG_SERIAL_GRLIB_GAISLER_APBUART is not set |
| 520 | CONFIG_UNIX98_PTYS=y | 534 | CONFIG_UNIX98_PTYS=y |
| 521 | # CONFIG_DEVPTS_MULTIPLE_INSTANCES is not set | 535 | # CONFIG_DEVPTS_MULTIPLE_INSTANCES is not set |
| @@ -544,6 +558,12 @@ CONFIG_ARCH_WANT_OPTIONAL_GPIOLIB=y | |||
| 544 | # CONFIG_HWMON is not set | 558 | # CONFIG_HWMON is not set |
| 545 | # CONFIG_THERMAL is not set | 559 | # CONFIG_THERMAL is not set |
| 546 | # CONFIG_WATCHDOG is not set | 560 | # CONFIG_WATCHDOG is not set |
| 561 | CONFIG_SSB_POSSIBLE=y | ||
| 562 | |||
| 563 | # | ||
| 564 | # Sonics Silicon Backplane | ||
| 565 | # | ||
| 566 | # CONFIG_SSB is not set | ||
| 547 | 567 | ||
| 548 | # | 568 | # |
| 549 | # Multifunction device drivers | 569 | # Multifunction device drivers |
| @@ -593,6 +613,7 @@ CONFIG_USB_ARCH_HAS_EHCI=y | |||
| 593 | # CONFIG_NEW_LEDS is not set | 613 | # CONFIG_NEW_LEDS is not set |
| 594 | # CONFIG_ACCESSIBILITY is not set | 614 | # CONFIG_ACCESSIBILITY is not set |
| 595 | # CONFIG_RTC_CLASS is not set | 615 | # CONFIG_RTC_CLASS is not set |
| 616 | # CONFIG_DMADEVICES is not set | ||
| 596 | # CONFIG_AUXDISPLAY is not set | 617 | # CONFIG_AUXDISPLAY is not set |
| 597 | # CONFIG_UIO is not set | 618 | # CONFIG_UIO is not set |
| 598 | 619 | ||
| @@ -661,6 +682,7 @@ CONFIG_MISC_FILESYSTEMS=y | |||
| 661 | # CONFIG_BFS_FS is not set | 682 | # CONFIG_BFS_FS is not set |
| 662 | # CONFIG_EFS_FS is not set | 683 | # CONFIG_EFS_FS is not set |
| 663 | # CONFIG_JFFS2_FS is not set | 684 | # CONFIG_JFFS2_FS is not set |
| 685 | # CONFIG_LOGFS is not set | ||
| 664 | CONFIG_CRAMFS=y | 686 | CONFIG_CRAMFS=y |
| 665 | # CONFIG_SQUASHFS is not set | 687 | # CONFIG_SQUASHFS is not set |
| 666 | # CONFIG_VXFS_FS is not set | 688 | # CONFIG_VXFS_FS is not set |
| @@ -689,6 +711,7 @@ CONFIG_SUNRPC=y | |||
| 689 | # CONFIG_RPCSEC_GSS_KRB5 is not set | 711 | # CONFIG_RPCSEC_GSS_KRB5 is not set |
| 690 | # CONFIG_RPCSEC_GSS_SPKM3 is not set | 712 | # CONFIG_RPCSEC_GSS_SPKM3 is not set |
| 691 | # CONFIG_SMB_FS is not set | 713 | # CONFIG_SMB_FS is not set |
| 714 | # CONFIG_CEPH_FS is not set | ||
| 692 | # CONFIG_CIFS is not set | 715 | # CONFIG_CIFS is not set |
| 693 | # CONFIG_NCP_FS is not set | 716 | # CONFIG_NCP_FS is not set |
| 694 | # CONFIG_CODA_FS is not set | 717 | # CONFIG_CODA_FS is not set |
| @@ -733,6 +756,7 @@ CONFIG_DEBUG_OBJECTS_TIMERS=y | |||
| 733 | # CONFIG_DEBUG_OBJECTS_WORK is not set | 756 | # CONFIG_DEBUG_OBJECTS_WORK is not set |
| 734 | CONFIG_DEBUG_OBJECTS_ENABLE_DEFAULT=1 | 757 | CONFIG_DEBUG_OBJECTS_ENABLE_DEFAULT=1 |
| 735 | # CONFIG_DEBUG_SLAB is not set | 758 | # CONFIG_DEBUG_SLAB is not set |
| 759 | # CONFIG_DEBUG_KMEMLEAK is not set | ||
| 736 | # CONFIG_DEBUG_RT_MUTEXES is not set | 760 | # CONFIG_DEBUG_RT_MUTEXES is not set |
| 737 | # CONFIG_RT_MUTEX_TESTER is not set | 761 | # CONFIG_RT_MUTEX_TESTER is not set |
| 738 | # CONFIG_DEBUG_SPINLOCK is not set | 762 | # CONFIG_DEBUG_SPINLOCK is not set |
| @@ -758,6 +782,7 @@ CONFIG_DEBUG_SG=y | |||
| 758 | # CONFIG_BACKTRACE_SELF_TEST is not set | 782 | # CONFIG_BACKTRACE_SELF_TEST is not set |
| 759 | # CONFIG_DEBUG_BLOCK_EXT_DEVT is not set | 783 | # CONFIG_DEBUG_BLOCK_EXT_DEVT is not set |
| 760 | # CONFIG_DEBUG_FORCE_WEAK_PER_CPU is not set | 784 | # CONFIG_DEBUG_FORCE_WEAK_PER_CPU is not set |
| 785 | # CONFIG_LKDTM is not set | ||
| 761 | # CONFIG_FAULT_INJECTION is not set | 786 | # CONFIG_FAULT_INJECTION is not set |
| 762 | # CONFIG_LATENCYTOP is not set | 787 | # CONFIG_LATENCYTOP is not set |
| 763 | CONFIG_SYSCTL_SYSCALL_CHECK=y | 788 | CONFIG_SYSCTL_SYSCALL_CHECK=y |
| @@ -782,6 +807,7 @@ CONFIG_BRANCH_PROFILE_NONE=y | |||
| 782 | # CONFIG_WORKQUEUE_TRACER is not set | 807 | # CONFIG_WORKQUEUE_TRACER is not set |
| 783 | # CONFIG_BLK_DEV_IO_TRACE is not set | 808 | # CONFIG_BLK_DEV_IO_TRACE is not set |
| 784 | # CONFIG_DYNAMIC_DEBUG is not set | 809 | # CONFIG_DYNAMIC_DEBUG is not set |
| 810 | # CONFIG_DMA_API_DEBUG is not set | ||
| 785 | # CONFIG_SAMPLES is not set | 811 | # CONFIG_SAMPLES is not set |
| 786 | CONFIG_EARLY_PRINTK=y | 812 | CONFIG_EARLY_PRINTK=y |
| 787 | # CONFIG_HEART_BEAT is not set | 813 | # CONFIG_HEART_BEAT is not set |
| @@ -901,5 +927,6 @@ CONFIG_GENERIC_FIND_LAST_BIT=y | |||
| 901 | CONFIG_ZLIB_INFLATE=y | 927 | CONFIG_ZLIB_INFLATE=y |
| 902 | CONFIG_HAS_IOMEM=y | 928 | CONFIG_HAS_IOMEM=y |
| 903 | CONFIG_HAS_IOPORT=y | 929 | CONFIG_HAS_IOPORT=y |
| 930 | CONFIG_HAS_DMA=y | ||
| 904 | CONFIG_HAVE_LMB=y | 931 | CONFIG_HAVE_LMB=y |
| 905 | CONFIG_NLATTR=y | 932 | CONFIG_NLATTR=y |
diff --git a/arch/microblaze/include/asm/cache.h b/arch/microblaze/include/asm/cache.h index e52210891d78..4efe96a036f7 100644 --- a/arch/microblaze/include/asm/cache.h +++ b/arch/microblaze/include/asm/cache.h | |||
| @@ -15,7 +15,7 @@ | |||
| 15 | 15 | ||
| 16 | #include <asm/registers.h> | 16 | #include <asm/registers.h> |
| 17 | 17 | ||
| 18 | #define L1_CACHE_SHIFT 2 | 18 | #define L1_CACHE_SHIFT 5 |
| 19 | /* word-granular cache in microblaze */ | 19 | /* word-granular cache in microblaze */ |
| 20 | #define L1_CACHE_BYTES (1 << L1_CACHE_SHIFT) | 20 | #define L1_CACHE_BYTES (1 << L1_CACHE_SHIFT) |
| 21 | 21 | ||
diff --git a/arch/microblaze/include/asm/dma.h b/arch/microblaze/include/asm/dma.h index 08c073badf19..0d73d0c6de37 100644 --- a/arch/microblaze/include/asm/dma.h +++ b/arch/microblaze/include/asm/dma.h | |||
| @@ -18,4 +18,10 @@ | |||
| 18 | #define MAX_DMA_ADDRESS (CONFIG_KERNEL_START + memory_size - 1) | 18 | #define MAX_DMA_ADDRESS (CONFIG_KERNEL_START + memory_size - 1) |
| 19 | #endif | 19 | #endif |
| 20 | 20 | ||
| 21 | #ifdef CONFIG_PCI | ||
| 22 | extern int isa_dma_bridge_buggy; | ||
| 23 | #else | ||
| 24 | #define isa_dma_bridge_buggy (0) | ||
| 25 | #endif | ||
| 26 | |||
| 21 | #endif /* _ASM_MICROBLAZE_DMA_H */ | 27 | #endif /* _ASM_MICROBLAZE_DMA_H */ |
diff --git a/arch/microblaze/include/asm/exceptions.h b/arch/microblaze/include/asm/exceptions.h index 90731df9e574..4c7b5d037c88 100644 --- a/arch/microblaze/include/asm/exceptions.h +++ b/arch/microblaze/include/asm/exceptions.h | |||
| @@ -64,12 +64,6 @@ asmlinkage void full_exception(struct pt_regs *regs, unsigned int type, | |||
| 64 | void die(const char *str, struct pt_regs *fp, long err); | 64 | void die(const char *str, struct pt_regs *fp, long err); |
| 65 | void _exception(int signr, struct pt_regs *regs, int code, unsigned long addr); | 65 | void _exception(int signr, struct pt_regs *regs, int code, unsigned long addr); |
| 66 | 66 | ||
| 67 | #ifdef CONFIG_MMU | ||
| 68 | void __bug(const char *file, int line, void *data); | ||
| 69 | int bad_trap(int trap_num, struct pt_regs *regs); | ||
| 70 | int debug_trap(struct pt_regs *regs); | ||
| 71 | #endif /* CONFIG_MMU */ | ||
| 72 | |||
| 73 | #if defined(CONFIG_KGDB) | 67 | #if defined(CONFIG_KGDB) |
| 74 | void (*debugger)(struct pt_regs *regs); | 68 | void (*debugger)(struct pt_regs *regs); |
| 75 | int (*debugger_bpt)(struct pt_regs *regs); | 69 | int (*debugger_bpt)(struct pt_regs *regs); |
diff --git a/arch/microblaze/include/asm/io.h b/arch/microblaze/include/asm/io.h index e45a6eea92e0..00b5398d08c7 100644 --- a/arch/microblaze/include/asm/io.h +++ b/arch/microblaze/include/asm/io.h | |||
| @@ -139,8 +139,6 @@ static inline void writel(unsigned int v, volatile void __iomem *addr) | |||
| 139 | 139 | ||
| 140 | #ifdef CONFIG_MMU | 140 | #ifdef CONFIG_MMU |
| 141 | 141 | ||
| 142 | #define mm_ptov(addr) ((void *)__phys_to_virt(addr)) | ||
| 143 | #define mm_vtop(addr) ((unsigned long)__virt_to_phys(addr)) | ||
| 144 | #define phys_to_virt(addr) ((void *)__phys_to_virt(addr)) | 142 | #define phys_to_virt(addr) ((void *)__phys_to_virt(addr)) |
| 145 | #define virt_to_phys(addr) ((unsigned long)__virt_to_phys(addr)) | 143 | #define virt_to_phys(addr) ((unsigned long)__virt_to_phys(addr)) |
| 146 | #define virt_to_bus(addr) ((unsigned long)__virt_to_phys(addr)) | 144 | #define virt_to_bus(addr) ((unsigned long)__virt_to_phys(addr)) |
diff --git a/arch/microblaze/include/asm/page.h b/arch/microblaze/include/asm/page.h index 2dd1d04129e0..de493f86d28f 100644 --- a/arch/microblaze/include/asm/page.h +++ b/arch/microblaze/include/asm/page.h | |||
| @@ -31,6 +31,9 @@ | |||
| 31 | 31 | ||
| 32 | #ifndef __ASSEMBLY__ | 32 | #ifndef __ASSEMBLY__ |
| 33 | 33 | ||
| 34 | /* MS be sure that SLAB allocates aligned objects */ | ||
| 35 | #define ARCH_KMALLOC_MINALIGN L1_CACHE_BYTES | ||
| 36 | |||
| 34 | #define PAGE_UP(addr) (((addr)+((PAGE_SIZE)-1))&(~((PAGE_SIZE)-1))) | 37 | #define PAGE_UP(addr) (((addr)+((PAGE_SIZE)-1))&(~((PAGE_SIZE)-1))) |
| 35 | #define PAGE_DOWN(addr) ((addr)&(~((PAGE_SIZE)-1))) | 38 | #define PAGE_DOWN(addr) ((addr)&(~((PAGE_SIZE)-1))) |
| 36 | 39 | ||
| @@ -70,14 +73,7 @@ typedef unsigned long pte_basic_t; | |||
| 70 | 73 | ||
| 71 | #endif /* CONFIG_MMU */ | 74 | #endif /* CONFIG_MMU */ |
| 72 | 75 | ||
| 73 | # ifndef CONFIG_MMU | 76 | # define copy_page(to, from) memcpy((to), (from), PAGE_SIZE) |
| 74 | # define copy_page(to, from) memcpy((to), (from), PAGE_SIZE) | ||
| 75 | # define get_user_page(vaddr) __get_free_page(GFP_KERNEL) | ||
| 76 | # define free_user_page(page, addr) free_page(addr) | ||
| 77 | # else /* CONFIG_MMU */ | ||
| 78 | extern void copy_page(void *to, void *from); | ||
| 79 | # endif /* CONFIG_MMU */ | ||
| 80 | |||
| 81 | # define clear_page(pgaddr) memset((pgaddr), 0, PAGE_SIZE) | 77 | # define clear_page(pgaddr) memset((pgaddr), 0, PAGE_SIZE) |
| 82 | 78 | ||
| 83 | # define clear_user_page(pgaddr, vaddr, page) memset((pgaddr), 0, PAGE_SIZE) | 79 | # define clear_user_page(pgaddr, vaddr, page) memset((pgaddr), 0, PAGE_SIZE) |
diff --git a/arch/microblaze/include/asm/pci.h b/arch/microblaze/include/asm/pci.h index bdd65aaee30d..5a388eeeb28f 100644 --- a/arch/microblaze/include/asm/pci.h +++ b/arch/microblaze/include/asm/pci.h | |||
| @@ -94,14 +94,6 @@ extern int pci_mmap_legacy_page_range(struct pci_bus *bus, | |||
| 94 | 94 | ||
| 95 | #define HAVE_PCI_LEGACY 1 | 95 | #define HAVE_PCI_LEGACY 1 |
| 96 | 96 | ||
| 97 | /* pci_unmap_{page,single} is a nop so... */ | ||
| 98 | #define DECLARE_PCI_UNMAP_ADDR(ADDR_NAME) | ||
| 99 | #define DECLARE_PCI_UNMAP_LEN(LEN_NAME) | ||
| 100 | #define pci_unmap_addr(PTR, ADDR_NAME) (0) | ||
| 101 | #define pci_unmap_addr_set(PTR, ADDR_NAME, VAL) do { } while (0) | ||
| 102 | #define pci_unmap_len(PTR, LEN_NAME) (0) | ||
| 103 | #define pci_unmap_len_set(PTR, LEN_NAME, VAL) do { } while (0) | ||
| 104 | |||
| 105 | /* The PCI address space does equal the physical memory | 97 | /* The PCI address space does equal the physical memory |
| 106 | * address space (no IOMMU). The IDE and SCSI device layers use | 98 | * address space (no IOMMU). The IDE and SCSI device layers use |
| 107 | * this boolean for bounce buffer decisions. | 99 | * this boolean for bounce buffer decisions. |
diff --git a/arch/microblaze/include/asm/pgalloc.h b/arch/microblaze/include/asm/pgalloc.h index f44b0d696fe2..c614a893f8a3 100644 --- a/arch/microblaze/include/asm/pgalloc.h +++ b/arch/microblaze/include/asm/pgalloc.h | |||
| @@ -108,21 +108,7 @@ extern inline void free_pgd_slow(pgd_t *pgd) | |||
| 108 | #define pmd_alloc_one_fast(mm, address) ({ BUG(); ((pmd_t *)1); }) | 108 | #define pmd_alloc_one_fast(mm, address) ({ BUG(); ((pmd_t *)1); }) |
| 109 | #define pmd_alloc_one(mm, address) ({ BUG(); ((pmd_t *)2); }) | 109 | #define pmd_alloc_one(mm, address) ({ BUG(); ((pmd_t *)2); }) |
| 110 | 110 | ||
| 111 | static inline pte_t *pte_alloc_one_kernel(struct mm_struct *mm, | 111 | extern pte_t *pte_alloc_one_kernel(struct mm_struct *mm, unsigned long addr); |
| 112 | unsigned long address) | ||
| 113 | { | ||
| 114 | pte_t *pte; | ||
| 115 | extern void *early_get_page(void); | ||
| 116 | if (mem_init_done) { | ||
| 117 | pte = (pte_t *)__get_free_page(GFP_KERNEL | | ||
| 118 | __GFP_REPEAT | __GFP_ZERO); | ||
| 119 | } else { | ||
| 120 | pte = (pte_t *)early_get_page(); | ||
| 121 | if (pte) | ||
| 122 | clear_page(pte); | ||
| 123 | } | ||
| 124 | return pte; | ||
| 125 | } | ||
| 126 | 112 | ||
| 127 | static inline struct page *pte_alloc_one(struct mm_struct *mm, | 113 | static inline struct page *pte_alloc_one(struct mm_struct *mm, |
| 128 | unsigned long address) | 114 | unsigned long address) |
diff --git a/arch/microblaze/include/asm/pgtable.h b/arch/microblaze/include/asm/pgtable.h index dd2bb60651c7..ca2d92871545 100644 --- a/arch/microblaze/include/asm/pgtable.h +++ b/arch/microblaze/include/asm/pgtable.h | |||
| @@ -512,15 +512,6 @@ static inline pmd_t *pmd_offset(pgd_t *dir, unsigned long address) | |||
| 512 | extern pgd_t swapper_pg_dir[PTRS_PER_PGD]; | 512 | extern pgd_t swapper_pg_dir[PTRS_PER_PGD]; |
| 513 | 513 | ||
| 514 | /* | 514 | /* |
| 515 | * When flushing the tlb entry for a page, we also need to flush the hash | ||
| 516 | * table entry. flush_hash_page is assembler (for speed) in hashtable.S. | ||
| 517 | */ | ||
| 518 | extern int flush_hash_page(unsigned context, unsigned long va, pte_t *ptep); | ||
| 519 | |||
| 520 | /* Add an HPTE to the hash table */ | ||
| 521 | extern void add_hash_page(unsigned context, unsigned long va, pte_t *ptep); | ||
| 522 | |||
| 523 | /* | ||
| 524 | * Encode and decode a swap entry. | 515 | * Encode and decode a swap entry. |
| 525 | * Note that the bits we use in a PTE for representing a swap entry | 516 | * Note that the bits we use in a PTE for representing a swap entry |
| 526 | * must not include the _PAGE_PRESENT bit, or the _PAGE_HASHPTE bit | 517 | * must not include the _PAGE_PRESENT bit, or the _PAGE_HASHPTE bit |
| @@ -533,15 +524,7 @@ extern void add_hash_page(unsigned context, unsigned long va, pte_t *ptep); | |||
| 533 | #define __pte_to_swp_entry(pte) ((swp_entry_t) { pte_val(pte) >> 2 }) | 524 | #define __pte_to_swp_entry(pte) ((swp_entry_t) { pte_val(pte) >> 2 }) |
| 534 | #define __swp_entry_to_pte(x) ((pte_t) { (x).val << 2 }) | 525 | #define __swp_entry_to_pte(x) ((pte_t) { (x).val << 2 }) |
| 535 | 526 | ||
| 536 | |||
| 537 | /* CONFIG_APUS */ | ||
| 538 | /* For virtual address to physical address conversion */ | ||
| 539 | extern void cache_clear(__u32 addr, int length); | ||
| 540 | extern void cache_push(__u32 addr, int length); | ||
| 541 | extern int mm_end_of_chunk(unsigned long addr, int len); | ||
| 542 | extern unsigned long iopa(unsigned long addr); | 527 | extern unsigned long iopa(unsigned long addr); |
| 543 | /* extern unsigned long mm_ptov(unsigned long addr) \ | ||
| 544 | __attribute__ ((const)); TBD */ | ||
| 545 | 528 | ||
| 546 | /* Values for nocacheflag and cmode */ | 529 | /* Values for nocacheflag and cmode */ |
| 547 | /* These are not used by the APUS kernel_map, but prevents | 530 | /* These are not used by the APUS kernel_map, but prevents |
| @@ -552,18 +535,6 @@ extern unsigned long iopa(unsigned long addr); | |||
| 552 | #define IOMAP_NOCACHE_NONSER 2 | 535 | #define IOMAP_NOCACHE_NONSER 2 |
| 553 | #define IOMAP_NO_COPYBACK 3 | 536 | #define IOMAP_NO_COPYBACK 3 |
| 554 | 537 | ||
| 555 | /* | ||
| 556 | * Map some physical address range into the kernel address space. | ||
| 557 | */ | ||
| 558 | extern unsigned long kernel_map(unsigned long paddr, unsigned long size, | ||
| 559 | int nocacheflag, unsigned long *memavailp); | ||
| 560 | |||
| 561 | /* | ||
| 562 | * Set cache mode of (kernel space) address range. | ||
| 563 | */ | ||
| 564 | extern void kernel_set_cachemode(unsigned long address, unsigned long size, | ||
| 565 | unsigned int cmode); | ||
| 566 | |||
| 567 | /* Needs to be defined here and not in linux/mm.h, as it is arch dependent */ | 538 | /* Needs to be defined here and not in linux/mm.h, as it is arch dependent */ |
| 568 | #define kern_addr_valid(addr) (1) | 539 | #define kern_addr_valid(addr) (1) |
| 569 | 540 | ||
| @@ -577,10 +548,6 @@ extern void kernel_set_cachemode(unsigned long address, unsigned long size, | |||
| 577 | void do_page_fault(struct pt_regs *regs, unsigned long address, | 548 | void do_page_fault(struct pt_regs *regs, unsigned long address, |
| 578 | unsigned long error_code); | 549 | unsigned long error_code); |
| 579 | 550 | ||
| 580 | void __init io_block_mapping(unsigned long virt, phys_addr_t phys, | ||
| 581 | unsigned int size, int flags); | ||
| 582 | |||
| 583 | void __init adjust_total_lowmem(void); | ||
| 584 | void mapin_ram(void); | 551 | void mapin_ram(void); |
| 585 | int map_page(unsigned long va, phys_addr_t pa, int flags); | 552 | int map_page(unsigned long va, phys_addr_t pa, int flags); |
| 586 | 553 | ||
| @@ -601,7 +568,7 @@ void __init *early_get_page(void); | |||
| 601 | extern unsigned long ioremap_bot, ioremap_base; | 568 | extern unsigned long ioremap_bot, ioremap_base; |
| 602 | 569 | ||
| 603 | void *consistent_alloc(int gfp, size_t size, dma_addr_t *dma_handle); | 570 | void *consistent_alloc(int gfp, size_t size, dma_addr_t *dma_handle); |
| 604 | void consistent_free(void *vaddr); | 571 | void consistent_free(size_t size, void *vaddr); |
| 605 | void consistent_sync(void *vaddr, size_t size, int direction); | 572 | void consistent_sync(void *vaddr, size_t size, int direction); |
| 606 | void consistent_sync_page(struct page *page, unsigned long offset, | 573 | void consistent_sync_page(struct page *page, unsigned long offset, |
| 607 | size_t size, int direction); | 574 | size_t size, int direction); |
diff --git a/arch/microblaze/kernel/asm-offsets.c b/arch/microblaze/kernel/asm-offsets.c index 0071260a672c..c1b459c97571 100644 --- a/arch/microblaze/kernel/asm-offsets.c +++ b/arch/microblaze/kernel/asm-offsets.c | |||
| @@ -16,6 +16,7 @@ | |||
| 16 | #include <linux/hardirq.h> | 16 | #include <linux/hardirq.h> |
| 17 | #include <linux/thread_info.h> | 17 | #include <linux/thread_info.h> |
| 18 | #include <linux/kbuild.h> | 18 | #include <linux/kbuild.h> |
| 19 | #include <asm/cpuinfo.h> | ||
| 19 | 20 | ||
| 20 | int main(int argc, char *argv[]) | 21 | int main(int argc, char *argv[]) |
| 21 | { | 22 | { |
diff --git a/arch/microblaze/kernel/cpu/cache.c b/arch/microblaze/kernel/cpu/cache.c index f04d8a86dead..21c3a92394de 100644 --- a/arch/microblaze/kernel/cpu/cache.c +++ b/arch/microblaze/kernel/cpu/cache.c | |||
| @@ -96,13 +96,16 @@ static inline void __disable_dcache_nomsr(void) | |||
| 96 | } | 96 | } |
| 97 | 97 | ||
| 98 | 98 | ||
| 99 | /* Helper macro for computing the limits of cache range loops */ | 99 | /* Helper macro for computing the limits of cache range loops |
| 100 | * | ||
| 101 | * End address can be unaligned which is OK for C implementation. | ||
| 102 | * ASM implementation align it in ASM macros | ||
| 103 | */ | ||
| 100 | #define CACHE_LOOP_LIMITS(start, end, cache_line_length, cache_size) \ | 104 | #define CACHE_LOOP_LIMITS(start, end, cache_line_length, cache_size) \ |
| 101 | do { \ | 105 | do { \ |
| 102 | int align = ~(cache_line_length - 1); \ | 106 | int align = ~(cache_line_length - 1); \ |
| 103 | end = min(start + cache_size, end); \ | 107 | end = min(start + cache_size, end); \ |
| 104 | start &= align; \ | 108 | start &= align; \ |
| 105 | end = ((end & align) + cache_line_length); \ | ||
| 106 | } while (0); | 109 | } while (0); |
| 107 | 110 | ||
| 108 | /* | 111 | /* |
| @@ -111,9 +114,9 @@ do { \ | |||
| 111 | */ | 114 | */ |
| 112 | #define CACHE_ALL_LOOP(cache_size, line_length, op) \ | 115 | #define CACHE_ALL_LOOP(cache_size, line_length, op) \ |
| 113 | do { \ | 116 | do { \ |
| 114 | unsigned int len = cache_size; \ | 117 | unsigned int len = cache_size - line_length; \ |
| 115 | int step = -line_length; \ | 118 | int step = -line_length; \ |
| 116 | BUG_ON(step >= 0); \ | 119 | WARN_ON(step >= 0); \ |
| 117 | \ | 120 | \ |
| 118 | __asm__ __volatile__ (" 1: " #op " %0, r0; \ | 121 | __asm__ __volatile__ (" 1: " #op " %0, r0; \ |
| 119 | bgtid %0, 1b; \ | 122 | bgtid %0, 1b; \ |
| @@ -122,26 +125,21 @@ do { \ | |||
| 122 | : "memory"); \ | 125 | : "memory"); \ |
| 123 | } while (0); | 126 | } while (0); |
| 124 | 127 | ||
| 125 | 128 | /* Used for wdc.flush/clear which can use rB for offset which is not possible | |
| 126 | #define CACHE_ALL_LOOP2(cache_size, line_length, op) \ | 129 | * to use for simple wdc or wic. |
| 127 | do { \ | 130 | * |
| 128 | unsigned int len = cache_size; \ | 131 | * start address is cache aligned |
| 129 | int step = -line_length; \ | 132 | * end address is not aligned, if end is aligned then I have to substract |
| 130 | BUG_ON(step >= 0); \ | 133 | * cacheline length because I can't flush/invalidate the next cacheline. |
| 131 | \ | 134 | * If is not, I align it because I will flush/invalidate whole line. |
| 132 | __asm__ __volatile__ (" 1: " #op " r0, %0; \ | 135 | */ |
| 133 | bgtid %0, 1b; \ | ||
| 134 | addk %0, %0, %1; \ | ||
| 135 | " : : "r" (len), "r" (step) \ | ||
| 136 | : "memory"); \ | ||
| 137 | } while (0); | ||
| 138 | |||
| 139 | /* for wdc.flush/clear */ | ||
| 140 | #define CACHE_RANGE_LOOP_2(start, end, line_length, op) \ | 136 | #define CACHE_RANGE_LOOP_2(start, end, line_length, op) \ |
| 141 | do { \ | 137 | do { \ |
| 142 | int step = -line_length; \ | 138 | int step = -line_length; \ |
| 139 | int align = ~(line_length - 1); \ | ||
| 140 | end = ((end & align) == end) ? end - line_length : end & align; \ | ||
| 143 | int count = end - start; \ | 141 | int count = end - start; \ |
| 144 | BUG_ON(count <= 0); \ | 142 | WARN_ON(count < 0); \ |
| 145 | \ | 143 | \ |
| 146 | __asm__ __volatile__ (" 1: " #op " %0, %1; \ | 144 | __asm__ __volatile__ (" 1: " #op " %0, %1; \ |
| 147 | bgtid %1, 1b; \ | 145 | bgtid %1, 1b; \ |
| @@ -154,7 +152,9 @@ do { \ | |||
| 154 | #define CACHE_RANGE_LOOP_1(start, end, line_length, op) \ | 152 | #define CACHE_RANGE_LOOP_1(start, end, line_length, op) \ |
| 155 | do { \ | 153 | do { \ |
| 156 | int volatile temp; \ | 154 | int volatile temp; \ |
| 157 | BUG_ON(end - start <= 0); \ | 155 | int align = ~(line_length - 1); \ |
| 156 | end = ((end & align) == end) ? end - line_length : end & align; \ | ||
| 157 | WARN_ON(end - start < 0); \ | ||
| 158 | \ | 158 | \ |
| 159 | __asm__ __volatile__ (" 1: " #op " %1, r0; \ | 159 | __asm__ __volatile__ (" 1: " #op " %1, r0; \ |
| 160 | cmpu %0, %1, %2; \ | 160 | cmpu %0, %1, %2; \ |
| @@ -360,8 +360,12 @@ static void __invalidate_dcache_all_noirq_wt(void) | |||
| 360 | #endif | 360 | #endif |
| 361 | } | 361 | } |
| 362 | 362 | ||
| 363 | /* FIXME this is weird - should be only wdc but not work | 363 | /* FIXME It is blindly invalidation as is expected |
| 364 | * MS: I am getting bus errors and other weird things */ | 364 | * but can't be called on noMMU in microblaze_cache_init below |
| 365 | * | ||
| 366 | * MS: noMMU kernel won't boot if simple wdc is used | ||
| 367 | * The reason should be that there are discared data which kernel needs | ||
| 368 | */ | ||
| 365 | static void __invalidate_dcache_all_wb(void) | 369 | static void __invalidate_dcache_all_wb(void) |
| 366 | { | 370 | { |
| 367 | #ifndef ASM_LOOP | 371 | #ifndef ASM_LOOP |
| @@ -369,12 +373,12 @@ static void __invalidate_dcache_all_wb(void) | |||
| 369 | #endif | 373 | #endif |
| 370 | pr_debug("%s\n", __func__); | 374 | pr_debug("%s\n", __func__); |
| 371 | #ifdef ASM_LOOP | 375 | #ifdef ASM_LOOP |
| 372 | CACHE_ALL_LOOP2(cpuinfo.dcache_size, cpuinfo.dcache_line_length, | 376 | CACHE_ALL_LOOP(cpuinfo.dcache_size, cpuinfo.dcache_line_length, |
| 373 | wdc.clear) | 377 | wdc) |
| 374 | #else | 378 | #else |
| 375 | for (i = 0; i < cpuinfo.dcache_size; | 379 | for (i = 0; i < cpuinfo.dcache_size; |
| 376 | i += cpuinfo.dcache_line_length) | 380 | i += cpuinfo.dcache_line_length) |
| 377 | __asm__ __volatile__ ("wdc.clear %0, r0;" \ | 381 | __asm__ __volatile__ ("wdc %0, r0;" \ |
| 378 | : : "r" (i)); | 382 | : : "r" (i)); |
| 379 | #endif | 383 | #endif |
| 380 | } | 384 | } |
| @@ -393,7 +397,7 @@ static void __invalidate_dcache_range_wb(unsigned long start, | |||
| 393 | #ifdef ASM_LOOP | 397 | #ifdef ASM_LOOP |
| 394 | CACHE_RANGE_LOOP_2(start, end, cpuinfo.dcache_line_length, wdc.clear); | 398 | CACHE_RANGE_LOOP_2(start, end, cpuinfo.dcache_line_length, wdc.clear); |
| 395 | #else | 399 | #else |
| 396 | for (i = start; i < end; i += cpuinfo.icache_line_length) | 400 | for (i = start; i < end; i += cpuinfo.dcache_line_length) |
| 397 | __asm__ __volatile__ ("wdc.clear %0, r0;" \ | 401 | __asm__ __volatile__ ("wdc.clear %0, r0;" \ |
| 398 | : : "r" (i)); | 402 | : : "r" (i)); |
| 399 | #endif | 403 | #endif |
| @@ -413,7 +417,7 @@ static void __invalidate_dcache_range_nomsr_wt(unsigned long start, | |||
| 413 | #ifdef ASM_LOOP | 417 | #ifdef ASM_LOOP |
| 414 | CACHE_RANGE_LOOP_1(start, end, cpuinfo.dcache_line_length, wdc); | 418 | CACHE_RANGE_LOOP_1(start, end, cpuinfo.dcache_line_length, wdc); |
| 415 | #else | 419 | #else |
| 416 | for (i = start; i < end; i += cpuinfo.icache_line_length) | 420 | for (i = start; i < end; i += cpuinfo.dcache_line_length) |
| 417 | __asm__ __volatile__ ("wdc %0, r0;" \ | 421 | __asm__ __volatile__ ("wdc %0, r0;" \ |
| 418 | : : "r" (i)); | 422 | : : "r" (i)); |
| 419 | #endif | 423 | #endif |
| @@ -437,7 +441,7 @@ static void __invalidate_dcache_range_msr_irq_wt(unsigned long start, | |||
| 437 | #ifdef ASM_LOOP | 441 | #ifdef ASM_LOOP |
| 438 | CACHE_RANGE_LOOP_1(start, end, cpuinfo.dcache_line_length, wdc); | 442 | CACHE_RANGE_LOOP_1(start, end, cpuinfo.dcache_line_length, wdc); |
| 439 | #else | 443 | #else |
| 440 | for (i = start; i < end; i += cpuinfo.icache_line_length) | 444 | for (i = start; i < end; i += cpuinfo.dcache_line_length) |
| 441 | __asm__ __volatile__ ("wdc %0, r0;" \ | 445 | __asm__ __volatile__ ("wdc %0, r0;" \ |
| 442 | : : "r" (i)); | 446 | : : "r" (i)); |
| 443 | #endif | 447 | #endif |
| @@ -465,7 +469,7 @@ static void __invalidate_dcache_range_nomsr_irq(unsigned long start, | |||
| 465 | #ifdef ASM_LOOP | 469 | #ifdef ASM_LOOP |
| 466 | CACHE_RANGE_LOOP_1(start, end, cpuinfo.dcache_line_length, wdc); | 470 | CACHE_RANGE_LOOP_1(start, end, cpuinfo.dcache_line_length, wdc); |
| 467 | #else | 471 | #else |
| 468 | for (i = start; i < end; i += cpuinfo.icache_line_length) | 472 | for (i = start; i < end; i += cpuinfo.dcache_line_length) |
| 469 | __asm__ __volatile__ ("wdc %0, r0;" \ | 473 | __asm__ __volatile__ ("wdc %0, r0;" \ |
| 470 | : : "r" (i)); | 474 | : : "r" (i)); |
| 471 | #endif | 475 | #endif |
| @@ -504,7 +508,7 @@ static void __flush_dcache_range_wb(unsigned long start, unsigned long end) | |||
| 504 | #ifdef ASM_LOOP | 508 | #ifdef ASM_LOOP |
| 505 | CACHE_RANGE_LOOP_2(start, end, cpuinfo.dcache_line_length, wdc.flush); | 509 | CACHE_RANGE_LOOP_2(start, end, cpuinfo.dcache_line_length, wdc.flush); |
| 506 | #else | 510 | #else |
| 507 | for (i = start; i < end; i += cpuinfo.icache_line_length) | 511 | for (i = start; i < end; i += cpuinfo.dcache_line_length) |
| 508 | __asm__ __volatile__ ("wdc.flush %0, r0;" \ | 512 | __asm__ __volatile__ ("wdc.flush %0, r0;" \ |
| 509 | : : "r" (i)); | 513 | : : "r" (i)); |
| 510 | #endif | 514 | #endif |
| @@ -650,7 +654,11 @@ void microblaze_cache_init(void) | |||
| 650 | } | 654 | } |
| 651 | } | 655 | } |
| 652 | } | 656 | } |
| 653 | invalidate_dcache(); | 657 | /* FIXME Invalidation is done in U-BOOT |
| 658 | * WT cache: Data is already written to main memory | ||
| 659 | * WB cache: Discard data on noMMU which caused that kernel doesn't boot | ||
| 660 | */ | ||
| 661 | /* invalidate_dcache(); */ | ||
| 654 | enable_dcache(); | 662 | enable_dcache(); |
| 655 | 663 | ||
| 656 | invalidate_icache(); | 664 | invalidate_icache(); |
diff --git a/arch/microblaze/kernel/cpu/mb.c b/arch/microblaze/kernel/cpu/mb.c index 0c912b2a8e03..4216eb1eaa32 100644 --- a/arch/microblaze/kernel/cpu/mb.c +++ b/arch/microblaze/kernel/cpu/mb.c | |||
| @@ -98,15 +98,17 @@ static int show_cpuinfo(struct seq_file *m, void *v) | |||
| 98 | 98 | ||
| 99 | if (cpuinfo.use_icache) | 99 | if (cpuinfo.use_icache) |
| 100 | count += seq_printf(m, | 100 | count += seq_printf(m, |
| 101 | "Icache:\t\t%ukB\n", | 101 | "Icache:\t\t%ukB\tline length:\t%dB\n", |
| 102 | cpuinfo.icache_size >> 10); | 102 | cpuinfo.icache_size >> 10, |
| 103 | cpuinfo.icache_line_length); | ||
| 103 | else | 104 | else |
| 104 | count += seq_printf(m, "Icache:\t\tno\n"); | 105 | count += seq_printf(m, "Icache:\t\tno\n"); |
| 105 | 106 | ||
| 106 | if (cpuinfo.use_dcache) { | 107 | if (cpuinfo.use_dcache) { |
| 107 | count += seq_printf(m, | 108 | count += seq_printf(m, |
| 108 | "Dcache:\t\t%ukB\n", | 109 | "Dcache:\t\t%ukB\tline length:\t%dB\n", |
| 109 | cpuinfo.dcache_size >> 10); | 110 | cpuinfo.dcache_size >> 10, |
| 111 | cpuinfo.dcache_line_length); | ||
| 110 | if (cpuinfo.dcache_wb) | 112 | if (cpuinfo.dcache_wb) |
| 111 | count += seq_printf(m, "\t\twrite-back\n"); | 113 | count += seq_printf(m, "\t\twrite-back\n"); |
| 112 | else | 114 | else |
diff --git a/arch/microblaze/kernel/dma.c b/arch/microblaze/kernel/dma.c index ce72dd4967cf..9dcd90b5df55 100644 --- a/arch/microblaze/kernel/dma.c +++ b/arch/microblaze/kernel/dma.c | |||
| @@ -74,7 +74,7 @@ static void dma_direct_free_coherent(struct device *dev, size_t size, | |||
| 74 | void *vaddr, dma_addr_t dma_handle) | 74 | void *vaddr, dma_addr_t dma_handle) |
| 75 | { | 75 | { |
| 76 | #ifdef NOT_COHERENT_CACHE | 76 | #ifdef NOT_COHERENT_CACHE |
| 77 | consistent_free(vaddr); | 77 | consistent_free(size, vaddr); |
| 78 | #else | 78 | #else |
| 79 | free_pages((unsigned long)vaddr, get_order(size)); | 79 | free_pages((unsigned long)vaddr, get_order(size)); |
| 80 | #endif | 80 | #endif |
diff --git a/arch/microblaze/kernel/exceptions.c b/arch/microblaze/kernel/exceptions.c index d9f70f83097f..02cbdfe5aa8d 100644 --- a/arch/microblaze/kernel/exceptions.c +++ b/arch/microblaze/kernel/exceptions.c | |||
| @@ -121,7 +121,7 @@ asmlinkage void full_exception(struct pt_regs *regs, unsigned int type, | |||
| 121 | } | 121 | } |
| 122 | printk(KERN_WARNING "Divide by zero exception " \ | 122 | printk(KERN_WARNING "Divide by zero exception " \ |
| 123 | "in kernel mode.\n"); | 123 | "in kernel mode.\n"); |
| 124 | die("Divide by exception", regs, SIGBUS); | 124 | die("Divide by zero exception", regs, SIGBUS); |
| 125 | break; | 125 | break; |
| 126 | case MICROBLAZE_FPU_EXCEPTION: | 126 | case MICROBLAZE_FPU_EXCEPTION: |
| 127 | pr_debug(KERN_WARNING "FPU exception\n"); | 127 | pr_debug(KERN_WARNING "FPU exception\n"); |
diff --git a/arch/microblaze/kernel/head.S b/arch/microblaze/kernel/head.S index da6a5f5dc766..1bf739888260 100644 --- a/arch/microblaze/kernel/head.S +++ b/arch/microblaze/kernel/head.S | |||
| @@ -28,6 +28,7 @@ | |||
| 28 | * for more details. | 28 | * for more details. |
| 29 | */ | 29 | */ |
| 30 | 30 | ||
| 31 | #include <linux/init.h> | ||
| 31 | #include <linux/linkage.h> | 32 | #include <linux/linkage.h> |
| 32 | #include <asm/thread_info.h> | 33 | #include <asm/thread_info.h> |
| 33 | #include <asm/page.h> | 34 | #include <asm/page.h> |
| @@ -49,7 +50,7 @@ swapper_pg_dir: | |||
| 49 | 50 | ||
| 50 | #endif /* CONFIG_MMU */ | 51 | #endif /* CONFIG_MMU */ |
| 51 | 52 | ||
| 52 | .text | 53 | __HEAD |
| 53 | ENTRY(_start) | 54 | ENTRY(_start) |
| 54 | #if CONFIG_KERNEL_BASE_ADDR == 0 | 55 | #if CONFIG_KERNEL_BASE_ADDR == 0 |
| 55 | brai TOPHYS(real_start) | 56 | brai TOPHYS(real_start) |
diff --git a/arch/microblaze/kernel/irq.c b/arch/microblaze/kernel/irq.c index 6f39e2c001f3..8f120aca123d 100644 --- a/arch/microblaze/kernel/irq.c +++ b/arch/microblaze/kernel/irq.c | |||
| @@ -9,6 +9,7 @@ | |||
| 9 | */ | 9 | */ |
| 10 | 10 | ||
| 11 | #include <linux/init.h> | 11 | #include <linux/init.h> |
| 12 | #include <linux/ftrace.h> | ||
| 12 | #include <linux/kernel.h> | 13 | #include <linux/kernel.h> |
| 13 | #include <linux/hardirq.h> | 14 | #include <linux/hardirq.h> |
| 14 | #include <linux/interrupt.h> | 15 | #include <linux/interrupt.h> |
| @@ -32,7 +33,7 @@ EXPORT_SYMBOL_GPL(irq_of_parse_and_map); | |||
| 32 | 33 | ||
| 33 | static u32 concurrent_irq; | 34 | static u32 concurrent_irq; |
| 34 | 35 | ||
| 35 | void do_IRQ(struct pt_regs *regs) | 36 | void __irq_entry do_IRQ(struct pt_regs *regs) |
| 36 | { | 37 | { |
| 37 | unsigned int irq; | 38 | unsigned int irq; |
| 38 | struct pt_regs *old_regs = set_irq_regs(regs); | 39 | struct pt_regs *old_regs = set_irq_regs(regs); |
diff --git a/arch/microblaze/kernel/misc.S b/arch/microblaze/kernel/misc.S index 7cf86498326c..0fb5fc6c1fc2 100644 --- a/arch/microblaze/kernel/misc.S +++ b/arch/microblaze/kernel/misc.S | |||
| @@ -93,39 +93,3 @@ early_console_reg_tlb_alloc: | |||
| 93 | nop | 93 | nop |
| 94 | 94 | ||
| 95 | .size early_console_reg_tlb_alloc, . - early_console_reg_tlb_alloc | 95 | .size early_console_reg_tlb_alloc, . - early_console_reg_tlb_alloc |
| 96 | |||
| 97 | /* | ||
| 98 | * Copy a whole page (4096 bytes). | ||
| 99 | */ | ||
| 100 | #define COPY_16_BYTES \ | ||
| 101 | lwi r7, r6, 0; \ | ||
| 102 | lwi r8, r6, 4; \ | ||
| 103 | lwi r9, r6, 8; \ | ||
| 104 | lwi r10, r6, 12; \ | ||
| 105 | swi r7, r5, 0; \ | ||
| 106 | swi r8, r5, 4; \ | ||
| 107 | swi r9, r5, 8; \ | ||
| 108 | swi r10, r5, 12 | ||
| 109 | |||
| 110 | |||
| 111 | /* FIXME DCACHE_LINE_BYTES (CONFIG_XILINX_MICROBLAZE0_DCACHE_LINE_LEN * 4)*/ | ||
| 112 | #define DCACHE_LINE_BYTES (4 * 4) | ||
| 113 | |||
| 114 | .globl copy_page; | ||
| 115 | .type copy_page, @function | ||
| 116 | .align 4; | ||
| 117 | copy_page: | ||
| 118 | ori r11, r0, (PAGE_SIZE/DCACHE_LINE_BYTES) - 1 | ||
| 119 | _copy_page_loop: | ||
| 120 | COPY_16_BYTES | ||
| 121 | #if DCACHE_LINE_BYTES >= 32 | ||
| 122 | COPY_16_BYTES | ||
| 123 | #endif | ||
| 124 | addik r6, r6, DCACHE_LINE_BYTES | ||
| 125 | addik r5, r5, DCACHE_LINE_BYTES | ||
| 126 | bneid r11, _copy_page_loop | ||
| 127 | addik r11, r11, -1 | ||
| 128 | rtsd r15, 8 | ||
| 129 | nop | ||
| 130 | |||
| 131 | .size copy_page, . - copy_page | ||
diff --git a/arch/microblaze/kernel/traps.c b/arch/microblaze/kernel/traps.c index 5e4570ef515c..75e49202a5ed 100644 --- a/arch/microblaze/kernel/traps.c +++ b/arch/microblaze/kernel/traps.c | |||
| @@ -95,37 +95,3 @@ void dump_stack(void) | |||
| 95 | show_stack(NULL, NULL); | 95 | show_stack(NULL, NULL); |
| 96 | } | 96 | } |
| 97 | EXPORT_SYMBOL(dump_stack); | 97 | EXPORT_SYMBOL(dump_stack); |
| 98 | |||
| 99 | #ifdef CONFIG_MMU | ||
| 100 | void __bug(const char *file, int line, void *data) | ||
| 101 | { | ||
| 102 | if (data) | ||
| 103 | printk(KERN_CRIT "kernel BUG at %s:%d (data = %p)!\n", | ||
| 104 | file, line, data); | ||
| 105 | else | ||
| 106 | printk(KERN_CRIT "kernel BUG at %s:%d!\n", file, line); | ||
| 107 | |||
| 108 | machine_halt(); | ||
| 109 | } | ||
| 110 | |||
| 111 | int bad_trap(int trap_num, struct pt_regs *regs) | ||
| 112 | { | ||
| 113 | printk(KERN_CRIT | ||
| 114 | "unimplemented trap %d called at 0x%08lx, pid %d!\n", | ||
| 115 | trap_num, regs->pc, current->pid); | ||
| 116 | return -ENOSYS; | ||
| 117 | } | ||
| 118 | |||
| 119 | int debug_trap(struct pt_regs *regs) | ||
| 120 | { | ||
| 121 | int i; | ||
| 122 | printk(KERN_CRIT "debug trap\n"); | ||
| 123 | for (i = 0; i < 32; i++) { | ||
| 124 | /* printk("r%i:%08X\t",i,regs->gpr[i]); */ | ||
| 125 | if ((i % 4) == 3) | ||
| 126 | printk(KERN_CRIT "\n"); | ||
| 127 | } | ||
| 128 | printk(KERN_CRIT "pc:%08lX\tmsr:%08lX\n", regs->pc, regs->msr); | ||
| 129 | return -ENOSYS; | ||
| 130 | } | ||
| 131 | #endif | ||
diff --git a/arch/microblaze/kernel/vmlinux.lds.S b/arch/microblaze/kernel/vmlinux.lds.S index 5ef619aad634..db72d7124602 100644 --- a/arch/microblaze/kernel/vmlinux.lds.S +++ b/arch/microblaze/kernel/vmlinux.lds.S | |||
| @@ -24,7 +24,8 @@ SECTIONS { | |||
| 24 | .text : AT(ADDR(.text) - LOAD_OFFSET) { | 24 | .text : AT(ADDR(.text) - LOAD_OFFSET) { |
| 25 | _text = . ; | 25 | _text = . ; |
| 26 | _stext = . ; | 26 | _stext = . ; |
| 27 | *(.text .text.*) | 27 | HEAD_TEXT |
| 28 | TEXT_TEXT | ||
| 28 | *(.fixup) | 29 | *(.fixup) |
| 29 | EXIT_TEXT | 30 | EXIT_TEXT |
| 30 | EXIT_CALL | 31 | EXIT_CALL |
diff --git a/arch/microblaze/mm/consistent.c b/arch/microblaze/mm/consistent.c index f956e24fe49c..5a59dad62bd2 100644 --- a/arch/microblaze/mm/consistent.c +++ b/arch/microblaze/mm/consistent.c | |||
| @@ -42,11 +42,12 @@ | |||
| 42 | #include <linux/uaccess.h> | 42 | #include <linux/uaccess.h> |
| 43 | #include <asm/pgtable.h> | 43 | #include <asm/pgtable.h> |
| 44 | #include <asm/cpuinfo.h> | 44 | #include <asm/cpuinfo.h> |
| 45 | #include <asm/tlbflush.h> | ||
| 45 | 46 | ||
| 46 | #ifndef CONFIG_MMU | 47 | #ifndef CONFIG_MMU |
| 47 | |||
| 48 | /* I have to use dcache values because I can't relate on ram size */ | 48 | /* I have to use dcache values because I can't relate on ram size */ |
| 49 | #define UNCACHED_SHADOW_MASK (cpuinfo.dcache_high - cpuinfo.dcache_base + 1) | 49 | # define UNCACHED_SHADOW_MASK (cpuinfo.dcache_high - cpuinfo.dcache_base + 1) |
| 50 | #endif | ||
| 50 | 51 | ||
| 51 | /* | 52 | /* |
| 52 | * Consistent memory allocators. Used for DMA devices that want to | 53 | * Consistent memory allocators. Used for DMA devices that want to |
| @@ -60,71 +61,16 @@ | |||
| 60 | */ | 61 | */ |
| 61 | void *consistent_alloc(int gfp, size_t size, dma_addr_t *dma_handle) | 62 | void *consistent_alloc(int gfp, size_t size, dma_addr_t *dma_handle) |
| 62 | { | 63 | { |
| 63 | struct page *page, *end, *free; | 64 | unsigned long order, vaddr; |
| 64 | unsigned long order; | 65 | void *ret; |
| 65 | void *ret, *virt; | 66 | unsigned int i, err = 0; |
| 66 | 67 | struct page *page, *end; | |
| 67 | if (in_interrupt()) | ||
| 68 | BUG(); | ||
| 69 | |||
| 70 | size = PAGE_ALIGN(size); | ||
| 71 | order = get_order(size); | ||
| 72 | |||
| 73 | page = alloc_pages(gfp, order); | ||
| 74 | if (!page) | ||
| 75 | goto no_page; | ||
| 76 | |||
| 77 | /* We could do with a page_to_phys and page_to_bus here. */ | ||
| 78 | virt = page_address(page); | ||
| 79 | ret = ioremap(virt_to_phys(virt), size); | ||
| 80 | if (!ret) | ||
| 81 | goto no_remap; | ||
| 82 | |||
| 83 | /* | ||
| 84 | * Here's the magic! Note if the uncached shadow is not implemented, | ||
| 85 | * it's up to the calling code to also test that condition and make | ||
| 86 | * other arranegments, such as manually flushing the cache and so on. | ||
| 87 | */ | ||
| 88 | #ifdef CONFIG_XILINX_UNCACHED_SHADOW | ||
| 89 | ret = (void *)((unsigned) ret | UNCACHED_SHADOW_MASK); | ||
| 90 | #endif | ||
| 91 | /* dma_handle is same as physical (shadowed) address */ | ||
| 92 | *dma_handle = (dma_addr_t)ret; | ||
| 93 | |||
| 94 | /* | ||
| 95 | * free wasted pages. We skip the first page since we know | ||
| 96 | * that it will have count = 1 and won't require freeing. | ||
| 97 | * We also mark the pages in use as reserved so that | ||
| 98 | * remap_page_range works. | ||
| 99 | */ | ||
| 100 | page = virt_to_page(virt); | ||
| 101 | free = page + (size >> PAGE_SHIFT); | ||
| 102 | end = page + (1 << order); | ||
| 103 | |||
| 104 | for (; page < end; page++) { | ||
| 105 | init_page_count(page); | ||
| 106 | if (page >= free) | ||
| 107 | __free_page(page); | ||
| 108 | else | ||
| 109 | SetPageReserved(page); | ||
| 110 | } | ||
| 111 | |||
| 112 | return ret; | ||
| 113 | no_remap: | ||
| 114 | __free_pages(page, order); | ||
| 115 | no_page: | ||
| 116 | return NULL; | ||
| 117 | } | ||
| 118 | |||
| 119 | #else | ||
| 120 | 68 | ||
| 121 | void *consistent_alloc(int gfp, size_t size, dma_addr_t *dma_handle) | 69 | #ifdef CONFIG_MMU |
| 122 | { | ||
| 123 | int order, err, i; | ||
| 124 | unsigned long page, va, flags; | ||
| 125 | phys_addr_t pa; | 70 | phys_addr_t pa; |
| 126 | struct vm_struct *area; | 71 | struct vm_struct *area; |
| 127 | void *ret; | 72 | unsigned long va; |
| 73 | #endif | ||
| 128 | 74 | ||
| 129 | if (in_interrupt()) | 75 | if (in_interrupt()) |
| 130 | BUG(); | 76 | BUG(); |
| @@ -133,71 +79,133 @@ void *consistent_alloc(int gfp, size_t size, dma_addr_t *dma_handle) | |||
| 133 | size = PAGE_ALIGN(size); | 79 | size = PAGE_ALIGN(size); |
| 134 | order = get_order(size); | 80 | order = get_order(size); |
| 135 | 81 | ||
| 136 | page = __get_free_pages(gfp, order); | 82 | vaddr = __get_free_pages(gfp, order); |
| 137 | if (!page) { | 83 | if (!vaddr) |
| 138 | BUG(); | ||
| 139 | return NULL; | 84 | return NULL; |
| 140 | } | ||
| 141 | 85 | ||
| 142 | /* | 86 | /* |
| 143 | * we need to ensure that there are no cachelines in use, | 87 | * we need to ensure that there are no cachelines in use, |
| 144 | * or worse dirty in this area. | 88 | * or worse dirty in this area. |
| 145 | */ | 89 | */ |
| 146 | flush_dcache_range(virt_to_phys(page), virt_to_phys(page) + size); | 90 | flush_dcache_range(virt_to_phys((void *)vaddr), |
| 91 | virt_to_phys((void *)vaddr) + size); | ||
| 147 | 92 | ||
| 93 | #ifndef CONFIG_MMU | ||
| 94 | ret = (void *)vaddr; | ||
| 95 | /* | ||
| 96 | * Here's the magic! Note if the uncached shadow is not implemented, | ||
| 97 | * it's up to the calling code to also test that condition and make | ||
| 98 | * other arranegments, such as manually flushing the cache and so on. | ||
| 99 | */ | ||
| 100 | # ifdef CONFIG_XILINX_UNCACHED_SHADOW | ||
| 101 | ret = (void *)((unsigned) ret | UNCACHED_SHADOW_MASK); | ||
| 102 | # endif | ||
| 103 | if ((unsigned int)ret > cpuinfo.dcache_base && | ||
| 104 | (unsigned int)ret < cpuinfo.dcache_high) | ||
| 105 | printk(KERN_WARNING | ||
| 106 | "ERROR: Your cache coherent area is CACHED!!!\n"); | ||
| 107 | |||
| 108 | /* dma_handle is same as physical (shadowed) address */ | ||
| 109 | *dma_handle = (dma_addr_t)ret; | ||
| 110 | #else | ||
| 148 | /* Allocate some common virtual space to map the new pages. */ | 111 | /* Allocate some common virtual space to map the new pages. */ |
| 149 | area = get_vm_area(size, VM_ALLOC); | 112 | area = get_vm_area(size, VM_ALLOC); |
| 150 | if (area == NULL) { | 113 | if (!area) { |
| 151 | free_pages(page, order); | 114 | free_pages(vaddr, order); |
| 152 | return NULL; | 115 | return NULL; |
| 153 | } | 116 | } |
| 154 | va = (unsigned long) area->addr; | 117 | va = (unsigned long) area->addr; |
| 155 | ret = (void *)va; | 118 | ret = (void *)va; |
| 156 | 119 | ||
| 157 | /* This gives us the real physical address of the first page. */ | 120 | /* This gives us the real physical address of the first page. */ |
| 158 | *dma_handle = pa = virt_to_bus((void *)page); | 121 | *dma_handle = pa = virt_to_bus((void *)vaddr); |
| 159 | 122 | #endif | |
| 160 | /* MS: This is the whole magic - use cache inhibit pages */ | ||
| 161 | flags = _PAGE_KERNEL | _PAGE_NO_CACHE; | ||
| 162 | 123 | ||
| 163 | /* | 124 | /* |
| 164 | * Set refcount=1 on all pages in an order>0 | 125 | * free wasted pages. We skip the first page since we know |
| 165 | * allocation so that vfree() will actually | 126 | * that it will have count = 1 and won't require freeing. |
| 166 | * free all pages that were allocated. | 127 | * We also mark the pages in use as reserved so that |
| 128 | * remap_page_range works. | ||
| 167 | */ | 129 | */ |
| 168 | if (order > 0) { | 130 | page = virt_to_page(vaddr); |
| 169 | struct page *rpage = virt_to_page(page); | 131 | end = page + (1 << order); |
| 170 | for (i = 1; i < (1 << order); i++) | 132 | |
| 171 | init_page_count(rpage+i); | 133 | split_page(page, order); |
| 134 | |||
| 135 | for (i = 0; i < size && err == 0; i += PAGE_SIZE) { | ||
| 136 | #ifdef CONFIG_MMU | ||
| 137 | /* MS: This is the whole magic - use cache inhibit pages */ | ||
| 138 | err = map_page(va + i, pa + i, _PAGE_KERNEL | _PAGE_NO_CACHE); | ||
| 139 | #endif | ||
| 140 | |||
| 141 | SetPageReserved(page); | ||
| 142 | page++; | ||
| 172 | } | 143 | } |
| 173 | 144 | ||
| 174 | err = 0; | 145 | /* Free the otherwise unused pages. */ |
| 175 | for (i = 0; i < size && err == 0; i += PAGE_SIZE) | 146 | while (page < end) { |
| 176 | err = map_page(va+i, pa+i, flags); | 147 | __free_page(page); |
| 148 | page++; | ||
| 149 | } | ||
| 177 | 150 | ||
| 178 | if (err) { | 151 | if (err) { |
| 179 | vfree((void *)va); | 152 | free_pages(vaddr, order); |
| 180 | return NULL; | 153 | return NULL; |
| 181 | } | 154 | } |
| 182 | 155 | ||
| 183 | return ret; | 156 | return ret; |
| 184 | } | 157 | } |
| 185 | #endif /* CONFIG_MMU */ | ||
| 186 | EXPORT_SYMBOL(consistent_alloc); | 158 | EXPORT_SYMBOL(consistent_alloc); |
| 187 | 159 | ||
| 188 | /* | 160 | /* |
| 189 | * free page(s) as defined by the above mapping. | 161 | * free page(s) as defined by the above mapping. |
| 190 | */ | 162 | */ |
| 191 | void consistent_free(void *vaddr) | 163 | void consistent_free(size_t size, void *vaddr) |
| 192 | { | 164 | { |
| 165 | struct page *page; | ||
| 166 | |||
| 193 | if (in_interrupt()) | 167 | if (in_interrupt()) |
| 194 | BUG(); | 168 | BUG(); |
| 195 | 169 | ||
| 170 | size = PAGE_ALIGN(size); | ||
| 171 | |||
| 172 | #ifndef CONFIG_MMU | ||
| 196 | /* Clear SHADOW_MASK bit in address, and free as per usual */ | 173 | /* Clear SHADOW_MASK bit in address, and free as per usual */ |
| 197 | #ifdef CONFIG_XILINX_UNCACHED_SHADOW | 174 | # ifdef CONFIG_XILINX_UNCACHED_SHADOW |
| 198 | vaddr = (void *)((unsigned)vaddr & ~UNCACHED_SHADOW_MASK); | 175 | vaddr = (void *)((unsigned)vaddr & ~UNCACHED_SHADOW_MASK); |
| 176 | # endif | ||
| 177 | page = virt_to_page(vaddr); | ||
| 178 | |||
| 179 | do { | ||
| 180 | ClearPageReserved(page); | ||
| 181 | __free_page(page); | ||
| 182 | page++; | ||
| 183 | } while (size -= PAGE_SIZE); | ||
| 184 | #else | ||
| 185 | do { | ||
| 186 | pte_t *ptep; | ||
| 187 | unsigned long pfn; | ||
| 188 | |||
| 189 | ptep = pte_offset_kernel(pmd_offset(pgd_offset_k( | ||
| 190 | (unsigned int)vaddr), | ||
| 191 | (unsigned int)vaddr), | ||
| 192 | (unsigned int)vaddr); | ||
| 193 | if (!pte_none(*ptep) && pte_present(*ptep)) { | ||
| 194 | pfn = pte_pfn(*ptep); | ||
| 195 | pte_clear(&init_mm, (unsigned int)vaddr, ptep); | ||
| 196 | if (pfn_valid(pfn)) { | ||
| 197 | page = pfn_to_page(pfn); | ||
| 198 | |||
| 199 | ClearPageReserved(page); | ||
| 200 | __free_page(page); | ||
| 201 | } | ||
| 202 | } | ||
| 203 | vaddr += PAGE_SIZE; | ||
| 204 | } while (size -= PAGE_SIZE); | ||
| 205 | |||
| 206 | /* flush tlb */ | ||
| 207 | flush_tlb_all(); | ||
| 199 | #endif | 208 | #endif |
| 200 | vfree(vaddr); | ||
| 201 | } | 209 | } |
| 202 | EXPORT_SYMBOL(consistent_free); | 210 | EXPORT_SYMBOL(consistent_free); |
| 203 | 211 | ||
| @@ -221,7 +229,7 @@ void consistent_sync(void *vaddr, size_t size, int direction) | |||
| 221 | case PCI_DMA_NONE: | 229 | case PCI_DMA_NONE: |
| 222 | BUG(); | 230 | BUG(); |
| 223 | case PCI_DMA_FROMDEVICE: /* invalidate only */ | 231 | case PCI_DMA_FROMDEVICE: /* invalidate only */ |
| 224 | flush_dcache_range(start, end); | 232 | invalidate_dcache_range(start, end); |
| 225 | break; | 233 | break; |
| 226 | case PCI_DMA_TODEVICE: /* writeback only */ | 234 | case PCI_DMA_TODEVICE: /* writeback only */ |
| 227 | flush_dcache_range(start, end); | 235 | flush_dcache_range(start, end); |
diff --git a/arch/microblaze/mm/fault.c b/arch/microblaze/mm/fault.c index 7af87f4b2c2c..bab922993185 100644 --- a/arch/microblaze/mm/fault.c +++ b/arch/microblaze/mm/fault.c | |||
| @@ -273,16 +273,11 @@ bad_area_nosemaphore: | |||
| 273 | * us unable to handle the page fault gracefully. | 273 | * us unable to handle the page fault gracefully. |
| 274 | */ | 274 | */ |
| 275 | out_of_memory: | 275 | out_of_memory: |
| 276 | if (current->pid == 1) { | ||
| 277 | yield(); | ||
| 278 | down_read(&mm->mmap_sem); | ||
| 279 | goto survive; | ||
| 280 | } | ||
| 281 | up_read(&mm->mmap_sem); | 276 | up_read(&mm->mmap_sem); |
| 282 | printk(KERN_WARNING "VM: killing process %s\n", current->comm); | 277 | if (!user_mode(regs)) |
| 283 | if (user_mode(regs)) | 278 | bad_page_fault(regs, address, SIGKILL); |
| 284 | do_exit(SIGKILL); | 279 | else |
| 285 | bad_page_fault(regs, address, SIGKILL); | 280 | pagefault_out_of_memory(); |
| 286 | return; | 281 | return; |
| 287 | 282 | ||
| 288 | do_sigbus: | 283 | do_sigbus: |
diff --git a/arch/microblaze/mm/pgtable.c b/arch/microblaze/mm/pgtable.c index d31312cde6ea..784557fb28cf 100644 --- a/arch/microblaze/mm/pgtable.c +++ b/arch/microblaze/mm/pgtable.c | |||
| @@ -161,24 +161,6 @@ int map_page(unsigned long va, phys_addr_t pa, int flags) | |||
| 161 | return err; | 161 | return err; |
| 162 | } | 162 | } |
| 163 | 163 | ||
| 164 | void __init adjust_total_lowmem(void) | ||
| 165 | { | ||
| 166 | /* TBD */ | ||
| 167 | #if 0 | ||
| 168 | unsigned long max_low_mem = MAX_LOW_MEM; | ||
| 169 | |||
| 170 | if (total_lowmem > max_low_mem) { | ||
| 171 | total_lowmem = max_low_mem; | ||
| 172 | #ifndef CONFIG_HIGHMEM | ||
| 173 | printk(KERN_INFO "Warning, memory limited to %ld Mb, use " | ||
| 174 | "CONFIG_HIGHMEM to reach %ld Mb\n", | ||
| 175 | max_low_mem >> 20, total_memory >> 20); | ||
| 176 | total_memory = total_lowmem; | ||
| 177 | #endif /* CONFIG_HIGHMEM */ | ||
| 178 | } | ||
| 179 | #endif | ||
| 180 | } | ||
| 181 | |||
| 182 | /* | 164 | /* |
| 183 | * Map in all of physical memory starting at CONFIG_KERNEL_START. | 165 | * Map in all of physical memory starting at CONFIG_KERNEL_START. |
| 184 | */ | 166 | */ |
| @@ -206,24 +188,6 @@ void __init mapin_ram(void) | |||
| 206 | /* is x a power of 2? */ | 188 | /* is x a power of 2? */ |
| 207 | #define is_power_of_2(x) ((x) != 0 && (((x) & ((x) - 1)) == 0)) | 189 | #define is_power_of_2(x) ((x) != 0 && (((x) & ((x) - 1)) == 0)) |
| 208 | 190 | ||
| 209 | /* | ||
| 210 | * Set up a mapping for a block of I/O. | ||
| 211 | * virt, phys, size must all be page-aligned. | ||
| 212 | * This should only be called before ioremap is called. | ||
| 213 | */ | ||
| 214 | void __init io_block_mapping(unsigned long virt, phys_addr_t phys, | ||
| 215 | unsigned int size, int flags) | ||
| 216 | { | ||
| 217 | int i; | ||
| 218 | |||
| 219 | if (virt > CONFIG_KERNEL_START && virt < ioremap_bot) | ||
| 220 | ioremap_bot = ioremap_base = virt; | ||
| 221 | |||
| 222 | /* Put it in the page tables. */ | ||
| 223 | for (i = 0; i < size; i += PAGE_SIZE) | ||
| 224 | map_page(virt + i, phys + i, flags); | ||
| 225 | } | ||
| 226 | |||
| 227 | /* Scan the real Linux page tables and return a PTE pointer for | 191 | /* Scan the real Linux page tables and return a PTE pointer for |
| 228 | * a virtual address in a context. | 192 | * a virtual address in a context. |
| 229 | * Returns true (1) if PTE was found, zero otherwise. The pointer to | 193 | * Returns true (1) if PTE was found, zero otherwise. The pointer to |
| @@ -274,3 +238,18 @@ unsigned long iopa(unsigned long addr) | |||
| 274 | 238 | ||
| 275 | return pa; | 239 | return pa; |
| 276 | } | 240 | } |
| 241 | |||
| 242 | __init_refok pte_t *pte_alloc_one_kernel(struct mm_struct *mm, | ||
| 243 | unsigned long address) | ||
| 244 | { | ||
| 245 | pte_t *pte; | ||
| 246 | if (mem_init_done) { | ||
| 247 | pte = (pte_t *)__get_free_page(GFP_KERNEL | | ||
| 248 | __GFP_REPEAT | __GFP_ZERO); | ||
| 249 | } else { | ||
| 250 | pte = (pte_t *)early_get_page(); | ||
| 251 | if (pte) | ||
| 252 | clear_page(pte); | ||
| 253 | } | ||
| 254 | return pte; | ||
| 255 | } | ||
diff --git a/arch/microblaze/pci/pci-common.c b/arch/microblaze/pci/pci-common.c index 740bb32ec57e..01c8c97c15b7 100644 --- a/arch/microblaze/pci/pci-common.c +++ b/arch/microblaze/pci/pci-common.c | |||
| @@ -1025,7 +1025,7 @@ static void __devinit pcibios_fixup_bridge(struct pci_bus *bus) | |||
| 1025 | 1025 | ||
| 1026 | struct pci_dev *dev = bus->self; | 1026 | struct pci_dev *dev = bus->self; |
| 1027 | 1027 | ||
| 1028 | for (i = 0; i < PCI_BUS_NUM_RESOURCES; ++i) { | 1028 | pci_bus_for_each_resource(bus, res, i) { |
| 1029 | res = bus->resource[i]; | 1029 | res = bus->resource[i]; |
| 1030 | if (!res) | 1030 | if (!res) |
| 1031 | continue; | 1031 | continue; |
| @@ -1131,21 +1131,20 @@ static int skip_isa_ioresource_align(struct pci_dev *dev) | |||
| 1131 | * but we want to try to avoid allocating at 0x2900-0x2bff | 1131 | * but we want to try to avoid allocating at 0x2900-0x2bff |
| 1132 | * which might have be mirrored at 0x0100-0x03ff.. | 1132 | * which might have be mirrored at 0x0100-0x03ff.. |
| 1133 | */ | 1133 | */ |
| 1134 | void pcibios_align_resource(void *data, struct resource *res, | 1134 | resource_size_t pcibios_align_resource(void *data, const struct resource *res, |
| 1135 | resource_size_t size, resource_size_t align) | 1135 | resource_size_t size, resource_size_t align) |
| 1136 | { | 1136 | { |
| 1137 | struct pci_dev *dev = data; | 1137 | struct pci_dev *dev = data; |
| 1138 | resource_size_t start = res->start; | ||
| 1138 | 1139 | ||
| 1139 | if (res->flags & IORESOURCE_IO) { | 1140 | if (res->flags & IORESOURCE_IO) { |
| 1140 | resource_size_t start = res->start; | ||
| 1141 | |||
| 1142 | if (skip_isa_ioresource_align(dev)) | 1141 | if (skip_isa_ioresource_align(dev)) |
| 1143 | return; | 1142 | return start; |
| 1144 | if (start & 0x300) { | 1143 | if (start & 0x300) |
| 1145 | start = (start + 0x3ff) & ~0x3ff; | 1144 | start = (start + 0x3ff) & ~0x3ff; |
| 1146 | res->start = start; | ||
| 1147 | } | ||
| 1148 | } | 1145 | } |
| 1146 | |||
| 1147 | return start; | ||
| 1149 | } | 1148 | } |
| 1150 | EXPORT_SYMBOL(pcibios_align_resource); | 1149 | EXPORT_SYMBOL(pcibios_align_resource); |
| 1151 | 1150 | ||
| @@ -1228,7 +1227,7 @@ void pcibios_allocate_bus_resources(struct pci_bus *bus) | |||
| 1228 | pr_debug("PCI: Allocating bus resources for %04x:%02x...\n", | 1227 | pr_debug("PCI: Allocating bus resources for %04x:%02x...\n", |
| 1229 | pci_domain_nr(bus), bus->number); | 1228 | pci_domain_nr(bus), bus->number); |
| 1230 | 1229 | ||
| 1231 | for (i = 0; i < PCI_BUS_NUM_RESOURCES; ++i) { | 1230 | pci_bus_for_each_resource(bus, res, i) { |
| 1232 | res = bus->resource[i]; | 1231 | res = bus->resource[i]; |
| 1233 | if (!res || !res->flags | 1232 | if (!res || !res->flags |
| 1234 | || res->start > res->end || res->parent) | 1233 | || res->start > res->end || res->parent) |
diff --git a/arch/sh/configs/rts7751r2d1_defconfig b/arch/sh/configs/rts7751r2d1_defconfig index fba1f62d56e7..dba024d72a89 100644 --- a/arch/sh/configs/rts7751r2d1_defconfig +++ b/arch/sh/configs/rts7751r2d1_defconfig | |||
| @@ -877,7 +877,7 @@ CONFIG_SERIAL_8250_RUNTIME_UARTS=4 | |||
| 877 | # | 877 | # |
| 878 | # CONFIG_SERIAL_MAX3100 is not set | 878 | # CONFIG_SERIAL_MAX3100 is not set |
| 879 | CONFIG_SERIAL_SH_SCI=y | 879 | CONFIG_SERIAL_SH_SCI=y |
| 880 | CONFIG_SERIAL_SH_SCI_NR_UARTS=1 | 880 | CONFIG_SERIAL_SH_SCI_NR_UARTS=2 |
| 881 | CONFIG_SERIAL_SH_SCI_CONSOLE=y | 881 | CONFIG_SERIAL_SH_SCI_CONSOLE=y |
| 882 | CONFIG_SERIAL_CORE=y | 882 | CONFIG_SERIAL_CORE=y |
| 883 | CONFIG_SERIAL_CORE_CONSOLE=y | 883 | CONFIG_SERIAL_CORE_CONSOLE=y |
diff --git a/arch/sh/configs/rts7751r2dplus_defconfig b/arch/sh/configs/rts7751r2dplus_defconfig index a8d538f06e67..6d511d06cbf6 100644 --- a/arch/sh/configs/rts7751r2dplus_defconfig +++ b/arch/sh/configs/rts7751r2dplus_defconfig | |||
| @@ -963,7 +963,7 @@ CONFIG_SERIAL_8250_RUNTIME_UARTS=4 | |||
| 963 | # | 963 | # |
| 964 | # CONFIG_SERIAL_MAX3100 is not set | 964 | # CONFIG_SERIAL_MAX3100 is not set |
| 965 | CONFIG_SERIAL_SH_SCI=y | 965 | CONFIG_SERIAL_SH_SCI=y |
| 966 | CONFIG_SERIAL_SH_SCI_NR_UARTS=1 | 966 | CONFIG_SERIAL_SH_SCI_NR_UARTS=2 |
| 967 | CONFIG_SERIAL_SH_SCI_CONSOLE=y | 967 | CONFIG_SERIAL_SH_SCI_CONSOLE=y |
| 968 | CONFIG_SERIAL_CORE=y | 968 | CONFIG_SERIAL_CORE=y |
| 969 | CONFIG_SERIAL_CORE_CONSOLE=y | 969 | CONFIG_SERIAL_CORE_CONSOLE=y |
diff --git a/arch/sh/drivers/pci/pci-sh7751.c b/arch/sh/drivers/pci/pci-sh7751.c index 17811e5d287b..f98141b3b7d7 100644 --- a/arch/sh/drivers/pci/pci-sh7751.c +++ b/arch/sh/drivers/pci/pci-sh7751.c | |||
| @@ -17,6 +17,7 @@ | |||
| 17 | #include <linux/io.h> | 17 | #include <linux/io.h> |
| 18 | #include "pci-sh4.h" | 18 | #include "pci-sh4.h" |
| 19 | #include <asm/addrspace.h> | 19 | #include <asm/addrspace.h> |
| 20 | #include <asm/sizes.h> | ||
| 20 | 21 | ||
| 21 | static int __init __area_sdram_check(struct pci_channel *chan, | 22 | static int __init __area_sdram_check(struct pci_channel *chan, |
| 22 | unsigned int area) | 23 | unsigned int area) |
| @@ -47,8 +48,8 @@ static int __init __area_sdram_check(struct pci_channel *chan, | |||
| 47 | static struct resource sh7751_pci_resources[] = { | 48 | static struct resource sh7751_pci_resources[] = { |
| 48 | { | 49 | { |
| 49 | .name = "SH7751_IO", | 50 | .name = "SH7751_IO", |
| 50 | .start = SH7751_PCI_IO_BASE, | 51 | .start = 0x1000, |
| 51 | .end = SH7751_PCI_IO_BASE + SH7751_PCI_IO_SIZE - 1, | 52 | .end = SZ_4M - 1, |
| 52 | .flags = IORESOURCE_IO | 53 | .flags = IORESOURCE_IO |
| 53 | }, { | 54 | }, { |
| 54 | .name = "SH7751_mem", | 55 | .name = "SH7751_mem", |
diff --git a/arch/sh/include/cpu-sh4/cpu/dma-register.h b/arch/sh/include/cpu-sh4/cpu/dma-register.h index 55f9fec082d4..de2359533994 100644 --- a/arch/sh/include/cpu-sh4/cpu/dma-register.h +++ b/arch/sh/include/cpu-sh4/cpu/dma-register.h | |||
| @@ -76,7 +76,7 @@ enum { | |||
| 76 | } | 76 | } |
| 77 | 77 | ||
| 78 | #define TS_INDEX2VAL(i) ((((i) & 3) << CHCR_TS_LOW_SHIFT) | \ | 78 | #define TS_INDEX2VAL(i) ((((i) & 3) << CHCR_TS_LOW_SHIFT) | \ |
| 79 | ((((i) >> 2) & 3) << CHCR_TS_HIGH_SHIFT)) | 79 | (((i) & 0xc) << CHCR_TS_HIGH_SHIFT)) |
| 80 | 80 | ||
| 81 | #else /* CONFIG_CPU_SH4A */ | 81 | #else /* CONFIG_CPU_SH4A */ |
| 82 | 82 | ||
diff --git a/block/blk-cgroup.c b/block/blk-cgroup.c index 5fe03def34b2..2cc682b860ea 100644 --- a/block/blk-cgroup.c +++ b/block/blk-cgroup.c | |||
| @@ -286,16 +286,16 @@ done: | |||
| 286 | static struct cgroup_subsys_state * | 286 | static struct cgroup_subsys_state * |
| 287 | blkiocg_create(struct cgroup_subsys *subsys, struct cgroup *cgroup) | 287 | blkiocg_create(struct cgroup_subsys *subsys, struct cgroup *cgroup) |
| 288 | { | 288 | { |
| 289 | struct blkio_cgroup *blkcg, *parent_blkcg; | 289 | struct blkio_cgroup *blkcg; |
| 290 | struct cgroup *parent = cgroup->parent; | ||
| 290 | 291 | ||
| 291 | if (!cgroup->parent) { | 292 | if (!parent) { |
| 292 | blkcg = &blkio_root_cgroup; | 293 | blkcg = &blkio_root_cgroup; |
| 293 | goto done; | 294 | goto done; |
| 294 | } | 295 | } |
| 295 | 296 | ||
| 296 | /* Currently we do not support hierarchy deeper than two level (0,1) */ | 297 | /* Currently we do not support hierarchy deeper than two level (0,1) */ |
| 297 | parent_blkcg = cgroup_to_blkio_cgroup(cgroup->parent); | 298 | if (parent != cgroup->top_cgroup) |
| 298 | if (css_depth(&parent_blkcg->css) > 0) | ||
| 299 | return ERR_PTR(-EINVAL); | 299 | return ERR_PTR(-EINVAL); |
| 300 | 300 | ||
| 301 | blkcg = kzalloc(sizeof(*blkcg), GFP_KERNEL); | 301 | blkcg = kzalloc(sizeof(*blkcg), GFP_KERNEL); |
diff --git a/block/cfq-iosched.c b/block/cfq-iosched.c index 838834be115b..5f127cfb2e92 100644 --- a/block/cfq-iosched.c +++ b/block/cfq-iosched.c | |||
| @@ -3694,8 +3694,10 @@ static void *cfq_init_queue(struct request_queue *q) | |||
| 3694 | * to make sure that cfq_put_cfqg() does not try to kfree root group | 3694 | * to make sure that cfq_put_cfqg() does not try to kfree root group |
| 3695 | */ | 3695 | */ |
| 3696 | atomic_set(&cfqg->ref, 1); | 3696 | atomic_set(&cfqg->ref, 1); |
| 3697 | rcu_read_lock(); | ||
| 3697 | blkiocg_add_blkio_group(&blkio_root_cgroup, &cfqg->blkg, (void *)cfqd, | 3698 | blkiocg_add_blkio_group(&blkio_root_cgroup, &cfqg->blkg, (void *)cfqd, |
| 3698 | 0); | 3699 | 0); |
| 3700 | rcu_read_unlock(); | ||
| 3699 | #endif | 3701 | #endif |
| 3700 | /* | 3702 | /* |
| 3701 | * Not strictly needed (since RB_ROOT just clears the node and we | 3703 | * Not strictly needed (since RB_ROOT just clears the node and we |
diff --git a/drivers/Makefile b/drivers/Makefile index 34f1e1064dbc..f42a03029b7c 100644 --- a/drivers/Makefile +++ b/drivers/Makefile | |||
| @@ -17,6 +17,7 @@ obj-$(CONFIG_SFI) += sfi/ | |||
| 17 | obj-$(CONFIG_PNP) += pnp/ | 17 | obj-$(CONFIG_PNP) += pnp/ |
| 18 | obj-$(CONFIG_ARM_AMBA) += amba/ | 18 | obj-$(CONFIG_ARM_AMBA) += amba/ |
| 19 | 19 | ||
| 20 | obj-$(CONFIG_VIRTIO) += virtio/ | ||
| 20 | obj-$(CONFIG_XEN) += xen/ | 21 | obj-$(CONFIG_XEN) += xen/ |
| 21 | 22 | ||
| 22 | # regulators early, since some subsystems rely on them to initialize | 23 | # regulators early, since some subsystems rely on them to initialize |
| @@ -108,7 +109,6 @@ obj-$(CONFIG_PPC_PS3) += ps3/ | |||
| 108 | obj-$(CONFIG_OF) += of/ | 109 | obj-$(CONFIG_OF) += of/ |
| 109 | obj-$(CONFIG_SSB) += ssb/ | 110 | obj-$(CONFIG_SSB) += ssb/ |
| 110 | obj-$(CONFIG_VHOST_NET) += vhost/ | 111 | obj-$(CONFIG_VHOST_NET) += vhost/ |
| 111 | obj-$(CONFIG_VIRTIO) += virtio/ | ||
| 112 | obj-$(CONFIG_VLYNQ) += vlynq/ | 112 | obj-$(CONFIG_VLYNQ) += vlynq/ |
| 113 | obj-$(CONFIG_STAGING) += staging/ | 113 | obj-$(CONFIG_STAGING) += staging/ |
| 114 | obj-y += platform/ | 114 | obj-y += platform/ |
diff --git a/drivers/acpi/acpi_pad.c b/drivers/acpi/acpi_pad.c index 19dacfd43163..62122134693b 100644 --- a/drivers/acpi/acpi_pad.c +++ b/drivers/acpi/acpi_pad.c | |||
| @@ -31,7 +31,7 @@ | |||
| 31 | #include <acpi/acpi_bus.h> | 31 | #include <acpi/acpi_bus.h> |
| 32 | #include <acpi/acpi_drivers.h> | 32 | #include <acpi/acpi_drivers.h> |
| 33 | 33 | ||
| 34 | #define ACPI_PROCESSOR_AGGREGATOR_CLASS "processor_aggregator" | 34 | #define ACPI_PROCESSOR_AGGREGATOR_CLASS "acpi_pad" |
| 35 | #define ACPI_PROCESSOR_AGGREGATOR_DEVICE_NAME "Processor Aggregator" | 35 | #define ACPI_PROCESSOR_AGGREGATOR_DEVICE_NAME "Processor Aggregator" |
| 36 | #define ACPI_PROCESSOR_AGGREGATOR_NOTIFY 0x80 | 36 | #define ACPI_PROCESSOR_AGGREGATOR_NOTIFY 0x80 |
| 37 | static DEFINE_MUTEX(isolated_cpus_lock); | 37 | static DEFINE_MUTEX(isolated_cpus_lock); |
diff --git a/drivers/acpi/bus.c b/drivers/acpi/bus.c index 37132dc2da03..743576bf1bd7 100644 --- a/drivers/acpi/bus.c +++ b/drivers/acpi/bus.c | |||
| @@ -527,7 +527,7 @@ int acpi_bus_generate_proc_event4(const char *device_class, const char *bus_id, | |||
| 527 | if (!event_is_open) | 527 | if (!event_is_open) |
| 528 | return 0; | 528 | return 0; |
| 529 | 529 | ||
| 530 | event = kmalloc(sizeof(struct acpi_bus_event), GFP_ATOMIC); | 530 | event = kzalloc(sizeof(struct acpi_bus_event), GFP_ATOMIC); |
| 531 | if (!event) | 531 | if (!event) |
| 532 | return -ENOMEM; | 532 | return -ENOMEM; |
| 533 | 533 | ||
diff --git a/drivers/acpi/hest.c b/drivers/acpi/hest.c index 4bb18c980ac6..1c527a192872 100644 --- a/drivers/acpi/hest.c +++ b/drivers/acpi/hest.c | |||
| @@ -123,6 +123,10 @@ int acpi_hest_firmware_first_pci(struct pci_dev *pci) | |||
| 123 | { | 123 | { |
| 124 | acpi_status status = AE_NOT_FOUND; | 124 | acpi_status status = AE_NOT_FOUND; |
| 125 | struct acpi_table_header *hest = NULL; | 125 | struct acpi_table_header *hest = NULL; |
| 126 | |||
| 127 | if (acpi_disabled) | ||
| 128 | return 0; | ||
| 129 | |||
| 126 | status = acpi_get_table(ACPI_SIG_HEST, 1, &hest); | 130 | status = acpi_get_table(ACPI_SIG_HEST, 1, &hest); |
| 127 | 131 | ||
| 128 | if (ACPI_SUCCESS(status)) { | 132 | if (ACPI_SUCCESS(status)) { |
diff --git a/drivers/acpi/power_meter.c b/drivers/acpi/power_meter.c index e8c32a49f14e..66f67293341e 100644 --- a/drivers/acpi/power_meter.c +++ b/drivers/acpi/power_meter.c | |||
| @@ -35,7 +35,7 @@ | |||
| 35 | #define ACPI_POWER_METER_NAME "power_meter" | 35 | #define ACPI_POWER_METER_NAME "power_meter" |
| 36 | ACPI_MODULE_NAME(ACPI_POWER_METER_NAME); | 36 | ACPI_MODULE_NAME(ACPI_POWER_METER_NAME); |
| 37 | #define ACPI_POWER_METER_DEVICE_NAME "Power Meter" | 37 | #define ACPI_POWER_METER_DEVICE_NAME "Power Meter" |
| 38 | #define ACPI_POWER_METER_CLASS "power_meter_resource" | 38 | #define ACPI_POWER_METER_CLASS "pwr_meter_resource" |
| 39 | 39 | ||
| 40 | #define NUM_SENSORS 17 | 40 | #define NUM_SENSORS 17 |
| 41 | 41 | ||
diff --git a/drivers/acpi/sbshc.c b/drivers/acpi/sbshc.c index 36704b887ccf..f8be23b6c129 100644 --- a/drivers/acpi/sbshc.c +++ b/drivers/acpi/sbshc.c | |||
| @@ -18,7 +18,7 @@ | |||
| 18 | 18 | ||
| 19 | #define PREFIX "ACPI: " | 19 | #define PREFIX "ACPI: " |
| 20 | 20 | ||
| 21 | #define ACPI_SMB_HC_CLASS "smbus_host_controller" | 21 | #define ACPI_SMB_HC_CLASS "smbus_host_ctl" |
| 22 | #define ACPI_SMB_HC_DEVICE_NAME "ACPI SMBus HC" | 22 | #define ACPI_SMB_HC_DEVICE_NAME "ACPI SMBus HC" |
| 23 | 23 | ||
| 24 | struct acpi_smb_hc { | 24 | struct acpi_smb_hc { |
diff --git a/drivers/acpi/sleep.c b/drivers/acpi/sleep.c index f74834a544fd..e2e992599e68 100644 --- a/drivers/acpi/sleep.c +++ b/drivers/acpi/sleep.c | |||
| @@ -450,6 +450,126 @@ static struct dmi_system_id __initdata acpisleep_dmi_table[] = { | |||
| 450 | }, | 450 | }, |
| 451 | }, | 451 | }, |
| 452 | { | 452 | { |
| 453 | .callback = init_set_sci_en_on_resume, | ||
| 454 | .ident = "Lenovo ThinkPad T410", | ||
| 455 | .matches = { | ||
| 456 | DMI_MATCH(DMI_SYS_VENDOR, "LENOVO"), | ||
| 457 | DMI_MATCH(DMI_PRODUCT_VERSION, "ThinkPad T410"), | ||
| 458 | }, | ||
| 459 | }, | ||
| 460 | { | ||
| 461 | .callback = init_set_sci_en_on_resume, | ||
| 462 | .ident = "Lenovo ThinkPad T510", | ||
| 463 | .matches = { | ||
| 464 | DMI_MATCH(DMI_SYS_VENDOR, "LENOVO"), | ||
| 465 | DMI_MATCH(DMI_PRODUCT_VERSION, "ThinkPad T510"), | ||
| 466 | }, | ||
| 467 | }, | ||
| 468 | { | ||
| 469 | .callback = init_set_sci_en_on_resume, | ||
| 470 | .ident = "Lenovo ThinkPad W510", | ||
| 471 | .matches = { | ||
| 472 | DMI_MATCH(DMI_SYS_VENDOR, "LENOVO"), | ||
| 473 | DMI_MATCH(DMI_PRODUCT_VERSION, "ThinkPad W510"), | ||
| 474 | }, | ||
| 475 | }, | ||
| 476 | { | ||
| 477 | .callback = init_set_sci_en_on_resume, | ||
| 478 | .ident = "Lenovo ThinkPad X201", | ||
| 479 | .matches = { | ||
| 480 | DMI_MATCH(DMI_SYS_VENDOR, "LENOVO"), | ||
| 481 | DMI_MATCH(DMI_PRODUCT_VERSION, "ThinkPad X201"), | ||
| 482 | }, | ||
| 483 | }, | ||
| 484 | { | ||
| 485 | .callback = init_set_sci_en_on_resume, | ||
| 486 | .ident = "Lenovo ThinkPad X201", | ||
| 487 | .matches = { | ||
| 488 | DMI_MATCH(DMI_SYS_VENDOR, "LENOVO"), | ||
| 489 | DMI_MATCH(DMI_PRODUCT_VERSION, "ThinkPad X201s"), | ||
| 490 | }, | ||
| 491 | }, | ||
| 492 | { | ||
| 493 | .callback = init_set_sci_en_on_resume, | ||
| 494 | .ident = "Lenovo ThinkPad T410", | ||
| 495 | .matches = { | ||
| 496 | DMI_MATCH(DMI_SYS_VENDOR, "LENOVO"), | ||
| 497 | DMI_MATCH(DMI_PRODUCT_VERSION, "ThinkPad T410"), | ||
| 498 | }, | ||
| 499 | }, | ||
| 500 | { | ||
| 501 | .callback = init_set_sci_en_on_resume, | ||
| 502 | .ident = "Lenovo ThinkPad T510", | ||
| 503 | .matches = { | ||
| 504 | DMI_MATCH(DMI_SYS_VENDOR, "LENOVO"), | ||
| 505 | DMI_MATCH(DMI_PRODUCT_VERSION, "ThinkPad T510"), | ||
| 506 | }, | ||
| 507 | }, | ||
| 508 | { | ||
| 509 | .callback = init_set_sci_en_on_resume, | ||
| 510 | .ident = "Lenovo ThinkPad W510", | ||
| 511 | .matches = { | ||
| 512 | DMI_MATCH(DMI_SYS_VENDOR, "LENOVO"), | ||
| 513 | DMI_MATCH(DMI_PRODUCT_VERSION, "ThinkPad W510"), | ||
| 514 | }, | ||
| 515 | }, | ||
| 516 | { | ||
| 517 | .callback = init_set_sci_en_on_resume, | ||
| 518 | .ident = "Lenovo ThinkPad X201", | ||
| 519 | .matches = { | ||
| 520 | DMI_MATCH(DMI_SYS_VENDOR, "LENOVO"), | ||
| 521 | DMI_MATCH(DMI_PRODUCT_VERSION, "ThinkPad X201"), | ||
| 522 | }, | ||
| 523 | }, | ||
| 524 | { | ||
| 525 | .callback = init_set_sci_en_on_resume, | ||
| 526 | .ident = "Lenovo ThinkPad X201", | ||
| 527 | .matches = { | ||
| 528 | DMI_MATCH(DMI_SYS_VENDOR, "LENOVO"), | ||
| 529 | DMI_MATCH(DMI_PRODUCT_VERSION, "ThinkPad X201s"), | ||
| 530 | }, | ||
| 531 | }, | ||
| 532 | { | ||
| 533 | .callback = init_set_sci_en_on_resume, | ||
| 534 | .ident = "Lenovo ThinkPad T410", | ||
| 535 | .matches = { | ||
| 536 | DMI_MATCH(DMI_SYS_VENDOR, "LENOVO"), | ||
| 537 | DMI_MATCH(DMI_PRODUCT_VERSION, "ThinkPad T410"), | ||
| 538 | }, | ||
| 539 | }, | ||
| 540 | { | ||
| 541 | .callback = init_set_sci_en_on_resume, | ||
| 542 | .ident = "Lenovo ThinkPad T510", | ||
| 543 | .matches = { | ||
| 544 | DMI_MATCH(DMI_SYS_VENDOR, "LENOVO"), | ||
| 545 | DMI_MATCH(DMI_PRODUCT_VERSION, "ThinkPad T510"), | ||
| 546 | }, | ||
| 547 | }, | ||
| 548 | { | ||
| 549 | .callback = init_set_sci_en_on_resume, | ||
| 550 | .ident = "Lenovo ThinkPad W510", | ||
| 551 | .matches = { | ||
| 552 | DMI_MATCH(DMI_SYS_VENDOR, "LENOVO"), | ||
| 553 | DMI_MATCH(DMI_PRODUCT_VERSION, "ThinkPad W510"), | ||
| 554 | }, | ||
| 555 | }, | ||
| 556 | { | ||
| 557 | .callback = init_set_sci_en_on_resume, | ||
| 558 | .ident = "Lenovo ThinkPad X201", | ||
| 559 | .matches = { | ||
| 560 | DMI_MATCH(DMI_SYS_VENDOR, "LENOVO"), | ||
| 561 | DMI_MATCH(DMI_PRODUCT_VERSION, "ThinkPad X201"), | ||
| 562 | }, | ||
| 563 | }, | ||
| 564 | { | ||
| 565 | .callback = init_set_sci_en_on_resume, | ||
| 566 | .ident = "Lenovo ThinkPad X201", | ||
| 567 | .matches = { | ||
| 568 | DMI_MATCH(DMI_SYS_VENDOR, "LENOVO"), | ||
| 569 | DMI_MATCH(DMI_PRODUCT_VERSION, "ThinkPad X201s"), | ||
| 570 | }, | ||
| 571 | }, | ||
| 572 | { | ||
| 453 | .callback = init_old_suspend_ordering, | 573 | .callback = init_old_suspend_ordering, |
| 454 | .ident = "Panasonic CF51-2L", | 574 | .ident = "Panasonic CF51-2L", |
| 455 | .matches = { | 575 | .matches = { |
| @@ -458,6 +578,30 @@ static struct dmi_system_id __initdata acpisleep_dmi_table[] = { | |||
| 458 | DMI_MATCH(DMI_BOARD_NAME, "CF51-2L"), | 578 | DMI_MATCH(DMI_BOARD_NAME, "CF51-2L"), |
| 459 | }, | 579 | }, |
| 460 | }, | 580 | }, |
| 581 | { | ||
| 582 | .callback = init_set_sci_en_on_resume, | ||
| 583 | .ident = "Dell Studio 1558", | ||
| 584 | .matches = { | ||
| 585 | DMI_MATCH(DMI_SYS_VENDOR, "Dell Inc."), | ||
| 586 | DMI_MATCH(DMI_PRODUCT_NAME, "Studio 1558"), | ||
| 587 | }, | ||
| 588 | }, | ||
| 589 | { | ||
| 590 | .callback = init_set_sci_en_on_resume, | ||
| 591 | .ident = "Dell Studio 1557", | ||
| 592 | .matches = { | ||
| 593 | DMI_MATCH(DMI_SYS_VENDOR, "Dell Inc."), | ||
| 594 | DMI_MATCH(DMI_PRODUCT_NAME, "Studio 1557"), | ||
| 595 | }, | ||
| 596 | }, | ||
| 597 | { | ||
| 598 | .callback = init_set_sci_en_on_resume, | ||
| 599 | .ident = "Dell Studio 1555", | ||
| 600 | .matches = { | ||
| 601 | DMI_MATCH(DMI_SYS_VENDOR, "Dell Inc."), | ||
| 602 | DMI_MATCH(DMI_PRODUCT_NAME, "Studio 1555"), | ||
| 603 | }, | ||
| 604 | }, | ||
| 461 | {}, | 605 | {}, |
| 462 | }; | 606 | }; |
| 463 | #endif /* CONFIG_SUSPEND */ | 607 | #endif /* CONFIG_SUSPEND */ |
diff --git a/drivers/block/drbd/drbd_worker.c b/drivers/block/drbd/drbd_worker.c index 44bf6d11197e..d48a1dfd7b24 100644 --- a/drivers/block/drbd/drbd_worker.c +++ b/drivers/block/drbd/drbd_worker.c | |||
| @@ -235,7 +235,7 @@ void drbd_endio_pri(struct bio *bio, int error) | |||
| 235 | if (unlikely(error)) { | 235 | if (unlikely(error)) { |
| 236 | what = (bio_data_dir(bio) == WRITE) | 236 | what = (bio_data_dir(bio) == WRITE) |
| 237 | ? write_completed_with_error | 237 | ? write_completed_with_error |
| 238 | : (bio_rw(bio) == READA) | 238 | : (bio_rw(bio) == READ) |
| 239 | ? read_completed_with_error | 239 | ? read_completed_with_error |
| 240 | : read_ahead_completed_with_error; | 240 | : read_ahead_completed_with_error; |
| 241 | } else | 241 | } else |
diff --git a/drivers/dma/shdma.c b/drivers/dma/shdma.c index 7cc31b3f40d8..6f25a20de99f 100644 --- a/drivers/dma/shdma.c +++ b/drivers/dma/shdma.c | |||
| @@ -290,6 +290,7 @@ static int sh_dmae_alloc_chan_resources(struct dma_chan *chan) | |||
| 290 | struct sh_dmae_chan *sh_chan = to_sh_chan(chan); | 290 | struct sh_dmae_chan *sh_chan = to_sh_chan(chan); |
| 291 | struct sh_desc *desc; | 291 | struct sh_desc *desc; |
| 292 | struct sh_dmae_slave *param = chan->private; | 292 | struct sh_dmae_slave *param = chan->private; |
| 293 | int ret; | ||
| 293 | 294 | ||
| 294 | pm_runtime_get_sync(sh_chan->dev); | 295 | pm_runtime_get_sync(sh_chan->dev); |
| 295 | 296 | ||
| @@ -301,11 +302,15 @@ static int sh_dmae_alloc_chan_resources(struct dma_chan *chan) | |||
| 301 | struct sh_dmae_slave_config *cfg; | 302 | struct sh_dmae_slave_config *cfg; |
| 302 | 303 | ||
| 303 | cfg = sh_dmae_find_slave(sh_chan, param->slave_id); | 304 | cfg = sh_dmae_find_slave(sh_chan, param->slave_id); |
| 304 | if (!cfg) | 305 | if (!cfg) { |
| 305 | return -EINVAL; | 306 | ret = -EINVAL; |
| 307 | goto efindslave; | ||
| 308 | } | ||
| 306 | 309 | ||
| 307 | if (test_and_set_bit(param->slave_id, sh_dmae_slave_used)) | 310 | if (test_and_set_bit(param->slave_id, sh_dmae_slave_used)) { |
| 308 | return -EBUSY; | 311 | ret = -EBUSY; |
| 312 | goto etestused; | ||
| 313 | } | ||
| 309 | 314 | ||
| 310 | param->config = cfg; | 315 | param->config = cfg; |
| 311 | 316 | ||
| @@ -334,10 +339,20 @@ static int sh_dmae_alloc_chan_resources(struct dma_chan *chan) | |||
| 334 | } | 339 | } |
| 335 | spin_unlock_bh(&sh_chan->desc_lock); | 340 | spin_unlock_bh(&sh_chan->desc_lock); |
| 336 | 341 | ||
| 337 | if (!sh_chan->descs_allocated) | 342 | if (!sh_chan->descs_allocated) { |
| 338 | pm_runtime_put(sh_chan->dev); | 343 | ret = -ENOMEM; |
| 344 | goto edescalloc; | ||
| 345 | } | ||
| 339 | 346 | ||
| 340 | return sh_chan->descs_allocated; | 347 | return sh_chan->descs_allocated; |
| 348 | |||
| 349 | edescalloc: | ||
| 350 | if (param) | ||
| 351 | clear_bit(param->slave_id, sh_dmae_slave_used); | ||
| 352 | etestused: | ||
| 353 | efindslave: | ||
| 354 | pm_runtime_put(sh_chan->dev); | ||
| 355 | return ret; | ||
| 341 | } | 356 | } |
| 342 | 357 | ||
| 343 | /* | 358 | /* |
diff --git a/drivers/gpu/drm/radeon/radeon_drv.c b/drivers/gpu/drm/radeon/radeon_drv.c index 4b05563d99e1..b3749d47be7b 100644 --- a/drivers/gpu/drm/radeon/radeon_drv.c +++ b/drivers/gpu/drm/radeon/radeon_drv.c | |||
| @@ -216,6 +216,7 @@ static struct drm_driver driver_old = { | |||
| 216 | .mmap = drm_mmap, | 216 | .mmap = drm_mmap, |
| 217 | .poll = drm_poll, | 217 | .poll = drm_poll, |
| 218 | .fasync = drm_fasync, | 218 | .fasync = drm_fasync, |
| 219 | .read = drm_read, | ||
| 219 | #ifdef CONFIG_COMPAT | 220 | #ifdef CONFIG_COMPAT |
| 220 | .compat_ioctl = radeon_compat_ioctl, | 221 | .compat_ioctl = radeon_compat_ioctl, |
| 221 | #endif | 222 | #endif |
| @@ -304,6 +305,7 @@ static struct drm_driver kms_driver = { | |||
| 304 | .mmap = radeon_mmap, | 305 | .mmap = radeon_mmap, |
| 305 | .poll = drm_poll, | 306 | .poll = drm_poll, |
| 306 | .fasync = drm_fasync, | 307 | .fasync = drm_fasync, |
| 308 | .read = drm_read, | ||
| 307 | #ifdef CONFIG_COMPAT | 309 | #ifdef CONFIG_COMPAT |
| 308 | .compat_ioctl = radeon_kms_compat_ioctl, | 310 | .compat_ioctl = radeon_kms_compat_ioctl, |
| 309 | #endif | 311 | #endif |
diff --git a/drivers/gpu/drm/ttm/ttm_bo.c b/drivers/gpu/drm/ttm/ttm_bo.c index dd47b2a9a791..0e3754a3a303 100644 --- a/drivers/gpu/drm/ttm/ttm_bo.c +++ b/drivers/gpu/drm/ttm/ttm_bo.c | |||
| @@ -1716,40 +1716,12 @@ int ttm_bo_wait(struct ttm_buffer_object *bo, | |||
| 1716 | } | 1716 | } |
| 1717 | EXPORT_SYMBOL(ttm_bo_wait); | 1717 | EXPORT_SYMBOL(ttm_bo_wait); |
| 1718 | 1718 | ||
| 1719 | void ttm_bo_unblock_reservation(struct ttm_buffer_object *bo) | ||
| 1720 | { | ||
| 1721 | atomic_set(&bo->reserved, 0); | ||
| 1722 | wake_up_all(&bo->event_queue); | ||
| 1723 | } | ||
| 1724 | |||
| 1725 | int ttm_bo_block_reservation(struct ttm_buffer_object *bo, bool interruptible, | ||
| 1726 | bool no_wait) | ||
| 1727 | { | ||
| 1728 | int ret; | ||
| 1729 | |||
| 1730 | while (unlikely(atomic_cmpxchg(&bo->reserved, 0, 1) != 0)) { | ||
| 1731 | if (no_wait) | ||
| 1732 | return -EBUSY; | ||
| 1733 | else if (interruptible) { | ||
| 1734 | ret = wait_event_interruptible | ||
| 1735 | (bo->event_queue, atomic_read(&bo->reserved) == 0); | ||
| 1736 | if (unlikely(ret != 0)) | ||
| 1737 | return ret; | ||
| 1738 | } else { | ||
| 1739 | wait_event(bo->event_queue, | ||
| 1740 | atomic_read(&bo->reserved) == 0); | ||
| 1741 | } | ||
| 1742 | } | ||
| 1743 | return 0; | ||
| 1744 | } | ||
| 1745 | |||
| 1746 | int ttm_bo_synccpu_write_grab(struct ttm_buffer_object *bo, bool no_wait) | 1719 | int ttm_bo_synccpu_write_grab(struct ttm_buffer_object *bo, bool no_wait) |
| 1747 | { | 1720 | { |
| 1748 | int ret = 0; | 1721 | int ret = 0; |
| 1749 | 1722 | ||
| 1750 | /* | 1723 | /* |
| 1751 | * Using ttm_bo_reserve instead of ttm_bo_block_reservation | 1724 | * Using ttm_bo_reserve makes sure the lru lists are updated. |
| 1752 | * makes sure the lru lists are updated. | ||
| 1753 | */ | 1725 | */ |
| 1754 | 1726 | ||
| 1755 | ret = ttm_bo_reserve(bo, true, no_wait, false, 0); | 1727 | ret = ttm_bo_reserve(bo, true, no_wait, false, 0); |
diff --git a/drivers/gpu/drm/ttm/ttm_lock.c b/drivers/gpu/drm/ttm/ttm_lock.c index 3d172ef04ee1..de41e55a944a 100644 --- a/drivers/gpu/drm/ttm/ttm_lock.c +++ b/drivers/gpu/drm/ttm/ttm_lock.c | |||
| @@ -204,7 +204,6 @@ static int __ttm_vt_unlock(struct ttm_lock *lock) | |||
| 204 | lock->flags &= ~TTM_VT_LOCK; | 204 | lock->flags &= ~TTM_VT_LOCK; |
| 205 | wake_up_all(&lock->queue); | 205 | wake_up_all(&lock->queue); |
| 206 | spin_unlock(&lock->lock); | 206 | spin_unlock(&lock->lock); |
| 207 | printk(KERN_INFO TTM_PFX "vt unlock.\n"); | ||
| 208 | 207 | ||
| 209 | return ret; | 208 | return ret; |
| 210 | } | 209 | } |
| @@ -265,10 +264,8 @@ int ttm_vt_lock(struct ttm_lock *lock, | |||
| 265 | ttm_lock_type, &ttm_vt_lock_remove, NULL); | 264 | ttm_lock_type, &ttm_vt_lock_remove, NULL); |
| 266 | if (ret) | 265 | if (ret) |
| 267 | (void)__ttm_vt_unlock(lock); | 266 | (void)__ttm_vt_unlock(lock); |
| 268 | else { | 267 | else |
| 269 | lock->vt_holder = tfile; | 268 | lock->vt_holder = tfile; |
| 270 | printk(KERN_INFO TTM_PFX "vt lock.\n"); | ||
| 271 | } | ||
| 272 | 269 | ||
| 273 | return ret; | 270 | return ret; |
| 274 | } | 271 | } |
diff --git a/drivers/media/common/saa7146_fops.c b/drivers/media/common/saa7146_fops.c index fd8e1f45be36..7364b9642d00 100644 --- a/drivers/media/common/saa7146_fops.c +++ b/drivers/media/common/saa7146_fops.c | |||
| @@ -423,15 +423,14 @@ static void vv_callback(struct saa7146_dev *dev, unsigned long status) | |||
| 423 | } | 423 | } |
| 424 | } | 424 | } |
| 425 | 425 | ||
| 426 | int saa7146_vv_devinit(struct saa7146_dev *dev) | ||
| 427 | { | ||
| 428 | return v4l2_device_register(&dev->pci->dev, &dev->v4l2_dev); | ||
| 429 | } | ||
| 430 | EXPORT_SYMBOL_GPL(saa7146_vv_devinit); | ||
| 431 | |||
| 432 | int saa7146_vv_init(struct saa7146_dev* dev, struct saa7146_ext_vv *ext_vv) | 426 | int saa7146_vv_init(struct saa7146_dev* dev, struct saa7146_ext_vv *ext_vv) |
| 433 | { | 427 | { |
| 434 | struct saa7146_vv *vv; | 428 | struct saa7146_vv *vv; |
| 429 | int err; | ||
| 430 | |||
| 431 | err = v4l2_device_register(&dev->pci->dev, &dev->v4l2_dev); | ||
| 432 | if (err) | ||
| 433 | return err; | ||
| 435 | 434 | ||
| 436 | vv = kzalloc(sizeof(struct saa7146_vv), GFP_KERNEL); | 435 | vv = kzalloc(sizeof(struct saa7146_vv), GFP_KERNEL); |
| 437 | if (vv == NULL) { | 436 | if (vv == NULL) { |
diff --git a/drivers/media/common/saa7146_video.c b/drivers/media/common/saa7146_video.c index 5ed75263340a..b8b2c551a1e2 100644 --- a/drivers/media/common/saa7146_video.c +++ b/drivers/media/common/saa7146_video.c | |||
| @@ -558,9 +558,11 @@ static int vidioc_s_fbuf(struct file *file, void *fh, struct v4l2_framebuffer *f | |||
| 558 | /* ok, accept it */ | 558 | /* ok, accept it */ |
| 559 | vv->ov_fb = *fb; | 559 | vv->ov_fb = *fb; |
| 560 | vv->ov_fmt = fmt; | 560 | vv->ov_fmt = fmt; |
| 561 | if (0 == vv->ov_fb.fmt.bytesperline) | 561 | |
| 562 | vv->ov_fb.fmt.bytesperline = | 562 | if (vv->ov_fb.fmt.bytesperline < vv->ov_fb.fmt.width) { |
| 563 | vv->ov_fb.fmt.width * fmt->depth / 8; | 563 | vv->ov_fb.fmt.bytesperline = vv->ov_fb.fmt.width * fmt->depth / 8; |
| 564 | DEB_D(("setting bytesperline to %d\n", vv->ov_fb.fmt.bytesperline)); | ||
| 565 | } | ||
| 564 | 566 | ||
| 565 | mutex_unlock(&dev->lock); | 567 | mutex_unlock(&dev->lock); |
| 566 | return 0; | 568 | return 0; |
diff --git a/drivers/media/dvb/frontends/stv090x.c b/drivers/media/dvb/frontends/stv090x.c index a3c07fe0e6c4..96972804f4ad 100644 --- a/drivers/media/dvb/frontends/stv090x.c +++ b/drivers/media/dvb/frontends/stv090x.c | |||
| @@ -4470,6 +4470,10 @@ static int stv090x_setup(struct dvb_frontend *fe) | |||
| 4470 | if (stv090x_write_reg(state, STV090x_TSTRES0, 0x00) < 0) | 4470 | if (stv090x_write_reg(state, STV090x_TSTRES0, 0x00) < 0) |
| 4471 | goto err; | 4471 | goto err; |
| 4472 | 4472 | ||
| 4473 | /* workaround for stuck DiSEqC output */ | ||
| 4474 | if (config->diseqc_envelope_mode) | ||
| 4475 | stv090x_send_diseqc_burst(fe, SEC_MINI_A); | ||
| 4476 | |||
| 4473 | return 0; | 4477 | return 0; |
| 4474 | err: | 4478 | err: |
| 4475 | dprintk(FE_ERROR, 1, "I/O error"); | 4479 | dprintk(FE_ERROR, 1, "I/O error"); |
diff --git a/drivers/media/dvb/ttpci/budget.c b/drivers/media/dvb/ttpci/budget.c index 9fdf26cc6998..1500210c06cf 100644 --- a/drivers/media/dvb/ttpci/budget.c +++ b/drivers/media/dvb/ttpci/budget.c | |||
| @@ -643,9 +643,6 @@ static void frontend_init(struct budget *budget) | |||
| 643 | &budget->i2c_adap, | 643 | &budget->i2c_adap, |
| 644 | &tt1600_isl6423_config); | 644 | &tt1600_isl6423_config); |
| 645 | 645 | ||
| 646 | } else { | ||
| 647 | dvb_frontend_detach(budget->dvb_frontend); | ||
| 648 | budget->dvb_frontend = NULL; | ||
| 649 | } | 646 | } |
| 650 | } | 647 | } |
| 651 | break; | 648 | break; |
diff --git a/drivers/media/video/Kconfig b/drivers/media/video/Kconfig index f8fc8654693d..9644cf760aaa 100644 --- a/drivers/media/video/Kconfig +++ b/drivers/media/video/Kconfig | |||
| @@ -361,7 +361,7 @@ config VIDEO_SAA717X | |||
| 361 | 361 | ||
| 362 | config VIDEO_SAA7191 | 362 | config VIDEO_SAA7191 |
| 363 | tristate "Philips SAA7191 video decoder" | 363 | tristate "Philips SAA7191 video decoder" |
| 364 | depends on VIDEO_V4L1 && I2C | 364 | depends on VIDEO_V4L2 && I2C |
| 365 | ---help--- | 365 | ---help--- |
| 366 | Support for the Philips SAA7191 video decoder. | 366 | Support for the Philips SAA7191 video decoder. |
| 367 | 367 | ||
| @@ -756,7 +756,7 @@ source "drivers/media/video/saa7134/Kconfig" | |||
| 756 | 756 | ||
| 757 | config VIDEO_MXB | 757 | config VIDEO_MXB |
| 758 | tristate "Siemens-Nixdorf 'Multimedia eXtension Board'" | 758 | tristate "Siemens-Nixdorf 'Multimedia eXtension Board'" |
| 759 | depends on PCI && VIDEO_V4L1 && I2C | 759 | depends on PCI && VIDEO_V4L2 && I2C |
| 760 | select VIDEO_SAA7146_VV | 760 | select VIDEO_SAA7146_VV |
| 761 | select VIDEO_TUNER | 761 | select VIDEO_TUNER |
| 762 | select VIDEO_SAA711X if VIDEO_HELPER_CHIPS_AUTO | 762 | select VIDEO_SAA711X if VIDEO_HELPER_CHIPS_AUTO |
diff --git a/drivers/media/video/Makefile b/drivers/media/video/Makefile index b88b6174a331..c51c386559f2 100644 --- a/drivers/media/video/Makefile +++ b/drivers/media/video/Makefile | |||
| @@ -160,8 +160,6 @@ obj-$(CONFIG_VIDEO_MX3) += mx3_camera.o | |||
| 160 | obj-$(CONFIG_VIDEO_PXA27x) += pxa_camera.o | 160 | obj-$(CONFIG_VIDEO_PXA27x) += pxa_camera.o |
| 161 | obj-$(CONFIG_VIDEO_SH_MOBILE_CEU) += sh_mobile_ceu_camera.o | 161 | obj-$(CONFIG_VIDEO_SH_MOBILE_CEU) += sh_mobile_ceu_camera.o |
| 162 | 162 | ||
| 163 | obj-$(CONFIG_ARCH_DAVINCI) += davinci/ | ||
| 164 | |||
| 165 | obj-$(CONFIG_VIDEO_AU0828) += au0828/ | 163 | obj-$(CONFIG_VIDEO_AU0828) += au0828/ |
| 166 | 164 | ||
| 167 | obj-$(CONFIG_USB_VIDEO_CLASS) += uvc/ | 165 | obj-$(CONFIG_USB_VIDEO_CLASS) += uvc/ |
diff --git a/drivers/media/video/davinci/vpfe_capture.c b/drivers/media/video/davinci/vpfe_capture.c index 7cf042f9b377..398dbe71cb82 100644 --- a/drivers/media/video/davinci/vpfe_capture.c +++ b/drivers/media/video/davinci/vpfe_capture.c | |||
| @@ -223,7 +223,6 @@ int vpfe_register_ccdc_device(struct ccdc_hw_device *dev) | |||
| 223 | BUG_ON(!dev->hw_ops.get_frame_format); | 223 | BUG_ON(!dev->hw_ops.get_frame_format); |
| 224 | BUG_ON(!dev->hw_ops.get_pixel_format); | 224 | BUG_ON(!dev->hw_ops.get_pixel_format); |
| 225 | BUG_ON(!dev->hw_ops.set_pixel_format); | 225 | BUG_ON(!dev->hw_ops.set_pixel_format); |
| 226 | BUG_ON(!dev->hw_ops.set_params); | ||
| 227 | BUG_ON(!dev->hw_ops.set_image_window); | 226 | BUG_ON(!dev->hw_ops.set_image_window); |
| 228 | BUG_ON(!dev->hw_ops.get_image_window); | 227 | BUG_ON(!dev->hw_ops.get_image_window); |
| 229 | BUG_ON(!dev->hw_ops.get_line_length); | 228 | BUG_ON(!dev->hw_ops.get_line_length); |
| @@ -1689,11 +1688,12 @@ static long vpfe_param_handler(struct file *file, void *priv, | |||
| 1689 | struct vpfe_device *vpfe_dev = video_drvdata(file); | 1688 | struct vpfe_device *vpfe_dev = video_drvdata(file); |
| 1690 | int ret = 0; | 1689 | int ret = 0; |
| 1691 | 1690 | ||
| 1692 | v4l2_dbg(1, debug, &vpfe_dev->v4l2_dev, "vpfe_param_handler\n"); | 1691 | v4l2_dbg(2, debug, &vpfe_dev->v4l2_dev, "vpfe_param_handler\n"); |
| 1693 | 1692 | ||
| 1694 | if (vpfe_dev->started) { | 1693 | if (vpfe_dev->started) { |
| 1695 | /* only allowed if streaming is not started */ | 1694 | /* only allowed if streaming is not started */ |
| 1696 | v4l2_err(&vpfe_dev->v4l2_dev, "device already started\n"); | 1695 | v4l2_dbg(1, debug, &vpfe_dev->v4l2_dev, |
| 1696 | "device already started\n"); | ||
| 1697 | return -EBUSY; | 1697 | return -EBUSY; |
| 1698 | } | 1698 | } |
| 1699 | 1699 | ||
| @@ -1705,16 +1705,23 @@ static long vpfe_param_handler(struct file *file, void *priv, | |||
| 1705 | case VPFE_CMD_S_CCDC_RAW_PARAMS: | 1705 | case VPFE_CMD_S_CCDC_RAW_PARAMS: |
| 1706 | v4l2_warn(&vpfe_dev->v4l2_dev, | 1706 | v4l2_warn(&vpfe_dev->v4l2_dev, |
| 1707 | "VPFE_CMD_S_CCDC_RAW_PARAMS: experimental ioctl\n"); | 1707 | "VPFE_CMD_S_CCDC_RAW_PARAMS: experimental ioctl\n"); |
| 1708 | ret = ccdc_dev->hw_ops.set_params(param); | 1708 | if (ccdc_dev->hw_ops.set_params) { |
| 1709 | if (ret) { | 1709 | ret = ccdc_dev->hw_ops.set_params(param); |
| 1710 | v4l2_err(&vpfe_dev->v4l2_dev, | 1710 | if (ret) { |
| 1711 | "Error in setting parameters in CCDC\n"); | 1711 | v4l2_dbg(1, debug, &vpfe_dev->v4l2_dev, |
| 1712 | goto unlock_out; | 1712 | "Error setting parameters in CCDC\n"); |
| 1713 | } | 1713 | goto unlock_out; |
| 1714 | if (vpfe_get_ccdc_image_format(vpfe_dev, &vpfe_dev->fmt) < 0) { | 1714 | } |
| 1715 | v4l2_err(&vpfe_dev->v4l2_dev, | 1715 | if (vpfe_get_ccdc_image_format(vpfe_dev, |
| 1716 | "Invalid image format at CCDC\n"); | 1716 | &vpfe_dev->fmt) < 0) { |
| 1717 | goto unlock_out; | 1717 | v4l2_dbg(1, debug, &vpfe_dev->v4l2_dev, |
| 1718 | "Invalid image format at CCDC\n"); | ||
| 1719 | goto unlock_out; | ||
| 1720 | } | ||
| 1721 | } else { | ||
| 1722 | ret = -EINVAL; | ||
| 1723 | v4l2_dbg(1, debug, &vpfe_dev->v4l2_dev, | ||
| 1724 | "VPFE_CMD_S_CCDC_RAW_PARAMS not supported\n"); | ||
| 1718 | } | 1725 | } |
| 1719 | break; | 1726 | break; |
| 1720 | default: | 1727 | default: |
| @@ -1830,7 +1837,7 @@ static __init int vpfe_probe(struct platform_device *pdev) | |||
| 1830 | if (NULL == ccdc_cfg) { | 1837 | if (NULL == ccdc_cfg) { |
| 1831 | v4l2_err(pdev->dev.driver, | 1838 | v4l2_err(pdev->dev.driver, |
| 1832 | "Memory allocation failed for ccdc_cfg\n"); | 1839 | "Memory allocation failed for ccdc_cfg\n"); |
| 1833 | goto probe_free_dev_mem; | 1840 | goto probe_free_lock; |
| 1834 | } | 1841 | } |
| 1835 | 1842 | ||
| 1836 | strncpy(ccdc_cfg->name, vpfe_cfg->ccdc, 32); | 1843 | strncpy(ccdc_cfg->name, vpfe_cfg->ccdc, 32); |
| @@ -1982,8 +1989,9 @@ probe_out_video_release: | |||
| 1982 | probe_out_release_irq: | 1989 | probe_out_release_irq: |
| 1983 | free_irq(vpfe_dev->ccdc_irq0, vpfe_dev); | 1990 | free_irq(vpfe_dev->ccdc_irq0, vpfe_dev); |
| 1984 | probe_free_ccdc_cfg_mem: | 1991 | probe_free_ccdc_cfg_mem: |
| 1985 | mutex_unlock(&ccdc_lock); | ||
| 1986 | kfree(ccdc_cfg); | 1992 | kfree(ccdc_cfg); |
| 1993 | probe_free_lock: | ||
| 1994 | mutex_unlock(&ccdc_lock); | ||
| 1987 | probe_free_dev_mem: | 1995 | probe_free_dev_mem: |
| 1988 | kfree(vpfe_dev); | 1996 | kfree(vpfe_dev); |
| 1989 | return ret; | 1997 | return ret; |
diff --git a/drivers/media/video/gspca/sn9c20x.c b/drivers/media/video/gspca/sn9c20x.c index 38a6e15e096b..3dee3e5844b6 100644 --- a/drivers/media/video/gspca/sn9c20x.c +++ b/drivers/media/video/gspca/sn9c20x.c | |||
| @@ -1427,7 +1427,7 @@ static int input_kthread(void *data) | |||
| 1427 | struct gspca_dev *gspca_dev = (struct gspca_dev *)data; | 1427 | struct gspca_dev *gspca_dev = (struct gspca_dev *)data; |
| 1428 | struct sd *sd = (struct sd *) gspca_dev; | 1428 | struct sd *sd = (struct sd *) gspca_dev; |
| 1429 | 1429 | ||
| 1430 | DECLARE_WAIT_QUEUE_HEAD(wait); | 1430 | DECLARE_WAIT_QUEUE_HEAD_ONSTACK(wait); |
| 1431 | set_freezable(); | 1431 | set_freezable(); |
| 1432 | for (;;) { | 1432 | for (;;) { |
| 1433 | if (kthread_should_stop()) | 1433 | if (kthread_should_stop()) |
diff --git a/drivers/media/video/gspca/spca508.c b/drivers/media/video/gspca/spca508.c index 15b2eef8a3f6..edf0fe157501 100644 --- a/drivers/media/video/gspca/spca508.c +++ b/drivers/media/video/gspca/spca508.c | |||
| @@ -1513,7 +1513,6 @@ static const struct sd_desc sd_desc = { | |||
| 1513 | static const __devinitdata struct usb_device_id device_table[] = { | 1513 | static const __devinitdata struct usb_device_id device_table[] = { |
| 1514 | {USB_DEVICE(0x0130, 0x0130), .driver_info = HamaUSBSightcam}, | 1514 | {USB_DEVICE(0x0130, 0x0130), .driver_info = HamaUSBSightcam}, |
| 1515 | {USB_DEVICE(0x041e, 0x4018), .driver_info = CreativeVista}, | 1515 | {USB_DEVICE(0x041e, 0x4018), .driver_info = CreativeVista}, |
| 1516 | {USB_DEVICE(0x0461, 0x0815), .driver_info = MicroInnovationIC200}, | ||
| 1517 | {USB_DEVICE(0x0733, 0x0110), .driver_info = ViewQuestVQ110}, | 1516 | {USB_DEVICE(0x0733, 0x0110), .driver_info = ViewQuestVQ110}, |
| 1518 | {USB_DEVICE(0x0af9, 0x0010), .driver_info = HamaUSBSightcam}, | 1517 | {USB_DEVICE(0x0af9, 0x0010), .driver_info = HamaUSBSightcam}, |
| 1519 | {USB_DEVICE(0x0af9, 0x0011), .driver_info = HamaUSBSightcam2}, | 1518 | {USB_DEVICE(0x0af9, 0x0011), .driver_info = HamaUSBSightcam2}, |
diff --git a/drivers/media/video/gspca/spca561.c b/drivers/media/video/gspca/spca561.c index dc7f2b0fbc79..b9c80e2103b9 100644 --- a/drivers/media/video/gspca/spca561.c +++ b/drivers/media/video/gspca/spca561.c | |||
| @@ -1053,6 +1053,7 @@ static const __devinitdata struct usb_device_id device_table[] = { | |||
| 1053 | {USB_DEVICE(0x041e, 0x401a), .driver_info = Rev072A}, | 1053 | {USB_DEVICE(0x041e, 0x401a), .driver_info = Rev072A}, |
| 1054 | {USB_DEVICE(0x041e, 0x403b), .driver_info = Rev012A}, | 1054 | {USB_DEVICE(0x041e, 0x403b), .driver_info = Rev012A}, |
| 1055 | {USB_DEVICE(0x0458, 0x7004), .driver_info = Rev072A}, | 1055 | {USB_DEVICE(0x0458, 0x7004), .driver_info = Rev072A}, |
| 1056 | {USB_DEVICE(0x0461, 0x0815), .driver_info = Rev072A}, | ||
| 1056 | {USB_DEVICE(0x046d, 0x0928), .driver_info = Rev012A}, | 1057 | {USB_DEVICE(0x046d, 0x0928), .driver_info = Rev012A}, |
| 1057 | {USB_DEVICE(0x046d, 0x0929), .driver_info = Rev012A}, | 1058 | {USB_DEVICE(0x046d, 0x0929), .driver_info = Rev012A}, |
| 1058 | {USB_DEVICE(0x046d, 0x092a), .driver_info = Rev012A}, | 1059 | {USB_DEVICE(0x046d, 0x092a), .driver_info = Rev012A}, |
diff --git a/drivers/media/video/gspca/stv06xx/stv06xx.c b/drivers/media/video/gspca/stv06xx/stv06xx.c index af73da34c83f..14f179a19485 100644 --- a/drivers/media/video/gspca/stv06xx/stv06xx.c +++ b/drivers/media/video/gspca/stv06xx/stv06xx.c | |||
| @@ -524,8 +524,6 @@ static const __devinitdata struct usb_device_id device_table[] = { | |||
| 524 | {USB_DEVICE(0x046D, 0x08F5), .driver_info = BRIDGE_ST6422 }, | 524 | {USB_DEVICE(0x046D, 0x08F5), .driver_info = BRIDGE_ST6422 }, |
| 525 | /* QuickCam Messenger (new) */ | 525 | /* QuickCam Messenger (new) */ |
| 526 | {USB_DEVICE(0x046D, 0x08F6), .driver_info = BRIDGE_ST6422 }, | 526 | {USB_DEVICE(0x046D, 0x08F6), .driver_info = BRIDGE_ST6422 }, |
| 527 | /* QuickCam Messenger (new) */ | ||
| 528 | {USB_DEVICE(0x046D, 0x08DA), .driver_info = BRIDGE_ST6422 }, | ||
| 529 | {} | 527 | {} |
| 530 | }; | 528 | }; |
| 531 | MODULE_DEVICE_TABLE(usb, device_table); | 529 | MODULE_DEVICE_TABLE(usb, device_table); |
diff --git a/drivers/media/video/hexium_gemini.c b/drivers/media/video/hexium_gemini.c index e620a3a92f25..ad2c232baa6d 100644 --- a/drivers/media/video/hexium_gemini.c +++ b/drivers/media/video/hexium_gemini.c | |||
| @@ -356,9 +356,6 @@ static int hexium_attach(struct saa7146_dev *dev, struct saa7146_pci_extension_d | |||
| 356 | 356 | ||
| 357 | DEB_EE((".\n")); | 357 | DEB_EE((".\n")); |
| 358 | 358 | ||
| 359 | ret = saa7146_vv_devinit(dev); | ||
| 360 | if (ret) | ||
| 361 | return ret; | ||
| 362 | hexium = kzalloc(sizeof(struct hexium), GFP_KERNEL); | 359 | hexium = kzalloc(sizeof(struct hexium), GFP_KERNEL); |
| 363 | if (NULL == hexium) { | 360 | if (NULL == hexium) { |
| 364 | printk("hexium_gemini: not enough kernel memory in hexium_attach().\n"); | 361 | printk("hexium_gemini: not enough kernel memory in hexium_attach().\n"); |
diff --git a/drivers/media/video/hexium_orion.c b/drivers/media/video/hexium_orion.c index fe596a1c12a8..938a1f8f880a 100644 --- a/drivers/media/video/hexium_orion.c +++ b/drivers/media/video/hexium_orion.c | |||
| @@ -216,10 +216,6 @@ static int hexium_probe(struct saa7146_dev *dev) | |||
| 216 | return -EFAULT; | 216 | return -EFAULT; |
| 217 | } | 217 | } |
| 218 | 218 | ||
| 219 | err = saa7146_vv_devinit(dev); | ||
| 220 | if (err) | ||
| 221 | return err; | ||
| 222 | |||
| 223 | hexium = kzalloc(sizeof(struct hexium), GFP_KERNEL); | 219 | hexium = kzalloc(sizeof(struct hexium), GFP_KERNEL); |
| 224 | if (NULL == hexium) { | 220 | if (NULL == hexium) { |
| 225 | printk("hexium_orion: hexium_probe: not enough kernel memory.\n"); | 221 | printk("hexium_orion: hexium_probe: not enough kernel memory.\n"); |
diff --git a/drivers/media/video/mx1_camera.c b/drivers/media/video/mx1_camera.c index 3c8ebfcb742e..34a66019190e 100644 --- a/drivers/media/video/mx1_camera.c +++ b/drivers/media/video/mx1_camera.c | |||
| @@ -49,8 +49,6 @@ | |||
| 49 | /* | 49 | /* |
| 50 | * CSI registers | 50 | * CSI registers |
| 51 | */ | 51 | */ |
| 52 | #define DMA_CCR(x) (0x8c + ((x) << 6)) /* Control Registers */ | ||
| 53 | #define DMA_DIMR 0x08 /* Interrupt mask Register */ | ||
| 54 | #define CSICR1 0x00 /* CSI Control Register 1 */ | 52 | #define CSICR1 0x00 /* CSI Control Register 1 */ |
| 55 | #define CSISR 0x08 /* CSI Status Register */ | 53 | #define CSISR 0x08 /* CSI Status Register */ |
| 56 | #define CSIRXR 0x10 /* CSI RxFIFO Register */ | 54 | #define CSIRXR 0x10 /* CSI RxFIFO Register */ |
| @@ -784,7 +782,7 @@ static int __init mx1_camera_probe(struct platform_device *pdev) | |||
| 784 | pcdev); | 782 | pcdev); |
| 785 | 783 | ||
| 786 | imx_dma_config_channel(pcdev->dma_chan, IMX_DMA_TYPE_FIFO, | 784 | imx_dma_config_channel(pcdev->dma_chan, IMX_DMA_TYPE_FIFO, |
| 787 | IMX_DMA_MEMSIZE_32, DMA_REQ_CSI_R, 0); | 785 | IMX_DMA_MEMSIZE_32, MX1_DMA_REQ_CSI_R, 0); |
| 788 | /* burst length : 16 words = 64 bytes */ | 786 | /* burst length : 16 words = 64 bytes */ |
| 789 | imx_dma_config_burstlen(pcdev->dma_chan, 0); | 787 | imx_dma_config_burstlen(pcdev->dma_chan, 0); |
| 790 | 788 | ||
| @@ -798,8 +796,8 @@ static int __init mx1_camera_probe(struct platform_device *pdev) | |||
| 798 | set_fiq_handler(&mx1_camera_sof_fiq_start, &mx1_camera_sof_fiq_end - | 796 | set_fiq_handler(&mx1_camera_sof_fiq_start, &mx1_camera_sof_fiq_end - |
| 799 | &mx1_camera_sof_fiq_start); | 797 | &mx1_camera_sof_fiq_start); |
| 800 | 798 | ||
| 801 | regs.ARM_r8 = DMA_BASE + DMA_DIMR; | 799 | regs.ARM_r8 = (long)MX1_DMA_DIMR; |
| 802 | regs.ARM_r9 = DMA_BASE + DMA_CCR(pcdev->dma_chan); | 800 | regs.ARM_r9 = (long)MX1_DMA_CCR(pcdev->dma_chan); |
| 803 | regs.ARM_r10 = (long)pcdev->base + CSICR1; | 801 | regs.ARM_r10 = (long)pcdev->base + CSICR1; |
| 804 | regs.ARM_fp = (long)pcdev->base + CSISR; | 802 | regs.ARM_fp = (long)pcdev->base + CSISR; |
| 805 | regs.ARM_sp = 1 << pcdev->dma_chan; | 803 | regs.ARM_sp = 1 << pcdev->dma_chan; |
diff --git a/drivers/media/video/mxb.c b/drivers/media/video/mxb.c index 9f01f14e4aa2..ef0c8178f255 100644 --- a/drivers/media/video/mxb.c +++ b/drivers/media/video/mxb.c | |||
| @@ -169,11 +169,7 @@ static struct saa7146_extension extension; | |||
| 169 | static int mxb_probe(struct saa7146_dev *dev) | 169 | static int mxb_probe(struct saa7146_dev *dev) |
| 170 | { | 170 | { |
| 171 | struct mxb *mxb = NULL; | 171 | struct mxb *mxb = NULL; |
| 172 | int err; | ||
| 173 | 172 | ||
| 174 | err = saa7146_vv_devinit(dev); | ||
| 175 | if (err) | ||
| 176 | return err; | ||
| 177 | mxb = kzalloc(sizeof(struct mxb), GFP_KERNEL); | 173 | mxb = kzalloc(sizeof(struct mxb), GFP_KERNEL); |
| 178 | if (mxb == NULL) { | 174 | if (mxb == NULL) { |
| 179 | DEB_D(("not enough kernel memory.\n")); | 175 | DEB_D(("not enough kernel memory.\n")); |
| @@ -699,14 +695,17 @@ static struct saa7146_ext_vv vv_data; | |||
| 699 | /* this function only gets called when the probing was successful */ | 695 | /* this function only gets called when the probing was successful */ |
| 700 | static int mxb_attach(struct saa7146_dev *dev, struct saa7146_pci_extension_data *info) | 696 | static int mxb_attach(struct saa7146_dev *dev, struct saa7146_pci_extension_data *info) |
| 701 | { | 697 | { |
| 702 | struct mxb *mxb = (struct mxb *)dev->ext_priv; | 698 | struct mxb *mxb; |
| 703 | 699 | ||
| 704 | DEB_EE(("dev:%p\n", dev)); | 700 | DEB_EE(("dev:%p\n", dev)); |
| 705 | 701 | ||
| 706 | /* checking for i2c-devices can be omitted here, because we | ||
| 707 | already did this in "mxb_vl42_probe" */ | ||
| 708 | |||
| 709 | saa7146_vv_init(dev, &vv_data); | 702 | saa7146_vv_init(dev, &vv_data); |
| 703 | if (mxb_probe(dev)) { | ||
| 704 | saa7146_vv_release(dev); | ||
| 705 | return -1; | ||
| 706 | } | ||
| 707 | mxb = (struct mxb *)dev->ext_priv; | ||
| 708 | |||
| 710 | vv_data.ops.vidioc_queryctrl = vidioc_queryctrl; | 709 | vv_data.ops.vidioc_queryctrl = vidioc_queryctrl; |
| 711 | vv_data.ops.vidioc_g_ctrl = vidioc_g_ctrl; | 710 | vv_data.ops.vidioc_g_ctrl = vidioc_g_ctrl; |
| 712 | vv_data.ops.vidioc_s_ctrl = vidioc_s_ctrl; | 711 | vv_data.ops.vidioc_s_ctrl = vidioc_s_ctrl; |
| @@ -726,6 +725,7 @@ static int mxb_attach(struct saa7146_dev *dev, struct saa7146_pci_extension_data | |||
| 726 | vv_data.ops.vidioc_default = vidioc_default; | 725 | vv_data.ops.vidioc_default = vidioc_default; |
| 727 | if (saa7146_register_device(&mxb->video_dev, dev, "mxb", VFL_TYPE_GRABBER)) { | 726 | if (saa7146_register_device(&mxb->video_dev, dev, "mxb", VFL_TYPE_GRABBER)) { |
| 728 | ERR(("cannot register capture v4l2 device. skipping.\n")); | 727 | ERR(("cannot register capture v4l2 device. skipping.\n")); |
| 728 | saa7146_vv_release(dev); | ||
| 729 | return -1; | 729 | return -1; |
| 730 | } | 730 | } |
| 731 | 731 | ||
| @@ -846,7 +846,6 @@ static struct saa7146_extension extension = { | |||
| 846 | .pci_tbl = &pci_tbl[0], | 846 | .pci_tbl = &pci_tbl[0], |
| 847 | .module = THIS_MODULE, | 847 | .module = THIS_MODULE, |
| 848 | 848 | ||
| 849 | .probe = mxb_probe, | ||
| 850 | .attach = mxb_attach, | 849 | .attach = mxb_attach, |
| 851 | .detach = mxb_detach, | 850 | .detach = mxb_detach, |
| 852 | 851 | ||
diff --git a/drivers/media/video/omap24xxcam.c b/drivers/media/video/omap24xxcam.c index b189fe63394b..ce76d952e161 100644 --- a/drivers/media/video/omap24xxcam.c +++ b/drivers/media/video/omap24xxcam.c | |||
| @@ -1405,7 +1405,7 @@ static int omap24xxcam_mmap_buffers(struct file *file, | |||
| 1405 | } | 1405 | } |
| 1406 | 1406 | ||
| 1407 | size = 0; | 1407 | size = 0; |
| 1408 | for (i = first; i <= last; i++) { | 1408 | for (i = first; i <= last && i < VIDEO_MAX_FRAME; i++) { |
| 1409 | struct videobuf_dmabuf *dma = videobuf_to_dma(vbq->bufs[i]); | 1409 | struct videobuf_dmabuf *dma = videobuf_to_dma(vbq->bufs[i]); |
| 1410 | 1410 | ||
| 1411 | for (j = 0; j < dma->sglen; j++) { | 1411 | for (j = 0; j < dma->sglen; j++) { |
diff --git a/drivers/media/video/pxa_camera.c b/drivers/media/video/pxa_camera.c index 5ecc30daef2d..04bf5c11308d 100644 --- a/drivers/media/video/pxa_camera.c +++ b/drivers/media/video/pxa_camera.c | |||
| @@ -609,12 +609,9 @@ static void pxa_dma_add_tail_buf(struct pxa_camera_dev *pcdev, | |||
| 609 | */ | 609 | */ |
| 610 | static void pxa_camera_start_capture(struct pxa_camera_dev *pcdev) | 610 | static void pxa_camera_start_capture(struct pxa_camera_dev *pcdev) |
| 611 | { | 611 | { |
| 612 | unsigned long cicr0, cifr; | 612 | unsigned long cicr0; |
| 613 | 613 | ||
| 614 | dev_dbg(pcdev->soc_host.v4l2_dev.dev, "%s\n", __func__); | 614 | dev_dbg(pcdev->soc_host.v4l2_dev.dev, "%s\n", __func__); |
| 615 | /* Reset the FIFOs */ | ||
| 616 | cifr = __raw_readl(pcdev->base + CIFR) | CIFR_RESET_F; | ||
| 617 | __raw_writel(cifr, pcdev->base + CIFR); | ||
| 618 | /* Enable End-Of-Frame Interrupt */ | 615 | /* Enable End-Of-Frame Interrupt */ |
| 619 | cicr0 = __raw_readl(pcdev->base + CICR0) | CICR0_ENB; | 616 | cicr0 = __raw_readl(pcdev->base + CICR0) | CICR0_ENB; |
| 620 | cicr0 &= ~CICR0_EOFM; | 617 | cicr0 &= ~CICR0_EOFM; |
| @@ -935,7 +932,7 @@ static void pxa_camera_deactivate(struct pxa_camera_dev *pcdev) | |||
| 935 | static irqreturn_t pxa_camera_irq(int irq, void *data) | 932 | static irqreturn_t pxa_camera_irq(int irq, void *data) |
| 936 | { | 933 | { |
| 937 | struct pxa_camera_dev *pcdev = data; | 934 | struct pxa_camera_dev *pcdev = data; |
| 938 | unsigned long status, cicr0; | 935 | unsigned long status, cifr, cicr0; |
| 939 | struct pxa_buffer *buf; | 936 | struct pxa_buffer *buf; |
| 940 | struct videobuf_buffer *vb; | 937 | struct videobuf_buffer *vb; |
| 941 | 938 | ||
| @@ -949,6 +946,10 @@ static irqreturn_t pxa_camera_irq(int irq, void *data) | |||
| 949 | __raw_writel(status, pcdev->base + CISR); | 946 | __raw_writel(status, pcdev->base + CISR); |
| 950 | 947 | ||
| 951 | if (status & CISR_EOF) { | 948 | if (status & CISR_EOF) { |
| 949 | /* Reset the FIFOs */ | ||
| 950 | cifr = __raw_readl(pcdev->base + CIFR) | CIFR_RESET_F; | ||
| 951 | __raw_writel(cifr, pcdev->base + CIFR); | ||
| 952 | |||
| 952 | pcdev->active = list_first_entry(&pcdev->capture, | 953 | pcdev->active = list_first_entry(&pcdev->capture, |
| 953 | struct pxa_buffer, vb.queue); | 954 | struct pxa_buffer, vb.queue); |
| 954 | vb = &pcdev->active->vb; | 955 | vb = &pcdev->active->vb; |
diff --git a/drivers/media/video/sh_mobile_ceu_camera.c b/drivers/media/video/sh_mobile_ceu_camera.c index 6e16b3979326..1ad980f8e770 100644 --- a/drivers/media/video/sh_mobile_ceu_camera.c +++ b/drivers/media/video/sh_mobile_ceu_camera.c | |||
| @@ -1633,7 +1633,7 @@ static int sh_mobile_ceu_try_fmt(struct soc_camera_device *icd, | |||
| 1633 | height = pix->height; | 1633 | height = pix->height; |
| 1634 | 1634 | ||
| 1635 | pix->bytesperline = soc_mbus_bytes_per_line(width, xlate->host_fmt); | 1635 | pix->bytesperline = soc_mbus_bytes_per_line(width, xlate->host_fmt); |
| 1636 | if (pix->bytesperline < 0) | 1636 | if ((int)pix->bytesperline < 0) |
| 1637 | return pix->bytesperline; | 1637 | return pix->bytesperline; |
| 1638 | pix->sizeimage = height * pix->bytesperline; | 1638 | pix->sizeimage = height * pix->bytesperline; |
| 1639 | 1639 | ||
diff --git a/drivers/pcmcia/cs.c b/drivers/pcmcia/cs.c index 75ed866e6953..c3383750e333 100644 --- a/drivers/pcmcia/cs.c +++ b/drivers/pcmcia/cs.c | |||
| @@ -671,20 +671,22 @@ static int pccardd(void *__skt) | |||
| 671 | socket_remove(skt); | 671 | socket_remove(skt); |
| 672 | if (sysfs_events & PCMCIA_UEVENT_INSERT) | 672 | if (sysfs_events & PCMCIA_UEVENT_INSERT) |
| 673 | socket_insert(skt); | 673 | socket_insert(skt); |
| 674 | if ((sysfs_events & PCMCIA_UEVENT_RESUME) && | ||
| 675 | !(skt->state & SOCKET_CARDBUS)) { | ||
| 676 | ret = socket_resume(skt); | ||
| 677 | if (!ret && skt->callback) | ||
| 678 | skt->callback->resume(skt); | ||
| 679 | } | ||
| 680 | if ((sysfs_events & PCMCIA_UEVENT_SUSPEND) && | 674 | if ((sysfs_events & PCMCIA_UEVENT_SUSPEND) && |
| 681 | !(skt->state & SOCKET_CARDBUS)) { | 675 | !(skt->state & SOCKET_CARDBUS)) { |
| 682 | if (skt->callback) | 676 | if (skt->callback) |
| 683 | ret = skt->callback->suspend(skt); | 677 | ret = skt->callback->suspend(skt); |
| 684 | else | 678 | else |
| 685 | ret = 0; | 679 | ret = 0; |
| 686 | if (!ret) | 680 | if (!ret) { |
| 687 | socket_suspend(skt); | 681 | socket_suspend(skt); |
| 682 | msleep(100); | ||
| 683 | } | ||
| 684 | } | ||
| 685 | if ((sysfs_events & PCMCIA_UEVENT_RESUME) && | ||
| 686 | !(skt->state & SOCKET_CARDBUS)) { | ||
| 687 | ret = socket_resume(skt); | ||
| 688 | if (!ret && skt->callback) | ||
| 689 | skt->callback->resume(skt); | ||
| 688 | } | 690 | } |
| 689 | if ((sysfs_events & PCMCIA_UEVENT_REQUERY) && | 691 | if ((sysfs_events & PCMCIA_UEVENT_REQUERY) && |
| 690 | !(skt->state & SOCKET_CARDBUS)) { | 692 | !(skt->state & SOCKET_CARDBUS)) { |
diff --git a/drivers/pcmcia/ds.c b/drivers/pcmcia/ds.c index 508f94a2a78d..041eee43fd8d 100644 --- a/drivers/pcmcia/ds.c +++ b/drivers/pcmcia/ds.c | |||
| @@ -1283,6 +1283,7 @@ static int ds_event(struct pcmcia_socket *skt, event_t event, int priority) | |||
| 1283 | destroy_cis_cache(skt); | 1283 | destroy_cis_cache(skt); |
| 1284 | kfree(skt->fake_cis); | 1284 | kfree(skt->fake_cis); |
| 1285 | skt->fake_cis = NULL; | 1285 | skt->fake_cis = NULL; |
| 1286 | s->functions = 0; | ||
| 1286 | mutex_unlock(&s->ops_mutex); | 1287 | mutex_unlock(&s->ops_mutex); |
| 1287 | /* now, add the new card */ | 1288 | /* now, add the new card */ |
| 1288 | ds_event(skt, CS_EVENT_CARD_INSERTION, | 1289 | ds_event(skt, CS_EVENT_CARD_INSERTION, |
diff --git a/drivers/pcmcia/pcmcia_ioctl.c b/drivers/pcmcia/pcmcia_ioctl.c index 104e73d5d86c..7631faa0cadd 100644 --- a/drivers/pcmcia/pcmcia_ioctl.c +++ b/drivers/pcmcia/pcmcia_ioctl.c | |||
| @@ -711,7 +711,7 @@ static int ds_open(struct inode *inode, struct file *file) | |||
| 711 | warning_printed = 1; | 711 | warning_printed = 1; |
| 712 | } | 712 | } |
| 713 | 713 | ||
| 714 | if (s->pcmcia_state.present) | 714 | if (atomic_read(&s->present)) |
| 715 | queue_event(user, CS_EVENT_CARD_INSERTION); | 715 | queue_event(user, CS_EVENT_CARD_INSERTION); |
| 716 | out: | 716 | out: |
| 717 | unlock_kernel(); | 717 | unlock_kernel(); |
| @@ -770,9 +770,6 @@ static ssize_t ds_read(struct file *file, char __user *buf, | |||
| 770 | return -EIO; | 770 | return -EIO; |
| 771 | 771 | ||
| 772 | s = user->socket; | 772 | s = user->socket; |
| 773 | if (s->pcmcia_state.dead) | ||
| 774 | return -EIO; | ||
| 775 | |||
| 776 | ret = wait_event_interruptible(s->queue, !queue_empty(user)); | 773 | ret = wait_event_interruptible(s->queue, !queue_empty(user)); |
| 777 | if (ret == 0) | 774 | if (ret == 0) |
| 778 | ret = put_user(get_queued_event(user), (int __user *)buf) ? -EFAULT : 4; | 775 | ret = put_user(get_queued_event(user), (int __user *)buf) ? -EFAULT : 4; |
| @@ -838,8 +835,6 @@ static int ds_ioctl(struct inode *inode, struct file *file, | |||
| 838 | return -EIO; | 835 | return -EIO; |
| 839 | 836 | ||
| 840 | s = user->socket; | 837 | s = user->socket; |
| 841 | if (s->pcmcia_state.dead) | ||
| 842 | return -EIO; | ||
| 843 | 838 | ||
| 844 | size = (cmd & IOCSIZE_MASK) >> IOCSIZE_SHIFT; | 839 | size = (cmd & IOCSIZE_MASK) >> IOCSIZE_SHIFT; |
| 845 | if (size > sizeof(ds_ioctl_arg_t)) | 840 | if (size > sizeof(ds_ioctl_arg_t)) |
diff --git a/drivers/pnp/pnpacpi/rsparser.c b/drivers/pnp/pnpacpi/rsparser.c index 35bb44af49b3..100e4d9372f1 100644 --- a/drivers/pnp/pnpacpi/rsparser.c +++ b/drivers/pnp/pnpacpi/rsparser.c | |||
| @@ -274,26 +274,6 @@ static void pnpacpi_parse_allocated_busresource(struct pnp_dev *dev, | |||
| 274 | pnp_add_bus_resource(dev, start, end); | 274 | pnp_add_bus_resource(dev, start, end); |
| 275 | } | 275 | } |
| 276 | 276 | ||
| 277 | static u64 addr_space_length(struct pnp_dev *dev, u64 min, u64 max, u64 len) | ||
| 278 | { | ||
| 279 | u64 max_len; | ||
| 280 | |||
| 281 | max_len = max - min + 1; | ||
| 282 | if (len <= max_len) | ||
| 283 | return len; | ||
| 284 | |||
| 285 | /* | ||
| 286 | * Per 6.4.3.5, _LEN cannot exceed _MAX - _MIN + 1, but some BIOSes | ||
| 287 | * don't do this correctly, e.g., | ||
| 288 | * https://bugzilla.kernel.org/show_bug.cgi?id=15480 | ||
| 289 | */ | ||
| 290 | dev_info(&dev->dev, | ||
| 291 | "resource length %#llx doesn't fit in %#llx-%#llx, trimming\n", | ||
| 292 | (unsigned long long) len, (unsigned long long) min, | ||
| 293 | (unsigned long long) max); | ||
| 294 | return max_len; | ||
| 295 | } | ||
| 296 | |||
| 297 | static void pnpacpi_parse_allocated_address_space(struct pnp_dev *dev, | 277 | static void pnpacpi_parse_allocated_address_space(struct pnp_dev *dev, |
| 298 | struct acpi_resource *res) | 278 | struct acpi_resource *res) |
| 299 | { | 279 | { |
| @@ -309,7 +289,8 @@ static void pnpacpi_parse_allocated_address_space(struct pnp_dev *dev, | |||
| 309 | return; | 289 | return; |
| 310 | } | 290 | } |
| 311 | 291 | ||
| 312 | len = addr_space_length(dev, p->minimum, p->maximum, p->address_length); | 292 | /* Windows apparently computes length rather than using _LEN */ |
| 293 | len = p->maximum - p->minimum + 1; | ||
| 313 | window = (p->producer_consumer == ACPI_PRODUCER) ? 1 : 0; | 294 | window = (p->producer_consumer == ACPI_PRODUCER) ? 1 : 0; |
| 314 | 295 | ||
| 315 | if (p->resource_type == ACPI_MEMORY_RANGE) | 296 | if (p->resource_type == ACPI_MEMORY_RANGE) |
| @@ -330,7 +311,8 @@ static void pnpacpi_parse_allocated_ext_address_space(struct pnp_dev *dev, | |||
| 330 | int window; | 311 | int window; |
| 331 | u64 len; | 312 | u64 len; |
| 332 | 313 | ||
| 333 | len = addr_space_length(dev, p->minimum, p->maximum, p->address_length); | 314 | /* Windows apparently computes length rather than using _LEN */ |
| 315 | len = p->maximum - p->minimum + 1; | ||
| 334 | window = (p->producer_consumer == ACPI_PRODUCER) ? 1 : 0; | 316 | window = (p->producer_consumer == ACPI_PRODUCER) ? 1 : 0; |
| 335 | 317 | ||
| 336 | if (p->resource_type == ACPI_MEMORY_RANGE) | 318 | if (p->resource_type == ACPI_MEMORY_RANGE) |
diff --git a/drivers/pnp/resource.c b/drivers/pnp/resource.c index 2e54e6a23c72..e3446ab8b563 100644 --- a/drivers/pnp/resource.c +++ b/drivers/pnp/resource.c | |||
| @@ -211,6 +211,8 @@ int pnp_check_port(struct pnp_dev *dev, struct resource *res) | |||
| 211 | if (tres->flags & IORESOURCE_IO) { | 211 | if (tres->flags & IORESOURCE_IO) { |
| 212 | if (cannot_compare(tres->flags)) | 212 | if (cannot_compare(tres->flags)) |
| 213 | continue; | 213 | continue; |
| 214 | if (tres->flags & IORESOURCE_WINDOW) | ||
| 215 | continue; | ||
| 214 | tport = &tres->start; | 216 | tport = &tres->start; |
| 215 | tend = &tres->end; | 217 | tend = &tres->end; |
| 216 | if (ranged_conflict(port, end, tport, tend)) | 218 | if (ranged_conflict(port, end, tport, tend)) |
| @@ -271,6 +273,8 @@ int pnp_check_mem(struct pnp_dev *dev, struct resource *res) | |||
| 271 | if (tres->flags & IORESOURCE_MEM) { | 273 | if (tres->flags & IORESOURCE_MEM) { |
| 272 | if (cannot_compare(tres->flags)) | 274 | if (cannot_compare(tres->flags)) |
| 273 | continue; | 275 | continue; |
| 276 | if (tres->flags & IORESOURCE_WINDOW) | ||
| 277 | continue; | ||
| 274 | taddr = &tres->start; | 278 | taddr = &tres->start; |
| 275 | tend = &tres->end; | 279 | tend = &tres->end; |
| 276 | if (ranged_conflict(addr, end, taddr, tend)) | 280 | if (ranged_conflict(addr, end, taddr, tend)) |
diff --git a/drivers/video/sh_mobile_lcdcfb.c b/drivers/video/sh_mobile_lcdcfb.c index e14bd0749129..e8c769944812 100644 --- a/drivers/video/sh_mobile_lcdcfb.c +++ b/drivers/video/sh_mobile_lcdcfb.c | |||
| @@ -695,6 +695,7 @@ static int sh_mobile_lcdc_setup_clocks(struct platform_device *pdev, | |||
| 695 | * 1) Enable Runtime PM | 695 | * 1) Enable Runtime PM |
| 696 | * 2) Force Runtime PM Resume since hardware is accessed from probe() | 696 | * 2) Force Runtime PM Resume since hardware is accessed from probe() |
| 697 | */ | 697 | */ |
| 698 | priv->dev = &pdev->dev; | ||
| 698 | pm_runtime_enable(priv->dev); | 699 | pm_runtime_enable(priv->dev); |
| 699 | pm_runtime_resume(priv->dev); | 700 | pm_runtime_resume(priv->dev); |
| 700 | return 0; | 701 | return 0; |
| @@ -957,25 +958,24 @@ static int __devinit sh_mobile_lcdc_probe(struct platform_device *pdev) | |||
| 957 | 958 | ||
| 958 | if (!pdev->dev.platform_data) { | 959 | if (!pdev->dev.platform_data) { |
| 959 | dev_err(&pdev->dev, "no platform data defined\n"); | 960 | dev_err(&pdev->dev, "no platform data defined\n"); |
| 960 | error = -EINVAL; | 961 | return -EINVAL; |
| 961 | goto err0; | ||
| 962 | } | 962 | } |
| 963 | 963 | ||
| 964 | res = platform_get_resource(pdev, IORESOURCE_MEM, 0); | 964 | res = platform_get_resource(pdev, IORESOURCE_MEM, 0); |
| 965 | i = platform_get_irq(pdev, 0); | 965 | i = platform_get_irq(pdev, 0); |
| 966 | if (!res || i < 0) { | 966 | if (!res || i < 0) { |
| 967 | dev_err(&pdev->dev, "cannot get platform resources\n"); | 967 | dev_err(&pdev->dev, "cannot get platform resources\n"); |
| 968 | error = -ENOENT; | 968 | return -ENOENT; |
| 969 | goto err0; | ||
| 970 | } | 969 | } |
| 971 | 970 | ||
| 972 | priv = kzalloc(sizeof(*priv), GFP_KERNEL); | 971 | priv = kzalloc(sizeof(*priv), GFP_KERNEL); |
| 973 | if (!priv) { | 972 | if (!priv) { |
| 974 | dev_err(&pdev->dev, "cannot allocate device data\n"); | 973 | dev_err(&pdev->dev, "cannot allocate device data\n"); |
| 975 | error = -ENOMEM; | 974 | return -ENOMEM; |
| 976 | goto err0; | ||
| 977 | } | 975 | } |
| 978 | 976 | ||
| 977 | platform_set_drvdata(pdev, priv); | ||
| 978 | |||
| 979 | error = request_irq(i, sh_mobile_lcdc_irq, IRQF_DISABLED, | 979 | error = request_irq(i, sh_mobile_lcdc_irq, IRQF_DISABLED, |
| 980 | dev_name(&pdev->dev), priv); | 980 | dev_name(&pdev->dev), priv); |
| 981 | if (error) { | 981 | if (error) { |
| @@ -984,8 +984,6 @@ static int __devinit sh_mobile_lcdc_probe(struct platform_device *pdev) | |||
| 984 | } | 984 | } |
| 985 | 985 | ||
| 986 | priv->irq = i; | 986 | priv->irq = i; |
| 987 | priv->dev = &pdev->dev; | ||
| 988 | platform_set_drvdata(pdev, priv); | ||
| 989 | pdata = pdev->dev.platform_data; | 987 | pdata = pdev->dev.platform_data; |
| 990 | 988 | ||
| 991 | j = 0; | 989 | j = 0; |
| @@ -1099,9 +1097,9 @@ static int __devinit sh_mobile_lcdc_probe(struct platform_device *pdev) | |||
| 1099 | info = ch->info; | 1097 | info = ch->info; |
| 1100 | 1098 | ||
| 1101 | if (info->fbdefio) { | 1099 | if (info->fbdefio) { |
| 1102 | priv->ch->sglist = vmalloc(sizeof(struct scatterlist) * | 1100 | ch->sglist = vmalloc(sizeof(struct scatterlist) * |
| 1103 | info->fix.smem_len >> PAGE_SHIFT); | 1101 | info->fix.smem_len >> PAGE_SHIFT); |
| 1104 | if (!priv->ch->sglist) { | 1102 | if (!ch->sglist) { |
| 1105 | dev_err(&pdev->dev, "cannot allocate sglist\n"); | 1103 | dev_err(&pdev->dev, "cannot allocate sglist\n"); |
| 1106 | goto err1; | 1104 | goto err1; |
| 1107 | } | 1105 | } |
| @@ -1126,9 +1124,9 @@ static int __devinit sh_mobile_lcdc_probe(struct platform_device *pdev) | |||
| 1126 | } | 1124 | } |
| 1127 | 1125 | ||
| 1128 | return 0; | 1126 | return 0; |
| 1129 | err1: | 1127 | err1: |
| 1130 | sh_mobile_lcdc_remove(pdev); | 1128 | sh_mobile_lcdc_remove(pdev); |
| 1131 | err0: | 1129 | |
| 1132 | return error; | 1130 | return error; |
| 1133 | } | 1131 | } |
| 1134 | 1132 | ||
| @@ -1139,7 +1137,7 @@ static int sh_mobile_lcdc_remove(struct platform_device *pdev) | |||
| 1139 | int i; | 1137 | int i; |
| 1140 | 1138 | ||
| 1141 | for (i = 0; i < ARRAY_SIZE(priv->ch); i++) | 1139 | for (i = 0; i < ARRAY_SIZE(priv->ch); i++) |
| 1142 | if (priv->ch[i].info->dev) | 1140 | if (priv->ch[i].info && priv->ch[i].info->dev) |
| 1143 | unregister_framebuffer(priv->ch[i].info); | 1141 | unregister_framebuffer(priv->ch[i].info); |
| 1144 | 1142 | ||
| 1145 | sh_mobile_lcdc_stop(priv); | 1143 | sh_mobile_lcdc_stop(priv); |
| @@ -1162,7 +1160,8 @@ static int sh_mobile_lcdc_remove(struct platform_device *pdev) | |||
| 1162 | if (priv->dot_clk) | 1160 | if (priv->dot_clk) |
| 1163 | clk_put(priv->dot_clk); | 1161 | clk_put(priv->dot_clk); |
| 1164 | 1162 | ||
| 1165 | pm_runtime_disable(priv->dev); | 1163 | if (priv->dev) |
| 1164 | pm_runtime_disable(priv->dev); | ||
| 1166 | 1165 | ||
| 1167 | if (priv->base) | 1166 | if (priv->base) |
| 1168 | iounmap(priv->base); | 1167 | iounmap(priv->base); |
diff --git a/fs/nfs/delegation.c b/fs/nfs/delegation.c index 15671245c6ee..ea61d26e7871 100644 --- a/fs/nfs/delegation.c +++ b/fs/nfs/delegation.c | |||
| @@ -24,6 +24,8 @@ | |||
| 24 | 24 | ||
| 25 | static void nfs_do_free_delegation(struct nfs_delegation *delegation) | 25 | static void nfs_do_free_delegation(struct nfs_delegation *delegation) |
| 26 | { | 26 | { |
| 27 | if (delegation->cred) | ||
| 28 | put_rpccred(delegation->cred); | ||
| 27 | kfree(delegation); | 29 | kfree(delegation); |
| 28 | } | 30 | } |
| 29 | 31 | ||
| @@ -36,13 +38,7 @@ static void nfs_free_delegation_callback(struct rcu_head *head) | |||
| 36 | 38 | ||
| 37 | static void nfs_free_delegation(struct nfs_delegation *delegation) | 39 | static void nfs_free_delegation(struct nfs_delegation *delegation) |
| 38 | { | 40 | { |
| 39 | struct rpc_cred *cred; | ||
| 40 | |||
| 41 | cred = rcu_dereference(delegation->cred); | ||
| 42 | rcu_assign_pointer(delegation->cred, NULL); | ||
| 43 | call_rcu(&delegation->rcu, nfs_free_delegation_callback); | 41 | call_rcu(&delegation->rcu, nfs_free_delegation_callback); |
| 44 | if (cred) | ||
| 45 | put_rpccred(cred); | ||
| 46 | } | 42 | } |
| 47 | 43 | ||
| 48 | void nfs_mark_delegation_referenced(struct nfs_delegation *delegation) | 44 | void nfs_mark_delegation_referenced(struct nfs_delegation *delegation) |
| @@ -129,21 +125,35 @@ again: | |||
| 129 | */ | 125 | */ |
| 130 | void nfs_inode_reclaim_delegation(struct inode *inode, struct rpc_cred *cred, struct nfs_openres *res) | 126 | void nfs_inode_reclaim_delegation(struct inode *inode, struct rpc_cred *cred, struct nfs_openres *res) |
| 131 | { | 127 | { |
| 132 | struct nfs_delegation *delegation = NFS_I(inode)->delegation; | 128 | struct nfs_delegation *delegation; |
| 133 | struct rpc_cred *oldcred; | 129 | struct rpc_cred *oldcred = NULL; |
| 134 | 130 | ||
| 135 | if (delegation == NULL) | 131 | rcu_read_lock(); |
| 136 | return; | 132 | delegation = rcu_dereference(NFS_I(inode)->delegation); |
| 137 | memcpy(delegation->stateid.data, res->delegation.data, | 133 | if (delegation != NULL) { |
| 138 | sizeof(delegation->stateid.data)); | 134 | spin_lock(&delegation->lock); |
| 139 | delegation->type = res->delegation_type; | 135 | if (delegation->inode != NULL) { |
| 140 | delegation->maxsize = res->maxsize; | 136 | memcpy(delegation->stateid.data, res->delegation.data, |
| 141 | oldcred = delegation->cred; | 137 | sizeof(delegation->stateid.data)); |
| 142 | delegation->cred = get_rpccred(cred); | 138 | delegation->type = res->delegation_type; |
| 143 | clear_bit(NFS_DELEGATION_NEED_RECLAIM, &delegation->flags); | 139 | delegation->maxsize = res->maxsize; |
| 144 | NFS_I(inode)->delegation_state = delegation->type; | 140 | oldcred = delegation->cred; |
| 145 | smp_wmb(); | 141 | delegation->cred = get_rpccred(cred); |
| 146 | put_rpccred(oldcred); | 142 | clear_bit(NFS_DELEGATION_NEED_RECLAIM, |
| 143 | &delegation->flags); | ||
| 144 | NFS_I(inode)->delegation_state = delegation->type; | ||
| 145 | spin_unlock(&delegation->lock); | ||
| 146 | put_rpccred(oldcred); | ||
| 147 | rcu_read_unlock(); | ||
| 148 | } else { | ||
| 149 | /* We appear to have raced with a delegation return. */ | ||
| 150 | spin_unlock(&delegation->lock); | ||
| 151 | rcu_read_unlock(); | ||
| 152 | nfs_inode_set_delegation(inode, cred, res); | ||
| 153 | } | ||
| 154 | } else { | ||
| 155 | rcu_read_unlock(); | ||
| 156 | } | ||
| 147 | } | 157 | } |
| 148 | 158 | ||
| 149 | static int nfs_do_return_delegation(struct inode *inode, struct nfs_delegation *delegation, int issync) | 159 | static int nfs_do_return_delegation(struct inode *inode, struct nfs_delegation *delegation, int issync) |
| @@ -166,9 +176,13 @@ static struct inode *nfs_delegation_grab_inode(struct nfs_delegation *delegation | |||
| 166 | return inode; | 176 | return inode; |
| 167 | } | 177 | } |
| 168 | 178 | ||
| 169 | static struct nfs_delegation *nfs_detach_delegation_locked(struct nfs_inode *nfsi, const nfs4_stateid *stateid) | 179 | static struct nfs_delegation *nfs_detach_delegation_locked(struct nfs_inode *nfsi, |
| 180 | const nfs4_stateid *stateid, | ||
| 181 | struct nfs_client *clp) | ||
| 170 | { | 182 | { |
| 171 | struct nfs_delegation *delegation = rcu_dereference(nfsi->delegation); | 183 | struct nfs_delegation *delegation = |
| 184 | rcu_dereference_protected(nfsi->delegation, | ||
| 185 | lockdep_is_held(&clp->cl_lock)); | ||
| 172 | 186 | ||
| 173 | if (delegation == NULL) | 187 | if (delegation == NULL) |
| 174 | goto nomatch; | 188 | goto nomatch; |
| @@ -195,7 +209,7 @@ int nfs_inode_set_delegation(struct inode *inode, struct rpc_cred *cred, struct | |||
| 195 | { | 209 | { |
| 196 | struct nfs_client *clp = NFS_SERVER(inode)->nfs_client; | 210 | struct nfs_client *clp = NFS_SERVER(inode)->nfs_client; |
| 197 | struct nfs_inode *nfsi = NFS_I(inode); | 211 | struct nfs_inode *nfsi = NFS_I(inode); |
| 198 | struct nfs_delegation *delegation; | 212 | struct nfs_delegation *delegation, *old_delegation; |
| 199 | struct nfs_delegation *freeme = NULL; | 213 | struct nfs_delegation *freeme = NULL; |
| 200 | int status = 0; | 214 | int status = 0; |
| 201 | 215 | ||
| @@ -213,10 +227,12 @@ int nfs_inode_set_delegation(struct inode *inode, struct rpc_cred *cred, struct | |||
| 213 | spin_lock_init(&delegation->lock); | 227 | spin_lock_init(&delegation->lock); |
| 214 | 228 | ||
| 215 | spin_lock(&clp->cl_lock); | 229 | spin_lock(&clp->cl_lock); |
| 216 | if (rcu_dereference(nfsi->delegation) != NULL) { | 230 | old_delegation = rcu_dereference_protected(nfsi->delegation, |
| 217 | if (memcmp(&delegation->stateid, &nfsi->delegation->stateid, | 231 | lockdep_is_held(&clp->cl_lock)); |
| 218 | sizeof(delegation->stateid)) == 0 && | 232 | if (old_delegation != NULL) { |
| 219 | delegation->type == nfsi->delegation->type) { | 233 | if (memcmp(&delegation->stateid, &old_delegation->stateid, |
| 234 | sizeof(old_delegation->stateid)) == 0 && | ||
| 235 | delegation->type == old_delegation->type) { | ||
| 220 | goto out; | 236 | goto out; |
| 221 | } | 237 | } |
| 222 | /* | 238 | /* |
| @@ -226,12 +242,12 @@ int nfs_inode_set_delegation(struct inode *inode, struct rpc_cred *cred, struct | |||
| 226 | dfprintk(FILE, "%s: server %s handed out " | 242 | dfprintk(FILE, "%s: server %s handed out " |
| 227 | "a duplicate delegation!\n", | 243 | "a duplicate delegation!\n", |
| 228 | __func__, clp->cl_hostname); | 244 | __func__, clp->cl_hostname); |
| 229 | if (delegation->type <= nfsi->delegation->type) { | 245 | if (delegation->type <= old_delegation->type) { |
| 230 | freeme = delegation; | 246 | freeme = delegation; |
| 231 | delegation = NULL; | 247 | delegation = NULL; |
| 232 | goto out; | 248 | goto out; |
| 233 | } | 249 | } |
| 234 | freeme = nfs_detach_delegation_locked(nfsi, NULL); | 250 | freeme = nfs_detach_delegation_locked(nfsi, NULL, clp); |
| 235 | } | 251 | } |
| 236 | list_add_rcu(&delegation->super_list, &clp->cl_delegations); | 252 | list_add_rcu(&delegation->super_list, &clp->cl_delegations); |
| 237 | nfsi->delegation_state = delegation->type; | 253 | nfsi->delegation_state = delegation->type; |
| @@ -301,7 +317,7 @@ restart: | |||
| 301 | if (inode == NULL) | 317 | if (inode == NULL) |
| 302 | continue; | 318 | continue; |
| 303 | spin_lock(&clp->cl_lock); | 319 | spin_lock(&clp->cl_lock); |
| 304 | delegation = nfs_detach_delegation_locked(NFS_I(inode), NULL); | 320 | delegation = nfs_detach_delegation_locked(NFS_I(inode), NULL, clp); |
| 305 | spin_unlock(&clp->cl_lock); | 321 | spin_unlock(&clp->cl_lock); |
| 306 | rcu_read_unlock(); | 322 | rcu_read_unlock(); |
| 307 | if (delegation != NULL) { | 323 | if (delegation != NULL) { |
| @@ -330,9 +346,9 @@ void nfs_inode_return_delegation_noreclaim(struct inode *inode) | |||
| 330 | struct nfs_inode *nfsi = NFS_I(inode); | 346 | struct nfs_inode *nfsi = NFS_I(inode); |
| 331 | struct nfs_delegation *delegation; | 347 | struct nfs_delegation *delegation; |
| 332 | 348 | ||
| 333 | if (rcu_dereference(nfsi->delegation) != NULL) { | 349 | if (rcu_access_pointer(nfsi->delegation) != NULL) { |
| 334 | spin_lock(&clp->cl_lock); | 350 | spin_lock(&clp->cl_lock); |
| 335 | delegation = nfs_detach_delegation_locked(nfsi, NULL); | 351 | delegation = nfs_detach_delegation_locked(nfsi, NULL, clp); |
| 336 | spin_unlock(&clp->cl_lock); | 352 | spin_unlock(&clp->cl_lock); |
| 337 | if (delegation != NULL) | 353 | if (delegation != NULL) |
| 338 | nfs_do_return_delegation(inode, delegation, 0); | 354 | nfs_do_return_delegation(inode, delegation, 0); |
| @@ -346,9 +362,9 @@ int nfs_inode_return_delegation(struct inode *inode) | |||
| 346 | struct nfs_delegation *delegation; | 362 | struct nfs_delegation *delegation; |
| 347 | int err = 0; | 363 | int err = 0; |
| 348 | 364 | ||
| 349 | if (rcu_dereference(nfsi->delegation) != NULL) { | 365 | if (rcu_access_pointer(nfsi->delegation) != NULL) { |
| 350 | spin_lock(&clp->cl_lock); | 366 | spin_lock(&clp->cl_lock); |
| 351 | delegation = nfs_detach_delegation_locked(nfsi, NULL); | 367 | delegation = nfs_detach_delegation_locked(nfsi, NULL, clp); |
| 352 | spin_unlock(&clp->cl_lock); | 368 | spin_unlock(&clp->cl_lock); |
| 353 | if (delegation != NULL) { | 369 | if (delegation != NULL) { |
| 354 | nfs_msync_inode(inode); | 370 | nfs_msync_inode(inode); |
| @@ -526,7 +542,7 @@ restart: | |||
| 526 | if (inode == NULL) | 542 | if (inode == NULL) |
| 527 | continue; | 543 | continue; |
| 528 | spin_lock(&clp->cl_lock); | 544 | spin_lock(&clp->cl_lock); |
| 529 | delegation = nfs_detach_delegation_locked(NFS_I(inode), NULL); | 545 | delegation = nfs_detach_delegation_locked(NFS_I(inode), NULL, clp); |
| 530 | spin_unlock(&clp->cl_lock); | 546 | spin_unlock(&clp->cl_lock); |
| 531 | rcu_read_unlock(); | 547 | rcu_read_unlock(); |
| 532 | if (delegation != NULL) | 548 | if (delegation != NULL) |
diff --git a/include/drm/ttm/ttm_bo_driver.h b/include/drm/ttm/ttm_bo_driver.h index e929c27ede22..6b9db917e717 100644 --- a/include/drm/ttm/ttm_bo_driver.h +++ b/include/drm/ttm/ttm_bo_driver.h | |||
| @@ -789,34 +789,6 @@ extern void ttm_bo_unreserve(struct ttm_buffer_object *bo); | |||
| 789 | extern int ttm_bo_wait_unreserved(struct ttm_buffer_object *bo, | 789 | extern int ttm_bo_wait_unreserved(struct ttm_buffer_object *bo, |
| 790 | bool interruptible); | 790 | bool interruptible); |
| 791 | 791 | ||
| 792 | /** | ||
| 793 | * ttm_bo_block_reservation | ||
| 794 | * | ||
| 795 | * @bo: A pointer to a struct ttm_buffer_object. | ||
| 796 | * @interruptible: Use interruptible sleep when waiting. | ||
| 797 | * @no_wait: Don't sleep, but rather return -EBUSY. | ||
| 798 | * | ||
| 799 | * Block reservation for validation by simply reserving the buffer. | ||
| 800 | * This is intended for single buffer use only without eviction, | ||
| 801 | * and thus needs no deadlock protection. | ||
| 802 | * | ||
| 803 | * Returns: | ||
| 804 | * -EBUSY: If no_wait == 1 and the buffer is already reserved. | ||
| 805 | * -ERESTARTSYS: If interruptible == 1 and the process received a signal | ||
| 806 | * while sleeping. | ||
| 807 | */ | ||
| 808 | extern int ttm_bo_block_reservation(struct ttm_buffer_object *bo, | ||
| 809 | bool interruptible, bool no_wait); | ||
| 810 | |||
| 811 | /** | ||
| 812 | * ttm_bo_unblock_reservation | ||
| 813 | * | ||
| 814 | * @bo: A pointer to a struct ttm_buffer_object. | ||
| 815 | * | ||
| 816 | * Unblocks reservation leaving lru lists untouched. | ||
| 817 | */ | ||
| 818 | extern void ttm_bo_unblock_reservation(struct ttm_buffer_object *bo); | ||
| 819 | |||
| 820 | /* | 792 | /* |
| 821 | * ttm_bo_util.c | 793 | * ttm_bo_util.c |
| 822 | */ | 794 | */ |
diff --git a/include/linux/cgroup.h b/include/linux/cgroup.h index b8ad1ea99586..8f78073d7caa 100644 --- a/include/linux/cgroup.h +++ b/include/linux/cgroup.h | |||
| @@ -530,6 +530,7 @@ static inline struct cgroup_subsys_state *task_subsys_state( | |||
| 530 | { | 530 | { |
| 531 | return rcu_dereference_check(task->cgroups->subsys[subsys_id], | 531 | return rcu_dereference_check(task->cgroups->subsys[subsys_id], |
| 532 | rcu_read_lock_held() || | 532 | rcu_read_lock_held() || |
| 533 | lockdep_is_held(&task->alloc_lock) || | ||
| 533 | cgroup_lock_is_held()); | 534 | cgroup_lock_is_held()); |
| 534 | } | 535 | } |
| 535 | 536 | ||
diff --git a/include/linux/rcupdate.h b/include/linux/rcupdate.h index 07db2feb8572..db266bbed23f 100644 --- a/include/linux/rcupdate.h +++ b/include/linux/rcupdate.h | |||
| @@ -190,6 +190,8 @@ static inline int rcu_read_lock_sched_held(void) | |||
| 190 | 190 | ||
| 191 | #ifdef CONFIG_PROVE_RCU | 191 | #ifdef CONFIG_PROVE_RCU |
| 192 | 192 | ||
| 193 | extern int rcu_my_thread_group_empty(void); | ||
| 194 | |||
| 193 | /** | 195 | /** |
| 194 | * rcu_dereference_check - rcu_dereference with debug checking | 196 | * rcu_dereference_check - rcu_dereference with debug checking |
| 195 | * @p: The pointer to read, prior to dereferencing | 197 | * @p: The pointer to read, prior to dereferencing |
diff --git a/include/media/saa7146_vv.h b/include/media/saa7146_vv.h index b9da1f5591e7..4aeff96ff7d8 100644 --- a/include/media/saa7146_vv.h +++ b/include/media/saa7146_vv.h | |||
| @@ -188,7 +188,6 @@ void saa7146_buffer_timeout(unsigned long data); | |||
| 188 | void saa7146_dma_free(struct saa7146_dev* dev,struct videobuf_queue *q, | 188 | void saa7146_dma_free(struct saa7146_dev* dev,struct videobuf_queue *q, |
| 189 | struct saa7146_buf *buf); | 189 | struct saa7146_buf *buf); |
| 190 | 190 | ||
| 191 | int saa7146_vv_devinit(struct saa7146_dev *dev); | ||
| 192 | int saa7146_vv_init(struct saa7146_dev* dev, struct saa7146_ext_vv *ext_vv); | 191 | int saa7146_vv_init(struct saa7146_dev* dev, struct saa7146_ext_vv *ext_vv); |
| 193 | int saa7146_vv_release(struct saa7146_dev* dev); | 192 | int saa7146_vv_release(struct saa7146_dev* dev); |
| 194 | 193 | ||
diff --git a/kernel/cgroup.c b/kernel/cgroup.c index e2769e13980c..3a53c771e503 100644 --- a/kernel/cgroup.c +++ b/kernel/cgroup.c | |||
| @@ -1646,7 +1646,9 @@ static inline struct cftype *__d_cft(struct dentry *dentry) | |||
| 1646 | int cgroup_path(const struct cgroup *cgrp, char *buf, int buflen) | 1646 | int cgroup_path(const struct cgroup *cgrp, char *buf, int buflen) |
| 1647 | { | 1647 | { |
| 1648 | char *start; | 1648 | char *start; |
| 1649 | struct dentry *dentry = rcu_dereference(cgrp->dentry); | 1649 | struct dentry *dentry = rcu_dereference_check(cgrp->dentry, |
| 1650 | rcu_read_lock_held() || | ||
| 1651 | cgroup_lock_is_held()); | ||
| 1650 | 1652 | ||
| 1651 | if (!dentry || cgrp == dummytop) { | 1653 | if (!dentry || cgrp == dummytop) { |
| 1652 | /* | 1654 | /* |
| @@ -1662,13 +1664,17 @@ int cgroup_path(const struct cgroup *cgrp, char *buf, int buflen) | |||
| 1662 | *--start = '\0'; | 1664 | *--start = '\0'; |
| 1663 | for (;;) { | 1665 | for (;;) { |
| 1664 | int len = dentry->d_name.len; | 1666 | int len = dentry->d_name.len; |
| 1667 | |||
| 1665 | if ((start -= len) < buf) | 1668 | if ((start -= len) < buf) |
| 1666 | return -ENAMETOOLONG; | 1669 | return -ENAMETOOLONG; |
| 1667 | memcpy(start, cgrp->dentry->d_name.name, len); | 1670 | memcpy(start, dentry->d_name.name, len); |
| 1668 | cgrp = cgrp->parent; | 1671 | cgrp = cgrp->parent; |
| 1669 | if (!cgrp) | 1672 | if (!cgrp) |
| 1670 | break; | 1673 | break; |
| 1671 | dentry = rcu_dereference(cgrp->dentry); | 1674 | |
| 1675 | dentry = rcu_dereference_check(cgrp->dentry, | ||
| 1676 | rcu_read_lock_held() || | ||
| 1677 | cgroup_lock_is_held()); | ||
| 1672 | if (!cgrp->parent) | 1678 | if (!cgrp->parent) |
| 1673 | continue; | 1679 | continue; |
| 1674 | if (--start < buf) | 1680 | if (--start < buf) |
| @@ -4555,13 +4561,13 @@ static int alloc_css_id(struct cgroup_subsys *ss, struct cgroup *parent, | |||
| 4555 | { | 4561 | { |
| 4556 | int subsys_id, i, depth = 0; | 4562 | int subsys_id, i, depth = 0; |
| 4557 | struct cgroup_subsys_state *parent_css, *child_css; | 4563 | struct cgroup_subsys_state *parent_css, *child_css; |
| 4558 | struct css_id *child_id, *parent_id = NULL; | 4564 | struct css_id *child_id, *parent_id; |
| 4559 | 4565 | ||
| 4560 | subsys_id = ss->subsys_id; | 4566 | subsys_id = ss->subsys_id; |
| 4561 | parent_css = parent->subsys[subsys_id]; | 4567 | parent_css = parent->subsys[subsys_id]; |
| 4562 | child_css = child->subsys[subsys_id]; | 4568 | child_css = child->subsys[subsys_id]; |
| 4563 | depth = css_depth(parent_css) + 1; | ||
| 4564 | parent_id = parent_css->id; | 4569 | parent_id = parent_css->id; |
| 4570 | depth = parent_id->depth; | ||
| 4565 | 4571 | ||
| 4566 | child_id = get_new_cssid(ss, depth); | 4572 | child_id = get_new_cssid(ss, depth); |
| 4567 | if (IS_ERR(child_id)) | 4573 | if (IS_ERR(child_id)) |
diff --git a/kernel/rcupdate.c b/kernel/rcupdate.c index 03a7ea1579f6..49d808e833b0 100644 --- a/kernel/rcupdate.c +++ b/kernel/rcupdate.c | |||
| @@ -122,3 +122,14 @@ void wakeme_after_rcu(struct rcu_head *head) | |||
| 122 | rcu = container_of(head, struct rcu_synchronize, head); | 122 | rcu = container_of(head, struct rcu_synchronize, head); |
| 123 | complete(&rcu->completion); | 123 | complete(&rcu->completion); |
| 124 | } | 124 | } |
| 125 | |||
| 126 | #ifdef CONFIG_PROVE_RCU | ||
| 127 | /* | ||
| 128 | * wrapper function to avoid #include problems. | ||
| 129 | */ | ||
| 130 | int rcu_my_thread_group_empty(void) | ||
| 131 | { | ||
| 132 | return thread_group_empty(current); | ||
| 133 | } | ||
| 134 | EXPORT_SYMBOL_GPL(rcu_my_thread_group_empty); | ||
| 135 | #endif /* #ifdef CONFIG_PROVE_RCU */ | ||
diff --git a/kernel/sched_debug.c b/kernel/sched_debug.c index 9b49db144037..19be00ba6123 100644 --- a/kernel/sched_debug.c +++ b/kernel/sched_debug.c | |||
| @@ -114,7 +114,9 @@ print_task(struct seq_file *m, struct rq *rq, struct task_struct *p) | |||
| 114 | { | 114 | { |
| 115 | char path[64]; | 115 | char path[64]; |
| 116 | 116 | ||
| 117 | rcu_read_lock(); | ||
| 117 | cgroup_path(task_group(p)->css.cgroup, path, sizeof(path)); | 118 | cgroup_path(task_group(p)->css.cgroup, path, sizeof(path)); |
| 119 | rcu_read_unlock(); | ||
| 118 | SEQ_printf(m, " %s", path); | 120 | SEQ_printf(m, " %s", path); |
| 119 | } | 121 | } |
| 120 | #endif | 122 | #endif |
diff --git a/mm/memcontrol.c b/mm/memcontrol.c index 6c755de385f7..0f711c213d2e 100644 --- a/mm/memcontrol.c +++ b/mm/memcontrol.c | |||
| @@ -811,10 +811,12 @@ int task_in_mem_cgroup(struct task_struct *task, const struct mem_cgroup *mem) | |||
| 811 | * enabled in "curr" and "curr" is a child of "mem" in *cgroup* | 811 | * enabled in "curr" and "curr" is a child of "mem" in *cgroup* |
| 812 | * hierarchy(even if use_hierarchy is disabled in "mem"). | 812 | * hierarchy(even if use_hierarchy is disabled in "mem"). |
| 813 | */ | 813 | */ |
| 814 | rcu_read_lock(); | ||
| 814 | if (mem->use_hierarchy) | 815 | if (mem->use_hierarchy) |
| 815 | ret = css_is_ancestor(&curr->css, &mem->css); | 816 | ret = css_is_ancestor(&curr->css, &mem->css); |
| 816 | else | 817 | else |
| 817 | ret = (curr == mem); | 818 | ret = (curr == mem); |
| 819 | rcu_read_unlock(); | ||
| 818 | css_put(&curr->css); | 820 | css_put(&curr->css); |
| 819 | return ret; | 821 | return ret; |
| 820 | } | 822 | } |
| @@ -2312,7 +2314,9 @@ mem_cgroup_uncharge_swapcache(struct page *page, swp_entry_t ent, bool swapout) | |||
| 2312 | 2314 | ||
| 2313 | /* record memcg information */ | 2315 | /* record memcg information */ |
| 2314 | if (do_swap_account && swapout && memcg) { | 2316 | if (do_swap_account && swapout && memcg) { |
| 2317 | rcu_read_lock(); | ||
| 2315 | swap_cgroup_record(ent, css_id(&memcg->css)); | 2318 | swap_cgroup_record(ent, css_id(&memcg->css)); |
| 2319 | rcu_read_unlock(); | ||
| 2316 | mem_cgroup_get(memcg); | 2320 | mem_cgroup_get(memcg); |
| 2317 | } | 2321 | } |
| 2318 | if (swapout && memcg) | 2322 | if (swapout && memcg) |
| @@ -2369,8 +2373,10 @@ static int mem_cgroup_move_swap_account(swp_entry_t entry, | |||
| 2369 | { | 2373 | { |
| 2370 | unsigned short old_id, new_id; | 2374 | unsigned short old_id, new_id; |
| 2371 | 2375 | ||
| 2376 | rcu_read_lock(); | ||
| 2372 | old_id = css_id(&from->css); | 2377 | old_id = css_id(&from->css); |
| 2373 | new_id = css_id(&to->css); | 2378 | new_id = css_id(&to->css); |
| 2379 | rcu_read_unlock(); | ||
| 2374 | 2380 | ||
| 2375 | if (swap_cgroup_cmpxchg(entry, old_id, new_id) == old_id) { | 2381 | if (swap_cgroup_cmpxchg(entry, old_id, new_id) == old_id) { |
| 2376 | mem_cgroup_swap_statistics(from, false); | 2382 | mem_cgroup_swap_statistics(from, false); |
| @@ -4038,11 +4044,16 @@ static int is_target_pte_for_mc(struct vm_area_struct *vma, | |||
| 4038 | put_page(page); | 4044 | put_page(page); |
| 4039 | } | 4045 | } |
| 4040 | /* throught */ | 4046 | /* throught */ |
| 4041 | if (ent.val && do_swap_account && !ret && | 4047 | if (ent.val && do_swap_account && !ret) { |
| 4042 | css_id(&mc.from->css) == lookup_swap_cgroup(ent)) { | 4048 | unsigned short id; |
| 4043 | ret = MC_TARGET_SWAP; | 4049 | rcu_read_lock(); |
| 4044 | if (target) | 4050 | id = css_id(&mc.from->css); |
| 4045 | target->ent = ent; | 4051 | rcu_read_unlock(); |
| 4052 | if (id == lookup_swap_cgroup(ent)) { | ||
| 4053 | ret = MC_TARGET_SWAP; | ||
| 4054 | if (target) | ||
| 4055 | target->ent = ent; | ||
| 4056 | } | ||
| 4046 | } | 4057 | } |
| 4047 | return ret; | 4058 | return ret; |
| 4048 | } | 4059 | } |
