139 lines
3.6 KiB
C
139 lines
3.6 KiB
C
//=-------------------------------------------------------------------------=//
|
|
// base definition //
|
|
// //
|
|
// Copyright © 2021 The Gem-graph Project //
|
|
// //
|
|
// This file is part of gem-graph. //
|
|
// //
|
|
// This program is free software: you can redistribute it and/or modify //
|
|
// it under the terms of the GNU Affero General Public License as //
|
|
// published by the Free Software Foundation, either version 3 of the //
|
|
// License, or (at your option) any later version. //
|
|
// //
|
|
// 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 Affero General Public License for more details. //
|
|
// //
|
|
// You should have received a copy of the GNU Affero General Public License //
|
|
// along with this program. If not, see <https://www.gnu.org/licenses/>. //
|
|
//=-------------------------------------------------------------------------=//
|
|
|
|
#include <sys/param.h>
|
|
#include <stdbool.h>
|
|
#include <pthread.h>
|
|
#include <unistd.h>
|
|
#include <malloc.h>
|
|
#include <string.h>
|
|
#include <stdlib.h>
|
|
#include <errno.h>
|
|
#include <stdio.h>
|
|
|
|
#define BASE_H
|
|
|
|
struct {
|
|
size_t size;
|
|
int *space;
|
|
} typedef IntArray_t;
|
|
|
|
struct {
|
|
int x;
|
|
int y;
|
|
int z;
|
|
int siteId;
|
|
} typedef Arrow_t;
|
|
|
|
struct {
|
|
size_t size;
|
|
pthread_spinlock_t lock;
|
|
Arrow_t *array;
|
|
} typedef ArrowArray_t;
|
|
|
|
struct {
|
|
char *label;
|
|
int narrow;
|
|
} typedef Site_t;
|
|
|
|
struct {
|
|
int nsite;
|
|
char *label;
|
|
Site_t *sites;
|
|
} typedef SpaceUnit_t;
|
|
|
|
struct {
|
|
int xmax;
|
|
int ymax;
|
|
int zmax;
|
|
size_t size;
|
|
SpaceUnit_t *space;
|
|
} typedef Space_t;
|
|
|
|
#define LOGMSG "[%s]"
|
|
#define printLog(FORMAT, ...) printf(LOGMSG " " FORMAT, __func__, ##__VA_ARGS__)
|
|
|
|
#define LEN(x) (sizeof(x) / sizeof((x)[0]))
|
|
|
|
/* -------------------------------------------------------------------------- */
|
|
|
|
//
|
|
// Scheduler
|
|
//
|
|
struct {
|
|
Space_t *globalDrawingSpace;
|
|
IntArray_t *conditionTree;
|
|
ArrowArray_t *arrowArray;
|
|
int nmaxThread;
|
|
int nmaxCycles;
|
|
int ruleRadius;
|
|
pthread_t *id;
|
|
bool pleaseStop;
|
|
} typedef Scheduler_t;
|
|
|
|
/* -------------------------------------------------------------------------- */
|
|
|
|
//
|
|
// Local threads
|
|
//
|
|
struct Center_t {
|
|
int x;
|
|
int y;
|
|
int z;
|
|
|
|
struct Center_t *next;
|
|
struct Center_t *prev;
|
|
} typedef Center_t;
|
|
|
|
struct {
|
|
pthread_t *id;
|
|
Center_t *localWorkAreaCenter;
|
|
Space_t *globalDrawingSpace;
|
|
IntArray_t *conditionTree;
|
|
ArrowArray_t *arrowArray;
|
|
bool pleaseStop;
|
|
bool terminated;
|
|
int returnValue;
|
|
} typedef Worker_t;
|
|
|
|
/* -------------------------------------------------------------------------- */
|
|
|
|
//
|
|
// Server
|
|
//
|
|
struct {
|
|
pthread_t *id;
|
|
bool pleaseStop;
|
|
} typedef Server_t;
|
|
|
|
/* -------------------------------------------------------------------------- */
|
|
|
|
//
|
|
// Model
|
|
//
|
|
struct {
|
|
int id;
|
|
int space_xmax;
|
|
int space_ymax;
|
|
int space_zmax;
|
|
int siteNumber;
|
|
} typedef Model_t;
|