diff options
| author | Arnd Bergmann <arnd@arndb.de> | 2026-03-16 17:42:51 +0300 |
|---|---|---|
| committer | Dave Kleikamp <dave.kleikamp@oracle.com> | 2026-03-16 18:20:47 +0300 |
| commit | dad98c5b2a05ef744af4c884c97066a3c8cdad61 (patch) | |
| tree | 3186b0a53d950f6ce72ceca5fe8eec7dc732a7f0 | |
| parent | 679330e4a7af1d102d035b13b2b9d41bc1dfbbf7 (diff) | |
| download | linux-dad98c5b2a05ef744af4c884c97066a3c8cdad61.tar.xz | |
jfs: avoid -Wtautological-constant-out-of-range-compare warning again
The comparison of an __s8 value against DTPAGEMAXSLOT is still trivially
true, causing a harmless (default disabled) warning with clang:
fs/jfs/jfs_dtree.c:4419:25: error: result of comparison of constant 128 with expression of type 's8' (aka 'signed char') is always false [-Werror,-Wtautological-constant-out-of-range-compare]
4419 | p->header.freelist >= DTPAGEMAXSLOT)) {
| ~~~~~~~~~~~~~~~~~~ ^ ~~~~~~~~~~~~~
I previously worked around two of these in commit 7833570dae83 ("jfs: avoid
-Wtautological-constant-out-of-range-compare warning"), but now a new one has
come up, so address the same way by dropping the redundant range check.
Fixes: 119e448bb50a ("jfs: add dtpage integrity check to prevent index/pointer overflows")
Signed-off-by: Arnd Bergmann <arnd@arndb.de>
Signed-off-by: Dave Kleikamp <dave.kleikamp@oracle.com>
| -rw-r--r-- | fs/jfs/jfs_dtree.c | 7 |
1 files changed, 2 insertions, 5 deletions
diff --git a/fs/jfs/jfs_dtree.c b/fs/jfs/jfs_dtree.c index 7669e268fe35..ac0f79fafaca 100644 --- a/fs/jfs/jfs_dtree.c +++ b/fs/jfs/jfs_dtree.c @@ -4412,11 +4412,8 @@ bool check_dtpage(dtpage_t *p) } } else { int fsi; - /* When there are free slots, freelist must be a valid slot index in - * 1~DTROOTMAXSLOT-1(since slot[0] is occupied by the header). - */ - if (unlikely(p->header.freelist < 1 || - p->header.freelist >= DTPAGEMAXSLOT)) { + + if (unlikely(p->header.freelist < 1)) { jfs_err("Bad freelist:%d in dtpage\n", p->header.freelist); return false; } |
