当前位置:首页 > 芯闻号 > 充电吧
[导读]WinCE7 + Telechips 8935,通过串口输出 LOG 时,可能是由于多个应用同时使用串口输出 LOG,会出现 LOG 混乱的情况。出现这种情况后,LOG 完全是乱的,根本没有办法看。 

WinCE7 + Telechips 8935,通过串口输出 LOG 时,可能是由于多个应用同时使用串口输出 LOG,会出现 LOG 混乱的情况。
出现这种情况后,LOG 完全是乱的,根本没有办法看。 修改的方法是:将 LOG 写入 U 盘中,形成一个文件。
写文件的操作很简单,但如何将 RETAILMSG 的格式转成字符串呢?
但由于我负责这个应用是主控,负责各个应用之间的调度,写的过程中增加了很多 RETAILMSG 和 printf 的 LOG 输出以方便分析问题,统计了一下大概有 800 个左右,大多数是 RETAILMSG。
如果需要一个个修改,我只能考虑放弃。考虑到 RETAILMSG 是一个宏定义,能否通过一个自定义的、类似的宏代替它,这样对源代码的修改就可以尽可能的少。

先是实现了一个如下定义的宏:RETMSG,可以完成将 RETAILMSG 后的变参格式转成字符串。简单的测试后,发现可以达到想要的功能。

#ifndef _RET_MSG_H_
#define _RET_MSG_H_
#include "atlstr.h"

#define LOG_FILE_PATH	L"/hard disk"
#define LOG_FILE_NAME	L"/hard disk/logFileName.dat"
#define MAX_UNICODE_LEN	2048

void InitWriteFileCs(void);
void DeleteWriteFileCs(void);
void WriteAnsiDataToFile(const char *pcDataBuf);

#define RETMSG(cond,printf_exp)	
{ 
	CString csDataBuf; 
	char cTmpBuf[2 * MAX_UNICODE_LEN + 1]; 
	csDataBuf.Format printf_exp; 
	WriteAnsiDataToFile(csDataBuf); 
}

#endif


但是由于我的应用没有使用 MFC,虽然整合编译通过,但是运行时报错了。只要执行这句:csDataBuf.Format printf_exp; 就会有异常的信息输出。
出错的原因,偶只是怀疑与多线程相关(因为在简单的 MFC 对应框中测试是可以正常使用的)。因为偶的应用中有多个线程,每个线程之间异步运行。

不能使用 CString,让我头痛了一段时间。没有关系,关键是我想找一个与 CString.Format 相同参数的格式化字符串的函数。
但是没有! 看来想通过简单的方法是不行了,开始考虑使用 wsprintf/sprintf 函数。
如何将这两个函数 wsprintf/sprintf 的第一个参数代入 wsprintf/sprintf printf_exp 中?
后来实在没有办法,只能将 wsprintf/sprintf 的第一个参数写在 RETMSG 的调用中,如:

RETMSG(1,(gtcRetMsgBuf,L"[MP]show UI,show page id: 0x%x failed!!!rn",pageid));

这样就可以得到类似的语句:

wsprintf(gtcRetMsgBuf,L"[MP]show UI,show page id: 0x%x failed!!!rn",pageid);

从而完成字符串格式的功能。
同样,完成替代 printf 的宏定义。

#ifndef _RET_MSG_H_
#define _RET_MSG_H_

#define LOG_FILE_PATH	L"/hard disk"
#define LOG_FILE_NAME	L"/hard disk/logFileName.dat"
#define MAX_UNICODE_LEN	(2048 + 1)

void WriteAnsiDataToFile(const char *pcDataBuf);
void WriteUnicodeDataToFile(TCHAR *ptcDataBuf);

extern TCHAR gtcRetMsgBuf[];
extern char gcRetMsgBuf[];

