Toggle navigation
首页
问答
文章
积分商城
专家
专区
更多专区...
文档中心
返回主站
搜索
提问
会员
中心
登录
注册
RT-Thread一般讨论
一段log代码
发布于 2014-01-10 14:46:35 浏览:3711
订阅该版
如果想用在rtt中,请自行把printf替换为 rt_kprintf。 **log.h 头文件** ``` #ifndef LOG_H #define LOG_H #define LOG_LEVEL_NOISY -1 #define LOG_LEVEL_NORMAL 0 #define LOG_LEVEL_SERIOUS 1 #define LOG_LEVEL_DEAD 2 #define LOG_LEVEL_NOMSG 100 #define LOG_LEVEL LOG_LEVEL_NORMAL #define TENDSTR " " #define log_msg(level, prefix, suffix, errFmt, ...) do { if (level >= LOG_LEVEL) printf(prefix errFmt suffix, ##__VA_ARGS__); } while(0) #define LOGE(fmt, ...) log_msg(LOG_LEVEL_DEAD, "E/", TENDSTR, fmt, ##__VA_ARGS__) #define LOGD(fmt, ...) log_msg(LOG_LEVEL_NORMAL,"D/", TENDSTR, fmt, ##__VA_ARGS__) #define LOGI(fmt, ...) log_msg(LOG_LEVEL_NORMAL,"I/", TENDSTR, fmt, ##__VA_ARGS__) extern void dumphex(uint8_t* buf, int32_t len); #define DUMPHEX(level, buf, len) do { if (level >= LOG_LEVEL) dumphex(buf, len); } while(0) #define LOG8(exp) LOGD(#exp "= 0x%02x[%d]", exp, exp) #define LOG16(exp) LOGD(#exp "= 0x%04x[%d]", exp, exp) #define LOG24(exp) LOGD(#exp "= 0x%08x[%d]", exp, exp) #define LOG32(exp) LOGD(#exp "= 0x%08x[%d]", exp, exp) #define LOG64(exp) LOGD(#exp "= 0x%llx[%d]", exp, exp) #define LOGDUMP(buf, len) DUMPHEX(LOG_LEVEL_NORMAL, buf, len) #endif //LOGH ``` ``` //原dumhex实现可参考3楼,由于实现的较冗长,建议使用2楼bernard给出的dumphex函数,比较精简。 ``` **使用用例** ``` dl->manufacturer_code = buf[0]; dl->hardware_code = buf[1]; dl->load_sequence_number = buf[2]; dl->partition_count = buf[3]; dl->loader_gte_v3 = (buf[4] & (1<<6)) ? 1 : 0; dl->key_load = (buf[4] & (1<<5)) ? 1 : 0; dl->text_length = buf[4] & 0x1F; dl->text_character = &buf[5]; LOG8(dl->manufacturer_code); LOG8(dl->hardware_code); LOG8(dl->load_sequence_number); LOG8(dl->partition_count); LOG8(dl->loader_gte_v3); LOG8(dl->key_load); LOG8(dl->text_length); LOGDUMP(dl->text_character, dl->text_length); ``` ================================================================= 效果如下 ![1.jpg](/uploads/3230_314f3b949e7fc03b8e197a40952eb1c4.jpg) 关于dumphex实现,二楼bernard的实现更简洁~ 为了使大家关注重点,我决定把原dumphex代码移动至3楼。 **编辑历史** 2014年1月10日晚11点修改:简单修改了下 DUMPHEX宏实现,与LOGD等保持一致。
查看更多
7
个回答
默认排序
按发布时间排序
Yafei
2014-01-10
这家伙很懒,什么也没写!
不错,学习下酱油哥的Log,涨姿势!
bernard
2014-01-10
这家伙很懒,什么也没写!
``` #define __is_print(ch) ((unsigned int)((ch) - ' ') < 127u - ' ') void nftl_dump_hex(void *ptr, int buflen) { unsigned char *buf = (unsigned char*)ptr; int i, j; for (i=0; i
yfj300
2014-01-10
这家伙很懒,什么也没写!
涨姿势
prife
2014-01-10
这家伙很懒,什么也没写!
原来首楼的dumphex实现,原来实现的较冗长,为了使大家关注重点,将其移动至本楼 ``` void dumphex(uint8_t* buf, int32_t len) { static char membuf[1024]; uint8_t *ptr = (uint8_t *)buf; char * ibuf = membuf; int32_t i, j; int len1, len2; len1 = len / 16 * 16; len2 = len % 16; ibuf[0]=0; #define BIN2CHAR(ch) (((ch) > ' ' && (ch) <= '~') ? (ch) : '.') for (i=0; i
> 4) << 4)); ibuf += 6; for (i=0; i
bernard
2014-01-11
这家伙很懒,什么也没写!
不是太明白,意思是有个简单的log可以用? 那么可以看看log_trace的实现,虽然nftl_dump_hex并未包括在log_trace中
bernard
2014-01-11
这家伙很懒,什么也没写!
log_trace中唯一不好的就是要去注册session,和grissiom说了无数次,都不行啊。 不过应该把example下的mem log也加入到log_trace中的,这个mem log实现得太好了!
撰写答案
登录
注册新账号
关注者
0
被浏览
3.7k
关于作者
prife
这家伙很懒,什么也没写!
提问
20
回答
550
被采纳
0
关注TA
发私信
相关问题
1
有关动态模块加载的一篇论文
2
最近的调程序总结
3
晕掉了,这么久都不见layer2的踪影啊
4
继续K9ii的历程
5
[GUI相关] FreeType 2
6
[GUI相关]嵌入式系统中文输入法的设计
7
20081101 RT-Thread开发者聚会总结
8
嵌入式系统基础
9
linux2.4.19在at91rm9200 上的寄存器设置
10
[转]基于嵌入式Linux的通用触摸屏校准程序
推荐文章
1
RT-Thread应用项目汇总
2
玩转RT-Thread系列教程
3
国产MCU移植系列教程汇总,欢迎查看!
4
机器人操作系统 (ROS2) 和 RT-Thread 通信
5
五分钟玩转RT-Thread新社区
6
【技术三千问】之《玩转ART-Pi》,看这篇就够了!干货汇总
7
关于STM32H7开发板上使用SDIO接口驱动SD卡挂载文件系统的问题总结
8
STM32的“GPU”——DMA2D实例详解
9
RT-Thread隐藏的宝藏之completion
10
【ART-PI】RT-Thread 开启RTC 与 Alarm组件
最新文章
1
ulog 日志 LOG_HEX 输出时间改为本地日期时间
2
在RT-Thread Studio中构建前执行python命令
3
研究一了一段时间RTT,直接标准版上手太难,想用nano,但又舍不得组件
4
CherryUSB开发笔记(一):FSDEV USB IP核的 HID Remote WakeUp (USB HID 远程唤醒) 2025-01-18 V1.1
5
RT-thread 缩写字典
热门标签
RT-Thread Studio
串口
Env
LWIP
SPI
AT
Bootloader
Hardfault
CAN总线
FinSH
ART-Pi
USB
DMA
文件系统
RT-Thread
SCons
RT-Thread Nano
线程
MQTT
STM32
RTC
FAL
rt-smart
I2C_IIC
ESP8266
UART
WIZnet_W5500
ota在线升级
PWM
cubemx
flash
freemodbus
BSP
packages_软件包
潘多拉开发板_Pandora
定时器
ADC
flashDB
GD32
socket
编译报错
中断
Debug
rt_mq_消息队列_msg_queue
SFUD
msh
keil_MDK
ulog
C++_cpp
MicroPython
本月问答贡献
踩姑娘的小蘑菇
1
个答案
2
次被采纳
用户名由3_15位
7
个答案
1
次被采纳
xusiwei1236
5
个答案
1
次被采纳
bernard
4
个答案
1
次被采纳
张世争
1
个答案
1
次被采纳
本月文章贡献
聚散无由
2
篇文章
15
次点赞
catcatbing
2
篇文章
5
次点赞
Wade
2
篇文章
2
次点赞
Ghost_Girls
1
篇文章
6
次点赞
YZRD
1
篇文章
2
次点赞
回到
顶部
发布
问题
分享
好友
手机
浏览
扫码手机浏览
投诉
建议
回到
底部