cvs commit: src/sys/dev/disk/ccd ccd.c src/sys/dev/disk/vn vn.c src/sys/dev/raid/vinum vinuminterrupt.c vinumrequest.c src/sys/kern kern_physio.c subr_disk.c subr_diskslice.c vfs_bio.c vfs_cluster.c src/sys/sys buf.h src/sys/vfs/specfs spec_vnops.c ...

Matthew Dillon dillon at crater.dragonflybsd.org
Wed May 3 13:45:51 PDT 2006


dillon      2006/05/03 13:44:49 PDT

DragonFly src repository

  Modified files:
    sys/dev/disk/ccd     ccd.c 
    sys/dev/disk/vn      vn.c 
    sys/dev/raid/vinum   vinuminterrupt.c vinumrequest.c 
    sys/kern             kern_physio.c subr_disk.c 
                         subr_diskslice.c vfs_bio.c vfs_cluster.c 
    sys/sys              buf.h 
    sys/vfs/specfs       spec_vnops.c 
    sys/vm               swap_pager.c vm_pager.c vnode_pager.c 
  Log:
  - Clarify the definitions of b_bufsize, b_bcount, and b_resid.
  - Remove unnecessary assignments based on the clarified fields.
  - Add additional checks for premature EOF.
  
  b_bufsize is only used by buffer management entities such as getblk() and
  other vnode-backed buffer handling procedures.  b_bufsize is not required
  for calls to vn_strategy() or dev_dstrategy().  A number of other subsystems
  use it to track the original request size.
  
  b_bcount is the I/O request size, but b_bcount() is allowed to be truncated
  by the device chain if the request encompasses EOF (such as on a raw disk
  device).  A caller which needs to record the original buffer size verses
  the EOF-truncated buffer can compare b_bcount after the I/O against a
  recorded copy of the original request size.  This copy can be recorded in
  b_bufsize for unmanaged buffers (malloced or getpbuf()'d buffers).
  
  b_resid is always relative to b_bcount, not b_bufsize.  A successful read
  that is truncated to the device EOF will thus have a b_resid of 0 and a
  truncated b_bcount.
  
  Revision  Changes    Path
  1.28      +15 -7     src/sys/dev/disk/ccd/ccd.c
  1.20      +3 -5      src/sys/dev/disk/vn/vn.c
  1.10      +0 -2      src/sys/dev/raid/vinum/vinuminterrupt.c
  1.12      +0 -2      src/sys/dev/raid/vinum/vinumrequest.c
  1.21      +0 -1      src/sys/kern/kern_physio.c
  1.24      +6 -6      src/sys/kern/subr_disk.c
  1.18      +13 -4     src/sys/kern/subr_diskslice.c
  1.71      +3 -5      src/sys/kern/vfs_bio.c
  1.24      +10 -4     src/sys/kern/vfs_cluster.c
  1.34      +23 -8     src/sys/sys/buf.h
  1.40      +12 -10    src/sys/vfs/specfs/spec_vnops.c
  1.24      +0 -4      src/sys/vm/swap_pager.c
  1.22      +2 -0      src/sys/vm/vm_pager.c
  1.26      +2 -4      src/sys/vm/vnode_pager.c


http://www.dragonflybsd.org/cvsweb/src/sys/dev/disk/ccd/ccd.c.diff?r1=1.27&r2=1.28&f=u
http://www.dragonflybsd.org/cvsweb/src/sys/dev/disk/vn/vn.c.diff?r1=1.19&r2=1.20&f=u
http://www.dragonflybsd.org/cvsweb/src/sys/dev/raid/vinum/vinuminterrupt.c.diff?r1=1.9&r2=1.10&f=u
http://www.dragonflybsd.org/cvsweb/src/sys/dev/raid/vinum/vinumrequest.c.diff?r1=1.11&r2=1.12&f=u
http://www.dragonflybsd.org/cvsweb/src/sys/kern/kern_physio.c.diff?r1=1.20&r2=1.21&f=u
http://www.dragonflybsd.org/cvsweb/src/sys/kern/subr_disk.c.diff?r1=1.23&r2=1.24&f=u
http://www.dragonflybsd.org/cvsweb/src/sys/kern/subr_diskslice.c.diff?r1=1.17&r2=1.18&f=u
http://www.dragonflybsd.org/cvsweb/src/sys/kern/vfs_bio.c.diff?r1=1.70&r2=1.71&f=u
http://www.dragonflybsd.org/cvsweb/src/sys/kern/vfs_cluster.c.diff?r1=1.23&r2=1.24&f=u
http://www.dragonflybsd.org/cvsweb/src/sys/sys/buf.h.diff?r1=1.33&r2=1.34&f=u
http://www.dragonflybsd.org/cvsweb/src/sys/vfs/specfs/spec_vnops.c.diff?r1=1.39&r2=1.40&f=u
http://www.dragonflybsd.org/cvsweb/src/sys/vm/swap_pager.c.diff?r1=1.23&r2=1.24&f=u
http://www.dragonflybsd.org/cvsweb/src/sys/vm/vm_pager.c.diff?r1=1.21&r2=1.22&f=u
http://www.dragonflybsd.org/cvsweb/src/sys/vm/vnode_pager.c.diff?r1=1.25&r2=1.26&f=u





More information about the Commits mailing list