1
0
atdalīts no xt-sys/exectos

Implement memory barriers

Šī revīzija ir iekļauta:
2024-02-04 22:10:37 +01:00
vecāks ec81294eba
revīzija 9ce841e957
4 mainīti faili ar 85 papildinājumiem un 0 dzēšanām

Parādīt failu

@@ -271,6 +271,23 @@ ArLoadTaskRegister(USHORT Source)
: "rm" (Source));
}
/**
* Orders memory accesses as seen by other processors.
*
* @return This routine does not return any value.
*
* @since XT 1.0
*/
XTCDECL
VOID
ArMemoryBarrier()
{
LONG Barrier;
asm volatile("lock; orl $0, %0;"
:
: "m"(Barrier));
}
/**
* Reads the specified CPU control register and returns its value.
*
@@ -485,6 +502,23 @@ ArReadTimeStampCounter()
return ((ULONGLONG)High << 32) | Low;
}
/**
* Orders memory accesses as seen by other processors, without fence.
*
* @return This routine does not return any value.
*
* @since XT 1.0
*/
XTCDECL
VOID
ArReadWriteBarrier()
{
asm volatile(""
:
:
: "memory");
}
/**
* Instructs the processor to set the interrupt flag.
*