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=-9.8 required=3.0 tests=DKIM_SIGNED,DKIM_VALID, DKIM_VALID_AU,HEADER_FROM_DIFFERENT_DOMAINS,INCLUDES_PATCH,MAILING_LIST_MULTI, SIGNED_OFF_BY,SPF_HELO_NONE,SPF_PASS,URIBL_BLOCKED,USER_AGENT_GIT 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 A46C1C433FF for ; Wed, 14 Aug 2019 18:48:24 +0000 (UTC) Received: from vger.kernel.org (vger.kernel.org [209.132.180.67]) by mail.kernel.org (Postfix) with ESMTP id 7314E21743 for ; Wed, 14 Aug 2019 18:48:24 +0000 (UTC) Authentication-Results: mail.kernel.org; dkim=pass (2048-bit key) header.d=linaro.org header.i=@linaro.org header.b="T9iZEwFJ" Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1729688AbfHNSsV (ORCPT ); Wed, 14 Aug 2019 14:48:21 -0400 Received: from mail-pf1-f195.google.com ([209.85.210.195]:35846 "EHLO mail-pf1-f195.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1729415AbfHNSr2 (ORCPT ); Wed, 14 Aug 2019 14:47:28 -0400 Received: by mail-pf1-f195.google.com with SMTP id w2so3283342pfi.3 for ; Wed, 14 Aug 2019 11:47:27 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=linaro.org; s=google; h=from:to:cc:subject:date:message-id:in-reply-to:references; bh=sfKXX+o4Qp2/I5oLyNwYp5frrb8P6SiEjD+Gvi5BkT0=; b=T9iZEwFJF+TJKY0hHgQxpaN4a7p8bUuNIhxCNxLQu39fiS3b6qpIngIlGx0/PsKPxL 5BhpUZFNY4Y1uicrCiOl/ecaqtix8bpnBrPTriSTl+FU6MvKZhD40K1X9tpi1TJvUPHm ZcAJO5JN/u2+RtuXPVeqCXTc3hi688nlSKe/ziB84VAnL9rED7HxiWWfh4RFYEADZwot SFUn3RzcO/DdUz0dukUuu57PdnIWrfbgtu4pdiouqY8sD6tKNiQFqbIJ2WGGR0Ld88tt +rvamYv9LUD5NWc/6TOtfO5PHTojq78/3MAmbMdtuZTQZHWhgnPjE3bkqg75GhB2aJe5 AbPQ== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:from:to:cc:subject:date:message-id:in-reply-to :references; bh=sfKXX+o4Qp2/I5oLyNwYp5frrb8P6SiEjD+Gvi5BkT0=; b=gyIp49jTKRecI5I32wU7+hs9BymcYtdrRf74k47yoKrdhX3pSoQWeJSLRueCQM3hN4 lmcHWG/PYTE48TdkXLurfAZwp1y0ewiBNsYnpHcZDDhi1Eb+mbC0G14DpzuT+PHHVqOt C3mrcC21/kCPSJP/o2vsYfP3mlGd6x66hRVDNEX3PUlptbGU8AnuMUxR+EOQ305/E3Wm r42r3ZV/ti/QYKvCyrsaBdbqT7LIq+xjPVtJGKT91xOOS21zSc5gcU9dT93dED63+1Et X0GGLxpoCVnD2yGr2/2kHvZL911WZuKM9svShcjcoMBG4ageFQrGZIFge3YivBTADrsX 0gpg== X-Gm-Message-State: APjAAAVM7u2KpHyk2A7YPCpJ1FrpxsC+qDy4lEepRJXQ9KnkXcnIQjy7 W4zVggLx5HoDp5UvD2NTZR746zyY3AQ= X-Google-Smtp-Source: APXvYqyti+/OTVYfzLGL5f/MtTZ6Q0iILK/4POxjmbTxxzDN0spGBwaiT/XdSekW3R43JNlWtf0cCw== X-Received: by 2002:a17:90a:5288:: with SMTP id w8mr1079972pjh.61.1565808446871; Wed, 14 Aug 2019 11:47:26 -0700 (PDT) Received: from localhost.localdomain ([2601:1c2:680:1319:692:26ff:feda:3a81]) by smtp.gmail.com with ESMTPSA id y16sm610855pfc.36.2019.08.14.11.47.25 (version=TLS1_3 cipher=AEAD-AES256-GCM-SHA384 bits=256/256); Wed, 14 Aug 2019 11:47:26 -0700 (PDT) From: John Stultz To: lkml Cc: Xu YiPing , Rongrong Zou , Xinliang Liu , David Airlie , Daniel Vetter , dri-devel , Sam Ravnborg , John Stultz Subject: [RESEND][PATCH v3 13/26] drm: kirin: Reanme dc_ops to kirin_drm_data Date: Wed, 14 Aug 2019 18:46:49 +0000 Message-Id: <20190814184702.54275-14-john.stultz@linaro.org> X-Mailer: git-send-email 2.17.1 In-Reply-To: <20190814184702.54275-1-john.stultz@linaro.org> References: <20190814184702.54275-1-john.stultz@linaro.org> Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org From: Xu YiPing As part of refactoring the kirin driver to better support different hardware revisions, this patch renames the struct kirin_dc_ops to struct kirin_drm_data and cleans up the related variable names. Cc: Rongrong Zou Cc: Xinliang Liu Cc: David Airlie Cc: Daniel Vetter Cc: dri-devel Cc: Sam Ravnborg Reviewed-by: Sam Ravnborg Signed-off-by: Xu YiPing [jstultz: reworded commit message] Signed-off-by: John Stultz --- drivers/gpu/drm/hisilicon/kirin/kirin_drm_ade.c | 2 +- drivers/gpu/drm/hisilicon/kirin/kirin_drm_drv.c | 16 ++++++++-------- drivers/gpu/drm/hisilicon/kirin/kirin_drm_drv.h | 4 ++-- 3 files changed, 11 insertions(+), 11 deletions(-) diff --git a/drivers/gpu/drm/hisilicon/kirin/kirin_drm_ade.c b/drivers/gpu/drm/hisilicon/kirin/kirin_drm_ade.c index 3ad1e290bf58..acae2815eded 100644 --- a/drivers/gpu/drm/hisilicon/kirin/kirin_drm_ade.c +++ b/drivers/gpu/drm/hisilicon/kirin/kirin_drm_ade.c @@ -1055,7 +1055,7 @@ static void ade_drm_cleanup(struct platform_device *pdev) { } -const struct kirin_dc_ops ade_dc_ops = { +struct kirin_drm_data ade_driver_data = { .init = ade_drm_init, .cleanup = ade_drm_cleanup }; diff --git a/drivers/gpu/drm/hisilicon/kirin/kirin_drm_drv.c b/drivers/gpu/drm/hisilicon/kirin/kirin_drm_drv.c index bfe0505ac4a0..60c164623f56 100644 --- a/drivers/gpu/drm/hisilicon/kirin/kirin_drm_drv.c +++ b/drivers/gpu/drm/hisilicon/kirin/kirin_drm_drv.c @@ -28,12 +28,12 @@ #include "kirin_drm_drv.h" -static struct kirin_dc_ops *dc_ops; +static struct kirin_drm_data *driver_data; static int kirin_drm_kms_cleanup(struct drm_device *dev) { drm_kms_helper_poll_fini(dev); - dc_ops->cleanup(to_platform_device(dev->dev)); + driver_data->cleanup(to_platform_device(dev->dev)); drm_mode_config_cleanup(dev); return 0; @@ -67,7 +67,7 @@ static int kirin_drm_kms_init(struct drm_device *dev) kirin_drm_mode_config_init(dev); /* display controller init */ - ret = dc_ops->init(to_platform_device(dev->dev)); + ret = driver_data->init(to_platform_device(dev->dev)); if (ret) goto err_mode_config_cleanup; @@ -98,7 +98,7 @@ static int kirin_drm_kms_init(struct drm_device *dev) err_unbind_all: component_unbind_all(dev->dev, dev); err_dc_cleanup: - dc_ops->cleanup(to_platform_device(dev->dev)); + driver_data->cleanup(to_platform_device(dev->dev)); err_mode_config_cleanup: drm_mode_config_cleanup(dev); @@ -196,8 +196,8 @@ static int kirin_drm_platform_probe(struct platform_device *pdev) struct component_match *match = NULL; struct device_node *remote; - dc_ops = (struct kirin_dc_ops *)of_device_get_match_data(dev); - if (!dc_ops) { + driver_data = (struct kirin_drm_data *)of_device_get_match_data(dev); + if (!driver_data) { DRM_ERROR("failed to get dt id data\n"); return -EINVAL; } @@ -215,13 +215,13 @@ static int kirin_drm_platform_probe(struct platform_device *pdev) static int kirin_drm_platform_remove(struct platform_device *pdev) { component_master_del(&pdev->dev, &kirin_drm_ops); - dc_ops = NULL; + driver_data = NULL; return 0; } static const struct of_device_id kirin_drm_dt_ids[] = { { .compatible = "hisilicon,hi6220-ade", - .data = &ade_dc_ops, + .data = &ade_driver_data, }, { /* end node */ }, }; diff --git a/drivers/gpu/drm/hisilicon/kirin/kirin_drm_drv.h b/drivers/gpu/drm/hisilicon/kirin/kirin_drm_drv.h index d47cbb427979..cd2eaa653db7 100644 --- a/drivers/gpu/drm/hisilicon/kirin/kirin_drm_drv.h +++ b/drivers/gpu/drm/hisilicon/kirin/kirin_drm_drv.h @@ -34,11 +34,11 @@ struct kirin_plane { }; /* display controller init/cleanup ops */ -struct kirin_dc_ops { +struct kirin_drm_data { int (*init)(struct platform_device *pdev); void (*cleanup)(struct platform_device *pdev); }; -extern const struct kirin_dc_ops ade_dc_ops; +extern struct kirin_drm_data ade_driver_data; #endif /* __KIRIN_DRM_DRV_H__ */ -- 2.17.1 From mboxrd@z Thu Jan 1 00:00:00 1970 From: John Stultz Subject: [RESEND][PATCH v3 13/26] drm: kirin: Reanme dc_ops to kirin_drm_data Date: Wed, 14 Aug 2019 18:46:49 +0000 Message-ID: <20190814184702.54275-14-john.stultz@linaro.org> References: <20190814184702.54275-1-john.stultz@linaro.org> Mime-Version: 1.0 Content-Type: text/plain; charset="utf-8" Content-Transfer-Encoding: base64 Return-path: Received: from mail-pf1-x444.google.com (mail-pf1-x444.google.com [IPv6:2607:f8b0:4864:20::444]) by gabe.freedesktop.org (Postfix) with ESMTPS id 7B3E66E7DC for ; Wed, 14 Aug 2019 18:47:27 +0000 (UTC) Received: by mail-pf1-x444.google.com with SMTP id 129so7187521pfa.4 for ; Wed, 14 Aug 2019 11:47:27 -0700 (PDT) In-Reply-To: <20190814184702.54275-1-john.stultz@linaro.org> List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , Errors-To: dri-devel-bounces@lists.freedesktop.org Sender: "dri-devel" To: lkml Cc: Xu YiPing , David Airlie , dri-devel , Xinliang Liu , Rongrong Zou , Sam Ravnborg List-Id: dri-devel@lists.freedesktop.org RnJvbTogWHUgWWlQaW5nIDx4dXlpcGluZ0BoaXNpbGljb24uY29tPgoKQXMgcGFydCBvZiByZWZh Y3RvcmluZyB0aGUga2lyaW4gZHJpdmVyIHRvIGJldHRlciBzdXBwb3J0CmRpZmZlcmVudCBoYXJk d2FyZSByZXZpc2lvbnMsIHRoaXMgcGF0Y2ggcmVuYW1lcyB0aGUKc3RydWN0IGtpcmluX2RjX29w cyB0byBzdHJ1Y3Qga2lyaW5fZHJtX2RhdGEgYW5kIGNsZWFucwp1cCB0aGUgcmVsYXRlZCB2YXJp YWJsZSBuYW1lcy4KCkNjOiBSb25ncm9uZyBab3UgPHpvdXJvbmdyb25nQGdtYWlsLmNvbT4KQ2M6 IFhpbmxpYW5nIExpdSA8ei5saXV4aW5saWFuZ0BoaXNpbGljb24uY29tPgpDYzogRGF2aWQgQWly bGllIDxhaXJsaWVkQGxpbnV4LmllPgpDYzogRGFuaWVsIFZldHRlciA8ZGFuaWVsQGZmd2xsLmNo PgpDYzogZHJpLWRldmVsIDxkcmktZGV2ZWxAbGlzdHMuZnJlZWRlc2t0b3Aub3JnPgpDYzogU2Ft IFJhdm5ib3JnIDxzYW1AcmF2bmJvcmcub3JnPgpSZXZpZXdlZC1ieTogU2FtIFJhdm5ib3JnIDxz YW1AcmF2bmJvcmcub3JnPgpTaWduZWQtb2ZmLWJ5OiBYdSBZaVBpbmcgPHh1eWlwaW5nQGhpc2ls aWNvbi5jb20+Cltqc3R1bHR6OiByZXdvcmRlZCBjb21taXQgbWVzc2FnZV0KU2lnbmVkLW9mZi1i eTogSm9obiBTdHVsdHogPGpvaG4uc3R1bHR6QGxpbmFyby5vcmc+Ci0tLQogZHJpdmVycy9ncHUv ZHJtL2hpc2lsaWNvbi9raXJpbi9raXJpbl9kcm1fYWRlLmMgfCAgMiArLQogZHJpdmVycy9ncHUv ZHJtL2hpc2lsaWNvbi9raXJpbi9raXJpbl9kcm1fZHJ2LmMgfCAxNiArKysrKysrKy0tLS0tLS0t CiBkcml2ZXJzL2dwdS9kcm0vaGlzaWxpY29uL2tpcmluL2tpcmluX2RybV9kcnYuaCB8ICA0ICsr LS0KIDMgZmlsZXMgY2hhbmdlZCwgMTEgaW5zZXJ0aW9ucygrKSwgMTEgZGVsZXRpb25zKC0pCgpk aWZmIC0tZ2l0IGEvZHJpdmVycy9ncHUvZHJtL2hpc2lsaWNvbi9raXJpbi9raXJpbl9kcm1fYWRl LmMgYi9kcml2ZXJzL2dwdS9kcm0vaGlzaWxpY29uL2tpcmluL2tpcmluX2RybV9hZGUuYwppbmRl eCAzYWQxZTI5MGJmNTguLmFjYWUyODE1ZWRlZCAxMDA2NDQKLS0tIGEvZHJpdmVycy9ncHUvZHJt L2hpc2lsaWNvbi9raXJpbi9raXJpbl9kcm1fYWRlLmMKKysrIGIvZHJpdmVycy9ncHUvZHJtL2hp c2lsaWNvbi9raXJpbi9raXJpbl9kcm1fYWRlLmMKQEAgLTEwNTUsNyArMTA1NSw3IEBAIHN0YXRp YyB2b2lkIGFkZV9kcm1fY2xlYW51cChzdHJ1Y3QgcGxhdGZvcm1fZGV2aWNlICpwZGV2KQogewog fQogCi1jb25zdCBzdHJ1Y3Qga2lyaW5fZGNfb3BzIGFkZV9kY19vcHMgPSB7CitzdHJ1Y3Qga2ly aW5fZHJtX2RhdGEgYWRlX2RyaXZlcl9kYXRhID0gewogCS5pbml0ID0gYWRlX2RybV9pbml0LAog CS5jbGVhbnVwID0gYWRlX2RybV9jbGVhbnVwCiB9OwpkaWZmIC0tZ2l0IGEvZHJpdmVycy9ncHUv ZHJtL2hpc2lsaWNvbi9raXJpbi9raXJpbl9kcm1fZHJ2LmMgYi9kcml2ZXJzL2dwdS9kcm0vaGlz aWxpY29uL2tpcmluL2tpcmluX2RybV9kcnYuYwppbmRleCBiZmUwNTA1YWM0YTAuLjYwYzE2NDYy M2Y1NiAxMDA2NDQKLS0tIGEvZHJpdmVycy9ncHUvZHJtL2hpc2lsaWNvbi9raXJpbi9raXJpbl9k cm1fZHJ2LmMKKysrIGIvZHJpdmVycy9ncHUvZHJtL2hpc2lsaWNvbi9raXJpbi9raXJpbl9kcm1f ZHJ2LmMKQEAgLTI4LDEyICsyOCwxMiBAQAogCiAjaW5jbHVkZSAia2lyaW5fZHJtX2Rydi5oIgog Ci1zdGF0aWMgc3RydWN0IGtpcmluX2RjX29wcyAqZGNfb3BzOworc3RhdGljIHN0cnVjdCBraXJp bl9kcm1fZGF0YSAqZHJpdmVyX2RhdGE7CiAKIHN0YXRpYyBpbnQga2lyaW5fZHJtX2ttc19jbGVh bnVwKHN0cnVjdCBkcm1fZGV2aWNlICpkZXYpCiB7CiAJZHJtX2ttc19oZWxwZXJfcG9sbF9maW5p KGRldik7Ci0JZGNfb3BzLT5jbGVhbnVwKHRvX3BsYXRmb3JtX2RldmljZShkZXYtPmRldikpOwor CWRyaXZlcl9kYXRhLT5jbGVhbnVwKHRvX3BsYXRmb3JtX2RldmljZShkZXYtPmRldikpOwogCWRy bV9tb2RlX2NvbmZpZ19jbGVhbnVwKGRldik7CiAKIAlyZXR1cm4gMDsKQEAgLTY3LDcgKzY3LDcg QEAgc3RhdGljIGludCBraXJpbl9kcm1fa21zX2luaXQoc3RydWN0IGRybV9kZXZpY2UgKmRldikK IAlraXJpbl9kcm1fbW9kZV9jb25maWdfaW5pdChkZXYpOwogCiAJLyogZGlzcGxheSBjb250cm9s bGVyIGluaXQgKi8KLQlyZXQgPSBkY19vcHMtPmluaXQodG9fcGxhdGZvcm1fZGV2aWNlKGRldi0+ ZGV2KSk7CisJcmV0ID0gZHJpdmVyX2RhdGEtPmluaXQodG9fcGxhdGZvcm1fZGV2aWNlKGRldi0+ ZGV2KSk7CiAJaWYgKHJldCkKIAkJZ290byBlcnJfbW9kZV9jb25maWdfY2xlYW51cDsKIApAQCAt OTgsNyArOTgsNyBAQCBzdGF0aWMgaW50IGtpcmluX2RybV9rbXNfaW5pdChzdHJ1Y3QgZHJtX2Rl dmljZSAqZGV2KQogZXJyX3VuYmluZF9hbGw6CiAJY29tcG9uZW50X3VuYmluZF9hbGwoZGV2LT5k ZXYsIGRldik7CiBlcnJfZGNfY2xlYW51cDoKLQlkY19vcHMtPmNsZWFudXAodG9fcGxhdGZvcm1f ZGV2aWNlKGRldi0+ZGV2KSk7CisJZHJpdmVyX2RhdGEtPmNsZWFudXAodG9fcGxhdGZvcm1fZGV2 aWNlKGRldi0+ZGV2KSk7CiBlcnJfbW9kZV9jb25maWdfY2xlYW51cDoKIAlkcm1fbW9kZV9jb25m aWdfY2xlYW51cChkZXYpOwogCkBAIC0xOTYsOCArMTk2LDggQEAgc3RhdGljIGludCBraXJpbl9k cm1fcGxhdGZvcm1fcHJvYmUoc3RydWN0IHBsYXRmb3JtX2RldmljZSAqcGRldikKIAlzdHJ1Y3Qg Y29tcG9uZW50X21hdGNoICptYXRjaCA9IE5VTEw7CiAJc3RydWN0IGRldmljZV9ub2RlICpyZW1v dGU7CiAKLQlkY19vcHMgPSAoc3RydWN0IGtpcmluX2RjX29wcyAqKW9mX2RldmljZV9nZXRfbWF0 Y2hfZGF0YShkZXYpOwotCWlmICghZGNfb3BzKSB7CisJZHJpdmVyX2RhdGEgPSAoc3RydWN0IGtp cmluX2RybV9kYXRhICopb2ZfZGV2aWNlX2dldF9tYXRjaF9kYXRhKGRldik7CisJaWYgKCFkcml2 ZXJfZGF0YSkgewogCQlEUk1fRVJST1IoImZhaWxlZCB0byBnZXQgZHQgaWQgZGF0YVxuIik7CiAJ CXJldHVybiAtRUlOVkFMOwogCX0KQEAgLTIxNSwxMyArMjE1LDEzIEBAIHN0YXRpYyBpbnQga2ly aW5fZHJtX3BsYXRmb3JtX3Byb2JlKHN0cnVjdCBwbGF0Zm9ybV9kZXZpY2UgKnBkZXYpCiBzdGF0 aWMgaW50IGtpcmluX2RybV9wbGF0Zm9ybV9yZW1vdmUoc3RydWN0IHBsYXRmb3JtX2RldmljZSAq cGRldikKIHsKIAljb21wb25lbnRfbWFzdGVyX2RlbCgmcGRldi0+ZGV2LCAma2lyaW5fZHJtX29w cyk7Ci0JZGNfb3BzID0gTlVMTDsKKwlkcml2ZXJfZGF0YSA9IE5VTEw7CiAJcmV0dXJuIDA7CiB9 CiAKIHN0YXRpYyBjb25zdCBzdHJ1Y3Qgb2ZfZGV2aWNlX2lkIGtpcmluX2RybV9kdF9pZHNbXSA9 IHsKIAl7IC5jb21wYXRpYmxlID0gImhpc2lsaWNvbixoaTYyMjAtYWRlIiwKLQkgIC5kYXRhID0g JmFkZV9kY19vcHMsCisJICAuZGF0YSA9ICZhZGVfZHJpdmVyX2RhdGEsCiAJfSwKIAl7IC8qIGVu ZCBub2RlICovIH0sCiB9OwpkaWZmIC0tZ2l0IGEvZHJpdmVycy9ncHUvZHJtL2hpc2lsaWNvbi9r aXJpbi9raXJpbl9kcm1fZHJ2LmggYi9kcml2ZXJzL2dwdS9kcm0vaGlzaWxpY29uL2tpcmluL2tp cmluX2RybV9kcnYuaAppbmRleCBkNDdjYmI0Mjc5NzkuLmNkMmVhYTY1M2RiNyAxMDA2NDQKLS0t IGEvZHJpdmVycy9ncHUvZHJtL2hpc2lsaWNvbi9raXJpbi9raXJpbl9kcm1fZHJ2LmgKKysrIGIv ZHJpdmVycy9ncHUvZHJtL2hpc2lsaWNvbi9raXJpbi9raXJpbl9kcm1fZHJ2LmgKQEAgLTM0LDEx ICszNCwxMSBAQCBzdHJ1Y3Qga2lyaW5fcGxhbmUgewogfTsKIAogLyogZGlzcGxheSBjb250cm9s bGVyIGluaXQvY2xlYW51cCBvcHMgKi8KLXN0cnVjdCBraXJpbl9kY19vcHMgeworc3RydWN0IGtp cmluX2RybV9kYXRhIHsKIAlpbnQgKCppbml0KShzdHJ1Y3QgcGxhdGZvcm1fZGV2aWNlICpwZGV2 KTsKIAl2b2lkICgqY2xlYW51cCkoc3RydWN0IHBsYXRmb3JtX2RldmljZSAqcGRldik7CiB9Owog Ci1leHRlcm4gY29uc3Qgc3RydWN0IGtpcmluX2RjX29wcyBhZGVfZGNfb3BzOworZXh0ZXJuIHN0 cnVjdCBraXJpbl9kcm1fZGF0YSBhZGVfZHJpdmVyX2RhdGE7CiAKICNlbmRpZiAvKiBfX0tJUklO X0RSTV9EUlZfSF9fICovCi0tIAoyLjE3LjEKCl9fX19fX19fX19fX19fX19fX19fX19fX19fX19f X19fX19fX19fX19fX19fX19fCmRyaS1kZXZlbCBtYWlsaW5nIGxpc3QKZHJpLWRldmVsQGxpc3Rz LmZyZWVkZXNrdG9wLm9yZwpodHRwczovL2xpc3RzLmZyZWVkZXNrdG9wLm9yZy9tYWlsbWFuL2xp c3RpbmZvL2RyaS1kZXZlbA==