diff options
| author | Linus Torvalds <torvalds@linux-foundation.org> | 2008-07-26 16:25:05 -0400 |
|---|---|---|
| committer | Linus Torvalds <torvalds@linux-foundation.org> | 2008-07-26 16:25:05 -0400 |
| commit | fb3b80614438f8b73b3879a19350439d6aa402da (patch) | |
| tree | 8397dc4dd85b3ecc8d3cb3f56d143843a6346b8c | |
| parent | 7f268a2ba7c884a239713696238dd4207a57dd9a (diff) | |
| parent | 3a61ec387c9092dfc91a5959145d36835a72fc4c (diff) | |
Merge branch 'x86-fixes-for-linus' of git://git.kernel.org/pub/scm/linux/kernel/git/tip/linux-2.6-tip
* 'x86-fixes-for-linus' of git://git.kernel.org/pub/scm/linux/kernel/git/tip/linux-2.6-tip:
x86, AMD IOMMU: include amd_iommu_last_bdf in device initialization
x86: fix IBM Summit based systems' phys_cpu_present_map on 32-bit kernels
x86, RDC321x: remove gpio.h complications
x86, RDC321x: add to mach-default
crashdump: fix undefined reference to `elfcorehdr_addr'
flag parameters: fix compile error of sys_epoll_create1
| -rw-r--r-- | arch/x86/Kconfig | 26 | ||||
| -rw-r--r-- | arch/x86/Makefile | 5 | ||||
| -rw-r--r-- | arch/x86/kernel/amd_iommu.c | 4 | ||||
| -rw-r--r-- | arch/x86/kernel/amd_iommu_init.c | 4 | ||||
| -rw-r--r-- | include/asm-x86/gpio.h | 6 | ||||
| -rw-r--r-- | include/asm-x86/mach-summit/mach_apic.h | 2 | ||||
| -rw-r--r-- | include/linux/crash_dump.h | 6 |
7 files changed, 22 insertions, 31 deletions
diff --git a/arch/x86/Kconfig b/arch/x86/Kconfig index 6bdde845818e..b6fa2877b173 100644 --- a/arch/x86/Kconfig +++ b/arch/x86/Kconfig | |||
| @@ -24,7 +24,7 @@ config X86 | |||
| 24 | select HAVE_IOREMAP_PROT | 24 | select HAVE_IOREMAP_PROT |
| 25 | select HAVE_GET_USER_PAGES_FAST | 25 | select HAVE_GET_USER_PAGES_FAST |
| 26 | select HAVE_KPROBES | 26 | select HAVE_KPROBES |
| 27 | select ARCH_WANT_OPTIONAL_GPIOLIB if !X86_RDC321X | 27 | select ARCH_WANT_OPTIONAL_GPIOLIB |
| 28 | select HAVE_KRETPROBES | 28 | select HAVE_KRETPROBES |
| 29 | select HAVE_DYNAMIC_FTRACE | 29 | select HAVE_DYNAMIC_FTRACE |
| 30 | select HAVE_FTRACE | 30 | select HAVE_FTRACE |
| @@ -333,20 +333,6 @@ config X86_BIGSMP | |||
| 333 | 333 | ||
| 334 | endif | 334 | endif |
| 335 | 335 | ||
| 336 | config X86_RDC321X | ||
| 337 | bool "RDC R-321x SoC" | ||
| 338 | depends on X86_32 | ||
| 339 | select M486 | ||
| 340 | select X86_REBOOTFIXUPS | ||
| 341 | select GENERIC_GPIO | ||
| 342 | select LEDS_CLASS | ||
| 343 | select LEDS_GPIO | ||
| 344 | select NEW_LEDS | ||
| 345 | help | ||
| 346 | This option is needed for RDC R-321x system-on-chip, also known | ||
| 347 | as R-8610-(G). | ||
| 348 | If you don't have one of these chips, you should say N here. | ||
| 349 | |||
| 350 | config X86_VSMP | 336 | config X86_VSMP |
| 351 | bool "Support for ScaleMP vSMP" | 337 | bool "Support for ScaleMP vSMP" |
| 352 | select PARAVIRT | 338 | select PARAVIRT |
| @@ -370,6 +356,16 @@ config X86_VISWS | |||
| 370 | A kernel compiled for the Visual Workstation will run on general | 356 | A kernel compiled for the Visual Workstation will run on general |
| 371 | PCs as well. See <file:Documentation/sgi-visws.txt> for details. | 357 | PCs as well. See <file:Documentation/sgi-visws.txt> for details. |
| 372 | 358 | ||
| 359 | config X86_RDC321X | ||
| 360 | bool "RDC R-321x SoC" | ||
| 361 | depends on X86_32 | ||
| 362 | select M486 | ||
| 363 | select X86_REBOOTFIXUPS | ||
| 364 | help | ||
| 365 | This option is needed for RDC R-321x system-on-chip, also known | ||
| 366 | as R-8610-(G). | ||
| 367 | If you don't have one of these chips, you should say N here. | ||
| 368 | |||
| 373 | config SCHED_NO_NO_OMIT_FRAME_POINTER | 369 | config SCHED_NO_NO_OMIT_FRAME_POINTER |
| 374 | def_bool y | 370 | def_bool y |
| 375 | prompt "Single-depth WCHAN output" | 371 | prompt "Single-depth WCHAN output" |
diff --git a/arch/x86/Makefile b/arch/x86/Makefile index 919ce21ea654..f5631da585b6 100644 --- a/arch/x86/Makefile +++ b/arch/x86/Makefile | |||
| @@ -118,11 +118,6 @@ mflags-$(CONFIG_X86_GENERICARCH):= -Iinclude/asm-x86/mach-generic | |||
| 118 | fcore-$(CONFIG_X86_GENERICARCH) += arch/x86/mach-generic/ | 118 | fcore-$(CONFIG_X86_GENERICARCH) += arch/x86/mach-generic/ |
| 119 | mcore-$(CONFIG_X86_GENERICARCH) := arch/x86/mach-default/ | 119 | mcore-$(CONFIG_X86_GENERICARCH) := arch/x86/mach-default/ |
| 120 | 120 | ||
| 121 | # RDC R-321x subarch support | ||
| 122 | mflags-$(CONFIG_X86_RDC321X) := -Iinclude/asm-x86/mach-rdc321x | ||
| 123 | mcore-$(CONFIG_X86_RDC321X) := arch/x86/mach-default/ | ||
| 124 | core-$(CONFIG_X86_RDC321X) += arch/x86/mach-rdc321x/ | ||
| 125 | |||
| 126 | # default subarch .h files | 121 | # default subarch .h files |
| 127 | mflags-y += -Iinclude/asm-x86/mach-default | 122 | mflags-y += -Iinclude/asm-x86/mach-default |
| 128 | 123 | ||
diff --git a/arch/x86/kernel/amd_iommu.c b/arch/x86/kernel/amd_iommu.c index c25210e6ac88..74697408576f 100644 --- a/arch/x86/kernel/amd_iommu.c +++ b/arch/x86/kernel/amd_iommu.c | |||
| @@ -667,7 +667,7 @@ static int get_device_resources(struct device *dev, | |||
| 667 | _bdf = calc_devid(pcidev->bus->number, pcidev->devfn); | 667 | _bdf = calc_devid(pcidev->bus->number, pcidev->devfn); |
| 668 | 668 | ||
| 669 | /* device not translated by any IOMMU in the system? */ | 669 | /* device not translated by any IOMMU in the system? */ |
| 670 | if (_bdf >= amd_iommu_last_bdf) { | 670 | if (_bdf > amd_iommu_last_bdf) { |
| 671 | *iommu = NULL; | 671 | *iommu = NULL; |
| 672 | *domain = NULL; | 672 | *domain = NULL; |
| 673 | *bdf = 0xffff; | 673 | *bdf = 0xffff; |
| @@ -1085,7 +1085,7 @@ void prealloc_protection_domains(void) | |||
| 1085 | 1085 | ||
| 1086 | while ((dev = pci_get_device(PCI_ANY_ID, PCI_ANY_ID, dev)) != NULL) { | 1086 | while ((dev = pci_get_device(PCI_ANY_ID, PCI_ANY_ID, dev)) != NULL) { |
| 1087 | devid = (dev->bus->number << 8) | dev->devfn; | 1087 | devid = (dev->bus->number << 8) | dev->devfn; |
| 1088 | if (devid >= amd_iommu_last_bdf) | 1088 | if (devid > amd_iommu_last_bdf) |
| 1089 | continue; | 1089 | continue; |
| 1090 | devid = amd_iommu_alias_table[devid]; | 1090 | devid = amd_iommu_alias_table[devid]; |
| 1091 | if (domain_for_device(devid)) | 1091 | if (domain_for_device(devid)) |
diff --git a/arch/x86/kernel/amd_iommu_init.c b/arch/x86/kernel/amd_iommu_init.c index c9d8ff2eb130..d9a9da597e79 100644 --- a/arch/x86/kernel/amd_iommu_init.c +++ b/arch/x86/kernel/amd_iommu_init.c | |||
| @@ -732,7 +732,7 @@ static int __init init_exclusion_range(struct ivmd_header *m) | |||
| 732 | set_device_exclusion_range(m->devid, m); | 732 | set_device_exclusion_range(m->devid, m); |
| 733 | break; | 733 | break; |
| 734 | case ACPI_IVMD_TYPE_ALL: | 734 | case ACPI_IVMD_TYPE_ALL: |
| 735 | for (i = 0; i < amd_iommu_last_bdf; ++i) | 735 | for (i = 0; i <= amd_iommu_last_bdf; ++i) |
| 736 | set_device_exclusion_range(i, m); | 736 | set_device_exclusion_range(i, m); |
| 737 | break; | 737 | break; |
| 738 | case ACPI_IVMD_TYPE_RANGE: | 738 | case ACPI_IVMD_TYPE_RANGE: |
| @@ -934,7 +934,7 @@ int __init amd_iommu_init(void) | |||
| 934 | /* | 934 | /* |
| 935 | * let all alias entries point to itself | 935 | * let all alias entries point to itself |
| 936 | */ | 936 | */ |
| 937 | for (i = 0; i < amd_iommu_last_bdf; ++i) | 937 | for (i = 0; i <= amd_iommu_last_bdf; ++i) |
| 938 | amd_iommu_alias_table[i] = i; | 938 | amd_iommu_alias_table[i] = i; |
| 939 | 939 | ||
| 940 | /* | 940 | /* |
diff --git a/include/asm-x86/gpio.h b/include/asm-x86/gpio.h index 116e9147fe66..c4c91b37c104 100644 --- a/include/asm-x86/gpio.h +++ b/include/asm-x86/gpio.h | |||
| @@ -16,10 +16,6 @@ | |||
| 16 | #ifndef _ASM_I386_GPIO_H | 16 | #ifndef _ASM_I386_GPIO_H |
| 17 | #define _ASM_I386_GPIO_H | 17 | #define _ASM_I386_GPIO_H |
| 18 | 18 | ||
| 19 | #ifdef CONFIG_X86_RDC321X | ||
| 20 | #include <gpio.h> | ||
| 21 | #else /* CONFIG_X86_RDC321X */ | ||
| 22 | |||
| 23 | #include <asm-generic/gpio.h> | 19 | #include <asm-generic/gpio.h> |
| 24 | 20 | ||
| 25 | #ifdef CONFIG_GPIOLIB | 21 | #ifdef CONFIG_GPIOLIB |
| @@ -57,6 +53,4 @@ static inline int irq_to_gpio(unsigned int irq) | |||
| 57 | 53 | ||
| 58 | #endif /* CONFIG_GPIOLIB */ | 54 | #endif /* CONFIG_GPIOLIB */ |
| 59 | 55 | ||
| 60 | #endif /* CONFIG_X86_RDC321X */ | ||
| 61 | |||
| 62 | #endif /* _ASM_I386_GPIO_H */ | 56 | #endif /* _ASM_I386_GPIO_H */ |
diff --git a/include/asm-x86/mach-summit/mach_apic.h b/include/asm-x86/mach-summit/mach_apic.h index 75d2c95005d7..c47e2ab5c5ca 100644 --- a/include/asm-x86/mach-summit/mach_apic.h +++ b/include/asm-x86/mach-summit/mach_apic.h | |||
| @@ -122,7 +122,7 @@ static inline physid_mask_t ioapic_phys_id_map(physid_mask_t phys_id_map) | |||
| 122 | 122 | ||
| 123 | static inline physid_mask_t apicid_to_cpu_present(int apicid) | 123 | static inline physid_mask_t apicid_to_cpu_present(int apicid) |
| 124 | { | 124 | { |
| 125 | return physid_mask_of_physid(0); | 125 | return physid_mask_of_physid(apicid); |
| 126 | } | 126 | } |
| 127 | 127 | ||
| 128 | static inline void setup_portio_remap(void) | 128 | static inline void setup_portio_remap(void) |
diff --git a/include/linux/crash_dump.h b/include/linux/crash_dump.h index 6cd39a927e1f..025e4f575103 100644 --- a/include/linux/crash_dump.h +++ b/include/linux/crash_dump.h | |||
| @@ -8,7 +8,13 @@ | |||
| 8 | #include <linux/proc_fs.h> | 8 | #include <linux/proc_fs.h> |
| 9 | 9 | ||
| 10 | #define ELFCORE_ADDR_MAX (-1ULL) | 10 | #define ELFCORE_ADDR_MAX (-1ULL) |
| 11 | |||
| 12 | #ifdef CONFIG_PROC_VMCORE | ||
| 11 | extern unsigned long long elfcorehdr_addr; | 13 | extern unsigned long long elfcorehdr_addr; |
| 14 | #else | ||
| 15 | static const unsigned long long elfcorehdr_addr = ELFCORE_ADDR_MAX; | ||
| 16 | #endif | ||
| 17 | |||
| 12 | extern ssize_t copy_oldmem_page(unsigned long, char *, size_t, | 18 | extern ssize_t copy_oldmem_page(unsigned long, char *, size_t, |
| 13 | unsigned long, int); | 19 | unsigned long, int); |
| 14 | extern const struct file_operations proc_vmcore_operations; | 20 | extern const struct file_operations proc_vmcore_operations; |
