summaryrefslogtreecommitdiff
path: root/src/linux
diff options
context:
space:
mode:
authorChristian Pointner <equinox@anytun.org>2009-01-20 15:04:27 +0000
committerChristian Pointner <equinox@anytun.org>2009-01-20 15:04:27 +0000
commit025ca82002b81796f34752c4c590fde9c6729df0 (patch)
tree2bcaa1fe3fff746dc99857336210d828aea18bea /src/linux
parentfixed linux and bsd tunDevice (filedescriptor gets now closed in case of an e... (diff)
further cleanup for system execution
Diffstat (limited to 'src/linux')
-rw-r--r--src/linux/tunDevice.cpp13
1 files changed, 10 insertions, 3 deletions
diff --git a/src/linux/tunDevice.cpp b/src/linux/tunDevice.cpp
index dba22e5..403cd99 100644
--- a/src/linux/tunDevice.cpp
+++ b/src/linux/tunDevice.cpp
@@ -168,7 +168,14 @@ void TunDevice::do_ifconfig()
int result = system(command.str().c_str());
if(result == -1)
- cLog.msg(Log::PRIO_ERR) << "Execution of ifconfig failed";
- else
- cLog.msg(Log::PRIO_NOTICE) << "ifconfig returned " << WEXITSTATUS(result);
+ cLog.msg(Log::PRIO_ERR) << "Execution of ifconfig failed: " << LogErrno(errno);
+ else {
+ if(WIFEXITED(result))
+ cLog.msg(Log::PRIO_NOTICE) << "ifconfig returned " << WEXITSTATUS(result);
+ else if(WIFSIGNALED(result))
+ cLog.msg(Log::PRIO_NOTICE) << "ifconfig terminated after signal " << WTERMSIG(result);
+ else
+ cLog.msg(Log::PRIO_ERR) << "Execution of ifconfig: unkown error";
+ }
+
}