00001
00002
00003
00004
00005
00006
00007
00008
00009
00010
00011
00012
00013
00014
00015
00016
00017
00018
00019
00020
00021
00022
00023
00024
00025
00026
00027
00028
00029
#include "ki.h"
00030
#include "kxia64.h"
00031
00032
00033
00034
00035
00036
00037 ULONG
ProbePalVisibilitySupport=1;
00038 ULONG
NeedPalVisibilitySupport=1;
00039 extern KSPIN_LOCK
KiCacheFlushLock;
00040
00041
00042
00043
00044
VOID
00045
KiSweepDcacheTarget (
00046 IN PULONG SignalDone,
00047 IN PVOID Parameter1,
00048 IN PVOID Parameter2,
00049 IN PVOID Parameter3
00050 );
00051
00052
VOID
00053
KiSweepIcacheTarget (
00054 IN PULONG SignalDone,
00055 IN PVOID Parameter1,
00056 IN PVOID Parameter2,
00057 IN PVOID Parameter3
00058 );
00059
00060
VOID
00061
KiFlushIoBuffersTarget (
00062 IN PKIPI_CONTEXT SignalDone,
00063 IN PVOID Mdl,
00064 IN PVOID ReadOperation,
00065 IN PVOID DmaOperation
00066 );
00067
00068
VOID
00069
KiSyncCacheTarget(
00070 IN PKIPI_CONTEXT SignalDone,
00071 IN PVOID Parameter1,
00072 IN PVOID Parameter2,
00073 IN PVOID Parameter3
00074 );
00075
00076 ULONG_PTR
00077
KiSyncMC_DrainTarget(
00078 );
00079
00080
00081 ULONG_PTR
00082
KiSyncMC_Drain(
00083 IN BOOLEAN AllProcessors,
00084 IN PVOID BaseAddress,
00085 IN ULONG Length
00086 );
00087
00088 ULONG_PTR
00089
KiSyncPrefetchVisibleTarget(
00090 );
00091
00092 ULONG_PTR
00093
KiSyncPrefetchVisible (
00094 IN BOOLEAN AllProcessors,
00095 IN PVOID BaseAddress,
00096 IN ULONG Length
00097 );
00098
00099
00100
00101
00102
VOID
00103 KiSyncCacheTarget (
00104 IN PKIPI_CONTEXT SignalDone,
00105 IN PVOID Parameter1,
00106 IN PVOID Parameter2,
00107 IN PVOID Parameter3
00108 )
00109
00110
00111
00112
00113
00114
00115
00116
00117
00118
00119
00120
00121
00122
00123
00124
00125
00126
00127
00128
00129
00130 {
00131
00132
#if !defined(NT_UP)
00133
00134 __synci();
00135
KiIpiSignalPacketDone(SignalDone);
00136
00137
#endif
00138
return;
00139
00140 }
00141
00142
VOID
00143 KeSweepIcache (
00144 IN BOOLEAN AllProcessors
00145 )
00146
00147
00148
00149
00150
00151
00152
00153
00154
00155
00156
00157
00158
00159
00160
00161
00162
00163
00164
00165
00166
00167
00168
00169
00170 {
00171
00172 KIRQL OldIrql;
00173 KAFFINITY TargetProcessors;
00174
00175
ASSERT(KeGetCurrentIrql() <=
DISPATCH_LEVEL);
00176
00177
#if !defined(NT_UP)
00178
00179
00180
00181
00182
KeAcquireSpinLock(&
KiCacheFlushLock, &OldIrql);
00183
00184
#endif
00185
00186 HalSweepDcache();
00187 HalSweepIcache();
00188
00189
#if !defined(NT_UP)
00190
00191
00192
00193
00194
00195
00196 TargetProcessors =
KeActiveProcessors & PCR->NotMember;
00197
if (TargetProcessors != 0) {
00198
KiIpiSendPacket(TargetProcessors,
00199
KiSweepIcacheTarget,
00200
NULL,
00201
NULL,
00202
NULL);
00203 }
00204
00205
00206
00207
00208
00209
00210
00211
00212
if (TargetProcessors != 0) {
00213
KiIpiStallOnPacketTargets(TargetProcessors);
00214 }
00215
00216
00217
00218
00219
00220
KeReleaseSpinLock(&
KiCacheFlushLock, OldIrql);
00221
00222
#endif
00223
00224
return;
00225 }
00226
00227
VOID
00228 KiSweepIcacheTarget (
00229 IN PULONG SignalDone,
00230 IN PVOID Parameter1,
00231 IN PVOID Parameter2,
00232 IN PVOID Parameter3
00233 )
00234
00235
00236
00237
00238
00239
00240
00241
00242
00243
00244
00245
00246
00247
00248
00249
00250
00251
00252
00253
00254
00255 {
00256
00257
00258
00259
00260
00261
00262
00263
#if !defined(NT_UP)
00264
00265 HalSweepDcache();
00266 HalSweepIcache();
00267
00268
KiIpiSignalPacketDone(SignalDone);
00269
00270
#endif
00271
00272
return;
00273 }
00274
00275
VOID
00276 KeSweepDcache (
00277 IN BOOLEAN AllProcessors
00278 )
00279
00280
00281
00282
00283
00284
00285
00286
00287
00288
00289
00290
00291
00292
00293
00294
00295
00296
00297
00298
00299
00300
00301
00302
00303 {
00304
00305 KIRQL OldIrql;
00306 KAFFINITY TargetProcessors;
00307
00308
ASSERT(KeGetCurrentIrql() <=
DISPATCH_LEVEL);
00309
00310
#if !defined(NT_UP)
00311
00312
00313
00314
00315
KeAcquireSpinLock(&
KiCacheFlushLock, &OldIrql);
00316
00317
#endif
00318
00319 HalSweepDcache();
00320
00321
#if !defined(NT_UP)
00322
00323
00324
00325
00326
00327
00328 TargetProcessors =
KeActiveProcessors & PCR->NotMember;
00329
if (TargetProcessors != 0) {
00330
KiIpiSendPacket(TargetProcessors,
00331
KiSweepDcacheTarget,
00332
NULL,
00333
NULL,
00334
NULL);
00335 }
00336
00337
00338
00339
00340
00341
00342
00343
00344
if (TargetProcessors != 0) {
00345
KiIpiStallOnPacketTargets(TargetProcessors);
00346 }
00347
00348
00349
00350
00351
00352
KeReleaseSpinLock(&
KiCacheFlushLock, OldIrql);
00353
00354
#endif
00355
00356
return;
00357 }
00358
00359
VOID
00360 KiSweepDcacheTarget (
00361 IN PULONG SignalDone,
00362 IN PVOID Parameter1,
00363 IN PVOID Parameter2,
00364 IN PVOID Parameter3
00365 )
00366
00367
00368
00369
00370
00371
00372
00373
00374
00375
00376
00377
00378
00379
00380
00381
00382
00383
00384
00385
00386
00387 {
00388
00389
00390
00391
00392
00393
00394
#if !defined(NT_UP)
00395
00396 HalSweepDcache();
00397
KiIpiSignalPacketDone(SignalDone);
00398
00399
#endif
00400
00401
return;
00402 }
00403
00404
00405
00406 ULONG_PTR
00407 KiSyncMC_DrainTarget(
00408 )
00409
00410
00411
00412
00413
00414
00415
00416
00417
00418
00419
00420
00421
00422
00423
00424
00425
00426
00427
00428
00429 {
00430 ULONG_PTR
Status;
00431
00432
00433
00434
00435
00436
Status = HalCallPal(PAL_MC_DRAIN,
00437 0,
00438 0,
00439 0,
00440 0,
00441 0,
00442 0,
00443 0);
00444
00445
ASSERT(
Status == PAL_STATUS_SUCCESS);
00446
00447
return Status;
00448
00449 }
00450
00451
00452
VOID
00453 KeSweepCacheRange (
00454 IN BOOLEAN AllProcessors,
00455 IN PVOID BaseAddress,
00456 IN ULONG Length
00457 )
00458
00459
00460
00461
00462
00463
00464
00465
00466
00467
00468
00469
00470
00471
00472
00473
00474
00475
00476
00477
00478
00479
00480
00481
00482
00483
00484
00485
00486
00487
00488
00489 {
00490 KIRQL OldIrql;
00491 KAFFINITY TargetProcessors;
00492
00493
00494
00495
00496
00497
00498
00499
00500 HalSweepCacheRange(BaseAddress,Length);
00501
00502
ASSERT(KeGetCurrentIrql() <= KiSynchIrql);
00503
00504
00505
00506
00507
00508
#if !defined(NT_UP)
00509
00510 OldIrql = KeRaiseIrqlToSynchLevel();
00511
00512
00513
00514
00515
00516
00517 TargetProcessors =
KeActiveProcessors & PCR->NotMember;
00518
if (TargetProcessors != 0) {
00519
KiIpiSendPacket(TargetProcessors,
00520
KiSyncCacheTarget,
00521
NULL,
00522
NULL,
00523
NULL);
00524 }
00525
00526
#endif
00527
00528
00529
00530
00531
00532 __synci();
00533 __isrlz();
00534
00535
00536
00537
00538
00539
00540
#if !defined(NT_UP)
00541
00542
if (TargetProcessors != 0) {
00543
KiIpiStallOnPacketTargets(TargetProcessors);
00544 }
00545
00546
00547
00548
00549
00550
KeLowerIrql(OldIrql);
00551
00552
#endif
00553
00554
return;
00555
00556 }
00557
00558
VOID
00559 KeSweepIcacheRange (
00560 IN BOOLEAN AllProcessors,
00561 IN PVOID BaseAddress,
00562 IN ULONG Length
00563 )
00564
00565
00566
00567
00568
00569
00570
00571
00572
00573
00574
00575
00576
00577
00578
00579
00580
00581
00582
00583
00584
00585
00586
00587
00588
00589
00590
00591
00592
00593
00594
00595
00596
00597
00598
00599
00600
00601 {
00602 KIRQL OldIrql;
00603 KAFFINITY TargetProcessors;
00604
00605
00606
00607
00608
00609
00610
00611
00612 HalSweepIcacheRange(BaseAddress,Length);
00613
00614
ASSERT(KeGetCurrentIrql() <= KiSynchIrql);
00615
00616
00617
00618
00619
00620
#if !defined(NT_UP)
00621
00622 OldIrql = KeRaiseIrqlToSynchLevel();
00623
00624
00625
00626
00627
00628
00629 TargetProcessors =
KeActiveProcessors & PCR->NotMember;
00630
if (TargetProcessors != 0) {
00631
KiIpiSendPacket(TargetProcessors,
00632
KiSyncCacheTarget,
00633
NULL,
00634
NULL,
00635
NULL);
00636 }
00637
00638
#endif
00639
00640
00641
00642
00643
00644 __synci();
00645 __isrlz();
00646
00647
00648
00649
00650
00651
00652
#if !defined(NT_UP)
00653
00654
if (TargetProcessors != 0) {
00655
KiIpiStallOnPacketTargets(TargetProcessors);
00656 }
00657
00658
00659
00660
00661
00662
KeLowerIrql(OldIrql);
00663
00664
#endif
00665
00666
return;
00667
00668
00669 }
00670
00671
00672
00673
VOID
00674 KeSweepDcacheRange (
00675 IN BOOLEAN AllProcessors,
00676 IN PVOID BaseAddress,
00677 IN ULONG Length
00678 )
00679
00680
00681
00682
00683
00684
00685
00686
00687
00688
00689
00690
00691
00692
00693
00694
00695
00696
00697
00698
00699
00700
00701
00702
00703
00704
00705
00706
00707
00708
00709
00710
00711
00712
00713
00714
00715
00716 {
00717 KIRQL OldIrql;
00718 KAFFINITY TargetProcessors;
00719
00720
00721
00722
00723
00724
00725
00726
00727 HalSweepDcacheRange(BaseAddress,Length);
00728
00729
ASSERT(KeGetCurrentIrql() <= KiSynchIrql);
00730
00731
00732
00733
00734
00735
#if !defined(NT_UP)
00736
00737 OldIrql = KeRaiseIrqlToSynchLevel();
00738
00739
00740
00741
00742
00743
00744 TargetProcessors =
KeActiveProcessors & PCR->NotMember;
00745
if (TargetProcessors != 0) {
00746
KiIpiSendPacket(TargetProcessors,
00747
KiSyncCacheTarget,
00748
NULL,
00749
NULL,
00750
NULL);
00751 }
00752
00753
#endif
00754
00755
00756
00757
00758
00759 __synci();
00760 __isrlz();
00761
00762
00763
00764
00765
00766
00767
#if !defined(NT_UP)
00768
00769
if (TargetProcessors != 0) {
00770
KiIpiStallOnPacketTargets(TargetProcessors);
00771 }
00772
00773
00774
00775
00776
00777
KeLowerIrql(OldIrql);
00778
00779
#endif
00780
00781
return;
00782
00783
00784 }
00785
00786 ULONG_PTR
00787 KiSyncMC_Drain (
00788 IN BOOLEAN AllProcessors,
00789 IN PVOID BaseAddress,
00790 IN ULONG Length
00791 )
00792
00793
00794
00795
00796
00797
00798
00799
00800
00801
00802
00803
00804
00805
00806
00807
00808
00809
00810
00811
00812
00813
00814
00815
00816
00817
00818
00819 {
00820 ULONG_PTR
Status;
00821
00822
00823
00824
00825
Status = (
KiIpiGenericCall (
00826 (
PKIPI_BROADCAST_WORKER)
KiSyncMC_DrainTarget,
00827 (ULONG_PTR)
NULL)
00828 );
00829
00830
ASSERT(
Status == PAL_STATUS_SUCCESS);
00831
00832
return Status;
00833
00834
00835 }
00836
00837 ULONG_PTR
00838 KiSyncPrefetchVisibleTarget(
00839 )
00840
00841
00842
00843
00844
00845
00846
00847
00848
00849
00850
00851
00852
00853
00854
00855
00856
00857
00858
00859 {
00860 ULONG_PTR
Status;
00861
00862
00863
00864
00865
00866
Status = HalCallPal(PAL_PREFETCH_VISIBILITY,
00867 0,
00868 0,
00869 0,
00870 0,
00871 0,
00872 0,
00873 0);
00874
00875
00876
ASSERT(
Status != PAL_STATUS_ERROR);
00877
00878
return Status;
00879
00880 }
00881
00882
00883
00884 ULONG_PTR
00885 KiSyncPrefetchVisible (
00886 IN BOOLEAN AllProcessors,
00887 IN PVOID BaseAddress,
00888 IN ULONG Length
00889 )
00890
00891
00892
00893
00894
00895
00896
00897
00898
00899
00900
00901
00902
00903
00904
00905
00906
00907
00908
00909
00910
00911
00912
00913
00914
00915
00916
00917
00918
00919
00920
00921
00922
00923
00924
00925
00926 {
00927 ULONG_PTR
Status;
00928
00929
switch (
ProbePalVisibilitySupport) {
00930
case 0:
00931
if (
NeedPalVisibilitySupport == 0)
00932
return PAL_STATUS_SUPPORT_NOT_NEEDED;
00933
else {
00934
Status = (
KiIpiGenericCall (
00935 (
PKIPI_BROADCAST_WORKER)
KiSyncPrefetchVisibleTarget,
00936 (ULONG_PTR)
NULL)
00937 );
00938
00939
ASSERT(
Status != PAL_STATUS_ERROR);
00940
return Status;
00941
00942 }
00943
break;
00944
00945
case 1:
00946
Status =
KiSyncPrefetchVisibleTarget();
00947
00948
ASSERT(
Status != PAL_STATUS_ERROR);
00949
00950
ProbePalVisibilitySupport = 0;
00951
00952
if (
Status == PAL_STATUS_SUPPORT_NOT_NEEDED) {
00953
NeedPalVisibilitySupport = 0;
00954
return PAL_STATUS_SUPPORT_NOT_NEEDED;
00955 }
else {
00956
00957
00958
Status = (
KiIpiGenericCall (
00959 (
PKIPI_BROADCAST_WORKER)
KiSyncPrefetchVisibleTarget,
00960 (ULONG_PTR)
NULL)
00961 );
00962
00963
ASSERT(
Status != PAL_STATUS_ERROR);
00964
00965
return Status;
00966
00967 }
00968
00969
break;
00970
00971 }
00972
00973
00974 }
00975
00976
00977
00978
VOID
00979 KeSweepCacheRangeWithDrain (
00980 IN BOOLEAN AllProcessors,
00981 IN PVOID BaseAddress,
00982 IN ULONG Length
00983 )
00984
00985
00986
00987
00988
00989
00990
00991
00992
00993
00994
00995
00996
00997
00998
00999
01000
01001
01002
01003
01004
01005
01006
01007
01008
01009
01010
01011 {
01012 ULONG_PTR
Status;
01013
01014
Status =
KiSyncPrefetchVisible(
01015 AllProcessors,
01016 BaseAddress,
01017 Length
01018 );
01019
01020
ASSERT(
Status != PAL_STATUS_ERROR);
01021
01022
01023
KeSweepCacheRange (
01024 AllProcessors,
01025 BaseAddress,
01026 Length
01027 );
01028
01029
Status =
KiSyncMC_Drain (
01030 AllProcessors,
01031 BaseAddress,
01032 Length
01033 );
01034
01035
ASSERT(
Status == PAL_STATUS_SUCCESS);
01036
01037
return;
01038
01039
01040 }
01041