您的位置:首页 > 其它

VxWorks异常任务检测

2010-03-10 13:56 411 查看
1,系统输出信息捕获

在VxWorks下系统输出信息包括:标准输出(STD_OUT,文件描述为1)和标准错误输出(STD_ERR,文件描述为2)。使用printf、
IogMsg语句等输出的信息,以及用户和操作系统其他的打印输出信息均通过STD_OUT输出,而STD_ERR则是在系统出错时使用,例如:

data access

Exception current instruction address:0x00072054

Machine Status Register:0x0000b030

Data Access Register:0xeeeeeef2

Condition Register:0x22000040

Data storage interrupt Register:0x0000b030

Task:0x1c9e50 "RadarProc"

上面的打印信息是任务“RadarProc”出错时操作系统输出的错误信息,通过STD_ERR文件描述符输出的。

STD_OUT和STD_ERR可以分别输出,但是通常情况下它们均定向到控制台(consoleFd),即在交叉开发模式下通过目标机Target
Agent和宿主机的Target
Server输出到串口或者网络。在VxWorks下操作系统提供ioGIobalStdSet接口函数支持输出重定向,函数原型:

void ioGIobaIStdSet(int stdFd,int newFd)

其中stdFd为STD_OUT(1)或者STD_ERR(2),newFd为重定向的文件描述符。利用这个函数就可以实现系统输出信息的捕获,具体方法如下:

FILE* printf_stream = fopen("/ide0/log.txt","a+" ):

ioGlobalStdSet(STD_OUT,fileno(printf_stream));

ioGlobalStdSet(STD_ERR,fileno(printf_stream));

在上面的代码中,在设备/ide0(电子盘)上打开名为log.txt的文件,打开方式为追加式,将STD_OUT和STD_ERR重定向到
printf_stream 指向的文件。需要注意的是,不能像平常那样关闭printf_stream
文件指针,这样就可以将系统的所有输出信息保存在文件log.txt

2,任务监控设计

任务监控需要周期性的监测操作系统中所有运行的任务状态,发现某任务出错时记录任务的相关基本信息,并自动重启。任务监控必须两个操作系统接口函数:

int taskIdListGet(int idList[],int maxTasks)

STATUS taskStatusString(int tid,char* pString)

taskIdListGet函数可以获得当前操作系统中运行的所有任务,idList存放获取的任务id的数组,maxTasks为数组大小。taskStatusString获取任务状态名称,tid是任务id,pString为任务状态名称。

在发现时任务出错时通过回调函数告诉用户出错任务情况,出错任务数据结构:

struct TroubleTaskStruct

{

int taskID;//出错任务id

char taskName[256];//任务名称

char taskState[32];//任务状态

};

回调函数原型:

typedef void (*TroubleTaskFuncPtr)(const TroubleTaskStruct troubleTaskVector,int troubleTaskNum);

转自http://www.mcuol.com/Tech/115/31650.htm
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: