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 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 smtp.lore.kernel.org (Postfix) with ESMTPS id 82A3CC2BD09 for ; Thu, 27 Jun 2024 10:39:04 +0000 (UTC) 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:In-Reply-To:References:Cc:To:Subject: MIME-Version:Date:Message-ID:From:Reply-To:Content-ID:Content-Description: Resent-Date:Resent-From:Resent-Sender:Resent-To:Resent-Cc:Resent-Message-ID: List-Owner; bh=irgfgJ4f6M92g7bu/4MWkzHF/MukFs7Deu/QtmEjNdo=; b=KBh8DxfI/770xs E+xz6QDHpd+hbYTJABxiqd+f1upiYkigprmrbW7bl/zYhbhUT0VEyWEQda//aWJGQTRRTp+R2NNm5 2eebUT2jn/za73n1siEw4iE8O8a+4XePbO5XwWJK9ozukIJTI7V7lR+BU9iYOgDpy/tGRvl4cmScC kzumIUDOBAYYDg7pr43EAQwCQFl2QUzsCfE6mkTQumlQ5svyYNcfElY1YmP890me7EeQrYaP9pxqo yzoMeJjjhTtlru9N+uBUfMDmHR6qYzZQQtyY3+LA9lSwnhGr7466j/Y4c9pTFOvzcNCDrQCxnLXst xKpMW1o+dbXYPu16O3Tw==; Received: from localhost ([::1] helo=bombadil.infradead.org) by bombadil.infradead.org with esmtp (Exim 4.97.1 #2 (Red Hat Linux)) id 1sMmWa-00000009znP-2DFg; Thu, 27 Jun 2024 10:38:44 +0000 Received: from mail-pg1-x541.google.com ([2607:f8b0:4864:20::541]) by bombadil.infradead.org with esmtps (Exim 4.97.1 #2 (Red Hat Linux)) id 1sMmW0-00000009zax-2luf for linux-riscv@lists.infradead.org; Thu, 27 Jun 2024 10:38:21 +0000 Received: by mail-pg1-x541.google.com with SMTP id 41be03b00d2f7-7226821ad86so2101644a12.2 for ; Thu, 27 Jun 2024 03:38:08 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=gmail.com; s=20230601; t=1719484688; x=1720089488; darn=lists.infradead.org; h=content-transfer-encoding:in-reply-to:references:cc:to :content-language:subject:user-agent:mime-version:date:message-id :from:from:to:cc:subject:date:message-id:reply-to; bh=VP116iJGPVlyOU9i7r1chrOZ2teOoateaPGqU1Fh3fA=; b=Jy9F7AAlNd+N/CvtvD8lHtWwqLKt8aHi1sbgbKIjLHoyrETXE7Hl6PIWQyp0j9Jpfz Ne3zLMOGeaGs+tfXfL7v/9yODM8gzq786r6jivuWLY2hqUkp35kyGwq/pL3BJr13nfEv Zpg5hxFfBmmNDcEmAqr+8MW47FwMz2sVH3N2iCtE6yGfHCxL6Ct++CJ0oDvu14ThQKQZ VTOhDvDksJXg4bFgVNxxo33xVAYhHkEnG9yqSVuiyio8uOxC4dgww6eVRtdTwIMJgC1s BUb3ySmiD77NVCmfKr7QMEOTJFHcMx1aBa4T52vUou2ElIz1S2UIHisbmky2Y8unsJxF hoUw== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20230601; t=1719484688; x=1720089488; h=content-transfer-encoding:in-reply-to:references:cc:to :content-language:subject:user-agent:mime-version:date:message-id :from:x-gm-message-state:from:to:cc:subject:date:message-id:reply-to; bh=VP116iJGPVlyOU9i7r1chrOZ2teOoateaPGqU1Fh3fA=; b=sfcjMnzNnRwKaag6yo8uYvn8qYGDULN6FWmUt1MgratQY9DSCPtYpMkfT60lDNaAiz 8chd9afh/nkCNEQoD7SISeUZ0oFHC4QBFyxw6eKkKhr/UcfFbRnOHBMhP9ymZ92CV0KC EXveXVtmZe2oL0MfdWgMhCmNOa3HTXi5sWgh+xmf+Ci7ALpb9Qv/2O/qNTgc523pZ2Yt xCMxNepxSsFQXH0NQSkXU4OMCPT2KUtF07PoInpKzN5RwR+s3vJpP/jD10zuuyNrzGHK tr6aVJ6FXm6z2NR0IiNk9aW2baFPqiqLSbYPJhciNkxSi3oCuxbqCDoNi/gFHifckFwA E9fg== X-Forwarded-Encrypted: i=1; AJvYcCWo4cH78qJ9kmA/Wj9pEn1nPGD8MF7THgXemQTdaA98l1gdZWiN25FWcKxu/KO7SGgEl45DSjrkbLx8T1Rn8g+OCsJWXnI0ukFRe7M14TSQ X-Gm-Message-State: AOJu0Yy9ZEZD21EhBeEkxF0yHwlOhEQfhO1mIkhneQgpyO5nYnp/Aft0 wjTAh1jJamVC+p0XjA2opO20omzeitDY36JAof6ifrQ942jBWVoZ X-Google-Smtp-Source: AGHT+IFk0Amdhpf4cK0iUI4x3T9hkQpae0MzhAzCcaQlXIdwTZ4OZp2YM86yegLigF9y+e3nhCl4WA== X-Received: by 2002:a05:6a21:19b:b0:1b5:44eb:2eda with SMTP id adf61e73a8af0-1bcf7e6a28amr14131000637.5.1719484687761; Thu, 27 Jun 2024 03:38:07 -0700 (PDT) Received: from [127.0.0.1] ([212.107.28.57]) by smtp.gmail.com with ESMTPSA id d9443c01a7336-1faac8fcd45sm10248005ad.116.2024.06.27.03.38.03 (version=TLS1_3 cipher=TLS_AES_128_GCM_SHA256 bits=128/128); Thu, 27 Jun 2024 03:38:07 -0700 (PDT) From: Celeste Liu X-Google-Original-From: Celeste Liu Message-ID: Date: Thu, 27 Jun 2024 18:38:01 +0800 MIME-Version: 1.0 User-Agent: Mozilla Thunderbird Subject: Re: [PATCH v5] riscv: entry: set a0 = -ENOSYS only when syscall != -1 Content-Language: en-GB-large To: =?UTF-8?B?QmrDtnJuIFTDtnBlbA==?= Cc: "Dmitry V. Levin" , Palmer Dabbelt , Paul Walmsley , Albert Ou , Guo Ren , Conor Dooley , linux-riscv@lists.infradead.org, linux-kernel@vger.kernel.org, Andreas Schwab , David Laight , Felix Yan , Ruizhe Pan , Shiqi Zhang , Emil Renner Berthing , "Ivan A. Melnikov" References: <20230801141607.435192-1-CoelacanthusHex@gmail.com> <20240627071422.GA2626@altlinux.org> <9c102328-6bb3-46b6-bc2f-d011a284d5b0@gmail.com> In-Reply-To: X-CRM114-Version: 20100106-BlameMichelson ( TRE 0.8.0 (BSD) ) MR-646709E3 X-CRM114-CacheID: sfid-20240627_033819_067733_DDED597B X-CRM114-Status: GOOD ( 25.26 ) X-BeenThere: linux-riscv@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-riscv" Errors-To: linux-riscv-bounces+linux-riscv=archiver.kernel.org@lists.infradead.org T24gMjAyNC0wNi0yNyAxNzo0MywgQmrDtnJuIFTDtnBlbCB3cm90ZToKCj4gT24gVGh1LCBKdW4g MjcsIDIwMjQgYXQgOTo0N+KAr0FNIENlbGVzdGUgTGl1IDxjb2VsYWNhbnRodXNoZXhAZ21haWwu Y29tPiB3cm90ZToKPj4KPj4gT24gMjAyNC0wNi0yNyAxNToxNCwgRG1pdHJ5IFYuIExldmluIHdy b3RlOgo+Pgo+Pj4gSGksCj4+Pgo+Pj4gT24gVHVlLCBBdWcgMDEsIDIwMjMgYXQgMTA6MTU6MTZQ TSArMDgwMCwgQ2VsZXN0ZSBMaXUgd3JvdGU6Cj4+Pj4gV2hlbiB3ZSB0ZXN0IHNlY2NvbXAgd2l0 aCA2LjQga2VybmVsLCB3ZSBmb3VuZCBlcnJubyBoYXMgd3JvbmcgdmFsdWUuCj4+Pj4gSWYgd2Ug ZGVueSBORVRMSU5LX0FVRElUIHdpdGggRUFGTk9TVVBQT1JULCBhZnRlciBmMGJkZGY1MDU4NmQs IHdlIHdpbGwKPj4+PiBnZXQgRU5PU1lTIGluc3RlYWQuIFdlIGdvdCBzYW1lIHJlc3VsdCB3aXRo IGNvbW1pdCA5YzI1OThkNDM1MTAgKCJyaXNjdjoKPj4+PiBlbnRyeTogU2F2ZSBhMCBwcmlvciBz eXNjYWxsX2VudGVyX2Zyb21fdXNlcl9tb2RlKCkiKS4KPj4+Pgo+Pj4+IEFmdGVyIGFuYWx5c2lu ZyBjb2RlLCB3ZSB0aGluayB0aGF0IHJlZ3MtPmEwID0gLUVOT1NZUyBzaG91bGQgb25seSBiZQo+ Pj4+IGV4ZWN1dGVkIHdoZW4gc3lzY2FsbCAhPSAtMS4gSW4gX19zZWNjb21wX2ZpbHRlciwgd2hl biBzZWNjb21wIHJlamVjdGVkCj4+Pj4gdGhpcyBzeXNjYWxsIHdpdGggc3BlY2lmaWVkIGVycm5v LCB0aGV5IHdpbGwgc2V0IGEwIHRvIHJldHVybiBudW1iZXIgYXMKPj4+PiBzeXNjYWxsIEFCSSwg YW5kIHRoZW4gcmV0dXJuIC0xLiBUaGlzIHJldHVybiBudW1iZXIgaXMgZmluYWxseSBwYXNzIGFz Cj4+Pj4gcmV0dXJuIG51bWJlciBvZiBzeXNjYWxsX2VudGVyX2Zyb21fdXNlcl9tb2RlLCBhbmQg dGhlbiBpcyBjb21wYXJlZCB3aXRoCj4+Pj4gTlJfc3lzY2FsbHMgYWZ0ZXIgY29udmVydGVkIHRv IHVsb25nIChzbyBpdCB3aWxsIGJlIFVMT05HX01BWCkuIFRoZQo+Pj4+IGNvbmRpdGlvbiBzeXNj YWxsIDwgTlJfc3lzY2FsbHMgd2lsbCBhbHdheXMgYmUgZmFsc2UsIHNvIHJlZ3MtPmEwID0gLUVO T1NZUwo+Pj4+IGlzIGFsd2F5cyBleGVjdXRlZC4gSXQgY292ZXJlZCBhMCBzZXQgYnkgc2VjY29t cCwgc28gd2UgYWx3YXlzIGdldAo+Pj4+IEVOT1NZUyB3aGVuIG1hdGNoIHNlY2NvbXAgUkVUX0VS Uk5PIHJ1bGUuCj4+Pj4KPj4+PiBGaXhlczogZjBiZGRmNTA1ODZkICgicmlzY3Y6IGVudHJ5OiBD b252ZXJ0IHRvIGdlbmVyaWMgZW50cnkiKQo+Pj4+IFJlcG9ydGVkLWJ5OiBGZWxpeCBZYW4gPGZl bGl4b25tYXJzQGFyY2hsaW51eC5vcmc+Cj4+Pj4gQ28tZGV2ZWxvcGVkLWJ5OiBSdWl6aGUgUGFu IDxjMTQxMDI4QGdtYWlsLmNvbT4KPj4+PiBTaWduZWQtb2ZmLWJ5OiBSdWl6aGUgUGFuIDxjMTQx MDI4QGdtYWlsLmNvbT4KPj4+PiBDby1kZXZlbG9wZWQtYnk6IFNoaXFpIFpoYW5nIDxzaGlxaUBp c3JjLmlzY2FzLmFjLmNuPgo+Pj4+IFNpZ25lZC1vZmYtYnk6IFNoaXFpIFpoYW5nIDxzaGlxaUBp c3JjLmlzY2FzLmFjLmNuPgo+Pj4+IFNpZ25lZC1vZmYtYnk6IENlbGVzdGUgTGl1IDxDb2VsYWNh bnRodXNIZXhAZ21haWwuY29tPgo+Pj4+IFRlc3RlZC1ieTogRmVsaXggWWFuIDxmZWxpeG9ubWFy c0BhcmNobGludXgub3JnPgo+Pj4+IFRlc3RlZC1ieTogRW1pbCBSZW5uZXIgQmVydGhpbmcgPGVt aWwucmVubmVyLmJlcnRoaW5nQGNhbm9uaWNhbC5jb20+Cj4+Pj4gUmV2aWV3ZWQtYnk6IEJqw7Zy biBUw7ZwZWwgPGJqb3JuQHJpdm9zaW5jLmNvbT4KPj4+PiBSZXZpZXdlZC1ieTogR3VvIFJlbiA8 Z3VvcmVuQGtlcm5lbC5vcmc+Cj4+Pj4gLS0tCj4+Pj4KPj4+PiB2NCAtPiB2NTogYWRkIFRlc3Rl ZC1ieSBFbWlsIFJlbm5lciBCZXJ0aGluZyA8ZW1pbC5yZW5uZXIuYmVydGhpbmdAY2Fub25pY2Fs LmNvbT4KPj4+PiB2MyAtPiB2NDogdXNlIGxvbmcgaW5zdGVhZCBvZiB1bG9uZyB0byByZWR1Y2Ug dHlwZSBjYXN0IGFuZCBhdm9pZAo+Pj4+ICAgICAgICAgICBpbXBsZW1lbnRhdGlvbi1kZWZpbmVk IGJlaGF2aW9yLCBhbmQgbWFrZSB0aGUganVkZ21lbnQgb2Ygc3lzY2FsbAo+Pj4+ICAgICAgICAg ICBpbnZhbGlkIG1vcmUgZXhwbGljaXQKPj4+PiB2MiAtPiB2MzogdXNlIGlmLXN0YXRlbWVudCBp bnN0ZWFkIG9mIHNldCBkZWZhdWx0IHZhbHVlLAo+Pj4+ICAgICAgICAgICBjbGFyaWZ5IHRoZSB0 eXBlIG9mIHN5c2NhbGwKPj4+PiB2MSAtPiB2MjogYWRkZWQgZXhwbGFuYXRpb24gb24gd2h5IGFs d2F5cyBnb3QgRU5PU1lTCj4+Pj4KPj4+PiAgYXJjaC9yaXNjdi9rZXJuZWwvdHJhcHMuYyB8IDYg KysrLS0tCj4+Pj4gIDEgZmlsZSBjaGFuZ2VkLCAzIGluc2VydGlvbnMoKyksIDMgZGVsZXRpb25z KC0pCj4+Pj4KPj4+PiBkaWZmIC0tZ2l0IGEvYXJjaC9yaXNjdi9rZXJuZWwvdHJhcHMuYyBiL2Fy Y2gvcmlzY3Yva2VybmVsL3RyYXBzLmMKPj4+PiBpbmRleCBmOTEwZGZjY2JmNWQyLi43MjlmNzlj OTdlMmJmIDEwMDY0NAo+Pj4+IC0tLSBhL2FyY2gvcmlzY3Yva2VybmVsL3RyYXBzLmMKPj4+PiAr KysgYi9hcmNoL3Jpc2N2L2tlcm5lbC90cmFwcy5jCj4+Pj4gQEAgLTI5Nyw3ICsyOTcsNyBAQCBh c21saW5rYWdlIF9fdmlzaWJsZSBfX3RyYXBfc2VjdGlvbiB2b2lkIGRvX3RyYXBfYnJlYWsoc3Ry dWN0IHB0X3JlZ3MgKnJlZ3MpCj4+Pj4gIGFzbWxpbmthZ2UgX192aXNpYmxlIF9fdHJhcF9zZWN0 aW9uIHZvaWQgZG9fdHJhcF9lY2FsbF91KHN0cnVjdCBwdF9yZWdzICpyZWdzKQo+Pj4+ICB7Cj4+ Pj4gICAgICBpZiAodXNlcl9tb2RlKHJlZ3MpKSB7Cj4+Pj4gLSAgICAgICAgICAgIHVsb25nIHN5 c2NhbGwgPSByZWdzLT5hNzsKPj4+PiArICAgICAgICAgICAgbG9uZyBzeXNjYWxsID0gcmVncy0+ YTc7Cj4+Pj4KPj4+PiAgICAgICAgICAgICAgcmVncy0+ZXBjICs9IDQ7Cj4+Pj4gICAgICAgICAg ICAgIHJlZ3MtPm9yaWdfYTAgPSByZWdzLT5hMDsKPj4+PiBAQCAtMzA2LDkgKzMwNiw5IEBAIGFz bWxpbmthZ2UgX192aXNpYmxlIF9fdHJhcF9zZWN0aW9uIHZvaWQgZG9fdHJhcF9lY2FsbF91KHN0 cnVjdCBwdF9yZWdzICpyZWdzKQo+Pj4+Cj4+Pj4gICAgICAgICAgICAgIHN5c2NhbGwgPSBzeXNj YWxsX2VudGVyX2Zyb21fdXNlcl9tb2RlKHJlZ3MsIHN5c2NhbGwpOwo+Pj4+Cj4+Pj4gLSAgICAg ICAgICAgIGlmIChzeXNjYWxsIDwgTlJfc3lzY2FsbHMpCj4+Pj4gKyAgICAgICAgICAgIGlmIChz eXNjYWxsID49IDAgJiYgc3lzY2FsbCA8IE5SX3N5c2NhbGxzKQo+Pj4+ICAgICAgICAgICAgICAg ICAgICAgIHN5c2NhbGxfaGFuZGxlcihyZWdzLCBzeXNjYWxsKTsKPj4+PiAtICAgICAgICAgICAg ZWxzZQo+Pj4+ICsgICAgICAgICAgICBlbHNlIGlmIChzeXNjYWxsICE9IC0xKQo+Pj4+ICAgICAg ICAgICAgICAgICAgICAgIHJlZ3MtPmEwID0gLUVOT1NZUzsKPj4+Pgo+Pj4+ICAgICAgICAgICAg ICBzeXNjYWxsX2V4aXRfdG9fdXNlcl9tb2RlKHJlZ3MpOwo+Pj4KPj4+IFVuZm9ydHVuYXRlbHks IHRoaXMgY2hhbmdlIGludHJvZHVjZWQgYSByZWdyZXNzaW9uOiBpdCBicm9rZSBzdHJhY2UKPj4+ IHN5c2NhbGwgdGFtcGVyaW5nIG9uIHJpc2N2LiAgV2hlbiB0aGUgdHJhY2VyIGNoYW5nZXMgc3lz Y2FsbCBudW1iZXIgdG8gLTEsCj4+PiB0aGUga2VybmVsIGZhaWxzIHRvIGluaXRpYWxpemUgYTAg d2l0aCAtRU5PU1lTIGFuZCBzdWJzZXF1ZW50bHkgZmFpbHMgdG8KPj4+IHJldHVybiB0aGUgZXJy b3IgY29kZSBvZiB0aGUgZmFpbGVkIHN5c2NhbGwgdG8gdXNlcnNwYWNlLgo+Pgo+PiBJbiB0aGUg cGF0Y2ggdjIsIHdlIGFjdHVhbGx5IGRvIHRoZSByaWdodCB0aGluZy4gQnV0IGFzIEJqw7ZybiBU w7ZwZWwncwo+PiBzdWdnZXN0aW9uIGFuZCB3ZSBmb3VuZCBjYXN0IGxvbmcgdG8gdWxvbmcgaXMg aW1wbGVtZW50YXRpb24tZGVmaW5lZAo+PiBiZWhhdmlvciBpbiBDLCBzbyB3ZSBjaGFuZ2UgaXQg dG8gY3VycmVudCBmb3JtLiBTbyByZXZlcnQgdGhpcyBwYXRjaCBhbmQKPj4gYXBwbHkgcGF0Y2gg djIgc2hvdWxkIGZpeCB0aGlzIGlzc3VlLiBQYXRjaCB2MiB1c2VzIHRocyBzYW1lIHdheSB3aXRo Cj4+IG90aGVyIGFyY2hpdGVjdHVyZXMuCj4+Cj4+IFsxXTogaHR0cHM6Ly9sb3JlLmtlcm5lbC5v cmcvYWxsLzIwMjMwNzE4MTYyOTQwLjIyNjExOC0xLUNvZWxhY2FudGh1c0hleEBnbWFpbC5jb20v Cj4gCj4gTm90IHJldmVydGluZywgYnV0IGEgZml4IHRvIG1ha2Ugc3VyZSB0aGF0IGEwIGlzIGlu aXRpYWxpemVkIHRvIC1FTk9TWVMsIGUuZy46Cj4gCj4gLS04PC0tCj4gZGlmZiAtLWdpdCBhL2Fy Y2gvcmlzY3Yva2VybmVsL3RyYXBzLmMgYi9hcmNoL3Jpc2N2L2tlcm5lbC90cmFwcy5jCj4gaW5k ZXggMDVhMTZiMWYwYWVlLi41MWViZmQyM2UwMDcgMTAwNjQ0Cj4gLS0tIGEvYXJjaC9yaXNjdi9r ZXJuZWwvdHJhcHMuYwo+ICsrKyBiL2FyY2gvcmlzY3Yva2VybmVsL3RyYXBzLmMKPiBAQCAtMzE5 LDYgKzMxOSw3IEBAIHZvaWQgZG9fdHJhcF9lY2FsbF91KHN0cnVjdCBwdF9yZWdzICpyZWdzKQo+ IAo+ICAgcmVncy0+ZXBjICs9IDQ7Cj4gICByZWdzLT5vcmlnX2EwID0gcmVncy0+YTA7Cj4gKyBy ZWdzLT5hMCA9IC1FTk9TWVM7Cj4gCj4gICByaXNjdl92X3ZzdGF0ZV9kaXNjYXJkKHJlZ3MpOwo+ IAo+IEBAIC0zMjgsOCArMzI5LDcgQEAgdm9pZCBkb190cmFwX2VjYWxsX3Uoc3RydWN0IHB0X3Jl Z3MgKnJlZ3MpCj4gCj4gICBpZiAoc3lzY2FsbCA+PSAwICYmIHN5c2NhbGwgPCBOUl9zeXNjYWxs cykKPiAgIHN5c2NhbGxfaGFuZGxlcihyZWdzLCBzeXNjYWxsKTsKPiAtIGVsc2UgaWYgKHN5c2Nh bGwgIT0gLTEpCj4gLSByZWdzLT5hMCA9IC1FTk9TWVM7Cj4gKwo+ICAgLyoKPiAgICogVWx0aW1h dGVseSwgdGhpcyB2YWx1ZSB3aWxsIGdldCBsaW1pdGVkIGJ5IEtTVEFDS19PRkZTRVRfTUFYKCks Cj4gICAqIHNvIHRoZSBtYXhpbXVtIHN0YWNrIG9mZnNldCBpcyAxayBieXRlcyAoMTAgYml0cyku Cj4gLS04PC0tCj4gCj4gQ2VsZXN0ZSwgZG8geW91IHdhbnQgdG8gY29vayB0aGF0IGZpeCBwcm9w ZXJseT8KClBhdGNoIGhhcyBiZWVuIHNlbnQuCgpodHRwczovL2xvcmUua2VybmVsLm9yZy9hbGwv MjAyNDA2MjcxMDMyMDUuMjc5MTQtMi1Db2VsYWNhbnRodXNIZXhAZ21haWwuY29tLwoKQW5kIGxp bnV4LXJpc2N2IG1haWwgbGlzdCBwcm9ibGFibHkgaGFzIHNvbWUgaXNzdWU6IHRoZXJlIGFyZSB0 d28gY29waWVzCm9mIHBhdGNoLCBvcmdpbmFsIG9uZSBhbmQgYW5vdGhlciBvbmUgd2l0aCBsaW51 eC1yaXNjdiBmb290LgoKPiAKPiAKPiBCasO2cm4KCgpfX19fX19fX19fX19fX19fX19fX19fX19f X19fX19fX19fX19fX19fX19fX19fXwpsaW51eC1yaXNjdiBtYWlsaW5nIGxpc3QKbGludXgtcmlz Y3ZAbGlzdHMuaW5mcmFkZWFkLm9yZwpodHRwOi8vbGlzdHMuaW5mcmFkZWFkLm9yZy9tYWlsbWFu L2xpc3RpbmZvL2xpbnV4LXJpc2N2Cg== From mboxrd@z Thu Jan 1 00:00:00 1970 Received: from mail-pg1-f194.google.com (mail-pg1-f194.google.com [209.85.215.194]) (using TLSv1.2 with cipher ECDHE-RSA-AES128-GCM-SHA256 (128/128 bits)) (No client certificate requested) by smtp.subspace.kernel.org (Postfix) with ESMTPS id A50F9145B13 for ; Thu, 27 Jun 2024 10:38:08 +0000 (UTC) Authentication-Results: smtp.subspace.kernel.org; arc=none smtp.client-ip=209.85.215.194 ARC-Seal:i=1; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1719484690; cv=none; b=HMd4IA1N1C9AyeaIATru7D6aqVK7U8X3Lh5LFuBoEiMWrKrW/BJ9MCH/ZED2+UFXfE8lU9SyjYOX/wHJs1AaQbUkpfvuYGdtF515J+/ZUo5uFqFlpyDo96TelGESnjBCZ7Fwdm6bHIVKrpFsocR5UsXIjCKDpv0zgks9NpdGC8E= ARC-Message-Signature:i=1; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1719484690; c=relaxed/simple; bh=YQLZi64znaS7CI8bs0dup11FBoCRlGtT69JGRlvL4jo=; h=From:Message-ID:Date:MIME-Version:Subject:To:Cc:References: In-Reply-To:Content-Type; b=LBwO7LGTojPdK7ox7DiVTgeykybPGdaQXFqFbkakGRroPgszL5+pOyBc6Y4Zp7Ovr4FjJRZsBgC2vMAbgEHM03/E9wAKVgl4DZvTfteHgNid0lA4YZarL7nxNBfN0X+3Fg67TkdwaeIAr9n546vXih1ZQJN7ksWc8370AAJXArI= ARC-Authentication-Results:i=1; smtp.subspace.kernel.org; dmarc=pass (p=none dis=none) header.from=gmail.com; spf=pass smtp.mailfrom=gmail.com; dkim=pass (2048-bit key) header.d=gmail.com header.i=@gmail.com header.b=Ck1/EMKk; arc=none smtp.client-ip=209.85.215.194 Authentication-Results: smtp.subspace.kernel.org; dmarc=pass (p=none dis=none) header.from=gmail.com Authentication-Results: smtp.subspace.kernel.org; spf=pass smtp.mailfrom=gmail.com Authentication-Results: smtp.subspace.kernel.org; dkim=pass (2048-bit key) header.d=gmail.com header.i=@gmail.com header.b="Ck1/EMKk" Received: by mail-pg1-f194.google.com with SMTP id 41be03b00d2f7-718b714d362so4116246a12.0 for ; Thu, 27 Jun 2024 03:38:08 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=gmail.com; s=20230601; t=1719484688; x=1720089488; darn=vger.kernel.org; h=content-transfer-encoding:in-reply-to:references:cc:to :content-language:subject:user-agent:mime-version:date:message-id :from:from:to:cc:subject:date:message-id:reply-to; bh=VP116iJGPVlyOU9i7r1chrOZ2teOoateaPGqU1Fh3fA=; b=Ck1/EMKkCB5OyYDT53KWpq1UgXQefK0VKYSnR0TwGvxHkP9cfX49ZOn1B5pJK/+Bdd DIqy3O2N4zqeoKfVuDAHu0F2JiGfwl4QXadb3BNuR8BuermP5wbTKtdN9YsR6TmLa0Dj WfyGG6anwyHzJzHQVy+miZMoq+9O73caPqnihv6bsUwjjw2MB+8Eb4U+0CQ0LTCkhbEs 7ZCqN5IG+153zNIPI5l6q8IIbc6ogo04RATdJKTIA0yYYZ+cX2qPxrdgypfYaTmOzimG TubEDhMVsBzowRbTRo//n7kcFRLS1ikzsgDrkq2czargX3p+icHj7F5Ny7NKYC2dnZ0Y CMGg== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20230601; t=1719484688; x=1720089488; h=content-transfer-encoding:in-reply-to:references:cc:to :content-language:subject:user-agent:mime-version:date:message-id :from:x-gm-message-state:from:to:cc:subject:date:message-id:reply-to; bh=VP116iJGPVlyOU9i7r1chrOZ2teOoateaPGqU1Fh3fA=; b=NfZ4ziJK24YHS8aqNlZ0ME69XSRTaMo0jyAjLoH68bBeLm5Ix0nLKjraGHbI5KVcRs U+R5FBMSc0UGdPars4L63t/zMz4hnuTTuBO0iiZnk0lD8Q1nyD862YUhpC+G9KsGH4jm 6KYi4zya4myzMUtSlAX64lb3+tfDxL92VwaaFUtSevDfqCi9+64kEjZtnkZoNq1j5pry n67mWs9WO5Z3iP4ANU94gWOEEYwBFphIGyS1783iw8Ngdr+6L7zuy2DfU+CI/p4p7Erk xkYjG0J0s8koUhkJt6Kdu1WW29Z2hlRhlF/UhXzQw+YG/56b9urtobw1eCIpReXya3Lp u/qA== X-Forwarded-Encrypted: i=1; AJvYcCUA7eKCmRli0IV/CZG9ei+zZB7H+6FlrVJOpbQeb6RCCgRacNvnY02VqSkeqZSsrkKABytQag5jt1RfCLjBC9GCwtwjQcdzT2WGKYKq X-Gm-Message-State: AOJu0YxhgCQXw8rfrSbG9SWCzYNF5aA9hB78DEQAGy3ABxvIwNdxEW6c U1+0AQoM83nGyBorkHylfnxwJnbyvqYLqGQhOk6PTtbcNflydhcL X-Google-Smtp-Source: AGHT+IFk0Amdhpf4cK0iUI4x3T9hkQpae0MzhAzCcaQlXIdwTZ4OZp2YM86yegLigF9y+e3nhCl4WA== X-Received: by 2002:a05:6a21:19b:b0:1b5:44eb:2eda with SMTP id adf61e73a8af0-1bcf7e6a28amr14131000637.5.1719484687761; Thu, 27 Jun 2024 03:38:07 -0700 (PDT) Received: from [127.0.0.1] ([212.107.28.57]) by smtp.gmail.com with ESMTPSA id d9443c01a7336-1faac8fcd45sm10248005ad.116.2024.06.27.03.38.03 (version=TLS1_3 cipher=TLS_AES_128_GCM_SHA256 bits=128/128); Thu, 27 Jun 2024 03:38:07 -0700 (PDT) From: Celeste Liu X-Google-Original-From: Celeste Liu Message-ID: Date: Thu, 27 Jun 2024 18:38:01 +0800 Precedence: bulk X-Mailing-List: linux-kernel@vger.kernel.org List-Id: List-Subscribe: List-Unsubscribe: MIME-Version: 1.0 User-Agent: Mozilla Thunderbird Subject: Re: [PATCH v5] riscv: entry: set a0 = -ENOSYS only when syscall != -1 Content-Language: en-GB-large To: =?UTF-8?B?QmrDtnJuIFTDtnBlbA==?= Cc: "Dmitry V. Levin" , Palmer Dabbelt , Paul Walmsley , Albert Ou , Guo Ren , Conor Dooley , linux-riscv@lists.infradead.org, linux-kernel@vger.kernel.org, Andreas Schwab , David Laight , Felix Yan , Ruizhe Pan , Shiqi Zhang , Emil Renner Berthing , "Ivan A. Melnikov" References: <20230801141607.435192-1-CoelacanthusHex@gmail.com> <20240627071422.GA2626@altlinux.org> <9c102328-6bb3-46b6-bc2f-d011a284d5b0@gmail.com> In-Reply-To: Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit On 2024-06-27 17:43, Björn Töpel wrote: > On Thu, Jun 27, 2024 at 9:47 AM Celeste Liu wrote: >> >> On 2024-06-27 15:14, Dmitry V. Levin wrote: >> >>> Hi, >>> >>> On Tue, Aug 01, 2023 at 10:15:16PM +0800, Celeste Liu wrote: >>>> When we test seccomp with 6.4 kernel, we found errno has wrong value. >>>> If we deny NETLINK_AUDIT with EAFNOSUPPORT, after f0bddf50586d, we will >>>> get ENOSYS instead. We got same result with commit 9c2598d43510 ("riscv: >>>> entry: Save a0 prior syscall_enter_from_user_mode()"). >>>> >>>> After analysing code, we think that regs->a0 = -ENOSYS should only be >>>> executed when syscall != -1. In __seccomp_filter, when seccomp rejected >>>> this syscall with specified errno, they will set a0 to return number as >>>> syscall ABI, and then return -1. This return number is finally pass as >>>> return number of syscall_enter_from_user_mode, and then is compared with >>>> NR_syscalls after converted to ulong (so it will be ULONG_MAX). The >>>> condition syscall < NR_syscalls will always be false, so regs->a0 = -ENOSYS >>>> is always executed. It covered a0 set by seccomp, so we always get >>>> ENOSYS when match seccomp RET_ERRNO rule. >>>> >>>> Fixes: f0bddf50586d ("riscv: entry: Convert to generic entry") >>>> Reported-by: Felix Yan >>>> Co-developed-by: Ruizhe Pan >>>> Signed-off-by: Ruizhe Pan >>>> Co-developed-by: Shiqi Zhang >>>> Signed-off-by: Shiqi Zhang >>>> Signed-off-by: Celeste Liu >>>> Tested-by: Felix Yan >>>> Tested-by: Emil Renner Berthing >>>> Reviewed-by: Björn Töpel >>>> Reviewed-by: Guo Ren >>>> --- >>>> >>>> v4 -> v5: add Tested-by Emil Renner Berthing >>>> v3 -> v4: use long instead of ulong to reduce type cast and avoid >>>> implementation-defined behavior, and make the judgment of syscall >>>> invalid more explicit >>>> v2 -> v3: use if-statement instead of set default value, >>>> clarify the type of syscall >>>> v1 -> v2: added explanation on why always got ENOSYS >>>> >>>> arch/riscv/kernel/traps.c | 6 +++--- >>>> 1 file changed, 3 insertions(+), 3 deletions(-) >>>> >>>> diff --git a/arch/riscv/kernel/traps.c b/arch/riscv/kernel/traps.c >>>> index f910dfccbf5d2..729f79c97e2bf 100644 >>>> --- a/arch/riscv/kernel/traps.c >>>> +++ b/arch/riscv/kernel/traps.c >>>> @@ -297,7 +297,7 @@ asmlinkage __visible __trap_section void do_trap_break(struct pt_regs *regs) >>>> asmlinkage __visible __trap_section void do_trap_ecall_u(struct pt_regs *regs) >>>> { >>>> if (user_mode(regs)) { >>>> - ulong syscall = regs->a7; >>>> + long syscall = regs->a7; >>>> >>>> regs->epc += 4; >>>> regs->orig_a0 = regs->a0; >>>> @@ -306,9 +306,9 @@ asmlinkage __visible __trap_section void do_trap_ecall_u(struct pt_regs *regs) >>>> >>>> syscall = syscall_enter_from_user_mode(regs, syscall); >>>> >>>> - if (syscall < NR_syscalls) >>>> + if (syscall >= 0 && syscall < NR_syscalls) >>>> syscall_handler(regs, syscall); >>>> - else >>>> + else if (syscall != -1) >>>> regs->a0 = -ENOSYS; >>>> >>>> syscall_exit_to_user_mode(regs); >>> >>> Unfortunately, this change introduced a regression: it broke strace >>> syscall tampering on riscv. When the tracer changes syscall number to -1, >>> the kernel fails to initialize a0 with -ENOSYS and subsequently fails to >>> return the error code of the failed syscall to userspace. >> >> In the patch v2, we actually do the right thing. But as Björn Töpel's >> suggestion and we found cast long to ulong is implementation-defined >> behavior in C, so we change it to current form. So revert this patch and >> apply patch v2 should fix this issue. Patch v2 uses ths same way with >> other architectures. >> >> [1]: https://lore.kernel.org/all/20230718162940.226118-1-CoelacanthusHex@gmail.com/ > > Not reverting, but a fix to make sure that a0 is initialized to -ENOSYS, e.g.: > > --8<-- > diff --git a/arch/riscv/kernel/traps.c b/arch/riscv/kernel/traps.c > index 05a16b1f0aee..51ebfd23e007 100644 > --- a/arch/riscv/kernel/traps.c > +++ b/arch/riscv/kernel/traps.c > @@ -319,6 +319,7 @@ void do_trap_ecall_u(struct pt_regs *regs) > > regs->epc += 4; > regs->orig_a0 = regs->a0; > + regs->a0 = -ENOSYS; > > riscv_v_vstate_discard(regs); > > @@ -328,8 +329,7 @@ void do_trap_ecall_u(struct pt_regs *regs) > > if (syscall >= 0 && syscall < NR_syscalls) > syscall_handler(regs, syscall); > - else if (syscall != -1) > - regs->a0 = -ENOSYS; > + > /* > * Ultimately, this value will get limited by KSTACK_OFFSET_MAX(), > * so the maximum stack offset is 1k bytes (10 bits). > --8<-- > > Celeste, do you want to cook that fix properly? Patch has been sent. https://lore.kernel.org/all/20240627103205.27914-2-CoelacanthusHex@gmail.com/ And linux-riscv mail list problably has some issue: there are two copies of patch, orginal one and another one with linux-riscv foot. > > > Björn