From mboxrd@z Thu Jan 1 00:00:00 1970 Return-Path: X-Spam-Checker-Version: SpamAssassin 3.4.0 (2014-02-07) on aws-us-west-2-korg-lkml-1.web.codeaurora.org X-Spam-Level: X-Spam-Status: No, score=-13.6 required=3.0 tests=BAYES_00,DKIM_INVALID, DKIM_SIGNED,HEADER_FROM_DIFFERENT_DOMAINS,INCLUDES_CR_TRAILER,INCLUDES_PATCH, MAILING_LIST_MULTI,SPF_HELO_NONE,SPF_PASS,URIBL_BLOCKED autolearn=ham autolearn_force=no version=3.4.0 Received: from mail.kernel.org (mail.kernel.org [198.145.29.99]) by smtp.lore.kernel.org (Postfix) with ESMTP id 32DE2C433ED for ; Tue, 11 May 2021 15:16:45 +0000 (UTC) Received: from gabe.freedesktop.org (gabe.freedesktop.org [131.252.210.177]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by mail.kernel.org (Postfix) with ESMTPS id CF653613DE for ; Tue, 11 May 2021 15:16:44 +0000 (UTC) DMARC-Filter: OpenDMARC Filter v1.3.2 mail.kernel.org CF653613DE Authentication-Results: mail.kernel.org; dmarc=none (p=none dis=none) header.from=ffwll.ch Authentication-Results: mail.kernel.org; spf=none smtp.mailfrom=dri-devel-bounces@lists.freedesktop.org Received: from gabe.freedesktop.org (localhost [127.0.0.1]) by gabe.freedesktop.org (Postfix) with ESMTP id 0A08D6E077; Tue, 11 May 2021 15:16:44 +0000 (UTC) Received: from mail-ej1-x635.google.com (mail-ej1-x635.google.com [IPv6:2a00:1450:4864:20::635]) by gabe.freedesktop.org (Postfix) with ESMTPS id 1411E6EA5C for ; Tue, 11 May 2021 15:16:42 +0000 (UTC) Received: by mail-ej1-x635.google.com with SMTP id l4so30312808ejc.10 for ; Tue, 11 May 2021 08:16:42 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=ffwll.ch; s=google; h=date:from:to:cc:subject:message-id:references:mime-version :content-disposition:content-transfer-encoding:in-reply-to; bh=SY3eNIKlFQA+E0KUS5PuS+vKiX349FdxNO2N7RLoAeQ=; b=DbDP77yJjbe3YQGfwvyzTHjjoMTdhaD2lD2pLA/QjURJ1I2gVZK17hWOF8QC/kmsR2 MmzDeNcVa8rvstPwEW35sZE8aWBKjwdgiYzTEubtlCBTuhMvPCcWLdWYh2UkcR+i8te1 91g1H3s0HTNoFWpkPot3JOYTYzvdHTnzNKAYQ= X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:date:from:to:cc:subject:message-id:references :mime-version:content-disposition:content-transfer-encoding :in-reply-to; bh=SY3eNIKlFQA+E0KUS5PuS+vKiX349FdxNO2N7RLoAeQ=; b=SeHR8MmZkCBk+zfg51lKeV8dPcqMH32jF2gAlpc9Qn0KUFk00u+4hbL/bdhqEWhAXg w2xFBjaRbaCbGU9eIlzOJJy8aiuKcV+rwjzc/2vdFtYgqVPNzAfcTMgita7cZfXgZZSR A1H7PRq/cqrIfTJTmG0Js/yBeATYb841j7UevvHhdbvzvOxdyoUUxS2dT+DUP1brl1Zn lGHK41tRTaXCn6M94Ui97/1wl9dVHCr3eUmqD8CsPUjZpSEMWsUk2b0XiE94LPUF89o6 8YEnKMOJYpeNqdyFjQA7oPD/IBMK/dlfkKMjYQdXmpKs94r28YYgUkwVN7Cn8yKzP0kA oO+A== X-Gm-Message-State: AOAM532ATANfzjsb39cAEN04xP9JJxt2HosJZ1pP7lLNbfZV1N5mDoSM hJV01UYTnavTVOvld9SazaNoCQ== X-Google-Smtp-Source: ABdhPJxg6v8stXrNwzqqgmkSUx9yDxeYyL52IXNn/NrFjLC3jCZbV1142kqlv71nyc4VkccZYHLmcA== X-Received: by 2002:a17:907:33ce:: with SMTP id zk14mr32001638ejb.372.1620746200768; Tue, 11 May 2021 08:16:40 -0700 (PDT) Received: from phenom.ffwll.local ([2a02:168:57f4:0:efd0:b9e5:5ae6:c2fa]) by smtp.gmail.com with ESMTPSA id p18sm11762708ejb.19.2021.05.11.08.16.39 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Tue, 11 May 2021 08:16:40 -0700 (PDT) Date: Tue, 11 May 2021 17:16:38 +0200 From: Daniel Vetter To: Matthew Brost Subject: Re: [RFC PATCH 20/97] drm/i915/guc: Introduce unified HXG messages Message-ID: References: <20210506191451.77768-1-matthew.brost@intel.com> <20210506191451.77768-21-matthew.brost@intel.com> MIME-Version: 1.0 Content-Type: text/plain; charset=utf-8 Content-Disposition: inline Content-Transfer-Encoding: 8bit In-Reply-To: <20210506191451.77768-21-matthew.brost@intel.com> X-Operating-System: Linux phenom 5.10.32scarlett+ X-BeenThere: dri-devel@lists.freedesktop.org X-Mailman-Version: 2.1.29 Precedence: list List-Id: Direct Rendering Infrastructure - Development List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , Cc: tvrtko.ursulin@intel.com, intel-gfx@lists.freedesktop.org, dri-devel@lists.freedesktop.org, jason.ekstrand@intel.com, daniele.ceraolospurio@intel.com, jon.bloomfield@intel.com, daniel.vetter@intel.com, john.c.harrison@intel.com Errors-To: dri-devel-bounces@lists.freedesktop.org Sender: "dri-devel" On Thu, May 06, 2021 at 12:13:34PM -0700, Matthew Brost wrote: > From: Michal Wajdeczko > > New GuC firmware will unify format of MMIO and CTB H2G messages. > Introduce their definitions now to allow gradual transition of > our code to match new changes. > > Signed-off-by: Michal Wajdeczko > Signed-off-by: Matthew Brost > Cc: MichaƂ Winiarski > --- > .../gpu/drm/i915/gt/uc/abi/guc_messages_abi.h | 226 ++++++++++++++++++ > 1 file changed, 226 insertions(+) > > diff --git a/drivers/gpu/drm/i915/gt/uc/abi/guc_messages_abi.h b/drivers/gpu/drm/i915/gt/uc/abi/guc_messages_abi.h > index 775e21f3058c..1c264819aa03 100644 > --- a/drivers/gpu/drm/i915/gt/uc/abi/guc_messages_abi.h > +++ b/drivers/gpu/drm/i915/gt/uc/abi/guc_messages_abi.h > @@ -6,6 +6,232 @@ > #ifndef _ABI_GUC_MESSAGES_ABI_H > #define _ABI_GUC_MESSAGES_ABI_H > > +/** > + * DOC: HXG Message These aren't useful if we don't pull them in somewhere in the Documentation/gpu hierarchy. General comment, and also please check that it all renders correctly still. btw if you respin a patch not originally by you we generally add a (v1) to the original s-o-b line (or whever the version split was) and explain in the usual changelog in the commit message what was changed. This holds for the entire series ofc. -Daniel > + * > + * All messages exchanged with GuC are defined using 32 bit dwords. > + * First dword is treated as a message header. Remaining dwords are optional. > + * > + * .. _HXG Message: > + * > + * +---+-------+--------------------------------------------------------------+ > + * | | Bits | Description | > + * +===+=======+==============================================================+ > + * | | | | > + * | 0 | 31 | **ORIGIN** - originator of the message | > + * | | | - _`GUC_HXG_ORIGIN_HOST` = 0 | > + * | | | - _`GUC_HXG_ORIGIN_GUC` = 1 | > + * | | | | > + * | +-------+--------------------------------------------------------------+ > + * | | 30:28 | **TYPE** - message type | > + * | | | - _`GUC_HXG_TYPE_REQUEST` = 0 | > + * | | | - _`GUC_HXG_TYPE_EVENT` = 1 | > + * | | | - _`GUC_HXG_TYPE_NO_RESPONSE_BUSY` = 3 | > + * | | | - _`GUC_HXG_TYPE_NO_RESPONSE_RETRY` = 5 | > + * | | | - _`GUC_HXG_TYPE_RESPONSE_FAILURE` = 6 | > + * | | | - _`GUC_HXG_TYPE_RESPONSE_SUCCESS` = 7 | > + * | +-------+--------------------------------------------------------------+ > + * | | 27:0 | **AUX** - auxiliary data (depends TYPE) | > + * +---+-------+--------------------------------------------------------------+ > + * | 1 | 31:0 | optional payload (depends on TYPE) | > + * +---+-------+ | > + * |...| | | > + * +---+-------+ | > + * | n | 31:0 | | > + * +---+-------+--------------------------------------------------------------+ > + */ > + > +#define GUC_HXG_MSG_MIN_LEN 1u > +#define GUC_HXG_MSG_0_ORIGIN (0x1 << 31) > +#define GUC_HXG_ORIGIN_HOST 0u > +#define GUC_HXG_ORIGIN_GUC 1u > +#define GUC_HXG_MSG_0_TYPE (0x7 << 28) > +#define GUC_HXG_TYPE_REQUEST 0u > +#define GUC_HXG_TYPE_EVENT 1u > +#define GUC_HXG_TYPE_NO_RESPONSE_BUSY 3u > +#define GUC_HXG_TYPE_NO_RESPONSE_RETRY 5u > +#define GUC_HXG_TYPE_RESPONSE_FAILURE 6u > +#define GUC_HXG_TYPE_RESPONSE_SUCCESS 7u > +#define GUC_HXG_MSG_0_AUX (0xfffffff << 0) > + > +/** > + * DOC: HXG Request > + * > + * The `HXG Request`_ message should be used to initiate synchronous activity > + * for which confirmation or return data is expected. > + * > + * The recipient of this message shall use `HXG Response`_, `HXG Failure`_ > + * or `HXG Retry`_ message as a definite reply, and may use `HXG Busy`_ > + * message as a intermediate reply. > + * > + * Format of @DATA0 and all @DATAn fields depends on the @ACTION code. > + * > + * _HXG Request: > + * > + * +---+-------+--------------------------------------------------------------+ > + * | | Bits | Description | > + * +===+=======+==============================================================+ > + * | 0 | 31 | ORIGIN | > + * | +-------+--------------------------------------------------------------+ > + * | | 30:28 | TYPE = GUC_HXG_TYPE_REQUEST_ | > + * | +-------+--------------------------------------------------------------+ > + * | | 27:16 | **DATA0** - request data (depends on ACTION) | > + * | +-------+--------------------------------------------------------------+ > + * | | 15:0 | **ACTION** - requested action code | > + * +---+-------+--------------------------------------------------------------+ > + * | 1 | 31:0 | **DATA1** - optional data (depends on ACTION) | > + * +---+-------+--------------------------------------------------------------+ > + * |...| | | > + * +---+-------+--------------------------------------------------------------+ > + * | n | 31:0 | **DATAn** - optional data (depends on ACTION) | > + * +---+-------+--------------------------------------------------------------+ > + */ > + > +#define GUC_HXG_REQUEST_MSG_MIN_LEN GUC_HXG_MSG_MIN_LEN > +#define GUC_HXG_REQUEST_MSG_0_DATA0 (0xfff << 16) > +#define GUC_HXG_REQUEST_MSG_0_ACTION (0xffff << 0) > +#define GUC_HXG_REQUEST_MSG_n_DATAn (0xffffffff << 0) > + > +/** > + * DOC: HXG Event > + * > + * The `HXG Event`_ message should be used to initiate asynchronous activity > + * that does not involves immediate confirmation nor data. > + * > + * Format of @DATA0 and all @DATAn fields depends on the @ACTION code. > + * > + * .. _HXG Event: > + * > + * +---+-------+--------------------------------------------------------------+ > + * | | Bits | Description | > + * +===+=======+==============================================================+ > + * | 0 | 31 | ORIGIN | > + * | +-------+--------------------------------------------------------------+ > + * | | 30:28 | TYPE = GUC_HXG_TYPE_EVENT_ | > + * | +-------+--------------------------------------------------------------+ > + * | | 27:16 | **DATA0** - event data (depends on ACTION) | > + * | +-------+--------------------------------------------------------------+ > + * | | 15:0 | **ACTION** - event action code | > + * +---+-------+--------------------------------------------------------------+ > + * | 1 | 31:0 | **DATA1** - optional event data (depends on ACTION) | > + * +---+-------+--------------------------------------------------------------+ > + * |...| | | > + * +---+-------+--------------------------------------------------------------+ > + * | n | 31:0 | **DATAn** - optional event data (depends on ACTION) | > + * +---+-------+--------------------------------------------------------------+ > + */ > + > +#define GUC_HXG_EVENT_MSG_MIN_LEN GUC_HXG_MSG_MIN_LEN > +#define GUC_HXG_EVENT_MSG_0_DATA0 (0xfff << 16) > +#define GUC_HXG_EVENT_MSG_0_ACTION (0xffff << 0) > +#define GUC_HXG_EVENT_MSG_n_DATAn (0xffffffff << 0) > + > +/** > + * DOC: HXG Busy > + * > + * The `HXG Busy`_ message may be used to acknowledge reception of the `HXG Request`_ > + * message if the recipient expects that it processing will be longer than default > + * timeout. > + * > + * The @COUNTER field may be used as a progress indicator. > + * > + * .. _HXG Busy: > + * > + * +---+-------+--------------------------------------------------------------+ > + * | | Bits | Description | > + * +===+=======+==============================================================+ > + * | 0 | 31 | ORIGIN | > + * | +-------+--------------------------------------------------------------+ > + * | | 30:28 | TYPE = GUC_HXG_TYPE_NO_RESPONSE_BUSY_ | > + * | +-------+--------------------------------------------------------------+ > + * | | 27:0 | **COUNTER** - progress indicator | > + * +---+-------+--------------------------------------------------------------+ > + */ > + > +#define GUC_HXG_BUSY_MSG_LEN GUC_HXG_MSG_MIN_LEN > +#define GUC_HXG_BUSY_MSG_0_COUNTER GUC_HXG_MSG_0_AUX > + > +/** > + * DOC: HXG Retry > + * > + * The `HXG Retry`_ message should be used by recipient to indicate that the > + * `HXG Request`_ message was dropped and it should be resent again. > + * > + * The @REASON field may be used to provide additional information. > + * > + * .. _HXG Retry: > + * > + * +---+-------+--------------------------------------------------------------+ > + * | | Bits | Description | > + * +===+=======+==============================================================+ > + * | 0 | 31 | ORIGIN | > + * | +-------+--------------------------------------------------------------+ > + * | | 30:28 | TYPE = GUC_HXG_TYPE_NO_RESPONSE_RETRY_ | > + * | +-------+--------------------------------------------------------------+ > + * | | 27:0 | **REASON** - reason for retry | > + * | | | - _`GUC_HXG_RETRY_REASON_UNSPECIFIED` = 0 | > + * +---+-------+--------------------------------------------------------------+ > + */ > + > +#define GUC_HXG_RETRY_MSG_LEN GUC_HXG_MSG_MIN_LEN > +#define GUC_HXG_RETRY_MSG_0_REASON GUC_HXG_MSG_0_AUX > +#define GUC_HXG_RETRY_REASON_UNSPECIFIED 0u > + > +/** > + * DOC: HXG Failure > + * > + * The `HXG Failure`_ message shall be used as a reply to the `HXG Request`_ > + * message that could not be processed due to an error. > + * > + * .. _HXG Failure: > + * > + * +---+-------+--------------------------------------------------------------+ > + * | | Bits | Description | > + * +===+=======+==============================================================+ > + * | 0 | 31 | ORIGIN | > + * | +-------+--------------------------------------------------------------+ > + * | | 30:28 | TYPE = GUC_HXG_TYPE_RESPONSE_FAILURE_ | > + * | +-------+--------------------------------------------------------------+ > + * | | 27:16 | **HINT** - additional error hint | > + * | +-------+--------------------------------------------------------------+ > + * | | 15:0 | **ERROR** - error/result code | > + * +---+-------+--------------------------------------------------------------+ > + */ > + > +#define GUC_HXG_FAILURE_MSG_LEN GUC_HXG_MSG_MIN_LEN > +#define GUC_HXG_FAILURE_MSG_0_HINT (0xfff << 16) > +#define GUC_HXG_FAILURE_MSG_0_ERROR (0xffff << 0) > + > +/** > + * DOC: HXG Response > + * > + * The `HXG Response`_ message SHALL be used as a reply to the `HXG Request`_ > + * message that was successfully processed without an error. > + * > + * .. _HXG Response: > + * > + * +---+-------+--------------------------------------------------------------+ > + * | | Bits | Description | > + * +===+=======+==============================================================+ > + * | 0 | 31 | ORIGIN | > + * | +-------+--------------------------------------------------------------+ > + * | | 30:28 | TYPE = GUC_HXG_TYPE_RESPONSE_SUCCESS_ | > + * | +-------+--------------------------------------------------------------+ > + * | | 27:0 | **DATA0** - data (depends on ACTION from `HXG Request`_) | > + * +---+-------+--------------------------------------------------------------+ > + * | 1 | 31:0 | **DATA1** - data (depends on ACTION from `HXG Request`_) | > + * +---+-------+--------------------------------------------------------------+ > + * |...| | | > + * +---+-------+--------------------------------------------------------------+ > + * | n | 31:0 | **DATAn** - data (depends on ACTION from `HXG Request`_) | > + * +---+-------+--------------------------------------------------------------+ > + */ > + > +#define GUC_HXG_RESPONSE_MSG_MIN_LEN GUC_HXG_MSG_MIN_LEN > +#define GUC_HXG_RESPONSE_MSG_0_DATA0 GUC_HXG_MSG_0_AUX > +#define GUC_HXG_RESPONSE_MSG_n_DATAn (0xffffffff << 0) > + > +/* deprecated */ > #define INTEL_GUC_MSG_TYPE_SHIFT 28 > #define INTEL_GUC_MSG_TYPE_MASK (0xF << INTEL_GUC_MSG_TYPE_SHIFT) > #define INTEL_GUC_MSG_DATA_SHIFT 16 > -- > 2.28.0 > -- Daniel Vetter Software Engineer, Intel Corporation http://blog.ffwll.ch From mboxrd@z Thu Jan 1 00:00:00 1970 Return-Path: X-Spam-Checker-Version: SpamAssassin 3.4.0 (2014-02-07) on aws-us-west-2-korg-lkml-1.web.codeaurora.org X-Spam-Level: X-Spam-Status: No, score=-13.6 required=3.0 tests=BAYES_00,DKIM_INVALID, DKIM_SIGNED,HEADER_FROM_DIFFERENT_DOMAINS,INCLUDES_CR_TRAILER,INCLUDES_PATCH, MAILING_LIST_MULTI,SPF_HELO_NONE,SPF_PASS,URIBL_BLOCKED autolearn=ham autolearn_force=no version=3.4.0 Received: from mail.kernel.org (mail.kernel.org [198.145.29.99]) by smtp.lore.kernel.org (Postfix) with ESMTP id A9773C433B4 for ; Tue, 11 May 2021 15:16:47 +0000 (UTC) Received: from gabe.freedesktop.org (gabe.freedesktop.org [131.252.210.177]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by mail.kernel.org (Postfix) with ESMTPS id 58FB661400 for ; Tue, 11 May 2021 15:16:47 +0000 (UTC) DMARC-Filter: OpenDMARC Filter v1.3.2 mail.kernel.org 58FB661400 Authentication-Results: mail.kernel.org; dmarc=none (p=none dis=none) header.from=ffwll.ch Authentication-Results: mail.kernel.org; spf=none smtp.mailfrom=intel-gfx-bounces@lists.freedesktop.org Received: from gabe.freedesktop.org (localhost [127.0.0.1]) by gabe.freedesktop.org (Postfix) with ESMTP id 9C9B96EA5D; Tue, 11 May 2021 15:16:44 +0000 (UTC) Received: from mail-ej1-x62f.google.com (mail-ej1-x62f.google.com [IPv6:2a00:1450:4864:20::62f]) by gabe.freedesktop.org (Postfix) with ESMTPS id 051296E077 for ; Tue, 11 May 2021 15:16:42 +0000 (UTC) Received: by mail-ej1-x62f.google.com with SMTP id u21so30262661ejo.13 for ; Tue, 11 May 2021 08:16:42 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=ffwll.ch; s=google; h=date:from:to:cc:subject:message-id:references:mime-version :content-disposition:content-transfer-encoding:in-reply-to; bh=SY3eNIKlFQA+E0KUS5PuS+vKiX349FdxNO2N7RLoAeQ=; b=DbDP77yJjbe3YQGfwvyzTHjjoMTdhaD2lD2pLA/QjURJ1I2gVZK17hWOF8QC/kmsR2 MmzDeNcVa8rvstPwEW35sZE8aWBKjwdgiYzTEubtlCBTuhMvPCcWLdWYh2UkcR+i8te1 91g1H3s0HTNoFWpkPot3JOYTYzvdHTnzNKAYQ= X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:date:from:to:cc:subject:message-id:references :mime-version:content-disposition:content-transfer-encoding :in-reply-to; bh=SY3eNIKlFQA+E0KUS5PuS+vKiX349FdxNO2N7RLoAeQ=; b=SSuZxjmHYZ0zIIBOiXp0Al8xh7AiyrE7O5TjNaghtY3Sq7xZORieo4qnoBzz5spdgr xTPgoGfwIrrtZZJxQBacVmUaZBrM+Q1W3Xrzh9mGD/R0eMHRD+RVc/3aDCbNaYdROlhG UZnVlYhgjrJEggtwwi2P+0jt0CsFdUfp9Wxc/O9OXmh3XmHjCrwByZ5qgk3d5PNamIG+ aNQoKVMwPImKcfvjVf8JygmaHgJCJx7uY9WqlgZitSSYWHPQWES66yQwzqO0ZGzC7Zsp Q0ynpXOMg67+5qLQCv1xmuxNq+leOSBFfSPXwj/fR10y0ivyA1YwJxGnSW1V+ki4vA6F P4bQ== X-Gm-Message-State: AOAM533dtQqaJkUfXpI3Gnko4f6TfGtEWH5C/rkwR7cd4boVEuKgzzjj hMgqkk7QQmgbLnzxz9l0ruXYJw== X-Google-Smtp-Source: ABdhPJxg6v8stXrNwzqqgmkSUx9yDxeYyL52IXNn/NrFjLC3jCZbV1142kqlv71nyc4VkccZYHLmcA== X-Received: by 2002:a17:907:33ce:: with SMTP id zk14mr32001638ejb.372.1620746200768; Tue, 11 May 2021 08:16:40 -0700 (PDT) Received: from phenom.ffwll.local ([2a02:168:57f4:0:efd0:b9e5:5ae6:c2fa]) by smtp.gmail.com with ESMTPSA id p18sm11762708ejb.19.2021.05.11.08.16.39 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Tue, 11 May 2021 08:16:40 -0700 (PDT) Date: Tue, 11 May 2021 17:16:38 +0200 From: Daniel Vetter To: Matthew Brost Message-ID: References: <20210506191451.77768-1-matthew.brost@intel.com> <20210506191451.77768-21-matthew.brost@intel.com> MIME-Version: 1.0 Content-Disposition: inline In-Reply-To: <20210506191451.77768-21-matthew.brost@intel.com> X-Operating-System: Linux phenom 5.10.32scarlett+ Subject: Re: [Intel-gfx] [RFC PATCH 20/97] drm/i915/guc: Introduce unified HXG messages X-BeenThere: intel-gfx@lists.freedesktop.org X-Mailman-Version: 2.1.29 Precedence: list List-Id: Intel graphics driver community testing & development List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , Cc: intel-gfx@lists.freedesktop.org, dri-devel@lists.freedesktop.org, jason.ekstrand@intel.com, daniel.vetter@intel.com Content-Type: text/plain; charset="utf-8" Content-Transfer-Encoding: base64 Errors-To: intel-gfx-bounces@lists.freedesktop.org Sender: "Intel-gfx" T24gVGh1LCBNYXkgMDYsIDIwMjEgYXQgMTI6MTM6MzRQTSAtMDcwMCwgTWF0dGhldyBCcm9zdCB3 cm90ZToKPiBGcm9tOiBNaWNoYWwgV2FqZGVjemtvIDxtaWNoYWwud2FqZGVjemtvQGludGVsLmNv bT4KPiAKPiBOZXcgR3VDIGZpcm13YXJlIHdpbGwgdW5pZnkgZm9ybWF0IG9mIE1NSU8gYW5kIENU QiBIMkcgbWVzc2FnZXMuCj4gSW50cm9kdWNlIHRoZWlyIGRlZmluaXRpb25zIG5vdyB0byBhbGxv dyBncmFkdWFsIHRyYW5zaXRpb24gb2YKPiBvdXIgY29kZSB0byBtYXRjaCBuZXcgY2hhbmdlcy4K PiAKPiBTaWduZWQtb2ZmLWJ5OiBNaWNoYWwgV2FqZGVjemtvIDxtaWNoYWwud2FqZGVjemtvQGlu dGVsLmNvbT4KPiBTaWduZWQtb2ZmLWJ5OiBNYXR0aGV3IEJyb3N0IDxtYXR0aGV3LmJyb3N0QGlu dGVsLmNvbT4KPiBDYzogTWljaGHFgiBXaW5pYXJza2kgPG1pY2hhbC53aW5pYXJza2lAaW50ZWwu Y29tPgo+IC0tLQo+ICAuLi4vZ3B1L2RybS9pOTE1L2d0L3VjL2FiaS9ndWNfbWVzc2FnZXNfYWJp LmggfCAyMjYgKysrKysrKysrKysrKysrKysrCj4gIDEgZmlsZSBjaGFuZ2VkLCAyMjYgaW5zZXJ0 aW9ucygrKQo+IAo+IGRpZmYgLS1naXQgYS9kcml2ZXJzL2dwdS9kcm0vaTkxNS9ndC91Yy9hYmkv Z3VjX21lc3NhZ2VzX2FiaS5oIGIvZHJpdmVycy9ncHUvZHJtL2k5MTUvZ3QvdWMvYWJpL2d1Y19t ZXNzYWdlc19hYmkuaAo+IGluZGV4IDc3NWUyMWYzMDU4Yy4uMWMyNjQ4MTlhYTAzIDEwMDY0NAo+ IC0tLSBhL2RyaXZlcnMvZ3B1L2RybS9pOTE1L2d0L3VjL2FiaS9ndWNfbWVzc2FnZXNfYWJpLmgK PiArKysgYi9kcml2ZXJzL2dwdS9kcm0vaTkxNS9ndC91Yy9hYmkvZ3VjX21lc3NhZ2VzX2FiaS5o Cj4gQEAgLTYsNiArNiwyMzIgQEAKPiAgI2lmbmRlZiBfQUJJX0dVQ19NRVNTQUdFU19BQklfSAo+ ICAjZGVmaW5lIF9BQklfR1VDX01FU1NBR0VTX0FCSV9ICj4gIAo+ICsvKioKPiArICogRE9DOiBI WEcgTWVzc2FnZQoKVGhlc2UgYXJlbid0IHVzZWZ1bCBpZiB3ZSBkb24ndCBwdWxsIHRoZW0gaW4g c29tZXdoZXJlIGluIHRoZQpEb2N1bWVudGF0aW9uL2dwdSBoaWVyYXJjaHkuIEdlbmVyYWwgY29t bWVudCwgYW5kIGFsc28gcGxlYXNlIGNoZWNrIHRoYXQKaXQgYWxsIHJlbmRlcnMgY29ycmVjdGx5 IHN0aWxsLgoKYnR3IGlmIHlvdSByZXNwaW4gYSBwYXRjaCBub3Qgb3JpZ2luYWxseSBieSB5b3Ug d2UgZ2VuZXJhbGx5IGFkZCBhICh2MSkgdG8KdGhlIG9yaWdpbmFsIHMtby1iIGxpbmUgKG9yIHdo ZXZlciB0aGUgdmVyc2lvbiBzcGxpdCB3YXMpIGFuZCBleHBsYWluIGluCnRoZSB1c3VhbCBjaGFu Z2Vsb2cgaW4gdGhlIGNvbW1pdCBtZXNzYWdlIHdoYXQgd2FzIGNoYW5nZWQuCgpUaGlzIGhvbGRz IGZvciB0aGUgZW50aXJlIHNlcmllcyBvZmMuCi1EYW5pZWwKCj4gKyAqCj4gKyAqIEFsbCBtZXNz YWdlcyBleGNoYW5nZWQgd2l0aCBHdUMgYXJlIGRlZmluZWQgdXNpbmcgMzIgYml0IGR3b3Jkcy4K PiArICogRmlyc3QgZHdvcmQgaXMgdHJlYXRlZCBhcyBhIG1lc3NhZ2UgaGVhZGVyLiBSZW1haW5p bmcgZHdvcmRzIGFyZSBvcHRpb25hbC4KPiArICoKPiArICogLi4gX0hYRyBNZXNzYWdlOgo+ICsg Kgo+ICsgKiAgKy0tLSstLS0tLS0tKy0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0t LS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tKwo+ICsgKiAgfCAgIHwgQml0cyAgfCBEZXNjcmlw dGlvbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgfAo+ ICsgKiAgKz09PSs9PT09PT09Kz09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09 PT09PT09PT09PT09PT09PT09PT09PT09Kwo+ICsgKiAgfCAgIHwgICAgICAgfCAgICAgICAgICAg ICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgfAo+ICsg KiAgfCAwIHwgICAgMzEgfCAqKk9SSUdJTioqIC0gb3JpZ2luYXRvciBvZiB0aGUgbWVzc2FnZSAg ICAgICAgICAgICAgICAgICAgICAgfAo+ICsgKiAgfCAgIHwgICAgICAgfCAgIC0gX2BHVUNfSFhH X09SSUdJTl9IT1NUYCA9IDAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgfAo+ICsgKiAg fCAgIHwgICAgICAgfCAgIC0gX2BHVUNfSFhHX09SSUdJTl9HVUNgID0gMSAgICAgICAgICAgICAg ICAgICAgICAgICAgICAgICAgfAo+ICsgKiAgfCAgIHwgICAgICAgfCAgICAgICAgICAgICAgICAg ICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgfAo+ICsgKiAgfCAg ICstLS0tLS0tKy0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0t LS0tLS0tLS0tLS0tLS0tKwo+ICsgKiAgfCAgIHwgMzA6MjggfCAqKlRZUEUqKiAtIG1lc3NhZ2Ug dHlwZSAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgfAo+ICsgKiAgfCAgIHwg ICAgICAgfCAgIC0gX2BHVUNfSFhHX1RZUEVfUkVRVUVTVGAgPSAwICAgICAgICAgICAgICAgICAg ICAgICAgICAgICAgfAo+ICsgKiAgfCAgIHwgICAgICAgfCAgIC0gX2BHVUNfSFhHX1RZUEVfRVZF TlRgID0gMSAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgfAo+ICsgKiAgfCAgIHwgICAg ICAgfCAgIC0gX2BHVUNfSFhHX1RZUEVfTk9fUkVTUE9OU0VfQlVTWWAgPSAzICAgICAgICAgICAg ICAgICAgICAgfAo+ICsgKiAgfCAgIHwgICAgICAgfCAgIC0gX2BHVUNfSFhHX1RZUEVfTk9fUkVT UE9OU0VfUkVUUllgID0gNSAgICAgICAgICAgICAgICAgICAgfAo+ICsgKiAgfCAgIHwgICAgICAg fCAgIC0gX2BHVUNfSFhHX1RZUEVfUkVTUE9OU0VfRkFJTFVSRWAgPSA2ICAgICAgICAgICAgICAg ICAgICAgfAo+ICsgKiAgfCAgIHwgICAgICAgfCAgIC0gX2BHVUNfSFhHX1RZUEVfUkVTUE9OU0Vf U1VDQ0VTU2AgPSA3ICAgICAgICAgICAgICAgICAgICAgfAo+ICsgKiAgfCAgICstLS0tLS0tKy0t LS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0t LS0tKwo+ICsgKiAgfCAgIHwgIDI3OjAgfCAqKkFVWCoqIC0gYXV4aWxpYXJ5IGRhdGEgKGRlcGVu ZHMgVFlQRSkgICAgICAgICAgICAgICAgICAgICAgfAo+ICsgKiAgKy0tLSstLS0tLS0tKy0tLS0t LS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0t Kwo+ICsgKiAgfCAxIHwgIDMxOjAgfCBvcHRpb25hbCBwYXlsb2FkIChkZXBlbmRzIG9uIFRZUEUp ICAgICAgICAgICAgICAgICAgICAgICAgICAgfAo+ICsgKiAgKy0tLSstLS0tLS0tKyAgICAgICAg ICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgfAo+ ICsgKiAgfC4uLnwgICAgICAgfCAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAg ICAgICAgICAgICAgICAgICAgICAgICAgfAo+ICsgKiAgKy0tLSstLS0tLS0tKyAgICAgICAgICAg ICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgfAo+ICsg KiAgfCBuIHwgIDMxOjAgfCAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAg ICAgICAgICAgICAgICAgICAgICAgfAo+ICsgKiAgKy0tLSstLS0tLS0tKy0tLS0tLS0tLS0tLS0t LS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tKwo+ICsgKi8K PiArCj4gKyNkZWZpbmUgR1VDX0hYR19NU0dfTUlOX0xFTgkJCTF1Cj4gKyNkZWZpbmUgR1VDX0hY R19NU0dfMF9PUklHSU4JCQkoMHgxIDw8IDMxKQo+ICsjZGVmaW5lICAgR1VDX0hYR19PUklHSU5f SE9TVAkJCTB1Cj4gKyNkZWZpbmUgICBHVUNfSFhHX09SSUdJTl9HVUMJCQkxdQo+ICsjZGVmaW5l IEdVQ19IWEdfTVNHXzBfVFlQRQkJCSgweDcgPDwgMjgpCj4gKyNkZWZpbmUgICBHVUNfSFhHX1RZ UEVfUkVRVUVTVAkJCTB1Cj4gKyNkZWZpbmUgICBHVUNfSFhHX1RZUEVfRVZFTlQJCQkxdQo+ICsj ZGVmaW5lICAgR1VDX0hYR19UWVBFX05PX1JFU1BPTlNFX0JVU1kJCTN1Cj4gKyNkZWZpbmUgICBH VUNfSFhHX1RZUEVfTk9fUkVTUE9OU0VfUkVUUlkJNXUKPiArI2RlZmluZSAgIEdVQ19IWEdfVFlQ RV9SRVNQT05TRV9GQUlMVVJFCQk2dQo+ICsjZGVmaW5lICAgR1VDX0hYR19UWVBFX1JFU1BPTlNF X1NVQ0NFU1MJCTd1Cj4gKyNkZWZpbmUgR1VDX0hYR19NU0dfMF9BVVgJCQkoMHhmZmZmZmZmIDw8 IDApCj4gKwo+ICsvKioKPiArICogRE9DOiBIWEcgUmVxdWVzdAo+ICsgKgo+ICsgKiBUaGUgYEhY RyBSZXF1ZXN0YF8gbWVzc2FnZSBzaG91bGQgYmUgdXNlZCB0byBpbml0aWF0ZSBzeW5jaHJvbm91 cyBhY3Rpdml0eQo+ICsgKiBmb3Igd2hpY2ggY29uZmlybWF0aW9uIG9yIHJldHVybiBkYXRhIGlz IGV4cGVjdGVkLgo+ICsgKgo+ICsgKiBUaGUgcmVjaXBpZW50IG9mIHRoaXMgbWVzc2FnZSBzaGFs bCB1c2UgYEhYRyBSZXNwb25zZWBfLCBgSFhHIEZhaWx1cmVgXwo+ICsgKiBvciBgSFhHIFJldHJ5 YF8gbWVzc2FnZSBhcyBhIGRlZmluaXRlIHJlcGx5LCBhbmQgbWF5IHVzZSBgSFhHIEJ1c3lgXwo+ ICsgKiBtZXNzYWdlIGFzIGEgaW50ZXJtZWRpYXRlIHJlcGx5Lgo+ICsgKgo+ICsgKiBGb3JtYXQg b2YgQERBVEEwIGFuZCBhbGwgQERBVEFuIGZpZWxkcyBkZXBlbmRzIG9uIHRoZSBAQUNUSU9OIGNv ZGUuCj4gKyAqCj4gKyAqIF9IWEcgUmVxdWVzdDoKPiArICoKPiArICogICstLS0rLS0tLS0tLSst LS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0t LS0tLSsKPiArICogIHwgICB8IEJpdHMgIHwgRGVzY3JpcHRpb24gICAgICAgICAgICAgICAgICAg ICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIHwKPiArICogICs9PT0rPT09PT09PSs9PT09 PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09 PSsKPiArICogIHwgMCB8ICAgIDMxIHwgT1JJR0lOICAgICAgICAgICAgICAgICAgICAgICAgICAg ICAgICAgICAgICAgICAgICAgICAgICAgICAgIHwKPiArICogIHwgICArLS0tLS0tLSstLS0tLS0t LS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLSsK PiArICogIHwgICB8IDMwOjI4IHwgVFlQRSA9IEdVQ19IWEdfVFlQRV9SRVFVRVNUXyAgICAgICAg ICAgICAgICAgICAgICAgICAgICAgICAgIHwKPiArICogIHwgICArLS0tLS0tLSstLS0tLS0tLS0t LS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLSsKPiAr ICogIHwgICB8IDI3OjE2IHwgKipEQVRBMCoqIC0gcmVxdWVzdCBkYXRhIChkZXBlbmRzIG9uIEFD VElPTikgICAgICAgICAgICAgICAgIHwKPiArICogIHwgICArLS0tLS0tLSstLS0tLS0tLS0tLS0t LS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLSsKPiArICog IHwgICB8ICAxNTowIHwgKipBQ1RJT04qKiAtIHJlcXVlc3RlZCBhY3Rpb24gY29kZSAgICAgICAg ICAgICAgICAgICAgICAgICAgIHwKPiArICogICstLS0rLS0tLS0tLSstLS0tLS0tLS0tLS0tLS0t LS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLSsKPiArICogIHwg MSB8ICAzMTowIHwgKipEQVRBMSoqIC0gb3B0aW9uYWwgZGF0YSAoZGVwZW5kcyBvbiBBQ1RJT04p ICAgICAgICAgICAgICAgIHwKPiArICogICstLS0rLS0tLS0tLSstLS0tLS0tLS0tLS0tLS0tLS0t LS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLSsKPiArICogIHwuLi58 ICAgICAgIHwgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAg ICAgICAgICAgICAgIHwKPiArICogICstLS0rLS0tLS0tLSstLS0tLS0tLS0tLS0tLS0tLS0tLS0t LS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLSsKPiArICogIHwgbiB8ICAz MTowIHwgKipEQVRBbioqIC0gb3B0aW9uYWwgZGF0YSAoZGVwZW5kcyBvbiBBQ1RJT04pICAgICAg ICAgICAgICAgIHwKPiArICogICstLS0rLS0tLS0tLSstLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0t LS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLSsKPiArICovCj4gKwo+ICsjZGVm aW5lIEdVQ19IWEdfUkVRVUVTVF9NU0dfTUlOX0xFTgkJR1VDX0hYR19NU0dfTUlOX0xFTgo+ICsj ZGVmaW5lIEdVQ19IWEdfUkVRVUVTVF9NU0dfMF9EQVRBMAkJKDB4ZmZmIDw8IDE2KQo+ICsjZGVm aW5lIEdVQ19IWEdfUkVRVUVTVF9NU0dfMF9BQ1RJT04JCSgweGZmZmYgPDwgMCkKPiArI2RlZmlu ZSBHVUNfSFhHX1JFUVVFU1RfTVNHX25fREFUQW4JCSgweGZmZmZmZmZmIDw8IDApCj4gKwo+ICsv KioKPiArICogRE9DOiBIWEcgRXZlbnQKPiArICoKPiArICogVGhlIGBIWEcgRXZlbnRgXyBtZXNz YWdlIHNob3VsZCBiZSB1c2VkIHRvIGluaXRpYXRlIGFzeW5jaHJvbm91cyBhY3Rpdml0eQo+ICsg KiB0aGF0IGRvZXMgbm90IGludm9sdmVzIGltbWVkaWF0ZSBjb25maXJtYXRpb24gbm9yIGRhdGEu Cj4gKyAqCj4gKyAqIEZvcm1hdCBvZiBAREFUQTAgYW5kIGFsbCBAREFUQW4gZmllbGRzIGRlcGVu ZHMgb24gdGhlIEBBQ1RJT04gY29kZS4KPiArICoKPiArICogLi4gX0hYRyBFdmVudDoKPiArICoK PiArICogICstLS0rLS0tLS0tLSstLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0t LS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLSsKPiArICogIHwgICB8IEJpdHMgIHwgRGVzY3JpcHRp b24gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIHwKPiAr ICogICs9PT0rPT09PT09PSs9PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09 PT09PT09PT09PT09PT09PT09PT09PSsKPiArICogIHwgMCB8ICAgIDMxIHwgT1JJR0lOICAgICAg ICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIHwKPiArICog IHwgICArLS0tLS0tLSstLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0t LS0tLS0tLS0tLS0tLS0tLS0tLSsKPiArICogIHwgICB8IDMwOjI4IHwgVFlQRSA9IEdVQ19IWEdf VFlQRV9FVkVOVF8gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIHwKPiArICogIHwg ICArLS0tLS0tLSstLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0t LS0tLS0tLS0tLS0tLS0tLSsKPiArICogIHwgICB8IDI3OjE2IHwgKipEQVRBMCoqIC0gZXZlbnQg ZGF0YSAoZGVwZW5kcyBvbiBBQ1RJT04pICAgICAgICAgICAgICAgICAgIHwKPiArICogIHwgICAr LS0tLS0tLSstLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0t LS0tLS0tLS0tLS0tLSsKPiArICogIHwgICB8ICAxNTowIHwgKipBQ1RJT04qKiAtIGV2ZW50IGFj dGlvbiBjb2RlICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIHwKPiArICogICstLS0rLS0t LS0tLSstLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0t LS0tLS0tLS0tLSsKPiArICogIHwgMSB8ICAzMTowIHwgKipEQVRBMSoqIC0gb3B0aW9uYWwgZXZl bnQgZGF0YSAoZGVwZW5kcyBvbiBBQ1RJT04pICAgICAgICAgIHwKPiArICogICstLS0rLS0tLS0t LSstLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0t LS0tLS0tLSsKPiArICogIHwuLi58ICAgICAgIHwgICAgICAgICAgICAgICAgICAgICAgICAgICAg ICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIHwKPiArICogICstLS0rLS0tLS0tLSst LS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0t LS0tLSsKPiArICogIHwgbiB8ICAzMTowIHwgKipEQVRBbioqIC0gb3B0aW9uYWwgZXZlbnQgIGRh dGEgKGRlcGVuZHMgb24gQUNUSU9OKSAgICAgICAgIHwKPiArICogICstLS0rLS0tLS0tLSstLS0t LS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0t LSsKPiArICovCj4gKwo+ICsjZGVmaW5lIEdVQ19IWEdfRVZFTlRfTVNHX01JTl9MRU4JCUdVQ19I WEdfTVNHX01JTl9MRU4KPiArI2RlZmluZSBHVUNfSFhHX0VWRU5UX01TR18wX0RBVEEwCQkoMHhm ZmYgPDwgMTYpCj4gKyNkZWZpbmUgR1VDX0hYR19FVkVOVF9NU0dfMF9BQ1RJT04JCSgweGZmZmYg PDwgMCkKPiArI2RlZmluZSBHVUNfSFhHX0VWRU5UX01TR19uX0RBVEFuCQkoMHhmZmZmZmZmZiA8 PCAwKQo+ICsKPiArLyoqCj4gKyAqIERPQzogSFhHIEJ1c3kKPiArICoKPiArICogVGhlIGBIWEcg QnVzeWBfIG1lc3NhZ2UgbWF5IGJlIHVzZWQgdG8gYWNrbm93bGVkZ2UgcmVjZXB0aW9uIG9mIHRo ZSBgSFhHIFJlcXVlc3RgXwo+ICsgKiBtZXNzYWdlIGlmIHRoZSByZWNpcGllbnQgZXhwZWN0cyB0 aGF0IGl0IHByb2Nlc3Npbmcgd2lsbCBiZSBsb25nZXIgdGhhbiBkZWZhdWx0Cj4gKyAqIHRpbWVv dXQuCj4gKyAqCj4gKyAqIFRoZSBAQ09VTlRFUiBmaWVsZCBtYXkgYmUgdXNlZCBhcyBhIHByb2dy ZXNzIGluZGljYXRvci4KPiArICoKPiArICogLi4gX0hYRyBCdXN5Ogo+ICsgKgo+ICsgKiAgKy0t LSstLS0tLS0tKy0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0t LS0tLS0tLS0tLS0tLS0tKwo+ICsgKiAgfCAgIHwgQml0cyAgfCBEZXNjcmlwdGlvbiAgICAgICAg ICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgfAo+ICsgKiAgKz09PSs9 PT09PT09Kz09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09 PT09PT09PT09PT09Kwo+ICsgKiAgfCAwIHwgICAgMzEgfCBPUklHSU4gICAgICAgICAgICAgICAg ICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgfAo+ICsgKiAgfCAgICstLS0t LS0tKy0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0t LS0tLS0tLS0tKwo+ICsgKiAgfCAgIHwgMzA6MjggfCBUWVBFID0gR1VDX0hYR19UWVBFX05PX1JF U1BPTlNFX0JVU1lfICAgICAgICAgICAgICAgICAgICAgICAgfAo+ICsgKiAgfCAgICstLS0tLS0t Ky0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0t LS0tLS0tKwo+ICsgKiAgfCAgIHwgIDI3OjAgfCAqKkNPVU5URVIqKiAtIHByb2dyZXNzIGluZGlj YXRvciAgICAgICAgICAgICAgICAgICAgICAgICAgICAgfAo+ICsgKiAgKy0tLSstLS0tLS0tKy0t LS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0t LS0tKwo+ICsgKi8KPiArCj4gKyNkZWZpbmUgR1VDX0hYR19CVVNZX01TR19MRU4JCQlHVUNfSFhH X01TR19NSU5fTEVOCj4gKyNkZWZpbmUgR1VDX0hYR19CVVNZX01TR18wX0NPVU5URVIJCUdVQ19I WEdfTVNHXzBfQVVYCj4gKwo+ICsvKioKPiArICogRE9DOiBIWEcgUmV0cnkKPiArICoKPiArICog VGhlIGBIWEcgUmV0cnlgXyBtZXNzYWdlIHNob3VsZCBiZSB1c2VkIGJ5IHJlY2lwaWVudCB0byBp bmRpY2F0ZSB0aGF0IHRoZQo+ICsgKiBgSFhHIFJlcXVlc3RgXyBtZXNzYWdlIHdhcyBkcm9wcGVk IGFuZCBpdCBzaG91bGQgYmUgcmVzZW50IGFnYWluLgo+ICsgKgo+ICsgKiBUaGUgQFJFQVNPTiBm aWVsZCBtYXkgYmUgdXNlZCB0byBwcm92aWRlIGFkZGl0aW9uYWwgaW5mb3JtYXRpb24uCj4gKyAq Cj4gKyAqIC4uIF9IWEcgUmV0cnk6Cj4gKyAqCj4gKyAqICArLS0tKy0tLS0tLS0rLS0tLS0tLS0t LS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0rCj4g KyAqICB8ICAgfCBCaXRzICB8IERlc2NyaXB0aW9uICAgICAgICAgICAgICAgICAgICAgICAgICAg ICAgICAgICAgICAgICAgICAgICAgICB8Cj4gKyAqICArPT09Kz09PT09PT0rPT09PT09PT09PT09 PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT0rCj4gKyAq ICB8IDAgfCAgICAzMSB8IE9SSUdJTiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAg ICAgICAgICAgICAgICAgICAgICB8Cj4gKyAqICB8ICAgKy0tLS0tLS0rLS0tLS0tLS0tLS0tLS0t LS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0rCj4gKyAqICB8 ICAgfCAzMDoyOCB8IFRZUEUgPSBHVUNfSFhHX1RZUEVfTk9fUkVTUE9OU0VfUkVUUllfICAgICAg ICAgICAgICAgICAgICAgICB8Cj4gKyAqICB8ICAgKy0tLS0tLS0rLS0tLS0tLS0tLS0tLS0tLS0t LS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0rCj4gKyAqICB8ICAg fCAgMjc6MCB8ICoqUkVBU09OKiogLSByZWFzb24gZm9yIHJldHJ5ICAgICAgICAgICAgICAgICAg ICAgICAgICAgICAgICB8Cj4gKyAqICB8ICAgfCAgICAgICB8ICAtIF9gR1VDX0hYR19SRVRSWV9S RUFTT05fVU5TUEVDSUZJRURgID0gMCAgICAgICAgICAgICAgICAgICB8Cj4gKyAqICArLS0tKy0t LS0tLS0rLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0t LS0tLS0tLS0tLS0rCj4gKyAqLwo+ICsKPiArI2RlZmluZSBHVUNfSFhHX1JFVFJZX01TR19MRU4J CQlHVUNfSFhHX01TR19NSU5fTEVOCj4gKyNkZWZpbmUgR1VDX0hYR19SRVRSWV9NU0dfMF9SRUFT T04JCUdVQ19IWEdfTVNHXzBfQVVYCj4gKyNkZWZpbmUgICBHVUNfSFhHX1JFVFJZX1JFQVNPTl9V TlNQRUNJRklFRAkwdQo+ICsKPiArLyoqCj4gKyAqIERPQzogSFhHIEZhaWx1cmUKPiArICoKPiAr ICogVGhlIGBIWEcgRmFpbHVyZWBfIG1lc3NhZ2Ugc2hhbGwgYmUgdXNlZCBhcyBhIHJlcGx5IHRv IHRoZSBgSFhHIFJlcXVlc3RgXwo+ICsgKiBtZXNzYWdlIHRoYXQgY291bGQgbm90IGJlIHByb2Nl c3NlZCBkdWUgdG8gYW4gZXJyb3IuCj4gKyAqCj4gKyAqIC4uIF9IWEcgRmFpbHVyZToKPiArICoK PiArICogICstLS0rLS0tLS0tLSstLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0t LS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLSsKPiArICogIHwgICB8IEJpdHMgIHwgRGVzY3JpcHRp b24gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIHwKPiAr ICogICs9PT0rPT09PT09PSs9PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09 PT09PT09PT09PT09PT09PT09PT09PSsKPiArICogIHwgMCB8ICAgIDMxIHwgT1JJR0lOICAgICAg ICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIHwKPiArICog IHwgICArLS0tLS0tLSstLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0t LS0tLS0tLS0tLS0tLS0tLS0tLSsKPiArICogIHwgICB8IDMwOjI4IHwgVFlQRSA9IEdVQ19IWEdf VFlQRV9SRVNQT05TRV9GQUlMVVJFXyAgICAgICAgICAgICAgICAgICAgICAgIHwKPiArICogIHwg ICArLS0tLS0tLSstLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0t LS0tLS0tLS0tLS0tLS0tLSsKPiArICogIHwgICB8IDI3OjE2IHwgKipISU5UKiogLSBhZGRpdGlv bmFsIGVycm9yIGhpbnQgICAgICAgICAgICAgICAgICAgICAgICAgICAgIHwKPiArICogIHwgICAr LS0tLS0tLSstLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0t LS0tLS0tLS0tLS0tLSsKPiArICogIHwgICB8ICAxNTowIHwgKipFUlJPUioqIC0gZXJyb3IvcmVz dWx0IGNvZGUgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIHwKPiArICogICstLS0rLS0t LS0tLSstLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0t LS0tLS0tLS0tLSsKPiArICovCj4gKwo+ICsjZGVmaW5lIEdVQ19IWEdfRkFJTFVSRV9NU0dfTEVO CQkJR1VDX0hYR19NU0dfTUlOX0xFTgo+ICsjZGVmaW5lIEdVQ19IWEdfRkFJTFVSRV9NU0dfMF9I SU5UCQkoMHhmZmYgPDwgMTYpCj4gKyNkZWZpbmUgR1VDX0hYR19GQUlMVVJFX01TR18wX0VSUk9S CQkoMHhmZmZmIDw8IDApCj4gKwo+ICsvKioKPiArICogRE9DOiBIWEcgUmVzcG9uc2UKPiArICoK PiArICogVGhlIGBIWEcgUmVzcG9uc2VgXyBtZXNzYWdlIFNIQUxMIGJlIHVzZWQgYXMgYSByZXBs eSB0byB0aGUgYEhYRyBSZXF1ZXN0YF8KPiArICogbWVzc2FnZSB0aGF0IHdhcyBzdWNjZXNzZnVs bHkgcHJvY2Vzc2VkIHdpdGhvdXQgYW4gZXJyb3IuCj4gKyAqCj4gKyAqIC4uIF9IWEcgUmVzcG9u c2U6Cj4gKyAqCj4gKyAqICArLS0tKy0tLS0tLS0rLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0t LS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0rCj4gKyAqICB8ICAgfCBCaXRzICB8 IERlc2NyaXB0aW9uICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAg ICAgICB8Cj4gKyAqICArPT09Kz09PT09PT0rPT09PT09PT09PT09PT09PT09PT09PT09PT09PT09 PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT0rCj4gKyAqICB8IDAgfCAgICAzMSB8IE9S SUdJTiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAg ICB8Cj4gKyAqICB8ICAgKy0tLS0tLS0rLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0t LS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0rCj4gKyAqICB8ICAgfCAzMDoyOCB8IFRZUEUg PSBHVUNfSFhHX1RZUEVfUkVTUE9OU0VfU1VDQ0VTU18gICAgICAgICAgICAgICAgICAgICAgICB8 Cj4gKyAqICB8ICAgKy0tLS0tLS0rLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0t LS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0rCj4gKyAqICB8ICAgfCAgMjc6MCB8ICoqREFUQTAq KiAtIGRhdGEgKGRlcGVuZHMgb24gQUNUSU9OIGZyb20gYEhYRyBSZXF1ZXN0YF8pICAgICB8Cj4g KyAqICArLS0tKy0tLS0tLS0rLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0t LS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0rCj4gKyAqICB8IDEgfCAgMzE6MCB8ICoqREFUQTEqKiAt IGRhdGEgKGRlcGVuZHMgb24gQUNUSU9OIGZyb20gYEhYRyBSZXF1ZXN0YF8pICAgICB8Cj4gKyAq ICArLS0tKy0tLS0tLS0rLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0t LS0tLS0tLS0tLS0tLS0tLS0tLS0rCj4gKyAqICB8Li4ufCAgICAgICB8ICAgICAgICAgICAgICAg ICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICB8Cj4gKyAqICAr LS0tKy0tLS0tLS0rLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0t LS0tLS0tLS0tLS0tLS0tLS0rCj4gKyAqICB8IG4gfCAgMzE6MCB8ICoqREFUQW4qKiAtIGRhdGEg KGRlcGVuZHMgb24gQUNUSU9OIGZyb20gYEhYRyBSZXF1ZXN0YF8pICAgICB8Cj4gKyAqICArLS0t Ky0tLS0tLS0rLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0t LS0tLS0tLS0tLS0tLS0rCj4gKyAqLwo+ICsKPiArI2RlZmluZSBHVUNfSFhHX1JFU1BPTlNFX01T R19NSU5fTEVOCQlHVUNfSFhHX01TR19NSU5fTEVOCj4gKyNkZWZpbmUgR1VDX0hYR19SRVNQT05T RV9NU0dfMF9EQVRBMAkJR1VDX0hYR19NU0dfMF9BVVgKPiArI2RlZmluZSBHVUNfSFhHX1JFU1BP TlNFX01TR19uX0RBVEFuCQkoMHhmZmZmZmZmZiA8PCAwKQo+ICsKPiArLyogZGVwcmVjYXRlZCAq Lwo+ICAjZGVmaW5lIElOVEVMX0dVQ19NU0dfVFlQRV9TSElGVAkyOAo+ICAjZGVmaW5lIElOVEVM X0dVQ19NU0dfVFlQRV9NQVNLCQkoMHhGIDw8IElOVEVMX0dVQ19NU0dfVFlQRV9TSElGVCkKPiAg I2RlZmluZSBJTlRFTF9HVUNfTVNHX0RBVEFfU0hJRlQJMTYKPiAtLSAKPiAyLjI4LjAKPiAKCi0t IApEYW5pZWwgVmV0dGVyClNvZnR3YXJlIEVuZ2luZWVyLCBJbnRlbCBDb3Jwb3JhdGlvbgpodHRw Oi8vYmxvZy5mZndsbC5jaApfX19fX19fX19fX19fX19fX19fX19fX19fX19fX19fX19fX19fX19f X19fX19fXwpJbnRlbC1nZnggbWFpbGluZyBsaXN0CkludGVsLWdmeEBsaXN0cy5mcmVlZGVza3Rv cC5vcmcKaHR0cHM6Ly9saXN0cy5mcmVlZGVza3RvcC5vcmcvbWFpbG1hbi9saXN0aW5mby9pbnRl bC1nZngK