blob: 68aa27f8f526f22ffbd43f7a1d5089f92e6c525e [file] [log] [blame]
Alex Deymoaea4c1c2015-08-19 20:24:43 -07001//
2// Copyright (C) 2010 The Android Open Source Project
3//
4// Licensed under the Apache License, Version 2.0 (the "License");
5// you may not use this file except in compliance with the License.
6// You may obtain a copy of the License at
7//
8// http://www.apache.org/licenses/LICENSE-2.0
9//
10// Unless required by applicable law or agreed to in writing, software
11// distributed under the License is distributed on an "AS IS" BASIS,
12// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13// See the License for the specific language governing permissions and
14// limitations under the License.
15//
Andrew de los Reyes5fdae4a2010-10-05 10:47:42 -070016
Alex Deymo1beda782015-06-07 23:01:25 +020017#ifndef UPDATE_ENGINE_PAYLOAD_GENERATOR_EXTENT_RANGES_H_
18#define UPDATE_ENGINE_PAYLOAD_GENERATOR_EXTENT_RANGES_H_
Andrew de los Reyes5fdae4a2010-10-05 10:47:42 -070019
20#include <map>
21#include <set>
22#include <vector>
23
Ben Chan05735a12014-09-03 07:48:22 -070024#include <base/macros.h>
Andrew de los Reyes5fdae4a2010-10-05 10:47:42 -070025
Andrew de los Reyes5fdae4a2010-10-05 10:47:42 -070026#include "update_engine/update_metadata.pb.h"
27
Darin Petkov94817cb2013-05-08 14:33:24 +020028// An ExtentRanges object represents an unordered collection of extents (and
29// therefore blocks). Such an object may be modified by adding or subtracting
30// blocks (think: set addition or set subtraction). Note that ExtentRanges
31// ignores sparse hole extents mostly to avoid confusion between extending a
32// sparse hole range vs. set addition but also to ensure that the delta
33// generator doesn't use sparse holes as scratch space.
Andrew de los Reyes5fdae4a2010-10-05 10:47:42 -070034
35namespace chromeos_update_engine {
36
37struct ExtentLess {
38 bool operator()(const Extent& x, const Extent& y) const {
39 return x.start_block() < y.start_block();
40 }
41};
42
43Extent ExtentForRange(uint64_t start_block, uint64_t num_blocks);
Sen Jiang0a582fb2018-06-26 19:27:21 -070044Extent ExtentForBytes(uint64_t block_size,
45 uint64_t start_bytes,
46 uint64_t size_bytes);
Andrew de los Reyes5fdae4a2010-10-05 10:47:42 -070047
48class ExtentRanges {
49 public:
50 typedef std::set<Extent, ExtentLess> ExtentSet;
51
52 ExtentRanges() : blocks_(0) {}
53 void AddBlock(uint64_t block);
54 void SubtractBlock(uint64_t block);
55 void AddExtent(Extent extent);
56 void SubtractExtent(const Extent& extent);
57 void AddExtents(const std::vector<Extent>& extents);
58 void SubtractExtents(const std::vector<Extent>& extents);
59 void AddRepeatedExtents(
Amin Hassani232f8f92019-01-14 16:15:31 -080060 const ::google::protobuf::RepeatedPtrField<Extent>& exts);
Andrew de los Reyes5fdae4a2010-10-05 10:47:42 -070061 void SubtractRepeatedExtents(
Amin Hassani232f8f92019-01-14 16:15:31 -080062 const ::google::protobuf::RepeatedPtrField<Extent>& exts);
Andrew de los Reyes5fdae4a2010-10-05 10:47:42 -070063 void AddRanges(const ExtentRanges& ranges);
64 void SubtractRanges(const ExtentRanges& ranges);
65
Tianjie87af6c02020-08-11 15:06:26 -070066 // Returns true if the input extent overlaps with the current ExtentRanges.
67 bool OverlapsWithExtent(const Extent& extent) const;
68
Alex Deymof0061352015-07-01 14:59:15 -070069 // Returns whether the block |block| is in this ExtentRange.
70 bool ContainsBlock(uint64_t block) const;
71
Andrew de los Reyes5fdae4a2010-10-05 10:47:42 -070072 static bool ExtentsOverlapOrTouch(const Extent& a, const Extent& b);
73 static bool ExtentsOverlap(const Extent& a, const Extent& b);
74
75 // Dumps contents to the log file. Useful for debugging.
76 void Dump() const;
Darin Petkov94817cb2013-05-08 14:33:24 +020077
Andrew de los Reyes5fdae4a2010-10-05 10:47:42 -070078 uint64_t blocks() const { return blocks_; }
79 const ExtentSet& extent_set() const { return extent_set_; }
80
81 // Returns an ordered vector of extents for |count| blocks,
82 // using extents in extent_set_. The returned extents are not
83 // removed from extent_set_. |count| must be less than or equal to
84 // the number of blocks in this extent set.
85 std::vector<Extent> GetExtentsForBlockCount(uint64_t count) const;
86
87 private:
88 ExtentSet extent_set_;
89 uint64_t blocks_;
90};
91
Alex Deymoa376a6e2015-06-05 00:31:34 +020092// Filters out from the passed list of extents |extents| all the blocks in the
93// ExtentRanges set. Note that the order of the blocks in |extents| is preserved
94// omitting blocks present in the ExtentRanges |ranges|.
95std::vector<Extent> FilterExtentRanges(const std::vector<Extent>& extents,
96 const ExtentRanges& ranges);
97
Andrew de los Reyes5fdae4a2010-10-05 10:47:42 -070098} // namespace chromeos_update_engine
99
Alex Deymo1beda782015-06-07 23:01:25 +0200100#endif // UPDATE_ENGINE_PAYLOAD_GENERATOR_EXTENT_RANGES_H_