forked from mirrors/qmk_firmware
Improve avr wait_us() (#16879)
This commit is contained in:
parent
2f87abd4ef
commit
a83afb3fcd
1 changed files with 29 additions and 9 deletions
|
@ -17,6 +17,26 @@
|
||||||
|
|
||||||
#include <util/delay.h>
|
#include <util/delay.h>
|
||||||
|
|
||||||
|
// http://ww1.microchip.com/downloads/en/devicedoc/atmel-0856-avr-instruction-set-manual.pdf
|
||||||
|
// page 22: Table 4-2. Arithmetic and Logic Instructions
|
||||||
|
/*
|
||||||
|
for (uint16_t i = times; i > 0; i--) {
|
||||||
|
__builtin_avr_delay_cycles(1);
|
||||||
|
}
|
||||||
|
|
||||||
|
.L3: sbiw r24,0 // loop step 1
|
||||||
|
brne .L4 // loop step 2
|
||||||
|
ret
|
||||||
|
.L4: nop // __builtin_avr_delay_cycles(1);
|
||||||
|
sbiw r24,1 // loop step 3
|
||||||
|
rjmp .L3 // loop step 4
|
||||||
|
*/
|
||||||
|
|
||||||
|
#define AVR_sbiw_clocks 2
|
||||||
|
#define AVR_rjmp_clocks 2
|
||||||
|
#define AVR_brne_clocks 2
|
||||||
|
#define AVR_WAIT_LOOP_OVERHEAD (AVR_sbiw_clocks + AVR_brne_clocks + AVR_sbiw_clocks + AVR_rjmp_clocks)
|
||||||
|
|
||||||
#define wait_ms(ms) \
|
#define wait_ms(ms) \
|
||||||
do { \
|
do { \
|
||||||
if (__builtin_constant_p(ms)) { \
|
if (__builtin_constant_p(ms)) { \
|
||||||
|
@ -27,15 +47,15 @@
|
||||||
} \
|
} \
|
||||||
} \
|
} \
|
||||||
} while (0)
|
} while (0)
|
||||||
#define wait_us(us) \
|
#define wait_us(us) \
|
||||||
do { \
|
do { \
|
||||||
if (__builtin_constant_p(us)) { \
|
if (__builtin_constant_p(us)) { \
|
||||||
_delay_us(us); \
|
_delay_us(us); \
|
||||||
} else { \
|
} else { \
|
||||||
for (uint16_t i = us; i > 0; i--) { \
|
for (uint16_t i = us; i > 0; i--) { \
|
||||||
_delay_us(1); \
|
__builtin_avr_delay_cycles((F_CPU / 1000000) - AVR_WAIT_LOOP_OVERHEAD); \
|
||||||
} \
|
} \
|
||||||
} \
|
} \
|
||||||
} while (0)
|
} while (0)
|
||||||
#define wait_cpuclock(n) __builtin_avr_delay_cycles(n)
|
#define wait_cpuclock(n) __builtin_avr_delay_cycles(n)
|
||||||
#define CPU_CLOCK F_CPU
|
#define CPU_CLOCK F_CPU
|
||||||
|
|
Loading…
Reference in a new issue