From: neil.armstrong@linaro.org
To: Alexey Romanov <avromanov@salutedevices.com>,
narmstrong@baylibre.com, clabbe@baylibre.com,
herbert@gondor.apana.org.au, davem@davemloft.net,
robh+dt@kernel.org, krzysztof.kozlowski+dt@linaro.org,
conor+dt@kernel.org, khilman@baylibre.com, jbrunet@baylibre.com,
artin.blumenstingl@googlemail.com
Cc: linux-crypto@vger.kernel.org, linux-amlogic@lists.infradead.org,
linux-kernel@vger.kernel.org, devicetree@vger.kernel.org,
linux-arm-kernel@lists.infradead.org, kernel@salutedevices.com,
Jan Dakinevich <yvdakinevich@salutedevices.com>
Subject: Re: [PATCH v1 01/24] drivers: crypto: meson: don't hardcode IRQ count
Date: Thu, 11 Jan 2024 09:21:43 +0100 [thread overview]
Message-ID: <1a3b5004-751a-4479-be89-97265ca63d92@linaro.org> (raw)
In-Reply-To: <20240110201216.18016-2-avromanov@salutedevices.com>
On 10/01/2024 21:11, Alexey Romanov wrote:
> IRQ count is no longer hardcoded, and make it part of
> struct meson_flow. We need this for extend driver support for
> other Amlogic SoC's.
In this case you must make the interrupts maxItems lower for the new platforms in the bindings.
Neil
>
> Signed-off-by: Alexey Romanov <avromanov@salutedevices.com>
> Signed-off-by: Jan Dakinevich <yvdakinevich@salutedevices.com>
> ---
> drivers/crypto/amlogic/amlogic-gxl-cipher.c | 2 +-
> drivers/crypto/amlogic/amlogic-gxl-core.c | 47 ++++++++++++---------
> drivers/crypto/amlogic/amlogic-gxl.h | 8 ++--
> 3 files changed, 31 insertions(+), 26 deletions(-)
>
> diff --git a/drivers/crypto/amlogic/amlogic-gxl-cipher.c b/drivers/crypto/amlogic/amlogic-gxl-cipher.c
> index af017a087ebf..e01ed6347c3d 100644
> --- a/drivers/crypto/amlogic/amlogic-gxl-cipher.c
> +++ b/drivers/crypto/amlogic/amlogic-gxl-cipher.c
> @@ -19,7 +19,7 @@
>
> static int get_engine_number(struct meson_dev *mc)
> {
> - return atomic_inc_return(&mc->flow) % MAXFLOW;
> + return atomic_inc_return(&mc->flow) % mc->flow_cnt;
> }
>
> static bool meson_cipher_need_fallback(struct skcipher_request *areq)
> diff --git a/drivers/crypto/amlogic/amlogic-gxl-core.c b/drivers/crypto/amlogic/amlogic-gxl-core.c
> index 937187027ad5..a5df061f9890 100644
> --- a/drivers/crypto/amlogic/amlogic-gxl-core.c
> +++ b/drivers/crypto/amlogic/amlogic-gxl-core.c
> @@ -26,8 +26,8 @@ static irqreturn_t meson_irq_handler(int irq, void *data)
> int flow;
> u32 p;
>
> - for (flow = 0; flow < MAXFLOW; flow++) {
> - if (mc->irqs[flow] == irq) {
> + for (flow = 0; flow < mc->flow_cnt; flow++) {
> + if (mc->chanlist[flow].irq == irq) {
> p = readl(mc->base + ((0x04 + flow) << 2));
> if (p) {
> writel_relaxed(0xF, mc->base + ((0x4 + flow) << 2));
> @@ -103,7 +103,7 @@ static int meson_debugfs_show(struct seq_file *seq, void *v)
> struct meson_dev *mc = seq->private;
> int i;
>
> - for (i = 0; i < MAXFLOW; i++)
> + for (i = 0; i < mc->flow_cnt; i++)
> seq_printf(seq, "Channel %d: nreq %lu\n", i, mc->chanlist[i].stat_req);
>
> for (i = 0; i < ARRAY_SIZE(mc_algs); i++) {
> @@ -138,14 +138,32 @@ static void meson_free_chanlist(struct meson_dev *mc, int i)
> */
> static int meson_allocate_chanlist(struct meson_dev *mc)
> {
> + struct platform_device *pdev = to_platform_device(mc->dev);
> int i, err;
>
> - mc->chanlist = devm_kcalloc(mc->dev, MAXFLOW,
> + mc->flow_cnt = platform_irq_count(pdev);
> + if (mc->flow_cnt <= 0) {
> + dev_err(mc->dev, "No IRQs defined\n");
> + return -ENODEV;
> + }
> +
> + mc->chanlist = devm_kcalloc(mc->dev, mc->flow_cnt,
> sizeof(struct meson_flow), GFP_KERNEL);
> if (!mc->chanlist)
> return -ENOMEM;
>
> - for (i = 0; i < MAXFLOW; i++) {
> + for (i = 0; i < mc->flow_cnt; i++) {
> + mc->chanlist[i].irq = platform_get_irq(pdev, i);
> + if (mc->chanlist[i].irq < 0)
> + return mc->chanlist[i].irq;
> +
> + err = devm_request_irq(mc->dev, mc->chanlist[i].irq,
> + meson_irq_handler, 0, "aml-crypto", mc);
> + if (err < 0) {
> + dev_err(mc->dev, "Cannot request IRQ for flow %d\n", i);
> + return err;
> + }
> +
> init_completion(&mc->chanlist[i].complete);
>
> mc->chanlist[i].engine = crypto_engine_alloc_init(mc->dev, true);
> @@ -215,7 +233,7 @@ static void meson_unregister_algs(struct meson_dev *mc)
> static int meson_crypto_probe(struct platform_device *pdev)
> {
> struct meson_dev *mc;
> - int err, i;
> + int err;
>
> mc = devm_kzalloc(&pdev->dev, sizeof(*mc), GFP_KERNEL);
> if (!mc)
> @@ -237,19 +255,6 @@ static int meson_crypto_probe(struct platform_device *pdev)
> return err;
> }
>
> - for (i = 0; i < MAXFLOW; i++) {
> - mc->irqs[i] = platform_get_irq(pdev, i);
> - if (mc->irqs[i] < 0)
> - return mc->irqs[i];
> -
> - err = devm_request_irq(&pdev->dev, mc->irqs[i], meson_irq_handler, 0,
> - "gxl-crypto", mc);
> - if (err < 0) {
> - dev_err(mc->dev, "Cannot request IRQ for flow %d\n", i);
> - return err;
> - }
> - }
> -
> err = clk_prepare_enable(mc->busclk);
> if (err != 0) {
> dev_err(&pdev->dev, "Cannot prepare_enable busclk\n");
> @@ -273,7 +278,7 @@ static int meson_crypto_probe(struct platform_device *pdev)
> error_alg:
> meson_unregister_algs(mc);
> error_flow:
> - meson_free_chanlist(mc, MAXFLOW - 1);
> + meson_free_chanlist(mc, mc->flow_cnt - 1);
> clk_disable_unprepare(mc->busclk);
> return err;
> }
> @@ -288,7 +293,7 @@ static int meson_crypto_remove(struct platform_device *pdev)
>
> meson_unregister_algs(mc);
>
> - meson_free_chanlist(mc, MAXFLOW - 1);
> + meson_free_chanlist(mc, mc->flow_cnt - 1);
>
> clk_disable_unprepare(mc->busclk);
> return 0;
> diff --git a/drivers/crypto/amlogic/amlogic-gxl.h b/drivers/crypto/amlogic/amlogic-gxl.h
> index 8c0746a1d6d4..e5cc6e028fa8 100644
> --- a/drivers/crypto/amlogic/amlogic-gxl.h
> +++ b/drivers/crypto/amlogic/amlogic-gxl.h
> @@ -22,8 +22,6 @@
> #define MESON_OPMODE_ECB 0
> #define MESON_OPMODE_CBC 1
>
> -#define MAXFLOW 2
> -
> #define MAXDESC 64
>
> #define DESC_LAST BIT(18)
> @@ -62,6 +60,7 @@ struct meson_desc {
> * @keylen: keylen for this flow operation
> * @complete: completion for the current task on this flow
> * @status: set to 1 by interrupt if task is done
> + * @irq: IRQ number for amlogic-crypto
> * @t_phy: Physical address of task
> * @tl: pointer to the current ce_task for this flow
> * @stat_req: number of request done by this flow
> @@ -70,6 +69,7 @@ struct meson_flow {
> struct crypto_engine *engine;
> struct completion complete;
> int status;
> + int irq;
> unsigned int keylen;
> dma_addr_t t_phy;
> struct meson_desc *tl;
> @@ -85,7 +85,7 @@ struct meson_flow {
> * @dev: the platform device
> * @chanlist: array of all flow
> * @flow: flow to use in next request
> - * @irqs: IRQ numbers for amlogic-crypto
> + * @flow_cnt: flow count for amlogic-crypto
> * @dbgfs_dir: Debugfs dentry for statistic directory
> * @dbgfs_stats: Debugfs dentry for statistic counters
> */
> @@ -95,7 +95,7 @@ struct meson_dev {
> struct device *dev;
> struct meson_flow *chanlist;
> atomic_t flow;
> - int irqs[MAXFLOW];
> + int flow_cnt;
> #ifdef CONFIG_CRYPTO_DEV_AMLOGIC_GXL_DEBUG
> struct dentry *dbgfs_dir;
> #endif
_______________________________________________
linux-amlogic mailing list
linux-amlogic@lists.infradead.org
http://lists.infradead.org/mailman/listinfo/linux-amlogic
next prev parent reply other threads:[~2024-01-11 8:22 UTC|newest]
Thread overview: 37+ messages / expand[flat|nested] mbox.gz Atom feed top
2024-01-10 20:11 [PATCH v1 00/24] Support more Amlogic SoC families in crypto driver Alexey Romanov
2024-01-10 20:11 ` [PATCH v1 01/24] drivers: crypto: meson: don't hardcode IRQ count Alexey Romanov
2024-01-11 8:21 ` neil.armstrong [this message]
2024-01-10 20:11 ` [PATCH v1 02/24] drivers: crypto: meson: make CLK controller optional Alexey Romanov
2024-01-11 8:20 ` neil.armstrong
2024-01-10 20:11 ` [PATCH v1 03/24] drviers: crypto: meson: add platform data Alexey Romanov
2024-01-10 20:11 ` [PATCH v1 04/24] drivers: crypto: meson: add MMIO helpers Alexey Romanov
2024-01-10 20:11 ` [PATCH v1 05/24] drivers: crypto: meson: move get_engine_number() Alexey Romanov
2024-01-10 20:11 ` [PATCH v1 06/24] drivers: crypto: meson: drop status field from meson_flow Alexey Romanov
2024-01-10 20:11 ` [PATCH v1 07/24] drivers: crypto: meson: move algs definition and cipher API to cipher.c Alexey Romanov
2024-01-10 20:11 ` [PATCH v1 08/24] drivers: crypto: meson: cleanup defines Alexey Romanov
2024-01-10 20:11 ` [PATCH v1 09/24] drivers: crypto: meson: process more than MAXDESCS descriptors Alexey Romanov
2024-01-10 20:11 ` [PATCH v1 10/24] drivers: crypto: meson: avoid kzalloc in engine thread Alexey Romanov
2024-01-10 20:11 ` [PATCH v1 11/24] drivers: crypto: meson: introduce hasher Alexey Romanov
2024-01-10 20:11 ` [PATCH v1 12/24] drivers: crypto: meson: add support for AES-CTR Alexey Romanov
2024-01-10 20:11 ` [PATCH v1 13/24] drivers: crypto: meson: use fallback for 192-bit keys Alexey Romanov
2024-01-10 20:11 ` [PATCH v1 14/24] drivers: crypto: meson: add support for G12-series Alexey Romanov
2024-01-10 20:11 ` [PATCH v1 15/24] drivers: crypto: meson: add support for AXG-series Alexey Romanov
2024-01-10 20:11 ` [PATCH v1 16/24] dt-bindings: crypto: meson: add new compatibles Alexey Romanov
2024-01-10 21:25 ` Rob Herring
2024-01-11 1:44 ` Rob Herring
2024-01-11 8:15 ` neil.armstrong
2024-01-10 20:11 ` [PATCH v1 17/24] arch: arm64: dts: meson: a1: add crypto node Alexey Romanov
2024-01-11 8:16 ` neil.armstrong
2024-01-10 20:11 ` [PATCH v1 18/24] arch: arm64: dts: meson: s4: " Alexey Romanov
2024-01-10 20:11 ` [PATCH v1 19/24] arch: arm64: dts: meson: g12: " Alexey Romanov
2024-01-10 20:11 ` [PATCH v1 20/24] arch: arm64: dts: meson: axg: " Alexey Romanov
2024-01-10 20:11 ` [PATCH v1 21/24] arch: arm64: dts: meson: s4-s805x2-aq222: enable " Alexey Romanov
2024-01-10 20:11 ` [PATCH v1 22/24] arch: arm64: dts: meson: a1-ad401: " Alexey Romanov
2024-01-10 20:11 ` [PATCH v1 23/24] arch: arm64: dts: meson: axg-s400: " Alexey Romanov
2024-01-10 20:11 ` [PATCH v1 24/24] arch: arm64: dts: meson: g12a-u200: " Alexey Romanov
2024-01-10 21:08 ` [PATCH v1 00/24] Support more Amlogic SoC families in crypto driver Corentin Labbe
2024-01-11 9:18 ` Alexey Romanov
2024-01-11 9:29 ` Krzysztof Kozlowski
2024-01-11 9:31 ` Krzysztof Kozlowski
2024-01-11 8:19 ` neil.armstrong
2024-01-11 9:33 ` Alexey Romanov
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=1a3b5004-751a-4479-be89-97265ca63d92@linaro.org \
--to=neil.armstrong@linaro.org \
--cc=artin.blumenstingl@googlemail.com \
--cc=avromanov@salutedevices.com \
--cc=clabbe@baylibre.com \
--cc=conor+dt@kernel.org \
--cc=davem@davemloft.net \
--cc=devicetree@vger.kernel.org \
--cc=herbert@gondor.apana.org.au \
--cc=jbrunet@baylibre.com \
--cc=kernel@salutedevices.com \
--cc=khilman@baylibre.com \
--cc=krzysztof.kozlowski+dt@linaro.org \
--cc=linux-amlogic@lists.infradead.org \
--cc=linux-arm-kernel@lists.infradead.org \
--cc=linux-crypto@vger.kernel.org \
--cc=linux-kernel@vger.kernel.org \
--cc=narmstrong@baylibre.com \
--cc=robh+dt@kernel.org \
--cc=yvdakinevich@salutedevices.com \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).