s390/traps: print interrupt code and instruction length code
It always confuses me to see the mixed instruction length code and interruption code on user space faults, while the message clearly says it is the interruption code. So split the value and print both values separately. Also add the ILC output to the die() message, so thar user and kernel space faults contain the same information. Signed-off-by: Heiko Carstens <heiko.carstens@de.ibm.com> Signed-off-by: Martin Schwidefsky <schwidefsky@de.ibm.com>
This commit is contained in:
Родитель
4eafad7feb
Коммит
413d404768
|
@ -191,7 +191,8 @@ void die(struct pt_regs *regs, const char *str)
|
||||||
console_verbose();
|
console_verbose();
|
||||||
spin_lock_irq(&die_lock);
|
spin_lock_irq(&die_lock);
|
||||||
bust_spinlocks(1);
|
bust_spinlocks(1);
|
||||||
printk("%s: %04x [#%d] ", str, regs->int_code & 0xffff, ++die_counter);
|
printk("%s: %04x ilc:%d [#%d] ", str, regs->int_code & 0xffff,
|
||||||
|
regs->int_code >> 17, ++die_counter);
|
||||||
#ifdef CONFIG_PREEMPT
|
#ifdef CONFIG_PREEMPT
|
||||||
printk("PREEMPT ");
|
printk("PREEMPT ");
|
||||||
#endif
|
#endif
|
||||||
|
|
|
@ -49,7 +49,8 @@ static inline void report_user_fault(struct pt_regs *regs, int signr)
|
||||||
return;
|
return;
|
||||||
if (!printk_ratelimit())
|
if (!printk_ratelimit())
|
||||||
return;
|
return;
|
||||||
printk("User process fault: interruption code 0x%X ", regs->int_code);
|
printk("User process fault: interruption code %04x ilc:%d ",
|
||||||
|
regs->int_code & 0xffff, regs->int_code >> 17);
|
||||||
print_vma_addr("in ", regs->psw.addr & PSW_ADDR_INSN);
|
print_vma_addr("in ", regs->psw.addr & PSW_ADDR_INSN);
|
||||||
printk("\n");
|
printk("\n");
|
||||||
show_regs(regs);
|
show_regs(regs);
|
||||||
|
|
|
@ -261,8 +261,8 @@ static inline void report_user_fault(struct pt_regs *regs, long signr)
|
||||||
return;
|
return;
|
||||||
if (!printk_ratelimit())
|
if (!printk_ratelimit())
|
||||||
return;
|
return;
|
||||||
printk(KERN_ALERT "User process fault: interruption code 0x%X ",
|
printk(KERN_ALERT "User process fault: interruption code %04x ilc:%d",
|
||||||
regs->int_code);
|
regs->int_code & 0xffff, regs->int_code >> 17);
|
||||||
print_vma_addr(KERN_CONT "in ", regs->psw.addr & PSW_ADDR_INSN);
|
print_vma_addr(KERN_CONT "in ", regs->psw.addr & PSW_ADDR_INSN);
|
||||||
printk(KERN_CONT "\n");
|
printk(KERN_CONT "\n");
|
||||||
printk(KERN_ALERT "failing address: %016lx TEID: %016lx\n",
|
printk(KERN_ALERT "failing address: %016lx TEID: %016lx\n",
|
||||||
|
|
Загрузка…
Ссылка в новой задаче