Received: by 2002:a25:4158:0:0:0:0:0 with SMTP id o85csp2693966yba; Mon, 6 May 2019 10:05:26 -0700 (PDT) X-Google-Smtp-Source: APXvYqykgojTlQuvPv8MscYW2d56a0piYlJl4DlYU4umPmJUzBWe0b2MfChinFKGvgh+/aD737VP X-Received: by 2002:a17:902:3324:: with SMTP id a33mr2304939plc.1.1557162326329; Mon, 06 May 2019 10:05:26 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1557162326; cv=none; d=google.com; s=arc-20160816; b=vNmBwo9PQSCggTNnub1BnXdgT/a6gcVBDc54TDIjwCLlag0MxMSU9g7Kb8av50lWtf lHIU8rjLWRyvmy3Gdd5aU7qQFTmuOUwfkomP89BTEiKU97YnKbxUi0VPQm4yQ9m22SLK rFKJHS8T/SH7AGehkw8HvfmmNeiLIC/LU32IpSMWxjg9etw0xjBN/pHwT4/1mCO8wg/Y SlGJutEQ19CVhUHA7aVBsMxigXWSzNcpJyc1STiDJ/5DkPfbH8jFzxQcqMSl1jlkzWxx 7kkSH7fDOMozlyUz/T2LaepGLBRmFNhPQO2Z6GhAA3eETMU2rPczzED64IDUnJJeP5VL z2eg== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:cc:to:subject:message-id:date:from :in-reply-to:references:mime-version:dkim-signature; bh=Qy+Uvnt48sjAfiUPJQkldDmklRLHRIc2GGNrnTuoC0Q=; b=AO/AcrjMiS19+Ac0VxyRivhXYL3/Xu7F8xiTkRLsOJNqfWbWMrGIaHstOeuvb8F/mv xo+FbK6DIGnu+rWqsj2HrUV/m0y1ZPrtVjGffWdK2RaLCi4EUaVENSlfFkqZRffKaAiz 1HNgLf5nUi2u6S6cg+9z0bsg0jbxDNaDvywwq/8Vpftk5PS9GkH1bkeuCUWPx7lM8RT4 D/WG6Jyn9rbvlJM1jWi7IWpsCE7qZdDMd+D6CLBE9CWufPCFNBBnaiQn+SPLpbA/kSOa WDXijE7zhuHK22vUH/KY5RVFGM9BpADezVePrSgiclJFJAkgASb8iyuQ/w7lVoCSZKQ/ XFwA== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@gmail.com header.s=20161025 header.b=Cz5Eejok; 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 y14si14883722pga.217.2019.05.06.10.05.09; Mon, 06 May 2019 10:05:26 -0700 (PDT) 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=Cz5Eejok; 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 S1726833AbfEFRCU (ORCPT + 99 others); Mon, 6 May 2019 13:02:20 -0400 Received: from mail-pg1-f196.google.com ([209.85.215.196]:32890 "EHLO mail-pg1-f196.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1726517AbfEFRCT (ORCPT ); Mon, 6 May 2019 13:02:19 -0400 Received: by mail-pg1-f196.google.com with SMTP id h17so775231pgv.0; Mon, 06 May 2019 10:02:19 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=gmail.com; s=20161025; h=mime-version:references:in-reply-to:from:date:message-id:subject:to :cc; bh=Qy+Uvnt48sjAfiUPJQkldDmklRLHRIc2GGNrnTuoC0Q=; b=Cz5Eejokd6UGPW9qdjFeTimi9ZTg0DcaFj32df9nbInXYCObQYSCoEkyAChntWZ5H+ E5FD/xoLySqtV06cAIB523RuTsFNGsmeMHQuQ4PFZrzOzU3NjbnNgPM1zDbIHwE0ras+ 1fmQJDHy3FiA3btWdLmfXNWo+a5ebrpr1qHcEfK+w6CNAlPW69DoCwB9JXNyTOoYKBxk +OS7iAiP5ajY19lxbGlrIJAPdtFbDNLsHIqsP2I8eRLJD7+kC4JzLqaj9TJW5LHMsclL dDnaa9ZXEAz4Kdq300KGoFHfc4fXwki4OiMKZks27JiVbmI/Pb1QUsVRpUoaN3SuOPEj mdTg== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:mime-version:references:in-reply-to:from:date :message-id:subject:to:cc; bh=Qy+Uvnt48sjAfiUPJQkldDmklRLHRIc2GGNrnTuoC0Q=; b=L5tvZ2Jz0X0aOIyjcstpAshBjy3QO/40YkqunZid3CkDKJnTVT/eqnCu9tAX48J0S+ w3n5R2/i03f5OYbz396iyywXYmybLXnayAPNREYIVOPydQkGGKAYI1LHddKou1lz0IfB jarJGAJqC6EBMlPvX+qBeZhEPvuU/loyHkZaP0s/mVavjuGnQvLDYHVBtJG8sJZnliuC gFQVweCC1NPn8tXfIOal/wwhsAUTmdcMzQWVavwpD/W0lkZyQJI9LPOY0QL7fjj1FHxh nvgAl3r5s39Aw1s7f28G6F9lUQZ3alwtNAMRYvIYRv2QEFT1F7ZBNg0dGUovCZl82b8H PWIA== X-Gm-Message-State: APjAAAVsLx43oasMudwEIEejfLhlhUPz+TcY+ulAzd4i4wviwXz9ojtb x4zDqPd7QoVVQRBoPVstNIr10HGPbFreEa8X5uQ= X-Received: by 2002:a62:479b:: with SMTP id p27mr35842131pfi.111.1557162138865; Mon, 06 May 2019 10:02:18 -0700 (PDT) MIME-Version: 1.0 References: <1557155792-2703-1-git-send-email-kernel@probst.it> <20190506165658.GA168433@jra4> In-Reply-To: <20190506165658.GA168433@jra4> From: Steve French Date: Mon, 6 May 2019 12:02:07 -0500 Message-ID: Subject: Re: [PATCH] cifs: fix strcat buffer overflow in smb21_set_oplock_level() To: Jeremy Allison Cc: Christoph Probst , Steve French , CIFS , samba-technical , LKML Content-Type: text/plain; charset="UTF-8" Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org We could always switch it to strncpy :) In any case - he is correct, it is better than what was there because we should not strcat unless the array were locked across the whole function On Mon, May 6, 2019 at 11:57 AM Jeremy Allison wrote: > > On Mon, May 06, 2019 at 11:53:44AM -0500, Steve French via samba-technical wrote: > > I think strcpy is clearer - but I don't think it can overflow since if > > R, W or W were written to "message" then cinode->oplock would be > > non-zero so we would never strcap "None" > > Ahem. In Samba we have : > > lib/util/safe_string.h:#define strcpy(dest,src) __ERROR__XX__NEVER_USE_STRCPY___; > > Maybe you should do likewise :-). > > > On Mon, May 6, 2019 at 10:26 AM Christoph Probst wrote: > > > > > > Change strcat to strcpy in the "None" case as it is never valid to append > > > "None" to any other message. It may also overflow char message[5], in a > > > race condition on cinode if cinode->oplock is unset by another thread > > > after "RHW" or "RH" had been written to message. > > > > > > Signed-off-by: Christoph Probst > > > --- > > > fs/cifs/smb2ops.c | 2 +- > > > 1 file changed, 1 insertion(+), 1 deletion(-) > > > > > > diff --git a/fs/cifs/smb2ops.c b/fs/cifs/smb2ops.c > > > index c36ff0d..5fd5567 100644 > > > --- a/fs/cifs/smb2ops.c > > > +++ b/fs/cifs/smb2ops.c > > > @@ -2936,7 +2936,7 @@ smb21_set_oplock_level(struct cifsInodeInfo *cinode, __u32 oplock, > > > strcat(message, "W"); > > > } > > > if (!cinode->oplock) > > > - strcat(message, "None"); > > > + strcpy(message, "None"); > > > cifs_dbg(FYI, "%s Lease granted on inode %p\n", message, > > > &cinode->vfs_inode); > > > } > > > -- > > > 2.1.4 > > > > > > > > > -- > > Thanks, > > > > Steve > > -- Thanks, Steve