提交 f6072452 编写于 作者: L Linus Torvalds

Merge branch 'for-v3.4-rc5' of git://git.kernel.org/pub/scm/linux/kernel/git/paulg/linux

Pull build fixes for less mainstream architectures from Paul Gortmaker:
 "These are fixes for frv(1), blackfin(2), powerpc(1) and xtensa(4).

  Fortunately the touches are nearly all specific to files just used by
  the arch in question.  The two touches to shared/common files
  [kernel/irq/debug.h and drivers/pci/Makefile] are trivial to assess as
  no risk to anyone.

  Half of them relate to xtensa directly.  It was only when I fixed the
  last xtensa issue that I realized that the arch has been broken for a
  significant time, and isn't a specific v3.4 regression.  So if you
  wanted, we could leave xtensa lying bleeding in the street for a
  couple more weeks and queue those for 3.5.  But given they are no risk
  to anyone outside of xtensa, I figured to just leave them in.

  If you are OK with taking the xtensa fixes, then please pull to get:

   - one last implicit include uncovered by system.h that is in a file
     specific to just one powerpc defconfig.  (I'd sync'd with BenH).

   - fix an oversight in the PCI makefile where shared code wasn't being
     compiled for ARCH=frv

   - fix a missing include for GPIO in blackfin framebuffer.

   - audit and tag endif in blackfin ezkit board file, in order to find
     and fix the misplaced endif masking a block of code.

   - fix irq/debug.h choice of temporary macro names to be more internal
     so they don't conflict with names used by xtensa.

   - fix a reference to an undeclared local var in xtensa's signal.c

   - fix an implicit bug.h usage in xtensa's asm/io.h uncovered by my
     removing bug.h from kernel.h

   - fix xtensa to properly indicate it is using asm-generic/hardirq.h
     in order to resolve the link error - undefined ack_bad_irq

  The xtensa still fails final link as my latest binutils does something
  evil when ld forward-relocates unlikely() blocks, but in theory people
  who have older/valid toolchains could now use the thing."

* 'for-v3.4-rc5' of git://git.kernel.org/pub/scm/linux/kernel/git/paulg/linux:
  xtensa: fix build fail on undefined ack_bad_irq
  blackfin: fix ifdef fustercluck in mach-bf538/boards/ezkit.c
  blackfin: fix compile error in bfin-lq035q1-fb.c
  pci: frv architecture needs generic setup-bus infrastructure
  irq: hide debug macros so they don't collide with others.
  xtensa: fix build error in xtensa/include/asm/io.h
  xtensa: fix build failure in xtensa/kernel/signal.c
  powerpc: fix system.h fallout in sysdev/scom.c [chroma_defconfig]
