Skip to content

Commit

Permalink
sctp: factor out stream->out allocation
Browse files Browse the repository at this point in the history
There is 1 place allocating it and 2 other reallocating. Move such
procedures to a common function.

Tested-by: Xin Long <lucien.xin@gmail.com>
Signed-off-by: Marcelo Ricardo Leitner <marcelo.leitner@gmail.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
  • Loading branch information
Marcelo Ricardo Leitner authored and David S. Miller committed Oct 3, 2017
1 parent 1ae2eaa commit e090abd
Showing 1 changed file with 32 additions and 20 deletions.
52 changes: 32 additions & 20 deletions net/sctp/stream.c
Original file line number Diff line number Diff line change
Expand Up @@ -35,6 +35,30 @@
#include <net/sctp/sctp.h>
#include <net/sctp/sm.h>

static int sctp_stream_alloc_out(struct sctp_stream *stream, __u16 outcnt,
gfp_t gfp)
{
struct sctp_stream_out *out;

out = kmalloc_array(outcnt, sizeof(*out), gfp);
if (!out)
return -ENOMEM;

if (stream->out) {
memcpy(out, stream->out, min(outcnt, stream->outcnt) *
sizeof(*out));
kfree(stream->out);
}

if (outcnt > stream->outcnt)
memset(out + stream->outcnt, 0,
(outcnt - stream->outcnt) * sizeof(*out));

stream->out = out;

return 0;
}

int sctp_stream_init(struct sctp_stream *stream, __u16 outcnt, __u16 incnt,
gfp_t gfp)
{
Expand All @@ -48,11 +72,9 @@ int sctp_stream_init(struct sctp_stream *stream, __u16 outcnt, __u16 incnt,
if (outcnt == stream->outcnt)
goto in;

kfree(stream->out);

stream->out = kcalloc(outcnt, sizeof(*stream->out), gfp);
if (!stream->out)
return -ENOMEM;
i = sctp_stream_alloc_out(stream, outcnt, gfp);
if (i)
return i;

stream->outcnt = outcnt;
for (i = 0; i < stream->outcnt; i++)
Expand Down Expand Up @@ -276,15 +298,9 @@ int sctp_send_add_streams(struct sctp_association *asoc,
}

if (out) {
struct sctp_stream_out *streamout;

streamout = krealloc(stream->out, outcnt * sizeof(*streamout),
GFP_KERNEL);
if (!streamout)
retval = sctp_stream_alloc_out(stream, outcnt, GFP_KERNEL);
if (retval)
goto out;

memset(streamout + stream->outcnt, 0, out * sizeof(*streamout));
stream->out = streamout;
}

chunk = sctp_make_strreset_addstrm(asoc, out, in);
Expand Down Expand Up @@ -682,10 +698,10 @@ struct sctp_chunk *sctp_process_strreset_addstrm_in(
struct sctp_strreset_addstrm *addstrm = param.v;
struct sctp_stream *stream = &asoc->stream;
__u32 result = SCTP_STRRESET_DENIED;
struct sctp_stream_out *streamout;
struct sctp_chunk *chunk = NULL;
__u32 request_seq, outcnt;
__u16 out, i;
int ret;

request_seq = ntohl(addstrm->request_seq);
if (TSN_lt(asoc->strreset_inseq, request_seq) ||
Expand Down Expand Up @@ -714,14 +730,10 @@ struct sctp_chunk *sctp_process_strreset_addstrm_in(
if (!out || outcnt > SCTP_MAX_STREAM)
goto out;

streamout = krealloc(stream->out, outcnt * sizeof(*streamout),
GFP_ATOMIC);
if (!streamout)
ret = sctp_stream_alloc_out(stream, outcnt, GFP_ATOMIC);
if (ret)
goto out;

memset(streamout + stream->outcnt, 0, out * sizeof(*streamout));
stream->out = streamout;

chunk = sctp_make_strreset_addstrm(asoc, out, 0);
if (!chunk)
goto out;
Expand Down

0 comments on commit e090abd

Please sign in to comment.