#define RETMSG(cond,printf_exp)	
{ 
	if(cond) 
	{ 
		ZeroMemory(gtcRetMsgBuf,sizeof(TCHAR) * MAX_UNICODE_LEN); 
		wsprintf printf_exp; 
		WriteUnicodeDataToFile(gtcRetMsgBuf); 
	} 
}

#define RETMSG_printf(printf_exp) 
{ 
	ZeroMemory(gcRetMsgBuf,sizeof(char) * MAX_UNICODE_LEN); 
	sprintf printf_exp; 
	WriteAnsiDataToFile(gcRetMsgBuf); 
} 

#endif

多线程时,引功能需要增加了临界区,否则会出现 LOG 被覆盖的问题。

再考虑到刚启动时 U 盘的识别可能慢,所以后续增加了缓冲的功能......

想要完善一个功能,真是不容易啊!


本站声明: 本文章由作者或相关机构授权发布,目的在于传递更多信息,并不代表本站赞同其观点,本站亦不保证或承诺内容真实性等。需要转载请联系该专栏作者,如若文章内容侵犯您的权益,请及时联系本站删除。
换一批
延伸阅读

摘 要:启动装载程序是嵌入式系统的重要组成部分。文章结合在ARM平台上广泛使用的U-Boot,详细讨论了Boot Loader开发中用到的主要技术,分析引导程序的执行流程,提出了WinCE和Linux在ARM平台下...

关键字: 启动装载程序 U-Boot 嵌入式系统 WinCE Linux

摘 要:火车货运在高速发展的同时,也带来了越来越多的不安全因素,货运物资被盗是铁路货运事故的主要原因之一。 基于此,设计和实现了基于ZigBee和WinCE技术的火车货运防盗预警系统,用于解决站停、待编、待卸和运行途中...

关键字: 火车货运 智能防盗 Zigbee WinCE PDA软件

嵌入式软件基本都会存在打印输出数据的情况,我们最常见就是串口打印输出。

关键字: J-Link 串口 输出

电源大家都知道,为我们的社会的发展,贡献了很大的能量,现有的所有的电子产品都离不开电源,那么你知道电源管理吗?伴随着移动嵌入式产品的普及,电源管理已经成为重要技术指标和产品的有机组成。典型移动嵌入式设备对能耗越来越敏感,...

关键字: 电源管理 WinCE 有机组成

  车载操作系统(AutomoTIve OperaTIng System,简称AOS)是管理和控制车载硬件与车载软件资源的程序系统,是直接运行在AB上的最基本的系统软件,任何上层软件,HMI,数

关键字: iOS Linux WinCE

从这里可以看出当运行ifconfig 这个命令,操作系统就会通过显示器输出网卡相关信息,现在我们再回过头去理解上图从键盘到终端处理程序的这个过程,我们从键盘输入命令,然后交给操作系统内核执行之后在输出这样一个过程,因此我...

关键字: Linux 输入 输出

你知道提供12位输出的CSG14k图像传感器吗?全球领先的高性能传感器解决方案供应商艾迈斯半导体(ams AG,瑞士股票交易所股票代码:AMS)今日推出了一款新的全局快门图像传感器,用于机器视觉和自动光学检测(AOI)设...

关键字: 传感器 艾迈斯 输出

电路中都会有电阻,那么你知道什么是输入输出阻抗吗?对于输入输出阻抗是怎么一回事,总是迷迷糊糊的,不是很清楚,今天分享一下高人总结的关于输入输出阻抗是怎么一回事?

关键字: 输入 输出 阻抗

LevelDB中log文件在LevelDB中的主要作用是系统故障恢复时,能够保证不会丢失数据。因为在将记录写入内存的Memtable之前,会先写入Log文件,这样即使系统发生故障,Memtable中的

关键字: leveldb log

荣耀移动电源2上市已有一段时间,那么这款荣耀旗下的产品的性能究竟如何呢?为获得这个答案,小编在此特地为大家带来这款移动电源的输出功能测评。

关键字: 移动电源 荣耀 输出
关闭
关闭