Received: by 2002:a25:8b91:0:0:0:0:0 with SMTP id j17csp21761215ybl; Mon, 6 Jan 2020 10:41:12 -0800 (PST) X-Google-Smtp-Source: APXvYqzcxzGtwMeTPmWUPqe0od7iTIzDhgs1OCzMyboUaaxsmj3p0Tm0uNQWuKZ3BPT6AtQE/fFn X-Received: by 2002:aca:814:: with SMTP id 20mr6388948oii.159.1578336071863; Mon, 06 Jan 2020 10:41:11 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1578336071; cv=none; d=google.com; s=arc-20160816; b=Z4N9zFlZg+Hw7AJVRSWCYKjUxJWyqxWxhJqa7Q4Vhz+6Iaxqm6/urRmont+3r2UCu0 IvSe/ecwGE7ltU0vJkFGyXNKpnGn4/HmSv6RehADsIOubMfalJSuM4LK9MoIJAL5ozr/ /WD01KnlkbDWI0LoAvQ0VeSbONVLczzQ9sh0JXdkoaiKtXnbwe4NMCdv/NagZZQkd0S7 eUzNzc761gnkFV/+TvhnWgZFi3nSNCKh4c4F+MDAYYpRsgKrlUzv0cWbepVhdBK2ygzx B1D/aPRpQoeoXtsIvgZjOR0CiWC5kSv64ixya1fOGANCdOCJWXC78lVK5LQ1H7JqYWSM G2Tg== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:user-agent:in-reply-to :content-disposition:mime-version:references:message-id:subject:cc :to:from:date:dkim-signature; bh=mmou7dXM3wWe+JTZkb/QQRMmirkmqCySfSXVPt2rVE8=; b=rmutF3GguVZFuXelqU6ZswT7L5aibuEKSMNFH2S/VU6Frq5JabyvdGa+RtJfCtZGHG 4vT0BT/ThJCHTYG1LdGGHGX6BQFmJt+jWmuWGJrlh1dm1ONOqylE25niXFwk53P1iQ54 NFWEny9rjLCk6HKq5Ijc9jk/ctHuDgo9+lzsHMso6U9JQmNqq9lC+nrW0+c97NmRO3bc ytNWofUY9cjxDD0O5Y3pj5zw1j7K3hv5SMkNTGD9KFraEC35SBy+2ELQwhYmkLZUi975 CRqTAWYgV00BBISoFTj7BUykiHbjZfvvMvgQjWHDUP/lskeCjUHuaJDK55WYU99lHG3n 7bpw== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@kernel.org header.s=default header.b=1Bcx7ryd; 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; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=kernel.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id a10si19462347oid.84.2020.01.06.10.40.58; Mon, 06 Jan 2020 10:41:11 -0800 (PST) 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; dkim=pass header.i=@kernel.org header.s=default header.b=1Bcx7ryd; 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; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1726659AbgAFSkT (ORCPT + 99 others); Mon, 6 Jan 2020 13:40:19 -0500 Received: from mail.kernel.org ([198.145.29.99]:39260 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1726569AbgAFSkS (ORCPT ); Mon, 6 Jan 2020 13:40:18 -0500 Received: from localhost (unknown [104.132.0.81]) (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 E0D92208C4; Mon, 6 Jan 2020 18:40:17 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=default; t=1578336018; bh=Lk2b8isd4AKJZh0uG3znLmDlvurajw8PnaAef68wq2k=; h=Date:From:To:Cc:Subject:References:In-Reply-To:From; b=1Bcx7rydQDjiPxZ3nYt4l5Uc9HBnHLOnDifre9sjZr/zLAFc+MgnKi8yeB3k/pEf+ fLaGhfKkD73da0pEkrP41WLYiRuody5qYkX9xAEynZA5kgo7PQhwzmd36lsdgY8ZuR KGEYjUJYwYAU08342QAl3Fl9NqwGd5aiKI9iVcJM= Date: Mon, 6 Jan 2020 10:40:17 -0800 From: Jaegeuk Kim To: Chao Yu Cc: Oleksandr Natalenko , linux-f2fs-devel@lists.sourceforge.net, linux-kernel@vger.kernel.org Subject: Re: [f2fs-dev] Multidevice f2fs mount after disk rearrangement Message-ID: <20200106184017.GD50058@jaegeuk-macbookpro.roam.corp.google.com> References: <4c6cf8418236145f7124ac61eb2908ad@natalenko.name> <2c4cafd35d1595a62134203669d7c244@natalenko.name> MIME-Version: 1.0 Content-Type: text/plain; charset=us-ascii Content-Disposition: inline In-Reply-To: User-Agent: Mutt/1.8.2 (2017-04-18) Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On 01/06, Chao Yu wrote: > Hello, > > Thanks for the report. :) > > On 2020/1/5 5:52, Oleksandr Natalenko via Linux-f2fs-devel wrote: > > Hi. > > > > On 04.01.2020 17:29, Oleksandr Natalenko wrote: > >> I was brave enough to create f2fs filesystem spanning through 2 > >> physical device using this command: > >> > >> # mkfs.f2fs -t 0 /dev/sdc -c /dev/sdd > >> > >> It worked fine until I removed /dev/sdb from my system, so f2fs devices > >> became: > >> > >> /dev/sdc -> /dev/sdb > >> /dev/sdd -> /dev/sdc > >> > >> Now, when I try to mount it, I get the following: > >> > >> # mount -t f2fs /dev/sdb /mnt/fs > >> mount: /mnt/fs: mount(2) system call failed: No such file or directory. > >> > >> In dmesg: > >> > >> [Jan 4 17:25] F2FS-fs (sdb): Mount Device [ 0]: /dev/sdc, > >> 59063, 0 - 1cd6fff > >> [ +0,000024] F2FS-fs (sdb): Failed to find devices > >> > >> fsck also fails with the following assertion: > >> > >> [ASSERT] (init_sb_info: 908) !strcmp((char *)sb->devs[i].path, (char > >> *)c.devices[i].path) > >> > >> Am I doing something obviously stupid, and the device path can be > >> (somehow) changed so that the mount succeeds, or this is unfixable, > >> and f2fs relies on persistent device naming? > >> > >> Please suggest. > >> > >> Thank you. > > > > Erm, fine. I studied f2fs-tools code a little bit and discovered that > > superblock indeed had /dev/sdX paths saved as strings. So I fired up > > hexedit and just changed the superblock directly on the first device, > > substituting sdc with sdb and sdd with sdc (I did it twice; I guess > > there are 2 copies of superblock), and after this the mount worked. > > Alright, it works if superblock checksum feature is off... > > > > > Am I really supposed to do this manually ;)? > > We'd better add that ability in tune.f2fs. And I guess we need to let > kernel/fsck to notice that case, and give hint to run tune.f2fs to > reconfigure primary/secondary/... device paths. I'm thinking to add tunesb.f2fs to edit superblock explicitly, since it has to edit it without getting superblock/checkpoint and other f2fs metadata. For example, # tunesb.f2fs -c /dev/sdb -c /dev/sdc /dev/sda .. superblock info .. .. device list .. .. hot/cold extensions .. Will modify the device list, if it's different from parameter. > > Thanks, > > >