Received: by 2002:a25:ab43:0:0:0:0:0 with SMTP id u61csp4717404ybi; Tue, 28 May 2019 01:09:59 -0700 (PDT) X-Google-Smtp-Source: APXvYqz5uC6jPnyqKTabWHvLf5glF9757eSyqef7cX5K4eN8qtpwpqYFWpjdlFH8jLGVAMkhH5n8 X-Received: by 2002:a65:628d:: with SMTP id f13mr29228457pgv.177.1559030999080; Tue, 28 May 2019 01:09:59 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1559030999; cv=none; d=google.com; s=arc-20160816; b=aAChn0TfYxvwwDM9H/BIpDKsnSzC7XXGdYMv7s7bDu4oiouJ+cHMfsmQeYsIBE8SvQ TVGpnDrEReWOUoWGVzYy9m8HYE+u0S9ocXoBurOXgCdbZRIt7zgjnueUBskpCup/eGVU JnBwRWUGzqFeF8Lbl/V1vpjZDneI1DyQb095s31xuHtcN0+qWnxvtl8b7D+bvM67PBhC lC2kYgHHgNfLcMwZe0PkaFP64zdu1472KcVQKowmIIG9h2VBwAMp1NfrZywvLVKjWRME E+7ynmjNu92UzgNbuk0oKqLoSJJP4mS9DgAKXTelayFDLXSDGQsDFWJEyw5M+BxBM11y aWwA== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:content-language :content-transfer-encoding:in-reply-to:mime-version:user-agent:date :message-id:organization:from:references:cc:to:subject; bh=CCxAI5uVJipuLyg1blGp1gIUL/fjDknc13cT8cSl7T8=; b=TailkvkV/0qL9W/4qR4hjZxfDWb0ki7xBUnjMdfkC/MFU8rm9cXa/bQQWky8auy9Kn gJgNRntaXTWbMqle8pPPn13ts8EFXpwRqcW+9U+W1WKsxz5IR9lK3uzyKiDRaDKk8cEw 6RhNsdj6zTLK3QVwpgTWbbJgBpVIYnG8TKiKo9K5le+CjLxHaIsf6NAoRH9RaV4c1S7y lunJBFwSR0hJKpUd5Md75vd+cVeLeTEd3sR8RsW3K4iwn/KwfmS827LoC66z0nyU/0PW bZ27BdDzXffsmQyoHdmzWhsVFqcwvZY5fVVfkjwKZZ9zKefXL3zgcuyRKD14N2eUuW/i kHtw== ARC-Authentication-Results: i=1; mx.google.com; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=intel.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id q20si25366287pfn.139.2019.05.28.01.09.43; Tue, 28 May 2019 01:09:59 -0700 (PDT) Received-SPF: pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) client-ip=209.132.180.67; Authentication-Results: mx.google.com; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=intel.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1726504AbfE1IHI (ORCPT + 99 others); Tue, 28 May 2019 04:07:08 -0400 Received: from mga05.intel.com ([192.55.52.43]:42867 "EHLO mga05.intel.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1725943AbfE1IHI (ORCPT ); Tue, 28 May 2019 04:07:08 -0400 X-Amp-Result: SKIPPED(no attachment in message) X-Amp-File-Uploaded: False Received: from fmsmga004.fm.intel.com ([10.253.24.48]) by fmsmga105.fm.intel.com with ESMTP/TLS/DHE-RSA-AES256-GCM-SHA384; 28 May 2019 01:07:07 -0700 X-ExtLoop1: 1 Received: from kjoyce-mobl.ger.corp.intel.com (HELO [10.252.14.75]) ([10.252.14.75]) by fmsmga004.fm.intel.com with ESMTP; 28 May 2019 01:07:04 -0700 Subject: Re: [PATCH 25/44] tools headers UAPI: Sync drm/drm.h with the kernel To: Arnaldo Carvalho de Melo , Ingo Molnar , Thomas Gleixner Cc: Jiri Olsa , Namhyung Kim , Clark Williams , linux-kernel@vger.kernel.org, linux-perf-users@vger.kernel.org, Arnaldo Carvalho de Melo , Adrian Hunter , Brendan Gregg , =?UTF-8?Q?Christian_K=c3=b6nig?= , Chunming Zhou , Dave Airlie , =?UTF-8?Q?Luis_Cl=c3=a1udio_Gon=c3=a7alves?= References: <20190527223730.11474-1-acme@kernel.org> <20190527223730.11474-26-acme@kernel.org> From: Lionel Landwerlin Organization: Intel Corporation (UK) Ltd. - Co. Reg. #1134945 - Pipers Way, Swindon SN3 1RJ Message-ID: <9dac0e36-237f-34a5-1791-e5e45e0dcc4e@intel.com> Date: Tue, 28 May 2019 09:07:03 +0100 User-Agent: Mozilla/5.0 (X11; Linux x86_64; rv:60.0) Gecko/20100101 Thunderbird/60.7.0 MIME-Version: 1.0 In-Reply-To: <20190527223730.11474-26-acme@kernel.org> Content-Type: text/plain; charset=utf-8; format=flowed Content-Transfer-Encoding: 8bit Content-Language: en-US Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On 27/05/2019 23:37, Arnaldo Carvalho de Melo wrote: > From: Arnaldo Carvalho de Melo > > To pick up the changes in these csets: > > 060cebb20cdb ("drm: introduce a capability flag for syncobj timeline support") > 50d1ebef79ef ("drm/syncobj: add timeline signal ioctl for syncobj v5") > ea569910cbab ("drm/syncobj: add transition iotcls between binary and timeline v2") > 27b575a9aa2f ("drm/syncobj: add timeline payload query ioctl v6") > 01d6c3578379 ("drm/syncobj: add support for timeline point wait v8") > 783195ec1cad ("drm/syncobj: disable the timeline UAPI for now v2") > 48197bc564c7 ("drm: add syncobj timeline support v9") > > Which automagically results in the following new ioctls being recognized > by the 'perf trace' ioctl cmd arg beautifier: > > $ tools/perf/trace/beauty/drm_ioctl.sh > /tmp/before > $ cp include/uapi/drm/drm.h tools/include/uapi/drm/drm.h > $ tools/perf/trace/beauty/drm_ioctl.sh > /tmp/after > $ diff -u /tmp/before /tmp/after > --- /tmp/before 2019-05-22 10:25:31.443151182 -0300 > +++ /tmp/after 2019-05-22 10:25:46.449354819 -0300 > @@ -103,6 +103,10 @@ > [0xC7] = "MODE_LIST_LESSEES", > [0xC8] = "MODE_GET_LEASE", > [0xC9] = "MODE_REVOKE_LEASE", > + [0xCA] = "SYNCOBJ_TIMELINE_WAIT", > + [0xCB] = "SYNCOBJ_QUERY", > + [0xCC] = "SYNCOBJ_TRANSFER", > + [0xCD] = "SYNCOBJ_TIMELINE_SIGNAL", > [DRM_COMMAND_BASE + 0x00] = "I915_INIT", > [DRM_COMMAND_BASE + 0x01] = "I915_FLUSH", > [DRM_COMMAND_BASE + 0x02] = "I915_FLIP", > $ > > I.e. the strace like raw_tracepoint:sys_enter handler in 'perf trace' > will get the cmd integer value and map it to the string. > > At some point it should be possible to translate from string to integer > and use to filter using expressions such as: > > # perf trace -e ioctl/cmd==DRM_IOCTL_SYNCOBJ*/ > > Or some more suitable syntax to express that only these ioctls when > acting on DRM fds should be shown. > > Cc: Adrian Hunter > Cc: Brendan Gregg > Cc: Christian König > Cc: Chunming Zhou > Cc: Dave Airlie > Cc: Jiri Olsa > Cc: Lionel Landwerlin > Cc: Luis Cláudio Gonçalves > Cc: Namhyung Kim > Link: https://lkml.kernel.org/n/tip-jrc9ogw33w4zgqc3pu7o1l3g@git.kernel.org > Signed-off-by: Arnaldo Carvalho de Melo Acked-by: Lionel Landwerlin > --- > tools/include/uapi/drm/drm.h | 37 ++++++++++++++++++++++++++++++++++++ > 1 file changed, 37 insertions(+) > > diff --git a/tools/include/uapi/drm/drm.h b/tools/include/uapi/drm/drm.h > index 300f336633f2..661d73f9a919 100644 > --- a/tools/include/uapi/drm/drm.h > +++ b/tools/include/uapi/drm/drm.h > @@ -649,6 +649,7 @@ struct drm_gem_open { > #define DRM_CAP_PAGE_FLIP_TARGET 0x11 > #define DRM_CAP_CRTC_IN_VBLANK_EVENT 0x12 > #define DRM_CAP_SYNCOBJ 0x13 > +#define DRM_CAP_SYNCOBJ_TIMELINE 0x14 > > /** DRM_IOCTL_GET_CAP ioctl argument type */ > struct drm_get_cap { > @@ -735,8 +736,18 @@ struct drm_syncobj_handle { > __u32 pad; > }; > > +struct drm_syncobj_transfer { > + __u32 src_handle; > + __u32 dst_handle; > + __u64 src_point; > + __u64 dst_point; > + __u32 flags; > + __u32 pad; > +}; > + > #define DRM_SYNCOBJ_WAIT_FLAGS_WAIT_ALL (1 << 0) > #define DRM_SYNCOBJ_WAIT_FLAGS_WAIT_FOR_SUBMIT (1 << 1) > +#define DRM_SYNCOBJ_WAIT_FLAGS_WAIT_AVAILABLE (1 << 2) /* wait for time point to become available */ > struct drm_syncobj_wait { > __u64 handles; > /* absolute timeout */ > @@ -747,12 +758,33 @@ struct drm_syncobj_wait { > __u32 pad; > }; > > +struct drm_syncobj_timeline_wait { > + __u64 handles; > + /* wait on specific timeline point for every handles*/ > + __u64 points; > + /* absolute timeout */ > + __s64 timeout_nsec; > + __u32 count_handles; > + __u32 flags; > + __u32 first_signaled; /* only valid when not waiting all */ > + __u32 pad; > +}; > + > + > struct drm_syncobj_array { > __u64 handles; > __u32 count_handles; > __u32 pad; > }; > > +struct drm_syncobj_timeline_array { > + __u64 handles; > + __u64 points; > + __u32 count_handles; > + __u32 pad; > +}; > + > + > /* Query current scanout sequence number */ > struct drm_crtc_get_sequence { > __u32 crtc_id; /* requested crtc_id */ > @@ -909,6 +941,11 @@ extern "C" { > #define DRM_IOCTL_MODE_GET_LEASE DRM_IOWR(0xC8, struct drm_mode_get_lease) > #define DRM_IOCTL_MODE_REVOKE_LEASE DRM_IOWR(0xC9, struct drm_mode_revoke_lease) > > +#define DRM_IOCTL_SYNCOBJ_TIMELINE_WAIT DRM_IOWR(0xCA, struct drm_syncobj_timeline_wait) > +#define DRM_IOCTL_SYNCOBJ_QUERY DRM_IOWR(0xCB, struct drm_syncobj_timeline_array) > +#define DRM_IOCTL_SYNCOBJ_TRANSFER DRM_IOWR(0xCC, struct drm_syncobj_transfer) > +#define DRM_IOCTL_SYNCOBJ_TIMELINE_SIGNAL DRM_IOWR(0xCD, struct drm_syncobj_timeline_array) > + > /** > * Device specific ioctls should only be in their respective headers > * The device specific ioctl range is from 0x40 to 0x9f.