diff options
| author | Nick Brassel <nick@tzarc.org> | 2021-01-18 05:12:15 +1100 |
|---|---|---|
| committer | Zach White <skullydazed@drpepper.org> | 2021-01-17 10:19:56 -0800 |
| commit | 31c57aab35e6fd49c4c8336f449419afe7630e93 (patch) | |
| tree | 60b3508af9b3a953826d027a2dc6f2e2d028d1cc /tmk_core | |
| parent | e702c7f1b4cfa8fe1579498ef2877994baa64056 (diff) | |
| download | qmk_firmware-31c57aab35e6fd49c4c8336f449419afe7630e93.tar.gz qmk_firmware-31c57aab35e6fd49c4c8336f449419afe7630e93.zip | |
`qmk cformat`
Diffstat (limited to 'tmk_core')
| -rw-r--r-- | tmk_core/common/avr/bootloader.c | 8 | ||||
| -rw-r--r-- | tmk_core/common/mousekey.c | 32 | ||||
| -rw-r--r-- | tmk_core/common/mousekey.h | 78 | ||||
| -rw-r--r-- | tmk_core/common/wait.h | 89 |
4 files changed, 115 insertions, 92 deletions
diff --git a/tmk_core/common/avr/bootloader.c b/tmk_core/common/avr/bootloader.c index c0272903b..4e3a27022 100644 --- a/tmk_core/common/avr/bootloader.c +++ b/tmk_core/common/avr/bootloader.c | |||
| @@ -237,13 +237,13 @@ __attribute__((weak)) void bootloader_jump(void) { | |||
| 237 | "bootloader_startup_loop%=: \n\t" | 237 | "bootloader_startup_loop%=: \n\t" |
| 238 | "rjmp bootloader_startup_loop%= \n\t" | 238 | "rjmp bootloader_startup_loop%= \n\t" |
| 239 | : | 239 | : |
| 240 | : [mcucsrio] "I"(_SFR_IO_ADDR(MCUCSR)), | 240 | : [ mcucsrio ] "I"(_SFR_IO_ADDR(MCUCSR)), |
| 241 | # if (FLASHEND > 131071) | 241 | # if (FLASHEND > 131071) |
| 242 | [ramendhi] "M"(((RAMEND - 2) >> 8) & 0xff), [ramendlo] "M"(((RAMEND - 2) >> 0) & 0xff), [bootaddrhi] "M"((((FLASH_SIZE - BOOTLOADER_SIZE) >> 1) >> 16) & 0xff), | 242 | [ ramendhi ] "M"(((RAMEND - 2) >> 8) & 0xff), [ ramendlo ] "M"(((RAMEND - 2) >> 0) & 0xff), [ bootaddrhi ] "M"((((FLASH_SIZE - BOOTLOADER_SIZE) >> 1) >> 16) & 0xff), |
| 243 | # else | 243 | # else |
| 244 | [ramendhi] "M"(((RAMEND - 1) >> 8) & 0xff), [ramendlo] "M"(((RAMEND - 1) >> 0) & 0xff), | 244 | [ ramendhi ] "M"(((RAMEND - 1) >> 8) & 0xff), [ ramendlo ] "M"(((RAMEND - 1) >> 0) & 0xff), |
| 245 | # endif | 245 | # endif |
| 246 | [bootaddrme] "M"((((FLASH_SIZE - BOOTLOADER_SIZE) >> 1) >> 8) & 0xff), [bootaddrlo] "M"((((FLASH_SIZE - BOOTLOADER_SIZE) >> 1) >> 0) & 0xff)); | 246 | [ bootaddrme ] "M"((((FLASH_SIZE - BOOTLOADER_SIZE) >> 1) >> 8) & 0xff), [ bootaddrlo ] "M"((((FLASH_SIZE - BOOTLOADER_SIZE) >> 1) >> 0) & 0xff)); |
| 247 | 247 | ||
| 248 | #else // Assume remaining boards are DFU, even if the flag isn't set | 248 | #else // Assume remaining boards are DFU, even if the flag isn't set |
| 249 | 249 | ||
diff --git a/tmk_core/common/mousekey.c b/tmk_core/common/mousekey.c index 697e0692c..6c9df6723 100644 --- a/tmk_core/common/mousekey.c +++ b/tmk_core/common/mousekey.c | |||
| @@ -37,7 +37,7 @@ static uint8_t mousekey_accel = 0; | |||
| 37 | static uint8_t mousekey_repeat = 0; | 37 | static uint8_t mousekey_repeat = 0; |
| 38 | static uint8_t mousekey_wheel_repeat = 0; | 38 | static uint8_t mousekey_wheel_repeat = 0; |
| 39 | #ifdef MK_KINETIC_SPEED | 39 | #ifdef MK_KINETIC_SPEED |
| 40 | static uint16_t mouse_timer = 0; | 40 | static uint16_t mouse_timer = 0; |
| 41 | #endif | 41 | #endif |
| 42 | 42 | ||
| 43 | #ifndef MK_3_SPEED | 43 | #ifndef MK_3_SPEED |
| @@ -123,20 +123,18 @@ static uint8_t wheel_unit(void) { | |||
| 123 | * B: base mouse travel speed | 123 | * B: base mouse travel speed |
| 124 | */ | 124 | */ |
| 125 | const uint16_t mk_accelerated_speed = MOUSEKEY_ACCELERATED_SPEED; | 125 | const uint16_t mk_accelerated_speed = MOUSEKEY_ACCELERATED_SPEED; |
| 126 | const uint16_t mk_base_speed = MOUSEKEY_BASE_SPEED; | 126 | const uint16_t mk_base_speed = MOUSEKEY_BASE_SPEED; |
| 127 | const uint16_t mk_decelerated_speed = MOUSEKEY_DECELERATED_SPEED; | 127 | const uint16_t mk_decelerated_speed = MOUSEKEY_DECELERATED_SPEED; |
| 128 | const uint16_t mk_initial_speed = MOUSEKEY_INITIAL_SPEED; | 128 | const uint16_t mk_initial_speed = MOUSEKEY_INITIAL_SPEED; |
| 129 | 129 | ||
| 130 | static uint8_t move_unit(void) { | 130 | static uint8_t move_unit(void) { |
| 131 | float speed = mk_initial_speed; | 131 | float speed = mk_initial_speed; |
| 132 | 132 | ||
| 133 | if (mousekey_accel & ((1<<0) | (1<<2))) { | 133 | if (mousekey_accel & ((1 << 0) | (1 << 2))) { |
| 134 | speed = mousekey_accel & (1<<2) ? mk_accelerated_speed : mk_decelerated_speed; | 134 | speed = mousekey_accel & (1 << 2) ? mk_accelerated_speed : mk_decelerated_speed; |
| 135 | } else if (mousekey_repeat && mouse_timer) { | 135 | } else if (mousekey_repeat && mouse_timer) { |
| 136 | const float time_elapsed = timer_elapsed(mouse_timer) / 50; | 136 | const float time_elapsed = timer_elapsed(mouse_timer) / 50; |
| 137 | speed = mk_initial_speed + | 137 | speed = mk_initial_speed + MOUSEKEY_MOVE_DELTA * time_elapsed + MOUSEKEY_MOVE_DELTA * 0.5 * time_elapsed * time_elapsed; |
| 138 | MOUSEKEY_MOVE_DELTA * time_elapsed + | ||
| 139 | MOUSEKEY_MOVE_DELTA * 0.5 * time_elapsed * time_elapsed; | ||
| 140 | 138 | ||
| 141 | speed = speed > mk_base_speed ? mk_base_speed : speed; | 139 | speed = speed > mk_base_speed ? mk_base_speed : speed; |
| 142 | } | 140 | } |
| @@ -153,14 +151,12 @@ float mk_wheel_interval = 1000.0f / MOUSEKEY_WHEEL_INITIAL_MOVEMENTS; | |||
| 153 | static uint8_t wheel_unit(void) { | 151 | static uint8_t wheel_unit(void) { |
| 154 | float speed = MOUSEKEY_WHEEL_INITIAL_MOVEMENTS; | 152 | float speed = MOUSEKEY_WHEEL_INITIAL_MOVEMENTS; |
| 155 | 153 | ||
| 156 | if (mousekey_accel & ((1<<0) | (1<<2))) { | 154 | if (mousekey_accel & ((1 << 0) | (1 << 2))) { |
| 157 | speed = mousekey_accel & (1<<2) ? MOUSEKEY_WHEEL_ACCELERATED_MOVEMENTS : MOUSEKEY_WHEEL_DECELERATED_MOVEMENTS; | 155 | speed = mousekey_accel & (1 << 2) ? MOUSEKEY_WHEEL_ACCELERATED_MOVEMENTS : MOUSEKEY_WHEEL_DECELERATED_MOVEMENTS; |
| 158 | } else if (mousekey_repeat && mouse_timer) { | 156 | } else if (mousekey_repeat && mouse_timer) { |
| 159 | if (mk_wheel_interval != MOUSEKEY_WHEEL_BASE_MOVEMENTS) { | 157 | if (mk_wheel_interval != MOUSEKEY_WHEEL_BASE_MOVEMENTS) { |
| 160 | const float time_elapsed = timer_elapsed(mouse_timer) / 50; | 158 | const float time_elapsed = timer_elapsed(mouse_timer) / 50; |
| 161 | speed = MOUSEKEY_WHEEL_INITIAL_MOVEMENTS + | 159 | speed = MOUSEKEY_WHEEL_INITIAL_MOVEMENTS + 1 * time_elapsed + 1 * 0.5 * time_elapsed * time_elapsed; |
| 162 | 1 * time_elapsed + | ||
| 163 | 1 * 0.5 * time_elapsed * time_elapsed; | ||
| 164 | } | 160 | } |
| 165 | speed = speed > MOUSEKEY_WHEEL_BASE_MOVEMENTS ? MOUSEKEY_WHEEL_BASE_MOVEMENTS : speed; | 161 | speed = speed > MOUSEKEY_WHEEL_BASE_MOVEMENTS ? MOUSEKEY_WHEEL_BASE_MOVEMENTS : speed; |
| 166 | } | 162 | } |
| @@ -209,7 +205,7 @@ static uint8_t wheel_unit(void) { | |||
| 209 | } | 205 | } |
| 210 | 206 | ||
| 211 | # endif /* #ifndef MK_KINETIC_SPEED */ | 207 | # endif /* #ifndef MK_KINETIC_SPEED */ |
| 212 | # endif /* #ifndef MK_COMBINED */ | 208 | # endif /* #ifndef MK_COMBINED */ |
| 213 | 209 | ||
| 214 | void mousekey_task(void) { | 210 | void mousekey_task(void) { |
| 215 | // report cursor and scroll movement independently | 211 | // report cursor and scroll movement independently |
| @@ -260,11 +256,11 @@ void mousekey_task(void) { | |||
| 260 | } | 256 | } |
| 261 | 257 | ||
| 262 | void mousekey_on(uint8_t code) { | 258 | void mousekey_on(uint8_t code) { |
| 263 | #ifdef MK_KINETIC_SPEED | 259 | # ifdef MK_KINETIC_SPEED |
| 264 | if (mouse_timer == 0) { | 260 | if (mouse_timer == 0) { |
| 265 | mouse_timer = timer_read(); | 261 | mouse_timer = timer_read(); |
| 266 | } | 262 | } |
| 267 | #endif /* #ifdef MK_KINETIC_SPEED */ | 263 | # endif /* #ifdef MK_KINETIC_SPEED */ |
| 268 | 264 | ||
| 269 | if (code == KC_MS_UP) | 265 | if (code == KC_MS_UP) |
| 270 | mouse_report.y = move_unit() * -1; | 266 | mouse_report.y = move_unit() * -1; |
| @@ -335,9 +331,9 @@ void mousekey_off(uint8_t code) { | |||
| 335 | mousekey_accel &= ~(1 << 2); | 331 | mousekey_accel &= ~(1 << 2); |
| 336 | if (mouse_report.x == 0 && mouse_report.y == 0) { | 332 | if (mouse_report.x == 0 && mouse_report.y == 0) { |
| 337 | mousekey_repeat = 0; | 333 | mousekey_repeat = 0; |
| 338 | #ifdef MK_KINETIC_SPEED | 334 | # ifdef MK_KINETIC_SPEED |
| 339 | mouse_timer = 0; | 335 | mouse_timer = 0; |
| 340 | #endif /* #ifdef MK_KINETIC_SPEED */ | 336 | # endif /* #ifdef MK_KINETIC_SPEED */ |
| 341 | } | 337 | } |
| 342 | if (mouse_report.v == 0 && mouse_report.h == 0) mousekey_wheel_repeat = 0; | 338 | if (mouse_report.v == 0 && mouse_report.h == 0) mousekey_wheel_repeat = 0; |
| 343 | } | 339 | } |
diff --git a/tmk_core/common/mousekey.h b/tmk_core/common/mousekey.h index 911d11eeb..52b8fe10e 100644 --- a/tmk_core/common/mousekey.h +++ b/tmk_core/common/mousekey.h | |||
| @@ -36,28 +36,28 @@ along with this program. If not, see <http://www.gnu.org/licenses/>. | |||
| 36 | # endif | 36 | # endif |
| 37 | 37 | ||
| 38 | # ifndef MOUSEKEY_MOVE_DELTA | 38 | # ifndef MOUSEKEY_MOVE_DELTA |
| 39 | #ifndef MK_KINETIC_SPEED | 39 | # ifndef MK_KINETIC_SPEED |
| 40 | # define MOUSEKEY_MOVE_DELTA 5 | 40 | # define MOUSEKEY_MOVE_DELTA 5 |
| 41 | #else | 41 | # else |
| 42 | # define MOUSEKEY_MOVE_DELTA 25 | 42 | # define MOUSEKEY_MOVE_DELTA 25 |
| 43 | #endif | 43 | # endif |
| 44 | # endif | 44 | # endif |
| 45 | # ifndef MOUSEKEY_WHEEL_DELTA | 45 | # ifndef MOUSEKEY_WHEEL_DELTA |
| 46 | # define MOUSEKEY_WHEEL_DELTA 1 | 46 | # define MOUSEKEY_WHEEL_DELTA 1 |
| 47 | # endif | 47 | # endif |
| 48 | # ifndef MOUSEKEY_DELAY | 48 | # ifndef MOUSEKEY_DELAY |
| 49 | #ifndef MK_KINETIC_SPEED | 49 | # ifndef MK_KINETIC_SPEED |
| 50 | # define MOUSEKEY_DELAY 300 | 50 | # define MOUSEKEY_DELAY 300 |
| 51 | #else | 51 | # else |
| 52 | # define MOUSEKEY_DELAY 8 | 52 | # define MOUSEKEY_DELAY 8 |
| 53 | #endif | 53 | # endif |
| 54 | # endif | 54 | # endif |
| 55 | # ifndef MOUSEKEY_INTERVAL | 55 | # ifndef MOUSEKEY_INTERVAL |
| 56 | #ifndef MK_KINETIC_SPEED | 56 | # ifndef MK_KINETIC_SPEED |
| 57 | # define MOUSEKEY_INTERVAL 50 | 57 | # define MOUSEKEY_INTERVAL 50 |
| 58 | #else | 58 | # else |
| 59 | # define MOUSEKEY_INTERVAL 8 | 59 | # define MOUSEKEY_INTERVAL 8 |
| 60 | #endif | 60 | # endif |
| 61 | # endif | 61 | # endif |
| 62 | # ifndef MOUSEKEY_MAX_SPEED | 62 | # ifndef MOUSEKEY_MAX_SPEED |
| 63 | # define MOUSEKEY_MAX_SPEED 10 | 63 | # define MOUSEKEY_MAX_SPEED 10 |
| @@ -78,30 +78,30 @@ along with this program. If not, see <http://www.gnu.org/licenses/>. | |||
| 78 | # define MOUSEKEY_WHEEL_TIME_TO_MAX 40 | 78 | # define MOUSEKEY_WHEEL_TIME_TO_MAX 40 |
| 79 | # endif | 79 | # endif |
| 80 | 80 | ||
| 81 | #ifndef MOUSEKEY_INITIAL_SPEED | 81 | # ifndef MOUSEKEY_INITIAL_SPEED |
| 82 | #define MOUSEKEY_INITIAL_SPEED 100 | 82 | # define MOUSEKEY_INITIAL_SPEED 100 |
| 83 | #endif | 83 | # endif |
| 84 | #ifndef MOUSEKEY_BASE_SPEED | 84 | # ifndef MOUSEKEY_BASE_SPEED |
| 85 | #define MOUSEKEY_BASE_SPEED 1000 | 85 | # define MOUSEKEY_BASE_SPEED 1000 |
| 86 | #endif | 86 | # endif |
| 87 | #ifndef MOUSEKEY_DECELERATED_SPEED | 87 | # ifndef MOUSEKEY_DECELERATED_SPEED |
| 88 | #define MOUSEKEY_DECELERATED_SPEED 400 | 88 | # define MOUSEKEY_DECELERATED_SPEED 400 |
| 89 | #endif | 89 | # endif |
| 90 | #ifndef MOUSEKEY_ACCELERATED_SPEED | 90 | # ifndef MOUSEKEY_ACCELERATED_SPEED |
| 91 | #define MOUSEKEY_ACCELERATED_SPEED 3000 | 91 | # define MOUSEKEY_ACCELERATED_SPEED 3000 |
| 92 | #endif | 92 | # endif |
| 93 | #ifndef MOUSEKEY_WHEEL_INITIAL_MOVEMENTS | 93 | # ifndef MOUSEKEY_WHEEL_INITIAL_MOVEMENTS |
| 94 | #define MOUSEKEY_WHEEL_INITIAL_MOVEMENTS 16 | 94 | # define MOUSEKEY_WHEEL_INITIAL_MOVEMENTS 16 |
| 95 | #endif | 95 | # endif |
| 96 | #ifndef MOUSEKEY_WHEEL_BASE_MOVEMENTS | 96 | # ifndef MOUSEKEY_WHEEL_BASE_MOVEMENTS |
| 97 | #define MOUSEKEY_WHEEL_BASE_MOVEMENTS 32 | 97 | # define MOUSEKEY_WHEEL_BASE_MOVEMENTS 32 |
| 98 | #endif | 98 | # endif |
| 99 | #ifndef MOUSEKEY_WHEEL_ACCELERATED_MOVEMENTS | 99 | # ifndef MOUSEKEY_WHEEL_ACCELERATED_MOVEMENTS |
| 100 | #define MOUSEKEY_WHEEL_ACCELERATED_MOVEMENTS 48 | 100 | # define MOUSEKEY_WHEEL_ACCELERATED_MOVEMENTS 48 |
| 101 | #endif | 101 | # endif |
| 102 | #ifndef MOUSEKEY_WHEEL_DECELERATED_MOVEMENTS | 102 | # ifndef MOUSEKEY_WHEEL_DECELERATED_MOVEMENTS |
| 103 | #define MOUSEKEY_WHEEL_DECELERATED_MOVEMENTS 8 | 103 | # define MOUSEKEY_WHEEL_DECELERATED_MOVEMENTS 8 |
| 104 | #endif | 104 | # endif |
| 105 | 105 | ||
| 106 | #else /* #ifndef MK_3_SPEED */ | 106 | #else /* #ifndef MK_3_SPEED */ |
| 107 | 107 | ||
diff --git a/tmk_core/common/wait.h b/tmk_core/common/wait.h index 0b3fd755a..28224fe3a 100644 --- a/tmk_core/common/wait.h +++ b/tmk_core/common/wait.h | |||
| @@ -15,44 +15,71 @@ extern "C" { | |||
| 15 | 15 | ||
| 16 | # define CLOCK_DELAY_NOP8 "nop\n\t nop\n\t nop\n\t nop\n\t nop\n\t nop\n\t nop\n\t nop\n\t" | 16 | # define CLOCK_DELAY_NOP8 "nop\n\t nop\n\t nop\n\t nop\n\t nop\n\t nop\n\t nop\n\t nop\n\t" |
| 17 | 17 | ||
| 18 | __attribute__((always_inline)) | 18 | __attribute__((always_inline)) static inline void wait_cpuclock_allnop(unsigned int n) { /* n: 1..135 */ |
| 19 | static inline void wait_cpuclock_allnop(unsigned int n) { /* n: 1..135 */ | ||
| 20 | /* The argument n must be a constant expression. | 19 | /* The argument n must be a constant expression. |
| 21 | * That way, compiler optimization will remove unnecessary code. */ | 20 | * That way, compiler optimization will remove unnecessary code. */ |
| 22 | if (n < 1) { return; } | 21 | if (n < 1) { |
| 22 | return; | ||
| 23 | } | ||
| 23 | if (n > 8) { | 24 | if (n > 8) { |
| 24 | unsigned int n8 = n/8; | 25 | unsigned int n8 = n / 8; |
| 25 | n = n - n8*8; | 26 | n = n - n8 * 8; |
| 26 | switch (n8) { | 27 | switch (n8) { |
| 27 | case 16: asm volatile (CLOCK_DELAY_NOP8::: "memory"); | 28 | case 16: |
| 28 | case 15: asm volatile (CLOCK_DELAY_NOP8::: "memory"); | 29 | asm volatile(CLOCK_DELAY_NOP8::: "memory"); |
| 29 | case 14: asm volatile (CLOCK_DELAY_NOP8::: "memory"); | 30 | case 15: |
| 30 | case 13: asm volatile (CLOCK_DELAY_NOP8::: "memory"); | 31 | asm volatile(CLOCK_DELAY_NOP8::: "memory"); |
| 31 | case 12: asm volatile (CLOCK_DELAY_NOP8::: "memory"); | 32 | case 14: |
| 32 | case 11: asm volatile (CLOCK_DELAY_NOP8::: "memory"); | 33 | asm volatile(CLOCK_DELAY_NOP8::: "memory"); |
| 33 | case 10: asm volatile (CLOCK_DELAY_NOP8::: "memory"); | 34 | case 13: |
| 34 | case 9: asm volatile (CLOCK_DELAY_NOP8::: "memory"); | 35 | asm volatile(CLOCK_DELAY_NOP8::: "memory"); |
| 35 | case 8: asm volatile (CLOCK_DELAY_NOP8::: "memory"); | 36 | case 12: |
| 36 | case 7: asm volatile (CLOCK_DELAY_NOP8::: "memory"); | 37 | asm volatile(CLOCK_DELAY_NOP8::: "memory"); |
| 37 | case 6: asm volatile (CLOCK_DELAY_NOP8::: "memory"); | 38 | case 11: |
| 38 | case 5: asm volatile (CLOCK_DELAY_NOP8::: "memory"); | 39 | asm volatile(CLOCK_DELAY_NOP8::: "memory"); |
| 39 | case 4: asm volatile (CLOCK_DELAY_NOP8::: "memory"); | 40 | case 10: |
| 40 | case 3: asm volatile (CLOCK_DELAY_NOP8::: "memory"); | 41 | asm volatile(CLOCK_DELAY_NOP8::: "memory"); |
| 41 | case 2: asm volatile (CLOCK_DELAY_NOP8::: "memory"); | 42 | case 9: |
| 42 | case 1: asm volatile (CLOCK_DELAY_NOP8::: "memory"); | 43 | asm volatile(CLOCK_DELAY_NOP8::: "memory"); |
| 43 | case 0: break; | 44 | case 8: |
| 45 | asm volatile(CLOCK_DELAY_NOP8::: "memory"); | ||
| 46 | case 7: | ||
| 47 | asm volatile(CLOCK_DELAY_NOP8::: "memory"); | ||
| 48 | case 6: | ||
| 49 | asm volatile(CLOCK_DELAY_NOP8::: "memory"); | ||
| 50 | case 5: | ||
| 51 | asm volatile(CLOCK_DELAY_NOP8::: "memory"); | ||
| 52 | case 4: | ||
| 53 | asm volatile(CLOCK_DELAY_NOP8::: "memory"); | ||
| 54 | case 3: | ||
| 55 | asm volatile(CLOCK_DELAY_NOP8::: "memory"); | ||
| 56 | case 2: | ||
| 57 | asm volatile(CLOCK_DELAY_NOP8::: "memory"); | ||
| 58 | case 1: | ||
| 59 | asm volatile(CLOCK_DELAY_NOP8::: "memory"); | ||
| 60 | case 0: | ||
| 61 | break; | ||
| 44 | } | 62 | } |
| 45 | } | 63 | } |
| 46 | switch (n) { | 64 | switch (n) { |
| 47 | case 8: asm volatile ("nop"::: "memory"); | 65 | case 8: |
| 48 | case 7: asm volatile ("nop"::: "memory"); | 66 | asm volatile("nop" ::: "memory"); |
| 49 | case 6: asm volatile ("nop"::: "memory"); | 67 | case 7: |
| 50 | case 5: asm volatile ("nop"::: "memory"); | 68 | asm volatile("nop" ::: "memory"); |
| 51 | case 4: asm volatile ("nop"::: "memory"); | 69 | case 6: |
| 52 | case 3: asm volatile ("nop"::: "memory"); | 70 | asm volatile("nop" ::: "memory"); |
| 53 | case 2: asm volatile ("nop"::: "memory"); | 71 | case 5: |
| 54 | case 1: asm volatile ("nop"::: "memory"); | 72 | asm volatile("nop" ::: "memory"); |
| 55 | case 0: break; | 73 | case 4: |
| 74 | asm volatile("nop" ::: "memory"); | ||
| 75 | case 3: | ||
| 76 | asm volatile("nop" ::: "memory"); | ||
| 77 | case 2: | ||
| 78 | asm volatile("nop" ::: "memory"); | ||
| 79 | case 1: | ||
| 80 | asm volatile("nop" ::: "memory"); | ||
| 81 | case 0: | ||
| 82 | break; | ||
| 56 | } | 83 | } |
| 57 | } | 84 | } |
| 58 | #endif | 85 | #endif |
