Naseer Ahmed | 78c952e | 2013-11-25 18:12:23 -0500 | [diff] [blame] | 1 | /* |
| 2 | * Copyright (c) 2013 The Linux Foundation. All rights reserved. |
| 3 | * |
| 4 | * Redistribution and use in source and binary forms, with or without |
| 5 | * modification, are permitted provided that the following conditions are |
| 6 | * met: |
| 7 | * * Redistributions of source code must retain the above copyright |
| 8 | * notice, this list of conditions and the following disclaimer. |
| 9 | * * Redistributions in binary form must reproduce the above |
| 10 | * copyright notice, this list of conditions and the following |
| 11 | * disclaimer in the documentation and/or other materials provided |
| 12 | * with the distribution. |
| 13 | * * Neither the name of The Linux Foundation. nor the names of its |
| 14 | * contributors may be used to endorse or promote products derived |
| 15 | * from this software without specific prior written permission. |
| 16 | * |
| 17 | * THIS SOFTWARE IS PROVIDED "AS IS" AND ANY EXPRESS OR IMPLIED |
| 18 | * WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF |
| 19 | * MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NON-INFRINGEMENT |
| 20 | * ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS |
| 21 | * BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR |
| 22 | * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF |
| 23 | * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR |
| 24 | * BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, |
| 25 | * WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE |
| 26 | * OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN |
| 27 | * IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. |
| 28 | */ |
| 29 | #include <gralloc_priv.h> |
| 30 | #include <qdMetaData.h> |
| 31 | #include <mdp_version.h> |
Arun Kumar K.R | 8e7a62f | 2013-12-06 18:55:41 -0800 | [diff] [blame] | 32 | #include <hardware/hwcomposer.h> |
Naseer Ahmed | 78c952e | 2013-11-25 18:12:23 -0500 | [diff] [blame] | 33 | |
Saurabh Shah | 90c55cf | 2015-02-10 15:37:39 -0800 | [diff] [blame] | 34 | // This header is for clients to use to set/get global display configuration. |
Naseer Ahmed | 78c952e | 2013-11-25 18:12:23 -0500 | [diff] [blame] | 35 | // Only primary and external displays are supported here. |
Naseer Ahmed | 78c952e | 2013-11-25 18:12:23 -0500 | [diff] [blame] | 36 | |
| 37 | namespace qdutils { |
| 38 | |
Raj Kamal | 0d53fc6 | 2014-11-25 17:36:36 +0530 | [diff] [blame] | 39 | |
| 40 | /* TODO: Have all the common enums that need be exposed to clients and which |
| 41 | * are also needed in hwc defined here. Remove such definitions we have in |
| 42 | * hwc_utils.h |
| 43 | */ |
| 44 | |
Naseer Ahmed | 78c952e | 2013-11-25 18:12:23 -0500 | [diff] [blame] | 45 | // Use this enum to specify the dpy parameters where needed |
| 46 | enum { |
| 47 | DISPLAY_PRIMARY = 0, |
| 48 | DISPLAY_EXTERNAL, |
Arun Kumar K.R | 33888f5 | 2014-10-09 15:56:33 -0700 | [diff] [blame] | 49 | DISPLAY_VIRTUAL, |
| 50 | }; |
| 51 | |
| 52 | // External Display states - used in setSecondaryDisplayStatus() |
| 53 | // To be consistent with the same defined in hwc_utils.h |
| 54 | enum { |
| 55 | EXTERNAL_OFFLINE = 0, |
| 56 | EXTERNAL_ONLINE, |
| 57 | EXTERNAL_PAUSE, |
| 58 | EXTERNAL_RESUME, |
Naseer Ahmed | 78c952e | 2013-11-25 18:12:23 -0500 | [diff] [blame] | 59 | }; |
| 60 | |
Raj Kamal | 0d53fc6 | 2014-11-25 17:36:36 +0530 | [diff] [blame] | 61 | enum { |
| 62 | DISABLE_METADATA_DYN_REFRESH_RATE = 0, |
| 63 | ENABLE_METADATA_DYN_REFRESH_RATE, |
| 64 | SET_BINDER_DYN_REFRESH_RATE, |
| 65 | }; |
| 66 | |
Tatenda Chipeperekwa | 4207288 | 2015-03-24 11:50:27 -0700 | [diff] [blame^] | 67 | enum { |
| 68 | DEFAULT_MODE = 0, |
| 69 | VIDEO_MODE, |
| 70 | COMMAND_MODE, |
| 71 | }; |
| 72 | |
Naseer Ahmed | 78c952e | 2013-11-25 18:12:23 -0500 | [diff] [blame] | 73 | // Display Attributes that are available to clients of this library |
| 74 | // Not to be confused with a similar struct in hwc_utils (in the hwc namespace) |
Saurabh Shah | 90c55cf | 2015-02-10 15:37:39 -0800 | [diff] [blame] | 75 | typedef struct DisplayAttributes { |
Naseer Ahmed | 78c952e | 2013-11-25 18:12:23 -0500 | [diff] [blame] | 76 | uint32_t vsync_period; //nanoseconds |
| 77 | uint32_t xres; |
| 78 | uint32_t yres; |
| 79 | float xdpi; |
| 80 | float ydpi; |
| 81 | char panel_type; |
Saurabh Shah | 90c55cf | 2015-02-10 15:37:39 -0800 | [diff] [blame] | 82 | DisplayAttributes() : vsync_period(0), xres(0), yres(0), xdpi(0.0f), |
| 83 | ydpi(0.0f), panel_type(0) {} |
| 84 | } DisplayAttributes_t; |
| 85 | |
| 86 | //============================================================================= |
| 87 | // The functions below run in the client process and wherever necessary |
| 88 | // do a binder call to HWC to get/set data. |
Naseer Ahmed | 78c952e | 2013-11-25 18:12:23 -0500 | [diff] [blame] | 89 | |
| 90 | // Check if external display is connected. Useful to check before making |
| 91 | // calls for external displays |
| 92 | // Returns 1 if connected, 0 if disconnected, negative values on errors |
| 93 | int isExternalConnected(void); |
| 94 | |
| 95 | // Get display vsync period which is in nanoseconds |
| 96 | // i.e vsync_period = 1000000000l / fps |
| 97 | // Returns 0 on success, negative values on errors |
| 98 | int getDisplayAttributes(int dpy, DisplayAttributes_t& dpyattr); |
| 99 | |
| 100 | // Set HSIC data on a given display ID |
| 101 | // Returns 0 on success, negative values on errors |
| 102 | int setHSIC(int dpy, const HSICData_t& hsic_data); |
| 103 | |
Arun Kumar K.R | 8e7a62f | 2013-12-06 18:55:41 -0800 | [diff] [blame] | 104 | // get the active visible region for the display |
| 105 | // Returns 0 on success, negative values on errors |
| 106 | int getDisplayVisibleRegion(int dpy, hwc_rect_t &rect); |
Ramkumar Radhakrishnan | 0a021a8 | 2014-05-19 19:53:56 -0700 | [diff] [blame] | 107 | |
| 108 | // set the view frame information in hwc context from surfaceflinger |
| 109 | int setViewFrame(int dpy, int l, int t, int r, int b); |
Arun Kumar K.R | 33888f5 | 2014-10-09 15:56:33 -0700 | [diff] [blame] | 110 | |
| 111 | // Set the secondary display status(pause/resume/offline etc.,) |
| 112 | int setSecondaryDisplayStatus(int dpy, uint32_t status); |
Raj Kamal | 0d53fc6 | 2014-11-25 17:36:36 +0530 | [diff] [blame] | 113 | |
| 114 | // Enable/Disable/Set refresh rate dynamically |
| 115 | int configureDynRefreshRate(uint32_t op, uint32_t refreshRate); |
Saurabh Shah | 90c55cf | 2015-02-10 15:37:39 -0800 | [diff] [blame] | 116 | |
| 117 | // Returns the number of configs supported for the display on success. |
| 118 | // Returns -1 on error. |
| 119 | // Only primary display supported for now, value of dpy ignored. |
| 120 | int getConfigCount(int dpy); |
| 121 | |
| 122 | // Returns the index of config that is current set for the display on success. |
| 123 | // Returns -1 on error. |
| 124 | // Only primary display supported for now, value of dpy ignored. |
| 125 | int getActiveConfig(int dpy); |
| 126 | |
| 127 | // Sets the config for the display on success and returns 0. |
| 128 | // Returns -1 on error. |
| 129 | // Only primary display supported for now, value of dpy ignored |
| 130 | int setActiveConfig(int configIndex, int dpy); |
| 131 | |
| 132 | // Returns the attributes for the specified config for the display on success. |
| 133 | // Returns xres and yres as 0 on error. |
| 134 | // Only primary display supported for now, value of dpy ignored |
| 135 | DisplayAttributes getDisplayAttributes(int configIndex, int dpy); |
| 136 | |
Tatenda Chipeperekwa | 4207288 | 2015-03-24 11:50:27 -0700 | [diff] [blame^] | 137 | // Set the primary display mode to command or video mode |
| 138 | int setDisplayMode(int mode); |
| 139 | |
Saurabh Shah | 90c55cf | 2015-02-10 15:37:39 -0800 | [diff] [blame] | 140 | //============================================================================= |
| 141 | // The functions and methods below run in the context of HWC and |
| 142 | // are called in response to binder calls from clients |
| 143 | |
| 144 | class Configs { |
| 145 | public: |
| 146 | DisplayAttributes getAttributes(const uint32_t& index) const; |
| 147 | uint32_t getActiveConfig() const; |
| 148 | bool setActiveConfig(const uint32_t& index); |
| 149 | uint32_t getConfigCount() const; |
| 150 | static Configs *getInstance(); |
| 151 | private: |
| 152 | enum { CONFIGS_MAX = 32 }; |
| 153 | Configs(); |
| 154 | bool init(); |
| 155 | bool getCurrentMode(DisplayAttributes& dpyAttr); |
| 156 | DisplayAttributes mConfigs[CONFIGS_MAX]; |
| 157 | char *mModeStr[CONFIGS_MAX]; |
| 158 | uint32_t mActiveConfig; |
| 159 | uint32_t mConfigsSupported; |
| 160 | static Configs *sConfigs; |
| 161 | }; |
| 162 | |
| 163 | inline DisplayAttributes Configs::getAttributes(const uint32_t& index) const { |
| 164 | if(index >= mConfigsSupported) { |
| 165 | ALOGE("%s() Invalid index %d, max %d", __FUNCTION__, index, |
| 166 | mConfigsSupported); |
| 167 | return DisplayAttributes(); //All 0s |
| 168 | } |
| 169 | return mConfigs[index]; |
| 170 | } |
| 171 | |
| 172 | // Retuns the current config index, -1 if called without a setActiveConfig |
| 173 | inline uint32_t Configs::getActiveConfig() const { |
| 174 | return mActiveConfig; |
| 175 | } |
| 176 | |
| 177 | inline uint32_t Configs::getConfigCount() const { |
| 178 | return mConfigsSupported; |
| 179 | } |
| 180 | |
Naseer Ahmed | 78c952e | 2013-11-25 18:12:23 -0500 | [diff] [blame] | 181 | }; //namespace |