Received: by 2002:a05:6a11:4021:0:0:0:0 with SMTP id ky33csp75062pxb; Tue, 21 Sep 2021 19:12:01 -0700 (PDT) X-Google-Smtp-Source: ABdhPJzauYtgT1EDVFM/5TNch6p1isesuTITtvvMLVxWJYKArZojrfaZK4PxxjjKg+oVO9Wi481e X-Received: by 2002:a05:6e02:f94:: with SMTP id v20mr25161780ilo.148.1632276721238; Tue, 21 Sep 2021 19:12:01 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1632276721; cv=none; d=google.com; s=arc-20160816; b=p63TGb2khPLMoO4A1KbsQx/xvP3lQdXJkfN2kJx2Nvk6eZHRK6m30Kdy2JCLeAAo21 81gyNn/0caLWom1abkMwbCfJP0Sb2X2HUrnGRYV9GRWFepwjOxsN6JF5/xgILB5AA2T1 n72fk6/1m+4Cbjuny1GX2FUuuWhoueeh5nQYG2HBrcpL0INir4SiSgkapfbC+cNeNsZm otYJ0yLLDsj5guOd7O6aj+9CDb/53OKl9iQZt6lNPEWJqWgfHBwSc6Hc018MCBPVWb/7 4EoaghYk9tMgHXEn6nBw0PVb76seHYzPedWCBKMqO7Kls/EvqeJoFX2FR5kTK/1iqodw FLfA== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:mime-version:message-id:date:subject:cc:to:from; bh=/35KAmmgcVkqneJCTAdzmwOPCNn4MaqYV7TYjxDcxiM=; b=tjvYwrGk3QuxpXAJqS3na+exgg8HJelDRH1huyJBmXRz7Db6OHcUS1S0RTSIuf/jyY 0aJO+VuxHVZoiOtGkJhzsbh2zsnC/Ch8m8MM+4B54Z4z5ZR+PsUKX9LwXB5sja4QFTLy Ne5qbwy4W+2QbonACIW0HzP+Kkcj6KXKyT9xofmMXXpm5ff35Lx7dnnS936fGh1rLOdR IvKQ1jjGZkcdpxgEaefqoxcN+7zUCAxKmLKfzUUvYyPVBoUHOmGxxxV99GGml2La4ebp i1O32eSls74c6ce2jcd6DW3KwM98jTvoheIRntG0ma2w5M2O0vyF11SKDeKji5jW/wSD bQgw== 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 s17si959273ios.107.2021.09.21.19.11.50; Tue, 21 Sep 2021 19:12:01 -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 S231297AbhIVBpc (ORCPT + 99 others); Tue, 21 Sep 2021 21:45:32 -0400 Received: from szxga02-in.huawei.com ([45.249.212.188]:9899 "EHLO szxga02-in.huawei.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S229834AbhIVBp3 (ORCPT ); Tue, 21 Sep 2021 21:45:29 -0400 Received: from dggemv703-chm.china.huawei.com (unknown [172.30.72.56]) by szxga02-in.huawei.com (SkyGuard) with ESMTP id 4HDgvJ5qwkz8yfd; Wed, 22 Sep 2021 09:39:24 +0800 (CST) Received: from dggpemm500006.china.huawei.com (7.185.36.236) by dggemv703-chm.china.huawei.com (10.3.19.46) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_128_GCM_SHA256) id 15.1.2308.8; Wed, 22 Sep 2021 09:43:56 +0800 Received: from mdc.huawei.com (10.175.112.208) by dggpemm500006.china.huawei.com (7.185.36.236) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_128_GCM_SHA256) id 15.1.2308.8; Wed, 22 Sep 2021 09:43:56 +0800 From: Chen Jun To: , CC: , , , Subject: [PATCH v2 1/1] mm: Fix the uninitialized use in overcommit_policy_handler Date: Wed, 22 Sep 2021 01:41:22 +0000 Message-ID: <20210922014122.47219-1-chenjun102@huawei.com> X-Mailer: git-send-email 2.17.1 MIME-Version: 1.0 Content-Type: text/plain X-Originating-IP: [10.175.112.208] X-ClientProxiedBy: dggems705-chm.china.huawei.com (10.3.19.182) To dggpemm500006.china.huawei.com (7.185.36.236) X-CFilter-Loop: Reflected Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org An unexpected value of /proc/sys/vm/panic_on_oom we will get, after running the following program. int main() { int fd = open("/proc/sys/vm/panic_on_oom", O_RDWR) write(fd, "1", 1); write(fd, "2", 1); close(fd); } write(fd, "2", 1) will pass *ppos = 1 to proc_dointvec_minmax. proc_dointvec_minmax will return 0 without setting new_policy. t.data = &new_policy; ret = proc_dointvec_minmax(&t, write, buffer, lenp, ppos) -->do_proc_dointvec -->__do_proc_dointvec if (write) { if (proc_first_pos_non_zero_ignore(ppos, table)) goto out; sysctl_overcommit_memory = new_policy; so sysctl_overcommit_memory will be set to an uninitialized value. Check whether new_policy has been changed by proc_dointvec_minmax. Fixes: 56f3547bfa4d ("mm: adjust vm_committed_as_batch according to vm overcommit policy" Signed-off-by: Chen Jun --- v2: * Check whether new_policy has been changed by proc_dointvec_minmax. mm/util.c | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/mm/util.c b/mm/util.c index 4ddb6e186dd5..d5be67771850 100644 --- a/mm/util.c +++ b/mm/util.c @@ -756,7 +756,7 @@ int overcommit_policy_handler(struct ctl_table *table, int write, void *buffer, size_t *lenp, loff_t *ppos) { struct ctl_table t; - int new_policy; + int new_policy = -1; int ret; /* @@ -774,7 +774,7 @@ int overcommit_policy_handler(struct ctl_table *table, int write, void *buffer, t = *table; t.data = &new_policy; ret = proc_dointvec_minmax(&t, write, buffer, lenp, ppos); - if (ret) + if (ret || new_policy == -1) return ret; mm_compute_batch(new_policy); -- 2.17.1