maple_tree: introduce store_type enum
Patch series "Introduce a store type enum for the Maple tree", v4. ================================ OVERVIEW ================================ This series implements two work items[3]: "aligning mas_store_gfp() with mas_preallocate()" and "enum for store type". mas_store_gfp() is modified to preallocate nodes. This simplies many of the write helper functions by allowing them to use mas_store_gfp() rather than open coding node allocation and error handling. The enum defines the following store types: enum store_type { wr_invalid, wr_new_root, wr_store_root, wr_exact_fit, wr_spanning_store, wr_split_store, wr_rebalance, wr_append, wr_node_store, wr_slot_store, }; In the current maple tree code, a walk down the tree is done in mas_preallocate() to determine the number of nodes needed for this write. After node allocation, mas_wr_store_entry() will perform another walk to determine which write helper function to use to complete the write. Rather than performing the second walk, we can store the type of write in the maple write state during node allocation and read this field to complete the write. Patches 1-16 implement this store type feature. Patch 17 is a cleanup patch to change functions that have unused return types to be void. ================================ RESULTS ================================= Phoronix t-test-1 (Seconds < Lower Is Better) v6.10-rc6 Threads: 1 33.15 Threads: 2 10.81 v6.10-rc6 + this series Threads: 1 32.69 Threads: 2 10.45 Stress-ng mmap 6.10_base store_type_v4 Duration User 2744.65 2769.40 Duration System 10862.69 10817.59 Duration Elapsed 1477.58 1478.35 ================================ TESTING ================================= Testing was done with the maple tree test suite. A new test case is also added to validate the order in which we test for and assign the store type. [1]: https://lore.kernel.org/linux-mm/80926b22-a8d2-9992-eb5e-27e2c99cf460@google.com/T/#m81044feb66765265f8ca7f21e4b4b3725b18780a [2]: https://lore.kernel.org/linux-mm/80926b22-a8d2-9992-eb5e-27e2c99cf460@google.com/T/#mb36c6526486638e82518c0f37a428fb279c84d8a [3]: https://lists.infradead.org/pipermail/maple-tree/2023-December/003098.html This patch (of 17): Add a store_type enum that is stored in ma_state. This will be used to keep track of partial walks of the tree so that subsequent walks can pick up where a previous walk left off. Link: https://lkml.kernel.org/r/20240814161944.55347-1-sidhartha.kumar@oracle.com Link: https://lkml.kernel.org/r/20240814161944.55347-2-sidhartha.kumar@oracle.com Signed-off-by: Sidhartha Kumar <sidhartha.kumar@oracle.com> Cc: Liam R. Howlett <Liam.Howlett@oracle.com> Cc: Matthew Wilcox (Oracle) <willy@infradead.org> Cc: Suren Baghdasaryan <surenb@google.com> Signed-off-by: Andrew Morton <akpm@linux-foundation.org>
This commit is contained in:
parent
02f4bbefca
commit
bd164d81a7
@ -148,6 +148,18 @@ enum maple_type {
|
|||||||
maple_arange_64,
|
maple_arange_64,
|
||||||
};
|
};
|
||||||
|
|
||||||
|
enum store_type {
|
||||||
|
wr_invalid,
|
||||||
|
wr_new_root,
|
||||||
|
wr_store_root,
|
||||||
|
wr_exact_fit,
|
||||||
|
wr_spanning_store,
|
||||||
|
wr_split_store,
|
||||||
|
wr_rebalance,
|
||||||
|
wr_append,
|
||||||
|
wr_node_store,
|
||||||
|
wr_slot_store,
|
||||||
|
};
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* DOC: Maple tree flags
|
* DOC: Maple tree flags
|
||||||
@ -436,6 +448,7 @@ struct ma_state {
|
|||||||
unsigned char offset;
|
unsigned char offset;
|
||||||
unsigned char mas_flags;
|
unsigned char mas_flags;
|
||||||
unsigned char end; /* The end of the node */
|
unsigned char end; /* The end of the node */
|
||||||
|
enum store_type store_type; /* The type of store needed for this operation */
|
||||||
};
|
};
|
||||||
|
|
||||||
struct ma_wr_state {
|
struct ma_wr_state {
|
||||||
@ -477,6 +490,7 @@ struct ma_wr_state {
|
|||||||
.max = ULONG_MAX, \
|
.max = ULONG_MAX, \
|
||||||
.alloc = NULL, \
|
.alloc = NULL, \
|
||||||
.mas_flags = 0, \
|
.mas_flags = 0, \
|
||||||
|
.store_type = wr_invalid, \
|
||||||
}
|
}
|
||||||
|
|
||||||
#define MA_WR_STATE(name, ma_state, wr_entry) \
|
#define MA_WR_STATE(name, ma_state, wr_entry) \
|
||||||
|
Loading…
Reference in New Issue
Block a user