RFR: 7194254 jstack reports wrong thread priorities

Dmytro Sheyko dmytro_sheyko at hotmail.com
Fri Sep 7 01:21:08 PDT 2012


David,

Maybe it makes sense to do some little corrections in format specifiers:

    st->print("#" INT64_FORMAT " ", java_lang_Thread::thread_id(thread_oop));
    if (java_lang_Thread::is_daemon(thread_oop))  st->print("daemon ");
    st->print("prio=" INT32_FORMAT " ", java_lang_Thread::priority(thread_oop));

instead of

    st->print("#%ld ", java_lang_Thread::thread_id(thread_oop));
    if (java_lang_Thread::is_daemon(thread_oop))  st->print("daemon ");
    st->print("prio=%d ", java_lang_Thread::priority(thread_oop));

Thanks,
Dmytro


> Date: Fri, 7 Sep 2012 16:54:32 +1000
> From: david.holmes at oracle.com
> To: hotspot-dev at openjdk.java.net
> CC: dmytro_sheyko at hotmail.com; serviceability-dev at openjdk.java.net
> Subject: RFR: 7194254 jstack reports wrong thread priorities
> 
> This is a formal request for review for the patch contributed by Dymtro 
> Sheyko as discussed previously here:
> 
> http://mail.openjdk.java.net/pipermail/hotspot-dev/2012-August/006376.html
> 
> I am one reviewer of course.
> 
> The webrev is here:
> 
> http://cr.openjdk.java.net/~dholmes/7194254/webrev.v1/
> 
> The fix has two components:
> 
> 1. It fixes a bug in os::get_priority that assumed a more positive 
> integer was always higher priority than a less positive one.
> 
> 2. It addresses the problem that os::get_priority is often inexact when 
> desiring the Java thread priority (because the mapping from Java 
> priority to OS priority is often M:1) by not using it in 
> Threads::print_on. Instead Threads::print_on will always report the 
> native OS priority, and JavaThread::print_on() will print the 
> java.lang.Thread.getId() value together with the 
> java.lang.Thread.getPriority() value.
> 
> This change in output affects all stackdumps including crash logs and 
> thread dumps (including those shown by jstack).
> 
> There is also a test program to check jstack output. I'll be doing some 
> additional validation while the RFR is in progress.
> 
> Thanks,
> David
 		 	   		  


More information about the hotspot-dev mailing list