parent
ff52e24fba
commit
9b25a48dd4
|
@ -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
|
||||||
|
|
Loading…
Reference in New Issue