Commit 3e28af3
feat: Add cross-platform deterministic math via fdlibm
Replace hardware-dependent x87 FPU trig functions (fsin, fcos) in
WWMath with fdlibm 5.3 — a portable, bit-exact IEEE 754 C implementation.
This ensures lockstep CRC parity between macOS ARM64/x64 and Windows x86
clients, eliminating multiplayer desyncs caused by floating-point
precision divergence.
Changes:
- Integrate fdlibm 5.3 via FetchContent from Okladnoj/fdlibm-deterministic
- Replace all x87 asm blocks in wwmath.h with fdlibm wrappers
- Route ~80+ direct sin/cos/sqrt/atan2 calls in GameLogic through WWMath
- Replace Inv_Sqrt Quake-era hack with 1.0f/WWMath::Sqrt()
- Gate all changes behind USE_DETERMINISTIC_MATH (RETAIL_COMPATIBLE_CRC)
- Clean Weapon.cpp diff to contain only functional WWMath replacements
- Preserve Fast_Sin/Fast_Cos LUT (already deterministic)
- Leave render/UI layer (GameClient, WW3D2) on system math (no CRC impact)
- Add SimulationMathCrc dual-path diagnostic (fdlibm vs system math)1 parent b7fcf9f commit 3e28af3
14 files changed
Lines changed: 119 additions & 201 deletions
File tree
- Core/Libraries/Source/WWVegas/WWMath
- GeneralsMD/Code/GameEngine/Source
- Common/System
- GameLogic
- AI
- Object
- Update
- cmake
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
64 | 64 | | |
65 | 65 | | |
66 | 66 | | |
| 67 | + | |
67 | 68 | | |
68 | 69 | | |
69 | 70 | | |
| |||
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
89 | 89 | | |
90 | 90 | | |
91 | 91 | | |
| 92 | + | |
92 | 93 | | |
93 | 94 | | |
94 | 95 | | |
| |||
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
39 | 39 | | |
40 | 40 | | |
41 | 41 | | |
| 42 | + | |
42 | 43 | | |
43 | 44 | | |
44 | 45 | | |
| |||
104 | 105 | | |
105 | 106 | | |
106 | 107 | | |
| 108 | + | |
107 | 109 | | |
108 | 110 | | |
| 111 | + | |
109 | 112 | | |
110 | | - | |
111 | | - | |
112 | | - | |
113 | | - | |
114 | | - | |
115 | | - | |
116 | | - | |
117 | 113 | | |
118 | 114 | | |
119 | 115 | | |
120 | 116 | | |
121 | 117 | | |
122 | | - | |
123 | 118 | | |
124 | 119 | | |
125 | 120 | | |
| |||
133 | 128 | | |
134 | 129 | | |
135 | 130 | | |
136 | | - | |
137 | | - | |
| 131 | + | |
| 132 | + | |
| 133 | + | |
| 134 | + | |
| 135 | + | |
| 136 | + | |
| 137 | + | |
| 138 | + | |
| 139 | + | |
| 140 | + | |
138 | 141 | | |
139 | 142 | | |
140 | 143 | | |
141 | 144 | | |
142 | | - | |
| 145 | + | |
143 | 146 | | |
144 | 147 | | |
145 | 148 | | |
| |||
313 | 316 | | |
314 | 317 | | |
315 | 318 | | |
316 | | - | |
317 | | - | |
318 | | - | |
319 | | - | |
320 | | - | |
321 | | - | |
322 | | - | |
323 | | - | |
324 | | - | |
325 | | - | |
326 | | - | |
327 | | - | |
328 | | - | |
329 | 319 | | |
330 | 320 | | |
331 | | - | |
| 321 | + | |
332 | 322 | | |
333 | | - | |
334 | 323 | | |
335 | 324 | | |
336 | 325 | | |
337 | | - | |
338 | | - | |
339 | | - | |
340 | | - | |
341 | | - | |
342 | | - | |
343 | | - | |
344 | | - | |
| 326 | + | |
345 | 327 | | |
346 | 328 | | |
347 | 329 | | |
348 | 330 | | |
349 | 331 | | |
350 | 332 | | |
351 | | - | |
352 | | - | |
353 | | - | |
354 | | - | |
355 | | - | |
356 | | - | |
357 | | - | |
358 | | - | |
359 | | - | |
360 | | - | |
361 | | - | |
362 | | - | |
363 | 333 | | |
364 | 334 | | |
365 | | - | |
| 335 | + | |
366 | 336 | | |
367 | | - | |
368 | 337 | | |
369 | 338 | | |
370 | 339 | | |
371 | 340 | | |
372 | 341 | | |
373 | | - | |
374 | | - | |
375 | | - | |
376 | | - | |
377 | | - | |
378 | | - | |
379 | | - | |
380 | | - | |
381 | | - | |
382 | | - | |
383 | | - | |
384 | | - | |
385 | 342 | | |
386 | 343 | | |
387 | | - | |
| 344 | + | |
388 | 345 | | |
389 | | - | |
390 | 346 | | |
391 | 347 | | |
392 | 348 | | |
| |||
516 | 472 | | |
517 | 473 | | |
518 | 474 | | |
519 | | - | |
| 475 | + | |
520 | 476 | | |
521 | 477 | | |
522 | 478 | | |
| |||
553 | 509 | | |
554 | 510 | | |
555 | 511 | | |
556 | | - | |
| 512 | + | |
557 | 513 | | |
558 | 514 | | |
559 | 515 | | |
560 | 516 | | |
561 | 517 | | |
562 | 518 | | |
563 | | - | |
564 | | - | |
565 | | - | |
566 | | - | |
567 | | - | |
568 | | - | |
569 | | - | |
570 | | - | |
571 | | - | |
572 | | - | |
573 | | - | |
574 | | - | |
575 | 519 | | |
576 | 520 | | |
577 | | - | |
| 521 | + | |
578 | 522 | | |
579 | | - | |
580 | 523 | | |
| 524 | + | |
581 | 525 | | |
582 | 526 | | |
583 | 527 | | |
| |||
603 | 547 | | |
604 | 548 | | |
605 | 549 | | |
| 550 | + | |
606 | 551 | | |
607 | 552 | | |
608 | 553 | | |
609 | 554 | | |
610 | 555 | | |
611 | | - | |
612 | | - | |
613 | | - | |
614 | | - | |
615 | | - | |
616 | | - | |
617 | | - | |
618 | | - | |
619 | | - | |
620 | | - | |
621 | | - | |
622 | | - | |
623 | | - | |
624 | | - | |
625 | | - | |
626 | | - | |
627 | | - | |
628 | | - | |
629 | | - | |
630 | | - | |
631 | | - | |
632 | | - | |
633 | | - | |
634 | | - | |
635 | | - | |
636 | | - | |
637 | | - | |
638 | | - | |
639 | | - | |
640 | | - | |
641 | | - | |
642 | | - | |
643 | | - | |
644 | | - | |
645 | | - | |
646 | | - | |
647 | | - | |
648 | | - | |
649 | | - | |
650 | | - | |
651 | | - | |
652 | | - | |
653 | | - | |
654 | | - | |
655 | | - | |
656 | | - | |
657 | | - | |
658 | | - | |
659 | | - | |
660 | | - | |
661 | | - | |
662 | | - | |
663 | | - | |
| 556 | + | |
664 | 557 | | |
665 | | - | |
| 558 | + | |
666 | 559 | | |
667 | | - | |
668 | 560 | | |
669 | 561 | | |
670 | 562 | | |
| |||
Lines changed: 7 additions & 5 deletions
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
31 | 31 | | |
32 | 32 | | |
33 | 33 | | |
| 34 | + | |
| 35 | + | |
34 | 36 | | |
35 | 37 | | |
36 | 38 | | |
| |||
806 | 808 | | |
807 | 809 | | |
808 | 810 | | |
809 | | - | |
810 | | - | |
| 811 | + | |
| 812 | + | |
811 | 813 | | |
812 | 814 | | |
813 | 815 | | |
| |||
854 | 856 | | |
855 | 857 | | |
856 | 858 | | |
857 | | - | |
858 | | - | |
| 859 | + | |
| 860 | + | |
859 | 861 | | |
860 | 862 | | |
861 | 863 | | |
| |||
1435 | 1437 | | |
1436 | 1438 | | |
1437 | 1439 | | |
1438 | | - | |
| 1440 | + | |
1439 | 1441 | | |
1440 | 1442 | | |
1441 | 1443 | | |
| |||
Lines changed: 12 additions & 11 deletions
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
31 | 31 | | |
32 | 32 | | |
33 | 33 | | |
| 34 | + | |
34 | 35 | | |
35 | 36 | | |
36 | 37 | | |
| |||
173 | 174 | | |
174 | 175 | | |
175 | 176 | | |
176 | | - | |
| 177 | + | |
177 | 178 | | |
178 | 179 | | |
179 | 180 | | |
180 | 181 | | |
181 | 182 | | |
182 | 183 | | |
183 | | - | |
| 184 | + | |
184 | 185 | | |
185 | 186 | | |
186 | | - | |
| 187 | + | |
187 | 188 | | |
188 | 189 | | |
189 | 190 | | |
| |||
279 | 280 | | |
280 | 281 | | |
281 | 282 | | |
282 | | - | |
283 | | - | |
| 283 | + | |
| 284 | + | |
284 | 285 | | |
285 | 286 | | |
286 | 287 | | |
| |||
329 | 330 | | |
330 | 331 | | |
331 | 332 | | |
332 | | - | |
| 333 | + | |
333 | 334 | | |
334 | 335 | | |
335 | 336 | | |
| |||
361 | 362 | | |
362 | 363 | | |
363 | 364 | | |
364 | | - | |
| 365 | + | |
365 | 366 | | |
366 | 367 | | |
367 | 368 | | |
| |||
398 | 399 | | |
399 | 400 | | |
400 | 401 | | |
401 | | - | |
402 | | - | |
| 402 | + | |
| 403 | + | |
403 | 404 | | |
404 | 405 | | |
405 | 406 | | |
| |||
506 | 507 | | |
507 | 508 | | |
508 | 509 | | |
509 | | - | |
510 | | - | |
| 510 | + | |
| 511 | + | |
511 | 512 | | |
512 | 513 | | |
513 | 514 | | |
| |||
0 commit comments