On Thu, Dec 12, 2019 at 11:16 AM Barret Rhoden <brho@xxxxxxxxxx> wrote: > > On 12/12/19 12:37 PM, Dan Williams wrote: > > Yeah, since device-dax is the only path to support longterm page > > pinning for vfio device assignment, testing with device-dax + 1GB > > pages would be a useful sanity check. > > What are the issues with fs-dax and page pinning? Is that limitation > something that is permanent and unfixable (by me or anyone)? It's a surprisingly painful point of contention... File backed DAX pages cannot be truncated while the page is pinned because the pin may indicate that DMA is ongoing to the file block / DAX page. When that pin is from RDMA or VFIO that creates a situation where filesystem operations are blocked indefinitely. More details here: 94db151dc892 "vfio: disable filesystem-dax page pinning". Currently, to prevent the deadlock, RDMA, VFIO, and IO_URING memory registration is blocked if the mapping is filesystem-dax backed (see the FOLL_LONGTERM flag to get_user_pages). One of the proposals to break the impasse was to allow the filesystem to forcibly revoke the mapping. I.e. to use the IOMMU to forcibly kick the RDMA device out of its registration. That was rejected by RDMA folks because RDMA applications are not prepared for this revocation to happen and the application that performed the registration may not be the application that uses the registration. There was an attempt to use a file lease to indicate the presence of a file / memory-registration that is blocking file-system operations, but that was still less palatable to filesystem folks than just keeping the status quo of blocking longterm pinning. That said, the VFIO use case seems a different situation than RDMA. There's often a 1:1 relationship between the application performing the memory registration and the application consuming it, the VMM, and there is always an IOMMU present that could revoke access and kill the guest is the mapping got truncated. It seems in theory that VFIO could tolerate a "revoke pin on truncate" mechanism where RDMA could not. > I'd like to put a lot more in a DAX/pmem region than just a guest's > memory, and having a mountable filesystem would be extremely convenient. Why would page pinning be involved in allowing the guest to mount a filesystem on guest-pmem? That already works today, it's just the device-passthrough that causes guest memory to be pinned indefinitely.