1 /* 2 * Copyright (c) 2014 - 2018, 2020 The Linux Foundation. All rights reserved. 3 * 4 * Redistribution and use in source and binary forms, with or without 5 * modification, are permitted provided that the following conditions are 6 * met: 7 * * Redistributions of source code must retain the above copyright 8 * notice, this list of conditions and the following disclaimer. 9 * * Redistributions in binary form must reproduce the above 10 * copyright notice, this list of conditions and the following 11 * disclaimer in the documentation and/or other materials provided 12 * with the distribution. 13 * * Neither the name of The Linux Foundation nor the names of its 14 * contributors may be used to endorse or promote products derived 15 * from this software without specific prior written permission. 16 * 17 * THIS SOFTWARE IS PROVIDED "AS IS" AND ANY EXPRESS OR IMPLIED 18 * WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF 19 * MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NON-INFRINGEMENT 20 * ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS 21 * BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR 22 * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF 23 * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR 24 * BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, 25 * WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE 26 * OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN 27 * IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. 28 */ 29 30 #ifndef __HWC_DEBUGGER_H__ 31 #define __HWC_DEBUGGER_H__ 32 33 #define ATRACE_TAG (ATRACE_TAG_GRAPHICS | ATRACE_TAG_HAL) 34 35 #include <core/sdm_types.h> 36 #include <debug_handler.h> 37 #include <log/log.h> 38 #include <utils/Trace.h> 39 #include <bitset> 40 41 namespace sdm { 42 43 using display::DebugHandler; 44 45 class HWCDebugHandler : public DebugHandler { 46 public: 47 HWCDebugHandler(); Get()48 static inline DebugHandler* Get() { return &debug_handler_; } DumpDir()49 static const char* DumpDir() { return "/data/vendor/display"; } 50 51 static void DebugAll(bool enable, int verbose_level); 52 static void DebugResources(bool enable, int verbose_level); 53 static void DebugStrategy(bool enable, int verbose_level); 54 static void DebugCompManager(bool enable, int verbose_level); 55 static void DebugDriverConfig(bool enable, int verbose_level); 56 static void DebugRotator(bool enable, int verbose_level); 57 static void DebugScalar(bool enable, int verbose_level); 58 static void DebugQdcm(bool enable, int verbose_level); 59 static void DebugClient(bool enable, int verbose_level); 60 static void DebugQos(bool enable, int verbose_level); 61 static void DebugDisplay(bool enable, int verbose_level); 62 static int GetIdleTimeoutMs(); 63 64 virtual void Error(const char *fmt, ...) __attribute__((format(printf, 2, 3))); 65 virtual void Warning(const char *fmt, ...) __attribute__((format(printf, 2, 3))); 66 virtual void Info(const char *fmt, ...) __attribute__((format(printf, 2, 3))); 67 virtual void Debug(const char *fmt, ...) __attribute__((format(printf, 2, 3))); 68 virtual void Verbose(const char *fmt, ...) __attribute__((format(printf, 2, 3))); 69 virtual void BeginTrace(const char *class_name, const char *function_name, 70 const char *custom_string); 71 virtual void EndTrace(); 72 virtual int GetProperty(const char *property_name, int *value); 73 virtual int GetProperty(const char *property_name, char *value); 74 75 private: 76 static HWCDebugHandler debug_handler_; 77 std::bitset<32> log_mask_; 78 int32_t verbose_level_; 79 }; 80 81 } // namespace sdm 82 83 #endif // __HWC_DEBUGGER_H__ 84 85