M7350/base/services/surfaceflinger/DumpFrame.cpp
2024-09-09 08:52:07 +00:00

96 lines
3.3 KiB
C++

/*
* Copyright (c) 2011, The Linux Foundation. All rights reserved.
*
* Redistribution and use in source and binary forms, with or without
* modification, are permitted provided that the following conditions are
* met:
* * Redistributions of source code must retain the above copyright
* notice, this list of conditions and the following disclaimer.
* * Redistributions in binary form must reproduce the above
* copyright notice, this list of conditions and the following
* disclaimer in the documentation and/or other materials provided
* with the distribution.
* * Neither the name of The Linux Foundation nor the names of its
* contributors may be used to endorse or promote products derived
* from this software without specific prior written permission.
*
* THIS SOFTWARE IS PROVIDED "AS IS" AND ANY EXPRESS OR IMPLIED
* WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF
* MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NON-INFRINGEMENT
* ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS
* BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
* CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
* SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR
* BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY,
* WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE
* OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN
* IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
*/
#include "DumpFrame.h"
#include "Layer.h"
#include <cutils/properties.h>
#include <cutils/native_handle.h>
#include <ui/PixelFormat.h>
#include <utils/Errors.h>
#include <utils/Log.h>
#include "SurfaceFlinger.h"
#include "gralloc_priv.h"
namespace android {
/* actual dump */
void DumpFrame::dump(const Layer* const layer, const Region& clip)
{
// done dumping frames?, set dumpframe to 0
// user can go ahead and re-setprop
if(!mLeftFrames){
eval();
return;
}
if (layer->isNothingToUpdate())
return;
sp<GraphicBuffer> mybuffer(layer->getBypassBuffer());
void* vaddr=0;
uint32_t w = mybuffer->getWidth();
uint32_t h = mybuffer->getHeight();
Region region(Rect(0, 0, w, h));
LOGE_IF(!mDumpWH, "Layer=%x w=%d h=%d", reinterpret_cast<unsigned int>(layer) ,w, h);
mDumpWH=true;
SimpleLock l (mybuffer, region, vaddr);
if (l.res() != NO_ERROR) {
LOGE("dumpFrame can not lock. Will not dump");
return;
}
--mLeftFrames;
// stop dumpframe.
if(!mLeftFrames)
property_set("debug.dumpframe", "0");
char filename[256] = {0};
::memset(filename, 0, 256);
sprintf(filename, "/data/dump.%x-%d-%d.raw",
reinterpret_cast<unsigned int>(layer),
mSession, mCurrFrame++);
FILE* fp = fopen(filename, "w+");
if (fp == NULL) {
LOGE("dumpFrame cannot open file %s", filename);
return;
}
buffer_handle_t handle = (mybuffer->getNativeBuffer())->handle;
private_handle_t const* hnd = reinterpret_cast
<private_handle_t const*>(handle);
size_t size = hnd->size;
fwrite(vaddr, hnd->size, 1, fp);
fclose(fp);
}
}