Merge git://git.kernel.org/pub/scm/linux/kernel/git/davem/sparc-next-2.6

* git://git.kernel.org/pub/scm/linux/kernel/git/davem/sparc-next-2.6:
  sparc: Support show_unhandled_signals.
  sparc: use __ratelimit
  sunxvr500: Additional PCI id for sunxvr500 driver
  sparc: use asm-generic/scatterlist.h
  sparc64: If 'slot-names' property exist, create sysfs PCI slot information.
  sparc: remove trailing space in messages
  sparc: remove redundant return statements
This commit is contained in:
Linus Torvalds 2010-03-02 07:56:44 -08:00
commit b7f3a209e9
23 changed files with 176 additions and 100 deletions

View File

@ -1,27 +1,8 @@
#ifndef _SPARC_SCATTERLIST_H #ifndef _SPARC_SCATTERLIST_H
#define _SPARC_SCATTERLIST_H #define _SPARC_SCATTERLIST_H
#include <asm/page.h>
#include <asm/types.h>
struct scatterlist {
#ifdef CONFIG_DEBUG_SG
unsigned long sg_magic;
#endif
unsigned long page_link;
unsigned int offset;
unsigned int length;
dma_addr_t dma_address;
__u32 dma_length;
};
#define sg_dma_address(sg) ((sg)->dma_address)
#define sg_dma_len(sg) ((sg)->dma_length) #define sg_dma_len(sg) ((sg)->dma_length)
#define ISA_DMA_THRESHOLD (~0UL) #include <asm-generic/scatterlist.h>
#define ARCH_HAS_SG_CHAIN
#endif /* !(_SPARC_SCATTERLIST_H) */ #endif /* !(_SPARC_SCATTERLIST_H) */

View File

@ -143,6 +143,4 @@ void __init device_scan(void)
if (ARCH_SUN4C) if (ARCH_SUN4C)
sun4c_probe_memerr_reg(); sun4c_probe_memerr_reg();
return;
} }

View File

@ -124,7 +124,7 @@ void __init leon_init_timers(irq_handler_t counter_fn)
if (!(LEON3_BYPASS_LOAD_PA(&leon3_gptimer_regs->config) & if (!(LEON3_BYPASS_LOAD_PA(&leon3_gptimer_regs->config) &
(1<<LEON3_GPTIMER_SEPIRQ))) { (1<<LEON3_GPTIMER_SEPIRQ))) {
prom_printf("irq timer not configured with seperate irqs \n"); prom_printf("irq timer not configured with separate irqs\n");
BUG(); BUG();
} }

View File

