WIP FPC-III support
[linux/fpc-iii.git] / arch / arm / include / asm / fiq.h
blob6bdfb4a47322066e0e344b97229abd03077571a3
1 /* SPDX-License-Identifier: GPL-2.0 */
2 /*
3 * arch/arm/include/asm/fiq.h
5 * Support for FIQ on ARM architectures.
6 * Written by Philip Blundell <philb@gnu.org>, 1998
7 * Re-written by Russell King
9 * NOTE: The FIQ mode registers are not magically preserved across
10 * suspend/resume.
12 * Drivers which require these registers to be preserved across power
13 * management operations must implement appropriate suspend/resume handlers to
14 * save and restore them.
17 #ifndef __ASM_FIQ_H
18 #define __ASM_FIQ_H
20 #include <asm/ptrace.h>
22 struct fiq_handler {
23 struct fiq_handler *next;
24 /* Name
26 const char *name;
27 /* Called to ask driver to relinquish/
28 * reacquire FIQ
29 * return zero to accept, or -<errno>
31 int (*fiq_op)(void *, int relinquish);
32 /* data for the relinquish/reacquire functions
34 void *dev_id;
37 extern int claim_fiq(struct fiq_handler *f);
38 extern void release_fiq(struct fiq_handler *f);
39 extern void set_fiq_handler(void *start, unsigned int length);
40 extern void enable_fiq(int fiq);
41 extern void disable_fiq(int fiq);
43 /* helpers defined in fiqasm.S: */
44 extern void __set_fiq_regs(unsigned long const *regs);
45 extern void __get_fiq_regs(unsigned long *regs);
47 static inline void set_fiq_regs(struct pt_regs const *regs)
49 __set_fiq_regs(&regs->ARM_r8);
52 static inline void get_fiq_regs(struct pt_regs *regs)
54 __get_fiq_regs(&regs->ARM_r8);
57 #endif