From mboxrd@z Thu Jan 1 00:00:00 1970 Return-Path: Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1755934Ab1EWPPf (ORCPT ); Mon, 23 May 2011 11:15:35 -0400 Received: from casper.infradead.org ([85.118.1.10]:43709 "EHLO casper.infradead.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1755415Ab1EWPPe convert rfc822-to-8bit (ORCPT ); Mon, 23 May 2011 11:15:34 -0400 Subject: Re: [PATCH 0/3] perf_events: update extra shared registers management (v2) From: Peter Zijlstra To: Stephane Eranian Cc: LKML , "mingo@elte.hu" , Andi Kleen , Lin Ming In-Reply-To: References: <20110520143707.GA5347@quad> <1306141897.18455.8.camel@twins> <1306143168.18455.10.camel@twins> <1306149026.18455.11.camel@twins> Content-Type: text/plain; charset="UTF-8" Content-Transfer-Encoding: 8BIT Date: Mon, 23 May 2011 17:15:00 +0200 Message-ID: <1306163700.18455.16.camel@twins> Mime-Version: 1.0 X-Mailer: Evolution 2.30.3 Sender: linux-kernel-owner@vger.kernel.org List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On Mon, 2011-05-23 at 14:00 +0200, Stephane Eranian wrote: > On Mon, May 23, 2011 at 1:10 PM, Peter Zijlstra wrote: > > On Mon, 2011-05-23 at 12:58 +0200, Stephane Eranian wrote: > >> There is a major issue as it stands, though. You can > >> get into an infinite loop bouncing between RSP_0 and RSP_1 > >> in case there is no solution in the group, i.e., you have 3 values > >> for the extra MSR. I think you need to count the number of times > >> you've called intel_try_alt_er() with success or maintain some sort > >> of bitmask of possible alternate choices and when you exhaust that, > >> you simply fail. > > > > That should be sorted by the compare with the initial idx value, no? > > Once its back where it started out it'll bail. > > > Nope. > > Take: > - ev1=rsp_0:0x1001 > - ev2=rsp_0:0x1002 > - ev3=rsp_1:0x1008 > > ev1-> rsp_0 > ev2-> rsp_0, conflict, then try yields rsp_1 -> ok > ev3 -> rsp_1, conflict, then rsp_0, but fails, try again -> rsp_1, > fails, and so on > > The issue is that the intel_try() function does not know the > history of the swaps between rsp_0, rsp1. But it does, we pass the initial reg->idx in, and return false when that matches the new idx, so in your example, ev3 will do: rsp_1 -> conflict, try rsp_0 -> conflict, try rsp_1 -> bail, return emptyconstraint