1
0

🔨」 fix: fixed error in helgrind

This commit is contained in:
2024-08-12 21:06:38 +02:00
parent 471ca75712
commit 36bda7d5c0
4 changed files with 13 additions and 7 deletions

View File

@ -6,7 +6,7 @@
/* By: adjoly <adjoly@student.42angouleme.fr> +#+ +:+ +#+ */
/* +#+#+#+#+#+ +#+ */
/* Created: 2024/08/08 17:29:51 by adjoly #+# #+# */
/* Updated: 2024/08/12 20:50:55 by adjoly ### ########.fr */
/* Updated: 2024/08/12 21:04:57 by adjoly ### ########.fr */
/* */
/* ************************************************************************** */
@ -23,19 +23,21 @@ void take_fork(t_fork *fork, int id)
bool philo_eat(t_philo *philo)
{
philo->state = FORK_TAKEN;
take_fork(&philo->fork, philo->id);
if (get_death(philo, RETURN))
return (true);
take_fork(&philo->fork, philo->id);
log_philo(philo);
if (&(philo->fork.left) == philo->fork.right)
return (print_death(philo));
if (get_death(philo, RETURN))
return (true);
take_fork(&philo->fork, philo->id + 1);
// if (get_death(philo, RETURN))
// return (true);
log_philo(philo);
philo->state = EAT;
log_philo(philo);
pthread_mutex_lock(philo->check);
gettimeofday(&philo->eat, NULL);
pthread_mutex_unlock(philo->check);
if (sleep_phil(philo) == true)
return (true);
pthread_mutex_unlock(&philo->fork.left);

View File

@ -6,7 +6,7 @@
/* By: adjoly <adjoly@student.42angouleme.fr> +#+ +:+ +#+ */
/* +#+#+#+#+#+ +#+ */
/* Created: 2024/08/12 12:13:35 by adjoly #+# #+# */
/* Updated: 2024/08/12 20:50:17 by adjoly ### ########.fr */
/* Updated: 2024/08/12 21:00:27 by adjoly ### ########.fr */
/* */
/* ************************************************************************** */
@ -22,13 +22,17 @@ bool philo_check(t_philo *philo, t_pdata data)
eaten = 0;
while (i < data.philo_nbr)
{
gettimeofday(&t1, NULL);
pthread_mutex_lock(philo->check);
if (get_time_in_ms(philo[i].eat, t1) > data.die_time)
{
pthread_mutex_unlock(philo->check);
pthread_mutex_unlock(&philo[i].fork.left);
pthread_mutex_unlock(philo[i].fork.right);
return (print_death(&philo[i]));
}
pthread_mutex_unlock(philo->check);
if (philo[i].meal_left == 0)
eaten++;
if (get_death(philo, RETURN))

View File

@ -6,7 +6,7 @@
/* By: adjoly <adjoly@student.42angouleme.fr> +#+ +:+ +#+ */
/* +#+#+#+#+#+ +#+ */
/* Created: 2024/07/22 21:24:53 by adjoly #+# #+# */
/* Updated: 2024/08/12 20:27:14 by adjoly ### ########.fr */
/* Updated: 2024/08/12 21:03:47 by adjoly ### ########.fr */
/* */
/* ************************************************************************** */

View File

@ -6,7 +6,7 @@
/* By: adjoly <adjoly@student.42angouleme.fr> +#+ +:+ +#+ */
/* +#+#+#+#+#+ +#+ */
/* Created: 2024/07/23 17:15:24 by adjoly #+# #+# */
/* Updated: 2024/08/12 20:47:05 by adjoly ### ########.fr */
/* Updated: 2024/08/12 21:05:12 by adjoly ### ########.fr */
/* */
/* ************************************************************************** */