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

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

 



Hello Johan,

On Wed, May 16, 2018 at 09:54:54AM +0200, Johan Hovold wrote:
> On Mon, May 14, 2018 at 12:15:05PM +0200, 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.
> 
> This also has the negative effect of having the blink rate (and
> pattern) be dependent on the size of the buffers provided by userspace
> however.
> 
> With buffers of 2048 bytes or more and at 115200 baud you get a 178 ms
> period (rather than the "default" 100 ms used for smaller buffers and
> high-enough baudrates) and this drops to 2 seconds and 68 second periods
> for 9600 and 300 baud respectively.

that is something I wouldn't care about. I think nobody will want to
determine the transfer rate from the emitted light.
 
> Also note that by hooking into do_tty_write, for UARTs used for consoles
> there will be no blink on console output, only for console input...

I tested the patch with the trigger for the console device. I didn't
test if kernel messages trigger the trigger, but the shell running on
the console device does (e.g. when running seq 1 10000).

> [...]

I agree to all of your comments that I stripped and will address them in
the next round.

> > @@ -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)) {
> 
> This doesn't really improve readability much. Use compile guards in the
> header file to provide dummy implementations for setup/teardown
> functions when the trigger isn't selected. And yes, the actual
> implementation may require ifdefs around them in the c-file as well.

I like this better than cpp stuff because it respects the indention of
the C source. This is also supported by Documentation/process/coding-style.rst.
(Well, I have admit that it's not impossible to interpret the document
to prefer dummy implementations over IS_ENABLED, but what I learned from
reviews to other contributions I expected this to be the commonly
accepted and expected way.).
 
> Also note that you need to add this to tty_port_register_device() as
> well... Serdev is currently opt-in and only enabled for serial core (due
> to some lifetime issues and issues related to hotplug), but there's no
> reason to limit these triggers to serial core.

I cannot follow this immediatly. Will study the code a bit and then
probably understand.

Best regards
Uwe

-- 
Pengutronix e.K.                           | Uwe Kleine-König            |
Industrial Linux Solutions                 | http://www.pengutronix.de/  |



[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