Description: fix indentations

Reviewed-by: jianghan
This commit is contained in:
c00546070 2020-09-07 14:57:17 +08:00
parent ff52e24fba
commit 9b25a48dd4
1 changed files with 419 additions and 419 deletions

View File

@ -208,31 +208,31 @@ int netstat_netconn_sendq(struct netconn *conn);
#define PRINT_BUF_LEN 1024 #define PRINT_BUF_LEN 1024
#define MAX_MACADDR_STRING_LENGTH 18 /* including NULL */ #define MAX_MACADDR_STRING_LENGTH 18 /* including NULL */
#define CONVERT_STRING_TO_HEX(_src, _dest) \ #define CONVERT_STRING_TO_HEX(_src, _dest) \
{ \ { \
const char *_srcString = (char *)_src; \ const char *_srcString = (char *)_src; \
_dest = 0; \ _dest = 0; \
while (*_srcString) { \ while (*_srcString) { \
_dest = (unsigned char)((_dest << 4) & 0xFF); \ _dest = (unsigned char)((_dest << 4) & 0xFF); \
if ((*_srcString >= 48) && (*_srcString <= 57)) /* between 0 to 9 */ \ if ((*_srcString >= 48) && (*_srcString <= 57)) /* between 0 to 9 */ \
_dest |= (unsigned char)(*_srcString - 48); \ _dest |= (unsigned char)(*_srcString - 48); \
else if ((*_srcString >= 65 && *_srcString <= 70)) /* between A to F */ \ else if ((*_srcString >= 65 && *_srcString <= 70)) /* between A to F */ \
_dest |= (unsigned char)((*_srcString - 65) + 10); \ _dest |= (unsigned char)((*_srcString - 65) + 10); \
else if ((*_srcString >= 97 && *_srcString <= 102)) /* between a to f */ \ else if ((*_srcString >= 97 && *_srcString <= 102)) /* between a to f */ \
_dest |= (unsigned char)((*_srcString - 97) + 10); \ _dest |= (unsigned char)((*_srcString - 97) + 10); \
else break; \ else break; \
++_srcString; \ ++_srcString; \
} \ } \
} }
#define ERR_IFCONFIG_STRING_PUT(ret, str) do \ #define ERR_IFCONFIG_STRING_PUT(ret, str) \
{ \ do { \
(ret) = snprintf_s(ifconfig_cmd->cb_print_buf + ifconfig_cmd->print_len, \ (ret) = snprintf_s(ifconfig_cmd->cb_print_buf + ifconfig_cmd->print_len, \
PRINT_BUF_LEN - ifconfig_cmd->print_len, \ PRINT_BUF_LEN - ifconfig_cmd->print_len, \
((PRINT_BUF_LEN - ifconfig_cmd->print_len) - 1), (str)); \ ((PRINT_BUF_LEN - ifconfig_cmd->print_len) - 1), (str)); \
if (((ret) > 0) && ((unsigned int)(ret) < (PRINT_BUF_LEN - ifconfig_cmd->print_len))) \ if (((ret) > 0) && ((unsigned int)(ret) < (PRINT_BUF_LEN - ifconfig_cmd->print_len))) \
ifconfig_cmd->print_len += (unsigned int)(ret); \ ifconfig_cmd->print_len += (unsigned int)(ret); \
} while(0) } while (0) \
#define LWIP_MSECS_TO_SECS(time_in_msecs) (time_in_msecs / 1000) #define LWIP_MSECS_TO_SECS(time_in_msecs) (time_in_msecs / 1000)
struct ifconfig_option { struct ifconfig_option {
@ -1922,149 +1922,149 @@ SHELLCMD_ENTRY(ping_shellcmd, CMD_TYPE_EX, "ping", XARGS, (CmdCallBackFunc)osShe
u32_t osShellPing(int argc, const char **argv) u32_t osShellPing(int argc, const char **argv)
{ {
int sfd; int sfd;
struct sockaddr_in to; struct sockaddr_in to;
struct icmp_echo_hdr iecho; struct icmp_echo_hdr iecho;
struct pbuf *pbuf_resp = NULL; struct pbuf *pbuf_resp = NULL;
struct icmp_echo_hdr *iecho_resp = NULL; struct icmp_echo_hdr *iecho_resp = NULL;
struct ip_hdr *iphdr_resp = NULL; struct ip_hdr *iphdr_resp = NULL;
s16_t ip_hlen; s16_t ip_hlen;
ip_addr_t dst_ipaddr; ip_addr_t dst_ipaddr;
fd_set fdReadSet; fd_set fdReadSet;
struct timeval stTimeVal; struct timeval stTimeVal;
struct timespec start, end; struct timespec start, end;
int ret; int ret;
s32_t i; s32_t i;
long rtt; long rtt;
s32_t pingcount; s32_t pingcount;
char buf[50]; char buf[50];
if (!tcpip_init_finish) { if (!tcpip_init_finish) {
PRINTK("ping: tcpip_init have not been called\n"); PRINTK("ping: tcpip_init have not been called\n");
return LOS_NOK; return LOS_NOK;
} }
if ((argc < 1) || (argv == NULL)) { if ((argc < 1) || (argv == NULL)) {
PRINTK("ping : invalid arguments, ping command receives ip as command line argument \n"); PRINTK("ping : invalid arguments, ping command receives ip as command line argument \n");
return LOS_NOK; return LOS_NOK;
} }
if (argc == 2) { if (argc == 2) {
pingcount = atoi(argv[1]); pingcount = atoi(argv[1]);
if (pingcount < 1) if (pingcount < 1)
pingcount = LWIP_SHELL_CMD_PING_RETRY_TIMES; pingcount = LWIP_SHELL_CMD_PING_RETRY_TIMES;
} else { } else {
pingcount = LWIP_SHELL_CMD_PING_RETRY_TIMES; pingcount = LWIP_SHELL_CMD_PING_RETRY_TIMES;
} }
PRINTK("ping %u packets start.\n", pingcount); PRINTK("ping %u packets start.\n", pingcount);
/* initialize dst IP address */ /* initialize dst IP address */
#if LWIP_DNS #if LWIP_DNS
ip_2_ip4(&dst_ipaddr)->addr = get_hostip(argv[0]); ip_2_ip4(&dst_ipaddr)->addr = get_hostip(argv[0]);
#else /* LWIP_DNS */ #else /* LWIP_DNS */
ip_2_ip4(&dst_ipaddr)->addr = inet_addr(argv[0]); ip_2_ip4(&dst_ipaddr)->addr = inet_addr(argv[0]);
#endif /* LWIP_DNS */ #endif /* LWIP_DNS */
to.sin_family = AF_INET; to.sin_family = AF_INET;
to.sin_addr.s_addr = ip_2_ip4(&dst_ipaddr)->addr; to.sin_addr.s_addr = ip_2_ip4(&dst_ipaddr)->addr;
to.sin_port = 0; to.sin_port = 0;
if (to.sin_addr.s_addr == IPADDR_NONE || to.sin_addr.s_addr == IPADDR_ANY) { if (to.sin_addr.s_addr == IPADDR_NONE || to.sin_addr.s_addr == IPADDR_ANY) {
PRINTK("ping : invalid ip address : %s\n", argv[0]); PRINTK("ping : invalid ip address : %s\n", argv[0]);
return LOS_NOK; return LOS_NOK;
}
sfd = lwip_socket(PF_INET, SOCK_RAW, IPPROTO_ICMP);
if (sfd == -1) {
PRINTK("ping : failed, socket creation failed\n");
return LOS_NOK;
}
pbuf_resp = pbuf_alloc(PBUF_RAW, IP_HLEN + sizeof(struct icmp_echo_hdr), PBUF_RAM);
if (pbuf_resp == NULL) {
PRINTK("ping : memory allocation failed\n");
goto FAILURE;
}
for (i = 0; i < pingcount; i++) {
(void)memset_s(&iecho, sizeof(iecho), 0, sizeof(iecho));
ICMPH_TYPE_SET(&iecho, (u8_t)ICMP_ECHO);
iecho.chksum = inet_chksum(&iecho, sizeof(struct icmp_echo_hdr));
ret = lwip_sendto(sfd, &iecho, sizeof(struct icmp_echo_hdr), 0, (struct sockaddr *)&to, (socklen_t)sizeof(to));
if (ret == -1) {
PRINTK("ping : sending ICMP echo msg failed\n");
goto FAILURE;
} }
/* capture the start time to calculate round trip time */ sfd = lwip_socket(PF_INET, SOCK_RAW, IPPROTO_ICMP);
(void)clock_gettime(CLOCK_MONOTONIC_RAW, &start); if (sfd == -1) {
/* Wait in select for ICMP response msg */ PRINTK("ping : failed, socket creation failed\n");
FD_ZERO(&fdReadSet); return LOS_NOK;
FD_SET(sfd, &fdReadSet); }
stTimeVal.tv_sec = LWIP_SHELL_CMD_PING_TIMEOUT / 1000;
stTimeVal.tv_usec = 0; pbuf_resp = pbuf_alloc(PBUF_RAW, IP_HLEN + sizeof(struct icmp_echo_hdr), PBUF_RAM);
if (pbuf_resp == NULL) {
PRINTK("ping : memory allocation failed\n");
goto FAILURE;
}
for (i = 0; i < pingcount; i++) {
(void)memset_s(&iecho, sizeof(iecho), 0, sizeof(iecho));
ICMPH_TYPE_SET(&iecho, (u8_t)ICMP_ECHO);
iecho.chksum = inet_chksum(&iecho, sizeof(struct icmp_echo_hdr));
ret = lwip_sendto(sfd, &iecho, sizeof(struct icmp_echo_hdr), 0, (struct sockaddr *)&to, (socklen_t)sizeof(to));
if (ret == -1) {
PRINTK("ping : sending ICMP echo msg failed\n");
goto FAILURE;
}
/* capture the start time to calculate round trip time */
(void)clock_gettime(CLOCK_MONOTONIC_RAW, &start);
/* Wait in select for ICMP response msg */
FD_ZERO(&fdReadSet);
FD_SET(sfd, &fdReadSet);
stTimeVal.tv_sec = LWIP_SHELL_CMD_PING_TIMEOUT / 1000;
stTimeVal.tv_usec = 0;
DO_SELECT: DO_SELECT:
ret = select(sfd + 1, &fdReadSet, 0, 0, &stTimeVal); ret = select(sfd + 1, &fdReadSet, 0, 0, &stTimeVal);
if (ret < 0) { if (ret < 0) {
PRINTK("ping : select failure\n"); PRINTK("ping : select failure\n");
goto FAILURE; goto FAILURE;
} else if (ret == 0) { } else if (ret == 0) {
PRINTK("Request timed out.\n"); PRINTK("Request timed out.\n");
continue; continue;
}
/* capture the end time to calculate round trip time */
(void)clock_gettime(CLOCK_MONOTONIC_RAW, &end);
rtt = ((end.tv_sec - start.tv_sec) * 1000 + (end.tv_nsec - start.tv_nsec) / 1000000);
ret = lwip_recv(sfd, pbuf_resp->payload, pbuf_resp->len, 0);
if (ret == -1) {
PRINTK("ping : receiving ICMP echo response msg failed\n");
goto FAILURE;
}
/* Accessing ip header and icmp header */
iphdr_resp = (struct ip_hdr *)(pbuf_resp->payload);
ip_hlen = (s16_t)(IPH_HL(iphdr_resp) * 4);
if (pbuf_header(pbuf_resp, (s16_t)(-ip_hlen))) {
/* this failure will never happen, but failure handle is written just to be in safe side */
PRINTK("ping : memory management failure\n");
goto FAILURE;
}
iecho_resp = (struct icmp_echo_hdr *)pbuf_resp->payload;
/* Reverting back pbuf to its original state */
if (pbuf_header(pbuf_resp, ip_hlen)) {
/* this failure will never happen, but failure handle is written just to be in safe side */
PRINTK("ping : memory management failure\n");
goto FAILURE;
}
if (iphdr_resp->src.addr == to.sin_addr.s_addr) {
if (ICMPH_TYPE(iecho_resp) == ICMP_ER) {
PRINTK("[%u]Reply from %s: time=%ims TTL=%u\n", i,
inet_ntoa_r(to.sin_addr.s_addr, buf, sizeof(buf)), rtt, iphdr_resp->_ttl);
} else if (ICMPH_TYPE(iecho_resp) == ICMP_ECHO) {
/* If ping self, stack will receive a ICMP_ECHO request message flowing a ICMP_ER reply message,
and we need reply only, do select again */
goto DO_SELECT;
}
}
} }
/* capture the end time to calculate round trip time */ (void)lwip_close(sfd);
(void)clock_gettime(CLOCK_MONOTONIC_RAW, &end); (void)pbuf_free(pbuf_resp);
rtt = ((end.tv_sec - start.tv_sec) * 1000 + (end.tv_nsec - start.tv_nsec) / 1000000); return LOS_OK;
ret = lwip_recv(sfd, pbuf_resp->payload, pbuf_resp->len, 0);
if (ret == -1) {
PRINTK("ping : receiving ICMP echo response msg failed\n");
goto FAILURE;
}
/* Accessing ip header and icmp header */
iphdr_resp = (struct ip_hdr*)(pbuf_resp->payload);
ip_hlen = (s16_t)(IPH_HL(iphdr_resp) * 4);
if (pbuf_header(pbuf_resp, (s16_t)(-ip_hlen))) {
/* this failure will never happen, but failure handle is written just to be in safe side */
PRINTK("ping : memory management failure\n");
goto FAILURE;
}
iecho_resp = (struct icmp_echo_hdr *)pbuf_resp->payload;
/* Reverting back pbuf to its original state */
if (pbuf_header(pbuf_resp, ip_hlen)) {
/* this failure will never happen, but failure handle is written just to be in safe side */
PRINTK("ping : memory management failure\n");
goto FAILURE;
}
if (iphdr_resp->src.addr == to.sin_addr.s_addr) {
if (ICMPH_TYPE(iecho_resp) == ICMP_ER) {
PRINTK("[%u]Reply from %s: time=%ims TTL=%u\n", i,
inet_ntoa_r(to.sin_addr.s_addr, buf, sizeof(buf)), rtt, iphdr_resp->_ttl);
} else if (ICMPH_TYPE(iecho_resp) == ICMP_ECHO) {
/* If ping self, stack will receive a ICMP_ECHO request message flowing a ICMP_ER reply message,
and we need reply only, do select again */
goto DO_SELECT;
}
}
}
(void)lwip_close(sfd);
(void)pbuf_free(pbuf_resp);
return LOS_OK;
FAILURE: FAILURE:
(void)lwip_close(sfd); (void)lwip_close(sfd);
if (pbuf_resp != NULL) { if (pbuf_resp != NULL) {
(void)pbuf_free(pbuf_resp); (void)pbuf_free(pbuf_resp);
} }
return LOS_NOK; return LOS_NOK;
} }
#ifdef LOSCFG_SHELL #ifdef LOSCFG_SHELL
@ -2389,11 +2389,11 @@ LWIP_STATIC int create_ping6_socket(u8_t type, const void *param)
} }
/* /*
Function to parse the command line args for ping6 shell utility * Function to parse the command line args for ping6 shell utility
@return: * @return:
Success: ERR_OK * Success: ERR_OK
Failure: -1 * Failure: -1
*/ */
LWIP_STATIC int parse_args_ping6(int argc, const char **argv, ping6_args_t *ping6_params) LWIP_STATIC int parse_args_ping6(int argc, const char **argv, ping6_args_t *ping6_params)
{ {
int pingcount; int pingcount;
@ -2581,43 +2581,43 @@ SHELLCMD_ENTRY(ping6_shellcmd, CMD_TYPE_EX, "ping6", XARGS, (CmdCallBackFunc)osS
#endif /* LOSCFG_SHELL_CMD_DEBUG */ #endif /* LOSCFG_SHELL_CMD_DEBUG */
#endif /* LWIP_IPV6 */ #endif /* LWIP_IPV6 */
#if LWIP_SNTP #if LWIP_SNTP
u32_t osShellNtpdate(int argc, const char **argv) u32_t osShellNtpdate(int argc, const char **argv)
{ {
int server_num = 0; int server_num = 0;
char *ret = NULL; char *ret = NULL;
struct timeval get_time; struct timeval get_time;
char buf[50]; char buf[50];
(void)memset_s(&get_time, sizeof(struct timeval), 0, sizeof(struct timeval)); (void)memset_s(&get_time, sizeof(struct timeval), 0, sizeof(struct timeval));
if (!tcpip_init_finish) { if (!tcpip_init_finish) {
PRINTK("%s: tcpip_init have not been called\n", __FUNCTION__); PRINTK("%s: tcpip_init have not been called\n", __FUNCTION__);
return LOS_NOK; return LOS_NOK;
}
if (argc < 1 || argv == NULL) {
goto usage;
}
server_num = lwip_sntp_start(argc, (char **)argv, &get_time);
if (server_num >= 0 && server_num < argc) {
ret = ctime_r((time_t *)&get_time.tv_sec, buf);
if (ret != NULL) {
PRINTK("time server %s: %s\n", argv[server_num], ret);
} else {
PRINTK("ctime return null error\n");
} }
} else {
PRINTK("no server suitable for synchronization found\n");
}
return LOS_OK; if (argc < 1 || argv == NULL) {
goto usage;
}
server_num = lwip_sntp_start(argc, (char **)argv, &get_time);
if (server_num >= 0 && server_num < argc) {
ret = ctime_r((time_t *)&get_time.tv_sec, buf);
if (ret != NULL) {
PRINTK("time server %s: %s\n", argv[server_num], ret);
} else {
PRINTK("ctime return null error\n");
}
} else {
PRINTK("no server suitable for synchronization found\n");
}
return LOS_OK;
usage: usage:
PRINTK("\nUsage:\n"); PRINTK("\nUsage:\n");
PRINTK("ntpdate [SERVER_IP1] [SERVER_IP2] ...\n"); PRINTK("ntpdate [SERVER_IP1] [SERVER_IP2] ...\n");
return LOS_NOK; return LOS_NOK;
} }
#ifdef LOSCFG_SHELL_CMD_DEBUG #ifdef LOSCFG_SHELL_CMD_DEBUG
@ -3548,113 +3548,113 @@ SHELLCMD_ENTRY(dhclient_shellcmd, CMD_TYPE_EX, "dhclient", XARGS, (CmdCallBackFu
#define MAX_SIZE 1024 #define MAX_SIZE 1024
void tcp_access(int sockfd) void tcp_access(int sockfd)
{ {
size_t n, i; size_t n, i;
ssize_t ret; ssize_t ret;
char msg[MAX_SIZE] = {0}; char msg[MAX_SIZE] = {0};
while (1) { while (1) {
PRINTK("waiting for recv\n"); PRINTK("waiting for recv\n");
(void)memset_s(msg, MAX_SIZE, 0, MAX_SIZE); (void)memset_s(msg, MAX_SIZE, 0, MAX_SIZE);
ret = recv(sockfd, msg, MAX_SIZE - 1, 0); ret = recv(sockfd, msg, MAX_SIZE - 1, 0);
if (ret < 0) { if (ret < 0) {
PRINTK("recv failed, %d.\n", (u32_t)ret); PRINTK("recv failed, %d.\n", (u32_t)ret);
(void)closesocket(sockfd); (void)closesocket(sockfd);
return; return;
} else if (ret == 0) { } else if (ret == 0) {
(void)closesocket(sockfd); (void)closesocket(sockfd);
PRINTK("client disconnect.\n"); PRINTK("client disconnect.\n");
return; return;
} }
n = strlen(msg); n = strlen(msg);
for (i = 0; i < n; ++i) { for (i = 0; i < n; ++i) {
if (msg[i] >= 'a' && msg[i] <= 'z') { if (msg[i] >= 'a' && msg[i] <= 'z') {
msg[i] = (char)(msg[i] + ('A' - 'a')); msg[i] = (char)(msg[i] + ('A' - 'a'));
} else if (msg[i] >= 'A' && msg[i] <= 'Z') { } else if (msg[i] >= 'A' && msg[i] <= 'Z') {
msg[i] = (char)(msg[i] + ('a' - 'A')); msg[i] = (char)(msg[i] + ('a' - 'A'));
} }
} }
if (send(sockfd, msg, n, 0) < 0) { if (send(sockfd, msg, n, 0) < 0) {
PRINTK("send failed!\r\n"); PRINTK("send failed!\r\n");
continue; continue;
}
} }
}
} }
u32_t osTcpserver(int argc, const char **argv) u32_t osTcpserver(int argc, const char **argv)
{ {
uint16_t port; uint16_t port;
int sockfd = -1; int sockfd = -1;
int ret; int ret;
struct sockaddr_in seraddr; struct sockaddr_in seraddr;
struct sockaddr_in cliaddr; struct sockaddr_in cliaddr;
u32_t cliaddr_size = (u32_t)sizeof(cliaddr); u32_t cliaddr_size = (u32_t)sizeof(cliaddr);
int reuse, iPortVal; int reuse, iPortVal;
if (tcpip_init_finish == 0) { if (tcpip_init_finish == 0) {
PRINTK("tcpip_init have not been called\n"); PRINTK("tcpip_init have not been called\n");
return LOS_NOK; return LOS_NOK;
}
if (argc < 1 || argv == NULL) {
PRINTK("\nUsage: tcpserver <port>\n");
return LOS_NOK;
}
iPortVal = atoi(argv[0]);
/* Port 0 not supported , negative values not supported , max port limit is 65535 */
if (iPortVal <= 0 || iPortVal > 65535) {
PRINTK("\nUsage: Invalid port\n");
return LOS_NOK;
}
port = (uint16_t)iPortVal;
/* removed the print of argv[1] as its accessing argv[1] without verifying argc and
* argv[1] not used anywhere else */
PRINTK("argv[0]:%s, argc:%d\r\n", argv[0], argc);
sockfd = socket(AF_INET, SOCK_STREAM, 0);
if (sockfd < 0) {
PRINTK("\nUsage: create socket fail!\n");
return LOS_NOK;
}
reuse = 1;
if (setsockopt(sockfd, SOL_SOCKET, SO_REUSEADDR, (const char *) &reuse, sizeof(reuse)) != 0) {
(void)closesocket(sockfd);
PRINTK("set SO_REUSEADDR failed\n");
return LOS_NOK;
}
(void)memset_s(&seraddr, sizeof(seraddr), 0, sizeof(seraddr));
seraddr.sin_family = AF_INET;
seraddr.sin_addr.s_addr = htonl(INADDR_ANY);
seraddr.sin_port = htons(port);
ret = bind(sockfd, (struct sockaddr*)&seraddr, sizeof(seraddr));
if (ret < 0) {
PRINTK("bind ip and port failed");
(void)closesocket(sockfd);
return LOS_NOK;
}
ret = listen(sockfd, 5);
if (ret < 0) {
(void)closesocket(sockfd);
PRINTK("listen failed\n");
return LOS_NOK;
}
while (1) {
PRINTK("waiting for accept\n");
(void)memset_s(&cliaddr, sizeof(struct sockaddr_in), 0, sizeof(struct sockaddr_in));
ret = (int)accept(sockfd, (struct sockaddr*)&cliaddr, &cliaddr_size);
if (ret < 0) {
(void)closesocket(sockfd);
PRINTK("Accept failed, %d\n", ret);
break ;
} }
tcp_access(ret);
} if (argc < 1 || argv == NULL) {
return LOS_NOK; // Hits Only If Accept Fails PRINTK("\nUsage: tcpserver <port>\n");
return LOS_NOK;
}
iPortVal = atoi(argv[0]);
/* Port 0 not supported , negative values not supported , max port limit is 65535 */
if (iPortVal <= 0 || iPortVal > 65535) {
PRINTK("\nUsage: Invalid port\n");
return LOS_NOK;
}
port = (uint16_t)iPortVal;
/* removed the print of argv[1] as its accessing argv[1] without verifying argc and
* argv[1] not used anywhere else */
PRINTK("argv[0]:%s, argc:%d\r\n", argv[0], argc);
sockfd = socket(AF_INET, SOCK_STREAM, 0);
if (sockfd < 0) {
PRINTK("\nUsage: create socket fail!\n");
return LOS_NOK;
}
reuse = 1;
if (setsockopt(sockfd, SOL_SOCKET, SO_REUSEADDR, (const char *)&reuse, sizeof(reuse)) != 0) {
(void)closesocket(sockfd);
PRINTK("set SO_REUSEADDR failed\n");
return LOS_NOK;
}
(void)memset_s(&seraddr, sizeof(seraddr), 0, sizeof(seraddr));
seraddr.sin_family = AF_INET;
seraddr.sin_addr.s_addr = htonl(INADDR_ANY);
seraddr.sin_port = htons(port);
ret = bind(sockfd, (struct sockaddr *)&seraddr, sizeof(seraddr));
if (ret < 0) {
PRINTK("bind ip and port failed");
(void)closesocket(sockfd);
return LOS_NOK;
}
ret = listen(sockfd, 5);
if (ret < 0) {
(void)closesocket(sockfd);
PRINTK("listen failed\n");
return LOS_NOK;
}
while (1) {
PRINTK("waiting for accept\n");
(void)memset_s(&cliaddr, sizeof(struct sockaddr_in), 0, sizeof(struct sockaddr_in));
ret = (int)accept(sockfd, (struct sockaddr *)&cliaddr, &cliaddr_size);
if (ret < 0) {
(void)closesocket(sockfd);
PRINTK("Accept failed, %d\n", ret);
break;
}
tcp_access(ret);
}
return LOS_NOK; // Hits Only If Accept Fails
} }
#ifdef LOSCFG_SHELL_CMD_DEBUG #ifdef LOSCFG_SHELL_CMD_DEBUG
@ -3665,71 +3665,71 @@ SHELLCMD_ENTRY(tcpserver_shellcmd, CMD_TYPE_EX, "tcpserver", XARGS, (CmdCallBack
#ifdef LWIP_DEBUG_UDPSERVER #ifdef LWIP_DEBUG_UDPSERVER
void udpserver(int argc, const char **argv) void udpserver(int argc, const char **argv)
{ {
int sockfd, fromlen; int sockfd, fromlen;
int ret, iPortVal; int ret, iPortVal;
struct sockaddr_in seraddr; struct sockaddr_in seraddr;
struct sockaddr_in cliaddr; struct sockaddr_in cliaddr;
size_t n, i; size_t n, i;
char msg[MAX_SIZE] = {0}; char msg[MAX_SIZE] = {0};
uint16_t port; uint16_t port;
if (argc < 1) { if (argc < 1) {
PRINTK("\nUsage: udpserver <port>\n"); PRINTK("\nUsage: udpserver <port>\n");
return; return;
} }
iPortVal = atoi(argv[0]); iPortVal = atoi(argv[0]);
/* Port 0 not supported , negative values not supported , max port limit is 65535 */ /* Port 0 not supported , negative values not supported , max port limit is 65535 */
if (iPortVal <= 0 || iPortVal > 65535) { if (iPortVal <= 0 || iPortVal > 65535) {
PRINTK("\nUsage: Invalid Port\n"); PRINTK("\nUsage: Invalid Port\n");
return ; return;
} }
port = (uint16_t)iPortVal; port = (uint16_t)iPortVal;
PRINTK("port:%d\r\n", port); PRINTK("port:%d\r\n", port);
sockfd = lwip_socket(AF_INET, SOCK_DGRAM, IPPROTO_UDP); sockfd = lwip_socket(AF_INET, SOCK_DGRAM, IPPROTO_UDP);
if (sockfd == -1) { if (sockfd == -1) {
PRINTK("\ncreate socket fail\n"); PRINTK("\ncreate socket fail\n");
return; return;
} }
(void)memset_s(&seraddr, sizeof(seraddr), 0, sizeof(seraddr));
(void)memset_s(&cliaddr, sizeof(cliaddr), 0, sizeof(cliaddr));
seraddr.sin_family = AF_INET;
seraddr.sin_addr.s_addr = htonl(INADDR_ANY);
seraddr.sin_port = htons(port);
ret = lwip_bind(sockfd, (struct sockaddr *)&seraddr, sizeof(seraddr));
if (ret < 0) {
PRINTK("bind ip and port failed:%d\n", errno);
(void)closesocket(sockfd);
return;
}
while (1) {
ret = recvfrom(sockfd, msg, MAX_SIZE - 1, 0, (struct sockaddr *)&cliaddr, (socklen_t *)&fromlen);
if (ret >= 0) {
n = strlen(msg);
for (i = 0; i < n; ++i) {
if (msg[i] >= 'a' && msg[i] <= 'z') {
msg[i] = (char)(msg[i] + 'A' - 'a');
} else if (msg[i] >= 'A' && msg[i] <= 'Z') {
msg[i] = (char)(msg[i] + 'a' - 'A');
}
}
ret = sendto(sockfd, msg, n + 1, 0, (struct sockaddr *)&cliaddr, (socklen_t)fromlen);
if (ret <= 0 && errno == EPIPE) {
break;
}
} else {
break;
}
}
(void)memset_s(&seraddr, sizeof(seraddr), 0, sizeof(seraddr));
(void)memset_s(&cliaddr, sizeof(cliaddr), 0, sizeof(cliaddr));
seraddr.sin_family = AF_INET;
seraddr.sin_addr.s_addr = htonl(INADDR_ANY);
seraddr.sin_port = htons(port);
ret = lwip_bind(sockfd, (struct sockaddr*)&seraddr, sizeof(seraddr));
if (ret < 0) {
PRINTK("bind ip and port failed:%d\n", errno);
(void)closesocket(sockfd); (void)closesocket(sockfd);
return; return;
}
while(1) {
ret = recvfrom(sockfd, msg, MAX_SIZE - 1, 0, (struct sockaddr *)&cliaddr, (socklen_t *)&fromlen);
if (ret >= 0) {
n = strlen(msg);
for (i = 0; i < n; ++i) {
if (msg[i] >= 'a' && msg[i] <= 'z') {
msg[i] = (char)(msg[i] + 'A' - 'a');
} else if (msg[i] >= 'A' && msg[i] <= 'Z') {
msg[i] = (char)(msg[i] + 'a' - 'A');
}
}
ret = sendto(sockfd, msg, n + 1, 0, (struct sockaddr *)&cliaddr, (socklen_t)fromlen);
if (ret <= 0 && errno == EPIPE) {
break;
}
} else {
break;
}
}
(void)closesocket(sockfd);
return;
} }
#ifdef LOSCFG_SHELL_CMD_DEBUG #ifdef LOSCFG_SHELL_CMD_DEBUG
@ -3741,115 +3741,115 @@ SHELLCMD_ENTRY(udpserver_shellcmd, CMD_TYPE_EX, "udpserver", XARGS, (CmdCallBack
LWIP_STATIC LWIP_STATIC
u32_t netdebug_memp(int argc, const char **argv) u32_t netdebug_memp(int argc, const char **argv)
{ {
u32_t ret = LOS_OK; u32_t ret = LOS_OK;
int type; int type;
if (argc == 2) { if (argc == 2) {
if (!strcmp("-i", argv[1])) { if (!strcmp("-i", argv[1])) {
debug_memp_info(); debug_memp_info();
} else if (!strcmp("-udp", argv[1])) { } else if (!strcmp("-udp", argv[1])) {
debug_memp_type_info(MEMP_UDP_PCB); debug_memp_type_info(MEMP_UDP_PCB);
} else if (!strcmp("-tcp", argv[1])) { } else if (!strcmp("-tcp", argv[1])) {
debug_memp_type_info(MEMP_TCP_PCB); debug_memp_type_info(MEMP_TCP_PCB);
} else if (!strcmp("-raw", argv[1])) { } else if (!strcmp("-raw", argv[1])) {
debug_memp_type_info(MEMP_RAW_PCB); debug_memp_type_info(MEMP_RAW_PCB);
} else if (!strcmp("-conn", argv[1])) { } else if (!strcmp("-conn", argv[1])) {
debug_memp_type_info(MEMP_NETCONN); debug_memp_type_info(MEMP_NETCONN);
} else {
ret = LOS_NOK;
}
} else if (argc == 3) {
if (!strcmp("-d", argv[1])) {
type = atoi(argv[2]);
if (type >= 0) {
debug_memp_detail(type);
} else {
PRINTK("Error: type < 0\n");
ret = LOS_NOK;
}
} else {
ret = LOS_NOK;
}
} else { } else {
ret = LOS_NOK;
}
} else if (argc == 3) {
if (!strcmp("-d", argv[1])) {
type = atoi(argv[2]);
if (type >= 0) {
debug_memp_detail(type);
} else {
PRINTK("Error: type < 0\n");
ret = LOS_NOK; ret = LOS_NOK;
}
} else {
ret = LOS_NOK;
} }
} else {
ret = LOS_NOK;
}
return ret; return ret;
} }
LWIP_STATIC LWIP_STATIC
u32_t netdebug_sock(int argc, const char **argv) u32_t netdebug_sock(int argc, const char **argv)
{ {
int idx; int idx;
u32_t ret = LOS_NOK; u32_t ret = LOS_NOK;
if (argc == 2) { if (argc == 2) {
if (!strcmp("-i", argv[1])) { if (!strcmp("-i", argv[1])) {
/* netdebug sock -i */ /* netdebug sock -i */
for (idx = 0; idx < (int)LWIP_CONFIG_NUM_SOCKETS; idx++) { for (idx = 0; idx < (int)LWIP_CONFIG_NUM_SOCKETS; idx++) {
debug_socket_info(idx, 1, 0); debug_socket_info(idx, 1, 0);
} }
ret = LOS_OK; ret = LOS_OK;
}
} else if (argc == 3) {
if (!strcmp("-d", argv[1])) {
/* netdebug sock -d <idx> */
idx = atoi(argv[2]);
if (idx >= 0) {
debug_socket_info(idx, 1, 1);
ret = LOS_OK;
} else {
PRINTK("Error: idx < 0\n");
}
}
} }
} else if (argc == 3) {
if (!strcmp("-d", argv[1])) {
/* netdebug sock -d <idx> */
idx = atoi(argv[2]);
if (idx >= 0) {
debug_socket_info(idx, 1, 1);
ret = LOS_OK;
} else {
PRINTK("Error: idx < 0\n");
}
}
}
return ret; return ret;
} }
u32_t osShellNetDebug(int argc, const char **argv) u32_t osShellNetDebug(int argc, const char **argv)
{ {
u32_t ret = LOS_NOK; u32_t ret = LOS_NOK;
if (argc < 1 || argv == NULL) { if (argc < 1 || argv == NULL) {
goto usage; goto usage;
} }
if (!strcmp("memp", argv[0])) { if (!strcmp("memp", argv[0])) {
ret = netdebug_memp(argc, argv); ret = netdebug_memp(argc, argv);
if (ret != LOS_OK) { if (ret != LOS_OK) {
goto usage_memp; goto usage_memp;
}
} else if (!strcmp("sock", argv[0])) {
/* netdebug sock {-i | -d <idx>} */
ret = netdebug_sock(argc, argv);
if (ret != LOS_OK) {
goto usage_sock;
}
} else {
goto usage;
} }
} else if (!strcmp("sock", argv[0])) { return ret;
/* netdebug sock {-i | -d <idx>} */
ret = netdebug_sock(argc, argv);
if (ret != LOS_OK) {
goto usage_sock;
}
} else {
goto usage;
}
return ret;
usage: usage:
/* Cmd help */ /* Cmd help */
PRINTK("\nUsage:\n"); PRINTK("\nUsage:\n");
PRINTK("netdebug memp {-i | -d <type> | -udp | -tcp | -raw |-conn}\n"); PRINTK("netdebug memp {-i | -d <type> | -udp | -tcp | -raw |-conn}\n");
PRINTK("netdebug sock {-i | -d <idx>}\n"); PRINTK("netdebug sock {-i | -d <idx>}\n");
return LOS_NOK; return LOS_NOK;
usage_memp: usage_memp:
/* netdebug memp help */ /* netdebug memp help */
PRINTK("\nUsage:\n"); PRINTK("\nUsage:\n");
PRINTK("netdebug memp {-i | -d <type> | -udp | -tcp | -raw |-conn}\n"); PRINTK("netdebug memp {-i | -d <type> | -udp | -tcp | -raw |-conn}\n");
return LOS_NOK; return LOS_NOK;
usage_sock: usage_sock:
/* netdebug sock help */ /* netdebug sock help */
PRINTK("\nUsage:\n"); PRINTK("\nUsage:\n");
PRINTK("netdebug sock {-i | -d <idx>}\n"); PRINTK("netdebug sock {-i | -d <idx>}\n");
return LOS_NOK; return LOS_NOK;
} }
#endif /* LWIP_DEBUG_INFO */ #endif /* LWIP_DEBUG_INFO */
@ -3991,7 +3991,7 @@ extern void cmd_reset(void);
void osShellReboot(int argc, const char **argv) void osShellReboot(int argc, const char **argv)
{ {
cmd_reset(); cmd_reset();
} }
#ifdef LOSCFG_SHELL_CMD_DEBUG #ifdef LOSCFG_SHELL_CMD_DEBUG