@ -177,7 +177,7 @@ void __init leon_boot_cpus(void)
int nrcpu = leon_smp_nrcpus(); int nrcpu = leon_smp_nrcpus();
int me = smp_processor_id(); int me = smp_processor_id();
printk(KERN_INFO "%d:(%d:%d) cpus mpirq at 0x%x \n", (unsigned int)me, printk(KERN_INFO "%d:(%d:%d) cpus mpirq at 0x%x\n", (unsigned int)me,
(unsigned int)nrcpu, (unsigned int)NR_CPUS, (unsigned int)nrcpu, (unsigned int)NR_CPUS,
(unsigned int)&(leon3_irqctrl_regs->mpstatus)); (unsigned int)&(leon3_irqctrl_regs->mpstatus));
@ -226,7 +226,7 @@ int __cpuinit leon_boot_one_cpu(int i)
break; break;
udelay(200); udelay(200);
} }
printk(KERN_INFO "Started CPU %d \n", (unsigned int)i); printk(KERN_INFO "Started CPU %d\n", (unsigned int)i);
if (!(cpu_callin_map[i])) { if (!(cpu_callin_map[i])) {
printk(KERN_ERR "Processor %d is stuck.\n", i); printk(KERN_ERR "Processor %d is stuck.\n", i);

View File

@ -1095,3 +1095,78 @@ static int __init pcibios_init(void)
return 0; return 0;
} }
subsys_initcall(pcibios_init); subsys_initcall(pcibios_init);
#ifdef CONFIG_SYSFS
static void __devinit pci_bus_slot_names(struct device_node *node,
struct pci_bus *bus)
{
const struct pci_slot_names {
u32 slot_mask;
char names[0];
} *prop;
const char *sp;
int len, i;
u32 mask;
prop = of_get_property(node, "slot-names", &len);
if (!prop)
return;
mask = prop->slot_mask;
sp = prop->names;
if (ofpci_verbose)
printk("PCI: Making slots for [%s] mask[0x%02x]\n",
node->full_name, mask);
i = 0;
while (mask) {
struct pci_slot *pci_slot;
u32 this_bit = 1 << i;
if (!(mask & this_bit)) {
i++;
continue;
}
if (ofpci_verbose)
printk("PCI: Making slot [%s]\n", sp);
pci_slot = pci_create_slot(bus, i, sp, NULL);
if (IS_ERR(pci_slot))
printk(KERN_ERR "PCI: pci_create_slot returned %ld\n",
PTR_ERR(pci_slot));
sp += strlen(sp) + 1;
mask &= ~this_bit;
i++;
}
}
static int __init of_pci_slot_init(void)
{
struct pci_bus *pbus = NULL;
while ((pbus = pci_find_next_bus(pbus)) != NULL) {
struct device_node *node;
if (pbus->self) {
struct dev_archdata *sd = pbus->self->sysdata;
/* PCI->PCI bridge */
node = sd->prom_node;
} else {
struct pci_pbm_info *pbm = pbus->sysdata;
/* Host PCI controller */
node = pbm->op->node;
}
pci_bus_slot_names(node, pbus);
}
return 0;
}
module_init(of_pci_slot_init);
#endif

View File

@ -585,8 +585,6 @@ pcic_fill_irq(struct linux_pcic *pcic, struct pci_dev *dev, int node)
writew(ivec, pcic->pcic_regs+PCI_INT_SELECT_LO); writew(ivec, pcic->pcic_regs+PCI_INT_SELECT_LO);
} }
} }
return;
} }
/* /*

View File

@ -95,8 +95,6 @@ static void prom_sync_me(void)
"nop\n\t" "nop\n\t"
"nop\n\t" : : "r" (prom_tbr)); "nop\n\t" : : "r" (prom_tbr));
local_irq_restore(flags); local_irq_restore(flags);
return;
} }
static unsigned int boot_flags __initdata = 0; static unsigned int boot_flags __initdata = 0;

View File

@ -194,7 +194,7 @@ int __cpuinit smp4d_boot_one_cpu(int i)
smp_penguin_ctable.reg_size = 0; smp_penguin_ctable.reg_size = 0;
/* whirrr, whirrr, whirrrrrrrrr... */ /* whirrr, whirrr, whirrrrrrrrr... */
SMP_PRINTK(("Starting CPU %d at %p \n", i, entry)); SMP_PRINTK(("Starting CPU %d at %p\n", i, entry));
local_flush_cache_all(); local_flush_cache_all();
prom_startcpu(cpu_node, prom_startcpu(cpu_node,
&smp_penguin_ctable, 0, (char *)entry); &smp_penguin_ctable, 0, (char *)entry);

View File

@ -21,6 +21,7 @@
#include <linux/smp.h> #include <linux/smp.h>
#include <linux/bitops.h> #include <linux/bitops.h>
#include <linux/perf_event.h> #include <linux/perf_event.h>
#include <linux/ratelimit.h>
#include <asm/fpumacro.h> #include <asm/fpumacro.h>
enum direction { enum direction {
@ -274,13 +275,9 @@ static void kernel_mna_trap_fault(int fixup_tstate_asi)
static void log_unaligned(struct pt_regs *regs) static void log_unaligned(struct pt_regs *regs)
{ {
static unsigned long count, last_time; static DEFINE_RATELIMIT_STATE(ratelimit, 5 * HZ, 5);
if (time_after(jiffies, last_time + 5 * HZ)) if (__ratelimit(&ratelimit)) {
count = 0;
if (count < 5) {
last_time = jiffies;
count++;
printk("Kernel unaligned access at TPC[%lx] %pS\n", printk("Kernel unaligned access at TPC[%lx] %pS\n",
regs->tpc, (void *) regs->tpc); regs->tpc, (void *) regs->tpc);
} }
@ -636,7 +633,6 @@ daex:
return; return;
} }
advance(regs); advance(regs);
return;
} }
void handle_stdfmna(struct pt_regs *regs, unsigned long sfar, unsigned long sfsr) void handle_stdfmna(struct pt_regs *regs, unsigned long sfar, unsigned long sfsr)
@ -685,5 +681,4 @@ daex:
return; return;
} }
advance(regs); advance(regs);
return;
} }

