Changeset bea6233 in mainline
- Timestamp:
- 2023-02-26T15:27:13Z (23 months ago)
- Branches:
- master, ticket/834-toolchain-update, topic/msim-upgrade, topic/simplify-dev-export
- Children:
- 7cf5ddb
- Parents:
- deed510
- git-author:
- Jiří Zárevúcky <zarevucky.jiri@…> (2023-02-26 15:18:02)
- git-committer:
- Jiří Zárevúcky <zarevucky.jiri@…> (2023-02-26 15:27:13)
- Location:
- kernel
- Files:
-
- 11 edited
Legend:
- Unmodified
- Added
- Removed
-
kernel/arch/abs32le/include/arch/asm.h
rdeed510 rbea6233 197 197 } 198 198 199 /** Enables interrupts and blocks until an interrupt arrives, 200 * atomically if possible on target architecture. 201 * Disables interrupts again before returning to caller. 202 */ 203 _NO_TRACE static inline void cpu_interruptible_sleep(void) 204 { 205 interrupts_enable(); 206 cpu_sleep(); 207 interrupts_disable(); 208 } 209 199 210 #endif 200 211 -
kernel/arch/amd64/include/arch/asm.h
rdeed510 rbea6233 43 43 #define IO_SPACE_BOUNDARY ((void *) (64 * 1024)) 44 44 45 _NO_TRACE static inline void cpu_sleep(void) 46 { 47 asm volatile ( 45 /** Enables interrupts and blocks until an interrupt arrives, 46 * atomically if possible on target architecture. 47 * Disables interrupts again before returning to caller. 48 */ 49 _NO_TRACE static inline void cpu_interruptible_sleep() 50 { 51 /* 52 * On x86, "sti" enables interrupts after the next instruction. 53 * Therefore, this sequence is guaranteed to be atomic. 54 */ 55 asm volatile ( 56 "sti\n" 48 57 "hlt\n" 58 "cli\n" 49 59 ); 50 60 } -
kernel/arch/arm32/include/arch/asm.h
rdeed510 rbea6233 65 65 } 66 66 67 /** Enables interrupts and blocks until an interrupt arrives, 68 * atomically if possible on target architecture. 69 * Disables interrupts again before returning to caller. 70 */ 71 _NO_TRACE static inline void cpu_interruptible_sleep(void) 72 { 73 // FIXME: do this atomically 74 interrupts_enable(); 75 cpu_sleep(); 76 interrupts_disable(); 77 } 78 67 79 _NO_TRACE static inline void cpu_spin_hint(void) 68 80 { -
kernel/arch/arm64/include/arch/asm.h
rdeed510 rbea6233 52 52 { 53 53 asm volatile ("wfe"); 54 } 55 56 /** Enables interrupts and blocks until an interrupt arrives, 57 * atomically if possible on target architecture. 58 * Disables interrupts again before returning to caller. 59 */ 60 _NO_TRACE static inline void cpu_interruptible_sleep(void) 61 { 62 // FIXME: do this atomically 63 interrupts_enable(); 64 cpu_sleep(); 65 interrupts_disable(); 54 66 } 55 67 -
kernel/arch/ia32/include/arch/asm.h
rdeed510 rbea6233 57 57 } 58 58 59 _NO_TRACE static inline void cpu_sleep(void) 60 { 61 asm volatile ( 59 /** Enables interrupts and blocks until an interrupt arrives, 60 * atomically if possible on target architecture. 61 * Disables interrupts again before returning to caller. 62 */ 63 _NO_TRACE static inline void cpu_interruptible_sleep(void) 64 { 65 asm volatile ( 66 "sti\n" 62 67 "hlt\n" 68 "cli\n" 63 69 ); 64 70 } -
kernel/arch/ia64/include/arch/asm.h
rdeed510 rbea6233 473 473 uint64_t, uint64_t); 474 474 475 /** Enables interrupts and blocks until an interrupt arrives, 476 * atomically if possible on target architecture. 477 * Disables interrupts again before returning to caller. 478 */ 479 _NO_TRACE static inline void cpu_interruptible_sleep(void) 480 { 481 // FIXME: do this properly 482 interrupts_enable(); 483 cpu_sleep(); 484 interrupts_disable(); 485 } 486 475 487 #endif 476 488 -
kernel/arch/mips32/include/arch/asm.h
rdeed510 rbea6233 89 89 extern bool interrupts_disabled(void); 90 90 91 /** Enables interrupts and blocks until an interrupt arrives, 92 * atomically if possible on target architecture. 93 * Disables interrupts again before returning to caller. 94 */ 95 _NO_TRACE static inline void cpu_interruptible_sleep(void) 96 { 97 // FIXME: do this atomically 98 interrupts_enable(); 99 cpu_sleep(); 100 interrupts_disable(); 101 } 102 91 103 #endif 92 104 -
kernel/arch/ppc32/include/arch/asm.h
rdeed510 rbea6233 167 167 } 168 168 169 _NO_TRACE static inline void cpu_sleep(void) 170 { 169 /** Enables interrupts and blocks until an interrupt arrives, 170 * atomically if possible on target architecture. 171 * Disables interrupts again before returning to caller. 172 */ 173 _NO_TRACE static inline void cpu_interruptible_sleep(void) 174 { 175 // FIXME: do this properly 176 interrupts_enable(); 177 interrupts_disable(); 171 178 } 172 179 -
kernel/arch/riscv64/include/arch/asm.h
rdeed510 rbea6233 95 95 } 96 96 97 _NO_TRACE static inline void cpu_sleep(void) 97 /** Enables interrupts and blocks until an interrupt arrives, 98 * atomically if possible on target architecture. 99 * Disables interrupts again before returning to caller. 100 */ 101 _NO_TRACE static inline void cpu_interruptible_sleep(void) 98 102 { 103 // FIXME: do this properly 104 interrupts_enable(); 105 interrupts_disable(); 99 106 } 100 107 -
kernel/arch/sparc64/include/arch/asm.h
rdeed510 rbea6233 539 539 extern void switch_to_userspace(uint64_t pc, uint64_t sp, uint64_t uarg); 540 540 541 /** Enables interrupts and blocks until an interrupt arrives, 542 * atomically if possible on target architecture. 543 * Disables interrupts again before returning to caller. 544 */ 545 _NO_TRACE static inline void cpu_interruptible_sleep(void) 546 { 547 // FIXME: do this atomically 548 interrupts_enable(); 549 cpu_sleep(); 550 interrupts_disable(); 551 } 552 541 553 #endif 542 554 -
kernel/generic/src/proc/scheduler.c
rdeed510 rbea6233 187 187 188 188 loop: 189 190 189 if (atomic_load(&CPU->nrdy) == 0) { 191 190 /* … … 197 196 CPU->idle = true; 198 197 irq_spinlock_unlock(&CPU->lock, false); 199 interrupts_enable();200 198 201 199 /* 202 * An interrupt might occur right now and wake up a thread. 203 * In such case, the CPU will continue to go to sleep 204 * even though there is a runnable thread. 200 * Go to sleep with interrupts enabled. 201 * Ideally, this should be atomic, but this is not guaranteed on 202 * all platforms yet, so it is possible we will go sleep when 203 * a thread has just become available. 205 204 */ 206 cpu_sleep(); 207 interrupts_disable(); 205 cpu_interruptible_sleep(); 206 207 /* Interrupts are disabled again. */ 208 208 goto loop; 209 209 }
Note:
See TracChangeset
for help on using the changeset viewer.