123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207 |
- /*
- * Copyright (c) 2006-2021, RT-Thread Development Team
- *
- * SPDX-License-Identifier: Apache-2.0
- *
- * Change Logs:
- * Date Author Notes
- * 2021-08-12 flybreak the first version
- *
- * case 1:rt_signal_install, install all available signal
- * case 2:rt_signal_install, install illegal signal
- * case 3:rt_signal_mask/unmask, one thread self, install and unmask, then kill, should received.
- * case 4:rt_signal_mask/unmask, one thread self, install and unmask and mask, then kill, should can't received.
- * case 5:rt_signal_wait, two thread, thread1: install and unmask, then wait 1s; thread2: kill, should received.
- * case 6:rt_signal_wait, two thread, thread1: install and unmask, then wait 1s; thread2: sleep 2s then kill, should can't received.
- * case 7:rt_signal_kill, kill legal thread, return 0;
- * case 8:rt_signal_kill, kill illegal thread, return failed (unused);
- * case 9:rt_signal_kill, kill illegal signo, return -RT_EINVAL;
- *
- */
- #include <rtthread.h>
- #include "utest.h"
- static volatile int recive_sig = 0;
- static struct rt_semaphore _received_signal;
- void sig_handle_default(int signo)
- {
- recive_sig = signo;
- }
- static void rt_signal_install_test(void)
- {
- int signo;
- rt_sighandler_t result;
- /* case 1:rt_signal_install, install all available signal. */
- for (signo = 0; signo < RT_SIG_MAX; signo++)
- {
- result = rt_signal_install(signo, sig_handle_default);
- uassert_true(result != SIG_ERR);
- }
- /* case 2:rt_signal_install, install illegal signal. */
- result = rt_signal_install(signo, sig_handle_default);
- uassert_true(result == SIG_ERR);
- return;
- }
- static void rt_signal_mask_test(void)
- {
- int signo;
- rt_sighandler_t result;
- /* case 3:rt_signal_mask/unmask, one thread self, install and unmask, then kill, should received. */
- for (signo = 0; signo < RT_SIG_MAX; signo++)
- {
- recive_sig = -1;
- result = rt_signal_install(signo, sig_handle_default);
- uassert_true(result != SIG_ERR);
- rt_signal_unmask(signo);
- uassert_int_equal(rt_thread_kill(rt_thread_self(), signo), RT_EOK);
- rt_thread_mdelay(1);
- uassert_int_equal(recive_sig, signo);
- }
- return;
- }
- static void rt_signal_unmask_test(void)
- {
- int signo;
- rt_sighandler_t result;
- /* case 4:rt_signal_mask/unmask, one thread self, install and unmask and mask, then kill, should can't received. */
- for (signo = 0; signo < RT_SIG_MAX; signo++)
- {
- recive_sig = -1;
- result = rt_signal_install(signo, sig_handle_default);
- uassert_true(result != SIG_ERR);
- rt_signal_unmask(signo);
- rt_signal_mask(signo);
- uassert_int_equal(rt_thread_kill(rt_thread_self(), signo), RT_EOK);
- rt_thread_mdelay(1);
- uassert_int_not_equal(recive_sig, signo);
- }
- return;
- }
- static void rt_signal_kill_test(void)
- {
- int signo;
- rt_sighandler_t result;
- /* case 7:rt_signal_kill, kill legal thread, return 0; */
- for (signo = 0; signo < RT_SIG_MAX; signo++)
- {
- recive_sig = -1;
- result = rt_signal_install(signo, sig_handle_default);
- uassert_true(result != SIG_ERR);
- rt_signal_unmask(signo);
- uassert_int_equal(rt_thread_kill(rt_thread_self(), signo), RT_EOK);
- rt_thread_mdelay(1);
- uassert_int_equal(recive_sig, signo);
- }
- /* case 8:rt_signal_kill, kill illegal thread, return failed; */
- // uassert_true(rt_thread_kill((rt_thread_t)-1, signo) == -RT_ERROR);
- /* case 9:rt_signal_kill, kill illegal signo, return -RT_EINVAL; */
- uassert_true(rt_thread_kill(rt_thread_self(), -1) == -RT_EINVAL);
- return;
- }
- void rt_signal_wait_thread(void *parm)
- {
- sigset_t selectset;
- siginfo_t recive_si;
- rt_signal_install(SIGUSR1, sig_handle_default);
- rt_signal_unmask(SIGUSR1);
- (void)sigemptyset(&selectset);
- (void)sigaddset(&selectset, SIGUSR1);
- /* case 5:rt_signal_wait, two thread, thread1: install and unmask, then wait 1s; thread2: kill, should received. */
- if (rt_signal_wait((void *)&selectset, &recive_si, RT_TICK_PER_SECOND) != RT_EOK)
- {
- return;
- }
- recive_sig = recive_si.si_signo;
- LOG_I("received signal %d", recive_sig);
- rt_sem_release(&_received_signal);
- }
- static void rt_signal_wait_test(void)
- {
- rt_thread_t t1;
- recive_sig = -1;
- t1 = rt_thread_create("sig_t1", rt_signal_wait_thread, 0, 4096, 14, 10);
- if (t1)
- {
- rt_thread_startup(t1);
- }
- rt_thread_mdelay(1);
- /* case 5:rt_signal_wait, two thread, thread1: install and unmask, then wait 1s; thread2: kill, should received. */
- uassert_int_equal(rt_thread_kill(t1, SIGUSR1), RT_EOK);
- rt_sem_take(&_received_signal, RT_WAITING_FOREVER);
- uassert_int_equal(recive_sig, SIGUSR1);
- return;
- }
- static void rt_signal_wait_test2(void)
- {
- rt_thread_t t1;
- recive_sig = -1;
- t1 = rt_thread_create("sig_t1", rt_signal_wait_thread, 0, 4096, 14, 10);
- if (t1)
- {
- rt_thread_startup(t1);
- }
- /* case 6:rt_signal_wait, two thread, thread1: install and unmask, then wait 1s; thread2: sleep 2s then kill, should can't received. */
- rt_thread_mdelay(2000);
- uassert_int_equal(rt_thread_kill(t1, SIGUSR1), RT_EOK);
- uassert_int_not_equal(
- rt_sem_take(&_received_signal, 1),
- RT_EOK);
- uassert_int_not_equal(recive_sig, SIGUSR1);
- return;
- }
- static rt_err_t utest_tc_init(void)
- {
- rt_sem_init(&_received_signal, "utest", 0, RT_IPC_FLAG_PRIO);
- return RT_EOK;
- }
- static rt_err_t utest_tc_cleanup(void)
- {
- rt_sem_detach(&_received_signal);
- return RT_EOK;
- }
- static void testcase(void)
- {
- #ifdef RT_USING_HEAP
- UTEST_UNIT_RUN(rt_signal_install_test);
- UTEST_UNIT_RUN(rt_signal_mask_test);
- UTEST_UNIT_RUN(rt_signal_unmask_test);
- UTEST_UNIT_RUN(rt_signal_kill_test);
- UTEST_UNIT_RUN(rt_signal_wait_test);
- UTEST_UNIT_RUN(rt_signal_wait_test2);
- #endif /* RT_USING_HEAP */
- }
- UTEST_TC_EXPORT(testcase, "testcases.kernel.signal_tc", utest_tc_init, utest_tc_cleanup, 1000);
- /*********************** end of file ****************************/
|