Page MenuHomeFreeBSD

p9fs: Use UNLINKAT instead of REMOVE to implement removals
ClosedPublic

Authored by markj on Nov 4 2024, 5:26 PM.
Tags
None
Referenced Files
F108414450: D47438.diff
Fri, Jan 24, 2:34 PM
Unknown Object (File)
Wed, Jan 22, 8:16 PM
Unknown Object (File)
Mon, Jan 6, 1:08 AM
Unknown Object (File)
Sat, Jan 4, 8:00 PM
Unknown Object (File)
Sat, Jan 4, 4:50 AM
Unknown Object (File)
Sun, Dec 29, 1:25 AM
Unknown Object (File)
Dec 13 2024, 1:15 PM
Unknown Object (File)
Dec 11 2024, 12:19 AM
Subscribers

Details

Summary

REMOVE doesn't work properly in the face of hard links. Use UNLINKAT
instead, which is implemented by qemu and bhyve and lets the client
specify the name being removed.

PR: 282432

Test Plan

Just manual testing in bhyve. It's a bit tricky to write regression tests without having a socket-based transport, since that'd make it easy to implement a simple server using contrib/lib9p...

Diff Detail

Repository
rG FreeBSD src repository
Lint
Lint Skipped
Unit
Tests Skipped
Build Status
Buildable 60385
Build 57269: arc lint + arc unit

Event Timeline

markj requested review of this revision.Nov 4 2024, 5:26 PM
markj added a reviewer: val_packett.cool.

LGTM - thanks for working on this. I think lib9p can support a socket-based transport which allows for testing lib9p itself. In the kernel there is an attempt at an abstraction layer but I think that its only ever been used with virtio,

This revision is now accepted and ready to land.Nov 6 2024, 1:04 PM