Received: by 2002:a05:7412:419a:b0:f3:1519:9f41 with SMTP id i26csp262749rdh; Thu, 23 Nov 2023 03:27:23 -0800 (PST) X-Google-Smtp-Source: AGHT+IE4/DT8ZroEIpI2ZUC/9ci7egVKdaXMh7n0eYmaUXTEOJVS+XPChZz5pyR79w/uBGvNCP0m X-Received: by 2002:a05:6a20:2447:b0:188:e223:961c with SMTP id t7-20020a056a20244700b00188e223961cmr5372201pzc.59.1700738842663; Thu, 23 Nov 2023 03:27:22 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1700738842; cv=none; d=google.com; s=arc-20160816; b=d5rCtt57dY1hHjNVxx9cmn080lO9Z81fNRLbFpJeFYW7PuhlSvMN8qvZtfNtFe+ZiJ 0woqnIkN989BwepEDf+Rp1TWA55IrD3cF7KDHiFZGvlNlcOFRpokt/3+QP4JWfrzvViq NWGSgHpcYQkTaH2Cn5SYSILSmmtWShT8u4M9+SxrwjFCoULpmuMmEzmM11Qbb+y+sgdI jkfMj4vSBJiAwk0xeY/TFdjvT9zEWNtLAqyDRpqo67xwoYFb4vtJzOUsoDldOWCiWwUe 22CYl3cBhsdzDLKDQ257ZXWrVJcvxqTVURw+wMf0fNtHBEc8wCUVZtPIeqKOmdfPvbPe lANQ== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:mime-version:user-agent :content-transfer-encoding:references:in-reply-to:date:cc:to:from :subject:message-id:dkim-signature; bh=eFq+BEnbZxFqfaT3CQSP/UqcZPRY8UI20FDoLhF4BDY=; fh=+0Fond1Dc8+jA3NhViuh3TxbJ/XCjS4RLpvcSsxKs1s=; b=kNSCzLpxkaBMiVdPupskyzC5hzhideJSENm7tqdPUR2m6ox+wYKt4izwOZMkMdO5gM TBcdPkg1gAahy2jCFWgkCBYLD4kF6y0wz9Im8Q0o8I5VQRo55gFAJ2eQQ7VsyWEeX+KJ aTrD3y3ZcGUmNJp7/IvEpIkgfP/F1OHzK8aq1zskHw8Y7l4vDULYAv8C1wRfVWXl1Y/4 LPgZXB+eAdS9KkB2GwL0wl38AHxEdfSZTBBDZEdwtjYg8dQWqHZX7HdN24vMqoQykmx4 y/z4aAZTkLztnmiSDT53XeG9hXEiYKu4nSpq95/QL6SfPU0jyuF7m7X3NEGNPF0+eTQB vNHQ== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@redhat.com header.s=mimecast20190719 header.b=U+wxMOnR; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.38 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=redhat.com Return-Path: Received: from fry.vger.email (fry.vger.email. [23.128.96.38]) by mx.google.com with ESMTPS id cm5-20020a17090afa0500b002800fffeb61si1635716pjb.5.2023.11.23.03.27.22 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Thu, 23 Nov 2023 03:27:22 -0800 (PST) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.38 as permitted sender) client-ip=23.128.96.38; Authentication-Results: mx.google.com; dkim=pass header.i=@redhat.com header.s=mimecast20190719 header.b=U+wxMOnR; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.38 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=redhat.com Received: from out1.vger.email (depot.vger.email [IPv6:2620:137:e000::3:0]) by fry.vger.email (Postfix) with ESMTP id 0C7558382314; Thu, 23 Nov 2023 03:27:20 -0800 (PST) X-Virus-Status: Clean X-Virus-Scanned: clamav-milter 0.103.11 at fry.vger.email Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1345039AbjKWL06 (ORCPT + 99 others); Thu, 23 Nov 2023 06:26:58 -0500 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:40680 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1345069AbjKWL0y (ORCPT ); Thu, 23 Nov 2023 06:26:54 -0500 Received: from us-smtp-delivery-124.mimecast.com (us-smtp-delivery-124.mimecast.com [170.10.129.124]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id AFC65D7D for ; Thu, 23 Nov 2023 03:26:58 -0800 (PST) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=redhat.com; s=mimecast20190719; t=1700738817; h=from:from:reply-to:subject:subject:date:date:message-id:message-id: to:to:cc:cc:mime-version:mime-version:content-type:content-type: content-transfer-encoding:content-transfer-encoding: in-reply-to:in-reply-to:references:references; bh=eFq+BEnbZxFqfaT3CQSP/UqcZPRY8UI20FDoLhF4BDY=; b=U+wxMOnRV8Da0pw7a1ofpqaId2euhZFwR/vnCiJCVH30jZ9g0+P55IKxVClthGuDhyTy4Y teJ0Z5+ls/OXt0zkhGx1IOQYUWZuB7JuIs/G6TxhTUiVUBj9OjwPa9f+mjW1N5F1q0qqWl qeXrNYmQJEocZGY7BWoqrUt7Ah2g4UQ= Received: from mail-ej1-f70.google.com (mail-ej1-f70.google.com [209.85.218.70]) by relay.mimecast.com with ESMTP with STARTTLS (version=TLSv1.3, cipher=TLS_AES_256_GCM_SHA384) id us-mta-619-SFqZnqLgO1mc-JxxuPn-KA-1; Thu, 23 Nov 2023 06:26:56 -0500 X-MC-Unique: SFqZnqLgO1mc-JxxuPn-KA-1 Received: by mail-ej1-f70.google.com with SMTP id a640c23a62f3a-a0627211f11so10639066b.1 for ; Thu, 23 Nov 2023 03:26:56 -0800 (PST) X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20230601; t=1700738815; x=1701343615; h=mime-version:user-agent:content-transfer-encoding:references :in-reply-to:date:cc:to:from:subject:message-id:x-gm-message-state :from:to:cc:subject:date:message-id:reply-to; bh=eFq+BEnbZxFqfaT3CQSP/UqcZPRY8UI20FDoLhF4BDY=; b=aRGQUPtetk/Pbx/dTUPV+7/Jg5Bp8QgFGO4KqXwvs7APupVy9cZV8UunzFQ+riehiZ UJAVtupv+XDFjeIm4gqnDXGIimFMche6ufgwmGAUw1BDn5Mi7IVu42EHn73rw/00IK6/ GBBWSZiWW4Q+XpIkRIrgsQ5Yp7265L1ddZ+Eer4zhcczCDYKbh3aNsis5vPN9gEiyOl7 1VDY8Vg+93h9voswDc1SM2udgMuBGEUDOt6h6Wi+z/QG432pdAL/fpDyMu8tSryZiHgI xfGNN8SDQHq8aTVygn5EWvn5pXaXJ7dWTFJ3f6iUOfxARD8s52cVanfWx/3mSJmrtphF uQ9g== X-Gm-Message-State: AOJu0YwhXer5Iikd+vaTYwVuUZfbwhsMx2hr5BgweXSNPanCdzSspViF XH/FmAyHFplWG/AJr7jlq/zTDiSo0Mm7gAJI1d94SaPR5HNQrf29eESS1oVJSV4/ioFfA+giSpU i4MkM1V7N4RmM+1idwgSQVLSE8Ox8N42l X-Received: by 2002:a17:906:74ca:b0:9dd:5609:55b9 with SMTP id z10-20020a17090674ca00b009dd560955b9mr3755032ejl.2.1700738815109; Thu, 23 Nov 2023 03:26:55 -0800 (PST) X-Received: by 2002:a17:906:74ca:b0:9dd:5609:55b9 with SMTP id z10-20020a17090674ca00b009dd560955b9mr3755014ejl.2.1700738814760; Thu, 23 Nov 2023 03:26:54 -0800 (PST) Received: from gerbillo.redhat.com (146-241-241-213.dyn.eolo.it. [146.241.241.213]) by smtp.gmail.com with ESMTPSA id fy21-20020a170906b7d500b009e603786444sm665877ejb.90.2023.11.23.03.26.53 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Thu, 23 Nov 2023 03:26:54 -0800 (PST) Message-ID: <5327988fc5d02f3352be66b5f0a2ca9a468ef1da.camel@redhat.com> Subject: Re: [PATCH 1/4 net] qca_spi: Fix SPI thread creation From: Paolo Abeni To: Stefan Wahren , "David S. Miller" , Eric Dumazet , Jakub Kicinski Cc: Lino Sanfilippo , Florian Fainelli , netdev@vger.kernel.org, linux-kernel@vger.kernel.org Date: Thu, 23 Nov 2023 12:26:53 +0100 In-Reply-To: <20231121163004.21232-2-wahrenst@gmx.net> References: <20231121163004.21232-1-wahrenst@gmx.net> <20231121163004.21232-2-wahrenst@gmx.net> Content-Type: text/plain; charset="UTF-8" Content-Transfer-Encoding: quoted-printable User-Agent: Evolution 3.46.4 (3.46.4-1.fc37) MIME-Version: 1.0 X-Spam-Status: No, score=-0.9 required=5.0 tests=DKIMWL_WL_HIGH,DKIM_SIGNED, DKIM_VALID,DKIM_VALID_AU,HEADER_FROM_DIFFERENT_DOMAINS, MAILING_LIST_MULTI,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 fry.vger.email Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org X-Greylist: Sender passed SPF test, not delayed by milter-greylist-4.6.4 (fry.vger.email [0.0.0.0]); Thu, 23 Nov 2023 03:27:20 -0800 (PST) On Tue, 2023-11-21 at 17:30 +0100, Stefan Wahren wrote: > The qca_spi driver create/stop the SPI kernel thread in case > of netdev_open/close. This is a big issue because it allows > userspace to prevent from restarting the SPI thread after > ring parameter changes (e.g. signals which stop the thread). > This could be done by terminating a script which changes > the ring parameter in a loop. >=20 > So fix this by moving create/stop of the SPI kernel into > the init/uninit ops. The open/close ops could be realized just > by 'park/unpark' the SPI kernel thread. >=20 > Fixes: 291ab06ecf67 ("net: qualcomm: new Ethernet over SPI driver for QCA= 7000") > Signed-off-by: Stefan Wahren > --- > drivers/net/ethernet/qualcomm/qca_spi.c | 35 ++++++++++++++++--------- > 1 file changed, 23 insertions(+), 12 deletions(-) >=20 > diff --git a/drivers/net/ethernet/qualcomm/qca_spi.c b/drivers/net/ethern= et/qualcomm/qca_spi.c > index bec723028e96..b11a998b2456 100644 > --- a/drivers/net/ethernet/qualcomm/qca_spi.c > +++ b/drivers/net/ethernet/qualcomm/qca_spi.c > @@ -580,6 +580,11 @@ qcaspi_spi_thread(void *data) > netdev_info(qca->net_dev, "SPI thread created\n"); > while (!kthread_should_stop()) { > set_current_state(TASK_INTERRUPTIBLE); > + if (kthread_should_park()) { > + kthread_parkme(); > + continue; > + } > + > if ((qca->intr_req =3D=3D qca->intr_svc) && > !qca->txr.skb[qca->txr.head]) > schedule(); > @@ -679,25 +684,17 @@ qcaspi_netdev_open(struct net_device *dev) > qca->sync =3D QCASPI_SYNC_UNKNOWN; > qcafrm_fsm_init_spi(&qca->frm_handle); >=20 > - qca->spi_thread =3D kthread_run((void *)qcaspi_spi_thread, > - qca, "%s", dev->name); > - > - if (IS_ERR(qca->spi_thread)) { > - netdev_err(dev, "%s: unable to start kernel thread.\n", > - QCASPI_DRV_NAME); > - return PTR_ERR(qca->spi_thread); > - } > - > ret =3D request_irq(qca->spi_dev->irq, qcaspi_intr_handler, 0, > dev->name, qca); > if (ret) { > netdev_err(dev, "%s: unable to get IRQ %d (irqval=3D%d).\n", > QCASPI_DRV_NAME, qca->spi_dev->irq, ret); > - kthread_stop(qca->spi_thread); > return ret; > } >=20 > /* SPI thread takes care of TX queue */ > + kthread_unpark(qca->spi_thread); > + wake_up_process(qca->spi_thread); The above looks racy: after 'request_irq()' the interrupt handler can raise an irq before the thread being unparked. Additionally I think you can drop the 'if (qca->spi_thread)' in qcaspi_intr_handler() Cheers, Paolo