|
@@ -49,12 +49,9 @@ static void aw_a10_pic_update(AwA10PICState *s)
|
|
static void aw_a10_pic_set_irq(void *opaque, int irq, int level)
|
|
static void aw_a10_pic_set_irq(void *opaque, int irq, int level)
|
|
{
|
|
{
|
|
AwA10PICState *s = opaque;
|
|
AwA10PICState *s = opaque;
|
|
|
|
+ uint32_t *pending_reg = &s->irq_pending[irq / 32];
|
|
|
|
|
|
- if (level) {
|
|
|
|
- set_bit(irq % 32, (void *)&s->irq_pending[irq / 32]);
|
|
|
|
- } else {
|
|
|
|
- clear_bit(irq % 32, (void *)&s->irq_pending[irq / 32]);
|
|
|
|
- }
|
|
|
|
|
|
+ *pending_reg = deposit32(*pending_reg, irq % 32, 1, level);
|
|
aw_a10_pic_update(s);
|
|
aw_a10_pic_update(s);
|
|
}
|
|
}
|
|
|
|
|