On 04/01/20 22:05, Michael Christie wrote:
On 04/01/2020 08:21 AM, Bodo Stroesser wrote:
In commit b49d6f7885306ee636d5c1af52170f3069ccf5f7 the new attribute> emulate_pr was added.
passthrough_parse_cdb() uses the attribute's value to distinguish,
whether reservation commands should be rejected or not.
But the new attribute was not added to passthrough_attrib_attrs, so in
pscsi and tcmu - the users of passthrough_parse_cdb() - the attribute
is not available to change parser's behavior.
This patch adds the new attribute as well as the "pr control" attributes
enforce_pr_isids and force_pr_aptpl to passthrough_attrib_attrs.
Signed-off-by: Bodo Stroesser <bstroesser@xxxxxxxxxxxxxx>
---
drivers/target/target_core_configfs.c | 3 +++
1 file changed, 3 insertions(+)
diff --git a/drivers/target/target_core_configfs.c b/drivers/target/target_core_configfs.c
index ff82b21fdcce..c5a974c5b31d 100644
--- a/drivers/target/target_core_configfs.c
+++ b/drivers/target/target_core_configfs.c
@@ -1203,6 +1203,9 @@ struct configfs_attribute *passthrough_attrib_attrs[] = {
&attr_hw_block_size,
&attr_hw_max_sectors,
&attr_hw_queue_depth,
+ &attr_emulate_pr,
This one seems ok here, because it works for both pscsi and tcmu.
+ &attr_enforce_pr_isids,
+ &attr_force_pr_aptpl,
These only work for tcmu. pscsi will do whatever the physical device
does, and we can't control it. I guess the options would be:
Sorry, I forgot to add a note, that I'm preparing a further patch, that
allows to write pgr_support attribute (TRANSPORT_FLAG_PASSTHROUGH_PGR),
if the backend allows it.
We need this to be able to set TRANSPORT_FLAG_PASSTHROUGH_PGR for tcmu.
But of course it also would be an option for pscsi to allow resetting of
TRANSPORT_FLAG_PASSTHROUGH_PGR. Then the pr emulation in target core can
be used by pscsi. (And then the two other attributes become useful.)
I'm wondering anyway, whether reservation passthrough makes sense for
pscsi? For tcmu we will also send a patch allowing to pass nexus info up
to userland.
1. Just add them above.
According to what I wrote above, I'd still prefer option 1. :)
Thank you,
Bodo
2. Add them above and add some TRANSPORT_FLAG_PASSTHROUGH_PGR checks in
functions like force_pr_aptpl_store like we did for the pr functions, so
the user gets some feedback if they try to use them for pscsi. We would
have to add a isid function too.
3. Export the attrs or some common lib/helper functions to get/set the
values then target_core_user.c can setup the attrs and add it to
tcmu_attrib_attrs.
&attr_alua_support,
&attr_pgr_support,
NULL,