//=-------------------------------------------------------------------------=// // 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 . // //=-------------------------------------------------------------------------=// #include #include #include #include #include #include #include #include #include #include #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; int returnValue; int sockfd; } typedef Server_t; struct { pthread_t id; bool pleaseStop; Server_t *parent; int sockfd; struct sockaddr_in clientAddr; socklen_t socklen; } typedef ServerCommunication_t; /* -------------------------------------------------------------------------- */ // // Supervisor // struct { pthread_t id; bool pleaseStop; int *workerCreationOccurency; } typedef Supervisor_t; /* -------------------------------------------------------------------------- */ // // Model // struct { int id; char *name; int space_xMax; int space_yMax; int space_zMax; int nmaxThread; int nmaxCycles; int siteNumber; bool isRunning; Scheduler_t *scheduler; Supervisor_t *supervisor; } typedef Model_t;