Re: [PATCH][RFC] splice support

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



On Thu, Mar 30 2006, KAMEZAWA Hiroyuki wrote:
> On Wed, 29 Mar 2006 14:28:41 +0200
> Jens Axboe <[email protected]> wrote:
> >
> > +	/*
> > +	 * Get as many pages from the page cache as possible..
> > +	 * Start IO on the page cache entries we create (we
> > +	 * can assume that any pre-existing ones we find have
> > +	 * already had IO started on them).
> > +	 */
> > +	i = find_get_pages(mapping, index, pages, array);
> > +
> 
> It looks page caches in this array is hold by pipe until data is consumed.
> So..this page cannot be reclaimd or migrated and hot-removed :).

Right

> I don't know about sendfile() but this looks client can hold server's
> memory, when server uses sendfile() 64k/conn.

You mean when the server uses splice, 64kb (well 16 pages actually) /
connection? That's a correct observation, I wouldn't think that pinning
that small a number of pages is likely to cause any issues. At least I
can think of much worse pinning by just doing IO :-)

> Is there a way to force these pages to be freed ? or page reclaimer
> can know this page is held by splice ? (we need additional PG_flags to
> do this ?)
> 
> I think these pages are necessary to be held only when data in them is
> used.

Not without tearing down the pipe.

-- 
Jens Axboe

-
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to [email protected]
More majordomo info at  http://vger.kernel.org/majordomo-info.html
Please read the FAQ at  http://www.tux.org/lkml/

[Index of Archives]     [Kernel Newbies]     [Netfilter]     [Bugtraq]     [Photo]     [Stuff]     [Gimp]     [Yosemite News]     [MIPS Linux]     [ARM Linux]     [Linux Security]     [Linux RAID]     [Video 4 Linux]     [Linux for the blind]     [Linux Resources]
  Powered by Linux