Received: by 2002:a5d:9c59:0:0:0:0:0 with SMTP id 25csp1742789iof; Tue, 7 Jun 2022 10:37:27 -0700 (PDT) X-Google-Smtp-Source: ABdhPJxbxmG9m4oJlZl4t/x5rgoXliILmtVyCXZf44Zgubxgk+zI2ZWpB+1Q3BdgAnsEcb77PawJ X-Received: by 2002:a17:907:2d86:b0:711:da8b:b579 with SMTP id gt6-20020a1709072d8600b00711da8bb579mr7404088ejc.67.1654623447513; Tue, 07 Jun 2022 10:37:27 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1654623447; cv=none; d=google.com; s=arc-20160816; b=i8IHtOI4roLvRPMb3jzv5Q5voIroyM/hAQi1WARR7CXV8a8+gwq+9IRfZzNCWMQf/c Y+SahGQFFj1+oFgRocptBGJ5hX+m0zJ4WzIYVyRl7MSSikt0yBgc1Tuiy5U7iy8BxZVA YkyEWoSRJNTnTOmyxyekHO9lDd/C9VGanWiO7g0YMWTnZWFRLnI1E+w7mADXO2hxaCsd N1ZSg1M6yb/5aGtQy2PzVqsKu319D2eIdlMJ7IoZ86iPCU6Gdu41YyGekYdVv9jtpACH dx5yYlCi/QpEF3xqEijGxXUiDe9GjmHMciZCdjr9lS7WLk1DE5fiYzaupbaKYzrhu+0A o28g== 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=4002ZoQbfZgD0XX9YDZ6wPiQ9rsbL1Ku9Z7hWp9EhXQ=; b=rTwVOfi85iCyQG20LZvJqWkc1xu8u6w3J1ss7UPdGEyO7Uj4ZIXf0LM/raVy5M8+pd qXRRVDkeOloJUcJeuEcb/tjgNG/fqrpBk7adkglq6EyeYDUT9HE7aMy9p8h+0zB8+sjm Dy3Z85p+SeuK5cO4R6Yl+lqA8GTQYE21MLC3pimEFUeUqwrPuSKwdutyg2sS0uXEFDUr suU64NjS2UCdZ6ZjYVL/gpWXPF5ENz2neG6m1tGOK0SiXhhu1nRve3/qKXElvTUfIhno wJcX2tUzA6Jeh1rveK90jCCCvhDwvdjaBM7hdQhfRpV1EDoqwKkRbrWnbW5B9ok7lDma iLuw== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@amarulasolutions.com header.s=google header.b="jnJyM9v/"; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=amarulasolutions.com Return-Path: Received: from out1.vger.email (out1.vger.email. [2620:137:e000::1:20]) by mx.google.com with ESMTP id dm22-20020a170907949600b00709627395e8si18443583ejc.623.2022.06.07.10.37.00; Tue, 07 Jun 2022 10:37:27 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) client-ip=2620:137:e000::1:20; Authentication-Results: mx.google.com; dkim=pass header.i=@amarulasolutions.com header.s=google header.b="jnJyM9v/"; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=amarulasolutions.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S234517AbiFGJtU (ORCPT + 99 others); Tue, 7 Jun 2022 05:49:20 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:38214 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S240056AbiFGJsX (ORCPT ); Tue, 7 Jun 2022 05:48:23 -0400 Received: from mail-wr1-x434.google.com (mail-wr1-x434.google.com [IPv6:2a00:1450:4864:20::434]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 75C1CE52B4 for ; Tue, 7 Jun 2022 02:48:22 -0700 (PDT) Received: by mail-wr1-x434.google.com with SMTP id k16so23357733wrg.7 for ; Tue, 07 Jun 2022 02:48:22 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=amarulasolutions.com; s=google; h=from:to:cc:subject:date:message-id:in-reply-to:references :mime-version:content-transfer-encoding; bh=4002ZoQbfZgD0XX9YDZ6wPiQ9rsbL1Ku9Z7hWp9EhXQ=; b=jnJyM9v/kBy9PKMgM/nNI5Iy1Hw1MRy8KxtNeBQYHruTG9NV6j4BsTckaQZJI9/sYz app9i/gkaIzMR/+yp3eoYX5eNeQ+e1r1yoZkzbPrdHgvIaHPZ/UUcIjdy1LjjSyR6Qkg XHUzjidNt5YCE5O730FZmHE/IXwd+j10Abs7k= X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20210112; h=x-gm-message-state:from:to:cc:subject:date:message-id:in-reply-to :references:mime-version:content-transfer-encoding; bh=4002ZoQbfZgD0XX9YDZ6wPiQ9rsbL1Ku9Z7hWp9EhXQ=; b=TOfvL1PPPXgX0FUoaI7J83ogW8MjzoC5YI7V3F+tpIOVvnUU8TK5wpZ0mRnA111Pbz eBrgcj4MNy/RP3/h9ssLvMTrzDyL0IpecJoi6i+MZvMC78uUcb3rD+ebsiU1UyNZXP8f ljriuozByPkmLLM4C8CpUQ2jPl1oRy31NYQpYZPoZ2SDIGpr5Il3anc9Rk7wtdkqyv/q 9RJW4NemIl2Oh7HLhMS6TUsRf05EmEUvAlFB45ePPmUdAE4tGK+eeIzfzbAvg95PG2FG ki+Zg1nvKOSoK/eFZGZwR+hKBLB+nLPM9LUkpzzY4p5OQ1BYyjTLwh36CMeCAV3gTd06 dT7Q== X-Gm-Message-State: AOAM531wREfzevYtD3mPwnFaaf/IMixQ6LVzIkXukcpLXqTytErPrt2c M4iF3lpyLfAZzKl9sgz4FAOtDJNli+l4tQ== X-Received: by 2002:adf:fb05:0:b0:20a:e113:8f3f with SMTP id c5-20020adffb05000000b0020ae1138f3fmr26424039wrr.534.1654595301578; Tue, 07 Jun 2022 02:48:21 -0700 (PDT) Received: from dario-ThinkPad-T14s-Gen-2i.pdxnet.pdxeng.ch (mob-5-90-137-51.net.vodafone.it. [5.90.137.51]) by smtp.gmail.com with ESMTPSA id o4-20020a05600c510400b0039748be12dbsm23200547wms.47.2022.06.07.02.48.19 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Tue, 07 Jun 2022 02:48:20 -0700 (PDT) From: Dario Binacchi To: linux-kernel@vger.kernel.org Cc: Amarula patchwork , michael@amarulasolutions.com, Dario Binacchi , "David S. Miller" , Eric Dumazet , Jakub Kicinski , Marc Kleine-Budde , Paolo Abeni , Wolfgang Grandegger , linux-can@vger.kernel.org, netdev@vger.kernel.org Subject: [RFC PATCH 06/13] can: slcan: allow to send commands to the adapter Date: Tue, 7 Jun 2022 11:47:45 +0200 Message-Id: <20220607094752.1029295-7-dario.binacchi@amarulasolutions.com> X-Mailer: git-send-email 2.32.0 In-Reply-To: <20220607094752.1029295-1-dario.binacchi@amarulasolutions.com> References: <20220607094752.1029295-1-dario.binacchi@amarulasolutions.com> MIME-Version: 1.0 Content-Transfer-Encoding: 8bit X-Spam-Status: No, score=-2.1 required=5.0 tests=BAYES_00,DKIM_SIGNED, DKIM_VALID,DKIM_VALID_AU,DKIM_VALID_EF,RCVD_IN_DNSWL_NONE, SPF_HELO_NONE,SPF_PASS,T_SCC_BODY_TEXT_LINE autolearn=unavailable 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 This is a preparation patch for the upcoming support to change the bitrate via ip tool, reset the adapter error states via the ethtool API and, more generally, send commands to the adapter. Since some commands (e. g. setting the bitrate) will be sent before calling the open_candev(), the netif_running() will return false and so a new flag bit (i. e. SLF_XCMD) for serial transmission has to be added. Signed-off-by: Dario Binacchi --- drivers/net/can/slcan.c | 46 ++++++++++++++++++++++++++++++++++++++++- 1 file changed, 45 insertions(+), 1 deletion(-) diff --git a/drivers/net/can/slcan.c b/drivers/net/can/slcan.c index 4df0455e11a2..dbd4ebdfa024 100644 --- a/drivers/net/can/slcan.c +++ b/drivers/net/can/slcan.c @@ -97,6 +97,9 @@ struct slcan { unsigned long flags; /* Flag values/ mode etc */ #define SLF_INUSE 0 /* Channel in use */ #define SLF_ERROR 1 /* Parity, etc. error */ +#define SLF_XCMD 2 /* Command transmission */ + wait_queue_head_t xcmd_wait; /* Wait queue for commands */ + /* transmission */ }; static struct net_device **slcan_devs; @@ -310,12 +313,22 @@ static void slcan_transmit(struct work_struct *work) spin_lock_bh(&sl->lock); /* First make sure we're connected. */ - if (!sl->tty || sl->magic != SLCAN_MAGIC || !netif_running(sl->dev)) { + if (!sl->tty || sl->magic != SLCAN_MAGIC || + (unlikely(!netif_running(sl->dev)) && + likely(!test_bit(SLF_XCMD, &sl->flags)))) { spin_unlock_bh(&sl->lock); return; } if (sl->xleft <= 0) { + if (unlikely(test_bit(SLF_XCMD, &sl->flags))) { + clear_bit(SLF_XCMD, &sl->flags); + clear_bit(TTY_DO_WRITE_WAKEUP, &sl->tty->flags); + spin_unlock_bh(&sl->lock); + wake_up(&sl->xcmd_wait); + return; + } + /* Now serial buffer is almost free & we can start * transmission of another packet */ sl->dev->stats.tx_packets++; @@ -379,6 +392,36 @@ static netdev_tx_t slc_xmit(struct sk_buff *skb, struct net_device *dev) * Routines looking at netdevice side. ******************************************/ +static int slcan_transmit_cmd(struct slcan *sl, const unsigned char *cmd) +{ + int ret, actual, n; + + spin_lock(&sl->lock); + if (sl->tty == NULL) { + spin_unlock(&sl->lock); + return -ENODEV; + } + + n = snprintf(sl->xbuff, sizeof(sl->xbuff), "%s", cmd); + set_bit(TTY_DO_WRITE_WAKEUP, &sl->tty->flags); + actual = sl->tty->ops->write(sl->tty, sl->xbuff, n); + sl->xleft = n - actual; + sl->xhead = sl->xbuff + actual; + set_bit(SLF_XCMD, &sl->flags); + spin_unlock(&sl->lock); + ret = wait_event_interruptible_timeout(sl->xcmd_wait, + !test_bit(SLF_XCMD, &sl->flags), + HZ); + clear_bit(SLF_XCMD, &sl->flags); + if (ret == -ERESTARTSYS) + return ret; + + if (ret == 0) + return -ETIMEDOUT; + + return 0; +} + /* Netdevice UP -> DOWN routine */ static int slc_close(struct net_device *dev) { @@ -542,6 +585,7 @@ static struct slcan *slc_alloc(void) sl->dev = dev; spin_lock_init(&sl->lock); INIT_WORK(&sl->tx_work, slcan_transmit); + init_waitqueue_head(&sl->xcmd_wait); slcan_devs[i] = dev; return sl; -- 2.32.0