From mboxrd@z Thu Jan 1 00:00:00 1970 Return-Path: Received: from ffbox0-bg.mplayerhq.hu (ffbox0-bg.ffmpeg.org [79.124.17.100]) by master.gitmailbox.com (Postfix) with ESMTP id C21B343CE2 for ; Tue, 6 Sep 2022 18:44:10 +0000 (UTC) Received: from [127.0.1.1] (localhost [127.0.0.1]) by ffbox0-bg.mplayerhq.hu (Postfix) with ESMTP id E376068BB35; Tue, 6 Sep 2022 21:44:08 +0300 (EEST) Received: from ursule.remlab.net (vps-a2bccee9.vps.ovh.net [51.75.19.47]) by ffbox0-bg.mplayerhq.hu (Postfix) with ESMTP id 8675C68BABD for ; Tue, 6 Sep 2022 21:44:02 +0300 (EEST) Received: from basile.remlab.net (localhost [IPv6:::1]) by ursule.remlab.net (Postfix) with ESMTP id 3286BC00AD for ; Tue, 6 Sep 2022 21:44:02 +0300 (EEST) From: remi@remlab.net To: ffmpeg-devel@ffmpeg.org Date: Tue, 6 Sep 2022 21:43:51 +0300 Message-Id: <20220906184402.119826-1-remi@remlab.net> X-Mailer: git-send-email 2.37.2 In-Reply-To: <5753736.MhkbZ0Pkbq@basile.remlab.net> References: <5753736.MhkbZ0Pkbq@basile.remlab.net> MIME-Version: 1.0 Subject: [FFmpeg-devel] [PATCH 01/12] lavu/riscv: add CPU flags for the RISC-V Vector extension X-BeenThere: ffmpeg-devel@ffmpeg.org X-Mailman-Version: 2.1.29 Precedence: list List-Id: FFmpeg development discussions and patches List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , Reply-To: FFmpeg development discussions and patches Content-Type: text/plain; charset="utf-8" Content-Transfer-Encoding: base64 Errors-To: ffmpeg-devel-bounces@ffmpeg.org Sender: "ffmpeg-devel" Archived-At: List-Archive: List-Post: RnJvbTogUsOpbWkgRGVuaXMtQ291cm1vbnQgPHJlbWlAcmVtbGFiLm5ldD4KClJWViBkZWZpbmVz IGEgdG90YWwgb2YgMTIgZGlmZmVyZW50IGV4dGVuc2lvbnMsIGluY2x1ZGluZzoKCi0gNSBkaWZm ZXJlbnQgaW5zdHJ1Y3Rpb24gc3Vic2V0czoKICAtIFp2ZTMyeDogOC0sIDE2LSBhbmQgMzItYml0 IGludGVnZXJzLAogIC0gWnZlMzJmOiBadmUzMnggcGx1cyBzaW5nbGUgcHJlY2lzaW9uIGZsb2F0 cywKICAtIFp2ZTY0eDogWnZlMzJ4IHBsdXMgNjQtYml0IGludGVnZXJzLAogIC0gWnZlNjRmOiBa dmUzMmYgcGx1cyBadmU2NHgsCiAgLSBadmU2NGQ6IFp2ZTY0ZiBwbHVzIGRvdWJsZSBwcmVjaXNp b24gZmxvYXRzLgoKLSA2IGRpZmZlcmVudCB2ZWN0b3IgbGVuZ3RoczoKICAtIFp2bDMyYiAoZW1i ZWRkZWQgb25seSksCiAgLSBadmw2NGIgKGVtYmVkZGVkIG9ubHkpLAogIC0gWnZsMTI4YiwKICAt IFp2bDI1NmIsCiAgLSBadmw1MTJiLAogIC0gWnZsMTAyNGIsCgotIGFuZCB0aGUgViBleHRlbnNp b24gcHJvcGVyOiBlcXVpdmFsZW50IHRvIFp2ZTY0ZiBhbmQgWnZsMTI4Yi4KCkluIHRvdGFsLCB0 aGVyZSBhcmUgNiBkaWZmZXJlbnQgcG9zc2libGUgc2V0cyBvZiBzdXBwb3J0ZWQgaW5zdHJ1Y3Rp b25zCihpbmNsdWRpbmcgdGhlIGVtcHR5IHNldCksIGJ1dCBmb3IgY29udmVuaWVuY2Ugd2UgYWxs b2NhdGUgb25lIGJpdCBmb3IKZWFjaCB0eXBlIHNldHM6IHVwLXRvLTMyLWJpdCBpbnRzIChaVkUz MlgpLCBmbG9hdHMgKFpWMzJGKSwKNjQtYml0IGludHMgKFpWNjRYKSBhbmQgZG91YmxlcyAoWlZF NjREKS4KCldoZW5jZSB0aGUgdmVjdG9yIHNpemUgaXMgbmVlZGVkLCBpdCBjYW4gYmUgcmV0cmll dmVkIGJ5IHJlYWRpbmcgdGhlCnVucHJpdmlsZWdlZCByZWFkLW9ubHkgdmxlbmIgQ1NSLiBUaGlz IHNob3VsZCBwcm9iYWJseSBiZSBhIHNlcGFyYXRlCmhlbHBlciBtYWNybyBpZiBuZWVkZWQgYXQg YSBsYXRlciBwb2ludC4KLS0tCiBsaWJhdnV0aWwvY3B1LmMgICAgICAgICAgfCAxNSArKysrKysr KysrKwogbGliYXZ1dGlsL2NwdS5oICAgICAgICAgIHwgIDYgKysrKysKIGxpYmF2dXRpbC9jcHVf aW50ZXJuYWwuaCB8ICAxICsKIGxpYmF2dXRpbC9yaXNjdi9NYWtlZmlsZSB8ICAxICsKIGxpYmF2 dXRpbC9yaXNjdi9jcHUuYyAgICB8IDU3ICsrKysrKysrKysrKysrKysrKysrKysrKysrKysrKysr KysrKysrKysKIDUgZmlsZXMgY2hhbmdlZCwgODAgaW5zZXJ0aW9ucygrKQogY3JlYXRlIG1vZGUg MTAwNjQ0IGxpYmF2dXRpbC9yaXNjdi9NYWtlZmlsZQogY3JlYXRlIG1vZGUgMTAwNjQ0IGxpYmF2 dXRpbC9yaXNjdi9jcHUuYwoKZGlmZiAtLWdpdCBhL2xpYmF2dXRpbC9jcHUuYyBiL2xpYmF2dXRp bC9jcHUuYwppbmRleCAwMDM1ZTkyN2E1Li44OWQyZmI2ZjU2IDEwMDY0NAotLS0gYS9saWJhdnV0 aWwvY3B1LmMKKysrIGIvbGliYXZ1dGlsL2NwdS5jCkBAIC02Miw2ICs2Miw4IEBAIHN0YXRpYyBp bnQgZ2V0X2NwdV9mbGFncyh2b2lkKQogICAgIHJldHVybiBmZl9nZXRfY3B1X2ZsYWdzX2FybSgp OwogI2VsaWYgQVJDSF9QUEMKICAgICByZXR1cm4gZmZfZ2V0X2NwdV9mbGFnc19wcGMoKTsKKyNl bGlmIEFSQ0hfUklTQ1YKKyAgICByZXR1cm4gZmZfZ2V0X2NwdV9mbGFnc19yaXNjdigpOwogI2Vs aWYgQVJDSF9YODYKICAgICByZXR1cm4gZmZfZ2V0X2NwdV9mbGFnc194ODYoKTsKICNlbGlmIEFS Q0hfTE9PTkdBUkNICkBAIC0xNzgsNiArMTgwLDE5IEBAIGludCBhdl9wYXJzZV9jcHVfY2Fwcyh1 bnNpZ25lZCAqZmxhZ3MsIGNvbnN0IGNoYXIgKnMpCiAjZWxpZiBBUkNIX0xPT05HQVJDSAogICAg ICAgICB7ICJsc3giLCAgICAgIE5VTEwsIDAsIEFWX09QVF9UWVBFX0NPTlNULCB7IC5pNjQgPSBB Vl9DUFVfRkxBR19MU1ggICAgICB9LCAgICAudW5pdCA9ICJmbGFncyIgfSwKICAgICAgICAgeyAi bGFzeCIsICAgICBOVUxMLCAwLCBBVl9PUFRfVFlQRV9DT05TVCwgeyAuaTY0ID0gQVZfQ1BVX0ZM QUdfTEFTWCAgICAgfSwgICAgLnVuaXQgPSAiZmxhZ3MiIH0sCisjZWxpZiBBUkNIX1JJU0NWCisj ZGVmaW5lIEFWX0NQVV9GTEFHX1pWRTMyWF9NIChBVl9DUFVfRkxBR19aVkUzMlgpCisjZGVmaW5l IEFWX0NQVV9GTEFHX1pWRTMyRl9NIChBVl9DUFVfRkxBR19aVkUzMlhfTSB8IEFWX0NQVV9GTEFH X1pWRTMyRikKKyNkZWZpbmUgQVZfQ1BVX0ZMQUdfWlZFNjRYX00gKEFWX0NQVV9GTEFHX1pWRTMy WF9NIHwgQVZfQ1BVX0ZMQUdfWlZFNjRYKQorI2RlZmluZSBBVl9DUFVfRkxBR19aVkU2NEZfTSAo QVZfQ1BVX0ZMQUdfWlZFMzJGX00gfCBBVl9DUFVfRkxBR19aVkU2NFgpCisjZGVmaW5lIEFWX0NQ VV9GTEFHX1pWRTY0RF9NIChBVl9DUFVfRkxBR19aVkU2NEZfTSB8IEFWX0NQVV9GTEFHX1pWRTY0 RCkKKyNkZWZpbmUgQVZfQ1BVX0ZMQUdfVkVDVE9SUyAgQVZfQ1BVX0ZMQUdfWlZFNjREX00KKyAg ICAgICAgeyAidmVjdG9ycyIsICBOVUxMLCAwLCBBVl9PUFRfVFlQRV9DT05TVCwgeyAuaTY0ID0g QVZfQ1BVX0ZMQUdfVkVDVE9SUyAgfSwgICAgLnVuaXQgPSAiZmxhZ3MiIH0sCisgICAgICAgIHsg Inp2ZTMyeCIsICAgTlVMTCwgMCwgQVZfT1BUX1RZUEVfQ09OU1QsIHsgLmk2NCA9IEFWX0NQVV9G TEFHX1pWRTMyWCAgIH0sICAgIC51bml0ID0gImZsYWdzIiB9LAorICAgICAgICB7ICJ6dmUzMmYi LCAgIE5VTEwsIDAsIEFWX09QVF9UWVBFX0NPTlNULCB7IC5pNjQgPSBBVl9DUFVfRkxBR19aVkUz MkZfTSB9LCAgICAudW5pdCA9ICJmbGFncyIgfSwKKyAgICAgICAgeyAienZlNjR4IiwgICBOVUxM LCAwLCBBVl9PUFRfVFlQRV9DT05TVCwgeyAuaTY0ID0gQVZfQ1BVX0ZMQUdfWlZFNjRYX00gfSwg ICAgLnVuaXQgPSAiZmxhZ3MiIH0sCisgICAgICAgIHsgInp2ZTY0ZiIsICAgTlVMTCwgMCwgQVZf T1BUX1RZUEVfQ09OU1QsIHsgLmk2NCA9IEFWX0NQVV9GTEFHX1pWRTY0Rl9NIH0sICAgIC51bml0 ID0gImZsYWdzIiB9LAorICAgICAgICB7ICJ6dmU2NGQiLCAgIE5VTEwsIDAsIEFWX09QVF9UWVBF X0NPTlNULCB7IC5pNjQgPSBBVl9DUFVfRkxBR19aVkU2NERfTSB9LCAgICAudW5pdCA9ICJmbGFn cyIgfSwKICNlbmRpZgogICAgICAgICB7IE5VTEwgfSwKICAgICB9OwpkaWZmIC0tZ2l0IGEvbGli YXZ1dGlsL2NwdS5oIGIvbGliYXZ1dGlsL2NwdS5oCmluZGV4IDk3MTFlNTc0YzUuLjQ0ODM2ZTUw ZDYgMTAwNjQ0Ci0tLSBhL2xpYmF2dXRpbC9jcHUuaAorKysgYi9saWJhdnV0aWwvY3B1LmgKQEAg LTc4LDYgKzc4LDEyIEBACiAjZGVmaW5lIEFWX0NQVV9GTEFHX0xTWCAgICAgICAgICAoMSA8PCAw KQogI2RlZmluZSBBVl9DUFVfRkxBR19MQVNYICAgICAgICAgKDEgPDwgMSkKIAorLy8gUklTQy1W IFZlY3RvciBleHRlbnNpb24KKyNkZWZpbmUgQVZfQ1BVX0ZMQUdfWlZFMzJYICAgICAgICgxIDw8 IDApIC8qIDgtLCAxNi0sIDMyLWJpdCBpbnRlZ2VycyAqLworI2RlZmluZSBBVl9DUFVfRkxBR19a VkUzMkYgICAgICAgKDEgPDwgMSkgLyogc2luZ2xlIHByZWNpc2lvbiBzY2FsYXJzICovCisjZGVm aW5lIEFWX0NQVV9GTEFHX1pWRTY0WCAgICAgICAoMSA8PCAyKSAvKiA2NC1iaXQgaW50ZWdlcnMg Ki8KKyNkZWZpbmUgQVZfQ1BVX0ZMQUdfWlZFNjREICAgICAgICgxIDw8IDMpIC8qIGRvdWJsZSBw cmVjaXNpb24gc2NhbGFycyAqLworCiAvKioKICAqIFJldHVybiB0aGUgZmxhZ3Mgd2hpY2ggc3Bl Y2lmeSBleHRlbnNpb25zIHN1cHBvcnRlZCBieSB0aGUgQ1BVLgogICogVGhlIHJldHVybmVkIHZh bHVlIGlzIGFmZmVjdGVkIGJ5IGF2X2ZvcmNlX2NwdV9mbGFncygpIGlmIHRoYXQgd2FzIHVzZWQK ZGlmZiAtLWdpdCBhL2xpYmF2dXRpbC9jcHVfaW50ZXJuYWwuaCBiL2xpYmF2dXRpbC9jcHVfaW50 ZXJuYWwuaAppbmRleCA2NTBkNDdmYzk2Li42MzRmMjhiYWM0IDEwMDY0NAotLS0gYS9saWJhdnV0 aWwvY3B1X2ludGVybmFsLmgKKysrIGIvbGliYXZ1dGlsL2NwdV9pbnRlcm5hbC5oCkBAIC00OCw2 ICs0OCw3IEBAIGludCBmZl9nZXRfY3B1X2ZsYWdzX21pcHModm9pZCk7CiBpbnQgZmZfZ2V0X2Nw dV9mbGFnc19hYXJjaDY0KHZvaWQpOwogaW50IGZmX2dldF9jcHVfZmxhZ3NfYXJtKHZvaWQpOwog aW50IGZmX2dldF9jcHVfZmxhZ3NfcHBjKHZvaWQpOworaW50IGZmX2dldF9jcHVfZmxhZ3Nfcmlz Y3Yodm9pZCk7CiBpbnQgZmZfZ2V0X2NwdV9mbGFnc194ODYodm9pZCk7CiBpbnQgZmZfZ2V0X2Nw dV9mbGFnc19sb29uZ2FyY2godm9pZCk7CiAKZGlmZiAtLWdpdCBhL2xpYmF2dXRpbC9yaXNjdi9N YWtlZmlsZSBiL2xpYmF2dXRpbC9yaXNjdi9NYWtlZmlsZQpuZXcgZmlsZSBtb2RlIDEwMDY0NApp bmRleCAwMDAwMDAwMDAwLi4xZjgxODA0M2RjCi0tLSAvZGV2L251bGwKKysrIGIvbGliYXZ1dGls L3Jpc2N2L01ha2VmaWxlCkBAIC0wLDAgKzEgQEAKK09CSlMgKz0gcmlzY3YvY3B1Lm8KZGlmZiAt LWdpdCBhL2xpYmF2dXRpbC9yaXNjdi9jcHUuYyBiL2xpYmF2dXRpbC9yaXNjdi9jcHUuYwpuZXcg ZmlsZSBtb2RlIDEwMDY0NAppbmRleCAwMDAwMDAwMDAwLi45ZTRjY2U1ZThiCi0tLSAvZGV2L251 bGwKKysrIGIvbGliYXZ1dGlsL3Jpc2N2L2NwdS5jCkBAIC0wLDAgKzEsNTcgQEAKKy8qCisgKiBU aGlzIGZpbGUgaXMgcGFydCBvZiBGRm1wZWcuCisgKgorICogRkZtcGVnIGlzIGZyZWUgc29mdHdh cmU7IHlvdSBjYW4gcmVkaXN0cmlidXRlIGl0IGFuZC9vcgorICogbW9kaWZ5IGl0IHVuZGVyIHRo ZSB0ZXJtcyBvZiB0aGUgR05VIExlc3NlciBHZW5lcmFsIFB1YmxpYworICogTGljZW5zZSBhcyBw dWJsaXNoZWQgYnkgdGhlIEZyZWUgU29mdHdhcmUgRm91bmRhdGlvbjsgZWl0aGVyCisgKiB2ZXJz aW9uIDIuMSBvZiB0aGUgTGljZW5zZSwgb3IgKGF0IHlvdXIgb3B0aW9uKSBhbnkgbGF0ZXIgdmVy c2lvbi4KKyAqCisgKiBGRm1wZWcgaXMgZGlzdHJpYnV0ZWQgaW4gdGhlIGhvcGUgdGhhdCBpdCB3 aWxsIGJlIHVzZWZ1bCwKKyAqIGJ1dCBXSVRIT1VUIEFOWSBXQVJSQU5UWTsgd2l0aG91dCBldmVu IHRoZSBpbXBsaWVkIHdhcnJhbnR5IG9mCisgKiBNRVJDSEFOVEFCSUxJVFkgb3IgRklUTkVTUyBG T1IgQSBQQVJUSUNVTEFSIFBVUlBPU0UuICBTZWUgdGhlIEdOVQorICogTGVzc2VyIEdlbmVyYWwg UHVibGljIExpY2Vuc2UgZm9yIG1vcmUgZGV0YWlscy4KKyAqCisgKiBZb3Ugc2hvdWxkIGhhdmUg cmVjZWl2ZWQgYSBjb3B5IG9mIHRoZSBHTlUgTGVzc2VyIEdlbmVyYWwgUHVibGljCisgKiBMaWNl bnNlIGFsb25nIHdpdGggRkZtcGVnOyBpZiBub3QsIHdyaXRlIHRvIHRoZSBGcmVlIFNvZnR3YXJl CisgKiBGb3VuZGF0aW9uLCBJbmMuLCA1MSBGcmFua2xpbiBTdHJlZXQsIEZpZnRoIEZsb29yLCBC b3N0b24sIE1BIDAyMTEwLTEzMDEgVVNBCisgKi8KKworI2luY2x1ZGUgImxpYmF2dXRpbC9jcHUu aCIKKyNpbmNsdWRlICJsaWJhdnV0aWwvY3B1X2ludGVybmFsLmgiCisjaW5jbHVkZSAiY29uZmln LmgiCisKKyNpZiBIQVZFX0dFVEFVWFZBTAorI2luY2x1ZGUgPHN5cy9hdXh2Lmg+CisjZW5kaWYK KworI2RlZmluZSBIV0NBUF9SVihsZXR0ZXIpICgxdWwgPDwgKChsZXR0ZXIpIC0gJ0EnKSkKKwor aW50IGZmX2dldF9jcHVfZmxhZ3NfcmlzY3Yodm9pZCkKK3sKKyAgICBpbnQgcmV0ID0gMDsKKwor ICAgIC8qIElmIFJWLVYgaXMgZW5hYmxlZCBzdGF0aWNhbGx5IGF0IGNvbXBpbGUtdGltZSwgY2hl Y2sgdGhlIGRldGFpbHMuICovCisjaWZkZWYgX19yaXNjdl92ZWN0b3JzCisgICAgcmV0IHw9IEFW X0NQVV9GTEFHX1pWRTMyWDsKKyNpZiBfX3Jpc2N2X3ZfZWxlbiA+PSA2NAorICAgIHJldCB8PSBB Vl9DUFVfRkxBR19aVkU2NFg7CisjZW5kaWYKKyNpZiBfX3Jpc2N2X3ZfZWxlbl9mcCA+PSAzMgor ICAgIHJldCB8PSBBVl9DUFVfRkxBR19aVkUzMkY7CisjaWYgX19yaXNjdl92X2VsZW5fZnAgPj0g NjQKKyAgICByZXQgfD0gQVZfQ1BVX0ZMQUdfWlZFNjRGOworI2VuZGlmCisjZW5kaWYKKyNlbmRp ZgorCisjaWYgSEFWRV9HRVRBVVhWQUwKKyAgICBjb25zdCB1bnNpZ25lZCBsb25nIGh3Y2FwID0g Z2V0YXV4dmFsKEFUX0hXQ0FQKTsKKworICAgIC8qIFRoZSBWIGV4dGVuc2lvbiBpbXBsaWVzIGFs bCBzdWJzZXRzICovCisgICAgaWYgKGh3Y2FwICYgSFdDQVBfUlYoJ1YnKSkKKyAgICAgICAgcmV0 IHw9IEFWX0NQVV9GTEFHX1pWRTMyWCB8IEFWX0NQVV9GTEFHX1pWRTY0WAorICAgICAgICAgICAg IHwgQVZfQ1BVX0ZMQUdfWlZFMzJGIHwgQVZfQ1BVX0ZMQUdfWlZFNjREOworI2VuZGlmCisKKyAg ICByZXR1cm4gcmV0OworfQotLSAKMi4zNy4yCgpfX19fX19fX19fX19fX19fX19fX19fX19fX19f X19fX19fX19fX19fX19fX19fXwpmZm1wZWctZGV2ZWwgbWFpbGluZyBsaXN0CmZmbXBlZy1kZXZl bEBmZm1wZWcub3JnCmh0dHBzOi8vZmZtcGVnLm9yZy9tYWlsbWFuL2xpc3RpbmZvL2ZmbXBlZy1k ZXZlbAoKVG8gdW5zdWJzY3JpYmUsIHZpc2l0IGxpbmsgYWJvdmUsIG9yIGVtYWlsCmZmbXBlZy1k ZXZlbC1yZXF1ZXN0QGZmbXBlZy5vcmcgd2l0aCBzdWJqZWN0ICJ1bnN1YnNjcmliZSIuCg==