unplugged-system/frameworks/native/services/surfaceflinger/CompositionEngine/mediatek/MtkCeDebug.h

91 lines
3.3 KiB
C
Raw Normal View History

/* Copyright Statement:
*
* This software/firmware and related documentation ("MediaTek Software") are
* protected under relevant copyright laws. The information contained herein is
* confidential and proprietary to MediaTek Inc. and/or its licensors. Without
* the prior written permission of MediaTek inc. and/or its licensors, any
* reproduction, modification, use or disclosure of MediaTek Software, and
* information contained herein, in whole or in part, shall be strictly
* prohibited.
*
* MediaTek Inc. (C) 2018. All rights reserved.
*
* BY OPENING THIS FILE, RECEIVER HEREBY UNEQUIVOCALLY ACKNOWLEDGES AND AGREES
* THAT THE SOFTWARE/FIRMWARE AND ITS DOCUMENTATIONS ("MEDIATEK SOFTWARE")
* RECEIVED FROM MEDIATEK AND/OR ITS REPRESENTATIVES ARE PROVIDED TO RECEIVER
* ON AN "AS-IS" BASIS ONLY. MEDIATEK EXPRESSLY DISCLAIMS ANY AND ALL
* WARRANTIES, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE IMPLIED
* WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE OR
* NONINFRINGEMENT. NEITHER DOES MEDIATEK PROVIDE ANY WARRANTY WHATSOEVER WITH
* RESPECT TO THE SOFTWARE OF ANY THIRD PARTY WHICH MAY BE USED BY,
* INCORPORATED IN, OR SUPPLIED WITH THE MEDIATEK SOFTWARE, AND RECEIVER AGREES
* TO LOOK ONLY TO SUCH THIRD PARTY FOR ANY WARRANTY CLAIM RELATING THERETO.
* RECEIVER EXPRESSLY ACKNOWLEDGES THAT IT IS RECEIVER'S SOLE RESPONSIBILITY TO
* OBTAIN FROM ANY THIRD PARTY ALL PROPER LICENSES CONTAINED IN MEDIATEK
* SOFTWARE. MEDIATEK SHALL ALSO NOT BE RESPONSIBLE FOR ANY MEDIATEK SOFTWARE
* RELEASES MADE TO RECEIVER'S SPECIFICATION OR TO CONFORM TO A PARTICULAR
* STANDARD OR OPEN FORUM. RECEIVER'S SOLE AND EXCLUSIVE REMEDY AND MEDIATEK'S
* ENTIRE AND CUMULATIVE LIABILITY WITH RESPECT TO THE MEDIATEK SOFTWARE
* RELEASED HEREUNDER WILL BE, AT MEDIATEK'S OPTION, TO REVISE OR REPLACE THE
* MEDIATEK SOFTWARE AT ISSUE, OR REFUND ANY SOFTWARE LICENSE FEES OR SERVICE
* CHARGE PAID BY RECEIVER TO MEDIATEK FOR SUCH MEDIATEK SOFTWARE AT ISSUE.
*
* The following software/firmware and/or related documentation ("MediaTek
* Software") have been modified by MediaTek Inc. All revisions are subject to
* any receiver's applicable license agreements with MediaTek Inc.
*/
#pragma once
#ifdef MTK_SF_DEBUG_SUPPORT
#include <string>
#include <cutils/compiler.h> // For CC_[UN]LIKELY
#include <log/log.h>
#include <ui/Region.h>
#include <utils/Trace.h>
#include "SFProperty.h"
#include "PropertiesState.h"
#define LOG_MAX_SIZE 256
namespace android {
class Region;
namespace compositionengine {
void startLogRepaint(const std::string& debugName);
template<typename ...Args>
void logRepaint(const Region& region, const char* msg, Args... values)
{
if (msg == nullptr) {
return;
}
// debug log
char buf[LOG_MAX_SIZE] = {'\0'};
#pragma GCC diagnostic push
#pragma GCC diagnostic ignored "-Wformat-security"
if (snprintf(buf, LOG_MAX_SIZE, msg, values...) > 0) {
#pragma GCC diagnostic pop
#pragma push_macro("ATRACE_TAG")
#define ATRACE_TAG ATRACE_TAG_GRAPHICS
ATRACE_NAME(buf);
#pragma pop_macro("ATRACE_TAG")
}
if (CC_UNLIKELY(SFProperty::getInstance().getPropState()->mLogRepaint)) {
std::string str;
region.dump(str, "");
ALOGD("%s%s", buf, str.c_str());
}
}
}; // namespace compositionengine
}; // namespace android
#endif