blob: c1684fc6d67bfaa40814e38b9b5fcd66e0987618 [file] [log] [blame]
Naseer Ahmed29a26812012-06-14 00:56:20 -07001/*
2* Copyright (C) 2008 The Android Open Source Project
Raj kamal23f69b22012-11-17 00:20:55 +05303* Copyright (c) 2010-2013, The Linux Foundation. All rights reserved.
Naseer Ahmed29a26812012-06-14 00:56:20 -07004*
5* Licensed under the Apache License, Version 2.0 (the "License");
6* you may not use this file except in compliance with the License.
7* You may obtain a copy of the License at
8*
9* http://www.apache.org/licenses/LICENSE-2.0
10*
11* Unless required by applicable law or agreed to in writing, software
12* distributed under the License is distributed on an "AS IS" BASIS,
13* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
14* See the License for the specific language governing permissions and
15* limitations under the License.
16*/
17
18#ifndef OVERLAY_MDP_H
19#define OVERLAY_MDP_H
20
21#include <linux/msm_mdp.h>
22
23#include "overlayUtils.h"
24#include "mdpWrapper.h"
Naseer Ahmed29a26812012-06-14 00:56:20 -070025
26namespace overlay{
27
Naseer Ahmed29a26812012-06-14 00:56:20 -070028/*
29* Mdp Ctrl holds corresponding fd and MDP related struct.
30* It is simple wrapper to MDP services
31* */
32class MdpCtrl {
33public:
34 /* ctor reset */
35 explicit MdpCtrl();
36
37 /* dtor close */
38 ~MdpCtrl();
39
Naseer Ahmedf48aef62012-07-20 09:05:53 -070040 /* init underlying device using fbnum */
41 bool init(uint32_t fbnum);
Naseer Ahmed29a26812012-06-14 00:56:20 -070042
43 /* unset overlay, reset and close fd */
44 bool close();
45
Naseer Ahmedf48aef62012-07-20 09:05:53 -070046 /* reset and set ov id to -1 / MSMFB_NEW_REQUEST */
Naseer Ahmed29a26812012-06-14 00:56:20 -070047 void reset();
48
49 /* get orient / user_data[0] */
50 int getOrient() const;
51
52 /* returns session id */
Naseer Ahmedf48aef62012-07-20 09:05:53 -070053 int getPipeId() const;
Naseer Ahmed29a26812012-06-14 00:56:20 -070054
55 /* returns the fd associated to ctrl*/
56 int getFd() const;
57
58 /* Get screen info. out: info*/
59 bool getScreenInfo(utils::ScreenInfo& info);
60
61 /* overlay get */
62 bool get();
63
Naseer Ahmedf48aef62012-07-20 09:05:53 -070064 /* returns flags from mdp structure */
Naseer Ahmed29a26812012-06-14 00:56:20 -070065 int getFlags() const;
66
67 /* set flags to mdp structure */
68 void setFlags(int f);
69
Naseer Ahmed29a26812012-06-14 00:56:20 -070070 /* set z order */
71 void setZ(utils::eZorder z);
72
Naseer Ahmed29a26812012-06-14 00:56:20 -070073 /* set isFg flag */
74 void setIsFg(utils::eIsFg isFg);
75
76 /* calls overlay set
77 * Set would always consult last good known ov instance.
78 * Only if it is different, set would actually exectue ioctl.
79 * On a sucess ioctl. last good known ov instance is updated */
80 bool set();
81
82 /* return a copy of src whf*/
83 utils::Whf getSrcWhf() const;
84
85 /* set src whf */
86 void setSrcWhf(const utils::Whf& whf);
87
Naseer Ahmedf48aef62012-07-20 09:05:53 -070088 /* adjust source width height format based on rot info */
89 void adjustSrcWhf(const bool& rotUsed);
Naseer Ahmed29a26812012-06-14 00:56:20 -070090
91 /* swap src w/h*/
92 void swapSrcWH();
93
94 /* swap src rect w/h */
95 void swapSrcRectWH();
96
97 /* returns a copy to src rect dim */
98 utils::Dim getSrcRectDim() const;
99
100 /* set src/dst rect dim */
101 void setSrcRectDim(const utils::Dim d);
102 void setDstRectDim(const utils::Dim d);
103
104 /* returns a copy ro dst rect dim */
105 utils::Dim getDstRectDim() const;
106
107 /* returns user_data[0]*/
108 int getUserData() const;
109
110 /* sets user_data[0] */
111 void setUserData(int v);
112
113 /* return true if current overlay is different
Naseer Ahmedf48aef62012-07-20 09:05:53 -0700114 * than last known good overlay */
Naseer Ahmed29a26812012-06-14 00:56:20 -0700115 bool ovChanged() const;
116
117 /* save mOVInfo to be last known good ov*/
118 void save();
119
120 /* restore last known good ov to be the current */
121 void restore();
122
Naseer Ahmedf48aef62012-07-20 09:05:53 -0700123 /* Sets the source total width, height, format */
124 bool setSource(const utils::PipeArgs& pargs);
125
Naseer Ahmed29a26812012-06-14 00:56:20 -0700126 /*
127 * Sets ROI, the unpadded region, for source buffer.
128 * Should be called before a setPosition, for small clips.
129 * Dim - ROI dimensions.
130 */
131 bool setCrop(const utils::Dim& d);
132
Ramkumar Radhakrishnan288f8c72013-01-15 11:37:54 -0800133 bool setTransform(const utils::eTransform& orient);
134
135 /* set whether rotator can be used */
136 void setRotatorUsed(const bool& rotUsed);
Naseer Ahmedf48aef62012-07-20 09:05:53 -0700137
Naseer Ahmed29a26812012-06-14 00:56:20 -0700138 /* given a dim and w/h, set overlay dim */
139 bool setPosition(const utils::Dim& dim, int w, int h);
140
141 /* using user_data, sets/unsets roationvalue in mdp flags */
142 void setRotationFlags();
143
144 /* dump state of the object */
145 void dump() const;
Naseer Ahmedf48aef62012-07-20 09:05:53 -0700146
Ramkumar Radhakrishnan288f8c72013-01-15 11:37:54 -0800147 /* Perform transformation calculations */
148 void doTransform();
149
150 /* Performs downscale calculations */
151 void doDownscale(int dscale_factor);
152
153 /* Get downscale factor */
154 int getDownscalefactor();
155
Raj kamal23f69b22012-11-17 00:20:55 +0530156 /* Update the src format */
157 void updateSrcformat(const uint32_t& inputsrcFormat);
158
Naseer Ahmed29a26812012-06-14 00:56:20 -0700159private:
160
Naseer Ahmedf48aef62012-07-20 09:05:53 -0700161 /* helper functions for overlayTransform */
Naseer Ahmedf48aef62012-07-20 09:05:53 -0700162 void overlayTransFlipH();
163 void overlayTransFlipV();
164 void overlayTransRot90();
165
166 utils::eTransform mOrientation; //Holds requested orientation
167 bool mRotUsed; //whether rotator should be used even if requested
168 //orientation is 0.
169
Naseer Ahmed29a26812012-06-14 00:56:20 -0700170 /* last good known ov info */
171 mdp_overlay mLkgo;
172
173 /* Actual overlay mdp structure */
174 mdp_overlay mOVInfo;
175
176 /* FD for the mdp fbnum */
177 OvFD mFd;
Naseer Ahmed29a26812012-06-14 00:56:20 -0700178};
179
180
181/* MDP 3D related ctrl */
182class MdpCtrl3D {
183public:
184 /* ctor reset data */
185 MdpCtrl3D();
186 /* calls MSMFB_OVERLAY_3D */
187 bool close();
188 /* set w/h. format is ignored*/
189 void setWh(const utils::Whf& whf);
190 /* set is_3d calls MSMFB_OVERLAY_3D */
191 bool useVirtualFB();
192 /* set fd to be used in ioctl */
193 void setFd(int fd);
194 /* dump */
195 void dump() const;
196private:
197 /* reset */
198 void reset();
199 /* actual MSM 3D info */
200 msmfb_overlay_3d m3DOVInfo;
201 /* FD for the mdp 3D */
202 OvFD mFd;
203};
204
205/* MDP data */
206class MdpData {
207public:
208 /* ctor reset data */
209 explicit MdpData();
210
211 /* dtor close*/
212 ~MdpData();
213
Naseer Ahmedf48aef62012-07-20 09:05:53 -0700214 /* init FD */
215 bool init(uint32_t fbnum);
Naseer Ahmed29a26812012-06-14 00:56:20 -0700216
217 /* memset0 the underlying mdp object */
218 void reset();
219
220 /* close fd, and reset */
221 bool close();
222
Naseer Ahmed29a26812012-06-14 00:56:20 -0700223 /* set id of mdp data */
Naseer Ahmedf48aef62012-07-20 09:05:53 -0700224 void setPipeId(int id);
Naseer Ahmed29a26812012-06-14 00:56:20 -0700225
226 /* return ses id of data */
Naseer Ahmedf48aef62012-07-20 09:05:53 -0700227 int getPipeId() const;
Naseer Ahmed29a26812012-06-14 00:56:20 -0700228
229 /* get underlying fd*/
230 int getFd() const;
231
232 /* get memory_id */
Naseer Ahmedf48aef62012-07-20 09:05:53 -0700233 int getSrcMemoryId() const;
Naseer Ahmed29a26812012-06-14 00:56:20 -0700234
235 /* calls wrapper play */
Naseer Ahmedf48aef62012-07-20 09:05:53 -0700236 bool play(int fd, uint32_t offset);
Naseer Ahmed29a26812012-06-14 00:56:20 -0700237
Naseer Ahmed29a26812012-06-14 00:56:20 -0700238 /* dump state of the object */
239 void dump() const;
240private:
241
242 /* actual overlay mdp data */
243 msmfb_overlay_data mOvData;
244
245 /* fd to mdp fbnum */
246 OvFD mFd;
247};
248
249//--------------Inlines---------------------------------
Naseer Ahmedf48aef62012-07-20 09:05:53 -0700250namespace {
251// just a helper func for common operations x-(y+z)
252int compute(uint32_t x, uint32_t y, uint32_t z) {
253 return x-(y+z);
254}
255}
Naseer Ahmed29a26812012-06-14 00:56:20 -0700256
257///// MdpCtrl //////
258
Naseer Ahmedf48aef62012-07-20 09:05:53 -0700259inline MdpCtrl::MdpCtrl() {
Naseer Ahmed29a26812012-06-14 00:56:20 -0700260 reset();
261}
262
263inline MdpCtrl::~MdpCtrl() {
264 close();
265}
266
267inline int MdpCtrl::getOrient() const {
268 return getUserData();
269}
270
Naseer Ahmedf48aef62012-07-20 09:05:53 -0700271inline int MdpCtrl::getPipeId() const {
Naseer Ahmed29a26812012-06-14 00:56:20 -0700272 return mOVInfo.id;
273}
274
275inline int MdpCtrl::getFd() const {
276 return mFd.getFD();
277}
278
279inline int MdpCtrl::getFlags() const {
280 return mOVInfo.flags;
281}
282
283inline void MdpCtrl::setFlags(int f) {
284 mOVInfo.flags = f;
285}
286
287inline void MdpCtrl::setZ(overlay::utils::eZorder z) {
288 mOVInfo.z_order = z;
289}
290
Naseer Ahmed29a26812012-06-14 00:56:20 -0700291inline void MdpCtrl::setIsFg(overlay::utils::eIsFg isFg) {
292 mOVInfo.is_fg = isFg;
293}
294
295inline bool MdpCtrl::ovChanged() const {
296 // 0 means same
297 if(0 == ::memcmp(&mOVInfo, &mLkgo, sizeof (mdp_overlay))) {
298 return false;
299 }
300 return true;
301}
302
303inline void MdpCtrl::save() {
Naseer Ahmedf48aef62012-07-20 09:05:53 -0700304 if(static_cast<ssize_t>(mOVInfo.id) == MSMFB_NEW_REQUEST) {
Naseer Ahmed29a26812012-06-14 00:56:20 -0700305 ALOGE("MdpCtrl current ov has id -1, will not save");
Naseer Ahmed29a26812012-06-14 00:56:20 -0700306 return;
307 }
308 mLkgo = mOVInfo;
309}
310
311inline void MdpCtrl::restore() {
Naseer Ahmedf48aef62012-07-20 09:05:53 -0700312 if(static_cast<ssize_t>(mLkgo.id) == MSMFB_NEW_REQUEST) {
Naseer Ahmed29a26812012-06-14 00:56:20 -0700313 ALOGE("MdpCtrl Lkgo ov has id -1, will not restore");
Naseer Ahmed29a26812012-06-14 00:56:20 -0700314 return;
315 }
316 mOVInfo = mLkgo;
317}
318
319inline overlay::utils::Whf MdpCtrl::getSrcWhf() const {
Naseer Ahmedf48aef62012-07-20 09:05:53 -0700320 return utils::Whf( mOVInfo.src.width,
321 mOVInfo.src.height,
322 mOVInfo.src.format);
Naseer Ahmed29a26812012-06-14 00:56:20 -0700323}
324
325inline void MdpCtrl::setSrcWhf(const overlay::utils::Whf& whf) {
326 mOVInfo.src.width = whf.w;
327 mOVInfo.src.height = whf.h;
328 mOVInfo.src.format = whf.format;
329}
330
331inline overlay::utils::Dim MdpCtrl::getSrcRectDim() const {
Naseer Ahmedf48aef62012-07-20 09:05:53 -0700332 return utils::Dim( mOVInfo.src_rect.x,
333 mOVInfo.src_rect.y,
334 mOVInfo.src_rect.w,
335 mOVInfo.src_rect.h);
Naseer Ahmed29a26812012-06-14 00:56:20 -0700336}
337
338inline void MdpCtrl::setSrcRectDim(const overlay::utils::Dim d) {
339 mOVInfo.src_rect.x = d.x;
340 mOVInfo.src_rect.y = d.y;
341 mOVInfo.src_rect.w = d.w;
342 mOVInfo.src_rect.h = d.h;
343}
344
345inline overlay::utils::Dim MdpCtrl::getDstRectDim() const {
Naseer Ahmedf48aef62012-07-20 09:05:53 -0700346 return utils::Dim( mOVInfo.dst_rect.x,
347 mOVInfo.dst_rect.y,
348 mOVInfo.dst_rect.w,
349 mOVInfo.dst_rect.h);
Naseer Ahmed29a26812012-06-14 00:56:20 -0700350}
351
352inline void MdpCtrl::setDstRectDim(const overlay::utils::Dim d) {
353 mOVInfo.dst_rect.x = d.x;
354 mOVInfo.dst_rect.y = d.y;
355 mOVInfo.dst_rect.w = d.w;
356 mOVInfo.dst_rect.h = d.h;
357}
358
359inline int MdpCtrl::getUserData() const { return mOVInfo.user_data[0]; }
360
361inline void MdpCtrl::setUserData(int v) { mOVInfo.user_data[0] = v; }
362
363inline void MdpCtrl::setRotationFlags() {
364 const int u = getUserData();
365 if (u == MDP_ROT_90 || u == MDP_ROT_270)
366 mOVInfo.flags |= MDP_SOURCE_ROTATED_90;
367 else
368 mOVInfo.flags &= ~MDP_SOURCE_ROTATED_90;
369}
370
Naseer Ahmed29a26812012-06-14 00:56:20 -0700371inline void MdpCtrl::swapSrcWH() {
372 utils::swap(mOVInfo.src.width,
Naseer Ahmedf48aef62012-07-20 09:05:53 -0700373 mOVInfo.src.height);
374}
Naseer Ahmed29a26812012-06-14 00:56:20 -0700375
376inline void MdpCtrl::swapSrcRectWH() {
Naseer Ahmedf48aef62012-07-20 09:05:53 -0700377 utils::swap(mOVInfo.src_rect.w,
378 mOVInfo.src_rect.h);
379}
380
381inline void MdpCtrl::overlayTransFlipH()
382{
383 utils::Dim d = getSrcRectDim();
384 utils::Whf whf = getSrcWhf();
385 d.x = compute(whf.w, d.x, d.w);
386 setSrcRectDim(d);
387}
388
389inline void MdpCtrl::overlayTransFlipV()
390{
391 utils::Dim d = getSrcRectDim();
392 utils::Whf whf = getSrcWhf();
393 d.y = compute(whf.h, d.y, d.h);
394 setSrcRectDim(d);
395}
396
397inline void MdpCtrl::overlayTransRot90()
398{
399 utils::Dim d = getSrcRectDim();
400 utils::Whf whf = getSrcWhf();
401 int tmp = d.x;
402 d.x = compute(whf.h,
403 d.y,
404 d.h);
405 d.y = tmp;
406 setSrcRectDim(d);
407 swapSrcWH();
408 swapSrcRectWH();
409}
410
Naseer Ahmed29a26812012-06-14 00:56:20 -0700411
412/////// MdpCtrl3D //////
413
414inline MdpCtrl3D::MdpCtrl3D() { reset(); }
415inline bool MdpCtrl3D::close() {
416 if (m3DOVInfo.is_3d) {
417 m3DOVInfo.is_3d = 0;
418 if(!mdp_wrapper::set3D(mFd.getFD(), m3DOVInfo)) {
419 ALOGE("MdpCtrl3D close failed set3D with 0");
420 return false;
421 }
422 }
423 reset();
424 return true;
425}
426inline void MdpCtrl3D::reset() {
427 utils::memset0(m3DOVInfo);
428}
429
430inline void MdpCtrl3D::setFd(int fd) {
431 mFd.copy(fd);
432 OVASSERT(mFd.valid(), "MdpCtrl3D setFd, FD should be valid");
433}
434
435inline void MdpCtrl3D::setWh(const utils::Whf& whf) {
436 // ignore fmt. Needed for useVirtualFB callflow
437 m3DOVInfo.width = whf.w;
438 m3DOVInfo.height = whf.h;
439}
440
441inline bool MdpCtrl3D::useVirtualFB() {
442 if(!m3DOVInfo.is_3d) {
443 m3DOVInfo.is_3d = 1;
444 if(!mdp_wrapper::set3D(mFd.getFD(), m3DOVInfo)) {
445 ALOGE("MdpCtrl3D close failed set3D with 0");
446 return false;
447 }
448 }
449 return true;
450}
451
452/////// MdpData //////
453
454inline MdpData::MdpData() { reset(); }
455
456inline MdpData::~MdpData() { close(); }
457
Naseer Ahmedf48aef62012-07-20 09:05:53 -0700458inline bool MdpData::init(uint32_t fbnum) {
459 // FD init
460 if(!utils::openDev(mFd, fbnum, Res::fbPath, O_RDWR)){
461 ALOGE("Ctrl failed to init fbnum=%d", fbnum);
Naseer Ahmed29a26812012-06-14 00:56:20 -0700462 return false;
463 }
464 return true;
465}
466
467inline void MdpData::reset() {
468 overlay::utils::memset0(mOvData);
469 mOvData.data.memory_id = -1;
470}
471
472inline bool MdpData::close() {
Naseer Ahmed29a26812012-06-14 00:56:20 -0700473 reset();
Saurabh Shah8e1ae952012-08-15 12:15:14 -0700474 return mFd.close();
Naseer Ahmed29a26812012-06-14 00:56:20 -0700475}
476
Naseer Ahmedf48aef62012-07-20 09:05:53 -0700477inline int MdpData::getSrcMemoryId() const { return mOvData.data.memory_id; }
Naseer Ahmed29a26812012-06-14 00:56:20 -0700478
Naseer Ahmedf48aef62012-07-20 09:05:53 -0700479inline void MdpData::setPipeId(int id) { mOvData.id = id; }
Naseer Ahmed29a26812012-06-14 00:56:20 -0700480
Naseer Ahmedf48aef62012-07-20 09:05:53 -0700481inline int MdpData::getPipeId() const { return mOvData.id; }
Naseer Ahmed29a26812012-06-14 00:56:20 -0700482
483inline int MdpData::getFd() const { return mFd.getFD(); }
484
Naseer Ahmedf48aef62012-07-20 09:05:53 -0700485inline bool MdpData::play(int fd, uint32_t offset) {
486 mOvData.data.memory_id = fd;
487 mOvData.data.offset = offset;
Naseer Ahmed29a26812012-06-14 00:56:20 -0700488 if(!mdp_wrapper::play(mFd.getFD(), mOvData)){
489 ALOGE("MdpData failed to play");
Naseer Ahmedf48aef62012-07-20 09:05:53 -0700490 dump();
Naseer Ahmed29a26812012-06-14 00:56:20 -0700491 return false;
492 }
493 return true;
494}
495
Naseer Ahmed29a26812012-06-14 00:56:20 -0700496} // overlay
497
498#endif // OVERLAY_MDP_H