summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--source3/utils/locktest.c60
1 files changed, 29 insertions, 31 deletions
diff --git a/source3/utils/locktest.c b/source3/utils/locktest.c
index 04eb28b236..475e20fa66 100644
--- a/source3/utils/locktest.c
+++ b/source3/utils/locktest.c
@@ -33,11 +33,16 @@ static BOOL analyze;
#define FILENAME "locktest.dat"
#define LOCKRANGE 100
+#define LOCKBASE 0
+
+/*
+#define LOCKBASE (0x40000000 - 50)
+*/
#define READ_PCT 50
#define LOCK_PCT 25
#define UNLOCK_PCT 65
-#define RANGE_MULTIPLE 32
+#define RANGE_MULTIPLE 1
#define NCONNECTIONS 2
#define NFILES 2
#define LOCK_TIMEOUT 0
@@ -48,19 +53,11 @@ static BOOL analyze;
struct record {
char r1, r2;
char conn, f;
- int start, len;
+ unsigned start, len;
char needed;
};
static struct record preset[] = {
-{77, 11, 0, 0, 2432, 480, 1},
-{13, 11, 0, 0, 2624, 224, 1},
-{16, 19, 0, 1, 448, 1344, 1},
-{21, 96, 0, 0, 2144, 640, 1},
-{53, 5, 1, 1, 2336, 608, 1},
-
-
-
{36, 5, 0, 0, 0, 8, 1},
{ 2, 6, 0, 1, 0, 1, 1},
{53, 92, 0, 0, 0, 0, 1},
@@ -80,7 +77,7 @@ static void print_brl(SMB_DEV_T dev, SMB_INO_T ino, int pid,
if (lastino != ino) {
slprintf(cmd, sizeof(cmd),
- "egrep POSIX.*%d /proc/locks", (int)ino);
+ "egrep POSIX.*%u /proc/locks", (int)ino);
system(cmd);
}
lastino = ino;
@@ -118,7 +115,7 @@ struct cli_state *connect_one(char *share)
ip = ipzero;
- slprintf(myname,sizeof(myname), "lock-%d-%d", getpid(), count++);
+ slprintf(myname,sizeof(myname), "lock-%u-%u", getpid(), count++);
make_nmb_name(&calling, myname, 0x0);
make_nmb_name(&called , server, 0x20);
@@ -226,13 +223,13 @@ static BOOL test_one(struct cli_state *cli[2][2],
int fnum[2][2][2],
struct record *rec)
{
- int conn = rec->conn;
- int f = rec->f;
- int start = rec->start;
- int len = rec->len;
- int r1 = rec->r1;
- int r2 = rec->r2;
- int op;
+ unsigned conn = rec->conn;
+ unsigned f = rec->f;
+ unsigned start = rec->start;
+ unsigned len = rec->len;
+ unsigned r1 = rec->r1;
+ unsigned r2 = rec->r2;
+ unsigned op;
BOOL ret1, ret2;
if (r1 < READ_PCT) {
@@ -250,7 +247,7 @@ static BOOL test_one(struct cli_state *cli[2][2],
fnum[1][conn][f],
start, len, LOCK_TIMEOUT, op);
if (showall || ret1 != ret2) {
- printf("lock conn=%d f=%d range=%d:%d(%d) op=%s -> %d:%d\n",
+ printf("lock conn=%u f=%u range=%u:%u(%u) op=%s -> %u:%u\n",
conn, f,
start, start+len-1, len,
op==READ_LOCK?"READ_LOCK":"WRITE_LOCK",
@@ -267,7 +264,7 @@ static BOOL test_one(struct cli_state *cli[2][2],
fnum[1][conn][f],
start, len);
if (showall || ret1 != ret2) {
- printf("unlock conn=%d f=%d range=%d:%d(%d) -> %d:%d\n",
+ printf("unlock conn=%u f=%u range=%u:%u(%u) -> %u:%u\n",
conn, f,
start, start+len-1, len,
ret1, ret2);
@@ -293,7 +290,7 @@ static BOOL test_one(struct cli_state *cli[2][2],
return False;
}
if (showall) {
- printf("reopen conn=%d f=%d\n",
+ printf("reopen conn=%u f=%u\n",
conn, f);
brl_forall(print_brl);
}
@@ -302,7 +299,7 @@ static BOOL test_one(struct cli_state *cli[2][2],
}
static void close_files(struct cli_state *cli[2][2],
- int fnum[2][2][2])
+ int fnum[2][2][2])
{
int server, conn, f;
@@ -330,7 +327,7 @@ static void open_files(struct cli_state *cli[2][2],
O_RDWR|O_CREAT,
DENY_NONE);
if (fnum[server][conn][f] == -1) {
- fprintf(stderr,"Failed to open fnum[%d][%d][%d]\n",
+ fprintf(stderr,"Failed to open fnum[%u][%u][%u]\n",
server, conn, f);
exit(1);
}
@@ -343,10 +340,10 @@ static int retest(struct cli_state *cli[2][2],
int n)
{
int i;
- printf("testing %d ...\n", n);
+ printf("testing %u ...\n", n);
for (i=0; i<n; i++) {
if (i && i % 100 == 0) {
- printf("%d\n", i);
+ printf("%u\n", i);
}
if (recorded[i].needed &&
@@ -379,8 +376,9 @@ static void test_locks(char *share1, char *share2)
} else {
recorded[n].conn = random() % NCONNECTIONS;
recorded[n].f = random() % NFILES;
- recorded[n].start = random() % (LOCKRANGE-1);
- recorded[n].len = 1 + random() % (LOCKRANGE-recorded[n].start);
+ recorded[n].start = LOCKBASE + ((unsigned)random() % (LOCKRANGE-1));
+ recorded[n].len = 1 +
+ random() % (LOCKRANGE-(recorded[n].start-LOCKBASE));
recorded[n].start *= RANGE_MULTIPLE;
recorded[n].len *= RANGE_MULTIPLE;
recorded[n].r1 = random() % 100;
@@ -432,12 +430,12 @@ static void test_locks(char *share1, char *share2)
showall = True;
n1 = retest(cli, fnum, n);
if (n1 != n-1) {
- printf("ERROR - inconsistent result (%d %d)\n", n1, n);
+ printf("ERROR - inconsistent result (%u %u)\n", n1, n);
}
close_files(cli, fnum);
for (i=0;i<n;i++) {
- printf("{%d, %d, %d, %d, %d, %d, %d},\n",
+ printf("{%u, %u, %u, %u, %u, %u, %u},\n",
recorded[i].r1,
recorded[i].r2,
recorded[i].conn,
@@ -544,7 +542,7 @@ static void usage(void)
argc -= optind;
argv += optind;
- DEBUG(0,("seed=%d\n", seed));
+ DEBUG(0,("seed=%u\n", seed));
srandom(seed);
locking_init(1);