On Thu, Mar 21, 2013 at 03:58:35PM +0200, Konstantin Belousov wrote:
> ...
> > Script started on Thu Mar 21 06:07:41 2013
> > g1-235(10.0-C)[1] uname -a
> > FreeBSD g1-235.catwhisker.org 10.0-CURRENT FreeBSD 10.0-CURRENT #845  
> > r248575M/248575: Thu Mar 21 05:35:06 PDT 2013     
> > r...@g1-235.catwhisker.org:/usr/obj/usr/src/sys/CANARY  i386
> > g1-235(10.0-C)[2] sysctl vfs.unmapped_buf_allowed kern.bio_transient_maxcnt 
> > kern.nbuf
> > vfs.unmapped_buf_allowed: 1
> > kern.bio_transient_maxcnt: 697
> > kern.nbuf: 7224
> Could you, please, do some more measurements in the r248575M ?
> 
> Please show the kern.nbuf for vfs.unmapped_buf_allowed=0 case.
> Also, from there, run "kgdb /boot/kernel/kernel /dev/mem" and do
> p *buffer_map.
> 
> Reboot without applying any unmapped/transient tuning, run the kgdb
> again, and do
> p *buffer_map
> p *bio_transient_map
> 
> Reboot with kern.bio_transient_maxcnt tunable set to 256 and again
> print the buffer_map and bio_transient_map from the kgdb.
> ...

OK; sorry about the delay -- I needed to use the machinie for a while
(at work), and then I had a weekly staff meeting....

Anyway... I've attached results of the above.  For the first & last, I
did each twice -- once using the "nv" driver, and once using the
"nvidia" driver.  (The middle one only got the "nv" driver.)

So the files are:

kib_0_nv
kib_0_nvidia
kib_1_nv
kib_2_nv
kib_2_nvidia

Peace,
david
-- 
David H. Wolfskill                              da...@catwhisker.org
Taliban: Evil men with guns afraid of truth from a 14-year old girl.

See http://www.catwhisker.org/~david/publickey.gpg for my public key.
Script started on Thu Mar 21 10:39:14 2013
root@d129:~ # uname -a

FreeBSD g1-235.catwhisker.org 10.0-CURRENT FreeBSD 10.0-CURRENT #845  
r248575M/248575: Thu Mar 21 05:35:06 PDT 2013     
r...@g1-235.catwhisker.org:/usr/obj/usr/src/sys/CANARY  i386
root@d129:~ # sysctl vfs.unmapped_buf_allowed

vfs.unmapped_buf_allowed: 0
root@d129:~ # ksystctl kern.nbuf

kern.nbuf: 7224
root@d129:~ # kgdb /boot/kernel/kernel /dev/mem

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"...
Reading symbols from /boot/kernel/linux.ko...Reading symbols from 
/boot/kernel/linux.ko.symbols...done.
done.
Loaded symbols for /boot/kernel/linux.ko
Reading symbols from /boot/kernel/coretemp.ko...Reading symbols from 
/boot/kernel/coretemp.ko.symbols...done.
done.
Loaded symbols for /boot/kernel/coretemp.ko
Reading symbols from /boot/kernel/iwn5000fw.ko...Reading symbols from 
/boot/kernel/iwn5000fw.ko.symbols...done.
done.
Loaded symbols for /boot/kernel/iwn5000fw.ko
Reading symbols from /boot/kernel/tmpfs.ko...Reading symbols from 
/boot/kernel/tmpfs.ko.symbols...done.
done.
Loaded symbols for /boot/kernel/tmpfs.ko
Reading symbols from /boot/kernel/fdescfs.ko...Reading symbols from 
/boot/kernel/fdescfs.ko.symbols...done.
done.
Loaded symbols for /boot/kernel/fdescfs.ko
#0  sched_switch (td=0xc1312a70, newtd=0xcd98b900, flags=-1048441924)
    at /usr/src/sys/kern/sched_ule.c:1954
1954                    cpuid = PCPU_GET(cpuid);
(kgdb) p *buffer_map
$1 = {header = {prev = 0xc19cf288, next = 0xc19cf288, left = 0x0, right = 0x0, 
    start = 3925868544, end = 4044226560, avail_ssize = 0, adj_free = 0, 
    max_free = 0, object = {vm_object = 0x0, sub_map = 0x0}, offset = 0, 
    eflags = 0, protection = 0 '\0', max_protection = 0 '\0', 
    inheritance = 0 '\0', read_ahead = 0 '\0', wired_count = 0, next_read = 0, 
    cred = 0x0}, lock = {lock_object = {lo_name = 0xc0fc6c80 "vm map (user)", 
      lo_flags = 36896768, lo_data = 0, lo_witness = 0xcd8022b0}, 
    sx_lock = 1}, system_mtx = {lock_object = {
      lo_name = 0xc0fc6c52 "vm map (system)", lo_flags = 21168128, 
      lo_data = 0, lo_witness = 0xcd802110}, mtx_lock = 4}, nentries = 1, 
  size = 84590592, timestamp = 5163, needs_wakeup = 0 '\0', 
  system_map = 1 '\001', flags = 0 '\0', root = 0xc19cf288, pmap = 0xc13279f8, 
  busy = 0}
