Akira-san, I joined the project ohsm team a couple weeks ago and we hope to use your patches / features to build on. Below is our feedback as relates to ohsm as well as my personal feedback. 2009/8/7 Akira Fujita <a-fujita@xxxxxxxxxxxxx>: > Hi Andreas, > > Andreas Dilger wrote: >> On Jun 23, 2009 17:25 +0900, Akira Fujita wrote: >>> alloc_flag of ext4_alloc_rule structure is set as "mandatory" or "advisory". >>> Restricted blocks with "mandatory" are never used by block allocator. >>> But in "advisory" case, block allocator is allowed to use restricted blocks >>> when there are no free blocks on FS. >> >> Would it make more sense to implement the range protections via the >> existing preallocation ranges (PA)? An inode can have multiple >> PAs attached to it to have it prefer allocations from that range. >> >> We could also attach PAs to the superblock to prevent other files from >> allocating out of those ranges. This would work better with the existing >> allocation code instead of creating a second similar mechanism. > > Thank you for comments. > > I have considered about the block allocation control with preallocation (PA). > This is my new implementation idea. > > a. Block allocation restriction (balloc restriction) > Redesigned balloc restriction ioctl (EXT4_IOC_BALOC_CONTROL) can set > and clear protected ranges with flag. > And balloc restriction used a new type PA (MB_RESTRICT_PA), > not inode PA (MB_INODE_PA) and group PA (MB_GROUP_PA). > > Previous my patch set has implemented two restriction types: mandatory > (never used by block allocator) and advisory (used if there is > no other free blocks to allocate). > But, to make more simple, I implement only mandatory mode. The ohsm team has no current specific plan to use "Block allocation restriction", but if we did it would be in the advisory role. We agree this functionality can be added later when there is an actual user. > With "SET_BALLOC_RESTRICTION" flag, this ioctl sets MB_RESTRIT_PA, > and blocks in this PA covers are protected from other block allocator. > If you want to use these ranges, call with "CLR_BALLOC_RESTRICTIOIN" flag. > > EXT4_IOC_BALLOC_CONTROL calls ext4_mb_new_blocks(). It tries to check > whether specified range blocks are free or not with mballoc routine. > If range blocks are free, ext4_mb_new_blocks() sets memory block bitmap > used (same as ext4 PA), and then adds this information to restriction PA. > But it does *not* set disk block bitmap used, because these blocks are part of PA. > > ext4_prealloc_space has a new list structure "pa_restrict_list" which holds > restriction PA passed from user-space. > ext4_group_info also has a new list structure "bb_restrict_request" which holds > block group related restriction range. > This list is used, when we calculate blocks count which are free > but can not use because of restriction PA. Can't say I know enough to comment on the implementation details. > > b. Preferred block allocation for inode (preferred balloc) > EXT4_IOC_ADD_PREALLOC adds specified blocks to the inode PA. > You can set arbitrary blocks ranges to inode PA, > this is the different from fallocate. > This function is the core functionality that ohsm still needs from ext4, and we look forward to seeing actual functioning patches, and in turn those eventually getting pushed to Linus. > > Ext4 inode PA is removed when file is closed, therefore it is not > necessary to implement to clear inode PA. That is fine from ohsm perspective. Possibly there are other use cases that need a longer lifetime? > Ioctl interfaces are as follows. > > a. EXT4_IOC_BALLOC_CONTROL (Set or clear balloc restriction) > > EXT4_IOC_BALLOC_CONTROL > _IOW('f', 16, struct ext4_balloc_control balloc_control) > > struct ext4_balloc_control { > __u64 start; /* start physical block offset balloc rest */ > __u64 len; /* block length */ > __u32 flags; /* set or clear */ > } > > "flags" can be set following 2 types. > - SET_BALLOC_RESTRICTION > Set blocks in range to the balloc restriction list. > - CLR_BALLOC_RESTRICTION > Clear blocks from the balloc restriction list. ohsm will be an in kernel user of the above, so we hope a kernel API is also provided. I assume that would be a simple export and documenting it in Documentation/filesystems/ext4. It seems you need to add 3 flags to the above: mandatory - Have a future block allocate request return ENO_SPACE_PA if the blocks cannot be found within the restricted range. advisory - Attempt future block allocate requests from the restricted range, but use entire unrestricted block range if that fails. mandatory_with_fallback - Not Implemented - If block allocate from restricted range fails, fallback to an alternate block range. API and implementation details not yet agreed on. As to mandatory_with_fallback, we (the ohsm team) are looking for feedback on the below proposal: The ohsm team envisions submitting subsequent patches to enhance the ext4 block allocator function such that it makes a callout to ohsm if a block allocation fails from the current restricted block range. Possibly by adding an init routine that would allow ohsm to register a callout routine for the ENO_SPACE_PA condition. This can be thought of as a inotify type situation for that one case. After making the callout (to ohsm or other registered kernel user), we would like to see the block allocation re-attempted. This would allow ohsm to eventually have multiple tiers of preferred storage. And if one tier is not able to provide the requested blocks, an alternate block range could be set. We envision the oshm callout function in turn calling the EXT4_IOC_BALLOC_CONTROL kernel API to set the alternate block range. Thus the block allocator function would need to be made aware of this possibility. Again, the above is mostly our future plans / enhancements to the initial primary patch and is provided just to let everyone keep ohsm's needs in mind as the patch is writen / reviewed. ie. ohsm is the only known use case for this routine other than defrag at present so we thought it useful explain how ohsm would utilize / enhance this function. > b. EXT4_IOC_ADD_PREALLOC (Add inode preferred range) > > EXT4_IOC_ADD_PREALLOC _IOW('f', 18, struct ext4_balloc_control) > > struct ext4_balloc_control { > __u64 start; /* start physical block offset */ > __u64 len; /* block length */ > __u32 flags; /* create and add mode for inode PA */ > } > > "flags" must include one of the following create modes > (MANDATORY or ADVISORY). In addition, one of the control modes also must > be set (REPLACER_INODE_PREALLOC or ADD_INODE_PREALLOC). > Create modes: > - MANDATORY > Find free extent which satisfies "start" and "len" completely. > - ADVISORY > Try to find free extent from "start" and "len" blocks. > Control modes: > - REPLACE_INODE_PREALLOC > Remove existed inode PA first, and then add specified range to > the inode PA list newly. > - ADD_INODE_PREALLOC > Add specified range to the inode PA list. > > e.g. flag = MANDATORY | ADD_INODE_PREALLOC > Find free extent which fulfills the requirements completely, > and if succeed, add this extent to the inode PA. I am unsure how the above relates to EXT4_IOC_BALLOC_CONTROL. It appears to be totally independent which I don't think is a good idea. Nor do I understand the use case of the advisory flag and add_inode_prealloc flag. I would prefer if the above API were simplified to: b. EXT4_IOC_RESET_PREALLOC (Ensure inode prealloc range is withing preferred block alloc range) EXT4_IOC_ADD_PREALLOC _IOW('f', 18, struct ext4_balloc_control) struct ext4_balloc_control { __u32 flags; /* Currently unused */ } Find appropriate free prealloc block extent within range set of inode via EXT4_IOC_BALLOC_CONTROL. If unable to do so, a preallock block is set via the default logic and a error is returned to show that the prealloc block is not within the restricted block range. This seems far simpler to code, understand, and use. > Regards, > Akira Fujita Thanks Greg -- Greg Freemyer Member of OHSM devel team http://sourceforge.net/projects/ohsm/ -- To unsubscribe from this list: send the line "unsubscribe linux-ext4" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html