ULE status, invalid load, buildkernel times.
Jeff Roberson
jroberson at chesapeake.net
Mon Jul 23 22:21:01 UTC 2007
On Mon, 23 Jul 2007, Matt wrote:
> On 7/21/07, Jeff Roberson <jroberson at chesapeake.net> wrote:
>> I have a patch available at:
>>
>> http://people.freebsd.org/~jeff/ulehtt.diff
>>
>> This resolves issues in the code that handles HTT enabled processors and
>> also adds some ULE information to bootverbose on SMP systems. Peter Wemm
>> has a seperate patch that fixes a bug where some amd64 cpus were still
>> being misidentified as HTT. Those of you with invalid loads either have
>> Hyper-threading CPUs or misidentified amd cores. You should expect
>> slightly poorer performance as long as your cores are misidentified but
>> the bad loads should be fixed.
>>
>> I also believe that the buildkernel/world times are now significantly
>> improved. If this is not the case for you please send a mail. Any other
>> performance data is appreciated.
>>
>> Thanks,
>> Jeff
>> _______________________________________________
>> freebsd-current at freebsd.org mailing list
>> http://lists.freebsd.org/mailman/listinfo/freebsd-current
>> To unsubscribe, send any mail to "freebsd-current-unsubscribe at freebsd.org"
>>
>
> -current system with sources update July 22 at approx. 3PM central
> time with the ulehtt.diff patch applied experienced a panic this
> afternoon while restarting a local Apache Tomcat server. Backtrace
> information is shown below. Unclear to me whether or not the patch
> and the panic are related.
I suspect that this is unrelated to my patch but I can't say for certain.
There have been some kse locking problems that Attilio has a patch for. I
believe it went in today. Hopefully he will comment.
This does show that you are using libkse which is deprecated. You should
switch to libthr as it will perform significantly better for you.
Thanks,
Jeff
>
> Matt
>
> (kgdb) mtosto-bsd# kgdb kernel.debug /var/crash/vmcore.1
> [GDB will not be able to debug user-mode threads:
> /usr/lib/libthread_db.so: Undefined symbol "ps_pglobal_lookup"]
> GNU gdb 6.1.1 [FreeBSD]
> Copyright 2004 Free Software Foundation, Inc.
> GDB is free software, covered by the GNU General Public License, and you are
> welcome to change it and/or distribute copies of it under certain conditions.
> Type "show copying" to see the conditions.
> There is absolutely no warranty for GDB. Type "show warranty" for details.
> This GDB was configured as "i386-marcel-freebsd".
>
> Unread portion of the kernel message buffer:
> panic: kse_wakeup: no owner
> cpuid = 1
> Uptime: 23h29m24s
> Physical memory: 2030 MB
> Dumping 288 MB: 273 257 241 225 209 193 177 161 145 129 113 97 81 65 49 33 17
> 1
>
> #0 doadump () at pcpu.h:195
> 195 __asm __volatile("movl %%fs:0,%0" : "=r" (td));
> (kgdb) bt
> #0 doadump () at pcpu.h:195
> #1 0xc05d57c7 in boot (howto=260) at /usr/src/sys/kern/kern_shutdown.c:409
> #2 0xc05d5abb in panic (fmt=Variable "fmt" is not available.
> ) at /usr/src/sys/kern/kern_shutdown.c:563
> #3 0xc05bc398 in kse_wakeup (td=0xc5f99440, uap=0xe8787cfc)
> at /usr/src/sys/kern/kern_kse.c:536
> #4 0xc0829355 in syscall (frame=0xe8787d38) at
> /usr/src/sys/i386/i386/trap.c:1006
> #5 0xc080f1b0 in Xint0x80_syscall () at
> /usr/src/sys/i386/i386/exception.s:196
> #6 0x00000033 in ?? ()
> Previous frame inner to this frame (corrupt stack?)
> (kgdb) list *0xc05bc398
> 0xc05bc398 is in kse_wakeup (/usr/src/sys/kern/kern_kse.c:537).
> 532 return (ESRCH);
> 533 }
> 534 if ((td2 = ku->ku_owner) == NULL) {
> 535 PROC_SUNLOCK(p);
> 536 panic("%s: no owner", __func__);
> 537 } else if (td2->td_kflags & (TDK_KSEREL | TDK_KSERELSIG)) {
> 538 if (!(td2->td_kflags & TDK_WAKEUP)) {
> 539 td2->td_kflags |= TDK_WAKEUP;
> 540 if (td2->td_kflags & TDK_KSEREL)
> 541 sleepq_remove(td2, &p->p_completed);
> (kgdb) list *0xc0829355
> 0xc0829355 is in syscall (/usr/src/sys/i386/i386/trap.c:1006).
> 1001 STOPEVENT(p, S_SCE, narg);
> 1002
> 1003 PTRACESTOP_SC(p, td, S_PT_SCE);
> 1004
> 1005 AUDIT_SYSCALL_ENTER(code, td);
> 1006 error = (*callp->sy_call)(td, args);
> 1007 AUDIT_SYSCALL_EXIT(error, td);
> 1008 }
> 1009
> 1010 switch (error) {
> (kgdb) list *0xc080f1b0
> 0xc080f1b0 is at /usr/src/sys/i386/i386/exception.s:197.
> 192 pushl %fs
> 193 SET_KERNEL_SREGS
> 194 FAKE_MCOUNT(TF_EIP(%esp))
> 195 pushl %esp
> 196 call syscall
> 197 add $4, %esp
> 198 MEXITCOUNT
> 199 jmp doreti
> 200
> 201 ENTRY(fork_trampoline)
> (kgdb)
> _______________________________________________
> freebsd-current at freebsd.org mailing list
> http://lists.freebsd.org/mailman/listinfo/freebsd-current
> To unsubscribe, send any mail to "freebsd-current-unsubscribe at freebsd.org"
>
More information about the freebsd-current
mailing list