mirror of
https://mirrors.bfsu.edu.cn/git/linux.git
synced 2025-01-27 08:14:35 +08:00
xfs: cleanup xfs_iomap_eof_align_last_fsb
Replace the nasty if, else if, elseif condition with more natural C flow that expressed the logic we want here better. Signed-off-by: Christoph Hellwig <hch@lst.de> Reviewed-by: Dave Chinner <dchinner@redhat.com> Signed-off-by: Ben Myers <bpm@sgi.com>
This commit is contained in:
parent
673e8e597c
commit
bf322d983e
@ -57,26 +57,26 @@ xfs_iomap_eof_align_last_fsb(
|
||||
xfs_fileoff_t *last_fsb)
|
||||
{
|
||||
xfs_fileoff_t new_last_fsb = 0;
|
||||
xfs_extlen_t align;
|
||||
xfs_extlen_t align = 0;
|
||||
int eof, error;
|
||||
|
||||
if (XFS_IS_REALTIME_INODE(ip))
|
||||
;
|
||||
/*
|
||||
* If mounted with the "-o swalloc" option, roundup the allocation
|
||||
* request to a stripe width boundary if the file size is >=
|
||||
* stripe width and we are allocating past the allocation eof.
|
||||
*/
|
||||
else if (mp->m_swidth && (mp->m_flags & XFS_MOUNT_SWALLOC) &&
|
||||
(ip->i_size >= XFS_FSB_TO_B(mp, mp->m_swidth)))
|
||||
new_last_fsb = roundup_64(*last_fsb, mp->m_swidth);
|
||||
/*
|
||||
* Roundup the allocation request to a stripe unit (m_dalign) boundary
|
||||
* if the file size is >= stripe unit size, and we are allocating past
|
||||
* the allocation eof.
|
||||
*/
|
||||
else if (mp->m_dalign && (ip->i_size >= XFS_FSB_TO_B(mp, mp->m_dalign)))
|
||||
new_last_fsb = roundup_64(*last_fsb, mp->m_dalign);
|
||||
if (!XFS_IS_REALTIME_INODE(ip)) {
|
||||
/*
|
||||
* Round up the allocation request to a stripe unit
|
||||
* (m_dalign) boundary if the file size is >= stripe unit
|
||||
* size, and we are allocating past the allocation eof.
|
||||
*
|
||||
* If mounted with the "-o swalloc" option the alignment is
|
||||
* increased from the strip unit size to the stripe width.
|
||||
*/
|
||||
if (mp->m_swidth && (mp->m_flags & XFS_MOUNT_SWALLOC))
|
||||
align = mp->m_swidth;
|
||||
else if (mp->m_dalign)
|
||||
align = mp->m_dalign;
|
||||
|
||||
if (align && ip->i_size >= XFS_FSB_TO_B(mp, align))
|
||||
new_last_fsb = roundup_64(*last_fsb, align);
|
||||
}
|
||||
|
||||
/*
|
||||
* Always round up the allocation request to an extent boundary
|
||||
|
Loading…
Reference in New Issue
Block a user