fuse_lowlevel.c: fix possible 64 bits value truncation
authorLuis Henriques <luis@igalia.com>
Fri, 31 Jan 2025 15:26:20 +0000 (15:26 +0000)
committerBernd Schubert <bernd@bsbernd.com>
Mon, 10 Feb 2025 15:56:45 +0000 (16:56 +0100)
Because conn.want_ext is a uint64_t, copying it into a uint32_t may result
in truncating it's value.  This patch fixes a bug in do_init() where the
32 bits copy is again converted into a 64 bits value, because it will be
used in convert_to_conn_want_ext().

Signed-off-by: Luis Henriques <luis@igalia.com>
lib/fuse_lowlevel.c

index c993860cdf3808f3adeaed2c30db3384a5c2add1..36baaa65b50dfc3b69b1b2e8cfdd3c10c8577d18 100644 (file)
@@ -2178,7 +2178,7 @@ void do_init(fuse_req_t req, fuse_ino_t nodeid, const void *inarg)
 
        se->got_init = 1;
        if (se->op.init) {
-               uint32_t want_ext_default = se->conn.want_ext;
+               uint64_t want_ext_default = se->conn.want_ext;
                int rc;
 
                // Apply the first 32 bits of capable_ext to capable