mirror of
https://github.com/ceph/ceph
synced 2025-01-20 18:21:57 +00:00
common: bl::appends don't use the append_buffer anymore.
Signed-off-by: Radoslaw Zarzynski <rzarzyns@redhat.com>
This commit is contained in:
parent
602c875bd6
commit
a94e54af68
@ -1321,9 +1321,10 @@ static ceph::spinlock debug_lock;
|
|||||||
|
|
||||||
void buffer::list::reserve(size_t prealloc)
|
void buffer::list::reserve(size_t prealloc)
|
||||||
{
|
{
|
||||||
if (append_buffer.unused_tail_length() < prealloc) {
|
if (get_append_buffer_unused_tail_length() < prealloc) {
|
||||||
append_buffer = buffer::create_page_aligned(prealloc);
|
auto ptr = ptr_node::create(buffer::create_page_aligned(prealloc));
|
||||||
append_buffer.set_length(0); // unused, so far.
|
ptr->set_length(0); // unused, so far.
|
||||||
|
_buffers.push_back(*ptr.release());
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -1400,39 +1401,50 @@ static ceph::spinlock debug_lock;
|
|||||||
void buffer::list::append(char c)
|
void buffer::list::append(char c)
|
||||||
{
|
{
|
||||||
// put what we can into the existing append_buffer.
|
// put what we can into the existing append_buffer.
|
||||||
unsigned gap = append_buffer.unused_tail_length();
|
unsigned gap = get_append_buffer_unused_tail_length();
|
||||||
if (!gap) {
|
if (!gap) {
|
||||||
// make a new append_buffer!
|
// make a new buffer!
|
||||||
append_buffer = raw_combined::create(CEPH_BUFFER_APPEND_SIZE, 0,
|
auto buf = ptr_node::create(
|
||||||
get_mempool());
|
raw_combined::create(CEPH_BUFFER_APPEND_SIZE, 0, get_mempool()));
|
||||||
append_buffer.set_length(0); // unused, so far.
|
buf->set_length(0); // unused, so far.
|
||||||
|
_buffers.push_back(*buf.release());
|
||||||
}
|
}
|
||||||
append(append_buffer, append_buffer.append(c) - 1, 1); // add segment to the list
|
_buffers.back().append(c);
|
||||||
|
_len++;
|
||||||
}
|
}
|
||||||
|
|
||||||
void buffer::list::append(const char *data, unsigned len)
|
void buffer::list::append(const char *data, unsigned len)
|
||||||
{
|
{
|
||||||
|
// hmm, maybe let's provide ::appends with guarantee the container is
|
||||||
|
// never empty?
|
||||||
|
if (_buffers.empty()) {
|
||||||
|
size_t need = round_up_to(len, sizeof(size_t)) + sizeof(raw_combined);
|
||||||
|
size_t alen = round_up_to(need, CEPH_BUFFER_ALLOC_UNIT) -
|
||||||
|
sizeof(raw_combined);
|
||||||
|
_buffers.emplace_back(raw_combined::create(alen, 0, get_mempool()));
|
||||||
|
_buffers.back().set_length(0); // unused, so far.
|
||||||
|
}
|
||||||
|
|
||||||
while (len > 0) {
|
while (len > 0) {
|
||||||
// put what we can into the existing append_buffer.
|
ptr& last_one = _buffers.back();
|
||||||
unsigned gap = append_buffer.unused_tail_length();
|
unsigned gap = \
|
||||||
if (gap > 0) {
|
std::min(last_one.raw_nref() == 1 ? last_one.unused_tail_length() : 0, len);
|
||||||
if (gap > len) gap = len;
|
last_one.append(data, gap);
|
||||||
//cout << "append first char is " << data[0] << ", last char is " << data[len-1] << std::endl;
|
_len += gap;
|
||||||
append_buffer.append(data, gap);
|
len -= gap;
|
||||||
append(append_buffer, append_buffer.length() - gap, gap); // add segment to the list
|
data += gap;
|
||||||
len -= gap;
|
|
||||||
data += gap;
|
if (len == 0) {
|
||||||
|
break;
|
||||||
}
|
}
|
||||||
if (len == 0)
|
|
||||||
break; // done!
|
// make a new buffer. fill out a complete page, factoring in the
|
||||||
|
|
||||||
// make a new append_buffer. fill out a complete page, factoring in the
|
|
||||||
// raw_combined overhead.
|
// raw_combined overhead.
|
||||||
size_t need = round_up_to(len, sizeof(size_t)) + sizeof(raw_combined);
|
size_t need = round_up_to(len, sizeof(size_t)) + sizeof(raw_combined);
|
||||||
size_t alen = round_up_to(need, CEPH_BUFFER_ALLOC_UNIT) -
|
size_t alen = round_up_to(need, CEPH_BUFFER_ALLOC_UNIT) -
|
||||||
sizeof(raw_combined);
|
sizeof(raw_combined);
|
||||||
append_buffer = raw_combined::create(alen, 0, get_mempool());
|
_buffers.emplace_back(raw_combined::create(alen, 0, get_mempool()));
|
||||||
append_buffer.set_length(0); // unused, so far.
|
_buffers.back().set_length(0); // unused, so far.
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -1511,16 +1523,19 @@ static ceph::spinlock debug_lock;
|
|||||||
|
|
||||||
void buffer::list::append_zero(unsigned len)
|
void buffer::list::append_zero(unsigned len)
|
||||||
{
|
{
|
||||||
unsigned need = std::min(append_buffer.unused_tail_length(), len);
|
_len += len;
|
||||||
if (need) {
|
|
||||||
append_buffer.append_zeros(need);
|
const unsigned free_in_last = get_append_buffer_unused_tail_length();
|
||||||
append(append_buffer, append_buffer.length() - need, need);
|
const unsigned first_round = std::min(len, free_in_last);
|
||||||
len -= need;
|
if (first_round) {
|
||||||
|
_buffers.back().append_zeros(first_round);
|
||||||
}
|
}
|
||||||
if (len) {
|
|
||||||
auto bp = ptr_node::create(buffer::create_page_aligned(len));
|
const unsigned second_round = len - first_round;
|
||||||
bp->zero(false);
|
if (second_round) {
|
||||||
push_back(std::move(bp));
|
auto& new_back = refill_append_space(second_round);
|
||||||
|
new_back.set_length(second_round);
|
||||||
|
new_back.zero(false);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1005,7 +1005,16 @@ namespace buffer CEPH_BUFFER_API {
|
|||||||
void try_assign_to_mempool(int pool);
|
void try_assign_to_mempool(int pool);
|
||||||
|
|
||||||
size_t get_append_buffer_unused_tail_length() const {
|
size_t get_append_buffer_unused_tail_length() const {
|
||||||
return append_buffer.unused_tail_length();
|
if (_buffers.empty()) {
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
auto& buf = _buffers.back();
|
||||||
|
if (buf.raw_nref() != 1) {
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
return buf.unused_tail_length();
|
||||||
}
|
}
|
||||||
|
|
||||||
unsigned get_memcopy_count() const {return _memcopy_count; }
|
unsigned get_memcopy_count() const {return _memcopy_count; }
|
||||||
|
Loading…
Reference in New Issue
Block a user