Received: by 2002:a05:6a10:17d3:0:0:0:0 with SMTP id hz19csp2406380pxb; Tue, 13 Apr 2021 00:44:06 -0700 (PDT) X-Google-Smtp-Source: ABdhPJxoz0LVll+frmLpzpzSWAMI33G5qcqoOUYmZSckIXpjz5JYafUY8aHpm7TaoY5G9Y9U33Dr X-Received: by 2002:a05:6402:1d29:: with SMTP id dh9mr30575934edb.257.1618299846301; Tue, 13 Apr 2021 00:44:06 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1618299846; cv=none; d=google.com; s=arc-20160816; b=Dur30IHZqcqTjjMjIwYP4jGXt5YR5vWyNIiHJqKoxXVZDHssFlOFkipH3qxnwzzsQb Yc+hANL+xQsTmeEwjp6zVJG8UsM1pSbPv6DaRxSRdkU33bzQ91LJ28hOyGJ6fNSgXYH8 VVGkJ4kzFaBtfw8+2Vc37UWeSgRCVWDF/yfg7srZhWET1gCvt2i8M0v/EmsIB01XCutg kD5fBvXLXVLL6ISzB02zUkl7vm6wrlwTN+9XA3yv2XIY+gDi9QU1OFpEDCQIW4S42Da0 WpNAG5+4UbmRkrIIViHGvtlsZuL3UlHczpk9QqMes7ryYaAwICCIw805kk8L1+NMsumH DTXg== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:mime-version:content-transfer-encoding :content-language:accept-language:references:message-id:date :thread-index:thread-topic:subject:cc:to:from; bh=oeQTRK5S0bc0WZvzurIyw3CW7T6O7KNQX7kdiY0nprI=; b=zXTQAsLtNWqLT1gy8U+TRqxGtwN21BX4EYIxtDdhPp9AC39C5MNzffllAqJ+kUOBBw KZJ0lS9EuTACx1TC9OvhjUT3i/5MIRkJQ11B90q8EzPnwskKtOUt1nyonQ4EpftS8AZ2 ew9Qa3XnowUQmn5LrtGILsP9YuBrsDqP3eh4g9qIpJUxWqN2fovw9SQV/ozzgTvhsXMM tcXbMG0iXmiN3ssXdaLarw6SGlknFbnL5Lrg8Wqu7KmJFJWqQSLW08zGzA8cnyX90JwP Varp0LVseJalQaW1PaE+7bWUVuNBlAlbSuRluOOS835+zBAFmXnS+fwj0AqXy1qZA2xj Dqsg== ARC-Authentication-Results: i=1; mx.google.com; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=huawei.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id dn3si273681ejc.690.2021.04.13.00.43.43; Tue, 13 Apr 2021 00:44:06 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) client-ip=23.128.96.18; Authentication-Results: mx.google.com; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=huawei.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S239256AbhDMBr0 convert rfc822-to-8bit (ORCPT + 99 others); Mon, 12 Apr 2021 21:47:26 -0400 Received: from szxga01-in.huawei.com ([45.249.212.187]:5129 "EHLO szxga01-in.huawei.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S237718AbhDMBrZ (ORCPT ); Mon, 12 Apr 2021 21:47:25 -0400 Received: from dggeml406-hub.china.huawei.com (unknown [172.30.72.53]) by szxga01-in.huawei.com (SkyGuard) with ESMTP id 4FK7hW27DYzYVr4; Tue, 13 Apr 2021 09:44:59 +0800 (CST) Received: from dggpemm500008.china.huawei.com (7.185.36.136) by dggeml406-hub.china.huawei.com (10.3.17.50) with Microsoft SMTP Server (TLS) id 14.3.498.0; Tue, 13 Apr 2021 09:47:03 +0800 Received: from dggpemm500006.china.huawei.com (7.185.36.236) by dggpemm500008.china.huawei.com (7.185.36.136) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_128_GCM_SHA256) id 15.1.2106.2; Tue, 13 Apr 2021 09:47:03 +0800 Received: from dggpemm500006.china.huawei.com ([7.185.36.236]) by dggpemm500006.china.huawei.com ([7.185.36.236]) with mapi id 15.01.2106.013; Tue, 13 Apr 2021 09:47:03 +0800 From: "chenjun (AM)" To: Richard Cochran CC: "linux-kernel@vger.kernel.org" , "tglx@linutronix.de" , "john.stultz@linaro.org" , "Xiangrui (Euler)" Subject: Re: [PATCH] time: Fix overwrite err unexpected in clock_adjtime32 Thread-Topic: [PATCH] time: Fix overwrite err unexpected in clock_adjtime32 Thread-Index: AQHXL6blk8YXTY0RLUu2MVHj98u5SQ== Date: Tue, 13 Apr 2021 01:47:03 +0000 Message-ID: References: <20210412124552.50213-1-chenjun102@huawei.com> <20210412141950.GA18311@hoboy.vegasvil.org> <0aacd0e17515458483653f570b1efd2d@huawei.com> <20210412155830.GA19589@hoboy.vegasvil.org> Accept-Language: zh-CN, en-US Content-Language: en-US X-MS-Has-Attach: X-MS-TNEF-Correlator: x-originating-ip: [10.174.178.53] Content-Type: text/plain; charset="iso-2022-jp" Content-Transfer-Encoding: 8BIT MIME-Version: 1.0 X-CFilter-Loop: Reflected Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org 在 2021/4/12 23:58, Richard Cochran 写道: > On Mon, Apr 12, 2021 at 02:52:11PM +0000, chenjun (AM) wrote: >> 在 2021/4/12 22:20, Richard Cochran 写道: >>> On Mon, Apr 12, 2021 at 12:45:51PM +0000, Chen Jun wrote: >>>> the correct error is covered by put_old_timex32. >>> >>> Well, the non-negative return code (TIME_OK, TIME_INS, etc) is >>> clobbered by put_old_timex32(). >>> >>>> Fixes: f1f1d5ebd10f ("posix-timers: Introduce a syscall for clock tuning.") >>> >>> This is not the correct commit for the "Fixes" tag. Please find the >>> actual commit that introduced the issue. >>> >>> In commit f1f1d5ebd10f the code looked like this... >>> >>> long compat_sys_clock_adjtime(clockid_t which_clock, >>> struct compat_timex __user *utp) >>> { >>> struct timex txc; >>> mm_segment_t oldfs; >>> int err, ret; >>> >>> err = compat_get_timex(&txc, utp); >>> if (err) >>> return err; >>> >>> oldfs = get_fs(); >>> set_fs(KERNEL_DS); >>> ret = sys_clock_adjtime(which_clock, (struct timex __user *) &txc); >>> set_fs(oldfs); >>> >>> err = compat_put_timex(utp, &txc); >>> if (err) >>> return err; >>> >>> return ret; >>> } > > Look at the code ^^^ > >> The implement of clock_adjtime32 is similar to compat_sys_clock_adjtime. >> And I think f1f1d5ebd10 introduced the problem actually. > > See how 'ret' and 'err' are two separate variables? It makes a difference. > > Thanks, > Richard > Oh, yee.. Very thanks. 3a4d44b616 ("ntp: Move adjtimex related compat syscalls to native counterparts") made the change. -- Regards Chen Jun