Date: Wed, 3 Sep 2008 16:47:33 +0400 From: Igor Sysoev <is@rambler-co.ru> To: Kostik Belousov <kostikbel@gmail.com> Cc: Tor Egge <tegge@freebsd.org>, freebsd-stable@freebsd.org Subject: Re: vfs.ffs.rawreadahead Message-ID: <20080903124733.GH62541@rambler-co.ru> In-Reply-To: <20080903123955.GE2038@deviant.kiev.zoral.com.ua> References: <20080903095352.GA62541@rambler-co.ru> <20080903123955.GE2038@deviant.kiev.zoral.com.ua>
next in thread | previous in thread | raw e-mail | index | archive | help
On Wed, Sep 03, 2008 at 03:39:55PM +0300, Kostik Belousov wrote: > On Wed, Sep 03, 2008 at 01:53:52PM +0400, Igor Sysoev wrote: > > Hi, > > > > could anyone tell what does vfs.ffs.rawreadahead enable ? > > As I understand it's used in DIRECTIO code that allows read data > > directly to an userland buffer bypassing the buffer cache. > > What I can not understand where the read ahead data can be placed in ? > > The operation of the ffs_rawread is more accurately described as > bypassing the page cache. It creates the physical buffer that maps > the user pages. > > The readahead is performed only when the supplied user memory region > is bigger then blocksize. In this case, two reads are performed > simultaneously, with both buffers mapping consequent blocks from > user-supplied buffers. The read operation looks like footsteps. Nice! As I understand the size limit of one read operation is MAXPHYS, which is equal to 128K due to LBA28 ATA limit. On SCSI, SATA, and LBA48 ATA this limit can be increased. Is it safe ? -- Igor Sysoev http://sysoev.ru/en/
Want to link to this message? Use this URL: <https://mail-archive.FreeBSD.org/cgi/mid.cgi?20080903124733.GH62541>