overlayMdssRot.cpp revision a34d74561f653dd083c7f3765fce719eafb88521
1bf4ef717fabff427327613de76b69f964c51484dSaurabh Shah/* 2bf4ef717fabff427327613de76b69f964c51484dSaurabh Shah* Copyright (C) 2008 The Android Open Source Project 3bf4ef717fabff427327613de76b69f964c51484dSaurabh Shah* Copyright (c) 2010-2012, Code Aurora Forum. All rights reserved. 4bf4ef717fabff427327613de76b69f964c51484dSaurabh Shah* 5bf4ef717fabff427327613de76b69f964c51484dSaurabh Shah* Licensed under the Apache License, Version 2.0 (the "License"); 6bf4ef717fabff427327613de76b69f964c51484dSaurabh Shah* you may not use this file except in compliance with the License. 7bf4ef717fabff427327613de76b69f964c51484dSaurabh Shah* You may obtain a copy of the License at 8bf4ef717fabff427327613de76b69f964c51484dSaurabh Shah* 9bf4ef717fabff427327613de76b69f964c51484dSaurabh Shah* http://www.apache.org/licenses/LICENSE-2.0 10bf4ef717fabff427327613de76b69f964c51484dSaurabh Shah* 11bf4ef717fabff427327613de76b69f964c51484dSaurabh Shah* Unless required by applicable law or agreed to in writing, software 12bf4ef717fabff427327613de76b69f964c51484dSaurabh Shah* distributed under the License is distributed on an "AS IS" BASIS, 13bf4ef717fabff427327613de76b69f964c51484dSaurabh Shah* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. 14bf4ef717fabff427327613de76b69f964c51484dSaurabh Shah* See the License for the specific language governing permissions and 15bf4ef717fabff427327613de76b69f964c51484dSaurabh Shah* limitations under the License. 16bf4ef717fabff427327613de76b69f964c51484dSaurabh Shah*/ 17bf4ef717fabff427327613de76b69f964c51484dSaurabh Shah 18bf4ef717fabff427327613de76b69f964c51484dSaurabh Shah#include "overlayUtils.h" 19bf4ef717fabff427327613de76b69f964c51484dSaurabh Shah#include "overlayRotator.h" 20bf4ef717fabff427327613de76b69f964c51484dSaurabh Shah 21a34d74561f653dd083c7f3765fce719eafb88521Naseer Ahmed#ifndef MDSS_MDP_ROT_ONLY 22a34d74561f653dd083c7f3765fce719eafb88521Naseer Ahmed#define MDSS_MDP_ROT_ONLY 0x80 23a34d74561f653dd083c7f3765fce719eafb88521Naseer Ahmed#endif 24a34d74561f653dd083c7f3765fce719eafb88521Naseer Ahmed 25bf4ef717fabff427327613de76b69f964c51484dSaurabh Shahnamespace ovutils = overlay::utils; 26bf4ef717fabff427327613de76b69f964c51484dSaurabh Shah 27bf4ef717fabff427327613de76b69f964c51484dSaurabh Shahnamespace overlay { 28bf4ef717fabff427327613de76b69f964c51484dSaurabh Shah 29bf4ef717fabff427327613de76b69f964c51484dSaurabh Shahbool MdssRot::init() { 30bf4ef717fabff427327613de76b69f964c51484dSaurabh Shah if(!utils::openDev(mFd, 0, Res::fbPath, O_RDWR)) { 31bf4ef717fabff427327613de76b69f964c51484dSaurabh Shah ALOGE("MdssRot failed to init fb0"); 32bf4ef717fabff427327613de76b69f964c51484dSaurabh Shah return false; 33bf4ef717fabff427327613de76b69f964c51484dSaurabh Shah } 34bf4ef717fabff427327613de76b69f964c51484dSaurabh Shah return true; 35bf4ef717fabff427327613de76b69f964c51484dSaurabh Shah} 36bf4ef717fabff427327613de76b69f964c51484dSaurabh Shah 37bf4ef717fabff427327613de76b69f964c51484dSaurabh Shahvoid MdssRot::setSource(const overlay::utils::Whf& awhf) { 38bf4ef717fabff427327613de76b69f964c51484dSaurabh Shah utils::Whf whf(awhf); 39bf4ef717fabff427327613de76b69f964c51484dSaurabh Shah 40bf4ef717fabff427327613de76b69f964c51484dSaurabh Shah mRotInfo.src.format = whf.format; 41bf4ef717fabff427327613de76b69f964c51484dSaurabh Shah if(whf.format == MDP_Y_CRCB_H2V2_TILE || 42bf4ef717fabff427327613de76b69f964c51484dSaurabh Shah whf.format == MDP_Y_CBCR_H2V2_TILE) { 43bf4ef717fabff427327613de76b69f964c51484dSaurabh Shah whf.w = utils::alignup(awhf.w, 64); 44bf4ef717fabff427327613de76b69f964c51484dSaurabh Shah whf.h = utils::alignup(awhf.h, 32); 45bf4ef717fabff427327613de76b69f964c51484dSaurabh Shah } 46bf4ef717fabff427327613de76b69f964c51484dSaurabh Shah 47bf4ef717fabff427327613de76b69f964c51484dSaurabh Shah mRotInfo.src.width = whf.w; 48bf4ef717fabff427327613de76b69f964c51484dSaurabh Shah mRotInfo.src.height = whf.h; 49bf4ef717fabff427327613de76b69f964c51484dSaurabh Shah 50bf4ef717fabff427327613de76b69f964c51484dSaurabh Shah mRotInfo.src_rect.w = whf.w; 51bf4ef717fabff427327613de76b69f964c51484dSaurabh Shah mRotInfo.src_rect.h = whf.h; 52bf4ef717fabff427327613de76b69f964c51484dSaurabh Shah 53bf4ef717fabff427327613de76b69f964c51484dSaurabh Shah mRotInfo.dst_rect.w = whf.w; 54bf4ef717fabff427327613de76b69f964c51484dSaurabh Shah mRotInfo.dst_rect.h = whf.h; 55bf4ef717fabff427327613de76b69f964c51484dSaurabh Shah 56bf4ef717fabff427327613de76b69f964c51484dSaurabh Shah mBufSize = awhf.size; 57bf4ef717fabff427327613de76b69f964c51484dSaurabh Shah} 58bf4ef717fabff427327613de76b69f964c51484dSaurabh Shah 59bf4ef717fabff427327613de76b69f964c51484dSaurabh Shahvoid MdssRot::setFlags(const utils::eMdpFlags& flags) { 60bf4ef717fabff427327613de76b69f964c51484dSaurabh Shah // TODO 61bf4ef717fabff427327613de76b69f964c51484dSaurabh Shah} 62bf4ef717fabff427327613de76b69f964c51484dSaurabh Shah 63bf4ef717fabff427327613de76b69f964c51484dSaurabh Shahvoid MdssRot::setTransform(const utils::eTransform& rot, const bool& rotUsed) 64bf4ef717fabff427327613de76b69f964c51484dSaurabh Shah{ 65bf4ef717fabff427327613de76b69f964c51484dSaurabh Shah int flags = utils::getMdpOrient(rot); 66bf4ef717fabff427327613de76b69f964c51484dSaurabh Shah if (flags != -1) 67bf4ef717fabff427327613de76b69f964c51484dSaurabh Shah setRotations(flags); 68bf4ef717fabff427327613de76b69f964c51484dSaurabh Shah //getMdpOrient will switch the flips if the source is 90 rotated. 69bf4ef717fabff427327613de76b69f964c51484dSaurabh Shah //Clients in Android dont factor in 90 rotation while deciding the flip. 70bf4ef717fabff427327613de76b69f964c51484dSaurabh Shah mOrientation = static_cast<utils::eTransform>(flags); 71bf4ef717fabff427327613de76b69f964c51484dSaurabh Shah ALOGE_IF(DEBUG_OVERLAY, "%s: rot=%d", __FUNCTION__, flags); 72bf4ef717fabff427327613de76b69f964c51484dSaurabh Shah 73bf4ef717fabff427327613de76b69f964c51484dSaurabh Shah setDisable(); 74bf4ef717fabff427327613de76b69f964c51484dSaurabh Shah if(rotUsed) { 75bf4ef717fabff427327613de76b69f964c51484dSaurabh Shah setEnable(); 76bf4ef717fabff427327613de76b69f964c51484dSaurabh Shah } 77bf4ef717fabff427327613de76b69f964c51484dSaurabh Shah} 78bf4ef717fabff427327613de76b69f964c51484dSaurabh Shah 79bf4ef717fabff427327613de76b69f964c51484dSaurabh Shahvoid MdssRot::doTransform() { 80bf4ef717fabff427327613de76b69f964c51484dSaurabh Shah if(mOrientation & utils::OVERLAY_TRANSFORM_ROT_90) 81bf4ef717fabff427327613de76b69f964c51484dSaurabh Shah utils::swap(mRotInfo.dst_rect.w, mRotInfo.dst_rect.h); 82bf4ef717fabff427327613de76b69f964c51484dSaurabh Shah} 83bf4ef717fabff427327613de76b69f964c51484dSaurabh Shah 84bf4ef717fabff427327613de76b69f964c51484dSaurabh Shahbool MdssRot::commit() { 85bf4ef717fabff427327613de76b69f964c51484dSaurabh Shah doTransform(); 86bf4ef717fabff427327613de76b69f964c51484dSaurabh Shah mRotInfo.flags |= MDSS_MDP_ROT_ONLY; 87bf4ef717fabff427327613de76b69f964c51484dSaurabh Shah if(!overlay::mdp_wrapper::setOverlay(mFd.getFD(), mRotInfo)) { 88bf4ef717fabff427327613de76b69f964c51484dSaurabh Shah ALOGE("MdssRot commit failed!"); 89bf4ef717fabff427327613de76b69f964c51484dSaurabh Shah dump(); 90bf4ef717fabff427327613de76b69f964c51484dSaurabh Shah return false; 91bf4ef717fabff427327613de76b69f964c51484dSaurabh Shah } 92bf4ef717fabff427327613de76b69f964c51484dSaurabh Shah mRotData.id = mRotInfo.id; 93bf4ef717fabff427327613de76b69f964c51484dSaurabh Shah return true; 94bf4ef717fabff427327613de76b69f964c51484dSaurabh Shah} 95bf4ef717fabff427327613de76b69f964c51484dSaurabh Shah 96bf4ef717fabff427327613de76b69f964c51484dSaurabh Shahbool MdssRot::queueBuffer(int fd, uint32_t offset) { 97bf4ef717fabff427327613de76b69f964c51484dSaurabh Shah if(enabled()) { 98bf4ef717fabff427327613de76b69f964c51484dSaurabh Shah mRotData.data.memory_id = fd; 99bf4ef717fabff427327613de76b69f964c51484dSaurabh Shah mRotData.data.offset = offset; 100bf4ef717fabff427327613de76b69f964c51484dSaurabh Shah 101bf4ef717fabff427327613de76b69f964c51484dSaurabh Shah remap(RotMem::Mem::ROT_NUM_BUFS); 102bf4ef717fabff427327613de76b69f964c51484dSaurabh Shah OVASSERT(mMem.curr().m.numBufs(), "queueBuffer numbufs is 0"); 103bf4ef717fabff427327613de76b69f964c51484dSaurabh Shah 104bf4ef717fabff427327613de76b69f964c51484dSaurabh Shah mRotData.dst_data.offset = 105bf4ef717fabff427327613de76b69f964c51484dSaurabh Shah mMem.curr().mRotOffset[mMem.curr().mCurrOffset]; 106bf4ef717fabff427327613de76b69f964c51484dSaurabh Shah mMem.curr().mCurrOffset = 107bf4ef717fabff427327613de76b69f964c51484dSaurabh Shah (mMem.curr().mCurrOffset + 1) % mMem.curr().m.numBufs(); 108bf4ef717fabff427327613de76b69f964c51484dSaurabh Shah 109bf4ef717fabff427327613de76b69f964c51484dSaurabh Shah if(!overlay::mdp_wrapper::play(mFd.getFD(), mRotData)) { 110bf4ef717fabff427327613de76b69f964c51484dSaurabh Shah ALOGE("MdssRot play failed!"); 111bf4ef717fabff427327613de76b69f964c51484dSaurabh Shah dump(); 112bf4ef717fabff427327613de76b69f964c51484dSaurabh Shah return false; 113bf4ef717fabff427327613de76b69f964c51484dSaurabh Shah } 114bf4ef717fabff427327613de76b69f964c51484dSaurabh Shah 115bf4ef717fabff427327613de76b69f964c51484dSaurabh Shah // if the prev mem is valid, we need to close 116bf4ef717fabff427327613de76b69f964c51484dSaurabh Shah if(mMem.prev().valid()) { 117bf4ef717fabff427327613de76b69f964c51484dSaurabh Shah // FIXME if no wait for vsync the above 118bf4ef717fabff427327613de76b69f964c51484dSaurabh Shah // play will return immediatly and might cause 119bf4ef717fabff427327613de76b69f964c51484dSaurabh Shah // tearing when prev.close is called. 120bf4ef717fabff427327613de76b69f964c51484dSaurabh Shah if(!mMem.prev().close()) { 121bf4ef717fabff427327613de76b69f964c51484dSaurabh Shah ALOGE("%s error in closing prev rot mem", __FUNCTION__); 122bf4ef717fabff427327613de76b69f964c51484dSaurabh Shah return false; 123bf4ef717fabff427327613de76b69f964c51484dSaurabh Shah } 124bf4ef717fabff427327613de76b69f964c51484dSaurabh Shah } 125bf4ef717fabff427327613de76b69f964c51484dSaurabh Shah } 126bf4ef717fabff427327613de76b69f964c51484dSaurabh Shah return true; 127bf4ef717fabff427327613de76b69f964c51484dSaurabh Shah} 128bf4ef717fabff427327613de76b69f964c51484dSaurabh Shah 129bf4ef717fabff427327613de76b69f964c51484dSaurabh Shahbool MdssRot::open_i(uint32_t numbufs, uint32_t bufsz) 130bf4ef717fabff427327613de76b69f964c51484dSaurabh Shah{ 131bf4ef717fabff427327613de76b69f964c51484dSaurabh Shah OvMem mem; 132bf4ef717fabff427327613de76b69f964c51484dSaurabh Shah OVASSERT(MAP_FAILED == mem.addr(), "MAP failed in open_i"); 133bf4ef717fabff427327613de76b69f964c51484dSaurabh Shah 134bf4ef717fabff427327613de76b69f964c51484dSaurabh Shah if(!mem.open(numbufs, bufsz, false)){ // TODO: secure for badger 135bf4ef717fabff427327613de76b69f964c51484dSaurabh Shah ALOGE("%s: Failed to open", __func__); 136bf4ef717fabff427327613de76b69f964c51484dSaurabh Shah mem.close(); 137bf4ef717fabff427327613de76b69f964c51484dSaurabh Shah return false; 138bf4ef717fabff427327613de76b69f964c51484dSaurabh Shah } 139bf4ef717fabff427327613de76b69f964c51484dSaurabh Shah 140bf4ef717fabff427327613de76b69f964c51484dSaurabh Shah OVASSERT(MAP_FAILED != mem.addr(), "MAP failed"); 141bf4ef717fabff427327613de76b69f964c51484dSaurabh Shah OVASSERT(mem.getFD() != -1, "getFd is -1"); 142bf4ef717fabff427327613de76b69f964c51484dSaurabh Shah 143bf4ef717fabff427327613de76b69f964c51484dSaurabh Shah mRotData.dst_data.memory_id = mem.getFD(); 144bf4ef717fabff427327613de76b69f964c51484dSaurabh Shah mRotData.dst_data.offset = 0; 145bf4ef717fabff427327613de76b69f964c51484dSaurabh Shah mMem.curr().m = mem; 146bf4ef717fabff427327613de76b69f964c51484dSaurabh Shah return true; 147bf4ef717fabff427327613de76b69f964c51484dSaurabh Shah} 148bf4ef717fabff427327613de76b69f964c51484dSaurabh Shah 149bf4ef717fabff427327613de76b69f964c51484dSaurabh Shahbool MdssRot::remap(uint32_t numbufs) { 150bf4ef717fabff427327613de76b69f964c51484dSaurabh Shah // if current size changed, remap 151bf4ef717fabff427327613de76b69f964c51484dSaurabh Shah if(mBufSize == mMem.curr().size()) { 152bf4ef717fabff427327613de76b69f964c51484dSaurabh Shah ALOGE_IF(DEBUG_OVERLAY, "%s: same size %d", __FUNCTION__, mBufSize); 153bf4ef717fabff427327613de76b69f964c51484dSaurabh Shah return true; 154bf4ef717fabff427327613de76b69f964c51484dSaurabh Shah } 155bf4ef717fabff427327613de76b69f964c51484dSaurabh Shah 156bf4ef717fabff427327613de76b69f964c51484dSaurabh Shah ALOGE_IF(DEBUG_OVERLAY, "%s: size changed - remapping", __FUNCTION__); 157bf4ef717fabff427327613de76b69f964c51484dSaurabh Shah OVASSERT(!mMem.prev().valid(), "Prev should not be valid"); 158bf4ef717fabff427327613de76b69f964c51484dSaurabh Shah 159bf4ef717fabff427327613de76b69f964c51484dSaurabh Shah // ++mMem will make curr to be prev, and prev will be curr 160bf4ef717fabff427327613de76b69f964c51484dSaurabh Shah ++mMem; 161bf4ef717fabff427327613de76b69f964c51484dSaurabh Shah if(!open_i(numbufs, mBufSize)) { 162bf4ef717fabff427327613de76b69f964c51484dSaurabh Shah ALOGE("%s Error could not open", __FUNCTION__); 163bf4ef717fabff427327613de76b69f964c51484dSaurabh Shah return false; 164bf4ef717fabff427327613de76b69f964c51484dSaurabh Shah } 165bf4ef717fabff427327613de76b69f964c51484dSaurabh Shah for (uint32_t i = 0; i < numbufs; ++i) { 166bf4ef717fabff427327613de76b69f964c51484dSaurabh Shah mMem.curr().mRotOffset[i] = i * mBufSize; 167bf4ef717fabff427327613de76b69f964c51484dSaurabh Shah } 168bf4ef717fabff427327613de76b69f964c51484dSaurabh Shah return true; 169bf4ef717fabff427327613de76b69f964c51484dSaurabh Shah} 170bf4ef717fabff427327613de76b69f964c51484dSaurabh Shah 171bf4ef717fabff427327613de76b69f964c51484dSaurabh Shahbool MdssRot::close() { 172bf4ef717fabff427327613de76b69f964c51484dSaurabh Shah bool success = true; 173bf4ef717fabff427327613de76b69f964c51484dSaurabh Shah if(mFd.valid() && (getSessId() > 0)) { 174bf4ef717fabff427327613de76b69f964c51484dSaurabh Shah if(!mdp_wrapper::unsetOverlay(mFd.getFD(), getSessId())) { 175bf4ef717fabff427327613de76b69f964c51484dSaurabh Shah ALOGE("MdssRot::close unsetOverlay failed, fd=%d sessId=%d", 176bf4ef717fabff427327613de76b69f964c51484dSaurabh Shah mFd.getFD(), getSessId()); 177bf4ef717fabff427327613de76b69f964c51484dSaurabh Shah success = false; 178bf4ef717fabff427327613de76b69f964c51484dSaurabh Shah } 179bf4ef717fabff427327613de76b69f964c51484dSaurabh Shah } 180bf4ef717fabff427327613de76b69f964c51484dSaurabh Shah 181bf4ef717fabff427327613de76b69f964c51484dSaurabh Shah if (!mFd.close()) { 182bf4ef717fabff427327613de76b69f964c51484dSaurabh Shah ALOGE("Mdss Rot error closing fd"); 183bf4ef717fabff427327613de76b69f964c51484dSaurabh Shah success = false; 184bf4ef717fabff427327613de76b69f964c51484dSaurabh Shah } 185bf4ef717fabff427327613de76b69f964c51484dSaurabh Shah if (!mMem.close()) { 186bf4ef717fabff427327613de76b69f964c51484dSaurabh Shah ALOGE("Mdss Rot error closing mem"); 187bf4ef717fabff427327613de76b69f964c51484dSaurabh Shah success = false; 188bf4ef717fabff427327613de76b69f964c51484dSaurabh Shah } 189bf4ef717fabff427327613de76b69f964c51484dSaurabh Shah reset(); 190bf4ef717fabff427327613de76b69f964c51484dSaurabh Shah return success; 191bf4ef717fabff427327613de76b69f964c51484dSaurabh Shah} 192bf4ef717fabff427327613de76b69f964c51484dSaurabh Shah 193bf4ef717fabff427327613de76b69f964c51484dSaurabh Shahvoid MdssRot::reset() { 194bf4ef717fabff427327613de76b69f964c51484dSaurabh Shah ovutils::memset0(mRotInfo); 195bf4ef717fabff427327613de76b69f964c51484dSaurabh Shah ovutils::memset0(mRotData); 196bf4ef717fabff427327613de76b69f964c51484dSaurabh Shah mRotData.data.memory_id = -1; 197bf4ef717fabff427327613de76b69f964c51484dSaurabh Shah mRotInfo.id = MSMFB_NEW_REQUEST; 198bf4ef717fabff427327613de76b69f964c51484dSaurabh Shah ovutils::memset0(mMem.curr().mRotOffset); 199bf4ef717fabff427327613de76b69f964c51484dSaurabh Shah ovutils::memset0(mMem.prev().mRotOffset); 200bf4ef717fabff427327613de76b69f964c51484dSaurabh Shah mMem.curr().mCurrOffset = 0; 201bf4ef717fabff427327613de76b69f964c51484dSaurabh Shah mMem.prev().mCurrOffset = 0; 202bf4ef717fabff427327613de76b69f964c51484dSaurabh Shah mBufSize = 0; 203bf4ef717fabff427327613de76b69f964c51484dSaurabh Shah mOrientation = utils::OVERLAY_TRANSFORM_0; 204bf4ef717fabff427327613de76b69f964c51484dSaurabh Shah} 205bf4ef717fabff427327613de76b69f964c51484dSaurabh Shah 206bf4ef717fabff427327613de76b69f964c51484dSaurabh Shahvoid MdssRot::dump() const { 207bf4ef717fabff427327613de76b69f964c51484dSaurabh Shah ALOGE("== Dump MdssRot start =="); 208bf4ef717fabff427327613de76b69f964c51484dSaurabh Shah mFd.dump(); 209bf4ef717fabff427327613de76b69f964c51484dSaurabh Shah mMem.curr().m.dump(); 210bf4ef717fabff427327613de76b69f964c51484dSaurabh Shah mdp_wrapper::dump("mRotInfo", mRotInfo); 211bf4ef717fabff427327613de76b69f964c51484dSaurabh Shah mdp_wrapper::dump("mRotData", mRotData); 212bf4ef717fabff427327613de76b69f964c51484dSaurabh Shah ALOGE("== Dump MdssRot end =="); 213bf4ef717fabff427327613de76b69f964c51484dSaurabh Shah} 214bf4ef717fabff427327613de76b69f964c51484dSaurabh Shah 215bf4ef717fabff427327613de76b69f964c51484dSaurabh Shah} // namespace overlay 216