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

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

 



Hello Johan,

On Tue, May 22, 2018 at 11:51:41AM +0200, Johan Hovold wrote:
> On Thu, May 17, 2018 at 08:16:25AM +0200, Uwe Kleine-König wrote:
> > 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.
> 
> Perhaps not, but it's an unfortunate effect of the choice of moving this
> into the tty layer instead of having the lower level drivers implement
> this, which I at least think you need to mention.

the observability is the same, independent of where the trigger fires,
isn't it?

> Personally I don't understand this obsession with blinking lights at
> all, but if this is to be supported we should at least try to do it the
> right way (after determining what that is).
> 
> > > 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).
> 
> You're right, a getty would open the tty device directly so then you'd
> get blinks in both directions in a login shell.
> 
> But printk messages won't trigger the led as consoles use a different
> write path.

I'm willing to sell this as an advantage :-)

> > > > @@ -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.).
> 
> Yeah, and I think the following paragraph is pretty clear on this:
> 
> 	Prefer to compile out entire functions, rather than portions of
> 	functions or portions of expressions.  Rather than putting an
> 	ifdef in an expression, factor out part or all of the expression
> 	into a separate helper function and apply the conditional to
> 	that function.

I understand "Prefer to compile out" as "Prefer to compile out using #if
et al", so it doesn't cover if (IS_ENABLED(...)). The section title is
"Conditional Compilation" which supports my interpretation and there is
no "ifdef in any affected expression". The nice thing about IS_ENABLED
is that it can be indented naturally without looking strange. And
compared to #if it still ensures that the block is looked at by the
compiler even when the condition is false, which is also a nice
property.

> And in this case I really don't want to see whatever magic is done to
> register a led trigger so factoring that out into helper function allows
> the tty code to remain clean. You also shouldn't keep those led triggers
> around in struct tty_port when !CONFIG_TTY_LEDS_TRIGGERS.

Having them even without CONFIG_TTY_LEDS_TRIGGERS helps to have to use
less #ifdef in the code. Without CONFIG_LEDS_TRIGGER sizeof(struct
led_trigger) is 0, which is an IMHO fine construct.

> > > 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.
> 
> There are (at least) three ways to register a tty device of which two
> set up the port link at registration and one where the tty port link is
> setup when the device is opened:
> 
> 	tty_port_register_device_attr()
> 	tty_port_register_device_attr_serdev()
> 	tty_register_device_attr()
> 
> The tty_port_register_device_attr_serdev() is supposed to be a temporary
> solution until we can enable serdev for all tty drivers that register
> their devices along the their ports. But for now, you'd probably want to
> register led triggers in both of the tty_port_register-functions.

OK, I will take another look.

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