Fix an overflow in getsockopt(). optval isn't big enough to hold
sbintime_t. Re-introduce r255030 behaviour capping socket timeouts to INT_32 if they're too large. CR: https://phabric.freebsd.org/D433 Reported by: demon Reviewed by: bde [1], jhb [2] MFC after: 2 weeks
This commit is contained in:
parent
f32f2c464b
commit
2df6a889b3
@ -2544,8 +2544,10 @@ sosetopt(struct socket *so, struct sockopt *sopt)
|
||||
error = EDOM;
|
||||
goto bad;
|
||||
}
|
||||
val = tvtosbt(tv);
|
||||
|
||||
if (tv.tv_sec > INT32_MAX)
|
||||
val = SBT_MAX;
|
||||
else
|
||||
val = tvtosbt(tv);
|
||||
switch (sopt->sopt_name) {
|
||||
case SO_SNDTIMEO:
|
||||
so->so_snd.sb_timeo = val;
|
||||
@ -2694,10 +2696,8 @@ sogetopt(struct socket *so, struct sockopt *sopt)
|
||||
|
||||
case SO_SNDTIMEO:
|
||||
case SO_RCVTIMEO:
|
||||
optval = (sopt->sopt_name == SO_SNDTIMEO ?
|
||||
so->so_snd.sb_timeo : so->so_rcv.sb_timeo);
|
||||
|
||||
tv = sbttotv(optval);
|
||||
tv = sbttotv(sopt->sopt_name == SO_SNDTIMEO ?
|
||||
so->so_snd.sb_timeo : so->so_rcv.sb_timeo);
|
||||
#ifdef COMPAT_FREEBSD32
|
||||
if (SV_CURPROC_FLAG(SV_ILP32)) {
|
||||
struct timeval32 tv32;
|
||||
|
Loading…
Reference in New Issue
Block a user