// -*- mode:C++; tab-width:8; c-basic-offset:2; indent-tabs-mode:t -*- // vim: ts=8 sw=2 smarttab /* * Ceph distributed storage system * * Copyright (C) 2014 Cloudwatt * * Author: Loic Dachary * * This library is free software; you can redistribute it and/or * modify it under the terms of the GNU Lesser General Public * License as published by the Free Software Foundation; either * version 2.1 of the License, or (at your option) any later version. * */ #ifndef CEPH_ERASURE_CODE_H #define CEPH_ERASURE_CODE_H /*! @file ErasureCode.h @brief Base class for erasure code plugins implementors */ #include "ErasureCodeInterface.h" namespace ceph { class ErasureCode : public ErasureCodeInterface { public: static const unsigned SIMD_ALIGN; std::vector chunk_mapping; ErasureCodeProfile _profile; // for CRUSH rule std::string rule_root; std::string rule_failure_domain; std::string rule_device_class; int rule_osds_per_failure_domain = -1; int rule_num_failure_domains = -1; ~ErasureCode() override {} int init(ceph::ErasureCodeProfile &profile, std::ostream *ss) override; const ErasureCodeProfile &get_profile() const override { return _profile; } int create_rule(const std::string &name, CrushWrapper &crush, std::ostream *ss) const override; int sanity_check_k_m(int k, int m, std::ostream *ss); unsigned int get_coding_chunk_count() const override { return get_chunk_count() - get_data_chunk_count(); } virtual int get_sub_chunk_count() override { return 1; } virtual int _minimum_to_decode(const std::set &want_to_read, const std::set &available_chunks, std::set *minimum); int minimum_to_decode(const std::set &want_to_read, const std::set &available, std::map>> *minimum) override; int minimum_to_decode_with_cost(const std::set &want_to_read, const std::map &available, std::set *minimum) override; int encode_prepare(const bufferlist &raw, std::map &encoded) const; int encode(const std::set &want_to_encode, const bufferlist &in, std::map *encoded) override; int decode(const std::set &want_to_read, const std::map &chunks, std::map *decoded, int chunk_size) override; virtual int _decode(const std::set &want_to_read, const std::map &chunks, std::map *decoded); const std::vector &get_chunk_mapping() const override; int to_mapping(const ErasureCodeProfile &profile, std::ostream *ss); static int to_int(const std::string &name, ErasureCodeProfile &profile, int *value, const std::string &default_value, std::ostream *ss); static int to_bool(const std::string &name, ErasureCodeProfile &profile, bool *value, const std::string &default_value, std::ostream *ss); static int to_string(const std::string &name, ErasureCodeProfile &profile, std::string *value, const std::string &default_value, std::ostream *ss); int decode_concat(const std::set& want_to_read, const std::map &chunks, bufferlist *decoded) override; int decode_concat(const std::map &chunks, bufferlist *decoded) override; protected: int parse(const ErasureCodeProfile &profile, std::ostream *ss); private: int chunk_index(unsigned int i) const; }; } #endif