Received: by 2002:ac0:aa62:0:0:0:0:0 with SMTP id w31-v6csp2073560ima; Thu, 25 Oct 2018 09:09:02 -0700 (PDT) X-Google-Smtp-Source: AJdET5eh8xG2sN+7ozGDYZmqiz0vX2Az3yhgk95hhhRmC+dp8vSdrUa13z0oe7ZKhkG93PcifUXB X-Received: by 2002:a17:902:9a91:: with SMTP id w17-v6mr2015381plp.274.1540483742884; Thu, 25 Oct 2018 09:09:02 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1540483742; cv=none; d=google.com; s=arc-20160816; b=mvfF0xRkAo3a9DhyC/wv++sHzO4mXmWBd/ZoGsRsr1O1io1KEUArZ27tjh11rvVFkL aJdQ7LL3SszZdvkspSe5r6ihLreTs60wXt2uP7/BubdYmjsSlpECER9Czn/QcyAGlyGu hGAWnvUnqEZLmtA7DhBsK68TsazPVL4VdO81paPuLO6j/ONm2nHwpk/dZb0sAxCh0d1z VUZf/23AfoXixXPt3fgBdbzLsCDGYo06rPkg6mT2SiwC9kL8KzfsZzVgVKBguubfGCX2 vd5hEBkn3XM2GFm2MliZ7ULmE7oi73v5BpVw+6jJC6iKt1QWdbFJgF+UTnL0mhWKCQzZ 5RCw== 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; bh=uC0plv4cA3eNizmAjMYEnaECZbGvjOii+QPk/oQ9wzM=; b=0SGbtA9IyCPzfel2nuIwv+Ruu6K2YimoZjpp9m8YjO0SY+8ct7Iqx9nPRUqYEzd9UO qSUAecpIu/Ir7pm3TiETdbY8uxoVnrtlOwIrcq19PhmgA99+5nnJu/OzHNxqgOVo8bfd 3O5JcnNlM2L96l3+uOotb12AFovjMRdndSAMeRnKzx3FrbW8kjjhBGsOGHz4EKe4TTeM vCwo0sNQ0SZt0tgzQy8ZP6V37HnBbxzVVj3bxjTxc15zJV+CmM2Oyz2FrK9gv52kCvw7 qv9p/EvZ6fKlrbEgyK2o0NRrwqU9vmUsE+o4ZecXUgEVNus33q2c/SlsoNsRkIecGDGN GzXA== 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 g9-v6si8026769plo.328.2018.10.25.09.08.41; Thu, 25 Oct 2018 09:09:02 -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 S1727642AbeJZAku (ORCPT + 99 others); Thu, 25 Oct 2018 20:40:50 -0400 Received: from mail.bootlin.com ([62.4.15.54]:50574 "EHLO mail.bootlin.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1727319AbeJZAkt (ORCPT ); Thu, 25 Oct 2018 20:40:49 -0400 Received: by mail.bootlin.com (Postfix, from userid 110) id B1569208C7; Thu, 25 Oct 2018 18:07:21 +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 (91-160-177-164.subs.proxad.net [91.160.177.164]) by mail.bootlin.com (Postfix) with ESMTPSA id D75282072D; Thu, 25 Oct 2018 18:07:20 +0200 (CEST) Date: Thu, 25 Oct 2018 18:07:20 +0200 From: Boris Brezillon To: Arnd Bergmann Cc: Wolfram Sang , linux-i2c@vger.kernel.org, Jonathan Corbet , linux-doc@vger.kernel.org, Greg Kroah-Hartman , 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, Sekhar Nori , Przemyslaw Gaj , Peter Rosin , Mike Shettel , Stephen Boyd , Joe Perches Subject: Re: [PATCH v9 6/9] i3c: master: Add driver for Cadence IP Message-ID: <20181025180720.1790f6a1@bbrezillon> In-Reply-To: References: <20181022133404.2061-1-boris.brezillon@bootlin.com> <20181022133404.2061-7-boris.brezillon@bootlin.com> <20181024202048.7e3534f7@bbrezillon> X-Mailer: Claws Mail 3.16.0 (GTK+ 2.24.32; x86_64-pc-linux-gnu) MIME-Version: 1.0 Content-Type: text/plain; charset=US-ASCII Content-Transfer-Encoding: 7bit Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On Thu, 25 Oct 2018 17:30:26 +0200 Arnd Bergmann wrote: > On 10/24/18, Boris Brezillon wrote: > > Hi Arnd, > > > > On Mon, 22 Oct 2018 15:34:01 +0200 > > Boris Brezillon wrote: > > > > > >> + > >> +static void cdns_i3c_master_rd_from_rx_fifo(struct cdns_i3c_master > >> *master, > >> + u8 *bytes, int nbytes) > >> +{ > >> + readsl(master->regs + RX_FIFO, bytes, nbytes / 4); > > > > Vitor reported a problem with readsl(): this function expects the 2nd > > argument to be aligned on 32-bit, which is not guaranteed here. Unless > > you see a better solution, I'll switch back to a loop doing: > > > > for (i = 0; i < nbytes; i += 4) { > > u32 tmp = __raw_readl(...); > > memcpy(bytes + i, &tmp, > > nbytes - i > 4 ? 4 : nbytes - i); > > } > > Could we maybe mandate that the buffer itself must be aligned here? > What would be a reason why we see an unaligned target buffer? Well, the buffers we pass to i3c_send_ccc_cmd() are not necessarily aligned because they're not dynamically allocated (allocated on the stack) and are not naturally aligned on 32-bits (either because they are smaller than 32bits or because the struct is declared __packed). I guess I could dynamically allocate the payload, but that requires going over all users of i3c_send_ccc_cmd() to patch them.