Date: Tue, 24 Jun 2008 12:14:26 +0530 From: "Saradhi Kothapalli" <saikothapalli@gmail.com> To: freebsd-threads@freebsd.org Subject: Threads stuck in kserel state Message-ID: <52db57fb0806232344y95eb159ra2dd43a4462ee082@mail.gmail.com>
next in thread | raw e-mail | index | archive | help
Hi I am running FreeBSD 5.4 on my machine. When i run mpd on it, i see it stuck in kserel state. I have written a sample thread program to check whether its an mpd problem or not. Observations on the Sample test program: I have created only one thread from the process, but the top output shows total 3 entries. Even when the thread has finished i see 2 entries that to one in kserel and other in ksesig state. Is the main process stuck in "kserel" state or is it an expected behavior? Is it because of KSE the other thread is shown in top output? Is the state "ksesig" signifies that it is waiting for an event to occur? Thanks in advance for the help. Regards Saradhi The Sample Test program: #include <stdio.h> #include <pthread.h> #include <pdel/structs/structs.h> #include <pdel/structs/type/array.h> #include <pdel/util/typed_mem.h> #include <pdel/util/pevent.h> #include <pdel/util/paction.h> #include <pdel/util/ghash.h> #include <unistd.h> pthread_mutex_t mutex; static void startFn(void * arg) { printf("\n *** Thread Start Function *** \n"); getchar(); return; } static void endFn(void * arg, int done) { printf("\n *** Thread End Function *** \n"); getchar(); return; } static void thrStart() { struct paction * thr; uint32_t temp; if ( paction_start(&thr, &mutex, startFn, endFn, &temp) == -1 ) { printf("\n *** Failed to start thread *** \n "); getchar(); } return ; } int main() { int ret = pthread_mutex_init(&mutex, NULL); if ( ret != 0 ) { printf("\n *** Mutex initialization Failed *** \n"); return -1; } printf("\n *** calling thread start *** \n "); getchar(); thrStart(); for ( ; ; ) { sleep(1); } return 0; } THE TOP OUTPUT WITH THREAD DISPLAY TURNED ON: When the thread is in existence (both during start and end function): ----------------------------------------------------------------------------------------------------- 18387 root 20 0 3384K 1760K ksesig 0:00 0.00% 0.00% thrd 18387 root 20 0 3384K 1760K kserel 0:00 0.00% 0.00% thrd 18387 root 5 0 3384K 1760K ttyin 0:00 0.00% 0.00% thrd After the thread execution is completed (the for loop): --------------------------------------------------------- 18387 root 20 0 3384K 1752K ksesig 0:00 0.00% 0.00% thrd 18387 root 20 0 3384K 1752K kserel 0:00 0.00% 0.00% thrd
Want to link to this message? Use this URL: <https://mail-archive.FreeBSD.org/cgi/mid.cgi?52db57fb0806232344y95eb159ra2dd43a4462ee082>