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 7B08FC19759 for ; Thu, 1 Aug 2019 03:45:14 +0000 (UTC) Received: from vger.kernel.org (vger.kernel.org [209.132.180.67]) by mail.kernel.org (Postfix) with ESMTP id 42E91217D6 for ; Thu, 1 Aug 2019 03:45:14 +0000 (UTC) Authentication-Results: mail.kernel.org; dkim=pass (2048-bit key) header.d=linaro.org header.i=@linaro.org header.b="uHlnFrgC" Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1730115AbfHADpN (ORCPT ); Wed, 31 Jul 2019 23:45:13 -0400 Received: from mail-pf1-f196.google.com ([209.85.210.196]:39468 "EHLO mail-pf1-f196.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1729751AbfHADpH (ORCPT ); Wed, 31 Jul 2019 23:45:07 -0400 Received: by mail-pf1-f196.google.com with SMTP id f17so29161706pfn.6 for ; Wed, 31 Jul 2019 20:45:06 -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=FV+Ip5UJVFLvXV2Kbx6mP8jgdekGleioA3N1UoXWC+U=; b=uHlnFrgC8+6Hfx3oZ5a9WhLfAgD+Y92NSQA89mb3ow8hsetvrvjs1DXJqOSilKtF0w TxSk2bWONbISR+w93knaEIZLQF2wPtpRx6eRi7kwtfpEhi4Auw17HwGJv9KybM3hSVoA 0ZhJCRbwtDI6O0HBojX4g880aVI7TWIpvtdkgTOxBglM8ve1niAjB0BH+ZkZ8RQLT93z iP4kqyzWPA/f+w59h08TZL9M4Jw4qGanPUfn1ZYyr2g0fmeCuVvT0NtSP2fw3YhiG43W n0PsKHdzC9QJZ8SqbqGdfq5AKd/juAs/9kGGeqpSMmYrrASeJJs5bu1t/zBs3UbHkryo dLMw== 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=FV+Ip5UJVFLvXV2Kbx6mP8jgdekGleioA3N1UoXWC+U=; b=B0CFj7f0KiOeQIvmM+9CemaCaBvAiLFS/xEgJAZHGABl7ZGFsPEfFy709PMcwjjz4j 6WkwTZaJH5P8p0nOev1HH++mwRnemsJLvNwk1n5nmoIlBFQoV2wXQF8v67LQ5lLFEtos QYm4WKR7j0KReduMAVLpJs1PBNPvTajRphylLOF1sbhqSosSlcG9+mB1ZKbKoEkjv9n2 gHx58igS16upTHulIQ5Wc2hbl0vUpobRCeptF4K+cjiQyz0OoMns1pVoyIuWR+61b7ir D+HOuoPMJ63Jvjs6/VQsOhhHJnOvTWnGfDiepz8C/EV9XiNooJ/5PjM/f8OnyJCc793F xGQQ== X-Gm-Message-State: APjAAAVT/FQXysr5N5gCyuEWLL3m2XmphNPcSeZkIMTFH1O57weqNI0u Hnq3+wajEbBFDqr5fmMzywkec67xB/E= X-Google-Smtp-Source: APXvYqxvh6sg9DNxbgSmyTVWeayZICBhMnV4QBgK8vE6UF4xYdS0IxloUbKEFvIE6TntZDtyx76h2g== X-Received: by 2002:aa7:85d8:: with SMTP id z24mr42260227pfn.218.1564631105631; Wed, 31 Jul 2019 20:45:05 -0700 (PDT) Received: from localhost.localdomain ([2601:1c2:680:1319:692:26ff:feda:3a81]) by smtp.gmail.com with ESMTPSA id h70sm64775674pgc.36.2019.07.31.20.45.03 (version=TLS1_3 cipher=AEAD-AES256-GCM-SHA384 bits=256/256); Wed, 31 Jul 2019 20:45:04 -0700 (PDT) From: John Stultz To: lkml Cc: Xu YiPing , Rongrong Zou , David Airlie , Daniel Vetter , dri-devel , Sam Ravnborg , John Stultz Subject: [PATCH v3 13/26] drm: kirin: Reanme dc_ops to kirin_drm_data Date: Thu, 1 Aug 2019 03:44:26 +0000 Message-Id: <20190801034439.98227-14-john.stultz@linaro.org> X-Mailer: git-send-email 2.17.1 In-Reply-To: <20190801034439.98227-1-john.stultz@linaro.org> References: <20190801034439.98227-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: 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: [PATCH v3 13/26] drm: kirin: Reanme dc_ops to kirin_drm_data Date: Thu, 1 Aug 2019 03:44:26 +0000 Message-ID: <20190801034439.98227-14-john.stultz@linaro.org> References: <20190801034439.98227-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-x441.google.com (mail-pf1-x441.google.com [IPv6:2607:f8b0:4864:20::441]) by gabe.freedesktop.org (Postfix) with ESMTPS id 44AD16E346 for ; Thu, 1 Aug 2019 03:45:06 +0000 (UTC) Received: by mail-pf1-x441.google.com with SMTP id i189so33157256pfg.10 for ; Wed, 31 Jul 2019 20:45:06 -0700 (PDT) In-Reply-To: <20190801034439.98227-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 , Rongrong Zou , Sam Ravnborg List-Id: dri-devel@lists.freedesktop.org RnJvbTogWHUgWWlQaW5nIDx4dXlpcGluZ0BoaXNpbGljb24uY29tPgoKQXMgcGFydCBvZiByZWZh Y3RvcmluZyB0aGUga2lyaW4gZHJpdmVyIHRvIGJldHRlciBzdXBwb3J0CmRpZmZlcmVudCBoYXJk d2FyZSByZXZpc2lvbnMsIHRoaXMgcGF0Y2ggcmVuYW1lcyB0aGUKc3RydWN0IGtpcmluX2RjX29w cyB0byBzdHJ1Y3Qga2lyaW5fZHJtX2RhdGEgYW5kIGNsZWFucwp1cCB0aGUgcmVsYXRlZCB2YXJp YWJsZSBuYW1lcy4KCkNjOiBSb25ncm9uZyBab3UgPHpvdXJvbmdyb25nQGdtYWlsLmNvbT4KQ2M6 IERhdmlkIEFpcmxpZSA8YWlybGllZEBsaW51eC5pZT4KQ2M6IERhbmllbCBWZXR0ZXIgPGRhbmll bEBmZndsbC5jaD4KQ2M6IGRyaS1kZXZlbCA8ZHJpLWRldmVsQGxpc3RzLmZyZWVkZXNrdG9wLm9y Zz4KQ2M6IFNhbSBSYXZuYm9yZyA8c2FtQHJhdm5ib3JnLm9yZz4KUmV2aWV3ZWQtYnk6IFNhbSBS YXZuYm9yZyA8c2FtQHJhdm5ib3JnLm9yZz4KU2lnbmVkLW9mZi1ieTogWHUgWWlQaW5nIDx4dXlp cGluZ0BoaXNpbGljb24uY29tPgpbanN0dWx0ejogcmV3b3JkZWQgY29tbWl0IG1lc3NhZ2VdClNp Z25lZC1vZmYtYnk6IEpvaG4gU3R1bHR6IDxqb2huLnN0dWx0ekBsaW5hcm8ub3JnPgotLS0KIGRy aXZlcnMvZ3B1L2RybS9oaXNpbGljb24va2lyaW4va2lyaW5fZHJtX2FkZS5jIHwgIDIgKy0KIGRy aXZlcnMvZ3B1L2RybS9oaXNpbGljb24va2lyaW4va2lyaW5fZHJtX2Rydi5jIHwgMTYgKysrKysr KystLS0tLS0tLQogZHJpdmVycy9ncHUvZHJtL2hpc2lsaWNvbi9raXJpbi9raXJpbl9kcm1fZHJ2 LmggfCAgNCArKy0tCiAzIGZpbGVzIGNoYW5nZWQsIDExIGluc2VydGlvbnMoKyksIDExIGRlbGV0 aW9ucygtKQoKZGlmZiAtLWdpdCBhL2RyaXZlcnMvZ3B1L2RybS9oaXNpbGljb24va2lyaW4va2ly aW5fZHJtX2FkZS5jIGIvZHJpdmVycy9ncHUvZHJtL2hpc2lsaWNvbi9raXJpbi9raXJpbl9kcm1f YWRlLmMKaW5kZXggM2FkMWUyOTBiZjU4Li5hY2FlMjgxNWVkZWQgMTAwNjQ0Ci0tLSBhL2RyaXZl cnMvZ3B1L2RybS9oaXNpbGljb24va2lyaW4va2lyaW5fZHJtX2FkZS5jCisrKyBiL2RyaXZlcnMv Z3B1L2RybS9oaXNpbGljb24va2lyaW4va2lyaW5fZHJtX2FkZS5jCkBAIC0xMDU1LDcgKzEwNTUs NyBAQCBzdGF0aWMgdm9pZCBhZGVfZHJtX2NsZWFudXAoc3RydWN0IHBsYXRmb3JtX2RldmljZSAq cGRldikKIHsKIH0KIAotY29uc3Qgc3RydWN0IGtpcmluX2RjX29wcyBhZGVfZGNfb3BzID0gewor c3RydWN0IGtpcmluX2RybV9kYXRhIGFkZV9kcml2ZXJfZGF0YSA9IHsKIAkuaW5pdCA9IGFkZV9k cm1faW5pdCwKIAkuY2xlYW51cCA9IGFkZV9kcm1fY2xlYW51cAogfTsKZGlmZiAtLWdpdCBhL2Ry aXZlcnMvZ3B1L2RybS9oaXNpbGljb24va2lyaW4va2lyaW5fZHJtX2Rydi5jIGIvZHJpdmVycy9n cHUvZHJtL2hpc2lsaWNvbi9raXJpbi9raXJpbl9kcm1fZHJ2LmMKaW5kZXggYmZlMDUwNWFjNGEw Li42MGMxNjQ2MjNmNTYgMTAwNjQ0Ci0tLSBhL2RyaXZlcnMvZ3B1L2RybS9oaXNpbGljb24va2ly aW4va2lyaW5fZHJtX2Rydi5jCisrKyBiL2RyaXZlcnMvZ3B1L2RybS9oaXNpbGljb24va2lyaW4v a2lyaW5fZHJtX2Rydi5jCkBAIC0yOCwxMiArMjgsMTIgQEAKIAogI2luY2x1ZGUgImtpcmluX2Ry bV9kcnYuaCIKIAotc3RhdGljIHN0cnVjdCBraXJpbl9kY19vcHMgKmRjX29wczsKK3N0YXRpYyBz dHJ1Y3Qga2lyaW5fZHJtX2RhdGEgKmRyaXZlcl9kYXRhOwogCiBzdGF0aWMgaW50IGtpcmluX2Ry bV9rbXNfY2xlYW51cChzdHJ1Y3QgZHJtX2RldmljZSAqZGV2KQogewogCWRybV9rbXNfaGVscGVy X3BvbGxfZmluaShkZXYpOwotCWRjX29wcy0+Y2xlYW51cCh0b19wbGF0Zm9ybV9kZXZpY2UoZGV2 LT5kZXYpKTsKKwlkcml2ZXJfZGF0YS0+Y2xlYW51cCh0b19wbGF0Zm9ybV9kZXZpY2UoZGV2LT5k ZXYpKTsKIAlkcm1fbW9kZV9jb25maWdfY2xlYW51cChkZXYpOwogCiAJcmV0dXJuIDA7CkBAIC02 Nyw3ICs2Nyw3IEBAIHN0YXRpYyBpbnQga2lyaW5fZHJtX2ttc19pbml0KHN0cnVjdCBkcm1fZGV2 aWNlICpkZXYpCiAJa2lyaW5fZHJtX21vZGVfY29uZmlnX2luaXQoZGV2KTsKIAogCS8qIGRpc3Bs YXkgY29udHJvbGxlciBpbml0ICovCi0JcmV0ID0gZGNfb3BzLT5pbml0KHRvX3BsYXRmb3JtX2Rl dmljZShkZXYtPmRldikpOworCXJldCA9IGRyaXZlcl9kYXRhLT5pbml0KHRvX3BsYXRmb3JtX2Rl dmljZShkZXYtPmRldikpOwogCWlmIChyZXQpCiAJCWdvdG8gZXJyX21vZGVfY29uZmlnX2NsZWFu dXA7CiAKQEAgLTk4LDcgKzk4LDcgQEAgc3RhdGljIGludCBraXJpbl9kcm1fa21zX2luaXQoc3Ry dWN0IGRybV9kZXZpY2UgKmRldikKIGVycl91bmJpbmRfYWxsOgogCWNvbXBvbmVudF91bmJpbmRf YWxsKGRldi0+ZGV2LCBkZXYpOwogZXJyX2RjX2NsZWFudXA6Ci0JZGNfb3BzLT5jbGVhbnVwKHRv X3BsYXRmb3JtX2RldmljZShkZXYtPmRldikpOworCWRyaXZlcl9kYXRhLT5jbGVhbnVwKHRvX3Bs YXRmb3JtX2RldmljZShkZXYtPmRldikpOwogZXJyX21vZGVfY29uZmlnX2NsZWFudXA6CiAJZHJt X21vZGVfY29uZmlnX2NsZWFudXAoZGV2KTsKIApAQCAtMTk2LDggKzE5Niw4IEBAIHN0YXRpYyBp bnQga2lyaW5fZHJtX3BsYXRmb3JtX3Byb2JlKHN0cnVjdCBwbGF0Zm9ybV9kZXZpY2UgKnBkZXYp CiAJc3RydWN0IGNvbXBvbmVudF9tYXRjaCAqbWF0Y2ggPSBOVUxMOwogCXN0cnVjdCBkZXZpY2Vf bm9kZSAqcmVtb3RlOwogCi0JZGNfb3BzID0gKHN0cnVjdCBraXJpbl9kY19vcHMgKilvZl9kZXZp Y2VfZ2V0X21hdGNoX2RhdGEoZGV2KTsKLQlpZiAoIWRjX29wcykgeworCWRyaXZlcl9kYXRhID0g KHN0cnVjdCBraXJpbl9kcm1fZGF0YSAqKW9mX2RldmljZV9nZXRfbWF0Y2hfZGF0YShkZXYpOwor CWlmICghZHJpdmVyX2RhdGEpIHsKIAkJRFJNX0VSUk9SKCJmYWlsZWQgdG8gZ2V0IGR0IGlkIGRh dGFcbiIpOwogCQlyZXR1cm4gLUVJTlZBTDsKIAl9CkBAIC0yMTUsMTMgKzIxNSwxMyBAQCBzdGF0 aWMgaW50IGtpcmluX2RybV9wbGF0Zm9ybV9wcm9iZShzdHJ1Y3QgcGxhdGZvcm1fZGV2aWNlICpw ZGV2KQogc3RhdGljIGludCBraXJpbl9kcm1fcGxhdGZvcm1fcmVtb3ZlKHN0cnVjdCBwbGF0Zm9y bV9kZXZpY2UgKnBkZXYpCiB7CiAJY29tcG9uZW50X21hc3Rlcl9kZWwoJnBkZXYtPmRldiwgJmtp cmluX2RybV9vcHMpOwotCWRjX29wcyA9IE5VTEw7CisJZHJpdmVyX2RhdGEgPSBOVUxMOwogCXJl dHVybiAwOwogfQogCiBzdGF0aWMgY29uc3Qgc3RydWN0IG9mX2RldmljZV9pZCBraXJpbl9kcm1f ZHRfaWRzW10gPSB7CiAJeyAuY29tcGF0aWJsZSA9ICJoaXNpbGljb24saGk2MjIwLWFkZSIsCi0J ICAuZGF0YSA9ICZhZGVfZGNfb3BzLAorCSAgLmRhdGEgPSAmYWRlX2RyaXZlcl9kYXRhLAogCX0s CiAJeyAvKiBlbmQgbm9kZSAqLyB9LAogfTsKZGlmZiAtLWdpdCBhL2RyaXZlcnMvZ3B1L2RybS9o aXNpbGljb24va2lyaW4va2lyaW5fZHJtX2Rydi5oIGIvZHJpdmVycy9ncHUvZHJtL2hpc2lsaWNv bi9raXJpbi9raXJpbl9kcm1fZHJ2LmgKaW5kZXggZDQ3Y2JiNDI3OTc5Li5jZDJlYWE2NTNkYjcg MTAwNjQ0Ci0tLSBhL2RyaXZlcnMvZ3B1L2RybS9oaXNpbGljb24va2lyaW4va2lyaW5fZHJtX2Ry di5oCisrKyBiL2RyaXZlcnMvZ3B1L2RybS9oaXNpbGljb24va2lyaW4va2lyaW5fZHJtX2Rydi5o CkBAIC0zNCwxMSArMzQsMTEgQEAgc3RydWN0IGtpcmluX3BsYW5lIHsKIH07CiAKIC8qIGRpc3Bs YXkgY29udHJvbGxlciBpbml0L2NsZWFudXAgb3BzICovCi1zdHJ1Y3Qga2lyaW5fZGNfb3BzIHsK K3N0cnVjdCBraXJpbl9kcm1fZGF0YSB7CiAJaW50ICgqaW5pdCkoc3RydWN0IHBsYXRmb3JtX2Rl dmljZSAqcGRldik7CiAJdm9pZCAoKmNsZWFudXApKHN0cnVjdCBwbGF0Zm9ybV9kZXZpY2UgKnBk ZXYpOwogfTsKIAotZXh0ZXJuIGNvbnN0IHN0cnVjdCBraXJpbl9kY19vcHMgYWRlX2RjX29wczsK K2V4dGVybiBzdHJ1Y3Qga2lyaW5fZHJtX2RhdGEgYWRlX2RyaXZlcl9kYXRhOwogCiAjZW5kaWYg LyogX19LSVJJTl9EUk1fRFJWX0hfXyAqLwotLSAKMi4xNy4xCgpfX19fX19fX19fX19fX19fX19f X19fX19fX19fX19fX19fX19fX19fX19fX19fXwpkcmktZGV2ZWwgbWFpbGluZyBsaXN0CmRyaS1k ZXZlbEBsaXN0cy5mcmVlZGVza3RvcC5vcmcKaHR0cHM6Ly9saXN0cy5mcmVlZGVza3RvcC5vcmcv bWFpbG1hbi9saXN0aW5mby9kcmktZGV2ZWw=