Important changes to repositories hosted on mbed.com
Mbed hosted mercurial repositories are deprecated and are due to be permanently deleted in July 2026.
To keep a copy of this software download the repository Zip archive or clone locally using Mercurial.
It is also possible to export all your personal repositories from the account settings page.
Puck/Log.h@0:b8221deeaa87, 2015-04-30 (annotated)
- 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?
User | Revision | Line number | New 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__ |