diff options
author | tegge <tegge@FreeBSD.org> | 2003-10-22 18:57:59 +0000 |
---|---|---|
committer | tegge <tegge@FreeBSD.org> | 2003-10-22 18:57:59 +0000 |
commit | 77f7b5a60ee42eb99151780ad4a4796a9d02b80a (patch) | |
tree | 1f478c9576769861c90b513362859ecd12ac0424 /sys/ufs | |
parent | 75025ec654e9e29e550a97657c165705b6496737 (diff) | |
download | FreeBSD-src-77f7b5a60ee42eb99151780ad4a4796a9d02b80a.zip FreeBSD-src-77f7b5a60ee42eb99151780ad4a4796a9d02b80a.tar.gz |
Initialize bp->b_offset to the physical offset in partition
so GEOM knows where to read from disk.
Diffstat (limited to 'sys/ufs')
-rw-r--r-- | sys/ufs/ffs/ffs_rawread.c | 11 |
1 files changed, 5 insertions, 6 deletions
diff --git a/sys/ufs/ffs/ffs_rawread.c b/sys/ufs/ffs/ffs_rawread.c index 66449a7..b6fc927 100644 --- a/sys/ufs/ffs/ffs_rawread.c +++ b/sys/ufs/ffs/ffs_rawread.c @@ -214,9 +214,8 @@ ffs_rawread_readahead(struct vnode *vp, bp->b_iodone = ffs_rawreadwakeup; bp->b_data = udata; bp->b_saveaddr = sa; - bp->b_offset = offset; - blockno = bp->b_offset / bsize; - blockoff = (bp->b_offset % bsize) / DEV_BSIZE; + blockno = offset / bsize; + blockoff = (offset % bsize) / DEV_BSIZE; if ((daddr_t) blockno != blockno) { return EINVAL; /* blockno overflow */ } @@ -226,8 +225,7 @@ ffs_rawread_readahead(struct vnode *vp, error = ufs_bmaparray(vp, bp->b_lblkno, &blkno, NULL, &bforwards, NULL); if (error != 0) return error; - bp->b_blkno = blkno; - if (bp->b_blkno == -1) { + if (blkno == -1) { /* Fill holes with NULs to preserve semantics */ @@ -248,11 +246,12 @@ ffs_rawread_readahead(struct vnode *vp, bp->b_flags |= B_DONE; return 0; } + bp->b_blkno = blkno + blockoff; + bp->b_offset = bp->b_iooffset = (blkno + blockoff) * DEV_BSIZE; if (bp->b_bcount + blockoff * DEV_BSIZE > bsize * (1 + bforwards)) bp->b_bcount = bsize * (1 + bforwards) - blockoff * DEV_BSIZE; bp->b_bufsize = bp->b_bcount; - bp->b_blkno += blockoff; bp->b_dev = dp->v_rdev; if (vmapbuf(bp) < 0) |