#if (INCLUDE__UBINOS__UBIK_TEST == 1)
#if !(UBINOS__UBIK_TEST__EXCLUDE_MUTEXTESTSET == 1)
#include <stdio.h>
static void mutextest01_task1func(void * arg) {
int r;
int i;
unsigned int waittick =
ubik_timemstotick(UBINOS__UBIK_TEST__TASKWAITTIMEMS * UBINOS__UBIK_TEST__TASKLOOPCOUNT);
for (i=0; i<UBINOS__UBIK_TEST__TASKLOOPCOUNT * 1; i++) {
printf("1");
}
printf("\n");
printf("task 1 tries to lock mutex\n");
if (0 != r) {
printf("task 1: fail at mutex_lock(), err=%d\n", r);
goto end0;
}
printf("task 1 locks mutex\n");
for (i=0; i<UBINOS__UBIK_TEST__TASKLOOPCOUNT * 1; i++) {
printf("1");
}
printf("\n");
printf("task 1 unlocks mutex\n");
if (0 != r) {
printf("task 1: fail at mutex_unlock(), err=%d\n", r);
goto end0;
}
printf("\n");
printf("task 1 wakes up\n");
for (i=0; i<UBINOS__UBIK_TEST__TASKLOOPCOUNT * 1; i++) {
printf("1");
}
printf("\n");
printf(
"task 1 tries to lock mutex with timeout (for %d ms)\n",
ubik_ticktotimems(waittick));
printf("task 1: fail at mutex_lock_timed(), err=%d\n", r);
goto end0;
}
printf("\n");
printf("task 1 wakes up\n");
for (i=0; i<UBINOS__UBIK_TEST__TASKLOOPCOUNT * 1; i++) {
printf("1");
}
printf("\n");
end0:
printf("task 1 ends\n");
}
static void mutextest01_task2func(void * arg) {
int r;
int i;
printf("task 2 tries to lock mutex\n");
if (0 != r) {
printf("task 2: fail at mutex_lock(), err=%d\n", r);
goto end0;
}
printf("task 2 locks mutex\n");
for (i=0; i<UBINOS__UBIK_TEST__TASKLOOPCOUNT * 2; i++) {
printf("2");
}
printf("\n");
printf("task 2 tries to lock mutex again\n");
if (0 != r) {
printf("task 2: fail at mutex_lock(), err=%d\n", r);
goto end0;
}
printf("task 2 locks mutex again\n");
for (i=0; i<UBINOS__UBIK_TEST__TASKLOOPCOUNT * 1; i++) {
printf("2");
}
printf("\n");
printf("task 2 unlocks mutex\n");
if (0 != r) {
printf("task 2: fail at mutex_unlock(), err=%d\n", r);
goto end0;
}
for (i=0; i<UBINOS__UBIK_TEST__TASKLOOPCOUNT * 1; i++) {
printf("2");
}
printf("\n");
printf("task 2 unlocks mutex again\n");
if (0 != r) {
printf("task 2: fail at mutex_unlock(), err=%d\n", r);
goto end0;
}
printf("task 2 tries to lock mutex\n");
if (0 != r) {
printf("task 2: fail at mutex_lock(), err=%d\n", r);
goto end0;
}
printf("task 2 locks mutex\n");
for (i=0; i<UBINOS__UBIK_TEST__TASKLOOPCOUNT * 3; i++) {
printf("2");
}
printf("\n");
printf("task 2 unlocks mutex\n");
if (0 != r) {
printf("task 2: fail at mutex_unlock(), err=%d\n", r);
goto end0;
}
end0:
printf("task 2 ends\n");
}
int r;
int r2;
unsigned int count1;
unsigned int count2;
unsigned int sleepvalue =
ubik_timemstotick(UBINOS__UBIK_TEST__TASKWAITTIMEMS) * UBINOS__UBIK_TEST__TASKLOOPCOUNT / 3;
printf("\n");
printf("<test>\n");
printf("<name>ubik_test_mutextest01</name>\n");
printf("<description>Test on basic functions of mutex</description>\n");
printf("<message>\n");
if (0 != r) {
printf("fail at mutex_create(), err=%d\n", r);
r = -1;
goto end0;
}
printf("create task 2\n");
if (0 != r) {
printf("fail at task_create_noautodel(), err=%d\n", r);
r = -1;
goto end1;
}
printf("\n");
printf("checking\n");
printf("\n");
printf("check point 01: ");
printf("fail\n");
r = -1;
goto end2;
}
printf("pass\n");
printf("\n");
printf("create task 1\n");
if (0 != r) {
printf("fail at task_create_noautodel(), err=%d\n", r);
r = -1;
goto end2;
}
printf("\n");
printf("checking\n");
printf("\n");
printf("check point 02: ");
printf("fail\n");
r = -1;
goto end2;
}
printf("pass\n");
printf("\n");
printf("checking\n");
printf("\n");
printf("check point 03: ");
printf("fail\n");
r = -1;
goto end2;
}
printf("pass\n");
printf("\n");
printf("checking\n");
printf("\n");
printf("check point 04: ");
printf("fail\n");
r = -1;
goto end2;
}
printf("pass\n");
printf("\n");
printf("checking\n");
printf("\n");
printf("check point 05: ");
printf("fail\n");
r = -1;
goto end2;
}
printf("pass\n");
printf("\n");
printf("checking\n");
printf("\n");
printf("check point 06: ");
printf("fail\n");
r = -1;
goto end2;
}
printf("pass\n");
printf("\n");
printf("checking\n");
printf("\n");
printf("check point 07: ");
printf("fail\n");
r = -1;
goto end2;
}
printf("pass\n");
printf("\n");
printf("checking\n");
printf("\n");
printf("check point 08: ");
printf("fail\n");
r = -1;
goto end2;
}
printf("pass\n");
printf("\n");
printf("checking\n");
printf("\n");
printf("check point 09: ");
printf("fail\n");
r = -1;
goto end2;
}
printf("pass\n");
printf("\n");
printf("checking\n");
printf("\n");
printf("check point 10: ");
printf("fail\n");
r = -1;
goto end2;
}
printf("pass\n");
printf("\n");
printf("checking\n");
printf("\n");
printf("check point 11: ");
printf("fail\n");
r = -1;
goto end2;
}
printf("pass\n");
r = 0;
end2:
if (0 != r2) {
printf("fail at task_join_and_delete(), err=%d\n", r2);
r = -1;
}
end1:
if (0 != r2) {
printf("fail at mutex_delete(), err=%d\n", r2);
r = -1;
}
end0:
r = -1;
}
else {
r = 0;
}
printf("</message>\n");
printf("<result>");
if (0 == r) {
printf("pass");
}
else {
printf("fail");
}
printf("</result>\n");
printf("</test>\n");
printf("\n");
return r;
}
#endif
#endif
void bsp_busywait(unsigned int count)
unsigned int bsp_getbusywaitcountperms(void)
int mutex_unlock(mutex_pt mutex)
int mutex_lock_timed(mutex_pt mutex, unsigned int tick)
int mutex_create(mutex_pt *mutex_p)
int mutex_delete(mutex_pt *mutex_p)
int mutex_lock(mutex_pt mutex)
stdlib (Standard Library) API
int task_create_noautodel(task_pt *task_p, taskfunc_ft func, void *arg, int priority, unsigned int stackdepth, const char *name)
int task_join_and_delete(task_pt *task_p, int *result_p, int count)
int task_sleep(unsigned int tick)
int task_getpriority(task_pt task)
#define NULL
Definition: type.h:42
unsigned int ubik_ticktotimems(unsigned int tick)
#define UBIK_ERR__TIMEOUT
Definition: ubik.h:32
unsigned int ubik_timemstotick(unsigned int timems)
volatile unsigned int _g_ubik_test_count1
태스크 별 시험 진행 상황을 저장하는 전역 변수 1
task_pt _g_ubik_test_task_a[4]
시험 용 태스크 배열
volatile unsigned int _g_ubik_test_count2
태스크 별 시험 진행 상황을 저장하는 전역 변수 2
int ubik_test_mutextest01(void)
Test on basic functions of mutex.
volatile unsigned int _g_ubik_test_result
시험 결과를 저장하는 전역 변수
mutex_pt _g_ubik_test_mutex
시험 용 뮤택스