Received: by 2002:a25:8b91:0:0:0:0:0 with SMTP id j17csp21813805ybl; Mon, 6 Jan 2020 11:47:45 -0800 (PST) X-Google-Smtp-Source: APXvYqwgZx9HmjvE7uv4DjD/w3JZQI0Mn+g2Q/L1dE84s/JcNzXvMJAV3xxjcf41U6cQZk5U7waS X-Received: by 2002:a9d:6745:: with SMTP id w5mr104138573otm.52.1578340065274; Mon, 06 Jan 2020 11:47:45 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1578340065; cv=none; d=google.com; s=arc-20160816; b=FGF5MlR1Wof+dwCyn2OvFRqX9jxnMMVe9x8iGzrmOHFDmlSG0ku+YrVlf8zw7AjwmP E61ycPQ/w4moFwc07LyLWWXm+RQk+uZ94QXvWXrK8ZJIRFzry2esnuZMY+nQTA8GmoKY QYvTUrpYV/WKabRWg7YPPImnl3m+oKMvfcdovaBIyu2kmalzAAiNaGsUSxmCihVrO+6+ tnyugSMXcThqGeGO5P/loeS3WzvLYbBTWxXSzTrvk4KdtUwUIH0bBMbL/tvTmnW50ZXw QeH424iseLBr73Un5La0IpU79Pge4VNC9LNQtaoTPYJFqfBPcqR/cg1Q0DIXoj25dtJR c8tQ== 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:message-id:in-reply-to:date:references:organization :subject:cc:to:from; bh=aK00Nprt1Z9ItYSP0C18G6WEFCK1qFQXifHr+gfuIMU=; b=TPKH795O40wrs3LEmMQbFikwuxyqeJruXUTfYx6k9WAXmyFZEV8O9YG8TWiZb0tigW Ap7PcPWTnCS/Mmf+qXLZJI7+9LoAeH2/g/UHF/5qNavnXvU4numtdkwQSSWap2q2X77h nbpahKlLBLETzbOnkFAyjeeFdMTITe2x4piGLg+21j7ltPgA9oFgqjU5BF5NN0zw3jy3 BALOzaxUZDNwcDJVWpvW9YYZEVk7nA8Aq+WXjYM4223lzUMfLz5gPmwBD9PwjJGDZZgH owOzlsJ/H+5flS/f/vJ+qIFd7h+pXZle8ngKm4pTWYFTnBQ2RkL8VDtt3PHqPR/wbTyy /HFg== 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; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=collabora.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id g1si33056591otj.115.2020.01.06.11.47.32; Mon, 06 Jan 2020 11:47:45 -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; 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=fail (p=NONE sp=NONE dis=NONE) header.from=collabora.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1726767AbgAFTqi convert rfc822-to-8bit (ORCPT + 99 others); Mon, 6 Jan 2020 14:46:38 -0500 Received: from bhuna.collabora.co.uk ([46.235.227.227]:36250 "EHLO bhuna.collabora.co.uk" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1726657AbgAFTqi (ORCPT ); Mon, 6 Jan 2020 14:46:38 -0500 Received: from localhost (unknown [IPv6:2610:98:8005::147]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) (Authenticated sender: krisman) by bhuna.collabora.co.uk (Postfix) with ESMTPSA id C2936291A19; Mon, 6 Jan 2020 19:46:36 +0000 (GMT) From: Gabriel Krisman Bertazi To: Pali =?utf-8?Q?Roh=C3=A1r?= Cc: Namjae Jeon , linux-kernel@vger.kernel.org, linux-fsdevel@vger.kernel.org, gregkh@linuxfoundation.org, valdis.kletnieks@vt.edu, hch@lst.de, sj1557.seo@samsung.com, linkinjeon@gmail.com, tytso@mit.edu Subject: Re: [PATCH v9 10/13] exfat: add nls operations Organization: Collabora References: <20200102082036.29643-1-namjae.jeon@samsung.com> <20200102082036.29643-11-namjae.jeon@samsung.com> <20200105165115.37dyrcwtgf6zgc6r@pali> Date: Mon, 06 Jan 2020 14:46:33 -0500 In-Reply-To: <20200105165115.37dyrcwtgf6zgc6r@pali> ("Pali =?utf-8?Q?Roh?= =?utf-8?Q?=C3=A1r=22's?= message of "Sun, 5 Jan 2020 17:51:15 +0100") Message-ID: <85woa4jrl2.fsf@collabora.com> User-Agent: Gnus/5.13 (Gnus v5.13) Emacs/26.1 (gnu/linux) 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 Pali Rohár writes: > What do you think what should kernel's exfat driver do in this case? > > To prevent such thing we need to use some kind of Unicode normalization > form here. > > CCing Gabriel as he was implementing some Unicode normalization for ext4 > driver and maybe should bring some light to new exfat driver too. We have an in-kernel implementation of the canonical decomposition normalization (NFD) in fs/unicode, which is what we use for f2fs and ext4. It is heated argument what is the best form for filesystem usage, and from what I researched, every proprietary filesystem does a different (and crazy in their unique way) thing. For exfat, even though the specification is quite liberal, I think the reasonable answer is to follow closely whatever behavior the Windows implementation has, whether it does normalization at all or not. Even if it is just an in-memory format used internally for lookups, assuming a different format or treating differently invalid file names can result in awkward results in a filesystem created on another operating system, like filename collisions or false misses in lookups. -- Gabriel Krisman Bertazi