#define _GNU_SOURCE #include #include #include #include #include #include #include #include #include pthread_mutex_t mutex1; pthread_cond_t cond1; pthread_mutex_t mutex2; pthread_cond_t cond2; char *m; int flag1, flag2; int sigst; pthread_t thr; void sigsegv(int s) { if (sigst == 1) { fprintf(stderr, "CT01007 munmap OK (SIGSEGV)\n"); pthread_join(thr, NULL); fprintf(stderr, "CT01008 exit(pthread_join) OK\n"); fprintf(stderr, "CT01009 futex (pthread_mutex/pthread_cond) OK\n"); fprintf(stderr, "CT01010 END\n"); exit(0); } printf("BAD SIGSEGV\n"); exit(1); } void * util_thread(void *arg) { int rc; rc = syscall(732); if (rc == -1) fprintf(stderr, "CT01003 running on Linux OK\n"); else { fprintf(stderr, "CT01003 running on McKernel NG\n", rc); exit(1); } errno = 0; m = mmap(NULL, 4096, PROT_READ|PROT_WRITE, MAP_PRIVATE|MAP_ANONYMOUS, -1, 0); if (m != (void *)-1) { fprintf(stderr, "CT01004 mmap OK\n"); } else { fprintf(stderr, "CT01004 mmap NG errno=%d\n", errno); exit(1); } strcpy(m, "mmap OK"); pthread_mutex_lock(&mutex1); flag1 = 1; pthread_cond_signal(&cond1); pthread_mutex_unlock(&mutex1); pthread_mutex_lock(&mutex2); while(!flag2) { pthread_cond_wait(&cond2, &mutex2); } flag2 = 0; pthread_mutex_unlock(&mutex2); rc = munmap(m, 4096); if (rc == 0) { fprintf(stderr, "CT01006 munmap OK\n"); } else { fprintf(stderr, "CT01006 munmap NG errno=%d\n", errno); exit(1); } pthread_mutex_lock(&mutex1); flag1 = 1; pthread_cond_signal(&cond1); pthread_mutex_unlock(&mutex1); return NULL; } int main(int argc, char **argv) { int rc; signal(SIGSEGV, sigsegv); pthread_mutex_init(&mutex1, NULL); pthread_cond_init(&cond1, NULL); pthread_mutex_init(&mutex2, NULL); pthread_cond_init(&cond2, NULL); fprintf(stderr, "CT01001 mmap/munmap/futex/exit START\n"); rc = syscall(731, 1, NULL); if (rc) { fprintf(stderr, "util_indicate_clone rc=%d, errno=%d\n", rc, errno); fflush(stderr); } rc = pthread_create(&thr, NULL, util_thread, NULL); if(rc){ fprintf(stderr, "pthread_create: %d\n", rc); exit(1); } fprintf(stderr, "CT01002 pthread_create OK\n"); pthread_mutex_lock(&mutex1); while(!flag1) { pthread_cond_wait(&cond1, &mutex1); } flag1 = 0; pthread_mutex_unlock(&mutex1); fprintf(stderr, "CT01005 %s\n", m); pthread_mutex_lock(&mutex2); flag2 = 1; pthread_cond_signal(&cond2); pthread_mutex_unlock(&mutex2); pthread_mutex_lock(&mutex1); while(!flag1) { pthread_cond_wait(&cond1, &mutex1); } flag1 = 0; pthread_mutex_unlock(&mutex1); sigst = 1; fprintf(stderr, "%s\n", m); fprintf(stderr, "CT01007 munmap NG\n"); pthread_join(thr, NULL); fprintf(stderr, "CT01008 exit(pthread_join) OK\n"); fprintf(stderr, "CT01009 futex (pthread_mutex/pthread_cond) OK\n"); fprintf(stderr, "CT01010 END\n"); exit(0); }