Re: + readahead-commentary.patch added to -mm tree

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

 



On 03/11/05, [email protected] <[email protected]> wrote:
>
> The patch titled
>
>      readahead commentary
>
> has been added to the -mm tree.  Its filename is
>
>      readahead-commentary.patch
>
>
> From: Andrew Morton <[email protected]>
>
> Add a few comments surrounding thr generic readahead API.
>
> Also convert some ulongs into pgoff_t: the identifier for PAGE_CACHE_SIZE
> offsets into pagecache.
>
> Signed-off-by: Andrew Morton <[email protected]>
> ---
>
>  include/linux/mm.h |    8 ++++----
>  mm/readahead.c     |   31 ++++++++++++++++++++++---------
>  2 files changed, 26 insertions(+), 13 deletions(-)
>
> diff -puN mm/readahead.c~readahead-commentary mm/readahead.c
> --- 25/mm/readahead.c~readahead-commentary      2005-11-03 08:06:16.000000000 +1100
> +++ 25-akpm/mm/readahead.c      2005-11-03 08:16:16.000000000 +1100
> @@ -254,7 +254,7 @@ out:
>   */
>  static int
>  __do_page_cache_readahead(struct address_space *mapping, struct file *filp,
> -                       unsigned long offset, unsigned long nr_to_read)
> +                       pgoff_t offset, unsigned long nr_to_read)
>  {
>         struct inode *inode = mapping->host;
>         struct page *page;
> @@ -274,7 +274,7 @@ __do_page_cache_readahead(struct address
>          */
>         read_lock_irq(&mapping->tree_lock);
>         for (page_idx = 0; page_idx < nr_to_read; page_idx++) {
> -               unsigned long page_offset = offset + page_idx;
> +               pgoff_t page_offset = offset + page_idx;
>
>                 if (page_offset > end_index)
>                         break;
> @@ -311,7 +311,7 @@ out:
>   * memory at once.
>   */
>  int force_page_cache_readahead(struct address_space *mapping, struct file *filp,
> -               unsigned long offset, unsigned long nr_to_read)
> +               pgoff_t offset, unsigned long nr_to_read)
>  {
>         int ret = 0;
>
> @@ -368,7 +368,7 @@ static inline int check_ra_success(struc
>   * request queues.
>   */
>  int do_page_cache_readahead(struct address_space *mapping, struct file *filp,
> -                       unsigned long offset, unsigned long nr_to_read)
> +                       pgoff_t offset, unsigned long nr_to_read)
>  {
>         if (bdi_read_congested(mapping->backing_dev_info))
>                 return -1;
> @@ -385,7 +385,7 @@ int do_page_cache_readahead(struct addre
>   */
>  static int
>  blockable_page_cache_readahead(struct address_space *mapping, struct file *filp,
> -                       unsigned long offset, unsigned long nr_to_read,
> +                       pgoff_t offset, unsigned long nr_to_read,
>                         struct file_ra_state *ra, int block)
>  {
>         int actual;
> @@ -430,14 +430,27 @@ static int make_ahead_window(struct addr
>         return ret;
>  }
>
> -/*
> - * page_cache_readahead is the main function.  If performs the adaptive
> +/**
> + * page_cache_readahead - generic adaptive readahead
> + * @mapping: address_space which holds te pagecache and I/O vectors

typo. s/te/the/

> + * @ra: file_ra_state which holds the readahead state
> + * @filp: passed on to ->readpage() and ->readpages()
> + * @offset: start offset into @mapping, in PAGE_CACHE_SIZE units
> + * @req_size: hint: total size of the read which the caller is performing in
> + *            PAGE_CACHE_SIZE units
> + *
> + * page_cache_readahead() is the main function.  If performs the adaptive
>   * readahead window size management and submits the readahead I/O.
> + *
> + * Note that @filp is purely used for passing on to the ->readpage[s]()
> + * handler: it may refer to a different file from @mapping (so we may not use
> + * @filp->f_mapping or @filp->f_dentry->d_inode here).
> + * Also, @ra may not be equal to &@filp->f_ra.
> + *
>   */
>  unsigned long
>  page_cache_readahead(struct address_space *mapping, struct file_ra_state *ra,
> -                    struct file *filp, unsigned long offset,
> -                    unsigned long req_size)
> +                    struct file *filp, pgoff_t offset, unsigned long req_size)
>  {
>         unsigned long max, newsize;
>         int sequential;

--
Coywolf Qi Hunt
http://sosdg.org/~coywolf/
-
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