View File

@ -35,6 +35,8 @@
extern int prom_node_root; extern int prom_node_root;
int show_unhandled_signals = 1;
/* At boot time we determine these two values necessary for setting /* At boot time we determine these two values necessary for setting
* up the segment maps and page table entries (pte's). * up the segment maps and page table entries (pte's).
*/ */
@ -149,6 +151,45 @@ asmlinkage int lookup_fault(unsigned long pc, unsigned long ret_pc,
return 0; return 0;
} }
static inline void
show_signal_msg(struct pt_regs *regs, int sig, int code,
unsigned long address, struct task_struct *tsk)
{
if (!unhandled_signal(tsk, sig))
return;
if (!printk_ratelimit())
return;
printk("%s%s[%d]: segfault at %lx ip %p (rpc %p) sp %p error %x",
task_pid_nr(tsk) > 1 ? KERN_INFO : KERN_EMERG,
tsk->comm, task_pid_nr(tsk), address,
(void *)regs->pc, (void *)regs->u_regs[UREG_I7],
(void *)regs->u_regs[UREG_FP], code);
print_vma_addr(KERN_CONT " in ", regs->pc);
printk(KERN_CONT "\n");
}
static void __do_fault_siginfo(int code, int sig, struct pt_regs *regs,
unsigned long addr)
{
siginfo_t info;
info.si_signo = sig;
info.si_code = code;
info.si_errno = 0;
info.si_addr = (void __user *) addr;
info.si_trapno = 0;
if (unlikely(show_unhandled_signals))
show_signal_msg(regs, sig, info.si_code,
addr, current);
force_sig_info (sig, &info, current);
}
extern unsigned long safe_compute_effective_address(struct pt_regs *, extern unsigned long safe_compute_effective_address(struct pt_regs *,
unsigned int); unsigned int);
@ -168,6 +209,14 @@ static unsigned long compute_si_addr(struct pt_regs *regs, int text_fault)
return safe_compute_effective_address(regs, insn); return safe_compute_effective_address(regs, insn);
} }
static noinline void do_fault_siginfo(int code, int sig, struct pt_regs *regs,
int text_fault)
{
unsigned long addr = compute_si_addr(regs, text_fault);
__do_fault_siginfo(code, sig, regs, addr);
}
asmlinkage void do_sparc_fault(struct pt_regs *regs, int text_fault, int write, asmlinkage void do_sparc_fault(struct pt_regs *regs, int text_fault, int write,
unsigned long address) unsigned long address)
{ {
@ -176,9 +225,8 @@ asmlinkage void do_sparc_fault(struct pt_regs *regs, int text_fault, int write,
struct mm_struct *mm = tsk->mm; struct mm_struct *mm = tsk->mm;
unsigned int fixup; unsigned int fixup;
unsigned long g2; unsigned long g2;
siginfo_t info;
int from_user = !(regs->psr & PSR_PS); int from_user = !(regs->psr & PSR_PS);
int fault; int fault, code;
if(text_fault) if(text_fault)
address = regs->pc; address = regs->pc;
@ -195,7 +243,7 @@ asmlinkage void do_sparc_fault(struct pt_regs *regs, int text_fault, int write,
if (!ARCH_SUN4C && address >= TASK_SIZE) if (!ARCH_SUN4C && address >= TASK_SIZE)
goto vmalloc_fault; goto vmalloc_fault;
info.si_code = SEGV_MAPERR; code = SEGV_MAPERR;
/* /*
* If we're in an interrupt or have no user * If we're in an interrupt or have no user
@ -229,7 +277,7 @@ asmlinkage void do_sparc_fault(struct pt_regs *regs, int text_fault, int write,
* we can handle it.. * we can handle it..
*/ */
good_area: good_area:
info.si_code = SEGV_ACCERR; code = SEGV_ACCERR;
if(write) { if(write) {
if(!(vma->vm_flags & VM_WRITE)) if(!(vma->vm_flags & VM_WRITE))
goto bad_area; goto bad_area;
@ -273,18 +321,8 @@ bad_area:
bad_area_nosemaphore: bad_area_nosemaphore:
/* User mode accesses just cause a SIGSEGV */ /* User mode accesses just cause a SIGSEGV */
if(from_user) { if (from_user) {
#if 0 do_fault_siginfo(code, SIGSEGV, regs, text_fault);
printk("Fault whee %s [%d]: segfaults at %08lx pc=%08lx\n",
tsk->comm, tsk->pid, address, regs->pc);
#endif
info.si_signo = SIGSEGV;
info.si_errno = 0;
/* info.si_code set above to make clear whether
this was a SEGV_MAPERR or SEGV_ACCERR fault. */
info.si_addr = (void __user *)compute_si_addr(regs, text_fault);
info.si_trapno = 0;
force_sig_info (SIGSEGV, &info, tsk);
return; return;
} }
@ -335,12 +373,7 @@ out_of_memory:
do_sigbus: do_sigbus:
up_read(&mm->mmap_sem); up_read(&mm->mmap_sem);
info.si_signo = SIGBUS; do_fault_siginfo(BUS_ADRERR, SIGBUS, regs, text_fault);
info.si_errno = 0;
info.si_code = BUS_ADRERR;
info.si_addr = (void __user *) compute_si_addr(regs, text_fault);
info.si_trapno = 0;
force_sig_info (SIGBUS, &info, tsk);
if (!from_user) if (!from_user)
goto no_context; goto no_context;
@ -466,14 +499,10 @@ static void force_user_fault(unsigned long address, int write)
struct vm_area_struct *vma; struct vm_area_struct *vma;
struct task_struct *tsk = current; struct task_struct *tsk = current;
struct mm_struct *mm = tsk->mm; struct mm_struct *mm = tsk->mm;
siginfo_t info; int code;
info.si_code = SEGV_MAPERR; code = SEGV_MAPERR;
#if 0
printk("wf<pid=%d,wr=%d,addr=%08lx>\n",
tsk->pid, write, address);
#endif
down_read(&mm->mmap_sem); down_read(&mm->mmap_sem);
vma = find_vma(mm, address); vma = find_vma(mm, address);
if(!vma) if(!vma)
@ -485,7 +514,7 @@ static void force_user_fault(unsigned long address, int write)
if(expand_stack(vma, address)) if(expand_stack(vma, address))
goto bad_area; goto bad_area;
good_area: good_area:
info.si_code = SEGV_ACCERR; code = SEGV_ACCERR;
if(write) { if(write) {
if(!(vma->vm_flags & VM_WRITE)) if(!(vma->vm_flags & VM_WRITE))
goto bad_area; goto bad_area;
@ -502,27 +531,12 @@ good_area:
return; return;
bad_area: bad_area:
up_read(&mm->mmap_sem); up_read(&mm->mmap_sem);
#if 0 __do_fault_siginfo(code, SIGSEGV, tsk->thread.kregs, address);
printk("Window whee %s [%d]: segfaults at %08lx\n",
tsk->comm, tsk->pid, address);
#endif
info.si_signo = SIGSEGV;
info.si_errno = 0;
/* info.si_code set above to make clear whether
this was a SEGV_MAPERR or SEGV_ACCERR fault. */
info.si_addr = (void __user *) address;
info.si_trapno = 0;
force_sig_info (SIGSEGV, &info, tsk);
return; return;
do_sigbus: do_sigbus:
up_read(&mm->mmap_sem); up_read(&mm->mmap_sem);
info.si_signo = SIGBUS; __do_fault_siginfo(BUS_ADRERR, SIGBUS, tsk->thread.kregs, address);
info.si_errno = 0;
info.si_code = BUS_ADRERR;
info.si_addr = (void __user *) address;
info.si_trapno = 0;
force_sig_info (SIGBUS, &info, tsk);
} }
void window_overflow_fault(void) void window_overflow_fault(void)

View File

@ -32,6 +32,8 @@
#include <asm/sections.h> #include <asm/sections.h>
#include <asm/mmu_context.h> #include <asm/mmu_context.h>
int show_unhandled_signals = 1;
static inline __kprobes int notify_page_fault(struct pt_regs *regs) static inline __kprobes int notify_page_fault(struct pt_regs *regs)
{ {
int ret = 0; int ret = 0;
@ -128,22 +130,48 @@ outret:
return insn; return insn;
} }
static inline void
show_signal_msg(struct pt_regs *regs, int sig, int code,
unsigned long address, struct task_struct *tsk)
{
if (!unhandled_signal(tsk, sig))
return;
if (!printk_ratelimit())
return;
printk("%s%s[%d]: segfault at %lx ip %p (rpc %p) sp %p error %x",
task_pid_nr(tsk) > 1 ? KERN_INFO : KERN_EMERG,
tsk->comm, task_pid_nr(tsk), address,
(void *)regs->tpc, (void *)regs->u_regs[UREG_I7],
(void *)regs->u_regs[UREG_FP], code);
print_vma_addr(KERN_CONT " in ", regs->tpc);
printk(KERN_CONT "\n");
}
extern unsigned long compute_effective_address(struct pt_regs *, unsigned int, unsigned int); extern unsigned long compute_effective_address(struct pt_regs *, unsigned int, unsigned int);
static void do_fault_siginfo(int code, int sig, struct pt_regs *regs, static void do_fault_siginfo(int code, int sig, struct pt_regs *regs,
unsigned int insn, int fault_code) unsigned int insn, int fault_code)
{ {
unsigned long addr;
siginfo_t info; siginfo_t info;
info.si_code = code; info.si_code = code;
info.si_signo = sig; info.si_signo = sig;
info.si_errno = 0; info.si_errno = 0;
if (fault_code & FAULT_CODE_ITLB) if (fault_code & FAULT_CODE_ITLB)
info.si_addr = (void __user *) regs->tpc; addr = regs->tpc;
else else
info.si_addr = (void __user *) addr = compute_effective_address(regs, insn, 0);
compute_effective_address(regs, insn, 0); info.si_addr = (void __user *) addr;
info.si_trapno = 0; info.si_trapno = 0;
if (unlikely(show_unhandled_signals))
show_signal_msg(regs, sig, code, addr, current);
force_sig_info(sig, &info, current); force_sig_info(sig, &info, current);
} }

View File

@ -94,5 +94,4 @@ void
prom_putchar(char c) prom_putchar(char c)
{ {
while(prom_nbputchar(c) == -1) ; while(prom_nbputchar(c) == -1) ;
return;
} }

View File

@ -62,7 +62,6 @@ void
prom_putchar(char c) prom_putchar(char c)
{ {
prom_nbputchar(c); prom_nbputchar(c);
return;
} }
void void

View File

@ -50,5 +50,4 @@ prom_unmapio(char *vaddr, unsigned int num_bytes)
(*(romvec->pv_v2devops.v2_dumb_munmap))(vaddr, num_bytes); (*(romvec->pv_v2devops.v2_dumb_munmap))(vaddr, num_bytes);
restore_current(); restore_current();
spin_unlock_irqrestore(&prom_lock, flags); spin_unlock_irqrestore(&prom_lock, flags);
return;
} }

View File

@ -84,6 +84,4 @@ prom_seek(int dhandle, unsigned int seekhi, unsigned int seeklo)
}; };
restore_current(); restore_current();
spin_unlock_irqrestore(&prom_lock, flags); spin_unlock_irqrestore(&prom_lock, flags);
return;
} }

