Commit Graph

1655 Commits

Author SHA1 Message Date
97703c7932 Add stub for System Service Descriptor Table accessor routine 2026-06-12 23:16:20 +02:00
2f5902119d Update thread initialization code 2026-06-12 20:52:23 +02:00
7a10135731 Replace jmp with call to maintain ABI stack alignment 2026-06-12 15:58:42 +02:00
b0074637f8 Remove hardcoded shift in SIPI vector calculation 2026-06-12 14:21:27 +02:00
1a062ca05f Trigger low memory allocation before PFN database initialization 2026-06-12 13:21:22 +02:00
c702152cca Refactor real-mode memory allocation and identity mapping for AP trampoline 2026-06-12 13:16:48 +02:00
81c799e590 Fix TrampolineCodeSize variable type 2026-06-12 12:59:16 +02:00
cf0d7f0a40 Update trampoline size output parameter to PULONG across bootloader and kernel 2026-06-12 12:54:53 +02:00
b0d2868f82 Update PTE mapping to allocate from PFN database 2026-06-12 08:54:51 +02:00
32f0b747a1 Convert dispatcher context switch functions to naked assembly 2026-06-10 16:48:54 +02:00
c57aa98923 Free affinity maps on allocation failure and remove redundant idle process affinity loop 2026-06-10 14:08:07 +02:00
429e4ef6f1 Add bounds checking to affinity map bit operations and introduce InitializeAffinityMap 2026-06-10 12:51:05 +02:00
39928f2ef4 Add documentation for InitializeProcessorAffinity 2026-06-10 12:11:03 +02:00
51ec7e3bab Fix build by initializing thread dispatcher header 2026-06-10 11:56:49 +02:00
f3ae70573c Initialize dispatcher header 2026-06-10 11:46:26 +02:00
830f84ab26 Pass initial affinity map to InitializeProcess 2026-06-10 11:27:25 +02:00
5a9df7ca86 Add helper to set full system processor affinity mask 2026-06-10 11:13:28 +02:00
4bcdcda3a0 Change ActiveProcessors to a pointer for dynamic allocation 2026-06-10 10:31:24 +02:00
7a27912dac Dynamically allocate active processors affinity map 2026-06-10 10:22:15 +02:00
cf4b91ac83 Simplify active processor bit setting 2026-06-09 23:27:24 +02:00
36c3d92399 Refactor idle thread initialization 2026-06-09 23:24:40 +02:00
6a2a35c008 Refactor idle process initialization 2026-06-09 23:17:03 +02:00
a9202f5b57 Refactor CalculateAffinityMapSize and add CreateAffinityMap 2026-06-09 22:53:37 +02:00
4cbefe3a22 Implement affinity map bit manipulation and memory sizing helpers 2026-06-09 20:17:47 +02:00
3841ceaf5b Refactor processor affinity logic 2026-06-09 19:33:20 +02:00
e2eb784eef Enter idle loop instead of halting system 2026-06-09 09:39:17 +02:00
6078a5ba29 Implement idle thread loop 2026-06-09 08:36:39 +02:00
663f5cd048 Drop obsolete IPI exception dispatch path 2026-06-08 20:55:17 +02:00
5999906bf0 Switch CPU exception IDT entries to interrupt gates to mask interrupts on entry 2026-06-08 20:46:51 +02:00
1e0c1490fb Remove redundant IDT gate initialization for vector 0xE1 2026-06-08 20:41:02 +02:00
5b0eebdb43 Initialize system interrupt handlers 2026-06-08 20:15:18 +02:00
9e64939de4 Add XTCLINK linkage to KeStartXtSystem 2026-06-08 20:06:23 +02:00
b911670121 Freeze secondary processors during kernel panic 2026-06-08 15:02:55 +02:00
d175a817a5 Add IPI service routines for APC, DPC, and freeze request handling 2026-06-08 14:49:02 +02:00
b285bc7312 Implement multi-processor freeze and thaw execution for SMP crash state synchronization 2026-06-08 14:38:17 +02:00
c8cd198c4e Fix Task Register restoration by clearing busy bit in TSS descriptor 2026-06-08 13:40:20 +02:00
95d45f5a0a Do not restore Task Register during AMD64 processor control state restoration 2026-06-08 13:05:24 +02:00
766e4d9603 Register BSP in processor block array during initialization 2026-06-08 11:21:53 +02:00
a601fd0afa Mark BSP processor as started 2026-06-08 10:22:41 +02:00
cc23e459e0 Move SwitchProcessor to architecture-specific implementations 2026-06-07 22:53:00 +02:00
d36b678ba1 Add kd/debug.cc to xtoskrnl source list 2026-06-07 22:41:31 +02:00
43265bcddb Bypass debug I/O locks during kernel panic or debugger session 2026-06-07 22:37:59 +02:00
47d4069d6f Add functions to save and restore processor context and control state 2026-06-07 20:33:02 +02:00
904df63198 Remove duplicate context flag definitions 2026-06-07 19:40:29 +02:00
1df971a71e Extend CONTEXT and PRCB structures with context flags and IPI state fields 2026-06-07 18:47:48 +02:00
2a413d5717 Update processor state save calls 2026-06-07 13:11:04 +02:00
9c2357dfe6 Expose installed CPU count and rename state save function 2026-06-07 13:05:31 +02:00
f82562f450 Rename SwitchCpu to SwitchProcessor 2026-06-07 12:33:56 +02:00
a33b63842a Add IPI definitions and frozen states, change KAFFINITY_MAP to flexible array 2026-06-07 12:13:55 +02:00
4256a312ae Implement kernel debugger entry point 2026-06-07 02:04:27 +02:00