2 * Copyright (C) 2015 The Android Open Source Project
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
8 * http://www.apache.org/licenses/LICENSE-2.0
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.
17 #ifndef ANDROID_DRM_DISPLAY_COMPOSITOR_H_
18 #define ANDROID_DRM_DISPLAY_COMPOSITOR_H_
20 #include "drmhwcomposer.h"
21 #include "drmcomposition.h"
22 #include "drmcompositorworker.h"
23 #include "drmframebuffer.h"
24 #include "separate_rects.h"
32 #include <hardware/hardware.h>
33 #include <hardware/hwcomposer.h>
35 #define DRM_DISPLAY_BUFFERS 2
39 class GLWorkerCompositor;
43 static const unsigned kHistoryLength = 6; // TODO: make this number not magic
44 static const unsigned kMaxLayers = 64;
48 std::bitset<kMaxLayers> layer_refs;
49 std::bitset<kHistoryLength> change_history;
50 bool squashed = false;
53 bool is_stable(int region_index) const {
54 return valid_history_ >= kHistoryLength &&
55 regions_[region_index].change_history.none();
58 const std::vector<Region> ®ions() const {
62 void Init(DrmHwcLayer *layers, size_t num_layers);
63 void GenerateHistory(DrmHwcLayer *layers, size_t num_layers,
64 std::vector<bool> &changed_regions) const;
65 void StableRegionsWithMarginalHistory(
66 const std::vector<bool> &changed_regions,
67 std::vector<bool> &stable_regions) const;
68 void RecordHistory(DrmHwcLayer *layers, size_t num_layers,
69 const std::vector<bool> &changed_regions);
70 bool RecordAndCompareSquashed(const std::vector<bool> &squashed_regions);
72 void Dump(std::ostringstream *out) const;
75 size_t generation_number_ = 0;
76 unsigned valid_history_ = 0;
77 std::vector<buffer_handle_t> last_handles_;
79 std::vector<Region> regions_;
82 class DrmDisplayCompositor {
84 DrmDisplayCompositor();
85 ~DrmDisplayCompositor();
87 int Init(DrmResources *drm, int display);
89 std::unique_ptr<DrmDisplayComposition> CreateComposition() const;
90 int QueueComposition(std::unique_ptr<DrmDisplayComposition> composition);
93 void Dump(std::ostringstream *out) const;
95 std::tuple<uint32_t, uint32_t, int> GetActiveModeResolution();
97 bool HaveQueuedComposites() const;
99 SquashState *squash_state() {
100 return &squash_state_;
105 std::unique_ptr<DrmDisplayComposition> composition;
109 class FrameWorker : public Worker {
111 FrameWorker(DrmDisplayCompositor *compositor);
112 ~FrameWorker() override;
115 void QueueFrame(std::unique_ptr<DrmDisplayComposition> composition,
119 void Routine() override;
122 DrmDisplayCompositor *compositor_;
123 std::queue<FrameState> frame_queue_;
126 DrmDisplayCompositor(const DrmDisplayCompositor &) = delete;
128 // We'll wait for acquire fences to fire for kAcquireWaitTimeoutMs,
129 // kAcquireWaitTries times, logging a warning in between.
130 static const int kAcquireWaitTries = 5;
131 static const int kAcquireWaitTimeoutMs = 100;
133 int PrepareFramebuffer(DrmFramebuffer &fb,
134 DrmDisplayComposition *display_comp);
135 int ApplySquash(DrmDisplayComposition *display_comp);
136 int ApplyPreComposite(DrmDisplayComposition *display_comp);
137 int PrepareFrame(DrmDisplayComposition *display_comp);
138 int CommitFrame(DrmDisplayComposition *display_comp);
139 int ApplyDpms(DrmDisplayComposition *display_comp);
140 int DisablePlanes(DrmDisplayComposition *display_comp);
142 void ApplyFrame(std::unique_ptr<DrmDisplayComposition> composition,
148 DrmCompositorWorker worker_;
149 FrameWorker frame_worker_;
151 std::queue<std::unique_ptr<DrmDisplayComposition>> composite_queue_;
152 std::unique_ptr<DrmDisplayComposition> active_composition_;
160 int framebuffer_index_;
161 DrmFramebuffer framebuffers_[DRM_DISPLAY_BUFFERS];
162 std::unique_ptr<GLWorkerCompositor> pre_compositor_;
164 SquashState squash_state_;
165 int squash_framebuffer_index_;
166 DrmFramebuffer squash_framebuffers_[2];
168 // mutable since we need to acquire in HaveQueuedComposites
169 mutable pthread_mutex_t lock_;
171 // State tracking progress since our last Dump(). These are mutable since
172 // we need to reset them on every Dump() call.
173 mutable uint64_t dump_frames_composited_;
174 mutable uint64_t dump_last_timestamp_ns_;
178 #endif // ANDROID_DRM_DISPLAY_COMPOSITOR_H_