я использую boost::system::error_code
захватить коды ошибок в файл журнала, и он записывает unknown error
, Я не нашел ссылки на эту ошибку в Интернете.
bool read_response_payload(size_t payload_len)
{
boost::system::error_code ec;
stream_connector<protocol_type, INTERFACE_BUFFER_LEN,
INTERFACE_TIMEOUT_SECS>::read_all(payload_len, ec);
if (ec) {
LOGGER_LOG_WARN("Interface read error: %s", ec.message().c_str());
stream_connector<protocol_type, INTERFACE_BUFFER_LEN,
INTERFACE_TIMEOUT_SECS>::disconnect();
return false;
}
else {
return true;
}
}
В файле журнала я получаю сообщения вроде этого:
Interface read error: Unknown error 158
Система является:
root@OpenWrt:~# uname -a
Linux OpenWrt 2.6.30.9 #4 Thu Jul 3 16:08:13 BRT 2014 rlx GNU/Linux
Как указано в комментарии, это была ошибка, описанная в <asm/errno.h>
от OpenWRT
#define ECONNREFUSED 146 /* Connection refused */
#define EHOSTDOWN 147 /* Host is down */
#define EHOSTUNREACH 148 /* No route to host */
#define EWOULDBLOCK EAGAIN /* Operation would block */
#define EALREADY 149 /* Operation already in progress */
#define EINPROGRESS 150 /* Operation now in progress */
#define ESTALE 151 /* Stale NFS file handle */
#define ECANCELED 158 /* AIO operation canceled */
Это асинхронная операция ввода-вывода, которая была отменена.