diff mbox series

target: make the pi_prot_format ConfigFS path readable

Message ID 20190204183210.8386-1-ddiss@suse.de (mailing list archive)
State Accepted
Headers show
Series target: make the pi_prot_format ConfigFS path readable | expand

Commit Message

David Disseldorp Feb. 4, 2019, 6:32 p.m. UTC
pi_prot_format conversion to write-only caused userspace breakage. Make
the ConfigFS path readable again and hardcode the "0\n" content,
matching previous output.

Fixes: 6baca7601bde ("scsi: target: drop unused pi_prot_format attribute storage")
Link: https://bugzilla.redhat.com/show_bug.cgi?id=1667505
Reported-by: Lee Duncan <lduncan@suse.com>
Reported-by: Laura Abbott <labbott@redhat.com>
Signed-off-by: David Disseldorp <ddiss@suse.de>
---
 drivers/target/target_core_configfs.c | 8 +++++++-
 1 file changed, 7 insertions(+), 1 deletion(-)

Comments

Martin K. Petersen Feb. 5, 2019, 2:18 a.m. UTC | #1
David,

> pi_prot_format conversion to write-only caused userspace
> breakage. Make the ConfigFS path readable again and hardcode the "0\n"
> content, matching previous output.

Applied to 5.0/scsi-fixes, thanks!
Bart Van Assche Feb. 5, 2019, 2:31 a.m. UTC | #2
On 2/4/19 10:32 AM, David Disseldorp wrote:
> pi_prot_format conversion to write-only caused userspace breakage. Make
> the ConfigFS path readable again and hardcode the "0\n" content,
> matching previous output.
> 
> Fixes: 6baca7601bde ("scsi: target: drop unused pi_prot_format attribute storage")
> Link: https://bugzilla.redhat.com/show_bug.cgi?id=1667505
> Reported-by: Lee Duncan <lduncan@suse.com>
> Reported-by: Laura Abbott <labbott@redhat.com>
> Signed-off-by: David Disseldorp <ddiss@suse.de>

Reviewed-by: Bart Van Assche <bvanassche@acm.org>
diff mbox series

Patch

diff --git a/drivers/target/target_core_configfs.c b/drivers/target/target_core_configfs.c
index 72016d0dfca5..8e7fffbb8802 100644
--- a/drivers/target/target_core_configfs.c
+++ b/drivers/target/target_core_configfs.c
@@ -852,6 +852,12 @@  static ssize_t pi_prot_type_store(struct config_item *item,
 	return count;
 }
 
+/* always zero, but attr needs to remain RW to avoid userspace breakage */
+static ssize_t pi_prot_format_show(struct config_item *item, char *page)
+{
+	return snprintf(page, PAGE_SIZE, "0\n");
+}
+
 static ssize_t pi_prot_format_store(struct config_item *item,
 		const char *page, size_t count)
 {
@@ -1132,7 +1138,7 @@  CONFIGFS_ATTR(, emulate_3pc);
 CONFIGFS_ATTR(, emulate_pr);
 CONFIGFS_ATTR(, pi_prot_type);
 CONFIGFS_ATTR_RO(, hw_pi_prot_type);
-CONFIGFS_ATTR_WO(, pi_prot_format);
+CONFIGFS_ATTR(, pi_prot_format);
 CONFIGFS_ATTR(, pi_prot_verify);
 CONFIGFS_ATTR(, enforce_pr_isids);
 CONFIGFS_ATTR(, is_nonrot);