Home | History | Annotate | Download | only in hwc2on1adapter
      1 /*
      2  * Copyright 2015 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  */
     16 
     17 #ifndef ANDROID_SF_HWC2_ON_1_ADAPTER_H
     18 #define ANDROID_SF_HWC2_ON_1_ADAPTER_H
     19 
     20 #define HWC2_INCLUDE_STRINGIFICATION
     21 #define HWC2_USE_CPP11
     22 #include <hardware/hwcomposer2.h>
     23 #undef HWC2_INCLUDE_STRINGIFICATION
     24 #undef HWC2_USE_CPP11
     25 
     26 #include "MiniFence.h"
     27 
     28 #include <atomic>
     29 #include <map>
     30 #include <mutex>
     31 #include <queue>
     32 #include <set>
     33 #include <unordered_map>
     34 #include <unordered_set>
     35 #include <vector>
     36 
     37 struct hwc_composer_device_1;
     38 struct hwc_display_contents_1;
     39 struct hwc_layer_1;
     40 
     41 namespace android {
     42 
     43 // For devices unable to provide an implementation of HWC2 (see hwcomposer2.h),
     44 // we provide an adapter able to talk to HWC1 (see hwcomposer.h). It translates
     45 // streamed function calls ala HWC2 model to batched array of structs calls ala
     46 // HWC1 model.
     47 class HWC2On1Adapter : public hwc2_device_t
     48 {
     49 public:
     50     explicit HWC2On1Adapter(struct hwc_composer_device_1* hwc1Device);
     51     ~HWC2On1Adapter();
     52 
     53     struct hwc_composer_device_1* getHwc1Device() const { return mHwc1Device; }
     54     uint8_t getHwc1MinorVersion() const { return mHwc1MinorVersion; }
     55 
     56 private:
     57     static inline HWC2On1Adapter* getAdapter(hwc2_device_t* device) {
     58         return static_cast<HWC2On1Adapter*>(device);
     59     }
     60 
     61     // getCapabilities
     62 
     63     void doGetCapabilities(uint32_t* outCount,
     64             int32_t* /*hwc2_capability_t*/ outCapabilities);
     65     static void getCapabilitiesHook(hwc2_device_t* device, uint32_t* outCount,
     66             int32_t* /*hwc2_capability_t*/ outCapabilities) {
     67         getAdapter(device)->doGetCapabilities(outCount, outCapabilities);
     68     }
     69 
     70     bool supportsBackgroundColor() {
     71         return mHwc1SupportsBackgroundColor;
     72     }
     73 
     74     // getFunction
     75 
     76     hwc2_function_pointer_t doGetFunction(HWC2::FunctionDescriptor descriptor);
     77     static hwc2_function_pointer_t getFunctionHook(hwc2_device_t* device,
     78             int32_t intDesc) {
     79         auto descriptor = static_cast<HWC2::FunctionDescriptor>(intDesc);
     80         return getAdapter(device)->doGetFunction(descriptor);
     81     }
     82 
     83     // Device functions
     84 
     85     HWC2::Error createVirtualDisplay(uint32_t width, uint32_t height,
     86             hwc2_display_t* outDisplay);
     87     static int32_t createVirtualDisplayHook(hwc2_device_t* device,
     88             uint32_t width, uint32_t height, int32_t* /*format*/,
     89             hwc2_display_t* outDisplay) {
     90         // HWC1 implementations cannot override the buffer format requested by
     91         // the consumer
     92         auto error = getAdapter(device)->createVirtualDisplay(width, height,
     93                 outDisplay);
     94         return static_cast<int32_t>(error);
     95     }
     96 
     97     HWC2::Error destroyVirtualDisplay(hwc2_display_t display);
     98     static int32_t destroyVirtualDisplayHook(hwc2_device_t* device,
     99             hwc2_display_t display) {
    100         auto error = getAdapter(device)->destroyVirtualDisplay(display);
    101         return static_cast<int32_t>(error);
    102     }
    103 
    104     std::string mDumpString;
    105     void dump(uint32_t* outSize, char* outBuffer);
    106     static void dumpHook(hwc2_device_t* device, uint32_t* outSize,
    107             char* outBuffer) {
    108         getAdapter(device)->dump(outSize, outBuffer);
    109     }
    110 
    111     uint32_t getMaxVirtualDisplayCount();
    112     static uint32_t getMaxVirtualDisplayCountHook(hwc2_device_t* device) {
    113         return getAdapter(device)->getMaxVirtualDisplayCount();
    114     }
    115 
    116     HWC2::Error registerCallback(HWC2::Callback descriptor,
    117             hwc2_callback_data_t callbackData, hwc2_function_pointer_t pointer);
    118     static int32_t registerCallbackHook(hwc2_device_t* device,
    119             int32_t intDesc, hwc2_callback_data_t callbackData,
    120             hwc2_function_pointer_t pointer) {
    121         auto descriptor = static_cast<HWC2::Callback>(intDesc);
    122         auto error = getAdapter(device)->registerCallback(descriptor,
    123                 callbackData, pointer);
    124         return static_cast<int32_t>(error);
    125     }
    126 
    127     // Display functions
    128 
    129     class Layer;
    130 
    131     class SortLayersByZ {
    132         public:
    133             bool operator()(const std::shared_ptr<Layer>& lhs,
    134                     const std::shared_ptr<Layer>& rhs);
    135     };
    136 
    137     // The semantics of the fences returned by the device differ between
    138     // hwc1.set() and hwc2.present(). Read hwcomposer.h and hwcomposer2.h
    139     // for more information.
    140     //
    141     // Release fences in hwc1 are obtained on set() for a frame n and signaled
    142     // when the layer buffer is not needed for read operations anymore
    143     // (typically on frame n+1). In HWC2, release fences are obtained with a
    144     // special call after present() for frame n. These fences signal
    145     // on frame n: More specifically, the fence for a given buffer provided in
    146     // frame n will signal when the prior buffer is no longer required.
    147     //
    148     // A retire fence (HWC1) is signaled when a composition is replaced
    149     // on the panel whereas a present fence (HWC2) is signaled when a
    150     // composition starts to be displayed on a panel.
    151     //
    152     // The HWC2to1Adapter emulates the new fence semantics for a frame
    153     // n by returning the fence from frame n-1. For frame 0, the adapter
    154     // returns NO_FENCE.
    155     class DeferredFence {
    156         public:
    157             DeferredFence()
    158               : mFences({MiniFence::NO_FENCE, MiniFence::NO_FENCE}) {}
    159 
    160             void add(int32_t fenceFd) {
    161                 mFences.emplace(new MiniFence(fenceFd));
    162                 mFences.pop();
    163             }
    164 
    165             const sp<MiniFence>& get() const {
    166                 return mFences.front();
    167             }
    168 
    169         private:
    170             // There are always two fences in this queue.
    171             std::queue<sp<MiniFence>> mFences;
    172     };
    173 
    174     class FencedBuffer {
    175         public:
    176             FencedBuffer() : mBuffer(nullptr), mFence(MiniFence::NO_FENCE) {}
    177 
    178             void setBuffer(buffer_handle_t buffer) { mBuffer = buffer; }
    179             void setFence(int fenceFd) { mFence = new MiniFence(fenceFd); }
    180 
    181             buffer_handle_t getBuffer() const { return mBuffer; }
    182             int getFence() const { return mFence->dup(); }
    183 
    184         private:
    185             buffer_handle_t mBuffer;
    186             sp<MiniFence> mFence;
    187     };
    188 
    189     class Display {
    190         public:
    191             Display(HWC2On1Adapter& device, HWC2::DisplayType type);
    192 
    193             hwc2_display_t getId() const { return mId; }
    194             HWC2On1Adapter& getDevice() const { return mDevice; }
    195 
    196             // Does not require locking because it is set before adding the
    197             // Displays to the Adapter's list of displays
    198             void setHwc1Id(int32_t id) { mHwc1Id = id; }
    199             int32_t getHwc1Id() const { return mHwc1Id; }
    200 
    201             // HWC2 Display functions
    202             HWC2::Error acceptChanges();
    203             HWC2::Error createLayer(hwc2_layer_t* outLayerId);
    204             HWC2::Error destroyLayer(hwc2_layer_t layerId);
    205             HWC2::Error getActiveConfig(hwc2_config_t* outConfigId);
    206             HWC2::Error getAttribute(hwc2_config_t configId,
    207                     HWC2::Attribute attribute, int32_t* outValue);
    208             HWC2::Error getChangedCompositionTypes(uint32_t* outNumElements,
    209                     hwc2_layer_t* outLayers, int32_t* outTypes);
    210             HWC2::Error getColorModes(uint32_t* outNumModes, int32_t* outModes);
    211             HWC2::Error getConfigs(uint32_t* outNumConfigs,
    212                     hwc2_config_t* outConfigIds);
    213             HWC2::Error getDozeSupport(int32_t* outSupport);
    214             HWC2::Error getHdrCapabilities(uint32_t* outNumTypes,
    215                     int32_t* outTypes, float* outMaxLuminance,
    216                     float* outMaxAverageLuminance, float* outMinLuminance);
    217             HWC2::Error getName(uint32_t* outSize, char* outName);
    218             HWC2::Error getReleaseFences(uint32_t* outNumElements,
    219                     hwc2_layer_t* outLayers, int32_t* outFences);
    220             HWC2::Error getRequests(int32_t* outDisplayRequests,
    221                     uint32_t* outNumElements, hwc2_layer_t* outLayers,
    222                     int32_t* outLayerRequests);
    223             HWC2::Error getType(int32_t* outType);
    224 
    225             // Since HWC1 "presents" (called "set" in HWC1) all Displays
    226             // at once, the first call to any Display::present will trigger
    227             // present() on all Displays in the Device. Subsequent calls without
    228             // first calling validate() are noop (except for duping/returning
    229             // the retire fence).
    230             HWC2::Error present(int32_t* outRetireFence);
    231 
    232             HWC2::Error setActiveConfig(hwc2_config_t configId);
    233             HWC2::Error setClientTarget(buffer_handle_t target,
    234                     int32_t acquireFence, int32_t dataspace,
    235                     hwc_region_t damage);
    236             HWC2::Error setColorMode(android_color_mode_t mode);
    237             HWC2::Error setColorTransform(android_color_transform_t hint);
    238             HWC2::Error setOutputBuffer(buffer_handle_t buffer,
    239                     int32_t releaseFence);
    240             HWC2::Error setPowerMode(HWC2::PowerMode mode);
    241             HWC2::Error setVsyncEnabled(HWC2::Vsync enabled);
    242 
    243             // Since HWC1 "validates" (called "prepare" in HWC1) all Displays
    244             // at once, the first call to any Display::validate() will trigger
    245             // validate() on all other Displays in the Device.
    246             HWC2::Error validate(uint32_t* outNumTypes,
    247                     uint32_t* outNumRequests);
    248 
    249             HWC2::Error updateLayerZ(hwc2_layer_t layerId, uint32_t z);
    250 
    251             HWC2::Error getClientTargetSupport(uint32_t width, uint32_t height,
    252                      int32_t format, int32_t dataspace);
    253 
    254             // Read configs from HWC1 device
    255             void populateConfigs();
    256 
    257             // Set configs for a virtual display
    258             void populateConfigs(uint32_t width, uint32_t height);
    259 
    260             bool prepare();
    261 
    262             // Called after hwc.prepare() with responses from the device.
    263             void generateChanges();
    264 
    265             bool hasChanges() const;
    266             HWC2::Error set(hwc_display_contents_1& hwcContents);
    267             void addRetireFence(int fenceFd);
    268             void addReleaseFences(const hwc_display_contents_1& hwcContents);
    269 
    270             bool hasColorTransform() const;
    271 
    272             std::string dump() const;
    273 
    274             // Return a rect from the pool allocated during validate()
    275             hwc_rect_t* GetRects(size_t numRects);
    276 
    277             hwc_display_contents_1* getDisplayContents();
    278 
    279             void markGeometryChanged() { mGeometryChanged = true; }
    280             void resetGeometryMarker() { mGeometryChanged = false;}
    281         private:
    282             class Config {
    283                 public:
    284                     Config(Display& display)
    285                       : mDisplay(display),
    286                         mId(0),
    287                         mAttributes() {}
    288 
    289                     bool isOnDisplay(const Display& display) const {
    290                         return display.getId() == mDisplay.getId();
    291                     }
    292 
    293                     void setAttribute(HWC2::Attribute attribute, int32_t value);
    294                     int32_t getAttribute(HWC2::Attribute attribute) const;
    295 
    296                     void setHwc1Id(uint32_t id);
    297                     bool hasHwc1Id(uint32_t id) const;
    298                     HWC2::Error getColorModeForHwc1Id(uint32_t id,
    299                             android_color_mode_t *outMode) const;
    300                     HWC2::Error getHwc1IdForColorMode(android_color_mode_t mode,
    301                             uint32_t* outId) const;
    302 
    303                     void setId(hwc2_config_t id) { mId = id; }
    304                     hwc2_config_t getId() const { return mId; }
    305 
    306                     // Attempts to merge two configs that differ only in color
    307                     // mode. Returns whether the merge was successful
    308                     bool merge(const Config& other);
    309 
    310                     std::set<android_color_mode_t> getColorModes() const;
    311 
    312                     // splitLine divides the output into two lines suitable for
    313                     // dumpsys SurfaceFlinger
    314                     std::string toString(bool splitLine = false) const;
    315 
    316                 private:
    317                     Display& mDisplay;
    318                     hwc2_config_t mId;
    319                     std::unordered_map<HWC2::Attribute, int32_t> mAttributes;
    320 
    321                     // Maps from color transform to HWC1 config ID
    322                     std::unordered_map<android_color_mode_t, uint32_t> mHwc1Ids;
    323             };
    324 
    325             // Stores changes requested from the device upon calling prepare().
    326             // Handles change request to:
    327             //   - Layer composition type.
    328             //   - Layer hints.
    329             class Changes {
    330                 public:
    331                     uint32_t getNumTypes() const {
    332                         return static_cast<uint32_t>(mTypeChanges.size());
    333                     }
    334 
    335                     uint32_t getNumLayerRequests() const {
    336                         return static_cast<uint32_t>(mLayerRequests.size());
    337                     }
    338 
    339                     const std::unordered_map<hwc2_layer_t, HWC2::Composition>&
    340                             getTypeChanges() const {
    341                         return mTypeChanges;
    342                     }
    343 
    344                     const std::unordered_map<hwc2_layer_t, HWC2::LayerRequest>&
    345                             getLayerRequests() const {
    346                         return mLayerRequests;
    347                     }
    348 
    349                     void addTypeChange(hwc2_layer_t layerId,
    350                             HWC2::Composition type) {
    351                         mTypeChanges.insert({layerId, type});
    352                     }
    353 
    354                     void clearTypeChanges() { mTypeChanges.clear(); }
    355 
    356                     void addLayerRequest(hwc2_layer_t layerId,
    357                             HWC2::LayerRequest request) {
    358                         mLayerRequests.insert({layerId, request});
    359                     }
    360 
    361                 private:
    362                     std::unordered_map<hwc2_layer_t, HWC2::Composition>
    363                             mTypeChanges;
    364                     std::unordered_map<hwc2_layer_t, HWC2::LayerRequest>
    365                             mLayerRequests;
    366             };
    367 
    368             std::shared_ptr<const Config>
    369                     getConfig(hwc2_config_t configId) const;
    370 
    371             void populateColorModes();
    372             void initializeActiveConfig();
    373 
    374             // Creates a bi-directional mapping between index in HWC1
    375             // prepare/set array and Layer object. Stores mapping in
    376             // mHwc1LayerMap and also updates Layer's attribute mHwc1Id.
    377             void assignHwc1LayerIds();
    378 
    379             // Called after a response to prepare() has been received:
    380             // Ingest composition type changes requested by the device.
    381             void updateTypeChanges(const struct hwc_layer_1& hwc1Layer,
    382                     const Layer& layer);
    383 
    384             // Called after a response to prepare() has been received:
    385             // Ingest layer hint changes requested by the device.
    386             void updateLayerRequests(const struct hwc_layer_1& hwc1Layer,
    387                     const Layer& layer);
    388 
    389             // Set all fields in HWC1 comm array for layer containing the
    390             // HWC_FRAMEBUFFER_TARGET (always the last layer).
    391             void prepareFramebufferTarget();
    392 
    393             // Display ID generator.
    394             static std::atomic<hwc2_display_t> sNextId;
    395             const hwc2_display_t mId;
    396 
    397 
    398             HWC2On1Adapter& mDevice;
    399 
    400             // The state of this display should only be modified from
    401             // SurfaceFlinger's main loop, with the exception of when dump is
    402             // called. To prevent a bad state from crashing us during a dump
    403             // call, all public calls into Display must acquire this mutex.
    404             //
    405             // It is recursive because we don't want to deadlock in validate
    406             // (or present) when we call HWC2On1Adapter::prepareAllDisplays
    407             // (or setAllDisplays), which calls back into Display functions
    408             // which require locking.
    409             mutable std::recursive_mutex mStateMutex;
    410 
    411             // Allocate RAM able to store all layers and rects used for
    412             // communication with HWC1. Place allocated RAM in variable
    413             // mHwc1RequestedContents.
    414             void allocateRequestedContents();
    415 
    416             // Array of structs exchanged between client and hwc1 device.
    417             // Sent to device upon calling prepare().
    418             std::unique_ptr<hwc_display_contents_1> mHwc1RequestedContents;
    419     private:
    420             DeferredFence mRetireFence;
    421 
    422             // Will only be non-null after the Display has been validated and
    423             // before it has been presented
    424             std::unique_ptr<Changes> mChanges;
    425 
    426             int32_t mHwc1Id;
    427 
    428             std::vector<std::shared_ptr<Config>> mConfigs;
    429             std::shared_ptr<const Config> mActiveConfig;
    430             std::set<android_color_mode_t> mColorModes;
    431             android_color_mode_t mActiveColorMode;
    432             std::string mName;
    433             HWC2::DisplayType mType;
    434             HWC2::PowerMode mPowerMode;
    435             HWC2::Vsync mVsyncEnabled;
    436 
    437             // Used to populate HWC1 HWC_FRAMEBUFFER_TARGET layer
    438             FencedBuffer mClientTarget;
    439 
    440 
    441             FencedBuffer mOutputBuffer;
    442 
    443             bool mHasColorTransform;
    444 
    445             // All layers this Display is aware of.
    446             std::multiset<std::shared_ptr<Layer>, SortLayersByZ> mLayers;
    447 
    448             // Mapping between layer index in array of hwc_display_contents_1*
    449             // passed to HWC1 during validate/set and Layer object.
    450             std::unordered_map<size_t, std::shared_ptr<Layer>> mHwc1LayerMap;
    451 
    452             // All communication with HWC1 via prepare/set is done with one
    453             // alloc. This pointer is pointing to a pool of hwc_rect_t.
    454             size_t mNumAvailableRects;
    455             hwc_rect_t* mNextAvailableRect;
    456 
    457             // True if any of the Layers contained in this Display have been
    458             // updated with anything other than a buffer since last call to
    459             // Display::set()
    460             bool mGeometryChanged;
    461     };
    462 
    463     // Utility template calling a Display object method directly based on the
    464     // hwc2_display_t displayId parameter.
    465     template <typename ...Args>
    466     static int32_t callDisplayFunction(hwc2_device_t* device,
    467             hwc2_display_t displayId, HWC2::Error (Display::*member)(Args...),
    468             Args... args) {
    469         auto display = getAdapter(device)->getDisplay(displayId);
    470         if (!display) {
    471             return static_cast<int32_t>(HWC2::Error::BadDisplay);
    472         }
    473         auto error = ((*display).*member)(std::forward<Args>(args)...);
    474         return static_cast<int32_t>(error);
    475     }
    476 
    477     template <typename MF, MF memFunc, typename ...Args>
    478     static int32_t displayHook(hwc2_device_t* device, hwc2_display_t displayId,
    479             Args... args) {
    480         return HWC2On1Adapter::callDisplayFunction(device, displayId, memFunc,
    481                 std::forward<Args>(args)...);
    482     }
    483 
    484     static int32_t getDisplayAttributeHook(hwc2_device_t* device,
    485             hwc2_display_t display, hwc2_config_t config,
    486             int32_t intAttribute, int32_t* outValue) {
    487         auto attribute = static_cast<HWC2::Attribute>(intAttribute);
    488         return callDisplayFunction(device, display, &Display::getAttribute,
    489                 config, attribute, outValue);
    490     }
    491 
    492     static int32_t setColorTransformHook(hwc2_device_t* device,
    493             hwc2_display_t display, const float* /*matrix*/,
    494             int32_t /*android_color_transform_t*/ intHint) {
    495         // We intentionally throw away the matrix, because if the hint is
    496         // anything other than IDENTITY, we have to fall back to client
    497         // composition anyway
    498         auto hint = static_cast<android_color_transform_t>(intHint);
    499         return callDisplayFunction(device, display, &Display::setColorTransform,
    500                 hint);
    501     }
    502 
    503     static int32_t setColorModeHook(hwc2_device_t* device,
    504             hwc2_display_t display, int32_t /*android_color_mode_t*/ intMode) {
    505         auto mode = static_cast<android_color_mode_t>(intMode);
    506         return callDisplayFunction(device, display, &Display::setColorMode,
    507                 mode);
    508     }
    509 
    510     static int32_t setPowerModeHook(hwc2_device_t* device,
    511             hwc2_display_t display, int32_t intMode) {
    512         auto mode = static_cast<HWC2::PowerMode>(intMode);
    513         return callDisplayFunction(device, display, &Display::setPowerMode,
    514                 mode);
    515     }
    516 
    517     static int32_t setVsyncEnabledHook(hwc2_device_t* device,
    518             hwc2_display_t display, int32_t intEnabled) {
    519         auto enabled = static_cast<HWC2::Vsync>(intEnabled);
    520         return callDisplayFunction(device, display, &Display::setVsyncEnabled,
    521                 enabled);
    522     }
    523 
    524     class Layer {
    525         public:
    526             explicit Layer(Display& display);
    527 
    528             bool operator==(const Layer& other) { return mId == other.mId; }
    529             bool operator!=(const Layer& other) { return !(*this == other); }
    530 
    531             hwc2_layer_t getId() const { return mId; }
    532             Display& getDisplay() const { return mDisplay; }
    533 
    534             // HWC2 Layer functions
    535             HWC2::Error setBuffer(buffer_handle_t buffer, int32_t acquireFence);
    536             HWC2::Error setCursorPosition(int32_t x, int32_t y);
    537             HWC2::Error setSurfaceDamage(hwc_region_t damage);
    538 
    539             // HWC2 Layer state functions
    540             HWC2::Error setBlendMode(HWC2::BlendMode mode);
    541             HWC2::Error setColor(hwc_color_t color);
    542             HWC2::Error setCompositionType(HWC2::Composition type);
    543             HWC2::Error setDataspace(android_dataspace_t dataspace);
    544             HWC2::Error setDisplayFrame(hwc_rect_t frame);
    545             HWC2::Error setPlaneAlpha(float alpha);
    546             HWC2::Error setSidebandStream(const native_handle_t* stream);
    547             HWC2::Error setSourceCrop(hwc_frect_t crop);
    548             HWC2::Error setTransform(HWC2::Transform transform);
    549             HWC2::Error setVisibleRegion(hwc_region_t visible);
    550             HWC2::Error setZ(uint32_t z);
    551 
    552             HWC2::Composition getCompositionType() const {
    553                 return mCompositionType;
    554             }
    555             uint32_t getZ() const { return mZ; }
    556 
    557             void addReleaseFence(int fenceFd);
    558             const sp<MiniFence>& getReleaseFence() const;
    559 
    560             void setHwc1Id(size_t id) { mHwc1Id = id; }
    561             size_t getHwc1Id() const { return mHwc1Id; }
    562 
    563             // Write state to HWC1 communication struct.
    564             void applyState(struct hwc_layer_1& hwc1Layer);
    565 
    566             std::string dump() const;
    567 
    568             std::size_t getNumVisibleRegions() { return mVisibleRegion.size(); }
    569 
    570             std::size_t getNumSurfaceDamages() { return mSurfaceDamage.size(); }
    571 
    572             // True if a layer cannot be properly rendered by the device due
    573             // to usage of SolidColor (a.k.a BackgroundColor in HWC1).
    574             bool hasUnsupportedBackgroundColor() {
    575                 return (mCompositionType == HWC2::Composition::SolidColor &&
    576                         !mDisplay.getDevice().supportsBackgroundColor());
    577             }
    578         private:
    579             void applyCommonState(struct hwc_layer_1& hwc1Layer);
    580             void applySolidColorState(struct hwc_layer_1& hwc1Layer);
    581             void applySidebandState(struct hwc_layer_1& hwc1Layer);
    582             void applyBufferState(struct hwc_layer_1& hwc1Layer);
    583             void applyCompositionType(struct hwc_layer_1& hwc1Layer);
    584 
    585             static std::atomic<hwc2_layer_t> sNextId;
    586             const hwc2_layer_t mId;
    587             Display& mDisplay;
    588 
    589             FencedBuffer mBuffer;
    590             std::vector<hwc_rect_t> mSurfaceDamage;
    591 
    592             HWC2::BlendMode mBlendMode;
    593             hwc_color_t mColor;
    594             HWC2::Composition mCompositionType;
    595             hwc_rect_t mDisplayFrame;
    596             float mPlaneAlpha;
    597             const native_handle_t* mSidebandStream;
    598             hwc_frect_t mSourceCrop;
    599             HWC2::Transform mTransform;
    600             std::vector<hwc_rect_t> mVisibleRegion;
    601 
    602             uint32_t mZ;
    603 
    604             DeferredFence mReleaseFence;
    605 
    606             size_t mHwc1Id;
    607             bool mHasUnsupportedPlaneAlpha;
    608     };
    609 
    610     // Utility tempate calling a Layer object method based on ID parameters:
    611     // hwc2_display_t displayId
    612     // and
    613     // hwc2_layer_t layerId
    614     template <typename ...Args>
    615     static int32_t callLayerFunction(hwc2_device_t* device,
    616             hwc2_display_t displayId, hwc2_layer_t layerId,
    617             HWC2::Error (Layer::*member)(Args...), Args... args) {
    618         auto result = getAdapter(device)->getLayer(displayId, layerId);
    619         auto error = std::get<HWC2::Error>(result);
    620         if (error == HWC2::Error::None) {
    621             auto layer = std::get<Layer*>(result);
    622             error = ((*layer).*member)(std::forward<Args>(args)...);
    623         }
    624         return static_cast<int32_t>(error);
    625     }
    626 
    627     template <typename MF, MF memFunc, typename ...Args>
    628     static int32_t layerHook(hwc2_device_t* device, hwc2_display_t displayId,
    629             hwc2_layer_t layerId, Args... args) {
    630         return HWC2On1Adapter::callLayerFunction(device, displayId, layerId,
    631                 memFunc, std::forward<Args>(args)...);
    632     }
    633 
    634     // Layer state functions
    635 
    636     static int32_t setLayerBlendModeHook(hwc2_device_t* device,
    637             hwc2_display_t display, hwc2_layer_t layer, int32_t intMode) {
    638         auto mode = static_cast<HWC2::BlendMode>(intMode);
    639         return callLayerFunction(device, display, layer,
    640                 &Layer::setBlendMode, mode);
    641     }
    642 
    643     static int32_t setLayerCompositionTypeHook(hwc2_device_t* device,
    644             hwc2_display_t display, hwc2_layer_t layer, int32_t intType) {
    645         auto type = static_cast<HWC2::Composition>(intType);
    646         return callLayerFunction(device, display, layer,
    647                 &Layer::setCompositionType, type);
    648     }
    649 
    650     static int32_t setLayerDataspaceHook(hwc2_device_t* device,
    651             hwc2_display_t display, hwc2_layer_t layer, int32_t intDataspace) {
    652         auto dataspace = static_cast<android_dataspace_t>(intDataspace);
    653         return callLayerFunction(device, display, layer, &Layer::setDataspace,
    654                 dataspace);
    655     }
    656 
    657     static int32_t setLayerTransformHook(hwc2_device_t* device,
    658             hwc2_display_t display, hwc2_layer_t layer, int32_t intTransform) {
    659         auto transform = static_cast<HWC2::Transform>(intTransform);
    660         return callLayerFunction(device, display, layer, &Layer::setTransform,
    661                 transform);
    662     }
    663 
    664     static int32_t setLayerZOrderHook(hwc2_device_t* device,
    665             hwc2_display_t display, hwc2_layer_t layer, uint32_t z) {
    666         return callDisplayFunction(device, display, &Display::updateLayerZ,
    667                 layer, z);
    668     }
    669 
    670     // Adapter internals
    671 
    672     void populateCapabilities();
    673     Display* getDisplay(hwc2_display_t id);
    674     std::tuple<Layer*, HWC2::Error> getLayer(hwc2_display_t displayId,
    675             hwc2_layer_t layerId);
    676     void populatePrimary();
    677 
    678     bool prepareAllDisplays();
    679     std::vector<struct hwc_display_contents_1*> mHwc1Contents;
    680     HWC2::Error setAllDisplays();
    681 
    682     // Callbacks
    683     void hwc1Invalidate();
    684     void hwc1Vsync(int hwc1DisplayId, int64_t timestamp);
    685     void hwc1Hotplug(int hwc1DisplayId, int connected);
    686 
    687     // These are set in the constructor and before any asynchronous events are
    688     // possible
    689 
    690     struct hwc_composer_device_1* const mHwc1Device;
    691     const uint8_t mHwc1MinorVersion;
    692     bool mHwc1SupportsVirtualDisplays;
    693     bool mHwc1SupportsBackgroundColor;
    694 
    695     class Callbacks;
    696     const std::unique_ptr<Callbacks> mHwc1Callbacks;
    697 
    698     std::unordered_set<HWC2::Capability> mCapabilities;
    699 
    700     // These are only accessed from the main SurfaceFlinger thread (not from
    701     // callbacks or dump
    702 
    703     std::map<hwc2_layer_t, std::shared_ptr<Layer>> mLayers;
    704 
    705     // A HWC1 supports only one virtual display.
    706     std::shared_ptr<Display> mHwc1VirtualDisplay;
    707 
    708     // These are potentially accessed from multiple threads, and are protected
    709     // by this mutex. This needs to be recursive, since the HWC1 implementation
    710     // can call back into the invalidate callback on the same thread that is
    711     // calling prepare.
    712     std::recursive_timed_mutex mStateMutex;
    713 
    714     struct CallbackInfo {
    715         hwc2_callback_data_t data;
    716         hwc2_function_pointer_t pointer;
    717     };
    718     std::unordered_map<HWC2::Callback, CallbackInfo> mCallbacks;
    719     bool mHasPendingInvalidate;
    720 
    721     // There is a small gap between the time the HWC1 module is started and
    722     // when the callbacks for vsync and hotplugs are registered by the
    723     // HWC2on1Adapter. To prevent losing events they are stored in these arrays
    724     // and fed to the callback as soon as possible.
    725     std::vector<std::pair<int, int64_t>> mPendingVsyncs;
    726     std::vector<std::pair<int, int>> mPendingHotplugs;
    727 
    728     // Mapping between HWC1 display id and Display objects.
    729     std::map<hwc2_display_t, std::shared_ptr<Display>> mDisplays;
    730 
    731     // Map HWC1 display type (HWC_DISPLAY_PRIMARY, HWC_DISPLAY_EXTERNAL,
    732     // HWC_DISPLAY_VIRTUAL) to Display IDs generated by HWC2on1Adapter objects.
    733     std::unordered_map<int, hwc2_display_t> mHwc1DisplayMap;
    734 };
    735 
    736 } // namespace android
    737 
    738 #endif
    739