From mboxrd@z Thu Jan 1 00:00:00 1970 Return-Path: Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1752781AbcLMXn6 (ORCPT ); Tue, 13 Dec 2016 18:43:58 -0500 Received: from mail-pg0-f45.google.com ([74.125.83.45]:33021 "EHLO mail-pg0-f45.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1751041AbcLMXn4 (ORCPT ); Tue, 13 Dec 2016 18:43:56 -0500 Subject: Re: CVE-2016-7097 causes acl leak To: Cong Wang References: <3a180415-2f02-c9c0-e1e6-519b5d3115b7@android.com> Cc: LKML , aneesh.kumar@linux.vnet.ibm.com, Jan Kara , Greg KH From: Mark Salyzyn Message-ID: <5c0398cb-9ef2-42f3-0c46-e2e65fe92da9@android.com> Date: Tue, 13 Dec 2016 15:42:58 -0800 User-Agent: Mozilla/5.0 (X11; Linux x86_64; rv:45.0) Gecko/20100101 Thunderbird/45.4.0 MIME-Version: 1.0 In-Reply-To: Content-Type: text/plain; charset=utf-8; format=flowed Content-Transfer-Encoding: 7bit Sender: linux-kernel-owner@vger.kernel.org List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On 12/12/2016 10:26 PM, Cong Wang wrote: > On Mon, Dec 12, 2016 at 4:26 PM, Mark Salyzyn wrote: >> The leaks were introduced in 9p, gfs2, jfs and xfs drivers only. > > Only the 9p case is obvious to me: > > diff --git a/fs/9p/acl.c b/fs/9p/acl.c > index b3c2cc7..082d227 100644 > --- a/fs/9p/acl.c > +++ b/fs/9p/acl.c > @@ -277,6 +277,7 @@ static int v9fs_xattr_set_acl(const struct > xattr_handler *handler, > case ACL_TYPE_ACCESS: > if (acl) { > struct iattr iattr; > + struct posix_acl *old_acl = acl; > > retval = posix_acl_update_mode(inode, > &iattr.ia_mode, &acl); > if (retval) > @@ -287,6 +288,7 @@ static int v9fs_xattr_set_acl(const struct > xattr_handler *handler, > * by the mode bits. So don't > * update ACL. > */ > + posix_acl_release(old_acl); > value = NULL; > size = 0; > } > > > The rest are anti-pattern (modifying parameters on stack via address) > but look correct. Greg KH: Beware that this similar fix needs to be applied to _backports_ to stable kernel trees on other filesystem driver that have the same pattern (with local posix_acl_release(acl) calls). I have found that depending on vintage these would include this driver 9p, and possibly gfs2, jfs and xfs. Be aware. Sincerely -- Mark Salyzyn