• Home
  • Raw
  • Download

Lines Matching full:asoc

44 				struct sctp_association *asoc,
53 struct sctp_association **asoc,
64 static void sctp_do_ecn_ce_work(struct sctp_association *asoc, in sctp_do_ecn_ce_work() argument
69 asoc->last_ecne_tsn = lowest_tsn; in sctp_do_ecn_ce_work()
70 asoc->need_ecne = 1; in sctp_do_ecn_ce_work()
85 static struct sctp_chunk *sctp_do_ecn_ecne_work(struct sctp_association *asoc, in sctp_do_ecn_ecne_work() argument
101 if (TSN_lt(asoc->last_cwr_tsn, lowest_tsn)) { in sctp_do_ecn_ecne_work()
107 transport = sctp_assoc_lookup_tsn(asoc, lowest_tsn); in sctp_do_ecn_ecne_work()
113 asoc->last_cwr_tsn = lowest_tsn; in sctp_do_ecn_ecne_work()
119 repl = sctp_make_cwr(asoc, asoc->last_cwr_tsn, chunk); in sctp_do_ecn_ecne_work()
128 static void sctp_do_ecn_cwr_work(struct sctp_association *asoc, in sctp_do_ecn_cwr_work() argument
134 asoc->need_ecne = 0; in sctp_do_ecn_cwr_work()
138 static int sctp_gen_sack(struct sctp_association *asoc, int force, in sctp_gen_sack() argument
141 struct sctp_transport *trans = asoc->peer.last_data_from; in sctp_gen_sack()
147 (!trans && (asoc->param_flags & SPP_SACKDELAY_DISABLE)) || in sctp_gen_sack()
149 asoc->peer.sack_needed = 1; in sctp_gen_sack()
151 ctsn = sctp_tsnmap_get_ctsn(&asoc->peer.tsn_map); in sctp_gen_sack()
152 max_tsn_seen = sctp_tsnmap_get_max_tsn_seen(&asoc->peer.tsn_map); in sctp_gen_sack()
165 asoc->peer.sack_needed = 1; in sctp_gen_sack()
175 if (!asoc->peer.sack_needed) { in sctp_gen_sack()
176 asoc->peer.sack_cnt++; in sctp_gen_sack()
185 if (asoc->peer.sack_cnt >= trans->sackfreq - 1) in sctp_gen_sack()
186 asoc->peer.sack_needed = 1; in sctp_gen_sack()
188 asoc->timeouts[SCTP_EVENT_TIMEOUT_SACK] = in sctp_gen_sack()
192 if (asoc->peer.sack_cnt >= asoc->sackfreq - 1) in sctp_gen_sack()
193 asoc->peer.sack_needed = 1; in sctp_gen_sack()
195 asoc->timeouts[SCTP_EVENT_TIMEOUT_SACK] = in sctp_gen_sack()
196 asoc->sackdelay; in sctp_gen_sack()
203 __u32 old_a_rwnd = asoc->a_rwnd; in sctp_gen_sack()
205 asoc->a_rwnd = asoc->rwnd; in sctp_gen_sack()
206 sack = sctp_make_sack(asoc); in sctp_gen_sack()
208 asoc->a_rwnd = old_a_rwnd; in sctp_gen_sack()
212 asoc->peer.sack_needed = 0; in sctp_gen_sack()
213 asoc->peer.sack_cnt = 0; in sctp_gen_sack()
235 struct sctp_association *asoc = transport->asoc; in sctp_generate_t3_rtx_event() local
236 struct sock *sk = asoc->base.sk; in sctp_generate_t3_rtx_event()
255 asoc->state, in sctp_generate_t3_rtx_event()
256 asoc->ep, asoc, in sctp_generate_t3_rtx_event()
270 static void sctp_generate_timeout_event(struct sctp_association *asoc, in sctp_generate_timeout_event() argument
273 struct sock *sk = asoc->base.sk; in sctp_generate_timeout_event()
283 if (!mod_timer(&asoc->timers[timeout_type], jiffies + (HZ/20))) in sctp_generate_timeout_event()
284 sctp_association_hold(asoc); in sctp_generate_timeout_event()
291 if (asoc->base.dead) in sctp_generate_timeout_event()
297 asoc->state, asoc->ep, asoc, in sctp_generate_timeout_event()
305 sctp_association_put(asoc); in sctp_generate_timeout_event()
310 struct sctp_association *asoc = in sctp_generate_t1_cookie_event() local
311 from_timer(asoc, t, timers[SCTP_EVENT_TIMEOUT_T1_COOKIE]); in sctp_generate_t1_cookie_event()
313 sctp_generate_timeout_event(asoc, SCTP_EVENT_TIMEOUT_T1_COOKIE); in sctp_generate_t1_cookie_event()
318 struct sctp_association *asoc = in sctp_generate_t1_init_event() local
319 from_timer(asoc, t, timers[SCTP_EVENT_TIMEOUT_T1_INIT]); in sctp_generate_t1_init_event()
321 sctp_generate_timeout_event(asoc, SCTP_EVENT_TIMEOUT_T1_INIT); in sctp_generate_t1_init_event()
326 struct sctp_association *asoc = in sctp_generate_t2_shutdown_event() local
327 from_timer(asoc, t, timers[SCTP_EVENT_TIMEOUT_T2_SHUTDOWN]); in sctp_generate_t2_shutdown_event()
329 sctp_generate_timeout_event(asoc, SCTP_EVENT_TIMEOUT_T2_SHUTDOWN); in sctp_generate_t2_shutdown_event()
334 struct sctp_association *asoc = in sctp_generate_t4_rto_event() local
335 from_timer(asoc, t, timers[SCTP_EVENT_TIMEOUT_T4_RTO]); in sctp_generate_t4_rto_event()
337 sctp_generate_timeout_event(asoc, SCTP_EVENT_TIMEOUT_T4_RTO); in sctp_generate_t4_rto_event()
342 struct sctp_association *asoc = in sctp_generate_t5_shutdown_guard_event() local
343 from_timer(asoc, t, in sctp_generate_t5_shutdown_guard_event()
346 sctp_generate_timeout_event(asoc, in sctp_generate_t5_shutdown_guard_event()
353 struct sctp_association *asoc = in sctp_generate_autoclose_event() local
354 from_timer(asoc, t, timers[SCTP_EVENT_TIMEOUT_AUTOCLOSE]); in sctp_generate_autoclose_event()
356 sctp_generate_timeout_event(asoc, SCTP_EVENT_TIMEOUT_AUTOCLOSE); in sctp_generate_autoclose_event()
365 struct sctp_association *asoc = transport->asoc; in sctp_generate_heartbeat_event() local
366 struct sock *sk = asoc->base.sk; in sctp_generate_heartbeat_event()
393 asoc->state, asoc->ep, asoc, in sctp_generate_heartbeat_event()
411 struct sctp_association *asoc = transport->asoc; in sctp_generate_proto_unreach_event() local
412 struct sock *sk = asoc->base.sk; in sctp_generate_proto_unreach_event()
429 if (asoc->base.dead) in sctp_generate_proto_unreach_event()
434 asoc->state, asoc->ep, asoc, transport, GFP_ATOMIC); in sctp_generate_proto_unreach_event()
446 struct sctp_association *asoc = transport->asoc; in sctp_generate_reconf_event() local
447 struct sock *sk = asoc->base.sk; in sctp_generate_reconf_event()
462 if (!asoc->strreset_chunk) in sctp_generate_reconf_event()
467 asoc->state, asoc->ep, asoc, in sctp_generate_reconf_event()
481 struct sctp_association *asoc = in sctp_generate_sack_event() local
482 from_timer(asoc, t, timers[SCTP_EVENT_TIMEOUT_SACK]); in sctp_generate_sack_event()
484 sctp_generate_timeout_event(asoc, SCTP_EVENT_TIMEOUT_SACK); in sctp_generate_sack_event()
519 struct sctp_association *asoc, in sctp_do_8_2_transport_strike() argument
534 asoc->overall_error_count++; in sctp_do_8_2_transport_strike()
539 asoc->overall_error_count++; in sctp_do_8_2_transport_strike()
549 if (asoc->base.net->sctp.pf_enable && in sctp_do_8_2_transport_strike()
554 sctp_assoc_control_transport(asoc, transport, in sctp_do_8_2_transport_strike()
565 __func__, asoc, &transport->ipaddr.sa); in sctp_do_8_2_transport_strike()
567 sctp_assoc_control_transport(asoc, transport, in sctp_do_8_2_transport_strike()
573 asoc->peer.primary_path == transport && in sctp_do_8_2_transport_strike()
574 asoc->peer.active_path != transport) in sctp_do_8_2_transport_strike()
575 sctp_assoc_set_primary(asoc, asoc->peer.active_path); in sctp_do_8_2_transport_strike()
587 transport->rto = min((transport->rto * 2), transport->asoc->rto_max); in sctp_do_8_2_transport_strike()
588 sctp_max_rto(asoc, transport); in sctp_do_8_2_transport_strike()
594 struct sctp_association *asoc, in sctp_cmd_init_failed() argument
599 event = sctp_ulpevent_make_assoc_change(asoc, 0, SCTP_CANT_STR_ASSOC, in sctp_cmd_init_failed()
611 asoc->outqueue.error = error; in sctp_cmd_init_failed()
617 struct sctp_association *asoc, in sctp_cmd_assoc_failed() argument
627 asoc->stream.si->abort_pd(&asoc->ulpq, GFP_ATOMIC); in sctp_cmd_assoc_failed()
630 event = sctp_ulpevent_make_assoc_change(asoc, 0, SCTP_COMM_LOST, in sctp_cmd_assoc_failed()
634 event = sctp_ulpevent_make_assoc_change(asoc, 0, SCTP_COMM_LOST, in sctp_cmd_assoc_failed()
641 if (asoc->overall_error_count >= asoc->max_retrans) { in sctp_cmd_assoc_failed()
642 abort = sctp_make_violation_max_retrans(asoc, chunk); in sctp_cmd_assoc_failed()
652 asoc->outqueue.error = error; in sctp_cmd_assoc_failed()
662 struct sctp_association *asoc, in sctp_cmd_process_init() argument
674 if (!sctp_process_init(asoc, chunk, sctp_source(chunk), peer_init, gfp)) in sctp_cmd_process_init()
684 struct sctp_association *asoc) in sctp_cmd_hb_timers_start() argument
692 list_for_each_entry(t, &asoc->peer.transport_addr_list, transports) in sctp_cmd_hb_timers_start()
697 struct sctp_association *asoc) in sctp_cmd_hb_timers_stop() argument
703 list_for_each_entry(t, &asoc->peer.transport_addr_list, in sctp_cmd_hb_timers_stop()
712 struct sctp_association *asoc) in sctp_cmd_t3_rtx_timers_stop() argument
716 list_for_each_entry(t, &asoc->peer.transport_addr_list, in sctp_cmd_t3_rtx_timers_stop()
726 struct sctp_association *asoc, in sctp_cmd_transport_on() argument
747 if (t->asoc->state < SCTP_STATE_SHUTDOWN_PENDING) in sctp_cmd_transport_on()
748 t->asoc->overall_error_count = 0; in sctp_cmd_transport_on()
760 sctp_assoc_control_transport(asoc, t, SCTP_TRANSPORT_UP, in sctp_cmd_transport_on()
765 sctp_assoc_control_transport(asoc, t, SCTP_TRANSPORT_UP, in sctp_cmd_transport_on()
790 if (was_unconfirmed && asoc->peer.transport_count == 1) in sctp_cmd_transport_on()
797 struct sctp_association *asoc, in sctp_cmd_process_sack() argument
802 if (sctp_outq_sack(&asoc->outqueue, chunk)) { in sctp_cmd_process_sack()
804 err = sctp_do_sm(asoc->base.net, SCTP_EVENT_T_OTHER, in sctp_cmd_process_sack()
806 asoc->state, asoc->ep, asoc, NULL, in sctp_cmd_process_sack()
817 struct sctp_association *asoc, in sctp_cmd_setup_t2() argument
825 t = sctp_assoc_choose_alter_transport(asoc, in sctp_cmd_setup_t2()
826 asoc->shutdown_last_sent_to); in sctp_cmd_setup_t2()
829 asoc->shutdown_last_sent_to = t; in sctp_cmd_setup_t2()
830 asoc->timeouts[SCTP_EVENT_TIMEOUT_T2_SHUTDOWN] = t->rto; in sctp_cmd_setup_t2()
834 struct sctp_association *asoc, in sctp_cmd_assoc_update() argument
837 struct net *net = asoc->base.net; in sctp_cmd_assoc_update()
840 if (!sctp_assoc_update(asoc, new)) in sctp_cmd_assoc_update()
843 abort = sctp_make_abort(asoc, NULL, sizeof(struct sctp_errhdr)); in sctp_cmd_assoc_update()
857 struct sctp_association *asoc, in sctp_cmd_new_state() argument
860 struct sock *sk = asoc->base.sk; in sctp_cmd_new_state()
862 asoc->state = state; in sctp_cmd_new_state()
864 pr_debug("%s: asoc:%p[%s]\n", __func__, asoc, sctp_state_tbl[state]); in sctp_cmd_new_state()
870 if (sctp_state(asoc, ESTABLISHED) && sctp_sstate(sk, CLOSED)) in sctp_cmd_new_state()
874 if (sctp_state(asoc, SHUTDOWN_RECEIVED) && in sctp_cmd_new_state()
881 if (sctp_state(asoc, COOKIE_WAIT)) { in sctp_cmd_new_state()
885 asoc->timeouts[SCTP_EVENT_TIMEOUT_T1_INIT] = in sctp_cmd_new_state()
886 asoc->rto_initial; in sctp_cmd_new_state()
887 asoc->timeouts[SCTP_EVENT_TIMEOUT_T1_COOKIE] = in sctp_cmd_new_state()
888 asoc->rto_initial; in sctp_cmd_new_state()
891 if (sctp_state(asoc, ESTABLISHED)) { in sctp_cmd_new_state()
892 kfree(asoc->peer.cookie); in sctp_cmd_new_state()
893 asoc->peer.cookie = NULL; in sctp_cmd_new_state()
896 if (sctp_state(asoc, ESTABLISHED) || in sctp_cmd_new_state()
897 sctp_state(asoc, CLOSED) || in sctp_cmd_new_state()
898 sctp_state(asoc, SHUTDOWN_RECEIVED)) { in sctp_cmd_new_state()
899 /* Wake up any processes waiting in the asoc's wait queue in in sctp_cmd_new_state()
902 if (waitqueue_active(&asoc->wait)) in sctp_cmd_new_state()
903 wake_up_interruptible(&asoc->wait); in sctp_cmd_new_state()
915 if (sctp_state(asoc, SHUTDOWN_PENDING) && in sctp_cmd_new_state()
916 !sctp_outq_is_empty(&asoc->outqueue)) in sctp_cmd_new_state()
917 sctp_outq_uncork(&asoc->outqueue, GFP_ATOMIC); in sctp_cmd_new_state()
922 struct sctp_association *asoc) in sctp_cmd_delete_tcb() argument
924 struct sock *sk = asoc->base.sk; in sctp_cmd_delete_tcb()
931 (!asoc->temp) && (sk->sk_shutdown != SHUTDOWN_MASK)) in sctp_cmd_delete_tcb()
934 sctp_association_free(asoc); in sctp_cmd_delete_tcb()
944 struct sctp_association *asoc, in sctp_cmd_setup_t4() argument
949 t = sctp_assoc_choose_alter_transport(asoc, chunk->transport); in sctp_cmd_setup_t4()
950 asoc->timeouts[SCTP_EVENT_TIMEOUT_T4_RTO] = t->rto; in sctp_cmd_setup_t4()
956 struct sctp_association *asoc, in sctp_cmd_process_operr() argument
965 ev = sctp_ulpevent_make_remote_error(asoc, chunk, 0, in sctp_cmd_process_operr()
970 asoc->stream.si->enqueue_event(&asoc->ulpq, ev); in sctp_cmd_process_operr()
987 if (asoc->peer.asconf_capable == 0) in sctp_cmd_process_operr()
990 asoc->peer.asconf_capable = 0; in sctp_cmd_process_operr()
1008 static void sctp_cmd_del_non_primary(struct sctp_association *asoc) in sctp_cmd_del_non_primary() argument
1014 list_for_each_safe(pos, temp, &asoc->peer.transport_addr_list) { in sctp_cmd_del_non_primary()
1017 &asoc->peer.primary_addr)) { in sctp_cmd_del_non_primary()
1018 sctp_assoc_rm_peer(asoc, t); in sctp_cmd_del_non_primary()
1024 static void sctp_cmd_set_sk_err(struct sctp_association *asoc, int error) in sctp_cmd_set_sk_err() argument
1026 struct sock *sk = asoc->base.sk; in sctp_cmd_set_sk_err()
1034 struct sctp_association *asoc, in sctp_cmd_assoc_change() argument
1039 ev = sctp_ulpevent_make_assoc_change(asoc, 0, state, 0, in sctp_cmd_assoc_change()
1040 asoc->c.sinit_num_ostreams, in sctp_cmd_assoc_change()
1041 asoc->c.sinit_max_instreams, in sctp_cmd_assoc_change()
1044 asoc->stream.si->enqueue_event(&asoc->ulpq, ev); in sctp_cmd_assoc_change()
1048 struct sctp_association *asoc) in sctp_cmd_peer_no_auth() argument
1052 ev = sctp_ulpevent_make_authkey(asoc, 0, SCTP_AUTH_NO_AUTH, GFP_ATOMIC); in sctp_cmd_peer_no_auth()
1054 asoc->stream.si->enqueue_event(&asoc->ulpq, ev); in sctp_cmd_peer_no_auth()
1059 struct sctp_association *asoc) in sctp_cmd_adaptation_ind() argument
1063 ev = sctp_ulpevent_make_adaptation_indication(asoc, GFP_ATOMIC); in sctp_cmd_adaptation_ind()
1066 asoc->stream.si->enqueue_event(&asoc->ulpq, ev); in sctp_cmd_adaptation_ind()
1070 static void sctp_cmd_t1_timer_update(struct sctp_association *asoc, in sctp_cmd_t1_timer_update() argument
1076 t = asoc->init_last_sent_to; in sctp_cmd_t1_timer_update()
1077 asoc->init_err_counter++; in sctp_cmd_t1_timer_update()
1079 if (t->init_sent_count > (asoc->init_cycle + 1)) { in sctp_cmd_t1_timer_update()
1080 asoc->timeouts[timer] *= 2; in sctp_cmd_t1_timer_update()
1081 if (asoc->timeouts[timer] > asoc->max_init_timeo) { in sctp_cmd_t1_timer_update()
1082 asoc->timeouts[timer] = asoc->max_init_timeo; in sctp_cmd_t1_timer_update()
1084 asoc->init_cycle++; in sctp_cmd_t1_timer_update()
1088 asoc->init_err_counter, asoc->init_cycle, in sctp_cmd_t1_timer_update()
1089 asoc->timeouts[timer]); in sctp_cmd_t1_timer_update()
1098 static void sctp_cmd_send_msg(struct sctp_association *asoc, in sctp_cmd_send_msg() argument
1104 sctp_outq_tail(&asoc->outqueue, chunk, gfp); in sctp_cmd_send_msg()
1106 asoc->outqueue.sched->enqueue(&asoc->outqueue, msg); in sctp_cmd_send_msg()
1115 pr_debug("%s[pre-fn]: ep:%p, %s, %s, asoc:%p[%s], %s\n", __func__, \
1117 asoc, sctp_state_tbl[state], state_fn->name)
1120 pr_debug("%s[post-fn]: asoc:%p, status:%s\n", __func__, asoc, \
1124 pr_debug("%s[post-sfx]: error:%d, asoc:%p[%s]\n", __func__, error, \
1125 asoc, sctp_state_tbl[(asoc && sctp_id2assoc(ep->base.sk, \
1126 sctp_assoc2id(asoc))) ? asoc->state : SCTP_STATE_CLOSED])
1136 struct sctp_endpoint *ep, struct sctp_association *asoc, in sctp_do_sm() argument
1157 status = state_fn->fn(net, ep, asoc, subtype, event_arg, &commands); in sctp_do_sm()
1161 ep, &asoc, event_arg, status, in sctp_do_sm()
1175 struct sctp_association **asoc, in sctp_side_effects() argument
1190 ep, *asoc, in sctp_side_effects()
1215 *asoc = NULL; in sctp_side_effects()
1264 struct sctp_association *asoc, in sctp_cmd_interpreter() argument
1301 sctp_outq_uncork(&asoc->outqueue, gfp); in sctp_cmd_interpreter()
1306 asoc = cmd->obj.asoc; in sctp_cmd_interpreter()
1307 BUG_ON(asoc->peer.primary_path == NULL); in sctp_cmd_interpreter()
1308 sctp_endpoint_add_asoc(ep, asoc); in sctp_cmd_interpreter()
1312 sctp_cmd_assoc_update(commands, asoc, cmd->obj.asoc); in sctp_cmd_interpreter()
1316 sctp_outq_teardown(&asoc->outqueue); in sctp_cmd_interpreter()
1321 sctp_outq_uncork(&asoc->outqueue, gfp); in sctp_cmd_interpreter()
1325 sctp_cmd_delete_tcb(commands, asoc); in sctp_cmd_interpreter()
1326 asoc = NULL; in sctp_cmd_interpreter()
1331 sctp_cmd_new_state(commands, asoc, cmd->obj.state); in sctp_cmd_interpreter()
1336 error = sctp_tsnmap_mark(&asoc->peer.tsn_map, in sctp_cmd_interpreter()
1341 asoc->stream.si->report_ftsn(&asoc->ulpq, cmd->obj.u32); in sctp_cmd_interpreter()
1345 asoc->stream.si->handle_ftsn(&asoc->ulpq, in sctp_cmd_interpreter()
1356 error = sctp_gen_sack(asoc, force, commands); in sctp_cmd_interpreter()
1361 error = sctp_cmd_process_sack(commands, asoc, in sctp_cmd_interpreter()
1367 new_obj = sctp_make_init_ack(asoc, chunk, GFP_ATOMIC, in sctp_cmd_interpreter()
1384 error = sctp_cmd_process_init(commands, asoc, chunk, in sctp_cmd_interpreter()
1390 new_obj = sctp_make_cookie_echo(asoc, chunk); in sctp_cmd_interpreter()
1409 asoc->init_last_sent_to = new_obj->transport; in sctp_cmd_interpreter()
1415 * command plays with asoc->peer.retran_path to in sctp_cmd_interpreter()
1424 if ((asoc->peer.retran_path != in sctp_cmd_interpreter()
1425 asoc->peer.primary_path) && in sctp_cmd_interpreter()
1426 (asoc->init_err_counter > 0)) { in sctp_cmd_interpreter()
1438 asoc->overall_error_count = 0; in sctp_cmd_interpreter()
1441 new_obj = sctp_make_shutdown(asoc, chunk); in sctp_cmd_interpreter()
1453 __func__, cmd->obj.chunk, &asoc->ulpq); in sctp_cmd_interpreter()
1455 asoc->stream.si->ulpevent_data(&asoc->ulpq, in sctp_cmd_interpreter()
1463 __func__, cmd->obj.ulpevent, &asoc->ulpq); in sctp_cmd_interpreter()
1465 asoc->stream.si->enqueue_event(&asoc->ulpq, in sctp_cmd_interpreter()
1471 if (!asoc->outqueue.cork) { in sctp_cmd_interpreter()
1472 sctp_outq_cork(&asoc->outqueue); in sctp_cmd_interpreter()
1476 sctp_outq_tail(&asoc->outqueue, cmd->obj.chunk, gfp); in sctp_cmd_interpreter()
1488 sctp_retransmit(&asoc->outqueue, cmd->obj.transport, in sctp_cmd_interpreter()
1494 sctp_retransmit(&asoc->outqueue, cmd->obj.transport, in sctp_cmd_interpreter()
1500 sctp_do_ecn_ce_work(asoc, cmd->obj.u32); in sctp_cmd_interpreter()
1505 new_obj = sctp_do_ecn_ecne_work(asoc, cmd->obj.u32, in sctp_cmd_interpreter()
1514 sctp_do_ecn_cwr_work(asoc, cmd->obj.u32); in sctp_cmd_interpreter()
1518 sctp_cmd_setup_t2(commands, asoc, cmd->obj.chunk); in sctp_cmd_interpreter()
1522 timer = &asoc->timers[cmd->obj.to]; in sctp_cmd_interpreter()
1529 timer = &asoc->timers[cmd->obj.to]; in sctp_cmd_interpreter()
1530 timeout = asoc->timeouts[cmd->obj.to]; in sctp_cmd_interpreter()
1542 sctp_association_hold(asoc); in sctp_cmd_interpreter()
1547 timer = &asoc->timers[cmd->obj.to]; in sctp_cmd_interpreter()
1548 timeout = asoc->timeouts[cmd->obj.to]; in sctp_cmd_interpreter()
1550 sctp_association_hold(asoc); in sctp_cmd_interpreter()
1554 timer = &asoc->timers[cmd->obj.to]; in sctp_cmd_interpreter()
1556 sctp_association_put(asoc); in sctp_cmd_interpreter()
1561 t = sctp_assoc_choose_alter_transport(asoc, in sctp_cmd_interpreter()
1562 asoc->init_last_sent_to); in sctp_cmd_interpreter()
1563 asoc->init_last_sent_to = t; in sctp_cmd_interpreter()
1567 sctp_assoc_set_primary(asoc, t); in sctp_cmd_interpreter()
1577 sctp_cmd_t1_timer_update(asoc, in sctp_cmd_interpreter()
1592 sctp_cmd_t1_timer_update(asoc, in sctp_cmd_interpreter()
1599 list_for_each_entry(t, &asoc->peer.transport_addr_list, in sctp_cmd_interpreter()
1601 sctp_retransmit_mark(&asoc->outqueue, t, in sctp_cmd_interpreter()
1611 sctp_cmd_init_failed(commands, asoc, cmd->obj.u16); in sctp_cmd_interpreter()
1615 sctp_cmd_assoc_failed(commands, asoc, event_type, in sctp_cmd_interpreter()
1620 asoc->init_err_counter++; in sctp_cmd_interpreter()
1624 asoc->init_err_counter = 0; in sctp_cmd_interpreter()
1625 asoc->init_cycle = 0; in sctp_cmd_interpreter()
1626 list_for_each_entry(t, &asoc->peer.transport_addr_list, in sctp_cmd_interpreter()
1633 sctp_tsnmap_mark_dup(&asoc->peer.tsn_map, in sctp_cmd_interpreter()
1643 sctp_do_8_2_transport_strike(commands, asoc, in sctp_cmd_interpreter()
1654 sctp_do_8_2_transport_strike(commands, asoc, in sctp_cmd_interpreter()
1661 sctp_cmd_transport_on(commands, asoc, t, chunk); in sctp_cmd_interpreter()
1665 sctp_cmd_hb_timers_start(commands, asoc); in sctp_cmd_interpreter()
1674 sctp_cmd_hb_timers_stop(commands, asoc); in sctp_cmd_interpreter()
1684 sackh.a_rwnd = htonl(asoc->peer.rwnd + in sctp_cmd_interpreter()
1685 asoc->outqueue.outstanding_bytes); in sctp_cmd_interpreter()
1699 if (asoc) { in sctp_cmd_interpreter()
1700 sctp_outq_uncork(&asoc->outqueue, gfp); in sctp_cmd_interpreter()
1711 asoc->stream.si->start_pd(&asoc->ulpq, GFP_ATOMIC); in sctp_cmd_interpreter()
1715 asoc->stream.si->renege_events(&asoc->ulpq, in sctp_cmd_interpreter()
1721 sctp_cmd_setup_t4(commands, asoc, cmd->obj.chunk); in sctp_cmd_interpreter()
1725 sctp_cmd_process_operr(commands, asoc, chunk); in sctp_cmd_interpreter()
1728 asoc->peer.i.init_tag = 0; in sctp_cmd_interpreter()
1731 sctp_cmd_del_non_primary(asoc); in sctp_cmd_interpreter()
1734 sctp_cmd_t3_rtx_timers_stop(commands, asoc); in sctp_cmd_interpreter()
1737 t = asoc->peer.retran_path; in sctp_cmd_interpreter()
1738 asoc->peer.retran_path = asoc->peer.primary_path; in sctp_cmd_interpreter()
1739 sctp_outq_uncork(&asoc->outqueue, gfp); in sctp_cmd_interpreter()
1741 asoc->peer.retran_path = t; in sctp_cmd_interpreter()
1744 sctp_cmd_set_sk_err(asoc, cmd->obj.error); in sctp_cmd_interpreter()
1747 sctp_cmd_assoc_change(commands, asoc, in sctp_cmd_interpreter()
1751 sctp_cmd_adaptation_ind(commands, asoc); in sctp_cmd_interpreter()
1754 sctp_cmd_peer_no_auth(commands, asoc); in sctp_cmd_interpreter()
1758 error = sctp_auth_asoc_init_active_key(asoc, in sctp_cmd_interpreter()
1762 asoc->peer.i.init_tag = cmd->obj.u32; in sctp_cmd_interpreter()
1765 if (!asoc->outqueue.cork) { in sctp_cmd_interpreter()
1766 sctp_outq_cork(&asoc->outqueue); in sctp_cmd_interpreter()
1769 sctp_cmd_send_msg(asoc, cmd->obj.msg, gfp); in sctp_cmd_interpreter()
1772 sctp_asconf_queue_teardown(asoc); in sctp_cmd_interpreter()
1776 if (asoc && local_cork) { in sctp_cmd_interpreter()
1777 sctp_outq_uncork(&asoc->outqueue, gfp); in sctp_cmd_interpreter()
1780 asoc = cmd->obj.asoc; in sctp_cmd_interpreter()
1804 if (asoc && SCTP_EVENT_T_CHUNK == event_type && chunk) { in sctp_cmd_interpreter()
1806 sctp_outq_uncork(&asoc->outqueue, gfp); in sctp_cmd_interpreter()
1808 sctp_outq_uncork(&asoc->outqueue, gfp); in sctp_cmd_interpreter()