xref: /OK3568_Linux_fs/external/mpp/osal/test/mpp_thread_test.c (revision 4882a59341e53eb6f0b4789bf948001014eff981)
1*4882a593Smuzhiyun /*
2*4882a593Smuzhiyun  * Copyright 2015 Rockchip Electronics Co. LTD
3*4882a593Smuzhiyun  *
4*4882a593Smuzhiyun  * Licensed under the Apache License, Version 2.0 (the "License");
5*4882a593Smuzhiyun  * you may not use this file except in compliance with the License.
6*4882a593Smuzhiyun  * You may obtain a copy of the License at
7*4882a593Smuzhiyun  *
8*4882a593Smuzhiyun  *      http://www.apache.org/licenses/LICENSE-2.0
9*4882a593Smuzhiyun  *
10*4882a593Smuzhiyun  * Unless required by applicable law or agreed to in writing, software
11*4882a593Smuzhiyun  * distributed under the License is distributed on an "AS IS" BASIS,
12*4882a593Smuzhiyun  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13*4882a593Smuzhiyun  * See the License for the specific language governing permissions and
14*4882a593Smuzhiyun  * limitations under the License.
15*4882a593Smuzhiyun  */
16*4882a593Smuzhiyun 
17*4882a593Smuzhiyun #define MODULE_TAG "mpp_thread_test"
18*4882a593Smuzhiyun 
19*4882a593Smuzhiyun #include <stdio.h>
20*4882a593Smuzhiyun #include <stdlib.h>
21*4882a593Smuzhiyun #include <string.h>
22*4882a593Smuzhiyun 
23*4882a593Smuzhiyun #include "rk_type.h"
24*4882a593Smuzhiyun 
25*4882a593Smuzhiyun #include "mpp_debug.h"
26*4882a593Smuzhiyun #include "mpp_thread.h"
27*4882a593Smuzhiyun #include "mpp_time.h"
28*4882a593Smuzhiyun 
29*4882a593Smuzhiyun // TODO: add thread mutex and condition test case
30*4882a593Smuzhiyun 
31*4882a593Smuzhiyun #define MAX_THREAD_NUM      10
32*4882a593Smuzhiyun #define MAX_LOCK_LOOP       10000
33*4882a593Smuzhiyun 
34*4882a593Smuzhiyun static RK_S32 thread_debug = 0;
35*4882a593Smuzhiyun #define thread_dbg(fmt, ...)    _mpp_dbg(thread_debug, 1, fmt, ## __VA_ARGS__)
36*4882a593Smuzhiyun 
37*4882a593Smuzhiyun static pthread_mutex_t mutex_0;
38*4882a593Smuzhiyun static pthread_mutex_t mutex_1;
39*4882a593Smuzhiyun static pthread_cond_t cond_0;
40*4882a593Smuzhiyun static pthread_cond_t cond_1;
41*4882a593Smuzhiyun static volatile RK_S32 flag_0 = 1;
42*4882a593Smuzhiyun static volatile RK_S32 flag_1 = 1;
43*4882a593Smuzhiyun 
thread_test(void * pdata)44*4882a593Smuzhiyun void *thread_test(void *pdata)
45*4882a593Smuzhiyun {
46*4882a593Smuzhiyun     int idx = *((int*)pdata);
47*4882a593Smuzhiyun     mpp_log("thread %d is running\n", idx);
48*4882a593Smuzhiyun     sleep(1);
49*4882a593Smuzhiyun     mpp_log("thread %d done\n", idx);
50*4882a593Smuzhiyun     return NULL;
51*4882a593Smuzhiyun }
52*4882a593Smuzhiyun 
mutex_performance_test_loop_0(void * arg)53*4882a593Smuzhiyun void* mutex_performance_test_loop_0(void *arg)
54*4882a593Smuzhiyun {
55*4882a593Smuzhiyun     RK_S32 i = 0;
56*4882a593Smuzhiyun 
57*4882a593Smuzhiyun     for (i = 0; i < MAX_LOCK_LOOP; i++) {
58*4882a593Smuzhiyun         thread_dbg("0 %5d lock\n", i);
59*4882a593Smuzhiyun         pthread_mutex_lock(&mutex_0);
60*4882a593Smuzhiyun 
61*4882a593Smuzhiyun         thread_dbg("0 %5d wait flag %d\n", i, flag_0);
62*4882a593Smuzhiyun         if (flag_0) {
63*4882a593Smuzhiyun             pthread_cond_wait(&cond_0, &mutex_0);
64*4882a593Smuzhiyun         }
65*4882a593Smuzhiyun 
66*4882a593Smuzhiyun         thread_dbg("0 %5d signal\n", i);
67*4882a593Smuzhiyun         pthread_mutex_lock(&mutex_1);
68*4882a593Smuzhiyun         flag_1 = 0;
69*4882a593Smuzhiyun         pthread_cond_signal(&cond_1);
70*4882a593Smuzhiyun         pthread_mutex_unlock(&mutex_1);
71*4882a593Smuzhiyun 
72*4882a593Smuzhiyun         thread_dbg("0 %5d unlock\n", i);
73*4882a593Smuzhiyun         flag_0 = 1;
74*4882a593Smuzhiyun         pthread_mutex_unlock(&mutex_0);
75*4882a593Smuzhiyun     }
76*4882a593Smuzhiyun     (void)arg;
77*4882a593Smuzhiyun     return NULL;
78*4882a593Smuzhiyun }
79*4882a593Smuzhiyun 
mutex_performance_test_loop_1(void * arg)80*4882a593Smuzhiyun void *mutex_performance_test_loop_1(void *arg)
81*4882a593Smuzhiyun {
82*4882a593Smuzhiyun     RK_S32 i = 0;
83*4882a593Smuzhiyun 
84*4882a593Smuzhiyun     for (i = 0; i < MAX_LOCK_LOOP; i++) {
85*4882a593Smuzhiyun         thread_dbg("1 %5d lock\n", i);
86*4882a593Smuzhiyun         pthread_mutex_lock(&mutex_1);
87*4882a593Smuzhiyun 
88*4882a593Smuzhiyun         thread_dbg("1 %5d wait flag %d\n", i, flag_1);
89*4882a593Smuzhiyun         if (flag_1) {
90*4882a593Smuzhiyun             pthread_cond_wait(&cond_1, &mutex_1);
91*4882a593Smuzhiyun         }
92*4882a593Smuzhiyun 
93*4882a593Smuzhiyun         thread_dbg("1 %5d signal\n", i);
94*4882a593Smuzhiyun         pthread_mutex_lock(&mutex_0);
95*4882a593Smuzhiyun         flag_0 = 0;
96*4882a593Smuzhiyun         pthread_cond_signal(&cond_0);
97*4882a593Smuzhiyun         pthread_mutex_unlock(&mutex_0);
98*4882a593Smuzhiyun 
99*4882a593Smuzhiyun         thread_dbg("1 %5d unlock\n", i);
100*4882a593Smuzhiyun         flag_1 = 1;
101*4882a593Smuzhiyun         pthread_mutex_unlock(&mutex_1);
102*4882a593Smuzhiyun     }
103*4882a593Smuzhiyun     (void)arg;
104*4882a593Smuzhiyun     return NULL;
105*4882a593Smuzhiyun }
106*4882a593Smuzhiyun 
mutex_performance_test_once(void)107*4882a593Smuzhiyun void mutex_performance_test_once(void)
108*4882a593Smuzhiyun {
109*4882a593Smuzhiyun     pthread_mutexattr_t attr;
110*4882a593Smuzhiyun     pthread_mutex_t mutex;
111*4882a593Smuzhiyun 
112*4882a593Smuzhiyun     pthread_mutexattr_init(&attr);
113*4882a593Smuzhiyun     pthread_mutexattr_settype(&attr, PTHREAD_MUTEX_RECURSIVE);
114*4882a593Smuzhiyun 
115*4882a593Smuzhiyun     pthread_mutex_init(&mutex, &attr);
116*4882a593Smuzhiyun     pthread_mutexattr_destroy(&attr);
117*4882a593Smuzhiyun 
118*4882a593Smuzhiyun     pthread_mutex_lock(&mutex);
119*4882a593Smuzhiyun     pthread_mutex_unlock(&mutex);
120*4882a593Smuzhiyun 
121*4882a593Smuzhiyun     pthread_mutex_lock(&mutex);
122*4882a593Smuzhiyun     pthread_mutex_unlock(&mutex);
123*4882a593Smuzhiyun 
124*4882a593Smuzhiyun     pthread_mutex_lock(&mutex);
125*4882a593Smuzhiyun     pthread_mutex_unlock(&mutex);
126*4882a593Smuzhiyun 
127*4882a593Smuzhiyun     pthread_mutex_lock(&mutex);
128*4882a593Smuzhiyun     pthread_mutex_unlock(&mutex);
129*4882a593Smuzhiyun 
130*4882a593Smuzhiyun     pthread_mutex_destroy(&mutex);
131*4882a593Smuzhiyun }
132*4882a593Smuzhiyun 
main()133*4882a593Smuzhiyun int main()
134*4882a593Smuzhiyun {
135*4882a593Smuzhiyun     int i;
136*4882a593Smuzhiyun     int pdata[MAX_THREAD_NUM];
137*4882a593Smuzhiyun     pthread_t threads[MAX_THREAD_NUM];
138*4882a593Smuzhiyun     pthread_attr_t attr;
139*4882a593Smuzhiyun     pthread_mutexattr_t mutex_attr;
140*4882a593Smuzhiyun     void *dummy;
141*4882a593Smuzhiyun     RK_S64 time_start, time_end;
142*4882a593Smuzhiyun 
143*4882a593Smuzhiyun     mpp_log("vpu test start\n");
144*4882a593Smuzhiyun     pthread_attr_init(&attr);
145*4882a593Smuzhiyun     pthread_attr_setdetachstate(&attr, PTHREAD_CREATE_JOINABLE);
146*4882a593Smuzhiyun 
147*4882a593Smuzhiyun     for (i = 0; i < MAX_THREAD_NUM; i++) {
148*4882a593Smuzhiyun         pdata[i] = i;
149*4882a593Smuzhiyun         pthread_create(&threads[i], &attr, thread_test, &pdata[i]);
150*4882a593Smuzhiyun     }
151*4882a593Smuzhiyun 
152*4882a593Smuzhiyun     sleep(2);
153*4882a593Smuzhiyun 
154*4882a593Smuzhiyun     for (i = 0; i < MAX_THREAD_NUM; i++) {
155*4882a593Smuzhiyun         pthread_join(threads[i], &dummy);
156*4882a593Smuzhiyun     }
157*4882a593Smuzhiyun 
158*4882a593Smuzhiyun     mpp_debug = MPP_DBG_TIMING;
159*4882a593Smuzhiyun     time_start = mpp_time();
160*4882a593Smuzhiyun 
161*4882a593Smuzhiyun     for (i = 0; i < MAX_LOCK_LOOP; i++)
162*4882a593Smuzhiyun         mutex_performance_test_once();
163*4882a593Smuzhiyun 
164*4882a593Smuzhiyun     time_end = mpp_time();
165*4882a593Smuzhiyun     mpp_time_diff(time_start, time_end, 0, "lock unlock test");
166*4882a593Smuzhiyun 
167*4882a593Smuzhiyun     pthread_mutexattr_init(&mutex_attr);
168*4882a593Smuzhiyun     pthread_mutexattr_settype(&mutex_attr, PTHREAD_MUTEX_RECURSIVE);
169*4882a593Smuzhiyun 
170*4882a593Smuzhiyun     pthread_mutex_init(&mutex_0, &mutex_attr);
171*4882a593Smuzhiyun     pthread_mutex_init(&mutex_1, &mutex_attr);
172*4882a593Smuzhiyun     pthread_cond_init(&cond_0, NULL);
173*4882a593Smuzhiyun     pthread_cond_init(&cond_1, NULL);
174*4882a593Smuzhiyun     pthread_mutexattr_destroy(&mutex_attr);
175*4882a593Smuzhiyun 
176*4882a593Smuzhiyun     time_start = mpp_time();
177*4882a593Smuzhiyun     pthread_create(&threads[0], &attr, mutex_performance_test_loop_0, NULL);
178*4882a593Smuzhiyun     flag_0 = 0;
179*4882a593Smuzhiyun     pthread_create(&threads[1], &attr, mutex_performance_test_loop_1, NULL);
180*4882a593Smuzhiyun 
181*4882a593Smuzhiyun     pthread_join(threads[0], &dummy);
182*4882a593Smuzhiyun     pthread_join(threads[1], &dummy);
183*4882a593Smuzhiyun     time_end = mpp_time();
184*4882a593Smuzhiyun     mpp_time_diff(time_start, time_end, 0, "lock and signal test");
185*4882a593Smuzhiyun 
186*4882a593Smuzhiyun     pthread_cond_destroy(&cond_0);
187*4882a593Smuzhiyun     pthread_cond_destroy(&cond_1);
188*4882a593Smuzhiyun 
189*4882a593Smuzhiyun     pthread_attr_destroy(&attr);
190*4882a593Smuzhiyun 
191*4882a593Smuzhiyun     mpp_debug = 0;
192*4882a593Smuzhiyun     mpp_log("vpu test end\n");
193*4882a593Smuzhiyun     return 0;
194*4882a593Smuzhiyun }
195*4882a593Smuzhiyun 
196