Received: by 2002:a6b:500f:0:0:0:0:0 with SMTP id e15csp5179077iob; Mon, 9 May 2022 10:15:49 -0700 (PDT) X-Google-Smtp-Source: ABdhPJyy/NO9eQWcmsR9/JP6insaiHFvSljAQYn+OIshdWmryfhOxZcV7iN3pBWorLyvJT70tYdE X-Received: by 2002:a05:620a:1a89:b0:6a0:30c7:a75c with SMTP id bl9-20020a05620a1a8900b006a030c7a75cmr12220118qkb.244.1652116549664; Mon, 09 May 2022 10:15:49 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1652116549; cv=none; d=google.com; s=arc-20160816; b=fmAx9Piu0hgskzmR4Z8Y0z3DzXAbqjam3rscOmaO9nxeMei6qCu3u0BEDL6s9tpZtv rJZVJDJVXfdI+Dhb7y3qSJspr7fByWXL1jbFwT6QuO/+1936LPZz8rdZ8u4i9qFyqawt CZelRjZ4RCjEFhYs0KSJfG6YuKd2MXa6s3y4Jyc9LFjcGw8w0qkHfIVflHxAH3QIP0xK VCltUXpEl1Z0RktOYRq6pVUbteyTgLm6jiGarwiOQyE5KI79xPYNax7cSbYcQk6Z2ZV9 TYbfWp9xLFC2faRARhWWb8f5Gx4QG47MAdcXy39tHFf3EJeQEKwdEnXfEpcRdcqKjW6O 1fgQ== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:mime-version :references:in-reply-to:message-id:date:subject:cc:to:from :dkim-signature; bh=i0XziHWrZd/+td+4ocNa810YQtwk+PMr7tdIKKwtqbI=; b=saIG/uCIrimu7Pkgo2yudzRbPYTlplXA7RcJWK0nXRsgwPdZOGp+IQq/fIp/1AC2Vs o/SJsU0qOLUCX8PfzZXyisHsGdmpahMpYNIRuTpdfgIrumw3qpJAtxvZiqBsMOnEeasl du9H8t13FOxPH/cQLn+YeEmeMj6d+of+gFJOPEpKYTvQeAfOZp5m/G2AHE7K5txnrCjq Pd6mY3eIgnAMIC0Cmu69u8yrUZVbGkwmaIBjE8xE4FvSVqwmvbOL78LvJ9Pg10R4MqgS VeSK6MkrV+j+ekNS3YQTetGQo5k2twZyZPJ2uVTh5sa5Cvqb4+auxg1kAdK5YJTcWHds BUvw== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@aruba.it header.s=a1 header.b=lQ157Da+; spf=softfail (google.com: domain of transitioning linux-kernel-owner@vger.kernel.org does not designate 23.128.96.19 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Return-Path: Received: from lindbergh.monkeyblade.net (lindbergh.monkeyblade.net. [23.128.96.19]) by mx.google.com with ESMTPS id c27-20020a05620a269b00b0067e4be2398csi9614115qkp.465.2022.05.09.10.15.49 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Mon, 09 May 2022 10:15:49 -0700 (PDT) Received-SPF: softfail (google.com: domain of transitioning linux-kernel-owner@vger.kernel.org does not designate 23.128.96.19 as permitted sender) client-ip=23.128.96.19; Authentication-Results: mx.google.com; dkim=pass header.i=@aruba.it header.s=a1 header.b=lQ157Da+; spf=softfail (google.com: domain of transitioning linux-kernel-owner@vger.kernel.org does not designate 23.128.96.19 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Received: from vger.kernel.org (vger.kernel.org [23.128.96.18]) by lindbergh.monkeyblade.net (Postfix) with ESMTP id 63BB21B775C; Mon, 9 May 2022 10:08:12 -0700 (PDT) Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S239708AbiEIRL6 (ORCPT + 99 others); Mon, 9 May 2022 13:11:58 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:59646 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S239682AbiEIRLu (ORCPT ); Mon, 9 May 2022 13:11:50 -0400 Received: from smtpcmd12132.aruba.it (smtpcmd12132.aruba.it [62.149.156.132]) by lindbergh.monkeyblade.net (Postfix) with ESMTP id F061817909E for ; Mon, 9 May 2022 10:07:50 -0700 (PDT) Received: from localhost.localdomain ([213.215.163.55]) by Aruba Outgoing Smtp with ESMTPSA id o6rMnQWIJPF2eo6rNnMWrE; Mon, 09 May 2022 19:07:49 +0200 DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=aruba.it; s=a1; t=1652116069; bh=zvVK/aJmzUqFc4aX2Dp9ESZBj1t6/6l/2t/r1bpWoG8=; h=From:To:Subject:Date:MIME-Version; b=lQ157Da+dz0osRvnK56TRcyoleZNnP4wCa/jp5k+RTv9jWe0TnIU0peTyk0X8djMs XQmesQJTINHx3MSp5H1hagtyqIDWjoXKWjes3V4DZXK7cQbK+scmdFBg3o6AznqZ3c MyouYpVCH9bhTzFYfZXmwQHo9/cquYCiXZ9/garwLif+QRrAwD/0YG2h9RNEIiUxV5 FfKjVbpQXaGjAt8YrCjVLV5p1pNjzVvoV+l53+A97yWnFyhJoYGB6enNa0r3kEcIFj 67uBHeOBp3I6anpZBnT5rXOwit8/NfcPKXL6lluQsaChhsQSwCiCnXCnnknyf/lIMb TNK5it2ifcyqg== From: Devid Antonio Filoni To: Robin van der Gracht , Oleksij Rempel Cc: kernel@pengutronix.de, linux-can@vger.kernel.org, Oleksij Rempel , Oliver Hartkopp , Marc Kleine-Budde , "David S. Miller" , Jakub Kicinski , Paolo Abeni , Maxime Jayat , kbuild test robot , netdev@vger.kernel.org, linux-kernel@vger.kernel.org, Devid Antonio Filoni Subject: [PATCH RESEND 2/2] can: j1939: make sure that sent CTL frames are marked as TX Date: Mon, 9 May 2022 19:07:46 +0200 Message-Id: <20220509170746.29893-3-devid.filoni@egluetechnologies.com> X-Mailer: git-send-email 2.25.1 In-Reply-To: <20220509170746.29893-1-devid.filoni@egluetechnologies.com> References: <20220509170746.29893-1-devid.filoni@egluetechnologies.com> MIME-Version: 1.0 Content-Transfer-Encoding: 8bit X-CMAE-Envelope: MS4xfF2xFHXIDDCHho1rSwAjnvHsr7MldqGXEXI/b06PUrL496M8myXTv1OYev0GlY3MhHta2oerXL+X3ejE9wxBNBRWHhDg8gnJeBe6Zt7lbA5xl+qb8WJy 9YS6eDR+qU4jExyX2T4gcH9ypA/BfT6VQ2lMPcM36m2QGW9CACGUemajuzJSsjqAOcnVH8+nN0X9Gf2z5Srt6/Pz21IVh2pwa+FP9HqX42SkYml+IQb2a4nE TN5WNQWGhzDrA/XN18oCuHdfd4O/ZJkwAzfJ0EqMsrFiFAC+Yi3+6FMahBz7aCV/Q6UnUPaOhucYZ3ZrFFC1n1FZj9wf6vuqsw67eu4y5a+PQ2mnP6HMbDSH E5xsrS7JqJmRG7eIjt0cJt0sTpOIS8heGcVUYiK/s8XlFW3b3CTd1KCaJ3FNcdYysR45qknJoFdBvguIkYTmiRp/js/y3g+NrhJZ3y9K5n6F+tGcvx8uKECh mfkLbaagIFG1o2AMXEJbpcjRs7OW0NQgEa58XvOMFOWicByCMoNfwIkNEXWHmLS/ZsE3JWcteS2o5xVwvwrJhGVNSbFJgVHBQLJYeRIncxK4O56sJ3pM7f6A hqnDgp09+rSA8OTzkWjgyIQXKon7VQDf02RMToDorF6lK9eyB19MKbEuXNC8f4wJUXIPRSCTGR7X/ZIsBy2hxuQe3nn8gFXOSbrssuXC/MyXTQ== X-Spam-Status: No, score=-1.9 required=5.0 tests=BAYES_00,DKIMWL_WL_MED, DKIM_SIGNED,DKIM_VALID,HEADER_FROM_DIFFERENT_DOMAINS, MAILING_LIST_MULTI,RDNS_NONE,SPF_HELO_NONE,T_SCC_BODY_TEXT_LINE autolearn=no autolearn_force=no version=3.4.6 X-Spam-Checker-Version: SpamAssassin 3.4.6 (2021-04-09) on lindbergh.monkeyblade.net Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Fixes: 9d71dd0 ("can: add support of SAE J1939 protocol") Signed-off-by: Devid Antonio Filoni --- net/can/j1939/transport.c | 55 +++++++++++++++++++++++++++++++-------- 1 file changed, 44 insertions(+), 11 deletions(-) diff --git a/net/can/j1939/transport.c b/net/can/j1939/transport.c index 030f5fe901e1..b8368f9c78c2 100644 --- a/net/can/j1939/transport.c +++ b/net/can/j1939/transport.c @@ -648,6 +648,7 @@ static int j1939_tp_tx_dat(struct j1939_session *session, } static int j1939_xtp_do_tx_ctl(struct j1939_priv *priv, + struct sock *re_sk, const struct j1939_sk_buff_cb *re_skcb, bool swap_src_dst, pgn_t pgn, const u8 *dat) { @@ -661,6 +662,8 @@ static int j1939_xtp_do_tx_ctl(struct j1939_priv *priv, if (IS_ERR(skb)) return PTR_ERR(skb); + can_skb_set_owner(skb, re_sk); + skdat = skb_put(skb, 8); memcpy(skdat, dat, 5); skdat[5] = (pgn >> 0); @@ -674,13 +677,26 @@ static inline int j1939_tp_tx_ctl(struct j1939_session *session, bool swap_src_dst, const u8 *dat) { struct j1939_priv *priv = session->priv; + struct sk_buff *se_skb = j1939_session_skb_get(session); + struct sock *se_skb_sk = NULL; + int ret; + + if (se_skb) + se_skb_sk = se_skb->sk; - return j1939_xtp_do_tx_ctl(priv, &session->skcb, - swap_src_dst, - session->skcb.addr.pgn, dat); + ret = j1939_xtp_do_tx_ctl(priv, se_skb_sk, &session->skcb, + swap_src_dst, + session->skcb.addr.pgn, dat); + + if (ret) + kfree_skb(se_skb); + else + consume_skb(se_skb); + return ret; } static int j1939_xtp_tx_abort(struct j1939_priv *priv, + struct sock *re_sk, const struct j1939_sk_buff_cb *re_skcb, bool swap_src_dst, enum j1939_xtp_abort err, @@ -694,7 +710,7 @@ static int j1939_xtp_tx_abort(struct j1939_priv *priv, memset(dat, 0xff, sizeof(dat)); dat[0] = J1939_TP_CMD_ABORT; dat[1] = err; - return j1939_xtp_do_tx_ctl(priv, re_skcb, swap_src_dst, pgn, dat); + return j1939_xtp_do_tx_ctl(priv, re_sk, re_skcb, swap_src_dst, pgn, dat); } void j1939_tp_schedule_txtimer(struct j1939_session *session, int msec) @@ -1117,6 +1133,8 @@ static void __j1939_session_cancel(struct j1939_session *session, enum j1939_xtp_abort err) { struct j1939_priv *priv = session->priv; + struct sk_buff *se_skb; + struct sock *se_skb_sk = NULL; WARN_ON_ONCE(!err); lockdep_assert_held(&session->priv->active_session_list_lock); @@ -1125,9 +1143,15 @@ static void __j1939_session_cancel(struct j1939_session *session, session->state = J1939_SESSION_WAITING_ABORT; /* do not send aborts on incoming broadcasts */ if (!j1939_cb_is_broadcast(&session->skcb)) { - j1939_xtp_tx_abort(priv, &session->skcb, - !session->transmission, - err, session->skcb.addr.pgn); + se_skb = j1939_session_skb_get(session); + if (se_skb) + se_skb_sk = se_skb->sk; + if (j1939_xtp_tx_abort(priv, se_skb_sk, &session->skcb, + !session->transmission, + err, session->skcb.addr.pgn)) + kfree_skb(se_skb); + else + consume_skb(se_skb); } if (session->sk) @@ -1274,6 +1298,8 @@ static bool j1939_xtp_rx_cmd_bad_pgn(struct j1939_session *session, const struct j1939_sk_buff_cb *skcb = j1939_skb_to_cb(skb); pgn_t pgn = j1939_xtp_ctl_to_pgn(skb->data); struct j1939_priv *priv = session->priv; + struct sk_buff *se_skb; + struct sock *se_skb_sk = NULL; enum j1939_xtp_abort abort = J1939_XTP_NO_ABORT; u8 cmd = skb->data[0]; @@ -1318,8 +1344,15 @@ static bool j1939_xtp_rx_cmd_bad_pgn(struct j1939_session *session, netdev_warn(priv->ndev, "%s: 0x%p: CMD 0x%02x with PGN 0x%05x for running session with different PGN 0x%05x.\n", __func__, session, cmd, pgn, session->skcb.addr.pgn); - if (abort != J1939_XTP_NO_ABORT) - j1939_xtp_tx_abort(priv, skcb, true, abort, pgn); + if (abort != J1939_XTP_NO_ABORT) { + se_skb = j1939_session_skb_get(session); + if (se_skb) + se_skb_sk = se_skb->sk; + if (j1939_xtp_tx_abort(priv, se_skb_sk, skcb, true, abort, pgn)) + kfree_skb(se_skb); + else + consume_skb(se_skb); + } return true; } @@ -1625,13 +1658,13 @@ j1939_session *j1939_xtp_rx_rts_session_new(struct j1939_priv *priv, } if (abort != J1939_XTP_NO_ABORT) { - j1939_xtp_tx_abort(priv, &skcb, true, abort, pgn); + j1939_xtp_tx_abort(priv, skb->sk, &skcb, true, abort, pgn); return NULL; } session = j1939_session_fresh_new(priv, len, &skcb); if (!session) { - j1939_xtp_tx_abort(priv, &skcb, true, + j1939_xtp_tx_abort(priv, skb->sk, &skcb, true, J1939_XTP_ABORT_RESOURCE, pgn); return NULL; } -- 2.25.1