From: Allison Henderson <achender@linux.vnet.ibm.com>
To: linux-ext4 <linux-ext4@vger.kernel.org>
Subject: Re: Extent tree status asking
Date: Fri, 20 Apr 2012 17:12:44 -0700 [thread overview]
Message-ID: <4F91FB7C.1050109@linux.vnet.ibm.com> (raw)
In-Reply-To: <20120419093829.GA4547@gmail.com>
On 04/19/2012 02:38 AM, Zheng Liu wrote:
> On Tue, Apr 17, 2012 at 11:19:26PM -0700, Allison Henderson wrote:
>> On 04/16/2012 10:55 AM, Zheng Liu wrote:
>>> Hi Allison,
>>>
>>> Currently I am trying to reduce the lock contention of direct I/O in ext4
>>> because it is a bottleneck. A trivial idea is that a new fucntion is
>>> defined to replace the generic_file_aio_write, which do some write
>>> operations with acquiring i_data_sem lock in inode.
>>>
>>> I know that you are trying to implement extent tree, and I have seen your patch
>>> set '[PATCH] Rename delayed extents to status extents'. After extent tree is
>>> made, the implementation of direct I/O without i_mutex and range lock is
>>> straightforward and it is better than my trivial idea. I think that
>>> maybe I can borrow you works. So could you please share me your schedule
>>> and/or other information?
>>>
>>> Last month on ext4 workshop, we discuss the extent tree, range lock and I/O
>>> tree. Obviously, I/O tree is used to store I/O operations, which can track
>>> delay allocation, do unwritten->written conversion and implement range lock.
>>> It is very useful for ext4 and I am interested in this proposal. I know that
>>> you have begun to do some works. So would you like to tell me the status of
>>> extent tree? I don't know whether or not there has some things that I can be
>>> involved. If you have some advices or there is something that I can help,
>>> please let me know. Thank you and looking forward your reply.
>>>
>>> Regards,
>>> Zheng
>>
>> Hi Zheng,
>>
>> Well, I can share with you what I have done so far with Yongqiang's
>> delayed extent tree, but since I was moved to the ganesha project,
>> extent locks are no longer a business priority now. I've done some
>> work on it on my own time, but I have not been able to keep up pace
>> with it. If someone else has the hours to push it faster than I can
>> at this point, I would certainly be understanding of that.
>>
>> Basically though the plan was to modify Yongqiang's delayed extent
>> tree to track allocated extents as well as delayed extents. And
>> then add the extent locks on top of that once that's working. My
>> idea was to add a type member to the extents so that we have have
>> "delayed" "allocated" and "hole" extents. I've renamed the delayed
>> extent scheme to "status extents" because it seemed more
>> appropriate. That part I can send out, but I was still in the
>> middle of coding and debugging allocated extents and extent locks.
>> Because the tree was originally written to merge things as much as
>> possible, there is some rewrite that is needed. I was working on
>> making the add and remove routines more like "type replace" routines
>> sense once the extent is locked, we can really only change the type,
>> and we cannot merge dissimilar types or extents locked by other
>> processes. I hope that makes sense, please let me know if you need
>> more clarification. I will send out the status extent set, sense
>> that part is stable.
>
> Thank you for sharing with me. I am willing to take this work because
> my employee provides me a full time to finish this work. I see that you
> have sent the patch set to the mailing list. I will pick it and go on
> working. Thanks again. :)
>
> Regards,
> Zheng
>
Alrighty then, thx Zheng for continuing this work item. Let me know if
you have any questions or need any help. :)
Allison Henderson
prev parent reply other threads:[~2012-04-21 0:12 UTC|newest]
Thread overview: 4+ messages / expand[flat|nested] mbox.gz Atom feed top
2012-04-16 17:55 Extent tree status asking Zheng Liu
2012-04-18 6:19 ` Allison Henderson
2012-04-19 9:38 ` Zheng Liu
2012-04-21 0:12 ` Allison Henderson [this message]
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=4F91FB7C.1050109@linux.vnet.ibm.com \
--to=achender@linux.vnet.ibm.com \
--cc=linux-ext4@vger.kernel.org \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).