Current language:  auto; currently minimal
(kgdb) p *bio_transient_map
Error accessing memory address 0x0: Bad address.
(kgdb) root@d129:~ # ^Dexit

Script done on Thu Mar 21 10:40:35 2013
Script started on Thu Mar 21 10:43:15 2013
root@d129:~ # uname -a

FreeBSD g1-235.catwhisker.org 10.0-CURRENT FreeBSD 10.0-CURRENT #845  
r248575M/248575: Thu Mar 21 05:35:06 PDT 2013     
r...@g1-235.catwhisker.org:/usr/obj/usr/src/sys/CANARY  i386
root@d129:~ # sysctl vfs.unmapped_buf_allowed

vfs.unmapped_buf_allowed: 0
root@d129:~ # sysctl kern.nbuf

kern.nbuf: 7224
root@d129:~ # kgdpb /boot/kernel/kernel /dev/mem

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"...
Reading symbols from /boot/kernel/linux.ko...Reading symbols from 
/boot/kernel/linux.ko.symbols...done.
done.
Loaded symbols for /boot/kernel/linux.ko
Reading symbols from /boot/kernel/coretemp.ko...Reading symbols from 
/boot/kernel/coretemp.ko.symbols...done.
done.
Loaded symbols for /boot/kernel/coretemp.ko
Reading symbols from /boot/kernel/iwn5000fw.ko...Reading symbols from 
/boot/kernel/iwn5000fw.ko.symbols...done.
done.
Loaded symbols for /boot/kernel/iwn5000fw.ko
Reading symbols from /boot/modules/nvidia.ko...done.
Loaded symbols for /boot/modules/nvidia.ko
Reading symbols from /boot/kernel/tmpfs.ko...Reading symbols from 
/boot/kernel/tmpfs.ko.symbols...done.
done.
Loaded symbols for /boot/kernel/tmpfs.ko
Reading symbols from /boot/kernel/fdescfs.ko...Reading symbols from 
/boot/kernel/fdescfs.ko.symbols...done.
done.
Loaded symbols for /boot/kernel/fdescfs.ko
#0  sched_switch (td=0xc1312a70, newtd=0xce18b900, flags=-1040053316)
    at /usr/src/sys/kern/sched_ule.c:1954
1954                    cpuid = PCPU_GET(cpuid);
(kgdb) p *buffer_map
$1 = {header = {prev = 0xc21ce630, next = 0xc21ce630, left = 0x0, right = 0x0, 
    start = 3934257152, end = 4052615168, avail_ssize = 0, adj_free = 0, 
    max_free = 0, object = {vm_object = 0x0, sub_map = 0x0}, offset = 0, 
    eflags = 0, protection = 0 '\0', max_protection = 0 '\0', 
    inheritance = 0 '\0', read_ahead = 0 '\0', wired_count = 0, next_read = 0, 
    cred = 0x0}, lock = {lock_object = {lo_name = 0xc0fc6c80 "vm map (user)", 
      lo_flags = 36896768, lo_data = 0, lo_witness = 0xce0022b0}, 
    sx_lock = 1}, system_mtx = {lock_object = {
      lo_name = 0xc0fc6c52 "vm map (system)", lo_flags = 21168128, 
      lo_data = 0, lo_witness = 0xce002110}, mtx_lock = 4}, nentries = 1, 
  size = 85229568, timestamp = 5202, needs_wakeup = 0 '\0', 
  system_map = 1 '\001', flags = 0 '\0', root = 0xc21ce630, pmap = 0xc13279f8, 
  busy = 0}
Current language:  auto; currently minimal
(kgdb) p *bio_transient_map
Error accessing memory address 0x0: Bad address.
(kgdb) root@d129:~ # ^Dexit

Script done on Thu Mar 21 10:44:35 2013
Script started on Thu Mar 21 10:46:18 2013
root@d129:~ # uname -a

