Hi Dave, Can we have your ack for the change in drivers/ide/ide-disk.c? Best regards, Jacek Anaszewski On 02/28/2018 04:03 PM, Bartlomiej Zolnierkiewicz wrote: > > [ added DaveM to Cc: ] > > On Saturday, February 24, 2018 11:45:56 PM Linus Walleij wrote: >> This adds two new disk triggers for triggering on reads >> and writes respectively, named "disk-read" and "disk-write". >> >> The use case comes from working on the D-Link DNS-313 NAS >> box. This features an RGB LED for disk activity. with >> these two triggers I can couple the green LED to read >> activity and the red LED to write activity, which gives >> the appropriate user feedback about what is happening >> on the disk. When tested it gave exactly the feedback >> desired. >> >> The in-kernel interface is simply changed to pass a bool >> indicating if the activity is write activity and update >> each trigger (and the composite "disk-activity" trigger) >> depending on what is passed in. >> >> This requires an ACK from the libata/IDE maintainers. >> >> Cc: Tejun Heo <tj@xxxxxxxxxx> >> Cc: Bartlomiej Zolnierkiewicz <b.zolnierkie@xxxxxxxxxxx> >> Cc: Jacek Anaszewski <jacek.anaszewski@xxxxxxxxx> >> Cc: Pavel Machek <pavel@xxxxxx> >> Signed-off-by: Linus Walleij <linus.walleij@xxxxxxxxxx> > > Reviewed-by: Bartlomiej Zolnierkiewicz <b.zolnierkie@xxxxxxxxxxx> > >> --- >> drivers/ata/libata-core.c | 2 +- >> drivers/ide/ide-disk.c | 2 +- >> drivers/leds/trigger/ledtrig-disk.c | 12 +++++++++++- >> include/linux/leds.h | 4 ++-- >> 4 files changed, 15 insertions(+), 5 deletions(-) >> >> diff --git a/drivers/ata/libata-core.c b/drivers/ata/libata-core.c >> index 3c09122bf038..fa75de6abbf1 100644 >> --- a/drivers/ata/libata-core.c >> +++ b/drivers/ata/libata-core.c >> @@ -5219,7 +5219,7 @@ void ata_qc_complete(struct ata_queued_cmd *qc) >> struct ata_port *ap = qc->ap; >> >> /* Trigger the LED (if available) */ >> - ledtrig_disk_activity(); >> + ledtrig_disk_activity(!!(qc->tf.flags & ATA_TFLAG_WRITE)); >> >> /* XXX: New EH and old EH use different mechanisms to >> * synchronize EH with regular execution path. >> diff --git a/drivers/ide/ide-disk.c b/drivers/ide/ide-disk.c >> index 188d1b03715d..67bc72d78fbf 100644 >> --- a/drivers/ide/ide-disk.c >> +++ b/drivers/ide/ide-disk.c >> @@ -187,7 +187,7 @@ static ide_startstop_t ide_do_rw_disk(ide_drive_t *drive, struct request *rq, >> BUG_ON(drive->dev_flags & IDE_DFLAG_BLOCKED); >> BUG_ON(blk_rq_is_passthrough(rq)); >> >> - ledtrig_disk_activity(); >> + ledtrig_disk_activity(rq_data_dir(rq) == WRITE); >> >> pr_debug("%s: %sing: block=%llu, sectors=%u\n", >> drive->name, rq_data_dir(rq) == READ ? "read" : "writ", >> diff --git a/drivers/leds/trigger/ledtrig-disk.c b/drivers/leds/trigger/ledtrig-disk.c >> index cd525b4125eb..9816b0d60270 100644 >> --- a/drivers/leds/trigger/ledtrig-disk.c >> +++ b/drivers/leds/trigger/ledtrig-disk.c >> @@ -18,9 +18,11 @@ >> #define BLINK_DELAY 30 >> >> DEFINE_LED_TRIGGER(ledtrig_disk); >> +DEFINE_LED_TRIGGER(ledtrig_disk_read); >> +DEFINE_LED_TRIGGER(ledtrig_disk_write); >> DEFINE_LED_TRIGGER(ledtrig_ide); >> >> -void ledtrig_disk_activity(void) >> +void ledtrig_disk_activity(bool write) >> { >> unsigned long blink_delay = BLINK_DELAY; >> >> @@ -28,12 +30,20 @@ void ledtrig_disk_activity(void) >> &blink_delay, &blink_delay, 0); >> led_trigger_blink_oneshot(ledtrig_ide, >> &blink_delay, &blink_delay, 0); >> + if (write) >> + led_trigger_blink_oneshot(ledtrig_disk_write, >> + &blink_delay, &blink_delay, 0); >> + else >> + led_trigger_blink_oneshot(ledtrig_disk_read, >> + &blink_delay, &blink_delay, 0); >> } >> EXPORT_SYMBOL(ledtrig_disk_activity); >> >> static int __init ledtrig_disk_init(void) >> { >> led_trigger_register_simple("disk-activity", &ledtrig_disk); >> + led_trigger_register_simple("disk-read", &ledtrig_disk_read); >> + led_trigger_register_simple("disk-write", &ledtrig_disk_write); >> led_trigger_register_simple("ide-disk", &ledtrig_ide); >> >> return 0; >> diff --git a/include/linux/leds.h b/include/linux/leds.h >> index 5579c64c8fd6..b7e82550e655 100644 >> --- a/include/linux/leds.h >> +++ b/include/linux/leds.h >> @@ -346,9 +346,9 @@ static inline void *led_get_trigger_data(struct led_classdev *led_cdev) >> >> /* Trigger specific functions */ >> #ifdef CONFIG_LEDS_TRIGGER_DISK >> -extern void ledtrig_disk_activity(void); >> +extern void ledtrig_disk_activity(bool write); >> #else >> -static inline void ledtrig_disk_activity(void) {} >> +static inline void ledtrig_disk_activity(bool write) {} >> #endif >> >> #ifdef CONFIG_LEDS_TRIGGER_MTD > > Best regards, > -- > Bartlomiej Zolnierkiewicz > Samsung R&D Institute Poland > Samsung Electronics > >