Re: [PATCH v4 4/4] tty: implement led triggers

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



On Mon 2018-05-14 12:15:05, Uwe Kleine-König wrote:
> The rx trigger fires when data is pushed to the ldisc by the driver. This
> is a bit later than the actual receiving of data but has the nice benefit
> that it doesn't need adaption for each driver and isn't in the hot path.
> 
> Similarly the tx trigger fires when data was copied from userspace and is
> given to the ldisc.
> 
> Signed-off-by: Uwe Kleine-König <u.kleine-koenig@xxxxxxxxxxxxxx>
> ---
>  drivers/tty/Kconfig      |  7 +++++++
>  drivers/tty/tty_buffer.c |  2 ++
>  drivers/tty/tty_io.c     |  3 +++
>  drivers/tty/tty_port.c   | 32 ++++++++++++++++++++++++++++++--
>  include/linux/tty.h      | 22 ++++++++++++++++++++++
>  5 files changed, 64 insertions(+), 2 deletions(-)
> 
> diff --git a/drivers/tty/Kconfig b/drivers/tty/Kconfig
> index 0840d27381ea..b119c0fa1f5a 100644
> --- a/drivers/tty/Kconfig
> +++ b/drivers/tty/Kconfig
> @@ -41,6 +41,13 @@ config VT
>  	  If unsure, say Y, or else you won't be able to do much with your new
>  	  shiny Linux system :-)
>  
> +config TTY_LEDS_TRIGGERS
> +	bool "Enable support for TTY actions making LEDs blink"
> +	depends on LEDS_TRIGGERS
> +	---help---
> +	  This enable support for tty triggers. It provides two LED triggers
> +	  (rx and tx) for each TTY.
> +
>  config CONSOLE_TRANSLATIONS
>  	depends on VT
>  	default y
> diff --git a/drivers/tty/tty_buffer.c b/drivers/tty/tty_buffer.c
> index c996b6859c5e..364080ce8e91 100644
> --- a/drivers/tty/tty_buffer.c
> +++ b/drivers/tty/tty_buffer.c
> @@ -521,6 +521,8 @@ static void flush_to_ldisc(struct work_struct *work)
>  			continue;
>  		}
>  
> +		tty_led_trigger_rx(port);
> +
>  		count = receive_buf(port, head, count);
>  		if (!count)
>  			break;
> diff --git a/drivers/tty/tty_io.c b/drivers/tty/tty_io.c
> index 7c838b90a31d..8ef597dc0c3d 100644
> --- a/drivers/tty/tty_io.c
> +++ b/drivers/tty/tty_io.c
> @@ -955,6 +955,9 @@ static inline ssize_t do_tty_write(
>  		ret = -EFAULT;
>  		if (copy_from_user(tty->write_buf, buf, size))
>  			break;
> +
> +		tty_led_trigger_tx(tty->port);
> +
>  		ret = write(tty, file, tty->write_buf, size);
>  		if (ret <= 0)
>  			break;
> diff --git a/drivers/tty/tty_port.c b/drivers/tty/tty_port.c
> index 25d736880013..72dcde234a7d 100644
> --- a/drivers/tty/tty_port.c
> +++ b/drivers/tty/tty_port.c
> @@ -37,6 +37,8 @@ static int tty_port_default_receive_buf(struct tty_port *port,
>  
>  	ret = tty_ldisc_receive_buf(disc, p, (char *)f, count);
>  
> +	tty_led_trigger_rx(port);
> +
>  	tty_ldisc_deref(disc);
>  
>  	return ret;
> @@ -163,8 +165,31 @@ struct device *tty_port_register_device_attr_serdev(struct tty_port *port,
>  		return dev;
>  	}
>  
> -	return tty_register_device_attr(driver, index, device, drvdata,
> -			attr_grp);
> +	if (IS_ENABLED(CONFIG_TTY_LEDS_TRIGGERS)) {
> +		int ret;
> +
> +		ret = led_trigger_register_format(&port->led_trigger_rx,
> +						  "%s%d-rx", driver->name, index);
> +		if (ret < 0)
> +			pr_warn("Failed to register rx trigger for %s%d (%d)\n",
> +				driver->name, index, ret);
> +
> +		ret = led_trigger_register_format(&port->led_trigger_tx,
> +						  "%s%d-tx", driver->name, index);
> +		if (ret < 0)
> +			pr_warn("Failed to register tx trigger for %s%d (%d)\n",
> +				driver->name, index, ret);
> +	}

There are many ttys and you'll eat quite a bit of kernel memory with this (besides other
effects).

Could we get trigger which takes tty name and rx/tx as a parameter? That should save a bit of
RAM and some headaches with .../triggers file being too big.

Thanks,

										Pavel



[Index of Archives]     [Linux ARM Kernel]     [Linux ARM]     [Linux Omap]     [Fedora ARM]     [IETF Annouce]     [Security]     [Bugtraq]     [Linux OMAP]     [Linux MIPS]     [ECOS]     [Asterisk Internet PBX]     [Linux API]

  Powered by Linux