blob: 9df1a04da0158f11422c558d49d6669ce43af0a5 [file] [log] [blame]
Naseer Ahmed29a26812012-06-14 00:56:20 -07001/*
2* Copyright (C) 2008 The Android Open Source Project
Duy Truong73d36df2013-02-09 20:33:23 -08003* Copyright (c) 2010-2012, 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
Naseer Ahmed29a26812012-06-14 00:56:20 -0700156private:
157
Naseer Ahmedf48aef62012-07-20 09:05:53 -0700158 /* helper functions for overlayTransform */
Naseer Ahmedf48aef62012-07-20 09:05:53 -0700159 void overlayTransFlipH();
160 void overlayTransFlipV();
161 void overlayTransRot90();
162
163 utils::eTransform mOrientation; //Holds requested orientation
164 bool mRotUsed; //whether rotator should be used even if requested
165 //orientation is 0.
166
Naseer Ahmed29a26812012-06-14 00:56:20 -0700167 /* last good known ov info */
168 mdp_overlay mLkgo;
169
170 /* Actual overlay mdp structure */
171 mdp_overlay mOVInfo;
172
173 /* FD for the mdp fbnum */
174 OvFD mFd;
Naseer Ahmed29a26812012-06-14 00:56:20 -0700175};
176
177
178/* MDP 3D related ctrl */
179class MdpCtrl3D {
180public:
181 /* ctor reset data */
182 MdpCtrl3D();
183 /* calls MSMFB_OVERLAY_3D */
184 bool close();
185 /* set w/h. format is ignored*/
186 void setWh(const utils::Whf& whf);
187 /* set is_3d calls MSMFB_OVERLAY_3D */
188 bool useVirtualFB();
189 /* set fd to be used in ioctl */
190 void setFd(int fd);
191 /* dump */
192 void dump() const;
193private:
194 /* reset */
195 void reset();
196 /* actual MSM 3D info */
197 msmfb_overlay_3d m3DOVInfo;
198 /* FD for the mdp 3D */
199 OvFD mFd;
200};
201
202/* MDP data */
203class MdpData {
204public:
205 /* ctor reset data */
206 explicit MdpData();
207
208 /* dtor close*/
209 ~MdpData();
210
Naseer Ahmedf48aef62012-07-20 09:05:53 -0700211 /* init FD */
212 bool init(uint32_t fbnum);
Naseer Ahmed29a26812012-06-14 00:56:20 -0700213
214 /* memset0 the underlying mdp object */
215 void reset();
216
217 /* close fd, and reset */
218 bool close();
219
Naseer Ahmed29a26812012-06-14 00:56:20 -0700220 /* set id of mdp data */
Naseer Ahmedf48aef62012-07-20 09:05:53 -0700221 void setPipeId(int id);
Naseer Ahmed29a26812012-06-14 00:56:20 -0700222
223 /* return ses id of data */
Naseer Ahmedf48aef62012-07-20 09:05:53 -0700224 int getPipeId() const;
Naseer Ahmed29a26812012-06-14 00:56:20 -0700225
226 /* get underlying fd*/
227 int getFd() const;
228
229 /* get memory_id */
Naseer Ahmedf48aef62012-07-20 09:05:53 -0700230 int getSrcMemoryId() const;
Naseer Ahmed29a26812012-06-14 00:56:20 -0700231
232 /* calls wrapper play */
Naseer Ahmedf48aef62012-07-20 09:05:53 -0700233 bool play(int fd, uint32_t offset);
Naseer Ahmed29a26812012-06-14 00:56:20 -0700234
Naseer Ahmed29a26812012-06-14 00:56:20 -0700235 /* dump state of the object */
236 void dump() const;
237private:
238
239 /* actual overlay mdp data */
240 msmfb_overlay_data mOvData;
241
242 /* fd to mdp fbnum */
243 OvFD mFd;
244};
245
246//--------------Inlines---------------------------------
Naseer Ahmedf48aef62012-07-20 09:05:53 -0700247namespace {
248// just a helper func for common operations x-(y+z)
249int compute(uint32_t x, uint32_t y, uint32_t z) {
250 return x-(y+z);
251}
252}
Naseer Ahmed29a26812012-06-14 00:56:20 -0700253
254///// MdpCtrl //////
255
Naseer Ahmedf48aef62012-07-20 09:05:53 -0700256inline MdpCtrl::MdpCtrl() {
Naseer Ahmed29a26812012-06-14 00:56:20 -0700257 reset();
258}
259
260inline MdpCtrl::~MdpCtrl() {
261 close();
262}
263
264inline int MdpCtrl::getOrient() const {
265 return getUserData();
266}
267
Naseer Ahmedf48aef62012-07-20 09:05:53 -0700268inline int MdpCtrl::getPipeId() const {
Naseer Ahmed29a26812012-06-14 00:56:20 -0700269 return mOVInfo.id;
270}
271
272inline int MdpCtrl::getFd() const {
273 return mFd.getFD();
274}
275
276inline int MdpCtrl::getFlags() const {
277 return mOVInfo.flags;
278}
279
280inline void MdpCtrl::setFlags(int f) {
281 mOVInfo.flags = f;
282}
283
284inline void MdpCtrl::setZ(overlay::utils::eZorder z) {
285 mOVInfo.z_order = z;
286}
287
Naseer Ahmed29a26812012-06-14 00:56:20 -0700288inline void MdpCtrl::setIsFg(overlay::utils::eIsFg isFg) {
289 mOVInfo.is_fg = isFg;
290}
291
292inline bool MdpCtrl::ovChanged() const {
293 // 0 means same
294 if(0 == ::memcmp(&mOVInfo, &mLkgo, sizeof (mdp_overlay))) {
295 return false;
296 }
297 return true;
298}
299
300inline void MdpCtrl::save() {
Naseer Ahmedf48aef62012-07-20 09:05:53 -0700301 if(static_cast<ssize_t>(mOVInfo.id) == MSMFB_NEW_REQUEST) {
Naseer Ahmed29a26812012-06-14 00:56:20 -0700302 ALOGE("MdpCtrl current ov has id -1, will not save");
Naseer Ahmed29a26812012-06-14 00:56:20 -0700303 return;
304 }
305 mLkgo = mOVInfo;
306}
307
308inline void MdpCtrl::restore() {
Naseer Ahmedf48aef62012-07-20 09:05:53 -0700309 if(static_cast<ssize_t>(mLkgo.id) == MSMFB_NEW_REQUEST) {
Naseer Ahmed29a26812012-06-14 00:56:20 -0700310 ALOGE("MdpCtrl Lkgo ov has id -1, will not restore");
Naseer Ahmed29a26812012-06-14 00:56:20 -0700311 return;
312 }
313 mOVInfo = mLkgo;
314}
315
316inline overlay::utils::Whf MdpCtrl::getSrcWhf() const {
Naseer Ahmedf48aef62012-07-20 09:05:53 -0700317 return utils::Whf( mOVInfo.src.width,
318 mOVInfo.src.height,
319 mOVInfo.src.format);
Naseer Ahmed29a26812012-06-14 00:56:20 -0700320}
321
322inline void MdpCtrl::setSrcWhf(const overlay::utils::Whf& whf) {
323 mOVInfo.src.width = whf.w;
324 mOVInfo.src.height = whf.h;
325 mOVInfo.src.format = whf.format;
326}
327
328inline overlay::utils::Dim MdpCtrl::getSrcRectDim() const {
Naseer Ahmedf48aef62012-07-20 09:05:53 -0700329 return utils::Dim( mOVInfo.src_rect.x,
330 mOVInfo.src_rect.y,
331 mOVInfo.src_rect.w,
332 mOVInfo.src_rect.h);
Naseer Ahmed29a26812012-06-14 00:56:20 -0700333}
334
335inline void MdpCtrl::setSrcRectDim(const overlay::utils::Dim d) {
336 mOVInfo.src_rect.x = d.x;
337 mOVInfo.src_rect.y = d.y;
338 mOVInfo.src_rect.w = d.w;
339 mOVInfo.src_rect.h = d.h;
340}
341
342inline overlay::utils::Dim MdpCtrl::getDstRectDim() const {
Naseer Ahmedf48aef62012-07-20 09:05:53 -0700343 return utils::Dim( mOVInfo.dst_rect.x,
344 mOVInfo.dst_rect.y,
345 mOVInfo.dst_rect.w,
346 mOVInfo.dst_rect.h);
Naseer Ahmed29a26812012-06-14 00:56:20 -0700347}
348
349inline void MdpCtrl::setDstRectDim(const overlay::utils::Dim d) {
350 mOVInfo.dst_rect.x = d.x;
351 mOVInfo.dst_rect.y = d.y;
352 mOVInfo.dst_rect.w = d.w;
353 mOVInfo.dst_rect.h = d.h;
354}
355
356inline int MdpCtrl::getUserData() const { return mOVInfo.user_data[0]; }
357
358inline void MdpCtrl::setUserData(int v) { mOVInfo.user_data[0] = v; }
359
360inline void MdpCtrl::setRotationFlags() {
361 const int u = getUserData();
362 if (u == MDP_ROT_90 || u == MDP_ROT_270)
363 mOVInfo.flags |= MDP_SOURCE_ROTATED_90;
364 else
365 mOVInfo.flags &= ~MDP_SOURCE_ROTATED_90;
366}
367
Naseer Ahmed29a26812012-06-14 00:56:20 -0700368inline void MdpCtrl::swapSrcWH() {
369 utils::swap(mOVInfo.src.width,
Naseer Ahmedf48aef62012-07-20 09:05:53 -0700370 mOVInfo.src.height);
371}
Naseer Ahmed29a26812012-06-14 00:56:20 -0700372
373inline void MdpCtrl::swapSrcRectWH() {
Naseer Ahmedf48aef62012-07-20 09:05:53 -0700374 utils::swap(mOVInfo.src_rect.w,
375 mOVInfo.src_rect.h);
376}
377
378inline void MdpCtrl::overlayTransFlipH()
379{
380 utils::Dim d = getSrcRectDim();
381 utils::Whf whf = getSrcWhf();
382 d.x = compute(whf.w, d.x, d.w);
383 setSrcRectDim(d);
384}
385
386inline void MdpCtrl::overlayTransFlipV()
387{
388 utils::Dim d = getSrcRectDim();
389 utils::Whf whf = getSrcWhf();
390 d.y = compute(whf.h, d.y, d.h);
391 setSrcRectDim(d);
392}
393
394inline void MdpCtrl::overlayTransRot90()
395{
396 utils::Dim d = getSrcRectDim();
397 utils::Whf whf = getSrcWhf();
398 int tmp = d.x;
399 d.x = compute(whf.h,
400 d.y,
401 d.h);
402 d.y = tmp;
403 setSrcRectDim(d);
404 swapSrcWH();
405 swapSrcRectWH();
406}
407
Naseer Ahmed29a26812012-06-14 00:56:20 -0700408
409/////// MdpCtrl3D //////
410
411inline MdpCtrl3D::MdpCtrl3D() { reset(); }
412inline bool MdpCtrl3D::close() {
413 if (m3DOVInfo.is_3d) {
414 m3DOVInfo.is_3d = 0;
415 if(!mdp_wrapper::set3D(mFd.getFD(), m3DOVInfo)) {
416 ALOGE("MdpCtrl3D close failed set3D with 0");
417 return false;
418 }
419 }
420 reset();
421 return true;
422}
423inline void MdpCtrl3D::reset() {
424 utils::memset0(m3DOVInfo);
425}
426
427inline void MdpCtrl3D::setFd(int fd) {
428 mFd.copy(fd);
429 OVASSERT(mFd.valid(), "MdpCtrl3D setFd, FD should be valid");
430}
431
432inline void MdpCtrl3D::setWh(const utils::Whf& whf) {
433 // ignore fmt. Needed for useVirtualFB callflow
434 m3DOVInfo.width = whf.w;
435 m3DOVInfo.height = whf.h;
436}
437
438inline bool MdpCtrl3D::useVirtualFB() {
439 if(!m3DOVInfo.is_3d) {
440 m3DOVInfo.is_3d = 1;
441 if(!mdp_wrapper::set3D(mFd.getFD(), m3DOVInfo)) {
442 ALOGE("MdpCtrl3D close failed set3D with 0");
443 return false;
444 }
445 }
446 return true;
447}
448
449/////// MdpData //////
450
451inline MdpData::MdpData() { reset(); }
452
453inline MdpData::~MdpData() { close(); }
454
Naseer Ahmedf48aef62012-07-20 09:05:53 -0700455inline bool MdpData::init(uint32_t fbnum) {
456 // FD init
457 if(!utils::openDev(mFd, fbnum, Res::fbPath, O_RDWR)){
458 ALOGE("Ctrl failed to init fbnum=%d", fbnum);
Naseer Ahmed29a26812012-06-14 00:56:20 -0700459 return false;
460 }
461 return true;
462}
463
464inline void MdpData::reset() {
465 overlay::utils::memset0(mOvData);
466 mOvData.data.memory_id = -1;
467}
468
469inline bool MdpData::close() {
Naseer Ahmed29a26812012-06-14 00:56:20 -0700470 reset();
Saurabh Shah8e1ae952012-08-15 12:15:14 -0700471 return mFd.close();
Naseer Ahmed29a26812012-06-14 00:56:20 -0700472}
473
Naseer Ahmedf48aef62012-07-20 09:05:53 -0700474inline int MdpData::getSrcMemoryId() const { return mOvData.data.memory_id; }
Naseer Ahmed29a26812012-06-14 00:56:20 -0700475
Naseer Ahmedf48aef62012-07-20 09:05:53 -0700476inline void MdpData::setPipeId(int id) { mOvData.id = id; }
Naseer Ahmed29a26812012-06-14 00:56:20 -0700477
Naseer Ahmedf48aef62012-07-20 09:05:53 -0700478inline int MdpData::getPipeId() const { return mOvData.id; }
Naseer Ahmed29a26812012-06-14 00:56:20 -0700479
480inline int MdpData::getFd() const { return mFd.getFD(); }
481
Naseer Ahmedf48aef62012-07-20 09:05:53 -0700482inline bool MdpData::play(int fd, uint32_t offset) {
483 mOvData.data.memory_id = fd;
484 mOvData.data.offset = offset;
Naseer Ahmed29a26812012-06-14 00:56:20 -0700485 if(!mdp_wrapper::play(mFd.getFD(), mOvData)){
486 ALOGE("MdpData failed to play");
Naseer Ahmedf48aef62012-07-20 09:05:53 -0700487 dump();
Naseer Ahmed29a26812012-06-14 00:56:20 -0700488 return false;
489 }
490 return true;
491}
492
Naseer Ahmed29a26812012-06-14 00:56:20 -0700493} // overlay
494
495#endif // OVERLAY_MDP_H