blob: 60a298574bb87c595851dacd55ff8818ed23276a [file] [log] [blame]
Naseer Ahmed29a26812012-06-14 00:56:20 -07001/*
Sushil Chauhan07a2c762013-03-06 15:36:49 -08002 * Copyright (c) 2012-2013, The Linux Foundation. All rights reserved.
Naseer Ahmed29a26812012-06-14 00:56:20 -07003
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.
Duy Truong73d36df2013-02-09 20:33:23 -080013 * * Neither the name of The Linux Foundation nor the names of its
Naseer Ahmed29a26812012-06-14 00:56:20 -070014 * 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
Naseer Ahmeda87da602012-07-01 23:54:19 -070030#ifndef INCLUDE_LIBQCOMUTILS_MDPVER
31#define INCLUDE_LIBQCOMUTILS_MDPVER
Naseer Ahmed29a26812012-06-14 00:56:20 -070032
Naseer Ahmeda87da602012-07-01 23:54:19 -070033#include <stdint.h>
34#include <utils/Singleton.h>
35#include <cutils/properties.h>
Naseer Ahmed29a26812012-06-14 00:56:20 -070036
Naseer Ahmeda87da602012-07-01 23:54:19 -070037/* This class gets the MSM type from the soc info
38*/
39using namespace android;
40namespace qdutils {
Manoj Kumar AVMc65ec612013-11-21 09:20:29 -080041// 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.
Naseer Ahmeda87da602012-07-01 23:54:19 -070045enum mdp_version {
46 MDP_V_UNKNOWN = 0,
47 MDP_V2_2 = 220,
48 MDP_V3_0 = 300,
49 MDP_V3_0_3 = 303,
Xiaoming Zhou530f8612013-05-01 20:53:06 -040050 MDP_V3_0_4 = 304,
Naseer Ahmeda87da602012-07-01 23:54:19 -070051 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,
Naseer Ahmed29a26812012-06-14 00:56:20 -070058};
59
Saurabh Shah173ec332013-12-03 15:34:58 -080060// 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..
Saurabh Shahe2474082013-05-15 16:32:13 -070066enum mdp_rev {
Saurabh Shah75b81b92013-08-29 17:31:17 -070067 MDSS_MDP_HW_REV_100 = 0x10000000, //8974 v1
Saurabh Shahe2474082013-05-15 16:32:13 -070068 MDSS_MDP_HW_REV_101 = 0x10010000, //8x26
Saurabh Shah75b81b92013-08-29 17:31:17 -070069 MDSS_MDP_HW_REV_102 = 0x10020000, //8974 v2
Saurabh Shah173ec332013-12-03 15:34:58 -080070 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
Zohaib Alam4eff7902013-11-01 02:35:05 -040074 MDSS_MDP_HW_REV_200 = 0x20000000, //8092
75 MDSS_MDP_HW_REV_206 = 0x20060000, //Future
Saurabh Shahe2474082013-05-15 16:32:13 -070076};
77
Saurabh Shahbd2d0832013-04-04 14:33:08 -070078enum {
79 MAX_DISPLAY_DIM = 2048,
80};
81
Manoj Kumar AVMc65ec612013-11-21 09:20:29 -080082#define NO_PANEL '0'
Naseer Ahmed96c4c952012-07-25 18:27:14 -070083#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'
Manoj Kumar AVMc65ec612013-11-21 09:20:29 -080093#define EDP_PANEL 'c'
Naseer Ahmed96c4c952012-07-25 18:27:14 -070094
Saurabh Shah67a38c32013-06-10 16:23:15 -070095class 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};
Naseer Ahmed96c4c952012-07-25 18:27:14 -0700105
Naseer Ahmeda87da602012-07-01 23:54:19 -0700106class MDPVersion : public Singleton <MDPVersion>
107{
108public:
109 MDPVersion();
Xiaoming Zhou3da712a2013-07-04 14:37:45 -0400110 ~MDPVersion();
Naseer Ahmeda87da602012-07-01 23:54:19 -0700111 int getMDPVersion() {return mMDPVersion;}
Naseer Ahmed96c4c952012-07-25 18:27:14 -0700112 char getPanelType() {return mPanelType;}
Naseer Ahmeda87da602012-07-01 23:54:19 -0700113 bool hasOverlay() {return mHasOverlay;}
Sushil Chauhan07a2c762013-03-06 15:36:49 -0800114 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; }
Saurabh Shahbd2d0832013-04-04 14:33:08 -0700118 bool supportsDecimation();
119 uint32_t getMaxMDPDownscale();
Sushil Chauhanbab187a2013-01-30 17:44:15 -0800120 bool supportsBWC();
Saurabh Shah67a38c32013-06-10 16:23:15 -0700121 int getLeftSplit() { return mSplit.left(); }
122 int getRightSplit() { return mSplit.right(); }
Saurabh Shah8ee5e892013-11-25 10:51:40 -0800123 unsigned long getLowBw() { return mLowBw; }
124 unsigned long getHighBw() { return mHighBw; }
Saurabh Shah173ec332013-12-03 15:34:58 -0800125
126 bool is8x26() {
127 return (mMdpRev >= MDSS_MDP_HW_REV_101 and
128 mMdpRev < MDSS_MDP_HW_REV_102);
129 }
130 bool is8x74v2() {
131 return (mMdpRev >= MDSS_MDP_HW_REV_102 and
132 mMdpRev < MDSS_MDP_HW_REV_103);
133 }
134 bool is8084() {
135 return (mMdpRev >= MDSS_MDP_HW_REV_103 and
136 mMdpRev < MDSS_MDP_HW_REV_104);
137 }
138 bool is8092() {
139 return (mMdpRev >= MDSS_MDP_HW_REV_200 and
140 mMdpRev < MDSS_MDP_HW_REV_206);
141 }
142
Naseer Ahmeda87da602012-07-01 23:54:19 -0700143private:
manoj kumar amara venkata mastanbc05ef02013-09-17 19:29:32 -0700144 bool updateSysFsInfo();
Manoj Kumar AVMc65ec612013-11-21 09:20:29 -0800145 bool updatePanelInfo();
146 bool updateSplitInfo();
manoj kumar amara venkata mastanbc05ef02013-09-17 19:29:32 -0700147 int tokenizeParams(char *inputParams, const char *delim,
148 char* tokenStr[], int *idx);
Xiaoming Zhou3da712a2013-07-04 14:37:45 -0400149 int mFd;
Naseer Ahmeda87da602012-07-01 23:54:19 -0700150 int mMDPVersion;
Naseer Ahmed96c4c952012-07-25 18:27:14 -0700151 char mPanelType;
Naseer Ahmeda87da602012-07-01 23:54:19 -0700152 bool mHasOverlay;
Sushil Chauhan07a2c762013-03-06 15:36:49 -0800153 uint32_t mMdpRev;
154 uint8_t mRGBPipes;
155 uint8_t mVGPipes;
156 uint8_t mDMAPipes;
Saurabh Shahbd2d0832013-04-04 14:33:08 -0700157 uint32_t mFeatures;
158 uint32_t mMDPDownscale;
manoj kumar amara venkata mastanbc05ef02013-09-17 19:29:32 -0700159 uint32_t mMDPUpscale;
Saurabh Shah67a38c32013-06-10 16:23:15 -0700160 Split mSplit;
Saurabh Shah8ee5e892013-11-25 10:51:40 -0800161 unsigned long mLowBw; //kbps
162 unsigned long mHighBw; //kbps
Naseer Ahmeda87da602012-07-01 23:54:19 -0700163};
164}; //namespace qdutils
165#endif //INCLUDE_LIBQCOMUTILS_MDPVER