提交 528ba4ef 编写于 作者: L Linus Torvalds

Merge branch 'upstream' of git://ftp.linux-mips.org/pub/scm/upstream-linus

* 'upstream' of git://ftp.linux-mips.org/pub/scm/upstream-linus:
  [MIPS] MIPS doesn't need compat_sys_getdents.
  [MIPS] JMR3927: Fixup another victim of the irq pt_regs cleanup.
  [MIPS] EMMA 2 / Markeins: struct resource takes physical addresses.
  [MIPS] EMMA 2 / Markeins: Convert to name struct resource initialization.
  [MIPS] EMMA 2 / Markeins: Formitting fixes split from actual address fixes.
  [MIPS] EMMA 2 / Markeins: Fix build wreckage due to genirq wreckage.
  [MIPS] Ocelot G: Fix build error and numerous warnings.
  [MIPS] Fix return value of TXX9 SPI interrupt handler
  [MIPS] Au1000: Fix warning about unused variable.
  [MIPS] Wire up getcpu(2) and epoll_wait(2) syscalls.
  [MIPS] Make SB1 cache flushes not to use on_each_cpu
  [MIPS] Fix warning about unused definition in c-sb1.c
  [MIPS] SMTC: Make 8 the default number of processors.
  [MIPS] Oprofile: Fix MIPSxx counter number detection.
  [MIPS] Au1xx0 code sets incorrect mips_hpt_frequency
  [MIPS] Oprofile: fix on non-VSMP / non-SMTC SMP configurations.
