Received: by 2002:a25:ad19:0:0:0:0:0 with SMTP id y25csp11922104ybi; Fri, 26 Jul 2019 01:52:45 -0700 (PDT) X-Google-Smtp-Source: APXvYqwYipPogx1WvKxdmivj8FE9C0RVVqghKGMU99roAlS5Xc/EJLAjTSP/I5+5uZQtDnfi6f3Y X-Received: by 2002:a17:90a:974b:: with SMTP id i11mr95932023pjw.21.1564131165362; Fri, 26 Jul 2019 01:52:45 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1564131165; cv=none; d=google.com; s=arc-20160816; b=X84miuAn1VkXfHBSUmjg1jndXqzAwALbNTArnKi00XsAfaRDNGZ3A7/OPyKua2a2UX iTFXnTDkDMM1QyNrPZs1hHK4JZRuKrq3guS9SoSD06ZfDuKgWmCf+/YupU7ot6axSPAe swm41hq01yVa5X6la/WyUpYdzUxKVK1TpZ+ZBmKEyvR+h9Bh0+myszMO6tJZoC6Qa8w9 R3XlCf15ua4ceRQOB8JLTkG+PTaT3YZ7dB7fFqfI97A5bweUrRU90HZEww3vPPvyLcyR q92OuY5GpLw/nnhZq/QG0tUoslaXhUuDNTAT0MeTlo1lEFzp8uQIkErDm2b8CdSBS0wa 6AaQ== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:message-id:date:subject:cc:to:from; bh=37VA2D8LfWo40YrL9ip5KZBLMzTdTiuzz1VE2IivKeA=; b=wr3UDlUrhOm5IUp9sCNlIofkuVWYP3SeuIkvegpswwogQFeYRUSVTpRuC5XyLZgJ5w IIakPQ4FI/94hVBJoqydSbFZsBXU81JxZ6ECF70II1lna9JD5bnr+ii90DEjuGqvNFfO Zr8PMD2dXd2zPhdgCiyxJKKr2vLmNG88mobGRmbpC56NJW2V1UBhN9Am9dUmS3hIj+/9 Ua9DxfrMWKIBYsPDD1vNSzuf6W9SXd7yWPlnDypGkVRL25D8UXdEUp+bsy71+A8ETZEC CuUebaMH6PwpYJsriU+rjGQydIdFShW7exU1vBqlmf+ivCOkitOy1MzYazAUt6oDhCmv 44Kg== ARC-Authentication-Results: i=1; mx.google.com; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=nxp.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id b6si17970379pjz.29.2019.07.26.01.52.30; Fri, 26 Jul 2019 01:52:45 -0700 (PDT) Received-SPF: pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) client-ip=209.132.180.67; Authentication-Results: mx.google.com; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=nxp.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1726191AbfGZIvt (ORCPT + 99 others); Fri, 26 Jul 2019 04:51:49 -0400 Received: from inva020.nxp.com ([92.121.34.13]:45332 "EHLO inva020.nxp.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1725815AbfGZIvs (ORCPT ); Fri, 26 Jul 2019 04:51:48 -0400 Received: from inva020.nxp.com (localhost [127.0.0.1]) by inva020.eu-rdc02.nxp.com (Postfix) with ESMTP id D69E81A0966; Fri, 26 Jul 2019 10:51:45 +0200 (CEST) Received: from invc005.ap-rdc01.nxp.com (invc005.ap-rdc01.nxp.com [165.114.16.14]) by inva020.eu-rdc02.nxp.com (Postfix) with ESMTP id 222B41A0976; Fri, 26 Jul 2019 10:51:42 +0200 (CEST) Received: from localhost.localdomain (shlinux2.ap.freescale.net [10.192.224.44]) by invc005.ap-rdc01.nxp.com (Postfix) with ESMTP id 8BDA7402A9; Fri, 26 Jul 2019 16:51:37 +0800 (SGT) From: Richard Zhu To: jassisinghbrar@gmail.com, o.rempel@pengutronix.de, aisheng.dong@nxp.com Cc: linux-kernel@vger.kernel.org, linux-arm-kernel@lists.infradead.org, Richard Zhu Subject: [RFC] mailbox: imx: Add support for i.MX v1 messaging unit Date: Fri, 26 Jul 2019 16:29:36 +0800 Message-Id: <1564129776-19574-1-git-send-email-hongxing.zhu@nxp.com> X-Mailer: git-send-email 2.7.4 X-Virus-Scanned: ClamAV using ClamSMTP Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org There is a version1.0 MU on i.MX7ULP platform. One new version ID register is added, and the offset is 0. TRn registers are defined at the offset 0x20 ~ 0x2C. RRn registers are defined at the offset 0x40 ~ 0x4C. SR/CR registers are defined at 0x60/0x64. Extend this driver to support it. Signed-off-by: Richard Zhu --- drivers/mailbox/imx-mailbox.c | 45 +++++++++++++++++++++++++++++++++---------- 1 file changed, 35 insertions(+), 10 deletions(-) diff --git a/drivers/mailbox/imx-mailbox.c b/drivers/mailbox/imx-mailbox.c index 25be8bb..eb55bbe 100644 --- a/drivers/mailbox/imx-mailbox.c +++ b/drivers/mailbox/imx-mailbox.c @@ -12,10 +12,14 @@ #include #include +#define MU_VER_ID_V1 0x0100 + /* Transmit Register */ #define IMX_MU_xTRn(x) (0x00 + 4 * (x)) +#define IMX_MU_xTRn_V1(x) (0x20 + 4 * (x)) /* Receive Register */ #define IMX_MU_xRRn(x) (0x10 + 4 * (x)) +#define IMX_MU_xRRn_V1(x) (0x40 + 4 * (x)) /* Status Register */ #define IMX_MU_xSR 0x20 #define IMX_MU_xSR_GIPn(x) BIT(28 + (3 - (x))) @@ -25,6 +29,7 @@ /* Control Register */ #define IMX_MU_xCR 0x24 +#define IMX_MU_xSCR_V1_OFFSET 0x40 /* General Purpose Interrupt Enable */ #define IMX_MU_xCR_GIEn(x) BIT(28 + (3 - (x))) /* Receive Interrupt Enable */ @@ -63,6 +68,7 @@ struct imx_mu_priv { struct imx_mu_con_priv con_priv[IMX_MU_CHANS]; struct clk *clk; int irq; + int version; bool side_b; }; @@ -85,13 +91,16 @@ static u32 imx_mu_read(struct imx_mu_priv *priv, u32 offs) static u32 imx_mu_xcr_rmw(struct imx_mu_priv *priv, u32 set, u32 clr) { unsigned long flags; - u32 val; + u32 val, offset; + + offset = unlikely(priv->version == MU_VER_ID_V1) ? + IMX_MU_xSCR_V1_OFFSET : 0; spin_lock_irqsave(&priv->xcr_lock, flags); - val = imx_mu_read(priv, IMX_MU_xCR); + val = imx_mu_read(priv, IMX_MU_xCR + offset); val &= ~clr; val |= set; - imx_mu_write(priv, val, IMX_MU_xCR); + imx_mu_write(priv, val, IMX_MU_xCR + offset); spin_unlock_irqrestore(&priv->xcr_lock, flags); return val; @@ -109,10 +118,13 @@ static irqreturn_t imx_mu_isr(int irq, void *p) struct mbox_chan *chan = p; struct imx_mu_priv *priv = to_imx_mu_priv(chan->mbox); struct imx_mu_con_priv *cp = chan->con_priv; - u32 val, ctrl, dat; + u32 val, ctrl, dat, offset; + + offset = unlikely(priv->version == MU_VER_ID_V1) ? + IMX_MU_xSCR_V1_OFFSET : 0; - ctrl = imx_mu_read(priv, IMX_MU_xCR); - val = imx_mu_read(priv, IMX_MU_xSR); + ctrl = imx_mu_read(priv, IMX_MU_xCR + offset); + val = imx_mu_read(priv, IMX_MU_xSR + offset); switch (cp->type) { case IMX_MU_TYPE_TX: @@ -138,10 +150,14 @@ static irqreturn_t imx_mu_isr(int irq, void *p) imx_mu_xcr_rmw(priv, 0, IMX_MU_xCR_TIEn(cp->idx)); mbox_chan_txdone(chan, 0); } else if (val == IMX_MU_xSR_RFn(cp->idx)) { - dat = imx_mu_read(priv, IMX_MU_xRRn(cp->idx)); + if (unlikely(priv->version == MU_VER_ID_V1)) + dat = imx_mu_read(priv, IMX_MU_xRRn_V1(cp->idx)); + else + dat = imx_mu_read(priv, IMX_MU_xRRn(cp->idx)); mbox_chan_received_data(chan, (void *)&dat); } else if (val == IMX_MU_xSR_GIPn(cp->idx)) { - imx_mu_write(priv, IMX_MU_xSR_GIPn(cp->idx), IMX_MU_xSR); + imx_mu_write(priv, IMX_MU_xSR_GIPn(cp->idx), + IMX_MU_xSR + offset); mbox_chan_received_data(chan, NULL); } else { dev_warn_ratelimited(priv->dev, "Not handled interrupt\n"); @@ -159,7 +175,10 @@ static int imx_mu_send_data(struct mbox_chan *chan, void *data) switch (cp->type) { case IMX_MU_TYPE_TX: - imx_mu_write(priv, *arg, IMX_MU_xTRn(cp->idx)); + if (unlikely(priv->version == MU_VER_ID_V1)) + imx_mu_write(priv, *arg, IMX_MU_xTRn_V1(cp->idx)); + else + imx_mu_write(priv, *arg, IMX_MU_xTRn(cp->idx)); imx_mu_xcr_rmw(priv, IMX_MU_xCR_TIEn(cp->idx), 0); break; case IMX_MU_TYPE_TXDB: @@ -253,11 +272,17 @@ static struct mbox_chan * imx_mu_xlate(struct mbox_controller *mbox, static void imx_mu_init_generic(struct imx_mu_priv *priv) { + u32 offset; + if (priv->side_b) return; + priv->version = imx_mu_read(priv, 0) >> 16; + offset = unlikely(priv->version == MU_VER_ID_V1) ? + IMX_MU_xSCR_V1_OFFSET : 0; + /* Set default MU configuration */ - imx_mu_write(priv, 0, IMX_MU_xCR); + imx_mu_write(priv, 0, IMX_MU_xCR + offset); } static int imx_mu_probe(struct platform_device *pdev) -- 2.7.4