Source code of Windows XP (NT5)
You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
|
|
#include "ksia64.h"
.file "mpipis.s" SBTTL("Signal Packet Done") //++ // // VOID // KiIpiSignalPacketDone ( // IN PKIPI_CONTEXT SignalDone // );
// // Routine Description: // // This routine signals that a processor has completed a packet by // clearing the calling processor's set member of the requesting // processor's packet. // // Arguments: // // SignalDone (a0) - Supplies a pointer to the processor block of the // sending processor. // // N.B. The low order bit of signal done is set if the target set // has one and only one bit set. // // Return Value: // // None. // //--
#if !defined(NT_UP)
LEAF_ENTRY(KiIpiSignalPacketDone)
tbit.nz pt0 = a0, 0 dep a0 = 0, a0, 0, 1 ;;
add t1 = PbTargetSet, a0 movl t0 = KiPcr+PcSetMember ;;
(pt0) st4.rel [t1] = r0 // clear target set add t5 = PbPacketBarrier, a0 (pt0) br.ret.spnt brp
ld4.nt1 v0 = [t1] ld4 t3 = [t0] ;;
Kispd10: mov ar.ccv = v0 xor t4 = v0, t3 ;;
cmp.eq pt3, pt4 = 0, t4 ;;
(pt3) st4 [t1] = r0 // last processor clears target set mov t2 = v0
(pt4) cmpxchg4.acq v0 = [t1], t4 (pt3) st4.rel [t5] = r0 // last processor clears barrier (pt3) br.ret.spnt brp ;;
cmp.ne pt1, pt2 = v0, t2 (pt2) br.ret.sptk brp (pt1) br.spnt Kispd10 ;;
LEAF_EXIT(KiIpiSignalPacketDone)
#endif
|