diff options
author | Joe Perches <joe@perches.com> | 2014-12-01 23:29:06 -0500 |
---|---|---|
committer | David S. Miller <davem@davemloft.net> | 2014-12-08 20:28:47 -0500 |
commit | 60c04aecd8a72a84869308bdf2289a7aabb9a88c (patch) | |
tree | d1ab7ab4a17e112d6f27ab5b5268f602cc1be3a1 | |
parent | b0ba512e25d729a43858ad1f6cb8b94dbb95dbeb (diff) |
udp: Neaten and reduce size of compute_score functions
The compute_score functions are a bit difficult to read.
Neaten them a bit to reduce object sizes and make them a
bit more intelligible.
Return early to avoid indentation and avoid unnecessary
initializations.
(allyesconfig, but w/ -O2 and no profiling)
$ size net/ipv[46]/udp.o.*
text data bss dec hex filename
28680 1184 25 29889 74c1 net/ipv4/udp.o.new
28756 1184 25 29965 750d net/ipv4/udp.o.old
17600 1010 2 18612 48b4 net/ipv6/udp.o.new
17632 1010 2 18644 48d4 net/ipv6/udp.o.old
Signed-off-by: Joe Perches <joe@perches.com>
Acked-by: Eric Dumazet <edumazet@google.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
-rw-r--r-- | net/ipv4/udp.c | 111 | ||||
-rw-r--r-- | net/ipv6/udp.c | 113 |
2 files changed, 125 insertions, 99 deletions
diff --git a/net/ipv4/udp.c b/net/ipv4/udp.c index b2d606833ce4..dd8e00634563 100644 --- a/net/ipv4/udp.c +++ b/net/ipv4/udp.c | |||
@@ -336,38 +336,45 @@ int udp_v4_get_port(struct sock *sk, unsigned short snum) | |||
336 | return udp_lib_get_port(sk, snum, ipv4_rcv_saddr_equal, hash2_nulladdr); | 336 | return udp_lib_get_port(sk, snum, ipv4_rcv_saddr_equal, hash2_nulladdr); |
337 | } | 337 | } |
338 | 338 | ||
339 | static inline int compute_score(struct sock *sk, struct net *net, __be32 saddr, | 339 | static inline int compute_score(struct sock *sk, struct net *net, |
340 | unsigned short hnum, | 340 | __be32 saddr, unsigned short hnum, __be16 sport, |
341 | __be16 sport, __be32 daddr, __be16 dport, int dif) | 341 | __be32 daddr, __be16 dport, int dif) |
342 | { | 342 | { |
343 | int score = -1; | 343 | int score; |
344 | struct inet_sock *inet; | ||
344 | 345 | ||
345 | if (net_eq(sock_net(sk), net) && udp_sk(sk)->udp_port_hash == hnum && | 346 | if (!net_eq(sock_net(sk), net) || |
346 | !ipv6_only_sock(sk)) { | 347 | udp_sk(sk)->udp_port_hash != hnum || |
347 | struct inet_sock *inet = inet_sk(sk); | 348 | ipv6_only_sock(sk)) |
349 | return -1; | ||
348 | 350 | ||
349 | score = (sk->sk_family == PF_INET ? 2 : 1); | 351 | score = (sk->sk_family == PF_INET) ? 2 : 1; |
350 | if (inet->inet_rcv_saddr) { | 352 | inet = inet_sk(sk); |
351 | if (inet->inet_rcv_saddr != daddr) | 353 | |
352 | return -1; | 354 | if (inet->inet_rcv_saddr) { |
353 | score += 4; | 355 | if (inet->inet_rcv_saddr != daddr) |
354 | } | 356 | return -1; |
355 | if (inet->inet_daddr) { | 357 | score += 4; |
356 | if (inet->inet_daddr != saddr) | 358 | } |
357 | return -1; | 359 | |
358 | score += 4; | 360 | if (inet->inet_daddr) { |
359 | } | 361 | if (inet->inet_daddr != saddr) |
360 | if (inet->inet_dport) { | 362 | return -1; |
361 | if (inet->inet_dport != sport) | 363 | score += 4; |
362 | return -1; | ||
363 | score += 4; | ||
364 | } | ||
365 | if (sk->sk_bound_dev_if) { | ||
366 | if (sk->sk_bound_dev_if != dif) | ||
367 | return -1; | ||
368 | score += 4; | ||
369 | } | ||
370 | } | 364 | } |
365 | |||
366 | if (inet->inet_dport) { | ||
367 | if (inet->inet_dport != sport) | ||
368 | return -1; | ||
369 | score += 4; | ||
370 | } | ||
371 | |||
372 | if (sk->sk_bound_dev_if) { | ||
373 | if (sk->sk_bound_dev_if != dif) | ||
374 | return -1; | ||
375 | score += 4; | ||
376 | } | ||
377 | |||
371 | return score; | 378 | return score; |
372 | } | 379 | } |
373 | 380 | ||
@@ -378,33 +385,39 @@ static inline int compute_score2(struct sock *sk, struct net *net, | |||
378 | __be32 saddr, __be16 sport, | 385 | __be32 saddr, __be16 sport, |
379 | __be32 daddr, unsigned int hnum, int dif) | 386 | __be32 daddr, unsigned int hnum, int dif) |
380 | { | 387 | { |
381 | int score = -1; | 388 | int score; |
389 | struct inet_sock *inet; | ||
390 | |||
391 | if (!net_eq(sock_net(sk), net) || | ||
392 | ipv6_only_sock(sk)) | ||
393 | return -1; | ||
382 | 394 | ||
383 | if (net_eq(sock_net(sk), net) && !ipv6_only_sock(sk)) { | 395 | inet = inet_sk(sk); |
384 | struct inet_sock *inet = inet_sk(sk); | ||
385 | 396 | ||
386 | if (inet->inet_rcv_saddr != daddr) | 397 | if (inet->inet_rcv_saddr != daddr || |
398 | inet->inet_num != hnum) | ||
399 | return -1; | ||
400 | |||
401 | score = (sk->sk_family == PF_INET) ? 2 : 1; | ||
402 | |||
403 | if (inet->inet_daddr) { | ||
404 | if (inet->inet_daddr != saddr) | ||
387 | return -1; | 405 | return -1; |
388 | if (inet->inet_num != hnum) | 406 | score += 4; |
407 | } | ||
408 | |||
409 | if (inet->inet_dport) { | ||
410 | if (inet->inet_dport != sport) | ||
389 | return -1; | 411 | return -1; |
412 | score += 4; | ||
413 | } | ||
390 | 414 | ||
391 | score = (sk->sk_family == PF_INET ? 2 : 1); | 415 | if (sk->sk_bound_dev_if) { |
392 | if (inet->inet_daddr) { | 416 | if (sk->sk_bound_dev_if != dif) |
393 | if (inet->inet_daddr != saddr) | 417 | return -1; |
394 | return -1; | 418 | score += 4; |
395 | score += 4; | ||
396 | } | ||
397 | if (inet->inet_dport) { | ||
398 | if (inet->inet_dport != sport) | ||
399 | return -1; | ||
400 | score += 4; | ||
401 | } | ||
402 | if (sk->sk_bound_dev_if) { | ||
403 | if (sk->sk_bound_dev_if != dif) | ||
404 | return -1; | ||
405 | score += 4; | ||
406 | } | ||
407 | } | 419 | } |
420 | |||
408 | return score; | 421 | return score; |
409 | } | 422 | } |
410 | 423 | ||
diff --git a/net/ipv6/udp.c b/net/ipv6/udp.c index 7cfb5d745a2d..7f96432292ce 100644 --- a/net/ipv6/udp.c +++ b/net/ipv6/udp.c | |||
@@ -148,72 +148,85 @@ static inline int compute_score(struct sock *sk, struct net *net, | |||
148 | const struct in6_addr *daddr, __be16 dport, | 148 | const struct in6_addr *daddr, __be16 dport, |
149 | int dif) | 149 | int dif) |
150 | { | 150 | { |
151 | int score = -1; | 151 | int score; |
152 | struct inet_sock *inet; | ||
152 | 153 | ||
153 | if (net_eq(sock_net(sk), net) && udp_sk(sk)->udp_port_hash == hnum && | 154 | if (!net_eq(sock_net(sk), net) || |
154 | sk->sk_family == PF_INET6) { | 155 | udp_sk(sk)->udp_port_hash != hnum || |
155 | struct inet_sock *inet = inet_sk(sk); | 156 | sk->sk_family != PF_INET6) |
157 | return -1; | ||
156 | 158 | ||
157 | score = 0; | 159 | score = 0; |
158 | if (inet->inet_dport) { | 160 | inet = inet_sk(sk); |
159 | if (inet->inet_dport != sport) | 161 | |
160 | return -1; | 162 | if (inet->inet_dport) { |
161 | score++; | 163 | if (inet->inet_dport != sport) |
162 | } | 164 | return -1; |
163 | if (!ipv6_addr_any(&sk->sk_v6_rcv_saddr)) { | 165 | score++; |
164 | if (!ipv6_addr_equal(&sk->sk_v6_rcv_saddr, daddr)) | ||
165 | return -1; | ||
166 | score++; | ||
167 | } | ||
168 | if (!ipv6_addr_any(&sk->sk_v6_daddr)) { | ||
169 | if (!ipv6_addr_equal(&sk->sk_v6_daddr, saddr)) | ||
170 | return -1; | ||
171 | score++; | ||
172 | } | ||
173 | if (sk->sk_bound_dev_if) { | ||
174 | if (sk->sk_bound_dev_if != dif) | ||
175 | return -1; | ||
176 | score++; | ||
177 | } | ||
178 | } | 166 | } |
167 | |||
168 | if (!ipv6_addr_any(&sk->sk_v6_rcv_saddr)) { | ||
169 | if (!ipv6_addr_equal(&sk->sk_v6_rcv_saddr, daddr)) | ||
170 | return -1; | ||
171 | score++; | ||
172 | } | ||
173 | |||
174 | if (!ipv6_addr_any(&sk->sk_v6_daddr)) { | ||
175 | if (!ipv6_addr_equal(&sk->sk_v6_daddr, saddr)) | ||
176 | return -1; | ||
177 | score++; | ||
178 | } | ||
179 | |||
180 | if (sk->sk_bound_dev_if) { | ||
181 | if (sk->sk_bound_dev_if != dif) | ||
182 | return -1; | ||
183 | score++; | ||
184 | } | ||
185 | |||
179 | return score; | 186 | return score; |
180 | } | 187 | } |
181 | 188 | ||
182 | #define SCORE2_MAX (1 + 1 + 1) | 189 | #define SCORE2_MAX (1 + 1 + 1) |
183 | static inline int compute_score2(struct sock *sk, struct net *net, | 190 | static inline int compute_score2(struct sock *sk, struct net *net, |
184 | const struct in6_addr *saddr, __be16 sport, | 191 | const struct in6_addr *saddr, __be16 sport, |
185 | const struct in6_addr *daddr, unsigned short hnum, | 192 | const struct in6_addr *daddr, |
186 | int dif) | 193 | unsigned short hnum, int dif) |
187 | { | 194 | { |
188 | int score = -1; | 195 | int score; |
196 | struct inet_sock *inet; | ||
189 | 197 | ||
190 | if (net_eq(sock_net(sk), net) && udp_sk(sk)->udp_port_hash == hnum && | 198 | if (!net_eq(sock_net(sk), net) || |
191 | sk->sk_family == PF_INET6) { | 199 | udp_sk(sk)->udp_port_hash != hnum || |
192 | struct inet_sock *inet = inet_sk(sk); | 200 | sk->sk_family != PF_INET6) |
201 | return -1; | ||
193 | 202 | ||
194 | if (!ipv6_addr_equal(&sk->sk_v6_rcv_saddr, daddr)) | 203 | if (!ipv6_addr_equal(&sk->sk_v6_rcv_saddr, daddr)) |
204 | return -1; | ||
205 | |||
206 | score = 0; | ||
207 | inet = inet_sk(sk); | ||
208 | |||
209 | if (inet->inet_dport) { | ||
210 | if (inet->inet_dport != sport) | ||
195 | return -1; | 211 | return -1; |
196 | score = 0; | 212 | score++; |
197 | if (inet->inet_dport) { | ||
198 | if (inet->inet_dport != sport) | ||
199 | return -1; | ||
200 | score++; | ||
201 | } | ||
202 | if (!ipv6_addr_any(&sk->sk_v6_daddr)) { | ||
203 | if (!ipv6_addr_equal(&sk->sk_v6_daddr, saddr)) | ||
204 | return -1; | ||
205 | score++; | ||
206 | } | ||
207 | if (sk->sk_bound_dev_if) { | ||
208 | if (sk->sk_bound_dev_if != dif) | ||
209 | return -1; | ||
210 | score++; | ||
211 | } | ||
212 | } | 213 | } |
214 | |||
215 | if (!ipv6_addr_any(&sk->sk_v6_daddr)) { | ||
216 | if (!ipv6_addr_equal(&sk->sk_v6_daddr, saddr)) | ||
217 | return -1; | ||
218 | score++; | ||
219 | } | ||
220 | |||
221 | if (sk->sk_bound_dev_if) { | ||
222 | if (sk->sk_bound_dev_if != dif) | ||
223 | return -1; | ||
224 | score++; | ||
225 | } | ||
226 | |||
213 | return score; | 227 | return score; |
214 | } | 228 | } |
215 | 229 | ||
216 | |||
217 | /* called with read_rcu_lock() */ | 230 | /* called with read_rcu_lock() */ |
218 | static struct sock *udp6_lib_lookup2(struct net *net, | 231 | static struct sock *udp6_lib_lookup2(struct net *net, |
219 | const struct in6_addr *saddr, __be16 sport, | 232 | const struct in6_addr *saddr, __be16 sport, |