From mboxrd@z Thu Jan 1 00:00:00 1970 Return-Path: Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S932466AbdBVLit (ORCPT ); Wed, 22 Feb 2017 06:38:49 -0500 Received: from merlin.infradead.org ([205.233.59.134]:34696 "EHLO merlin.infradead.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S932391AbdBVLin (ORCPT ); Wed, 22 Feb 2017 06:38:43 -0500 Date: Wed, 22 Feb 2017 12:38:32 +0100 From: Peter Zijlstra To: Stafford Horne Cc: Jonas Bonn , Stefan Kristiansson , linux@roeck-us.net, openrisc@lists.librecores.org, linux-kernel@vger.kernel.org, Ingo Molnar Subject: Re: [PATCH v3 10/25] openrisc: add spinlock implementation Message-ID: <20170222113832.GQ6515@twins.programming.kicks-ass.net> References: <9ec913b47790e9412d5b71a5fc52794ce4ebafb9.1487702890.git.shorne@gmail.com> MIME-Version: 1.0 Content-Type: text/plain; charset=us-ascii Content-Disposition: inline In-Reply-To: <9ec913b47790e9412d5b71a5fc52794ce4ebafb9.1487702890.git.shorne@gmail.com> User-Agent: Mutt/1.5.23.1 (2014-03-12) Sender: linux-kernel-owner@vger.kernel.org List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On Wed, Feb 22, 2017 at 04:11:39AM +0900, Stafford Horne wrote: > + lockval.tickets.owner = ACCESS_ONCE(lock->tickets.owner); > + return !arch_spin_value_unlocked(ACCESS_ONCE(*lock)); > + struct __raw_tickets tickets = ACCESS_ONCE(lock->tickets); > +#define arch_write_can_lock(x) (ACCESS_ONCE((x)->lock) == 0) > +#define arch_read_can_lock(x) (ACCESS_ONCE((x)->lock) < 0x80000000) Please, no ACCESS_ONCE() in new code, use READ_ONCE() or WRITE_ONCE().