2004-03-09 05:13:13 +03:00
/*
Unix SMB / CIFS implementation .
SMB torture tester - NBENCH test
Copyright ( C ) Andrew Tridgell 1997 - 2004
This program is free software ; you can redistribute it and / or modify
it under the terms of the GNU General Public License as published by
the Free Software Foundation ; either version 2 of the License , or
( at your option ) any later version .
This program is distributed in the hope that it will be useful ,
but WITHOUT ANY WARRANTY ; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE . See the
GNU General Public License for more details .
You should have received a copy of the GNU General Public License
along with this program ; if not , write to the Free Software
Foundation , Inc . , 675 Mass Ave , Cambridge , MA 0213 9 , USA .
*/
# include "includes.h"
2005-02-10 08:09:35 +03:00
# include "system/filesys.h"
# include "pstring.h"
2004-03-09 05:13:13 +03:00
int nbench_line_count = 0 ;
2004-03-09 05:24:14 +03:00
static int timelimit = 600 ;
2004-03-10 06:24:03 +03:00
static int warmup ;
2004-06-14 03:50:55 +04:00
static const char * loadfile ;
2004-03-09 05:13:13 +03:00
# define ival(s) strtol(s, NULL, 0)
/* run a test that simulates an approximate netbench client load */
2004-08-04 17:23:35 +04:00
static BOOL run_netbench ( struct smbcli_state * cli , int client )
2004-03-09 05:13:13 +03:00
{
2005-06-02 03:10:11 +04:00
extern int torture_nprocs ;
2004-03-09 05:13:13 +03:00
int i ;
pstring line ;
char * cname ;
FILE * f ;
fstring params [ 20 ] ;
const char * p ;
BOOL correct = True ;
2004-11-03 13:09:48 +03:00
2005-06-02 03:10:11 +04:00
if ( torture_nprocs = = 1 ) {
if ( ! torture_setup_dir ( cli , " \\ clients " ) ) {
return False ;
}
}
2004-11-26 02:05:43 +03:00
nb_setup ( cli , client ) ;
2004-03-09 05:13:13 +03:00
2004-03-26 05:09:51 +03:00
asprintf ( & cname , " client%d " , client + 1 ) ;
2004-03-09 05:13:13 +03:00
f = fopen ( loadfile , " r " ) ;
if ( ! f ) {
perror ( loadfile ) ;
return False ;
}
again :
while ( fgets ( line , sizeof ( line ) - 1 , f ) ) {
NTSTATUS status ;
2004-03-10 06:24:03 +03:00
2004-03-09 05:13:13 +03:00
nbench_line_count + + ;
line [ strlen ( line ) - 1 ] = 0 ;
all_string_sub ( line , " client1 " , cname , sizeof ( line ) ) ;
p = line ;
for ( i = 0 ;
i < 19 & & next_token ( & p , params [ i ] , " " , sizeof ( fstring ) ) ;
i + + ) ;
params [ i ] [ 0 ] = 0 ;
if ( i < 2 | | params [ 0 ] [ 0 ] = = ' # ' ) continue ;
if ( ! strncmp ( params [ 0 ] , " SMB " , 3 ) ) {
printf ( " ERROR: You are using a dbench 1 load file \n " ) ;
exit ( 1 ) ;
}
if ( strncmp ( params [ i - 1 ] , " NT_STATUS_ " , 10 ) ! = 0 ) {
printf ( " Badly formed status at line %d \n " , nbench_line_count ) ;
continue ;
}
status = nt_status_string_to_code ( params [ i - 1 ] ) ;
DEBUG ( 9 , ( " run_netbench(%d): %s %s \n " , client , params [ 0 ] , params [ 1 ] ) ) ;
if ( ! strcmp ( params [ 0 ] , " NTCreateX " ) ) {
nb_createx ( params [ 1 ] , ival ( params [ 2 ] ) , ival ( params [ 3 ] ) ,
ival ( params [ 4 ] ) , status ) ;
} else if ( ! strcmp ( params [ 0 ] , " Close " ) ) {
nb_close ( ival ( params [ 1 ] ) , status ) ;
} else if ( ! strcmp ( params [ 0 ] , " Rename " ) ) {
nb_rename ( params [ 1 ] , params [ 2 ] , status ) ;
} else if ( ! strcmp ( params [ 0 ] , " Unlink " ) ) {
nb_unlink ( params [ 1 ] , ival ( params [ 2 ] ) , status ) ;
} else if ( ! strcmp ( params [ 0 ] , " Deltree " ) ) {
nb_deltree ( params [ 1 ] ) ;
} else if ( ! strcmp ( params [ 0 ] , " Rmdir " ) ) {
nb_rmdir ( params [ 1 ] , status ) ;
2004-03-10 12:00:24 +03:00
} else if ( ! strcmp ( params [ 0 ] , " Mkdir " ) ) {
nb_mkdir ( params [ 1 ] , status ) ;
2004-03-09 05:13:13 +03:00
} else if ( ! strcmp ( params [ 0 ] , " QUERY_PATH_INFORMATION " ) ) {
nb_qpathinfo ( params [ 1 ] , ival ( params [ 2 ] ) , status ) ;
} else if ( ! strcmp ( params [ 0 ] , " QUERY_FILE_INFORMATION " ) ) {
nb_qfileinfo ( ival ( params [ 1 ] ) , ival ( params [ 2 ] ) , status ) ;
} else if ( ! strcmp ( params [ 0 ] , " QUERY_FS_INFORMATION " ) ) {
nb_qfsinfo ( ival ( params [ 1 ] ) , status ) ;
} else if ( ! strcmp ( params [ 0 ] , " SET_FILE_INFORMATION " ) ) {
nb_sfileinfo ( ival ( params [ 1 ] ) , ival ( params [ 2 ] ) , status ) ;
} else if ( ! strcmp ( params [ 0 ] , " FIND_FIRST " ) ) {
nb_findfirst ( params [ 1 ] , ival ( params [ 2 ] ) ,
ival ( params [ 3 ] ) , ival ( params [ 4 ] ) , status ) ;
} else if ( ! strcmp ( params [ 0 ] , " WriteX " ) ) {
nb_writex ( ival ( params [ 1 ] ) ,
ival ( params [ 2 ] ) , ival ( params [ 3 ] ) , ival ( params [ 4 ] ) ,
status ) ;
} else if ( ! strcmp ( params [ 0 ] , " Write " ) ) {
nb_write ( ival ( params [ 1 ] ) ,
ival ( params [ 2 ] ) , ival ( params [ 3 ] ) , ival ( params [ 4 ] ) ,
status ) ;
} else if ( ! strcmp ( params [ 0 ] , " LockX " ) ) {
nb_lockx ( ival ( params [ 1 ] ) ,
ival ( params [ 2 ] ) , ival ( params [ 3 ] ) , status ) ;
} else if ( ! strcmp ( params [ 0 ] , " UnlockX " ) ) {
nb_unlockx ( ival ( params [ 1 ] ) ,
ival ( params [ 2 ] ) , ival ( params [ 3 ] ) , status ) ;
} else if ( ! strcmp ( params [ 0 ] , " ReadX " ) ) {
nb_readx ( ival ( params [ 1 ] ) ,
ival ( params [ 2 ] ) , ival ( params [ 3 ] ) , ival ( params [ 4 ] ) ,
status ) ;
} else if ( ! strcmp ( params [ 0 ] , " Flush " ) ) {
nb_flush ( ival ( params [ 1 ] ) , status ) ;
2004-10-18 17:58:41 +04:00
} else if ( ! strcmp ( params [ 0 ] , " Sleep " ) ) {
nb_sleep ( ival ( params [ 1 ] ) , status ) ;
2004-03-09 05:13:13 +03:00
} else {
printf ( " [%d] Unknown operation %s \n " , nbench_line_count , params [ 0 ] ) ;
}
2004-11-26 02:05:43 +03:00
if ( nb_tick ( ) ) goto done ;
2004-03-09 05:13:13 +03:00
}
rewind ( f ) ;
goto again ;
done :
fclose ( f ) ;
2005-06-02 03:41:43 +04:00
if ( torture_nprocs = = 1 ) {
smbcli_deltree ( cli - > tree , " \\ clients " ) ;
}
2004-03-09 05:13:13 +03:00
if ( ! torture_close_connection ( cli ) ) {
correct = False ;
}
return correct ;
}
/* run a test that simulates an approximate netbench client load */
2004-10-28 17:40:50 +04:00
BOOL torture_nbench ( void )
2004-03-09 05:13:13 +03:00
{
BOOL correct = True ;
extern int torture_nprocs ;
2004-08-04 17:23:35 +04:00
struct smbcli_state * cli ;
2004-06-14 03:50:55 +04:00
const char * p ;
2004-03-09 05:13:13 +03:00
p = lp_parm_string ( - 1 , " torture " , " timelimit " ) ;
if ( p & & * p ) {
timelimit = atoi ( p ) ;
}
2004-03-10 06:24:03 +03:00
warmup = timelimit / 20 ;
2004-03-09 05:13:13 +03:00
loadfile = lp_parm_string ( - 1 , " torture " , " loadfile " ) ;
if ( ! loadfile | | ! * loadfile ) {
loadfile = " client.txt " ;
}
2005-06-02 03:10:11 +04:00
if ( torture_nprocs > 1 ) {
if ( ! torture_open_connection ( & cli ) ) {
return False ;
}
2004-03-09 05:13:13 +03:00
2005-06-02 03:10:11 +04:00
if ( ! torture_setup_dir ( cli , " \\ clients " ) ) {
return False ;
}
2004-11-26 02:05:43 +03:00
}
2004-03-09 05:13:13 +03:00
2004-11-26 02:05:43 +03:00
nbio_shmem ( torture_nprocs , timelimit , warmup ) ;
2004-03-09 05:13:13 +03:00
2004-03-10 06:24:03 +03:00
printf ( " Running for %d seconds with load '%s' and warmup %d secs \n " ,
timelimit , loadfile , warmup ) ;
2004-03-09 05:13:13 +03:00
2005-06-09 12:58:12 +04:00
/* we need to reset SIGCHLD here as the name resolution
library may have changed it . We rely on correct signals
from childs in the main torture code which reaps
children . This is why smbtorture BENCH - NBENCH was sometimes
failing */
signal ( SIGCHLD , SIG_DFL ) ;
2004-10-28 17:40:50 +04:00
signal ( SIGALRM , nb_alarm ) ;
2004-03-09 05:13:13 +03:00
alarm ( 1 ) ;
2004-03-10 06:24:03 +03:00
torture_create_procs ( run_netbench , & correct ) ;
2004-03-09 05:13:13 +03:00
alarm ( 0 ) ;
2005-06-02 03:41:43 +04:00
if ( torture_nprocs > 1 ) {
smbcli_deltree ( cli - > tree , " \\ clients " ) ;
}
2004-11-26 02:05:43 +03:00
printf ( " \n Throughput %g MB/sec \n " , nbio_result ( ) ) ;
2004-03-09 05:13:13 +03:00
return correct ;
}