On 24/09/26 12:35, Gao Xiang wrote: > Hi Ariel, > > On 2024/9/25 23:48, Ariel Miculas wrote: > > ... > > > I share the same opinions as Benno that we should try to use the > > existing filesystem abstractions, even if they are not yet upstream. > > Since erofs is a read-only filesystem and the Rust filesystem > > abstractions are also used by other two read-only filesystems (TarFS and > > PuzzleFS), it shouldn't be too difficult to adapt the erofs Rust code so > > that it also uses the existing filesystem abstractions. And if there is > > anything lacking, we can improve the existing generic APIs. This would > > also increase the chances of upstreaming them. > > I've expressed my ideas about "TarFS" [1] and PuzzleFS already: since > I'm one of the EROFS authors, I should be responsible for this > long-term project as my own promise to the Linux community and makes > it serve for more Linux users (it has not been interrupted since 2017, > even I sacrificed almost all my leisure time because the EROFS project > isn't all my paid job, I need to maintain our internal kernel storage > stack too). > > [1] https://lore.kernel.org/r/3a6314fc-7956-47f3-8727-9dc026f3f50e@xxxxxxxxxxxxxxxxx > > Basically there should be some good reasons to upstream a new stuff to > Linux kernel, I believe it has no exception on the Rust side even it's > somewhat premature: please help compare to the prior arts in details. > > And there are all thoughts for reference [2][3][4][5]: > [2] https://github.com/project-machine/puzzlefs/issues/114#issuecomment-2369872133 > [3] https://github.com/opencontainers/image-spec/issues/1190#issuecomment-2138572683 > [4] https://lore.kernel.org/linux-fsdevel/b9358e7c-8615-1b12-e35d-aae59bf6a467@xxxxxxxxxxxxxxxxx/ > [5] https://lore.kernel.org/linux-fsdevel/20230609-nachrangig-handwagen-375405d3b9f1@brauner/ > > Here still, I do really want to collaborate with you on your > reasonable use cases. But if you really want to do your upstream > attempt without even any comparsion, please go ahead because I > believe I can only express my own opinion, but I really don't > decide if your work is acceptable for the kernel. > Thanks for your thoughts on PuzzleFS, I would really like if we could centralize the discussions on the latest patch series I sent to the mailing lists back in May [1]. The reason I say this is because looking at that thread, it seems there is no feedback for PuzzleFS. The feedback exists, it's just scattered throughout different mediums. On top of this, I would also like to engage in the discussions with Dave Chinner, so I can better understand the limitations of PuzzleFS and the reasons for which it might be rejected in the Linux Kernel. I do appreciate your feedback and I need to take my time to respond to the technical issues that you brought up in the github issue. However, even if it's not upstream, PuzzleFS does use the latest Rust filesystem abstractions and thus it stands as an example of how to use them. And this thread is not about PuzzleFS, but about the Rust filesystem abstractions and how one might start to use them. That's where I offered to help, since I already went through the process of having to use them. [1] https://lore.kernel.org/all/20240516190345.957477-1-amiculas@xxxxxxxxx/ > > > > I'm happy to help you if you decide to go down this route. > > Again, the current VFS abstraction is totally incomplete and broken > [6]. If they're incomplete, we can work together to implement the missing functionalities. Furthermore, we can work to fix the broken stuff. I don't think these are good reasons to completely ignore the work that's already been done on this topic. By the way, what is it that's actually broken? You've linked to an LWN article [2] (or at least I think your 6th link was supposed to link to "Rust for filesystems" instead of the "Committing to Rust in the kernel" one), but I'm interested in the specifics. What exactly doesn't work as expected from the filesystem abstractions? [2] https://lwn.net/Articles/978738/ > > I believe it should be driven by a full-featured read-write fs [7] > (even like a simple minix fs in pre-Linux 1.0 era) and EROFS will I do find it weird that you want a full-featured read-write fs implemented in Rust, when erofs is a read-only filesystem. > use Rust in "fs/erofs" as the experiment, but I will definitely > polish the Rust version until it looks good before upstreaming. I honestly don't see how it would look good if they're not using the existing filesystem abstractions. And I'm not convinced that Rust in the kernel would be useful in any way without the many subsystem abstractions which were implemented by the Rust for Linux team for the past few years. Cheers, Ariel > > I really don't want to be a repeater again. > > [6] https://lwn.net/SubscriberLink/991062/9de8e9a466a3faf5 > [7] https://lore.kernel.org/linux-fsdevel/ZZ3GeehAw%2F78gZJk@xxxxxxxxxxxxxxxxxxx > > Thanks, > Gao Xiang > > > > > Cheers, > > Ariel >