From: Igor Fedotov <ifedotov@mirantis.com>
To: Sage Weil <sage@newdream.net>
Cc: Allen Samuels <Allen.Samuels@sandisk.com>,
ceph-devel <ceph-devel@vger.kernel.org>
Subject: Re: Adding compression support for bluestore.
Date: Mon, 4 Apr 2016 15:38:34 +0300 [thread overview]
Message-ID: <5702604A.50302@mirantis.com> (raw)
In-Reply-To: <alpine.DEB.2.11.1603311746080.4670@cpach.fuggernut.com>
On 01.04.2016 0:56, Sage Weil wrote:
> How about this:
>
> // in the onode:
> map<uint64_t, bluestore_lextent_t> data_map;
> map<int, bluestore_blob_t> blob_map;
>
> // in the enode
> map<int, bluestore_blob_t> blob_map;
>
> struct bluestore_lextent_t {
> enum {
> FLAG_SHARED = 1, ///< pextent lives in enode
> };
>
> uint64_t logical_length; ///< length of logical bytes we represent
> uint32_t pextent_id; ///< id of pextent in onode or enode
And I'd prefer 64-bit integer for this field as 4 Gb overwrites can
overflow the corresponding counter. That's just 4Tb data written by 4K
blocks.
> uint32_t x_off, x_len; ///< relative portion of pextent with our data
> uint32_t flags; ///< FLAG_*
> };
>
> struct bluestore_pextent_t {
> uint64_t offset; ///< offset on disk
> uint64_t length; ///< length on disk
> };
>
> struct bluestore_blob_t {
> enum {
> CSUM_XXHASH32 = 1,
> CSUM_XXHASH64 = 2,
> CSUM_CRC32C = 3,
> CSUM_CRC16 = 4,
> };
> enum {
> FLAG_IMMUTABLE = 1, ///< no overwrites allowed
> FLAG_COMPRESSED = 2, ///< extent is compressed; alg is in first byte of data
> };
> enum {
> COMP_ZLIB = 1,
> COMP_SNAPPY = 2,
> COMP_LZO = 3,
> };
>
> vector<bluestore_pextent_t> extents; ///< extents on disk
> uint32_t logical_length; ///< uncompressed length
> uint32_t flags; ///< FLAG_*
> uint8_t csum_type; ///< CSUM_*
> uint8_t csum_block_order;
> uint16_t num_refs; ///< reference count (always 1 when in onode)
> vector<char> csum_data; ///< opaque vector of csum data
>
> uint32_t get_ondisk_length() const {
> uint32_t len = 0;
> for (auto &p : extentes) {
> len += p.length;
> }
> return len;
> }
>
> uint32_t get_csum_block_size() const {
> return 1 << csum_block_order;
> }
> size_t get_csum_value_size() const {
> switch (csum_type) {
> case CSUM_XXHASH32: return 4;
> case CSUM_XXHASH64: return 8;
> case CSUM_CRC32C: return 4;
> case CSUM_CRC16: return 2;
> default: return 0;
> }
> }
>
> // assert (ondisk_length / csum_block_size) * csum_value_size ==
> // csum_data.length()
> };
prev parent reply other threads:[~2016-04-04 12:38 UTC|newest]
Thread overview: 55+ messages / expand[flat|nested] mbox.gz Atom feed top
2016-02-15 16:29 Adding compression support for bluestore Igor Fedotov
2016-02-16 2:06 ` Haomai Wang
2016-02-17 0:11 ` Igor Fedotov
2016-02-19 23:13 ` Allen Samuels
2016-02-22 12:25 ` Sage Weil
2016-02-24 18:18 ` Igor Fedotov
2016-02-24 18:43 ` Allen Samuels
2016-02-26 17:41 ` Igor Fedotov
2016-03-15 17:12 ` Sage Weil
2016-03-16 1:06 ` Allen Samuels
2016-03-16 18:34 ` Igor Fedotov
2016-03-16 19:02 ` Allen Samuels
2016-03-16 19:15 ` Sage Weil
2016-03-16 19:20 ` Allen Samuels
2016-03-16 19:29 ` Sage Weil
2016-03-16 19:36 ` Allen Samuels
2016-03-17 14:55 ` Igor Fedotov
2016-03-17 15:28 ` Allen Samuels
2016-03-18 13:00 ` Igor Fedotov
2016-03-16 19:27 ` Sage Weil
2016-03-16 19:41 ` Allen Samuels
[not found] ` <CA+z5DsxA9_LLozFrDOtnVRc7FcvN7S8OF12zswQZ4q4ysK_0BA@mail.gmail.com>
2016-03-16 22:56 ` Blair Bethwaite
2016-03-17 3:21 ` Allen Samuels
2016-03-17 10:01 ` Willem Jan Withagen
2016-03-17 17:29 ` Howard Chu
2016-03-17 15:21 ` Igor Fedotov
2016-03-17 15:18 ` Igor Fedotov
2016-03-17 15:33 ` Sage Weil
2016-03-17 18:53 ` Allen Samuels
2016-03-18 14:58 ` Igor Fedotov
2016-03-18 15:53 ` Igor Fedotov
2016-03-18 17:17 ` Vikas Sinha-SSI
2016-03-19 3:14 ` Allen Samuels
2016-03-21 14:19 ` Igor Fedotov
2016-03-19 3:14 ` Allen Samuels
2016-03-21 14:07 ` Igor Fedotov
2016-03-21 15:14 ` Allen Samuels
2016-03-21 16:35 ` Igor Fedotov
2016-03-21 17:14 ` Allen Samuels
2016-03-21 18:31 ` Igor Fedotov
2016-03-21 21:14 ` Allen Samuels
2016-03-21 15:32 ` Igor Fedotov
2016-03-21 15:50 ` Sage Weil
2016-03-21 18:01 ` Igor Fedotov
2016-03-24 12:45 ` Igor Fedotov
2016-03-24 22:29 ` Allen Samuels
2016-03-29 20:19 ` Sage Weil
2016-03-29 20:45 ` Allen Samuels
2016-03-30 12:32 ` Igor Fedotov
2016-03-30 12:28 ` Igor Fedotov
2016-03-30 12:47 ` Sage Weil
2016-03-31 21:56 ` Sage Weil
2016-04-01 18:54 ` Allen Samuels
2016-04-04 12:31 ` Igor Fedotov
2016-04-04 12:38 ` Igor Fedotov [this message]
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=5702604A.50302@mirantis.com \
--to=ifedotov@mirantis.com \
--cc=Allen.Samuels@sandisk.com \
--cc=ceph-devel@vger.kernel.org \
--cc=sage@newdream.net \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox