Received: by 2002:a25:ad19:0:0:0:0:0 with SMTP id y25csp9290350ybi; Wed, 24 Jul 2019 01:28:47 -0700 (PDT) X-Google-Smtp-Source: APXvYqzXr2kPOkPFaN6TEtXJplGGQTqX+/tJcN1ztQg2akzALkPwQNF+y7ezQAtfgJ4OYr0QmfJv X-Received: by 2002:a63:194f:: with SMTP id 15mr45560359pgz.382.1563956927694; Wed, 24 Jul 2019 01:28:47 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1563956927; cv=none; d=google.com; s=arc-20160816; b=z9NHZkVLByXiQyXIdQuhkN74ruEDWNwx4vrgsN5+sUSqBxUpQK+gmxWpClMzdbqcfL vqwMIa24EzqtEYzgmYiokaFCYXoy5wony5W1qVtL+WnLhCe/JYLt85syCeAH+SiFNocB wxK7HOUIMX8AfvpQRsLVHGeQZ2UGj6CoRBEGPmzAozNYX6m0WrFPy0SHD0uA8iOgjEVL dBQCZBXYI1wtE2/KOyjjUpXSmoary8LY8zjuWhsiAbrf0yNhdS4/ClxwONrvnjM7aDLx nG/XPeYwJau8xjlyOBU5Uv/nU0+13+8llaNBWfAo7tp9WZVpNdTVrjdVsH/Qvk3iFWQf YvjQ== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:message-id:date:subject:cc:to:from :dkim-signature; bh=0C3QHUgqiz2AWGYc73OVCf2o4dWSm01USkJ0t4N3DX4=; b=E1j6VUYHJBi5W+xpsleA6+FfU5RvMfgb/ebIdN/rnWIFCD7sh4XX6Qrb1EZlNZikTr mE8TTv523xfTSD1gnWMsxiQmdIKCJ02XnH9nLN9BMjrXNnjibKoMJ1N5Jk2j/YyPzTjL b0TaL2XCyhG8srTIgk47F9iwf0+tAiqRfZaURJfmCTtz2nokI2I73QL5Dx2CPIlamdcp /kc4I8ASmkFC334C+djq2qb5MI+Afw8coE107x4TIMJbYJl7r7hWBGnX0EiZ2bTfQ4A2 BZCESEZsZR9ah3SlgFkvn/2diEowHEMXWz0w9L0aDoZIU9KbOdvZnvbCbx6pHnJeeYfb 7tZA== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@gmail.com header.s=20161025 header.b=Pmja9Lry; spf=pass (google.com: best guess record for domain of linux-nfs-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-nfs-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 w11si13198683pgr.321.2019.07.24.01.28.26; Wed, 24 Jul 2019 01:28:47 -0700 (PDT) Received-SPF: pass (google.com: best guess record for domain of linux-nfs-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=Pmja9Lry; spf=pass (google.com: best guess record for domain of linux-nfs-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-nfs-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 S1726043AbfGXI2N (ORCPT + 99 others); Wed, 24 Jul 2019 04:28:13 -0400 Received: from mail-pg1-f195.google.com ([209.85.215.195]:36714 "EHLO mail-pg1-f195.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1726023AbfGXI2M (ORCPT ); Wed, 24 Jul 2019 04:28:12 -0400 Received: by mail-pg1-f195.google.com with SMTP id l21so20839006pgm.3; Wed, 24 Jul 2019 01:28:12 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=gmail.com; s=20161025; h=from:to:cc:subject:date:message-id; bh=0C3QHUgqiz2AWGYc73OVCf2o4dWSm01USkJ0t4N3DX4=; b=Pmja9LryXNERq5j5QPJ7x80n1QFTUD6r3VZAiyBwmifIu8xEmifP7rxzYzadZxiI18 Gl8jXyqQpBMvAZHAVnjtxVMM5TS1Bkv3q/lT+kG5iNft1wXvxoDtQpw3lbhdnGfWzoTl pkWjtfzaXv1gji8kUKy+Hews+GB0jMqtswQYfVY3bQR/WIfOTHSAnSJF1Kl0/njmYIBn bm6lW7FxgE/BUzJIJC1sYNq6l2Akcv7f197i0LxXkardtVnWOH7N8SnSlIowe1cSuBRZ By7dMPnzOGCwDR4fJSlbSMxickl78DpEYTWfbz2zdmoQJAM6k4T5MYHE5CPyhxfbpxrS +svg== 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; bh=0C3QHUgqiz2AWGYc73OVCf2o4dWSm01USkJ0t4N3DX4=; b=cXkHdqO2vl5XjliU6yFXHeDmpr9scAnqi5u590uFxAsQy3np/URLwgRirmUl97KC5T tyuJe9reckt8LxEoz0lRfLHH5uajspUg4DfG83V/aqiIU7N8qK3khkfxxrWtxtrg/fjE gq9cEIBpz95joO1rFpPERIMPlos+jyNvHG89ERED6EUfPjw0guQVGI5hQJeDTfFTvMO4 DWOdPi6Uzp8thXUYhvIdpHSKsQWUxEDO4nSQA/dKH2PQmY/zEwjnzRlXRcNZ2xZeWOmf zktNbIn4beCSZGPVbnJomIc4gHfodrxts3C19XLZIHwf030xfRWNq8rNB4DqV6VUUnH0 RWSA== X-Gm-Message-State: APjAAAXtaJunarFeNgx77yXaxNM+BAbFAEJSMbKuoRaQtWigQP/66yhm ic/WWkNi8IwUk7aNKAjjyqI= X-Received: by 2002:a17:90a:5887:: with SMTP id j7mr85540151pji.136.1563956892216; Wed, 24 Jul 2019 01:28:12 -0700 (PDT) Received: from oslab.tsinghua.edu.cn ([2402:f000:4:72:808::3ca]) by smtp.gmail.com with ESMTPSA id b68sm58226735pfb.149.2019.07.24.01.28.09 (version=TLS1_2 cipher=ECDHE-RSA-AES128-GCM-SHA256 bits=128/128); Wed, 24 Jul 2019 01:28:11 -0700 (PDT) From: Jia-Ju Bai To: bfields@fieldses.org, chuck.lever@oracle.com Cc: linux-nfs@vger.kernel.org, linux-kernel@vger.kernel.org, Jia-Ju Bai Subject: [PATCH] fs: nfsd: Fix three possible null-pointer dereferences Date: Wed, 24 Jul 2019 16:28:03 +0800 Message-Id: <20190724082803.1077-1-baijiaju1990@gmail.com> X-Mailer: git-send-email 2.17.0 Sender: linux-nfs-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-nfs@vger.kernel.org In nfs4_xdr_dec_cb_recall(), nfs4_xdr_dec_cb_layout() and nfs4_xdr_dec_cb_notify_lock(), there is an if statement to check whether cb is NULL. When cb is NULL, the three functions all call: decode_cb_op_status(..., &cb->cb_status); Thus, possible null-pointer dereferences may occur. To fix these possible bugs, -EINVAL is returned when cb is NULL. These bugs are found by a static analysis tool STCheck written by us. Signed-off-by: Jia-Ju Bai --- fs/nfsd/nfs4callback.c | 11 ++++++++--- 1 file changed, 8 insertions(+), 3 deletions(-) diff --git a/fs/nfsd/nfs4callback.c b/fs/nfsd/nfs4callback.c index 397eb7820929..55949a158b6b 100644 --- a/fs/nfsd/nfs4callback.c +++ b/fs/nfsd/nfs4callback.c @@ -516,7 +516,8 @@ static int nfs4_xdr_dec_cb_recall(struct rpc_rqst *rqstp, status = decode_cb_sequence4res(xdr, cb); if (unlikely(status || cb->cb_seq_status)) return status; - } + } else + return -EINVAL; return decode_cb_op_status(xdr, OP_CB_RECALL, &cb->cb_status); } @@ -608,7 +609,9 @@ static int nfs4_xdr_dec_cb_layout(struct rpc_rqst *rqstp, status = decode_cb_sequence4res(xdr, cb); if (unlikely(status || cb->cb_seq_status)) return status; - } + } else + return -EINVAL; + return decode_cb_op_status(xdr, OP_CB_LAYOUTRECALL, &cb->cb_status); } #endif /* CONFIG_NFSD_PNFS */ @@ -667,7 +670,9 @@ static int nfs4_xdr_dec_cb_notify_lock(struct rpc_rqst *rqstp, status = decode_cb_sequence4res(xdr, cb); if (unlikely(status || cb->cb_seq_status)) return status; - } + } else + return -EINVAL; + return decode_cb_op_status(xdr, OP_CB_NOTIFY_LOCK, &cb->cb_status); } -- 2.17.0