aboutsummaryrefslogtreecommitdiff
path: root/tests/server/sockfilt.c
diff options
context:
space:
mode:
authorYang Tse <yangsita@gmail.com>2010-02-04 17:17:19 +0000
committerYang Tse <yangsita@gmail.com>2010-02-04 17:17:19 +0000
commitf47b84b57ff74915820d26efc30459158bbe5c9c (patch)
treea9bfd9a7895df30e607615535fd26073f1efd73e /tests/server/sockfilt.c
parent1a5749424b11b117b4a6c8732b6b959de14d1741 (diff)
Validate server port argument
Diffstat (limited to 'tests/server/sockfilt.c')
-rw-r--r--tests/server/sockfilt.c22
1 files changed, 20 insertions, 2 deletions
diff --git a/tests/server/sockfilt.c b/tests/server/sockfilt.c
index 15993a5ab..8abde8b51 100644
--- a/tests/server/sockfilt.c
+++ b/tests/server/sockfilt.c
@@ -890,7 +890,16 @@ int main(int argc, char *argv[])
else if(!strcmp("--port", argv[arg])) {
arg++;
if(argc>arg) {
- port = (unsigned short)atoi(argv[arg]);
+ char *endptr;
+ long lnum = -1;
+ lnum = strtol(argv[arg], &endptr, 10);
+ if((endptr != argv[arg] + strlen(argv[arg])) ||
+ ((lnum != 0L) && ((lnum < 1025L) || (lnum > 65535L)))) {
+ fprintf(stderr, "sockfilt: invalid --port argument (%s)\n",
+ argv[arg]);
+ return 0;
+ }
+ port = (unsigned short)(lnum & 0xFFFFL);
arg++;
}
}
@@ -899,7 +908,16 @@ int main(int argc, char *argv[])
doing a passive server-style listening. */
arg++;
if(argc>arg) {
- connectport = (unsigned short)atoi(argv[arg]);
+ char *endptr;
+ long lnum = -1;
+ lnum = strtol(argv[arg], &endptr, 10);
+ if((endptr != argv[arg] + strlen(argv[arg])) ||
+ (lnum < 1025L) || (lnum > 65535L)) {
+ fprintf(stderr, "sockfilt: invalid --connect argument (%s)\n",
+ argv[arg]);
+ return 0;
+ }
+ connectport = (unsigned short)(lnum & 0xFFFFL);
arg++;
}
}