Re: [PATCH] serial: earlycon: stop abusing console::index

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

 



On Wed, Jun 08, 2016 at 10:06:22AM -0700, Peter Hurley wrote:
> On 06/03/2016 08:19 AM, Mark Rutland wrote:
> > Commit cda64e6824026575 ("serial: earlycon: Fixup earlycon console name
> > and index") added code to decompose an earlycon driver name into a
> > string prefix and numeric suffix, and place this into console::name and
> > console::index, such that we'd get a pretty name out of the core console
> > code, which requires a name and index. This is simply to give a
> > pretty/useful earlycon driver name in the log messages, and other than
> > logging the name and index hold no significance.
> 
> The idea was to keep the console_cmdline[] array consistent with the
> registered consoles, even though earlycon uses its own matching scheme.
> Least surprise and all that.
> 
> > However, this is broken for drivers such as "pl011", where the "011"
> > suffix gets stripped off, then subsequently restored, printed as a
> > decimal, erroneously giving "pl11" in log messages.
> 
> Yeah, I saw that.
> 
> > Additionally, for
> > earlycon drivers without a numeric suffix, "0" is added regardless. Thus
> > the code is broken in some cases, and generally inconsistent.
> 
> I would like to continue with some kind of naming scheme that preserves
> both the command line parameters (uart,uart8250,pl011,etc.) and uniquely
> identifies which uart driver is the earlycon.

I understand that we wish to know which driver is the earlycon. However,
I would argue that logging that at earlycon_init time (as this patch
does) should be sufficient.

> The current scheme could be fixed easily enough (by just using a single digit).
> Or using a separator, ie. uart/0, pl011/0, etc.

That would prevent the mangling issue, certainly.

The only issue I would have with this approach is that as with the
drivers that simply get a '0' appended, I suspect the index may be
confused with the usual index for the device (e.g. pl011/0 may be
assumed to be ttyAMA0, which isn't necessarily the case).

Regardless, it's definitely less confusing than "pl11".

Thanks,
Mark.

> 
> Regards,
> Peter Hurley
> 
> 
> > Instead, this patch changes the earlycon code to consistently register
> > "earlycon0", but ensures that the earlycon driver name is logged at
> > earlycon_init time. This is obvious, consistent, and sufficient to
> > provide the required information to the user.
> > 
> > With this in place, amongst the first messages from the kernel, the user
> > will see something like:
> > 
> > [    0.000000] earlycon: earlycon0 (pl011) at MMIO 0x000000007ff80000 (options '')
> > [    0.000000] bootconsole [earlycon0] enabled
> > 
> > Signed-off-by: Mark Rutland <mark.rutland@xxxxxxx>
> > Cc: Greg Kroah-Hartman <gregkh@xxxxxxxxxxxxxxxxxxx>
> > Cc: Jiri Slaby <jslaby@xxxxxxxx>
> > Cc: Leif Lindholm <leif.lindholm@xxxxxxx>
> > Cc: Peter Hurley <peter@xxxxxxxxxxxxxxxxxx>
> > Cc: Rob Herring <robh@xxxxxxxxxx>
> > Cc: Will Deacon <will.deacon@xxxxxxx>
> > Cc: linux-serial@xxxxxxxxxxxxxxx
> > Cc: linux-kernel@xxxxxxxxxxxxxxx
> > ---
> >  drivers/tty/serial/earlycon.c | 19 ++++---------------
> >  1 file changed, 4 insertions(+), 15 deletions(-)
> > 
> > diff --git a/drivers/tty/serial/earlycon.c b/drivers/tty/serial/earlycon.c
> > index 067783f..2b6622a 100644
> > --- a/drivers/tty/serial/earlycon.c
> > +++ b/drivers/tty/serial/earlycon.c
> > @@ -29,7 +29,7 @@
> >  #include <asm/serial.h>
> >  
> >  static struct console early_con = {
> > -	.name =		"uart",		/* fixed up at earlycon registration */
> > +	.name =		"earlycon",
> >  	.flags =	CON_PRINTBUFFER | CON_BOOT,
> >  	.index =	0,
> >  };
> > @@ -60,24 +60,13 @@ static void __init earlycon_init(struct earlycon_device *device,
> >  {
> >  	struct console *earlycon = device->con;
> >  	struct uart_port *port = &device->port;
> > -	const char *s;
> > -	size_t len;
> > -
> > -	/* scan backwards from end of string for first non-numeral */
> > -	for (s = name + strlen(name);
> > -	     s > name && s[-1] >= '0' && s[-1] <= '9';
> > -	     s--)
> > -		;
> > -	if (*s)
> > -		earlycon->index = simple_strtoul(s, NULL, 10);
> > -	len = s - name;
> > -	strlcpy(earlycon->name, name, min(len + 1, sizeof(earlycon->name)));
> > +
> >  	earlycon->data = &early_console_dev;
> >  
> >  	if (port->iotype == UPIO_MEM || port->iotype == UPIO_MEM16 ||
> >  	    port->iotype == UPIO_MEM32 || port->iotype == UPIO_MEM32BE)
> > -		pr_info("%s%d at MMIO%s %pa (options '%s')\n",
> > -			earlycon->name, earlycon->index,
> > +		pr_info("%s%d (%s) at MMIO%s %pa (options '%s')\n",
> > +			earlycon->name, earlycon->index, name,
> >  			(port->iotype == UPIO_MEM) ? "" :
> >  			(port->iotype == UPIO_MEM16) ? "16" :
> >  			(port->iotype == UPIO_MEM32) ? "32" : "32be",
> > 
> 
--
To unsubscribe from this list: send the line "unsubscribe linux-serial" in
the body of a message to majordomo@xxxxxxxxxxxxxxx
More majordomo info at  http://vger.kernel.org/majordomo-info.html



[Index of Archives]     [Kernel Newbies]     [Security]     [Netfilter]     [Bugtraq]     [Linux PPP]     [Linux FS]     [Yosemite News]     [MIPS Linux]     [ARM Linux]     [Linux Security]     [Linux RAID]     [Samba]     [Video 4 Linux]     [Linmodem]     [Device Mapper]     [Linux Kernel for ARM]

  Powered by Linux