Changes in uspace/app/nettest2/nettest2.c [d4d74dc:1ab8539] in mainline
- File:
-
- 1 edited
Legend:
- Unmodified
- Added
- Removed
-
uspace/app/nettest2/nettest2.c
rd4d74dc r1ab8539 38 38 #include "print_error.h" 39 39 40 #include <assert.h> 40 41 #include <malloc.h> 41 42 #include <stdio.h> … … 45 46 #include <time.h> 46 47 #include <arg_parse.h> 47 #include <bool.h> 48 48 #include <stdbool.h> 49 50 #include <inet/dnsr.h> 49 51 #include <net/in.h> 50 52 #include <net/in6.h> … … 54 56 55 57 /** Echo module name. */ 56 #define NAME "Nettest2"58 #define NAME "nettest2" 57 59 58 60 /** Packet data pattern. */ 59 #define NETTEST2_TEXT 60 61 static size_t size;62 static bool verbose;63 static sock_type_t type;64 static int sockets;65 static int messages;66 static int family;67 static uint16_t port ;61 #define NETTEST2_TEXT "Networking test 2 - transfer" 62 63 static uint16_t family = AF_NONE; 64 static size_t size = 28; 65 static bool verbose = false; 66 static sock_type_t type = SOCK_DGRAM; 67 static int sockets = 10; 68 static int messages = 10; 69 static uint16_t port = 7; 68 70 69 71 static void nettest2_print_help(void) … … 71 73 printf( 72 74 "Network Networking test 2 aplication - UDP transfer\n" 73 "Usage: echo [options] address\n"75 "Usage: nettest2 [options] host\n" 74 76 "Where options are:\n" 75 77 "-f protocol_family | --family=protocol_family\n" … … 106 108 static void nettest2_fill_buffer(char *buffer, size_t size) 107 109 { 108 size_t length; 109 110 length = 0; 110 size_t length = 0; 111 111 while (size > length + sizeof(NETTEST2_TEXT) - 1) { 112 112 memcpy(buffer + length, NETTEST2_TEXT, … … 114 114 length += sizeof(NETTEST2_TEXT) - 1; 115 115 } 116 116 117 117 memcpy(buffer + length, NETTEST2_TEXT, size - length); 118 118 buffer[size] = '\0'; … … 129 129 int value; 130 130 int rc; 131 131 132 132 switch (argv[*index][1]) { 133 133 /* … … 135 135 */ 136 136 case 'f': 137 rc = arg_parse_name_int(argc, argv, index, & family, 0,137 rc = arg_parse_name_int(argc, argv, index, &value, 0, 138 138 socket_parse_protocol_family); 139 139 if (rc != EOK) 140 140 return rc; 141 142 family = (uint16_t) value; 141 143 break; 142 144 case 'h': 143 145 nettest2_print_help(); 144 146 return EOK; 145 break;146 147 case 'm': 147 148 rc = arg_parse_int(argc, argv, index, &messages, 0); 148 149 if (rc != EOK) 149 150 return rc; 151 150 152 break; 151 153 case 'n': … … 153 155 if (rc != EOK) 154 156 return rc; 157 155 158 break; 156 159 case 'p': … … 158 161 if (rc != EOK) 159 162 return rc; 163 160 164 port = (uint16_t) value; 161 165 break; … … 164 168 if (rc != EOK) 165 169 return rc; 170 166 171 size = (value >= 0) ? (size_t) value : 0; 167 172 break; … … 171 176 if (rc != EOK) 172 177 return rc; 178 173 179 type = (sock_type_t) value; 174 180 break; … … 176 182 verbose = true; 177 183 break; 184 178 185 /* 179 186 * Long options with double dash ('-') … … 181 188 case '-': 182 189 if (str_lcmp(argv[*index] + 2, "family=", 7) == 0) { 183 rc = arg_parse_name_int(argc, argv, index, & family, 9,190 rc = arg_parse_name_int(argc, argv, index, &value, 9, 184 191 socket_parse_protocol_family); 185 192 if (rc != EOK) 186 193 return rc; 194 195 family = (uint16_t) value; 187 196 } else if (str_lcmp(argv[*index] + 2, "help", 5) == 0) { 188 197 nettest2_print_help(); … … 200 209 if (rc != EOK) 201 210 return rc; 211 202 212 port = (uint16_t) value; 203 213 } else if (str_lcmp(argv[*index] + 2, "type=", 5) == 0) { … … 206 216 if (rc != EOK) 207 217 return rc; 218 208 219 type = (sock_type_t) value; 209 220 } else if (str_lcmp(argv[*index] + 2, "verbose", 8) == 0) { … … 218 229 return EINVAL; 219 230 } 220 231 221 232 return EOK; 222 233 } … … 224 235 int main(int argc, char *argv[]) 225 236 { 226 struct sockaddr *address;227 struct sockaddr_in address_in;228 struct sockaddr_in6 address_in6;229 socklen_t addrlen;230 uint8_t *address_start;231 232 int *socket_ids;233 char *data;234 237 int index; 235 struct timeval time_before;236 struct timeval time_after;237 238 238 int rc; 239 240 size = 28; 241 verbose = false; 242 type = SOCK_DGRAM; 243 sockets = 10; 244 messages = 10; 245 family = PF_INET; 246 port = 7; 247 239 248 240 /* 249 241 * Parse the command line arguments. … … 253 245 for (index = 1; (index < argc - 1) || ((index == argc - 1) && 254 246 (argv[index][0] == '-')); ++index) { 255 256 247 /* Options should start with dash ('-') */ 257 248 if (argv[index][0] == '-') { … … 264 255 } 265 256 } 266 267 /* If not before the last argument containing the address*/257 258 /* The last argument containing the host */ 268 259 if (index >= argc) { 269 printf(" Command line error: missing address\n");260 printf("Host name missing.\n"); 270 261 nettest2_print_help(); 271 262 return EINVAL; 272 263 } 273 274 /* Prepare the address buffer */ 275 276 switch (family) { 277 case PF_INET: 278 address_in.sin_family = AF_INET; 279 address_in.sin_port = htons(port); 280 address = (struct sockaddr *) &address_in; 281 addrlen = sizeof(address_in); 282 address_start = (uint8_t *) &address_in.sin_addr.s_addr; 283 break; 284 case PF_INET6: 285 address_in6.sin6_family = AF_INET6; 286 address_in6.sin6_port = htons(port); 287 address = (struct sockaddr *) &address_in6; 288 addrlen = sizeof(address_in6); 289 address_start = (uint8_t *) &address_in6.sin6_addr.s6_addr; 290 break; 291 default: 292 fprintf(stderr, "Address family is not supported\n"); 293 return EAFNOSUPPORT; 294 } 295 296 /* Parse the last argument which should contain the address. */ 297 rc = inet_pton(family, argv[argc - 1], address_start); 264 265 char *addr_s = argv[argc - 1]; 266 267 /* Interpret as address */ 268 inet_addr_t addr_addr; 269 rc = inet_addr_parse(addr_s, &addr_addr); 270 298 271 if (rc != EOK) { 299 fprintf(stderr, "Address parse error %d\n", rc); 300 return rc; 301 } 302 272 /* Interpret as a host name */ 273 dnsr_hostinfo_t *hinfo = NULL; 274 rc = dnsr_name2host(addr_s, &hinfo, ipver_from_af(family)); 275 276 if (rc != EOK) { 277 printf("Error resolving host '%s'.\n", addr_s); 278 return EINVAL; 279 } 280 281 addr_addr = hinfo->addr; 282 } 283 284 struct sockaddr *address; 285 socklen_t addrlen; 286 rc = inet_addr_sockaddr(&addr_addr, port, &address, &addrlen); 287 if (rc != EOK) { 288 assert(rc == ENOMEM); 289 printf("Out of memory.\n"); 290 return ENOMEM; 291 } 292 293 if (family == AF_NONE) 294 family = address->sa_family; 295 296 if (address->sa_family != family) { 297 printf("Address family does not match explicitly set family.\n"); 298 return EINVAL; 299 } 300 303 301 /* Check data buffer size. */ 304 302 if (size <= 0) { … … 307 305 size = 1024; 308 306 } 309 307 310 308 /* 311 309 * Prepare the buffer. Allocate size bytes plus one for terminating 312 310 * null character. 313 311 */ 314 data = (char *) malloc(size + 1);312 char *data = (char *) malloc(size + 1); 315 313 if (!data) { 316 314 fprintf(stderr, "Failed to allocate data buffer.\n"); 317 315 return ENOMEM; 318 316 } 319 317 320 318 /* Fill buffer with a pattern. */ 321 319 nettest2_fill_buffer(data, size); 322 320 323 321 /* Check socket count. */ 324 322 if (sockets <= 0) { … … 327 325 sockets = 2; 328 326 } 329 327 330 328 /* 331 329 * Prepare the socket buffer. 332 330 * Allocate count entries plus the terminating null (\0) 333 331 */ 334 socket_ids = (int *) malloc(sizeof(int) * (sockets + 1));332 int *socket_ids = (int *) malloc(sizeof(int) * (sockets + 1)); 335 333 if (!socket_ids) { 336 334 fprintf(stderr, "Failed to allocate receive buffer.\n"); 337 335 return ENOMEM; 338 336 } 337 339 338 socket_ids[sockets] = 0; 340 339 341 340 if (verbose) 342 341 printf("Starting tests\n"); 343 342 344 343 rc = sockets_create(verbose, socket_ids, sockets, family, type); 345 344 if (rc != EOK) 346 345 return rc; 347 346 348 347 if (type == SOCK_STREAM) { 349 348 rc = sockets_connect(verbose, socket_ids, sockets, … … 352 351 return rc; 353 352 } 354 353 355 354 if (verbose) 356 355 printf("\n"); 357 358 rc = gettimeofday(&time_before, NULL); 359 if (rc != EOK) { 360 fprintf(stderr, "Get time of day error %d\n", rc); 361 return rc; 362 } 363 356 357 struct timeval time_before; 358 gettimeofday(&time_before, NULL); 359 364 360 rc = sockets_sendto_recvfrom(verbose, socket_ids, sockets, address, 365 &addrlen, data, size, messages );361 &addrlen, data, size, messages, type); 366 362 if (rc != EOK) 367 363 return rc; 368 369 rc = gettimeofday(&time_after, NULL); 370 if (rc != EOK) { 371 fprintf(stderr, "Get time of day error %d\n", rc); 372 return rc; 373 } 374 364 365 struct timeval time_after; 366 gettimeofday(&time_after, NULL); 367 375 368 if (verbose) 376 369 printf("\tOK\n"); 377 370 378 371 printf("sendto + recvfrom tested in %ld microseconds\n", 379 372 tv_sub(&time_after, &time_before)); 380 381 rc = gettimeofday(&time_before, NULL); 382 if (rc != EOK) { 383 fprintf(stderr, "Get time of day error %d\n", rc); 384 return rc; 385 } 386 373 374 gettimeofday(&time_before, NULL); 375 387 376 rc = sockets_sendto(verbose, socket_ids, sockets, address, addrlen, 388 data, size, messages );377 data, size, messages, type); 389 378 if (rc != EOK) 390 379 return rc; 391 380 392 381 rc = sockets_recvfrom(verbose, socket_ids, sockets, address, &addrlen, 393 382 data, size, messages); 394 383 if (rc != EOK) 395 384 return rc; 396 397 rc = gettimeofday(&time_after, NULL); 398 if (rc != EOK) { 399 fprintf(stderr, "Get time of day error %d\n", rc); 400 return rc; 401 } 402 385 386 gettimeofday(&time_after, NULL); 387 403 388 if (verbose) 404 389 printf("\tOK\n"); 405 390 406 391 printf("sendto, recvfrom tested in %ld microseconds\n", 407 392 tv_sub(&time_after, &time_before)); 408 393 409 394 rc = sockets_close(verbose, socket_ids, sockets); 410 395 if (rc != EOK) 411 396 return rc; 412 397 398 free(address); 399 413 400 if (verbose) 414 401 printf("\nExiting\n"); 415 402 416 403 return EOK; 417 404 }
Note:
See TracChangeset
for help on using the changeset viewer.