Contributors: 8
Author |
Tokens |
Token Proportion |
Commits |
Commit Proportion |
Paul Mundt |
66 |
61.11% |
8 |
53.33% |
David Howells |
11 |
10.19% |
1 |
6.67% |
Yoshinori Sato |
10 |
9.26% |
1 |
6.67% |
Linus Torvalds (pre-git) |
8 |
7.41% |
1 |
6.67% |
Linus Torvalds |
8 |
7.41% |
1 |
6.67% |
Bobby Bingham |
3 |
2.78% |
1 |
6.67% |
Greg Kroah-Hartman |
1 |
0.93% |
1 |
6.67% |
Nobuhiro Iwamatsu |
1 |
0.93% |
1 |
6.67% |
Total |
108 |
|
15 |
|
/* SPDX-License-Identifier: GPL-2.0 */
#ifndef __ASM_SH_TRAPS_32_H
#define __ASM_SH_TRAPS_32_H
#include <linux/types.h>
#include <asm/mmu.h>
#ifdef CONFIG_CPU_HAS_SR_RB
#define lookup_exception_vector() \
({ \
unsigned long _vec; \
\
__asm__ __volatile__ ( \
"stc r2_bank, %0\n\t" \
: "=r" (_vec) \
); \
\
_vec; \
})
#else
#define lookup_exception_vector() \
({ \
unsigned long _vec; \
__asm__ __volatile__ ( \
"mov r4, %0\n\t" \
: "=r" (_vec) \
); \
\
_vec; \
})
#endif
static inline void trigger_address_error(void)
{
__asm__ __volatile__ (
"ldc %0, sr\n\t"
"mov.l @%1, %0"
:
: "r" (0x10000000), "r" (0x80000001)
);
}
asmlinkage void do_address_error(struct pt_regs *regs,
unsigned long writeaccess,
unsigned long address);
asmlinkage void do_divide_error(unsigned long r4);
asmlinkage void do_reserved_inst(void);
asmlinkage void do_illegal_slot_inst(void);
asmlinkage void do_exception_error(void);
#define BUILD_TRAP_HANDLER(name) \
asmlinkage void name##_trap_handler(unsigned long r4, unsigned long r5, \
unsigned long r6, unsigned long r7, \
struct pt_regs __regs)
#define TRAP_HANDLER_DECL \
struct pt_regs *regs = RELOC_HIDE(&__regs, 0); \
unsigned int vec = regs->tra; \
(void)vec;
#endif /* __ASM_SH_TRAPS_32_H */