diff options
author | Linus Torvalds <torvalds@linux-foundation.org> | 2008-04-18 21:02:35 -0400 |
---|---|---|
committer | Linus Torvalds <torvalds@linux-foundation.org> | 2008-04-18 21:02:35 -0400 |
commit | 334d094504c2fe1c44211ecb49146ae6bca8c321 (patch) | |
tree | d3c0f68e4b9f8e3d2ccc39e7dfe5de0534a5fad9 /net/sctp/sm_statefuns.c | |
parent | d1a4be630fb068f251d64b62919f143c49ca8057 (diff) | |
parent | d1643d24c61b725bef399cc1cf2944b4c9c23177 (diff) |
Merge git://git.kernel.org/pub/scm/linux/kernel/git/davem/net-2.6.26
* git://git.kernel.org/pub/scm/linux/kernel/git/davem/net-2.6.26: (1090 commits)
[NET]: Fix and allocate less memory for ->priv'less netdevices
[IPV6]: Fix dangling references on error in fib6_add().
[NETLABEL]: Fix NULL deref in netlbl_unlabel_staticlist_gen() if ifindex not found
[PKT_SCHED]: Fix datalen check in tcf_simp_init().
[INET]: Uninline the __inet_inherit_port call.
[INET]: Drop the inet_inherit_port() call.
SCTP: Initialize partial_bytes_acked to 0, when all of the data is acked.
[netdrvr] forcedeth: internal simplifications; changelog removal
phylib: factor out get_phy_id from within get_phy_device
PHY: add BCM5464 support to broadcom PHY driver
cxgb3: Fix __must_check warning with dev_dbg.
tc35815: Statistics cleanup
natsemi: fix MMIO for PPC 44x platforms
[TIPC]: Cleanup of TIPC reference table code
[TIPC]: Optimized initialization of TIPC reference table
[TIPC]: Remove inlining of reference table locking routines
e1000: convert uint16_t style integers to u16
ixgb: convert uint16_t style integers to u16
sb1000.c: make const arrays static
sb1000.c: stop inlining largish static functions
...
Diffstat (limited to 'net/sctp/sm_statefuns.c')
-rw-r--r-- | net/sctp/sm_statefuns.c | 38 |
1 files changed, 17 insertions, 21 deletions
diff --git a/net/sctp/sm_statefuns.c b/net/sctp/sm_statefuns.c index 07194c2a32df..0c9d5a6950fe 100644 --- a/net/sctp/sm_statefuns.c +++ b/net/sctp/sm_statefuns.c | |||
@@ -1124,7 +1124,7 @@ sctp_disposition_t sctp_sf_backbeat_8_3(const struct sctp_endpoint *ep, | |||
1124 | printk(KERN_WARNING | 1124 | printk(KERN_WARNING |
1125 | "%s association %p could not find address " | 1125 | "%s association %p could not find address " |
1126 | NIP6_FMT "\n", | 1126 | NIP6_FMT "\n", |
1127 | __FUNCTION__, | 1127 | __func__, |
1128 | asoc, | 1128 | asoc, |
1129 | NIP6(from_addr.v6.sin6_addr)); | 1129 | NIP6(from_addr.v6.sin6_addr)); |
1130 | } else { | 1130 | } else { |
@@ -1132,7 +1132,7 @@ sctp_disposition_t sctp_sf_backbeat_8_3(const struct sctp_endpoint *ep, | |||
1132 | printk(KERN_WARNING | 1132 | printk(KERN_WARNING |
1133 | "%s association %p could not find address " | 1133 | "%s association %p could not find address " |
1134 | NIPQUAD_FMT "\n", | 1134 | NIPQUAD_FMT "\n", |
1135 | __FUNCTION__, | 1135 | __func__, |
1136 | asoc, | 1136 | asoc, |
1137 | NIPQUAD(from_addr.v4.sin_addr.s_addr)); | 1137 | NIPQUAD(from_addr.v4.sin_addr.s_addr)); |
1138 | } | 1138 | } |
@@ -1150,7 +1150,7 @@ sctp_disposition_t sctp_sf_backbeat_8_3(const struct sctp_endpoint *ep, | |||
1150 | time_after(jiffies, hbinfo->sent_at + max_interval)) { | 1150 | time_after(jiffies, hbinfo->sent_at + max_interval)) { |
1151 | SCTP_DEBUG_PRINTK("%s: HEARTBEAT ACK with invalid timestamp " | 1151 | SCTP_DEBUG_PRINTK("%s: HEARTBEAT ACK with invalid timestamp " |
1152 | "received for transport: %p\n", | 1152 | "received for transport: %p\n", |
1153 | __FUNCTION__, link); | 1153 | __func__, link); |
1154 | return SCTP_DISPOSITION_DISCARD; | 1154 | return SCTP_DISPOSITION_DISCARD; |
1155 | } | 1155 | } |
1156 | 1156 | ||
@@ -1226,7 +1226,6 @@ static int sctp_sf_check_restart_addrs(const struct sctp_association *new_asoc, | |||
1226 | sctp_cmd_seq_t *commands) | 1226 | sctp_cmd_seq_t *commands) |
1227 | { | 1227 | { |
1228 | struct sctp_transport *new_addr, *addr; | 1228 | struct sctp_transport *new_addr, *addr; |
1229 | struct list_head *pos, *pos2; | ||
1230 | int found; | 1229 | int found; |
1231 | 1230 | ||
1232 | /* Implementor's Guide - Sectin 5.2.2 | 1231 | /* Implementor's Guide - Sectin 5.2.2 |
@@ -1243,12 +1242,11 @@ static int sctp_sf_check_restart_addrs(const struct sctp_association *new_asoc, | |||
1243 | new_addr = NULL; | 1242 | new_addr = NULL; |
1244 | found = 0; | 1243 | found = 0; |
1245 | 1244 | ||
1246 | list_for_each(pos, &new_asoc->peer.transport_addr_list) { | 1245 | list_for_each_entry(new_addr, &new_asoc->peer.transport_addr_list, |
1247 | new_addr = list_entry(pos, struct sctp_transport, transports); | 1246 | transports) { |
1248 | found = 0; | 1247 | found = 0; |
1249 | list_for_each(pos2, &asoc->peer.transport_addr_list) { | 1248 | list_for_each_entry(addr, &asoc->peer.transport_addr_list, |
1250 | addr = list_entry(pos2, struct sctp_transport, | 1249 | transports) { |
1251 | transports); | ||
1252 | if (sctp_cmp_addr_exact(&new_addr->ipaddr, | 1250 | if (sctp_cmp_addr_exact(&new_addr->ipaddr, |
1253 | &addr->ipaddr)) { | 1251 | &addr->ipaddr)) { |
1254 | found = 1; | 1252 | found = 1; |
@@ -3135,12 +3133,8 @@ sctp_disposition_t sctp_sf_operr_notify(const struct sctp_endpoint *ep, | |||
3135 | if (!ev) | 3133 | if (!ev) |
3136 | goto nomem; | 3134 | goto nomem; |
3137 | 3135 | ||
3138 | if (!sctp_add_cmd(commands, SCTP_CMD_EVENT_ULP, | 3136 | sctp_add_cmd_sf(commands, SCTP_CMD_EVENT_ULP, |
3139 | SCTP_ULPEVENT(ev))) { | 3137 | SCTP_ULPEVENT(ev)); |
3140 | sctp_ulpevent_free(ev); | ||
3141 | goto nomem; | ||
3142 | } | ||
3143 | |||
3144 | sctp_add_cmd_sf(commands, SCTP_CMD_PROCESS_OPERR, | 3138 | sctp_add_cmd_sf(commands, SCTP_CMD_PROCESS_OPERR, |
3145 | SCTP_CHUNK(chunk)); | 3139 | SCTP_CHUNK(chunk)); |
3146 | } | 3140 | } |
@@ -3668,7 +3662,7 @@ sctp_disposition_t sctp_sf_eat_fwd_tsn(const struct sctp_endpoint *ep, | |||
3668 | skb_pull(chunk->skb, len); | 3662 | skb_pull(chunk->skb, len); |
3669 | 3663 | ||
3670 | tsn = ntohl(fwdtsn_hdr->new_cum_tsn); | 3664 | tsn = ntohl(fwdtsn_hdr->new_cum_tsn); |
3671 | SCTP_DEBUG_PRINTK("%s: TSN 0x%x.\n", __FUNCTION__, tsn); | 3665 | SCTP_DEBUG_PRINTK("%s: TSN 0x%x.\n", __func__, tsn); |
3672 | 3666 | ||
3673 | /* The TSN is too high--silently discard the chunk and count on it | 3667 | /* The TSN is too high--silently discard the chunk and count on it |
3674 | * getting retransmitted later. | 3668 | * getting retransmitted later. |
@@ -3728,7 +3722,7 @@ sctp_disposition_t sctp_sf_eat_fwd_tsn_fast( | |||
3728 | skb_pull(chunk->skb, len); | 3722 | skb_pull(chunk->skb, len); |
3729 | 3723 | ||
3730 | tsn = ntohl(fwdtsn_hdr->new_cum_tsn); | 3724 | tsn = ntohl(fwdtsn_hdr->new_cum_tsn); |
3731 | SCTP_DEBUG_PRINTK("%s: TSN 0x%x.\n", __FUNCTION__, tsn); | 3725 | SCTP_DEBUG_PRINTK("%s: TSN 0x%x.\n", __func__, tsn); |
3732 | 3726 | ||
3733 | /* The TSN is too high--silently discard the chunk and count on it | 3727 | /* The TSN is too high--silently discard the chunk and count on it |
3734 | * getting retransmitted later. | 3728 | * getting retransmitted later. |
@@ -4237,7 +4231,7 @@ static sctp_disposition_t sctp_sf_violation_chunklen( | |||
4237 | void *arg, | 4231 | void *arg, |
4238 | sctp_cmd_seq_t *commands) | 4232 | sctp_cmd_seq_t *commands) |
4239 | { | 4233 | { |
4240 | char err_str[]="The following chunk had invalid length:"; | 4234 | static const char err_str[]="The following chunk had invalid length:"; |
4241 | 4235 | ||
4242 | return sctp_sf_abort_violation(ep, asoc, arg, commands, err_str, | 4236 | return sctp_sf_abort_violation(ep, asoc, arg, commands, err_str, |
4243 | sizeof(err_str)); | 4237 | sizeof(err_str)); |
@@ -4254,7 +4248,7 @@ static sctp_disposition_t sctp_sf_violation_paramlen( | |||
4254 | const sctp_subtype_t type, | 4248 | const sctp_subtype_t type, |
4255 | void *arg, | 4249 | void *arg, |
4256 | sctp_cmd_seq_t *commands) { | 4250 | sctp_cmd_seq_t *commands) { |
4257 | char err_str[] = "The following parameter had invalid length:"; | 4251 | static const char err_str[] = "The following parameter had invalid length:"; |
4258 | 4252 | ||
4259 | return sctp_sf_abort_violation(ep, asoc, arg, commands, err_str, | 4253 | return sctp_sf_abort_violation(ep, asoc, arg, commands, err_str, |
4260 | sizeof(err_str)); | 4254 | sizeof(err_str)); |
@@ -4273,7 +4267,7 @@ static sctp_disposition_t sctp_sf_violation_ctsn( | |||
4273 | void *arg, | 4267 | void *arg, |
4274 | sctp_cmd_seq_t *commands) | 4268 | sctp_cmd_seq_t *commands) |
4275 | { | 4269 | { |
4276 | char err_str[]="The cumulative tsn ack beyond the max tsn currently sent:"; | 4270 | static const char err_str[]="The cumulative tsn ack beyond the max tsn currently sent:"; |
4277 | 4271 | ||
4278 | return sctp_sf_abort_violation(ep, asoc, arg, commands, err_str, | 4272 | return sctp_sf_abort_violation(ep, asoc, arg, commands, err_str, |
4279 | sizeof(err_str)); | 4273 | sizeof(err_str)); |
@@ -4292,7 +4286,7 @@ static sctp_disposition_t sctp_sf_violation_chunk( | |||
4292 | void *arg, | 4286 | void *arg, |
4293 | sctp_cmd_seq_t *commands) | 4287 | sctp_cmd_seq_t *commands) |
4294 | { | 4288 | { |
4295 | char err_str[]="The following chunk violates protocol:"; | 4289 | static const char err_str[]="The following chunk violates protocol:"; |
4296 | 4290 | ||
4297 | if (!asoc) | 4291 | if (!asoc) |
4298 | return sctp_sf_violation(ep, asoc, type, arg, commands); | 4292 | return sctp_sf_violation(ep, asoc, type, arg, commands); |
@@ -5331,6 +5325,8 @@ sctp_disposition_t sctp_sf_t2_timer_expire(const struct sctp_endpoint *ep, | |||
5331 | SCTP_DEBUG_PRINTK("Timer T2 expired.\n"); | 5325 | SCTP_DEBUG_PRINTK("Timer T2 expired.\n"); |
5332 | SCTP_INC_STATS(SCTP_MIB_T2_SHUTDOWN_EXPIREDS); | 5326 | SCTP_INC_STATS(SCTP_MIB_T2_SHUTDOWN_EXPIREDS); |
5333 | 5327 | ||
5328 | ((struct sctp_association *)asoc)->shutdown_retries++; | ||
5329 | |||
5334 | if (asoc->overall_error_count >= asoc->max_retrans) { | 5330 | if (asoc->overall_error_count >= asoc->max_retrans) { |
5335 | sctp_add_cmd_sf(commands, SCTP_CMD_SET_SK_ERR, | 5331 | sctp_add_cmd_sf(commands, SCTP_CMD_SET_SK_ERR, |
5336 | SCTP_ERROR(ETIMEDOUT)); | 5332 | SCTP_ERROR(ETIMEDOUT)); |