Received: by 2002:a25:1985:0:0:0:0:0 with SMTP id 127csp1670456ybz; Thu, 16 Apr 2020 13:21:12 -0700 (PDT) X-Google-Smtp-Source: APiQypKywT1XOm/26HWIj9B5Yxl23y/jckd+nLjt6LpI6iIkF+yw+KSugmfwr2ecgvjPGorqDuVZ X-Received: by 2002:a17:906:2458:: with SMTP id a24mr11141781ejb.239.1587068472218; Thu, 16 Apr 2020 13:21:12 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1587068472; cv=none; d=google.com; s=arc-20160816; b=ydfzGA8qQbyozhulASkEaplwilOEyoEF2is1OoETNysmPieDRAxdB+IQLFkBSXTQjb 2IQC5xsWt+n4/9hLQnGCOXZtjsSVAAwSY4oTsMcyyOuIkbBBSiZb40S2fa2joxBo+wlG nAGo6utmt2EODLLgwcE17obLyit0drh81FYm6TreJGeR+9X8F6Dv2O0B1SLEm6i9A/uv J3/jOzwSuNKDltk4xGNrOSwevGzG7su/i6O1T3yoBqinpEgBEkwVeyQQ+HRGwKNXlpUM yGT7HfJQhebDGyIlM/Q3JU+Z/QXfMAKCb9G8K77FgTlSBJiveZNG+W7kwDK1velndSc2 O37A== 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 :user-agent:references:in-reply-to:message-id:date:subject:cc:to :from:dkim-signature; bh=n0K/mUWu53HQ7o4Z46khMnSfJi7erThWnxO0YZhpftk=; b=01gpcjPvxQ/2+1YKOibrzevWQhLIfyk07S1gI+lBzfQGY00uvHBa6Qejq0jJhGcvYR xRpFCY+dTTi+Gxck3YS1s7vwtqFMD4VzeUUYcU1Xi1jiyt5hEztVM1rCt+HhOAqavYCo k81On2WnDup5y5+pn4jwXvy1khCNkt2uGhD1HL3OfayQcQzYJwrtXGukFTF1JiGIIqI7 w1sbYcdbeGvf3Kw2pCvCif4dztM0fD5LDQD/jKY6TUeql5KiYOLHXjmc2Vdr6BVl71HA kW+ZCfjOgWHrFXVXwxXP3CHaNTAZBSB4eLzyJs+ozVkMM/UUv4G60q/fbAyP53pY3+xM rpXg== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@kernel.org header.s=default header.b=cZlZZNE4; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id y14si13396221edm.185.2020.04.16.13.20.49; Thu, 16 Apr 2020 13:21:12 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) client-ip=23.128.96.18; Authentication-Results: mx.google.com; dkim=pass header.i=@kernel.org header.s=default header.b=cZlZZNE4; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S2442201AbgDPOO0 (ORCPT + 99 others); Thu, 16 Apr 2020 10:14:26 -0400 Received: from mail.kernel.org ([198.145.29.99]:36626 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1732673AbgDPNuh (ORCPT ); Thu, 16 Apr 2020 09:50:37 -0400 Received: from localhost (83-86-89-107.cable.dynamic.v4.ziggo.nl [83.86.89.107]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by mail.kernel.org (Postfix) with ESMTPSA id 6E3FC2078B; Thu, 16 Apr 2020 13:50:35 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=default; t=1587045035; bh=SoVqO3bK3jHNnFnqoHbBV+IZFxZYUJeXCaLy+Ihncvo=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=cZlZZNE42wDifE3HxD0bUQfdG1hPfUcFISsrcF07BipIPJORRarveAz86Jf6YorOC vcgTGOjhAuYs3ZTl3YNiJ6cu5PdTcc+7HUNic53Kjz0AFrP2qyEJBNNqjxT2C2Is+J VNdvBjDq/E1oguEtMdmAUhaFzohKEYv0+GLUfeZI= From: Greg Kroah-Hartman To: linux-kernel@vger.kernel.org Cc: Greg Kroah-Hartman , stable@vger.kernel.org, Simon Gander , Andrew Morton , Anton Altaparmakov , Linus Torvalds Subject: [PATCH 5.4 203/232] hfsplus: fix crash and filesystem corruption when deleting files Date: Thu, 16 Apr 2020 15:24:57 +0200 Message-Id: <20200416131340.665541457@linuxfoundation.org> X-Mailer: git-send-email 2.26.1 In-Reply-To: <20200416131316.640996080@linuxfoundation.org> References: <20200416131316.640996080@linuxfoundation.org> User-Agent: quilt/0.66 MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org From: Simon Gander commit 25efb2ffdf991177e740b2f63e92b4ec7d310a92 upstream. When removing files containing extended attributes, the hfsplus driver may remove the wrong entries from the attributes b-tree, causing major filesystem damage and in some cases even kernel crashes. To remove a file, all its extended attributes have to be removed as well. The driver does this by looking up all keys in the attributes b-tree with the cnid of the file. Each of these entries then gets deleted using the key used for searching, which doesn't contain the attribute's name when it should. Since the key doesn't contain the name, the deletion routine will not find the correct entry and instead remove the one in front of it. If parent nodes have to be modified, these become corrupt as well. This causes invalid links and unsorted entries that not even macOS's fsck_hfs is able to fix. To fix this, modify the search key before an entry is deleted from the attributes b-tree by copying the found entry's key into the search key, therefore ensuring that the correct entry gets removed from the tree. Signed-off-by: Simon Gander Signed-off-by: Andrew Morton Reviewed-by: Anton Altaparmakov Cc: Link: http://lkml.kernel.org/r/20200327155541.1521-1-simon@tuxera.com Signed-off-by: Linus Torvalds Signed-off-by: Greg Kroah-Hartman --- fs/hfsplus/attributes.c | 4 ++++ 1 file changed, 4 insertions(+) --- a/fs/hfsplus/attributes.c +++ b/fs/hfsplus/attributes.c @@ -292,6 +292,10 @@ static int __hfsplus_delete_attr(struct return -ENOENT; } + /* Avoid btree corruption */ + hfs_bnode_read(fd->bnode, fd->search_key, + fd->keyoffset, fd->keylength); + err = hfs_brec_remove(fd); if (err) return err;