tun2socks 0.0.1

High performance tun2socks
Documentation
/*
 ============================================================================
 Name        : hev-task-mutex.c
 Author      : Heiher <r@hev.cc>
 Copyright   : Copyright (c) 2019 everyone.
 Description : Mutex
 ============================================================================
 */

#include <stddef.h>

#include "kern/task/hev-task.h"
#include "lib/misc/hev-compiler.h"

#include "hev-task-mutex.h"

struct _HevTaskMutexNode
{
    HevTaskMutexNode *next;

    HevTask *task;
};

EXPORT_SYMBOL int
hev_task_mutex_init (HevTaskMutex *self)
{
    self->locker = 0;
    self->waiters = NULL;

    return 0;
}

EXPORT_SYMBOL int
hev_task_mutex_lock (HevTaskMutex *self)
{
    if (self->locker) {
        HevTaskMutexNode node;

        node.next = self->waiters;
        node.task = hev_task_self ();
        self->waiters = &node;

        do {
            hev_task_yield (HEV_TASK_WAITIO);
        } while (READ_ONCE (self->locker) ||
                 READ_ONCE (self->waiters) != &node);

        self->waiters = node.next;
    }

    barrier ();
    self->locker = 1;
    barrier ();

    return 0;
}

EXPORT_SYMBOL int
hev_task_mutex_trylock (HevTaskMutex *self)
{
    if (self->locker)
        return -1;

    barrier ();
    self->locker = 1;
    barrier ();

    return 0;
}

EXPORT_SYMBOL int
hev_task_mutex_unlock (HevTaskMutex *self)
{
    barrier ();
    self->locker = 0;
    barrier ();

    if (self->waiters)
        hev_task_wakeup (self->waiters->task);

    return 0;
}