Received: by 2002:ac0:a5b6:0:0:0:0:0 with SMTP id m51-v6csp3482447imm; Mon, 4 Jun 2018 04:28:30 -0700 (PDT) X-Google-Smtp-Source: ADUXVKI0Mx1B2dBw2FIhPljLQZqWfUQvOnyKUwa+4fZZlGJGbXyIIiq3YTLUCJqfo1RzsUevier2 X-Received: by 2002:a62:bca:: with SMTP id 71-v6mr15684485pfl.234.1528111710311; Mon, 04 Jun 2018 04:28:30 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1528111710; cv=none; d=google.com; s=arc-20160816; b=bFdDMZrYqKV+OnzkK3tZcffGAAIHnsOvwFyZx7M2MGCRWN5iqt74cx98yGw8TbS8bf y/lCeAkZt6DlZ+X7y8PEvfGIcnHJ9bpC6e6GS22X42S9Zr/t0kCwDfP86p9L0CpACD0g nNcneSJXdyNACtefMIPzPwbfMro0zCgbvVocKPfmf5UWaq8pTWzSPxkxu+PmnaUQGZzd 7JKEemAWLJkNGJEVo9y90jCIcb385iIuXAEQ4XXkX9wQBpfnq6bnAXchFHP8XN9q2hQ2 v8CSSLAH3Wte2a+7ulpRyLggYh5nwFnM++XnRF3qMrUU/qXpBjZEAcQi5nTkgGH9OYyJ BZGw== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:content-transfer-encoding:mime-version :references:in-reply-to:message-id:subject:cc:to:from:date :arc-authentication-results; bh=eNAK1rH6Cw2Ey1eoINSzXPV8d6cYhLj9iXhQO+z15+Q=; b=yU/gLP3Ly5TTI5TlhhYc9yk/vRO7Z3TIh/6CvBHTyZSGp8oEqgpdfVVTtNG4Px2bAN WFwNW5icvYQVr9COk4/6fpevJAnLv4tRx68eWVr2YABP1sXSwPo+8PvRBtCLgauq3NEv XQ8E5RrBhnZz9tu36dgdtooU9O5TzevCJC9M4noXxeV6N4JRfuUtTqPyfTwZX+DaXVyn G4QPrV+O/JfWyCy2ipcoLbKO9slKLo2ldeyWw1xQT8JV0WtJLNwB910pTWV2SyyYEc9a rT2CWMGuLFPQSOxUHdoWj6aY24qezRW+sy3zxf9yM6zLbF8rt4I6fR9QOB21t0SjAoSf MWPg== 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 Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id e5-v6si36986671pgn.339.2018.06.04.04.28.16; Mon, 04 Jun 2018 04:28:30 -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 Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1752330AbeFDL0b convert rfc822-to-8bit (ORCPT + 99 others); Mon, 4 Jun 2018 07:26:31 -0400 Received: from mail.bootlin.com ([62.4.15.54]:46161 "EHLO mail.bootlin.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1750868AbeFDL02 (ORCPT ); Mon, 4 Jun 2018 07:26:28 -0400 Received: by mail.bootlin.com (Postfix, from userid 110) id 891452083D; Mon, 4 Jun 2018 13:26:26 +0200 (CEST) X-Spam-Checker-Version: SpamAssassin 3.4.0 (2014-02-07) on mail.bootlin.com X-Spam-Level: X-Spam-Status: No, score=-1.0 required=5.0 tests=ALL_TRUSTED,SHORTCIRCUIT, URIBL_BLOCKED shortcircuit=ham autolearn=disabled version=3.4.0 Received: from bbrezillon (AAubervilliers-681-1-125-111.w90-88.abo.wanadoo.fr [90.88.63.111]) by mail.bootlin.com (Postfix) with ESMTPSA id DE20E207BF; Mon, 4 Jun 2018 13:26:15 +0200 (CEST) Date: Mon, 4 Jun 2018 13:26:15 +0200 From: Boris Brezillon To: Przemyslaw Gaj Cc: Wolfram Sang , "linux-i2c@vger.kernel.org" , Jonathan Corbet , "linux-doc@vger.kernel.org" , Greg Kroah-Hartman , Arnd Bergmann , Przemyslaw Sroka , Arkadiusz Golec , Alan Douglas , Bartosz Folta , Damian Kos , Alicja Jurasik-Urbaniak , Cyprian Wronka , Suresh Punnoose , Rafal Ciepiela , Thomas Petazzoni , Nishanth Menon , Rob Herring , Pawel Moll , Mark Rutland , Ian Campbell , Kumar Gala , "devicetree@vger.kernel.org" , "linux-kernel@vger.kernel.org" , Vitor Soares , Geert Uytterhoeven , Linus Walleij , Xiang Lin , "linux-gpio@vger.kernel.org" Subject: Re: [PATCH v4 07/10] i3c: master: Add driver for Cadence IP Message-ID: <20180604132615.415db91a@bbrezillon> In-Reply-To: <9613475C-ECAE-4AD6-9C02-55C9214A6489@cadence.com> References: <20180330074751.25987-1-boris.brezillon@bootlin.com> <20180330074751.25987-8-boris.brezillon@bootlin.com> <9613475C-ECAE-4AD6-9C02-55C9214A6489@cadence.com> X-Mailer: Claws Mail 3.15.0-dirty (GTK+ 2.24.31; x86_64-pc-linux-gnu) MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8BIT Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Hi Przemek, On Mon, 4 Jun 2018 09:24:51 +0000 Przemyslaw Gaj wrote: > Hi Boris, > > Few things regarding Cadence IP driver: > > On 6/4/18, 9:31 AM, "Boris Brezillon" wrote: > > +static void cdns_i3c_master_handle_ibi(struct cdns_i3c_master *master, > + u32 ibir) > +{ > + struct cdns_i3c_i2c_dev_data *data; > + bool data_consumed = false; > + struct i3c_ibi_slot *slot; > + u32 id = IBIR_SLVID(ibir); > + struct i3c_device *dev; > + int len, i, j; > + u8 *buf; > + > + /* > + * FIXME: maybe we should report the FIFO OVF errors to the upper > + * layer. > + */ > + if (id >= master->ibi.num_slots || (ibir & IBIR_ERROR)) > + goto out; > + > + dev = master->ibi.slots[id]; > + spin_lock(&master->ibi.lock); > + > + data = i3c_device_get_master_data(dev); > + slot = i3c_generic_ibi_get_free_slot(data->ibi_pool); > + if (!slot) > + goto out_unlock; > + > + buf = slot->data; > + > + len = IBIR_XFER_BYTES(ibir); > + for (i = 0; i < IBIR_XFER_BYTES(ibir); i += 4) { > + u32 tmp = readl(master->regs + IBI_DATA_FIFO); > + > + for (j = 0; j < 4 && i + j < dev->ibi->max_payload_len; j++) > + buf[i + j] = tmp >> (j * 8); > + > + } > + slot->len = min_t(unsigned int, IBIR_XFER_BYTES(ibir), > + dev->ibi->max_payload_len); > + i3c_master_queue_ibi(dev, slot); > + data_consumed = true; > + > +out_unlock: > + spin_unlock(&master->ibi.lock); > + > +out: > + /* Consume data from the FIFO if it's not been done already. */ > + if (!data_consumed) { > + for (i = 0; i < IBIR_XFER_BYTES(ibir); i += 4) > + readl(master->regs + IBI_DATA_FIFO); > + } > +} > > len variable is unneeded. Will get rid of len. > + > + /* Device ID0 is reserved to describe this master. */ > + master->maxdevs = CONF_STATUS0_DEVS_NUM(val); > + master->free_rr_slots = GENMASK(master->maxdevs, 1); > + > + val = readl(master->regs + CONF_STATUS1); > + master->caps.cmdfifodepth = CONF_STATUS1_CMD_DEPTH(val); > + master->caps.rxfifodepth = CONF_STATUS1_RX_DEPTH(val); > + master->caps.txfifodepth = CONF_STATUS1_TX_DEPTH(val); > + master->caps.ibirfifodepth = 16; > > IBI fifo depth is hardcoded. You can read this value from CONF_STATUS0 register. > > + master->caps.cmdrfifodepth = 16; > > CMDR fifo depth is hardcoded. You can read this value from CONF_STATUS0 register also. Sure, I'll use the FIFO depth exposed in CONF_STATUS0. Thanks, Boris