/* * Copyright (c) 2022 Huawei Device Co., Ltd. * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ #include #include #include #include #include #include #include #include "test.h" #define SIGNUM 40 #define SLEEPTIME 5 static int count = 0; void handler(int sig) { count++; return; } /** * @tc.name : timer_create_0100 * @tc.desc : create a per-process timer * @tc.level : Level 0 */ void timer_create_0100(void) { struct sigevent sev; timer_t timerid; sev.sigev_notify = SIGEV_SIGNAL; sev.sigev_signo = SIGNUM; sev.sigev_value.sival_ptr = &timerid; signal(SIGNUM, handler); int result = timer_create(CLOCK_REALTIME, &sev, &timerid); if (result != 0) { t_error("%s failed: result = %d\n", __func__, result); } struct itimerspec its; its.it_value.tv_sec = 1; its.it_value.tv_nsec = 0; its.it_interval.tv_sec = its.it_value.tv_sec; its.it_interval.tv_nsec = its.it_value.tv_nsec; result = timer_settime(timerid, 0, &its, NULL); if (result != 0) { t_error("%s failed: result = %d\n", __func__, result); } while (count <= 0) { sleep(1); } result = timer_delete(timerid); if (result != 0) { t_error("%s failed: result = %d\n", __func__, result); } } /** * @tc.name : timer_create_0200 * @tc.desc : create a per-process timer with invalid parameters * @tc.level : Level 2 */ void timer_create_0200(void) { errno = 0; int result = timer_create(-1, NULL, NULL); if (result == 0) { t_error("%s failed: result = %d\n", __func__, result); } if (errno != EINVAL) { t_error("%s failed: errno = %d\n", __func__, errno); } } void timer_handler(union sigval sv) { void *data = sv.sival_ptr; printf("timer_handler handler: %p \n", data); dlclose(data); printf("dlclose data \n"); } /** * @tc.name : timer_create_0300 * @tc.desc : create a per-process timer with SIGEV_THREAD mode * @tc.level : Level 2 */ void timer_create_0300(void) { timer_t timerid; struct sigevent sev; struct itimerspec its; int ret; void* handle = dlopen("/data/local/tmp/libtls_timer.so", RTLD_LAZY); if (handle == NULL) { t_error("%s dlopen error \n", __func__); return; } sev.sigev_notify = SIGEV_THREAD; sev.sigev_notify_function = timer_handler; sev.sigev_notify_attributes = NULL; sev.sigev_value.sival_ptr = handle; ret = timer_create(CLOCK_REALTIME, &sev, &timerid); if (ret == -1) { t_error("%s timer_create failed \n", __func__); return; } printf("timer_create succeed: %lu \n", (unsigned long)timerid); its.it_value.tv_sec = 1; its.it_value.tv_nsec = 0; its.it_interval.tv_sec = 0; its.it_interval.tv_nsec = 0; ret = timer_settime(timerid, 0, &its, NULL); if (ret == -1) { t_error("%s timer_settime failed \n", __func__); return; } for (int i = 0; i < SLEEPTIME; i++) { printf("main running waiting for callback: %d \n", i); sleep(1); } ret = timer_delete(timerid); if (ret == -1) { t_error("%s timer_delete failed \n", __func__); return; } } int main(int argc, char *argv[]) { timer_create_0100(); timer_create_0200(); timer_create_0300(); return t_status; }