项目中使用的是海思HI35XX,设备端音频视频服务程序跑起来后一段时间,提示MMB LEAK(pid=xxx)后,主应用程序就退出了,开使以为是设备的内存不足引起的,调试时把一些服务线程关闭了,发现依旧有这错误出现,
错误现象:
MMB LEAK(pid=917): 0x83954000,249856 bytes, 'AENC_StrBuf'
mmz_userdev_release:mmb<0x83954000> mapped to userspace 0x413b4000 will be force unmaped!
原因:
当服务器close一个连接时,若client端接着发数据。根据TCP协议的规定,会收到一个RST响应,client再往这个服务器发送数据时,系统会发出一个SIGPIPE信号给进程,告诉进程这个连接已经断开了,不要再写了。根据信号的默认处理规则SIGPIPE信号的默认执行动作是terminate(终止、退出),所以client会退出。若不想客户端退出可以把SIGPIPE设为SIG_IGN,即收到这个信号时忽略掉。
解决办法:
在应用程序中增加对SIGPIPE信息的处理,收到信号时忽略。
signal(SIGPIPE, SIG_IGN);
这时SIGPIPE交给了系统处理。