Received: by 2002:a05:6a10:8c0a:0:0:0:0 with SMTP id go10csp695580pxb; Thu, 25 Feb 2021 12:39:05 -0800 (PST) X-Google-Smtp-Source: ABdhPJzTJc8xnxTV7ny0QPcWGplW7vRlRJ03e67d5zt/KjJ7/3slq5O5mPc/XhfhcgpMdCbhXM2x X-Received: by 2002:a17:906:4c85:: with SMTP id q5mr4481930eju.375.1614285545235; Thu, 25 Feb 2021 12:39:05 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1614285545; cv=none; d=google.com; s=arc-20160816; b=HC5HsXVuzqOZPZOih9KiAF5JZ1oXtRwCMz45dbcCoD5S3C/obHsNStKuT8jYyXcKpk ry1ixPAKZptJbIDMkfyGibB511F9MnWnsv8ju/chtlpIhfgUmvxJ+a7okzk7uEdgOgaz WKfdFycoA2kkIcJYp3LZXDDnA5RKGxc39xdN8PyECKSIrBz2h5zP79714JLieszUCXXC ld2h+6lB8mvJHEpNh7mzOzGPvlttIiKOuuS8Z1RCiJDUNRtI111VOMIpQp1nKGgVQWYo tMz6h6oVOCIey2CTFMJmEGiD0jMV+yfLSms5tMAEq0oSpdRED/7kWC/zR79m+JSzOlh+ 80qQ== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:in-reply-to:content-disposition:mime-version :references:message-id:subject:cc:to:from:date:dkim-signature; bh=XqCMFhwUlnyqm6Lv1VYrybaA/cljgkrXlwbFsgvGlhc=; b=RfRksBaDfYegNlBV99ovJeQ2qPVtpbB9+5MEkB1sfEI6+Dq7lIu8aJzYoJqHyfehwu BEp55IlHxHDd3Ig/8c3VqBq/wKXTsnma2BBwoTjOhVLz2NUkmqsRn/I8b9D3OOQs+eM7 gZUQ9tLfN+OXEuLH6ixpdPjGghPb5317dpHSAIoQasoIiAoFE1aj1UFL5uxPo4OgCUXl DjqgOsomHXQEhvqogBmhIDO7FVuCY/IAPs1P3/k3xBkcCa30kfeQAn6lLIZ2GWAdjPB8 KdnIML4vYiT+fZbHzdKNM5KAsxHfxwOPemk7L4y92nLYTwgb/kkpLArZpV/IXxYi83vK fDKg== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@redhat.com header.s=mimecast20190719 header.b=NxDwIzR8; 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; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=redhat.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id p23si4085303edw.196.2021.02.25.12.38.42; Thu, 25 Feb 2021 12:39:05 -0800 (PST) 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=@redhat.com header.s=mimecast20190719 header.b=NxDwIzR8; 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; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=redhat.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S233161AbhBYUiL (ORCPT + 99 others); Thu, 25 Feb 2021 15:38:11 -0500 Received: from us-smtp-delivery-124.mimecast.com ([216.205.24.124]:43719 "EHLO us-smtp-delivery-124.mimecast.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S234606AbhBYUgm (ORCPT ); Thu, 25 Feb 2021 15:36:42 -0500 DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=redhat.com; s=mimecast20190719; t=1614285314; h=from:from:reply-to:subject:subject:date:date:message-id:message-id: to:to:cc:cc:mime-version:mime-version:content-type:content-type: in-reply-to:in-reply-to:references:references; bh=XqCMFhwUlnyqm6Lv1VYrybaA/cljgkrXlwbFsgvGlhc=; b=NxDwIzR8cF1XX+cgZk99H7+ehwUkqeplHWsocTdJI3d27Piww0oojW4/XyNHbb6BW2IV+H RQOj4wuMFtnwoLHFiGSf1F8N/qnCGqVE7u/rfVFFyGVYzLlvp1v7MQwYNV4htVluJi7uOC bHmLvNnHdSYah6bFfgfa8kwpCgLcAN4= Received: from mimecast-mx01.redhat.com (mimecast-mx01.redhat.com [209.132.183.4]) (Using TLS) by relay.mimecast.com with ESMTP id us-mta-385-d4Ic5LAyMQiOFemV_vwI0Q-1; Thu, 25 Feb 2021 15:35:09 -0500 X-MC-Unique: d4Ic5LAyMQiOFemV_vwI0Q-1 Received: from smtp.corp.redhat.com (int-mx02.intmail.prod.int.phx2.redhat.com [10.5.11.12]) (using TLSv1.2 with cipher AECDH-AES256-SHA (256/256 bits)) (No client certificate requested) by mimecast-mx01.redhat.com (Postfix) with ESMTPS id F185C1E561; Thu, 25 Feb 2021 20:35:07 +0000 (UTC) Received: from krava (unknown [10.40.192.91]) by smtp.corp.redhat.com (Postfix) with SMTP id 78A7260BE5; Thu, 25 Feb 2021 20:35:05 +0000 (UTC) Date: Thu, 25 Feb 2021 21:35:04 +0100 From: Jiri Olsa To: Nicholas Fraser Cc: Peter Zijlstra , Ingo Molnar , Arnaldo Carvalho de Melo , Mark Rutland , Alexander Shishkin , Namhyung Kim , Ian Rogers , linux-kernel@vger.kernel.org, Ulrich Czekalla , Huw Davies Subject: Re: [PATCH] perf buildid-cache: Add test for PE executable Message-ID: References: <790bfe67-2155-a426-7130-ae7c45cb055b@codeweavers.com> MIME-Version: 1.0 Content-Type: text/plain; charset=us-ascii Content-Disposition: inline In-Reply-To: <790bfe67-2155-a426-7130-ae7c45cb055b@codeweavers.com> X-Scanned-By: MIMEDefang 2.79 on 10.5.11.12 Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On Wed, Feb 24, 2021 at 02:59:16PM -0500, Nicholas Fraser wrote: > From 9fd0b3889f00ad13662879767d833309d8a035b6 Mon Sep 17 00:00:00 2001 > From: Nicholas Fraser > Date: Thu, 18 Feb 2021 13:24:03 -0500 > Subject: [PATCH] perf buildid-cache: Add test for PE executable > > This builds on the previous changes to tests/shell/buildid.sh, adding > tests for a PE file. It adds it to the build-id cache manually and, if > Wine is available, runs it under "perf record" and verifies that it was > added automatically. > > If wine is not installed, only warnings are printed; the test can still > exit 0. > > Signed-off-by: Nicholas Fraser works nicely now, thanks Acked-by: Jiri Olsa jirka > --- > tools/perf/tests/shell/buildid.sh | 65 +++++++++++++++++++++++++++---- > 1 file changed, 58 insertions(+), 7 deletions(-) > > diff --git a/tools/perf/tests/shell/buildid.sh b/tools/perf/tests/shell/buildid.sh > index 416af614bbe0..f05670d1e39e 100755 > --- a/tools/perf/tests/shell/buildid.sh > +++ b/tools/perf/tests/shell/buildid.sh > @@ -14,18 +14,56 @@ if ! [ -x "$(command -v cc)" ]; then > exit 2 > fi > > +# check what we need to test windows binaries > +add_pe=1 > +run_pe=1 > +if ! perf version --build-options | grep -q 'libbfd: .* on '; then > + echo "WARNING: perf not built with libbfd. PE binaries will not be tested." > + add_pe=0 > + run_pe=0 > +fi > +if ! which wine > /dev/null; then > + echo "WARNING: wine not found. PE binaries will not be run." > + run_pe=0 > +fi > + > +# set up wine > +if [ ${run_pe} -eq 1 ]; then > + wineprefix=$(mktemp -d /tmp/perf.wineprefix.XXX) > + export WINEPREFIX=${wineprefix} > + # clear display variables to prevent wine from popping up dialogs > + unset DISPLAY > + unset WAYLAND_DISPLAY > +fi > + > ex_md5=$(mktemp /tmp/perf.ex.MD5.XXX) > ex_sha1=$(mktemp /tmp/perf.ex.SHA1.XXX) > +ex_pe=$(dirname $0)/../pe-file.exe > > echo 'int main(void) { return 0; }' | cc -Wl,--build-id=sha1 -o ${ex_sha1} -x c - > echo 'int main(void) { return 0; }' | cc -Wl,--build-id=md5 -o ${ex_md5} -x c - > > -echo "test binaries: ${ex_sha1} ${ex_md5}" > +echo "test binaries: ${ex_sha1} ${ex_md5} ${ex_pe}" > > check() > { > - id=`readelf -n ${1} 2>/dev/null | grep 'Build ID' | awk '{print $3}'` > - > + case $1 in > + *.exe) > + # We don't have a tool that can pull a nicely formatted build-id out of > + # a PE file, but we can extract the whole section with objcopy and > + # format it ourselves. The .buildid section is a Debug Directory > + # containing a CodeView entry: > + # https://docs.microsoft.com/en-us/windows/win32/debug/pe-format#debug-directory-image-only > + # https://github.com/dotnet/runtime/blob/da94c022576a5c3bbc0e896f006565905eb137f9/docs/design/specs/PE-COFF.md > + # The build-id starts at byte 33 and must be rearranged into a GUID. > + id=`objcopy -O binary --only-section=.buildid $1 /dev/stdout | \ > + cut -c 33-48 | hexdump -ve '/1 "%02x"' | \ > + sed 's@^\(..\)\(..\)\(..\)\(..\)\(..\)\(..\)\(..\)\(..\)\(.*\)0a$@\4\3\2\1\6\5\8\7\9@'` > + ;; > + *) > + id=`readelf -n ${1} 2>/dev/null | grep 'Build ID' | awk '{print $3}'` > + ;; > + esac > echo "build id: ${id}" > > link=${build_id_dir}/.build-id/${id:0:2}/${id:2} > @@ -50,7 +88,7 @@ check() > exit 1 > fi > > - ${perf} buildid-cache -l | grep $id > + ${perf} buildid-cache -l | grep ${id} > if [ $? -ne 0 ]; then > echo "failed: ${id} is not reported by \"perf buildid-cache -l\"" > exit 1 > @@ -79,16 +117,20 @@ test_record() > { > data=$(mktemp /tmp/perf.data.XXX) > build_id_dir=$(mktemp -d /tmp/perf.debug.XXX) > + log=$(mktemp /tmp/perf.log.XXX) > perf="perf --buildid-dir ${build_id_dir}" > > - ${perf} record --buildid-all -o ${data} ${1} > + echo "running: perf record $@" > + ${perf} record --buildid-all -o ${data} $@ &> ${log} > if [ $? -ne 0 ]; then > - echo "failed: record ${1}" > + echo "failed: record $@" > + echo "see log: ${log}" > exit 1 > fi > > - check ${1} > + check ${@: -1} > > + rm -f ${log} > rm -rf ${build_id_dir} > rm -rf ${data} > } > @@ -96,12 +138,21 @@ test_record() > # add binaries manual via perf buildid-cache -a > test_add ${ex_sha1} > test_add ${ex_md5} > +if [ ${add_pe} -eq 1 ]; then > + test_add ${ex_pe} > +fi > > # add binaries via perf record post processing > test_record ${ex_sha1} > test_record ${ex_md5} > +if [ ${run_pe} -eq 1 ]; then > + test_record wine ${ex_pe} > +fi > > # cleanup > rm ${ex_sha1} ${ex_md5} > +if [ ${run_pe} -eq 1 ]; then > + rm -r ${wineprefix} > +fi > > exit ${err} > -- > 2.30.1 > >