diff options
author | Jan Kara <[email protected]> | 2012-06-06 00:32:26 +0200 |
---|---|---|
committer | Ben Myers <[email protected]> | 2012-06-21 14:20:36 -0500 |
commit | 59c84ed0ddc11f1823b4a33ace4fbcc948261bb2 (patch) | |
tree | 32d64523ae5c46b4959876a3d6b498adb6452dbc /tools/perf/util/scripting-engines/trace-event-python.c | |
parent | 76d095388b040229ea1aad7dea45be0cfa20f589 (diff) |
xfs: Fix overallocation in xfs_buf_allocate_memory()
Commit de1cbee which removed b_file_offset in favor of b_bn introduced a bug
causing xfs_buf_allocate_memory() to overestimate the number of necessary
pages. The problem is that xfs_buf_alloc() sets b_bn to -1 and thus effectively
every buffer is straddling a page boundary which causes
xfs_buf_allocate_memory() to allocate two pages and use vmalloc() for access
which is unnecessary.
Dave says xfs_buf_alloc() doesn't need to set b_bn to -1 anymore since the
buffer is inserted into the cache only after being fully initialized now.
So just make xfs_buf_alloc() fill in proper block number from the beginning.
CC: David Chinner <[email protected]>
Signed-off-by: Jan Kara <[email protected]>
Reviewed-by: Christoph Hellwig <[email protected]>
Reviewed-by: Dave Chinner <[email protected]>
Signed-off-by: Ben Myers <[email protected]>
Diffstat (limited to 'tools/perf/util/scripting-engines/trace-event-python.c')
0 files changed, 0 insertions, 0 deletions