2011-03-20 19:18:19 +01:00
|
|
|
/****************************************************************************
|
2021-06-16 09:22:16 +02:00
|
|
|
* apps/examples/nettest/nettest_client.c
|
2011-03-20 19:18:19 +01:00
|
|
|
*
|
2021-06-15 09:09:58 +02:00
|
|
|
* Licensed to the Apache Software Foundation (ASF) under one or more
|
|
|
|
* contributor license agreements. See the NOTICE file distributed with
|
|
|
|
* this work for additional information regarding copyright ownership. The
|
|
|
|
* ASF licenses this file to you under the Apache License, Version 2.0 (the
|
|
|
|
* "License"); you may not use this file except in compliance with the
|
|
|
|
* License. You may obtain a copy of the License at
|
2011-03-20 19:18:19 +01:00
|
|
|
*
|
2021-06-15 09:09:58 +02:00
|
|
|
* http://www.apache.org/licenses/LICENSE-2.0
|
2011-03-20 19:18:19 +01:00
|
|
|
*
|
2021-06-15 09:09:58 +02:00
|
|
|
* Unless required by applicable law or agreed to in writing, software
|
|
|
|
* distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
|
|
|
|
* WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
|
|
|
|
* License for the specific language governing permissions and limitations
|
|
|
|
* under the License.
|
2011-03-20 19:18:19 +01:00
|
|
|
*
|
|
|
|
****************************************************************************/
|
|
|
|
|
|
|
|
/****************************************************************************
|
|
|
|
* Included Files
|
|
|
|
****************************************************************************/
|
|
|
|
|
2015-01-21 01:12:27 +01:00
|
|
|
#include "config.h"
|
|
|
|
|
2011-03-20 19:18:19 +01:00
|
|
|
#include <sys/socket.h>
|
|
|
|
#include <netinet/in.h>
|
|
|
|
|
|
|
|
#include <stdio.h>
|
|
|
|
#include <stdlib.h>
|
|
|
|
#include <unistd.h>
|
|
|
|
#include <string.h>
|
|
|
|
#include <errno.h>
|
|
|
|
|
2014-07-05 03:13:08 +02:00
|
|
|
#include <arpa/inet.h>
|
|
|
|
|
2011-03-20 19:18:19 +01:00
|
|
|
#include "nettest.h"
|
|
|
|
|
|
|
|
/****************************************************************************
|
|
|
|
* Public Functions
|
|
|
|
****************************************************************************/
|
|
|
|
|
2017-06-25 17:15:27 +02:00
|
|
|
void nettest_client(void)
|
2011-03-20 19:18:19 +01:00
|
|
|
{
|
2015-01-21 01:12:27 +01:00
|
|
|
#ifdef CONFIG_EXAMPLES_NETTEST_IPv6
|
2017-06-23 20:21:13 +02:00
|
|
|
struct sockaddr_in6 server;
|
2015-01-21 01:12:27 +01:00
|
|
|
#else
|
2017-06-23 20:21:13 +02:00
|
|
|
struct sockaddr_in server;
|
2015-01-21 01:12:27 +01:00
|
|
|
#endif
|
2011-03-20 19:18:19 +01:00
|
|
|
char *outbuf;
|
2012-10-04 19:36:07 +02:00
|
|
|
#ifndef CONFIG_EXAMPLES_NETTEST_PERFORMANCE
|
2011-03-20 19:18:19 +01:00
|
|
|
char *inbuf;
|
|
|
|
#endif
|
|
|
|
int sockfd;
|
2015-01-21 01:12:27 +01:00
|
|
|
socklen_t addrlen;
|
2011-03-20 19:18:19 +01:00
|
|
|
int nbytessent;
|
2012-10-04 19:36:07 +02:00
|
|
|
#ifndef CONFIG_EXAMPLES_NETTEST_PERFORMANCE
|
2011-03-20 19:18:19 +01:00
|
|
|
int nbytesrecvd;
|
|
|
|
int totalbytesrecvd;
|
|
|
|
#endif
|
|
|
|
int ch;
|
|
|
|
int i;
|
|
|
|
|
|
|
|
/* Allocate buffers */
|
|
|
|
|
2020-05-21 22:17:48 +02:00
|
|
|
outbuf = malloc(SENDSIZE);
|
2012-10-04 19:36:07 +02:00
|
|
|
#ifndef CONFIG_EXAMPLES_NETTEST_PERFORMANCE
|
2020-05-21 22:17:48 +02:00
|
|
|
inbuf = malloc(SENDSIZE);
|
2011-03-20 19:18:19 +01:00
|
|
|
if (!outbuf || !inbuf)
|
|
|
|
#else
|
|
|
|
if (!outbuf)
|
|
|
|
#endif
|
|
|
|
{
|
2014-10-08 16:33:00 +02:00
|
|
|
printf("client: failed to allocate buffers\n");
|
2011-03-20 19:18:19 +01:00
|
|
|
exit(1);
|
|
|
|
}
|
|
|
|
|
|
|
|
/* Create a new TCP socket */
|
|
|
|
|
2015-01-21 01:12:27 +01:00
|
|
|
sockfd = socket(PF_INETX, SOCK_STREAM, 0);
|
2011-03-20 19:18:19 +01:00
|
|
|
if (sockfd < 0)
|
|
|
|
{
|
2014-10-08 16:33:00 +02:00
|
|
|
printf("client socket failure %d\n", errno);
|
2011-03-20 19:18:19 +01:00
|
|
|
goto errout_with_buffers;
|
|
|
|
}
|
|
|
|
|
2017-06-23 20:21:13 +02:00
|
|
|
/* Set up the server address */
|
2011-03-20 19:18:19 +01:00
|
|
|
|
2015-01-21 01:12:27 +01:00
|
|
|
#ifdef CONFIG_EXAMPLES_NETTEST_IPv6
|
2020-05-21 22:17:48 +02:00
|
|
|
server.sin6_family = AF_INET6;
|
|
|
|
server.sin6_port = HTONS(CONFIG_EXAMPLES_NETTEST_SERVER_PORTNO);
|
|
|
|
memcpy(server.sin6_addr.s6_addr16,
|
|
|
|
g_nettestserver_ipv6, 8 * sizeof(uint16_t));
|
|
|
|
addrlen = sizeof(struct sockaddr_in6);
|
|
|
|
|
|
|
|
printf("Connecting to Address: %04x:%04x:%04x:%04x:%04x:%04x:%04x:%04x\n",
|
|
|
|
g_nettestserver_ipv6[0], g_nettestserver_ipv6[1],
|
|
|
|
g_nettestserver_ipv6[2], g_nettestserver_ipv6[3],
|
|
|
|
g_nettestserver_ipv6[4], g_nettestserver_ipv6[5],
|
|
|
|
g_nettestserver_ipv6[6], g_nettestserver_ipv6[7]);
|
2011-03-20 19:18:19 +01:00
|
|
|
#else
|
2020-05-21 22:17:48 +02:00
|
|
|
server.sin_family = AF_INET;
|
|
|
|
server.sin_port = HTONS(CONFIG_EXAMPLES_NETTEST_SERVER_PORTNO);
|
|
|
|
server.sin_addr.s_addr = (in_addr_t)g_nettestserver_ipv4;
|
|
|
|
addrlen = sizeof(struct sockaddr_in);
|
2015-08-26 18:35:40 +02:00
|
|
|
|
2020-05-21 22:17:48 +02:00
|
|
|
printf("Connecting to Address: %08lx\n",
|
|
|
|
(unsigned long)g_nettestserver_ipv4);
|
2015-08-26 18:35:40 +02:00
|
|
|
#endif
|
2015-01-21 01:12:27 +01:00
|
|
|
|
2017-06-23 20:21:13 +02:00
|
|
|
/* Connect the socket to the server */
|
2011-03-20 19:18:19 +01:00
|
|
|
|
2020-05-21 22:17:48 +02:00
|
|
|
if (connect(sockfd, (struct sockaddr *)&server, addrlen) < 0)
|
2011-03-20 19:18:19 +01:00
|
|
|
{
|
2014-10-08 16:33:00 +02:00
|
|
|
printf("client: connect failure: %d\n", errno);
|
2011-03-20 19:18:19 +01:00
|
|
|
goto errout_with_socket;
|
|
|
|
}
|
2015-01-21 01:12:27 +01:00
|
|
|
|
2014-10-08 16:33:00 +02:00
|
|
|
printf("client: Connected\n");
|
2011-03-20 19:18:19 +01:00
|
|
|
|
|
|
|
/* Initialize the buffer */
|
|
|
|
|
|
|
|
ch = 0x20;
|
|
|
|
for (i = 0; i < SENDSIZE; i++ )
|
|
|
|
{
|
|
|
|
outbuf[i] = ch;
|
|
|
|
if (++ch > 0x7e)
|
|
|
|
{
|
|
|
|
ch = 0x20;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2012-10-04 19:36:07 +02:00
|
|
|
#ifdef CONFIG_EXAMPLES_NETTEST_PERFORMANCE
|
2011-12-13 18:25:23 +01:00
|
|
|
/* Then send messages forever */
|
2011-03-20 19:18:19 +01:00
|
|
|
|
2020-05-21 22:17:48 +02:00
|
|
|
for (; ; )
|
2011-03-20 19:18:19 +01:00
|
|
|
{
|
2011-12-13 20:58:24 +01:00
|
|
|
nbytessent = send(sockfd, outbuf, SENDSIZE, 0);
|
2011-03-20 19:18:19 +01:00
|
|
|
if (nbytessent < 0)
|
|
|
|
{
|
2014-10-08 16:33:00 +02:00
|
|
|
printf("client: send failed: %d\n", errno);
|
2011-03-20 19:18:19 +01:00
|
|
|
goto errout_with_socket;
|
|
|
|
}
|
2011-12-13 20:58:24 +01:00
|
|
|
else if (nbytessent != SENDSIZE)
|
2011-03-20 19:18:19 +01:00
|
|
|
{
|
2014-10-08 16:33:00 +02:00
|
|
|
printf("client: Bad send length=%d: %d of \n",
|
2011-12-13 20:58:24 +01:00
|
|
|
nbytessent, SENDSIZE);
|
2011-03-20 19:18:19 +01:00
|
|
|
goto errout_with_socket;
|
|
|
|
}
|
2015-01-21 01:12:27 +01:00
|
|
|
|
2014-10-08 16:33:00 +02:00
|
|
|
printf("Sent %d bytes\n", nbytessent);
|
2011-03-20 19:18:19 +01:00
|
|
|
}
|
|
|
|
#else
|
|
|
|
/* Then send and receive one message */
|
|
|
|
|
2014-10-08 16:33:00 +02:00
|
|
|
printf("client: Sending %d bytes\n", SENDSIZE);
|
2011-03-20 19:18:19 +01:00
|
|
|
nbytessent = send(sockfd, outbuf, SENDSIZE, 0);
|
2014-10-08 16:33:00 +02:00
|
|
|
printf("client: Sent %d bytes\n", nbytessent);
|
2011-03-20 19:18:19 +01:00
|
|
|
|
|
|
|
if (nbytessent < 0)
|
|
|
|
{
|
2014-10-08 16:33:00 +02:00
|
|
|
printf("client: send failed: %d\n", errno);
|
2011-03-20 19:18:19 +01:00
|
|
|
goto errout_with_socket;
|
|
|
|
}
|
|
|
|
else if (nbytessent != SENDSIZE)
|
|
|
|
{
|
2020-05-21 22:17:48 +02:00
|
|
|
printf("client: Bad send length: %d Expected: %d\n",
|
|
|
|
nbytessent, SENDSIZE);
|
2011-03-20 19:18:19 +01:00
|
|
|
goto errout_with_socket;
|
|
|
|
}
|
|
|
|
|
|
|
|
totalbytesrecvd = 0;
|
|
|
|
do
|
|
|
|
{
|
2014-10-08 16:33:00 +02:00
|
|
|
printf("client: Receiving...\n");
|
2020-05-21 22:17:48 +02:00
|
|
|
nbytesrecvd = recv(sockfd, &inbuf[totalbytesrecvd],
|
|
|
|
SENDSIZE - totalbytesrecvd, 0);
|
2011-03-20 19:18:19 +01:00
|
|
|
|
|
|
|
if (nbytesrecvd < 0)
|
|
|
|
{
|
2014-10-08 16:33:00 +02:00
|
|
|
printf("client: recv failed: %d\n", errno);
|
2011-03-20 19:18:19 +01:00
|
|
|
goto errout_with_socket;
|
|
|
|
}
|
2012-02-18 19:13:30 +01:00
|
|
|
else if (nbytesrecvd == 0)
|
|
|
|
{
|
2014-10-08 16:33:00 +02:00
|
|
|
printf("client: The server closed the connection\n");
|
2012-02-18 19:13:30 +01:00
|
|
|
goto errout_with_socket;
|
|
|
|
}
|
2015-01-21 01:12:27 +01:00
|
|
|
|
2011-03-20 19:18:19 +01:00
|
|
|
totalbytesrecvd += nbytesrecvd;
|
2014-10-08 16:33:00 +02:00
|
|
|
printf("client: Received %d of %d bytes\n", totalbytesrecvd, SENDSIZE);
|
2011-03-20 19:18:19 +01:00
|
|
|
}
|
|
|
|
while (totalbytesrecvd < SENDSIZE);
|
|
|
|
|
|
|
|
if (totalbytesrecvd != SENDSIZE)
|
|
|
|
{
|
2020-05-21 22:17:48 +02:00
|
|
|
printf("client: Bad recv length: %d Expected: %d\n",
|
|
|
|
totalbytesrecvd, SENDSIZE);
|
2011-03-20 19:18:19 +01:00
|
|
|
goto errout_with_socket;
|
|
|
|
}
|
|
|
|
else if (memcmp(inbuf, outbuf, SENDSIZE) != 0)
|
|
|
|
{
|
2014-10-08 16:33:00 +02:00
|
|
|
printf("client: Received buffer does not match sent buffer\n");
|
2011-03-20 19:18:19 +01:00
|
|
|
goto errout_with_socket;
|
|
|
|
}
|
|
|
|
|
2017-06-26 18:54:32 +02:00
|
|
|
printf("client: Terminating\n");
|
2011-03-20 19:18:19 +01:00
|
|
|
close(sockfd);
|
|
|
|
free(outbuf);
|
2012-10-04 19:36:07 +02:00
|
|
|
#ifndef CONFIG_EXAMPLES_NETTEST_PERFORMANCE
|
2011-03-20 19:18:19 +01:00
|
|
|
free(inbuf);
|
|
|
|
#endif
|
|
|
|
return;
|
|
|
|
#endif
|
|
|
|
|
|
|
|
errout_with_socket:
|
|
|
|
close(sockfd);
|
|
|
|
|
|
|
|
errout_with_buffers:
|
|
|
|
free(outbuf);
|
2012-10-04 19:36:07 +02:00
|
|
|
#ifndef CONFIG_EXAMPLES_NETTEST_PERFORMANCE
|
2011-03-20 19:18:19 +01:00
|
|
|
free(inbuf);
|
|
|
|
#endif
|
|
|
|
exit(1);
|
|
|
|
}
|