blob: 0691dfc9bef41e7578c61548355f0e2499d11793 [file] [log] [blame]
Dileep Marchyaf9ba4852014-10-24 19:56:57 -07001/*
2* Copyright (c) 2014, The Linux Foundation. All rights reserved.
3*
4* Redistribution and use in source and binary forms, with or without modification, are permitted
5* provided that the following conditions are met:
6* * Redistributions of source code must retain the above copyright notice, this list of
7* conditions and the following disclaimer.
8* * Redistributions in binary form must reproduce the above copyright notice, this list of
9* conditions and the following disclaimer in the documentation and/or other materials provided
10* with the distribution.
11* * Neither the name of The Linux Foundation nor the names of its contributors may be used to
12* endorse or promote products derived from this software without specific prior written
13* permission.
14*
15* THIS SOFTWARE IS PROVIDED "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
16* LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
17* NON-INFRINGEMENT ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE
18* FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING,
19* BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS;
20* OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT,
21* STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
22* OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
23*/
24
25#ifndef __DEBUG_H__
26#define __DEBUG_H__
27
Dileep Marchyab61346f2014-11-06 14:36:19 -080028#ifndef SDE_LOG_TAG
29#define SDE_LOG_TAG kLogTagNone
30#endif
31
32#ifndef SDE_MODULE_NAME
33#define SDE_MODULE_NAME "SDE"
34#endif
35
36#define DLOG(method, format, ...) Debug::method(SDE_LOG_TAG, SDE_MODULE_NAME ": " format, \
37 ##__VA_ARGS__)
38
39// SDE_LOG_TAG and SDE_MODULE_NAME must be defined before #include this header file in
40// respective module, else default definitions are used.
41#define DLOGE(format, ...) DLOG(Error, format, ##__VA_ARGS__)
42#define DLOGW(format, ...) DLOG(Warning, format, ##__VA_ARGS__)
43#define DLOGI(format, ...) DLOG(Info, format, ##__VA_ARGS__)
44#define DLOGV(format, ...) DLOG(Verbose, format, ##__VA_ARGS__)
45
Dileep Marchyaf9ba4852014-10-24 19:56:57 -070046namespace sde {
47
48enum LogTag {
Ramkumar Radhakrishnanb36eee92014-11-03 19:39:11 -080049 kTagNone = 0, // Log tag name is not specified.
50 kTagCore, // Log is tagged for display core.
51 kTagStrategy, // Log is tagged for composition strategy.
Dileep Marchyaf9ba4852014-10-24 19:56:57 -070052};
53
54class Debug {
55 public:
56 // Log handlers
57 static void Error(const LogTag &tag, const char *format, ...);
58 static void Warning(const LogTag &tag, const char *format, ...);
59 static void Info(const LogTag &tag, const char *format, ...);
60 static void Verbose(const LogTag &tag, const char *format, ...);
61
62 // Debug properties
63 static bool IsVirtualDriver() { return debug_.virtual_driver_; }
64
65 private:
66 Debug();
67 bool virtual_driver_;
68 static Debug debug_;
69};
70
71} // namespace sde
72
73#endif // __DEBUG_H__
74