mirror of
https://github.com/RIOT-OS/RIOT.git
synced 2024-12-29 04:50:03 +01:00
9e566370bf
The inline assembly implementation was badly in need of improvement. - irq_disable() took 2 CPU cycles more than needed - The current interrupt state was stored in a temporary register and afterwards copied to the target register, rather than storing it in the target register right away - The lower bits of the state were cleared (as they have no meaning for the interrupt status), but the API purposely never required such things from implementations. - irq_restore() took 5 CPU cycles. This was reduced to 3 CPU cycles (or 2 CPU cycles in the best case) |
||
---|---|---|
.. | ||
atmega_gpio.h | ||
atmega_regs_common.h | ||
c11_atomics_compat_cpu.hpp | ||
cpu_conf.h | ||
cpu.h | ||
irq_arch.h | ||
periph_cpu_common.h |