Commit Graph

217 Commits

Author SHA1 Message Date
f79c9023d8 Initialize thread service table 2026-06-12 23:19:05 +02:00
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
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
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
7a27912dac Dynamically allocate active processors affinity map 2026-06-10 10:22:15 +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
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
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
47d4069d6f Add functions to save and restore processor context and control state 2026-06-07 20:33:02 +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
678a0f4f48 Add static member definitions for kernel debugger active flag and kernel panic state 2026-06-06 19:00:49 +02:00
537fbc8af4 Track kernel panic state 2026-06-06 18:52:05 +02:00
f680830b53 Implement resource cleanup for failed allocations during idle thread setup 2026-06-04 14:36:43 +02:00
53a239958f Propagate allocation failures from idle process and thread setup 2026-06-04 14:30:01 +02:00
75e7760d04 Delegate idle process and thread setup to PS subsystem 2026-06-04 13:14:21 +02:00
81fdf1f77a Allocate executive thread structure for idle thread and assign PRCB pointers 2026-06-04 11:57:58 +02:00
631f58bf72 Update InitializeProcess doxygen 2026-06-04 11:57:56 +02:00
1d2d66fc83 Dedicated Idle process and thread initialization with dynamic affinity allocation 2026-06-04 11:57:49 +02:00
65e86db731 Migrate thread affinity from GROUP_AFFINITY to KAFFINITY_MAP 2026-06-01 22:28:21 +02:00
615d253bb4 Update initial thread and process affinity assignment to use group-aware structures 2026-06-01 20:40:34 +02:00
2fcbc7bee8 Implement processor affinity search functions 2026-06-01 01:10:40 +02:00
2c14da997d Convert process affinity assignment to KAFFINITY_MAP 2026-06-01 01:06:13 +02:00
7d8b33390a Add runtime accounting and DPC throttling 2026-05-30 23:53:47 +02:00
5a5604c35d Register dispatch interrupt handler 2026-05-28 23:50:02 +02:00
addf9addab Verify system timer expiration on every clock interrupt 2026-05-28 00:38:49 +02:00
f562aa0874 Implement timer table list and check for expired timers 2026-05-28 00:36:25 +02:00
19a9dfe7c6 Add PrcbLock and runtime counters to KPROCESSOR_CONTROL_BLOCK 2026-05-27 23:15:19 +02:00
6b689baa7a Rename initial stack reserve macro to KTHREAD_STACK_OFFSET 2026-05-22 19:21:28 +02:00
102b357a75 Simplify thread frame setup using pointer arithmetic 2026-05-22 18:42:41 +02:00
6eb0b4d982 Unify initial stack reservation size calculation 2026-05-22 18:40:07 +02:00
d8cb7c9242 Initialize per-CPU spin lock queues during AP bootstrap 2026-05-22 15:27:59 +02:00