Received: by 2002:ab2:2994:0:b0:1ef:ca3e:3cd5 with SMTP id n20csp123474lqb; Thu, 14 Mar 2024 07:09:10 -0700 (PDT) X-Forwarded-Encrypted: i=3; AJvYcCWyaT0dPUTKCd50sx4EojZwvUqnlCsldKUSh8VrkQKTLNhEEAVzW67gDu7Tq7Kjk6NuUiR1bLvBb7bBI+/A4CEHOj9t3YmgQVwxyI8Fsg== X-Google-Smtp-Source: AGHT+IEty8ZoFIV/QvLyqeMLjVVY7H62doKYZl/Z6ndGo9BJxjcu7+vwuEhc/VUHMcTsHJO9kNgR X-Received: by 2002:a05:6808:16a3:b0:3c2:1f6b:ae6e with SMTP id bb35-20020a05680816a300b003c21f6bae6emr1972545oib.12.1710425350204; Thu, 14 Mar 2024 07:09:10 -0700 (PDT) ARC-Seal: i=2; a=rsa-sha256; t=1710425350; cv=pass; d=google.com; s=arc-20160816; b=hSHl+398kR+LulNavd7uyug4r09vrGeRqQuNm3pPatT5ZGP+GTh261G2DwvVmEwKus FbAF7oGxy2ATrQy9k+ip5XJKc2tnI6XaHdo/AxClzf9LdEl9+vuMzxppQnI8SKYThluB CShyrsmeuFFRDxXwDu8/07gd0u1KxS7waQDktNOvlVk8euhZgLvo/Z/3YTvvTaneLh3z nbFmcy89twKJ93fGWtl8dPKRgFPuqdm07+HRJijA2mjIK6gmPOyLXg0eZo3ijDeaHBSq /lOFBZnc+okEnmybRBpqxOkd90Vm65+6Z+Ff8ThBRKKIPFuvVuMAMkEuGh5+Wai5Ct7Z yb9w== ARC-Message-Signature: i=2; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=content-transfer-encoding:mime-version:list-unsubscribe :list-subscribe:list-id:precedence:message-id:date:subject:cc:to :from; bh=dbz5L4TOFU5gQ8ml0cScl7N3aCQgWpY3MxUN8NM8p84=; fh=4vN4thPQ5z49h0k3wc47Ze2ZGwmxH293ZHjdupTAu0I=; b=jrR9g4ZjCmR6eyme1PZsEYZyNBcr0GXZ4oB3FBziml/rVgnAcTdoF1yxcV0LZEfDsC n1kJU2N2hscEVGlqnFCcvkzIzvTjIfifIWcOLm6w+yLBURJuaTNmh2nBoP8LhzoqNTnd QNY8fVEVnLSYnPOKe+MGJ7vlHZomUgvYyodCpxqFRdxSbFEXFCL2ke0bPdt9VBz0Hoz5 IFqdIL6HwLsKSqAVdsP1QXXuNMz2niAo4IesLxhISHc8X0GEjCkZka1YcoBLDxiMk9ih uc3i6vSlTCzD+7b2b7tnkJHs7QRe0hO39A5vmcxTjijLA2562/Mp5x9bRegoQKlAuu1x z+iw==; dara=google.com ARC-Authentication-Results: i=2; mx.google.com; arc=pass (i=1 spf=pass spfdomain=huawei.com dmarc=pass fromdomain=huawei.com); spf=pass (google.com: domain of linux-kernel+bounces-103356-linux.lists.archive=gmail.com@vger.kernel.org designates 2604:1380:45d1:ec00::1 as permitted sender) smtp.mailfrom="linux-kernel+bounces-103356-linux.lists.archive=gmail.com@vger.kernel.org"; dmarc=fail (p=QUARANTINE sp=QUARANTINE dis=QUARANTINE) header.from=huawei.com Return-Path: Received: from ny.mirrors.kernel.org (ny.mirrors.kernel.org. [2604:1380:45d1:ec00::1]) by mx.google.com with ESMTPS id je8-20020a056130680800b007d952bdee65si143726uab.22.2024.03.14.07.09.10 for (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Thu, 14 Mar 2024 07:09:10 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel+bounces-103356-linux.lists.archive=gmail.com@vger.kernel.org designates 2604:1380:45d1:ec00::1 as permitted sender) client-ip=2604:1380:45d1:ec00::1; Authentication-Results: mx.google.com; arc=pass (i=1 spf=pass spfdomain=huawei.com dmarc=pass fromdomain=huawei.com); spf=pass (google.com: domain of linux-kernel+bounces-103356-linux.lists.archive=gmail.com@vger.kernel.org designates 2604:1380:45d1:ec00::1 as permitted sender) smtp.mailfrom="linux-kernel+bounces-103356-linux.lists.archive=gmail.com@vger.kernel.org"; dmarc=fail (p=QUARANTINE sp=QUARANTINE dis=QUARANTINE) header.from=huawei.com Received: from smtp.subspace.kernel.org (wormhole.subspace.kernel.org [52.25.139.140]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by ny.mirrors.kernel.org (Postfix) with ESMTPS id E0BD71C211B9 for ; Thu, 14 Mar 2024 14:09:09 +0000 (UTC) Received: from localhost.localdomain (localhost.localdomain [127.0.0.1]) by smtp.subspace.kernel.org (Postfix) with ESMTP id 2268371B2E; Thu, 14 Mar 2024 14:07:57 +0000 (UTC) Received: from szxga04-in.huawei.com (szxga04-in.huawei.com [45.249.212.190]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by smtp.subspace.kernel.org (Postfix) with ESMTPS id D46AE6FE0F; Thu, 14 Mar 2024 14:07:53 +0000 (UTC) Authentication-Results: smtp.subspace.kernel.org; arc=none smtp.client-ip=45.249.212.190 ARC-Seal:i=1; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1710425276; cv=none; b=KFZnZthRAmjiYtOk4Ge5OF5pA6+dc5V+RZxBsHbwQvb31BxAbv3MF0vxsQU+tEB89wxZQxUAQ2bhyosZdpdZSy1K78YsThDPjwGCG+pn7mzBh+tTh4Xr0Ksj2e8jjkVVpSGXiRje/rLYbQvC6eUGCQEGoSoi6OnAZrW8nVfCyk8= ARC-Message-Signature:i=1; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1710425276; c=relaxed/simple; bh=odRmT7UK/s7luR1x7tKC7jZZCm/oFTi/0JJje90h0xE=; h=From:To:CC:Subject:Date:Message-ID:MIME-Version:Content-Type; b=V4EaYkBDeDeNoJGk+bOgy8oHVcRJgOtrZtKw0RKnoqoURTvuwtXBTfRVvHu/orY38MPDhBJxoLxr6Z4L+Me5HRh5Ao9jHvpazcDOIcH8MRoPoimH6WItLNQaZ08ROrf7u/xia0yuDeb3IjZxDYmfXvtuh5GTslxe4+OVAAXGJv8= ARC-Authentication-Results:i=1; smtp.subspace.kernel.org; dmarc=pass (p=quarantine dis=none) header.from=huawei.com; spf=pass smtp.mailfrom=huawei.com; arc=none smtp.client-ip=45.249.212.190 Authentication-Results: smtp.subspace.kernel.org; dmarc=pass (p=quarantine dis=none) header.from=huawei.com Authentication-Results: smtp.subspace.kernel.org; spf=pass smtp.mailfrom=huawei.com Received: from mail.maildlp.com (unknown [172.19.163.17]) by szxga04-in.huawei.com (SkyGuard) with ESMTP id 4TwTfg0y5jz2Bd15; Thu, 14 Mar 2024 22:05:15 +0800 (CST) Received: from dggpeml500021.china.huawei.com (unknown [7.185.36.21]) by mail.maildlp.com (Postfix) with ESMTPS id 67C691A0172; Thu, 14 Mar 2024 22:07:43 +0800 (CST) Received: from huawei.com (10.175.127.227) by dggpeml500021.china.huawei.com (7.185.36.21) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.1.2507.35; Thu, 14 Mar 2024 22:07:42 +0800 From: Baokun Li To: CC: , , , , , , , , , Subject: [PATCH v3 0/9] ext4: avoid sysfs variables overflow causing BUG_ON/SOOB Date: Thu, 14 Mar 2024 22:08:57 +0800 Message-ID: <20240314140906.3064072-1-libaokun1@huawei.com> X-Mailer: git-send-email 2.31.1 Precedence: bulk X-Mailing-List: linux-kernel@vger.kernel.org List-Id: List-Subscribe: List-Unsubscribe: MIME-Version: 1.0 Content-Transfer-Encoding: 8bit Content-Type: text/plain X-ClientProxiedBy: dggems705-chm.china.huawei.com (10.3.19.182) To dggpeml500021.china.huawei.com (7.185.36.21) Hello everyone, This patchset is intended to avoid variables that can be modified via sysfs from overflowing when stored or used and thus causing various problems. "kvm-xfstests -c ext4/all -g auto" has been executed with no new failures. V2->V3: Add Reviewed-by tag from Jan Kara. Patch 4: Trimming order before the for loop makes the logic easier to understand. V1->V2: Patch 1: Use kstrtouint() as suggested by Alexey and Honza. Patch 2: Adapted to patch 1 changes. Patch 3: Add Reviewed-by tag. Patch 4: Avoid useless loops as suggested by Ojaswin and rename attr_group_prealloc to attr_clusters_in_group. Patch 5: New patch added to limit mb_best_avail_max_trim_order < 64 as Honza's suggestion. Patch 6: Reordered and updated description. Patch 7: Add Reviewed-by tag. Patch 8: Keep unrelated variables on different lines as suggested by Honza. Patch 9: New patch to fix warnings found during compile checking. [V1]: https://lore.kernel.org/all/20240126085716.1363019-1-libaokun1@huawei.com/ [V2]: https://lore.kernel.org/all/20240227091148.178435-1-libaokun1@huawei.com/ Baokun Li (9): ext4: avoid overflow when setting values via sysfs ext4: refactor out ext4_generic_attr_store() ext4: refactor out ext4_generic_attr_show() ext4: fix slab-out-of-bounds in ext4_mb_find_good_group_avg_frag_lists() ext4: add new attr pointer attr_mb_order ext4: add positive int attr pointer to avoid sysfs variables overflow ext4: set type of ac_groups_linear_remaining to __u32 to avoid overflow ext4: set the type of max_zeroout to unsigned int to avoid overflow ext4: clean up s_mb_rb_lock to fix build warnings with C=1 fs/ext4/extents.c | 3 +- fs/ext4/mballoc.c | 5 +- fs/ext4/mballoc.h | 2 +- fs/ext4/sysfs.c | 174 ++++++++++++++++++++++++++++------------------ 4 files changed, 112 insertions(+), 72 deletions(-) -- 2.31.1