/* * Copyright (c) 2022 Huawei Device Co., Ltd. All rights reserved. * * Redistribution and use in source and binary forms, with or without modification, * are permitted provided that the following conditions are met: * * 1. Redistributions of source code must retain the above copyright notice, this list of * conditions and the following disclaimer. * * 2. Redistributions in binary form must reproduce the above copyright notice, this list * of conditions and the following disclaimer in the documentation and/or other materials * provided with the distribution. * * 3. Neither the name of the copyright holder nor the names of its contributors may be used * to endorse or promote products derived from this software without specific prior written * permission. * * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, * THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR * PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR * CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, * EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, * PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; * OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, * WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR * OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF * ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. */ #undef _XOPEN_SOURCE #define _XOPEN_SOURCE 600 #include "It_posix_mutex.h" #include "unistd.h" #define THREAD_NUM 6 #define LOOPS 3 static pthread_mutex_t g_mutex040 = PTHREAD_MUTEX_INITIALIZER; static int g_value; static void *TaskF01(void *parm) { int i, tmp; int rc; /* Loopd M times to acquire the mutex, increase the value, and then release the mutex. */ for (i = 0; i < LOOPS; ++i) { rc = pthread_mutex_lock(&g_mutex040); if (rc != 0) { return (void *)(LOS_NOK); } tmp = g_value + 1; usleep(1000); // 1000, delay the increasement operation. g_value = tmp; rc = pthread_mutex_unlock(&g_mutex040); if (rc != 0) { return (void *)(LOS_NOK); } sleep(1); } return (void *)(LOS_OK); } static UINT32 Testcase(VOID) { int i, rc; pthread_t threads[THREAD_NUM]; g_value = 0; /* Create threads */ for (i = 0; i < THREAD_NUM; ++i) { rc = pthread_create(&threads[i], NULL, TaskF01, NULL); ICUNIT_ASSERT_EQUAL(rc, 0, rc); } /* Wait to join all threads */ for (i = 0; i < THREAD_NUM; ++i) { rc = pthread_join(threads[i], NULL); ICUNIT_ASSERT_EQUAL(rc, 0, rc); } pthread_mutex_destroy(&g_mutex040); /* Check if the final value is as expected */ ICUNIT_ASSERT_EQUAL(g_value, (THREAD_NUM) * LOOPS, LOS_NOK); return LOS_OK; } /** * @tc.name: ItPosixMux038 * @tc.desc: Test interface pthread_mutex_lock * @tc.type: FUNC * @tc.require: issueI5YAEX */ VOID ItPosixMux038(void) { TEST_ADD_CASE("ItPosixMux038", Testcase, TEST_POSIX, TEST_MUX, TEST_LEVEL2, TEST_FUNCTION); }