Работа над документацией

This commit is contained in:
2026-04-25 22:00:40 +05:00
parent 8ebacd77eb
commit 7d00738b55
25 changed files with 980 additions and 185 deletions
+70
View File
@@ -0,0 +1,70 @@
#pragma once
#include "FXAlloc.h"
#include "mword.h"
typedef struct FXMemoryBlock FXMemoryBlock;
/**
* @brief Минимальная структурная единица - блок памяти
* В памяти расположены друг за другом с гарантированным выравниванием по void*
* Клиентский указатель указывает непосредственно за структуру
* fxalloc() → return (void*)(block + 1);
* fxfree() → FXMemoryBlock* block = (FXMemoryBlock*)_Ptr - 1;
* @property next: FXMemoryBlock* - Указатель на следующий свободный блок
* @property Индекс потока в глобальном пуле
* @property Индекс грейда в пуле конкретного потока
* */
struct FXMemoryBlock {
/// @brief Указатель на следующий свободный блок
FXMemoryBlock* next;
/// @brief Индекс потока в глобальном пуле
umword_t tid;
/// @brief Индекс грейда в пуле конкретного потока
umword_t gid;
};
struct FXMemoryBlock {
/// @brief Указатель на следующий свободный блок
FXMemoryBlock* next;
/// @brief Индекс потока в глобальном пуле
uint32_t tid;
/// @brief Индекс грейда в пуле конкретного потока
uint32_t gid;
};
/**
* @brief Минимальная структурная единица - блок памяти
* В памяти расположены друг за другом с гарантированным выравниванием по void*
* Клиентский указатель указывает непосредственно за структуру
* fxalloc() → return (void*)(block + 1);
* fxfree() → FXMemoryBlock* block = (FXMemoryBlock*)_Ptr - 1;
* @property next: FXMemoryBlock* - Указатель на следующий свободный блок
* @property Индекс потока в глобальном пуле
* @property Индекс грейда в пуле конкретного потока
* */
struct FXMemoryBlock {
/// @brief Указатель на следующий свободный блок
FXMemoryBlock* next;
/// @brief Полезные данные в блоке
uint32_t used;
/// @brief Индекс потока в глобальном пуле
uint16_t tid;
/// @brief Индекс грейда в пуле конкретного потока
uint16_t gid;
};
/// @brief Группа блоков одной градации
typedef struct FXGradedMemoryPool {
/// @brief Указатель на последний свободный блок
FXMemoryBlock* free;
/// @brief Всего блоков в данной группе
umword_t total;
/// @brief Количество преаллоцированных блоков
umword_t count_pre;
/// @brief Количество используемых блоков
mword_t used;
/// @brief Количество свободных блоков
mword_t free;
} FXMemoryPoolGrade;
+49
View File
@@ -0,0 +1,49 @@
#ifndef FX_MEMORY_BLOCK_H
#define FX_MEMORY_BLOCK_H
#include <stdint.h>
#include "mword.h"
// Определяем оптимальный тип метаданных для FXMemoryBlock
#if defined(__x86_64__) || defined(_M_X64) || \
defined(__amd64__) || defined(__amd64) || \
defined(__aarch64__) || defined(_M_ARM64) || \
defined(__AARCH64__) || defined(__powerpc64__) || \
defined(__ppc64__)
// Для 64-битных архитектур используем uint32_t
// для оптимального баланса между размером и производительностью
typedef uint32_t fxmbmeta_t;
#elif defined(__i386__) || defined(_M_IX86) || \
defined(__i486__) || defined(__i586__) || \
defined(__i686__) || defined(__arm__) || \
defined(_M_ARM) || defined(__ARM_ARCH_7__) || \
defined(__ARM_ARCH_8__) || defined(__powerpc__) || \
defined(__ppc__)
// Для 32-битных архитектур используем uint32_t
typedef uint32_t fxmbmeta_t;
#elif defined(__riscv)
#if __riscv_xlen == 64
typedef uint32_t fxmbmeta_t;
#elif __riscv_xlen == 32
typedef uint32_t fxmbmeta_t;
#else
#error "Unsupported RISC-V word size: __riscv_xlen must be 32 or 64"
#endif
#else
// Резервный вариант: определяем по размеру указателя
#if sizeof(void*) == 8
typedef uint32_t fxmbmeta_t;
#elif sizeof(void*) == 4
typedef uint32_t fxmbmeta_t;
#else
#error "Unsupported pointer size"
#endif
#endif
// Проверка корректности определения типа
static_assert(sizeof(fxmbmeta_t) == 4, "fxmbmeta_t must be 32-bit");
#endif // FX_MEMORY_BLOCK_H
+74
View File
@@ -0,0 +1,74 @@
#pragma once
#include <stdint.h>
#if defined(__x86_64__) || defined(_M_X64) || \
defined(__amd64__) || defined(__amd64)
// x64: 64-битное машинное слово
typedef int64_t mword_t;
typedef uint64_t umword_t;
#elif defined(__i386__) || defined(_M_IX86) || \
defined(__i486__) || defined(__i586__) || \
defined(__i686__)
// x86: 32-битное машинное слово
typedef int32_t mword_t;
typedef uint32_t umword_t;
#elif defined(__aarch64__) || defined(_M_ARM64) || defined(__AARCH64__)
// ARM64: 64-битное машинное слово
typedef int64_t mword_t;
typedef uint64_t umword_t;
#elif defined(__arm__) || defined(_M_ARM) || defined(__ARM_ARCH_7__) || defined(__ARM_ARCH_8__)
// ARM32: 32-битное машинное слово
typedef int32_t mword_t;
typedef uint32_t umword_t;
#elif defined(__riscv) && defined(__riscv_xlen)
#if __riscv_xlen == 64
// RISCV 64: 64-битное машинное слово
typedef int64_t mword_t;
typedef uint64_t umword_t;
#elif __riscv_xlen == 32
// RISCV 32: 32-битное машинное слово
typedef int32_t mword_t;
typedef uint32_t umword_t;
#else
#error "Unsupported RISC-V word size: __riscv_xlen must be 32 or 64"
#endif
#elif defined(__powerpc64__) || defined(__ppc64__)
// PowerPC64: 64-битное машинное слово
typedef int64_t mword_t;
typedef uint64_t umword_t;
#elif defined(__powerpc__) || defined(__ppc__)
// PowerPC32: 32-битное машинное слово
typedef int32_t mword_t;
typedef uint32_t umword_t;
#else
// Резервный вариант: определяем по диапазону unsigned long
#include <limits.h>
#if ULONG_MAX == 18446744073709551615ULL // 2^64 - 1
typedef int64_t mword_t;
typedef uint64_t umword_t;
#elif ULONG_MAX == 4294967295UL // 2^32 - 1
typedef int32_t mword_t;
typedef uint32_t umword_t;
#elif ULONG_MAX == 65535U // 2^16 - 1
typedef int16_t mword_t;
typedef uint16_t umword_t;
#else
#error "Cannot determine machine word size: unsupported ULONG_MAX"
#endif
#endif
/* Проверки добавлены по настоянию YandexGPT 5.1 Pro(АлисаAI) */
// Статическая проверка: размер слова — степень двойки
static_assert((sizeof(mword_t) & (sizeof(mword_t) - 1)) == 0, "Machine word size must be a power of two");
// Статическая проверка: signed и unsigned версии имеют одинаковый размер
static_assert(sizeof(mword_t) == sizeof(umword_t), "mword_t and umword_t must have the same size");