diff options
author | Dave Chinner <dchinner@redhat.com> | 2012-10-04 21:06:58 -0400 |
---|---|---|
committer | Ben Myers <bpm@sgi.com> | 2012-10-18 18:41:56 -0400 |
commit | 2455881c0b52f87be539c4c7deab1afff4d8a560 (patch) | |
tree | ef2ed6c1f0f10727c929838992d89d54bb821993 /fs/xfs/xfs_bmap.c | |
parent | a00416844b8f4b0106344bdfd90fe45a854b1d05 (diff) |
xfs: introduce XFS_BMAPI_STACK_SWITCH
Certain allocation paths through xfs_bmapi_write() are in situations
where we have limited stack available. These are almost always in
the buffered IO writeback path when convertion delayed allocation
extents to real extents.
The current stack switch occurs for userdata allocations, which
means we also do stack switches for preallocation, direct IO and
unwritten extent conversion, even those these call chains have never
been implicated in a stack overrun.
Hence, let's target just the single stack overun offended for stack
switches. To do that, introduce a XFS_BMAPI_STACK_SWITCH flag that
the caller can pass xfs_bmapi_write() to indicate it should switch
stacks if it needs to do allocation.
Signed-off-by: Dave Chinner <dchinner@redhat.com>
Reviewed-by: Mark Tinguely <tinguely@sgi.com>
Signed-off-by: Ben Myers <bpm@sgi.com>
Diffstat (limited to 'fs/xfs/xfs_bmap.c')
-rw-r--r-- | fs/xfs/xfs_bmap.c | 4 |
1 files changed, 4 insertions, 0 deletions
diff --git a/fs/xfs/xfs_bmap.c b/fs/xfs/xfs_bmap.c index e1545ec2f7d2..91259554df8b 100644 --- a/fs/xfs/xfs_bmap.c +++ b/fs/xfs/xfs_bmap.c | |||
@@ -2441,6 +2441,7 @@ xfs_bmap_btalloc( | |||
2441 | args.tp = ap->tp; | 2441 | args.tp = ap->tp; |
2442 | args.mp = mp; | 2442 | args.mp = mp; |
2443 | args.fsbno = ap->blkno; | 2443 | args.fsbno = ap->blkno; |
2444 | args.stack_switch = ap->stack_switch; | ||
2444 | 2445 | ||
2445 | /* Trim the allocation back to the maximum an AG can fit. */ | 2446 | /* Trim the allocation back to the maximum an AG can fit. */ |
2446 | args.maxlen = MIN(ap->length, XFS_ALLOC_AG_MAX_USABLE(mp)); | 2447 | args.maxlen = MIN(ap->length, XFS_ALLOC_AG_MAX_USABLE(mp)); |
@@ -4675,6 +4676,9 @@ xfs_bmapi_allocate( | |||
4675 | return error; | 4676 | return error; |
4676 | } | 4677 | } |
4677 | 4678 | ||
4679 | if (flags & XFS_BMAPI_STACK_SWITCH) | ||
4680 | bma->stack_switch = 1; | ||
4681 | |||
4678 | error = xfs_bmap_alloc(bma); | 4682 | error = xfs_bmap_alloc(bma); |
4679 | if (error) | 4683 | if (error) |
4680 | return error; | 4684 | return error; |