Dileep Marchya | f9ba485 | 2014-10-24 19:56:57 -0700 | [diff] [blame] | 1 | /* |
Ramkumar Radhakrishnan | a35a273 | 2015-01-16 15:41:05 -0800 | [diff] [blame] | 2 | * Copyright (c) 2014 - 2015, The Linux Foundation. All rights reserved. |
Dileep Marchya | f9ba485 | 2014-10-24 19:56:57 -0700 | [diff] [blame] | 3 | * |
Ramkumar Radhakrishnan | 7ebf034 | 2015-01-20 15:00:46 -0800 | [diff] [blame] | 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. |
Dileep Marchya | f9ba485 | 2014-10-24 19:56:57 -0700 | [diff] [blame] | 16 | * |
Ramkumar Radhakrishnan | 7ebf034 | 2015-01-20 15:00:46 -0800 | [diff] [blame] | 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. |
Dileep Marchya | f9ba485 | 2014-10-24 19:56:57 -0700 | [diff] [blame] | 28 | */ |
| 29 | |
| 30 | #ifndef __DEBUG_H__ |
| 31 | #define __DEBUG_H__ |
| 32 | |
Manoj Kumar AVM | 4746f24 | 2015-01-06 20:25:22 -0800 | [diff] [blame] | 33 | #include <stdint.h> |
Dileep Marchya | 73d002e | 2015-05-08 18:58:33 -0700 | [diff] [blame] | 34 | #include <core/sdm_types.h> |
Ramkumar Radhakrishnan | 7ebf034 | 2015-01-20 15:00:46 -0800 | [diff] [blame] | 35 | #include <core/debug_interface.h> |
Dileep Marchya | b61346f | 2014-11-06 14:36:19 -0800 | [diff] [blame] | 36 | |
Ramkumar Radhakrishnan | 7ebf034 | 2015-01-20 15:00:46 -0800 | [diff] [blame] | 37 | #define DLOG(tag, method, format, ...) Debug::Get()->method(tag, __CLASS__ "::%s: " format, \ |
| 38 | __FUNCTION__, ##__VA_ARGS__) |
Dileep Marchya | b61346f | 2014-11-06 14:36:19 -0800 | [diff] [blame] | 39 | |
Dileep Marchya | 3ffb470 | 2014-12-04 16:31:37 -0800 | [diff] [blame] | 40 | #define DLOGE_IF(tag, format, ...) DLOG(tag, Error, format, ##__VA_ARGS__) |
| 41 | #define DLOGW_IF(tag, format, ...) DLOG(tag, Warning, format, ##__VA_ARGS__) |
| 42 | #define DLOGI_IF(tag, format, ...) DLOG(tag, Info, format, ##__VA_ARGS__) |
| 43 | #define DLOGV_IF(tag, format, ...) DLOG(tag, Verbose, format, ##__VA_ARGS__) |
Dileep Marchya | b61346f | 2014-11-06 14:36:19 -0800 | [diff] [blame] | 44 | |
Dileep Marchya | 3ffb470 | 2014-12-04 16:31:37 -0800 | [diff] [blame] | 45 | #define DLOGE(format, ...) DLOGE_IF(kTagNone, format, ##__VA_ARGS__) |
| 46 | #define DLOGW(format, ...) DLOGW_IF(kTagNone, format, ##__VA_ARGS__) |
| 47 | #define DLOGI(format, ...) DLOGI_IF(kTagNone, format, ##__VA_ARGS__) |
| 48 | #define DLOGV(format, ...) DLOGV_IF(kTagNone, format, ##__VA_ARGS__) |
Dileep Marchya | b61346f | 2014-11-06 14:36:19 -0800 | [diff] [blame] | 49 | |
Ramkumar Radhakrishnan | 7ebf034 | 2015-01-20 15:00:46 -0800 | [diff] [blame] | 50 | #define DTRACE_BEGIN(custom_string) Debug::Get()->BeginTrace(__CLASS__, __FUNCTION__, custom_string) |
| 51 | #define DTRACE_END() Debug::Get()->EndTrace() |
| 52 | #define DTRACE_SCOPED() ScopeTracer <Debug> scope_tracer(__CLASS__, __FUNCTION__) |
| 53 | |
Dileep Marchya | 73d002e | 2015-05-08 18:58:33 -0700 | [diff] [blame] | 54 | namespace sdm { |
Dileep Marchya | f9ba485 | 2014-10-24 19:56:57 -0700 | [diff] [blame] | 55 | |
Dileep Marchya | f9ba485 | 2014-10-24 19:56:57 -0700 | [diff] [blame] | 56 | class Debug { |
| 57 | public: |
Ramkumar Radhakrishnan | 7ebf034 | 2015-01-20 15:00:46 -0800 | [diff] [blame] | 58 | static inline void SetDebugHandler(DebugHandler *debug_handler) { |
| 59 | debug_.debug_handler_ = debug_handler; |
| 60 | } |
| 61 | static inline DebugHandler* Get() { return debug_.debug_handler_; } |
Manoj Kumar AVM | 4746f24 | 2015-01-06 20:25:22 -0800 | [diff] [blame] | 62 | static uint32_t GetSimulationFlag(); |
Arun Kumar K.R | ecae9b2 | 2015-01-07 20:59:16 -0800 | [diff] [blame] | 63 | static uint32_t GetHDMIResolution(); |
Ramkumar Radhakrishnan | a35a273 | 2015-01-16 15:41:05 -0800 | [diff] [blame] | 64 | static uint32_t GetIdleTimeoutMs(); |
Ken Zhang | e2605ea | 2015-02-02 10:17:45 -0500 | [diff] [blame] | 65 | static bool IsRotatorDownScaleDisabled(); |
| 66 | static bool IsDecimationDisabled(); |
Manoj Kumar AVM | 2405ce5 | 2015-04-02 23:13:19 -0700 | [diff] [blame] | 67 | static bool IsPartialUpdateEnabled(); |
Dileep Marchya | f9ba485 | 2014-10-24 19:56:57 -0700 | [diff] [blame] | 68 | |
| 69 | private: |
| 70 | Debug(); |
Dileep Marchya | 3ffb470 | 2014-12-04 16:31:37 -0800 | [diff] [blame] | 71 | |
Dileep Marchya | 73d002e | 2015-05-08 18:58:33 -0700 | [diff] [blame] | 72 | // By default, drop any log messages/traces coming from Display manager. It will be overriden by |
| 73 | // Display manager client when core is successfully initialized. |
Ramkumar Radhakrishnan | 7ebf034 | 2015-01-20 15:00:46 -0800 | [diff] [blame] | 74 | class DefaultDebugHandler : public DebugHandler { |
Dileep Marchya | 3ffb470 | 2014-12-04 16:31:37 -0800 | [diff] [blame] | 75 | public: |
Ramkumar Radhakrishnan | 7ebf034 | 2015-01-20 15:00:46 -0800 | [diff] [blame] | 76 | virtual void Error(DebugTag /*tag*/, const char */*format*/, ...) { } |
| 77 | virtual void Warning(DebugTag /*tag*/, const char */*format*/, ...) { } |
| 78 | virtual void Info(DebugTag /*tag*/, const char */*format*/, ...) { } |
| 79 | virtual void Verbose(DebugTag /*tag*/, const char */*format*/, ...) { } |
| 80 | virtual void BeginTrace(const char */*class_name*/, const char */*function_name*/, |
| 81 | const char */*custom_string*/) { } |
| 82 | virtual void EndTrace() { } |
Dileep Marchya | e2a5908 | 2015-05-21 13:29:05 -0700 | [diff] [blame^] | 83 | virtual DisplayError GetProperty(const char *property_name, int *value) { |
| 84 | return kErrorNotSupported; |
| 85 | } |
Dileep Marchya | 3ffb470 | 2014-12-04 16:31:37 -0800 | [diff] [blame] | 86 | }; |
| 87 | |
Ramkumar Radhakrishnan | 7ebf034 | 2015-01-20 15:00:46 -0800 | [diff] [blame] | 88 | DefaultDebugHandler default_debug_handler_; |
| 89 | DebugHandler *debug_handler_; |
Dileep Marchya | f9ba485 | 2014-10-24 19:56:57 -0700 | [diff] [blame] | 90 | static Debug debug_; |
| 91 | }; |
| 92 | |
Dileep Marchya | 73d002e | 2015-05-08 18:58:33 -0700 | [diff] [blame] | 93 | } // namespace sdm |
Dileep Marchya | f9ba485 | 2014-10-24 19:56:57 -0700 | [diff] [blame] | 94 | |
| 95 | #endif // __DEBUG_H__ |
| 96 | |