FreeBSD g1-235.catwhisker.org 10.0-CURRENT FreeBSD 10.0-CURRENT #845  
r248575M/248575: Thu Mar 21 05:35:06 PDT 2013     
r...@g1-235.catwhisker.org:/usr/obj/usr/src/sys/CANARY  i386
root@d129:~ # sysctl vfs.unmapped_buf_allowed

vfs.unmapped_buf_allowed: 1
root@d129:~ # sysctl kern.nbuf

kern.nbuf: 7224
root@d129:~ # kgdb /boot/kernel/kernel /dev/mem

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"...
Reading symbols from /boot/kernel/linux.ko...Reading symbols from 
/boot/kernel/linux.ko.symbols...done.
done.
Loaded symbols for /boot/kernel/linux.ko
Reading symbols from /boot/kernel/coretemp.ko...Reading symbols from 
/boot/kernel/coretemp.ko.symbols...done.
done.
Loaded symbols for /boot/kernel/coretemp.ko
Reading symbols from /boot/kernel/iwn5000fw.ko...Reading symbols from 
/boot/kernel/iwn5000fw.ko.symbols...done.
done.
Loaded symbols for /boot/kernel/iwn5000fw.ko
Reading symbols from /boot/kernel/tmpfs.ko...Reading symbols from 
/boot/kernel/tmpfs.ko.symbols...done.
done.
Loaded symbols for /boot/kernel/tmpfs.ko
Reading symbols from /boot/kernel/fdescfs.ko...Reading symbols from 
/boot/kernel/fdescfs.ko.symbols...done.
done.
Loaded symbols for /boot/kernel/fdescfs.ko
#0  sched_switch (td=0xc1312a70, newtd=0xcd98b600, flags=-1048441924)
    at /usr/src/sys/kern/sched_ule.c:1954
1954                    cpuid = PCPU_GET(cpuid);
(kgdb) p *buffer_map
$1 = {header = {prev = 0xc19ceb88, next = 0xc19ceb88, left = 0x0, right = 0x0, 
    start = 3925868544, end = 4044226560, avail_ssize = 0, adj_free = 0, 
    max_free = 0, object = {vm_object = 0x0, sub_map = 0x0}, offset = 0, 
    eflags = 0, protection = 0 '\0', max_protection = 0 '\0', 
    inheritance = 0 '\0', read_ahead = 0 '\0', wired_count = 0, next_read = 0, 
    cred = 0x0}, lock = {lock_object = {lo_name = 0xc0fc6c80 "vm map (user)", 
      lo_flags = 36896768, lo_data = 0, lo_witness = 0xcd8022b0}, 
    sx_lock = 1}, system_mtx = {lock_object = {
      lo_name = 0xc0fc6c52 "vm map (system)", lo_flags = 21168128, 
      lo_data = 0, lo_witness = 0xcd802110}, mtx_lock = 4}, nentries = 1, 
  size = 8765440, timestamp = 535, needs_wakeup = 0 '\0', 
  system_map = 1 '\001', flags = 0 '\0', root = 0xc19ceb88, pmap = 0xc13279f8, 
  busy = 0}
Current language:  auto; currently minimal
(kgdb) p *bio_transient_map
$2 = {header = {prev = 0xc19c1230, next = 0xc19c1230, left = 0x0, right = 0x0, 
    start = 4044226560, end = 4135583744, avail_ssize = 0, adj_free = 0, 
    max_free = 0, object = {vm_object = 0x0, sub_map = 0x0}, offset = 0, 
    eflags = 0, protection = 0 '\0', max_protection = 0 '\0', 
    inheritance = 0 '\0', read_ahead = 0 '\0', wired_count = 0, next_read = 0, 
    cred = 0x0}, lock = {lock_object = {lo_name = 0xc0fc6c80 "vm map (user)", 
      lo_flags = 36896768, lo_data = 0, lo_witness = 0xcd8022b0}, 
    sx_lock = 1}, system_mtx = {lock_object = {
      lo_name = 0xc0fc6c52 "vm map (system)", lo_flags = 21168128, 
      lo_data = 0, lo_witness = 0xcd802110}, mtx_lock = 4}, nentries = 0, 
  size = 0, timestamp = 0, needs_wakeup = 0 '\0', system_map = 1 '\001', 
  flags = 0 '\0', root = 0x0, pmap = 0xc13279f8, busy = 0}
(kgdb) root@d129:~ # ^Dexit

Script done on Thu Mar 21 10:47:34 2013
Script started on Thu Mar 21 10:49:39 2013
root@d129:~ # uname -a

