2022-06-03 19:15:11 +00:00
|
|
|
/* SPDX-License-Identifier: BSD-3-Clause
|
2022-11-01 20:26:26 +00:00
|
|
|
* Copyright (C) 2017 Intel Corporation.
|
2017-04-26 04:17:27 +00:00
|
|
|
* All rights reserved.
|
|
|
|
*/
|
|
|
|
|
|
|
|
#ifndef SPDK_TREE_H_
|
|
|
|
#define SPDK_TREE_H_
|
|
|
|
|
|
|
|
struct cache_buffer {
|
|
|
|
uint8_t *buf;
|
|
|
|
uint64_t offset;
|
|
|
|
uint32_t buf_size;
|
|
|
|
uint32_t bytes_filled;
|
|
|
|
uint32_t bytes_flushed;
|
|
|
|
bool in_progress;
|
|
|
|
};
|
|
|
|
|
2020-10-14 14:01:26 +00:00
|
|
|
#define CACHE_BUFFER_SHIFT (18)
|
|
|
|
#define CACHE_BUFFER_SIZE (1U << CACHE_BUFFER_SHIFT)
|
2017-04-26 04:17:27 +00:00
|
|
|
#define NEXT_CACHE_BUFFER_OFFSET(offset) \
|
2020-10-14 14:01:26 +00:00
|
|
|
(((offset + CACHE_BUFFER_SIZE) >> CACHE_BUFFER_SHIFT) << CACHE_BUFFER_SHIFT)
|
2017-04-26 04:17:27 +00:00
|
|
|
|
|
|
|
#define CACHE_TREE_SHIFT 6
|
2017-08-02 07:51:55 +00:00
|
|
|
#define CACHE_TREE_WIDTH (1U << CACHE_TREE_SHIFT)
|
2020-10-14 14:01:26 +00:00
|
|
|
#define CACHE_TREE_LEVEL_SHIFT(level) (CACHE_BUFFER_SHIFT + (level) * CACHE_TREE_SHIFT)
|
2017-04-26 04:17:27 +00:00
|
|
|
#define CACHE_TREE_LEVEL_SIZE(level) (1ULL << CACHE_TREE_LEVEL_SHIFT(level))
|
|
|
|
#define CACHE_TREE_LEVEL_MASK(level) (CACHE_TREE_LEVEL_SIZE(level) - 1)
|
|
|
|
#define CACHE_TREE_INDEX(level, offset) ((offset >> CACHE_TREE_LEVEL_SHIFT(level)) & (CACHE_TREE_WIDTH - 1))
|
|
|
|
|
|
|
|
struct cache_tree {
|
|
|
|
uint8_t level;
|
|
|
|
uint64_t present_mask;
|
|
|
|
union {
|
|
|
|
struct cache_buffer *buffer[CACHE_TREE_WIDTH];
|
|
|
|
struct cache_tree *tree[CACHE_TREE_WIDTH];
|
|
|
|
} u;
|
|
|
|
};
|
|
|
|
|
2020-04-07 00:55:54 +00:00
|
|
|
void cache_buffer_free(struct cache_buffer *cache_buffer);
|
2017-04-26 04:17:27 +00:00
|
|
|
|
2020-04-07 00:55:54 +00:00
|
|
|
struct cache_tree *tree_insert_buffer(struct cache_tree *root, struct cache_buffer *buffer);
|
|
|
|
void tree_free_buffers(struct cache_tree *tree);
|
|
|
|
struct cache_buffer *tree_find_buffer(struct cache_tree *tree, uint64_t offset);
|
|
|
|
struct cache_buffer *tree_find_filled_buffer(struct cache_tree *tree, uint64_t offset);
|
|
|
|
void tree_remove_buffer(struct cache_tree *tree, struct cache_buffer *buffer);
|
2017-04-26 04:17:27 +00:00
|
|
|
|
|
|
|
#endif /* SPDK_TREE_H_ */
|