Hi Kumar, Anton, Kumar Gala wrote: > > On Aug 19, 2009, at 1:37 PM, Anton Vorontsov wrote: > >> Currently fdt_fixup_stdout() is using hard-coded CONFIG_CONS_INDEX >> constant. With multi-serial support, the CONS_INDEX may no longer >> represent actual console, so we should try to extract port number >> from the current stdio device name instead of always hard-coding the >> constant value. >> >> Signed-off-by: Anton Vorontsov <[email protected]> >> --- >> common/fdt_support.c | 22 +++++++++++++++++++++- >> 1 files changed, 21 insertions(+), 1 deletions(-) > > Should get some Ack from Jerry. > > - k
Sorry, I was asleep at the wheel. I'm OK with the patch as is, but it could be tightened up slightly by having the new function fill in the serial name in the non-multi situation. I renamed the function as well to be fdt_fill_sername() to remove the "multi" connotation. Below is a *HAND MODIFIED* (i.e. probably broken) edit of Anton's patch reflecting my thoughts. I'll leave it up to Anton and Kumar... I'm OK with Anton's original patch and you have my Acked-by: Gerald Van Baren <[email protected]> or you can verify and adopt my proposed change (more work :-() and add a Signed-off-by: Gerald Van Baren <[email protected]> to Anton's s-o-b. Thanks, gvb ------------------------------------------------------------------------ Currently fdt_fixup_stdout() is using hard-coded CONFIG_CONS_INDEX constant. With multi-serial support, the CONS_INDEX may no longer represent actual console, so we should try to extract port number from the current stdio device name instead of always hard-coding the constant value. Signed-off-by: Anton Vorontsov <[email protected]> Signed-off-by: Gerald Van Baren <[email protected]> --- common/fdt_support.c | 22 +++++++++++++++++++++- 1 files changed, 21 insertions(+), 1 deletions(-) diff --git a/common/fdt_support.c b/common/fdt_support.c index 89164a1..e01303a 100644 --- a/common/fdt_support.c +++ b/common/fdt_support.c @@ -22,6 +22,7 @@ */ #include <common.h> +#include <stdio_dev.h> #include <linux/ctype.h> #include <linux/types.h> #include <asm/global_data.h> @@ -90,6 +91,26 @@ int fdt_find_and_setprop(void *fdt, const char *node, const char *prop, } #ifdef CONFIG_OF_STDOUT_VIA_ALIAS + +#ifdef CONFIG_SERIAL_MULTI +static void fdt_fill_sername(char *sername, size_t maxlen) +{ + const char *outname = stdio_devices[stdout]->name; + + if (strcmp(outname, "serial") > 0) + strncpy(sername, outname, maxlen); + + /* eserial? */ + if (strcmp(outname + 1, "serial") > 0) + strncpy(sername, outname + 1, maxlen); +} +#else +static inline void fdt_fill_sername(char *sername, size_t maxlen) +{ + sprintf(sername, "serial%d", CONFIG_CONS_INDEX - 1); +} +#endif /* CONFIG_SERIAL_MULTI */ + static int fdt_fixup_stdout(void *fdt, int chosenoff) { int err = 0; @@ -98,7 +116,7 @@ static int fdt_fixup_stdout(void *fdt, int chosenoff) char sername[9] = { 0 }; const char *path; - sprintf(sername, "serial%d", CONFIG_CONS_INDEX - 1); + fdt_fill_sername(sername, sizeof(sername) - 1); err = node = fdt_path_offset(fdt, "/aliases"); if (node >= 0) { -- 1.6.3.3 Original patch: > Currently fdt_fixup_stdout() is using hard-coded CONFIG_CONS_INDEX > constant. With multi-serial support, the CONS_INDEX may no longer > represent actual console, so we should try to extract port number > from the current stdio device name instead of always hard-coding the > constant value. > > Signed-off-by: Anton Vorontsov <avorontsov <at> ru.mvista.com> > --- > common/fdt_support.c | 22 +++++++++++++++++++++- > 1 files changed, 21 insertions(+), 1 deletions(-) > > diff --git a/common/fdt_support.c b/common/fdt_support.c > index 89164a1..e01303a 100644 > --- a/common/fdt_support.c > +++ b/common/fdt_support.c > @@ -22,6 +22,7 @@ > */ > > #include <common.h> > +#include <stdio_dev.h> > #include <linux/ctype.h> > #include <linux/types.h> > #include <asm/global_data.h> > @@ -90,6 +91,23 @@ int fdt_find_and_setprop(void *fdt, const char *node, > const char *prop, > } > > #ifdef CONFIG_OF_STDOUT_VIA_ALIAS > + > +#ifdef CONFIG_SERIAL_MULTI > +static void fdt_fill_multisername(char *sername, size_t maxlen) > +{ > + const char *outname = stdio_devices[stdout]->name; > + > + if (strcmp(outname, "serial") > 0) > + strncpy(sername, outname, maxlen); > + > + /* eserial? */ > + if (strcmp(outname + 1, "serial") > 0) > + strncpy(sername, outname + 1, maxlen); > +} > +#else > +static inline void fdt_fill_multisername(char *sername, size_t maxlen) {} > +#endif /* CONFIG_SERIAL_MULTI */ > + > static int fdt_fixup_stdout(void *fdt, int chosenoff) > { > int err = 0; > @@ -98,7 +116,9 @@ static int fdt_fixup_stdout(void *fdt, int chosenoff) > char sername[9] = { 0 }; > const char *path; > > - sprintf(sername, "serial%d", CONFIG_CONS_INDEX - 1); > + fdt_fill_multisername(sername, sizeof(sername) - 1); > + if (!sername[0]) > + sprintf(sername, "serial%d", CONFIG_CONS_INDEX - 1); > > err = node = fdt_path_offset(fdt, "/aliases"); > if (node >= 0) { > -- > 1.6.3.3 _______________________________________________ U-Boot mailing list [email protected] http://lists.denx.de/mailman/listinfo/u-boot

