/** * @file tm.h * @author Sébastien ROUAULT * @author Antoine MURAT * * @section LICENSE * * Copyright © 2018-2021 Sébastien ROUAULT. * * This program is free software; you can redistribute it and/or modify * it under the terms of the GNU General Public License as published by * the Free Software Foundation; either version 3 of the License, or * any later version. Please see https://gnu.org/licenses/gpl.html * * This program is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU General Public License for more details. * * @section DESCRIPTION * * Interface declaration for the transaction manager to use (C version). * YOU SHOULD NOT MODIFY THIS FILE. **/ #pragma once #include #include #include // -------------------------------------------------------------------------- // typedef void* shared_t; // The type of a shared memory region static shared_t const invalid_shared = NULL; // Invalid shared memory region // Note: a uintptr_t is an unsigned integer that is big enough to store an // address. Said differently, you can either use an integer to identify // transactions, or an address (e.g., if you created an associated data // structure). typedef uintptr_t tx_t; // The type of a transaction identifier static tx_t const invalid_tx = ~((tx_t) 0); // Invalid transaction constant typedef int alloc_t; static alloc_t const success_alloc = 0; // Allocation successful and the TX can continue static alloc_t const abort_alloc = 1; // TX was aborted and could be retried static alloc_t const nomem_alloc = 2; // Memory allocation failed but TX was not aborted // -------------------------------------------------------------------------- // shared_t tm_create(size_t, size_t); void tm_destroy(shared_t); void* tm_start(shared_t); size_t tm_size(shared_t); size_t tm_align(shared_t); tx_t tm_begin(shared_t, bool); bool tm_end(shared_t, tx_t); bool tm_read(shared_t, tx_t, void const*, size_t, void*); bool tm_write(shared_t, tx_t, void const*, size_t, void*); alloc_t tm_alloc(shared_t, tx_t, size_t, void**); bool tm_free(shared_t, tx_t, void*);