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=-17.4 required=3.0 tests=BAYES_00,DKIMWL_WL_HIGH, DKIM_SIGNED,DKIM_VALID,INCLUDES_CR_TRAILER,INCLUDES_PATCH,MAILING_LIST_MULTI, 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 303FCC49EA5 for ; Thu, 24 Jun 2021 22:55:52 +0000 (UTC) Received: from bombadil.infradead.org (bombadil.infradead.org [198.137.202.133]) (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 EFCF56023D for ; Thu, 24 Jun 2021 22:55:51 +0000 (UTC) DMARC-Filter: OpenDMARC Filter v1.3.2 mail.kernel.org EFCF56023D Authentication-Results: mail.kernel.org; dmarc=fail (p=none dis=none) header.from=kernel.org Authentication-Results: mail.kernel.org; spf=none smtp.mailfrom=linux-arm-kernel-bounces+linux-arm-kernel=archiver.kernel.org@lists.infradead.org DKIM-Signature: v=1; a=rsa-sha256; q=dns/txt; c=relaxed/relaxed; d=lists.infradead.org; s=bombadil.20210309; h=Sender: Content-Transfer-Encoding:Content-Type:List-Subscribe:List-Help:List-Post: List-Archive:List-Unsubscribe:List-Id:MIME-Version:References:In-Reply-To: Message-Id:Date:Subject:Cc:To:From:Reply-To:Content-ID:Content-Description: Resent-Date:Resent-From:Resent-Sender:Resent-To:Resent-Cc:Resent-Message-ID: List-Owner; bh=uKTKoHcXWIv6m/rcmmWPGlCk6hVeYV1tghTiHOm0FVg=; b=yci4iqvPM9GrPy XDil0ZN/DqYW3g2T/9AEuaB41SMRD6iy792Girhy8pCRlYczG7Hvq4iZceYh8/DjEpWAG+4OX+idg 7RoIdGsJUAXKerCOrtW95HFJJolJFUNbVVWpicpgPXEsOSBaA8D0sFJpO4aSV7XlHm6Wp4xkzAQd3 LOhaszjJy5SlGl49laU3bB9UJKbpSuo9oYLl0XZdJEBa3XgcLVo0xkrojOuNgeCd8n1sfQNtGkHUz 7hO83Rt+p0Ca0+anMqlD79hHObSz++upI/oPyR0MLHBKkP2qLkrrjdabwvInobQ5gmXgwLABZXl3u WUy04qI4v/xPhI/u96WA==; Received: from localhost ([::1] helo=bombadil.infradead.org) by bombadil.infradead.org with esmtp (Exim 4.94.2 #2 (Red Hat Linux)) id 1lwYEN-00GeJq-Dq; Thu, 24 Jun 2021 22:53:55 +0000 Received: from mail.kernel.org ([198.145.29.99]) by bombadil.infradead.org with esmtps (Exim 4.94.2 #2 (Red Hat Linux)) id 1lwYAc-00Gckh-Mv for linux-arm-kernel@lists.infradead.org; Thu, 24 Jun 2021 22:50:04 +0000 Received: by mail.kernel.org (Postfix) with ESMTPSA id 49D3360FEA; Thu, 24 Jun 2021 22:50:02 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=k20201202; t=1624575002; bh=xTrrqW1Uk9bDS1dpnf+ybK7Bd2bh4r1eXAeTLx4nDb8=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=eeqewRWYddKMw+HxnBY/cs/J1UWgxvEqcMgDJnomJbaThThRUBodNgYGF+Ku2vijQ dFJG6OxAPFjFOCQXuQso3MHYiS2TFw7g9rnoxumeuORDCZ0aYnjJI+lb4bENAfBFLd FRJ5H5+bg5CuTrN/i3vecPJcZS7Hn8uBPObzKMlG5Oe5QYVwcq5MrQwEIhBAyu7UPf xgcOHHGjYlXXZUQ+hEbopFJ8fzPkUDtuSdZHt5tZczCsQTYERJTYKb73WgVkXl4Vtd i4cCd1a3Hyb1iJa/3SljRvYzY7FeQby6nvPH0Lc7COaNC8AfC3kKO9JbtZMKEvVHJU IOaw2uEdlJdTA== Received: by pali.im (Postfix) id 05B0D8A3; Fri, 25 Jun 2021 00:50:01 +0200 (CEST) From: =?UTF-8?q?Pali=20Roh=C3=A1r?= To: Michael Turquette , Stephen Boyd , Rob Herring , Greg Kroah-Hartman Cc: Andrew Lunn , Gregory Clement , Sebastian Hesselbarth , Vladimir Vid , =?UTF-8?q?Marek=20Beh=C3=BAn?= , linux-clk@vger.kernel.org, linux-serial@vger.kernel.org, linux-kernel@vger.kernel.org, linux-arm-kernel@lists.infradead.org Subject: [PATCH 10/10] serial: mvebu-uart: implement support for baudrates higher than 230400 Date: Fri, 25 Jun 2021 00:49:09 +0200 Message-Id: <20210624224909.6350-11-pali@kernel.org> X-Mailer: git-send-email 2.20.1 In-Reply-To: <20210624224909.6350-1-pali@kernel.org> References: <20210624224909.6350-1-pali@kernel.org> MIME-Version: 1.0 X-CRM114-Version: 20100106-BlameMichelson ( TRE 0.8.0 (BSD) ) MR-646709E3 X-CRM114-CacheID: sfid-20210624_155002_841478_340D23FA X-CRM114-Status: GOOD ( 24.09 ) X-BeenThere: linux-arm-kernel@lists.infradead.org X-Mailman-Version: 2.1.34 Precedence: list List-Id: List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , Content-Type: text/plain; charset="utf-8" Content-Transfer-Encoding: base64 Sender: "linux-arm-kernel" Errors-To: linux-arm-kernel-bounces+linux-arm-kernel=archiver.kernel.org@lists.infradead.org VGhpcyBjaGFuZ2UgaW1wbGVtZW50cyBzaW1wbGUgdXNhZ2Ugb2YgZnJhY3Rpb25hbCBkaXZpc29y LiBXaGVuIG1haW4KZGl2aXNvciBEIGlzIHRvbyBsYXJnZSB0byByZXByZXNlbnQgcmVxdWVzdGVk IGJhdWRyYXRlIHRoZW4gdXNlIGRpdmlzb3IgTQpmcm9tIGZyYWN0aW9uYWwgZGl2aXNvciBmZWF0 dXJlLiBBbGwgdGhlIE0gcHJlc2NhbGVycyBhcmUgc2V0IHRvIHNhbWUgYW5kCm1heGltYWwgdmFs dWUgNjMsIHNvIGZyYWN0aW9uYWwgcGFydCBpcyBub3QgdXNlZCBhdCBhbGwuCgpUZXN0cyBzaG93 ZWQgdGhhdCBVQVJUIGF0IDE1MDAwMDAgYmF1ZHJhdGUgdmlhIHRoaXMgY29uZmlndXJhdGlvbiBp cyBzdGFibGUKYW5kIHVzYWJsZS4gU28gdGhlcmUgaXMgbm8gbmVlZCB0byBpbXBsZW1lbnQgY29t cGxpY2F0ZWQgY2FsY3VsYXRpb24gb2YKZnJhY3Rpb25hbCBjb2VmZmljaWVudHMgeWV0LgoKVG8g dXNlIHRoaXMgZmVhdHVyZSB3aXRoIGhpZ2hlciBiYXVkcmF0ZXMsIGl0IGlzIHJlcXVpcmVkIHRv IHVzZSBVQVJUIGNsb2NrCnByb3ZpZGVkIGJ5IFVBUlQgY2xvY2sgZHJpdmVyLiBEZWZhdWx0IGJv b3QgeHRhbCBjbG9jayBpcyBub3QgY2FwYWJsZSBvZgpoaWdoZXIgYmF1ZHJhdGVzIGFuZCB0aGlz IGNoYW5nZSBhbHNvIGNvbnRhaW5zIGNvZGUgZm9yIGRldGVybWluaW5nIHVwcGVyCmxpbWl0IG9m IHBvc3NpYmxlIGJhdWRyYXRlLgoKU2lnbmVkLW9mZi1ieTogUGFsaSBSb2jDoXIgPHBhbGlAa2Vy bmVsLm9yZz4KLS0tCiBkcml2ZXJzL3R0eS9zZXJpYWwvbXZlYnUtdWFydC5jIHwgNzkgKysrKysr KysrKysrKysrKysrKysrKysrKystLS0tLS0tCiAxIGZpbGUgY2hhbmdlZCwgNjIgaW5zZXJ0aW9u cygrKSwgMTcgZGVsZXRpb25zKC0pCgpkaWZmIC0tZ2l0IGEvZHJpdmVycy90dHkvc2VyaWFsL212 ZWJ1LXVhcnQuYyBiL2RyaXZlcnMvdHR5L3NlcmlhbC9tdmVidS11YXJ0LmMKaW5kZXggZTUxYTg0 YmUxOTM5Li4zMzczY2U2MGM4YzAgMTAwNjQ0Ci0tLSBhL2RyaXZlcnMvdHR5L3NlcmlhbC9tdmVi dS11YXJ0LmMKKysrIGIvZHJpdmVycy90dHkvc2VyaWFsL212ZWJ1LXVhcnQuYwpAQCAtOTgsNiAr OTgsNyBAQAogI2RlZmluZSBVQVJUX09TQU1QCQkweDE0CiAjZGVmaW5lICBPU0FNUF9ERUZBVUxU X0RJVklTT1IJMTYKICNkZWZpbmUgIE9TQU1QX0RJVklTT1JTX01BU0sJMHgzRjNGM0YzRgorI2Rl ZmluZSAgT1NBTVBfTUFYX0RJVklTT1IJNjMKIAogI2RlZmluZSBNVkVCVV9OUl9VQVJUUwkJMgog CkBAIC00NzgsMTggKzQ3OSw1OSBAQCBzdGF0aWMgaW50IG12ZWJ1X3VhcnRfYmF1ZF9yYXRlX3Nl dChzdHJ1Y3QgdWFydF9wb3J0ICpwb3J0LCB1bnNpZ25lZCBpbnQgYmF1ZCkKIAkJcmV0dXJuIC1F T1BOT1RTVVBQOwogCiAJLyoKLQkgKiBUaGUgYmF1ZHJhdGUgaXMgZGVyaXZlZCBmcm9tIHRoZSBV QVJUIGNsb2NrIHRoYW5rcyB0byB0d28gZGl2aXNvcnM6Ci0JICogICA+IEQgKCJiYXVkIGdlbmVy YXRvciIpOiBjYW4gZGl2aWRlIHRoZSBjbG9jayBmcm9tIDIgdG8gMl4xMCAtIDEuCi0JICogICA+ IE0gKCJmcmFjdGlvbmFsIGRpdmlzb3IiKTogYWxsb3dzIGEgYmV0dGVyIGFjY3VyYWN5IGZvcgot CSAqICAgICBiYXVkcmF0ZXMgaGlnaGVyIHRoYW4gMjMwNDAwLgorCSAqIFRoZSBiYXVkcmF0ZSBp cyBkZXJpdmVkIGZyb20gdGhlIFVBUlQgY2xvY2sgdGhhbmtzIHRvIGRpdmlzb3JzOgorCSAqICAg PiBkMSAqIGQyICgiVEJHIGRpdmlzb3JzIik6IGNhbiBkaXZpZGUgb25seSBUQkcgY2xvY2sgZnJv bSAxIHRvIDYKKwkgKiAgID4gRCAoImJhdWQgZ2VuZXJhdG9yIik6IGNhbiBkaXZpZGUgdGhlIGNs b2NrIGZyb20gMSB0byAxMDIzCisJICogICA+IE0gKCJmcmFjdGlvbmFsIGRpdmlzb3IiKTogYWxs b3dzIGEgYmV0dGVyIGFjY3VyYWN5IChmcm9tIDEgdG8gNjMpCiAJICoKLQkgKiBBcyB0aGUgZGVy aXZhdGlvbiBvZiBNIGlzIHJhdGhlciBjb21wbGljYXRlZCwgdGhlIGNvZGUgc3RpY2tzIHRvIGl0 cwotCSAqIGRlZmF1bHQgdmFsdWUgKHgxNikgd2hlbiBhbGwgdGhlIHByZXNjYWxlcnMgYXJlIHpl cm9lZCwgYW5kIG9ubHkKLQkgKiBtYWtlcyB1c2Ugb2YgRCB0byBjb25maWd1cmUgdGhlIGRlc2ly ZWQgYmF1ZHJhdGUuCisJICogRXhhY3QgZm9ybXVsYXMgZm9yIGNhbGN1bGF0aW5nIGJhdWRyYXRl OgorCSAqCisJICogd2l0aCBkZWZhdWx0IHgxNiBzY2hlbWU6CisJICogICBiYXVkcmF0ZSA9IHh0 YWwgLyAoZCAqIDE2KQorCSAqICAgYmF1ZHJhdGUgPSB0YmcgLyAoZDEgKiBkMiAqIGQgKiAxNikK KwkgKgorCSAqIHdpdGggZnJhY3Rpb25hbCBkaXZpc29yOgorCSAqICAgYmF1ZHJhdGUgPSAxMCAq IHh0YWwgLyAoZCAqICgzICogKG0xICsgbTIpICsgMiAqIChtMyArIG00KSkpCisJICogICBiYXVk cmF0ZSA9IDEwICogdGJnIC8gKGQxKmQyICogZCAqICgzICogKG0xICsgbTIpICsgMiAqIChtMyAr IG00KSkpCisJICoKKwkgKiBPdmVyc2FtcGxpbmcgdmFsdWU6CisJICogICBvc2FtcCA9IChtMSA8 PCAwKSB8IChtMiA8PCA4KSB8IChtMyA8PCAxNikgfCAobTQgPDwgMjQpOworCSAqCisJICogV2hl cmUgbTEgY29udHJvbHMgbnVtYmVyIG9mIGNsb2NrIGN5Y2xlcyBwZXIgYml0IGZvciBiaXRzIDEs MiwzOworCSAqIG0yIGZvciBiaXRzIDQsNSw2OyBtMyBmb3IgYml0cyA3LDggYW5kIG00IGZvciBi aXRzIDksMTAuCisJICoKKwkgKiBUbyBzaW1wbGlmeSBiYXVkcmF0ZSBzZXR1cCBzZXQgYWxsIHRo ZSBNIHByZXNjYWxlcnMgdG8gc2FtZSB2YWx1ZS4KKwkgKiBGb3IgOTYwMCBiYXVkcmF0ZSBhbmQg aGlnaGVyIGl0IGlzIGVub3VnaCB0byB1c2UganVzdCBkZWZhdWx0ICh4MTYpCisJICogZGl2aXNv ciBvciBmcmFjdGlvbmFsIGRpdmlzb3Igd2l0aCBNID0gNjMsIHNvIHRoZXJlIGlzIG5vIG5lZWQg dG8KKwkgKiB1c2UgcmVhbCBmcmFjdGlvbmFsIHN1cHBvcnQgKHdoZW4gdGhlIE0gcHJlc2NhbGVy cyBhcmUgbm90IGVxdWFsKS4KKwkgKgorCSAqIFdoZW4gYWxsIHRoZSBNIHByZXNjYWxlcnMgYXJl IHplcm9lZCB0aGVuIGRlZmF1bHQgKHgxNikgZGl2aXNvciBpcworCSAqIHVzZWQuIERlZmF1bHQg eDE2IHNjaGVtZSBpcyBtb3JlIHN0YWJsZSB0aGFuIE0gKGZyYWN0aW9uYWwgZGl2aXNvciksCisJ ICogc28gdXNlIE0gb25seSB3aGVuIEQgZGl2aXNvciBpcyBub3QgZW5vdWdoIHRvIGRlcml2YXRl IGJhdWRyYXRlLgorCSAqCisJICogTWVtYmVyIHBvcnQtPnVhcnRjbGsgaXMgZWl0aGVyIHh0YWwg Y2xvY2sgcmF0ZSBvciBUQkcgY2xvY2sgcmF0ZQorCSAqIGRpdmlkZWQgYnkgKGQxICogZDIpLiBT byBVQVJUIGNsb2NrIGRyaXZlciBhbHJlYWR5IHNldHMgZDEgYW5kIGQyCisJICogZGl2aXNvcnMg YW5kIFVBUlQgZHJpdmVyIGNhbm5vdCBjaGFuZ2UgdGhlbS4gTW9yZW92ZXIgdGhleSBhcmUKKwkg KiBzaGFyZWQgd2l0aCBib3RoIFVBUlRzLgogCSAqLworCiAJbV9kaXZpc29yID0gT1NBTVBfREVG QVVMVF9ESVZJU09SOwogCWRfZGl2aXNvciA9IERJVl9ST1VORF9DTE9TRVNUKHBvcnQtPnVhcnRj bGssIGJhdWQgKiBtX2Rpdmlzb3IpOwogCisJaWYgKGRfZGl2aXNvciA+IEJSRFZfQkFVRF9NQVgp IHsKKwkJLyoKKwkJICogRXhwZXJpbWVudHMgc2hvd2VkIHRoYXQgc21hbGwgTSBkaXZpc29ycyBh cmUgdW5zdGFibGUuCisJCSAqIFNvIHVzZSBtYXhpbWFsIHBvc3NpYmxlIE0gPSA2MyBhbmQgY2Fs Y3VsYXRlIEQgZGl2aXNvci4KKwkJICovCisJCW1fZGl2aXNvciA9IE9TQU1QX01BWF9ESVZJU09S OworCQlkX2Rpdmlzb3IgPSBESVZfUk9VTkRfQ0xPU0VTVChwb3J0LT51YXJ0Y2xrLCBiYXVkICog bV9kaXZpc29yKTsKKwl9CisKKwlpZiAoZF9kaXZpc29yIDwgMSkKKwkJZF9kaXZpc29yID0gMTsK KwllbHNlIGlmIChkX2Rpdmlzb3IgPiBCUkRWX0JBVURfTUFYKQorCQlkX2Rpdmlzb3IgPSBCUkRW X0JBVURfTUFYOworCiAJc3Bpbl9sb2NrX2lycXNhdmUoJm12ZWJ1X3VhcnRfbG9jaywgZmxhZ3Mp OwogCWJyZHYgPSByZWFkbChwb3J0LT5tZW1iYXNlICsgVUFSVF9CUkRWKTsKIAlicmR2ICY9IH5C UkRWX0JBVURfTUFTSzsKQEAgLTQ5OSw2ICs1NDEsOSBAQCBzdGF0aWMgaW50IG12ZWJ1X3VhcnRf YmF1ZF9yYXRlX3NldChzdHJ1Y3QgdWFydF9wb3J0ICpwb3J0LCB1bnNpZ25lZCBpbnQgYmF1ZCkK IAogCW9zYW1wID0gcmVhZGwocG9ydC0+bWVtYmFzZSArIFVBUlRfT1NBTVApOwogCW9zYW1wICY9 IH5PU0FNUF9ESVZJU09SU19NQVNLOworCWlmIChtX2Rpdmlzb3IgIT0gT1NBTVBfREVGQVVMVF9E SVZJU09SKQorCQlvc2FtcCB8PSAobV9kaXZpc29yIDw8IDApIHwgKG1fZGl2aXNvciA8PCA4KSB8 CisJCQkobV9kaXZpc29yIDw8IDE2KSB8IChtX2Rpdmlzb3IgPDwgMjQpOwogCXdyaXRlbChvc2Ft cCwgcG9ydC0+bWVtYmFzZSArIFVBUlRfT1NBTVApOwogCiAJcmV0dXJuIDA7CkBAIC01MjgsMTQg KzU3MywxNCBAQCBzdGF0aWMgdm9pZCBtdmVidV91YXJ0X3NldF90ZXJtaW9zKHN0cnVjdCB1YXJ0 X3BvcnQgKnBvcnQsCiAJCXBvcnQtPmlnbm9yZV9zdGF0dXNfbWFzayB8PSBTVEFUX1JYX1JEWShw b3J0KSB8IFNUQVRfQlJLX0VSUjsKIAogCS8qCi0JICogTWF4aW1hbCBkaXZpc29yIGlzIDEwMjMg KiAxNiB3aGVuIHVzaW5nIGRlZmF1bHQgKHgxNikgc2NoZW1lLgotCSAqIE1heGltdW0gYWNoaWV2 YWJsZSBmcmVxdWVuY3kgd2l0aCBzaW1wbGUgYmF1ZHJhdGUgZGl2aXNvciBpcyAyMzA0MDAuCi0J ICogU2luY2UgdGhlIGVycm9yIHBlciBiaXQgZnJhbWUgd291bGQgYmUgb2YgbW9yZSB0aGFuIDE1 JSwgYWNoaWV2aW5nCi0JICogaGlnaGVyIGZyZXF1ZW5jaWVzIHdvdWxkIHJlcXVpcmUgdG8gaW1w bGVtZW50IHRoZSBmcmFjdGlvbmFsIGRpdmlzb3IKLQkgKiBmZWF0dXJlLgorCSAqIE1heGltYWwg ZGl2aXNvciBpcyAxMDIzIGFuZCBtYXhpbWFsIGZyYWN0aW9uYWwgZGl2aXNvciBpcyA2My4gQW5k CisJICogZXhwZXJpbWVudHMgc2hvd2VkIHRoYXQgYmF1ZHJhdGVzIGFib3ZlIDEvODAgb2YgYmFz ZSBjbG9jayBhcmUgbm90CisJICogc3RhYmxlIGFuZCB1c2FibGUuIFNvIGRpc2FsbG93IGJhdWRy YXRlIGFib3ZlIDEvODAgb2YgdGhlIGJhc2UgY2xvY2suCisJICogV2hlbiBwb3J0LT51YXJ0Y2xr IGlzIG5vdCBhdmFpbGFibGUgdGhlbiBtdmVidV91YXJ0X2JhdWRfcmF0ZV9zZXQoKQorCSAqIGZh aWxzIHNvIHZhbHVlcyBtaW5fYmF1ZCBhbmQgbWF4X2JhdWQgaW4gdGhpcyBjYXNlIGRvZXMgbm90 IG1hdHRlci4KIAkgKi8KLQltaW5fYmF1ZCA9IERJVl9ST1VORF9VUChwb3J0LT51YXJ0Y2xrLCAx MDIzICogMTYpOwotCW1heF9iYXVkID0gMjMwNDAwOworCW1pbl9iYXVkID0gRElWX1JPVU5EX1VQ KHBvcnQtPnVhcnRjbGssIEJSRFZfQkFVRF9NQVgqT1NBTVBfTUFYX0RJVklTT1IpOworCW1heF9i YXVkID0gcG9ydC0+dWFydGNsayAvIDgwOwogCiAJYmF1ZCA9IHVhcnRfZ2V0X2JhdWRfcmF0ZShw b3J0LCB0ZXJtaW9zLCBvbGQsIG1pbl9iYXVkLCBtYXhfYmF1ZCk7CiAJaWYgKG12ZWJ1X3VhcnRf YmF1ZF9yYXRlX3NldChwb3J0LCBiYXVkKSkgewpAQCAtMTM5NSwxNCArMTQ0MCwxNCBAQCBzdGF0 aWMgaW50IG12ZWJ1X3VhcnRfY2xvY2tfcHJvYmUoc3RydWN0IHBsYXRmb3JtX2RldmljZSAqcGRl dikKIAkJCSAqIENhbGN1bGF0ZSB0aGUgc21hbGxlc3QgVEJHIGQxIGFuZCBkMiBkaXZpc29ycyB0 aGF0CiAJCQkgKiBzdGlsbCBjYW4gcHJvdmlkZSA5NjAwIGJhdWRyYXRlLgogCQkJICovCi0JCQlk MSA9IERJVl9ST1VORF9VUChyYXRlLCA5NjAwICogT1NBTVBfREVGQVVMVF9ESVZJU09SICoKKwkJ CWQxID0gRElWX1JPVU5EX1VQKHJhdGUsIDk2MDAgKiBPU0FNUF9NQVhfRElWSVNPUiAqCiAJCQkJ CQlCUkRWX0JBVURfTUFYKTsKIAkJCWlmIChkMSA8IDEpCiAJCQkJZDEgPSAxOwogCQkJZWxzZSBp ZiAoZDEgPiBDTEtfVEJHX0RJVjFfTUFYKQogCQkJCWQxID0gQ0xLX1RCR19ESVYxX01BWDsKIAot CQkJZDIgPSBESVZfUk9VTkRfVVAocmF0ZSwgOTYwMCAqIE9TQU1QX0RFRkFVTFRfRElWSVNPUiAq CisJCQlkMiA9IERJVl9ST1VORF9VUChyYXRlLCA5NjAwICogT1NBTVBfTUFYX0RJVklTT1IgKgog CQkJCQkJQlJEVl9CQVVEX01BWCAqIGQxKTsKIAkJCWlmIChkMiA8IDEpCiAJCQkJZDIgPSAxOwpA QCAtMTQxNyw3ICsxNDYyLDcgQEAgc3RhdGljIGludCBtdmVidV91YXJ0X2Nsb2NrX3Byb2JlKHN0 cnVjdCBwbGF0Zm9ybV9kZXZpY2UgKnBkZXYpCiAJCX0KIAogCQkvKiBTa2lwIGNsb2NrIHNvdXJj ZSB3aGljaCBjYW5ub3QgcHJvdmlkZSA5NjAwIGJhdWRyYXRlICovCi0JCWlmIChyYXRlID4gOTYw MCAqIE9TQU1QX0RFRkFVTFRfRElWSVNPUiAqIEJSRFZfQkFVRF9NQVggKiBkMSAqIGQyKQorCQlp ZiAocmF0ZSA+IDk2MDAgKiBPU0FNUF9NQVhfRElWSVNPUiAqIEJSRFZfQkFVRF9NQVggKiBkMSAq IGQyKQogCQkJY29udGludWU7CiAKIAkJLyoKLS0gCjIuMjAuMQoKCl9fX19fX19fX19fX19fX19f X19fX19fX19fX19fX19fX19fX19fX19fX19fX19fCmxpbnV4LWFybS1rZXJuZWwgbWFpbGluZyBs aXN0CmxpbnV4LWFybS1rZXJuZWxAbGlzdHMuaW5mcmFkZWFkLm9yZwpodHRwOi8vbGlzdHMuaW5m cmFkZWFkLm9yZy9tYWlsbWFuL2xpc3RpbmZvL2xpbnV4LWFybS1rZXJuZWwK