View File

@ -75,5 +75,4 @@ void __init prom_init(struct linux_romvec *rp)
romvec->pv_romvers, prom_rev); romvec->pv_romvers, prom_rev);
/* Initialization successful. */ /* Initialization successful. */
return;
} }

View File

@ -40,5 +40,4 @@ prom_free(char *vaddr, unsigned int num_bytes)
{ {
if((prom_vers == PROM_V0) || (num_bytes == 0x0)) return; if((prom_vers == PROM_V0) || (num_bytes == 0x0)) return;
(*(romvec->pv_v2devops.v2_dumb_mem_free))(vaddr, num_bytes); (*(romvec->pv_v2devops.v2_dumb_mem_free))(vaddr, num_bytes);
return;
} }

View File

@ -87,8 +87,6 @@ void __init prom_ranges_init(void)
if(num_obio_ranges) if(num_obio_ranges)
prom_printf("PROMLIB: obio_ranges %d\n", num_obio_ranges); prom_printf("PROMLIB: obio_ranges %d\n", num_obio_ranges);
return;
} }
void void

View File

@ -25,5 +25,4 @@ prom_putsegment(int ctx, unsigned long vaddr, int segment)
(*(romvec->pv_setctxt))(ctx, (char *) vaddr, segment); (*(romvec->pv_setctxt))(ctx, (char *) vaddr, segment);
restore_current(); restore_current();
spin_unlock_irqrestore(&prom_lock, flags); spin_unlock_irqrestore(&prom_lock, flags);
return;
} }

