b2bd8f7
diff --git a/commands.c b/commands.c
b2bd8f7
index 49619ac..636fb5c 100644
e0167b1
--- a/telnet/commands.c
e0167b1
+++ b/telnet/commands.c
b2bd8f7
@@ -2267,6 +2267,7 @@ tn(int argc, char *argv[])
b2bd8f7
     char *srp = 0;
b2bd8f7
     int srlen;
b2bd8f7
 #endif
b2bd8f7
+    int family = AF_UNSPEC;
b2bd8f7
     char *cmd, *hostp = 0, *portp = 0, *user = 0, *aliasp = 0;
b2bd8f7
     int retry;
b2bd8f7
 #ifdef NI_WITHSCOPEID
b2bd8f7
@@ -2317,6 +2318,21 @@ tn(int argc, char *argv[])
b2bd8f7
 	    autologin = 1;
b2bd8f7
 	    continue;
b2bd8f7
 	}
b2bd8f7
+	
b2bd8f7
+	if (strcmp(*argv, "-6") == 0) {
b2bd8f7
+	    --argc; ++argv;
b2bd8f7
+#ifdef AF_INET6
b2bd8f7
+	    family = AF_INET6;
b2bd8f7
+#else
b2bd8f7
+	    puts("IPv6 unsupported");
b2bd8f7
+#endif
b2bd8f7
+	    continue;
b2bd8f7
+	}
b2bd8f7
+	if (strcmp(*argv, "-4") == 0) {
b2bd8f7
+	    --argc; ++argv;
b2bd8f7
+	    family = AF_INET;
b2bd8f7
+	    continue;
b2bd8f7
+	}
b2bd8f7
 	if (hostp == 0) {
b2bd8f7
 	    hostp = *argv++;
b2bd8f7
 	    --argc;
b2bd8f7
@@ -2355,7 +2371,7 @@ tn(int argc, char *argv[])
b2bd8f7
     {
b2bd8f7
 	hostname = hostp;
b2bd8f7
 	memset(&hints, 0, sizeof(hints));
b2bd8f7
-	hints.ai_family = PF_UNSPEC;
b2bd8f7
+	hints.ai_family = family;
b2bd8f7
 	hints.ai_socktype = SOCK_STREAM;
b2bd8f7
 	hints.ai_flags = AI_CANONNAME;
b2bd8f7
 	if (portp == NULL) {
b2bd8f7
diff --git a/main.c b/main.c
b2bd8f7
index 5fa96e8..599f0af 100644
e0167b1
--- a/telnet/main.c
e0167b1
+++ b/telnet/main.c
b2bd8f7
@@ -80,10 +80,10 @@ usage(void)
b2bd8f7
 	fprintf(stderr, "Usage: %s %s%s%s%s\n",
b2bd8f7
 	    prompt,
b2bd8f7
 #ifdef	AUTHENTICATION
b2bd8f7
-	    "[-8] [-E] [-K] [-L] [-S tos] [-X atype] [-a] [-c] [-d] [-e char]",
b2bd8f7
+	    "[-4] [-6] [-8] [-E] [-K] [-L] [-S tos] [-X atype] [-a] [-c] [-d] [-e char]",
b2bd8f7
 	    "\n\t[-k realm] [-l user] [-f/-F] [-n tracefile] [-b hostalias ] ",
b2bd8f7
 #else
b2bd8f7
-	    "[-8] [-E] [-L] [-S tos] [-a] [-c] [-d] [-e char] [-l user]",
b2bd8f7
+	    "[-4] [-6] [-8] [-E] [-L] [-S tos] [-a] [-c] [-d] [-e char] [-l user]",
b2bd8f7
 	    "\n\t[-n tracefile] [-b hostalias ] ",
b2bd8f7
 #endif
b2bd8f7
 #if defined(TN3270) && defined(unix)
b2bd8f7
@@ -116,6 +116,7 @@ main(int argc, char *argv[])
b2bd8f7
 #endif
b2bd8f7
 	int ch;
b2bd8f7
 	char *user, *alias;
b2bd8f7
+	int family;
b2bd8f7
 #ifdef	FORWARD
b2bd8f7
 	extern int forward_flags;
b2bd8f7
 #endif	/* FORWARD */
b2bd8f7
@@ -130,7 +131,6 @@ main(int argc, char *argv[])
b2bd8f7
 		prompt = argv[0];
b2bd8f7
 
b2bd8f7
 	user = alias = NULL;
b2bd8f7
-
b2bd8f7
 	rlogin = (strncmp(prompt, "rlog", 4) == 0) ? '~' : _POSIX_VDISABLE;
b2bd8f7
 
b2bd8f7
 	/* 
b2bd8f7
@@ -139,9 +139,19 @@ main(int argc, char *argv[])
b2bd8f7
 	 * passed 
b2bd8f7
 	 */
b2bd8f7
 	autologin = -1;
b2bd8f7
-
b2bd8f7
-	while ((ch = getopt(argc, argv, "78DEKLS:X:ab:cde:fFk:l:n:rt:x")) != -1) {
b2bd8f7
+	family = 0;
b2bd8f7
+	while ((ch = getopt(argc, argv, "4678DEKLS:X:ab:cde:fFk:l:n:rt:x")) != -1) {
b2bd8f7
 		switch(ch) {
b2bd8f7
+		case '4':
b2bd8f7
+			family = AF_INET;
b2bd8f7
+			break;
b2bd8f7
+		case '6':
b2bd8f7
+#ifdef AF_INET6
b2bd8f7
+			family = AF_INET6;
b2bd8f7
+#else
b2bd8f7
+			fputs("IPv6 unsupported\n", stderr); 
b2bd8f7
+#endif
b2bd8f7
+			break;
b2bd8f7
 		case '8':
b2bd8f7
 			binary = 3;	/* send TELNET BINARY option for output and input */
b2bd8f7
 			break;
b2bd8f7
@@ -340,6 +350,9 @@ main(int argc, char *argv[])
b2bd8f7
 			*argp++ = "-b";
b2bd8f7
 			*argp++ = alias;
b2bd8f7
 		}
b2bd8f7
+		if (family) {
b2bd8f7
+			*argp++ = family == AF_INET ? "-4" : "-6";
b2bd8f7
+		}
b2bd8f7
 		*argp++ = argv[0];		/* host */
b2bd8f7
 		if (argc > 1)
b2bd8f7
 			*argp++ = argv[1];	/* port */
b2bd8f7
diff --git a/telnet.1 b/telnet.1
b2bd8f7
index 50015a6..f30e034 100644
e0167b1
--- a/telnet/telnet.1
e0167b1
+++ b/telnet/telnet.1
b2bd8f7
@@ -44,7 +44,7 @@
b2bd8f7
 protocol
b2bd8f7
 .Sh SYNOPSIS
b2bd8f7
 .Nm telnet
b2bd8f7
-.Op Fl 8EFKLacdfrx
b2bd8f7
+.Op Fl 468EFKLacdfrx
b2bd8f7
 .Op Fl X Ar authtype
b2bd8f7
 .Op Fl b Ar hostalias
b2bd8f7
 .Op Fl e Ar escapechar
b2bd8f7
@@ -76,6 +76,10 @@ command with those arguments.
b2bd8f7
 .Pp
b2bd8f7
 The options are as follows:
b2bd8f7
 .Bl -tag -width Ds
b2bd8f7
+.It Fl 4
b2bd8f7
+Force IPv4 address resolution.
b2bd8f7
+.It Fl 6
b2bd8f7
+Force IPv6 address resolution.
b2bd8f7
 .It Fl 7
b2bd8f7
 Strip 8th bit on input and output. Telnet is 8-bit clean by default but doesn't send the TELNET BINARY option unless forced.
b2bd8f7
 .It Fl 8