@@ -72,7 +72,7 @@ static void usage(void)
" [-]tentative | [-]deprecated | [-]dadfailed | temporary |\n"
" CONFFLAG-LIST ]\n"
"CONFFLAG-LIST := [ CONFFLAG-LIST ] CONFFLAG\n"
- "CONFFLAG := [ home | nodad | mngtmpaddr | noprefixroute | autojoin ]\n"
+ "CONFFLAG := [ home | nodad | optimistic | mngtmpaddr | noprefixroute | autojoin ]\n"
"LIFETIME := [ valid_lft LFT ] [ preferred_lft LFT ]\n"
"LFT := forever | SECONDS\n"
"TYPE := { vlan | veth | vcan | vxcan | dummy | ifb | macvlan | macvtap |\n"
@@ -2335,6 +2335,11 @@ static int ipaddr_modify(int cmd, int flags, int argc, char **argv)
ifa_flags |= IFA_F_HOMEADDRESS;
else
fprintf(stderr, "Warning: home option can be set only for IPv6 addresses\n");
+ } else if (strcmp(*argv, "optimistic") == 0) {
+ if (req.ifa.ifa_family == AF_INET6)
+ ifa_flags |= IFA_F_OPTIMISTIC;
+ else
+ fprintf(stderr, "Warning: optimistic option can be set only for IPv6 addresses\n");
} else if (strcmp(*argv, "nodad") == 0) {
if (req.ifa.ifa_family == AF_INET6)
ifa_flags |= IFA_F_NODAD;
@@ -92,7 +92,7 @@ ip-address \- protocol address management
.ti -8
.IR CONFFLAG " := "
-.RB "[ " home " | " mngtmpaddr " | " nodad " | " noprefixroute " | " autojoin " ]"
+.RB "[ " home " | " mngtmpaddr " | " nodad " | " optimstic " | " noprefixroute " | " autojoin " ]"
.ti -8
.IR LIFETIME " := [ "
@@ -258,6 +258,11 @@ stateless auto-configuration was active.
(IPv6 only) do not perform Duplicate Address Detection (RFC 4862) when
adding this address.
+.TP
+.B optimistic
+(IPv6 only) When performing Duplicate Address Detection, use the RFC 4429
+optimistic variant.
+
.TP
.B noprefixroute
Do not automatically create a route for the network prefix of the added