/****************************************************************************** * Grupo: * * Gustavo Sverzut Barbieri * * Ivens Prates Telles Alves * * Tiago Moreira de Melo * ****************************************************************************** * * * Solução para o problema dos filósofos famintos * * * * Idéia: * * Se fecharmos a mesa para apenas N-1 filósofos, sempre haverá ao menos* * um filósofo comendo e portanto o sistema não entra em deadlock. Também * * pode-se pensar que por existirem N-1 filósofos e N garfos, a situação de* * deadlock do problema anterior nunca ocorrerá pois se todos os filósofos * * pegarem o garfo da esquerda, ainda haverá um filósofo que conseguirá * * o garfo da direita, alimentando-se então. * * * ****************************************************************************** * * * This code is documented using the Doxygen tags, so you can run: * * doxygen Doxyfile * * If "Doxyfile" doesn't exist you may create one using doxywizard * * You can get Doxygen at: http://www.doxygen.org * * * ****************************************************************************** * * * Libraries used: * * - pthread * * Compilation Example: * * gcc -g 02_nodeadlock-alt.c -o 02_nodeadlock-alt -lpthread * * * ****************************************************************************** * (C) GPL - General Public License * * http://www.fsf.org * ****************************************************************************** */ #ifndef H_02_NODEADLOCK #define H_02_NODEADLOCK #include #include #include #include #include #define N 5 /**< number of philosophers */ /** States: */ #define THINKING 0 /**< philosopher is trying to get forks */ #define HUNGRY 1 /**< philosopher is hungry */ #define EATING 2 /**< philosopher is eating */ /** Boolean: */ #define TRUE 1 #define FALSE 0 /** globals */ #define MAX_MEALS 15 /**< maximum meals avaiable */ int meals = 0 ; /**< consumed meals */ sem_t forks[ N ]; /**< the forks */ sem_t printing; /**< says if we are printing or not */ sem_t table; /**< used to lock the table to 4 philosophers */ int state[ N ]; /**< the dinning philosopher */ char forks_position[ N ]; /**< show who have the fork. '|' = table, '<' = left philosopher, '>' = right philosopher */ char state_letters[3] = { 'T', /* THINKING */ 'H', /* HUNGRY */ 'E' /* EATING */ }; /** * The philosopher \a i, which only think and eat * \param i the philosopher number */ void philosopher( int i ); /** * A wrapper to \a philosopher to use with Pthread * \param p a pointer to an integer, which represent the philosopher number * \return always \c NULL * \sa philosopher() */ void *pthread_philosopher( void *p ); /** * The think action * \param i the philosopher number */ void think(int i); /** * The eat action * \param i the philosopher number */ void eat(int i); /** * Get the forks, first the left, then the right. * \warning This function does not release the left fork if it could not get * the right one, leading to a *DEADLOCK*. * \param i the philosopher number */ void take_forks( int i ); /** * Put the forks. * \param i the philosopher number */ void put_forks( int i ); /** * Print the table, with its philosophers.\n * Each philosopher is shown as a letter representing him/her state within [ ], * the letters are: * \li \c E for Eating * \li \c H for Hungry * \li \c T for Thinking * * \sa state_letters */ void print_table(); #endif /* ifdef H_02_NODEADLOCK */