This patch adds the user interface as discussed in the "cmd filter fixes" thread. This patch depends on the cmdfilter fixes sent by Fujita. I have done tests with this patch ontop of his patchset and everything works as expected. -------------- This patch changes the interface of the cmd filter to use a +/- notation like echo -- +0x02 +0x03 -0x08 . If neither + or - is given it defaults to + (allow command). Note: The interface was added in 2.6.17-rc1 and is unused and undocumented so far so it's safe to change it. Cc: matthew@xxxxxx Cc: fujita.tomonori@xxxxxxxxxxxxx, Cc: jens.axboe@xxxxxxxxxx Cc: James.Bottomley@xxxxxxxxxxxxxxxxxxxxx Cc: dan.j.williams@xxxxxxxxx Cc: pjones@xxxxxxxxxx Cc: viro@xxxxxxxxxxxxxxxxxx Cc: dougg@xxxxxxxxxx Signed-off-by: Adel Gadllah <adel.gadllah@xxxxxxxxx> block/cmd-filter.c | 45 +++++++++++++++++++++++++-------------------- 1 files changed, 25 insertions(+), 20 deletions(-) diff --git a/block/cmd-filter.c b/block/cmd-filter.c index eec4404..72a6e5e 100644 --- a/block/cmd-filter.c +++ b/block/cmd-filter.c @@ -84,8 +84,8 @@ static ssize_t rcf_cmds_show(struct blk_scsi_cmd_filter *filter, char *page, for (i = 0; i < BLK_SCSI_MAX_CMDS; i++) { if (test_bit(i, okbits)) { - sprintf(npage, "%02x", i); - npage += 2; + sprintf(npage, "0x%02x", i); + npage += 4; if (i < BLK_SCSI_MAX_CMDS - 1) sprintf(npage++, " "); } @@ -111,33 +111,38 @@ static ssize_t rcf_writecmds_show(struct blk_scsi_cmd_filter *filter, static ssize_t rcf_cmds_store(struct blk_scsi_cmd_filter *filter, const char *page, size_t count, int rw) { - ssize_t ret = 0; - unsigned long okbits[BLK_SCSI_CMD_PER_LONG], *target_okbits; - int cmd, status, len; + unsigned long *target_okbits; + int cmd, status, set; substring_t ss; + char *p; - memset(&okbits, 0, sizeof(okbits)); + if (rw == READ) + target_okbits = filter->read_ok; + else + target_okbits = filter->write_ok; + + while ((p = strsep(&page, " ")) != NULL) { + set = 1; + + if (p[0] == '-') { + set = 0; + p++; + } - for (len = strlen(page); len > 0; len -= 3) { - if (len < 2) - break; - ss.from = (char *) page + ret; - ss.to = (char *) page + ret + 2; - ret += 3; + if (p[0] == '+') + p++; + ss.from = (char *) p; + ss.to = (char *) p + 4; status = match_hex(&ss, &cmd); /* either of these cases means invalid input, so do nothing. */ if (status || cmd >= BLK_SCSI_MAX_CMDS) return -EINVAL; - - __set_bit(cmd, okbits); + if (set) + set_bit(cmd, target_okbits); + else + clear_bit(cmd, target_okbits); } - if (rw == READ) - target_okbits = filter->read_ok; - else - target_okbits = filter->write_ok; - - memmove(target_okbits, okbits, sizeof(okbits)); return count; } -- To unsubscribe from this list: send the line "unsubscribe linux-scsi" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html