Received: by 2002:ac0:aa62:0:0:0:0:0 with SMTP id w31-v6csp2081633ima; Thu, 25 Oct 2018 09:15:23 -0700 (PDT) X-Google-Smtp-Source: AJdET5ejE/8qgoIz5ZZznhL256suSPIA+GGT2FVRrJNqAg1qxVKf21M26EKWMSLVsO5y+9C5p1/7 X-Received: by 2002:a63:3204:: with SMTP id y4mr2023979pgy.41.1540484123530; Thu, 25 Oct 2018 09:15:23 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1540484123; cv=none; d=google.com; s=arc-20160816; b=rLNESs7ETYXVYn0cXvcLGCWJVmJ54NqVAlxNjKhlZfeEomgaM1zMT2+TJ3T6wpa1LR 7AJSupFP5uLOP+fCOm3q18ljPQzgkzvr4keNvqRaqxZbf1nvw0SWwYepzHuoD+z5hh84 kP14wsXEUXrgNv7fax5CJpo7sstX1XYWKf5pepMi3OQBDREDGwN1BG0M+a6igd6qXPQU Wt3xbJX2DZPMZ6C3i9XaGNXE9/0WRPJsuu+XbB03G3TrhFPVD/fYDfmP12rXTG4AOd4w 1ERVKUhNHBvQwusrFYuFq0clJmbMJvjdRl6OFdOdQ56VAJMbGdTXO4oFBhKe1Q58PWn1 J71g== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:cc:to:subject:message-id:date:from :in-reply-to:references:mime-version; bh=x3LXVVasdJKF778RgUuO4lJ6BM5jsyB1NU7WJ456Erk=; b=BjlWJLv1plk5suwSRmQBJfDliikR32/xaSsgAidvYOR+aMW/XmrdJJZ7LJHdaOQ/A9 W0/EWh5Cl9S+6EVelFENjOgUKgezcNPH1P050TqAetx3PP8VoeRN9hPI4X/pRom+XoKV CpgbYkb90+CRmFooOzzQJZVf9UycsdpCo/3Fj1TmZbV/p4zWUMLsxXyzQI1sy6F3sRQf yAN0V9JtD1/ZONMS1y/aDMR56vpUxbCWLrNAuuUItAw9cHTNeTmLTq7KhQ9Dfz0J9Wnw JojZmYx1ngHlW3N7JkflACEJxKNP0VYejLL8lJoXcfH8k8w+mJDfNoKlr8GbKPBb0lyS VwaA== 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 b28-v6si1907976pgm.568.2018.10.25.09.14.56; Thu, 25 Oct 2018 09:15:23 -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 S1727741AbeJZArg (ORCPT + 99 others); Thu, 25 Oct 2018 20:47:36 -0400 Received: from mail-qt1-f196.google.com ([209.85.160.196]:40055 "EHLO mail-qt1-f196.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1727313AbeJZArf (ORCPT ); Thu, 25 Oct 2018 20:47:35 -0400 Received: by mail-qt1-f196.google.com with SMTP id z9-v6so10526091qto.7; Thu, 25 Oct 2018 09:14:08 -0700 (PDT) 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=x3LXVVasdJKF778RgUuO4lJ6BM5jsyB1NU7WJ456Erk=; b=cA7pvcCOGsAn2bTBDjr/QBquEZrpAvNASeNbo1gqpOPkIUtG4iTji8KQh5vGHxqxUN rEHt/aDYq82Oev5krWZjX+GnGDTPHiuvo0AbbRg68x+uhJh3621Whdg33g+YiVAQ3NhQ BE0CgFnBq/zHoA/QFRaoFKLHJ9tKCZ8NgfR6nd8BTOxWu0KpdpdMQt3feoGEwTa1fgSu 3Rrcw9lz0ASYQKDBd04ceU2IMq5zn790ctItsLWgTGxb6x6wpaYWbzkqcTLjVVGhiHwP B88NsYj/raXWesU5AEc9N15HLCJhjAzkini1RVluEQvtkaEuu+LwgjIDI+T0E7RjFphY s4EQ== X-Gm-Message-State: AGRZ1gLo5py+LclPB4AuJm9oZfqsSBm2lwE5vcjc2aqwAujmj9fQQNjZ o88NesjBaWk2rdP2GGucumYOiJRewiis6vPM2eg= X-Received: by 2002:a0c:c68f:: with SMTP id d15-v6mr2202319qvj.40.1540484047699; Thu, 25 Oct 2018 09:14:07 -0700 (PDT) MIME-Version: 1.0 References: <20181022133404.2061-1-boris.brezillon@bootlin.com> <20181022133404.2061-7-boris.brezillon@bootlin.com> <20181024202048.7e3534f7@bbrezillon> <20181025180720.1790f6a1@bbrezillon> In-Reply-To: <20181025180720.1790f6a1@bbrezillon> From: Arnd Bergmann Date: Thu, 25 Oct 2018 18:13:51 +0200 Message-ID: Subject: Re: [PATCH v9 6/9] i3c: master: Add driver for Cadence IP To: Boris Brezillon Cc: Wolfram Sang , Linux I2C , Jonathan Corbet , "open list:DOCUMENTATION" , gregkh , 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 , DTML , Linux Kernel Mailing List , Vitor Soares , Geert Uytterhoeven , Linus Walleij , Xiang Lin , "open list:GPIO SUBSYSTEM" , Sekhar Nori , Przemyslaw Gaj , Peter Rosin , Mike Shettel , Stephen Boyd , Joe Perches Content-Type: text/plain; charset="UTF-8" Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On Thu, Oct 25, 2018 at 6:07 PM Boris Brezillon wrote: > > 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. This reminds me that Wolfram mentioned in his ELC talk that the buffers on i3c should all be DMA capable to make life easier for i3c master drivers that want to implement DMA transfers. If we have buffers here that are not aligned to cache lines (or even just 32 bit words), doesn't that also mean that the same buffers are not DMA capable either? Arnd