Re: [PATCH v2] scsi: target: Allow FUA if no write cache enabled
From: stuart hayes
Date: Mon Jun 01 2026 - 11:16:45 EST
On 4/30/2026 10:43 AM, Martin K. Petersen wrote:
I've gone through SBC and SPC, and I can't find anything that would suggest that this is a spec violation.
Stuart,
Without this patch, accesses with FUA set will be rejected, even
though they always go directly to the media when there's no write
cache.
The spec allows this. However, ...
This is needed because EDK2 FAT filesystem code sets the FUA bit when
writing, regardless of whether the device advertises support of
DPOFUA.
^^^ that is clearly a spec violation. What is being done to address this
issue?
And, not that what I think makes any difference, but I don't see the point in requiring an initiator to check DPOFUA before setting FUA on a write that needs to go straight to media... why not just set FUA whenever needed, and if the FUA bit wasn't strictly required to ensure that the write went straight to media, who cares, if the requested behavior is still provided?
Also, wrt. the patch itself, please see:The AI review suggests moving this fix to sbc_check_dpofua(), so that DPOFUA behavior in the mode page is unchanged, and it just silently allows writes with FUA set even if DPOFUA isn't set.
https://sashiko.dev/#/patchset/20260428203938.9738-1-stuart.w.hayes%40gmail.com
If there's no objection, I'll submit a new patch that does that. The reason I didn't do that the first time around is that it breaks some of the blktests that specifically check to make sure a command fails if FUA is set when DPOFUA isn't.