mirror of https://github.com/F-Stack/f-stack.git
Merge branch 'master' of https://github.com/F-Stack/f-stack
This commit is contained in:
commit
2bc927fd77
|
@ -1126,7 +1126,10 @@ if (lport == 0)
|
||||||
ifp_sin.sin_len = sizeof(ifp_sin);
|
ifp_sin.sin_len = sizeof(ifp_sin);
|
||||||
ifa = ifa_ifwithnet((struct sockaddr *)&ifp_sin, 0, RT_ALL_FIBS);
|
ifa = ifa_ifwithnet((struct sockaddr *)&ifp_sin, 0, RT_ALL_FIBS);
|
||||||
if (ifa == NULL) {
|
if (ifa == NULL) {
|
||||||
return (EADDRNOTAVAIL);
|
ifp_sin.sin_addr.s_addr = faddr.s_addr;
|
||||||
|
ifa = ifa_ifwithnet((struct sockaddr *)&ifp_sin, 0, RT_ALL_FIBS);
|
||||||
|
if ( ifa == NULL )
|
||||||
|
return (EADDRNOTAVAIL);
|
||||||
}
|
}
|
||||||
ifp = ifa->ifa_ifp;
|
ifp = ifa->ifa_ifp;
|
||||||
while (lport == 0) {
|
while (lport == 0) {
|
||||||
|
|
|
@ -1321,12 +1321,20 @@ tcp_connect(struct tcpcb *tp, struct sockaddr *nam, struct thread *td)
|
||||||
error = EADDRINUSE;
|
error = EADDRINUSE;
|
||||||
goto out;
|
goto out;
|
||||||
}
|
}
|
||||||
}
|
|
||||||
|
|
||||||
if (in_pcbinshash(inp) != 0) {
|
// inp->inp_lport != lport means in_pcbconnect_setup selected new port to inp->inp_lport.
|
||||||
inp->inp_laddr.s_addr = INADDR_ANY;
|
// inp will inhash.
|
||||||
inp->inp_lport = 0;
|
if (in_pcbinshash(inp) != 0) {
|
||||||
return (EAGAIN);
|
inp->inp_laddr.s_addr = INADDR_ANY;
|
||||||
|
inp->inp_lport = 0;
|
||||||
|
return (EAGAIN);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
// app call bind() and connect(), lport is set when bind, and the inp is inhashed in bind() function.
|
||||||
|
// in_pcbconnect_setup() update inp->inp_faddr/inp->inp_fport, so inp should be rehashed.
|
||||||
|
in_pcbrehash(inp);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (anonport) {
|
if (anonport) {
|
||||||
|
|
Loading…
Reference in New Issue