mdp_version.h revision f7ad1a3b9d99f9c59be31819742855893192b2bb
1/* 2 * Copyright (c) 2012-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 30#ifndef INCLUDE_LIBQCOMUTILS_MDPVER 31#define INCLUDE_LIBQCOMUTILS_MDPVER 32 33#include <stdint.h> 34#include <utils/Singleton.h> 35#include <cutils/properties.h> 36 37/* This class gets the MSM type from the soc info 38*/ 39using namespace android; 40namespace qdutils { 41// These panel definitions are available at mdss_mdp.h which is internal header 42// file and is not available at <linux/mdss_mdp.h>. 43// ToDo: once it is available at linux/mdss_mdp.h, these below definitions can 44// be removed. 45enum mdp_version { 46 MDP_V_UNKNOWN = 0, 47 MDP_V2_2 = 220, 48 MDP_V3_0 = 300, 49 MDP_V3_0_3 = 303, 50 MDP_V3_0_4 = 304, 51 MDP_V3_1 = 310, 52 MDP_V4_0 = 400, 53 MDP_V4_1 = 410, 54 MDP_V4_2 = 420, 55 MDP_V4_3 = 430, 56 MDP_V4_4 = 440, 57 MDSS_V5 = 500, 58}; 59 60// chip variants have same major number and minor numbers usually vary 61// for e.g., MDSS_MDP_HW_REV_101 is 0x10010000 62// 1001 - major number 63// 0000 - minor number 64// 8x26 v1 minor number is 0000 65// v2 minor number is 0001 etc.. 66enum mdp_rev { 67 MDSS_MDP_HW_REV_100 = 0x10000000, //8974 v1 68 MDSS_MDP_HW_REV_101 = 0x10010000, //8x26 69 MDSS_MDP_HW_REV_102 = 0x10020000, //8974 v2 70 MDSS_MDP_HW_REV_103 = 0x10030000, //8084 71 MDSS_MDP_HW_REV_104 = 0x10040000, //Next version 72 MDSS_MDP_HW_REV_105 = 0x10050000, //Next version 73 MDSS_MDP_HW_REV_107 = 0x10070000, //Next version 74 MDSS_MDP_HW_REV_200 = 0x20000000, //8092 75 MDSS_MDP_HW_REV_206 = 0x20060000, //Future 76}; 77 78enum { 79 MAX_DISPLAY_DIM = 2048, 80}; 81 82#define NO_PANEL '0' 83#define MDDI_PANEL '1' 84#define EBI2_PANEL '2' 85#define LCDC_PANEL '3' 86#define EXT_MDDI_PANEL '4' 87#define TV_PANEL '5' 88#define DTV_PANEL '7' 89#define MIPI_VIDEO_PANEL '8' 90#define MIPI_CMD_PANEL '9' 91#define WRITEBACK_PANEL 'a' 92#define LVDS_PANEL 'b' 93#define EDP_PANEL 'c' 94 95class MDPVersion; 96 97struct Split { 98 int mLeft; 99 int mRight; 100 Split() : mLeft(0), mRight(0){} 101 int left() { return mLeft; } 102 int right() { return mRight; } 103 friend class MDPVersion; 104}; 105 106class MDPVersion : public Singleton <MDPVersion> 107{ 108public: 109 MDPVersion(); 110 ~MDPVersion(); 111 int getMDPVersion() {return mMDPVersion;} 112 char getPanelType() {return mPanelType;} 113 bool hasOverlay() {return mHasOverlay;} 114 uint8_t getTotalPipes() { return (mRGBPipes + mVGPipes + mDMAPipes);} 115 uint8_t getRGBPipes() { return mRGBPipes; } 116 uint8_t getVGPipes() { return mVGPipes; } 117 uint8_t getDMAPipes() { return mDMAPipes; } 118 bool supportsDecimation(); 119 uint32_t getMaxMDPDownscale(); 120 uint32_t getMaxMDPUpscale(); 121 bool supportsBWC(); 122 bool supportsMacroTile(); 123 int getLeftSplit() { return mSplit.left(); } 124 int getRightSplit() { return mSplit.right(); } 125 unsigned long getLowBw() { return mLowBw; } 126 unsigned long getHighBw() { return mHighBw; } 127 128 bool is8x26() { 129 return (mMdpRev >= MDSS_MDP_HW_REV_101 and 130 mMdpRev < MDSS_MDP_HW_REV_102); 131 } 132 bool is8x74v2() { 133 return (mMdpRev >= MDSS_MDP_HW_REV_102 and 134 mMdpRev < MDSS_MDP_HW_REV_103); 135 } 136 bool is8084() { 137 return (mMdpRev >= MDSS_MDP_HW_REV_103 and 138 mMdpRev < MDSS_MDP_HW_REV_104); 139 } 140 bool is8092() { 141 return (mMdpRev >= MDSS_MDP_HW_REV_200 and 142 mMdpRev < MDSS_MDP_HW_REV_206); 143 } 144 145private: 146 bool updateSysFsInfo(); 147 bool updatePanelInfo(); 148 bool updateSplitInfo(); 149 int tokenizeParams(char *inputParams, const char *delim, 150 char* tokenStr[], int *idx); 151 int mFd; 152 int mMDPVersion; 153 char mPanelType; 154 bool mHasOverlay; 155 uint32_t mMdpRev; 156 uint8_t mRGBPipes; 157 uint8_t mVGPipes; 158 uint8_t mDMAPipes; 159 uint32_t mFeatures; 160 uint32_t mMDPDownscale; 161 uint32_t mMDPUpscale; 162 bool mMacroTileEnabled; 163 Split mSplit; 164 unsigned long mLowBw; //kbps 165 unsigned long mHighBw; //kbps 166}; 167}; //namespace qdutils 168#endif //INCLUDE_LIBQCOMUTILS_MDPVER 169