Received: by 2002:a05:6a10:8c0a:0:0:0:0 with SMTP id go10csp4048810pxb; Mon, 8 Feb 2021 06:47:30 -0800 (PST) X-Google-Smtp-Source: ABdhPJyJU+/ATaciZcDyr7vNTskv4elbrGQleTbM51sgl6KQnbahJWyhuMYQHFm3OhrqbRjBKBmk X-Received: by 2002:a17:906:ecfb:: with SMTP id qt27mr16993616ejb.123.1612795649742; Mon, 08 Feb 2021 06:47:29 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1612795649; cv=none; d=google.com; s=arc-20160816; b=gdoyxox8Ho0Xi44DTWrDWftQNWaxhzTI3wbhL2DPZXNFwl+qt57CbmwAm3ciJM6yOA mgI9kospsIFjgbNTV3GIPdl7Ci4SM0+jECgzSjB+FfYFi3aJ0OnHuck3U+0dI08vLET3 FMv+Q+AZhWVDOYDWG+FazAGLVBzpoz6RmCazKUSmq47FAvWNnDlK/jfeYEuKjBPDD6Pq YCwZP94Ss1ca80KBuLJ0c0dw3/HI3PIkyl2HYchSyBmyEw9pMsG7G81Ia4+mnogr01Zp zxH+2WnkEBiNvcew2eoAlcfdL0nG9FYbrc6Mg2adR8nlNqFS60KioZOx2cWe7rc81nb9 GOeQ== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:cc:to:subject:message-id:date:from:in-reply-to :references:mime-version:dkim-signature; bh=KuxNEK52/tWoYazLfm9IcbvC/RDZqE9jbqWUyvbiRuw=; b=AfHtYO3XSeJzkvoK1ErR9TmrnwA7AzWwPv9n2XNP3sKd2oeukJDW9pgTcvOKfgCl5Q KwvVnVVZbCEGsmnhaEFhCTSEVunhUy/RW1X+j0jOUEfphfWnTeZQV/2rpbwXNb9Ilku2 5a78IQgnGEhsVThw2WuF0freaDPymiCvPJDLZ6NFBJBBSvyCtdN3A6U/MyAeQEwe3Q32 5I13i7WrkCoxtB4BifIGeWocUlBXys5Dq794C1Zj8Ypg3aAzE/254WVAHmWKQN1tG7RJ egA6OjqGx/C2G863arE0DTruDvQJrTZ255XdCpn5Leq1gUrXL5Jzq1xvg+v0FVNqXcZ/ GsrA== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@gmail.com header.s=20161025 header.b=ecjvVxW5; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=QUARANTINE dis=NONE) header.from=gmail.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id z19si3174682edr.191.2021.02.08.06.47.05; Mon, 08 Feb 2021 06:47:29 -0800 (PST) Received-SPF: pass (google.com: domain of linux-kernel-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=@gmail.com header.s=20161025 header.b=ecjvVxW5; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=QUARANTINE dis=NONE) header.from=gmail.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S232690AbhBHOpN (ORCPT + 99 others); Mon, 8 Feb 2021 09:45:13 -0500 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:42540 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S231776AbhBHO2d (ORCPT ); Mon, 8 Feb 2021 09:28:33 -0500 Received: from mail-qk1-x736.google.com (mail-qk1-x736.google.com [IPv6:2607:f8b0:4864:20::736]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 918FBC06178C; Mon, 8 Feb 2021 06:27:53 -0800 (PST) Received: by mail-qk1-x736.google.com with SMTP id d85so14492898qkg.5; Mon, 08 Feb 2021 06:27:53 -0800 (PST) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=gmail.com; s=20161025; h=mime-version:references:in-reply-to:from:date:message-id:subject:to :cc; bh=KuxNEK52/tWoYazLfm9IcbvC/RDZqE9jbqWUyvbiRuw=; b=ecjvVxW5kEw6Hav+4q6Y+KpO0MUUrJr1ZvsvYap1H+4ErD76DvWS72EFgDEiMyoWwh Sl8X/R43v1Qo4dlyzjWq04ip2NWheeMJoQOb5chTlHqEkjnmVvdg/dDcm5gCMQyVvtRx iLJhKOqjokWaZv9pIdTG5DcBc0F4waVv90vyvZWap+QvaOfRNyTVbEYm19aXpLrUJbtK tBbnCkpVX8qJLBSOr3TN64DjfEAO/LT2HS7IfTEh1bXH3kDMvWG6yrXaJBEoFP/reAE1 x0Cwt+yI5rvwR4tRpUV/nHs+hLTUspQDFqriX7mOeNhrMeByr3/y3dwspd+5c9OZ7LLs zaKw== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:mime-version:references:in-reply-to:from:date :message-id:subject:to:cc; bh=KuxNEK52/tWoYazLfm9IcbvC/RDZqE9jbqWUyvbiRuw=; b=ag6/aRZOgmIeG9DxOPTRaVHjFUplIDoBGrQmwFT9jZZhvi2GHQHXKjW80G90O7u+iB 2dNIqVLcrlF08M4kVuDIV56VsBW9jWLTBTbi2c7so/XJAXFTtmS5RdMRGbryVe58XAnJ Rg6Z10TxJ5DAgsXj7wGRKMKJISX4eunUVyMZaYL4+tTaNKPzU3aEbp/F+USzIdtCx1+Z 98Lisxfzi0fr6320I8FrQrZu5/yueHlSX2jjW/w7+QrsxoBKwkVdRKXx9gDp4hq1NPTa /Y9CSQ/zLO1jjGihLXvN8Ff4/wSr2fKgsPDyLjfMzfNj4F5lcZcVqY5aymIfYJ6qsQ+1 sn/Q== X-Gm-Message-State: AOAM530t6edfJACf+G34Og1jIQEw6TMX0YoKRPoSoxg78xc0jWrCw3gu 2pQsoOW7FkGd19xUjYIhZM5xAOkRHp+QyyV2sQxJ5lSk X-Received: by 2002:a37:c01:: with SMTP id 1mr5337773qkm.493.1612794472680; Mon, 08 Feb 2021 06:27:52 -0800 (PST) MIME-Version: 1.0 References: <1612785064-3072-1-git-send-email-orsonzhai@gmail.com> <1612785064-3072-2-git-send-email-orsonzhai@gmail.com> In-Reply-To: <1612785064-3072-2-git-send-email-orsonzhai@gmail.com> From: Baolin Wang Date: Mon, 8 Feb 2021 22:27:47 +0800 Message-ID: Subject: Re: [PATCH 2/3] mailbox: sprd: Add supplementary inbox support To: Orson Zhai Cc: Rob Herring , Jassi Brar , Chunyan Zhang , Mark Brown , Devicetree List , LKML , Haidong Yao , Orson Zhai Content-Type: text/plain; charset="UTF-8" Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On Mon, Feb 8, 2021 at 7:52 PM Orson Zhai wrote: > > From: Orson Zhai > > Some sensors connected to Unisoc mailbox will send data very frequently. > This makes channel 0 very busy and the messages from other remote cores > not able to be handled as soon as possible. > > Then a supplementary inbox is added to the host core side for transferring > mass but not emergency messages from the remote cores, such as step > counting sensor, with an independent FIFO and interrupt. So this is another part of the mailbox hardware, containing a batch of hardware channels? I did not see it before, its function is similar with inbox/outbox? > > Signed-off-by: Orson Zhai > --- > drivers/mailbox/sprd-mailbox.c | 93 ++++++++++++++++++++++++++++++++++-------- > 1 file changed, 75 insertions(+), 18 deletions(-) > > diff --git a/drivers/mailbox/sprd-mailbox.c b/drivers/mailbox/sprd-mailbox.c > index e606f52..74648db 100644 > --- a/drivers/mailbox/sprd-mailbox.c > +++ b/drivers/mailbox/sprd-mailbox.c > @@ -11,6 +11,7 @@ > #include > #include > #include > +#include > #include > #include > > @@ -50,13 +51,17 @@ > #define SPRD_OUTBOX_FIFO_NOT_EMPTY_IRQ BIT(0) > #define SPRD_OUTBOX_FIFO_IRQ_MASK GENMASK(4, 0) > > +#define SPRD_OUTBOX_BASE_SPAN 0x1000 > #define SPRD_MBOX_CHAN_MAX 8 > +#define SPRD_SUPP_INBOX_ID_SC9860 6 > > struct sprd_mbox_priv { > struct mbox_controller mbox; > struct device *dev; > void __iomem *inbox_base; > void __iomem *outbox_base; > + /* Base register address for supplementary outbox */ > + void __iomem *supp_base; > struct clk *clk; > u32 outbox_fifo_depth; > > @@ -96,14 +101,13 @@ static u32 sprd_mbox_get_fifo_len(struct sprd_mbox_priv *priv, u32 fifo_sts) > return fifo_len; > } > > -static irqreturn_t sprd_mbox_outbox_isr(int irq, void *data) > +static inline irqreturn_t do_outbox_isr(void __iomem *base, struct sprd_mbox_priv *priv) No need to add an explicit 'inline' tag, the compiler can do the smart things than us. > { > - struct sprd_mbox_priv *priv = data; > struct mbox_chan *chan; > u32 fifo_sts, fifo_len, msg[2]; > int i, id; > > - fifo_sts = readl(priv->outbox_base + SPRD_MBOX_FIFO_STS); > + fifo_sts = readl(base + SPRD_MBOX_FIFO_STS); > > fifo_len = sprd_mbox_get_fifo_len(priv, fifo_sts); > if (!fifo_len) { > @@ -112,23 +116,41 @@ static irqreturn_t sprd_mbox_outbox_isr(int irq, void *data) > } > > for (i = 0; i < fifo_len; i++) { > - msg[0] = readl(priv->outbox_base + SPRD_MBOX_MSG_LOW); > - msg[1] = readl(priv->outbox_base + SPRD_MBOX_MSG_HIGH); > - id = readl(priv->outbox_base + SPRD_MBOX_ID); > + msg[0] = readl(base + SPRD_MBOX_MSG_LOW); > + msg[1] = readl(base + SPRD_MBOX_MSG_HIGH); > + id = readl(base + SPRD_MBOX_ID); > > chan = &priv->chan[id]; > - mbox_chan_received_data(chan, (void *)msg); > + if (chan->cl) > + mbox_chan_received_data(chan, (void *)msg); > + else > + dev_warn_ratelimited(priv->dev, > + "message's been dropped at ch[%d]\n", id); > > /* Trigger to update outbox FIFO pointer */ > - writel(0x1, priv->outbox_base + SPRD_MBOX_TRIGGER); > + writel(0x1, base + SPRD_MBOX_TRIGGER); > } > > /* Clear irq status after reading all message. */ > - writel(SPRD_MBOX_IRQ_CLR, priv->outbox_base + SPRD_MBOX_IRQ_STS); > + writel(SPRD_MBOX_IRQ_CLR, base + SPRD_MBOX_IRQ_STS); > > return IRQ_HANDLED; > } > > +static irqreturn_t sprd_mbox_outbox_isr(int irq, void *data) > +{ > + struct sprd_mbox_priv *priv = data; > + > + return do_outbox_isr(priv->outbox_base, priv); > +} > + > +static irqreturn_t sprd_mbox_supp_isr(int irq, void *data) > +{ > + struct sprd_mbox_priv *priv = data; > + > + return do_outbox_isr(priv->supp_base, priv); > +} > + > static irqreturn_t sprd_mbox_inbox_isr(int irq, void *data) > { > struct sprd_mbox_priv *priv = data; > @@ -231,6 +253,14 @@ static int sprd_mbox_startup(struct mbox_chan *chan) > val = readl(priv->outbox_base + SPRD_MBOX_IRQ_MSK); > val &= ~SPRD_OUTBOX_FIFO_NOT_EMPTY_IRQ; > writel(val, priv->outbox_base + SPRD_MBOX_IRQ_MSK); > + > + /* Enable supplementary outbox as the fundamental one */ > + if (priv->supp_base) { > + writel(0x0, priv->supp_base + SPRD_MBOX_FIFO_RST); > + val = readl(priv->supp_base + SPRD_MBOX_IRQ_MSK); > + val &= ~SPRD_OUTBOX_FIFO_NOT_EMPTY_IRQ; > + writel(val, priv->supp_base + SPRD_MBOX_IRQ_MSK); > + } > } > mutex_unlock(&priv->lock); > > @@ -246,6 +276,10 @@ static void sprd_mbox_shutdown(struct mbox_chan *chan) > /* Disable inbox & outbox interrupt */ > writel(SPRD_INBOX_FIFO_IRQ_MASK, priv->inbox_base + SPRD_MBOX_IRQ_MSK); > writel(SPRD_OUTBOX_FIFO_IRQ_MASK, priv->outbox_base + SPRD_MBOX_IRQ_MSK); > + > + if (priv->supp_base) > + writel(SPRD_OUTBOX_FIFO_IRQ_MASK, > + priv->supp_base + SPRD_MBOX_IRQ_MSK); > } > mutex_unlock(&priv->lock); > } > @@ -268,8 +302,8 @@ static int sprd_mbox_probe(struct platform_device *pdev) > { > struct device *dev = &pdev->dev; > struct sprd_mbox_priv *priv; > - int ret, inbox_irq, outbox_irq; > - unsigned long id; > + int ret, inbox_irq, outbox_irq, supp_irq; > + unsigned long id, supp; > > priv = devm_kzalloc(dev, sizeof(*priv), GFP_KERNEL); > if (!priv) > @@ -280,11 +314,15 @@ static int sprd_mbox_probe(struct platform_device *pdev) > mutex_init(&priv->lock); > > /* > - * The Spreadtrum mailbox uses an inbox to send messages to the target > - * core, and uses an outbox to receive messages from other cores. > + * Unisoc mailbox uses an inbox to send messages to the target > + * core, and uses (an) outbox(es) to receive messages from other > + * cores. > + * > + * Thus in general the mailbox controller supplies 2 different > + * register addresses and IRQ numbers for inbox and outbox. > * > - * Thus the mailbox controller supplies 2 different register addresses > - * and IRQ numbers for inbox and outbox. > + * If necessary, a supplementary inbox could be enabled optionally > + * with an independent FIFO and an extra interrupt. > */ > priv->inbox_base = devm_platform_ioremap_resource(pdev, 0); > if (IS_ERR(priv->inbox_base)) > @@ -310,7 +348,7 @@ static int sprd_mbox_probe(struct platform_device *pdev) > return ret; > } > > - inbox_irq = platform_get_irq(pdev, 0); > + inbox_irq = platform_get_irq_byname(pdev, "inbox"); I think you should put the dt changes before this patch. > if (inbox_irq < 0) > return inbox_irq; > > @@ -321,7 +359,7 @@ static int sprd_mbox_probe(struct platform_device *pdev) > return ret; > } > > - outbox_irq = platform_get_irq(pdev, 1); > + outbox_irq = platform_get_irq_byname(pdev, "outbox"); > if (outbox_irq < 0) > return outbox_irq; > > @@ -332,6 +370,24 @@ static int sprd_mbox_probe(struct platform_device *pdev) > return ret; > } > > + /* Supplementary outbox IRQ is optional */ > + supp_irq = platform_get_irq_byname(pdev, "supp-outbox"); > + if (supp_irq > 0) { > + ret = devm_request_irq(dev, supp_irq, sprd_mbox_supp_isr, > + IRQF_NO_SUSPEND, dev_name(dev), priv); > + if (ret) { > + dev_err(dev, "failed to request outbox IRQ: %d\n", ret); > + return ret; > + } > + > + supp = (unsigned long) of_device_get_match_data(dev); > + if (!supp) { > + dev_err(dev, "no supplementary outbox specified\n"); > + return -ENODEV; > + } > + priv->supp_base = priv->outbox_base + (SPRD_OUTBOX_BASE_SPAN * supp); > + } > + > /* Get the default outbox FIFO depth */ > priv->outbox_fifo_depth = > readl(priv->outbox_base + SPRD_MBOX_FIFO_DEPTH) + 1; > @@ -354,7 +410,8 @@ static int sprd_mbox_probe(struct platform_device *pdev) > } > > static const struct of_device_id sprd_mbox_of_match[] = { > - { .compatible = "sprd,sc9860-mailbox", }, > + { .compatible = "sprd,sc9860-mailbox", > + .data = (void *)SPRD_SUPP_INBOX_ID_SC9860 }, > { }, > }; > MODULE_DEVICE_TABLE(of, sprd_mbox_of_match); > -- > 2.7.4 > -- Baolin Wang