Lines Matching full:irq
29 #define GIC_DIST_SET_ENABLED(irq, cm) (s->irq_state[irq].enabled |= (cm)) argument
30 #define GIC_DIST_CLEAR_ENABLED(irq, cm) (s->irq_state[irq].enabled &= ~(cm)) argument
31 #define GIC_DIST_TEST_ENABLED(irq, cm) ((s->irq_state[irq].enabled & (cm)) != 0) argument
32 #define GIC_DIST_SET_PENDING(irq, cm) (s->irq_state[irq].pending |= (cm)) argument
33 #define GIC_DIST_CLEAR_PENDING(irq, cm) (s->irq_state[irq].pending &= ~(cm)) argument
34 #define GIC_DIST_SET_ACTIVE(irq, cm) (s->irq_state[irq].active |= (cm)) argument
35 #define GIC_DIST_CLEAR_ACTIVE(irq, cm) (s->irq_state[irq].active &= ~(cm)) argument
36 #define GIC_DIST_TEST_ACTIVE(irq, cm) ((s->irq_state[irq].active & (cm)) != 0) argument
37 #define GIC_DIST_SET_MODEL(irq) (s->irq_state[irq].model = true) argument
38 #define GIC_DIST_CLEAR_MODEL(irq) (s->irq_state[irq].model = false) argument
39 #define GIC_DIST_TEST_MODEL(irq) (s->irq_state[irq].model) argument
40 #define GIC_DIST_SET_LEVEL(irq, cm) (s->irq_state[irq].level |= (cm)) argument
41 #define GIC_DIST_CLEAR_LEVEL(irq, cm) (s->irq_state[irq].level &= ~(cm)) argument
42 #define GIC_DIST_TEST_LEVEL(irq, cm) ((s->irq_state[irq].level & (cm)) != 0) argument
43 #define GIC_DIST_SET_EDGE_TRIGGER(irq) (s->irq_state[irq].edge_trigger = true) argument
44 #define GIC_DIST_CLEAR_EDGE_TRIGGER(irq) \ argument
45 (s->irq_state[irq].edge_trigger = false)
46 #define GIC_DIST_TEST_EDGE_TRIGGER(irq) (s->irq_state[irq].edge_trigger) argument
47 #define GIC_DIST_GET_PRIORITY(irq, cpu) (((irq) < GIC_INTERNAL) ? \ argument
48 s->priority1[irq][cpu] : \
49 s->priority2[(irq) - GIC_INTERNAL])
50 #define GIC_DIST_TARGET(irq) (s->irq_target[irq]) argument
51 #define GIC_DIST_CLEAR_GROUP(irq, cm) (s->irq_state[irq].group &= ~(cm)) argument
52 #define GIC_DIST_SET_GROUP(irq, cm) (s->irq_state[irq].group |= (cm)) argument
53 #define GIC_DIST_TEST_GROUP(irq, cm) ((s->irq_state[irq].group & (cm)) != 0) argument
163 void gic_dist_set_priority(GICState *s, int cpu, int irq, uint8_t val,
166 static inline bool gic_test_pending(GICState *s, int irq, int cm) in gic_test_pending() argument
169 return s->irq_state[irq].pending & cm; in gic_test_pending()
176 return (s->irq_state[irq].pending & cm) || in gic_test_pending()
177 (!GIC_DIST_TEST_EDGE_TRIGGER(irq) && GIC_DIST_TEST_LEVEL(irq, cm)); in gic_test_pending()
198 static inline bool gic_virq_is_valid(GICState *s, int irq, int vcpu) in gic_virq_is_valid() argument
206 if ((GICH_LR_VIRT_ID(*entry) == irq) && in gic_virq_is_valid()
229 static inline uint32_t *gic_get_lr_entry(GICState *s, int irq, int vcpu) in gic_get_lr_entry() argument
237 if ((GICH_LR_VIRT_ID(*entry) == irq) && in gic_get_lr_entry()
246 static inline bool gic_test_group(GICState *s, int irq, int cpu) in gic_test_group() argument
249 uint32_t *entry = gic_get_lr_entry(s, irq, cpu); in gic_test_group()
252 return GIC_DIST_TEST_GROUP(irq, 1 << cpu); in gic_test_group()
256 static inline void gic_clear_pending(GICState *s, int irq, int cpu) in gic_clear_pending() argument
259 uint32_t *entry = gic_get_lr_entry(s, irq, cpu); in gic_clear_pending()
266 GIC_DIST_CLEAR_PENDING(irq, GIC_DIST_TEST_MODEL(irq) ? ALL_CPU_MASK in gic_clear_pending()
271 static inline void gic_set_active(GICState *s, int irq, int cpu) in gic_set_active() argument
274 uint32_t *entry = gic_get_lr_entry(s, irq, cpu); in gic_set_active()
277 GIC_DIST_SET_ACTIVE(irq, 1 << cpu); in gic_set_active()
281 static inline void gic_clear_active(GICState *s, int irq, int cpu) in gic_clear_active() argument
286 uint32_t *entry = gic_get_lr_entry(s, irq, cpu); in gic_clear_active()
311 cm = irq < GIC_INTERNAL ? 1 << cpu : ALL_CPU_MASK; in gic_clear_active()
312 GIC_DIST_CLEAR_ACTIVE(irq, cm); in gic_clear_active()
316 static inline int gic_get_priority(GICState *s, int irq, int cpu) in gic_get_priority() argument
319 uint32_t *entry = gic_get_lr_entry(s, irq, cpu); in gic_get_priority()
322 return GIC_DIST_GET_PRIORITY(irq, cpu); in gic_get_priority()