Received: by 2002:a05:6a10:9e8c:0:0:0:0 with SMTP id y12csp2919126pxx; Sun, 1 Nov 2020 15:25:30 -0800 (PST) X-Google-Smtp-Source: ABdhPJx7q6UkoBhPd7MRsYpike3+y2G3Xj9I4IiyHQPKNPpxFI0BKbqBRb67hVrwcQWYI9AZfjy0 X-Received: by 2002:a50:ef0a:: with SMTP id m10mr13974420eds.116.1604273130035; Sun, 01 Nov 2020 15:25:30 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1604273130; cv=none; d=google.com; s=arc-20160816; b=Sjdaj0yo/PlrhjtyMHWDO2Qh1feFzvi2WLb7XLwDKxRQ25uGM47D7liXKKVUqdSOqD WxM75VlXmTyDSlapOXRKVq88h8EMfrl4iYODauZZxiBHSsMhhEHP8yP5ahHdE1vKKrfu 4biT+gBH8GMJqrMtX+DTLeoZnCukK/1H3wrael9T2zfJ3bcEx+lEcU2DVNmFjWVYXS9N BCIoJB/j41nz8xT3kn7SBQIiYGOh2dNvIDy6mvm2RwQjFnR9PtBlbjDY9Y1xfdw5t327 KPNJh8zIAi69qJSLoQMUtQwMdoNnu7XIPTpzuqjCP4149SD0e8B0MU3MGeLbudvn6kHE 0gwg== 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:dkim-signature :dkim-signature:from; bh=1JCFBfexZTaTxNTJc/bdU0DkFV3ialzSAY95hXbQ9KA=; b=mIIHpx/0fGRogi5PVjk6TDuxuon7xDlzxmurW2SZ1GM7t4U6zYT+en0mkkO0FOtfJZ ZmMsxtkEzohEChDftT2Tl4jOwkvUYUo2jO/B0fGASsgJs1Kjn3/rNDZTmZK3bScwHMR2 OQ/SEs5z77f2S6TxBhG8+L3VvleaiyWlW/L3q04bfEl3EkZ7BxqjKHRz/fgBym2eG+DL T1f8IRgG8rXfy72FHBZuzaiu9qycsmc68DuMS8t2rFwU8M65SFvOtb6VTyC3uF2juW/w zgz3iZKBfGRdCUJLVviIScj9UyHxFa8Q+1QOA5/RT03oAMeRlzgFog1gG+N7JQVYK/0e fabw== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@linutronix.de header.s=2020 header.b=iUViDm8N; dkim=neutral (no key) header.i=@linutronix.de header.b=24m4nSr5; spf=pass (google.com: domain of linux-crypto-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-crypto-owner@vger.kernel.org; dmarc=pass (p=NONE sp=QUARANTINE dis=NONE) header.from=linutronix.de Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id d16si3196049edx.296.2020.11.01.15.25.06; Sun, 01 Nov 2020 15:25:30 -0800 (PST) Received-SPF: pass (google.com: domain of linux-crypto-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) client-ip=23.128.96.18; Authentication-Results: mx.google.com; dkim=pass header.i=@linutronix.de header.s=2020 header.b=iUViDm8N; dkim=neutral (no key) header.i=@linutronix.de header.b=24m4nSr5; spf=pass (google.com: domain of linux-crypto-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-crypto-owner@vger.kernel.org; dmarc=pass (p=NONE sp=QUARANTINE dis=NONE) header.from=linutronix.de Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1727445AbgKAXXY (ORCPT + 99 others); Sun, 1 Nov 2020 18:23:24 -0500 Received: from Galois.linutronix.de ([193.142.43.55]:55398 "EHLO galois.linutronix.de" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1727322AbgKAXXW (ORCPT ); Sun, 1 Nov 2020 18:23:22 -0500 From: Sebastian Andrzej Siewior DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=linutronix.de; s=2020; t=1604272999; 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=1JCFBfexZTaTxNTJc/bdU0DkFV3ialzSAY95hXbQ9KA=; b=iUViDm8NvlIWcJSV36zfgPtmec6C8UofAUybKpXMq0+4u1mAdzCAp0Wt64uviukSsd5VOb zPfRieYKxNwIni3RPTGF+hT6wZYqTrAFFXJmiaFm0gNsNnZoXC+VCIRZ9SIiLN1NTEu/Qf LCrqn77SiTmUnx+ehl2EQjnbgDxHCa8MSxA1sYBVB+E8T/OslzjeuFdh0W46rv8fTJjUKB GJAZ12Gb+o/5DK6N2dp4/4itmTXhaHZDIBOBR9E/hOr+UMAIaqAb+T29xJ+G5SWaNwEiZI INLgqeAaMH9VcrHjoC/GmGzmDlkJMrdoOAReRH6dqYG68JsP8ER3GCwIDnjAVQ== DKIM-Signature: v=1; a=ed25519-sha256; c=relaxed/relaxed; d=linutronix.de; s=2020e; t=1604272999; 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=1JCFBfexZTaTxNTJc/bdU0DkFV3ialzSAY95hXbQ9KA=; b=24m4nSr5As29K9Az1qCoaLo2NV+Umtfhb0UjgQX17Y8Dl3GP0N35SLzhCUHME7cTXqQKnj IE/zY44MlDEqtdDA== To: netdev@vger.kernel.org Cc: =?UTF-8?q?Horia=20Geant=C4=83?= , Aymen Sghaier , Herbert Xu , "David S. Miller" , Madalin Bucur , Jakub Kicinski , Li Yang , Thomas Gleixner , Sebastian Andrzej Siewior , linux-crypto@vger.kernel.org, linuxppc-dev@lists.ozlabs.org, linux-arm-kernel@lists.infradead.org Subject: [PATCH v2 net-next 3/3] crypto: caam: Replace in_irq() usage. Date: Mon, 2 Nov 2020 00:22:57 +0100 Message-Id: <20201101232257.3028508-4-bigeasy@linutronix.de> In-Reply-To: <20201101232257.3028508-1-bigeasy@linutronix.de> References: <20201101232257.3028508-1-bigeasy@linutronix.de> MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: quoted-printable Precedence: bulk List-ID: X-Mailing-List: linux-crypto@vger.kernel.org The driver uses in_irq() + in_serving_softirq() magic to decide if NAPI scheduling is required or packet processing. The usage of in_*() in drivers is phased out and Linus clearly requested that code which changes behaviour depending on context should either be separated or the context be conveyed in an argument passed by the caller, which usually knows the context. Use the `sched_napi' argument passed by the callback. It is set true if called from the interrupt handler and NAPI should be scheduled. Signed-off-by: Sebastian Andrzej Siewior Cc: "Horia Geant=C4=83" Cc: Aymen Sghaier Cc: Herbert Xu Cc: "David S. Miller" Cc: Madalin Bucur Cc: Jakub Kicinski Cc: Li Yang Cc: linux-crypto@vger.kernel.org Cc: netdev@vger.kernel.org Cc: linuxppc-dev@lists.ozlabs.org Cc: linux-arm-kernel@lists.infradead.org --- drivers/crypto/caam/qi.c | 12 ++++-------- 1 file changed, 4 insertions(+), 8 deletions(-) diff --git a/drivers/crypto/caam/qi.c b/drivers/crypto/caam/qi.c index 57f6ab6bfb56a..8163f5df8ebf7 100644 --- a/drivers/crypto/caam/qi.c +++ b/drivers/crypto/caam/qi.c @@ -545,14 +545,10 @@ static void cgr_cb(struct qman_portal *qm, struct qma= n_cgr *cgr, int congested) } } =20 -static int caam_qi_napi_schedule(struct qman_portal *p, struct caam_napi *= np) +static int caam_qi_napi_schedule(struct qman_portal *p, struct caam_napi *= np, + bool sched_napi) { - /* - * In case of threaded ISR, for RT kernels in_irq() does not return - * appropriate value, so use in_serving_softirq to distinguish between - * softirq and irq contexts. - */ - if (unlikely(in_irq() || !in_serving_softirq())) { + if (sched_napi) { /* Disable QMan IRQ source and invoke NAPI */ qman_p_irqsource_remove(p, QM_PIRQ_DQRI); np->p =3D p; @@ -574,7 +570,7 @@ static enum qman_cb_dqrr_result caam_rsp_fq_dqrr_cb(str= uct qman_portal *p, struct caam_drv_private *priv =3D dev_get_drvdata(qidev); u32 status; =20 - if (caam_qi_napi_schedule(p, caam_napi)) + if (caam_qi_napi_schedule(p, caam_napi, sched_napi)) return qman_cb_dqrr_stop; =20 fd =3D &dqrr->fd; --=20 2.29.1