summaryrefslogtreecommitdiffstatshomepage
path: root/cc3200/ftp/ftp.c
diff options
context:
space:
mode:
authorDaniel Campora <daniel@wipy.io>2015-06-04 09:22:29 +0200
committerDaniel Campora <daniel@wipy.io>2015-06-04 10:13:53 +0200
commit71f85cc33005c30b2722c6bfdc288cb1bb6151c3 (patch)
tree0237d24d93676fb9e56883328bd5ebe5c0e5e1ee /cc3200/ftp/ftp.c
parent53a8aeb6e7a89ad169ad3f9e5553d51fb86c03b8 (diff)
downloadmicropython-71f85cc33005c30b2722c6bfdc288cb1bb6151c3.tar.gz
micropython-71f85cc33005c30b2722c6bfdc288cb1bb6151c3.zip
cc3200: Close ftp and telnet server sockets if listening fails.
Diffstat (limited to 'cc3200/ftp/ftp.c')
-rw-r--r--cc3200/ftp/ftp.c11
1 files changed, 7 insertions, 4 deletions
diff --git a/cc3200/ftp/ftp.c b/cc3200/ftp/ftp.c
index df28e78d02..889b4191e5 100644
--- a/cc3200/ftp/ftp.c
+++ b/cc3200/ftp/ftp.c
@@ -443,19 +443,22 @@ static bool ftp_create_listening_socket (_i16 *sd, _u16 port, _u8 backlog) {
// Enable non-blocking mode
nonBlockingOption.NonblockingEnabled = 1;
- ASSERT (sl_SetSockOpt(_sd, SOL_SOCKET, SL_SO_NONBLOCKING, &nonBlockingOption, sizeof(nonBlockingOption)) == SL_SOC_OK);
+ ASSERT ((result = sl_SetSockOpt(_sd, SOL_SOCKET, SL_SO_NONBLOCKING, &nonBlockingOption, sizeof(nonBlockingOption))) == SL_SOC_OK);
// Bind the socket to a port number
sServerAddress.sin_family = AF_INET;
sServerAddress.sin_addr.s_addr = INADDR_ANY;
sServerAddress.sin_port = htons(port);
- ASSERT (sl_Bind(_sd, (const SlSockAddr_t *)&sServerAddress, sizeof(sServerAddress)) == SL_SOC_OK);
+ ASSERT ((result |= sl_Bind(_sd, (const SlSockAddr_t *)&sServerAddress, sizeof(sServerAddress))) == SL_SOC_OK);
// Start listening
- ASSERT ((result = sl_Listen (_sd, backlog)) == SL_SOC_OK);
+ ASSERT ((result |= sl_Listen (_sd, backlog)) == SL_SOC_OK);
- return (result == SL_SOC_OK) ? true : false;
+ if (result == SL_SOC_OK) {
+ return true;
+ }
+ servers_close_socket(sd);
}
return false;
}