diff options
author | Xin Long <lucien.xin@gmail.com> | 2017-11-26 07:16:08 -0500 |
---|---|---|
committer | David S. Miller <davem@davemloft.net> | 2017-11-28 11:00:13 -0500 |
commit | 1ba896f6f52bfafac6dec4ca583cdd9a073858e8 (patch) | |
tree | 39fb89151c14acafe4811c2b31116245f12e21c6 /net/sctp/stream_sched.c | |
parent | af2697a0273f7665429c47d71ab26f2412af924e (diff) |
sctp: remove extern from stream sched
Now each stream sched ops is defined in different .c file and
added into the global ops in another .c file, it uses extern
to make this work.
However extern is not good coding style to get them in and
even make C=2 reports errors for this.
This patch adds sctp_sched_ops_xxx_init for each stream sched
ops in their .c file, then get them into the global ops by
calling them when initializing sctp module.
Fixes: 637784ade221 ("sctp: introduce priority based stream scheduler")
Fixes: ac1ed8b82cd6 ("sctp: introduce round robin stream scheduler")
Signed-off-by: Xin Long <lucien.xin@gmail.com>
Acked-by: Marcelo Ricardo Leitner <marcelo.leitner@gmail.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
Diffstat (limited to 'net/sctp/stream_sched.c')
-rw-r--r-- | net/sctp/stream_sched.c | 25 |
1 files changed, 18 insertions, 7 deletions
diff --git a/net/sctp/stream_sched.c b/net/sctp/stream_sched.c index 0b83ec51e43b..d8c162a4089c 100644 --- a/net/sctp/stream_sched.c +++ b/net/sctp/stream_sched.c | |||
@@ -119,16 +119,27 @@ static struct sctp_sched_ops sctp_sched_fcfs = { | |||
119 | .unsched_all = sctp_sched_fcfs_unsched_all, | 119 | .unsched_all = sctp_sched_fcfs_unsched_all, |
120 | }; | 120 | }; |
121 | 121 | ||
122 | static void sctp_sched_ops_fcfs_init(void) | ||
123 | { | ||
124 | sctp_sched_ops_register(SCTP_SS_FCFS, &sctp_sched_fcfs); | ||
125 | } | ||
126 | |||
122 | /* API to other parts of the stack */ | 127 | /* API to other parts of the stack */ |
123 | 128 | ||
124 | extern struct sctp_sched_ops sctp_sched_prio; | 129 | static struct sctp_sched_ops *sctp_sched_ops[SCTP_SS_MAX + 1]; |
125 | extern struct sctp_sched_ops sctp_sched_rr; | ||
126 | 130 | ||
127 | static struct sctp_sched_ops *sctp_sched_ops[] = { | 131 | void sctp_sched_ops_register(enum sctp_sched_type sched, |
128 | &sctp_sched_fcfs, | 132 | struct sctp_sched_ops *sched_ops) |
129 | &sctp_sched_prio, | 133 | { |
130 | &sctp_sched_rr, | 134 | sctp_sched_ops[sched] = sched_ops; |
131 | }; | 135 | } |
136 | |||
137 | void sctp_sched_ops_init(void) | ||
138 | { | ||
139 | sctp_sched_ops_fcfs_init(); | ||
140 | sctp_sched_ops_prio_init(); | ||
141 | sctp_sched_ops_rr_init(); | ||
142 | } | ||
132 | 143 | ||
133 | int sctp_sched_set_sched(struct sctp_association *asoc, | 144 | int sctp_sched_set_sched(struct sctp_association *asoc, |
134 | enum sctp_sched_type sched) | 145 | enum sctp_sched_type sched) |