Received: by 2002:ac0:a5a7:0:0:0:0:0 with SMTP id m36-v6csp318306imm; Mon, 9 Jul 2018 02:16:02 -0700 (PDT) X-Google-Smtp-Source: AAOMgpfq0cJfuyjhE99nFR7Ig+04X0Rk2pMhxd/Ysxv3mTAGz+KmpKNNt00AeIp36Icagw1RWVEK X-Received: by 2002:a63:460d:: with SMTP id t13-v6mr7197096pga.201.1531127762738; Mon, 09 Jul 2018 02:16:02 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1531127762; cv=none; d=google.com; s=arc-20160816; b=YqLzqXxWKhrkGxn3EN2Keh3l9hWbZL+Zrm0L7QvdCzCswUBYwQmdUevGr/4Cn8uX40 ecADDDOgUhvtW86Fz2XjFmT0BFcdX6rJfE8tYF4fIYNUzQyK8dK7QQCdnGi5IZHruOAD reVfIsK42Tx80LyB1FN2AY3cfI4QR47Fzmg4EOKuGgXA8cEHL5O1pvcPXeXrw3SOU0Hq c2empc171OgDjMV8XME2twekmBBnq8tBx673JNaKQ7Q0Wj0VK3AFEeHhTMTSQBGJrZMV qyE4b2/4ahDM7w1N1Ih1wlq5ZvCgYg96uQ5753ecRSt/+FzbFieOjlvVmzH4G2rsYGbs z7Tg== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:mime-version:content-transfer-encoding :content-language:accept-language:in-reply-to:references:message-id :date:thread-index:thread-topic:subject:cc:to:from :arc-authentication-results; bh=Bwvz5AqEDyJIk5eVF74E2LieXMVA9UChma/etiuecU4=; b=d2Jkq96XzvsYxxbxgMbG3Q+iz2Iwm7u5Q1IkA5iuyiowd6DEj8xhQ+UPHEGArYYDUQ VmR4kEFg/21vM9jHZHuzEDbgK508C0Y9rxEVO3AvaFPxl8VQGMjUOSFlvAkqjpyCl4vT /5cdn86nE4IBFu2bMcK9Ib0yHv66+G6xLglZFHrJPOGssjnUQqCwwUbifMq2iH2OvVPI BZrYvL5thPGXPXRL64kY3VfZ8AAnSDVZlLaLThP4pyAOTiThXGtaCoAk5iaqtEocv3Zs PVZpJ6EgO46jaenofzQbyH0vgfBbiD0SLS2mG9qTiVHLzU6ZqIJ4eHJKCQ41qFTE1TjV z1Hg== 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 7-v6si14270362plc.179.2018.07.09.02.15.47; Mon, 09 Jul 2018 02:16: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 S932427AbeGIJPH convert rfc822-to-8bit (ORCPT + 99 others); Mon, 9 Jul 2018 05:15:07 -0400 Received: from smtp-out4.electric.net ([192.162.216.195]:59097 "EHLO smtp-out4.electric.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1754142AbeGIJPG (ORCPT ); Mon, 9 Jul 2018 05:15:06 -0400 Received: from 1fcSG3-000BOb-Uw by out4d.electric.net with emc1-ok (Exim 4.90_1) (envelope-from ) id 1fcSG5-000BW2-TP; Mon, 09 Jul 2018 02:15:01 -0700 Received: by emcmailer; Mon, 09 Jul 2018 02:15:01 -0700 Received: from [156.67.243.126] (helo=AcuMS.aculab.com) by out4d.electric.net with esmtps (TLSv1.2:ECDHE-RSA-AES256-SHA384:256) (Exim 4.90_1) (envelope-from ) id 1fcSG3-000BOb-Uw; Mon, 09 Jul 2018 02:14:59 -0700 Received: from AcuMS.Aculab.com (fd9f:af1c:a25b::d117) by AcuMS.aculab.com (fd9f:af1c:a25b::d117) with Microsoft SMTP Server (TLS) id 15.0.1347.2; Mon, 9 Jul 2018 10:16:38 +0100 Received: from AcuMS.Aculab.com ([fe80::43c:695e:880f:8750]) by AcuMS.aculab.com ([fe80::43c:695e:880f:8750%12]) with mapi id 15.00.1347.000; Mon, 9 Jul 2018 10:16:38 +0100 From: David Laight To: 'Alexey Brodkin' , "linux-kernel@vger.kernel.org" CC: "linux-snps-arc@lists.infradead.org" , "linux-arch@vger.kernel.org" , Greg KH , Greg Kroah-Hartman , "Thomas Gleixner" , "stable@vger.kernel.org" Subject: RE: [RESEND PATCH v2] devres: Really align data field to unsigned long long Thread-Topic: [RESEND PATCH v2] devres: Really align data field to unsigned long long Thread-Index: AQHUFz/Ztg2k3cQGIk2o/MVnG+7l9qSGmpBQ Date: Mon, 9 Jul 2018 09:16:38 +0000 Message-ID: References: <20180709044444.6397-1-abrodkin@synopsys.com> In-Reply-To: <20180709044444.6397-1-abrodkin@synopsys.com> Accept-Language: en-GB, en-US Content-Language: en-US X-MS-Has-Attach: X-MS-TNEF-Correlator: x-ms-exchange-transport-fromentityheader: Hosted x-originating-ip: [10.202.205.33] Content-Type: text/plain; charset="us-ascii" Content-Transfer-Encoding: 8BIT MIME-Version: 1.0 X-Outbound-IP: 156.67.243.126 X-Env-From: David.Laight@ACULAB.COM X-Proto: esmtps X-Revdns: X-HELO: AcuMS.aculab.com X-TLS: TLSv1.2:ECDHE-RSA-AES256-SHA384:256 X-Authenticated_ID: X-PolicySMART: 3396946, 3397078 X-Virus-Status: Scanned by VirusSMART (c) X-Virus-Status: Scanned by VirusSMART (s) Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org From: Alexey Brodkin > Sent: 09 July 2018 05:45 > Depending on ABI "long long" type of a particular 32-bit CPU > might be aligned by either word (32-bits) or double word (64-bits). > Make sure "data" is really 64-bit aligned for any 32-bit CPU. > > At least for 32-bit ARC cores ABI requires "long long" types > to be aligned by normal 32-bit word. This makes "data" field aligned to > 12 bytes. Which is still OK as long as we use 32-bit data only. > > But once we want to use native atomic64_t type (i.e. when we use special > instructions LLOCKD/SCONDD for accessing 64-bit data) we easily hit > misaligned access exception. Shouldn't there be a typedef for the actual type. Perhaps it is even atomic64_t ? And have the __aligned(8) applied to that typedef ?? > That's because even on CPUs capable of non-aligned data access LL/SC > instructions require strict alignment. ... > --- a/drivers/base/devres.c > +++ b/drivers/base/devres.c > @@ -24,8 +24,12 @@ struct devres_node { > > struct devres { > struct devres_node node; > - /* -- 3 pointers */ > - unsigned long long data[]; /* guarantee ull alignment */ > + /* > + * Depending on ABI "long long" type of a particular 32-bit CPU > + * might be aligned by either word (32-bits) or double word (64-bits). > + * Make sure "data" is really 64-bit aligned for any 32-bit CPU. Just: /* data[] must be 64 bit aligned even on 32 bit architectures * because it might be accessed by instructions that require * aligned memory arguments. > + */ > + unsigned long long data[] __aligned(sizeof(unsigned long long)); One day assuming that 'unsigned long long' is exactly 64 bits will bite. This probably ought to be u64 (or similar). (If not atomic64_t) David