View File

@ -173,7 +173,6 @@ void prom_getstring(int node, char *prop, char *user_buf, int ubuf_size)
len = prom_getproperty(node, prop, user_buf, ubuf_size); len = prom_getproperty(node, prop, user_buf, ubuf_size);
if(len != -1) return; if(len != -1) return;
user_buf[0] = 0; user_buf[0] = 0;
return;
} }
EXPORT_SYMBOL(prom_getstring); EXPORT_SYMBOL(prom_getstring);

View File

@ -154,7 +154,6 @@ void prom_getstring(int node, const char *prop, char *user_buf, int ubuf_size)
len = prom_getproperty(node, prop, user_buf, ubuf_size); len = prom_getproperty(node, prop, user_buf, ubuf_size);
if(len != -1) return; if(len != -1) return;
user_buf[0] = 0; user_buf[0] = 0;
return;
} }
EXPORT_SYMBOL(prom_getstring); EXPORT_SYMBOL(prom_getstring);

View File

@ -400,6 +400,7 @@ static void __devexit e3d_pci_unregister(struct pci_dev *pdev)
static struct pci_device_id e3d_pci_table[] = { static struct pci_device_id e3d_pci_table[] = {
{ PCI_DEVICE(PCI_VENDOR_ID_3DLABS, 0x7a0), }, { PCI_DEVICE(PCI_VENDOR_ID_3DLABS, 0x7a0), },
{ PCI_DEVICE(0x1091, 0x7a0), },
{ PCI_DEVICE(PCI_VENDOR_ID_3DLABS, 0x7a2), }, { PCI_DEVICE(PCI_VENDOR_ID_3DLABS, 0x7a2), },
{ .vendor = PCI_VENDOR_ID_3DLABS, { .vendor = PCI_VENDOR_ID_3DLABS,
.device = PCI_ANY_ID, .device = PCI_ANY_ID,

View File

@ -1441,7 +1441,7 @@ static struct ctl_table fs_table[] = {
}; };
static struct ctl_table debug_table[] = { static struct ctl_table debug_table[] = {
#if defined(CONFIG_X86) || defined(CONFIG_PPC) #if defined(CONFIG_X86) || defined(CONFIG_PPC) || defined(CONFIG_SPARC)
{ {
.procname = "exception-trace", .procname = "exception-trace",
.data = &show_unhandled_signals, .data = &show_unhandled_signals,