Received: by 2002:a05:7412:8d10:b0:f3:1519:9f41 with SMTP id bj16csp1052908rdb; Wed, 6 Dec 2023 07:25:30 -0800 (PST) X-Google-Smtp-Source: AGHT+IE3ZmVBBRWIWQtc7FRmXtzeW60aycUPCR5s8mWqHPzeUdIJZKRFLaVYnoRk7QYbDmMEwTpr X-Received: by 2002:a05:6a20:4ba9:b0:18f:97c:8a50 with SMTP id fu41-20020a056a204ba900b0018f097c8a50mr962284pzb.123.1701876329806; Wed, 06 Dec 2023 07:25:29 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1701876329; cv=none; d=google.com; s=arc-20160816; b=WpARFy+Y8BrpygBp8vHhUCvTRJAo8yrVHUY3GJVOksX+gxfZnl35iAgtG51EjNPxqG gP0TsMkI/dEKJuJempJwW/lSDeoXMnhPyLEUkwVwcy+JI5lBATUa3t0gS5GlxGGfqLfZ 9ApMwS3fkV7yxmTCBq3VTHOmS9YvLOAaVCetXF06/UNCaXoLBNxIBL7OkyanFC0Nbwdy gGW6bXe9H38W3CAzCmEeoUH3gpnl7SRr92eEZpGDMxHpq4Glt2CrN6XUP6KSVTk/VWoz jW9SdtoqOLgsrC5hbLpk1xHbcxB9iJVuu+z/jo0c1gxqb1Up+azCSgnvMcqAVAE7MHiX yUfw== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:in-reply-to:references :cc:to:from:content-language:subject:user-agent:mime-version:date :message-id:dkim-signature:dkim-signature; bh=h7CldxQv2S5Mzb+cgzMS8C/4d3oWIhrtzyaVf9z57fs=; fh=P7I85FIabZcM8ojWdeG8ABpTZepe/Xtte9jKWDfUHBM=; b=Uha5thnvwph9rIupjBgdxj8e4uQbs9pLD80sR0DRqu7T2CwvVNaFRd5yvH5rH9JRxJ jIgfAzZyaqStY2KuY2ifHIGFoY4S4t7ZXoVR54bAnJHLZVkOhgZ4i+aMM30Crm7OUQ1I SkTEH2Phg/tY7wHqADExJk/Q4/a4j7iLpREAdotnlhKw+hfejVMZBaPQht1aGmge3UeP N+bUG2YAiKyhjusVxFthJQOf3uQzcBinPsT+pZKNYAyTyzD969Mv4j0oeYqDaQR9hInB GnRSUWvEew9NJxMoxCflEmK2nAp/WU/9HP3heQw59xHQE9Ur4hOIJYKF4kDb50A7rxwr r+Sg== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@paragon-software.com header.s=mail header.b=FtCj3ZeR; dkim=pass header.i=@paragon-software.com header.s=mail header.b=eyslm8PS; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::3:3 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=QUARANTINE sp=QUARANTINE dis=NONE) header.from=paragon-software.com Return-Path: Received: from lipwig.vger.email (lipwig.vger.email. [2620:137:e000::3:3]) by mx.google.com with ESMTPS id o21-20020a634e55000000b005c67da710ddsi46565pgl.782.2023.12.06.07.25.27 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Wed, 06 Dec 2023 07:25:29 -0800 (PST) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::3:3 as permitted sender) client-ip=2620:137:e000::3:3; Authentication-Results: mx.google.com; dkim=pass header.i=@paragon-software.com header.s=mail header.b=FtCj3ZeR; dkim=pass header.i=@paragon-software.com header.s=mail header.b=eyslm8PS; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::3:3 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=QUARANTINE sp=QUARANTINE dis=NONE) header.from=paragon-software.com Received: from out1.vger.email (depot.vger.email [IPv6:2620:137:e000::3:0]) by lipwig.vger.email (Postfix) with ESMTP id 3C8E68029120; Wed, 6 Dec 2023 07:14:40 -0800 (PST) X-Virus-Status: Clean X-Virus-Scanned: clamav-milter 0.103.11 at lipwig.vger.email Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1442523AbjLFPOO (ORCPT + 99 others); Wed, 6 Dec 2023 10:14:14 -0500 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:46192 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1379244AbjLFPOK (ORCPT ); Wed, 6 Dec 2023 10:14:10 -0500 Received: from relayaws-01.paragon-software.com (relayaws-01.paragon-software.com [35.157.23.187]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 2355DD64; Wed, 6 Dec 2023 07:14:16 -0800 (PST) Received: from relayfre-01.paragon-software.com (unknown [172.30.72.12]) by relayaws-01.paragon-software.com (Postfix) with ESMTPS id DCC301D47; Wed, 6 Dec 2023 15:02:32 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=paragon-software.com; s=mail; t=1701874953; bh=h7CldxQv2S5Mzb+cgzMS8C/4d3oWIhrtzyaVf9z57fs=; h=Date:Subject:From:To:CC:References:In-Reply-To; b=FtCj3ZeRaBPZiv12dqOADExR+OT9YeqY3/k6OC2QQKJ9fE5ai7DN/5guAiwZgrx0Y jzP8+1cDoiXU1I2OILGI8oMrFGQ8Mzot78sQq7PJSr+NK9SifuC9zxxEqJPwFMUUQW 5WoniFgJM0xApmStxoud0SP6WIR1lmABVdHpzCw8= Received: from dlg2.mail.paragon-software.com (vdlg-exch-02.paragon-software.com [172.30.1.105]) by relayfre-01.paragon-software.com (Postfix) with ESMTPS id 243202117; Wed, 6 Dec 2023 15:08:57 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=paragon-software.com; s=mail; t=1701875337; bh=h7CldxQv2S5Mzb+cgzMS8C/4d3oWIhrtzyaVf9z57fs=; h=Date:Subject:From:To:CC:References:In-Reply-To; b=eyslm8PSDjgl/rJxNS7F5ffPQA97GTxlXUWYf2oWGY5RTCsYMvvFyqCsElJpRYSwz 6npCQYykuV9udtf+8QOPyVk307zBuOQjVyLCP2+qixg9ZdLjMW9bmjegmNrIfmBVN8 0V/6teX8F6muUqbGlKbZHgFBNOh1lspt8A1CwIIE= Received: from [172.16.192.129] (192.168.211.144) by vdlg-exch-02.paragon-software.com (172.30.1.105) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_128_GCM_SHA256) id 15.1.2375.7; Wed, 6 Dec 2023 18:08:56 +0300 Message-ID: <53c3c86f-c816-4747-9262-592c3ddc6660@paragon-software.com> Date: Wed, 6 Dec 2023 18:08:56 +0300 MIME-Version: 1.0 User-Agent: Mozilla Thunderbird Subject: [PATCH 01/16] fs/ntfs3: Improve alternative boot processing Content-Language: en-US From: Konstantin Komarovc To: CC: , References: <00fd1558-fda5-421b-be43-7de69e32cb4e@paragon-software.com> In-Reply-To: <00fd1558-fda5-421b-be43-7de69e32cb4e@paragon-software.com> Content-Type: text/plain; charset="UTF-8"; format=flowed Content-Transfer-Encoding: 8bit X-Originating-IP: [192.168.211.144] X-ClientProxiedBy: vobn-exch-01.paragon-software.com (172.30.72.13) To vdlg-exch-02.paragon-software.com (172.30.1.105) X-Spam-Status: No, score=-0.9 required=5.0 tests=DKIM_SIGNED,DKIM_VALID, DKIM_VALID_AU,HEADER_FROM_DIFFERENT_DOMAINS,MAILING_LIST_MULTI, SPF_HELO_NONE,SPF_PASS,T_SCC_BODY_TEXT_LINE autolearn=unavailable autolearn_force=no version=3.4.6 X-Spam-Checker-Version: SpamAssassin 3.4.6 (2021-04-09) on lipwig.vger.email Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org X-Greylist: Sender passed SPF test, not delayed by milter-greylist-4.6.4 (lipwig.vger.email [0.0.0.0]); Wed, 06 Dec 2023 07:14:40 -0800 (PST) Signed-off-by: Konstantin Komarov ---  fs/ntfs3/super.c | 35 +++++++++++++++++------------------  1 file changed, 17 insertions(+), 18 deletions(-) diff --git a/fs/ntfs3/super.c b/fs/ntfs3/super.c index 9153dffde950..09d61c6c90aa 100644 --- a/fs/ntfs3/super.c +++ b/fs/ntfs3/super.c @@ -866,6 +866,7 @@ static int ntfs_init_from_boot(struct super_block *sb, u32 sector_size,      u16 fn, ao;      u8 cluster_bits;      u32 boot_off = 0; +    sector_t boot_block = 0;      const char *hint = "Primary boot";      /* Save original dev_size. Used with alternative boot. */ @@ -873,11 +874,11 @@ static int ntfs_init_from_boot(struct super_block *sb, u32 sector_size,      sbi->volume.blocks = dev_size >> PAGE_SHIFT; -    bh = ntfs_bread(sb, 0); +read_boot: +    bh = ntfs_bread(sb, boot_block);      if (!bh) -        return -EIO; +        return boot_block ? -EINVAL : -EIO; -check_boot:      err = -EINVAL;      /* Corrupted image; do not read OOB */ @@ -1108,26 +1109,24 @@ static int ntfs_init_from_boot(struct super_block *sb, u32 sector_size,      }  out: -    if (err == -EINVAL && !bh->b_blocknr && dev_size0 > PAGE_SHIFT) { +    brelse(bh); + +    if (err == -EINVAL && !boot_block && dev_size0 > PAGE_SHIFT) {          u32 block_size = min_t(u32, sector_size, PAGE_SIZE);          u64 lbo = dev_size0 - sizeof(*boot); -        /* -          * Try alternative boot (last sector) -         */ -        brelse(bh); - -        sb_set_blocksize(sb, block_size); -        bh = ntfs_bread(sb, lbo >> blksize_bits(block_size)); -        if (!bh) -            return -EINVAL; - +        boot_block = lbo >> blksize_bits(block_size);          boot_off = lbo & (block_size - 1); -        hint = "Alternative boot"; -        dev_size = dev_size0; /* restore original size. */ -        goto check_boot; +        if (boot_block && block_size >= boot_off + sizeof(*boot)) { +            /* +             * Try alternative boot (last sector) +             */ +            sb_set_blocksize(sb, block_size); +            hint = "Alternative boot"; +            dev_size = dev_size0; /* restore original size. */ +            goto read_boot; +        }      } -    brelse(bh);      return err;  } -- 2.34.1