Return-Path: Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1752069AbaFDQL3 (ORCPT ); Wed, 4 Jun 2014 12:11:29 -0400 Received: from mail-qa0-f52.google.com ([209.85.216.52]:51096 "EHLO mail-qa0-f52.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1750722AbaFDQL1 (ORCPT ); Wed, 4 Jun 2014 12:11:27 -0400 Date: Wed, 4 Jun 2014 12:11:23 -0400 From: Tejun Heo To: Sebastian Ott Cc: Anatol Pomozov , Benjamin LaHaise , linux-aio@kvack.org, Kent Overstreet , Gu Zheng , Heiko Carstens , LKML Subject: Re: [PATCH] percpu-refcount: fix usage of this_cpu_ops (was Re: hanging aio process) Message-ID: <20140604161123.GG5004@htj.dyndns.org> References: <20140519180851.GD2915@kvack.org> MIME-Version: 1.0 Content-Type: text/plain; charset=us-ascii Content-Disposition: inline In-Reply-To: User-Agent: Mutt/1.5.23 (2014-03-12) Sender: linux-kernel-owner@vger.kernel.org List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On Wed, Jun 04, 2014 at 03:58:24PM +0200, Sebastian Ott wrote: > From 82295633cad58c7d6b9af4e470e3168ed43a6779 Mon Sep 17 00:00:00 2001 > From: Heiko Carstens > Date: Wed, 4 Jun 2014 12:53:19 +0200 > Subject: [PATCH] percpu-refcount: fix usage of this_cpu_ops > > The percpu-refcount infrastructure uses the underscore variants of > this_cpu_ops in order to modify percpu reference counters. > (e.g. __this_cpu_inc()). > > However the underscore variants do not atomically update the percpu > variable, instead they may be implemented using read-modify-write > semantics (more than one instruction). Therefore it is only safe to > use the underscore variant if the context is always the same (process, > softirq, or hardirq). Otherwise it is possible to lose updates. > > This problem is something that Sebastian has seen within the aio > subsystem which uses percpu refcounters both in process and softirq > context leading to reference counts that never dropped to zeroes; even > though the number of "get" and "put" calls matched. > > Fix this by using the non-underscore this_cpu_ops variant which > provides correct per cpu atomic semantics and fixes the corrupted > reference counts. > > Cc: Kent Overstreet > Cc: Tejun Heo > Cc: # v3.11+ > Reported-by: Sebastian Ott > Signed-off-by: Heiko Carstens Bah... should have caught it way back. Sorry about that. Appying to percpu/for-3.15-fixes with stable cc'd. Thanks. -- tejun -- To unsubscribe from this list: send the line "unsubscribe linux-kernel" in the body of a message to majordomo@vger.kernel.org More majordomo info at http://vger.kernel.org/majordomo-info.html Please read the FAQ at http://www.tux.org/lkml/