...@@ -38,7 +38,7 @@ static struct platform_device rtc_device = { ...@@ -38,7 +38,7 @@ static struct platform_device rtc_device = {
.name = "rtc-bfin", .name = "rtc-bfin",
.id = -1, .id = -1,
}; };
#endif #endif /* CONFIG_RTC_DRV_BFIN */
#if defined(CONFIG_SERIAL_BFIN) || defined(CONFIG_SERIAL_BFIN_MODULE) #if defined(CONFIG_SERIAL_BFIN) || defined(CONFIG_SERIAL_BFIN_MODULE)
#ifdef CONFIG_SERIAL_BFIN_UART0 #ifdef CONFIG_SERIAL_BFIN_UART0
...@@ -100,7 +100,7 @@ static struct platform_device bfin_uart0_device = { ...@@ -100,7 +100,7 @@ static struct platform_device bfin_uart0_device = {
.platform_data = &bfin_uart0_peripherals, /* Passed to driver */ .platform_data = &bfin_uart0_peripherals, /* Passed to driver */
}, },
}; };
#endif #endif /* CONFIG_SERIAL_BFIN_UART0 */
#ifdef CONFIG_SERIAL_BFIN_UART1 #ifdef CONFIG_SERIAL_BFIN_UART1
static struct resource bfin_uart1_resources[] = { static struct resource bfin_uart1_resources[] = {
{ {
...@@ -148,7 +148,7 @@ static struct platform_device bfin_uart1_device = { ...@@ -148,7 +148,7 @@ static struct platform_device bfin_uart1_device = {
.platform_data = &bfin_uart1_peripherals, /* Passed to driver */ .platform_data = &bfin_uart1_peripherals, /* Passed to driver */
}, },
}; };
#endif #endif /* CONFIG_SERIAL_BFIN_UART1 */
#ifdef CONFIG_SERIAL_BFIN_UART2 #ifdef CONFIG_SERIAL_BFIN_UART2
static struct resource bfin_uart2_resources[] = { static struct resource bfin_uart2_resources[] = {
{ {
...@@ -196,8 +196,8 @@ static struct platform_device bfin_uart2_device = { ...@@ -196,8 +196,8 @@ static struct platform_device bfin_uart2_device = {
.platform_data = &bfin_uart2_peripherals, /* Passed to driver */ .platform_data = &bfin_uart2_peripherals, /* Passed to driver */
}, },
}; };
#endif #endif /* CONFIG_SERIAL_BFIN_UART2 */
#endif #endif /* CONFIG_SERIAL_BFIN */
#if defined(CONFIG_BFIN_SIR) || defined(CONFIG_BFIN_SIR_MODULE) #if defined(CONFIG_BFIN_SIR) || defined(CONFIG_BFIN_SIR_MODULE)
#ifdef CONFIG_BFIN_SIR0 #ifdef CONFIG_BFIN_SIR0
...@@ -224,7 +224,7 @@ static struct platform_device bfin_sir0_device = { ...@@ -224,7 +224,7 @@ static struct platform_device bfin_sir0_device = {
.num_resources = ARRAY_SIZE(bfin_sir0_resources), .num_resources = ARRAY_SIZE(bfin_sir0_resources),
.resource = bfin_sir0_resources, .resource = bfin_sir0_resources,
}; };
#endif #endif /* CONFIG_BFIN_SIR0 */
#ifdef CONFIG_BFIN_SIR1 #ifdef CONFIG_BFIN_SIR1
static struct resource bfin_sir1_resources[] = { static struct resource bfin_sir1_resources[] = {
{ {
...@@ -249,7 +249,7 @@ static struct platform_device bfin_sir1_device = { ...@@ -249,7 +249,7 @@ static struct platform_device bfin_sir1_device = {
.num_resources = ARRAY_SIZE(bfin_sir1_resources), .num_resources = ARRAY_SIZE(bfin_sir1_resources),
.resource = bfin_sir1_resources, .resource = bfin_sir1_resources,
}; };
#endif #endif /* CONFIG_BFIN_SIR1 */
#ifdef CONFIG_BFIN_SIR2 #ifdef CONFIG_BFIN_SIR2
static struct resource bfin_sir2_resources[] = { static struct resource bfin_sir2_resources[] = {
{ {
...@@ -274,8 +274,8 @@ static struct platform_device bfin_sir2_device = { ...@@ -274,8 +274,8 @@ static struct platform_device bfin_sir2_device = {
.num_resources = ARRAY_SIZE(bfin_sir2_resources), .num_resources = ARRAY_SIZE(bfin_sir2_resources),
.resource = bfin_sir2_resources, .resource = bfin_sir2_resources,
}; };
#endif #endif /* CONFIG_BFIN_SIR2 */
#endif #endif /* CONFIG_BFIN_SIR */
#if defined(CONFIG_SERIAL_BFIN_SPORT) || defined(CONFIG_SERIAL_BFIN_SPORT_MODULE) #if defined(CONFIG_SERIAL_BFIN_SPORT) || defined(CONFIG_SERIAL_BFIN_SPORT_MODULE)
#ifdef CONFIG_SERIAL_BFIN_SPORT0_UART #ifdef CONFIG_SERIAL_BFIN_SPORT0_UART
...@@ -311,7 +311,7 @@ static struct platform_device bfin_sport0_uart_device = { ...@@ -311,7 +311,7 @@ static struct platform_device bfin_sport0_uart_device = {
.platform_data = &bfin_sport0_peripherals, /* Passed to driver */ .platform_data = &bfin_sport0_peripherals, /* Passed to driver */
}, },
}; };
#endif #endif /* CONFIG_SERIAL_BFIN_SPORT0_UART */
#ifdef CONFIG_SERIAL_BFIN_SPORT1_UART #ifdef CONFIG_SERIAL_BFIN_SPORT1_UART
static struct resource bfin_sport1_uart_resources[] = { static struct resource bfin_sport1_uart_resources[] = {
{ {
...@@ -345,7 +345,7 @@ static struct platform_device bfin_sport1_uart_device = { ...@@ -345,7 +345,7 @@ static struct platform_device bfin_sport1_uart_device = {
.platform_data = &bfin_sport1_peripherals, /* Passed to driver */ .platform_data = &bfin_sport1_peripherals, /* Passed to driver */
}, },
}; };
#endif #endif /* CONFIG_SERIAL_BFIN_SPORT1_UART */
#ifdef CONFIG_SERIAL_BFIN_SPORT2_UART #ifdef CONFIG_SERIAL_BFIN_SPORT2_UART
static struct resource bfin_sport2_uart_resources[] = { static struct resource bfin_sport2_uart_resources[] = {
{ {
...@@ -379,7 +379,7 @@ static struct platform_device bfin_sport2_uart_device = { ...@@ -379,7 +379,7 @@ static struct platform_device bfin_sport2_uart_device = {
.platform_data = &bfin_sport2_peripherals, /* Passed to driver */ .platform_data = &bfin_sport2_peripherals, /* Passed to driver */
}, },
}; };
#endif #endif /* CONFIG_SERIAL_BFIN_SPORT2_UART */
#ifdef CONFIG_SERIAL_BFIN_SPORT3_UART #ifdef CONFIG_SERIAL_BFIN_SPORT3_UART
static struct resource bfin_sport3_uart_resources[] = { static struct resource bfin_sport3_uart_resources[] = {
{ {
...@@ -413,8 +413,8 @@ static struct platform_device bfin_sport3_uart_device = { ...@@ -413,8 +413,8 @@ static struct platform_device bfin_sport3_uart_device = {
.platform_data = &bfin_sport3_peripherals, /* Passed to driver */ .platform_data = &bfin_sport3_peripherals, /* Passed to driver */
}, },
}; };
#endif #endif /* CONFIG_SERIAL_BFIN_SPORT3_UART */
#endif #endif /* CONFIG_SERIAL_BFIN_SPORT */
#if defined(CONFIG_CAN_BFIN) || defined(CONFIG_CAN_BFIN_MODULE) #if defined(CONFIG_CAN_BFIN) || defined(CONFIG_CAN_BFIN_MODULE)
static unsigned short bfin_can_peripherals[] = { static unsigned short bfin_can_peripherals[] = {
...@@ -452,7 +452,7 @@ static struct platform_device bfin_can_device = { ...@@ -452,7 +452,7 @@ static struct platform_device bfin_can_device = {
.platform_data = &bfin_can_peripherals, /* Passed to driver */ .platform_data = &bfin_can_peripherals, /* Passed to driver */
}, },
}; };
#endif #endif /* CONFIG_CAN_BFIN */
/* /*
* USB-LAN EzExtender board * USB-LAN EzExtender board
...@@ -488,7 +488,7 @@ static struct platform_device smc91x_device = { ...@@ -488,7 +488,7 @@ static struct platform_device smc91x_device = {
.platform_data = &smc91x_info, .platform_data = &smc91x_info,
}, },
}; };
#endif #endif /* CONFIG_SMC91X */
#if defined(CONFIG_SPI_BFIN5XX) || defined(CONFIG_SPI_BFIN5XX_MODULE) #if defined(CONFIG_SPI_BFIN5XX) || defined(CONFIG_SPI_BFIN5XX_MODULE)
/* all SPI peripherals info goes here */ /* all SPI peripherals info goes here */
...@@ -518,7 +518,8 @@ static struct flash_platform_data bfin_spi_flash_data = { ...@@ -518,7 +518,8 @@ static struct flash_platform_data bfin_spi_flash_data = {
static struct bfin5xx_spi_chip spi_flash_chip_info = { static struct bfin5xx_spi_chip spi_flash_chip_info = {
.enable_dma = 0, /* use dma transfer with this chip*/ .enable_dma = 0, /* use dma transfer with this chip*/
}; };
#endif #endif /* CONFIG_MTD_M25P80 */
#endif /* CONFIG_SPI_BFIN5XX */
#if defined(CONFIG_TOUCHSCREEN_AD7879) || defined(CONFIG_TOUCHSCREEN_AD7879_MODULE) #if defined(CONFIG_TOUCHSCREEN_AD7879) || defined(CONFIG_TOUCHSCREEN_AD7879_MODULE)
#include <linux/spi/ad7879.h> #include <linux/spi/ad7879.h>
...@@ -535,7 +536,7 @@ static const struct ad7879_platform_data bfin_ad7879_ts_info = { ...@@ -535,7 +536,7 @@ static const struct ad7879_platform_data bfin_ad7879_ts_info = {
.gpio_export = 1, /* Export GPIO to gpiolib */ .gpio_export = 1, /* Export GPIO to gpiolib */
.gpio_base = -1, /* Dynamic allocation */ .gpio_base = -1, /* Dynamic allocation */
}; };
#endif #endif /* CONFIG_TOUCHSCREEN_AD7879 */
#if defined(CONFIG_FB_BFIN_LQ035Q1) || defined(CONFIG_FB_BFIN_LQ035Q1_MODULE) #if defined(CONFIG_FB_BFIN_LQ035Q1) || defined(CONFIG_FB_BFIN_LQ035Q1_MODULE)
#include <asm/bfin-lq035q1.h> #include <asm/bfin-lq035q1.h>
...@@ -564,7 +565,7 @@ static struct platform_device bfin_lq035q1_device = { ...@@ -564,7 +565,7 @@ static struct platform_device bfin_lq035q1_device = {
.platform_data = &bfin_lq035q1_data, .platform_data = &bfin_lq035q1_data,
}, },
}; };
#endif #endif /* CONFIG_FB_BFIN_LQ035Q1 */
static struct spi_board_info bf538_spi_board_info[] __initdata = { static struct spi_board_info bf538_spi_board_info[] __initdata = {
#if defined(CONFIG_MTD_M25P80) \ #if defined(CONFIG_MTD_M25P80) \
...@@ -579,7 +580,7 @@ static struct spi_board_info bf538_spi_board_info[] __initdata = { ...@@ -579,7 +580,7 @@ static struct spi_board_info bf538_spi_board_info[] __initdata = {
.controller_data = &spi_flash_chip_info, .controller_data = &spi_flash_chip_info,
.mode = SPI_MODE_3, .mode = SPI_MODE_3,
}, },
#endif #endif /* CONFIG_MTD_M25P80 */
#if defined(CONFIG_TOUCHSCREEN_AD7879_SPI) || defined(CONFIG_TOUCHSCREEN_AD7879_SPI_MODULE) #if defined(CONFIG_TOUCHSCREEN_AD7879_SPI) || defined(CONFIG_TOUCHSCREEN_AD7879_SPI_MODULE)
{ {
.modalias = "ad7879", .modalias = "ad7879",
...@@ -590,7 +591,7 @@ static struct spi_board_info bf538_spi_board_info[] __initdata = { ...@@ -590,7 +591,7 @@ static struct spi_board_info bf538_spi_board_info[] __initdata = {
.chip_select = 1, .chip_select = 1,
.mode = SPI_CPHA | SPI_CPOL, .mode = SPI_CPHA | SPI_CPOL,
}, },
#endif #endif /* CONFIG_TOUCHSCREEN_AD7879_SPI */
#if defined(CONFIG_FB_BFIN_LQ035Q1) || defined(CONFIG_FB_BFIN_LQ035Q1_MODULE) #if defined(CONFIG_FB_BFIN_LQ035Q1) || defined(CONFIG_FB_BFIN_LQ035Q1_MODULE)
{ {
.modalias = "bfin-lq035q1-spi", .modalias = "bfin-lq035q1-spi",
...@@ -599,7 +600,7 @@ static struct spi_board_info bf538_spi_board_info[] __initdata = { ...@@ -599,7 +600,7 @@ static struct spi_board_info bf538_spi_board_info[] __initdata = {
.chip_select = 2, .chip_select = 2,
.mode = SPI_CPHA | SPI_CPOL, .mode = SPI_CPHA | SPI_CPOL,
}, },
#endif #endif /* CONFIG_FB_BFIN_LQ035Q1 */
#if defined(CONFIG_SPI_SPIDEV) || defined(CONFIG_SPI_SPIDEV_MODULE) #if defined(CONFIG_SPI_SPIDEV) || defined(CONFIG_SPI_SPIDEV_MODULE)
{ {
.modalias = "spidev", .modalias = "spidev",
...@@ -607,7 +608,7 @@ static struct spi_board_info bf538_spi_board_info[] __initdata = { ...@@ -607,7 +608,7 @@ static struct spi_board_info bf538_spi_board_info[] __initdata = {
.bus_num = 0, .bus_num = 0,
.chip_select = 1, .chip_select = 1,
}, },
#endif #endif /* CONFIG_SPI_SPIDEV */
}; };
/* SPI (0) */ /* SPI (0) */
...@@ -716,8 +717,6 @@ static struct platform_device bf538_spi_master2 = { ...@@ -716,8 +717,6 @@ static struct platform_device bf538_spi_master2 = {
}, },
}; };
#endif /* spi master and devices */
#if defined(CONFIG_I2C_BLACKFIN_TWI) || defined(CONFIG_I2C_BLACKFIN_TWI_MODULE) #if defined(CONFIG_I2C_BLACKFIN_TWI) || defined(CONFIG_I2C_BLACKFIN_TWI_MODULE)
static struct resource bfin_twi0_resource[] = { static struct resource bfin_twi0_resource[] = {
[0] = { [0] = {
...@@ -759,8 +758,8 @@ static struct platform_device i2c_bfin_twi1_device = { ...@@ -759,8 +758,8 @@ static struct platform_device i2c_bfin_twi1_device = {
.num_resources = ARRAY_SIZE(bfin_twi1_resource), .num_resources = ARRAY_SIZE(bfin_twi1_resource),
.resource = bfin_twi1_resource, .resource = bfin_twi1_resource,
}; };
#endif #endif /* CONFIG_BF542 */
#endif #endif /* CONFIG_I2C_BLACKFIN_TWI */
#if defined(CONFIG_KEYBOARD_GPIO) || defined(CONFIG_KEYBOARD_GPIO_MODULE) #if defined(CONFIG_KEYBOARD_GPIO) || defined(CONFIG_KEYBOARD_GPIO_MODULE)
#include <linux/gpio_keys.h> #include <linux/gpio_keys.h>
......
...@@ -22,6 +22,7 @@ ...@@ -22,6 +22,7 @@
#include <linux/debugfs.h> #include <linux/debugfs.h>
#include <linux/slab.h> #include <linux/slab.h>
#include <linux/export.h> #include <linux/export.h>
#include <asm/debug.h>
#include <asm/prom.h> #include <asm/prom.h>
#include <asm/scom.h> #include <asm/scom.h>
......
...@@ -11,9 +11,6 @@ ...@@ -11,9 +11,6 @@
#ifndef _XTENSA_HARDIRQ_H #ifndef _XTENSA_HARDIRQ_H
#define _XTENSA_HARDIRQ_H #define _XTENSA_HARDIRQ_H
void ack_bad_irq(unsigned int irq);
#define ack_bad_irq ack_bad_irq
#include <asm-generic/hardirq.h> #include <asm-generic/hardirq.h>
#endif /* _XTENSA_HARDIRQ_H */ #endif /* _XTENSA_HARDIRQ_H */
...@@ -14,6 +14,7 @@ ...@@ -14,6 +14,7 @@
#ifdef __KERNEL__ #ifdef __KERNEL__
#include <asm/byteorder.h> #include <asm/byteorder.h>
#include <asm/page.h> #include <asm/page.h>
#include <linux/bug.h>
#include <linux/kernel.h> #include <linux/kernel.h>
#include <linux/types.h> #include <linux/types.h>
......
...@@ -496,6 +496,7 @@ int do_signal(struct pt_regs *regs, sigset_t *oldset) ...@@ -496,6 +496,7 @@ int do_signal(struct pt_regs *regs, sigset_t *oldset)
signr = get_signal_to_deliver(&info, &ka, regs, NULL); signr = get_signal_to_deliver(&info, &ka, regs, NULL);
if (signr > 0) { if (signr > 0) {
int ret;
/* Are we from a system call? */ /* Are we from a system call? */
......
...@@ -42,6 +42,7 @@ obj-$(CONFIG_UNICORE32) += setup-bus.o setup-irq.o ...@@ -42,6 +42,7 @@ obj-$(CONFIG_UNICORE32) += setup-bus.o setup-irq.o
obj-$(CONFIG_PARISC) += setup-bus.o obj-$(CONFIG_PARISC) += setup-bus.o
obj-$(CONFIG_SUPERH) += setup-bus.o setup-irq.o obj-$(CONFIG_SUPERH) += setup-bus.o setup-irq.o
obj-$(CONFIG_PPC) += setup-bus.o obj-$(CONFIG_PPC) += setup-bus.o
obj-$(CONFIG_FRV) += setup-bus.o
obj-$(CONFIG_MIPS) += setup-bus.o setup-irq.o obj-$(CONFIG_MIPS) += setup-bus.o setup-irq.o
obj-$(CONFIG_X86_VISWS) += setup-irq.o obj-$(CONFIG_X86_VISWS) += setup-irq.o
obj-$(CONFIG_MN10300) += setup-bus.o obj-$(CONFIG_MN10300) += setup-bus.o
......
...@@ -13,6 +13,7 @@ ...@@ -13,6 +13,7 @@
#include <linux/errno.h> #include <linux/errno.h>
#include <linux/string.h> #include <linux/string.h>
#include <linux/fb.h> #include <linux/fb.h>
#include <linux/gpio.h>
#include <linux/slab.h> #include <linux/slab.h>
#include <linux/init.h> #include <linux/init.h>
#include <linux/types.h> #include <linux/types.h>
......
...@@ -4,10 +4,10 @@ ...@@ -4,10 +4,10 @@
#include <linux/kallsyms.h> #include <linux/kallsyms.h>
#define P(f) if (desc->status_use_accessors & f) printk("%14s set\n", #f) #define ___P(f) if (desc->status_use_accessors & f) printk("%14s set\n", #f)
#define PS(f) if (desc->istate & f) printk("%14s set\n", #f) #define ___PS(f) if (desc->istate & f) printk("%14s set\n", #f)
/* FIXME */ /* FIXME */
#define PD(f) do { } while (0) #define ___PD(f) do { } while (0)
static inline void print_irq_desc(unsigned int irq, struct irq_desc *desc) static inline void print_irq_desc(unsigned int irq, struct irq_desc *desc)
{ {
...@@ -23,23 +23,23 @@ static inline void print_irq_desc(unsigned int irq, struct irq_desc *desc) ...@@ -23,23 +23,23 @@ static inline void print_irq_desc(unsigned int irq, struct irq_desc *desc)
print_symbol("%s\n", (unsigned long)desc->action->handler); print_symbol("%s\n", (unsigned long)desc->action->handler);
} }
P(IRQ_LEVEL); ___P(IRQ_LEVEL);
P(IRQ_PER_CPU); ___P(IRQ_PER_CPU);
P(IRQ_NOPROBE); ___P(IRQ_NOPROBE);
P(IRQ_NOREQUEST); ___P(IRQ_NOREQUEST);
P(IRQ_NOTHREAD); ___P(IRQ_NOTHREAD);
P(IRQ_NOAUTOEN); ___P(IRQ_NOAUTOEN);
PS(IRQS_AUTODETECT); ___PS(IRQS_AUTODETECT);
PS(IRQS_REPLAY); ___PS(IRQS_REPLAY);
PS(IRQS_WAITING); ___PS(IRQS_WAITING);
PS(IRQS_PENDING); ___PS(IRQS_PENDING);
PD(IRQS_INPROGRESS); ___PD(IRQS_INPROGRESS);
PD(IRQS_DISABLED); ___PD(IRQS_DISABLED);
PD(IRQS_MASKED); ___PD(IRQS_MASKED);
} }
#undef P #undef ___P
#undef PS #undef ___PS
#undef PD #undef ___PD
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册