hwc_utils.h revision 1e8bb08f0275c3acef37838114ab2b37ae814f13
1befc466069680cb8a65b1f22ad44723d949128c8Naseer Ahmed/*
2befc466069680cb8a65b1f22ad44723d949128c8Naseer Ahmed * Copyright (C) 2010 The Android Open Source Project
3f39af541bb947658b15cda3602beeb0df8cf5c56Arun Kumar K.R * Copyright (C)2012-2014, The Linux Foundation. All rights reserved.
44019c64ad8721cd9f3dc5c4e7be260a5f0706e34Arun Kumar K.R *
54019c64ad8721cd9f3dc5c4e7be260a5f0706e34Arun Kumar K.R * Not a Contribution, Apache license notifications and license are retained
64019c64ad8721cd9f3dc5c4e7be260a5f0706e34Arun Kumar K.R * for attribution purposes only.
7befc466069680cb8a65b1f22ad44723d949128c8Naseer Ahmed *
8befc466069680cb8a65b1f22ad44723d949128c8Naseer Ahmed * Licensed under the Apache License, Version 2.0 (the "License");
9befc466069680cb8a65b1f22ad44723d949128c8Naseer Ahmed * you may not use this file except in compliance with the License.
10befc466069680cb8a65b1f22ad44723d949128c8Naseer Ahmed * You may obtain a copy of the License at
11befc466069680cb8a65b1f22ad44723d949128c8Naseer Ahmed *
12befc466069680cb8a65b1f22ad44723d949128c8Naseer Ahmed *      http://www.apache.org/licenses/LICENSE-2.0
13befc466069680cb8a65b1f22ad44723d949128c8Naseer Ahmed *
14befc466069680cb8a65b1f22ad44723d949128c8Naseer Ahmed * Unless required by applicable law or agreed to in writing, software
15befc466069680cb8a65b1f22ad44723d949128c8Naseer Ahmed * distributed under the License is distributed on an "AS IS" BASIS,
16befc466069680cb8a65b1f22ad44723d949128c8Naseer Ahmed * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
17befc466069680cb8a65b1f22ad44723d949128c8Naseer Ahmed * See the License for the specific language governing permissions and
18befc466069680cb8a65b1f22ad44723d949128c8Naseer Ahmed * limitations under the License.
19befc466069680cb8a65b1f22ad44723d949128c8Naseer Ahmed */
20befc466069680cb8a65b1f22ad44723d949128c8Naseer Ahmed
21befc466069680cb8a65b1f22ad44723d949128c8Naseer Ahmed#ifndef HWC_UTILS_H
22befc466069680cb8a65b1f22ad44723d949128c8Naseer Ahmed#define HWC_UTILS_H
231589dee5c27293d278d3e549af8a4bda27e080f8Naseer Ahmed
24660267c43bb3370ab49f4e95562c027171d8fb83Naseer Ahmed#define HWC_REMOVE_DEPRECATED_VERSIONS 1
252e449280f98f003bb5831c274fc07ab722ac1a94Saurabh Shah#include <fcntl.h>
268f42508dc1e3bf24da360d5fbefd8c6574f82868Saurabh Shah#include <math.h>
27befc466069680cb8a65b1f22ad44723d949128c8Naseer Ahmed#include <hardware/hwcomposer.h>
2877d8f24cb4fece120f062f2f997f018372338b66Naseer Ahmed#include <gr.h>
291589dee5c27293d278d3e549af8a4bda27e080f8Naseer Ahmed#include <gralloc_priv.h>
3093138887ec8fb0f232340c4fb852e3dbcb3542e4Naseer Ahmed#include <utils/String8.h>
31327b2ba85538669304a50d0fb6cc2f6aab7aaf3bSaurabh Shah#include "qdMetaData.h"
32327b2ba85538669304a50d0fb6cc2f6aab7aaf3bSaurabh Shah#include <overlayUtils.h>
33befc466069680cb8a65b1f22ad44723d949128c8Naseer Ahmed
34bd4704d4b447bd4aa59e4894d68a7162ce4f99fdNaseer Ahmed#define ALIGN_TO(x, align)     (((x) + ((align)-1)) & ~((align)-1))
35befc466069680cb8a65b1f22ad44723d949128c8Naseer Ahmed#define LIKELY( exp )       (__builtin_expect( (exp) != 0, true  ))
36befc466069680cb8a65b1f22ad44723d949128c8Naseer Ahmed#define UNLIKELY( exp )     (__builtin_expect( (exp) != 0, false ))
37d9381b134ed518570554296fbfab8fd1175ecdb8Ramkumar Radhakrishnan#define MAX_NUM_APP_LAYERS 32
38befc466069680cb8a65b1f22ad44723d949128c8Naseer Ahmed
391589dee5c27293d278d3e549af8a4bda27e080f8Naseer Ahmed//Fwrd decls
40befc466069680cb8a65b1f22ad44723d949128c8Naseer Ahmedstruct hwc_context_t;
411589dee5c27293d278d3e549af8a4bda27e080f8Naseer Ahmed
42327b2ba85538669304a50d0fb6cc2f6aab7aaf3bSaurabh Shahnamespace ovutils = overlay::utils;
43327b2ba85538669304a50d0fb6cc2f6aab7aaf3bSaurabh Shah
441589dee5c27293d278d3e549af8a4bda27e080f8Naseer Ahmednamespace overlay {
451589dee5c27293d278d3e549af8a4bda27e080f8Naseer Ahmedclass Overlay;
46327b2ba85538669304a50d0fb6cc2f6aab7aaf3bSaurabh Shahclass Rotator;
47327b2ba85538669304a50d0fb6cc2f6aab7aaf3bSaurabh Shahclass RotMgr;
481589dee5c27293d278d3e549af8a4bda27e080f8Naseer Ahmed}
491589dee5c27293d278d3e549af8a4bda27e080f8Naseer Ahmed
50befc466069680cb8a65b1f22ad44723d949128c8Naseer Ahmednamespace qhwc {
511589dee5c27293d278d3e549af8a4bda27e080f8Naseer Ahmed//fwrd decl
521589dee5c27293d278d3e549af8a4bda27e080f8Naseer Ahmedclass QueuedBufferStore;
53b3c6e058ce1dbc689f27e7d7acbf1529d37307d8Naseer Ahmedclass ExternalDisplay;
54361900d9a618d2c4d2276a10ca76919214f6759fJeykumar Sankaranclass VirtualDisplay;
55640cb9421639c13248aeb30c3496cdfaec6d894cSaurabh Shahclass IFBUpdate;
56327b2ba85538669304a50d0fb6cc2f6aab7aaf3bSaurabh Shahclass IVideoOverlay;
57c18b3a0ef41fe474fe37e2e1833ef1bb11c85b11Saurabh Shahclass MDPComp;
584019c64ad8721cd9f3dc5c4e7be260a5f0706e34Arun Kumar K.Rclass CopyBit;
59c9889a4a83afe2e431bd6982144cee1b6370d451Ramkumar Radhakrishnanclass HwcDebug;
60f1c9077e23f3fd814c27445ad73f6967a1ce5d9eSaurabh Shahclass AssertiveDisplay;
61c439b604bcd6441e3706fdcaa5084ec58cbaf16dNaseer Ahmedclass VPUClient;
62140ee6411106722dae886dc8c5b104b72d64dee0Ramkumar Radhakrishnanclass HWCVirtualBase;
63b3c6e058ce1dbc689f27e7d7acbf1529d37307d8Naseer Ahmed
6404a2afbd65e9f8bc580a637bf44bfc4e627edce0Naseer Ahmed
65b3c6e058ce1dbc689f27e7d7acbf1529d37307d8Naseer Ahmedstruct MDPInfo {
66b3c6e058ce1dbc689f27e7d7acbf1529d37307d8Naseer Ahmed    int version;
67b3c6e058ce1dbc689f27e7d7acbf1529d37307d8Naseer Ahmed    char panel;
68b3c6e058ce1dbc689f27e7d7acbf1529d37307d8Naseer Ahmed    bool hasOverlay;
69b3c6e058ce1dbc689f27e7d7acbf1529d37307d8Naseer Ahmed};
70befc466069680cb8a65b1f22ad44723d949128c8Naseer Ahmed
712e449280f98f003bb5831c274fc07ab722ac1a94Saurabh Shahstruct DisplayAttributes {
722e449280f98f003bb5831c274fc07ab722ac1a94Saurabh Shah    uint32_t vsync_period; //nanos
732e449280f98f003bb5831c274fc07ab722ac1a94Saurabh Shah    uint32_t xres;
742e449280f98f003bb5831c274fc07ab722ac1a94Saurabh Shah    uint32_t yres;
7516791f95b2570b9d48fa360875676e9c8559c0a1Naseer Ahmed    uint32_t stride;
7679e14117f5e66a080b9f2a783ce3b215c72c8653Naseer Ahmed    float xdpi;
7779e14117f5e66a080b9f2a783ce3b215c72c8653Naseer Ahmed    float ydpi;
782e449280f98f003bb5831c274fc07ab722ac1a94Saurabh Shah    int fd;
7976443245d153635b512539fbc68fdf7a904fdf6fSaurabh Shah    bool connected; //Applies only to pluggable disp.
8076443245d153635b512539fbc68fdf7a904fdf6fSaurabh Shah    //Connected does not mean it ready to use.
8176443245d153635b512539fbc68fdf7a904fdf6fSaurabh Shah    //It should be active also. (UNBLANKED)
822e449280f98f003bb5831c274fc07ab722ac1a94Saurabh Shah    bool isActive;
8390571fc7c38e38858ad22a79e95efcb99c3a8b1dAmara Venkata Mastan Manoj Kumar    // In pause state, composition is bypassed
8490571fc7c38e38858ad22a79e95efcb99c3a8b1dAmara Venkata Mastan Manoj Kumar    // used for WFD displays only
8590571fc7c38e38858ad22a79e95efcb99c3a8b1dAmara Venkata Mastan Manoj Kumar    bool isPause;
86361900d9a618d2c4d2276a10ca76919214f6759fJeykumar Sankaran    // To trigger padding round to clean up mdp
87361900d9a618d2c4d2276a10ca76919214f6759fJeykumar Sankaran    // pipes
88361900d9a618d2c4d2276a10ca76919214f6759fJeykumar Sankaran    bool isConfiguring;
89fea63d61337f1efeb2d1c7a7a4fafe472611704cAmara Venkata Mastan Manoj Kumar    // External Display is in MDP Downscale mode indicator
90fea63d61337f1efeb2d1c7a7a4fafe472611704cAmara Venkata Mastan Manoj Kumar    bool mDownScaleMode;
91ac5b9f4e6b7dc80e0f91c1581f0bcb4464a48ef4Arun Kumar K.R    // Ext dst Rect
92ac5b9f4e6b7dc80e0f91c1581f0bcb4464a48ef4Arun Kumar K.R    hwc_rect_t mDstRect;
93ba3d6165c19bcec9a56eb2db1b13f8f930c5651bRamkumar Radhakrishnan    //Action safe attributes
94ba3d6165c19bcec9a56eb2db1b13f8f930c5651bRamkumar Radhakrishnan    // Flag to indicate the presence of action safe dimensions for external
95ba3d6165c19bcec9a56eb2db1b13f8f930c5651bRamkumar Radhakrishnan    bool mActionSafePresent;
96ba3d6165c19bcec9a56eb2db1b13f8f930c5651bRamkumar Radhakrishnan    int mAsWidthRatio;
97ba3d6165c19bcec9a56eb2db1b13f8f930c5651bRamkumar Radhakrishnan    int mAsHeightRatio;
98bd4704d4b447bd4aa59e4894d68a7162ce4f99fdNaseer Ahmed};
992e449280f98f003bb5831c274fc07ab722ac1a94Saurabh Shah
1002e449280f98f003bb5831c274fc07ab722ac1a94Saurabh Shahstruct ListStats {
1012e449280f98f003bb5831c274fc07ab722ac1a94Saurabh Shah    int numAppLayers; //Total - 1, excluding FB layer.
1022e449280f98f003bb5831c274fc07ab722ac1a94Saurabh Shah    int skipCount;
1032e449280f98f003bb5831c274fc07ab722ac1a94Saurabh Shah    int fbLayerIndex; //Always last for now. = numAppLayers
1042e449280f98f003bb5831c274fc07ab722ac1a94Saurabh Shah    //Video specific
1052e449280f98f003bb5831c274fc07ab722ac1a94Saurabh Shah    int yuvCount;
106d9381b134ed518570554296fbfab8fd1175ecdb8Ramkumar Radhakrishnan    int yuvIndices[MAX_NUM_APP_LAYERS];
107eb43d2b7b681164a58e3f86bd0b0d88eea6a3591Arun Kumar K.R    int extOnlyLayerIndex;
1085c937230915bced21130a3e5d129c4f470fd74d3Sravan Kumar D.V.N    bool preMultipliedAlpha;
10915c02b94dcc7d61d4af05ac32b3c4db3b3b8a1e6radhakrishna    int yuv4k2kIndices[MAX_NUM_APP_LAYERS];
11015c02b94dcc7d61d4af05ac32b3c4db3b3b8a1e6radhakrishna    int yuv4k2kCount;
111a0e87cbc523323604e8fb7cb5526f410a1ed26dfRamkumar Radhakrishnan    // Notifies hwcomposer about the start and end of animation
112a0e87cbc523323604e8fb7cb5526f410a1ed26dfRamkumar Radhakrishnan    // This will be set to true during animation, otherwise false.
113a0e87cbc523323604e8fb7cb5526f410a1ed26dfRamkumar Radhakrishnan    bool isDisplayAnimating;
114bc037e0bbb3d1778fb4bde55582fd1d4e666f957Jeykumar Sankaran    ovutils::Dim roi;
1151b28b60e15c27fee703a16fbd1e42e3b41b031fdRamkumar Radhakrishnan    bool secureUI; // Secure display layer
11694f50bebdee0b3ab9deb6d51426c542407ced5fdSaurabh Shah    bool isSecurePresent;
117bd4704d4b447bd4aa59e4894d68a7162ce4f99fdNaseer Ahmed};
118bd4704d4b447bd4aa59e4894d68a7162ce4f99fdNaseer Ahmed
11916791f95b2570b9d48fa360875676e9c8559c0a1Naseer Ahmedstruct LayerProp {
12016791f95b2570b9d48fa360875676e9c8559c0a1Naseer Ahmed    uint32_t mFlags; //qcom specific layer flags
121bc037e0bbb3d1778fb4bde55582fd1d4e666f957Jeykumar Sankaran    LayerProp():mFlags(0){};
12216791f95b2570b9d48fa360875676e9c8559c0a1Naseer Ahmed};
12316791f95b2570b9d48fa360875676e9c8559c0a1Naseer Ahmed
12410d293b379d1b8bdaa383b67c05b187365c5d1afNaseer Ahmedstruct VsyncState {
12510d293b379d1b8bdaa383b67c05b187365c5d1afNaseer Ahmed    bool enable;
12610d293b379d1b8bdaa383b67c05b187365c5d1afNaseer Ahmed    bool fakevsync;
12710d293b379d1b8bdaa383b67c05b187365c5d1afNaseer Ahmed};
12810d293b379d1b8bdaa383b67c05b187365c5d1afNaseer Ahmed
129f0a7a20029deae76ea13d90099a09cc5e540f6baSaurabh Shahstruct BwcPM {
130f0a7a20029deae76ea13d90099a09cc5e540f6baSaurabh Shah    static void setBwc(hwc_context_t *ctx, const hwc_rect_t& crop,
131f0a7a20029deae76ea13d90099a09cc5e540f6baSaurabh Shah            const hwc_rect_t& dst, const int& transform,
132f0a7a20029deae76ea13d90099a09cc5e540f6baSaurabh Shah            ovutils::eMdpFlags& mdpFlags);
133f0a7a20029deae76ea13d90099a09cc5e540f6baSaurabh Shah};
134f0a7a20029deae76ea13d90099a09cc5e540f6baSaurabh Shah
13516791f95b2570b9d48fa360875676e9c8559c0a1Naseer Ahmed// LayerProp::flag values
136c85d6b7428ded41c74a9455f580f3ee8b451bbdeNaseer Ahmedenum {
13716791f95b2570b9d48fa360875676e9c8559c0a1Naseer Ahmed    HWC_MDPCOMP = 0x00000001,
13804a2afbd65e9f8bc580a637bf44bfc4e627edce0Naseer Ahmed    HWC_COPYBIT = 0x00000002,
139c85d6b7428ded41c74a9455f580f3ee8b451bbdeNaseer Ahmed};
140c85d6b7428ded41c74a9455f580f3ee8b451bbdeNaseer Ahmed
141f01e10a58786e9cb3200a757f65547868a29773dSushil Chauhan// HAL specific features
142f01e10a58786e9cb3200a757f65547868a29773dSushil Chauhanenum {
143905042d4ea8c4c736ea248b694d93ef2f59866d5Sushil Chauhan    HWC_COLOR_FILL = 0x00000008,
144f01e10a58786e9cb3200a757f65547868a29773dSushil Chauhan    HWC_FORMAT_RB_SWAP = 0x00000040,
145f01e10a58786e9cb3200a757f65547868a29773dSushil Chauhan};
146f01e10a58786e9cb3200a757f65547868a29773dSushil Chauhan
14743addde8368fa726b6be3ff2194eca4fc0741994Saurabh Shahclass LayerRotMap {
14843addde8368fa726b6be3ff2194eca4fc0741994Saurabh Shahpublic:
14943addde8368fa726b6be3ff2194eca4fc0741994Saurabh Shah    LayerRotMap() { reset(); }
15043addde8368fa726b6be3ff2194eca4fc0741994Saurabh Shah    enum { MAX_SESS = 3 };
15143addde8368fa726b6be3ff2194eca4fc0741994Saurabh Shah    void add(hwc_layer_1_t* layer, overlay::Rotator *rot);
152b746f91fe3184bf7c3b6475d247d3cc16cc74646Saurabh Shah    //Resets the mapping of layer to rotator
15343addde8368fa726b6be3ff2194eca4fc0741994Saurabh Shah    void reset();
154b746f91fe3184bf7c3b6475d247d3cc16cc74646Saurabh Shah    //Clears mappings and existing rotator fences
155b746f91fe3184bf7c3b6475d247d3cc16cc74646Saurabh Shah    //Intended to be used during errors
156b746f91fe3184bf7c3b6475d247d3cc16cc74646Saurabh Shah    void clear();
15743addde8368fa726b6be3ff2194eca4fc0741994Saurabh Shah    uint32_t getCount() const;
15843addde8368fa726b6be3ff2194eca4fc0741994Saurabh Shah    hwc_layer_1_t* getLayer(uint32_t index) const;
15943addde8368fa726b6be3ff2194eca4fc0741994Saurabh Shah    overlay::Rotator* getRot(uint32_t index) const;
16043addde8368fa726b6be3ff2194eca4fc0741994Saurabh Shah    void setReleaseFd(const int& fence);
16143addde8368fa726b6be3ff2194eca4fc0741994Saurabh Shahprivate:
16243addde8368fa726b6be3ff2194eca4fc0741994Saurabh Shah    hwc_layer_1_t* mLayer[MAX_SESS];
16343addde8368fa726b6be3ff2194eca4fc0741994Saurabh Shah    overlay::Rotator* mRot[MAX_SESS];
16443addde8368fa726b6be3ff2194eca4fc0741994Saurabh Shah    uint32_t mCount;
16543addde8368fa726b6be3ff2194eca4fc0741994Saurabh Shah};
16643addde8368fa726b6be3ff2194eca4fc0741994Saurabh Shah
16743addde8368fa726b6be3ff2194eca4fc0741994Saurabh Shahinline uint32_t LayerRotMap::getCount() const {
16843addde8368fa726b6be3ff2194eca4fc0741994Saurabh Shah    return mCount;
16943addde8368fa726b6be3ff2194eca4fc0741994Saurabh Shah}
17043addde8368fa726b6be3ff2194eca4fc0741994Saurabh Shah
17143addde8368fa726b6be3ff2194eca4fc0741994Saurabh Shahinline hwc_layer_1_t* LayerRotMap::getLayer(uint32_t index) const {
17243addde8368fa726b6be3ff2194eca4fc0741994Saurabh Shah    if(index >= mCount) return NULL;
17343addde8368fa726b6be3ff2194eca4fc0741994Saurabh Shah    return mLayer[index];
17443addde8368fa726b6be3ff2194eca4fc0741994Saurabh Shah}
17543addde8368fa726b6be3ff2194eca4fc0741994Saurabh Shah
17643addde8368fa726b6be3ff2194eca4fc0741994Saurabh Shahinline overlay::Rotator* LayerRotMap::getRot(uint32_t index) const {
17743addde8368fa726b6be3ff2194eca4fc0741994Saurabh Shah    if(index >= mCount) return NULL;
17843addde8368fa726b6be3ff2194eca4fc0741994Saurabh Shah    return mRot[index];
17943addde8368fa726b6be3ff2194eca4fc0741994Saurabh Shah}
18043addde8368fa726b6be3ff2194eca4fc0741994Saurabh Shah
1818f42508dc1e3bf24da360d5fbefd8c6574f82868Saurabh Shahinline hwc_rect_t integerizeSourceCrop(const hwc_frect_t& cropF) {
1828f42508dc1e3bf24da360d5fbefd8c6574f82868Saurabh Shah    hwc_rect_t cropI = {0};
1838f42508dc1e3bf24da360d5fbefd8c6574f82868Saurabh Shah    cropI.left = int(ceilf(cropF.left));
1848f42508dc1e3bf24da360d5fbefd8c6574f82868Saurabh Shah    cropI.top = int(ceilf(cropF.top));
1858f42508dc1e3bf24da360d5fbefd8c6574f82868Saurabh Shah    cropI.right = int(floorf(cropF.right));
1868f42508dc1e3bf24da360d5fbefd8c6574f82868Saurabh Shah    cropI.bottom = int(floorf(cropF.bottom));
1878f42508dc1e3bf24da360d5fbefd8c6574f82868Saurabh Shah    return cropI;
1888f42508dc1e3bf24da360d5fbefd8c6574f82868Saurabh Shah}
1898f42508dc1e3bf24da360d5fbefd8c6574f82868Saurabh Shah
19080864f9daffae7750e05efe41f63e029f5699511Naseer Ahmedinline bool isNonIntegralSourceCrop(const hwc_frect_t& cropF) {
19180864f9daffae7750e05efe41f63e029f5699511Naseer Ahmed    if(cropF.left - roundf(cropF.left)     ||
19280864f9daffae7750e05efe41f63e029f5699511Naseer Ahmed       cropF.top - roundf(cropF.top)       ||
19380864f9daffae7750e05efe41f63e029f5699511Naseer Ahmed       cropF.right - roundf(cropF.right)   ||
19480864f9daffae7750e05efe41f63e029f5699511Naseer Ahmed       cropF.bottom - roundf(cropF.bottom))
19580864f9daffae7750e05efe41f63e029f5699511Naseer Ahmed        return true;
19680864f9daffae7750e05efe41f63e029f5699511Naseer Ahmed    else
19780864f9daffae7750e05efe41f63e029f5699511Naseer Ahmed        return false;
19880864f9daffae7750e05efe41f63e029f5699511Naseer Ahmed}
19980864f9daffae7750e05efe41f63e029f5699511Naseer Ahmed
200befc466069680cb8a65b1f22ad44723d949128c8Naseer Ahmed// -----------------------------------------------------------------------------
201befc466069680cb8a65b1f22ad44723d949128c8Naseer Ahmed// Utility functions - implemented in hwc_utils.cpp
202660267c43bb3370ab49f4e95562c027171d8fb83Naseer Ahmedvoid dumpLayer(hwc_layer_1_t const* l);
2031e8bb08f0275c3acef37838114ab2b37ae814f13Ramkumar Radhakrishnan
2041e8bb08f0275c3acef37838114ab2b37ae814f13Ramkumar Radhakrishnan// Calculate viewframe for external/primary display from primary resolution and
2051e8bb08f0275c3acef37838114ab2b37ae814f13Ramkumar Radhakrishnan// primary device orientation
2061e8bb08f0275c3acef37838114ab2b37ae814f13Ramkumar Radhakrishnanhwc_rect_t calculateDisplayViewFrame(hwc_context_t *ctx, int dpy);
2071e8bb08f0275c3acef37838114ab2b37ae814f13Ramkumar Radhakrishnan
2086289b315a26aede5ac12b89e65d8024b1ed0dd05Saurabh Shahvoid setListStats(hwc_context_t *ctx, hwc_display_contents_1_t *list,
2092e449280f98f003bb5831c274fc07ab722ac1a94Saurabh Shah        int dpy);
210befc466069680cb8a65b1f22ad44723d949128c8Naseer Ahmedvoid initContext(hwc_context_t *ctx);
211befc466069680cb8a65b1f22ad44723d949128c8Naseer Ahmedvoid closeContext(hwc_context_t *ctx);
212ee7fc0347e52276d43413e91f31d72d6db99dcfbNaseer Ahmed//Crops source buffer against destination and FB boundaries
213ee7fc0347e52276d43413e91f31d72d6db99dcfbNaseer Ahmedvoid calculate_crop_rects(hwc_rect_t& crop, hwc_rect_t& dst,
214c8d563c4df56d25bf6ac6f38fb6703150458737aJeykumar Sankaran                         const hwc_rect_t& scissor, int orient);
21504a2afbd65e9f8bc580a637bf44bfc4e627edce0Naseer Ahmedvoid getNonWormholeRegion(hwc_display_contents_1_t* list,
21604a2afbd65e9f8bc580a637bf44bfc4e627edce0Naseer Ahmed                              hwc_rect_t& nwr);
217f9572cdbe3541d85522adea584f925671b375300Jeykumar Sankaranbool isSecuring(hwc_context_t* ctx, hwc_layer_1_t const* layer);
2186b90a0c838871669457f5f81361ec062feb7539dSushil Chauhanbool isSecureModePolicy(int mdpVersion);
2192e449280f98f003bb5831c274fc07ab722ac1a94Saurabh Shahbool isExternalActive(hwc_context_t* ctx);
22086c677669148a60b5d472fba407c2bfcdc0c05bePrabhanjan Kandulabool isAlphaScaled(hwc_layer_1_t const* layer);
22186c677669148a60b5d472fba407c2bfcdc0c05bePrabhanjan Kandulabool needsScaling(hwc_layer_1_t const* layer);
22286c677669148a60b5d472fba407c2bfcdc0c05bePrabhanjan Kandulabool isDownscaleRequired(hwc_layer_1_t const* layer);
22344625ff6484744d1307c0bb0d00e8c0ad90325ffSushil Chauhanbool needsScalingWithSplit(hwc_context_t* ctx, hwc_layer_1_t const* layer,
22444625ff6484744d1307c0bb0d00e8c0ad90325ffSushil Chauhan                           const int& dpy);
22544625ff6484744d1307c0bb0d00e8c0ad90325ffSushil Chauhanvoid sanitizeSourceCrop(hwc_rect_t& cropL, hwc_rect_t& cropR,
22644625ff6484744d1307c0bb0d00e8c0ad90325ffSushil Chauhan                        private_handle_t *hnd);
227a6b4d9570f8cc6d57f8b4f724c06e6ec6877b4a4Sravan Kumar D.V.Nbool isAlphaPresent(hwc_layer_1_t const* layer);
22855290a90518c4a8e2cc41d7bdb40918248a9920eNaseer Ahmedint hwc_vsync_control(hwc_context_t* ctx, int dpy, int enable);
22912a7b537b1e043a61b06db3d083c2372c11ef1f2Naseer Ahmedint getBlending(int blending);
230140ee6411106722dae886dc8c5b104b72d64dee0Ramkumar Radhakrishnanbool isGLESOnlyComp(hwc_context_t *ctx, const int& dpy);
231140ee6411106722dae886dc8c5b104b72d64dee0Ramkumar Radhakrishnanvoid reset_layer_prop(hwc_context_t* ctx, int dpy, int numAppLayers);
232a71a7ecd0323a16fe7728271474f8b7056c679d8Saurabh Shah
23393138887ec8fb0f232340c4fb852e3dbcb3542e4Naseer Ahmed//Helper function to dump logs
23493138887ec8fb0f232340c4fb852e3dbcb3542e4Naseer Ahmedvoid dumpsys_log(android::String8& buf, const char* fmt, ...);
23593138887ec8fb0f232340c4fb852e3dbcb3542e4Naseer Ahmed
23697c10c26c62d57a3fc31197fdd37d1bbfb8d1c2aRamkumar Radhakrishnanint getExtOrientation(hwc_context_t* ctx);
237f13681b96223de6b84461174aa08fe6d2959ced0Jeykumar Sankaranbool isValidRect(const hwc_rect_t& rect);
238b81222638c632a44d894b15590c9c90b1adc959eJeykumar Sankaranhwc_rect_t deductRect(const hwc_rect_t& rect1, const hwc_rect_t& rect2);
239f13681b96223de6b84461174aa08fe6d2959ced0Jeykumar Sankaranhwc_rect_t getIntersection(const hwc_rect_t& rect1, const hwc_rect_t& rect2);
240f13681b96223de6b84461174aa08fe6d2959ced0Jeykumar Sankaranhwc_rect_t getUnion(const hwc_rect_t& rect1, const hwc_rect_t& rect2);
24177846b8bdb582d03273ccaf9be58f8544659cd10Prabhanjan Kandulavoid optimizeLayerRects(hwc_context_t *ctx,
24236035afc0c366c26d7c330d004e7ded510c1f88cPrabhanjan Kandula        const hwc_display_contents_1_t *list, const int& dpy);
24336035afc0c366c26d7c330d004e7ded510c1f88cPrabhanjan Kandulabool areLayersIntersecting(const hwc_layer_1_t* layer1,
24436035afc0c366c26d7c330d004e7ded510c1f88cPrabhanjan Kandula        const hwc_layer_1_t* layer2);
24577846b8bdb582d03273ccaf9be58f8544659cd10Prabhanjan Kandula
246ba3d6165c19bcec9a56eb2db1b13f8f930c5651bRamkumar Radhakrishnan// returns true if Action safe dimensions are set and target supports Actionsafe
247ba3d6165c19bcec9a56eb2db1b13f8f930c5651bRamkumar Radhakrishnanbool isActionSafePresent(hwc_context_t *ctx, int dpy);
248ba3d6165c19bcec9a56eb2db1b13f8f930c5651bRamkumar Radhakrishnan
2490ae34e340382b0b3b767b844305db19e91257eddArun Kumar K.R/* Calculates the destination position based on the action safe rectangle */
25023421d260e81161813b0d8a14dac30d4d89ed380Arun Kumar K.Rvoid getActionSafePosition(hwc_context_t *ctx, int dpy, hwc_rect_t& dst);
2510ae34e340382b0b3b767b844305db19e91257eddArun Kumar K.R
25223421d260e81161813b0d8a14dac30d4d89ed380Arun Kumar K.Rvoid getAspectRatioPosition(int destWidth, int destHeight, int srcWidth,
25323421d260e81161813b0d8a14dac30d4d89ed380Arun Kumar K.R                                int srcHeight, hwc_rect_t& rect);
2543b9570a337a3115ad05dee3c1aa2ecc6f82f6ab1Arun Kumar K.R
25523421d260e81161813b0d8a14dac30d4d89ed380Arun Kumar K.Rvoid getAspectRatioPosition(hwc_context_t* ctx, int dpy, int extOrientation,
25623421d260e81161813b0d8a14dac30d4d89ed380Arun Kumar K.R                                hwc_rect_t& inRect, hwc_rect_t& outRect);
25723421d260e81161813b0d8a14dac30d4d89ed380Arun Kumar K.R
25823421d260e81161813b0d8a14dac30d4d89ed380Arun Kumar K.Rbool isPrimaryPortrait(hwc_context_t *ctx);
25923421d260e81161813b0d8a14dac30d4d89ed380Arun Kumar K.R
260fea63d61337f1efeb2d1c7a7a4fafe472611704cAmara Venkata Mastan Manoj Kumarbool isOrientationPortrait(hwc_context_t *ctx);
261fea63d61337f1efeb2d1c7a7a4fafe472611704cAmara Venkata Mastan Manoj Kumar
26223421d260e81161813b0d8a14dac30d4d89ed380Arun Kumar K.Rvoid calcExtDisplayPosition(hwc_context_t *ctx,
26397c10c26c62d57a3fc31197fdd37d1bbfb8d1c2aRamkumar Radhakrishnan                               private_handle_t *hnd,
264fea63d61337f1efeb2d1c7a7a4fafe472611704cAmara Venkata Mastan Manoj Kumar                               int dpy,
265fea63d61337f1efeb2d1c7a7a4fafe472611704cAmara Venkata Mastan Manoj Kumar                               hwc_rect_t& sourceCrop,
26697c10c26c62d57a3fc31197fdd37d1bbfb8d1c2aRamkumar Radhakrishnan                               hwc_rect_t& displayFrame,
26797c10c26c62d57a3fc31197fdd37d1bbfb8d1c2aRamkumar Radhakrishnan                               int& transform,
26897c10c26c62d57a3fc31197fdd37d1bbfb8d1c2aRamkumar Radhakrishnan                               ovutils::eTransform& orient);
26997c10c26c62d57a3fc31197fdd37d1bbfb8d1c2aRamkumar Radhakrishnan
270effbd25d502916fcdebadd1d2b83988559434e79Arun Kumar K.R// Returns the orientation that needs to be set on external for
271effbd25d502916fcdebadd1d2b83988559434e79Arun Kumar K.R// BufferMirrirMode(Sidesync)
272effbd25d502916fcdebadd1d2b83988559434e79Arun Kumar K.Rint getMirrorModeOrientation(hwc_context_t *ctx);
2733b9570a337a3115ad05dee3c1aa2ecc6f82f6ab1Arun Kumar K.R
274f39af541bb947658b15cda3602beeb0df8cf5c56Arun Kumar K.R// Handles wfd Pause and resume events
275f39af541bb947658b15cda3602beeb0df8cf5c56Arun Kumar K.Rvoid handle_pause(hwc_context_t *ctx, int dpy);
276f39af541bb947658b15cda3602beeb0df8cf5c56Arun Kumar K.Rvoid handle_resume(hwc_context_t *ctx, int dpy);
277f39af541bb947658b15cda3602beeb0df8cf5c56Arun Kumar K.R
278a2fbf2e17b5b50016125016f05cb0b52bea5ce5fSaurabh Shah//Close acquireFenceFds of all layers of incoming list
279a2fbf2e17b5b50016125016f05cb0b52bea5ce5fSaurabh Shahvoid closeAcquireFds(hwc_display_contents_1_t* list);
280a2fbf2e17b5b50016125016f05cb0b52bea5ce5fSaurabh Shah
28133147743328e88e7859db6c935072f11ca038448Kinjal Bhavsar//Sync point impl.
2824019c64ad8721cd9f3dc5c4e7be260a5f0706e34Arun Kumar K.Rint hwc_sync(hwc_context_t *ctx, hwc_display_contents_1_t* list, int dpy,
283327b2ba85538669304a50d0fb6cc2f6aab7aaf3bSaurabh Shah        int fd);
284327b2ba85538669304a50d0fb6cc2f6aab7aaf3bSaurabh Shah
285327b2ba85538669304a50d0fb6cc2f6aab7aaf3bSaurabh Shah//Sets appropriate mdp flags for a layer.
286327b2ba85538669304a50d0fb6cc2f6aab7aaf3bSaurabh Shahvoid setMdpFlags(hwc_layer_1_t *layer,
287327b2ba85538669304a50d0fb6cc2f6aab7aaf3bSaurabh Shah        ovutils::eMdpFlags &mdpFlags,
2883e76f19cb2c0441315ebe54110f7b452d2932f52Ramkumar Radhakrishnan        int rotDownscale, int transform);
289327b2ba85538669304a50d0fb6cc2f6aab7aaf3bSaurabh Shah
2905365726ef260406513c4787b6ed253eda754370cPrabhanjan Kandulaint configRotator(overlay::Rotator *rot, ovutils::Whf& whf,
291e2f07405d2d04aaf5577080761cd2b11a9e3c736Sushil Chauhan        hwc_rect_t& crop, const ovutils::eMdpFlags& mdpFlags,
2923b9570a337a3115ad05dee3c1aa2ecc6f82f6ab1Arun Kumar K.R        const ovutils::eTransform& orient, const int& downscale);
2933b9570a337a3115ad05dee3c1aa2ecc6f82f6ab1Arun Kumar K.R
2943b9570a337a3115ad05dee3c1aa2ecc6f82f6ab1Arun Kumar K.Rint configMdp(overlay::Overlay *ov, const ovutils::PipeArgs& parg,
2953b9570a337a3115ad05dee3c1aa2ecc6f82f6ab1Arun Kumar K.R        const ovutils::eTransform& orient, const hwc_rect_t& crop,
2963b9570a337a3115ad05dee3c1aa2ecc6f82f6ab1Arun Kumar K.R        const hwc_rect_t& pos, const MetaData_t *metadata,
2973b9570a337a3115ad05dee3c1aa2ecc6f82f6ab1Arun Kumar K.R        const ovutils::eDest& dest);
2983b9570a337a3115ad05dee3c1aa2ecc6f82f6ab1Arun Kumar K.R
29908cbd816733f17c957411ae915f2543afea70b67Sushil Chauhanint configColorLayer(hwc_context_t *ctx, hwc_layer_1_t *layer, const int& dpy,
30008cbd816733f17c957411ae915f2543afea70b67Sushil Chauhan        ovutils::eMdpFlags& mdpFlags, ovutils::eZorder& z,
30108cbd816733f17c957411ae915f2543afea70b67Sushil Chauhan        ovutils::eIsFg& isFg, const ovutils::eDest& dest);
30208cbd816733f17c957411ae915f2543afea70b67Sushil Chauhan
3033b9570a337a3115ad05dee3c1aa2ecc6f82f6ab1Arun Kumar K.Rvoid updateSource(ovutils::eTransform& orient, ovutils::Whf& whf,
3043b9570a337a3115ad05dee3c1aa2ecc6f82f6ab1Arun Kumar K.R        hwc_rect_t& crop);
3053b9570a337a3115ad05dee3c1aa2ecc6f82f6ab1Arun Kumar K.R
306327b2ba85538669304a50d0fb6cc2f6aab7aaf3bSaurabh Shah//Routine to configure low resolution panels (<= 2048 width)
307f8c680dacf0a357ea1f56542fb329bbc9749b6b5Saurabh Shahint configureNonSplit(hwc_context_t *ctx, hwc_layer_1_t *layer, const int& dpy,
308a0e87cbc523323604e8fb7cb5526f410a1ed26dfRamkumar Radhakrishnan        ovutils::eMdpFlags& mdpFlags, ovutils::eZorder& z,
309a0e87cbc523323604e8fb7cb5526f410a1ed26dfRamkumar Radhakrishnan        ovutils::eIsFg& isFg, const ovutils::eDest& dest,
310327b2ba85538669304a50d0fb6cc2f6aab7aaf3bSaurabh Shah        overlay::Rotator **rot);
311327b2ba85538669304a50d0fb6cc2f6aab7aaf3bSaurabh Shah
312327b2ba85538669304a50d0fb6cc2f6aab7aaf3bSaurabh Shah//Routine to configure high resolution panels (> 2048 width)
313f8c680dacf0a357ea1f56542fb329bbc9749b6b5Saurabh Shahint configureSplit(hwc_context_t *ctx, hwc_layer_1_t *layer, const int& dpy,
314a0e87cbc523323604e8fb7cb5526f410a1ed26dfRamkumar Radhakrishnan        ovutils::eMdpFlags& mdpFlags, ovutils::eZorder& z,
315a0e87cbc523323604e8fb7cb5526f410a1ed26dfRamkumar Radhakrishnan        ovutils::eIsFg& isFg, const ovutils::eDest& lDest,
316327b2ba85538669304a50d0fb6cc2f6aab7aaf3bSaurabh Shah        const ovutils::eDest& rDest, overlay::Rotator **rot);
31733147743328e88e7859db6c935072f11ca038448Kinjal Bhavsar
31815c02b94dcc7d61d4af05ac32b3c4db3b3b8a1e6radhakrishna//Routine to split and configure high resolution YUV layer (> 2048 width)
31915c02b94dcc7d61d4af05ac32b3c4db3b3b8a1e6radhakrishnaint configureSourceSplit(hwc_context_t *ctx, hwc_layer_1_t *layer,
32015c02b94dcc7d61d4af05ac32b3c4db3b3b8a1e6radhakrishna        const int& dpy,
32115c02b94dcc7d61d4af05ac32b3c4db3b3b8a1e6radhakrishna        ovutils::eMdpFlags& mdpFlags, ovutils::eZorder& z,
32215c02b94dcc7d61d4af05ac32b3c4db3b3b8a1e6radhakrishna        ovutils::eIsFg& isFg, const ovutils::eDest& lDest,
32315c02b94dcc7d61d4af05ac32b3c4db3b3b8a1e6radhakrishna        const ovutils::eDest& rDest, overlay::Rotator **rot);
32415c02b94dcc7d61d4af05ac32b3c4db3b3b8a1e6radhakrishna
325e188278e86ebb2f7f1ed3762855f15062b7f9d03Saurabh Shah//On certain targets DMA pipes are used for rotation and they won't be available
326e188278e86ebb2f7f1ed3762855f15062b7f9d03Saurabh Shah//for line operations. On a per-target basis we can restrict certain use cases
327e188278e86ebb2f7f1ed3762855f15062b7f9d03Saurabh Shah//from using rotator, since we know before-hand that such scenarios can lead to
328e188278e86ebb2f7f1ed3762855f15062b7f9d03Saurabh Shah//extreme unavailability of pipes. This can also be done via hybrid calculations
329e188278e86ebb2f7f1ed3762855f15062b7f9d03Saurabh Shah//also involving many more variables like number of write-back interfaces etc,
330e188278e86ebb2f7f1ed3762855f15062b7f9d03Saurabh Shah//but the variety of scenarios is too high to warrant that.
33186adeda0140053bfc618f5fc087d30c7221459daAmara Venkata Mastan Manoj Kumarbool canUseRotator(hwc_context_t *ctx, int dpy);
332e188278e86ebb2f7f1ed3762855f15062b7f9d03Saurabh Shah
3339640e380d8f815ef7ca71c1fdf23eb6f7b30db1eSaurabh Shahint getLeftSplit(hwc_context_t *ctx, const int& dpy);
3349640e380d8f815ef7ca71c1fdf23eb6f7b30db1eSaurabh Shah
335f8c680dacf0a357ea1f56542fb329bbc9749b6b5Saurabh Shahbool isDisplaySplit(hwc_context_t* ctx, int dpy);
336f8c680dacf0a357ea1f56542fb329bbc9749b6b5Saurabh Shah
337befc466069680cb8a65b1f22ad44723d949128c8Naseer Ahmed// Inline utility functions
338660267c43bb3370ab49f4e95562c027171d8fb83Naseer Ahmedstatic inline bool isSkipLayer(const hwc_layer_1_t* l) {
339befc466069680cb8a65b1f22ad44723d949128c8Naseer Ahmed    return (UNLIKELY(l && (l->flags & HWC_SKIP_LAYER)));
340befc466069680cb8a65b1f22ad44723d949128c8Naseer Ahmed}
341befc466069680cb8a65b1f22ad44723d949128c8Naseer Ahmed
342befc466069680cb8a65b1f22ad44723d949128c8Naseer Ahmed// Returns true if the buffer is yuv
343befc466069680cb8a65b1f22ad44723d949128c8Naseer Ahmedstatic inline bool isYuvBuffer(const private_handle_t* hnd) {
344befc466069680cb8a65b1f22ad44723d949128c8Naseer Ahmed    return (hnd && (hnd->bufferType == BUFFER_TYPE_VIDEO));
345befc466069680cb8a65b1f22ad44723d949128c8Naseer Ahmed}
346befc466069680cb8a65b1f22ad44723d949128c8Naseer Ahmed
34715c02b94dcc7d61d4af05ac32b3c4db3b3b8a1e6radhakrishna// Returns true if the buffer is yuv
34815c02b94dcc7d61d4af05ac32b3c4db3b3b8a1e6radhakrishnastatic inline bool is4kx2kYuvBuffer(const private_handle_t* hnd) {
34915c02b94dcc7d61d4af05ac32b3c4db3b3b8a1e6radhakrishna    return (hnd && (hnd->bufferType == BUFFER_TYPE_VIDEO) &&
35015c02b94dcc7d61d4af05ac32b3c4db3b3b8a1e6radhakrishna            (hnd->width > 2048));
35115c02b94dcc7d61d4af05ac32b3c4db3b3b8a1e6radhakrishna}
35215c02b94dcc7d61d4af05ac32b3c4db3b3b8a1e6radhakrishna
353ed68f0b13f56426735e7897519aa1c43072ceb90Saurabh Shah// Returns true if the buffer is secure
354ed68f0b13f56426735e7897519aa1c43072ceb90Saurabh Shahstatic inline bool isSecureBuffer(const private_handle_t* hnd) {
355ed68f0b13f56426735e7897519aa1c43072ceb90Saurabh Shah    return (hnd && (private_handle_t::PRIV_FLAGS_SECURE_BUFFER & hnd->flags));
356ed68f0b13f56426735e7897519aa1c43072ceb90Saurabh Shah}
357c38cdae859e0ee12ad3284a308eaeef9d2708c74Manoj Kumar AVM
358c38cdae859e0ee12ad3284a308eaeef9d2708c74Manoj Kumar AVMstatic inline bool isTileRendered(const private_handle_t* hnd) {
359c38cdae859e0ee12ad3284a308eaeef9d2708c74Manoj Kumar AVM    return (hnd && (private_handle_t::PRIV_FLAGS_TILE_RENDERED & hnd->flags));
360c38cdae859e0ee12ad3284a308eaeef9d2708c74Manoj Kumar AVM}
361c38cdae859e0ee12ad3284a308eaeef9d2708c74Manoj Kumar AVM
362befc466069680cb8a65b1f22ad44723d949128c8Naseer Ahmed//Return true if buffer is marked locked
363befc466069680cb8a65b1f22ad44723d949128c8Naseer Ahmedstatic inline bool isBufferLocked(const private_handle_t* hnd) {
364befc466069680cb8a65b1f22ad44723d949128c8Naseer Ahmed    return (hnd && (private_handle_t::PRIV_FLAGS_HWC_LOCK & hnd->flags));
365befc466069680cb8a65b1f22ad44723d949128c8Naseer Ahmed}
366bd4704d4b447bd4aa59e4894d68a7162ce4f99fdNaseer Ahmed
3675d0935531842ab9cf01775a77e92f204e6d40971Naseer Ahmed//Return true if buffer is for external display only
3685d0935531842ab9cf01775a77e92f204e6d40971Naseer Ahmedstatic inline bool isExtOnly(const private_handle_t* hnd) {
3695d0935531842ab9cf01775a77e92f204e6d40971Naseer Ahmed    return (hnd && (hnd->flags & private_handle_t::PRIV_FLAGS_EXTERNAL_ONLY));
3705d0935531842ab9cf01775a77e92f204e6d40971Naseer Ahmed}
3715d0935531842ab9cf01775a77e92f204e6d40971Naseer Ahmed
3725d0935531842ab9cf01775a77e92f204e6d40971Naseer Ahmed//Return true if buffer is for external display only with a BLOCK flag.
3735d0935531842ab9cf01775a77e92f204e6d40971Naseer Ahmedstatic inline bool isExtBlock(const private_handle_t* hnd) {
3745d0935531842ab9cf01775a77e92f204e6d40971Naseer Ahmed    return (hnd && (hnd->flags & private_handle_t::PRIV_FLAGS_EXTERNAL_BLOCK));
3755d0935531842ab9cf01775a77e92f204e6d40971Naseer Ahmed}
3765d0935531842ab9cf01775a77e92f204e6d40971Naseer Ahmed
3775d0935531842ab9cf01775a77e92f204e6d40971Naseer Ahmed//Return true if buffer is for external display only with a Close Caption flag.
3785d0935531842ab9cf01775a77e92f204e6d40971Naseer Ahmedstatic inline bool isExtCC(const private_handle_t* hnd) {
3795d0935531842ab9cf01775a77e92f204e6d40971Naseer Ahmed    return (hnd && (hnd->flags & private_handle_t::PRIV_FLAGS_EXTERNAL_CC));
3805d0935531842ab9cf01775a77e92f204e6d40971Naseer Ahmed}
3815d0935531842ab9cf01775a77e92f204e6d40971Naseer Ahmed
3821b28b60e15c27fee703a16fbd1e42e3b41b031fdRamkumar Radhakrishnan//Return true if the buffer is intended for Secure Display
3831b28b60e15c27fee703a16fbd1e42e3b41b031fdRamkumar Radhakrishnanstatic inline bool isSecureDisplayBuffer(const private_handle_t* hnd) {
3841b28b60e15c27fee703a16fbd1e42e3b41b031fdRamkumar Radhakrishnan    return (hnd && (hnd->flags & private_handle_t::PRIV_FLAGS_SECURE_DISPLAY));
3851b28b60e15c27fee703a16fbd1e42e3b41b031fdRamkumar Radhakrishnan}
3861b28b60e15c27fee703a16fbd1e42e3b41b031fdRamkumar Radhakrishnan
3870d530c8c754e9ccb1f122ee2818d9d1d47d7d4daRamkumar Radhakrishnanstatic inline int getWidth(const private_handle_t* hnd) {
3880d530c8c754e9ccb1f122ee2818d9d1d47d7d4daRamkumar Radhakrishnan    if(isYuvBuffer(hnd)) {
3890d530c8c754e9ccb1f122ee2818d9d1d47d7d4daRamkumar Radhakrishnan        MetaData_t *metadata = (MetaData_t *)hnd->base_metadata;
3900d530c8c754e9ccb1f122ee2818d9d1d47d7d4daRamkumar Radhakrishnan        if(metadata && metadata->operation & UPDATE_BUFFER_GEOMETRY) {
3910d530c8c754e9ccb1f122ee2818d9d1d47d7d4daRamkumar Radhakrishnan            return metadata->bufferDim.sliceWidth;
3920d530c8c754e9ccb1f122ee2818d9d1d47d7d4daRamkumar Radhakrishnan        }
3930d530c8c754e9ccb1f122ee2818d9d1d47d7d4daRamkumar Radhakrishnan    }
3940d530c8c754e9ccb1f122ee2818d9d1d47d7d4daRamkumar Radhakrishnan    return hnd->width;
3950d530c8c754e9ccb1f122ee2818d9d1d47d7d4daRamkumar Radhakrishnan}
3960d530c8c754e9ccb1f122ee2818d9d1d47d7d4daRamkumar Radhakrishnan
3970d530c8c754e9ccb1f122ee2818d9d1d47d7d4daRamkumar Radhakrishnanstatic inline int getHeight(const private_handle_t* hnd) {
3980d530c8c754e9ccb1f122ee2818d9d1d47d7d4daRamkumar Radhakrishnan    if(isYuvBuffer(hnd)) {
3990d530c8c754e9ccb1f122ee2818d9d1d47d7d4daRamkumar Radhakrishnan        MetaData_t *metadata = (MetaData_t *)hnd->base_metadata;
4000d530c8c754e9ccb1f122ee2818d9d1d47d7d4daRamkumar Radhakrishnan        if(metadata && metadata->operation & UPDATE_BUFFER_GEOMETRY) {
4010d530c8c754e9ccb1f122ee2818d9d1d47d7d4daRamkumar Radhakrishnan            return metadata->bufferDim.sliceHeight;
4020d530c8c754e9ccb1f122ee2818d9d1d47d7d4daRamkumar Radhakrishnan        }
4030d530c8c754e9ccb1f122ee2818d9d1d47d7d4daRamkumar Radhakrishnan    }
4040d530c8c754e9ccb1f122ee2818d9d1d47d7d4daRamkumar Radhakrishnan    return hnd->height;
4050d530c8c754e9ccb1f122ee2818d9d1d47d7d4daRamkumar Radhakrishnan}
4060d530c8c754e9ccb1f122ee2818d9d1d47d7d4daRamkumar Radhakrishnan
40704a2afbd65e9f8bc580a637bf44bfc4e627edce0Naseer Ahmedtemplate<typename T> inline T max(T a, T b) { return (a > b) ? a : b; }
40804a2afbd65e9f8bc580a637bf44bfc4e627edce0Naseer Ahmedtemplate<typename T> inline T min(T a, T b) { return (a < b) ? a : b; }
40904a2afbd65e9f8bc580a637bf44bfc4e627edce0Naseer Ahmed
4101589dee5c27293d278d3e549af8a4bda27e080f8Naseer Ahmed// Initialize uevent thread
4111589dee5c27293d278d3e549af8a4bda27e080f8Naseer Ahmedvoid init_uevent_thread(hwc_context_t* ctx);
412aff82051a79fbaf752d3769667d34828cee2841dNaseer Ahmed// Initialize vsync thread
413aff82051a79fbaf752d3769667d34828cee2841dNaseer Ahmedvoid init_vsync_thread(hwc_context_t* ctx);
414befc466069680cb8a65b1f22ad44723d949128c8Naseer Ahmed
415660267c43bb3370ab49f4e95562c027171d8fb83Naseer Ahmedinline void getLayerResolution(const hwc_layer_1_t* layer,
41612a7b537b1e043a61b06db3d083c2372c11ef1f2Naseer Ahmed                               int& width, int& height) {
417c85d6b7428ded41c74a9455f580f3ee8b451bbdeNaseer Ahmed    hwc_rect_t displayFrame  = layer->displayFrame;
418c85d6b7428ded41c74a9455f580f3ee8b451bbdeNaseer Ahmed    width = displayFrame.right - displayFrame.left;
419c85d6b7428ded41c74a9455f580f3ee8b451bbdeNaseer Ahmed    height = displayFrame.bottom - displayFrame.top;
420c85d6b7428ded41c74a9455f580f3ee8b451bbdeNaseer Ahmed}
4212e449280f98f003bb5831c274fc07ab722ac1a94Saurabh Shah
4222e449280f98f003bb5831c274fc07ab722ac1a94Saurabh Shahstatic inline int openFb(int dpy) {
4232e449280f98f003bb5831c274fc07ab722ac1a94Saurabh Shah    int fd = -1;
4242e449280f98f003bb5831c274fc07ab722ac1a94Saurabh Shah    const char *devtmpl = "/dev/graphics/fb%u";
4252e449280f98f003bb5831c274fc07ab722ac1a94Saurabh Shah    char name[64] = {0};
4262e449280f98f003bb5831c274fc07ab722ac1a94Saurabh Shah    snprintf(name, 64, devtmpl, dpy);
4272e449280f98f003bb5831c274fc07ab722ac1a94Saurabh Shah    fd = open(name, O_RDWR);
4282e449280f98f003bb5831c274fc07ab722ac1a94Saurabh Shah    return fd;
4292e449280f98f003bb5831c274fc07ab722ac1a94Saurabh Shah}
4302e449280f98f003bb5831c274fc07ab722ac1a94Saurabh Shah
4319a678455a788dc76a43ad93459ae6a792f0fd114Saurabh Shahtemplate <class T>
4329a678455a788dc76a43ad93459ae6a792f0fd114Saurabh Shahinline void swap(T& a, T& b) {
4339a678455a788dc76a43ad93459ae6a792f0fd114Saurabh Shah    T tmp = a;
4349a678455a788dc76a43ad93459ae6a792f0fd114Saurabh Shah    a = b;
4359a678455a788dc76a43ad93459ae6a792f0fd114Saurabh Shah    b = tmp;
4369a678455a788dc76a43ad93459ae6a792f0fd114Saurabh Shah}
4379a678455a788dc76a43ad93459ae6a792f0fd114Saurabh Shah
438ee7fc0347e52276d43413e91f31d72d6db99dcfbNaseer Ahmed}; //qhwc namespace
439befc466069680cb8a65b1f22ad44723d949128c8Naseer Ahmed
440c3da4cc59d8e21b5905bd0ee3adf556dfe62b0e1Ramkumar Radhakrishnanenum eAnimationState{
441c3da4cc59d8e21b5905bd0ee3adf556dfe62b0e1Ramkumar Radhakrishnan    ANIMATION_STOPPED,
442c3da4cc59d8e21b5905bd0ee3adf556dfe62b0e1Ramkumar Radhakrishnan    ANIMATION_STARTED,
443c3da4cc59d8e21b5905bd0ee3adf556dfe62b0e1Ramkumar Radhakrishnan};
444c3da4cc59d8e21b5905bd0ee3adf556dfe62b0e1Ramkumar Radhakrishnan
445befc466069680cb8a65b1f22ad44723d949128c8Naseer Ahmed// -----------------------------------------------------------------------------
446befc466069680cb8a65b1f22ad44723d949128c8Naseer Ahmed// HWC context
447befc466069680cb8a65b1f22ad44723d949128c8Naseer Ahmed// This structure contains overall state
448befc466069680cb8a65b1f22ad44723d949128c8Naseer Ahmedstruct hwc_context_t {
449660267c43bb3370ab49f4e95562c027171d8fb83Naseer Ahmed    hwc_composer_device_1_t device;
450359c544e1ca5ad76be326d9ee809e7bee51f94b4Jesse Hall    const hwc_procs_t* proc;
4514019c64ad8721cd9f3dc5c4e7be260a5f0706e34Arun Kumar K.R
4524019c64ad8721cd9f3dc5c4e7be260a5f0706e34Arun Kumar K.R    //CopyBit objects
4530df43c5a5da262ea6716f7614019fc710562028bAmara Venkata Mastan Manoj Kumar    qhwc::CopyBit *mCopyBit[HWC_NUM_DISPLAY_TYPES];
4544019c64ad8721cd9f3dc5c4e7be260a5f0706e34Arun Kumar K.R
455befc466069680cb8a65b1f22ad44723d949128c8Naseer Ahmed    //Overlay object - NULL for non overlay devices
45647377987cc4eef72ee3b0cdced8c3a15038b39ebNaseer Ahmed    overlay::Overlay *mOverlay;
457327b2ba85538669304a50d0fb6cc2f6aab7aaf3bSaurabh Shah    //Holds a few rot objects
458327b2ba85538669304a50d0fb6cc2f6aab7aaf3bSaurabh Shah    overlay::RotMgr *mRotMgr;
459640cb9421639c13248aeb30c3496cdfaec6d894cSaurabh Shah
460640cb9421639c13248aeb30c3496cdfaec6d894cSaurabh Shah    //Primary and external FB updater
4610df43c5a5da262ea6716f7614019fc710562028bAmara Venkata Mastan Manoj Kumar    qhwc::IFBUpdate *mFBUpdate[HWC_NUM_DISPLAY_TYPES];
462ccf943e44f9e9d615a6019459625148830039f8dNaseer Ahmed    // External display related information
4631589dee5c27293d278d3e549af8a4bda27e080f8Naseer Ahmed    qhwc::ExternalDisplay *mExtDisplay;
464361900d9a618d2c4d2276a10ca76919214f6759fJeykumar Sankaran    qhwc::VirtualDisplay *mVirtualDisplay;
465b3c6e058ce1dbc689f27e7d7acbf1529d37307d8Naseer Ahmed    qhwc::MDPInfo mMDP;
46610d293b379d1b8bdaa383b67c05b187365c5d1afNaseer Ahmed    qhwc::VsyncState vstate;
4670df43c5a5da262ea6716f7614019fc710562028bAmara Venkata Mastan Manoj Kumar    qhwc::DisplayAttributes dpyAttr[HWC_NUM_DISPLAY_TYPES];
4680df43c5a5da262ea6716f7614019fc710562028bAmara Venkata Mastan Manoj Kumar    qhwc::ListStats listStats[HWC_NUM_DISPLAY_TYPES];
4690df43c5a5da262ea6716f7614019fc710562028bAmara Venkata Mastan Manoj Kumar    qhwc::LayerProp *layerProp[HWC_NUM_DISPLAY_TYPES];
4700df43c5a5da262ea6716f7614019fc710562028bAmara Venkata Mastan Manoj Kumar    qhwc::MDPComp *mMDPComp[HWC_NUM_DISPLAY_TYPES];
4710df43c5a5da262ea6716f7614019fc710562028bAmara Venkata Mastan Manoj Kumar    qhwc::HwcDebug *mHwcDebug[HWC_NUM_DISPLAY_TYPES];
472456d555b1dc25dd1891ab7e38494d057b6bdf82eRamkumar Radhakrishnan    hwc_rect_t mViewFrame[HWC_NUM_DISPLAY_TYPES];
473f1c9077e23f3fd814c27445ad73f6967a1ce5d9eSaurabh Shah    qhwc::AssertiveDisplay *mAD;
474c439b604bcd6441e3706fdcaa5084ec58cbaf16dNaseer Ahmed    qhwc::VPUClient *mVPUClient;
475c3da4cc59d8e21b5905bd0ee3adf556dfe62b0e1Ramkumar Radhakrishnan    eAnimationState mAnimationState[HWC_NUM_DISPLAY_TYPES];
476140ee6411106722dae886dc8c5b104b72d64dee0Ramkumar Radhakrishnan    qhwc::HWCVirtualBase *mHWCVirtual;
4779f0b36a26d1c37ad0d31e59136b1e5d6f4d7efdeNaseer Ahmed
478c3da4cc59d8e21b5905bd0ee3adf556dfe62b0e1Ramkumar Radhakrishnan    // stores the primary device orientation
479a0e87cbc523323604e8fb7cb5526f410a1ed26dfRamkumar Radhakrishnan    int deviceOrientation;
480bbee5b1c3475b630caa5061fbf535f87f21743f7Saurabh Shah    //Securing in progress indicator
481bbee5b1c3475b630caa5061fbf535f87f21743f7Saurabh Shah    bool mSecuring;
482361900d9a618d2c4d2276a10ca76919214f6759fJeykumar Sankaran    //WFD on proprietary stack
483361900d9a618d2c4d2276a10ca76919214f6759fJeykumar Sankaran    bool mVirtualonExtActive;
484bbee5b1c3475b630caa5061fbf535f87f21743f7Saurabh Shah    //Display in secure mode indicator
485bbee5b1c3475b630caa5061fbf535f87f21743f7Saurabh Shah    bool mSecureMode;
4861a050829890735bc5a936ad65bf9cad80295306bSaurabh Shah    //Lock to protect drawing data structures
4871a050829890735bc5a936ad65bf9cad80295306bSaurabh Shah    mutable Locker mDrawLock;
488586aedccc2eaa76923bc22a3325fc2e4eff415e2Saurabh Shah    //Drawing round when we use GPU
489586aedccc2eaa76923bc22a3325fc2e4eff415e2Saurabh Shah    bool isPaddingRound;
4903b9570a337a3115ad05dee3c1aa2ecc6f82f6ab1Arun Kumar K.R    // External Orientation
4913b9570a337a3115ad05dee3c1aa2ecc6f82f6ab1Arun Kumar K.R    int mExtOrientation;
49256d570f1d7eb34ab0db968298efb8e75b849c893Saurabh Shah    //Flags the transition of a video session
49356d570f1d7eb34ab0db968298efb8e75b849c893Saurabh Shah    bool mVideoTransFlag;
494effbd25d502916fcdebadd1d2b83988559434e79Arun Kumar K.R
495effbd25d502916fcdebadd1d2b83988559434e79Arun Kumar K.R    //Used for SideSync feature
496effbd25d502916fcdebadd1d2b83988559434e79Arun Kumar K.R    //which overrides the mExtOrientation
497effbd25d502916fcdebadd1d2b83988559434e79Arun Kumar K.R    bool mBufferMirrorMode;
498effbd25d502916fcdebadd1d2b83988559434e79Arun Kumar K.R
4990df43c5a5da262ea6716f7614019fc710562028bAmara Venkata Mastan Manoj Kumar    qhwc::LayerRotMap *mLayerRotMap[HWC_NUM_DISPLAY_TYPES];
50027ed7a681887d87449209c0d3bab4fac6aae8e3cVeera Sankaran
50127ed7a681887d87449209c0d3bab4fac6aae8e3cVeera Sankaran    // Panel reset flag will be set if BTA check fails
50227ed7a681887d87449209c0d3bab4fac6aae8e3cVeera Sankaran    bool mPanelResetStatus;
503befc466069680cb8a65b1f22ad44723d949128c8Naseer Ahmed};
504befc466069680cb8a65b1f22ad44723d949128c8Naseer Ahmed
505327b2ba85538669304a50d0fb6cc2f6aab7aaf3bSaurabh Shahnamespace qhwc {
506c18b3a0ef41fe474fe37e2e1833ef1bb11c85b11Saurabh Shahstatic inline bool isSkipPresent (hwc_context_t *ctx, int dpy) {
507c18b3a0ef41fe474fe37e2e1833ef1bb11c85b11Saurabh Shah    return  ctx->listStats[dpy].skipCount;
508c18b3a0ef41fe474fe37e2e1833ef1bb11c85b11Saurabh Shah}
509c18b3a0ef41fe474fe37e2e1833ef1bb11c85b11Saurabh Shah
510c18b3a0ef41fe474fe37e2e1833ef1bb11c85b11Saurabh Shahstatic inline bool isYuvPresent (hwc_context_t *ctx, int dpy) {
511c18b3a0ef41fe474fe37e2e1833ef1bb11c85b11Saurabh Shah    return  ctx->listStats[dpy].yuvCount;
512c18b3a0ef41fe474fe37e2e1833ef1bb11c85b11Saurabh Shah}
513efab1d5273ce9a284e306f2607e501410cfbc8b9Saurabh Shah
514efab1d5273ce9a284e306f2607e501410cfbc8b9Saurabh Shahstatic inline bool has90Transform(hwc_layer_1_t *layer) {
51508cbd816733f17c957411ae915f2543afea70b67Sushil Chauhan    return ((layer->transform & HWC_TRANSFORM_ROT_90) &&
51608cbd816733f17c957411ae915f2543afea70b67Sushil Chauhan            !(layer->flags & HWC_COLOR_FILL));
517efab1d5273ce9a284e306f2607e501410cfbc8b9Saurabh Shah}
518efab1d5273ce9a284e306f2607e501410cfbc8b9Saurabh Shah
51994f50bebdee0b3ab9deb6d51426c542407ced5fdSaurabh Shahinline bool isSecurePresent(hwc_context_t *ctx, int dpy) {
52094f50bebdee0b3ab9deb6d51426c542407ced5fdSaurabh Shah    return ctx->listStats[dpy].isSecurePresent;
52194f50bebdee0b3ab9deb6d51426c542407ced5fdSaurabh Shah}
52294f50bebdee0b3ab9deb6d51426c542407ced5fdSaurabh Shah
523140ee6411106722dae886dc8c5b104b72d64dee0Ramkumar Radhakrishnanstatic inline bool isSecondaryConfiguring(hwc_context_t* ctx) {
524140ee6411106722dae886dc8c5b104b72d64dee0Ramkumar Radhakrishnan    return (ctx->dpyAttr[HWC_DISPLAY_EXTERNAL].isConfiguring ||
525140ee6411106722dae886dc8c5b104b72d64dee0Ramkumar Radhakrishnan            ctx->dpyAttr[HWC_DISPLAY_VIRTUAL].isConfiguring);
526140ee6411106722dae886dc8c5b104b72d64dee0Ramkumar Radhakrishnan}
527140ee6411106722dae886dc8c5b104b72d64dee0Ramkumar Radhakrishnan
528140ee6411106722dae886dc8c5b104b72d64dee0Ramkumar Radhakrishnanstatic inline bool isSecondaryConnected(hwc_context_t* ctx) {
529140ee6411106722dae886dc8c5b104b72d64dee0Ramkumar Radhakrishnan    return (ctx->dpyAttr[HWC_DISPLAY_EXTERNAL].connected ||
530140ee6411106722dae886dc8c5b104b72d64dee0Ramkumar Radhakrishnan            ctx->dpyAttr[HWC_DISPLAY_VIRTUAL].connected);
531140ee6411106722dae886dc8c5b104b72d64dee0Ramkumar Radhakrishnan}
532140ee6411106722dae886dc8c5b104b72d64dee0Ramkumar Radhakrishnan
533327b2ba85538669304a50d0fb6cc2f6aab7aaf3bSaurabh Shah};
534c18b3a0ef41fe474fe37e2e1833ef1bb11c85b11Saurabh Shah
535befc466069680cb8a65b1f22ad44723d949128c8Naseer Ahmed#endif //HWC_UTILS_H
536