Received: by 10.213.65.68 with SMTP id h4csp745343imn; Fri, 6 Apr 2018 08:11:55 -0700 (PDT) X-Google-Smtp-Source: AIpwx49Azq68jTzH7fCXBwda9ja+RkBtzQjucFlPYFfmdguQ1QOEI+bwzZ9I1jpANyz+z9mTmYjb X-Received: by 10.101.102.3 with SMTP id w3mr17564461pgv.200.1523027515454; Fri, 06 Apr 2018 08:11:55 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1523027515; cv=none; d=google.com; s=arc-20160816; b=TDF7UWCA3F+mcpg6yTfIzvpsN0rIEAED0p2KJ6e4tfV3Tyf/LWnHLeMoYX2YzAEPk7 Owqki/JYcvA5vBYcXu4HlLC1vVrnX903smzQNc+TauzWmRmjPdeRubaAdQJv8U5lQ4TN RzmTAKlaPt9Co7mGPHzem9WdhP6293SRtBZ3DwF2SYunjCdlwbxSdaOy37k8Hoi7YbE2 ujd1OKuGVBN85qso2dQnftW7Xq9FaxTH5Nz+LXmxY3trVgAKPYEg0ZyOebqHd+rZgH4J 7/0raIx1zXLQQn28Pr88l9TmaILQmO/jPeLcDV99jDZYiJvQ6eVdn5L1anYZDRAEEc0x ousQ== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:mime-version:user-agent:references :in-reply-to:message-id:date:subject:cc:to:from :arc-authentication-results; bh=QDDvei3aYKRitfSNU8etO6eLaiEFLA+HkDSaZYDt8Ug=; b=wGKGNvgWG//eFZ/qfGQguZrQ3NvEdfSjbu2WDT035HJDWgU3idwghvU5+2LU6ClB5F mOhmjgPfFwV/636/ENzUgDzoMghXU4qxcr52f0ujNi6HB5HCWz4lbtsSlxdTm29p0lfo uSRdGSX3GDjABCusxzNAyn0aBJVD+SvemgUk7NP4yMGH2oo9OE58o4+OrYdSzLaMV+dm allwijaZgXPqA85bLwN7oR0Lgl8Z+iPTYeyi7M9hK8YczcBCdhtGWbsxvTuTJS8Lycw4 PWeqeukW+mq6goEkw/WE8ooXk8X98kUSwzA3aFXCQXY0wkGrKs1UuZwuG7fKDUyu/SiU sjjA== ARC-Authentication-Results: i=1; mx.google.com; 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 Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id q10si7127547pgp.326.2018.04.06.08.11.41; Fri, 06 Apr 2018 08:11:55 -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; 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 Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1751952AbeDFPKf (ORCPT + 99 others); Fri, 6 Apr 2018 11:10:35 -0400 Received: from mail.linuxfoundation.org ([140.211.169.12]:55826 "EHLO mail.linuxfoundation.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1754642AbeDFN3d (ORCPT ); Fri, 6 Apr 2018 09:29:33 -0400 Received: from localhost (LFbn-1-12247-202.w90-92.abo.wanadoo.fr [90.92.61.202]) by mail.linuxfoundation.org (Postfix) with ESMTPSA id 46DFBD36; Fri, 6 Apr 2018 13:29:32 +0000 (UTC) From: Greg Kroah-Hartman To: linux-kernel@vger.kernel.org Cc: Greg Kroah-Hartman , stable@vger.kernel.org, Richard Narron , Jens Axboe Subject: [PATCH 4.4 05/72] partitions/msdos: Unable to mount UFS 44bsd partitions Date: Fri, 6 Apr 2018 15:23:06 +0200 Message-Id: <20180406084305.567693900@linuxfoundation.org> X-Mailer: git-send-email 2.17.0 In-Reply-To: <20180406084305.210085169@linuxfoundation.org> References: <20180406084305.210085169@linuxfoundation.org> User-Agent: quilt/0.65 X-stable: review MIME-Version: 1.0 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 4.4-stable review patch. If anyone has any objections, please let me know. ------------------ From: Richard Narron commit 5f15684bd5e5ef39d4337988864fec8012471dda upstream. UFS partitions from newer versions of FreeBSD 10 and 11 use relative addressing for their subpartitions. But older versions of FreeBSD still use absolute addressing just like OpenBSD and NetBSD. Instead of simply testing for a FreeBSD partition, the code needs to also test if the starting offset of the C subpartition is zero. https://bugzilla.kernel.org/show_bug.cgi?id=197733 Signed-off-by: Richard Narron Signed-off-by: Jens Axboe Signed-off-by: Greg Kroah-Hartman --- block/partitions/msdos.c | 4 +++- 1 file changed, 3 insertions(+), 1 deletion(-) --- a/block/partitions/msdos.c +++ b/block/partitions/msdos.c @@ -300,7 +300,9 @@ static void parse_bsd(struct parsed_part continue; bsd_start = le32_to_cpu(p->p_offset); bsd_size = le32_to_cpu(p->p_size); - if (memcmp(flavour, "bsd\0", 4) == 0) + /* FreeBSD has relative offset if C partition offset is zero */ + if (memcmp(flavour, "bsd\0", 4) == 0 && + le32_to_cpu(l->d_partitions[2].p_offset) == 0) bsd_start += offset; if (offset == bsd_start && size == bsd_size) /* full parent partition, we have it already */