Abraham Marsen / Mbed 2 deprecated Jazz_Hands_Nordic

Dependencies:   mbed

Committer:
Grimmkey
Date:
Thu Apr 30 20:46:27 2015 +0000
Revision:
0:b8221deeaa87
Georgia Institute of Technology ECE 4180 Spring 2015 Jazz Hands project, Nordic nRF51822 half

Who changed what in which revision?

UserRevisionLine numberNew contents of line
Grimmkey 0:b8221deeaa87 1 /**
Grimmkey 0:b8221deeaa87 2 * Copyright 2014 Nordic Semiconductor
Grimmkey 0:b8221deeaa87 3 *
Grimmkey 0:b8221deeaa87 4 * Licensed under the Apache License, Version 2.0 (the "License");
Grimmkey 0:b8221deeaa87 5 * you may not use this file except in compliance with the License.
Grimmkey 0:b8221deeaa87 6 * You may obtain a copy of the License at
Grimmkey 0:b8221deeaa87 7 *
Grimmkey 0:b8221deeaa87 8 * http://www.apache.org/licenses/LICENSE-2.0
Grimmkey 0:b8221deeaa87 9 *
Grimmkey 0:b8221deeaa87 10 * Unless required by applicable law or agreed to in writing, software
Grimmkey 0:b8221deeaa87 11 * distributed under the License is distributed on an "AS IS" BASIS,
Grimmkey 0:b8221deeaa87 12 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
Grimmkey 0:b8221deeaa87 13 * See the License for the specific language governing permissions and
Grimmkey 0:b8221deeaa87 14 * limitations under the License
Grimmkey 0:b8221deeaa87 15 */
Grimmkey 0:b8221deeaa87 16
Grimmkey 0:b8221deeaa87 17 #ifndef __LOG__H__
Grimmkey 0:b8221deeaa87 18 #define __LOG__H__
Grimmkey 0:b8221deeaa87 19
Grimmkey 0:b8221deeaa87 20 /**
Grimmkey 0:b8221deeaa87 21 * Warning: remove LOG_LEVEL_* defines in production for major power savings.
Grimmkey 0:b8221deeaa87 22 *
Grimmkey 0:b8221deeaa87 23 * Defining a log level will set up a serial connection to use for logging.
Grimmkey 0:b8221deeaa87 24 * This serial connection sets up a timer prohibiting the mbed chip
Grimmkey 0:b8221deeaa87 25 * from entering low power states, drawing ~1.4mAh instead of ~20µAh with logging disabled.
Grimmkey 0:b8221deeaa87 26 */
Grimmkey 0:b8221deeaa87 27
Grimmkey 0:b8221deeaa87 28 #ifdef LOG_LEVEL_VERBOSE
Grimmkey 0:b8221deeaa87 29 #define __PUCK_LOG_LEVEL_VERBOSE__
Grimmkey 0:b8221deeaa87 30 #endif
Grimmkey 0:b8221deeaa87 31 #ifdef LOG_LEVEL_DEBUG
Grimmkey 0:b8221deeaa87 32 #define __PUCK_LOG_LEVEL_DEBUG__
Grimmkey 0:b8221deeaa87 33 #endif
Grimmkey 0:b8221deeaa87 34 #ifdef LOG_LEVEL_INFO
Grimmkey 0:b8221deeaa87 35 #define __PUCK_LOG_LEVEL_INFO__
Grimmkey 0:b8221deeaa87 36 #endif
Grimmkey 0:b8221deeaa87 37 #ifdef LOG_LEVEL_WARN
Grimmkey 0:b8221deeaa87 38 #define __PUCK_LOG_LEVEL_WARN__
Grimmkey 0:b8221deeaa87 39 #endif
Grimmkey 0:b8221deeaa87 40 #ifdef LOG_LEVEL_ERROR
Grimmkey 0:b8221deeaa87 41 #define __PUCK_LOG_LEVEL_ERROR__
Grimmkey 0:b8221deeaa87 42 #endif
Grimmkey 0:b8221deeaa87 43
Grimmkey 0:b8221deeaa87 44 #ifdef __PUCK_LOG_LEVEL_VERBOSE__
Grimmkey 0:b8221deeaa87 45 #define LOG_VERBOSE(fmt, ...) do { logger.printf("[V] "); logger.printf(fmt, ##__VA_ARGS__); } while(0)
Grimmkey 0:b8221deeaa87 46 #define __PUCK_LOG_LEVEL_DEBUG__
Grimmkey 0:b8221deeaa87 47 #else
Grimmkey 0:b8221deeaa87 48 #define LOG_VERBOSE(fmt, ...)
Grimmkey 0:b8221deeaa87 49 #endif
Grimmkey 0:b8221deeaa87 50
Grimmkey 0:b8221deeaa87 51 #ifdef __PUCK_LOG_LEVEL_DEBUG__
Grimmkey 0:b8221deeaa87 52 #define LOG_DEBUG(fmt, ...) do { logger.printf("[D] "); logger.printf(fmt, ##__VA_ARGS__); } while(0)
Grimmkey 0:b8221deeaa87 53 #define __PUCK_LOG_LEVEL_INFO__
Grimmkey 0:b8221deeaa87 54 #else
Grimmkey 0:b8221deeaa87 55 #define LOG_DEBUG(fmt, ...)
Grimmkey 0:b8221deeaa87 56 #endif
Grimmkey 0:b8221deeaa87 57
Grimmkey 0:b8221deeaa87 58 #ifdef __PUCK_LOG_LEVEL_INFO__
Grimmkey 0:b8221deeaa87 59 #define LOG_INFO(fmt, ...) do { logger.printf("[I] "); logger.printf(fmt, ##__VA_ARGS__); } while(0)
Grimmkey 0:b8221deeaa87 60 #define __PUCK_LOG_LEVEL_WARN__
Grimmkey 0:b8221deeaa87 61 #else
Grimmkey 0:b8221deeaa87 62 #define LOG_INFO(fmt, ...)
Grimmkey 0:b8221deeaa87 63 #endif
Grimmkey 0:b8221deeaa87 64
Grimmkey 0:b8221deeaa87 65 #ifdef __PUCK_LOG_LEVEL_WARN__
Grimmkey 0:b8221deeaa87 66 #define LOG_WARN(fmt, ...) do { logger.printf("![W] "); logger.printf(fmt, ##__VA_ARGS__); } while(0)
Grimmkey 0:b8221deeaa87 67 #define __PUCK_LOG_LEVEL_ERROR__
Grimmkey 0:b8221deeaa87 68 #else
Grimmkey 0:b8221deeaa87 69 #define LOG_WARN(fmt, ...)
Grimmkey 0:b8221deeaa87 70 #endif
Grimmkey 0:b8221deeaa87 71
Grimmkey 0:b8221deeaa87 72 #ifdef __PUCK_LOG_LEVEL_ERROR__
Grimmkey 0:b8221deeaa87 73 #define LOG_ERROR(fmt, ...) do { logger.printf("!![E] "); logger.printf(fmt, ##__VA_ARGS__); } while(0)
Grimmkey 0:b8221deeaa87 74 #else
Grimmkey 0:b8221deeaa87 75 #define LOG_ERROR(fmt, ...)
Grimmkey 0:b8221deeaa87 76 #endif
Grimmkey 0:b8221deeaa87 77
Grimmkey 0:b8221deeaa87 78 #ifdef __PUCK_LOG_LEVEL_ERROR__
Grimmkey 0:b8221deeaa87 79 static Serial logger(USBTX, USBRX);
Grimmkey 0:b8221deeaa87 80 #endif
Grimmkey 0:b8221deeaa87 81
Grimmkey 0:b8221deeaa87 82
Grimmkey 0:b8221deeaa87 83 #endif //__LOG__H__