FreeBSD g1-235.catwhisker.org 10.0-CURRENT FreeBSD 10.0-CURRENT #845  
r248575M/248575: Thu Mar 21 05:35:06 PDT 2013     
r...@g1-235.catwhisker.org:/usr/obj/usr/src/sys/CANARY  i386
root@d129:~ # sysctl vfs.unmapped_buf_allowed kern.bio_transient_maxcnt

vfs.unmapped_buf_allowed: 1
kern.bio_transient_maxcnt: 256
root@d129:~ # kgdb /boot/kernel/kernel /dev/mem

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"...
Reading symbols from /boot/kernel/linux.ko...Reading symbols from 
/boot/kernel/linux.ko.symbols...done.
done.
Loaded symbols for /boot/kernel/linux.ko
Reading symbols from /boot/kernel/coretemp.ko...Reading symbols from 
/boot/kernel/coretemp.ko.symbols...done.
done.
Loaded symbols for /boot/kernel/coretemp.ko
Reading symbols from /boot/kernel/iwn5000fw.ko...Reading symbols from 
/boot/kernel/iwn5000fw.ko.symbols...done.
done.
Loaded symbols for /boot/kernel/iwn5000fw.ko
Reading symbols from /boot/kernel/tmpfs.ko...Reading symbols from 
/boot/kernel/tmpfs.ko.symbols...done.
done.
Loaded symbols for /boot/kernel/tmpfs.ko
Reading symbols from /boot/kernel/fdescfs.ko...Reading symbols from 
/boot/kernel/fdescfs.ko.symbols...done.
done.
Loaded symbols for /boot/kernel/fdescfs.ko
#0  sched_switch (td=0xc1312a70, newtd=0xcd98b600, flags=-1048441924)
    at /usr/src/sys/kern/sched_ule.c:1954
1954                    cpuid = PCPU_GET(cpuid);
(kgdb) p *buffer_map
$1 = {header = {prev = 0xf64f4750, next = 0xf64f4750, left = 0x0, right = 0x0, 
    start = 3925868544, end = 4044226560, avail_ssize = 0, adj_free = 0, 
    max_free = 0, object = {vm_object = 0x0, sub_map = 0x0}, offset = 0, 
    eflags = 0, protection = 0 '\0', max_protection = 0 '\0', 
    inheritance = 0 '\0', read_ahead = 0 '\0', wired_count = 0, next_read = 0, 
    cred = 0x0}, lock = {lock_object = {lo_name = 0xc0fc6c80 "vm map (user)", 
      lo_flags = 36896768, lo_data = 0, lo_witness = 0xcd8022b0}, 
    sx_lock = 1}, system_mtx = {lock_object = {
      lo_name = 0xc0fc6c52 "vm map (system)", lo_flags = 21168128, 
      lo_data = 0, lo_witness = 0xcd802110}, mtx_lock = 4}, nentries = 1, 
  size = 8814592, timestamp = 538, needs_wakeup = 0 '\0', 
  system_map = 1 '\001', flags = 0 '\0', root = 0xf64f4750, pmap = 0xc13279f8, 
  busy = 0}
Current language:  auto; currently minimal
(kgdb) p *bio_transienty_  _map
$2 = {header = {prev = 0xc19c1230, next = 0xc19c1230, left = 0x0, right = 0x0, 
    start = 4044226560, end = 4077780992, avail_ssize = 0, adj_free = 0, 
    max_free = 0, object = {vm_object = 0x0, sub_map = 0x0}, offset = 0, 
    eflags = 0, protection = 0 '\0', max_protection = 0 '\0', 
    inheritance = 0 '\0', read_ahead = 0 '\0', wired_count = 0, next_read = 0, 
    cred = 0x0}, lock = {lock_object = {lo_name = 0xc0fc6c80 "vm map (user)", 
      lo_flags = 36896768, lo_data = 0, lo_witness = 0xcd8022b0}, 
    sx_lock = 1}, system_mtx = {lock_object = {
      lo_name = 0xc0fc6c52 "vm map (system)", lo_flags = 21168128, 
      lo_data = 0, lo_witness = 0xcd802110}, mtx_lock = 4}, nentries = 0, 
  size = 0, timestamp = 0, needs_wakeup = 0 '\0', system_map = 1 '\001', 
  flags = 0 '\0', root = 0x0, pmap = 0xc13279f8, busy = 0}
(kgdb) root@d129:~ # ^Dexit

Script done on Thu Mar 21 10:50:47 2013
Script started on Thu Mar 21 10:52:46 2013
root@d129:~ # uname -a

