[PATCH 0/1] grlib/genirq: Issue when enabling/disabling interrupt

Moyano, Gabriel gabriel.moyano at dlr.de
Mon Apr 12 09:15:58 UTC 2021


Hello everyone,

I've found what can be an issue in the function genirq_set_active(): under some conditions it can return a value greater than 1.

This function is used by genirq_enable() and genirq_disable() and both of them returns the value returned by genirq_set_active(). According to the documentation in genirq.h, they should return -1, 0 or 1.

When this issue can happen? If there are 3 entries in the list of IRQ and 2 of them are already enabled, the variable `enabled` would be 2, because of `enabled += isrentry->enabled`.

As a possible solution, the value of `enabled` can changed to 1 if it's greater than 1 (see the patch) or maybe improve the search.

Thanks in advance,

Gabriel Moyano



Moyano, Gabriel (1):
  grlib/genirq: Taking into account that it could be more than one ISR
    enabled/disabled

 bsps/shared/grlib/irq/genirq.c | 5 +++++
 1 file changed, 5 insertions(+)

-- 
2.17.1



More information about the devel mailing list