Received: by 2002:a25:c205:0:0:0:0:0 with SMTP id s5csp2756912ybf; Mon, 2 Mar 2020 15:04:38 -0800 (PST) X-Google-Smtp-Source: ADFU+vtlRKvEIofwb85mOxykOzMmSL8KzI+C1pT3Y6AFFRhF8RIGxNfgNMsvYxxemPtFy2+JbSho X-Received: by 2002:a05:6830:11d4:: with SMTP id v20mr1135974otq.372.1583190278316; Mon, 02 Mar 2020 15:04:38 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1583190278; cv=none; d=google.com; s=arc-20160816; b=jKO9hcBzCHhoWvLKPZ084R1oxjnmtH+5QD7YDramypTtr5KxtyH6kgXL7p0d4Fw2YP 7WnT9flZC/R6GSYXP+Js7sSaRLkL6NowjThkqo2fapxNm9tWUc3vDrVm3lBJhwCUHd26 pqEu/Fjo8Srocvh/YHiOKrZSXdITii/X5h3SCEwG8rqSN5A2JY7Ql6E3/uGAcDdOXmom iW7ff1KB7J2w+7zkhCp1rMIfPyVmplBLZwsVejFULAonBNrm6y4ROH1w5NIdb2Y00K16 f/6UZdCnfroWo72+YFjjtb3aOqbpW+RKkE7tRfDLY7HP5gdXa5KirxJ6U2S+pFFOTbDt kbsA== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:content-transfer-encoding:mime-version :message-id:date:subject:cc:to:from:dkim-signature; bh=TQJUvsCfdhXZTMuK5P/1s7YDv4YpFHdf94n7B4huL1w=; b=bHwHy3MML8ZDUHNQNHcyEU6pu0jqMJxT0qfhH9HBTH2XpR5soswIy1jbKBQCzx5Mgm Mwn8SyLAQoC0sgLevWMvz4EetUWo811ke7s9vipgpcsRk/FPdUsM/EGtsncPctDkDYob cmeNGji6Rx/RJCqSeioYn/HHCZLcWI9Xtzv++BD4n1Rvzpuy6USOPxdIEdYQO3BBXEd+ WvJeji/QiyFMJ6PittU/1DZTAMNaBR4xNgLZNwBWX7FtUV3kQQ2HEosFi3JJDW+cirN9 Fc+FJ7X0EaBojFLMZ1sKoAr645b+zjjlkjI31PK+RowR2EAdyz8rX8nRn14udY1yw+Ge KrvQ== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@gmail.com header.s=20161025 header.b=TeAa4GF1; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=QUARANTINE dis=NONE) header.from=gmail.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id w20si4024009otj.294.2020.03.02.15.04.21; Mon, 02 Mar 2020 15:04:38 -0800 (PST) Received-SPF: pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) client-ip=209.132.180.67; Authentication-Results: mx.google.com; dkim=pass header.i=@gmail.com header.s=20161025 header.b=TeAa4GF1; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=QUARANTINE dis=NONE) header.from=gmail.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1726843AbgCBXCz (ORCPT + 99 others); Mon, 2 Mar 2020 18:02:55 -0500 Received: from mail-ot1-f67.google.com ([209.85.210.67]:41755 "EHLO mail-ot1-f67.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1726728AbgCBXCz (ORCPT ); Mon, 2 Mar 2020 18:02:55 -0500 Received: by mail-ot1-f67.google.com with SMTP id v19so1069331ote.8; Mon, 02 Mar 2020 15:02:54 -0800 (PST) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=gmail.com; s=20161025; h=from:to:cc:subject:date:message-id:mime-version :content-transfer-encoding; bh=TQJUvsCfdhXZTMuK5P/1s7YDv4YpFHdf94n7B4huL1w=; b=TeAa4GF1Uo6zEiC8wTfqSOdSDq+sIm2r7mCILqG9rM1RSOusW87Nsqi4KFuFyqI6vl L/6lC0DVayS+mWxkMhRUVIz1IQM7m47N9X5Wf0BSlohxkF+FuDUUZZuNlEsA0xy58pIW sUrKv9E+nU9x6wkIvrTvK/60H4W9/0TMM4y8VR0BUnmT/TnYVpB3fkr+inR+O/U4/tUe zspe0kB15glmsBQRwzBtjcjedPuqbP6U7mpCMGBODv8LbQrSHhsgcF6wb5M96ZpFpkvG NZJ14VcRepgy03TaDNOr1ggNuwqrGJS91UavFhd8UuiWEd/Cri3ZJq3qg1hg4/ltQcpk INkg== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:from:to:cc:subject:date:message-id:mime-version :content-transfer-encoding; bh=TQJUvsCfdhXZTMuK5P/1s7YDv4YpFHdf94n7B4huL1w=; b=Yk3Tio7HN+7GWktpKA4Q568sZYAY1eVNVSEZCnx3DRWHO4NkuRVQP+I95Cg3H40x2Y Kkg/dc1egLd7yGG4RNf5BW5mzCiYLRdsJ9zK8w05YfubSpMUL2LMWOeGjXL5Ij9KvOcp 7bNv5sT+33Xrs2fArN395lJoR4g31LO3xEf5zgtYtn6eRj2HPP7UDGK1cqk9kLAx+3pw fBdfS0Rq5kTAf1jAy+M5dfuaZMtK+6fkThMBqwacAZiObVbDQHxdqWz3HavXwvcbDQJj a9qBhtW+deWu+wpVMS3OMzt+qCMXib649KMMDjZl2lDcyXQHF0UFwAQpSdIvr2+s2mZt jCdw== X-Gm-Message-State: ANhLgQ2xi3uTjXNycCFTyYjyTgLcCk8bqllTF+RAnjSCR4zvka0XWVuC YhKyf1FSujyIFvWo6fMVzb4= X-Received: by 2002:a9d:3c1:: with SMTP id f59mr1248078otf.170.1583190174381; Mon, 02 Mar 2020 15:02:54 -0800 (PST) Received: from localhost.localdomain ([2604:1380:4111:8b00::1]) by smtp.gmail.com with ESMTPSA id n9sm3317261otq.73.2020.03.02.15.02.53 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Mon, 02 Mar 2020 15:02:53 -0800 (PST) From: Nathan Chancellor To: Jens Axboe Cc: io-uring@vger.kernel.org, linux-kernel@vger.kernel.org, clang-built-linux@googlegroups.com, Nathan Chancellor Subject: [PATCH -next] io_uring: Ensure mask is initialized in io_arm_poll_handler Date: Mon, 2 Mar 2020 16:01:19 -0700 Message-Id: <20200302230118.12060-1-natechancellor@gmail.com> X-Mailer: git-send-email 2.25.1 MIME-Version: 1.0 X-Patchwork-Bot: notify Content-Transfer-Encoding: 8bit Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Clang warns: fs/io_uring.c:4178:6: warning: variable 'mask' is used uninitialized whenever 'if' condition is false [-Wsometimes-uninitialized] if (def->pollin) ^~~~~~~~~~~ fs/io_uring.c:4182:2: note: uninitialized use occurs here mask |= POLLERR | POLLPRI; ^~~~ fs/io_uring.c:4178:2: note: remove the 'if' if its condition is always true if (def->pollin) ^~~~~~~~~~~~~~~~ fs/io_uring.c:4154:15: note: initialize the variable 'mask' to silence this warning __poll_t mask, ret; ^ = 0 1 warning generated. io_op_defs has many definitions where pollin is not set so mask indeed might be uninitialized. Initialize it to zero and change the next assignment to |=, in case further masks are added in the future to avoid missing changing the assignment then. Fixes: d7718a9d25a6 ("io_uring: use poll driven retry for files that support it") Link: https://github.com/ClangBuiltLinux/linux/issues/916 Signed-off-by: Nathan Chancellor --- I noticed that for-next has been force pushed; if you want to squash this into the commit that it fixes (or fix it in a different way), feel free. fs/io_uring.c | 3 ++- 1 file changed, 2 insertions(+), 1 deletion(-) diff --git a/fs/io_uring.c b/fs/io_uring.c index 8cdd3870cd4e..70e4624af3c2 100644 --- a/fs/io_uring.c +++ b/fs/io_uring.c @@ -3738,8 +3738,9 @@ static bool io_arm_poll_handler(struct io_kiocb *req) req->apoll = apoll; INIT_HLIST_NODE(&req->hash_node); + mask = 0; if (def->pollin) - mask = POLLIN | POLLRDNORM; + mask |= POLLIN | POLLRDNORM; if (def->pollout) mask |= POLLOUT | POLLWRNORM; mask |= POLLERR | POLLPRI; -- 2.25.1