Lines Matching refs:asoc

59 				struct sctp_association *asoc,
68 struct sctp_association **asoc,
79 static void sctp_do_ecn_ce_work(struct sctp_association *asoc, in sctp_do_ecn_ce_work() argument
84 asoc->last_ecne_tsn = lowest_tsn; in sctp_do_ecn_ce_work()
85 asoc->need_ecne = 1; in sctp_do_ecn_ce_work()
100 static struct sctp_chunk *sctp_do_ecn_ecne_work(struct sctp_association *asoc, in sctp_do_ecn_ecne_work() argument
116 if (TSN_lt(asoc->last_cwr_tsn, lowest_tsn)) { in sctp_do_ecn_ecne_work()
122 transport = sctp_assoc_lookup_tsn(asoc, lowest_tsn); in sctp_do_ecn_ecne_work()
128 asoc->last_cwr_tsn = lowest_tsn; in sctp_do_ecn_ecne_work()
134 repl = sctp_make_cwr(asoc, asoc->last_cwr_tsn, chunk); in sctp_do_ecn_ecne_work()
143 static void sctp_do_ecn_cwr_work(struct sctp_association *asoc, in sctp_do_ecn_cwr_work() argument
149 asoc->need_ecne = 0; in sctp_do_ecn_cwr_work()
153 static int sctp_gen_sack(struct sctp_association *asoc, int force, in sctp_gen_sack() argument
156 struct sctp_transport *trans = asoc->peer.last_data_from; in sctp_gen_sack()
162 (!trans && (asoc->param_flags & SPP_SACKDELAY_DISABLE)) || in sctp_gen_sack()
164 asoc->peer.sack_needed = 1; in sctp_gen_sack()
166 ctsn = sctp_tsnmap_get_ctsn(&asoc->peer.tsn_map); in sctp_gen_sack()
167 max_tsn_seen = sctp_tsnmap_get_max_tsn_seen(&asoc->peer.tsn_map); in sctp_gen_sack()
180 asoc->peer.sack_needed = 1; in sctp_gen_sack()
190 if (!asoc->peer.sack_needed) { in sctp_gen_sack()
191 asoc->peer.sack_cnt++; in sctp_gen_sack()
200 if (asoc->peer.sack_cnt >= trans->sackfreq - 1) in sctp_gen_sack()
201 asoc->peer.sack_needed = 1; in sctp_gen_sack()
203 asoc->timeouts[SCTP_EVENT_TIMEOUT_SACK] = in sctp_gen_sack()
207 if (asoc->peer.sack_cnt >= asoc->sackfreq - 1) in sctp_gen_sack()
208 asoc->peer.sack_needed = 1; in sctp_gen_sack()
210 asoc->timeouts[SCTP_EVENT_TIMEOUT_SACK] = in sctp_gen_sack()
211 asoc->sackdelay; in sctp_gen_sack()
218 __u32 old_a_rwnd = asoc->a_rwnd; in sctp_gen_sack()
220 asoc->a_rwnd = asoc->rwnd; in sctp_gen_sack()
221 sack = sctp_make_sack(asoc); in sctp_gen_sack()
223 asoc->a_rwnd = old_a_rwnd; in sctp_gen_sack()
227 asoc->peer.sack_needed = 0; in sctp_gen_sack()
228 asoc->peer.sack_cnt = 0; in sctp_gen_sack()
250 struct sctp_association *asoc = transport->asoc; in sctp_generate_t3_rtx_event() local
251 struct sock *sk = asoc->base.sk; in sctp_generate_t3_rtx_event()
270 asoc->state, in sctp_generate_t3_rtx_event()
271 asoc->ep, asoc, in sctp_generate_t3_rtx_event()
285 static void sctp_generate_timeout_event(struct sctp_association *asoc, in sctp_generate_timeout_event() argument
288 struct sock *sk = asoc->base.sk; in sctp_generate_timeout_event()
298 if (!mod_timer(&asoc->timers[timeout_type], jiffies + (HZ/20))) in sctp_generate_timeout_event()
299 sctp_association_hold(asoc); in sctp_generate_timeout_event()
306 if (asoc->base.dead) in sctp_generate_timeout_event()
312 asoc->state, asoc->ep, asoc, in sctp_generate_timeout_event()
320 sctp_association_put(asoc); in sctp_generate_timeout_event()
325 struct sctp_association *asoc = in sctp_generate_t1_cookie_event() local
326 from_timer(asoc, t, timers[SCTP_EVENT_TIMEOUT_T1_COOKIE]); in sctp_generate_t1_cookie_event()
328 sctp_generate_timeout_event(asoc, SCTP_EVENT_TIMEOUT_T1_COOKIE); in sctp_generate_t1_cookie_event()
333 struct sctp_association *asoc = in sctp_generate_t1_init_event() local
334 from_timer(asoc, t, timers[SCTP_EVENT_TIMEOUT_T1_INIT]); in sctp_generate_t1_init_event()
336 sctp_generate_timeout_event(asoc, SCTP_EVENT_TIMEOUT_T1_INIT); in sctp_generate_t1_init_event()
341 struct sctp_association *asoc = in sctp_generate_t2_shutdown_event() local
342 from_timer(asoc, t, timers[SCTP_EVENT_TIMEOUT_T2_SHUTDOWN]); in sctp_generate_t2_shutdown_event()
344 sctp_generate_timeout_event(asoc, SCTP_EVENT_TIMEOUT_T2_SHUTDOWN); in sctp_generate_t2_shutdown_event()
349 struct sctp_association *asoc = in sctp_generate_t4_rto_event() local
350 from_timer(asoc, t, timers[SCTP_EVENT_TIMEOUT_T4_RTO]); in sctp_generate_t4_rto_event()
352 sctp_generate_timeout_event(asoc, SCTP_EVENT_TIMEOUT_T4_RTO); in sctp_generate_t4_rto_event()
357 struct sctp_association *asoc = in sctp_generate_t5_shutdown_guard_event() local
358 from_timer(asoc, t, in sctp_generate_t5_shutdown_guard_event()
361 sctp_generate_timeout_event(asoc, in sctp_generate_t5_shutdown_guard_event()
368 struct sctp_association *asoc = in sctp_generate_autoclose_event() local
369 from_timer(asoc, t, timers[SCTP_EVENT_TIMEOUT_AUTOCLOSE]); in sctp_generate_autoclose_event()
371 sctp_generate_timeout_event(asoc, SCTP_EVENT_TIMEOUT_AUTOCLOSE); in sctp_generate_autoclose_event()
380 struct sctp_association *asoc = transport->asoc; in sctp_generate_heartbeat_event() local
381 struct sock *sk = asoc->base.sk; in sctp_generate_heartbeat_event()
408 asoc->state, asoc->ep, asoc, in sctp_generate_heartbeat_event()
426 struct sctp_association *asoc = transport->asoc; in sctp_generate_proto_unreach_event() local
427 struct sock *sk = asoc->base.sk; in sctp_generate_proto_unreach_event()
437 sctp_association_hold(asoc); in sctp_generate_proto_unreach_event()
444 if (asoc->base.dead) in sctp_generate_proto_unreach_event()
449 asoc->state, asoc->ep, asoc, transport, GFP_ATOMIC); in sctp_generate_proto_unreach_event()
453 sctp_association_put(asoc); in sctp_generate_proto_unreach_event()
461 struct sctp_association *asoc = transport->asoc; in sctp_generate_reconf_event() local
462 struct sock *sk = asoc->base.sk; in sctp_generate_reconf_event()
478 asoc->state, asoc->ep, asoc, in sctp_generate_reconf_event()
492 struct sctp_association *asoc = in sctp_generate_sack_event() local
493 from_timer(asoc, t, timers[SCTP_EVENT_TIMEOUT_SACK]); in sctp_generate_sack_event()
495 sctp_generate_timeout_event(asoc, SCTP_EVENT_TIMEOUT_SACK); in sctp_generate_sack_event()
530 struct sctp_association *asoc, in sctp_do_8_2_transport_strike() argument
534 struct net *net = sock_net(asoc->base.sk); in sctp_do_8_2_transport_strike()
547 asoc->overall_error_count++; in sctp_do_8_2_transport_strike()
552 asoc->overall_error_count++; in sctp_do_8_2_transport_strike()
564 (asoc->pf_retrans < transport->pathmaxrxt) && in sctp_do_8_2_transport_strike()
565 (transport->error_count > asoc->pf_retrans)) { in sctp_do_8_2_transport_strike()
567 sctp_assoc_control_transport(asoc, transport, in sctp_do_8_2_transport_strike()
578 __func__, asoc, &transport->ipaddr.sa); in sctp_do_8_2_transport_strike()
580 sctp_assoc_control_transport(asoc, transport, in sctp_do_8_2_transport_strike()
595 transport->rto = min((transport->rto * 2), transport->asoc->rto_max); in sctp_do_8_2_transport_strike()
596 sctp_max_rto(asoc, transport); in sctp_do_8_2_transport_strike()
602 struct sctp_association *asoc, in sctp_cmd_init_failed() argument
607 event = sctp_ulpevent_make_assoc_change(asoc, 0, SCTP_CANT_STR_ASSOC, in sctp_cmd_init_failed()
619 asoc->outqueue.error = error; in sctp_cmd_init_failed()
625 struct sctp_association *asoc, in sctp_cmd_assoc_failed() argument
635 asoc->stream.si->abort_pd(&asoc->ulpq, GFP_ATOMIC); in sctp_cmd_assoc_failed()
638 event = sctp_ulpevent_make_assoc_change(asoc, 0, SCTP_COMM_LOST, in sctp_cmd_assoc_failed()
642 event = sctp_ulpevent_make_assoc_change(asoc, 0, SCTP_COMM_LOST, in sctp_cmd_assoc_failed()
649 if (asoc->overall_error_count >= asoc->max_retrans) { in sctp_cmd_assoc_failed()
650 abort = sctp_make_violation_max_retrans(asoc, chunk); in sctp_cmd_assoc_failed()
660 asoc->outqueue.error = error; in sctp_cmd_assoc_failed()
670 struct sctp_association *asoc, in sctp_cmd_process_init() argument
682 if (!sctp_process_init(asoc, chunk, sctp_source(chunk), peer_init, gfp)) in sctp_cmd_process_init()
692 struct sctp_association *asoc) in sctp_cmd_hb_timers_start() argument
700 list_for_each_entry(t, &asoc->peer.transport_addr_list, transports) in sctp_cmd_hb_timers_start()
705 struct sctp_association *asoc) in sctp_cmd_hb_timers_stop() argument
711 list_for_each_entry(t, &asoc->peer.transport_addr_list, in sctp_cmd_hb_timers_stop()
720 struct sctp_association *asoc) in sctp_cmd_t3_rtx_timers_stop() argument
724 list_for_each_entry(t, &asoc->peer.transport_addr_list, in sctp_cmd_t3_rtx_timers_stop()
734 struct sctp_association *asoc, in sctp_cmd_transport_on() argument
755 if (t->asoc->state < SCTP_STATE_SHUTDOWN_PENDING) in sctp_cmd_transport_on()
756 t->asoc->overall_error_count = 0; in sctp_cmd_transport_on()
768 sctp_assoc_control_transport(asoc, t, SCTP_TRANSPORT_UP, in sctp_cmd_transport_on()
773 sctp_assoc_control_transport(asoc, t, SCTP_TRANSPORT_UP, in sctp_cmd_transport_on()
798 if (was_unconfirmed && asoc->peer.transport_count == 1) in sctp_cmd_transport_on()
805 struct sctp_association *asoc, in sctp_cmd_process_sack() argument
810 if (sctp_outq_sack(&asoc->outqueue, chunk)) { in sctp_cmd_process_sack()
811 struct net *net = sock_net(asoc->base.sk); in sctp_cmd_process_sack()
816 asoc->state, asoc->ep, asoc, NULL, in sctp_cmd_process_sack()
827 struct sctp_association *asoc, in sctp_cmd_setup_t2() argument
835 t = sctp_assoc_choose_alter_transport(asoc, in sctp_cmd_setup_t2()
836 asoc->shutdown_last_sent_to); in sctp_cmd_setup_t2()
839 asoc->shutdown_last_sent_to = t; in sctp_cmd_setup_t2()
840 asoc->timeouts[SCTP_EVENT_TIMEOUT_T2_SHUTDOWN] = t->rto; in sctp_cmd_setup_t2()
844 struct sctp_association *asoc, in sctp_cmd_assoc_update() argument
847 struct net *net = sock_net(asoc->base.sk); in sctp_cmd_assoc_update()
850 if (!sctp_assoc_update(asoc, new)) in sctp_cmd_assoc_update()
853 abort = sctp_make_abort(asoc, NULL, sizeof(struct sctp_errhdr)); in sctp_cmd_assoc_update()
867 struct sctp_association *asoc, in sctp_cmd_new_state() argument
870 struct sock *sk = asoc->base.sk; in sctp_cmd_new_state()
872 asoc->state = state; in sctp_cmd_new_state()
874 pr_debug("%s: asoc:%p[%s]\n", __func__, asoc, sctp_state_tbl[state]); in sctp_cmd_new_state()
880 if (sctp_state(asoc, ESTABLISHED) && sctp_sstate(sk, CLOSED)) in sctp_cmd_new_state()
884 if (sctp_state(asoc, SHUTDOWN_RECEIVED) && in sctp_cmd_new_state()
891 if (sctp_state(asoc, COOKIE_WAIT)) { in sctp_cmd_new_state()
895 asoc->timeouts[SCTP_EVENT_TIMEOUT_T1_INIT] = in sctp_cmd_new_state()
896 asoc->rto_initial; in sctp_cmd_new_state()
897 asoc->timeouts[SCTP_EVENT_TIMEOUT_T1_COOKIE] = in sctp_cmd_new_state()
898 asoc->rto_initial; in sctp_cmd_new_state()
901 if (sctp_state(asoc, ESTABLISHED) || in sctp_cmd_new_state()
902 sctp_state(asoc, CLOSED) || in sctp_cmd_new_state()
903 sctp_state(asoc, SHUTDOWN_RECEIVED)) { in sctp_cmd_new_state()
907 if (waitqueue_active(&asoc->wait)) in sctp_cmd_new_state()
908 wake_up_interruptible(&asoc->wait); in sctp_cmd_new_state()
920 if (sctp_state(asoc, SHUTDOWN_PENDING) && in sctp_cmd_new_state()
921 !sctp_outq_is_empty(&asoc->outqueue)) in sctp_cmd_new_state()
922 sctp_outq_uncork(&asoc->outqueue, GFP_ATOMIC); in sctp_cmd_new_state()
927 struct sctp_association *asoc) in sctp_cmd_delete_tcb() argument
929 struct sock *sk = asoc->base.sk; in sctp_cmd_delete_tcb()
936 (!asoc->temp) && (sk->sk_shutdown != SHUTDOWN_MASK)) in sctp_cmd_delete_tcb()
939 sctp_association_free(asoc); in sctp_cmd_delete_tcb()
949 struct sctp_association *asoc, in sctp_cmd_setup_t4() argument
954 t = sctp_assoc_choose_alter_transport(asoc, chunk->transport); in sctp_cmd_setup_t4()
955 asoc->timeouts[SCTP_EVENT_TIMEOUT_T4_RTO] = t->rto; in sctp_cmd_setup_t4()
961 struct sctp_association *asoc, in sctp_cmd_process_operr() argument
970 ev = sctp_ulpevent_make_remote_error(asoc, chunk, 0, in sctp_cmd_process_operr()
975 asoc->stream.si->enqueue_event(&asoc->ulpq, ev); in sctp_cmd_process_operr()
992 if (asoc->peer.asconf_capable == 0) in sctp_cmd_process_operr()
995 asoc->peer.asconf_capable = 0; in sctp_cmd_process_operr()
1013 static void sctp_cmd_del_non_primary(struct sctp_association *asoc) in sctp_cmd_del_non_primary() argument
1019 list_for_each_safe(pos, temp, &asoc->peer.transport_addr_list) { in sctp_cmd_del_non_primary()
1022 &asoc->peer.primary_addr)) { in sctp_cmd_del_non_primary()
1023 sctp_assoc_rm_peer(asoc, t); in sctp_cmd_del_non_primary()
1029 static void sctp_cmd_set_sk_err(struct sctp_association *asoc, int error) in sctp_cmd_set_sk_err() argument
1031 struct sock *sk = asoc->base.sk; in sctp_cmd_set_sk_err()
1039 struct sctp_association *asoc, in sctp_cmd_assoc_change() argument
1044 ev = sctp_ulpevent_make_assoc_change(asoc, 0, state, 0, in sctp_cmd_assoc_change()
1045 asoc->c.sinit_num_ostreams, in sctp_cmd_assoc_change()
1046 asoc->c.sinit_max_instreams, in sctp_cmd_assoc_change()
1049 asoc->stream.si->enqueue_event(&asoc->ulpq, ev); in sctp_cmd_assoc_change()
1053 struct sctp_association *asoc) in sctp_cmd_peer_no_auth() argument
1057 ev = sctp_ulpevent_make_authkey(asoc, 0, SCTP_AUTH_NO_AUTH, GFP_ATOMIC); in sctp_cmd_peer_no_auth()
1059 asoc->stream.si->enqueue_event(&asoc->ulpq, ev); in sctp_cmd_peer_no_auth()
1064 struct sctp_association *asoc) in sctp_cmd_adaptation_ind() argument
1068 ev = sctp_ulpevent_make_adaptation_indication(asoc, GFP_ATOMIC); in sctp_cmd_adaptation_ind()
1071 asoc->stream.si->enqueue_event(&asoc->ulpq, ev); in sctp_cmd_adaptation_ind()
1075 static void sctp_cmd_t1_timer_update(struct sctp_association *asoc, in sctp_cmd_t1_timer_update() argument
1081 t = asoc->init_last_sent_to; in sctp_cmd_t1_timer_update()
1082 asoc->init_err_counter++; in sctp_cmd_t1_timer_update()
1084 if (t->init_sent_count > (asoc->init_cycle + 1)) { in sctp_cmd_t1_timer_update()
1085 asoc->timeouts[timer] *= 2; in sctp_cmd_t1_timer_update()
1086 if (asoc->timeouts[timer] > asoc->max_init_timeo) { in sctp_cmd_t1_timer_update()
1087 asoc->timeouts[timer] = asoc->max_init_timeo; in sctp_cmd_t1_timer_update()
1089 asoc->init_cycle++; in sctp_cmd_t1_timer_update()
1093 asoc->init_err_counter, asoc->init_cycle, in sctp_cmd_t1_timer_update()
1094 asoc->timeouts[timer]); in sctp_cmd_t1_timer_update()
1103 static void sctp_cmd_send_msg(struct sctp_association *asoc, in sctp_cmd_send_msg() argument
1109 sctp_outq_tail(&asoc->outqueue, chunk, gfp); in sctp_cmd_send_msg()
1111 asoc->outqueue.sched->enqueue(&asoc->outqueue, msg); in sctp_cmd_send_msg()
1118 static void sctp_cmd_send_asconf(struct sctp_association *asoc) in sctp_cmd_send_asconf() argument
1120 struct net *net = sock_net(asoc->base.sk); in sctp_cmd_send_asconf()
1125 if (!list_empty(&asoc->addip_chunk_list)) { in sctp_cmd_send_asconf()
1126 struct list_head *entry = asoc->addip_chunk_list.next; in sctp_cmd_send_asconf()
1133 if (sctp_primitive_ASCONF(net, asoc, asconf)) in sctp_cmd_send_asconf()
1136 asoc->addip_last_asconf = asconf; in sctp_cmd_send_asconf()
1148 asoc, sctp_state_tbl[state], state_fn->name)
1151 pr_debug("%s[post-fn]: asoc:%p, status:%s\n", __func__, asoc, \
1156 asoc, sctp_state_tbl[(asoc && sctp_id2assoc(ep->base.sk, \
1157 sctp_assoc2id(asoc))) ? asoc->state : SCTP_STATE_CLOSED])
1167 struct sctp_endpoint *ep, struct sctp_association *asoc, in sctp_do_sm() argument
1188 status = state_fn->fn(net, ep, asoc, subtype, event_arg, &commands); in sctp_do_sm()
1192 ep, &asoc, event_arg, status, in sctp_do_sm()
1206 struct sctp_association **asoc, in sctp_side_effects() argument
1221 ep, *asoc, in sctp_side_effects()
1246 *asoc = NULL; in sctp_side_effects()
1292 struct sctp_association *asoc, in sctp_cmd_interpreter() argument
1329 sctp_outq_uncork(&asoc->outqueue, gfp); in sctp_cmd_interpreter()
1334 asoc = cmd->obj.asoc; in sctp_cmd_interpreter()
1335 BUG_ON(asoc->peer.primary_path == NULL); in sctp_cmd_interpreter()
1336 sctp_endpoint_add_asoc(ep, asoc); in sctp_cmd_interpreter()
1340 sctp_cmd_assoc_update(commands, asoc, cmd->obj.asoc); in sctp_cmd_interpreter()
1344 sctp_outq_teardown(&asoc->outqueue); in sctp_cmd_interpreter()
1349 sctp_outq_uncork(&asoc->outqueue, gfp); in sctp_cmd_interpreter()
1353 sctp_cmd_delete_tcb(commands, asoc); in sctp_cmd_interpreter()
1354 asoc = NULL; in sctp_cmd_interpreter()
1359 sctp_cmd_new_state(commands, asoc, cmd->obj.state); in sctp_cmd_interpreter()
1364 error = sctp_tsnmap_mark(&asoc->peer.tsn_map, in sctp_cmd_interpreter()
1369 asoc->stream.si->report_ftsn(&asoc->ulpq, cmd->obj.u32); in sctp_cmd_interpreter()
1373 asoc->stream.si->handle_ftsn(&asoc->ulpq, in sctp_cmd_interpreter()
1384 error = sctp_gen_sack(asoc, force, commands); in sctp_cmd_interpreter()
1389 error = sctp_cmd_process_sack(commands, asoc, in sctp_cmd_interpreter()
1395 new_obj = sctp_make_init_ack(asoc, chunk, GFP_ATOMIC, in sctp_cmd_interpreter()
1410 error = sctp_cmd_process_init(commands, asoc, chunk, in sctp_cmd_interpreter()
1416 new_obj = sctp_make_cookie_echo(asoc, chunk); in sctp_cmd_interpreter()
1434 asoc->init_last_sent_to = new_obj->transport; in sctp_cmd_interpreter()
1449 if ((asoc->peer.retran_path != in sctp_cmd_interpreter()
1450 asoc->peer.primary_path) && in sctp_cmd_interpreter()
1451 (asoc->init_err_counter > 0)) { in sctp_cmd_interpreter()
1463 asoc->overall_error_count = 0; in sctp_cmd_interpreter()
1466 new_obj = sctp_make_shutdown(asoc, chunk); in sctp_cmd_interpreter()
1476 __func__, cmd->obj.chunk, &asoc->ulpq); in sctp_cmd_interpreter()
1478 asoc->stream.si->ulpevent_data(&asoc->ulpq, in sctp_cmd_interpreter()
1486 __func__, cmd->obj.ulpevent, &asoc->ulpq); in sctp_cmd_interpreter()
1488 asoc->stream.si->enqueue_event(&asoc->ulpq, in sctp_cmd_interpreter()
1494 if (!asoc->outqueue.cork) { in sctp_cmd_interpreter()
1495 sctp_outq_cork(&asoc->outqueue); in sctp_cmd_interpreter()
1499 sctp_outq_tail(&asoc->outqueue, cmd->obj.chunk, gfp); in sctp_cmd_interpreter()
1511 sctp_retransmit(&asoc->outqueue, cmd->obj.transport, in sctp_cmd_interpreter()
1517 sctp_retransmit(&asoc->outqueue, cmd->obj.transport, in sctp_cmd_interpreter()
1523 sctp_do_ecn_ce_work(asoc, cmd->obj.u32); in sctp_cmd_interpreter()
1528 new_obj = sctp_do_ecn_ecne_work(asoc, cmd->obj.u32, in sctp_cmd_interpreter()
1537 sctp_do_ecn_cwr_work(asoc, cmd->obj.u32); in sctp_cmd_interpreter()
1541 sctp_cmd_setup_t2(commands, asoc, cmd->obj.chunk); in sctp_cmd_interpreter()
1545 timer = &asoc->timers[cmd->obj.to]; in sctp_cmd_interpreter()
1552 timer = &asoc->timers[cmd->obj.to]; in sctp_cmd_interpreter()
1553 timeout = asoc->timeouts[cmd->obj.to]; in sctp_cmd_interpreter()
1557 sctp_association_hold(asoc); in sctp_cmd_interpreter()
1562 timer = &asoc->timers[cmd->obj.to]; in sctp_cmd_interpreter()
1563 timeout = asoc->timeouts[cmd->obj.to]; in sctp_cmd_interpreter()
1565 sctp_association_hold(asoc); in sctp_cmd_interpreter()
1569 timer = &asoc->timers[cmd->obj.to]; in sctp_cmd_interpreter()
1571 sctp_association_put(asoc); in sctp_cmd_interpreter()
1576 t = sctp_assoc_choose_alter_transport(asoc, in sctp_cmd_interpreter()
1577 asoc->init_last_sent_to); in sctp_cmd_interpreter()
1578 asoc->init_last_sent_to = t; in sctp_cmd_interpreter()
1582 sctp_assoc_set_primary(asoc, t); in sctp_cmd_interpreter()
1592 sctp_cmd_t1_timer_update(asoc, in sctp_cmd_interpreter()
1607 sctp_cmd_t1_timer_update(asoc, in sctp_cmd_interpreter()
1614 list_for_each_entry(t, &asoc->peer.transport_addr_list, in sctp_cmd_interpreter()
1616 sctp_retransmit_mark(&asoc->outqueue, t, in sctp_cmd_interpreter()
1626 sctp_cmd_init_failed(commands, asoc, cmd->obj.u32); in sctp_cmd_interpreter()
1630 sctp_cmd_assoc_failed(commands, asoc, event_type, in sctp_cmd_interpreter()
1635 asoc->init_err_counter++; in sctp_cmd_interpreter()
1639 asoc->init_err_counter = 0; in sctp_cmd_interpreter()
1640 asoc->init_cycle = 0; in sctp_cmd_interpreter()
1641 list_for_each_entry(t, &asoc->peer.transport_addr_list, in sctp_cmd_interpreter()
1648 sctp_tsnmap_mark_dup(&asoc->peer.tsn_map, in sctp_cmd_interpreter()
1658 sctp_do_8_2_transport_strike(commands, asoc, in sctp_cmd_interpreter()
1669 sctp_do_8_2_transport_strike(commands, asoc, in sctp_cmd_interpreter()
1676 sctp_cmd_transport_on(commands, asoc, t, chunk); in sctp_cmd_interpreter()
1680 sctp_cmd_hb_timers_start(commands, asoc); in sctp_cmd_interpreter()
1689 sctp_cmd_hb_timers_stop(commands, asoc); in sctp_cmd_interpreter()
1699 sackh.a_rwnd = htonl(asoc->peer.rwnd + in sctp_cmd_interpreter()
1700 asoc->outqueue.outstanding_bytes); in sctp_cmd_interpreter()
1714 if (asoc) { in sctp_cmd_interpreter()
1715 sctp_outq_uncork(&asoc->outqueue, gfp); in sctp_cmd_interpreter()
1726 asoc->stream.si->start_pd(&asoc->ulpq, GFP_ATOMIC); in sctp_cmd_interpreter()
1730 asoc->stream.si->renege_events(&asoc->ulpq, in sctp_cmd_interpreter()
1736 sctp_cmd_setup_t4(commands, asoc, cmd->obj.chunk); in sctp_cmd_interpreter()
1740 sctp_cmd_process_operr(commands, asoc, chunk); in sctp_cmd_interpreter()
1743 asoc->peer.i.init_tag = 0; in sctp_cmd_interpreter()
1746 sctp_cmd_del_non_primary(asoc); in sctp_cmd_interpreter()
1749 sctp_cmd_t3_rtx_timers_stop(commands, asoc); in sctp_cmd_interpreter()
1752 t = asoc->peer.retran_path; in sctp_cmd_interpreter()
1753 asoc->peer.retran_path = asoc->peer.primary_path; in sctp_cmd_interpreter()
1754 sctp_outq_uncork(&asoc->outqueue, gfp); in sctp_cmd_interpreter()
1756 asoc->peer.retran_path = t; in sctp_cmd_interpreter()
1759 sctp_cmd_set_sk_err(asoc, cmd->obj.error); in sctp_cmd_interpreter()
1762 sctp_cmd_assoc_change(commands, asoc, in sctp_cmd_interpreter()
1766 sctp_cmd_adaptation_ind(commands, asoc); in sctp_cmd_interpreter()
1769 sctp_cmd_peer_no_auth(commands, asoc); in sctp_cmd_interpreter()
1773 error = sctp_auth_asoc_init_active_key(asoc, in sctp_cmd_interpreter()
1777 asoc->peer.i.init_tag = cmd->obj.u32; in sctp_cmd_interpreter()
1780 if (!asoc->outqueue.cork) { in sctp_cmd_interpreter()
1781 sctp_outq_cork(&asoc->outqueue); in sctp_cmd_interpreter()
1784 sctp_cmd_send_msg(asoc, cmd->obj.msg, gfp); in sctp_cmd_interpreter()
1787 sctp_cmd_send_asconf(asoc); in sctp_cmd_interpreter()
1790 sctp_asconf_queue_teardown(asoc); in sctp_cmd_interpreter()
1794 if (asoc && local_cork) { in sctp_cmd_interpreter()
1795 sctp_outq_uncork(&asoc->outqueue, gfp); in sctp_cmd_interpreter()
1798 asoc = cmd->obj.asoc; in sctp_cmd_interpreter()
1816 if (asoc && SCTP_EVENT_T_CHUNK == event_type && chunk) { in sctp_cmd_interpreter()
1818 sctp_outq_uncork(&asoc->outqueue, gfp); in sctp_cmd_interpreter()
1820 sctp_outq_uncork(&asoc->outqueue, gfp); in sctp_cmd_interpreter()