23 */
24
25 #include "precompiled.hpp"
26 #include "oops/oop.inline.hpp"
27 #include "runtime/osThread.hpp"
28
29 OSThread::OSThread(OSThreadStartFunc start_proc, void* start_parm) {
30 pd_initialize();
31 set_start_proc(start_proc);
32 set_start_parm(start_parm);
33 set_interrupted(false);
34 }
35
36 OSThread::~OSThread() {
37 pd_destroy();
38 }
39
40 // Printing
41 void OSThread::print_on(outputStream *st) const {
42 st->print("nid=0x%x ", thread_id());
43 switch (_state) {
44 case ALLOCATED: st->print("allocated "); break;
45 case INITIALIZED: st->print("initialized "); break;
46 case RUNNABLE: st->print("runnable "); break;
47 case MONITOR_WAIT: st->print("waiting for monitor entry "); break;
48 case CONDVAR_WAIT: st->print("waiting on condition "); break;
49 case OBJECT_WAIT: st->print("in Object.wait() "); break;
50 case BREAKPOINTED: st->print("at breakpoint"); break;
51 case SLEEPING: st->print("sleeping"); break;
52 case ZOMBIE: st->print("zombie"); break;
53 default: st->print("unknown state %d", _state); break;
54 }
55 }
|
23 */
24
25 #include "precompiled.hpp"
26 #include "oops/oop.inline.hpp"
27 #include "runtime/osThread.hpp"
28
29 OSThread::OSThread(OSThreadStartFunc start_proc, void* start_parm) {
30 pd_initialize();
31 set_start_proc(start_proc);
32 set_start_parm(start_parm);
33 set_interrupted(false);
34 }
35
36 OSThread::~OSThread() {
37 pd_destroy();
38 }
39
40 // Printing
41 void OSThread::print_on(outputStream *st) const {
42 st->print("nid=0x%x ", thread_id());
43
44 #ifdef _AIX
45 if (PrintExtendedThreadInfo) { st->print("ktid=" UINT64_FORMAT " ", kernel_thread_id()); }
46 #endif
47
48 #if defined(LINUX) || defined(BSD)
49 if (PrintExtendedThreadInfo) { st->print("pthread-id=0x%lx ", (unsigned long) pthread_id()); }
50 #endif
51 #if defined(__sun)
52 if (PrintExtendedThreadInfo) { st->print("lwp-id=0x%lx ", lwp_id()); }
53 #endif
54
55 switch (_state) {
56 case ALLOCATED: st->print("allocated "); break;
57 case INITIALIZED: st->print("initialized "); break;
58 case RUNNABLE: st->print("runnable "); break;
59 case MONITOR_WAIT: st->print("waiting for monitor entry "); break;
60 case CONDVAR_WAIT: st->print("waiting on condition "); break;
61 case OBJECT_WAIT: st->print("in Object.wait() "); break;
62 case BREAKPOINTED: st->print("at breakpoint"); break;
63 case SLEEPING: st->print("sleeping"); break;
64 case ZOMBIE: st->print("zombie"); break;
65 default: st->print("unknown state %d", _state); break;
66 }
67 }
|