2007-09-02 17:52:30 +02:00
|
|
|
/*
|
2013-01-07 05:43:01 +01:00
|
|
|
TEST-LOCKING - test locking functions
|
2007-09-02 17:52:30 +02:00
|
|
|
|
2008-03-10 04:25:03 +01:00
|
|
|
Copyright (C) Lumiera.org
|
|
|
|
|
2008, Christian Thaeter <ct@pipapo.org>
|
2007-09-02 17:52:30 +02:00
|
|
|
|
|
|
|
|
This program is free software; you can redistribute it and/or
|
|
|
|
|
modify it under the terms of the GNU General Public License as
|
2010-12-17 23:28:49 +01:00
|
|
|
published by the Free Software Foundation; either version 2 of
|
|
|
|
|
the License, or (at your option) any later version.
|
2007-09-02 17:52:30 +02:00
|
|
|
|
|
|
|
|
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 General Public License for more details.
|
|
|
|
|
|
|
|
|
|
You should have received a copy of the GNU General Public License
|
|
|
|
|
along with this program; if not, write to the Free Software
|
|
|
|
|
Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
|
2013-01-07 05:43:01 +01:00
|
|
|
|
|
|
|
|
* *****************************************************/
|
|
|
|
|
|
2017-02-22 03:46:23 +01:00
|
|
|
/** @file test-locking.c
|
|
|
|
|
** C unit test to cover convenience setup for POSIX locking primitives
|
|
|
|
|
** These convenience macros are intended for use in low-level C code,
|
|
|
|
|
** where minimal and precise locking is relevant for performance reasons.
|
|
|
|
|
** @see mutex.h
|
|
|
|
|
** @see condition.h
|
2016-11-03 18:26:43 +01:00
|
|
|
*/
|
|
|
|
|
|
2007-09-02 17:52:30 +02:00
|
|
|
|
2011-12-02 21:34:29 +01:00
|
|
|
#include "lib/test/test.h"
|
2008-08-09 09:33:14 +02:00
|
|
|
#include "lib/mutex.h"
|
2009-01-27 10:07:30 +01:00
|
|
|
#include "lib/recmutex.h"
|
2007-09-02 17:52:30 +02:00
|
|
|
|
2008-08-09 10:29:51 +02:00
|
|
|
#include <stdio.h>
|
|
|
|
|
#include <string.h>
|
2007-09-02 17:52:30 +02:00
|
|
|
|
2008-03-26 19:26:51 +01:00
|
|
|
TESTS_BEGIN
|
|
|
|
|
|
2008-08-09 10:29:51 +02:00
|
|
|
|
2010-03-04 16:23:57 +01:00
|
|
|
TEST (mutexsection)
|
2008-08-09 09:33:14 +02:00
|
|
|
{
|
|
|
|
|
lumiera_mutex m;
|
2010-01-23 01:40:27 +01:00
|
|
|
lumiera_mutex_init (&m, "mutexsection", &NOBUG_FLAG(NOBUG_ON), NOBUG_CONTEXT);
|
2008-08-09 09:33:14 +02:00
|
|
|
|
|
|
|
|
LUMIERA_MUTEX_SECTION (NOBUG_ON, &m)
|
|
|
|
|
{
|
|
|
|
|
printf ("mutex locked section 1\n");
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
LUMIERA_MUTEX_SECTION (NOBUG_ON, &m)
|
|
|
|
|
{
|
|
|
|
|
printf ("mutex locked section 2\n");
|
|
|
|
|
}
|
|
|
|
|
|
2010-01-23 01:40:27 +01:00
|
|
|
lumiera_mutex_destroy (&m, &NOBUG_FLAG(NOBUG_ON), NOBUG_CONTEXT);
|
2008-08-09 09:33:14 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
2010-03-04 16:23:57 +01:00
|
|
|
TEST (mutexforgotunlock)
|
2007-09-02 17:52:30 +02:00
|
|
|
{
|
2008-08-09 09:33:14 +02:00
|
|
|
lumiera_mutex m;
|
2010-01-23 01:40:27 +01:00
|
|
|
lumiera_mutex_init (&m, "mutexforgotunlock", &NOBUG_FLAG(NOBUG_ON), NOBUG_CONTEXT);
|
2008-08-09 09:33:14 +02:00
|
|
|
|
|
|
|
|
LUMIERA_MUTEX_SECTION (NOBUG_ON, &m)
|
|
|
|
|
{
|
|
|
|
|
break; // MUTEX_SECTIONS must not be left by a jump
|
|
|
|
|
}
|
|
|
|
|
|
2010-01-23 01:40:27 +01:00
|
|
|
lumiera_mutex_destroy (&m, &NOBUG_FLAG(NOBUG_ON), NOBUG_CONTEXT);
|
2007-09-02 17:52:30 +02:00
|
|
|
}
|
2008-03-26 19:26:51 +01:00
|
|
|
|
2008-08-09 09:33:14 +02:00
|
|
|
|
2010-03-04 16:23:57 +01:00
|
|
|
TEST (mutexexplicitunlock)
|
2009-01-25 14:39:18 +01:00
|
|
|
{
|
|
|
|
|
lumiera_mutex m;
|
2010-01-23 01:40:27 +01:00
|
|
|
lumiera_mutex_init (&m, "mutexforgotunlock", &NOBUG_FLAG(NOBUG_ON), NOBUG_CONTEXT);
|
2009-01-25 14:39:18 +01:00
|
|
|
|
|
|
|
|
LUMIERA_MUTEX_SECTION (NOBUG_ON, &m)
|
|
|
|
|
{
|
|
|
|
|
ECHO("mutex locked section");
|
|
|
|
|
LUMIERA_MUTEX_SECTION_UNLOCK;
|
|
|
|
|
break;
|
|
|
|
|
}
|
|
|
|
|
|
2010-01-23 01:40:27 +01:00
|
|
|
lumiera_mutex_destroy (&m, &NOBUG_FLAG(NOBUG_ON), NOBUG_CONTEXT);
|
2009-01-25 14:39:18 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
2010-03-04 16:23:57 +01:00
|
|
|
TEST (nestedmutexsection)
|
2008-08-09 09:33:14 +02:00
|
|
|
{
|
|
|
|
|
lumiera_mutex m;
|
2010-01-23 01:40:27 +01:00
|
|
|
lumiera_mutex_init (&m, "m_mutexsection", &NOBUG_FLAG(NOBUG_ON), NOBUG_CONTEXT);
|
2008-08-09 09:33:14 +02:00
|
|
|
|
|
|
|
|
lumiera_mutex n;
|
2010-01-23 01:40:27 +01:00
|
|
|
lumiera_mutex_init (&n, "n_mutexsection", &NOBUG_FLAG(NOBUG_ON), NOBUG_CONTEXT);
|
2008-08-09 09:33:14 +02:00
|
|
|
|
|
|
|
|
LUMIERA_MUTEX_SECTION (NOBUG_ON, &m)
|
|
|
|
|
{
|
|
|
|
|
printf ("outer mutex locked section\n");
|
|
|
|
|
|
|
|
|
|
LUMIERA_MUTEX_SECTION (NOBUG_ON, &n)
|
|
|
|
|
{
|
|
|
|
|
printf ("inner mutex locked section\n");
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
2010-01-23 01:40:27 +01:00
|
|
|
lumiera_mutex_destroy (&n, &NOBUG_FLAG(NOBUG_ON), NOBUG_CONTEXT);
|
|
|
|
|
lumiera_mutex_destroy (&m, &NOBUG_FLAG(NOBUG_ON), NOBUG_CONTEXT);
|
2008-08-09 09:33:14 +02:00
|
|
|
}
|
|
|
|
|
|
2010-03-04 16:23:57 +01:00
|
|
|
TEST (chainedmutexsection)
|
2008-09-16 00:45:05 +02:00
|
|
|
{
|
|
|
|
|
lumiera_mutex m;
|
2010-01-23 01:40:27 +01:00
|
|
|
lumiera_mutex_init (&m, "m_mutexsection", &NOBUG_FLAG(NOBUG_ON), NOBUG_CONTEXT);
|
2008-09-16 00:45:05 +02:00
|
|
|
|
|
|
|
|
lumiera_mutex n;
|
2010-01-23 01:40:27 +01:00
|
|
|
lumiera_mutex_init (&n, "n_mutexsection", &NOBUG_FLAG(NOBUG_ON), NOBUG_CONTEXT);
|
2008-09-16 00:45:05 +02:00
|
|
|
|
|
|
|
|
LUMIERA_MUTEX_SECTION (NOBUG_ON, &m)
|
|
|
|
|
{
|
|
|
|
|
printf ("outer mutex locked section\n");
|
|
|
|
|
|
2008-09-27 04:19:43 +02:00
|
|
|
LUMIERA_MUTEX_SECTION_CHAIN (NOBUG_ON, &n)
|
2008-09-16 00:45:05 +02:00
|
|
|
{
|
|
|
|
|
printf ("inner but not outer mutex locked section\n");
|
|
|
|
|
}
|
|
|
|
|
}
|
2008-08-09 09:33:14 +02:00
|
|
|
|
2010-01-23 01:40:27 +01:00
|
|
|
lumiera_mutex_destroy (&n, &NOBUG_FLAG(NOBUG_ON), NOBUG_CONTEXT);
|
|
|
|
|
lumiera_mutex_destroy (&m, &NOBUG_FLAG(NOBUG_ON), NOBUG_CONTEXT);
|
2008-09-16 00:45:05 +02:00
|
|
|
}
|
2008-08-09 09:33:14 +02:00
|
|
|
|
2009-01-25 14:39:18 +01:00
|
|
|
|
|
|
|
|
|
2010-03-04 16:23:57 +01:00
|
|
|
TEST (recursivemutexsection)
|
2008-09-27 04:19:43 +02:00
|
|
|
{
|
2009-01-25 14:39:18 +01:00
|
|
|
lumiera_recmutex m;
|
2010-01-23 01:40:27 +01:00
|
|
|
lumiera_recmutex_init (&m, "m_recmutexsection", &NOBUG_FLAG(NOBUG_ON), NOBUG_CONTEXT);
|
2008-09-27 04:19:43 +02:00
|
|
|
|
|
|
|
|
|
2009-01-25 14:39:18 +01:00
|
|
|
LUMIERA_RECMUTEX_SECTION (NOBUG_ON, &m)
|
2008-09-27 04:19:43 +02:00
|
|
|
{
|
2009-01-25 14:39:18 +01:00
|
|
|
printf ("recmutex locked once\n");
|
2008-09-27 04:19:43 +02:00
|
|
|
|
2009-01-25 14:39:18 +01:00
|
|
|
LUMIERA_RECMUTEX_SECTION (NOBUG_ON, &m)
|
2008-09-27 04:19:43 +02:00
|
|
|
{
|
2009-01-25 14:39:18 +01:00
|
|
|
printf ("recmutex locked twice\n");
|
2008-09-27 04:19:43 +02:00
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
2010-01-23 01:40:27 +01:00
|
|
|
lumiera_recmutex_destroy (&m, &NOBUG_FLAG(NOBUG_ON), NOBUG_CONTEXT);
|
2008-09-27 04:19:43 +02:00
|
|
|
}
|
|
|
|
|
|
2009-01-25 14:39:18 +01:00
|
|
|
|
2023-10-16 01:44:04 +02:00
|
|
|
/* ====== 10/2023 : partially dismantled
|
|
|
|
|
*
|
|
|
|
|
* After switching to C++14 Threads and Locking (#1279),
|
|
|
|
|
* some backend-services are no longer used...
|
|
|
|
|
* - rwlocksection
|
|
|
|
|
* - rwlockforgotunlock
|
|
|
|
|
* - rwdeadlockwr
|
|
|
|
|
* - rwdeadlockrw
|
|
|
|
|
* - rwlockdeadlockwr
|
|
|
|
|
* - rwlockdeadlockrw
|
|
|
|
|
* - conditionops
|
|
|
|
|
* - conditionsection
|
|
|
|
|
* - conditionforgotunlock
|
|
|
|
|
* - condition signaling (planned)
|
|
|
|
|
* - condition broadcasting (planned)
|
|
|
|
|
* - recconditionops
|
|
|
|
|
* - recconditionsection
|
|
|
|
|
* - recconditionforgotunlock
|
|
|
|
|
* - chainedrecconditionsection
|
|
|
|
|
* - nestedrecconditionsection
|
|
|
|
|
* - reccondition signaling (planned)
|
|
|
|
|
* - reccondition broadcasting (planned)
|
|
|
|
|
*
|
|
|
|
|
*/
|
2009-01-27 10:10:03 +01:00
|
|
|
|
2008-03-26 19:26:51 +01:00
|
|
|
TESTS_END
|