Re: PROBLEM how to sync page cache ?

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

 



On 3/9/06, Ali Ahmed Thawerani <aaht14@xxxxxxxxx> wrote:
> On 3/8/06, Ali Ahmed Thawerani <aaht14@xxxxxxxxx> wrote:
> > i have written a wrapper for a block device. my wrapper is also
> > registered as a block device and i am obtaining the pointer bdev of
> > the wrapper block device by using the open_by_devnum function with
> > FMODE_READ | FMODE_WRITE
> >
> > i want to sync the memory pages that are in the page cache for this
> > particular wrapper block device
> >
> > what i am doing is using two functions filemap_fdatawrite and
> > filemap_fdatawait which take bdev->bd_inode->i_mapping as argument and
> > sync the data associated with a particular block device
> >
> > the return status of these two functions is 0 which i think means no success
> >
> > i have tried to figure out what can be the reason for this and i
> > followed the function calling that have been made
> >
> > some of the possible reasons were: when
> > i_mapping->backing_dev_info->memory_backed is 1 then these functions
> > return 0 i have checked that this value is not greater than 0 moreover
> > i have also checked that the i_mapping->nr_pages are also greater than
> > 0
> >
> > i was not able to go any further
> >
> > i am calling these two functions in a thread
> >
> > there was also another problem that when there is some request coming
> > to my wrapper block device and wake up the thread which tries to sync
> > the page cache my system gets stuck may be both the threads are trying
> > to modify the inodes at the same time and none is succeeding
> >
> > what i did to solve this problem that i used kernel timer if there is
> > no request in the request queue for jiffies + 30 then i wake up the
> > thread to sync the buffer cache and at the same time set a
> > flag........ as according to my assumption when buffer cache will sync
> > data will come to my wrapper block device and i have to requeue it to
> > avoid any sort of problem but the thing is no such thing happens that
> > is there is no new request in request queue at all
> >
> > can any one help me out in this
> >
>
>
> i want to add a few more things that i have tried
>
> i looked at the function filemap_fdatawrite and followed the function
> calling at got to do_writepages which was in turn calling either the
> i_mapping->a_ops->writepages or generic_writepages with the parameters
> mapping and wbc
>
> i copied do_writepages as it is in my code and gave i_mapping in place
> of mapping and defined a structure of struct writeback_control with
> syncmode = WB_SYNC_ALL, start = 0, end = 0, nr_to_write =
> i_mapping->nr_pages * 2 and non_blocking = 1 the values of start and
> end are given 0 in __filemap_fdatawrite and syncmode = WB_SYNC_ALL is
> given in filemap_fdatawrite so i just gave the same values
>
> i have seen that i_mapping->a_ops->writepages is assigned
> generic_writepages and generic_writepages calls mpage_writepages
>

one of my collegues said that there should be a way to set the page
cache mode to write through or there will be a proc entry which
specifies how much cache should be used for the disk and we can make
it small or 0

--
Kernelnewbies: Help each other learn about the Linux kernel.
Archive:       http://mail.nl.linux.org/kernelnewbies/
FAQ:           http://kernelnewbies.org/faq/



[Index of Archives]     [Newbies FAQ]     [Linux Kernel Mentors]     [Linux Kernel Development]     [IETF Annouce]     [Git]     [Networking]     [Security]     [Bugtraq]     [Yosemite]     [MIPS Linux]     [ARM Linux]     [Linux RAID]     [Linux SCSI]     [Linux ACPI]
  Powered by Linux