diff options
Diffstat (limited to 'arch')
59 files changed, 825 insertions, 628 deletions
diff --git a/arch/alpha/Kconfig b/arch/alpha/Kconfig index 083c5df42d35..189d5eababa8 100644 --- a/arch/alpha/Kconfig +++ b/arch/alpha/Kconfig | |||
| @@ -522,7 +522,7 @@ source "mm/Kconfig" | |||
| 522 | 522 | ||
| 523 | config NUMA | 523 | config NUMA |
| 524 | bool "NUMA Support (EXPERIMENTAL)" | 524 | bool "NUMA Support (EXPERIMENTAL)" |
| 525 | depends on DISCONTIGMEM | 525 | depends on DISCONTIGMEM && BROKEN |
| 526 | help | 526 | help |
| 527 | Say Y to compile the kernel to support NUMA (Non-Uniform Memory | 527 | Say Y to compile the kernel to support NUMA (Non-Uniform Memory |
| 528 | Access). This option is for configuring high-end multiprocessor | 528 | Access). This option is for configuring high-end multiprocessor |
diff --git a/arch/alpha/kernel/smp.c b/arch/alpha/kernel/smp.c index 8f1e78551b1e..e211aa7404e6 100644 --- a/arch/alpha/kernel/smp.c +++ b/arch/alpha/kernel/smp.c | |||
| @@ -1036,7 +1036,7 @@ debug_spin_lock(spinlock_t * lock, const char *base_file, int line_no) | |||
| 1036 | " br 1b\n" | 1036 | " br 1b\n" |
| 1037 | ".previous" | 1037 | ".previous" |
| 1038 | : "=r" (tmp), "=m" (lock->lock), "=r" (stuck) | 1038 | : "=r" (tmp), "=m" (lock->lock), "=r" (stuck) |
| 1039 | : "1" (lock->lock), "2" (stuck) : "memory"); | 1039 | : "m" (lock->lock), "2" (stuck) : "memory"); |
| 1040 | 1040 | ||
| 1041 | if (stuck < 0) { | 1041 | if (stuck < 0) { |
| 1042 | printk(KERN_WARNING | 1042 | printk(KERN_WARNING |
| @@ -1115,7 +1115,7 @@ void _raw_write_lock(rwlock_t * lock) | |||
| 1115 | ".previous" | 1115 | ".previous" |
| 1116 | : "=m" (*(volatile int *)lock), "=&r" (regx), "=&r" (regy), | 1116 | : "=m" (*(volatile int *)lock), "=&r" (regx), "=&r" (regy), |
| 1117 | "=&r" (stuck_lock), "=&r" (stuck_reader) | 1117 | "=&r" (stuck_lock), "=&r" (stuck_reader) |
| 1118 | : "0" (*(volatile int *)lock), "3" (stuck_lock), "4" (stuck_reader) : "memory"); | 1118 | : "m" (*(volatile int *)lock), "3" (stuck_lock), "4" (stuck_reader) : "memory"); |
| 1119 | 1119 | ||
| 1120 | if (stuck_lock < 0) { | 1120 | if (stuck_lock < 0) { |
| 1121 | printk(KERN_WARNING "write_lock stuck at %p\n", inline_pc); | 1121 | printk(KERN_WARNING "write_lock stuck at %p\n", inline_pc); |
| @@ -1153,7 +1153,7 @@ void _raw_read_lock(rwlock_t * lock) | |||
| 1153 | " br 1b\n" | 1153 | " br 1b\n" |
| 1154 | ".previous" | 1154 | ".previous" |
| 1155 | : "=m" (*(volatile int *)lock), "=&r" (regx), "=&r" (stuck_lock) | 1155 | : "=m" (*(volatile int *)lock), "=&r" (regx), "=&r" (stuck_lock) |
| 1156 | : "0" (*(volatile int *)lock), "2" (stuck_lock) : "memory"); | 1156 | : "m" (*(volatile int *)lock), "2" (stuck_lock) : "memory"); |
| 1157 | 1157 | ||
| 1158 | if (stuck_lock < 0) { | 1158 | if (stuck_lock < 0) { |
| 1159 | printk(KERN_WARNING "read_lock stuck at %p\n", inline_pc); | 1159 | printk(KERN_WARNING "read_lock stuck at %p\n", inline_pc); |
diff --git a/arch/alpha/oprofile/common.c b/arch/alpha/oprofile/common.c index 908eb4af8dec..ba788cfdc3c6 100644 --- a/arch/alpha/oprofile/common.c +++ b/arch/alpha/oprofile/common.c | |||
| @@ -65,7 +65,7 @@ op_axp_setup(void) | |||
| 65 | model->reg_setup(®, ctr, &sys); | 65 | model->reg_setup(®, ctr, &sys); |
| 66 | 66 | ||
| 67 | /* Configure the registers on all cpus. */ | 67 | /* Configure the registers on all cpus. */ |
| 68 | smp_call_function(model->cpu_setup, ®, 0, 1); | 68 | (void)smp_call_function(model->cpu_setup, ®, 0, 1); |
| 69 | model->cpu_setup(®); | 69 | model->cpu_setup(®); |
| 70 | return 0; | 70 | return 0; |
| 71 | } | 71 | } |
| @@ -86,7 +86,7 @@ op_axp_cpu_start(void *dummy) | |||
| 86 | static int | 86 | static int |
| 87 | op_axp_start(void) | 87 | op_axp_start(void) |
| 88 | { | 88 | { |
| 89 | smp_call_function(op_axp_cpu_start, NULL, 0, 1); | 89 | (void)smp_call_function(op_axp_cpu_start, NULL, 0, 1); |
| 90 | op_axp_cpu_start(NULL); | 90 | op_axp_cpu_start(NULL); |
| 91 | return 0; | 91 | return 0; |
| 92 | } | 92 | } |
| @@ -101,7 +101,7 @@ op_axp_cpu_stop(void *dummy) | |||
| 101 | static void | 101 | static void |
| 102 | op_axp_stop(void) | 102 | op_axp_stop(void) |
| 103 | { | 103 | { |
| 104 | smp_call_function(op_axp_cpu_stop, NULL, 0, 1); | 104 | (void)smp_call_function(op_axp_cpu_stop, NULL, 0, 1); |
| 105 | op_axp_cpu_stop(NULL); | 105 | op_axp_cpu_stop(NULL); |
| 106 | } | 106 | } |
| 107 | 107 | ||
diff --git a/arch/arm/Kconfig b/arch/arm/Kconfig index 7bc4a583f4e1..c65c6eb9810d 100644 --- a/arch/arm/Kconfig +++ b/arch/arm/Kconfig | |||
| @@ -310,7 +310,7 @@ menu "Kernel Features" | |||
| 310 | 310 | ||
| 311 | config SMP | 311 | config SMP |
| 312 | bool "Symmetric Multi-Processing (EXPERIMENTAL)" | 312 | bool "Symmetric Multi-Processing (EXPERIMENTAL)" |
| 313 | depends on EXPERIMENTAL #&& n | 313 | depends on EXPERIMENTAL && BROKEN #&& n |
| 314 | help | 314 | help |
| 315 | This enables support for systems with more than one CPU. If you have | 315 | This enables support for systems with more than one CPU. If you have |
| 316 | a system with only one CPU, like most personal computers, say N. If | 316 | a system with only one CPU, like most personal computers, say N. If |
diff --git a/arch/arm/kernel/calls.S b/arch/arm/kernel/calls.S index e5d370c235d7..2b6b4c786e65 100644 --- a/arch/arm/kernel/calls.S +++ b/arch/arm/kernel/calls.S | |||
| @@ -327,6 +327,12 @@ __syscall_start: | |||
| 327 | /* 310 */ .long sys_request_key | 327 | /* 310 */ .long sys_request_key |
| 328 | .long sys_keyctl | 328 | .long sys_keyctl |
| 329 | .long sys_semtimedop | 329 | .long sys_semtimedop |
| 330 | /* vserver */ .long sys_ni_syscall | ||
| 331 | .long sys_ioprio_set | ||
| 332 | /* 315 */ .long sys_ioprio_get | ||
| 333 | .long sys_inotify_init | ||
| 334 | .long sys_inotify_add_watch | ||
| 335 | .long sys_inotify_rm_watch | ||
| 330 | __syscall_end: | 336 | __syscall_end: |
| 331 | 337 | ||
| 332 | .rept NR_syscalls - (__syscall_end - __syscall_start) / 4 | 338 | .rept NR_syscalls - (__syscall_end - __syscall_start) / 4 |
diff --git a/arch/arm/kernel/traps.c b/arch/arm/kernel/traps.c index d571c37ac30c..4554c961251c 100644 --- a/arch/arm/kernel/traps.c +++ b/arch/arm/kernel/traps.c | |||
| @@ -617,7 +617,7 @@ baddataabort(int code, unsigned long instr, struct pt_regs *regs) | |||
| 617 | notify_die("unknown data abort code", regs, &info, instr, 0); | 617 | notify_die("unknown data abort code", regs, &info, instr, 0); |
| 618 | } | 618 | } |
| 619 | 619 | ||
| 620 | volatile void __bug(const char *file, int line, void *data) | 620 | void __attribute__((noreturn)) __bug(const char *file, int line, void *data) |
| 621 | { | 621 | { |
| 622 | printk(KERN_CRIT"kernel BUG at %s:%d!", file, line); | 622 | printk(KERN_CRIT"kernel BUG at %s:%d!", file, line); |
| 623 | if (data) | 623 | if (data) |
diff --git a/arch/arm/mach-ixp4xx/coyote-setup.c b/arch/arm/mach-ixp4xx/coyote-setup.c index 7f58afb27e71..411ea9996190 100644 --- a/arch/arm/mach-ixp4xx/coyote-setup.c +++ b/arch/arm/mach-ixp4xx/coyote-setup.c | |||
| @@ -36,7 +36,7 @@ static struct flash_platform_data coyote_flash_data = { | |||
| 36 | 36 | ||
| 37 | static struct resource coyote_flash_resource = { | 37 | static struct resource coyote_flash_resource = { |
| 38 | .start = COYOTE_FLASH_BASE, | 38 | .start = COYOTE_FLASH_BASE, |
| 39 | .end = COYOTE_FLASH_BASE + COYOTE_FLASH_SIZE, | 39 | .end = COYOTE_FLASH_BASE + COYOTE_FLASH_SIZE - 1, |
| 40 | .flags = IORESOURCE_MEM, | 40 | .flags = IORESOURCE_MEM, |
| 41 | }; | 41 | }; |
| 42 | 42 | ||
diff --git a/arch/arm/mach-ixp4xx/gtwx5715-setup.c b/arch/arm/mach-ixp4xx/gtwx5715-setup.c index 65e356bd10d6..333459d6aa46 100644 --- a/arch/arm/mach-ixp4xx/gtwx5715-setup.c +++ b/arch/arm/mach-ixp4xx/gtwx5715-setup.c | |||
| @@ -114,7 +114,7 @@ static struct flash_platform_data gtwx5715_flash_data = { | |||
| 114 | 114 | ||
| 115 | static struct resource gtwx5715_flash_resource = { | 115 | static struct resource gtwx5715_flash_resource = { |
| 116 | .start = GTWX5715_FLASH_BASE, | 116 | .start = GTWX5715_FLASH_BASE, |
| 117 | .end = GTWX5715_FLASH_BASE + GTWX5715_FLASH_SIZE, | 117 | .end = GTWX5715_FLASH_BASE + GTWX5715_FLASH_SIZE - 1, |
| 118 | .flags = IORESOURCE_MEM, | 118 | .flags = IORESOURCE_MEM, |
| 119 | }; | 119 | }; |
| 120 | 120 | ||
diff --git a/arch/arm/mach-ixp4xx/ixdp425-setup.c b/arch/arm/mach-ixp4xx/ixdp425-setup.c index 4633470a6a37..fa0646c8693b 100644 --- a/arch/arm/mach-ixp4xx/ixdp425-setup.c +++ b/arch/arm/mach-ixp4xx/ixdp425-setup.c | |||
| @@ -36,7 +36,7 @@ static struct flash_platform_data ixdp425_flash_data = { | |||
| 36 | 36 | ||
| 37 | static struct resource ixdp425_flash_resource = { | 37 | static struct resource ixdp425_flash_resource = { |
| 38 | .start = IXDP425_FLASH_BASE, | 38 | .start = IXDP425_FLASH_BASE, |
| 39 | .end = IXDP425_FLASH_BASE + IXDP425_FLASH_SIZE, | 39 | .end = IXDP425_FLASH_BASE + IXDP425_FLASH_SIZE - 1, |
| 40 | .flags = IORESOURCE_MEM, | 40 | .flags = IORESOURCE_MEM, |
| 41 | }; | 41 | }; |
| 42 | 42 | ||
diff --git a/arch/arm/mach-s3c2410/s3c2410.c b/arch/arm/mach-s3c2410/s3c2410.c index ff2f25409e44..0b88993dfd27 100644 --- a/arch/arm/mach-s3c2410/s3c2410.c +++ b/arch/arm/mach-s3c2410/s3c2410.c | |||
| @@ -18,6 +18,7 @@ | |||
| 18 | * 28-Sep-2004 BJD Updates for new serial port bits | 18 | * 28-Sep-2004 BJD Updates for new serial port bits |
| 19 | * 04-Nov-2004 BJD Updated UART configuration process | 19 | * 04-Nov-2004 BJD Updated UART configuration process |
| 20 | * 10-Jan-2005 BJD Removed s3c2410_clock_tick_rate | 20 | * 10-Jan-2005 BJD Removed s3c2410_clock_tick_rate |
| 21 | * 13-Aug-2005 DA Removed UART from initial I/O mappings | ||
| 21 | */ | 22 | */ |
| 22 | 23 | ||
| 23 | #include <linux/kernel.h> | 24 | #include <linux/kernel.h> |
| @@ -49,10 +50,9 @@ static struct map_desc s3c2410_iodesc[] __initdata = { | |||
| 49 | IODESC_ENT(USBHOST), | 50 | IODESC_ENT(USBHOST), |
| 50 | IODESC_ENT(CLKPWR), | 51 | IODESC_ENT(CLKPWR), |
| 51 | IODESC_ENT(LCD), | 52 | IODESC_ENT(LCD), |
| 52 | IODESC_ENT(UART), | ||
| 53 | IODESC_ENT(TIMER), | 53 | IODESC_ENT(TIMER), |
| 54 | IODESC_ENT(ADC), | 54 | IODESC_ENT(ADC), |
| 55 | IODESC_ENT(WATCHDOG) | 55 | IODESC_ENT(WATCHDOG), |
| 56 | }; | 56 | }; |
| 57 | 57 | ||
| 58 | static struct resource s3c_uart0_resource[] = { | 58 | static struct resource s3c_uart0_resource[] = { |
diff --git a/arch/arm/mm/Kconfig b/arch/arm/mm/Kconfig index afbbeb6f4658..db5e47dfc303 100644 --- a/arch/arm/mm/Kconfig +++ b/arch/arm/mm/Kconfig | |||
| @@ -384,7 +384,7 @@ config CPU_DCACHE_DISABLE | |||
| 384 | 384 | ||
| 385 | config CPU_DCACHE_WRITETHROUGH | 385 | config CPU_DCACHE_WRITETHROUGH |
| 386 | bool "Force write through D-cache" | 386 | bool "Force write through D-cache" |
| 387 | depends on (CPU_ARM920T || CPU_ARM922T || CPU_ARM925T || CPU_ARM926T || CPU_ARM1020) && !CPU_DISABLE_DCACHE | 387 | depends on (CPU_ARM920T || CPU_ARM922T || CPU_ARM925T || CPU_ARM926T || CPU_ARM1020) && !CPU_DCACHE_DISABLE |
| 388 | default y if CPU_ARM925T | 388 | default y if CPU_ARM925T |
| 389 | help | 389 | help |
| 390 | Say Y here to use the data cache in writethrough mode. Unless you | 390 | Say Y here to use the data cache in writethrough mode. Unless you |
diff --git a/arch/arm/mm/proc-v6.S b/arch/arm/mm/proc-v6.S index 3429ddcf65d1..139a38670c5d 100644 --- a/arch/arm/mm/proc-v6.S +++ b/arch/arm/mm/proc-v6.S | |||
| @@ -105,7 +105,7 @@ ENTRY(cpu_v6_dcache_clean_area) | |||
| 105 | ENTRY(cpu_v6_switch_mm) | 105 | ENTRY(cpu_v6_switch_mm) |
| 106 | mov r2, #0 | 106 | mov r2, #0 |
| 107 | ldr r1, [r1, #MM_CONTEXT_ID] @ get mm->context.id | 107 | ldr r1, [r1, #MM_CONTEXT_ID] @ get mm->context.id |
| 108 | mcr p15, 0, r2, c7, c5, 6 @ flush BTAC/BTB | 108 | mcr p15, 0, r2, c7, c5, 6 @ flush BTAC/BTB |
| 109 | mcr p15, 0, r2, c7, c10, 4 @ drain write buffer | 109 | mcr p15, 0, r2, c7, c10, 4 @ drain write buffer |
| 110 | mcr p15, 0, r0, c2, c0, 0 @ set TTB 0 | 110 | mcr p15, 0, r0, c2, c0, 0 @ set TTB 0 |
| 111 | mcr p15, 0, r1, c13, c0, 1 @ set context ID | 111 | mcr p15, 0, r1, c13, c0, 1 @ set context ID |
diff --git a/arch/arm/nwfpe/fpopcode.h b/arch/arm/nwfpe/fpopcode.h index 8035f4faafbf..1777e92a88e6 100644 --- a/arch/arm/nwfpe/fpopcode.h +++ b/arch/arm/nwfpe/fpopcode.h | |||
| @@ -370,20 +370,20 @@ TABLE 5 | |||
| 370 | #define getRoundingMode(opcode) ((opcode & MASK_ROUNDING_MODE) >> 5) | 370 | #define getRoundingMode(opcode) ((opcode & MASK_ROUNDING_MODE) >> 5) |
| 371 | 371 | ||
| 372 | #ifdef CONFIG_FPE_NWFPE_XP | 372 | #ifdef CONFIG_FPE_NWFPE_XP |
| 373 | static inline const floatx80 getExtendedConstant(const unsigned int nIndex) | 373 | static inline __attribute_pure__ floatx80 getExtendedConstant(const unsigned int nIndex) |
| 374 | { | 374 | { |
| 375 | extern const floatx80 floatx80Constant[]; | 375 | extern const floatx80 floatx80Constant[]; |
| 376 | return floatx80Constant[nIndex]; | 376 | return floatx80Constant[nIndex]; |
| 377 | } | 377 | } |
| 378 | #endif | 378 | #endif |
| 379 | 379 | ||
| 380 | static inline const float64 getDoubleConstant(const unsigned int nIndex) | 380 | static inline __attribute_pure__ float64 getDoubleConstant(const unsigned int nIndex) |
| 381 | { | 381 | { |
| 382 | extern const float64 float64Constant[]; | 382 | extern const float64 float64Constant[]; |
| 383 | return float64Constant[nIndex]; | 383 | return float64Constant[nIndex]; |
| 384 | } | 384 | } |
| 385 | 385 | ||
| 386 | static inline const float32 getSingleConstant(const unsigned int nIndex) | 386 | static inline __attribute_pure__ float32 getSingleConstant(const unsigned int nIndex) |
| 387 | { | 387 | { |
| 388 | extern const float32 float32Constant[]; | 388 | extern const float32 float32Constant[]; |
| 389 | return float32Constant[nIndex]; | 389 | return float32Constant[nIndex]; |
diff --git a/arch/arm/nwfpe/softfloat.c b/arch/arm/nwfpe/softfloat.c index 8b75a6e7cb3a..f9f049132a17 100644 --- a/arch/arm/nwfpe/softfloat.c +++ b/arch/arm/nwfpe/softfloat.c | |||
| @@ -1602,9 +1602,7 @@ flag float32_le_quiet( float32 a, float32 b ) | |||
| 1602 | if ( ( ( extractFloat32Exp( a ) == 0xFF ) && extractFloat32Frac( a ) ) | 1602 | if ( ( ( extractFloat32Exp( a ) == 0xFF ) && extractFloat32Frac( a ) ) |
| 1603 | || ( ( extractFloat32Exp( b ) == 0xFF ) && extractFloat32Frac( b ) ) | 1603 | || ( ( extractFloat32Exp( b ) == 0xFF ) && extractFloat32Frac( b ) ) |
| 1604 | ) { | 1604 | ) { |
| 1605 | if ( float32_is_signaling_nan( a ) || float32_is_signaling_nan( b ) ) { | 1605 | /* Do nothing, even if NaN as we're quiet */ |
| 1606 | float_raise( float_flag_invalid ); | ||
| 1607 | } | ||
| 1608 | return 0; | 1606 | return 0; |
| 1609 | } | 1607 | } |
| 1610 | aSign = extractFloat32Sign( a ); | 1608 | aSign = extractFloat32Sign( a ); |
| @@ -1629,9 +1627,7 @@ flag float32_lt_quiet( float32 a, float32 b ) | |||
| 1629 | if ( ( ( extractFloat32Exp( a ) == 0xFF ) && extractFloat32Frac( a ) ) | 1627 | if ( ( ( extractFloat32Exp( a ) == 0xFF ) && extractFloat32Frac( a ) ) |
| 1630 | || ( ( extractFloat32Exp( b ) == 0xFF ) && extractFloat32Frac( b ) ) | 1628 | || ( ( extractFloat32Exp( b ) == 0xFF ) && extractFloat32Frac( b ) ) |
| 1631 | ) { | 1629 | ) { |
| 1632 | if ( float32_is_signaling_nan( a ) || float32_is_signaling_nan( b ) ) { | 1630 | /* Do nothing, even if NaN as we're quiet */ |
| 1633 | float_raise( float_flag_invalid ); | ||
| 1634 | } | ||
| 1635 | return 0; | 1631 | return 0; |
| 1636 | } | 1632 | } |
| 1637 | aSign = extractFloat32Sign( a ); | 1633 | aSign = extractFloat32Sign( a ); |
| @@ -2493,9 +2489,7 @@ flag float64_le_quiet( float64 a, float64 b ) | |||
| 2493 | if ( ( ( extractFloat64Exp( a ) == 0x7FF ) && extractFloat64Frac( a ) ) | 2489 | if ( ( ( extractFloat64Exp( a ) == 0x7FF ) && extractFloat64Frac( a ) ) |
| 2494 | || ( ( extractFloat64Exp( b ) == 0x7FF ) && extractFloat64Frac( b ) ) | 2490 | || ( ( extractFloat64Exp( b ) == 0x7FF ) && extractFloat64Frac( b ) ) |
| 2495 | ) { | 2491 | ) { |
| 2496 | if ( float64_is_signaling_nan( a ) || float64_is_signaling_nan( b ) ) { | 2492 | /* Do nothing, even if NaN as we're quiet */ |
| 2497 | float_raise( float_flag_invalid ); | ||
| 2498 | } | ||
| 2499 | return 0; | 2493 | return 0; |
| 2500 | } | 2494 | } |
| 2501 | aSign = extractFloat64Sign( a ); | 2495 | aSign = extractFloat64Sign( a ); |
| @@ -2520,9 +2514,7 @@ flag float64_lt_quiet( float64 a, float64 b ) | |||
| 2520 | if ( ( ( extractFloat64Exp( a ) == 0x7FF ) && extractFloat64Frac( a ) ) | 2514 | if ( ( ( extractFloat64Exp( a ) == 0x7FF ) && extractFloat64Frac( a ) ) |
| 2521 | || ( ( extractFloat64Exp( b ) == 0x7FF ) && extractFloat64Frac( b ) ) | 2515 | || ( ( extractFloat64Exp( b ) == 0x7FF ) && extractFloat64Frac( b ) ) |
| 2522 | ) { | 2516 | ) { |
| 2523 | if ( float64_is_signaling_nan( a ) || float64_is_signaling_nan( b ) ) { | 2517 | /* Do nothing, even if NaN as we're quiet */ |
| 2524 | float_raise( float_flag_invalid ); | ||
| 2525 | } | ||
| 2526 | return 0; | 2518 | return 0; |
| 2527 | } | 2519 | } |
| 2528 | aSign = extractFloat64Sign( a ); | 2520 | aSign = extractFloat64Sign( a ); |
| @@ -3256,7 +3248,7 @@ flag floatx80_eq( floatx80 a, floatx80 b ) | |||
| 3256 | ) { | 3248 | ) { |
| 3257 | if ( floatx80_is_signaling_nan( a ) | 3249 | if ( floatx80_is_signaling_nan( a ) |
| 3258 | || floatx80_is_signaling_nan( b ) ) { | 3250 | || floatx80_is_signaling_nan( b ) ) { |
| 3259 | roundData->exception |= float_flag_invalid; | 3251 | float_raise( float_flag_invalid ); |
| 3260 | } | 3252 | } |
| 3261 | return 0; | 3253 | return 0; |
| 3262 | } | 3254 | } |
| @@ -3286,7 +3278,7 @@ flag floatx80_le( floatx80 a, floatx80 b ) | |||
| 3286 | || ( ( extractFloatx80Exp( b ) == 0x7FFF ) | 3278 | || ( ( extractFloatx80Exp( b ) == 0x7FFF ) |
| 3287 | && (bits64) ( extractFloatx80Frac( b )<<1 ) ) | 3279 | && (bits64) ( extractFloatx80Frac( b )<<1 ) ) |
| 3288 | ) { | 3280 | ) { |
| 3289 | roundData->exception |= float_flag_invalid; | 3281 | float_raise( float_flag_invalid ); |
| 3290 | return 0; | 3282 | return 0; |
| 3291 | } | 3283 | } |
| 3292 | aSign = extractFloatx80Sign( a ); | 3284 | aSign = extractFloatx80Sign( a ); |
| @@ -3320,7 +3312,7 @@ flag floatx80_lt( floatx80 a, floatx80 b ) | |||
| 3320 | || ( ( extractFloatx80Exp( b ) == 0x7FFF ) | 3312 | || ( ( extractFloatx80Exp( b ) == 0x7FFF ) |
| 3321 | && (bits64) ( extractFloatx80Frac( b )<<1 ) ) | 3313 | && (bits64) ( extractFloatx80Frac( b )<<1 ) ) |
| 3322 | ) { | 3314 | ) { |
| 3323 | roundData->exception |= float_flag_invalid; | 3315 | float_raise( float_flag_invalid ); |
| 3324 | return 0; | 3316 | return 0; |
| 3325 | } | 3317 | } |
| 3326 | aSign = extractFloatx80Sign( a ); | 3318 | aSign = extractFloatx80Sign( a ); |
| @@ -3353,7 +3345,7 @@ flag floatx80_eq_signaling( floatx80 a, floatx80 b ) | |||
| 3353 | || ( ( extractFloatx80Exp( b ) == 0x7FFF ) | 3345 | || ( ( extractFloatx80Exp( b ) == 0x7FFF ) |
| 3354 | && (bits64) ( extractFloatx80Frac( b )<<1 ) ) | 3346 | && (bits64) ( extractFloatx80Frac( b )<<1 ) ) |
| 3355 | ) { | 3347 | ) { |
| 3356 | roundData->exception |= float_flag_invalid; | 3348 | float_raise( float_flag_invalid ); |
| 3357 | return 0; | 3349 | return 0; |
| 3358 | } | 3350 | } |
| 3359 | return | 3351 | return |
| @@ -3382,10 +3374,7 @@ flag floatx80_le_quiet( floatx80 a, floatx80 b ) | |||
| 3382 | || ( ( extractFloatx80Exp( b ) == 0x7FFF ) | 3374 | || ( ( extractFloatx80Exp( b ) == 0x7FFF ) |
| 3383 | && (bits64) ( extractFloatx80Frac( b )<<1 ) ) | 3375 | && (bits64) ( extractFloatx80Frac( b )<<1 ) ) |
| 3384 | ) { | 3376 | ) { |
| 3385 | if ( floatx80_is_signaling_nan( a ) | 3377 | /* Do nothing, even if NaN as we're quiet */ |
| 3386 | || floatx80_is_signaling_nan( b ) ) { | ||
| 3387 | roundData->exception |= float_flag_invalid; | ||
| 3388 | } | ||
| 3389 | return 0; | 3378 | return 0; |
| 3390 | } | 3379 | } |
| 3391 | aSign = extractFloatx80Sign( a ); | 3380 | aSign = extractFloatx80Sign( a ); |
| @@ -3419,10 +3408,7 @@ flag floatx80_lt_quiet( floatx80 a, floatx80 b ) | |||
| 3419 | || ( ( extractFloatx80Exp( b ) == 0x7FFF ) | 3408 | || ( ( extractFloatx80Exp( b ) == 0x7FFF ) |
| 3420 | && (bits64) ( extractFloatx80Frac( b )<<1 ) ) | 3409 | && (bits64) ( extractFloatx80Frac( b )<<1 ) ) |
| 3421 | ) { | 3410 | ) { |
| 3422 | if ( floatx80_is_signaling_nan( a ) | 3411 | /* Do nothing, even if NaN as we're quiet */ |
| 3423 | || floatx80_is_signaling_nan( b ) ) { | ||
| 3424 | roundData->exception |= float_flag_invalid; | ||
| 3425 | } | ||
| 3426 | return 0; | 3412 | return 0; |
| 3427 | } | 3413 | } |
| 3428 | aSign = extractFloatx80Sign( a ); | 3414 | aSign = extractFloatx80Sign( a ); |
diff --git a/arch/i386/kernel/apic.c b/arch/i386/kernel/apic.c index bd1dbf3bd223..a22a866de8f9 100644 --- a/arch/i386/kernel/apic.c +++ b/arch/i386/kernel/apic.c | |||
| @@ -726,15 +726,11 @@ __setup("apic=", apic_set_verbosity); | |||
| 726 | static int __init detect_init_APIC (void) | 726 | static int __init detect_init_APIC (void) |
| 727 | { | 727 | { |
| 728 | u32 h, l, features; | 728 | u32 h, l, features; |
| 729 | extern void get_cpu_vendor(struct cpuinfo_x86*); | ||
| 730 | 729 | ||
| 731 | /* Disabled by kernel option? */ | 730 | /* Disabled by kernel option? */ |
| 732 | if (enable_local_apic < 0) | 731 | if (enable_local_apic < 0) |
| 733 | return -1; | 732 | return -1; |
| 734 | 733 | ||
| 735 | /* Workaround for us being called before identify_cpu(). */ | ||
| 736 | get_cpu_vendor(&boot_cpu_data); | ||
| 737 | |||
| 738 | switch (boot_cpu_data.x86_vendor) { | 734 | switch (boot_cpu_data.x86_vendor) { |
| 739 | case X86_VENDOR_AMD: | 735 | case X86_VENDOR_AMD: |
| 740 | if ((boot_cpu_data.x86 == 6 && boot_cpu_data.x86_model > 1) || | 736 | if ((boot_cpu_data.x86 == 6 && boot_cpu_data.x86_model > 1) || |
diff --git a/arch/i386/kernel/nmi.c b/arch/i386/kernel/nmi.c index da6c46d667cb..8c242bb1ef45 100644 --- a/arch/i386/kernel/nmi.c +++ b/arch/i386/kernel/nmi.c | |||
| @@ -195,7 +195,7 @@ static void disable_lapic_nmi_watchdog(void) | |||
| 195 | wrmsr(MSR_P6_EVNTSEL0, 0, 0); | 195 | wrmsr(MSR_P6_EVNTSEL0, 0, 0); |
| 196 | break; | 196 | break; |
| 197 | case 15: | 197 | case 15: |
| 198 | if (boot_cpu_data.x86_model > 0x3) | 198 | if (boot_cpu_data.x86_model > 0x4) |
| 199 | break; | 199 | break; |
| 200 | 200 | ||
| 201 | wrmsr(MSR_P4_IQ_CCCR0, 0, 0); | 201 | wrmsr(MSR_P4_IQ_CCCR0, 0, 0); |
| @@ -432,7 +432,7 @@ void setup_apic_nmi_watchdog (void) | |||
| 432 | setup_p6_watchdog(); | 432 | setup_p6_watchdog(); |
| 433 | break; | 433 | break; |
| 434 | case 15: | 434 | case 15: |
| 435 | if (boot_cpu_data.x86_model > 0x3) | 435 | if (boot_cpu_data.x86_model > 0x4) |
| 436 | return; | 436 | return; |
| 437 | 437 | ||
| 438 | if (!setup_p4_watchdog()) | 438 | if (!setup_p4_watchdog()) |
diff --git a/arch/i386/kernel/traps.c b/arch/i386/kernel/traps.c index a61f33d06ea3..cd2d5d5514fe 100644 --- a/arch/i386/kernel/traps.c +++ b/arch/i386/kernel/traps.c | |||
| @@ -803,15 +803,17 @@ void math_error(void __user *eip) | |||
| 803 | */ | 803 | */ |
| 804 | cwd = get_fpu_cwd(task); | 804 | cwd = get_fpu_cwd(task); |
| 805 | swd = get_fpu_swd(task); | 805 | swd = get_fpu_swd(task); |
| 806 | switch (((~cwd) & swd & 0x3f) | (swd & 0x240)) { | 806 | switch (swd & ~cwd & 0x3f) { |
| 807 | case 0x000: | 807 | case 0x000: |
| 808 | default: | 808 | default: |
| 809 | break; | 809 | break; |
| 810 | case 0x001: /* Invalid Op */ | 810 | case 0x001: /* Invalid Op */ |
| 811 | case 0x041: /* Stack Fault */ | 811 | /* |
| 812 | case 0x241: /* Stack Fault | Direction */ | 812 | * swd & 0x240 == 0x040: Stack Underflow |
| 813 | * swd & 0x240 == 0x240: Stack Overflow | ||
| 814 | * User must clear the SF bit (0x40) if set | ||
| 815 | */ | ||
| 813 | info.si_code = FPE_FLTINV; | 816 | info.si_code = FPE_FLTINV; |
| 814 | /* Should we clear the SF or let user space do it ???? */ | ||
| 815 | break; | 817 | break; |
| 816 | case 0x002: /* Denormalize */ | 818 | case 0x002: /* Denormalize */ |
| 817 | case 0x010: /* Underflow */ | 819 | case 0x010: /* Underflow */ |
diff --git a/arch/ia64/Kconfig b/arch/ia64/Kconfig index cbb3e0cef93a..80988136f26d 100644 --- a/arch/ia64/Kconfig +++ b/arch/ia64/Kconfig | |||
| @@ -392,15 +392,8 @@ menu "Bus options (PCI, PCMCIA)" | |||
| 392 | config PCI | 392 | config PCI |
| 393 | bool "PCI support" | 393 | bool "PCI support" |
| 394 | help | 394 | help |
| 395 | Find out whether you have a PCI motherboard. PCI is the name of a | 395 | Real IA-64 machines all have PCI/PCI-X/PCI Express busses. Say Y |
| 396 | bus system, i.e. the way the CPU talks to the other stuff inside | 396 | here unless you are using a simulator without PCI support. |
| 397 | your box. Other bus systems are ISA, EISA, MicroChannel (MCA) or | ||
| 398 | VESA. If you have PCI, say Y, otherwise N. | ||
| 399 | |||
| 400 | The PCI-HOWTO, available from | ||
| 401 | <http://www.tldp.org/docs.html#howto>, contains valuable | ||
| 402 | information about which PCI hardware does work under Linux and which | ||
| 403 | doesn't. | ||
| 404 | 397 | ||
| 405 | config PCI_DOMAINS | 398 | config PCI_DOMAINS |
| 406 | bool | 399 | bool |
diff --git a/arch/ia64/configs/sn2_defconfig b/arch/ia64/configs/sn2_defconfig index 04d0b00a2b8c..dccf35c60b94 100644 --- a/arch/ia64/configs/sn2_defconfig +++ b/arch/ia64/configs/sn2_defconfig | |||
| @@ -1,7 +1,7 @@ | |||
| 1 | # | 1 | # |
| 2 | # Automatically generated make config: don't edit | 2 | # Automatically generated make config: don't edit |
| 3 | # Linux kernel version: 2.6.10 | 3 | # Linux kernel version: 2.6.13-rc6 |
| 4 | # Mon Jan 10 13:57:35 2005 | 4 | # Tue Aug 16 14:40:41 2005 |
| 5 | # | 5 | # |
| 6 | 6 | ||
| 7 | # | 7 | # |
| @@ -10,6 +10,7 @@ | |||
| 10 | CONFIG_EXPERIMENTAL=y | 10 | CONFIG_EXPERIMENTAL=y |
| 11 | CONFIG_CLEAN_COMPILE=y | 11 | CONFIG_CLEAN_COMPILE=y |
| 12 | CONFIG_LOCK_KERNEL=y | 12 | CONFIG_LOCK_KERNEL=y |
| 13 | CONFIG_INIT_ENV_ARG_LIMIT=32 | ||
| 13 | 14 | ||
| 14 | # | 15 | # |
| 15 | # General setup | 16 | # General setup |
| @@ -21,24 +22,26 @@ CONFIG_POSIX_MQUEUE=y | |||
| 21 | # CONFIG_BSD_PROCESS_ACCT is not set | 22 | # CONFIG_BSD_PROCESS_ACCT is not set |
| 22 | CONFIG_SYSCTL=y | 23 | CONFIG_SYSCTL=y |
| 23 | # CONFIG_AUDIT is not set | 24 | # CONFIG_AUDIT is not set |
| 24 | CONFIG_LOG_BUF_SHIFT=20 | ||
| 25 | CONFIG_HOTPLUG=y | 25 | CONFIG_HOTPLUG=y |
| 26 | CONFIG_KOBJECT_UEVENT=y | 26 | CONFIG_KOBJECT_UEVENT=y |
| 27 | # CONFIG_IKCONFIG is not set | 27 | # CONFIG_IKCONFIG is not set |
| 28 | CONFIG_CPUSETS=y | ||
| 28 | # CONFIG_EMBEDDED is not set | 29 | # CONFIG_EMBEDDED is not set |
| 29 | CONFIG_KALLSYMS=y | 30 | CONFIG_KALLSYMS=y |
| 30 | CONFIG_KALLSYMS_ALL=y | 31 | CONFIG_KALLSYMS_ALL=y |
| 31 | # CONFIG_KALLSYMS_EXTRA_PASS is not set | 32 | # CONFIG_KALLSYMS_EXTRA_PASS is not set |
| 33 | CONFIG_PRINTK=y | ||
| 34 | CONFIG_BUG=y | ||
| 35 | CONFIG_BASE_FULL=y | ||
| 32 | CONFIG_FUTEX=y | 36 | CONFIG_FUTEX=y |
| 33 | CONFIG_EPOLL=y | 37 | CONFIG_EPOLL=y |
| 34 | CONFIG_CPUSETS=y | ||
| 35 | # CONFIG_CC_OPTIMIZE_FOR_SIZE is not set | ||
| 36 | CONFIG_SHMEM=y | 38 | CONFIG_SHMEM=y |
| 37 | CONFIG_CC_ALIGN_FUNCTIONS=0 | 39 | CONFIG_CC_ALIGN_FUNCTIONS=0 |
| 38 | CONFIG_CC_ALIGN_LABELS=0 | 40 | CONFIG_CC_ALIGN_LABELS=0 |
| 39 | CONFIG_CC_ALIGN_LOOPS=0 | 41 | CONFIG_CC_ALIGN_LOOPS=0 |
| 40 | CONFIG_CC_ALIGN_JUMPS=0 | 42 | CONFIG_CC_ALIGN_JUMPS=0 |
| 41 | # CONFIG_TINY_SHMEM is not set | 43 | # CONFIG_TINY_SHMEM is not set |
| 44 | CONFIG_BASE_SMALL=0 | ||
| 42 | 45 | ||
| 43 | # | 46 | # |
| 44 | # Loadable module support | 47 | # Loadable module support |
| @@ -63,9 +66,12 @@ CONFIG_GENERIC_CALIBRATE_DELAY=y | |||
| 63 | CONFIG_TIME_INTERPOLATION=y | 66 | CONFIG_TIME_INTERPOLATION=y |
| 64 | CONFIG_EFI=y | 67 | CONFIG_EFI=y |
| 65 | CONFIG_GENERIC_IOMAP=y | 68 | CONFIG_GENERIC_IOMAP=y |
| 69 | CONFIG_SCHED_NO_NO_OMIT_FRAME_POINTER=y | ||
| 70 | CONFIG_IA64_UNCACHED_ALLOCATOR=y | ||
| 66 | # CONFIG_IA64_GENERIC is not set | 71 | # CONFIG_IA64_GENERIC is not set |
| 67 | # CONFIG_IA64_DIG is not set | 72 | # CONFIG_IA64_DIG is not set |
| 68 | # CONFIG_IA64_HP_ZX1 is not set | 73 | # CONFIG_IA64_HP_ZX1 is not set |
| 74 | # CONFIG_IA64_HP_ZX1_SWIOTLB is not set | ||
| 69 | CONFIG_IA64_SGI_SN2=y | 75 | CONFIG_IA64_SGI_SN2=y |
| 70 | # CONFIG_IA64_HP_SIM is not set | 76 | # CONFIG_IA64_HP_SIM is not set |
| 71 | # CONFIG_ITANIUM is not set | 77 | # CONFIG_ITANIUM is not set |
| @@ -74,6 +80,10 @@ CONFIG_MCKINLEY=y | |||
| 74 | # CONFIG_IA64_PAGE_SIZE_8KB is not set | 80 | # CONFIG_IA64_PAGE_SIZE_8KB is not set |
| 75 | CONFIG_IA64_PAGE_SIZE_16KB=y | 81 | CONFIG_IA64_PAGE_SIZE_16KB=y |
| 76 | # CONFIG_IA64_PAGE_SIZE_64KB is not set | 82 | # CONFIG_IA64_PAGE_SIZE_64KB is not set |
| 83 | # CONFIG_HZ_100 is not set | ||
| 84 | CONFIG_HZ_250=y | ||
| 85 | # CONFIG_HZ_1000 is not set | ||
| 86 | CONFIG_HZ=250 | ||
| 77 | CONFIG_IA64_L1_CACHE_SHIFT=7 | 87 | CONFIG_IA64_L1_CACHE_SHIFT=7 |
| 78 | CONFIG_NUMA=y | 88 | CONFIG_NUMA=y |
| 79 | CONFIG_VIRTUAL_MEM_MAP=y | 89 | CONFIG_VIRTUAL_MEM_MAP=y |
| @@ -81,11 +91,20 @@ CONFIG_HOLES_IN_ZONE=y | |||
| 81 | CONFIG_ARCH_DISCONTIGMEM_ENABLE=y | 91 | CONFIG_ARCH_DISCONTIGMEM_ENABLE=y |
| 82 | # CONFIG_IA64_CYCLONE is not set | 92 | # CONFIG_IA64_CYCLONE is not set |
| 83 | CONFIG_IOSAPIC=y | 93 | CONFIG_IOSAPIC=y |
| 94 | CONFIG_IA64_SGI_SN_XP=m | ||
| 84 | CONFIG_FORCE_MAX_ZONEORDER=18 | 95 | CONFIG_FORCE_MAX_ZONEORDER=18 |
| 85 | CONFIG_SMP=y | 96 | CONFIG_SMP=y |
| 86 | CONFIG_NR_CPUS=512 | 97 | CONFIG_NR_CPUS=512 |
| 87 | # CONFIG_HOTPLUG_CPU is not set | 98 | # CONFIG_HOTPLUG_CPU is not set |
| 99 | CONFIG_SCHED_SMT=y | ||
| 88 | CONFIG_PREEMPT=y | 100 | CONFIG_PREEMPT=y |
| 101 | CONFIG_SELECT_MEMORY_MODEL=y | ||
| 102 | # CONFIG_FLATMEM_MANUAL is not set | ||
| 103 | CONFIG_DISCONTIGMEM_MANUAL=y | ||
| 104 | # CONFIG_SPARSEMEM_MANUAL is not set | ||
| 105 | CONFIG_DISCONTIGMEM=y | ||
| 106 | CONFIG_FLAT_NODE_MEM_MAP=y | ||
| 107 | CONFIG_NEED_MULTIPLE_NODES=y | ||
| 89 | CONFIG_HAVE_DEC_LOCK=y | 108 | CONFIG_HAVE_DEC_LOCK=y |
| 90 | CONFIG_IA32_SUPPORT=y | 109 | CONFIG_IA32_SUPPORT=y |
| 91 | CONFIG_COMPAT=y | 110 | CONFIG_COMPAT=y |
| @@ -105,6 +124,7 @@ CONFIG_BINFMT_ELF=y | |||
| 105 | # | 124 | # |
| 106 | # Power management and ACPI | 125 | # Power management and ACPI |
| 107 | # | 126 | # |
| 127 | CONFIG_PM=y | ||
| 108 | CONFIG_ACPI=y | 128 | CONFIG_ACPI=y |
| 109 | 129 | ||
| 110 | # | 130 | # |
| @@ -114,6 +134,7 @@ CONFIG_ACPI_BOOT=y | |||
| 114 | CONFIG_ACPI_INTERPRETER=y | 134 | CONFIG_ACPI_INTERPRETER=y |
| 115 | # CONFIG_ACPI_BUTTON is not set | 135 | # CONFIG_ACPI_BUTTON is not set |
| 116 | CONFIG_ACPI_VIDEO=m | 136 | CONFIG_ACPI_VIDEO=m |
| 137 | CONFIG_ACPI_HOTKEY=m | ||
| 117 | # CONFIG_ACPI_FAN is not set | 138 | # CONFIG_ACPI_FAN is not set |
| 118 | # CONFIG_ACPI_PROCESSOR is not set | 139 | # CONFIG_ACPI_PROCESSOR is not set |
| 119 | CONFIG_ACPI_NUMA=y | 140 | CONFIG_ACPI_NUMA=y |
| @@ -133,6 +154,7 @@ CONFIG_PCI_DOMAINS=y | |||
| 133 | # CONFIG_PCI_MSI is not set | 154 | # CONFIG_PCI_MSI is not set |
| 134 | CONFIG_PCI_LEGACY_PROC=y | 155 | CONFIG_PCI_LEGACY_PROC=y |
| 135 | CONFIG_PCI_NAMES=y | 156 | CONFIG_PCI_NAMES=y |
| 157 | # CONFIG_PCI_DEBUG is not set | ||
| 136 | 158 | ||
| 137 | # | 159 | # |
| 138 | # PCI Hotplug Support | 160 | # PCI Hotplug Support |
| @@ -141,7 +163,6 @@ CONFIG_HOTPLUG_PCI=y | |||
| 141 | # CONFIG_HOTPLUG_PCI_FAKE is not set | 163 | # CONFIG_HOTPLUG_PCI_FAKE is not set |
| 142 | # CONFIG_HOTPLUG_PCI_ACPI is not set | 164 | # CONFIG_HOTPLUG_PCI_ACPI is not set |
| 143 | # CONFIG_HOTPLUG_PCI_CPCI is not set | 165 | # CONFIG_HOTPLUG_PCI_CPCI is not set |
| 144 | # CONFIG_HOTPLUG_PCI_PCIE is not set | ||
| 145 | # CONFIG_HOTPLUG_PCI_SHPC is not set | 166 | # CONFIG_HOTPLUG_PCI_SHPC is not set |
| 146 | CONFIG_HOTPLUG_PCI_SGI=y | 167 | CONFIG_HOTPLUG_PCI_SGI=y |
| 147 | 168 | ||
| @@ -151,8 +172,70 @@ CONFIG_HOTPLUG_PCI_SGI=y | |||
| 151 | # CONFIG_PCCARD is not set | 172 | # CONFIG_PCCARD is not set |
| 152 | 173 | ||
| 153 | # | 174 | # |
| 154 | # PC-card bridges | 175 | # Networking |
| 176 | # | ||
| 177 | CONFIG_NET=y | ||
| 178 | |||
| 179 | # | ||
| 180 | # Networking options | ||
| 181 | # | ||
| 182 | CONFIG_PACKET=y | ||
| 183 | CONFIG_PACKET_MMAP=y | ||
| 184 | CONFIG_UNIX=y | ||
| 185 | # CONFIG_NET_KEY is not set | ||
| 186 | CONFIG_INET=y | ||
| 187 | CONFIG_IP_MULTICAST=y | ||
| 188 | # CONFIG_IP_ADVANCED_ROUTER is not set | ||
| 189 | CONFIG_IP_FIB_HASH=y | ||
| 190 | # CONFIG_IP_PNP is not set | ||
| 191 | # CONFIG_NET_IPIP is not set | ||
| 192 | # CONFIG_NET_IPGRE is not set | ||
| 193 | # CONFIG_IP_MROUTE is not set | ||
| 194 | # CONFIG_ARPD is not set | ||
| 195 | CONFIG_SYN_COOKIES=y | ||
| 196 | # CONFIG_INET_AH is not set | ||
| 197 | # CONFIG_INET_ESP is not set | ||
| 198 | # CONFIG_INET_IPCOMP is not set | ||
| 199 | # CONFIG_INET_TUNNEL is not set | ||
| 200 | CONFIG_IP_TCPDIAG=y | ||
| 201 | # CONFIG_IP_TCPDIAG_IPV6 is not set | ||
| 202 | # CONFIG_TCP_CONG_ADVANCED is not set | ||
| 203 | CONFIG_TCP_CONG_BIC=y | ||
| 204 | CONFIG_IPV6=m | ||
| 205 | # CONFIG_IPV6_PRIVACY is not set | ||
| 206 | # CONFIG_INET6_AH is not set | ||
| 207 | # CONFIG_INET6_ESP is not set | ||
| 208 | # CONFIG_INET6_IPCOMP is not set | ||
| 209 | # CONFIG_INET6_TUNNEL is not set | ||
| 210 | # CONFIG_IPV6_TUNNEL is not set | ||
| 211 | # CONFIG_NETFILTER is not set | ||
| 212 | |||
| 213 | # | ||
| 214 | # SCTP Configuration (EXPERIMENTAL) | ||
| 215 | # | ||
| 216 | # CONFIG_IP_SCTP is not set | ||
| 217 | # CONFIG_ATM is not set | ||
| 218 | # CONFIG_BRIDGE is not set | ||
| 219 | # CONFIG_VLAN_8021Q is not set | ||
| 220 | # CONFIG_DECNET is not set | ||
| 221 | # CONFIG_LLC2 is not set | ||
| 222 | # CONFIG_IPX is not set | ||
| 223 | # CONFIG_ATALK is not set | ||
| 224 | # CONFIG_X25 is not set | ||
| 225 | # CONFIG_LAPB is not set | ||
| 226 | # CONFIG_NET_DIVERT is not set | ||
| 227 | # CONFIG_ECONET is not set | ||
| 228 | # CONFIG_WAN_ROUTER is not set | ||
| 229 | # CONFIG_NET_SCHED is not set | ||
| 230 | # CONFIG_NET_CLS_ROUTE is not set | ||
| 231 | |||
| 232 | # | ||
| 233 | # Network testing | ||
| 155 | # | 234 | # |
| 235 | # CONFIG_NET_PKTGEN is not set | ||
| 236 | # CONFIG_HAMRADIO is not set | ||
| 237 | # CONFIG_IRDA is not set | ||
| 238 | # CONFIG_BT is not set | ||
| 156 | 239 | ||
| 157 | # | 240 | # |
| 158 | # Device Drivers | 241 | # Device Drivers |
| @@ -163,7 +246,7 @@ CONFIG_HOTPLUG_PCI_SGI=y | |||
| 163 | # | 246 | # |
| 164 | CONFIG_STANDALONE=y | 247 | CONFIG_STANDALONE=y |
| 165 | CONFIG_PREVENT_FIRMWARE_BUILD=y | 248 | CONFIG_PREVENT_FIRMWARE_BUILD=y |
| 166 | CONFIG_FW_LOADER=m | 249 | CONFIG_FW_LOADER=y |
| 167 | # CONFIG_DEBUG_DRIVER is not set | 250 | # CONFIG_DEBUG_DRIVER is not set |
| 168 | 251 | ||
| 169 | # | 252 | # |
| @@ -188,6 +271,7 @@ CONFIG_FW_LOADER=m | |||
| 188 | # CONFIG_BLK_CPQ_CISS_DA is not set | 271 | # CONFIG_BLK_CPQ_CISS_DA is not set |
| 189 | # CONFIG_BLK_DEV_DAC960 is not set | 272 | # CONFIG_BLK_DEV_DAC960 is not set |
| 190 | # CONFIG_BLK_DEV_UMEM is not set | 273 | # CONFIG_BLK_DEV_UMEM is not set |
| 274 | # CONFIG_BLK_DEV_COW_COMMON is not set | ||
| 191 | CONFIG_BLK_DEV_LOOP=y | 275 | CONFIG_BLK_DEV_LOOP=y |
| 192 | CONFIG_BLK_DEV_CRYPTOLOOP=m | 276 | CONFIG_BLK_DEV_CRYPTOLOOP=m |
| 193 | CONFIG_BLK_DEV_NBD=m | 277 | CONFIG_BLK_DEV_NBD=m |
| @@ -252,6 +336,7 @@ CONFIG_IDEDMA_PCI_AUTO=y | |||
| 252 | # CONFIG_BLK_DEV_HPT366 is not set | 336 | # CONFIG_BLK_DEV_HPT366 is not set |
| 253 | # CONFIG_BLK_DEV_SC1200 is not set | 337 | # CONFIG_BLK_DEV_SC1200 is not set |
| 254 | # CONFIG_BLK_DEV_PIIX is not set | 338 | # CONFIG_BLK_DEV_PIIX is not set |
| 339 | # CONFIG_BLK_DEV_IT821X is not set | ||
| 255 | # CONFIG_BLK_DEV_NS87415 is not set | 340 | # CONFIG_BLK_DEV_NS87415 is not set |
| 256 | # CONFIG_BLK_DEV_PDC202XX_OLD is not set | 341 | # CONFIG_BLK_DEV_PDC202XX_OLD is not set |
| 257 | # CONFIG_BLK_DEV_PDC202XX_NEW is not set | 342 | # CONFIG_BLK_DEV_PDC202XX_NEW is not set |
| @@ -282,6 +367,7 @@ CONFIG_CHR_DEV_ST=m | |||
| 282 | CONFIG_BLK_DEV_SR=m | 367 | CONFIG_BLK_DEV_SR=m |
| 283 | # CONFIG_BLK_DEV_SR_VENDOR is not set | 368 | # CONFIG_BLK_DEV_SR_VENDOR is not set |
| 284 | CONFIG_CHR_DEV_SG=m | 369 | CONFIG_CHR_DEV_SG=m |
| 370 | CONFIG_CHR_DEV_SCH=m | ||
| 285 | 371 | ||
| 286 | # | 372 | # |
| 287 | # Some SCSI devices (e.g. CD jukebox) support multiple LUNs | 373 | # Some SCSI devices (e.g. CD jukebox) support multiple LUNs |
| @@ -315,24 +401,20 @@ CONFIG_SCSI_SATA=y | |||
| 315 | # CONFIG_SCSI_ATA_PIIX is not set | 401 | # CONFIG_SCSI_ATA_PIIX is not set |
| 316 | # CONFIG_SCSI_SATA_NV is not set | 402 | # CONFIG_SCSI_SATA_NV is not set |
| 317 | # CONFIG_SCSI_SATA_PROMISE is not set | 403 | # CONFIG_SCSI_SATA_PROMISE is not set |
| 404 | # CONFIG_SCSI_SATA_QSTOR is not set | ||
| 318 | # CONFIG_SCSI_SATA_SX4 is not set | 405 | # CONFIG_SCSI_SATA_SX4 is not set |
| 319 | # CONFIG_SCSI_SATA_SIL is not set | 406 | # CONFIG_SCSI_SATA_SIL is not set |
| 320 | # CONFIG_SCSI_SATA_SIS is not set | 407 | # CONFIG_SCSI_SATA_SIS is not set |
| 321 | # CONFIG_SCSI_SATA_ULI is not set | 408 | # CONFIG_SCSI_SATA_ULI is not set |
| 322 | # CONFIG_SCSI_SATA_VIA is not set | 409 | # CONFIG_SCSI_SATA_VIA is not set |
| 323 | CONFIG_SCSI_SATA_VITESSE=y | 410 | CONFIG_SCSI_SATA_VITESSE=y |
| 324 | # CONFIG_SCSI_BUSLOGIC is not set | ||
| 325 | # CONFIG_SCSI_DMX3191D is not set | 411 | # CONFIG_SCSI_DMX3191D is not set |
| 326 | # CONFIG_SCSI_EATA is not set | ||
| 327 | # CONFIG_SCSI_EATA_PIO is not set | ||
| 328 | # CONFIG_SCSI_FUTURE_DOMAIN is not set | 412 | # CONFIG_SCSI_FUTURE_DOMAIN is not set |
| 329 | # CONFIG_SCSI_GDTH is not set | ||
| 330 | # CONFIG_SCSI_IPS is not set | 413 | # CONFIG_SCSI_IPS is not set |
| 331 | # CONFIG_SCSI_INITIO is not set | 414 | # CONFIG_SCSI_INITIO is not set |
| 332 | # CONFIG_SCSI_INIA100 is not set | 415 | # CONFIG_SCSI_INIA100 is not set |
| 333 | # CONFIG_SCSI_SYM53C8XX_2 is not set | 416 | # CONFIG_SCSI_SYM53C8XX_2 is not set |
| 334 | # CONFIG_SCSI_IPR is not set | 417 | # CONFIG_SCSI_IPR is not set |
| 335 | # CONFIG_SCSI_QLOGIC_ISP is not set | ||
| 336 | # CONFIG_SCSI_QLOGIC_FC is not set | 418 | # CONFIG_SCSI_QLOGIC_FC is not set |
| 337 | CONFIG_SCSI_QLOGIC_1280=y | 419 | CONFIG_SCSI_QLOGIC_1280=y |
| 338 | # CONFIG_SCSI_QLOGIC_1280_1040 is not set | 420 | # CONFIG_SCSI_QLOGIC_1280_1040 is not set |
| @@ -342,6 +424,8 @@ CONFIG_SCSI_QLA22XX=y | |||
| 342 | CONFIG_SCSI_QLA2300=y | 424 | CONFIG_SCSI_QLA2300=y |
| 343 | CONFIG_SCSI_QLA2322=y | 425 | CONFIG_SCSI_QLA2322=y |
| 344 | # CONFIG_SCSI_QLA6312 is not set | 426 | # CONFIG_SCSI_QLA6312 is not set |
| 427 | # CONFIG_SCSI_QLA24XX is not set | ||
| 428 | # CONFIG_SCSI_LPFC is not set | ||
| 345 | # CONFIG_SCSI_DC395x is not set | 429 | # CONFIG_SCSI_DC395x is not set |
| 346 | # CONFIG_SCSI_DC390T is not set | 430 | # CONFIG_SCSI_DC390T is not set |
| 347 | # CONFIG_SCSI_DEBUG is not set | 431 | # CONFIG_SCSI_DEBUG is not set |
| @@ -364,11 +448,15 @@ CONFIG_DM_CRYPT=m | |||
| 364 | CONFIG_DM_SNAPSHOT=m | 448 | CONFIG_DM_SNAPSHOT=m |
| 365 | CONFIG_DM_MIRROR=m | 449 | CONFIG_DM_MIRROR=m |
| 366 | CONFIG_DM_ZERO=m | 450 | CONFIG_DM_ZERO=m |
| 451 | CONFIG_DM_MULTIPATH=m | ||
| 452 | CONFIG_DM_MULTIPATH_EMC=m | ||
| 367 | 453 | ||
| 368 | # | 454 | # |
| 369 | # Fusion MPT device support | 455 | # Fusion MPT device support |
| 370 | # | 456 | # |
| 371 | CONFIG_FUSION=y | 457 | CONFIG_FUSION=y |
| 458 | CONFIG_FUSION_SPI=y | ||
| 459 | CONFIG_FUSION_FC=y | ||
| 372 | CONFIG_FUSION_MAX_SGE=128 | 460 | CONFIG_FUSION_MAX_SGE=128 |
| 373 | CONFIG_FUSION_CTL=m | 461 | CONFIG_FUSION_CTL=m |
| 374 | 462 | ||
| @@ -383,82 +471,13 @@ CONFIG_FUSION_CTL=m | |||
| 383 | # CONFIG_I2O is not set | 471 | # CONFIG_I2O is not set |
| 384 | 472 | ||
| 385 | # | 473 | # |
| 386 | # Networking support | 474 | # Network device support |
| 387 | # | ||
| 388 | CONFIG_NET=y | ||
| 389 | |||
| 390 | # | ||
| 391 | # Networking options | ||
| 392 | # | ||
| 393 | CONFIG_PACKET=y | ||
| 394 | CONFIG_PACKET_MMAP=y | ||
| 395 | CONFIG_NETLINK_DEV=y | ||
| 396 | CONFIG_UNIX=y | ||
| 397 | # CONFIG_NET_KEY is not set | ||
| 398 | CONFIG_INET=y | ||
| 399 | CONFIG_IP_MULTICAST=y | ||
| 400 | # CONFIG_IP_ADVANCED_ROUTER is not set | ||
| 401 | # CONFIG_IP_PNP is not set | ||
| 402 | # CONFIG_NET_IPIP is not set | ||
| 403 | # CONFIG_NET_IPGRE is not set | ||
| 404 | # CONFIG_IP_MROUTE is not set | ||
| 405 | # CONFIG_ARPD is not set | ||
| 406 | CONFIG_SYN_COOKIES=y | ||
| 407 | # CONFIG_INET_AH is not set | ||
| 408 | # CONFIG_INET_ESP is not set | ||
| 409 | # CONFIG_INET_IPCOMP is not set | ||
| 410 | # CONFIG_INET_TUNNEL is not set | ||
| 411 | CONFIG_IP_TCPDIAG=y | ||
| 412 | # CONFIG_IP_TCPDIAG_IPV6 is not set | ||
| 413 | CONFIG_IPV6=m | ||
| 414 | # CONFIG_IPV6_PRIVACY is not set | ||
| 415 | # CONFIG_INET6_AH is not set | ||
| 416 | # CONFIG_INET6_ESP is not set | ||
| 417 | # CONFIG_INET6_IPCOMP is not set | ||
| 418 | # CONFIG_INET6_TUNNEL is not set | ||
| 419 | # CONFIG_IPV6_TUNNEL is not set | ||
| 420 | # CONFIG_NETFILTER is not set | ||
| 421 | |||
| 422 | # | ||
| 423 | # SCTP Configuration (EXPERIMENTAL) | ||
| 424 | # | ||
| 425 | # CONFIG_IP_SCTP is not set | ||
| 426 | # CONFIG_ATM is not set | ||
| 427 | # CONFIG_BRIDGE is not set | ||
| 428 | # CONFIG_VLAN_8021Q is not set | ||
| 429 | # CONFIG_DECNET is not set | ||
| 430 | # CONFIG_LLC2 is not set | ||
| 431 | # CONFIG_IPX is not set | ||
| 432 | # CONFIG_ATALK is not set | ||
| 433 | # CONFIG_X25 is not set | ||
| 434 | # CONFIG_LAPB is not set | ||
| 435 | # CONFIG_NET_DIVERT is not set | ||
| 436 | # CONFIG_ECONET is not set | ||
| 437 | # CONFIG_WAN_ROUTER is not set | ||
| 438 | |||
| 439 | # | ||
| 440 | # QoS and/or fair queueing | ||
| 441 | # | ||
| 442 | # CONFIG_NET_SCHED is not set | ||
| 443 | # CONFIG_NET_CLS_ROUTE is not set | ||
| 444 | |||
| 445 | # | ||
| 446 | # Network testing | ||
| 447 | # | 475 | # |
| 448 | # CONFIG_NET_PKTGEN is not set | ||
| 449 | CONFIG_NETPOLL=y | ||
| 450 | # CONFIG_NETPOLL_RX is not set | ||
| 451 | # CONFIG_NETPOLL_TRAP is not set | ||
| 452 | CONFIG_NET_POLL_CONTROLLER=y | ||
| 453 | # CONFIG_HAMRADIO is not set | ||
| 454 | # CONFIG_IRDA is not set | ||
| 455 | # CONFIG_BT is not set | ||
| 456 | CONFIG_NETDEVICES=y | 476 | CONFIG_NETDEVICES=y |
| 457 | # CONFIG_DUMMY is not set | 477 | # CONFIG_DUMMY is not set |
| 458 | # CONFIG_BONDING is not set | 478 | # CONFIG_BONDING is not set |
| 459 | # CONFIG_EQUALIZER is not set | 479 | # CONFIG_EQUALIZER is not set |
| 460 | # CONFIG_TUN is not set | 480 | # CONFIG_TUN is not set |
| 461 | # CONFIG_ETHERTAP is not set | ||
| 462 | 481 | ||
| 463 | # | 482 | # |
| 464 | # ARCnet devices | 483 | # ARCnet devices |
| @@ -480,8 +499,10 @@ CONFIG_NETDEVICES=y | |||
| 480 | # CONFIG_HAMACHI is not set | 499 | # CONFIG_HAMACHI is not set |
| 481 | # CONFIG_YELLOWFIN is not set | 500 | # CONFIG_YELLOWFIN is not set |
| 482 | # CONFIG_R8169 is not set | 501 | # CONFIG_R8169 is not set |
| 502 | # CONFIG_SKGE is not set | ||
| 483 | # CONFIG_SK98LIN is not set | 503 | # CONFIG_SK98LIN is not set |
| 484 | CONFIG_TIGON3=y | 504 | CONFIG_TIGON3=y |
| 505 | # CONFIG_BNX2 is not set | ||
| 485 | 506 | ||
| 486 | # | 507 | # |
| 487 | # Ethernet (10000 Mbit) | 508 | # Ethernet (10000 Mbit) |
| @@ -512,6 +533,10 @@ CONFIG_S2IO=m | |||
| 512 | # CONFIG_NET_FC is not set | 533 | # CONFIG_NET_FC is not set |
| 513 | # CONFIG_SHAPER is not set | 534 | # CONFIG_SHAPER is not set |
| 514 | CONFIG_NETCONSOLE=y | 535 | CONFIG_NETCONSOLE=y |
| 536 | CONFIG_NETPOLL=y | ||
| 537 | # CONFIG_NETPOLL_RX is not set | ||
| 538 | # CONFIG_NETPOLL_TRAP is not set | ||
| 539 | CONFIG_NET_POLL_CONTROLLER=y | ||
| 515 | 540 | ||
| 516 | # | 541 | # |
| 517 | # ISDN subsystem | 542 | # ISDN subsystem |
| @@ -541,14 +566,6 @@ CONFIG_INPUT_MOUSEDEV_SCREEN_Y=768 | |||
| 541 | # CONFIG_INPUT_EVBUG is not set | 566 | # CONFIG_INPUT_EVBUG is not set |
| 542 | 567 | ||
| 543 | # | 568 | # |
| 544 | # Input I/O drivers | ||
| 545 | # | ||
| 546 | # CONFIG_GAMEPORT is not set | ||
| 547 | CONFIG_SOUND_GAMEPORT=y | ||
| 548 | # CONFIG_SERIO is not set | ||
| 549 | # CONFIG_SERIO_I8042 is not set | ||
| 550 | |||
| 551 | # | ||
| 552 | # Input Device Drivers | 569 | # Input Device Drivers |
| 553 | # | 570 | # |
| 554 | # CONFIG_INPUT_KEYBOARD is not set | 571 | # CONFIG_INPUT_KEYBOARD is not set |
| @@ -558,6 +575,12 @@ CONFIG_SOUND_GAMEPORT=y | |||
| 558 | # CONFIG_INPUT_MISC is not set | 575 | # CONFIG_INPUT_MISC is not set |
| 559 | 576 | ||
| 560 | # | 577 | # |
| 578 | # Hardware I/O ports | ||
| 579 | # | ||
| 580 | # CONFIG_SERIO is not set | ||
| 581 | # CONFIG_GAMEPORT is not set | ||
| 582 | |||
| 583 | # | ||
| 561 | # Character devices | 584 | # Character devices |
| 562 | # | 585 | # |
| 563 | CONFIG_VT=y | 586 | CONFIG_VT=y |
| @@ -568,9 +591,10 @@ CONFIG_SERIAL_NONSTANDARD=y | |||
| 568 | # CONFIG_CYCLADES is not set | 591 | # CONFIG_CYCLADES is not set |
| 569 | # CONFIG_MOXA_SMARTIO is not set | 592 | # CONFIG_MOXA_SMARTIO is not set |
| 570 | # CONFIG_ISI is not set | 593 | # CONFIG_ISI is not set |
| 571 | # CONFIG_SYNCLINK is not set | ||
| 572 | # CONFIG_SYNCLINKMP is not set | 594 | # CONFIG_SYNCLINKMP is not set |
| 573 | # CONFIG_N_HDLC is not set | 595 | # CONFIG_N_HDLC is not set |
| 596 | # CONFIG_SPECIALIX is not set | ||
| 597 | # CONFIG_SX is not set | ||
| 574 | # CONFIG_STALDRV is not set | 598 | # CONFIG_STALDRV is not set |
| 575 | CONFIG_SGI_SNSC=y | 599 | CONFIG_SGI_SNSC=y |
| 576 | CONFIG_SGI_TIOCX=y | 600 | CONFIG_SGI_TIOCX=y |
| @@ -587,6 +611,7 @@ CONFIG_SGI_MBCS=m | |||
| 587 | CONFIG_SERIAL_CORE=y | 611 | CONFIG_SERIAL_CORE=y |
| 588 | CONFIG_SERIAL_CORE_CONSOLE=y | 612 | CONFIG_SERIAL_CORE_CONSOLE=y |
| 589 | CONFIG_SERIAL_SGI_L1_CONSOLE=y | 613 | CONFIG_SERIAL_SGI_L1_CONSOLE=y |
| 614 | # CONFIG_SERIAL_JSM is not set | ||
| 590 | CONFIG_SERIAL_SGI_IOC4=y | 615 | CONFIG_SERIAL_SGI_IOC4=y |
| 591 | CONFIG_UNIX98_PTYS=y | 616 | CONFIG_UNIX98_PTYS=y |
| 592 | CONFIG_LEGACY_PTYS=y | 617 | CONFIG_LEGACY_PTYS=y |
| @@ -615,12 +640,19 @@ CONFIG_EFI_RTC=y | |||
| 615 | CONFIG_RAW_DRIVER=m | 640 | CONFIG_RAW_DRIVER=m |
| 616 | # CONFIG_HPET is not set | 641 | # CONFIG_HPET is not set |
| 617 | CONFIG_MAX_RAW_DEVS=256 | 642 | CONFIG_MAX_RAW_DEVS=256 |
| 643 | # CONFIG_HANGCHECK_TIMER is not set | ||
| 618 | CONFIG_MMTIMER=y | 644 | CONFIG_MMTIMER=y |
| 619 | 645 | ||
| 620 | # | 646 | # |
| 647 | # TPM devices | ||
| 648 | # | ||
| 649 | # CONFIG_TCG_TPM is not set | ||
| 650 | |||
| 651 | # | ||
| 621 | # I2C support | 652 | # I2C support |
| 622 | # | 653 | # |
| 623 | # CONFIG_I2C is not set | 654 | # CONFIG_I2C is not set |
| 655 | # CONFIG_I2C_SENSOR is not set | ||
| 624 | 656 | ||
| 625 | # | 657 | # |
| 626 | # Dallas's 1-wire bus | 658 | # Dallas's 1-wire bus |
| @@ -628,6 +660,11 @@ CONFIG_MMTIMER=y | |||
| 628 | # CONFIG_W1 is not set | 660 | # CONFIG_W1 is not set |
| 629 | 661 | ||
| 630 | # | 662 | # |
| 663 | # Hardware Monitoring support | ||
| 664 | # | ||
| 665 | # CONFIG_HWMON is not set | ||
| 666 | |||
| 667 | # | ||
| 631 | # Misc devices | 668 | # Misc devices |
| 632 | # | 669 | # |
| 633 | 670 | ||
| @@ -660,6 +697,8 @@ CONFIG_DUMMY_CONSOLE=y | |||
| 660 | # | 697 | # |
| 661 | # USB support | 698 | # USB support |
| 662 | # | 699 | # |
| 700 | CONFIG_USB_ARCH_HAS_HCD=y | ||
| 701 | CONFIG_USB_ARCH_HAS_OHCI=y | ||
| 663 | CONFIG_USB=m | 702 | CONFIG_USB=m |
| 664 | # CONFIG_USB_DEBUG is not set | 703 | # CONFIG_USB_DEBUG is not set |
| 665 | 704 | ||
| @@ -669,9 +708,8 @@ CONFIG_USB=m | |||
| 669 | # CONFIG_USB_DEVICEFS is not set | 708 | # CONFIG_USB_DEVICEFS is not set |
| 670 | # CONFIG_USB_BANDWIDTH is not set | 709 | # CONFIG_USB_BANDWIDTH is not set |
| 671 | # CONFIG_USB_DYNAMIC_MINORS is not set | 710 | # CONFIG_USB_DYNAMIC_MINORS is not set |
| 711 | # CONFIG_USB_SUSPEND is not set | ||
| 672 | # CONFIG_USB_OTG is not set | 712 | # CONFIG_USB_OTG is not set |
| 673 | CONFIG_USB_ARCH_HAS_HCD=y | ||
| 674 | CONFIG_USB_ARCH_HAS_OHCI=y | ||
| 675 | 713 | ||
| 676 | # | 714 | # |
| 677 | # USB Host Controller Drivers | 715 | # USB Host Controller Drivers |
| @@ -679,7 +717,10 @@ CONFIG_USB_ARCH_HAS_OHCI=y | |||
| 679 | CONFIG_USB_EHCI_HCD=m | 717 | CONFIG_USB_EHCI_HCD=m |
| 680 | # CONFIG_USB_EHCI_SPLIT_ISO is not set | 718 | # CONFIG_USB_EHCI_SPLIT_ISO is not set |
| 681 | # CONFIG_USB_EHCI_ROOT_HUB_TT is not set | 719 | # CONFIG_USB_EHCI_ROOT_HUB_TT is not set |
| 720 | # CONFIG_USB_ISP116X_HCD is not set | ||
| 682 | CONFIG_USB_OHCI_HCD=m | 721 | CONFIG_USB_OHCI_HCD=m |
| 722 | # CONFIG_USB_OHCI_BIG_ENDIAN is not set | ||
| 723 | CONFIG_USB_OHCI_LITTLE_ENDIAN=y | ||
| 683 | CONFIG_USB_UHCI_HCD=m | 724 | CONFIG_USB_UHCI_HCD=m |
| 684 | # CONFIG_USB_SL811_HCD is not set | 725 | # CONFIG_USB_SL811_HCD is not set |
| 685 | 726 | ||
| @@ -710,12 +751,15 @@ CONFIG_USB_HIDINPUT=y | |||
| 710 | # CONFIG_USB_MOUSE is not set | 751 | # CONFIG_USB_MOUSE is not set |
| 711 | # CONFIG_USB_AIPTEK is not set | 752 | # CONFIG_USB_AIPTEK is not set |
| 712 | # CONFIG_USB_WACOM is not set | 753 | # CONFIG_USB_WACOM is not set |
| 754 | # CONFIG_USB_ACECAD is not set | ||
| 713 | # CONFIG_USB_KBTAB is not set | 755 | # CONFIG_USB_KBTAB is not set |
| 714 | # CONFIG_USB_POWERMATE is not set | 756 | # CONFIG_USB_POWERMATE is not set |
| 715 | # CONFIG_USB_MTOUCH is not set | 757 | # CONFIG_USB_MTOUCH is not set |
| 758 | # CONFIG_USB_ITMTOUCH is not set | ||
| 716 | # CONFIG_USB_EGALAX is not set | 759 | # CONFIG_USB_EGALAX is not set |
| 717 | # CONFIG_USB_XPAD is not set | 760 | # CONFIG_USB_XPAD is not set |
| 718 | # CONFIG_USB_ATI_REMOTE is not set | 761 | # CONFIG_USB_ATI_REMOTE is not set |
| 762 | # CONFIG_USB_KEYSPAN_REMOTE is not set | ||
| 719 | 763 | ||
| 720 | # | 764 | # |
| 721 | # USB Imaging devices | 765 | # USB Imaging devices |
| @@ -740,6 +784,7 @@ CONFIG_USB_HIDINPUT=y | |||
| 740 | # CONFIG_USB_PEGASUS is not set | 784 | # CONFIG_USB_PEGASUS is not set |
| 741 | # CONFIG_USB_RTL8150 is not set | 785 | # CONFIG_USB_RTL8150 is not set |
| 742 | # CONFIG_USB_USBNET is not set | 786 | # CONFIG_USB_USBNET is not set |
| 787 | CONFIG_USB_MON=y | ||
| 743 | 788 | ||
| 744 | # | 789 | # |
| 745 | # USB port drivers | 790 | # USB port drivers |
| @@ -763,9 +808,12 @@ CONFIG_USB_HIDINPUT=y | |||
| 763 | # CONFIG_USB_CYTHERM is not set | 808 | # CONFIG_USB_CYTHERM is not set |
| 764 | # CONFIG_USB_PHIDGETKIT is not set | 809 | # CONFIG_USB_PHIDGETKIT is not set |
| 765 | # CONFIG_USB_PHIDGETSERVO is not set | 810 | # CONFIG_USB_PHIDGETSERVO is not set |
| 811 | # CONFIG_USB_IDMOUSE is not set | ||
| 812 | # CONFIG_USB_SISUSBVGA is not set | ||
| 813 | # CONFIG_USB_LD is not set | ||
| 766 | 814 | ||
| 767 | # | 815 | # |
| 768 | # USB ATM/DSL drivers | 816 | # USB DSL modem support |
| 769 | # | 817 | # |
| 770 | 818 | ||
| 771 | # | 819 | # |
| @@ -782,6 +830,7 @@ CONFIG_USB_HIDINPUT=y | |||
| 782 | # InfiniBand support | 830 | # InfiniBand support |
| 783 | # | 831 | # |
| 784 | CONFIG_INFINIBAND=m | 832 | CONFIG_INFINIBAND=m |
| 833 | CONFIG_INFINIBAND_USER_VERBS=m | ||
| 785 | CONFIG_INFINIBAND_MTHCA=m | 834 | CONFIG_INFINIBAND_MTHCA=m |
| 786 | # CONFIG_INFINIBAND_MTHCA_DEBUG is not set | 835 | # CONFIG_INFINIBAND_MTHCA_DEBUG is not set |
| 787 | CONFIG_INFINIBAND_IPOIB=m | 836 | CONFIG_INFINIBAND_IPOIB=m |
| @@ -799,6 +848,7 @@ CONFIG_EXT2_FS=y | |||
| 799 | CONFIG_EXT2_FS_XATTR=y | 848 | CONFIG_EXT2_FS_XATTR=y |
| 800 | CONFIG_EXT2_FS_POSIX_ACL=y | 849 | CONFIG_EXT2_FS_POSIX_ACL=y |
| 801 | CONFIG_EXT2_FS_SECURITY=y | 850 | CONFIG_EXT2_FS_SECURITY=y |
| 851 | # CONFIG_EXT2_FS_XIP is not set | ||
| 802 | CONFIG_EXT3_FS=y | 852 | CONFIG_EXT3_FS=y |
| 803 | CONFIG_EXT3_FS_XATTR=y | 853 | CONFIG_EXT3_FS_XATTR=y |
| 804 | CONFIG_EXT3_FS_POSIX_ACL=y | 854 | CONFIG_EXT3_FS_POSIX_ACL=y |
| @@ -814,13 +864,19 @@ CONFIG_REISERFS_FS_POSIX_ACL=y | |||
| 814 | CONFIG_REISERFS_FS_SECURITY=y | 864 | CONFIG_REISERFS_FS_SECURITY=y |
| 815 | # CONFIG_JFS_FS is not set | 865 | # CONFIG_JFS_FS is not set |
| 816 | CONFIG_FS_POSIX_ACL=y | 866 | CONFIG_FS_POSIX_ACL=y |
| 867 | |||
| 868 | # | ||
| 869 | # XFS support | ||
| 870 | # | ||
| 817 | CONFIG_XFS_FS=y | 871 | CONFIG_XFS_FS=y |
| 872 | CONFIG_XFS_EXPORT=y | ||
| 818 | CONFIG_XFS_RT=y | 873 | CONFIG_XFS_RT=y |
| 819 | CONFIG_XFS_QUOTA=y | 874 | CONFIG_XFS_QUOTA=y |
| 820 | # CONFIG_XFS_SECURITY is not set | 875 | # CONFIG_XFS_SECURITY is not set |
| 821 | CONFIG_XFS_POSIX_ACL=y | 876 | CONFIG_XFS_POSIX_ACL=y |
| 822 | # CONFIG_MINIX_FS is not set | 877 | # CONFIG_MINIX_FS is not set |
| 823 | # CONFIG_ROMFS_FS is not set | 878 | # CONFIG_ROMFS_FS is not set |
| 879 | CONFIG_INOTIFY=y | ||
| 824 | CONFIG_QUOTA=y | 880 | CONFIG_QUOTA=y |
| 825 | # CONFIG_QFMT_V1 is not set | 881 | # CONFIG_QFMT_V1 is not set |
| 826 | # CONFIG_QFMT_V2 is not set | 882 | # CONFIG_QFMT_V2 is not set |
| @@ -854,7 +910,6 @@ CONFIG_FAT_DEFAULT_IOCHARSET="iso8859-1" | |||
| 854 | CONFIG_PROC_FS=y | 910 | CONFIG_PROC_FS=y |
| 855 | CONFIG_PROC_KCORE=y | 911 | CONFIG_PROC_KCORE=y |
| 856 | CONFIG_SYSFS=y | 912 | CONFIG_SYSFS=y |
| 857 | # CONFIG_DEVFS_FS is not set | ||
| 858 | # CONFIG_DEVPTS_FS_XATTR is not set | 913 | # CONFIG_DEVPTS_FS_XATTR is not set |
| 859 | CONFIG_TMPFS=y | 914 | CONFIG_TMPFS=y |
| 860 | CONFIG_TMPFS_XATTR=y | 915 | CONFIG_TMPFS_XATTR=y |
| @@ -885,15 +940,18 @@ CONFIG_RAMFS=y | |||
| 885 | # | 940 | # |
| 886 | CONFIG_NFS_FS=m | 941 | CONFIG_NFS_FS=m |
| 887 | CONFIG_NFS_V3=y | 942 | CONFIG_NFS_V3=y |
| 943 | # CONFIG_NFS_V3_ACL is not set | ||
| 888 | CONFIG_NFS_V4=y | 944 | CONFIG_NFS_V4=y |
| 889 | CONFIG_NFS_DIRECTIO=y | 945 | CONFIG_NFS_DIRECTIO=y |
| 890 | CONFIG_NFSD=m | 946 | CONFIG_NFSD=m |
| 891 | CONFIG_NFSD_V3=y | 947 | CONFIG_NFSD_V3=y |
| 948 | # CONFIG_NFSD_V3_ACL is not set | ||
| 892 | CONFIG_NFSD_V4=y | 949 | CONFIG_NFSD_V4=y |
| 893 | CONFIG_NFSD_TCP=y | 950 | CONFIG_NFSD_TCP=y |
| 894 | CONFIG_LOCKD=m | 951 | CONFIG_LOCKD=m |
| 895 | CONFIG_LOCKD_V4=y | 952 | CONFIG_LOCKD_V4=y |
| 896 | CONFIG_EXPORTFS=m | 953 | CONFIG_EXPORTFS=y |
| 954 | CONFIG_NFS_COMMON=y | ||
| 897 | CONFIG_SUNRPC=m | 955 | CONFIG_SUNRPC=m |
| 898 | CONFIG_SUNRPC_GSS=m | 956 | CONFIG_SUNRPC_GSS=m |
| 899 | CONFIG_RPCSEC_GSS_KRB5=m | 957 | CONFIG_RPCSEC_GSS_KRB5=m |
| @@ -980,6 +1038,9 @@ CONFIG_CRC32=y | |||
| 980 | # CONFIG_LIBCRC32C is not set | 1038 | # CONFIG_LIBCRC32C is not set |
| 981 | CONFIG_ZLIB_INFLATE=m | 1039 | CONFIG_ZLIB_INFLATE=m |
| 982 | CONFIG_ZLIB_DEFLATE=m | 1040 | CONFIG_ZLIB_DEFLATE=m |
| 1041 | CONFIG_GENERIC_ALLOCATOR=y | ||
| 1042 | CONFIG_GENERIC_HARDIRQS=y | ||
| 1043 | CONFIG_GENERIC_IRQ_PROBE=y | ||
| 983 | 1044 | ||
| 984 | # | 1045 | # |
| 985 | # Profiling support | 1046 | # Profiling support |
| @@ -989,15 +1050,19 @@ CONFIG_ZLIB_DEFLATE=m | |||
| 989 | # | 1050 | # |
| 990 | # Kernel hacking | 1051 | # Kernel hacking |
| 991 | # | 1052 | # |
| 1053 | # CONFIG_PRINTK_TIME is not set | ||
| 992 | CONFIG_DEBUG_KERNEL=y | 1054 | CONFIG_DEBUG_KERNEL=y |
| 993 | CONFIG_MAGIC_SYSRQ=y | 1055 | CONFIG_MAGIC_SYSRQ=y |
| 1056 | CONFIG_LOG_BUF_SHIFT=20 | ||
| 994 | # CONFIG_SCHEDSTATS is not set | 1057 | # CONFIG_SCHEDSTATS is not set |
| 995 | # CONFIG_DEBUG_SLAB is not set | 1058 | # CONFIG_DEBUG_SLAB is not set |
| 1059 | CONFIG_DEBUG_PREEMPT=y | ||
| 996 | # CONFIG_DEBUG_SPINLOCK is not set | 1060 | # CONFIG_DEBUG_SPINLOCK is not set |
| 997 | # CONFIG_DEBUG_SPINLOCK_SLEEP is not set | 1061 | # CONFIG_DEBUG_SPINLOCK_SLEEP is not set |
| 998 | # CONFIG_DEBUG_KOBJECT is not set | 1062 | # CONFIG_DEBUG_KOBJECT is not set |
| 999 | CONFIG_DEBUG_INFO=y | 1063 | CONFIG_DEBUG_INFO=y |
| 1000 | # CONFIG_DEBUG_FS is not set | 1064 | # CONFIG_DEBUG_FS is not set |
| 1065 | # CONFIG_KPROBES is not set | ||
| 1001 | CONFIG_IA64_GRANULE_16MB=y | 1066 | CONFIG_IA64_GRANULE_16MB=y |
| 1002 | # CONFIG_IA64_GRANULE_64MB is not set | 1067 | # CONFIG_IA64_GRANULE_64MB is not set |
| 1003 | # CONFIG_IA64_PRINT_HAZARDS is not set | 1068 | # CONFIG_IA64_PRINT_HAZARDS is not set |
| @@ -1019,11 +1084,12 @@ CONFIG_CRYPTO=y | |||
| 1019 | CONFIG_CRYPTO_HMAC=y | 1084 | CONFIG_CRYPTO_HMAC=y |
| 1020 | # CONFIG_CRYPTO_NULL is not set | 1085 | # CONFIG_CRYPTO_NULL is not set |
| 1021 | # CONFIG_CRYPTO_MD4 is not set | 1086 | # CONFIG_CRYPTO_MD4 is not set |
| 1022 | CONFIG_CRYPTO_MD5=m | 1087 | CONFIG_CRYPTO_MD5=y |
| 1023 | CONFIG_CRYPTO_SHA1=m | 1088 | CONFIG_CRYPTO_SHA1=m |
| 1024 | # CONFIG_CRYPTO_SHA256 is not set | 1089 | # CONFIG_CRYPTO_SHA256 is not set |
| 1025 | # CONFIG_CRYPTO_SHA512 is not set | 1090 | # CONFIG_CRYPTO_SHA512 is not set |
| 1026 | # CONFIG_CRYPTO_WP512 is not set | 1091 | # CONFIG_CRYPTO_WP512 is not set |
| 1092 | # CONFIG_CRYPTO_TGR192 is not set | ||
| 1027 | CONFIG_CRYPTO_DES=m | 1093 | CONFIG_CRYPTO_DES=m |
| 1028 | # CONFIG_CRYPTO_BLOWFISH is not set | 1094 | # CONFIG_CRYPTO_BLOWFISH is not set |
| 1029 | # CONFIG_CRYPTO_TWOFISH is not set | 1095 | # CONFIG_CRYPTO_TWOFISH is not set |
diff --git a/arch/ia64/configs/tiger_defconfig b/arch/ia64/configs/tiger_defconfig index 73454eee26f1..c853cfcd2d11 100644 --- a/arch/ia64/configs/tiger_defconfig +++ b/arch/ia64/configs/tiger_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.13-rc1-20050629 | 3 | # Linux kernel version: 2.6.13-rc6-tiger-smp |
| 4 | # Wed Jun 29 15:28:12 2005 | 4 | # Wed Aug 17 10:19:51 2005 |
| 5 | # | 5 | # |
| 6 | 6 | ||
| 7 | # | 7 | # |
| @@ -132,6 +132,7 @@ CONFIG_ACPI_BOOT=y | |||
| 132 | CONFIG_ACPI_INTERPRETER=y | 132 | CONFIG_ACPI_INTERPRETER=y |
| 133 | CONFIG_ACPI_BUTTON=m | 133 | CONFIG_ACPI_BUTTON=m |
| 134 | # CONFIG_ACPI_VIDEO is not set | 134 | # CONFIG_ACPI_VIDEO is not set |
| 135 | # CONFIG_ACPI_HOTKEY is not set | ||
| 135 | CONFIG_ACPI_FAN=m | 136 | CONFIG_ACPI_FAN=m |
| 136 | CONFIG_ACPI_PROCESSOR=m | 137 | CONFIG_ACPI_PROCESSOR=m |
| 137 | # CONFIG_ACPI_HOTPLUG_CPU is not set | 138 | # CONFIG_ACPI_HOTPLUG_CPU is not set |
| @@ -170,6 +171,66 @@ CONFIG_HOTPLUG_PCI_ACPI=m | |||
| 170 | # CONFIG_PCCARD is not set | 171 | # CONFIG_PCCARD is not set |
| 171 | 172 | ||
| 172 | # | 173 | # |
| 174 | # Networking | ||
| 175 | # | ||
| 176 | CONFIG_NET=y | ||
| 177 | |||
| 178 | # | ||
| 179 | # Networking options | ||
| 180 | # | ||
| 181 | CONFIG_PACKET=y | ||
| 182 | # CONFIG_PACKET_MMAP is not set | ||
| 183 | CONFIG_UNIX=y | ||
| 184 | # CONFIG_NET_KEY is not set | ||
| 185 | CONFIG_INET=y | ||
| 186 | CONFIG_IP_MULTICAST=y | ||
| 187 | # CONFIG_IP_ADVANCED_ROUTER is not set | ||
| 188 | CONFIG_IP_FIB_HASH=y | ||
| 189 | # CONFIG_IP_PNP is not set | ||
| 190 | # CONFIG_NET_IPIP is not set | ||
| 191 | # CONFIG_NET_IPGRE is not set | ||
| 192 | # CONFIG_IP_MROUTE is not set | ||
| 193 | CONFIG_ARPD=y | ||
| 194 | CONFIG_SYN_COOKIES=y | ||
| 195 | # CONFIG_INET_AH is not set | ||
| 196 | # CONFIG_INET_ESP is not set | ||
| 197 | # CONFIG_INET_IPCOMP is not set | ||
| 198 | # CONFIG_INET_TUNNEL is not set | ||
| 199 | CONFIG_IP_TCPDIAG=y | ||
| 200 | # CONFIG_IP_TCPDIAG_IPV6 is not set | ||
| 201 | # CONFIG_TCP_CONG_ADVANCED is not set | ||
| 202 | CONFIG_TCP_CONG_BIC=y | ||
| 203 | # CONFIG_IPV6 is not set | ||
| 204 | # CONFIG_NETFILTER is not set | ||
| 205 | |||
| 206 | # | ||
| 207 | # SCTP Configuration (EXPERIMENTAL) | ||
| 208 | # | ||
| 209 | # CONFIG_IP_SCTP is not set | ||
| 210 | # CONFIG_ATM is not set | ||
| 211 | # CONFIG_BRIDGE is not set | ||
| 212 | # CONFIG_VLAN_8021Q is not set | ||
| 213 | # CONFIG_DECNET is not set | ||
| 214 | # CONFIG_LLC2 is not set | ||
| 215 | # CONFIG_IPX is not set | ||
| 216 | # CONFIG_ATALK is not set | ||
| 217 | # CONFIG_X25 is not set | ||
| 218 | # CONFIG_LAPB is not set | ||
| 219 | # CONFIG_NET_DIVERT is not set | ||
| 220 | # CONFIG_ECONET is not set | ||
| 221 | # CONFIG_WAN_ROUTER is not set | ||
| 222 | # CONFIG_NET_SCHED is not set | ||
| 223 | # CONFIG_NET_CLS_ROUTE is not set | ||
| 224 | |||
| 225 | # | ||
| 226 | # Network testing | ||
| 227 | # | ||
| 228 | # CONFIG_NET_PKTGEN is not set | ||
| 229 | # CONFIG_HAMRADIO is not set | ||
| 230 | # CONFIG_IRDA is not set | ||
| 231 | # CONFIG_BT is not set | ||
| 232 | |||
| 233 | # | ||
| 173 | # Device Drivers | 234 | # Device Drivers |
| 174 | # | 235 | # |
| 175 | 236 | ||
| @@ -178,7 +239,7 @@ CONFIG_HOTPLUG_PCI_ACPI=m | |||
| 178 | # | 239 | # |
| 179 | CONFIG_STANDALONE=y | 240 | CONFIG_STANDALONE=y |
| 180 | CONFIG_PREVENT_FIRMWARE_BUILD=y | 241 | CONFIG_PREVENT_FIRMWARE_BUILD=y |
| 181 | # CONFIG_FW_LOADER is not set | 242 | CONFIG_FW_LOADER=m |
| 182 | # CONFIG_DEBUG_DRIVER is not set | 243 | # CONFIG_DEBUG_DRIVER is not set |
| 183 | 244 | ||
| 184 | # | 245 | # |
| @@ -348,6 +409,7 @@ CONFIG_SCSI_QLA22XX=m | |||
| 348 | CONFIG_SCSI_QLA2300=m | 409 | CONFIG_SCSI_QLA2300=m |
| 349 | CONFIG_SCSI_QLA2322=m | 410 | CONFIG_SCSI_QLA2322=m |
| 350 | # CONFIG_SCSI_QLA6312 is not set | 411 | # CONFIG_SCSI_QLA6312 is not set |
| 412 | # CONFIG_SCSI_QLA24XX is not set | ||
| 351 | # CONFIG_SCSI_LPFC is not set | 413 | # CONFIG_SCSI_LPFC is not set |
| 352 | # CONFIG_SCSI_DC395x is not set | 414 | # CONFIG_SCSI_DC395x is not set |
| 353 | # CONFIG_SCSI_DC390T is not set | 415 | # CONFIG_SCSI_DC390T is not set |
| @@ -393,72 +455,8 @@ CONFIG_FUSION_CTL=y | |||
| 393 | # CONFIG_I2O is not set | 455 | # CONFIG_I2O is not set |
| 394 | 456 | ||
| 395 | # | 457 | # |
| 396 | # Networking support | 458 | # Network device support |
| 397 | # | ||
| 398 | CONFIG_NET=y | ||
| 399 | |||
| 400 | # | ||
| 401 | # Networking options | ||
| 402 | # | 459 | # |
| 403 | CONFIG_PACKET=y | ||
| 404 | # CONFIG_PACKET_MMAP is not set | ||
| 405 | CONFIG_UNIX=y | ||
| 406 | # CONFIG_NET_KEY is not set | ||
| 407 | CONFIG_INET=y | ||
| 408 | CONFIG_IP_MULTICAST=y | ||
| 409 | # CONFIG_IP_ADVANCED_ROUTER is not set | ||
| 410 | CONFIG_IP_FIB_HASH=y | ||
| 411 | # CONFIG_IP_PNP is not set | ||
| 412 | # CONFIG_NET_IPIP is not set | ||
| 413 | # CONFIG_NET_IPGRE is not set | ||
| 414 | # CONFIG_IP_MROUTE is not set | ||
| 415 | CONFIG_ARPD=y | ||
| 416 | CONFIG_SYN_COOKIES=y | ||
| 417 | # CONFIG_INET_AH is not set | ||
| 418 | # CONFIG_INET_ESP is not set | ||
| 419 | # CONFIG_INET_IPCOMP is not set | ||
| 420 | # CONFIG_INET_TUNNEL is not set | ||
| 421 | CONFIG_IP_TCPDIAG=y | ||
| 422 | # CONFIG_IP_TCPDIAG_IPV6 is not set | ||
| 423 | # CONFIG_TCP_CONG_ADVANCED is not set | ||
| 424 | CONFIG_TCP_CONG_BIC=y | ||
| 425 | # CONFIG_IPV6 is not set | ||
| 426 | # CONFIG_NETFILTER is not set | ||
| 427 | |||
| 428 | # | ||
| 429 | # SCTP Configuration (EXPERIMENTAL) | ||
| 430 | # | ||
| 431 | # CONFIG_IP_SCTP is not set | ||
| 432 | # CONFIG_ATM is not set | ||
| 433 | # CONFIG_BRIDGE is not set | ||
| 434 | # CONFIG_VLAN_8021Q is not set | ||
| 435 | # CONFIG_DECNET is not set | ||
| 436 | # CONFIG_LLC2 is not set | ||
| 437 | # CONFIG_IPX is not set | ||
| 438 | # CONFIG_ATALK is not set | ||
| 439 | # CONFIG_X25 is not set | ||
| 440 | # CONFIG_LAPB is not set | ||
| 441 | # CONFIG_NET_DIVERT is not set | ||
| 442 | # CONFIG_ECONET is not set | ||
| 443 | # CONFIG_WAN_ROUTER is not set | ||
| 444 | |||
| 445 | # | ||
| 446 | # QoS and/or fair queueing | ||
| 447 | # | ||
| 448 | # CONFIG_NET_SCHED is not set | ||
| 449 | # CONFIG_NET_CLS_ROUTE is not set | ||
| 450 | |||
| 451 | # | ||
| 452 | # Network testing | ||
| 453 | # | ||
| 454 | # CONFIG_NET_PKTGEN is not set | ||
| 455 | CONFIG_NETPOLL=y | ||
| 456 | # CONFIG_NETPOLL_RX is not set | ||
| 457 | # CONFIG_NETPOLL_TRAP is not set | ||
| 458 | CONFIG_NET_POLL_CONTROLLER=y | ||
| 459 | # CONFIG_HAMRADIO is not set | ||
| 460 | # CONFIG_IRDA is not set | ||
| 461 | # CONFIG_BT is not set | ||
| 462 | CONFIG_NETDEVICES=y | 460 | CONFIG_NETDEVICES=y |
| 463 | CONFIG_DUMMY=m | 461 | CONFIG_DUMMY=m |
| 464 | # CONFIG_BONDING is not set | 462 | # CONFIG_BONDING is not set |
| @@ -555,6 +553,10 @@ CONFIG_TIGON3=y | |||
| 555 | # CONFIG_NET_FC is not set | 553 | # CONFIG_NET_FC is not set |
| 556 | # CONFIG_SHAPER is not set | 554 | # CONFIG_SHAPER is not set |
| 557 | CONFIG_NETCONSOLE=y | 555 | CONFIG_NETCONSOLE=y |
| 556 | CONFIG_NETPOLL=y | ||
| 557 | # CONFIG_NETPOLL_RX is not set | ||
| 558 | # CONFIG_NETPOLL_TRAP is not set | ||
| 559 | CONFIG_NET_POLL_CONTROLLER=y | ||
| 558 | 560 | ||
| 559 | # | 561 | # |
| 560 | # ISDN subsystem | 562 | # ISDN subsystem |
| @@ -680,6 +682,7 @@ CONFIG_DRM_R128=m | |||
| 680 | CONFIG_DRM_RADEON=m | 682 | CONFIG_DRM_RADEON=m |
| 681 | CONFIG_DRM_MGA=m | 683 | CONFIG_DRM_MGA=m |
| 682 | CONFIG_DRM_SIS=m | 684 | CONFIG_DRM_SIS=m |
| 685 | # CONFIG_DRM_VIA is not set | ||
| 683 | CONFIG_RAW_DRIVER=m | 686 | CONFIG_RAW_DRIVER=m |
| 684 | CONFIG_HPET=y | 687 | CONFIG_HPET=y |
| 685 | # CONFIG_HPET_RTC_IRQ is not set | 688 | # CONFIG_HPET_RTC_IRQ is not set |
| @@ -696,6 +699,7 @@ CONFIG_MAX_RAW_DEVS=256 | |||
| 696 | # I2C support | 699 | # I2C support |
| 697 | # | 700 | # |
| 698 | # CONFIG_I2C is not set | 701 | # CONFIG_I2C is not set |
| 702 | # CONFIG_I2C_SENSOR is not set | ||
| 699 | 703 | ||
| 700 | # | 704 | # |
| 701 | # Dallas's 1-wire bus | 705 | # Dallas's 1-wire bus |
| @@ -703,6 +707,12 @@ CONFIG_MAX_RAW_DEVS=256 | |||
| 703 | # CONFIG_W1 is not set | 707 | # CONFIG_W1 is not set |
| 704 | 708 | ||
| 705 | # | 709 | # |
| 710 | # Hardware Monitoring support | ||
| 711 | # | ||
| 712 | CONFIG_HWMON=y | ||
| 713 | # CONFIG_HWMON_DEBUG_CHIP is not set | ||
| 714 | |||
| 715 | # | ||
| 706 | # Misc devices | 716 | # Misc devices |
| 707 | # | 717 | # |
| 708 | 718 | ||
| @@ -800,6 +810,7 @@ CONFIG_USB_HIDINPUT=y | |||
| 800 | # CONFIG_USB_EGALAX is not set | 810 | # CONFIG_USB_EGALAX is not set |
| 801 | # CONFIG_USB_XPAD is not set | 811 | # CONFIG_USB_XPAD is not set |
| 802 | # CONFIG_USB_ATI_REMOTE is not set | 812 | # CONFIG_USB_ATI_REMOTE is not set |
| 813 | # CONFIG_USB_KEYSPAN_REMOTE is not set | ||
| 803 | 814 | ||
| 804 | # | 815 | # |
| 805 | # USB Imaging devices | 816 | # USB Imaging devices |
| @@ -850,6 +861,7 @@ CONFIG_USB_HIDINPUT=y | |||
| 850 | # CONFIG_USB_PHIDGETSERVO is not set | 861 | # CONFIG_USB_PHIDGETSERVO is not set |
| 851 | # CONFIG_USB_IDMOUSE is not set | 862 | # CONFIG_USB_IDMOUSE is not set |
| 852 | # CONFIG_USB_SISUSBVGA is not set | 863 | # CONFIG_USB_SISUSBVGA is not set |
| 864 | # CONFIG_USB_LD is not set | ||
| 853 | # CONFIG_USB_TEST is not set | 865 | # CONFIG_USB_TEST is not set |
| 854 | 866 | ||
| 855 | # | 867 | # |
| @@ -910,6 +922,7 @@ CONFIG_XFS_EXPORT=y | |||
| 910 | # CONFIG_XFS_POSIX_ACL is not set | 922 | # CONFIG_XFS_POSIX_ACL is not set |
| 911 | # CONFIG_MINIX_FS is not set | 923 | # CONFIG_MINIX_FS is not set |
| 912 | # CONFIG_ROMFS_FS is not set | 924 | # CONFIG_ROMFS_FS is not set |
| 925 | CONFIG_INOTIFY=y | ||
| 913 | # CONFIG_QUOTA is not set | 926 | # CONFIG_QUOTA is not set |
| 914 | CONFIG_DNOTIFY=y | 927 | CONFIG_DNOTIFY=y |
| 915 | CONFIG_AUTOFS_FS=y | 928 | CONFIG_AUTOFS_FS=y |
diff --git a/arch/ia64/configs/zx1_defconfig b/arch/ia64/configs/zx1_defconfig index b7755e4436d2..88e8867fa8e8 100644 --- a/arch/ia64/configs/zx1_defconfig +++ b/arch/ia64/configs/zx1_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.13-rc1-20050629 | 3 | # Linux kernel version: 2.6.13-rc6 |
| 4 | # Wed Jun 29 15:31:11 2005 | 4 | # Wed Aug 17 10:02:43 2005 |
| 5 | # | 5 | # |
| 6 | 6 | ||
| 7 | # | 7 | # |
| @@ -132,6 +132,7 @@ CONFIG_ACPI_BOOT=y | |||
| 132 | CONFIG_ACPI_INTERPRETER=y | 132 | CONFIG_ACPI_INTERPRETER=y |
| 133 | CONFIG_ACPI_BUTTON=y | 133 | CONFIG_ACPI_BUTTON=y |
| 134 | CONFIG_ACPI_VIDEO=m | 134 | CONFIG_ACPI_VIDEO=m |
| 135 | CONFIG_ACPI_HOTKEY=m | ||
| 135 | CONFIG_ACPI_FAN=y | 136 | CONFIG_ACPI_FAN=y |
| 136 | CONFIG_ACPI_PROCESSOR=y | 137 | CONFIG_ACPI_PROCESSOR=y |
| 137 | CONFIG_ACPI_THERMAL=y | 138 | CONFIG_ACPI_THERMAL=y |
| @@ -169,6 +170,83 @@ CONFIG_HOTPLUG_PCI_ACPI=y | |||
| 169 | # CONFIG_PCCARD is not set | 170 | # CONFIG_PCCARD is not set |
| 170 | 171 | ||
| 171 | # | 172 | # |
| 173 | # Networking | ||
| 174 | # | ||
| 175 | CONFIG_NET=y | ||
| 176 | |||
| 177 | # | ||
| 178 | # Networking options | ||
| 179 | # | ||
| 180 | CONFIG_PACKET=y | ||
| 181 | # CONFIG_PACKET_MMAP is not set | ||
| 182 | CONFIG_UNIX=y | ||
| 183 | # CONFIG_NET_KEY is not set | ||
| 184 | CONFIG_INET=y | ||
| 185 | CONFIG_IP_MULTICAST=y | ||
| 186 | # CONFIG_IP_ADVANCED_ROUTER is not set | ||
| 187 | CONFIG_IP_FIB_HASH=y | ||
| 188 | # CONFIG_IP_PNP is not set | ||
| 189 | # CONFIG_NET_IPIP is not set | ||
| 190 | # CONFIG_NET_IPGRE is not set | ||
| 191 | # CONFIG_IP_MROUTE is not set | ||
| 192 | # CONFIG_ARPD is not set | ||
| 193 | # CONFIG_SYN_COOKIES is not set | ||
| 194 | # CONFIG_INET_AH is not set | ||
| 195 | # CONFIG_INET_ESP is not set | ||
| 196 | # CONFIG_INET_IPCOMP is not set | ||
| 197 | # CONFIG_INET_TUNNEL is not set | ||
| 198 | # CONFIG_IP_TCPDIAG is not set | ||
| 199 | # CONFIG_IP_TCPDIAG_IPV6 is not set | ||
| 200 | # CONFIG_TCP_CONG_ADVANCED is not set | ||
| 201 | CONFIG_TCP_CONG_BIC=y | ||
| 202 | |||
| 203 | # | ||
| 204 | # IP: Virtual Server Configuration | ||
| 205 | # | ||
| 206 | # CONFIG_IP_VS is not set | ||
| 207 | # CONFIG_IPV6 is not set | ||
| 208 | CONFIG_NETFILTER=y | ||
| 209 | # CONFIG_NETFILTER_DEBUG is not set | ||
| 210 | |||
| 211 | # | ||
| 212 | # IP: Netfilter Configuration | ||
| 213 | # | ||
| 214 | # CONFIG_IP_NF_CONNTRACK is not set | ||
| 215 | # CONFIG_IP_NF_CONNTRACK_MARK is not set | ||
| 216 | # CONFIG_IP_NF_QUEUE is not set | ||
| 217 | # CONFIG_IP_NF_IPTABLES is not set | ||
| 218 | CONFIG_IP_NF_ARPTABLES=y | ||
| 219 | # CONFIG_IP_NF_ARPFILTER is not set | ||
| 220 | # CONFIG_IP_NF_ARP_MANGLE is not set | ||
| 221 | |||
| 222 | # | ||
| 223 | # SCTP Configuration (EXPERIMENTAL) | ||
| 224 | # | ||
| 225 | # CONFIG_IP_SCTP is not set | ||
| 226 | # CONFIG_ATM is not set | ||
| 227 | # CONFIG_BRIDGE is not set | ||
| 228 | # CONFIG_VLAN_8021Q is not set | ||
| 229 | # CONFIG_DECNET is not set | ||
| 230 | # CONFIG_LLC2 is not set | ||
| 231 | # CONFIG_IPX is not set | ||
| 232 | # CONFIG_ATALK is not set | ||
| 233 | # CONFIG_X25 is not set | ||
| 234 | # CONFIG_LAPB is not set | ||
| 235 | # CONFIG_NET_DIVERT is not set | ||
| 236 | # CONFIG_ECONET is not set | ||
| 237 | # CONFIG_WAN_ROUTER is not set | ||
| 238 | # CONFIG_NET_SCHED is not set | ||
| 239 | # CONFIG_NET_CLS_ROUTE is not set | ||
| 240 | |||
| 241 | # | ||
| 242 | # Network testing | ||
| 243 | # | ||
| 244 | # CONFIG_NET_PKTGEN is not set | ||
| 245 | # CONFIG_HAMRADIO is not set | ||
| 246 | # CONFIG_IRDA is not set | ||
| 247 | # CONFIG_BT is not set | ||
| 248 | |||
| 249 | # | ||
| 172 | # Device Drivers | 250 | # Device Drivers |
| 173 | # | 251 | # |
| 174 | 252 | ||
| @@ -349,6 +427,7 @@ CONFIG_SCSI_QLA2XXX=y | |||
| 349 | # CONFIG_SCSI_QLA2300 is not set | 427 | # CONFIG_SCSI_QLA2300 is not set |
| 350 | # CONFIG_SCSI_QLA2322 is not set | 428 | # CONFIG_SCSI_QLA2322 is not set |
| 351 | # CONFIG_SCSI_QLA6312 is not set | 429 | # CONFIG_SCSI_QLA6312 is not set |
| 430 | # CONFIG_SCSI_QLA24XX is not set | ||
| 352 | # CONFIG_SCSI_LPFC is not set | 431 | # CONFIG_SCSI_LPFC is not set |
| 353 | # CONFIG_SCSI_DC395x is not set | 432 | # CONFIG_SCSI_DC395x is not set |
| 354 | # CONFIG_SCSI_DC390T is not set | 433 | # CONFIG_SCSI_DC390T is not set |
| @@ -362,9 +441,11 @@ CONFIG_SCSI_QLA2XXX=y | |||
| 362 | # | 441 | # |
| 363 | # Fusion MPT device support | 442 | # Fusion MPT device support |
| 364 | # | 443 | # |
| 365 | # CONFIG_FUSION is not set | 444 | CONFIG_FUSION=y |
| 366 | # CONFIG_FUSION_SPI is not set | 445 | CONFIG_FUSION_SPI=y |
| 367 | # CONFIG_FUSION_FC is not set | 446 | CONFIG_FUSION_FC=y |
| 447 | CONFIG_FUSION_MAX_SGE=128 | ||
| 448 | CONFIG_FUSION_CTL=m | ||
| 368 | 449 | ||
| 369 | # | 450 | # |
| 370 | # IEEE 1394 (FireWire) support | 451 | # IEEE 1394 (FireWire) support |
| @@ -377,87 +458,8 @@ CONFIG_SCSI_QLA2XXX=y | |||
| 377 | # CONFIG_I2O is not set | 458 | # CONFIG_I2O is not set |
| 378 | 459 | ||
| 379 | # | 460 | # |
| 380 | # Networking support | 461 | # Network device support |
| 381 | # | ||
| 382 | CONFIG_NET=y | ||
| 383 | |||
| 384 | # | ||
| 385 | # Networking options | ||
| 386 | # | ||
| 387 | CONFIG_PACKET=y | ||
| 388 | # CONFIG_PACKET_MMAP is not set | ||
| 389 | CONFIG_UNIX=y | ||
| 390 | # CONFIG_NET_KEY is not set | ||
| 391 | CONFIG_INET=y | ||
| 392 | CONFIG_IP_MULTICAST=y | ||
| 393 | # CONFIG_IP_ADVANCED_ROUTER is not set | ||
| 394 | CONFIG_IP_FIB_HASH=y | ||
| 395 | # CONFIG_IP_PNP is not set | ||
| 396 | # CONFIG_NET_IPIP is not set | ||
| 397 | # CONFIG_NET_IPGRE is not set | ||
| 398 | # CONFIG_IP_MROUTE is not set | ||
| 399 | # CONFIG_ARPD is not set | ||
| 400 | # CONFIG_SYN_COOKIES is not set | ||
| 401 | # CONFIG_INET_AH is not set | ||
| 402 | # CONFIG_INET_ESP is not set | ||
| 403 | # CONFIG_INET_IPCOMP is not set | ||
| 404 | # CONFIG_INET_TUNNEL is not set | ||
| 405 | # CONFIG_IP_TCPDIAG is not set | ||
| 406 | # CONFIG_IP_TCPDIAG_IPV6 is not set | ||
| 407 | # CONFIG_TCP_CONG_ADVANCED is not set | ||
| 408 | CONFIG_TCP_CONG_BIC=y | ||
| 409 | |||
| 410 | # | ||
| 411 | # IP: Virtual Server Configuration | ||
| 412 | # | ||
| 413 | # CONFIG_IP_VS is not set | ||
| 414 | # CONFIG_IPV6 is not set | ||
| 415 | CONFIG_NETFILTER=y | ||
| 416 | # CONFIG_NETFILTER_DEBUG is not set | ||
| 417 | |||
| 418 | # | ||
| 419 | # IP: Netfilter Configuration | ||
| 420 | # | 462 | # |
| 421 | # CONFIG_IP_NF_CONNTRACK is not set | ||
| 422 | # CONFIG_IP_NF_CONNTRACK_MARK is not set | ||
| 423 | # CONFIG_IP_NF_QUEUE is not set | ||
| 424 | # CONFIG_IP_NF_IPTABLES is not set | ||
| 425 | CONFIG_IP_NF_ARPTABLES=y | ||
| 426 | # CONFIG_IP_NF_ARPFILTER is not set | ||
| 427 | # CONFIG_IP_NF_ARP_MANGLE is not set | ||
| 428 | |||
| 429 | # | ||
| 430 | # SCTP Configuration (EXPERIMENTAL) | ||
| 431 | # | ||
| 432 | # CONFIG_IP_SCTP is not set | ||
| 433 | # CONFIG_ATM is not set | ||
| 434 | # CONFIG_BRIDGE is not set | ||
| 435 | # CONFIG_VLAN_8021Q is not set | ||
| 436 | # CONFIG_DECNET is not set | ||
| 437 | # CONFIG_LLC2 is not set | ||
| 438 | # CONFIG_IPX is not set | ||
| 439 | # CONFIG_ATALK is not set | ||
| 440 | # CONFIG_X25 is not set | ||
| 441 | # CONFIG_LAPB is not set | ||
| 442 | # CONFIG_NET_DIVERT is not set | ||
| 443 | # CONFIG_ECONET is not set | ||
| 444 | # CONFIG_WAN_ROUTER is not set | ||
| 445 | |||
| 446 | # | ||
| 447 | # QoS and/or fair queueing | ||
| 448 | # | ||
| 449 | # CONFIG_NET_SCHED is not set | ||
| 450 | # CONFIG_NET_CLS_ROUTE is not set | ||
| 451 | |||
| 452 | # | ||
| 453 | # Network testing | ||
| 454 | # | ||
| 455 | # CONFIG_NET_PKTGEN is not set | ||
| 456 | # CONFIG_NETPOLL is not set | ||
| 457 | # CONFIG_NET_POLL_CONTROLLER is not set | ||
| 458 | # CONFIG_HAMRADIO is not set | ||
| 459 | # CONFIG_IRDA is not set | ||
| 460 | # CONFIG_BT is not set | ||
| 461 | CONFIG_NETDEVICES=y | 463 | CONFIG_NETDEVICES=y |
| 462 | CONFIG_DUMMY=y | 464 | CONFIG_DUMMY=y |
| 463 | # CONFIG_BONDING is not set | 465 | # CONFIG_BONDING is not set |
| @@ -555,6 +557,8 @@ CONFIG_TIGON3=y | |||
| 555 | # CONFIG_NET_FC is not set | 557 | # CONFIG_NET_FC is not set |
| 556 | # CONFIG_SHAPER is not set | 558 | # CONFIG_SHAPER is not set |
| 557 | # CONFIG_NETCONSOLE is not set | 559 | # CONFIG_NETCONSOLE is not set |
| 560 | # CONFIG_NETPOLL is not set | ||
| 561 | # CONFIG_NET_POLL_CONTROLLER is not set | ||
| 558 | 562 | ||
| 559 | # | 563 | # |
| 560 | # ISDN subsystem | 564 | # ISDN subsystem |
| @@ -659,6 +663,7 @@ CONFIG_DRM=y | |||
| 659 | CONFIG_DRM_RADEON=y | 663 | CONFIG_DRM_RADEON=y |
| 660 | # CONFIG_DRM_MGA is not set | 664 | # CONFIG_DRM_MGA is not set |
| 661 | # CONFIG_DRM_SIS is not set | 665 | # CONFIG_DRM_SIS is not set |
| 666 | # CONFIG_DRM_VIA is not set | ||
| 662 | # CONFIG_RAW_DRIVER is not set | 667 | # CONFIG_RAW_DRIVER is not set |
| 663 | # CONFIG_HPET is not set | 668 | # CONFIG_HPET is not set |
| 664 | # CONFIG_HANGCHECK_TIMER is not set | 669 | # CONFIG_HANGCHECK_TIMER is not set |
| @@ -706,47 +711,10 @@ CONFIG_I2C_ALGOPCF=y | |||
| 706 | # CONFIG_I2C_VIAPRO is not set | 711 | # CONFIG_I2C_VIAPRO is not set |
| 707 | # CONFIG_I2C_VOODOO3 is not set | 712 | # CONFIG_I2C_VOODOO3 is not set |
| 708 | # CONFIG_I2C_PCA_ISA is not set | 713 | # CONFIG_I2C_PCA_ISA is not set |
| 714 | # CONFIG_I2C_SENSOR is not set | ||
| 709 | 715 | ||
| 710 | # | 716 | # |
| 711 | # Hardware Sensors Chip support | 717 | # Miscellaneous I2C Chip support |
| 712 | # | ||
| 713 | # CONFIG_I2C_SENSOR is not set | ||
| 714 | # CONFIG_SENSORS_ADM1021 is not set | ||
| 715 | # CONFIG_SENSORS_ADM1025 is not set | ||
| 716 | # CONFIG_SENSORS_ADM1026 is not set | ||
| 717 | # CONFIG_SENSORS_ADM1031 is not set | ||
| 718 | # CONFIG_SENSORS_ADM9240 is not set | ||
| 719 | # CONFIG_SENSORS_ASB100 is not set | ||
| 720 | # CONFIG_SENSORS_ATXP1 is not set | ||
| 721 | # CONFIG_SENSORS_DS1621 is not set | ||
| 722 | # CONFIG_SENSORS_FSCHER is not set | ||
| 723 | # CONFIG_SENSORS_FSCPOS is not set | ||
| 724 | # CONFIG_SENSORS_GL518SM is not set | ||
| 725 | # CONFIG_SENSORS_GL520SM is not set | ||
| 726 | # CONFIG_SENSORS_IT87 is not set | ||
| 727 | # CONFIG_SENSORS_LM63 is not set | ||
| 728 | # CONFIG_SENSORS_LM75 is not set | ||
| 729 | # CONFIG_SENSORS_LM77 is not set | ||
| 730 | # CONFIG_SENSORS_LM78 is not set | ||
| 731 | # CONFIG_SENSORS_LM80 is not set | ||
| 732 | # CONFIG_SENSORS_LM83 is not set | ||
| 733 | # CONFIG_SENSORS_LM85 is not set | ||
| 734 | # CONFIG_SENSORS_LM87 is not set | ||
| 735 | # CONFIG_SENSORS_LM90 is not set | ||
| 736 | # CONFIG_SENSORS_LM92 is not set | ||
| 737 | # CONFIG_SENSORS_MAX1619 is not set | ||
| 738 | # CONFIG_SENSORS_PC87360 is not set | ||
| 739 | # CONFIG_SENSORS_SMSC47B397 is not set | ||
| 740 | # CONFIG_SENSORS_SIS5595 is not set | ||
| 741 | # CONFIG_SENSORS_SMSC47M1 is not set | ||
| 742 | # CONFIG_SENSORS_VIA686A is not set | ||
| 743 | # CONFIG_SENSORS_W83781D is not set | ||
| 744 | # CONFIG_SENSORS_W83L785TS is not set | ||
| 745 | # CONFIG_SENSORS_W83627HF is not set | ||
| 746 | # CONFIG_SENSORS_W83627EHF is not set | ||
| 747 | |||
| 748 | # | ||
| 749 | # Other I2C Chip support | ||
| 750 | # | 718 | # |
| 751 | # CONFIG_SENSORS_DS1337 is not set | 719 | # CONFIG_SENSORS_DS1337 is not set |
| 752 | # CONFIG_SENSORS_DS1374 is not set | 720 | # CONFIG_SENSORS_DS1374 is not set |
| @@ -767,6 +735,11 @@ CONFIG_I2C_ALGOPCF=y | |||
| 767 | # CONFIG_W1 is not set | 735 | # CONFIG_W1 is not set |
| 768 | 736 | ||
| 769 | # | 737 | # |
| 738 | # Hardware Monitoring support | ||
| 739 | # | ||
| 740 | # CONFIG_HWMON is not set | ||
| 741 | |||
| 742 | # | ||
| 770 | # Misc devices | 743 | # Misc devices |
| 771 | # | 744 | # |
| 772 | 745 | ||
| @@ -782,7 +755,6 @@ CONFIG_VIDEO_DEV=y | |||
| 782 | # | 755 | # |
| 783 | # Video Adapters | 756 | # Video Adapters |
| 784 | # | 757 | # |
| 785 | # CONFIG_TUNER_MULTI_I2C is not set | ||
| 786 | # CONFIG_VIDEO_BT848 is not set | 758 | # CONFIG_VIDEO_BT848 is not set |
| 787 | # CONFIG_VIDEO_CPIA is not set | 759 | # CONFIG_VIDEO_CPIA is not set |
| 788 | # CONFIG_VIDEO_SAA5246A is not set | 760 | # CONFIG_VIDEO_SAA5246A is not set |
| @@ -1025,6 +997,7 @@ CONFIG_USB_HIDDEV=y | |||
| 1025 | # CONFIG_USB_EGALAX is not set | 997 | # CONFIG_USB_EGALAX is not set |
| 1026 | # CONFIG_USB_XPAD is not set | 998 | # CONFIG_USB_XPAD is not set |
| 1027 | # CONFIG_USB_ATI_REMOTE is not set | 999 | # CONFIG_USB_ATI_REMOTE is not set |
| 1000 | # CONFIG_USB_KEYSPAN_REMOTE is not set | ||
| 1028 | 1001 | ||
| 1029 | # | 1002 | # |
| 1030 | # USB Imaging devices | 1003 | # USB Imaging devices |
| @@ -1080,6 +1053,7 @@ CONFIG_USB_MON=y | |||
| 1080 | # CONFIG_USB_PHIDGETSERVO is not set | 1053 | # CONFIG_USB_PHIDGETSERVO is not set |
| 1081 | # CONFIG_USB_IDMOUSE is not set | 1054 | # CONFIG_USB_IDMOUSE is not set |
| 1082 | # CONFIG_USB_SISUSBVGA is not set | 1055 | # CONFIG_USB_SISUSBVGA is not set |
| 1056 | # CONFIG_USB_LD is not set | ||
| 1083 | 1057 | ||
| 1084 | # | 1058 | # |
| 1085 | # USB DSL modem support | 1059 | # USB DSL modem support |
| @@ -1121,6 +1095,7 @@ CONFIG_JBD=y | |||
| 1121 | CONFIG_FS_MBCACHE=y | 1095 | CONFIG_FS_MBCACHE=y |
| 1122 | # CONFIG_REISERFS_FS is not set | 1096 | # CONFIG_REISERFS_FS is not set |
| 1123 | # CONFIG_JFS_FS is not set | 1097 | # CONFIG_JFS_FS is not set |
| 1098 | # CONFIG_FS_POSIX_ACL is not set | ||
| 1124 | 1099 | ||
| 1125 | # | 1100 | # |
| 1126 | # XFS support | 1101 | # XFS support |
| @@ -1128,6 +1103,7 @@ CONFIG_FS_MBCACHE=y | |||
| 1128 | # CONFIG_XFS_FS is not set | 1103 | # CONFIG_XFS_FS is not set |
| 1129 | # CONFIG_MINIX_FS is not set | 1104 | # CONFIG_MINIX_FS is not set |
| 1130 | # CONFIG_ROMFS_FS is not set | 1105 | # CONFIG_ROMFS_FS is not set |
| 1106 | # CONFIG_INOTIFY is not set | ||
| 1131 | # CONFIG_QUOTA is not set | 1107 | # CONFIG_QUOTA is not set |
| 1132 | CONFIG_DNOTIFY=y | 1108 | CONFIG_DNOTIFY=y |
| 1133 | CONFIG_AUTOFS_FS=y | 1109 | CONFIG_AUTOFS_FS=y |
diff --git a/arch/ia64/hp/sim/boot/boot_head.S b/arch/ia64/hp/sim/boot/boot_head.S index 9364199e5632..1c8c7e6a9a5e 100644 --- a/arch/ia64/hp/sim/boot/boot_head.S +++ b/arch/ia64/hp/sim/boot/boot_head.S | |||
| @@ -22,7 +22,7 @@ GLOBAL_ENTRY(_start) | |||
| 22 | .save rp, r0 | 22 | .save rp, r0 |
| 23 | .body | 23 | .body |
| 24 | movl gp = __gp | 24 | movl gp = __gp |
| 25 | movl sp = stack_mem | 25 | movl sp = stack_mem+16384-16 |
| 26 | bsw.1 | 26 | bsw.1 |
| 27 | br.call.sptk.many rp=start_bootloader | 27 | br.call.sptk.many rp=start_bootloader |
| 28 | END(_start) | 28 | END(_start) |
diff --git a/arch/ia64/kernel/perfmon.c b/arch/ia64/kernel/perfmon.c index b8ebb8e427ef..f1201ac8a116 100644 --- a/arch/ia64/kernel/perfmon.c +++ b/arch/ia64/kernel/perfmon.c | |||
| @@ -4312,6 +4312,7 @@ pfm_context_load(pfm_context_t *ctx, void *arg, int count, struct pt_regs *regs) | |||
| 4312 | DPRINT(("before cmpxchg() old_ctx=%p new_ctx=%p\n", | 4312 | DPRINT(("before cmpxchg() old_ctx=%p new_ctx=%p\n", |
| 4313 | thread->pfm_context, ctx)); | 4313 | thread->pfm_context, ctx)); |
| 4314 | 4314 | ||
| 4315 | ret = -EBUSY; | ||
| 4315 | old = ia64_cmpxchg(acq, &thread->pfm_context, NULL, ctx, sizeof(pfm_context_t *)); | 4316 | old = ia64_cmpxchg(acq, &thread->pfm_context, NULL, ctx, sizeof(pfm_context_t *)); |
| 4316 | if (old != NULL) { | 4317 | if (old != NULL) { |
| 4317 | DPRINT(("load_pid [%d] already has a context\n", req->load_pid)); | 4318 | DPRINT(("load_pid [%d] already has a context\n", req->load_pid)); |
diff --git a/arch/ia64/kernel/salinfo.c b/arch/ia64/kernel/salinfo.c index d227fabecd02..6f0cc7a6634e 100644 --- a/arch/ia64/kernel/salinfo.c +++ b/arch/ia64/kernel/salinfo.c | |||
| @@ -143,7 +143,8 @@ struct salinfo_data { | |||
| 143 | 143 | ||
| 144 | static struct salinfo_data salinfo_data[ARRAY_SIZE(salinfo_log_name)]; | 144 | static struct salinfo_data salinfo_data[ARRAY_SIZE(salinfo_log_name)]; |
| 145 | 145 | ||
| 146 | static spinlock_t data_lock, data_saved_lock; | 146 | static DEFINE_SPINLOCK(data_lock); |
| 147 | static DEFINE_SPINLOCK(data_saved_lock); | ||
| 147 | 148 | ||
| 148 | /** salinfo_platform_oemdata - optional callback to decode oemdata from an error | 149 | /** salinfo_platform_oemdata - optional callback to decode oemdata from an error |
| 149 | * record. | 150 | * record. |
diff --git a/arch/ia64/pci/pci.c b/arch/ia64/pci/pci.c index 54d9ed444e4a..f9472c50ab42 100644 --- a/arch/ia64/pci/pci.c +++ b/arch/ia64/pci/pci.c | |||
| @@ -380,6 +380,7 @@ void pcibios_bus_to_resource(struct pci_dev *dev, | |||
| 380 | res->start = region->start + offset; | 380 | res->start = region->start + offset; |
| 381 | res->end = region->end + offset; | 381 | res->end = region->end + offset; |
| 382 | } | 382 | } |
| 383 | EXPORT_SYMBOL(pcibios_bus_to_resource); | ||
| 383 | 384 | ||
| 384 | static int __devinit is_valid_resource(struct pci_dev *dev, int idx) | 385 | static int __devinit is_valid_resource(struct pci_dev *dev, int idx) |
| 385 | { | 386 | { |
diff --git a/arch/ia64/sn/kernel/io_init.c b/arch/ia64/sn/kernel/io_init.c index a6649baf629a..414cdf2e3c96 100644 --- a/arch/ia64/sn/kernel/io_init.c +++ b/arch/ia64/sn/kernel/io_init.c | |||
| @@ -203,6 +203,7 @@ static void sn_fixup_ionodes(void) | |||
| 203 | continue; | 203 | continue; |
| 204 | } | 204 | } |
| 205 | 205 | ||
| 206 | spin_lock_init(&sn_flush_device_list->sfdl_flush_lock); | ||
| 206 | hubdev->hdi_flush_nasid_list.widget_p[widget] = | 207 | hubdev->hdi_flush_nasid_list.widget_p[widget] = |
| 207 | sn_flush_device_list; | 208 | sn_flush_device_list; |
| 208 | } | 209 | } |
| @@ -322,7 +323,7 @@ void sn_pci_controller_fixup(int segment, int busnum, struct pci_bus *bus) | |||
| 322 | struct pci_controller *controller; | 323 | struct pci_controller *controller; |
| 323 | struct pcibus_bussoft *prom_bussoft_ptr; | 324 | struct pcibus_bussoft *prom_bussoft_ptr; |
| 324 | struct hubdev_info *hubdev_info; | 325 | struct hubdev_info *hubdev_info; |
| 325 | void *provider_soft; | 326 | void *provider_soft = NULL; |
| 326 | struct sn_pcibus_provider *provider; | 327 | struct sn_pcibus_provider *provider; |
| 327 | 328 | ||
| 328 | status = sal_get_pcibus_info((u64) segment, (u64) busnum, | 329 | status = sal_get_pcibus_info((u64) segment, (u64) busnum, |
| @@ -338,7 +339,7 @@ void sn_pci_controller_fixup(int segment, int busnum, struct pci_bus *bus) | |||
| 338 | if (bus == NULL) { | 339 | if (bus == NULL) { |
| 339 | bus = pci_scan_bus(busnum, &pci_root_ops, controller); | 340 | bus = pci_scan_bus(busnum, &pci_root_ops, controller); |
| 340 | if (bus == NULL) | 341 | if (bus == NULL) |
| 341 | return; /* error, or bus already scanned */ | 342 | goto error_return; /* error, or bus already scanned */ |
| 342 | bus->sysdata = NULL; | 343 | bus->sysdata = NULL; |
| 343 | } | 344 | } |
| 344 | 345 | ||
| @@ -351,28 +352,30 @@ void sn_pci_controller_fixup(int segment, int busnum, struct pci_bus *bus) | |||
| 351 | */ | 352 | */ |
| 352 | 353 | ||
| 353 | if (prom_bussoft_ptr->bs_asic_type >= PCIIO_ASIC_MAX_TYPES) | 354 | if (prom_bussoft_ptr->bs_asic_type >= PCIIO_ASIC_MAX_TYPES) |
| 354 | return; /* unsupported asic type */ | 355 | goto error_return; /* unsupported asic type */ |
| 355 | 356 | ||
| 356 | if (prom_bussoft_ptr->bs_asic_type == PCIIO_ASIC_TYPE_PPB) | 357 | if (prom_bussoft_ptr->bs_asic_type == PCIIO_ASIC_TYPE_PPB) |
| 357 | goto error_return; /* no further fixup necessary */ | 358 | goto error_return; /* no further fixup necessary */ |
| 358 | 359 | ||
| 359 | provider = sn_pci_provider[prom_bussoft_ptr->bs_asic_type]; | 360 | provider = sn_pci_provider[prom_bussoft_ptr->bs_asic_type]; |
| 360 | if (provider == NULL) | 361 | if (provider == NULL) |
| 361 | return; /* no provider registerd for this asic */ | 362 | goto error_return; /* no provider registerd for this asic */ |
| 362 | 363 | ||
| 363 | provider_soft = NULL; | 364 | bus->sysdata = controller; |
| 364 | if (provider->bus_fixup) | 365 | if (provider->bus_fixup) |
| 365 | provider_soft = (*provider->bus_fixup) (prom_bussoft_ptr, controller); | 366 | provider_soft = (*provider->bus_fixup) (prom_bussoft_ptr, controller); |
| 366 | 367 | ||
| 367 | if (provider_soft == NULL) | 368 | if (provider_soft == NULL) { |
| 368 | return; /* fixup failed or not applicable */ | 369 | /* fixup failed or not applicable */ |
| 370 | bus->sysdata = NULL; | ||
| 371 | goto error_return; | ||
| 372 | } | ||
| 369 | 373 | ||
| 370 | /* | 374 | /* |
| 371 | * Generic bus fixup goes here. Don't reference prom_bussoft_ptr | 375 | * Generic bus fixup goes here. Don't reference prom_bussoft_ptr |
| 372 | * after this point. | 376 | * after this point. |
| 373 | */ | 377 | */ |
| 374 | 378 | ||
| 375 | bus->sysdata = controller; | ||
| 376 | PCI_CONTROLLER(bus)->platform_data = provider_soft; | 379 | PCI_CONTROLLER(bus)->platform_data = provider_soft; |
| 377 | nasid = NASID_GET(SN_PCIBUS_BUSSOFT(bus)->bs_base); | 380 | nasid = NASID_GET(SN_PCIBUS_BUSSOFT(bus)->bs_base); |
| 378 | cnode = nasid_to_cnodeid(nasid); | 381 | cnode = nasid_to_cnodeid(nasid); |
diff --git a/arch/m32r/Kconfig b/arch/m32r/Kconfig index 7772951df313..7622d4ec5f08 100644 --- a/arch/m32r/Kconfig +++ b/arch/m32r/Kconfig | |||
| @@ -269,7 +269,7 @@ config NR_CPUS | |||
| 269 | # Common NUMA Features | 269 | # Common NUMA Features |
| 270 | config NUMA | 270 | config NUMA |
| 271 | bool "Numa Memory Allocation Support" | 271 | bool "Numa Memory Allocation Support" |
| 272 | depends on SMP | 272 | depends on SMP && BROKEN |
| 273 | default n | 273 | default n |
| 274 | 274 | ||
| 275 | # turning this on wastes a bunch of space. | 275 | # turning this on wastes a bunch of space. |
| @@ -286,6 +286,7 @@ menu "Bus options (PCI, PCMCIA, EISA, MCA, ISA)" | |||
| 286 | 286 | ||
| 287 | config PCI | 287 | config PCI |
| 288 | bool "PCI support" | 288 | bool "PCI support" |
| 289 | depends on BROKEN | ||
| 289 | default n | 290 | default n |
| 290 | help | 291 | help |
| 291 | Find out whether you have a PCI motherboard. PCI is the name of a | 292 | Find out whether you have a PCI motherboard. PCI is the name of a |
diff --git a/arch/m32r/Kconfig.debug b/arch/m32r/Kconfig.debug index 31039723804f..bbf711bab69e 100644 --- a/arch/m32r/Kconfig.debug +++ b/arch/m32r/Kconfig.debug | |||
| @@ -20,7 +20,7 @@ config DEBUG_STACK_USAGE | |||
| 20 | 20 | ||
| 21 | config DEBUG_PAGEALLOC | 21 | config DEBUG_PAGEALLOC |
| 22 | bool "Page alloc debugging" | 22 | bool "Page alloc debugging" |
| 23 | depends on DEBUG_KERNEL | 23 | depends on DEBUG_KERNEL && BROKEN |
| 24 | help | 24 | help |
| 25 | Unmap pages from the kernel linear mapping after free_pages(). | 25 | Unmap pages from the kernel linear mapping after free_pages(). |
| 26 | This results in a large slowdown, but helps to find certain types | 26 | This results in a large slowdown, but helps to find certain types |
diff --git a/arch/m32r/kernel/setup_m32700ut.c b/arch/m32r/kernel/setup_m32700ut.c index a146b24a556b..708634b685e4 100644 --- a/arch/m32r/kernel/setup_m32700ut.c +++ b/arch/m32r/kernel/setup_m32700ut.c | |||
| @@ -30,9 +30,11 @@ | |||
| 30 | typedef struct { | 30 | typedef struct { |
| 31 | unsigned long icucr; /* ICU Control Register */ | 31 | unsigned long icucr; /* ICU Control Register */ |
| 32 | } icu_data_t; | 32 | } icu_data_t; |
| 33 | static icu_data_t icu_data[M32700UT_NUM_CPU_IRQ]; | ||
| 34 | #else | ||
| 35 | icu_data_t icu_data[M32700UT_NUM_CPU_IRQ]; | ||
| 33 | #endif /* CONFIG_SMP */ | 36 | #endif /* CONFIG_SMP */ |
| 34 | 37 | ||
| 35 | static icu_data_t icu_data[M32700UT_NUM_CPU_IRQ]; | ||
| 36 | 38 | ||
| 37 | static void disable_m32700ut_irq(unsigned int irq) | 39 | static void disable_m32700ut_irq(unsigned int irq) |
| 38 | { | 40 | { |
diff --git a/arch/m32r/kernel/setup_opsput.c b/arch/m32r/kernel/setup_opsput.c index f0301f58bcce..d7b7ec6d30f8 100644 --- a/arch/m32r/kernel/setup_opsput.c +++ b/arch/m32r/kernel/setup_opsput.c | |||
| @@ -31,9 +31,11 @@ | |||
| 31 | typedef struct { | 31 | typedef struct { |
| 32 | unsigned long icucr; /* ICU Control Register */ | 32 | unsigned long icucr; /* ICU Control Register */ |
| 33 | } icu_data_t; | 33 | } icu_data_t; |
| 34 | static icu_data_t icu_data[OPSPUT_NUM_CPU_IRQ]; | ||
| 35 | #else | ||
| 36 | icu_data_t icu_data[OPSPUT_NUM_CPU_IRQ]; | ||
| 34 | #endif /* CONFIG_SMP */ | 37 | #endif /* CONFIG_SMP */ |
| 35 | 38 | ||
| 36 | static icu_data_t icu_data[OPSPUT_NUM_CPU_IRQ]; | ||
| 37 | 39 | ||
| 38 | static void disable_opsput_irq(unsigned int irq) | 40 | static void disable_opsput_irq(unsigned int irq) |
| 39 | { | 41 | { |
diff --git a/arch/m32r/kernel/smpboot.c b/arch/m32r/kernel/smpboot.c index f9a0e723478d..640d592ea072 100644 --- a/arch/m32r/kernel/smpboot.c +++ b/arch/m32r/kernel/smpboot.c | |||
| @@ -91,6 +91,7 @@ extern struct { | |||
| 91 | 91 | ||
| 92 | /* which physical physical ID maps to which logical CPU number */ | 92 | /* which physical physical ID maps to which logical CPU number */ |
| 93 | static volatile int physid_2_cpu[NR_CPUS]; | 93 | static volatile int physid_2_cpu[NR_CPUS]; |
| 94 | #define physid_to_cpu(physid) physid_2_cpu[physid] | ||
| 94 | 95 | ||
| 95 | /* which logical CPU number maps to which physical ID */ | 96 | /* which logical CPU number maps to which physical ID */ |
| 96 | volatile int cpu_2_physid[NR_CPUS]; | 97 | volatile int cpu_2_physid[NR_CPUS]; |
diff --git a/arch/m32r/lib/csum_partial_copy.c b/arch/m32r/lib/csum_partial_copy.c index c871b4606b07..ddb16a83a8ce 100644 --- a/arch/m32r/lib/csum_partial_copy.c +++ b/arch/m32r/lib/csum_partial_copy.c | |||
| @@ -58,3 +58,4 @@ csum_partial_copy_from_user (const unsigned char __user *src, | |||
| 58 | return csum_partial(dst, len-missing, sum); | 58 | return csum_partial(dst, len-missing, sum); |
| 59 | } | 59 | } |
| 60 | EXPORT_SYMBOL(csum_partial_copy_from_user); | 60 | EXPORT_SYMBOL(csum_partial_copy_from_user); |
| 61 | EXPORT_SYMBOL(csum_partial); | ||
diff --git a/arch/m32r/mm/discontig.c b/arch/m32r/mm/discontig.c index 1d1a01e54b3f..08e727955555 100644 --- a/arch/m32r/mm/discontig.c +++ b/arch/m32r/mm/discontig.c | |||
| @@ -12,12 +12,14 @@ | |||
| 12 | #include <linux/mmzone.h> | 12 | #include <linux/mmzone.h> |
| 13 | #include <linux/initrd.h> | 13 | #include <linux/initrd.h> |
| 14 | #include <linux/nodemask.h> | 14 | #include <linux/nodemask.h> |
| 15 | #include <linux/module.h> | ||
| 15 | 16 | ||
| 16 | #include <asm/setup.h> | 17 | #include <asm/setup.h> |
| 17 | 18 | ||
| 18 | extern char _end[]; | 19 | extern char _end[]; |
| 19 | 20 | ||
| 20 | struct pglist_data *node_data[MAX_NUMNODES]; | 21 | struct pglist_data *node_data[MAX_NUMNODES]; |
| 22 | EXPORT_SYMBOL(node_data); | ||
| 21 | static bootmem_data_t node_bdata[MAX_NUMNODES] __initdata; | 23 | static bootmem_data_t node_bdata[MAX_NUMNODES] __initdata; |
| 22 | 24 | ||
| 23 | pg_data_t m32r_node_data[MAX_NUMNODES]; | 25 | pg_data_t m32r_node_data[MAX_NUMNODES]; |
diff --git a/arch/ppc/Kconfig b/arch/ppc/Kconfig index f6db3b385fea..e6fa1d1cc03a 100644 --- a/arch/ppc/Kconfig +++ b/arch/ppc/Kconfig | |||
| @@ -911,6 +911,7 @@ config PPCBUG_NVRAM | |||
| 911 | default y if PPC_PREP | 911 | default y if PPC_PREP |
| 912 | 912 | ||
| 913 | config SMP | 913 | config SMP |
| 914 | depends on PPC_STD_MMU | ||
| 914 | bool "Symmetric multi-processing support" | 915 | bool "Symmetric multi-processing support" |
| 915 | ---help--- | 916 | ---help--- |
| 916 | This enables support for systems with more than one CPU. If you have | 917 | This enables support for systems with more than one CPU. If you have |
| @@ -930,7 +931,7 @@ config SMP | |||
| 930 | 931 | ||
| 931 | config IRQ_ALL_CPUS | 932 | config IRQ_ALL_CPUS |
| 932 | bool "Distribute interrupts on all CPUs by default" | 933 | bool "Distribute interrupts on all CPUs by default" |
| 933 | depends on SMP | 934 | depends on SMP && !MV64360 |
| 934 | help | 935 | help |
| 935 | This option gives the kernel permission to distribute IRQs across | 936 | This option gives the kernel permission to distribute IRQs across |
| 936 | multiple CPUs. Saying N here will route all IRQs to the first | 937 | multiple CPUs. Saying N here will route all IRQs to the first |
| @@ -1121,7 +1122,9 @@ config PROC_HARDWARE | |||
| 1121 | 1122 | ||
| 1122 | source "drivers/zorro/Kconfig" | 1123 | source "drivers/zorro/Kconfig" |
| 1123 | 1124 | ||
| 1125 | if !44x || BROKEN | ||
| 1124 | source kernel/power/Kconfig | 1126 | source kernel/power/Kconfig |
| 1127 | endif | ||
| 1125 | 1128 | ||
| 1126 | config SECCOMP | 1129 | config SECCOMP |
| 1127 | bool "Enable seccomp to safely compute untrusted bytecode" | 1130 | bool "Enable seccomp to safely compute untrusted bytecode" |
diff --git a/arch/ppc/platforms/4xx/Kconfig b/arch/ppc/platforms/4xx/Kconfig index f7c045764e04..805dd98908a3 100644 --- a/arch/ppc/platforms/4xx/Kconfig +++ b/arch/ppc/platforms/4xx/Kconfig | |||
| @@ -3,6 +3,11 @@ config 4xx | |||
| 3 | depends on 40x || 44x | 3 | depends on 40x || 44x |
| 4 | default y | 4 | default y |
| 5 | 5 | ||
| 6 | config WANT_EARLY_SERIAL | ||
| 7 | bool | ||
| 8 | select SERIAL_8250 | ||
| 9 | default n | ||
| 10 | |||
| 6 | menu "IBM 4xx options" | 11 | menu "IBM 4xx options" |
| 7 | depends on 4xx | 12 | depends on 4xx |
| 8 | 13 | ||
| @@ -18,6 +23,7 @@ config ASH | |||
| 18 | 23 | ||
| 19 | config BUBINGA | 24 | config BUBINGA |
| 20 | bool "Bubinga" | 25 | bool "Bubinga" |
| 26 | select WANT_EARLY_SERIAL | ||
| 21 | help | 27 | help |
| 22 | This option enables support for the IBM 405EP evaluation board. | 28 | This option enables support for the IBM 405EP evaluation board. |
| 23 | 29 | ||
| @@ -70,21 +76,25 @@ choice | |||
| 70 | 76 | ||
| 71 | config BAMBOO | 77 | config BAMBOO |
| 72 | bool "Bamboo" | 78 | bool "Bamboo" |
| 79 | select WANT_EARLY_SERIAL | ||
| 73 | help | 80 | help |
| 74 | This option enables support for the IBM PPC440EP evaluation board. | 81 | This option enables support for the IBM PPC440EP evaluation board. |
| 75 | 82 | ||
| 76 | config EBONY | 83 | config EBONY |
| 77 | bool "Ebony" | 84 | bool "Ebony" |
| 85 | select WANT_EARLY_SERIAL | ||
| 78 | help | 86 | help |
| 79 | This option enables support for the IBM PPC440GP evaluation board. | 87 | This option enables support for the IBM PPC440GP evaluation board. |
| 80 | 88 | ||
| 81 | config LUAN | 89 | config LUAN |
| 82 | bool "Luan" | 90 | bool "Luan" |
| 91 | select WANT_EARLY_SERIAL | ||
| 83 | help | 92 | help |
| 84 | This option enables support for the IBM PPC440SP evaluation board. | 93 | This option enables support for the IBM PPC440SP evaluation board. |
| 85 | 94 | ||
| 86 | config OCOTEA | 95 | config OCOTEA |
| 87 | bool "Ocotea" | 96 | bool "Ocotea" |
| 97 | select WANT_EARLY_SERIAL | ||
| 88 | help | 98 | help |
| 89 | This option enables support for the IBM PPC440GX evaluation board. | 99 | This option enables support for the IBM PPC440GX evaluation board. |
| 90 | 100 | ||
| @@ -230,10 +240,6 @@ config PPC_GEN550 | |||
| 230 | depends on 4xx | 240 | depends on 4xx |
| 231 | default y | 241 | default y |
| 232 | 242 | ||
| 233 | config PM | ||
| 234 | bool "Power Management support (EXPERIMENTAL)" | ||
| 235 | depends on 4xx && EXPERIMENTAL | ||
| 236 | |||
| 237 | choice | 243 | choice |
| 238 | prompt "TTYS0 device and default console" | 244 | prompt "TTYS0 device and default console" |
| 239 | depends on 40x | 245 | depends on 40x |
diff --git a/arch/ppc/syslib/m8xx_setup.c b/arch/ppc/syslib/m8xx_setup.c index 55a381af4e37..a3702cfe8f7c 100644 --- a/arch/ppc/syslib/m8xx_setup.c +++ b/arch/ppc/syslib/m8xx_setup.c | |||
| @@ -423,7 +423,7 @@ platform_init(unsigned long r3, unsigned long r4, unsigned long r5, | |||
| 423 | ppc_md.find_end_of_memory = m8xx_find_end_of_memory; | 423 | ppc_md.find_end_of_memory = m8xx_find_end_of_memory; |
| 424 | ppc_md.setup_io_mappings = m8xx_map_io; | 424 | ppc_md.setup_io_mappings = m8xx_map_io; |
| 425 | 425 | ||
| 426 | #if defined(CONFIG_BLK_DEV_IDE) || defined(CONFIG_BLK_DEV_IDE_MODULE) | 426 | #if defined(CONFIG_BLK_DEV_MPC8xx_IDE) |
| 427 | m8xx_ide_init(); | 427 | m8xx_ide_init(); |
| 428 | #endif | 428 | #endif |
| 429 | } | 429 | } |
diff --git a/arch/ppc/syslib/ppc4xx_dma.c b/arch/ppc/syslib/ppc4xx_dma.c index 5015ab99afd2..f15e64285f96 100644 --- a/arch/ppc/syslib/ppc4xx_dma.c +++ b/arch/ppc/syslib/ppc4xx_dma.c | |||
| @@ -620,6 +620,7 @@ ppc4xx_clr_dma_status(unsigned int dmanr) | |||
| 620 | return DMA_STATUS_GOOD; | 620 | return DMA_STATUS_GOOD; |
| 621 | } | 621 | } |
| 622 | 622 | ||
| 623 | #ifdef CONFIG_PPC4xx_EDMA | ||
| 623 | /* | 624 | /* |
| 624 | * Enables the burst on the channel (BTEN bit in the control/count register) | 625 | * Enables the burst on the channel (BTEN bit in the control/count register) |
| 625 | * Note: | 626 | * Note: |
| @@ -685,6 +686,11 @@ ppc4xx_set_burst_size(unsigned int dmanr, unsigned int bsize) | |||
| 685 | return DMA_STATUS_GOOD; | 686 | return DMA_STATUS_GOOD; |
| 686 | } | 687 | } |
| 687 | 688 | ||
| 689 | EXPORT_SYMBOL(ppc4xx_enable_burst); | ||
| 690 | EXPORT_SYMBOL(ppc4xx_disable_burst); | ||
| 691 | EXPORT_SYMBOL(ppc4xx_set_burst_size); | ||
| 692 | #endif /* CONFIG_PPC4xx_EDMA */ | ||
| 693 | |||
| 688 | EXPORT_SYMBOL(ppc4xx_init_dma_channel); | 694 | EXPORT_SYMBOL(ppc4xx_init_dma_channel); |
| 689 | EXPORT_SYMBOL(ppc4xx_get_channel_config); | 695 | EXPORT_SYMBOL(ppc4xx_get_channel_config); |
| 690 | EXPORT_SYMBOL(ppc4xx_set_channel_priority); | 696 | EXPORT_SYMBOL(ppc4xx_set_channel_priority); |
| @@ -703,6 +709,4 @@ EXPORT_SYMBOL(ppc4xx_enable_dma_interrupt); | |||
| 703 | EXPORT_SYMBOL(ppc4xx_disable_dma_interrupt); | 709 | EXPORT_SYMBOL(ppc4xx_disable_dma_interrupt); |
| 704 | EXPORT_SYMBOL(ppc4xx_get_dma_status); | 710 | EXPORT_SYMBOL(ppc4xx_get_dma_status); |
| 705 | EXPORT_SYMBOL(ppc4xx_clr_dma_status); | 711 | EXPORT_SYMBOL(ppc4xx_clr_dma_status); |
| 706 | EXPORT_SYMBOL(ppc4xx_enable_burst); | 712 | |
| 707 | EXPORT_SYMBOL(ppc4xx_disable_burst); | ||
| 708 | EXPORT_SYMBOL(ppc4xx_set_burst_size); | ||
diff --git a/arch/ppc64/kernel/iommu.c b/arch/ppc64/kernel/iommu.c index 8316426ccaf6..845eebd1e28d 100644 --- a/arch/ppc64/kernel/iommu.c +++ b/arch/ppc64/kernel/iommu.c | |||
| @@ -242,7 +242,7 @@ int iommu_map_sg(struct device *dev, struct iommu_table *tbl, | |||
| 242 | dma_addr_t dma_next = 0, dma_addr; | 242 | dma_addr_t dma_next = 0, dma_addr; |
| 243 | unsigned long flags; | 243 | unsigned long flags; |
| 244 | struct scatterlist *s, *outs, *segstart; | 244 | struct scatterlist *s, *outs, *segstart; |
| 245 | int outcount; | 245 | int outcount, incount; |
| 246 | unsigned long handle; | 246 | unsigned long handle; |
| 247 | 247 | ||
| 248 | BUG_ON(direction == DMA_NONE); | 248 | BUG_ON(direction == DMA_NONE); |
| @@ -252,6 +252,7 @@ int iommu_map_sg(struct device *dev, struct iommu_table *tbl, | |||
| 252 | 252 | ||
| 253 | outs = s = segstart = &sglist[0]; | 253 | outs = s = segstart = &sglist[0]; |
| 254 | outcount = 1; | 254 | outcount = 1; |
| 255 | incount = nelems; | ||
| 255 | handle = 0; | 256 | handle = 0; |
| 256 | 257 | ||
| 257 | /* Init first segment length for backout at failure */ | 258 | /* Init first segment length for backout at failure */ |
| @@ -338,10 +339,10 @@ int iommu_map_sg(struct device *dev, struct iommu_table *tbl, | |||
| 338 | 339 | ||
| 339 | DBG("mapped %d elements:\n", outcount); | 340 | DBG("mapped %d elements:\n", outcount); |
| 340 | 341 | ||
| 341 | /* For the sake of iommu_free_sg, we clear out the length in the | 342 | /* For the sake of iommu_unmap_sg, we clear out the length in the |
| 342 | * next entry of the sglist if we didn't fill the list completely | 343 | * next entry of the sglist if we didn't fill the list completely |
| 343 | */ | 344 | */ |
| 344 | if (outcount < nelems) { | 345 | if (outcount < incount) { |
| 345 | outs++; | 346 | outs++; |
| 346 | outs->dma_address = DMA_ERROR_CODE; | 347 | outs->dma_address = DMA_ERROR_CODE; |
| 347 | outs->dma_length = 0; | 348 | outs->dma_length = 0; |
diff --git a/arch/ppc64/kernel/setup.c b/arch/ppc64/kernel/setup.c index 687e85595208..e9c24d2dbd91 100644 --- a/arch/ppc64/kernel/setup.c +++ b/arch/ppc64/kernel/setup.c | |||
| @@ -706,6 +706,8 @@ void machine_power_off(void) | |||
| 706 | local_irq_disable(); | 706 | local_irq_disable(); |
| 707 | while (1) ; | 707 | while (1) ; |
| 708 | } | 708 | } |
| 709 | /* Used by the G5 thermal driver */ | ||
| 710 | EXPORT_SYMBOL_GPL(machine_power_off); | ||
| 709 | 711 | ||
| 710 | void machine_halt(void) | 712 | void machine_halt(void) |
| 711 | { | 713 | { |
diff --git a/arch/s390/kernel/cpcmd.c b/arch/s390/kernel/cpcmd.c index 20062145e84e..d47fecb42cc5 100644 --- a/arch/s390/kernel/cpcmd.c +++ b/arch/s390/kernel/cpcmd.c | |||
| @@ -46,9 +46,9 @@ int __cpcmd(const char *cmd, char *response, int rlen, int *response_code) | |||
| 46 | "lra 3,0(%4)\n" | 46 | "lra 3,0(%4)\n" |
| 47 | "lr 5,%5\n" | 47 | "lr 5,%5\n" |
| 48 | "diag 2,4,0x8\n" | 48 | "diag 2,4,0x8\n" |
| 49 | "brc 8, .Litfits\n" | 49 | "brc 8, 1f\n" |
| 50 | "ar 5, %5\n" | 50 | "ar 5, %5\n" |
| 51 | ".Litfits: \n" | 51 | "1: \n" |
| 52 | "lr %0,4\n" | 52 | "lr %0,4\n" |
| 53 | "lr %1,5\n" | 53 | "lr %1,5\n" |
| 54 | : "=d" (return_code), "=d" (return_len) | 54 | : "=d" (return_code), "=d" (return_len) |
| @@ -64,9 +64,9 @@ int __cpcmd(const char *cmd, char *response, int rlen, int *response_code) | |||
| 64 | "sam31\n" | 64 | "sam31\n" |
| 65 | "diag 2,4,0x8\n" | 65 | "diag 2,4,0x8\n" |
| 66 | "sam64\n" | 66 | "sam64\n" |
| 67 | "brc 8, .Litfits\n" | 67 | "brc 8, 1f\n" |
| 68 | "agr 5, %5\n" | 68 | "agr 5, %5\n" |
| 69 | ".Litfits: \n" | 69 | "1: \n" |
| 70 | "lgr %0,4\n" | 70 | "lgr %0,4\n" |
| 71 | "lgr %1,5\n" | 71 | "lgr %1,5\n" |
| 72 | : "=d" (return_code), "=d" (return_len) | 72 | : "=d" (return_code), "=d" (return_len) |
diff --git a/arch/sh/kernel/entry.S b/arch/sh/kernel/entry.S index 6615e4838ee4..fb6368159dd0 100644 --- a/arch/sh/kernel/entry.S +++ b/arch/sh/kernel/entry.S | |||
| @@ -1145,5 +1145,10 @@ ENTRY(sys_call_table) | |||
| 1145 | .long sys_add_key /* 285 */ | 1145 | .long sys_add_key /* 285 */ |
| 1146 | .long sys_request_key | 1146 | .long sys_request_key |
| 1147 | .long sys_keyctl | 1147 | .long sys_keyctl |
| 1148 | .long sys_ioprio_set | ||
| 1149 | .long sys_ioprio_get | ||
| 1150 | .long sys_inotify_init /* 290 */ | ||
| 1151 | .long sys_inotify_add_watch | ||
| 1152 | .long sys_inotify_rm_watch | ||
| 1148 | 1153 | ||
| 1149 | /* End of entry.S */ | 1154 | /* End of entry.S */ |
diff --git a/arch/sh64/kernel/syscalls.S b/arch/sh64/kernel/syscalls.S index 6aabc63e4518..a3d037805f1c 100644 --- a/arch/sh64/kernel/syscalls.S +++ b/arch/sh64/kernel/syscalls.S | |||
| @@ -342,4 +342,9 @@ sys_call_table: | |||
| 342 | .long sys_add_key | 342 | .long sys_add_key |
| 343 | .long sys_request_key | 343 | .long sys_request_key |
| 344 | .long sys_keyctl /* 315 */ | 344 | .long sys_keyctl /* 315 */ |
| 345 | .long sys_ioprio_set | ||
| 346 | .long sys_ioprio_get | ||
| 347 | .long sys_inotify_init | ||
| 348 | .long sys_inotify_add_watch | ||
| 349 | .long sys_inotify_rm_watch /* 320 */ | ||
| 345 | 350 | ||
diff --git a/arch/sparc/kernel/sparc_ksyms.c b/arch/sparc/kernel/sparc_ksyms.c index 1bd430d0ca06..8faa8dc4de43 100644 --- a/arch/sparc/kernel/sparc_ksyms.c +++ b/arch/sparc/kernel/sparc_ksyms.c | |||
| @@ -98,8 +98,9 @@ extern void ___rw_write_enter(void); | |||
| 98 | * The module references will be fixed up by module_frob_arch_sections. | 98 | * The module references will be fixed up by module_frob_arch_sections. |
| 99 | */ | 99 | */ |
| 100 | #define DOT_ALIAS2(__ret, __x, __arg1, __arg2) \ | 100 | #define DOT_ALIAS2(__ret, __x, __arg1, __arg2) \ |
| 101 | extern __ret __x(__arg1, __arg2) \ | 101 | extern __ret __x(__arg1, __arg2); \ |
| 102 | __attribute__((weak, alias("." # __x))); | 102 | asm(".weak " #__x);\ |
| 103 | asm(#__x "=." #__x); | ||
| 103 | 104 | ||
| 104 | DOT_ALIAS2(int, div, int, int) | 105 | DOT_ALIAS2(int, div, int, int) |
| 105 | DOT_ALIAS2(int, mul, int, int) | 106 | DOT_ALIAS2(int, mul, int, int) |
diff --git a/arch/sparc64/kernel/Makefile b/arch/sparc64/kernel/Makefile index 093281bdf85f..6f00ab8b9d23 100644 --- a/arch/sparc64/kernel/Makefile +++ b/arch/sparc64/kernel/Makefile | |||
| @@ -8,7 +8,7 @@ EXTRA_CFLAGS := -Werror | |||
| 8 | extra-y := head.o init_task.o vmlinux.lds | 8 | extra-y := head.o init_task.o vmlinux.lds |
| 9 | 9 | ||
| 10 | obj-y := process.o setup.o cpu.o idprom.o \ | 10 | obj-y := process.o setup.o cpu.o idprom.o \ |
| 11 | traps.o devices.o auxio.o \ | 11 | traps.o devices.o auxio.o una_asm.o \ |
| 12 | irq.o ptrace.o time.o sys_sparc.o signal.o \ | 12 | irq.o ptrace.o time.o sys_sparc.o signal.o \ |
| 13 | unaligned.o central.o pci.o starfire.o semaphore.o \ | 13 | unaligned.o central.o pci.o starfire.o semaphore.o \ |
| 14 | power.o sbus.o iommu_common.o sparc64_ksyms.o chmc.o | 14 | power.o sbus.o iommu_common.o sparc64_ksyms.o chmc.o |
diff --git a/arch/sparc64/kernel/pci.c b/arch/sparc64/kernel/pci.c index bba140d98b1b..f21c993f8856 100644 --- a/arch/sparc64/kernel/pci.c +++ b/arch/sparc64/kernel/pci.c | |||
| @@ -540,6 +540,7 @@ void pcibios_bus_to_resource(struct pci_dev *pdev, struct resource *res, | |||
| 540 | 540 | ||
| 541 | pbm->parent->resource_adjust(pdev, res, root); | 541 | pbm->parent->resource_adjust(pdev, res, root); |
| 542 | } | 542 | } |
| 543 | EXPORT_SYMBOL(pcibios_bus_to_resource); | ||
| 543 | 544 | ||
| 544 | char * __init pcibios_setup(char *str) | 545 | char * __init pcibios_setup(char *str) |
| 545 | { | 546 | { |
diff --git a/arch/sparc64/kernel/traps.c b/arch/sparc64/kernel/traps.c index 100b0107c4be..0c9e54b2f0c8 100644 --- a/arch/sparc64/kernel/traps.c +++ b/arch/sparc64/kernel/traps.c | |||
| @@ -2127,6 +2127,9 @@ void __init trap_init(void) | |||
| 2127 | TI_PRE_COUNT != offsetof(struct thread_info, preempt_count) || | 2127 | TI_PRE_COUNT != offsetof(struct thread_info, preempt_count) || |
| 2128 | TI_NEW_CHILD != offsetof(struct thread_info, new_child) || | 2128 | TI_NEW_CHILD != offsetof(struct thread_info, new_child) || |
| 2129 | TI_SYS_NOERROR != offsetof(struct thread_info, syscall_noerror) || | 2129 | TI_SYS_NOERROR != offsetof(struct thread_info, syscall_noerror) || |
| 2130 | TI_RESTART_BLOCK != offsetof(struct thread_info, restart_block) || | ||
| 2131 | TI_KUNA_REGS != offsetof(struct thread_info, kern_una_regs) || | ||
| 2132 | TI_KUNA_INSN != offsetof(struct thread_info, kern_una_insn) || | ||
| 2130 | TI_FPREGS != offsetof(struct thread_info, fpregs) || | 2133 | TI_FPREGS != offsetof(struct thread_info, fpregs) || |
| 2131 | (TI_FPREGS & (64 - 1))) | 2134 | (TI_FPREGS & (64 - 1))) |
| 2132 | thread_info_offsets_are_bolixed_dave(); | 2135 | thread_info_offsets_are_bolixed_dave(); |
diff --git a/arch/sparc64/kernel/una_asm.S b/arch/sparc64/kernel/una_asm.S new file mode 100644 index 000000000000..cbb40585253c --- /dev/null +++ b/arch/sparc64/kernel/una_asm.S | |||
| @@ -0,0 +1,153 @@ | |||
| 1 | /* una_asm.S: Kernel unaligned trap assembler helpers. | ||
| 2 | * | ||
| 3 | * Copyright (C) 1996,2005 David S. Miller (davem@davemloft.net) | ||
| 4 | * Copyright (C) 1996,1997 Jakub Jelinek (jj@sunsite.mff.cuni.cz) | ||
| 5 | */ | ||
| 6 | |||
| 7 | .text | ||
| 8 | |||
| 9 | kernel_unaligned_trap_fault: | ||
| 10 | call kernel_mna_trap_fault | ||
| 11 | nop | ||
| 12 | retl | ||
| 13 | nop | ||
| 14 | .size kern_unaligned_trap_fault, .-kern_unaligned_trap_fault | ||
| 15 | |||
| 16 | .globl __do_int_store | ||
| 17 | __do_int_store: | ||
| 18 | rd %asi, %o4 | ||
| 19 | wr %o3, 0, %asi | ||
| 20 | ldx [%o2], %g3 | ||
| 21 | cmp %o1, 2 | ||
| 22 | be,pn %icc, 2f | ||
| 23 | cmp %o1, 4 | ||
| 24 | be,pt %icc, 1f | ||
| 25 | srlx %g3, 24, %g2 | ||
| 26 | srlx %g3, 56, %g1 | ||
| 27 | srlx %g3, 48, %g7 | ||
| 28 | 4: stba %g1, [%o0] %asi | ||
| 29 | srlx %g3, 40, %g1 | ||
| 30 | 5: stba %g7, [%o0 + 1] %asi | ||
| 31 | srlx %g3, 32, %g7 | ||
| 32 | 6: stba %g1, [%o0 + 2] %asi | ||
| 33 | 7: stba %g7, [%o0 + 3] %asi | ||
| 34 | srlx %g3, 16, %g1 | ||
| 35 | 8: stba %g2, [%o0 + 4] %asi | ||
| 36 | srlx %g3, 8, %g7 | ||
| 37 | 9: stba %g1, [%o0 + 5] %asi | ||
| 38 | 10: stba %g7, [%o0 + 6] %asi | ||
| 39 | ba,pt %xcc, 0f | ||
| 40 | 11: stba %g3, [%o0 + 7] %asi | ||
| 41 | 1: srl %g3, 16, %g7 | ||
| 42 | 12: stba %g2, [%o0] %asi | ||
| 43 | srl %g3, 8, %g2 | ||
| 44 | 13: stba %g7, [%o0 + 1] %asi | ||
| 45 | 14: stba %g2, [%o0 + 2] %asi | ||
| 46 | ba,pt %xcc, 0f | ||
| 47 | 15: stba %g3, [%o0 + 3] %asi | ||
| 48 | 2: srl %g3, 8, %g2 | ||
| 49 | 16: stba %g2, [%o0] %asi | ||
| 50 | 17: stba %g3, [%o0 + 1] %asi | ||
| 51 | 0: | ||
| 52 | wr %o4, 0x0, %asi | ||
| 53 | retl | ||
| 54 | nop | ||
| 55 | .size __do_int_store, .-__do_int_store | ||
| 56 | |||
| 57 | .section __ex_table | ||
| 58 | .word 4b, kernel_unaligned_trap_fault | ||
| 59 | .word 5b, kernel_unaligned_trap_fault | ||
| 60 | .word 6b, kernel_unaligned_trap_fault | ||
| 61 | .word 7b, kernel_unaligned_trap_fault | ||
| 62 | .word 8b, kernel_unaligned_trap_fault | ||
| 63 | .word 9b, kernel_unaligned_trap_fault | ||
| 64 | .word 10b, kernel_unaligned_trap_fault | ||
| 65 | .word 11b, kernel_unaligned_trap_fault | ||
| 66 | .word 12b, kernel_unaligned_trap_fault | ||
| 67 | .word 13b, kernel_unaligned_trap_fault | ||
| 68 | .word 14b, kernel_unaligned_trap_fault | ||
| 69 | .word 15b, kernel_unaligned_trap_fault | ||
| 70 | .word 16b, kernel_unaligned_trap_fault | ||
| 71 | .word 17b, kernel_unaligned_trap_fault | ||
| 72 | .previous | ||
| 73 | |||
| 74 | .globl do_int_load | ||
| 75 | do_int_load: | ||
| 76 | rd %asi, %o5 | ||
| 77 | wr %o4, 0, %asi | ||
| 78 | cmp %o1, 8 | ||
| 79 | bge,pn %icc, 9f | ||
| 80 | cmp %o1, 4 | ||
| 81 | be,pt %icc, 6f | ||
| 82 | 4: lduba [%o2] %asi, %g2 | ||
| 83 | 5: lduba [%o2 + 1] %asi, %g3 | ||
| 84 | sll %g2, 8, %g2 | ||
| 85 | brz,pt %o3, 3f | ||
| 86 | add %g2, %g3, %g2 | ||
| 87 | sllx %g2, 48, %g2 | ||
| 88 | srax %g2, 48, %g2 | ||
| 89 | 3: ba,pt %xcc, 0f | ||
| 90 | stx %g2, [%o0] | ||
| 91 | 6: lduba [%o2 + 1] %asi, %g3 | ||
| 92 | sll %g2, 24, %g2 | ||
| 93 | 7: lduba [%o2 + 2] %asi, %g7 | ||
| 94 | sll %g3, 16, %g3 | ||
| 95 | 8: lduba [%o2 + 3] %asi, %g1 | ||
| 96 | sll %g7, 8, %g7 | ||
| 97 | or %g2, %g3, %g2 | ||
| 98 | or %g7, %g1, %g7 | ||
| 99 | or %g2, %g7, %g2 | ||
| 100 | brnz,a,pt %o3, 3f | ||
| 101 | sra %g2, 0, %g2 | ||
| 102 | 3: ba,pt %xcc, 0f | ||
| 103 | stx %g2, [%o0] | ||
| 104 | 9: lduba [%o2] %asi, %g2 | ||
| 105 | 10: lduba [%o2 + 1] %asi, %g3 | ||
| 106 | sllx %g2, 56, %g2 | ||
| 107 | 11: lduba [%o2 + 2] %asi, %g7 | ||
| 108 | sllx %g3, 48, %g3 | ||
| 109 | 12: lduba [%o2 + 3] %asi, %g1 | ||
| 110 | sllx %g7, 40, %g7 | ||
| 111 | sllx %g1, 32, %g1 | ||
| 112 | or %g2, %g3, %g2 | ||
| 113 | or %g7, %g1, %g7 | ||
| 114 | 13: lduba [%o2 + 4] %asi, %g3 | ||
| 115 | or %g2, %g7, %g7 | ||
| 116 | 14: lduba [%o2 + 5] %asi, %g1 | ||
| 117 | sllx %g3, 24, %g3 | ||
| 118 | 15: lduba [%o2 + 6] %asi, %g2 | ||
| 119 | sllx %g1, 16, %g1 | ||
| 120 | or %g7, %g3, %g7 | ||
| 121 | 16: lduba [%o2 + 7] %asi, %g3 | ||
| 122 | sllx %g2, 8, %g2 | ||
| 123 | or %g7, %g1, %g7 | ||
| 124 | or %g2, %g3, %g2 | ||
| 125 | or %g7, %g2, %g7 | ||
| 126 | cmp %o1, 8 | ||
| 127 | be,a,pt %icc, 0f | ||
| 128 | stx %g7, [%o0] | ||
| 129 | srlx %g7, 32, %g2 | ||
| 130 | sra %g7, 0, %g7 | ||
| 131 | stx %g2, [%o0] | ||
| 132 | stx %g7, [%o0 + 8] | ||
| 133 | 0: | ||
| 134 | wr %o5, 0x0, %asi | ||
| 135 | retl | ||
| 136 | nop | ||
| 137 | .size __do_int_load, .-__do_int_load | ||
| 138 | |||
| 139 | .section __ex_table | ||
| 140 | .word 4b, kernel_unaligned_trap_fault | ||
| 141 | .word 5b, kernel_unaligned_trap_fault | ||
| 142 | .word 6b, kernel_unaligned_trap_fault | ||
| 143 | .word 7b, kernel_unaligned_trap_fault | ||
| 144 | .word 8b, kernel_unaligned_trap_fault | ||
| 145 | .word 9b, kernel_unaligned_trap_fault | ||
| 146 | .word 10b, kernel_unaligned_trap_fault | ||
| 147 | .word 11b, kernel_unaligned_trap_fault | ||
| 148 | .word 12b, kernel_unaligned_trap_fault | ||
| 149 | .word 13b, kernel_unaligned_trap_fault | ||
| 150 | .word 14b, kernel_unaligned_trap_fault | ||
| 151 | .word 15b, kernel_unaligned_trap_fault | ||
| 152 | .word 16b, kernel_unaligned_trap_fault | ||
| 153 | .previous | ||
diff --git a/arch/sparc64/kernel/unaligned.c b/arch/sparc64/kernel/unaligned.c index 4372bf32ecf6..11c3e88732e4 100644 --- a/arch/sparc64/kernel/unaligned.c +++ b/arch/sparc64/kernel/unaligned.c | |||
| @@ -180,169 +180,28 @@ static void __attribute_used__ unaligned_panic(char *str, struct pt_regs *regs) | |||
| 180 | die_if_kernel(str, regs); | 180 | die_if_kernel(str, regs); |
| 181 | } | 181 | } |
| 182 | 182 | ||
| 183 | #define do_integer_load(dest_reg, size, saddr, is_signed, asi, errh) ({ \ | 183 | extern void do_int_load(unsigned long *dest_reg, int size, |
| 184 | __asm__ __volatile__ ( \ | 184 | unsigned long *saddr, int is_signed, int asi); |
| 185 | "wr %4, 0, %%asi\n\t" \ | ||
| 186 | "cmp %1, 8\n\t" \ | ||
| 187 | "bge,pn %%icc, 9f\n\t" \ | ||
| 188 | " cmp %1, 4\n\t" \ | ||
| 189 | "be,pt %%icc, 6f\n" \ | ||
| 190 | "4:\t" " lduba [%2] %%asi, %%l1\n" \ | ||
| 191 | "5:\t" "lduba [%2 + 1] %%asi, %%l2\n\t" \ | ||
| 192 | "sll %%l1, 8, %%l1\n\t" \ | ||
| 193 | "brz,pt %3, 3f\n\t" \ | ||
| 194 | " add %%l1, %%l2, %%l1\n\t" \ | ||
| 195 | "sllx %%l1, 48, %%l1\n\t" \ | ||
| 196 | "srax %%l1, 48, %%l1\n" \ | ||
| 197 | "3:\t" "ba,pt %%xcc, 0f\n\t" \ | ||
| 198 | " stx %%l1, [%0]\n" \ | ||
| 199 | "6:\t" "lduba [%2 + 1] %%asi, %%l2\n\t" \ | ||
| 200 | "sll %%l1, 24, %%l1\n" \ | ||
| 201 | "7:\t" "lduba [%2 + 2] %%asi, %%g7\n\t" \ | ||
| 202 | "sll %%l2, 16, %%l2\n" \ | ||
| 203 | "8:\t" "lduba [%2 + 3] %%asi, %%g1\n\t" \ | ||
| 204 | "sll %%g7, 8, %%g7\n\t" \ | ||
| 205 | "or %%l1, %%l2, %%l1\n\t" \ | ||
| 206 | "or %%g7, %%g1, %%g7\n\t" \ | ||
| 207 | "or %%l1, %%g7, %%l1\n\t" \ | ||
| 208 | "brnz,a,pt %3, 3f\n\t" \ | ||
| 209 | " sra %%l1, 0, %%l1\n" \ | ||
| 210 | "3:\t" "ba,pt %%xcc, 0f\n\t" \ | ||
| 211 | " stx %%l1, [%0]\n" \ | ||
| 212 | "9:\t" "lduba [%2] %%asi, %%l1\n" \ | ||
| 213 | "10:\t" "lduba [%2 + 1] %%asi, %%l2\n\t" \ | ||
| 214 | "sllx %%l1, 56, %%l1\n" \ | ||
| 215 | "11:\t" "lduba [%2 + 2] %%asi, %%g7\n\t" \ | ||
| 216 | "sllx %%l2, 48, %%l2\n" \ | ||
| 217 | "12:\t" "lduba [%2 + 3] %%asi, %%g1\n\t" \ | ||
| 218 | "sllx %%g7, 40, %%g7\n\t" \ | ||
| 219 | "sllx %%g1, 32, %%g1\n\t" \ | ||
| 220 | "or %%l1, %%l2, %%l1\n\t" \ | ||
| 221 | "or %%g7, %%g1, %%g7\n" \ | ||
| 222 | "13:\t" "lduba [%2 + 4] %%asi, %%l2\n\t" \ | ||
| 223 | "or %%l1, %%g7, %%g7\n" \ | ||
| 224 | "14:\t" "lduba [%2 + 5] %%asi, %%g1\n\t" \ | ||
| 225 | "sllx %%l2, 24, %%l2\n" \ | ||
| 226 | "15:\t" "lduba [%2 + 6] %%asi, %%l1\n\t" \ | ||
| 227 | "sllx %%g1, 16, %%g1\n\t" \ | ||
| 228 | "or %%g7, %%l2, %%g7\n" \ | ||
| 229 | "16:\t" "lduba [%2 + 7] %%asi, %%l2\n\t" \ | ||
| 230 | "sllx %%l1, 8, %%l1\n\t" \ | ||
| 231 | "or %%g7, %%g1, %%g7\n\t" \ | ||
| 232 | "or %%l1, %%l2, %%l1\n\t" \ | ||
| 233 | "or %%g7, %%l1, %%g7\n\t" \ | ||
| 234 | "cmp %1, 8\n\t" \ | ||
| 235 | "be,a,pt %%icc, 0f\n\t" \ | ||
| 236 | " stx %%g7, [%0]\n\t" \ | ||
| 237 | "srlx %%g7, 32, %%l1\n\t" \ | ||
| 238 | "sra %%g7, 0, %%g7\n\t" \ | ||
| 239 | "stx %%l1, [%0]\n\t" \ | ||
| 240 | "stx %%g7, [%0 + 8]\n" \ | ||
| 241 | "0:\n\t" \ | ||
| 242 | "wr %%g0, %5, %%asi\n\n\t" \ | ||
| 243 | ".section __ex_table\n\t" \ | ||
| 244 | ".word 4b, " #errh "\n\t" \ | ||
| 245 | ".word 5b, " #errh "\n\t" \ | ||
| 246 | ".word 6b, " #errh "\n\t" \ | ||
| 247 | ".word 7b, " #errh "\n\t" \ | ||
| 248 | ".word 8b, " #errh "\n\t" \ | ||
| 249 | ".word 9b, " #errh "\n\t" \ | ||
| 250 | ".word 10b, " #errh "\n\t" \ | ||
| 251 | ".word 11b, " #errh "\n\t" \ | ||
| 252 | ".word 12b, " #errh "\n\t" \ | ||
| 253 | ".word 13b, " #errh "\n\t" \ | ||
| 254 | ".word 14b, " #errh "\n\t" \ | ||
| 255 | ".word 15b, " #errh "\n\t" \ | ||
| 256 | ".word 16b, " #errh "\n\n\t" \ | ||
| 257 | ".previous\n\t" \ | ||
| 258 | : : "r" (dest_reg), "r" (size), "r" (saddr), "r" (is_signed), \ | ||
| 259 | "r" (asi), "i" (ASI_AIUS) \ | ||
| 260 | : "l1", "l2", "g7", "g1", "cc"); \ | ||
| 261 | }) | ||
| 262 | 185 | ||
| 263 | #define store_common(dst_addr, size, src_val, asi, errh) ({ \ | 186 | extern void __do_int_store(unsigned long *dst_addr, int size, |
| 264 | __asm__ __volatile__ ( \ | 187 | unsigned long *src_val, int asi); |
| 265 | "wr %3, 0, %%asi\n\t" \ | 188 | |
| 266 | "ldx [%2], %%l1\n" \ | 189 | static inline void do_int_store(int reg_num, int size, unsigned long *dst_addr, |
| 267 | "cmp %1, 2\n\t" \ | 190 | struct pt_regs *regs, int asi) |
| 268 | "be,pn %%icc, 2f\n\t" \ | 191 | { |
| 269 | " cmp %1, 4\n\t" \ | 192 | unsigned long zero = 0; |
| 270 | "be,pt %%icc, 1f\n\t" \ | 193 | unsigned long *src_val = &zero; |
| 271 | " srlx %%l1, 24, %%l2\n\t" \ | 194 | |
| 272 | "srlx %%l1, 56, %%g1\n\t" \ | 195 | if (size == 16) { |
| 273 | "srlx %%l1, 48, %%g7\n" \ | 196 | size = 8; |
| 274 | "4:\t" "stba %%g1, [%0] %%asi\n\t" \ | 197 | zero = (((long)(reg_num ? |
| 275 | "srlx %%l1, 40, %%g1\n" \ | 198 | (unsigned)fetch_reg(reg_num, regs) : 0)) << 32) | |
| 276 | "5:\t" "stba %%g7, [%0 + 1] %%asi\n\t" \ | 199 | (unsigned)fetch_reg(reg_num + 1, regs); |
| 277 | "srlx %%l1, 32, %%g7\n" \ | 200 | } else if (reg_num) { |
| 278 | "6:\t" "stba %%g1, [%0 + 2] %%asi\n" \ | 201 | src_val = fetch_reg_addr(reg_num, regs); |
| 279 | "7:\t" "stba %%g7, [%0 + 3] %%asi\n\t" \ | 202 | } |
| 280 | "srlx %%l1, 16, %%g1\n" \ | 203 | __do_int_store(dst_addr, size, src_val, asi); |
| 281 | "8:\t" "stba %%l2, [%0 + 4] %%asi\n\t" \ | 204 | } |
| 282 | "srlx %%l1, 8, %%g7\n" \ | ||
| 283 | "9:\t" "stba %%g1, [%0 + 5] %%asi\n" \ | ||
| 284 | "10:\t" "stba %%g7, [%0 + 6] %%asi\n\t" \ | ||
| 285 | "ba,pt %%xcc, 0f\n" \ | ||
| 286 | "11:\t" " stba %%l1, [%0 + 7] %%asi\n" \ | ||
| 287 | "1:\t" "srl %%l1, 16, %%g7\n" \ | ||
| 288 | "12:\t" "stba %%l2, [%0] %%asi\n\t" \ | ||
| 289 | "srl %%l1, 8, %%l2\n" \ | ||
| 290 | "13:\t" "stba %%g7, [%0 + 1] %%asi\n" \ | ||
| 291 | "14:\t" "stba %%l2, [%0 + 2] %%asi\n\t" \ | ||
| 292 | "ba,pt %%xcc, 0f\n" \ | ||
| 293 | "15:\t" " stba %%l1, [%0 + 3] %%asi\n" \ | ||
| 294 | "2:\t" "srl %%l1, 8, %%l2\n" \ | ||
| 295 | "16:\t" "stba %%l2, [%0] %%asi\n" \ | ||
| 296 | "17:\t" "stba %%l1, [%0 + 1] %%asi\n" \ | ||
| 297 | "0:\n\t" \ | ||
| 298 | "wr %%g0, %4, %%asi\n\n\t" \ | ||
| 299 | ".section __ex_table\n\t" \ | ||
| 300 | ".word 4b, " #errh "\n\t" \ | ||
| 301 | ".word 5b, " #errh "\n\t" \ | ||
| 302 | ".word 6b, " #errh "\n\t" \ | ||
| 303 | ".word 7b, " #errh "\n\t" \ | ||
| 304 | ".word 8b, " #errh "\n\t" \ | ||
| 305 | ".word 9b, " #errh "\n\t" \ | ||
| 306 | ".word 10b, " #errh "\n\t" \ | ||
| 307 | ".word 11b, " #errh "\n\t" \ | ||
| 308 | ".word 12b, " #errh "\n\t" \ | ||
| 309 | ".word 13b, " #errh "\n\t" \ | ||
| 310 | ".word 14b, " #errh "\n\t" \ | ||
| 311 | ".word 15b, " #errh "\n\t" \ | ||
| 312 | ".word 16b, " #errh "\n\t" \ | ||
| 313 | ".word 17b, " #errh "\n\n\t" \ | ||
| 314 | ".previous\n\t" \ | ||
| 315 | : : "r" (dst_addr), "r" (size), "r" (src_val), "r" (asi), "i" (ASI_AIUS)\ | ||
| 316 | : "l1", "l2", "g7", "g1", "cc"); \ | ||
| 317 | }) | ||
| 318 | |||
| 319 | #define do_integer_store(reg_num, size, dst_addr, regs, asi, errh) ({ \ | ||
| 320 | unsigned long zero = 0; \ | ||
| 321 | unsigned long *src_val = &zero; \ | ||
| 322 | \ | ||
| 323 | if (size == 16) { \ | ||
| 324 | size = 8; \ | ||
| 325 | zero = (((long)(reg_num ? \ | ||
| 326 | (unsigned)fetch_reg(reg_num, regs) : 0)) << 32) | \ | ||
| 327 | (unsigned)fetch_reg(reg_num + 1, regs); \ | ||
| 328 | } else if (reg_num) src_val = fetch_reg_addr(reg_num, regs); \ | ||
| 329 | store_common(dst_addr, size, src_val, asi, errh); \ | ||
| 330 | }) | ||
| 331 | |||
| 332 | extern void smp_capture(void); | ||
| 333 | extern void smp_release(void); | ||
| 334 | |||
| 335 | #define do_atomic(srcdest_reg, mem, errh) ({ \ | ||
| 336 | unsigned long flags, tmp; \ | ||
| 337 | \ | ||
| 338 | smp_capture(); \ | ||
| 339 | local_irq_save(flags); \ | ||
| 340 | tmp = *srcdest_reg; \ | ||
| 341 | do_integer_load(srcdest_reg, 4, mem, 0, errh); \ | ||
| 342 | store_common(mem, 4, &tmp, errh); \ | ||
| 343 | local_irq_restore(flags); \ | ||
| 344 | smp_release(); \ | ||
| 345 | }) | ||
| 346 | 205 | ||
| 347 | static inline void advance(struct pt_regs *regs) | 206 | static inline void advance(struct pt_regs *regs) |
| 348 | { | 207 | { |
| @@ -364,24 +223,29 @@ static inline int ok_for_kernel(unsigned int insn) | |||
| 364 | return !floating_point_load_or_store_p(insn); | 223 | return !floating_point_load_or_store_p(insn); |
| 365 | } | 224 | } |
| 366 | 225 | ||
| 367 | void kernel_mna_trap_fault(struct pt_regs *regs, unsigned int insn) __asm__ ("kernel_mna_trap_fault"); | 226 | void kernel_mna_trap_fault(void) |
| 368 | |||
| 369 | void kernel_mna_trap_fault(struct pt_regs *regs, unsigned int insn) | ||
| 370 | { | 227 | { |
| 371 | unsigned long g2 = regs->u_regs [UREG_G2]; | 228 | struct pt_regs *regs = current_thread_info()->kern_una_regs; |
| 229 | unsigned int insn = current_thread_info()->kern_una_insn; | ||
| 230 | unsigned long g2 = regs->u_regs[UREG_G2]; | ||
| 372 | unsigned long fixup = search_extables_range(regs->tpc, &g2); | 231 | unsigned long fixup = search_extables_range(regs->tpc, &g2); |
| 373 | 232 | ||
| 374 | if (!fixup) { | 233 | if (!fixup) { |
| 375 | unsigned long address = compute_effective_address(regs, insn, ((insn >> 25) & 0x1f)); | 234 | unsigned long address; |
| 235 | |||
| 236 | address = compute_effective_address(regs, insn, | ||
| 237 | ((insn >> 25) & 0x1f)); | ||
| 376 | if (address < PAGE_SIZE) { | 238 | if (address < PAGE_SIZE) { |
| 377 | printk(KERN_ALERT "Unable to handle kernel NULL pointer dereference in mna handler"); | 239 | printk(KERN_ALERT "Unable to handle kernel NULL " |
| 240 | "pointer dereference in mna handler"); | ||
| 378 | } else | 241 | } else |
| 379 | printk(KERN_ALERT "Unable to handle kernel paging request in mna handler"); | 242 | printk(KERN_ALERT "Unable to handle kernel paging " |
| 243 | "request in mna handler"); | ||
| 380 | printk(KERN_ALERT " at virtual address %016lx\n",address); | 244 | printk(KERN_ALERT " at virtual address %016lx\n",address); |
| 381 | printk(KERN_ALERT "current->{mm,active_mm}->context = %016lx\n", | 245 | printk(KERN_ALERT "current->{active_,}mm->context = %016lx\n", |
| 382 | (current->mm ? CTX_HWBITS(current->mm->context) : | 246 | (current->mm ? CTX_HWBITS(current->mm->context) : |
| 383 | CTX_HWBITS(current->active_mm->context))); | 247 | CTX_HWBITS(current->active_mm->context))); |
| 384 | printk(KERN_ALERT "current->{mm,active_mm}->pgd = %016lx\n", | 248 | printk(KERN_ALERT "current->{active_,}mm->pgd = %016lx\n", |
| 385 | (current->mm ? (unsigned long) current->mm->pgd : | 249 | (current->mm ? (unsigned long) current->mm->pgd : |
| 386 | (unsigned long) current->active_mm->pgd)); | 250 | (unsigned long) current->active_mm->pgd)); |
| 387 | die_if_kernel("Oops", regs); | 251 | die_if_kernel("Oops", regs); |
| @@ -400,48 +264,41 @@ asmlinkage void kernel_unaligned_trap(struct pt_regs *regs, unsigned int insn, u | |||
| 400 | enum direction dir = decode_direction(insn); | 264 | enum direction dir = decode_direction(insn); |
| 401 | int size = decode_access_size(insn); | 265 | int size = decode_access_size(insn); |
| 402 | 266 | ||
| 267 | current_thread_info()->kern_una_regs = regs; | ||
| 268 | current_thread_info()->kern_una_insn = insn; | ||
| 269 | |||
| 403 | if (!ok_for_kernel(insn) || dir == both) { | 270 | if (!ok_for_kernel(insn) || dir == both) { |
| 404 | printk("Unsupported unaligned load/store trap for kernel at <%016lx>.\n", | 271 | printk("Unsupported unaligned load/store trap for kernel " |
| 405 | regs->tpc); | 272 | "at <%016lx>.\n", regs->tpc); |
| 406 | unaligned_panic("Kernel does fpu/atomic unaligned load/store.", regs); | 273 | unaligned_panic("Kernel does fpu/atomic " |
| 407 | 274 | "unaligned load/store.", regs); | |
| 408 | __asm__ __volatile__ ("\n" | 275 | |
| 409 | "kernel_unaligned_trap_fault:\n\t" | 276 | kernel_mna_trap_fault(); |
| 410 | "mov %0, %%o0\n\t" | ||
| 411 | "call kernel_mna_trap_fault\n\t" | ||
| 412 | " mov %1, %%o1\n\t" | ||
| 413 | : | ||
| 414 | : "r" (regs), "r" (insn) | ||
| 415 | : "o0", "o1", "o2", "o3", "o4", "o5", "o7", | ||
| 416 | "g1", "g2", "g3", "g4", "g7", "cc"); | ||
| 417 | } else { | 277 | } else { |
| 418 | unsigned long addr = compute_effective_address(regs, insn, ((insn >> 25) & 0x1f)); | 278 | unsigned long addr; |
| 419 | 279 | ||
| 280 | addr = compute_effective_address(regs, insn, | ||
| 281 | ((insn >> 25) & 0x1f)); | ||
| 420 | #ifdef DEBUG_MNA | 282 | #ifdef DEBUG_MNA |
| 421 | printk("KMNA: pc=%016lx [dir=%s addr=%016lx size=%d] retpc[%016lx]\n", | 283 | printk("KMNA: pc=%016lx [dir=%s addr=%016lx size=%d] " |
| 422 | regs->tpc, dirstrings[dir], addr, size, regs->u_regs[UREG_RETPC]); | 284 | "retpc[%016lx]\n", |
| 285 | regs->tpc, dirstrings[dir], addr, size, | ||
| 286 | regs->u_regs[UREG_RETPC]); | ||
| 423 | #endif | 287 | #endif |
| 424 | switch (dir) { | 288 | switch (dir) { |
| 425 | case load: | 289 | case load: |
| 426 | do_integer_load(fetch_reg_addr(((insn>>25)&0x1f), regs), | 290 | do_int_load(fetch_reg_addr(((insn>>25)&0x1f), regs), |
| 427 | size, (unsigned long *) addr, | 291 | size, (unsigned long *) addr, |
| 428 | decode_signedness(insn), decode_asi(insn, regs), | 292 | decode_signedness(insn), |
| 429 | kernel_unaligned_trap_fault); | 293 | decode_asi(insn, regs)); |
| 430 | break; | 294 | break; |
| 431 | 295 | ||
| 432 | case store: | 296 | case store: |
| 433 | do_integer_store(((insn>>25)&0x1f), size, | 297 | do_int_store(((insn>>25)&0x1f), size, |
| 434 | (unsigned long *) addr, regs, | 298 | (unsigned long *) addr, regs, |
| 435 | decode_asi(insn, regs), | 299 | decode_asi(insn, regs)); |
| 436 | kernel_unaligned_trap_fault); | ||
| 437 | break; | ||
| 438 | #if 0 /* unsupported */ | ||
| 439 | case both: | ||
| 440 | do_atomic(fetch_reg_addr(((insn>>25)&0x1f), regs), | ||
| 441 | (unsigned long *) addr, | ||
| 442 | kernel_unaligned_trap_fault); | ||
| 443 | break; | 300 | break; |
| 444 | #endif | 301 | |
| 445 | default: | 302 | default: |
| 446 | panic("Impossible kernel unaligned trap."); | 303 | panic("Impossible kernel unaligned trap."); |
| 447 | /* Not reached... */ | 304 | /* Not reached... */ |
diff --git a/arch/sparc64/kernel/us2e_cpufreq.c b/arch/sparc64/kernel/us2e_cpufreq.c index 7aae0a18aabe..686e526bec04 100644 --- a/arch/sparc64/kernel/us2e_cpufreq.c +++ b/arch/sparc64/kernel/us2e_cpufreq.c | |||
| @@ -88,7 +88,6 @@ static void frob_mem_refresh(int cpu_slowing_down, | |||
| 88 | { | 88 | { |
| 89 | unsigned long old_refr_count, refr_count, mctrl; | 89 | unsigned long old_refr_count, refr_count, mctrl; |
| 90 | 90 | ||
| 91 | |||
| 92 | refr_count = (clock_tick * MCTRL0_REFR_INTERVAL); | 91 | refr_count = (clock_tick * MCTRL0_REFR_INTERVAL); |
| 93 | refr_count /= (MCTRL0_REFR_CLKS_P_CNT * divisor * 1000000000UL); | 92 | refr_count /= (MCTRL0_REFR_CLKS_P_CNT * divisor * 1000000000UL); |
| 94 | 93 | ||
| @@ -230,6 +229,25 @@ static unsigned long estar_to_divisor(unsigned long estar) | |||
| 230 | return ret; | 229 | return ret; |
| 231 | } | 230 | } |
| 232 | 231 | ||
| 232 | static unsigned int us2e_freq_get(unsigned int cpu) | ||
| 233 | { | ||
| 234 | cpumask_t cpus_allowed; | ||
| 235 | unsigned long clock_tick, estar; | ||
| 236 | |||
| 237 | if (!cpu_online(cpu)) | ||
| 238 | return 0; | ||
| 239 | |||
| 240 | cpus_allowed = current->cpus_allowed; | ||
| 241 | set_cpus_allowed(current, cpumask_of_cpu(cpu)); | ||
| 242 | |||
| 243 | clock_tick = sparc64_get_clock_tick(cpu) / 1000; | ||
| 244 | estar = read_hbreg(HBIRD_ESTAR_MODE_ADDR); | ||
| 245 | |||
| 246 | set_cpus_allowed(current, cpus_allowed); | ||
| 247 | |||
| 248 | return clock_tick / estar_to_divisor(estar); | ||
| 249 | } | ||
| 250 | |||
| 233 | static void us2e_set_cpu_divider_index(unsigned int cpu, unsigned int index) | 251 | static void us2e_set_cpu_divider_index(unsigned int cpu, unsigned int index) |
| 234 | { | 252 | { |
| 235 | unsigned long new_bits, new_freq; | 253 | unsigned long new_bits, new_freq; |
| @@ -243,7 +261,7 @@ static void us2e_set_cpu_divider_index(unsigned int cpu, unsigned int index) | |||
| 243 | cpus_allowed = current->cpus_allowed; | 261 | cpus_allowed = current->cpus_allowed; |
| 244 | set_cpus_allowed(current, cpumask_of_cpu(cpu)); | 262 | set_cpus_allowed(current, cpumask_of_cpu(cpu)); |
| 245 | 263 | ||
| 246 | new_freq = clock_tick = sparc64_get_clock_tick(cpu); | 264 | new_freq = clock_tick = sparc64_get_clock_tick(cpu) / 1000; |
| 247 | new_bits = index_to_estar_mode(index); | 265 | new_bits = index_to_estar_mode(index); |
| 248 | divisor = index_to_divisor(index); | 266 | divisor = index_to_divisor(index); |
| 249 | new_freq /= divisor; | 267 | new_freq /= divisor; |
| @@ -258,7 +276,8 @@ static void us2e_set_cpu_divider_index(unsigned int cpu, unsigned int index) | |||
| 258 | cpufreq_notify_transition(&freqs, CPUFREQ_PRECHANGE); | 276 | cpufreq_notify_transition(&freqs, CPUFREQ_PRECHANGE); |
| 259 | 277 | ||
| 260 | if (old_divisor != divisor) | 278 | if (old_divisor != divisor) |
| 261 | us2e_transition(estar, new_bits, clock_tick, old_divisor, divisor); | 279 | us2e_transition(estar, new_bits, clock_tick * 1000, |
| 280 | old_divisor, divisor); | ||
| 262 | 281 | ||
| 263 | cpufreq_notify_transition(&freqs, CPUFREQ_POSTCHANGE); | 282 | cpufreq_notify_transition(&freqs, CPUFREQ_POSTCHANGE); |
| 264 | 283 | ||
| @@ -272,10 +291,8 @@ static int us2e_freq_target(struct cpufreq_policy *policy, | |||
| 272 | unsigned int new_index = 0; | 291 | unsigned int new_index = 0; |
| 273 | 292 | ||
| 274 | if (cpufreq_frequency_table_target(policy, | 293 | if (cpufreq_frequency_table_target(policy, |
| 275 | &us2e_freq_table[policy->cpu].table[0], | 294 | &us2e_freq_table[policy->cpu].table[0], |
| 276 | target_freq, | 295 | target_freq, relation, &new_index)) |
| 277 | relation, | ||
| 278 | &new_index)) | ||
| 279 | return -EINVAL; | 296 | return -EINVAL; |
| 280 | 297 | ||
| 281 | us2e_set_cpu_divider_index(policy->cpu, new_index); | 298 | us2e_set_cpu_divider_index(policy->cpu, new_index); |
| @@ -292,7 +309,7 @@ static int us2e_freq_verify(struct cpufreq_policy *policy) | |||
| 292 | static int __init us2e_freq_cpu_init(struct cpufreq_policy *policy) | 309 | static int __init us2e_freq_cpu_init(struct cpufreq_policy *policy) |
| 293 | { | 310 | { |
| 294 | unsigned int cpu = policy->cpu; | 311 | unsigned int cpu = policy->cpu; |
| 295 | unsigned long clock_tick = sparc64_get_clock_tick(cpu); | 312 | unsigned long clock_tick = sparc64_get_clock_tick(cpu) / 1000; |
| 296 | struct cpufreq_frequency_table *table = | 313 | struct cpufreq_frequency_table *table = |
| 297 | &us2e_freq_table[cpu].table[0]; | 314 | &us2e_freq_table[cpu].table[0]; |
| 298 | 315 | ||
| @@ -351,9 +368,10 @@ static int __init us2e_freq_init(void) | |||
| 351 | memset(us2e_freq_table, 0, | 368 | memset(us2e_freq_table, 0, |
| 352 | (NR_CPUS * sizeof(struct us2e_freq_percpu_info))); | 369 | (NR_CPUS * sizeof(struct us2e_freq_percpu_info))); |
| 353 | 370 | ||
| 371 | driver->init = us2e_freq_cpu_init; | ||
| 354 | driver->verify = us2e_freq_verify; | 372 | driver->verify = us2e_freq_verify; |
| 355 | driver->target = us2e_freq_target; | 373 | driver->target = us2e_freq_target; |
| 356 | driver->init = us2e_freq_cpu_init; | 374 | driver->get = us2e_freq_get; |
| 357 | driver->exit = us2e_freq_cpu_exit; | 375 | driver->exit = us2e_freq_cpu_exit; |
| 358 | driver->owner = THIS_MODULE, | 376 | driver->owner = THIS_MODULE, |
| 359 | strcpy(driver->name, "UltraSPARC-IIe"); | 377 | strcpy(driver->name, "UltraSPARC-IIe"); |
diff --git a/arch/sparc64/kernel/us3_cpufreq.c b/arch/sparc64/kernel/us3_cpufreq.c index 18fe54b8aa55..9080e7cd4bb0 100644 --- a/arch/sparc64/kernel/us3_cpufreq.c +++ b/arch/sparc64/kernel/us3_cpufreq.c | |||
| @@ -56,7 +56,7 @@ static void write_safari_cfg(unsigned long val) | |||
| 56 | 56 | ||
| 57 | static unsigned long get_current_freq(unsigned int cpu, unsigned long safari_cfg) | 57 | static unsigned long get_current_freq(unsigned int cpu, unsigned long safari_cfg) |
| 58 | { | 58 | { |
| 59 | unsigned long clock_tick = sparc64_get_clock_tick(cpu); | 59 | unsigned long clock_tick = sparc64_get_clock_tick(cpu) / 1000; |
| 60 | unsigned long ret; | 60 | unsigned long ret; |
| 61 | 61 | ||
| 62 | switch (safari_cfg & SAFARI_CFG_DIV_MASK) { | 62 | switch (safari_cfg & SAFARI_CFG_DIV_MASK) { |
| @@ -76,6 +76,26 @@ static unsigned long get_current_freq(unsigned int cpu, unsigned long safari_cfg | |||
| 76 | return ret; | 76 | return ret; |
| 77 | } | 77 | } |
| 78 | 78 | ||
| 79 | static unsigned int us3_freq_get(unsigned int cpu) | ||
| 80 | { | ||
| 81 | cpumask_t cpus_allowed; | ||
| 82 | unsigned long reg; | ||
| 83 | unsigned int ret; | ||
| 84 | |||
| 85 | if (!cpu_online(cpu)) | ||
| 86 | return 0; | ||
| 87 | |||
| 88 | cpus_allowed = current->cpus_allowed; | ||
| 89 | set_cpus_allowed(current, cpumask_of_cpu(cpu)); | ||
| 90 | |||
| 91 | reg = read_safari_cfg(); | ||
| 92 | ret = get_current_freq(cpu, reg); | ||
| 93 | |||
| 94 | set_cpus_allowed(current, cpus_allowed); | ||
| 95 | |||
| 96 | return ret; | ||
| 97 | } | ||
| 98 | |||
| 79 | static void us3_set_cpu_divider_index(unsigned int cpu, unsigned int index) | 99 | static void us3_set_cpu_divider_index(unsigned int cpu, unsigned int index) |
| 80 | { | 100 | { |
| 81 | unsigned long new_bits, new_freq, reg; | 101 | unsigned long new_bits, new_freq, reg; |
| @@ -88,7 +108,7 @@ static void us3_set_cpu_divider_index(unsigned int cpu, unsigned int index) | |||
| 88 | cpus_allowed = current->cpus_allowed; | 108 | cpus_allowed = current->cpus_allowed; |
| 89 | set_cpus_allowed(current, cpumask_of_cpu(cpu)); | 109 | set_cpus_allowed(current, cpumask_of_cpu(cpu)); |
| 90 | 110 | ||
| 91 | new_freq = sparc64_get_clock_tick(cpu); | 111 | new_freq = sparc64_get_clock_tick(cpu) / 1000; |
| 92 | switch (index) { | 112 | switch (index) { |
| 93 | case 0: | 113 | case 0: |
| 94 | new_bits = SAFARI_CFG_DIV_1; | 114 | new_bits = SAFARI_CFG_DIV_1; |
| @@ -150,7 +170,7 @@ static int us3_freq_verify(struct cpufreq_policy *policy) | |||
| 150 | static int __init us3_freq_cpu_init(struct cpufreq_policy *policy) | 170 | static int __init us3_freq_cpu_init(struct cpufreq_policy *policy) |
| 151 | { | 171 | { |
| 152 | unsigned int cpu = policy->cpu; | 172 | unsigned int cpu = policy->cpu; |
| 153 | unsigned long clock_tick = sparc64_get_clock_tick(cpu); | 173 | unsigned long clock_tick = sparc64_get_clock_tick(cpu) / 1000; |
| 154 | struct cpufreq_frequency_table *table = | 174 | struct cpufreq_frequency_table *table = |
| 155 | &us3_freq_table[cpu].table[0]; | 175 | &us3_freq_table[cpu].table[0]; |
| 156 | 176 | ||
| @@ -206,9 +226,10 @@ static int __init us3_freq_init(void) | |||
| 206 | memset(us3_freq_table, 0, | 226 | memset(us3_freq_table, 0, |
| 207 | (NR_CPUS * sizeof(struct us3_freq_percpu_info))); | 227 | (NR_CPUS * sizeof(struct us3_freq_percpu_info))); |
| 208 | 228 | ||
| 229 | driver->init = us3_freq_cpu_init; | ||
| 209 | driver->verify = us3_freq_verify; | 230 | driver->verify = us3_freq_verify; |
| 210 | driver->target = us3_freq_target; | 231 | driver->target = us3_freq_target; |
| 211 | driver->init = us3_freq_cpu_init; | 232 | driver->get = us3_freq_get; |
| 212 | driver->exit = us3_freq_cpu_exit; | 233 | driver->exit = us3_freq_cpu_exit; |
| 213 | driver->owner = THIS_MODULE, | 234 | driver->owner = THIS_MODULE, |
| 214 | strcpy(driver->name, "UltraSPARC-III"); | 235 | strcpy(driver->name, "UltraSPARC-III"); |
diff --git a/arch/um/kernel/skas/process.c b/arch/um/kernel/skas/process.c index 6dd9e5bf18ed..f228f8b54194 100644 --- a/arch/um/kernel/skas/process.c +++ b/arch/um/kernel/skas/process.c | |||
| @@ -61,7 +61,11 @@ void wait_stub_done(int pid, int sig, char * fname) | |||
| 61 | 61 | ||
| 62 | CATCH_EINTR(n = waitpid(pid, &status, WUNTRACED)); | 62 | CATCH_EINTR(n = waitpid(pid, &status, WUNTRACED)); |
| 63 | } while((n >= 0) && WIFSTOPPED(status) && | 63 | } while((n >= 0) && WIFSTOPPED(status) && |
| 64 | (WSTOPSIG(status) == SIGVTALRM)); | 64 | ((WSTOPSIG(status) == SIGVTALRM) || |
| 65 | /* running UML inside a detached screen can cause | ||
| 66 | * SIGWINCHes | ||
| 67 | */ | ||
| 68 | (WSTOPSIG(status) == SIGWINCH))); | ||
| 65 | 69 | ||
| 66 | if((n < 0) || !WIFSTOPPED(status) || | 70 | if((n < 0) || !WIFSTOPPED(status) || |
| 67 | (WSTOPSIG(status) != SIGUSR1 && WSTOPSIG(status) != SIGTRAP)){ | 71 | (WSTOPSIG(status) != SIGUSR1 && WSTOPSIG(status) != SIGTRAP)){ |
diff --git a/arch/um/os-Linux/elf_aux.c b/arch/um/os-Linux/elf_aux.c index 9416e1c29926..4cca3e9c23fe 100644 --- a/arch/um/os-Linux/elf_aux.c +++ b/arch/um/os-Linux/elf_aux.c | |||
| @@ -9,7 +9,6 @@ | |||
| 9 | */ | 9 | */ |
| 10 | #include <elf.h> | 10 | #include <elf.h> |
| 11 | #include <stddef.h> | 11 | #include <stddef.h> |
| 12 | #include <asm/elf.h> | ||
| 13 | #include "init.h" | 12 | #include "init.h" |
| 14 | #include "elf_user.h" | 13 | #include "elf_user.h" |
| 15 | #include "mem_user.h" | 14 | #include "mem_user.h" |
diff --git a/arch/x86_64/defconfig b/arch/x86_64/defconfig index 776f3c866b70..b97a61e1c71c 100644 --- a/arch/x86_64/defconfig +++ b/arch/x86_64/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.13-rc3 | 3 | # Linux kernel version: 2.6.13-rc6-git3 |
| 4 | # Fri Jul 22 16:47:31 2005 | 4 | # Fri Aug 12 16:40:34 2005 |
| 5 | # | 5 | # |
| 6 | CONFIG_X86_64=y | 6 | CONFIG_X86_64=y |
| 7 | CONFIG_64BIT=y | 7 | CONFIG_64BIT=y |
| @@ -284,10 +284,6 @@ CONFIG_IPV6=y | |||
| 284 | # Network testing | 284 | # Network testing |
| 285 | # | 285 | # |
| 286 | # CONFIG_NET_PKTGEN is not set | 286 | # CONFIG_NET_PKTGEN is not set |
| 287 | CONFIG_NETPOLL=y | ||
| 288 | # CONFIG_NETPOLL_RX is not set | ||
| 289 | # CONFIG_NETPOLL_TRAP is not set | ||
| 290 | CONFIG_NET_POLL_CONTROLLER=y | ||
| 291 | # CONFIG_HAMRADIO is not set | 287 | # CONFIG_HAMRADIO is not set |
| 292 | # CONFIG_IRDA is not set | 288 | # CONFIG_IRDA is not set |
| 293 | # CONFIG_BT is not set | 289 | # CONFIG_BT is not set |
| @@ -463,6 +459,7 @@ CONFIG_AIC79XX_DEBUG_MASK=0 | |||
| 463 | # CONFIG_MEGARAID_NEWGEN is not set | 459 | # CONFIG_MEGARAID_NEWGEN is not set |
| 464 | # CONFIG_MEGARAID_LEGACY is not set | 460 | # CONFIG_MEGARAID_LEGACY is not set |
| 465 | CONFIG_SCSI_SATA=y | 461 | CONFIG_SCSI_SATA=y |
| 462 | # CONFIG_SCSI_SATA_AHCI is not set | ||
| 466 | # CONFIG_SCSI_SATA_SVW is not set | 463 | # CONFIG_SCSI_SATA_SVW is not set |
| 467 | CONFIG_SCSI_ATA_PIIX=y | 464 | CONFIG_SCSI_ATA_PIIX=y |
| 468 | # CONFIG_SCSI_SATA_NV is not set | 465 | # CONFIG_SCSI_SATA_NV is not set |
| @@ -492,6 +489,7 @@ CONFIG_SCSI_QLA2XXX=y | |||
| 492 | # CONFIG_SCSI_QLA2300 is not set | 489 | # CONFIG_SCSI_QLA2300 is not set |
| 493 | # CONFIG_SCSI_QLA2322 is not set | 490 | # CONFIG_SCSI_QLA2322 is not set |
| 494 | # CONFIG_SCSI_QLA6312 is not set | 491 | # CONFIG_SCSI_QLA6312 is not set |
| 492 | # CONFIG_SCSI_QLA24XX is not set | ||
| 495 | # CONFIG_SCSI_LPFC is not set | 493 | # CONFIG_SCSI_LPFC is not set |
| 496 | # CONFIG_SCSI_DC395x is not set | 494 | # CONFIG_SCSI_DC395x is not set |
| 497 | # CONFIG_SCSI_DC390T is not set | 495 | # CONFIG_SCSI_DC390T is not set |
| @@ -512,9 +510,11 @@ CONFIG_BLK_DEV_DM=y | |||
| 512 | # | 510 | # |
| 513 | # Fusion MPT device support | 511 | # Fusion MPT device support |
| 514 | # | 512 | # |
| 515 | # CONFIG_FUSION is not set | 513 | CONFIG_FUSION=y |
| 516 | # CONFIG_FUSION_SPI is not set | 514 | CONFIG_FUSION_SPI=y |
| 517 | # CONFIG_FUSION_FC is not set | 515 | # CONFIG_FUSION_FC is not set |
| 516 | CONFIG_FUSION_MAX_SGE=128 | ||
| 517 | # CONFIG_FUSION_CTL is not set | ||
| 518 | 518 | ||
| 519 | # | 519 | # |
| 520 | # IEEE 1394 (FireWire) support | 520 | # IEEE 1394 (FireWire) support |
| @@ -585,6 +585,7 @@ CONFIG_8139TOO=y | |||
| 585 | # CONFIG_ACENIC is not set | 585 | # CONFIG_ACENIC is not set |
| 586 | # CONFIG_DL2K is not set | 586 | # CONFIG_DL2K is not set |
| 587 | CONFIG_E1000=y | 587 | CONFIG_E1000=y |
| 588 | # CONFIG_E1000_NAPI is not set | ||
| 588 | # CONFIG_NS83820 is not set | 589 | # CONFIG_NS83820 is not set |
| 589 | # CONFIG_HAMACHI is not set | 590 | # CONFIG_HAMACHI is not set |
| 590 | # CONFIG_YELLOWFIN is not set | 591 | # CONFIG_YELLOWFIN is not set |
| @@ -624,6 +625,10 @@ CONFIG_S2IO=m | |||
| 624 | # CONFIG_NET_FC is not set | 625 | # CONFIG_NET_FC is not set |
| 625 | # CONFIG_SHAPER is not set | 626 | # CONFIG_SHAPER is not set |
| 626 | CONFIG_NETCONSOLE=y | 627 | CONFIG_NETCONSOLE=y |
| 628 | CONFIG_NETPOLL=y | ||
| 629 | # CONFIG_NETPOLL_RX is not set | ||
| 630 | # CONFIG_NETPOLL_TRAP is not set | ||
| 631 | CONFIG_NET_POLL_CONTROLLER=y | ||
| 627 | 632 | ||
| 628 | # | 633 | # |
| 629 | # ISDN subsystem | 634 | # ISDN subsystem |
diff --git a/arch/x86_64/kernel/e820.c b/arch/x86_64/kernel/e820.c index 6ded3a50dfe6..b548dea4e5b9 100644 --- a/arch/x86_64/kernel/e820.c +++ b/arch/x86_64/kernel/e820.c | |||
| @@ -185,6 +185,40 @@ unsigned long __init e820_end_of_ram(void) | |||
| 185 | } | 185 | } |
| 186 | 186 | ||
| 187 | /* | 187 | /* |
| 188 | * Compute how much memory is missing in a range. | ||
| 189 | * Unlike the other functions in this file the arguments are in page numbers. | ||
| 190 | */ | ||
| 191 | unsigned long __init | ||
| 192 | e820_hole_size(unsigned long start_pfn, unsigned long end_pfn) | ||
| 193 | { | ||
| 194 | unsigned long ram = 0; | ||
| 195 | unsigned long start = start_pfn << PAGE_SHIFT; | ||
| 196 | unsigned long end = end_pfn << PAGE_SHIFT; | ||
| 197 | int i; | ||
| 198 | for (i = 0; i < e820.nr_map; i++) { | ||
| 199 | struct e820entry *ei = &e820.map[i]; | ||
| 200 | unsigned long last, addr; | ||
| 201 | |||
| 202 | if (ei->type != E820_RAM || | ||
| 203 | ei->addr+ei->size <= start || | ||
| 204 | ei->addr >= end) | ||
| 205 | continue; | ||
| 206 | |||
| 207 | addr = round_up(ei->addr, PAGE_SIZE); | ||
| 208 | if (addr < start) | ||
| 209 | addr = start; | ||
| 210 | |||
| 211 | last = round_down(ei->addr + ei->size, PAGE_SIZE); | ||
| 212 | if (last >= end) | ||
| 213 | last = end; | ||
| 214 | |||
| 215 | if (last > addr) | ||
| 216 | ram += last - addr; | ||
| 217 | } | ||
| 218 | return ((end - start) - ram) >> PAGE_SHIFT; | ||
| 219 | } | ||
| 220 | |||
| 221 | /* | ||
| 188 | * Mark e820 reserved areas as busy for the resource manager. | 222 | * Mark e820 reserved areas as busy for the resource manager. |
| 189 | */ | 223 | */ |
| 190 | void __init e820_reserve_resources(void) | 224 | void __init e820_reserve_resources(void) |
diff --git a/arch/x86_64/kernel/smpboot.c b/arch/x86_64/kernel/smpboot.c index b15761ff4101..fa25e39fe54d 100644 --- a/arch/x86_64/kernel/smpboot.c +++ b/arch/x86_64/kernel/smpboot.c | |||
| @@ -492,6 +492,14 @@ void __cpuinit start_secondary(void) | |||
| 492 | */ | 492 | */ |
| 493 | set_cpu_sibling_map(smp_processor_id()); | 493 | set_cpu_sibling_map(smp_processor_id()); |
| 494 | 494 | ||
| 495 | /* | ||
| 496 | * Wait for TSC sync to not schedule things before. | ||
| 497 | * We still process interrupts, which could see an inconsistent | ||
| 498 | * time in that window unfortunately. | ||
| 499 | * Do this here because TSC sync has global unprotected state. | ||
| 500 | */ | ||
| 501 | tsc_sync_wait(); | ||
| 502 | |||
| 495 | /* | 503 | /* |
| 496 | * We need to hold call_lock, so there is no inconsistency | 504 | * We need to hold call_lock, so there is no inconsistency |
| 497 | * between the time smp_call_function() determines number of | 505 | * between the time smp_call_function() determines number of |
| @@ -509,13 +517,6 @@ void __cpuinit start_secondary(void) | |||
| 509 | per_cpu(cpu_state, smp_processor_id()) = CPU_ONLINE; | 517 | per_cpu(cpu_state, smp_processor_id()) = CPU_ONLINE; |
| 510 | unlock_ipi_call_lock(); | 518 | unlock_ipi_call_lock(); |
| 511 | 519 | ||
| 512 | mb(); | ||
| 513 | |||
| 514 | /* Wait for TSC sync to not schedule things before. | ||
| 515 | We still process interrupts, which could see an inconsistent | ||
| 516 | time in that window unfortunately. */ | ||
| 517 | tsc_sync_wait(); | ||
| 518 | |||
| 519 | cpu_idle(); | 520 | cpu_idle(); |
| 520 | } | 521 | } |
| 521 | 522 | ||
diff --git a/arch/x86_64/mm/fault.c b/arch/x86_64/mm/fault.c index 493819e543a5..ca914c3bd49c 100644 --- a/arch/x86_64/mm/fault.c +++ b/arch/x86_64/mm/fault.c | |||
| @@ -211,9 +211,7 @@ int unhandled_signal(struct task_struct *tsk, int sig) | |||
| 211 | { | 211 | { |
| 212 | if (tsk->pid == 1) | 212 | if (tsk->pid == 1) |
| 213 | return 1; | 213 | return 1; |
| 214 | /* Warn for strace, but not for gdb */ | 214 | if (tsk->ptrace & PT_PTRACED) |
| 215 | if (!test_ti_thread_flag(tsk->thread_info, TIF_SYSCALL_TRACE) && | ||
| 216 | (tsk->ptrace & PT_PTRACED)) | ||
| 217 | return 0; | 215 | return 0; |
| 218 | return (tsk->sighand->action[sig-1].sa.sa_handler == SIG_IGN) || | 216 | return (tsk->sighand->action[sig-1].sa.sa_handler == SIG_IGN) || |
| 219 | (tsk->sighand->action[sig-1].sa.sa_handler == SIG_DFL); | 217 | (tsk->sighand->action[sig-1].sa.sa_handler == SIG_DFL); |
diff --git a/arch/x86_64/mm/init.c b/arch/x86_64/mm/init.c index 72e4b364ed73..aa4a5189ecee 100644 --- a/arch/x86_64/mm/init.c +++ b/arch/x86_64/mm/init.c | |||
| @@ -322,18 +322,26 @@ void zap_low_mappings(void) | |||
| 322 | void __init paging_init(void) | 322 | void __init paging_init(void) |
| 323 | { | 323 | { |
| 324 | { | 324 | { |
| 325 | unsigned long zones_size[MAX_NR_ZONES] = {0, 0, 0}; | 325 | unsigned long zones_size[MAX_NR_ZONES]; |
| 326 | unsigned long holes[MAX_NR_ZONES]; | ||
| 326 | unsigned int max_dma; | 327 | unsigned int max_dma; |
| 327 | 328 | ||
| 329 | memset(zones_size, 0, sizeof(zones_size)); | ||
| 330 | memset(holes, 0, sizeof(holes)); | ||
| 331 | |||
| 328 | max_dma = virt_to_phys((char *)MAX_DMA_ADDRESS) >> PAGE_SHIFT; | 332 | max_dma = virt_to_phys((char *)MAX_DMA_ADDRESS) >> PAGE_SHIFT; |
| 329 | 333 | ||
| 330 | if (end_pfn < max_dma) | 334 | if (end_pfn < max_dma) { |
| 331 | zones_size[ZONE_DMA] = end_pfn; | 335 | zones_size[ZONE_DMA] = end_pfn; |
| 332 | else { | 336 | holes[ZONE_DMA] = e820_hole_size(0, end_pfn); |
| 337 | } else { | ||
| 333 | zones_size[ZONE_DMA] = max_dma; | 338 | zones_size[ZONE_DMA] = max_dma; |
| 339 | holes[ZONE_DMA] = e820_hole_size(0, max_dma); | ||
| 334 | zones_size[ZONE_NORMAL] = end_pfn - max_dma; | 340 | zones_size[ZONE_NORMAL] = end_pfn - max_dma; |
| 341 | holes[ZONE_NORMAL] = e820_hole_size(max_dma, end_pfn); | ||
| 335 | } | 342 | } |
| 336 | free_area_init(zones_size); | 343 | free_area_init_node(0, NODE_DATA(0), zones_size, |
| 344 | __pa(PAGE_OFFSET) >> PAGE_SHIFT, holes); | ||
| 337 | } | 345 | } |
| 338 | return; | 346 | return; |
| 339 | } | 347 | } |
diff --git a/arch/x86_64/mm/numa.c b/arch/x86_64/mm/numa.c index 70cb2904a90f..6a156f5692ae 100644 --- a/arch/x86_64/mm/numa.c +++ b/arch/x86_64/mm/numa.c | |||
| @@ -126,9 +126,11 @@ void __init setup_node_zones(int nodeid) | |||
| 126 | { | 126 | { |
| 127 | unsigned long start_pfn, end_pfn; | 127 | unsigned long start_pfn, end_pfn; |
| 128 | unsigned long zones[MAX_NR_ZONES]; | 128 | unsigned long zones[MAX_NR_ZONES]; |
| 129 | unsigned long holes[MAX_NR_ZONES]; | ||
| 129 | unsigned long dma_end_pfn; | 130 | unsigned long dma_end_pfn; |
| 130 | 131 | ||
| 131 | memset(zones, 0, sizeof(unsigned long) * MAX_NR_ZONES); | 132 | memset(zones, 0, sizeof(unsigned long) * MAX_NR_ZONES); |
| 133 | memset(holes, 0, sizeof(unsigned long) * MAX_NR_ZONES); | ||
| 132 | 134 | ||
| 133 | start_pfn = node_start_pfn(nodeid); | 135 | start_pfn = node_start_pfn(nodeid); |
| 134 | end_pfn = node_end_pfn(nodeid); | 136 | end_pfn = node_end_pfn(nodeid); |
| @@ -139,13 +141,17 @@ void __init setup_node_zones(int nodeid) | |||
| 139 | dma_end_pfn = __pa(MAX_DMA_ADDRESS) >> PAGE_SHIFT; | 141 | dma_end_pfn = __pa(MAX_DMA_ADDRESS) >> PAGE_SHIFT; |
| 140 | if (start_pfn < dma_end_pfn) { | 142 | if (start_pfn < dma_end_pfn) { |
| 141 | zones[ZONE_DMA] = dma_end_pfn - start_pfn; | 143 | zones[ZONE_DMA] = dma_end_pfn - start_pfn; |
| 144 | holes[ZONE_DMA] = e820_hole_size(start_pfn, dma_end_pfn); | ||
| 142 | zones[ZONE_NORMAL] = end_pfn - dma_end_pfn; | 145 | zones[ZONE_NORMAL] = end_pfn - dma_end_pfn; |
| 146 | holes[ZONE_NORMAL] = e820_hole_size(dma_end_pfn, end_pfn); | ||
| 147 | |||
| 143 | } else { | 148 | } else { |
| 144 | zones[ZONE_NORMAL] = end_pfn - start_pfn; | 149 | zones[ZONE_NORMAL] = end_pfn - start_pfn; |
| 150 | holes[ZONE_NORMAL] = e820_hole_size(start_pfn, end_pfn); | ||
| 145 | } | 151 | } |
| 146 | 152 | ||
| 147 | free_area_init_node(nodeid, NODE_DATA(nodeid), zones, | 153 | free_area_init_node(nodeid, NODE_DATA(nodeid), zones, |
| 148 | start_pfn, NULL); | 154 | start_pfn, holes); |
| 149 | } | 155 | } |
| 150 | 156 | ||
| 151 | void __init numa_init_array(void) | 157 | void __init numa_init_array(void) |
diff --git a/arch/x86_64/pci/k8-bus.c b/arch/x86_64/pci/k8-bus.c index c2c38b579939..d80c323669e0 100644 --- a/arch/x86_64/pci/k8-bus.c +++ b/arch/x86_64/pci/k8-bus.c | |||
| @@ -47,13 +47,22 @@ fill_mp_bus_to_cpumask(void) | |||
| 47 | * if there are no busses hanging off of the current | 47 | * if there are no busses hanging off of the current |
| 48 | * ldt link then both the secondary and subordinate | 48 | * ldt link then both the secondary and subordinate |
| 49 | * bus number fields are set to 0. | 49 | * bus number fields are set to 0. |
| 50 | * | ||
| 51 | * RED-PEN | ||
| 52 | * This is slightly broken because it assumes | ||
| 53 | * HT node IDs == Linux node ids, which is not always | ||
| 54 | * true. However it is probably mostly true. | ||
| 50 | */ | 55 | */ |
| 51 | if (!(SECONDARY_LDT_BUS_NUMBER(ldtbus) == 0 | 56 | if (!(SECONDARY_LDT_BUS_NUMBER(ldtbus) == 0 |
| 52 | && SUBORDINATE_LDT_BUS_NUMBER(ldtbus) == 0)) { | 57 | && SUBORDINATE_LDT_BUS_NUMBER(ldtbus) == 0)) { |
| 53 | for (j = SECONDARY_LDT_BUS_NUMBER(ldtbus); | 58 | for (j = SECONDARY_LDT_BUS_NUMBER(ldtbus); |
| 54 | j <= SUBORDINATE_LDT_BUS_NUMBER(ldtbus); | 59 | j <= SUBORDINATE_LDT_BUS_NUMBER(ldtbus); |
| 55 | j++) | 60 | j++) { |
| 56 | pci_bus_to_node[j] = NODE_ID(nid); | 61 | int node = NODE_ID(nid); |
| 62 | if (!node_online(node)) | ||
| 63 | node = 0; | ||
| 64 | pci_bus_to_node[j] = node; | ||
| 65 | } | ||
| 57 | } | 66 | } |
| 58 | } | 67 | } |
| 59 | } | 68 | } |
