Message ID | 20230510092344.1390444-1-Ilia.Gavrilov@infotecs.ru (mailing list archive) |
---|---|
State | Accepted |
Commit | 059fa492027e99c167f4c53822c0900ca9bc254a |
Delegated to: | Netdev Maintainers |
Headers | show |
Series | [net-next,v4] sctp: fix a potential OOB access in sctp_sched_set_sched() | expand |
Hello: This patch was applied to netdev/net-next.git (main) by David S. Miller <davem@davemloft.net>: On Wed, 10 May 2023 09:23:40 +0000 you wrote: > From: "Ilia.Gavrilov" <Ilia.Gavrilov@infotecs.ru> > > The 'sched' index value must be checked before accessing an element > of the 'sctp_sched_ops' array. Otherwise, it can lead to OOB access. > > Note that it's harmless since the 'sched' parameter is checked before > calling 'sctp_sched_set_sched'. > > [...] Here is the summary with links: - [net-next,v4] sctp: fix a potential OOB access in sctp_sched_set_sched() https://git.kernel.org/netdev/net-next/c/059fa492027e You are awesome, thank you!
diff --git a/net/sctp/stream_sched.c b/net/sctp/stream_sched.c index 330067002deb..4d076a9b8592 100644 --- a/net/sctp/stream_sched.c +++ b/net/sctp/stream_sched.c @@ -146,18 +146,19 @@ static void sctp_sched_free_sched(struct sctp_stream *stream) int sctp_sched_set_sched(struct sctp_association *asoc, enum sctp_sched_type sched) { - struct sctp_sched_ops *n = sctp_sched_ops[sched]; struct sctp_sched_ops *old = asoc->outqueue.sched; struct sctp_datamsg *msg = NULL; + struct sctp_sched_ops *n; struct sctp_chunk *ch; int i, ret = 0; - if (old == n) - return ret; - if (sched > SCTP_SS_MAX) return -EINVAL; + n = sctp_sched_ops[sched]; + if (old == n) + return ret; + if (old) sctp_sched_free_sched(&asoc->stream);