Received: by 2002:a05:6a10:eb17:0:0:0:0 with SMTP id hx23csp1499908pxb; Fri, 10 Sep 2021 07:19:17 -0700 (PDT) X-Google-Smtp-Source: ABdhPJxnD6m0A1RLXl1douralNqAgtPAWSLGWDYVzRFKF5HyOZ1AF2ripIOz2R15sjDUYUIsHHu6 X-Received: by 2002:a92:c70e:: with SMTP id a14mr6002775ilp.299.1631283557752; Fri, 10 Sep 2021 07:19:17 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1631283557; cv=none; d=google.com; s=arc-20160816; b=oj+rHTY4Jcv+mWOM5GYTbL7FQkPJ/3N+eOxZHFurvY/2UnDtbvKVhypms2Z8oHzQYx 3RwfHPupsUDFJ9WWqSeBS8TR0t21MZCf6C5eIOlzdiFLt+p/h2P9IetkPdbbREVaw0kJ HGhOvAYQ3bbsTPix64WB+y7aCqJ+P+ac7AmXZtD6iAPqj9IrA386xhkESQwLm3154/te LWlcPComcDIsCUgcQ/YQyJZoRsVAX1v8ygFwHziu1/LrV1eVOjIEu01KwhkaSH1cuT9t X+p56gTrPpfd+ZqiGNaqGpJ8WuFnmiK3EjgD9iAvlVGxERCxXmQon6zOT/eU0uBCt8Df AV5w== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:mime-version:message-id:date:references :in-reply-to:subject:cc:to:from:dkim-signature; bh=K/rOvSuYgaLnknL2KSEDyeYf85pxBp1RfczcK2sf6XI=; b=AOkpXAp7Fd2R6Z4nkgRO9oD/wkvVbBS768ni7kHBLiNIpHtTo/ILvxGD6rj7yKY8pJ NTfOO5zRRFa1YiFpXA4WtjXADHNwR3R7Zu0JbVpHNy0P+mjP6tY0U4huXl35g1aip8JX iHbCDLvVqxp98C3s4F8l8ibFw5ltJI5jQAaw89EGhxgBHjbiJq2AQWh0w7lAL1FVqqvm 0dZt5UneFG6Ie/KCVQ5LIcUvvVL6ppatTRpn5zg4+aJw3SNGFpaC0RLTXWKUp1MmKm/X lhKx65OBrqSrlvdWprhuW4rSiyNiOLKXlPUE1waHzraRT8z8YW4sqO3Ay/8d6BZ4Z7FX 4M8A== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@ellerman.id.au header.s=201909 header.b=Hj8dW57P; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id r195si4629154ior.17.2021.09.10.07.19.05; Fri, 10 Sep 2021 07:19:17 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) client-ip=23.128.96.18; Authentication-Results: mx.google.com; dkim=pass header.i=@ellerman.id.au header.s=201909 header.b=Hj8dW57P; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S233975AbhIJORr (ORCPT + 99 others); Fri, 10 Sep 2021 10:17:47 -0400 Received: from bilbo.ozlabs.org ([203.11.71.1]:40641 "EHLO ozlabs.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S233806AbhIJORp (ORCPT ); Fri, 10 Sep 2021 10:17:45 -0400 DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=ellerman.id.au; s=201909; t=1631283390; bh=K/rOvSuYgaLnknL2KSEDyeYf85pxBp1RfczcK2sf6XI=; h=From:To:Cc:Subject:In-Reply-To:References:Date:From; b=Hj8dW57Pww3U3V7+GtXE5mdCuH0Ws+FugjziObUxVTAR4zC9IcQbj38K9e2XVgkp2 BqLpy8WpZ4uR7klbK/lIGyNdRP7PmMI3/uczieTB8dotWagtPC5xP1r02lrXNZdXF/ Pi6spJzIvNvsPeuZvWwLQtY0Ajf0y4TgmBMR5D8uYlesS/2I0wqP/Q+iGS4/GcG39t IdJbQf+fcKLszSbCKyfoUuRFuthd2+kKvQYWRtox82H7Lil0TqgDOLqGev43ds4j0k T7RYG69xX8EMFZ1JcmtDZBQRAEZeuR8/zhx0OAFN/Bu5tiB5fK4qhs+LxWnBeWjTCz CNmaogFhUZX3A== Received: from authenticated.ozlabs.org (localhost [127.0.0.1]) (using TLSv1.3 with cipher TLS_AES_256_GCM_SHA384 (256/256 bits) key-exchange ECDHE (P-256) server-signature RSA-PSS (4096 bits) server-digest SHA256) (No client certificate requested) by mail.ozlabs.org (Postfix) with ESMTPSA id 4H5dGP47xJz9sW4; Sat, 11 Sep 2021 00:16:29 +1000 (AEST) From: Michael Ellerman To: Peter Zijlstra , Stephane Eranian Cc: linux-kernel@vger.kernel.org, acme@redhat.com, jolsa@redhat.com, kim.phillips@amd.com, namhyung@kernel.org, irogers@google.com, atrajeev@linux.vnet.ibm.com, maddy@linux.ibm.com Subject: Re: [PATCH v1 01/13] perf/core: add union to struct perf_branch_entry In-Reply-To: <878s04my3b.fsf@mpe.ellerman.id.au> References: <20210909075700.4025355-1-eranian@google.com> <20210909075700.4025355-2-eranian@google.com> <20210909190342.GE4323@worktop.programming.kicks-ass.net> <878s04my3b.fsf@mpe.ellerman.id.au> Date: Sat, 11 Sep 2021 00:16:20 +1000 Message-ID: <875yv8ms7f.fsf@mpe.ellerman.id.au> MIME-Version: 1.0 Content-Type: text/plain Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Michael Ellerman writes: > Peter Zijlstra writes: >> On Thu, Sep 09, 2021 at 12:56:48AM -0700, Stephane Eranian wrote: >>> diff --git a/include/uapi/linux/perf_event.h b/include/uapi/linux/perf_event.h >>> index f92880a15645..eb11f383f4be 100644 >>> --- a/include/uapi/linux/perf_event.h >>> +++ b/include/uapi/linux/perf_event.h >>> @@ -1329,13 +1329,18 @@ union perf_mem_data_src { >>> struct perf_branch_entry { >>> __u64 from; >>> __u64 to; >>> - __u64 mispred:1, /* target mispredicted */ >>> - predicted:1,/* target predicted */ >>> - in_tx:1, /* in transaction */ >>> - abort:1, /* transaction abort */ >>> - cycles:16, /* cycle count to last branch */ >>> - type:4, /* branch type */ >>> - reserved:40; >>> + union { >>> + __u64 val; /* to make it easier to clear all fields */ >>> + struct { >>> + __u64 mispred:1, /* target mispredicted */ >>> + predicted:1,/* target predicted */ >>> + in_tx:1, /* in transaction */ >>> + abort:1, /* transaction abort */ >>> + cycles:16, /* cycle count to last branch */ >>> + type:4, /* branch type */ >>> + reserved:40; >>> + }; >>> + }; >>> }; >> >> >> Hurpmh... all other bitfields have ENDIAN_BITFIELD things except this >> one. Power folks, could you please have a look? > > The bit number of each field changes between big and little endian, but > as long as kernel and userspace are the same endian, and both only > access values via the bitfields then it works. ... > > It does look like we have a bug in perf tool though, if I take a > perf.data from a big endian system to a little endian one I don't see > any of the branch flags decoded. eg: > > BE: > > 2413132652524 0x1db8 [0x2d0]: PERF_RECORD_SAMPLE(IP, 0x1): 5279/5279: 0xc00000000045c028 period: 923003 addr: 0 > ... branch stack: nr:28 > ..... 0: c00000000045c028 -> c00000000dce7604 0 cycles P 0 > > LE: > > 2413132652524 0x1db8 [0x2d0]: PERF_RECORD_SAMPLE(IP, 0x1): 5279/5279: 0xc00000000045c028 period: 923003 addr: 0 > ... branch stack: nr:28 > ..... 0: c00000000045c028 -> c00000000dce7604 0 cycles 0 > ^ > missing P > > I guess we're missing a byte swap somewhere. Ugh. We _do_ have a byte swap, but we also need a bit swap. That works for the single bit fields, not sure if it will for the multi-bit fields. So that's a bit of a mess :/ cheers