*but since the only documented way to access it is from the current thread, I thought it was unnecessary.
I thought about that, but since the only documented way to access it is from the current thread.
Derek Lesho <dereklesho52@gmail.com> wrote:
> void WINAPI KeEnterCriticalRegion(void)
> {
> - FIXME(": stub\n");
> + TRACE(": semi-stub\n");
> + KeGetCurrentThread()->critical_region_count++;
> }
...
> void WINAPI KeLeaveCriticalRegion(void)
> {
> - FIXME(": stub\n");
> + TRACE(": semi-stub\n");
> + KeGetCurrentThread()->critical_region_count--;
> }
...
> +BOOLEAN WINAPI KeAreApcsDisabled(void)
> +{
> + return !!KeGetCurrentThread()->critical_region_count;
> +}
Shouldn't these APIs use interlocked operations?
--
Dmitry.