Lines Matching refs:session

98 static bool j1939_sk_queue_session(struct j1939_session *session)  in j1939_sk_queue_session()  argument
100 struct j1939_sock *jsk = j1939_sk(session->sk); in j1939_sk_queue_session()
105 j1939_session_get(session); in j1939_sk_queue_session()
106 list_add_tail(&session->sk_session_queue_entry, &jsk->sk_session_queue); in j1939_sk_queue_session()
116 struct j1939_session *session = NULL; in j1939_sk_get_incomplete_session() local
120 session = list_last_entry(&jsk->sk_session_queue, in j1939_sk_get_incomplete_session()
123 if (session->total_queued_size == session->total_message_size) in j1939_sk_get_incomplete_session()
124 session = NULL; in j1939_sk_get_incomplete_session()
126 j1939_session_get(session); in j1939_sk_get_incomplete_session()
130 return session; in j1939_sk_get_incomplete_session()
136 struct j1939_session *session, *tmp; in j1939_sk_queue_drop_all() local
140 list_for_each_entry_safe(session, tmp, &jsk->sk_session_queue, in j1939_sk_queue_drop_all()
142 list_del_init(&session->sk_session_queue_entry); in j1939_sk_queue_drop_all()
143 session->err = err; in j1939_sk_queue_drop_all()
144 j1939_session_put(session); in j1939_sk_queue_drop_all()
149 static void j1939_sk_queue_activate_next_locked(struct j1939_session *session) in j1939_sk_queue_activate_next_locked() argument
156 if (!session->sk) in j1939_sk_queue_activate_next_locked()
159 jsk = j1939_sk(session->sk); in j1939_sk_queue_activate_next_locked()
162 err = session->err; in j1939_sk_queue_activate_next_locked()
169 if (first != session) in j1939_sk_queue_activate_next_locked()
195 void j1939_sk_queue_activate_next(struct j1939_session *session) in j1939_sk_queue_activate_next() argument
199 if (!session->sk) in j1939_sk_queue_activate_next()
202 jsk = j1939_sk(session->sk); in j1939_sk_queue_activate_next()
205 j1939_sk_queue_activate_next_locked(session); in j1939_sk_queue_activate_next()
928 j1939_sk_get_timestamping_opt_stats(struct j1939_session *session, in j1939_sk_get_timestamping_opt_stats() argument
938 if (session->skcb.addr.type == J1939_SIMPLE) in j1939_sk_get_timestamping_opt_stats()
939 size = session->total_message_size; in j1939_sk_get_timestamping_opt_stats()
941 size = min(session->pkt.tx_acked * 7, in j1939_sk_get_timestamping_opt_stats()
942 session->total_message_size); in j1939_sk_get_timestamping_opt_stats()
947 session->total_message_size); in j1939_sk_get_timestamping_opt_stats()
949 session->skcb.addr.pgn); in j1939_sk_get_timestamping_opt_stats()
951 session->skcb.addr.src_name, J1939_NLA_PAD); in j1939_sk_get_timestamping_opt_stats()
953 session->skcb.addr.dst_name, J1939_NLA_PAD); in j1939_sk_get_timestamping_opt_stats()
955 session->skcb.addr.sa); in j1939_sk_get_timestamping_opt_stats()
957 session->skcb.addr.da); in j1939_sk_get_timestamping_opt_stats()
966 static void __j1939_sk_errqueue(struct j1939_session *session, struct sock *sk, in __j1939_sk_errqueue() argument
969 struct j1939_priv *priv = session->priv; in __j1939_sk_errqueue()
1004 skb = j1939_sk_get_timestamping_opt_stats(session, type); in __j1939_sk_errqueue()
1028 serr->ee.ee_errno = session->err; in __j1939_sk_errqueue()
1046 serr->ee.ee_errno = session->err; in __j1939_sk_errqueue()
1055 serr->ee.ee_data = session->tskey; in __j1939_sk_errqueue()
1057 netdev_dbg(session->priv->ndev, "%s: 0x%p tskey: %i, state: %s\n", in __j1939_sk_errqueue()
1058 __func__, session, session->tskey, state); in __j1939_sk_errqueue()
1065 void j1939_sk_errqueue(struct j1939_session *session, in j1939_sk_errqueue() argument
1068 struct j1939_priv *priv = session->priv; in j1939_sk_errqueue()
1071 if (session->sk) { in j1939_sk_errqueue()
1073 __j1939_sk_errqueue(session, session->sk, type); in j1939_sk_errqueue()
1080 if (j1939_sk_recv_match_one(jsk, &session->skcb)) in j1939_sk_errqueue()
1081 __j1939_sk_errqueue(session, &jsk->sk, type); in j1939_sk_errqueue()
1098 struct j1939_session *session = j1939_sk_get_incomplete_session(jsk); in j1939_sk_send_loop() local
1103 if (session && in j1939_sk_send_loop()
1104 session->total_message_size != session->total_queued_size + size) { in j1939_sk_send_loop()
1105 j1939_session_put(session); in j1939_sk_send_loop()
1125 if (!session) { in j1939_sk_send_loop()
1130 session = j1939_tp_send(priv, skb, size); in j1939_sk_send_loop()
1131 if (IS_ERR(session)) { in j1939_sk_send_loop()
1132 ret = PTR_ERR(session); in j1939_sk_send_loop()
1135 if (j1939_sk_queue_session(session)) { in j1939_sk_send_loop()
1139 if (!j1939_session_activate(session)) { in j1939_sk_send_loop()
1140 j1939_tp_schedule_txtimer(session, 0); in j1939_sk_send_loop()
1143 session->err = ret; in j1939_sk_send_loop()
1150 skcb->offset = session->total_queued_size; in j1939_sk_send_loop()
1151 j1939_session_skb_queue(session, skb); in j1939_sk_send_loop()
1155 session->total_queued_size += segment_size; in j1939_sk_send_loop()
1177 if (session) in j1939_sk_send_loop()
1178 j1939_session_put(session); in j1939_sk_send_loop()