SNICInterface for ThingPlug Example
Dependents: ThingPlug_WiFi_Example ThingPlug_WiFi_Example_2
Fork of SNICInterface by
Socket/Socket.cpp
- Committer:
- kishino
- Date:
- 2014-03-31
- Revision:
- 27:dcc4f34448f0
- Parent:
- 24:987e412ae879
- Child:
- 29:6a0ba999597d
File content as of revision 27:dcc4f34448f0:
/* Copyright (C) 2012 mbed.org, MIT License * * Permission is hereby granted, free of charge, to any person obtaining a copy of this software * and associated documentation files (the "Software"), to deal in the Software without restriction, * including without limitation the rights to use, copy, modify, merge, publish, distribute, * sublicense, and/or sell copies of the Software, and to permit persons to whom the Software is * furnished to do so, subject to the following conditions: * * The above copyright notice and this permission notice shall be included in all copies or * substantial portions of the Software. * * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING * BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND * NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, * DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. */ /******************* Murata Manufacturing Co.,Ltd. 2014 ***************** * * Filename: Socket.cpp * * Purpose: This module has implementation of socket. * * $Author: kishino $ * * $Date: 2014/03/26 $ * * $Revision: 0.0.0.1 $ * ***********************************************************************/ #include "Socket.h" #include <cstring> using namespace murata_wifi; Socket::Socket() { mSocketID = -1; } Socket::~Socket() { // close(); //Don't want to leak } int Socket::set_option(int level, int optname, const void *optval, socklen_t optlen) { return 0; } int Socket::get_option(int level, int optname, void *optval, socklen_t *optlen) { return 0; } int Socket::close(bool shutdown) { C_SNIC_Core *snic_core_p = C_SNIC_Core::getInstance(); C_SNIC_UartCommandManager *uartCmdMgr_p = snic_core_p->getUartCommand(); // Get buffer for response payload from MemoryPool C_SNIC_Core::tagMEMPOOL_BLOCK_T *payload_buf = snic_core_p->allocCmdBuf(); if( payload_buf == NULL ) { printf("socket close payload_buf NULL\r\n"); return -1; } C_SNIC_Core::tagSNIC_CLOSE_SOCKET_REQ_T req; // Make request req.cmd_sid = UART_CMD_SID_SNIC_CLOSE_SOCKET_REQ; req.seq = mUartRequestSeq++; req.socket_id = mSocketID; unsigned char command_array[UART_REQUEST_PAYLOAD_MAX]; unsigned int command_len; // Preparation of command command_len = snic_core_p->preparationSendCommand( UART_CMD_ID_SNIC, req.cmd_sid, (unsigned char *)&req , sizeof(C_SNIC_Core::tagSNIC_CLOSE_SOCKET_REQ_T), payload_buf->buf, command_array ); // Send uart command request snic_core_p->sendUart( command_len, command_array ); int ret; // Wait UART response ret = uartCmdMgr_p->wait(); if( ret != 0 ) { printf( "socket close failed\r\n" ); snic_core_p->freeCmdBuf( payload_buf ); return -1; } if( uartCmdMgr_p->getCommandStatus() != 0 ) { printf("socket close status:%02x\r\n", uartCmdMgr_p->getCommandStatus()); snic_core_p->freeCmdBuf( payload_buf ); return -1; } snic_core_p->freeCmdBuf( payload_buf ); return 0; } #if 0 int Socket::select(struct timeval *timeout, bool read, bool write) { return 0; } #endif int Socket::createSocket( unsigned char bind, unsigned int local_addr, unsigned short port ) { C_SNIC_Core *snic_core_p = C_SNIC_Core::getInstance(); C_SNIC_UartCommandManager *uartCmdMgr_p = snic_core_p->getUartCommand(); // Get buffer for response payload from MemoryPool C_SNIC_Core::tagMEMPOOL_BLOCK_T *payload_buf = snic_core_p->allocCmdBuf(); if( payload_buf == NULL ) { printf("createSocket payload_buf NULL\r\n"); return -1; } C_SNIC_Core::tagSNIC_TCP_CREATE_SOCKET_REQ_T req; int req_len = 0; // Make request req.cmd_sid = UART_CMD_SID_SNIC_TCP_CREATE_SOCKET_REQ; req_len++; req.seq = mUartRequestSeq++; req_len++; req.bind = bind; req_len++; if( bind != 0 ) { /* req.local_addr = local_addr; req_len++; req.local_port = port; req_len++; */ } unsigned char command_array[UART_REQUEST_PAYLOAD_MAX]; unsigned int command_len; // Preparation of command command_len = snic_core_p->preparationSendCommand( UART_CMD_ID_SNIC, req.cmd_sid, (unsigned char *)&req , req_len, payload_buf->buf, command_array ); // Send uart command request snic_core_p->sendUart( command_len, command_array ); int ret; // Wait UART response ret = uartCmdMgr_p->wait(); if( ret != 0 ) { printf( "createSocket failed\r\n" ); snic_core_p->freeCmdBuf( payload_buf ); return -1; } if( uartCmdMgr_p->getCommandStatus() != 0 ) { printf("createSocket status:%02x\r\n", uartCmdMgr_p->getCommandStatus()); snic_core_p->freeCmdBuf( payload_buf ); return -1; } mSocketID = payload_buf->buf[3]; snic_core_p->freeCmdBuf( payload_buf ); return 0; } int Socket::addrToInteger( const char *addr_p ) { if( addr_p == NULL ) { printf("addrToInteger parameter error\r\n"); return 0; } unsigned char ipadr[4]; unsigned char temp= 0; int i,j,k; /* convert to char[4] */ k=0; for(i=0; i<4; i ++) { for(j=0; j<4; j ++) { if((addr_p[k] > 0x2F)&&(addr_p[k] < 0x3A)) { temp = (temp * 10) + addr_p[k]-0x30; } else if((addr_p[k] == 0x20)&&(temp == 0)) { } else { ipadr[i]=temp; temp = 0; k++; break; } k++; } } int addr = ( (ipadr[0]<<24) | (ipadr[1]<<16) | (ipadr[2]<<8) | ipadr[3] ); return addr; }