FreeBSD g1-235.catwhisker.org 10.0-CURRENT FreeBSD 10.0-CURRENT #845  
r248575M/248575: Thu Mar 21 05:35:06 PDT 2013     
r...@g1-235.catwhisker.org:/usr/obj/usr/src/sys/CANARY  i386
root@d129:~ # sysctl vfs.unmapped_buf_allowed kern.bio_transient_macxcnt

vfs.unmapped_buf_allowed: 1
kern.bio_transient_maxcnt: 256
root@d129:~ # kgdb /boot/kernel/kernel /dev/meme

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"...
Reading symbols from /boot/kernel/linux.ko...Reading symbols from 
/boot/kernel/linux.ko.symbols...done.
done.
Loaded symbols for /boot/kernel/linux.ko
Reading symbols from /boot/kernel/coretemp.ko...Reading symbols from 
/boot/kernel/coretemp.ko.symbols...done.
done.
Loaded symbols for /boot/kernel/coretemp.ko
Reading symbols from /boot/kernel/iwn5000fw.ko...Reading symbols from 
/boot/kernel/iwn5000fw.ko.symbols...done.
done.
Loaded symbols for /boot/kernel/iwn5000fw.ko
Reading symbols from /boot/modules/nvidia.ko...done.
Loaded symbols for /boot/modules/nvidia.ko
Reading symbols from /boot/kernel/tmpfs.ko...Reading symbols from 
/boot/kernel/tmpfs.ko.symbols...done.
done.
Loaded symbols for /boot/kernel/tmpfs.ko
Reading symbols from /boot/kernel/fdescfs.ko...Reading symbols from 
/boot/kernel/fdescfs.ko.symbols...done.
done.
Loaded symbols for /boot/kernel/fdescfs.ko
#0  sched_switch (td=0xc1312a70, newtd=0xce18b600, flags=-1040053316)
    at /usr/src/sys/kern/sched_ule.c:1954
1954                    cpuid = PCPU_GET(cpuid);
(kgdb) p *buffer_map
$1 = {header = {prev = 0xc21cfd80, next = 0xc21cfd80, left = 0x0, right = 0x0, 
    start = 3934257152, end = 4052615168, avail_ssize = 0, adj_free = 0, 
    max_free = 0, object = {vm_object = 0x0, sub_map = 0x0}, offset = 0, 
    eflags = 0, protection = 0 '\0', max_protection = 0 '\0', 
    inheritance = 0 '\0', read_ahead = 0 '\0', wired_count = 0, next_read = 0, 
    cred = 0x0}, lock = {lock_object = {lo_name = 0xc0fc6c80 "vm map (user)", 
      lo_flags = 36896768, lo_data = 0, lo_witness = 0xce0022b0}, 
    sx_lock = 1}, system_mtx = {lock_object = {
      lo_name = 0xc0fc6c52 "vm map (system)", lo_flags = 21168128, 
      lo_data = 0, lo_witness = 0xce002110}, mtx_lock = 4}, nentries = 1, 
  size = 8798208, timestamp = 537, needs_wakeup = 0 '\0', 
  system_map = 1 '\001', flags = 0 '\0', root = 0xc21cfd80, pmap = 0xc13279f8, 
  busy = 0}
Current language:  auto; currently minimal
(kgdb) p *bio_transient_map
$2 = {header = {prev = 0xc21c1230, next = 0xc21c1230, left = 0x0, right = 0x0, 
    start = 4052615168, end = 4086169600, avail_ssize = 0, adj_free = 0, 
    max_free = 0, object = {vm_object = 0x0, sub_map = 0x0}, offset = 0, 
    eflags = 0, protection = 0 '\0', max_protection = 0 '\0', 
    inheritance = 0 '\0', read_ahead = 0 '\0', wired_count = 0, next_read = 0, 
    cred = 0x0}, lock = {lock_object = {lo_name = 0xc0fc6c80 "vm map (user)", 
      lo_flags = 36896768, lo_data = 0, lo_witness = 0xce0022b0}, 
    sx_lock = 1}, system_mtx = {lock_object = {
      lo_name = 0xc0fc6c52 "vm map (system)", lo_flags = 21168128, 
      lo_data = 0, lo_witness = 0xce002110}, mtx_lock = 4}, nentries = 0, 
  size = 0, timestamp = 0, needs_wakeup = 0 '\0', system_map = 1 '\001', 
  flags = 0 '\0', root = 0x0, pmap = 0xc13279f8, busy = 0}
(kgdb) ^Froot@d129:~ # ^Dexit

Script done on Thu Mar 21 10:53:52 2013

Attachment: pgpGkrrdGPpkN.pgp
Description: PGP signature

Reply via email to