/*
* CDDL HEADER START
*
* The contents of this file are subject to the terms
* of the Common Development and Distribution License
* (the "License"). You may not use this file except
* in compliance with the License.
*
* You can obtain a copy of the license at
* See the License for the specific language governing
* permissions and limitations under the License.
*
* When distributing Covered Code, include this CDDL
* HEADER in each file and include the License file at
* usr/src/OPENSOLARIS.LICENSE. If applicable,
* add the following below this CDDL HEADER, with the
* fields enclosed by brackets "[]" replaced with your
* own identifying information: Portions Copyright [yyyy]
* [name of copyright owner]
*
* CDDL HEADER END
*/
/*
* Copyright 2005 Sun Microsystems, Inc. All rights reserved.
* Use is subject to license terms.
*/
#include <netdb.h>
#include <string.h>
#include <unistd.h>
#include <stdlib.h>
#include <stdio.h>
#include <fcntl.h>
#include <errno.h>
#include "libmicro.h"
typedef struct {
int ts_once;
int *ts_lsns;
int *ts_accs;
int *ts_cons;
} tsd_t;
static int opta = 0;
static int optc = 0;
int
{
lm_defB = 256;
lm_tsdsize = sizeof (tsd_t);
" [-a] (measure accept() only)\n"
" [-c] (measure connect() only)\n"
"notes: measures connect()/accept()\n");
return (0);
}
/*ARGSUSED*/
int
{
switch (opt) {
case 'a':
opta = 1;
break;
case 'c':
optc = 1;
break;
default:
return (-1);
}
(void) printf("warning: -a overrides -c\n");
optc = 0;
}
return (0);
}
int
{
return (0);
}
int
{
int i, j;
int errors = 0;
errors ++;
}
errors ++;
}
errors ++;
}
sizeof (struct sockaddr_in));
errors ++;
}
j = FIRSTPORT;
for (i = 0; i < lm_optB; i++) {
perror("socket");
errors ++;
}
/*
* make accept socket non-blocking so in case of errors
* we don't hang
*/
perror("fcntl");
errors ++;
}
errors ++;
}
for (;;) {
sizeof (struct sockaddr_in));
sizeof (struct sockaddr_in)) == 0) {
break;
}
if (errno != EADDRINUSE) {
errors ++;
}
}
perror("listen");
errors ++;
}
}
return (errors);
}
int
{
int i;
int errors = 0;
int result;
return (-1);
}
}
for (i = 0; i < lm_optB; i++) {
perror("init:socket");
errors ++;
}
perror("init:fcntl");
errors ++;
}
if (opta) {
sizeof (struct sockaddr_in));
perror("init:connect");
errors ++;
}
}
}
return (errors);
}
int
{
int i;
int result;
for (i = 0; i < lm_optB; i++) {
if (!opta) {
sizeof (struct sockaddr_in));
if (errno == EINPROGRESS) {
if (optc)
continue;
goto again;
}
perror("benchmark:connect");
continue;
}
}
if (!optc) {
for (;;) {
break;
break;
}
if (result == -1) {
perror("benchmark:accept");
continue;
}
}
}
return (0);
}
int
{
int i;
for (i = 0; i < lm_optB; i++) {
if (!optc) {
}
}
return (0);
}