From mboxrd@z Thu Jan 1 00:00:00 1970 Return-Path: Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1751962AbdGRNi4 (ORCPT ); Tue, 18 Jul 2017 09:38:56 -0400 Received: from mga03.intel.com ([134.134.136.65]:62800 "EHLO mga03.intel.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1751415AbdGRNiz (ORCPT ); Tue, 18 Jul 2017 09:38:55 -0400 X-ExtLoop1: 1 X-IronPort-AV: E=Sophos;i="5.40,378,1496127600"; d="scan'208";a="880081349" Subject: Re: [PATCH v5 1/4]: perf/core: use rb trees for pinned/flexible groups To: Alexander Shishkin , Peter Zijlstra , Ingo Molnar , Arnaldo Carvalho de Melo Cc: Andi Kleen , Kan Liang , Dmitri Prokhorov , Valery Cherepennikov , Mark Rutland , David Carrillo-Cisneros , Stephane Eranian , linux-kernel References: <877ez6vtos.fsf@ashishki-desk.ger.corp.intel.com> From: Alexey Budankov Organization: Intel Corp. Message-ID: Date: Tue, 18 Jul 2017 16:38:48 +0300 User-Agent: Mozilla/5.0 (Windows NT 10.0; WOW64; rv:52.0) Gecko/20100101 Thunderbird/52.2.1 MIME-Version: 1.0 In-Reply-To: <877ez6vtos.fsf@ashishki-desk.ger.corp.intel.com> Content-Type: text/plain; charset=utf-8 Content-Language: en-US Content-Transfer-Encoding: 7bit Sender: linux-kernel-owner@vger.kernel.org List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Hi, On 18.07.2017 15:02, Alexander Shishkin wrote: > Alexey Budankov writes: > >> +static void >> +perf_event_groups_rotate(struct perf_event_groups *groups, int cpu) >> +{ >> + struct rb_node *node; >> + struct perf_event *node_event; >> + >> + WARN_ON_ONCE(!groups); > > This seems redundant. Used that for debugging. > >> + >> + list_rotate_left(&groups->list); >> + >> + /* will replace rotation above in patch v5 3/4 >> + >> + node = groups->tree.rb_node; >> + >> + while (node) { >> + node_event = container_of(node, >> + struct perf_event, group_node); >> + >> + if (cpu < node_event->cpu) { >> + node = node->rb_left; >> + } else if (cpu > node_event->cpu) { >> + node = node->rb_right; >> + } else { >> + list_rotate_left(&node_event->group_list); >> + break; >> + } >> + } >> + >> + */ > > Please don't do this, it doesn't add clarity. Accepted. Put it here just for review process simplification. > >> +static int >> +perf_event_groups_iterate(struct perf_event_groups *groups, >> + perf_event_groups_iterate_f callback, void *data) >> +{ >> + int ret = 0; >> + struct perf_event *event; >> + >> + WARN_ON_ONCE(!groups); >> + >> + list_for_each_entry(event, &groups->list, group_list_entry) { >> + ret = callback(event, data); >> + if (ret) >> + break; >> + } >> + >> + /* will replace itration above in patch v5 4/4 >> + >> + for (node = rb_first(groups); node; node = rb_next(node)) { >> + node_event = container_of(node, struct perf_event, group_node); >> + list_for_each_entry(event, &node_event->group_list, >> + group_list_entry) { >> + WARN_ON_ONCE(!(event->cpu == node_event->cpu)); >> + ret = callback(event, data); >> + if (ret) { >> + return ret; >> + } >> + } >> + } >> + >> + */ > > Ditto. > > Regards, > -- > Alex > Thanks, Alexey