Lines Matching +full:shared +full:- +full:interrupt

1 /* SPDX-License-Identifier: GPL-2.0-or-later */
8 # error Please include asm/mips-cps.h rather than asm/mips-gic.h
29 /* For read-only shared registers */
34 /* For read-write shared registers */
39 /* For read-only local registers */
44 /* For read-write local registers */
49 /* For read-only shared per-interrupt registers */
62 /* For read-write shared per-interrupt registers */
81 /* For read-only local per-interrupt registers */
88 /* For read-write local per-interrupt registers */
95 /* For read-only shared bit-per-interrupt registers */
118 /* For read-write shared bit-per-interrupt registers */
167 /* For read-only local bit-per-interrupt registers */
174 /* For read-write local bit-per-interrupt registers */
181 /* GIC_SH_CONFIG - Information about the GIC configuration */
188 /* GIC_SH_COUNTER - Shared global counter value */
193 /* GIC_SH_POL_* - Configures interrupt polarity */
197 #define GIC_POL_FALLING_EDGE 0 /* when single-edge triggered */
198 #define GIC_POL_RISING_EDGE 1 /* when single-edge triggered */
200 /* GIC_SH_TRIG_* - Configures interrupts to be edge or level triggered */
205 /* GIC_SH_DUAL_* - Configures whether interrupts trigger on both edges */
207 #define GIC_DUAL_SINGLE 0 /* when edge-triggered */
208 #define GIC_DUAL_DUAL 1 /* when edge-triggered */
210 /* GIC_SH_WEDGE - Write an 'edge', ie. trigger an interrupt */
215 /* GIC_SH_RMASK_* - Reset/clear shared interrupt mask bits */
218 /* GIC_SH_SMASK_* - Set shared interrupt mask bits */
221 /* GIC_SH_MASK_* - Read the current shared interrupt mask */
224 /* GIC_SH_PEND_* - Read currently pending shared interrupts */
227 /* GIC_SH_MAPx_PIN - Map shared interrupts to a particular CPU pin */
233 /* GIC_SH_MAPx_VP - Map shared interrupts to a particular Virtual Processor */
236 /* GIC_Vx_CTL - VP-level interrupt control */
244 /* GIC_Vx_PEND - Read currently pending local interrupts */
247 /* GIC_Vx_MASK - Read the current local interrupt mask */
250 /* GIC_Vx_RMASK - Reset/clear local interrupt mask bits */
253 /* GIC_Vx_SMASK - Set local interrupt mask bits */
256 /* GIC_Vx_*_MAP - Route local interrupts to the desired pins */
259 /* GIC_Vx_WD_MAP - Route the local watchdog timer interrupt */
262 /* GIC_Vx_COMPARE_MAP - Route the local count/compare interrupt */
265 /* GIC_Vx_TIMER_MAP - Route the local CPU timer (cp0 count/compare) interrupt */
268 /* GIC_Vx_FDC_MAP - Route the local fast debug channel interrupt */
271 /* GIC_Vx_PERFCTR_MAP - Route the local performance counter interrupt */
274 /* GIC_Vx_SWINT0_MAP - Route the local software interrupt 0 */
277 /* GIC_Vx_SWINT1_MAP - Route the local software interrupt 1 */
280 /* GIC_Vx_OTHER - Configure access to other Virtual Processor registers */
284 /* GIC_Vx_IDENT - Retrieve the local Virtual Processor's ID */
288 /* GIC_Vx_COMPARE - Value to compare with GIC_SH_COUNTER */
291 /* GIC_Vx_EIC_SHADOW_SET_BASE - Set shadow register set for each interrupt */
295 * enum mips_gic_local_interrupt - GIC local interrupts
296 * @GIC_LOCAL_INT_WD: GIC watchdog timer interrupt
297 * @GIC_LOCAL_INT_COMPARE: GIC count/compare interrupt
298 * @GIC_LOCAL_INT_TIMER: CP0 count/compare interrupt
299 * @GIC_LOCAL_INT_PERFCTR: Performance counter interrupt
300 * @GIC_LOCAL_INT_SWINT0: Software interrupt 0
301 * @GIC_LOCAL_INT_SWINT1: Software interrupt 1
302 * @GIC_LOCAL_INT_FDC: Fast debug channel interrupt
319 * mips_gic_present() - Determine whether a GIC is present
321 * Determines whether a MIPS Global Interrupt Controller (GIC) is present in
332 * mips_gic_vx_map_reg() - Return GIC_Vx_<intr>_MAP register offset
333 * @intr: A GIC local interrupt
338 * mips_gic_local_interrupt, but moves the FDC interrupt & thus offsets the
362 * gic_get_c0_compare_int() - Return cp0 count/compare interrupt virq
365 * interrupt, which may be routed via the GIC.
372 * gic_get_c0_perfcount_int() - Return performance counter interrupt virq
382 * gic_get_c0_fdc_int() - Return fast debug channel interrupt virq