blob: f7b16fa700947f11ba75e2adf42ec85c4249b3dd [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 {
41enum mdp_version {
42 MDP_V_UNKNOWN = 0,
43 MDP_V2_2 = 220,
44 MDP_V3_0 = 300,
45 MDP_V3_0_3 = 303,
Xiaoming Zhou530f8612013-05-01 20:53:06 -040046 MDP_V3_0_4 = 304,
Naseer Ahmeda87da602012-07-01 23:54:19 -070047 MDP_V3_1 = 310,
48 MDP_V4_0 = 400,
49 MDP_V4_1 = 410,
50 MDP_V4_2 = 420,
51 MDP_V4_3 = 430,
52 MDP_V4_4 = 440,
53 MDSS_V5 = 500,
Naseer Ahmed29a26812012-06-14 00:56:20 -070054};
55
Saurabh Shahe2474082013-05-15 16:32:13 -070056enum mdp_rev {
57 MDSS_MDP_HW_REV_100 = 0x10000000,
58 MDSS_MDP_HW_REV_101 = 0x10010000, //8x26
59 MDSS_MDP_HW_REV_102 = 0x10020000,
60};
61
Saurabh Shahbd2d0832013-04-04 14:33:08 -070062enum {
63 MAX_DISPLAY_DIM = 2048,
64};
65
Naseer Ahmed96c4c952012-07-25 18:27:14 -070066#define MDDI_PANEL '1'
67#define EBI2_PANEL '2'
68#define LCDC_PANEL '3'
69#define EXT_MDDI_PANEL '4'
70#define TV_PANEL '5'
71#define DTV_PANEL '7'
72#define MIPI_VIDEO_PANEL '8'
73#define MIPI_CMD_PANEL '9'
74#define WRITEBACK_PANEL 'a'
75#define LVDS_PANEL 'b'
76
77
Naseer Ahmeda87da602012-07-01 23:54:19 -070078class MDPVersion : public Singleton <MDPVersion>
79{
80public:
81 MDPVersion();
82 ~MDPVersion() { }
83 int getMDPVersion() {return mMDPVersion;}
Naseer Ahmed96c4c952012-07-25 18:27:14 -070084 char getPanelType() {return mPanelType;}
Naseer Ahmeda87da602012-07-01 23:54:19 -070085 bool hasOverlay() {return mHasOverlay;}
Sushil Chauhan07a2c762013-03-06 15:36:49 -080086 uint8_t getTotalPipes() { return (mRGBPipes + mVGPipes + mDMAPipes);}
87 uint8_t getRGBPipes() { return mRGBPipes; }
88 uint8_t getVGPipes() { return mVGPipes; }
89 uint8_t getDMAPipes() { return mDMAPipes; }
Saurabh Shahbd2d0832013-04-04 14:33:08 -070090 bool supportsDecimation();
91 uint32_t getMaxMDPDownscale();
Sushil Chauhanbab187a2013-01-30 17:44:15 -080092 bool supportsBWC();
Saurabh Shahe2474082013-05-15 16:32:13 -070093 bool is8x26();
Naseer Ahmeda87da602012-07-01 23:54:19 -070094private:
95 int mMDPVersion;
Naseer Ahmed96c4c952012-07-25 18:27:14 -070096 char mPanelType;
Naseer Ahmeda87da602012-07-01 23:54:19 -070097 bool mHasOverlay;
Sushil Chauhan07a2c762013-03-06 15:36:49 -080098 uint32_t mMdpRev;
99 uint8_t mRGBPipes;
100 uint8_t mVGPipes;
101 uint8_t mDMAPipes;
Saurabh Shahbd2d0832013-04-04 14:33:08 -0700102 uint32_t mFeatures;
103 uint32_t mMDPDownscale;
Naseer Ahmeda87da602012-07-01 23:54:19 -0700104};
105}; //namespace qdutils
106#endif //INCLUDE_LIBQCOMUTILS_MDPVER