Files
RedBear-OS/local/patches/kernel/P15-10-tlb-range-ordering.patch
T
vasilito cee25393d8 fix: boot process improvements — dependency cycle, INIT_NOTIFY, probing loop, and log spam fixes
- Fix P15-8-init-cycle-detection.patch: replace visiting+error with seen+silent-skip
  to eliminate 11 false-positive 'dependency cycle detected' errors on shared deps
- Fix P0-daemon-fix-init-notify-unwrap.patch: remove eprintln! for missing
  INIT_NOTIFY (expected for oneshot_async services, ~7 daemons affected)
- Fix driver-manager hotplug loop: add PERMANENTLY_SKIPPED static set shared
  between hotplug handler and DriverConfig::probe() to stop infinite re-probing
  of Fatal/NotSupported/deferred-exhausted device+driver pairs (e.g. ided)
- Fix driver-manager log_timeline: suppress repeated EPIPE/ENOENT errors with
  AtomicI32 dedup and AtomicBool one-shot guards for boot timeline JSON
- Add driver-manager SIGTERM handler, ACPI bus registration, --status mode,
  driver reap loop, graceful shutdown, and reduced deferred retries (30→3)
2026-05-17 12:34:02 +03:00

30 lines
1.3 KiB
Diff

--- a/src/percpu.rs
+++ b/src/percpu.rs
@@ -142,9 +142,10 @@
core::hint::spin_loop();
}
}
- // Full flush — clear range info
- percpublock.tlb_flush_start.store(0, Ordering::Relaxed);
- percpublock.tlb_flush_count.store(0, Ordering::Relaxed);
+ // Full flush — clear range info (Release ordering ensures the flag
+ // swap and these stores are visible to the handler before the IPI).
+ percpublock.tlb_flush_start.store(0, Ordering::Release);
+ percpublock.tlb_flush_count.store(0, Ordering::Release);
crate::ipi::ipi_single(crate::ipi::IpiKind::Tlb, percpublock);
} else {
@@ -175,9 +176,9 @@
hint::spin_loop();
}
}
- // Full flush — clear range info
- percpublock.tlb_flush_start.store(0, Ordering::Relaxed);
- percpublock.tlb_flush_count.store(0, Ordering::Relaxed);
+ // Full flush — clear range info (Release ordering)
+ percpublock.tlb_flush_start.store(0, Ordering::Release);
+ percpublock.tlb_flush_count.store(0, Ordering::Release);
}
// Single broadcast IPI to all other CPUs using destination shorthand
crate::ipi::ipi(crate::ipi::IpiKind::Tlb, crate::ipi::IpiTarget::Other);