...@@ -408,7 +408,7 @@ config MOMENCO_OCELOT_C ...@@ -408,7 +408,7 @@ config MOMENCO_OCELOT_C
select SWAP_IO_SPACE select SWAP_IO_SPACE
select SYS_HAS_CPU_RM7000 select SYS_HAS_CPU_RM7000
select SYS_SUPPORTS_32BIT_KERNEL select SYS_SUPPORTS_32BIT_KERNEL
select SYS_SUPPORTS_64BIT_KERNEL select SYS_SUPPORTS_64BIT_KERNEL if BROKEN
select SYS_SUPPORTS_BIG_ENDIAN select SYS_SUPPORTS_BIG_ENDIAN
help help
The Ocelot is a MIPS-based Single Board Computer (SBC) made by The Ocelot is a MIPS-based Single Board Computer (SBC) made by
...@@ -1690,6 +1690,7 @@ config NR_CPUS ...@@ -1690,6 +1690,7 @@ config NR_CPUS
depends on SMP depends on SMP
default "64" if SGI_IP27 default "64" if SGI_IP27
default "2" default "2"
default "8" if MIPS_MT_SMTC
help help
This allows you to specify the maximum number of CPUs which this This allows you to specify the maximum number of CPUs which this
kernel will support. The maximum supported value is 32 for 32-bit kernel will support. The maximum supported value is 32 for 32-bit
......
...@@ -82,7 +82,6 @@ unsigned long wtimer; ...@@ -82,7 +82,6 @@ unsigned long wtimer;
void mips_timer_interrupt(void) void mips_timer_interrupt(void)
{ {
int irq = 63; int irq = 63;
unsigned long count;
irq_enter(); irq_enter();
kstat_this_cpu.irqs[irq]++; kstat_this_cpu.irqs[irq]++;
...@@ -231,7 +230,6 @@ wakeup_counter0_set(int ticks) ...@@ -231,7 +230,6 @@ wakeup_counter0_set(int ticks)
*/ */
unsigned long cal_r4koff(void) unsigned long cal_r4koff(void)
{ {
unsigned long count;
unsigned long cpu_speed; unsigned long cpu_speed;
unsigned long flags; unsigned long flags;
unsigned long counter; unsigned long counter;
...@@ -258,7 +256,7 @@ unsigned long cal_r4koff(void) ...@@ -258,7 +256,7 @@ unsigned long cal_r4koff(void)
#if defined(CONFIG_AU1000_USE32K) #if defined(CONFIG_AU1000_USE32K)
{ {
unsigned long start, end; unsigned long start, end, count;
start = au_readl(SYS_RTCREAD); start = au_readl(SYS_RTCREAD);
start += 2; start += 2;
...@@ -282,7 +280,6 @@ unsigned long cal_r4koff(void) ...@@ -282,7 +280,6 @@ unsigned long cal_r4koff(void)
#else #else
cpu_speed = (au_readl(SYS_CPUPLL) & 0x0000003f) * cpu_speed = (au_readl(SYS_CPUPLL) & 0x0000003f) *
AU1000_SRC_CLK; AU1000_SRC_CLK;
count = cpu_speed / 2;
#endif #endif
} }
else { else {
...@@ -291,10 +288,9 @@ unsigned long cal_r4koff(void) ...@@ -291,10 +288,9 @@ unsigned long cal_r4koff(void)
* NOTE: some old silicon doesn't allow reading the PLL. * NOTE: some old silicon doesn't allow reading the PLL.
*/ */
cpu_speed = (au_readl(SYS_CPUPLL) & 0x0000003f) * AU1000_SRC_CLK; cpu_speed = (au_readl(SYS_CPUPLL) & 0x0000003f) * AU1000_SRC_CLK;
count = cpu_speed / 2;
no_au1xxx_32khz = 1; no_au1xxx_32khz = 1;
} }
mips_hpt_frequency = count; mips_hpt_frequency = cpu_speed;
// Equation: Baudrate = CPU / (SD * 2 * CLKDIV * 16) // Equation: Baudrate = CPU / (SD * 2 * CLKDIV * 16)
set_au1x00_uart_baud_base(cpu_speed / (2 * ((int)(au_readl(SYS_POWERCTRL)&0x03) + 2) * 16)); set_au1x00_uart_baud_base(cpu_speed / (2 * ((int)(au_readl(SYS_POWERCTRL)&0x03) + 2) * 16));
spin_unlock_irqrestore(&time_lock, flags); spin_unlock_irqrestore(&time_lock, flags);
......
...@@ -97,7 +97,7 @@ void emma2rh_irq_init(u32 irq_base) ...@@ -97,7 +97,7 @@ void emma2rh_irq_init(u32 irq_base)
irq_desc[i].status = IRQ_DISABLED; irq_desc[i].status = IRQ_DISABLED;
irq_desc[i].action = NULL; irq_desc[i].action = NULL;
irq_desc[i].depth = 1; irq_desc[i].depth = 1;
irq_desc[i].handler = &emma2rh_irq_controller; irq_desc[i].chip = &emma2rh_irq_controller;
} }
emma2rh_irq_base = irq_base; emma2rh_irq_base = irq_base;
......
...@@ -86,7 +86,7 @@ void emma2rh_sw_irq_init(u32 irq_base) ...@@ -86,7 +86,7 @@ void emma2rh_sw_irq_init(u32 irq_base)
irq_desc[i].status = IRQ_DISABLED; irq_desc[i].status = IRQ_DISABLED;
irq_desc[i].action = NULL; irq_desc[i].action = NULL;
irq_desc[i].depth = 2; irq_desc[i].depth = 2;
irq_desc[i].handler = &emma2rh_sw_irq_controller; irq_desc[i].chip = &emma2rh_sw_irq_controller;
} }
emma2rh_sw_irq_base = irq_base; emma2rh_sw_irq_base = irq_base;
...@@ -166,7 +166,7 @@ void emma2rh_gpio_irq_init(u32 irq_base) ...@@ -166,7 +166,7 @@ void emma2rh_gpio_irq_init(u32 irq_base)
irq_desc[i].status = IRQ_DISABLED; irq_desc[i].status = IRQ_DISABLED;
irq_desc[i].action = NULL; irq_desc[i].action = NULL;
irq_desc[i].depth = 2; irq_desc[i].depth = 2;
irq_desc[i].handler = &emma2rh_gpio_irq_controller; irq_desc[i].chip = &emma2rh_gpio_irq_controller;
} }
emma2rh_gpio_irq_base = irq_base; emma2rh_gpio_irq_base = irq_base;
......
...@@ -44,18 +44,45 @@ ...@@ -44,18 +44,45 @@
#define I2C_EMMA2RH "emma2rh-iic" /* must be in sync with IIC driver */ #define I2C_EMMA2RH "emma2rh-iic" /* must be in sync with IIC driver */
static struct resource i2c_emma_resources_0[] = { static struct resource i2c_emma_resources_0[] = {
{ NULL, EMMA2RH_IRQ_PIIC0, EMMA2RH_IRQ_PIIC0, IORESOURCE_IRQ }, {
{ NULL, KSEG1ADDR(EMMA2RH_PIIC0_BASE), KSEG1ADDR(EMMA2RH_PIIC0_BASE + 0x1000), 0 }, .name = NULL,
.start = EMMA2RH_IRQ_PIIC0,
.end = EMMA2RH_IRQ_PIIC0,
.flags = IORESOURCE_IRQ
}, {
.name = NULL,
.start = EMMA2RH_PIIC0_BASE,
.end = EMMA2RH_PIIC0_BASE + 0x1000,
.flags = 0
},
}; };
struct resource i2c_emma_resources_1[] = { struct resource i2c_emma_resources_1[] = {
{ NULL, EMMA2RH_IRQ_PIIC1, EMMA2RH_IRQ_PIIC1, IORESOURCE_IRQ }, {
{ NULL, KSEG1ADDR(EMMA2RH_PIIC1_BASE), KSEG1ADDR(EMMA2RH_PIIC1_BASE + 0x1000), 0 }, .name = NULL,
.start = EMMA2RH_IRQ_PIIC1,
.end = EMMA2RH_IRQ_PIIC1,
.flags = IORESOURCE_IRQ
}, {
.name = NULL,
.start = EMMA2RH_PIIC1_BASE,
.end = EMMA2RH_PIIC1_BASE + 0x1000,
.flags = 0
},
}; };
struct resource i2c_emma_resources_2[] = { struct resource i2c_emma_resources_2[] = {
{ NULL, EMMA2RH_IRQ_PIIC2, EMMA2RH_IRQ_PIIC2, IORESOURCE_IRQ }, {
{ NULL, KSEG1ADDR(EMMA2RH_PIIC2_BASE), KSEG1ADDR(EMMA2RH_PIIC2_BASE + 0x1000), 0 }, .name = NULL,
.start = EMMA2RH_IRQ_PIIC2,
.end = EMMA2RH_IRQ_PIIC2,
.flags = IORESOURCE_IRQ
}, {
.name = NULL,
.start = EMMA2RH_PIIC2_BASE,
.end = EMMA2RH_PIIC2_BASE + 0x1000,
.flags = 0
},
}; };
struct platform_device i2c_emma_devices[] = { struct platform_device i2c_emma_devices[] = {
...@@ -83,32 +110,29 @@ struct platform_device i2c_emma_devices[] = { ...@@ -83,32 +110,29 @@ struct platform_device i2c_emma_devices[] = {
#define EMMA2RH_SERIAL_FLAGS UPF_BOOT_AUTOCONF | UPF_SKIP_TEST #define EMMA2RH_SERIAL_FLAGS UPF_BOOT_AUTOCONF | UPF_SKIP_TEST
static struct plat_serial8250_port platform_serial_ports[] = { static struct plat_serial8250_port platform_serial_ports[] = {
[0] = { [0] = {
.membase = (void __iomem*)KSEG1ADDR(EMMA2RH_PFUR0_BASE + 3), .membase= (void __iomem*)KSEG1ADDR(EMMA2RH_PFUR0_BASE + 3),
.irq = EMMA2RH_IRQ_PFUR0, .irq = EMMA2RH_IRQ_PFUR0,
.uartclk = EMMA2RH_SERIAL_CLOCK, .uartclk = EMMA2RH_SERIAL_CLOCK,
.regshift = 4, .regshift = 4,
.iotype = UPIO_MEM, .iotype = UPIO_MEM,
.flags = EMMA2RH_SERIAL_FLAGS, .flags = EMMA2RH_SERIAL_FLAGS,
}, }, [1] = {
[1] = { .membase = (void __iomem*)KSEG1ADDR(EMMA2RH_PFUR1_BASE + 3),
.membase = (void __iomem*)KSEG1ADDR(EMMA2RH_PFUR1_BASE + 3), .irq = EMMA2RH_IRQ_PFUR1,
.irq = EMMA2RH_IRQ_PFUR1, .uartclk = EMMA2RH_SERIAL_CLOCK,
.uartclk = EMMA2RH_SERIAL_CLOCK, .regshift = 4,
.regshift = 4, .iotype = UPIO_MEM,
.iotype = UPIO_MEM, .flags = EMMA2RH_SERIAL_FLAGS,
.flags = EMMA2RH_SERIAL_FLAGS, }, [2] = {
}, .membase = (void __iomem*)KSEG1ADDR(EMMA2RH_PFUR2_BASE + 3),
[2] = { .irq = EMMA2RH_IRQ_PFUR2,
.membase = (void __iomem*)KSEG1ADDR(EMMA2RH_PFUR2_BASE + 3), .uartclk = EMMA2RH_SERIAL_CLOCK,
.irq = EMMA2RH_IRQ_PFUR2, .regshift = 4,
.uartclk = EMMA2RH_SERIAL_CLOCK, .iotype = UPIO_MEM,
.regshift = 4, .flags = EMMA2RH_SERIAL_FLAGS,
.iotype = UPIO_MEM, }, [3] = {
.flags = EMMA2RH_SERIAL_FLAGS, .flags = 0,
},
[3] = {
.flags = 0,
}, },
}; };
......
...@@ -288,6 +288,8 @@ static void tx_branch_likely_bug_fixup(void) ...@@ -288,6 +288,8 @@ static void tx_branch_likely_bug_fixup(void)
static void jmr3927_spurious(void) static void jmr3927_spurious(void)
{ {
struct pt_regs * regs = get_irq_regs();
#ifdef CONFIG_TX_BRANCH_LIKELY_BUG_WORKAROUND #ifdef CONFIG_TX_BRANCH_LIKELY_BUG_WORKAROUND
tx_branch_likely_bug_fixup(); tx_branch_likely_bug_fixup();
#endif #endif
...@@ -297,6 +299,7 @@ static void jmr3927_spurious(void) ...@@ -297,6 +299,7 @@ static void jmr3927_spurious(void)
asmlinkage void plat_irq_dispatch(void) asmlinkage void plat_irq_dispatch(void)
{ {
struct pt_regs * regs = get_irq_regs();
int irq; int irq;
#ifdef CONFIG_TX_BRANCH_LIKELY_BUG_WORKAROUND #ifdef CONFIG_TX_BRANCH_LIKELY_BUG_WORKAROUND
......
...@@ -654,6 +654,8 @@ einval: li v0, -EINVAL ...@@ -654,6 +654,8 @@ einval: li v0, -EINVAL
sys sys_set_robust_list 2 sys sys_set_robust_list 2
sys sys_get_robust_list 3 /* 4310 */ sys sys_get_robust_list 3 /* 4310 */
sys sys_ni_syscall 0 sys sys_ni_syscall 0
sys sys_getcpu 3
sys sys_epoll_pwait 6
.endm .endm
/* We pre-compute the number of _instruction_ bytes needed to /* We pre-compute the number of _instruction_ bytes needed to
......
...@@ -469,3 +469,5 @@ sys_call_table: ...@@ -469,3 +469,5 @@ sys_call_table:
PTR sys_set_robust_list PTR sys_set_robust_list
PTR sys_get_robust_list PTR sys_get_robust_list
PTR sys_ni_syscall /* 5270 */ PTR sys_ni_syscall /* 5270 */
PTR sys_getcpu
PTR sys_epoll_pwait
...@@ -395,3 +395,5 @@ EXPORT(sysn32_call_table) ...@@ -395,3 +395,5 @@ EXPORT(sysn32_call_table)
PTR compat_sys_set_robust_list PTR compat_sys_set_robust_list
PTR compat_sys_get_robust_list PTR compat_sys_get_robust_list
PTR sys_ni_syscall PTR sys_ni_syscall
PTR sys_getcpu
PTR sys_epoll_pwait
...@@ -517,4 +517,6 @@ sys_call_table: ...@@ -517,4 +517,6 @@ sys_call_table:
PTR compat_sys_set_robust_list PTR compat_sys_set_robust_list
PTR compat_sys_get_robust_list /* 4310 */ PTR compat_sys_get_robust_list /* 4310 */
PTR sys_ni_syscall PTR sys_ni_syscall
PTR sys_getcpu
PTR sys_epoll_pwait
.size sys_call_table,.-sys_call_table .size sys_call_table,.-sys_call_table
...@@ -49,6 +49,15 @@ static unsigned short dcache_sets; ...@@ -49,6 +49,15 @@ static unsigned short dcache_sets;
static unsigned int icache_range_cutoff; static unsigned int icache_range_cutoff;
static unsigned int dcache_range_cutoff; static unsigned int dcache_range_cutoff;
static inline void sb1_on_each_cpu(void (*func) (void *info), void *info,
int retry, int wait)
{
preempt_disable();
smp_call_function(func, info, retry, wait);
func(info);
preempt_enable();
}
/* /*
* The dcache is fully coherent to the system, with one * The dcache is fully coherent to the system, with one
* big caveat: the instruction stream. In other words, * big caveat: the instruction stream. In other words,
...@@ -226,7 +235,7 @@ static void sb1_flush_cache_page(struct vm_area_struct *vma, unsigned long addr, ...@@ -226,7 +235,7 @@ static void sb1_flush_cache_page(struct vm_area_struct *vma, unsigned long addr,
args.vma = vma; args.vma = vma;
args.addr = addr; args.addr = addr;
args.pfn = pfn; args.pfn = pfn;
on_each_cpu(sb1_flush_cache_page_ipi, (void *) &args, 1, 1); sb1_on_each_cpu(sb1_flush_cache_page_ipi, (void *) &args, 1, 1);
} }
#else #else
void sb1_flush_cache_page(struct vm_area_struct *vma, unsigned long addr, unsigned long pfn) void sb1_flush_cache_page(struct vm_area_struct *vma, unsigned long addr, unsigned long pfn)
...@@ -249,7 +258,7 @@ void sb1___flush_cache_all_ipi(void *ignored) ...@@ -249,7 +258,7 @@ void sb1___flush_cache_all_ipi(void *ignored)
static void sb1___flush_cache_all(void) static void sb1___flush_cache_all(void)
{ {
on_each_cpu(sb1___flush_cache_all_ipi, 0, 1, 1); sb1_on_each_cpu(sb1___flush_cache_all_ipi, 0, 1, 1);
} }
#else #else
void sb1___flush_cache_all(void) void sb1___flush_cache_all(void)
...@@ -299,7 +308,7 @@ void sb1_flush_icache_range(unsigned long start, unsigned long end) ...@@ -299,7 +308,7 @@ void sb1_flush_icache_range(unsigned long start, unsigned long end)
args.start = start; args.start = start;
args.end = end; args.end = end;
on_each_cpu(sb1_flush_icache_range_ipi, &args, 1, 1); sb1_on_each_cpu(sb1_flush_icache_range_ipi, &args, 1, 1);
} }
#else #else
void sb1_flush_icache_range(unsigned long start, unsigned long end) void sb1_flush_icache_range(unsigned long start, unsigned long end)
...@@ -326,7 +335,7 @@ static void sb1_flush_cache_sigtramp_ipi(void *info) ...@@ -326,7 +335,7 @@ static void sb1_flush_cache_sigtramp_ipi(void *info)
static void sb1_flush_cache_sigtramp(unsigned long addr) static void sb1_flush_cache_sigtramp(unsigned long addr)
{ {
on_each_cpu(sb1_flush_cache_sigtramp_ipi, (void *) addr, 1, 1); sb1_on_each_cpu(sb1_flush_cache_sigtramp_ipi, (void *) addr, 1, 1);
} }
#else #else
void sb1_flush_cache_sigtramp(unsigned long addr) void sb1_flush_cache_sigtramp(unsigned long addr)
...@@ -444,7 +453,6 @@ static __init void probe_cache_sizes(void) ...@@ -444,7 +453,6 @@ static __init void probe_cache_sizes(void)
void sb1_cache_init(void) void sb1_cache_init(void)
{ {
extern char except_vec2_sb1; extern char except_vec2_sb1;
extern char handle_vec2_sb1;
/* Special cache error handler for SB1 */ /* Special cache error handler for SB1 */
set_uncached_handler (0x100, &except_vec2_sb1, 0x80); set_uncached_handler (0x100, &except_vec2_sb1, 0x80);
......
...@@ -23,8 +23,8 @@ ...@@ -23,8 +23,8 @@
#define OCELOT_REG_INTSET (12) #define OCELOT_REG_INTSET (12)
#define OCELOT_REG_INTCLR (13) #define OCELOT_REG_INTCLR (13)
#define OCELOT_PLD_WRITE(x, y) writeb(x, OCELOT_CS0_ADDR + OCELOT_REG_##y) #define __PLD_REG_TO_ADDR(reg) ((void *) OCELOT_CS0_ADDR + OCELOT_REG_##reg)
#define OCELOT_PLD_READ(x) readb(OCELOT_CS0_ADDR + OCELOT_REG_##x) #define OCELOT_PLD_WRITE(x, reg) writeb(x, __PLD_REG_TO_ADDR(reg))
#define OCELOT_PLD_READ(reg) readb(__PLD_REG_TO_ADDR(reg))
#endif /* __MOMENCO_OCELOT_PLD_H__ */ #endif /* __MOMENCO_OCELOT_PLD_H__ */
...@@ -57,6 +57,7 @@ ...@@ -57,6 +57,7 @@
#include <asm/gt64240.h> #include <asm/gt64240.h>
#include <asm/irq.h> #include <asm/irq.h>
#include <asm/pci.h> #include <asm/pci.h>
#include <asm/pgtable.h>
#include <asm/processor.h> #include <asm/processor.h>
#include <asm/reboot.h> #include <asm/reboot.h>
#include <linux/bootmem.h> #include <linux/bootmem.h>
...@@ -160,6 +161,10 @@ static void __init setup_l3cache(unsigned long size) ...@@ -160,6 +161,10 @@ static void __init setup_l3cache(unsigned long size)
printk("Done\n"); printk("Done\n");
} }
void __init plat_timer_setup(struct irqaction *irq)
{
}
void __init plat_mem_setup(void) void __init plat_mem_setup(void)
{ {
void (*l3func)(unsigned long) = (void *) KSEG1ADDR(setup_l3cache); void (*l3func)(unsigned long) = (void *) KSEG1ADDR(setup_l3cache);
......
...@@ -31,16 +31,18 @@ ...@@ -31,16 +31,18 @@
#define M_COUNTER_OVERFLOW (1UL << 31) #define M_COUNTER_OVERFLOW (1UL << 31)
#ifdef CONFIG_MIPS_MT_SMP #ifdef CONFIG_MIPS_MT_SMP
#define WHAT (M_TC_EN_VPE | M_PERFCTL_VPEID(smp_processor_id())) #define WHAT (M_TC_EN_VPE | M_PERFCTL_VPEID(smp_processor_id()))
#define vpe_id() smp_processor_id()
#else #else
#define WHAT 0 #define WHAT 0
#define vpe_id() smp_processor_id()
#endif #endif
#define __define_perf_accessors(r, n, np) \ #define __define_perf_accessors(r, n, np) \
\ \
static inline unsigned int r_c0_ ## r ## n(void) \ static inline unsigned int r_c0_ ## r ## n(void) \
{ \ { \
unsigned int cpu = smp_processor_id(); \ unsigned int cpu = vpe_id(); \
\ \
switch (cpu) { \ switch (cpu) { \
case 0: \ case 0: \
...@@ -55,7 +57,7 @@ static inline unsigned int r_c0_ ## r ## n(void) \ ...@@ -55,7 +57,7 @@ static inline unsigned int r_c0_ ## r ## n(void) \
\ \
static inline void w_c0_ ## r ## n(unsigned int value) \ static inline void w_c0_ ## r ## n(unsigned int value) \
{ \ { \
unsigned int cpu = smp_processor_id(); \ unsigned int cpu = vpe_id(); \
\ \
switch (cpu) { \ switch (cpu) { \
case 0: \ case 0: \
...@@ -218,7 +220,7 @@ static inline int n_counters(void) ...@@ -218,7 +220,7 @@ static inline int n_counters(void)
{ {
int counters = __n_counters(); int counters = __n_counters();
#ifndef CONFIG_SMP #ifdef CONFIG_MIPS_MT_SMP
if (current_cpu_data.cputype == CPU_34K) if (current_cpu_data.cputype == CPU_34K)
return counters >> 1; return counters >> 1;
#endif #endif
......
...@@ -36,14 +36,18 @@ void __init txx9_spi_init(unsigned long base, int (*cs_func)(int chipid, int on) ...@@ -36,14 +36,18 @@ void __init txx9_spi_init(unsigned long base, int (*cs_func)(int chipid, int on)
static DECLARE_WAIT_QUEUE_HEAD(txx9_spi_wait); static DECLARE_WAIT_QUEUE_HEAD(txx9_spi_wait);
static void txx9_spi_interrupt(int irq, void *dev_id) static irqreturn_t txx9_spi_interrupt(int irq, void *dev_id)
{ {
/* disable rx intr */ /* disable rx intr */
tx4938_spiptr->cr0 &= ~TXx9_SPCR0_RBSIE; tx4938_spiptr->cr0 &= ~TXx9_SPCR0_RBSIE;
wake_up(&txx9_spi_wait); wake_up(&txx9_spi_wait);
return IRQ_HANDLED;
} }
static struct irqaction txx9_spi_action = { static struct irqaction txx9_spi_action = {
txx9_spi_interrupt, 0, 0, "spi", NULL, NULL, .handler = txx9_spi_interrupt,
.name = "spi",
}; };
void __init txx9_spi_irqinit(int irc_irq) void __init txx9_spi_irqinit(int irc_irq)
......
...@@ -332,16 +332,18 @@ ...@@ -332,16 +332,18 @@
#define __NR_set_robust_list (__NR_Linux + 309) #define __NR_set_robust_list (__NR_Linux + 309)
#define __NR_get_robust_list (__NR_Linux + 310) #define __NR_get_robust_list (__NR_Linux + 310)
#define __NR_kexec_load (__NR_Linux + 311) #define __NR_kexec_load (__NR_Linux + 311)
#define __NR_getcpu (__NR_Linux + 312)
#define __NR_epoll_pwait (__NR_Linux + 313)
/* /*
* Offset of the last Linux o32 flavoured syscall * Offset of the last Linux o32 flavoured syscall
*/ */
#define __NR_Linux_syscalls 311 #define __NR_Linux_syscalls 313
#endif /* _MIPS_SIM == _MIPS_SIM_ABI32 */ #endif /* _MIPS_SIM == _MIPS_SIM_ABI32 */
#define __NR_O32_Linux 4000 #define __NR_O32_Linux 4000
#define __NR_O32_Linux_syscalls 311 #define __NR_O32_Linux_syscalls 313
#if _MIPS_SIM == _MIPS_SIM_ABI64 #if _MIPS_SIM == _MIPS_SIM_ABI64
...@@ -620,16 +622,18 @@ ...@@ -620,16 +622,18 @@
#define __NR_set_robust_list (__NR_Linux + 268) #define __NR_set_robust_list (__NR_Linux + 268)
#define __NR_get_robust_list (__NR_Linux + 269) #define __NR_get_robust_list (__NR_Linux + 269)
#define __NR_kexec_load (__NR_Linux + 270) #define __NR_kexec_load (__NR_Linux + 270)
#define __NR_getcpu (__NR_Linux + 271)
#define __NR_epoll_pwait (__NR_Linux + 272)
/* /*
* Offset of the last Linux 64-bit flavoured syscall * Offset of the last Linux 64-bit flavoured syscall
*/ */
#define __NR_Linux_syscalls 270 #define __NR_Linux_syscalls 272
#endif /* _MIPS_SIM == _MIPS_SIM_ABI64 */ #endif /* _MIPS_SIM == _MIPS_SIM_ABI64 */
#define __NR_64_Linux 5000 #define __NR_64_Linux 5000
#define __NR_64_Linux_syscalls 270 #define __NR_64_Linux_syscalls 272
#if _MIPS_SIM == _MIPS_SIM_NABI32 #if _MIPS_SIM == _MIPS_SIM_NABI32
...@@ -912,16 +916,18 @@ ...@@ -912,16 +916,18 @@
#define __NR_set_robust_list (__NR_Linux + 272) #define __NR_set_robust_list (__NR_Linux + 272)
#define __NR_get_robust_list (__NR_Linux + 273) #define __NR_get_robust_list (__NR_Linux + 273)
#define __NR_kexec_load (__NR_Linux + 274) #define __NR_kexec_load (__NR_Linux + 274)
#define __NR_getcpu (__NR_Linux + 275)
#define __NR_epoll_pwait (__NR_Linux + 276)
/* /*
* Offset of the last N32 flavoured syscall * Offset of the last N32 flavoured syscall
*/ */
#define __NR_Linux_syscalls 274 #define __NR_Linux_syscalls 276
#endif /* _MIPS_SIM == _MIPS_SIM_NABI32 */ #endif /* _MIPS_SIM == _MIPS_SIM_NABI32 */
#define __NR_N32_Linux 6000 #define __NR_N32_Linux 6000
#define __NR_N32_Linux_syscalls 274 #define __NR_N32_Linux_syscalls 276
#ifdef __KERNEL__ #ifdef __KERNEL__
...@@ -1189,6 +1195,7 @@ type name (atype a,btype b,ctype c,dtype d,etype e,ftype f) \ ...@@ -1189,6 +1195,7 @@ type name (atype a,btype b,ctype c,dtype d,etype e,ftype f) \
#endif /* (_MIPS_SIM == _MIPS_SIM_NABI32) || (_MIPS_SIM == _MIPS_SIM_ABI64) */ #endif /* (_MIPS_SIM == _MIPS_SIM_NABI32) || (_MIPS_SIM == _MIPS_SIM_ABI64) */
#define __ARCH_OMIT_COMPAT_SYS_GETDENTS64
#define __ARCH_WANT_IPC_PARSE_VERSION #define __ARCH_WANT_IPC_PARSE_VERSION
#define __ARCH_WANT_OLD_READDIR #define __ARCH_WANT_OLD_READDIR
#define __ARCH_WANT_SYS_ALARM #define __ARCH_WANT_SYS_ALARM
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册