Received: by 2002:ac0:a5b6:0:0:0:0:0 with SMTP id m51-v6csp2289942imm; Thu, 7 Jun 2018 08:15:33 -0700 (PDT) X-Google-Smtp-Source: ADUXVKIZhx4QPZghbGGnDUfDXwfWBi+Fp6R7BX1g+MAKTumKK58l5Ul99gnNDrmnw4fyaQo9SBKO X-Received: by 2002:a17:902:581:: with SMTP id f1-v6mr2510738plf.48.1528384533163; Thu, 07 Jun 2018 08:15:33 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1528384533; cv=none; d=google.com; s=arc-20160816; b=J0u+YYRbGeeWiFrWB5SJd8BCWbhLuaSfnIYoNhwGK4C69vPu/hrCM0TblVz9kB1bq7 7SzFm75nWnHS/N1gL+uZE8Nk6rnqpBzgLNbgbfGajESX9zulw3Qss5V81Gaer7Jh4sZy B1O54fDyr9R/mkd3ZYkS4TgZG2ie7R9WdQZ5e9jLklW74dgKiuqs+nsN6ly+61oSQmek P7y7YnPq5KKxMo4OOf0g7YIGxtW3jlfXh1OFD3kNkBBwQJtpIlSWAqOjVX4UP9Od7qs5 4724W4QKlmKDkTRIK7zi2mcwFxsg3TjZXkQNMShbX1EDWQdKnVC4p5YzY4kKD1HYal3L 04fQ== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:in-reply-to:subject:message-id:date:cc:to :from:mime-version:content-transfer-encoding:content-disposition :arc-authentication-results; bh=tmgMbyW02DDUK5uUFdDoVBPE94yvqAcObxmvfV+173U=; b=MiKILrla1R41YkMjR1QXq9Eqmsz6ZB+yRLZ+ebYrt7wIngfTspVRbDmZiDZfMhdjaZ MgSf1PoTqEjexug86wjDtPLsGxiVGDLiQkhsJIaylcAWlQas/Uxh+7WkXvrdsSFUQckq lDNiNmueJQzlaGOAIMO+6g+6Nzchv45js4pX/4NWrtZZb3MFnoOMV7rpr/JCzrFw2JZv AERn+YOSU7aFGBPTex4OjMhk2sB10bZwN2eibxjAU4cF9Q7bL627tWO/rrXXEBVZ0T7f FFywHMWO5oee/Y9cgW44KOzNGlcnJmdAY9iymHplCvK0Icgb4G1e6rqMFf0XsugYMVvt 3wIQ== 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 w6-v6si3753438pgc.276.2018.06.07.08.15.18; Thu, 07 Jun 2018 08:15:33 -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 S935977AbeFGPOL (ORCPT + 99 others); Thu, 7 Jun 2018 11:14:11 -0400 Received: from shadbolt.e.decadent.org.uk ([88.96.1.126]:41424 "EHLO shadbolt.e.decadent.org.uk" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S935066AbeFGPB6 (ORCPT ); Thu, 7 Jun 2018 11:01:58 -0400 Received: from [148.252.241.226] (helo=deadeye) by shadbolt.decadent.org.uk with esmtps (TLS1.2:ECDHE_RSA_AES_256_GCM_SHA384:256) (Exim 4.84_2) (envelope-from ) id 1fQvbV-0005hO-Rh; Thu, 07 Jun 2018 15:09:30 +0100 Received: from ben by deadeye with local (Exim 4.91) (envelope-from ) id 1fQvbB-0003At-3k; Thu, 07 Jun 2018 15:09:09 +0100 Content-Type: text/plain; charset="UTF-8" Content-Disposition: inline Content-Transfer-Encoding: 8bit MIME-Version: 1.0 From: Ben Hutchings To: linux-kernel@vger.kernel.org, stable@vger.kernel.org CC: akpm@linux-foundation.org, "Liu Bo" , "Anand Jain" , "David Sterba" Date: Thu, 07 Jun 2018 15:05:21 +0100 Message-ID: X-Mailer: LinuxStableQueue (scripts by bwh) Subject: [PATCH 3.16 315/410] btrfs: use proper endianness accessors for super_copy In-Reply-To: X-SA-Exim-Connect-IP: 148.252.241.226 X-SA-Exim-Mail-From: ben@decadent.org.uk X-SA-Exim-Scanned: No (on shadbolt.decadent.org.uk); SAEximRunCond expanded to false Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org 3.16.57-rc1 review patch. If anyone has any objections, please let me know. ------------------ From: Anand Jain commit 3c181c12c431fe33b669410d663beb9cceefcd1b upstream. The fs_info::super_copy is a byte copy of the on-disk structure and all members must use the accessor macros/functions to obtain the right value. This was missing in update_super_roots and in sysfs readers. Moving between opposite endianness hosts will report bogus numbers in sysfs, and mount may fail as the root will not be restored correctly. If the filesystem is always used on a same endian host, this will not be a problem. Fix this by using the btrfs_set_super...() functions to set fs_info::super_copy values, and for the sysfs, use the cached fs_info::nodesize/sectorsize values. Fixes: df93589a17378 ("btrfs: export more from FS_INFO to sysfs") Signed-off-by: Anand Jain Reviewed-by: Liu Bo Reviewed-by: David Sterba [ update changelog ] Signed-off-by: David Sterba [bwh: Backported to 3.16: - btrfs_fs_info doesn't have cached nodesize or sectorsize fields, so use the accessor functions - Adjust context] Signed-off-by: Ben Hutchings --- --- a/fs/btrfs/sysfs.c +++ b/fs/btrfs/sysfs.c @@ -406,7 +406,7 @@ static ssize_t btrfs_nodesize_show(struc { struct btrfs_fs_info *fs_info = to_fs_info(kobj); - return snprintf(buf, PAGE_SIZE, "%u\n", fs_info->super_copy->nodesize); + return snprintf(buf, PAGE_SIZE, "%u\n", btrfs_super_nodesize(fs_info->super_copy)); } BTRFS_ATTR_RW(nodesize, 0444, btrfs_nodesize_show, btrfs_no_store); @@ -416,7 +416,7 @@ static ssize_t btrfs_sectorsize_show(str { struct btrfs_fs_info *fs_info = to_fs_info(kobj); - return snprintf(buf, PAGE_SIZE, "%u\n", fs_info->super_copy->sectorsize); + return snprintf(buf, PAGE_SIZE, "%u\n", btrfs_super_sectorsize(fs_info->super_copy)); } BTRFS_ATTR_RW(sectorsize, 0444, btrfs_sectorsize_show, btrfs_no_store); @@ -426,7 +426,7 @@ static ssize_t btrfs_clone_alignment_sho { struct btrfs_fs_info *fs_info = to_fs_info(kobj); - return snprintf(buf, PAGE_SIZE, "%u\n", fs_info->super_copy->sectorsize); + return snprintf(buf, PAGE_SIZE, "%u\n", btrfs_super_sectorsize(fs_info->super_copy)); } BTRFS_ATTR_RW(clone_alignment, 0444, btrfs_clone_alignment_show, btrfs_no_store); --- a/fs/btrfs/transaction.c +++ b/fs/btrfs/transaction.c @@ -1428,19 +1428,23 @@ static void update_super_roots(struct bt super = root->fs_info->super_copy; + /* update latest btrfs_super_block::chunk_root refs */ root_item = &root->fs_info->chunk_root->root_item; - super->chunk_root = root_item->bytenr; - super->chunk_root_generation = root_item->generation; - super->chunk_root_level = root_item->level; + btrfs_set_super_chunk_root(super, root_item->bytenr); + btrfs_set_super_chunk_root_generation(super, root_item->generation); + btrfs_set_super_chunk_root_level(super, root_item->level); + /* update latest btrfs_super_block::root refs */ root_item = &root->fs_info->tree_root->root_item; - super->root = root_item->bytenr; - super->generation = root_item->generation; - super->root_level = root_item->level; + btrfs_set_super_root(super, root_item->bytenr); + btrfs_set_super_generation(super, root_item->generation); + btrfs_set_super_root_level(super, root_item->level); + if (btrfs_test_opt(root, SPACE_CACHE)) - super->cache_generation = root_item->generation; + btrfs_set_super_cache_generation(super, root_item->generation); if (root->fs_info->update_uuid_tree_gen) - super->uuid_tree_generation = root_item->generation; + btrfs_set_super_uuid_tree_generation(super, + root_item->generation); } int btrfs_transaction_in_commit(struct btrfs_fs_info *info)