| Jason Evans | e476f8a | 2010-01-16 09:53:50 -0800 | [diff] [blame] | 1 | /******************************************************************************/ |
| 2 | #ifdef JEMALLOC_H_TYPES |
| 3 | |
| 4 | typedef struct extent_node_s extent_node_t; |
| 5 | |
| 6 | #endif /* JEMALLOC_H_TYPES */ |
| 7 | /******************************************************************************/ |
| 8 | #ifdef JEMALLOC_H_STRUCTS |
| 9 | |
| 10 | /* Tree of extents. */ |
| 11 | struct extent_node_s { |
| Jason Evans | cbf3a6d | 2015-02-11 12:24:27 -0800 | [diff] [blame] | 12 | /* Arena from which this extent came, if any. */ |
| 13 | arena_t *arena; |
| Jason Evans | 6109fe0 | 2010-02-10 10:37:56 -0800 | [diff] [blame] | 14 | |
| Jason Evans | e476f8a | 2010-01-16 09:53:50 -0800 | [diff] [blame] | 15 | /* Pointer to the extent that this tree node is responsible for. */ |
| Jason Evans | 6109fe0 | 2010-02-10 10:37:56 -0800 | [diff] [blame] | 16 | void *addr; |
| Jason Evans | e476f8a | 2010-01-16 09:53:50 -0800 | [diff] [blame] | 17 | |
| Jason Evans | cbf3a6d | 2015-02-11 12:24:27 -0800 | [diff] [blame] | 18 | /* |
| 19 | * Total region size, or 0 if this node corresponds to an arena chunk. |
| 20 | */ |
| Jason Evans | 6109fe0 | 2010-02-10 10:37:56 -0800 | [diff] [blame] | 21 | size_t size; |
| Jason Evans | 7de9276 | 2012-10-08 17:56:11 -0700 | [diff] [blame] | 22 | |
| Jason Evans | 918a1a5 | 2015-01-30 21:21:16 -0800 | [diff] [blame] | 23 | /* |
| 24 | * 'prof_tctx' and 'zeroed' are never needed at the same time, so |
| 25 | * overlay them in order to fit extent_node_t in one cache line. |
| 26 | */ |
| 27 | union { |
| 28 | /* Profile counters, used for huge objects. */ |
| 29 | prof_tctx_t *prof_tctx; |
| 30 | |
| 31 | /* True if zero-filled; used by chunk recycling code. */ |
| 32 | bool zeroed; |
| 33 | }; |
| Jason Evans | cbf3a6d | 2015-02-11 12:24:27 -0800 | [diff] [blame] | 34 | |
| 35 | union { |
| 36 | /* Linkage for the size/address-ordered tree. */ |
| Jason Evans | 2195ba4 | 2015-02-15 16:43:52 -0800 | [diff] [blame] | 37 | rb_node(extent_node_t) szad_link; |
| Jason Evans | cbf3a6d | 2015-02-11 12:24:27 -0800 | [diff] [blame] | 38 | |
| 39 | /* Linkage for huge allocations and cached chunks nodes. */ |
| Jason Evans | 2195ba4 | 2015-02-15 16:43:52 -0800 | [diff] [blame] | 40 | ql_elm(extent_node_t) ql_link; |
| Jason Evans | cbf3a6d | 2015-02-11 12:24:27 -0800 | [diff] [blame] | 41 | }; |
| 42 | |
| 43 | /* Linkage for the address-ordered tree. */ |
| Jason Evans | 2195ba4 | 2015-02-15 16:43:52 -0800 | [diff] [blame] | 44 | rb_node(extent_node_t) ad_link; |
| Jason Evans | e476f8a | 2010-01-16 09:53:50 -0800 | [diff] [blame] | 45 | }; |
| 46 | typedef rb_tree(extent_node_t) extent_tree_t; |
| 47 | |
| 48 | #endif /* JEMALLOC_H_STRUCTS */ |
| 49 | /******************************************************************************/ |
| 50 | #ifdef JEMALLOC_H_EXTERNS |
| 51 | |
| Jason Evans | e476f8a | 2010-01-16 09:53:50 -0800 | [diff] [blame] | 52 | rb_proto(, extent_tree_szad_, extent_tree_t, extent_node_t) |
| Jason Evans | e476f8a | 2010-01-16 09:53:50 -0800 | [diff] [blame] | 53 | |
| 54 | rb_proto(, extent_tree_ad_, extent_tree_t, extent_node_t) |
| 55 | |
| 56 | #endif /* JEMALLOC_H_EXTERNS */ |
| 57 | /******************************************************************************/ |
| 58 | #ifdef JEMALLOC_H_INLINES |
| 59 | |
| 60 | #endif /* JEMALLOC_H_INLINES */ |
| 61 | /******************************************************************************/ |
| 62 | |