Merge branch 'master' of master.kernel.org:/pub/scm/linux/kernel/git/davem/net-2.6
Conflicts: drivers/net/ehea/ehea_main.c drivers/net/wireless/iwlwifi/Kconfig drivers/net/wireless/rt2x00/rt61pci.c net/ipv4/inet_timewait_sock.c net/ipv6/raw.c net/mac80211/ieee80211_sta.c
This commit is contained in:
@ -4138,6 +4138,24 @@ static sctp_disposition_t sctp_sf_abort_violation(
|
||||
goto nomem;
|
||||
|
||||
if (asoc) {
|
||||
/* Treat INIT-ACK as a special case during COOKIE-WAIT. */
|
||||
if (chunk->chunk_hdr->type == SCTP_CID_INIT_ACK &&
|
||||
!asoc->peer.i.init_tag) {
|
||||
sctp_initack_chunk_t *initack;
|
||||
|
||||
initack = (sctp_initack_chunk_t *)chunk->chunk_hdr;
|
||||
if (!sctp_chunk_length_valid(chunk,
|
||||
sizeof(sctp_initack_chunk_t)))
|
||||
abort->chunk_hdr->flags |= SCTP_CHUNK_FLAG_T;
|
||||
else {
|
||||
unsigned int inittag;
|
||||
|
||||
inittag = ntohl(initack->init_hdr.init_tag);
|
||||
sctp_add_cmd_sf(commands, SCTP_CMD_UPDATE_INITTAG,
|
||||
SCTP_U32(inittag));
|
||||
}
|
||||
}
|
||||
|
||||
sctp_add_cmd_sf(commands, SCTP_CMD_REPLY, SCTP_CHUNK(abort));
|
||||
SCTP_INC_STATS(SCTP_MIB_OUTCTRLCHUNKS);
|
||||
|
||||
@ -4343,6 +4361,7 @@ sctp_disposition_t sctp_sf_do_prm_asoc(const struct sctp_endpoint *ep,
|
||||
sctp_cmd_seq_t *commands)
|
||||
{
|
||||
struct sctp_chunk *repl;
|
||||
struct sctp_association* my_asoc;
|
||||
|
||||
/* The comment below says that we enter COOKIE-WAIT AFTER
|
||||
* sending the INIT, but that doesn't actually work in our
|
||||
@ -4366,8 +4385,8 @@ sctp_disposition_t sctp_sf_do_prm_asoc(const struct sctp_endpoint *ep,
|
||||
/* Cast away the const modifier, as we want to just
|
||||
* rerun it through as a sideffect.
|
||||
*/
|
||||
sctp_add_cmd_sf(commands, SCTP_CMD_NEW_ASOC,
|
||||
SCTP_ASOC((struct sctp_association *) asoc));
|
||||
my_asoc = (struct sctp_association *)asoc;
|
||||
sctp_add_cmd_sf(commands, SCTP_CMD_NEW_ASOC, SCTP_ASOC(my_asoc));
|
||||
|
||||
/* Choose transport for INIT. */
|
||||
sctp_add_cmd_sf(commands, SCTP_CMD_INIT_CHOOSE_TRANSPORT,
|
||||
|
Reference in New Issue
Block a user