[U-Boot] [PATCH 2/2] include:configs: Add usb device-tree fixup for all fsl platforms

Ramneek Mehresh ramneek.mehresh at nxp.com
Mon Feb 8 12:07:29 CET 2016



> -----Original Message-----
> From: Ramneek Mehresh
> Sent: Thursday, January 28, 2016 5:45 PM
> To: 'Marek Vasut' <marex at denx.de>
> Cc: Ramneek Mehresh <ramneek.mehresh at freescale.com>; u-
> boot at lists.denx.de; Simon Glass <sjg at chromium.org>
> Subject: RE: [PATCH 2/2] include:configs: Add usb device-tree fixup for all fsl
> platforms
> 
> 
> 
> > -----Original Message-----
> > From: Marek Vasut [mailto:marex at denx.de]
> > Sent: Thursday, January 28, 2016 5:04 PM
> > To: Ramneek Mehresh <ramneek.mehresh at nxp.com>
> > Cc: Ramneek Mehresh <ramneek.mehresh at freescale.com>; u-
> > boot at lists.denx.de; Simon Glass <sjg at chromium.org>
> > Subject: Re: [PATCH 2/2] include:configs: Add usb device-tree fixup
> > for all fsl platforms
> >
> > On Thursday, January 28, 2016 at 12:05:29 PM, Ramneek Mehresh wrote:
> > > > -----Original Message-----
> > > > From: Marek Vasut [mailto:marex at denx.de]
> > > > Sent: Wednesday, January 27, 2016 5:13 PM
> > > > To: Ramneek Mehresh <ramneek.mehresh at nxp.com>
> > > > Cc: Ramneek Mehresh <ramneek.mehresh at freescale.com>; u-
> > > > boot at lists.denx.de; Simon Glass <sjg at chromium.org>
> > > > Subject: Re: [PATCH 2/2] include:configs: Add usb device-tree
> > > > fixup for all fsl platforms
> > > >
> > > > On Wednesday, January 27, 2016 at 12:33:04 PM, Ramneek Mehresh
> > wrote:
> > > > > > -----Original Message-----
> > > > > > From: Marek Vasut [mailto:marex at denx.de]
> > > > > > Sent: Wednesday, January 27, 2016 1:57 PM
> > > > > > To: Ramneek Mehresh <ramneek.mehresh at nxp.com>
> > > > > > Cc: Ramneek Mehresh <ramneek.mehresh at freescale.com>; u-
> > > > > > boot at lists.denx.de; Simon Glass <sjg at chromium.org>
> > > > > > Subject: Re: [PATCH 2/2] include:configs: Add usb device-tree
> > > > > > fixup for all fsl platforms
> > > > > >
> > > > > > On Wednesday, January 27, 2016 at 09:26:08 AM, Ramneek
> Mehresh
> > > >
> > > > wrote:
> > > > > > > > -----Original Message-----
> > > > > > > > From: Marek Vasut [mailto:marex at denx.de]
> > > > > > > > Sent: Wednesday, January 27, 2016 1:05 PM
> > > > > > > > To: Ramneek Mehresh <ramneek.mehresh at nxp.com>
> > > > > > > > Cc: Ramneek Mehresh <ramneek.mehresh at freescale.com>; u-
> > > > > > > > boot at lists.denx.de; Simon Glass <sjg at chromium.org>
> > > > > > > > Subject: Re: [PATCH 2/2] include:configs: Add usb
> > > > > > > > device-tree fixup for all fsl platforms
> > > > > > > >
> > > > > > > > On Wednesday, January 27, 2016 at 05:30:51 AM, Ramneek
> > > > > > > > Mehresh
> > > > > >
> > > > > > wrote:
> > > > > > > > > > -----Original Message-----
> > > > > > > > > > From: Marek Vasut [mailto:marex at denx.de]
> > > > > > > > > > Sent: Wednesday, January 27, 2016 9:57 AM
> > > > > > > > > > To: Ramneek Mehresh <ramneek.mehresh at nxp.com>
> > > > > > > > > > Cc: Ramneek Mehresh
> <ramneek.mehresh at freescale.com>;
> > u-
> > > > > > > > > > boot at lists.denx.de; Simon Glass <sjg at chromium.org>
> > > > > > > > > > Subject: Re: [PATCH 2/2] include:configs: Add usb
> > > > > > > > > > device-tree fixup for all fsl platforms
> > > > > > > > > >
> > > > > > > > > > On Wednesday, January 27, 2016 at 05:14:00 AM, Ramneek
> > > >
> > > > Mehresh
> > > >
> > > > > > > > wrote:
> > > > > > > > > > > > -----Original Message-----
> > > > > > > > > > > > From: Marek Vasut [mailto:marex at denx.de]
> > > > > > > > > > > > Sent: Tuesday, January 26, 2016 4:58 PM
> > > > > > > > > > > > To: Ramneek Mehresh
> > <ramneek.mehresh at freescale.com>
> > > > > > > > > > > > Cc: u-boot at lists.denx.de
> > > > > > > > > > > > Subject: Re: [PATCH 2/2] include:configs: Add usb
> > > > > > > > > > > > device-tree fixup for all fsl platforms
> > > > > > > > > > > >
> > > > > > > > > > > > On Tuesday, January 26, 2016 at 12:36:58 PM,
> > > > > > > > > > > > Ramneek
> > > >
> > > > Mehresh
> > > >
> > > > > > > > wrote:
> > > > > > > > > > > > > Add usb device-tree fixup for all relevant fsl
> > > > > > > > > > > > > ppc and arm platforms
> > > > > > > > > > > > >
> > > > > > > > > > > > > Signed-off-by: Ramneek Mehresh
> > > > > > > > > >
> > > > > > > > > > <ramneek.mehresh at freescale.com>
> > > > > > > > > >
> > > > > > > > > > > > > ---
> > > > > > > > > > > > >
> > > > > > > > > > > > >  board/freescale/b4860qds/b4860qds.c         | 2 +-
> > > > > > > > > > > > >  board/freescale/bsc9131rdb/bsc9131rdb.c     | 2 ++
> > > > > > > > > > > > >  board/freescale/bsc9132qds/bsc9132qds.c     | 2 ++
> > > > > > > > > > > > >  board/freescale/corenet_ds/corenet_ds.c     | 4 ++++
> > > > > > > > > > > > >  board/freescale/ls2080aqds/ls2080aqds.c     | 4 ++++
> > > > > > > > > > > > >  board/freescale/ls2080ardb/ls2080ardb.c     | 4 ++++
> > > > > > > > > > > > >  board/freescale/mpc8308rdb/mpc8308rdb.c     | 4
> ++++
> > > > > > > > > > > > >  board/freescale/mpc8315erdb/mpc8315erdb.c   | 2 ++
> > > > > > > > > > > > >  board/freescale/mpc837xemds/mpc837xemds.c   | 2
> ++
> > > > > > > > > > > > >  board/freescale/mpc837xerdb/mpc837xerdb.c   | 2 ++
> > > > > > > > > > > > >  board/freescale/mpc8536ds/mpc8536ds.c       | 2 +-
> > > > > > > > > > > > >  board/freescale/p1010rdb/p1010rdb.c         | 2 +-
> > > > > > > > > > > > >  board/freescale/p1022ds/p1022ds.c           | 2 +-
> > > > > > > > > > > > >  board/freescale/p1023rdb/p1023rdb.c         | 2 +-
> > > > > > > > > > > > >  board/freescale/p1_p2_rdb_pc/p1_p2_rdb_pc.c | 2 +-
> > > > > > > > > > > > >  board/freescale/p1_twr/p1_twr.c             | 3 +++
> > > > > > > > > > > > >  board/freescale/p2041rdb/p2041rdb.c         | 2 +-
> > > > > > > > > > > > >  board/freescale/t102xqds/t102xqds.c         | 2 +-
> > > > > > > > > > > > >  board/freescale/t102xrdb/t102xrdb.c         | 3 +++
> > > > > > > > > > > > >  board/freescale/t1040qds/t1040qds.c         | 2 +-
> > > > > > > > > > > > >  board/freescale/t104xrdb/t104xrdb.c         | 2 +-
> > > > > > > > > > > > >  board/freescale/t208xqds/t208xqds.c         | 3 +++
> > > > > > > > > > > > >  board/freescale/t208xrdb/t208xrdb.c         | 3 +++
> > > > > > > > > > > > >  board/freescale/t4qds/t4240emu.c            | 3 +++
> > > > > > > > > > > > >  board/freescale/t4qds/t4240qds.c            | 3 +++
> > > > > > > > > > > > >  board/freescale/t4rdb/t4240rdb.c            | 3 +++
> > > > > > > > > > > > >  include/configs/B4860QDS.h                  | 1 +
> > > > > > > > > > > > >  include/configs/BSC9131RDB.h                | 1 +
> > > > > > > > > > > > >  include/configs/BSC9132QDS.h                | 3 ++-
> > > > > > > > > > > > >  include/configs/MPC8308RDB.h                | 3 +++
> > > > > > > > > > > > >  include/configs/MPC8315ERDB.h               | 1 +
> > > > > > > > > > > > >  include/configs/MPC837XEMDS.h               | 3 ++-
> > > > > > > > > > > > >  include/configs/MPC837XERDB.h               | 1 +
> > > > > > > > > > > > >  include/configs/MPC8536DS.h                 | 1 +
> > > > > > > > > > > > >  include/configs/P1010RDB.h                  | 1 +
> > > > > > > > > > > > >  include/configs/P1022DS.h                   | 1 +
> > > > > > > > > > > > >  include/configs/P1023RDB.h                  | 1 +
> > > > > > > > > > > > >  include/configs/P2041RDB.h                  | 1 +
> > > > > > > > > > > > >  include/configs/T102xQDS.h                  | 1 +
> > > > > > > > > > > > >  include/configs/T102xRDB.h                  | 1 +
> > > > > > > > > > > > >  include/configs/T1040QDS.h                  | 1 +
> > > > > > > > > > > > >  include/configs/T104xRDB.h                  | 1 +
> > > > > > > > > > > > >  include/configs/T208xQDS.h                  | 1 +
> > > > > > > > > > > > >  include/configs/T208xRDB.h                  | 1 +
> > > > > > > > > > > > >  include/configs/T4240QDS.h                  | 1 +
> > > > > > > > > > > > >  include/configs/corenet_ds.h                | 1 +
> > > > > > > > > > > > >  include/configs/ls2080aqds.h                | 1 +
> > > > > > > > > > > > >  include/configs/ls2080ardb.h                | 1 +
> > > > > > > > > > > > >  include/configs/p1_p2_rdb_pc.h              | 1 +
> > > > > > > > > > > > >  include/configs/p1_twr.h                    | 1 +
> > > > > > > > > > > > >  50 files changed, 85 insertions(+), 12
> > > > > > > > > > > > > deletions(-)
> > > > > > > > > > > >
> > > > > > > > > > > > Each such new macro must be documented. What is
> > > > > > > > > > > > the point
> > > >
> > > > of
> > > >
> > > > > > > > > > > > this bulk rename anyway?
> > > > > > > > > > >
> > > > > > > > > > > Yes, I'll document the new MACRO defined for usb
> > > > > > > > > > > device-tree
> > > > > >
> > > > > > fixup.
> > > > > >
> > > > > > > > > > > However, this is not bulk rename. I just modified
> > > > > > > > > > > all these files to include usb device-tree fixup for
> > > > > > > > > > > all fsl ppc platforms. Most of these platforms were
> > > > > > > > > > > already using this mechanism (some via different
> > > > > > > > > > > ways),
> > > > > > > > > >
> > > > > > > > > > but
> > > > > > > > > >
> > > > > > > > > > > now its consistent across them.
> > > > > > > > > >
> > > > > > > > > > Wouldn't it make more sense to make this generic then
> > > > > > > > > > instead of patching zillion files ?
> > > > > > > > >
> > > > > > > > > The patch set is to make this support generic, but I do
> > > > > > > > > need to make these platforms use this generic support in
> > > > > > > > > consistent way via single macro inclusion in their configs...
> > > > > > > >
> > > > > > > > You can also just modify the function itself instead of
> > > > > > > > million board files. Adding ifdef-endif combo all around
> > > > > > > > the place is just not gonna work, sorry.
> > > > > > > >
> > > > > > > > Also, the macro should probably contain _OF_ instead of
> > > > > > > > DEVTREE ...
> > > > > > >
> > > > > > > Ok, in this case, I'll use the already defined macros used
> > > > > > > by these platforms. However, this approach will not make
> > > > > > > sure that all these platforms are using this feature in a
> > > > > > > consistent/similar
> > way.
> > > > > >
> > > > > > Why not ?
> > > > >
> > > > > All the platforms files are calling fdt_fixup_dr_usb() under
> > > > > following
> > > > > conditions: 1. no macro usage, direct call 2. Using
> > > > > CONFIG_HAS_FSL_DR_USB macro (for socs having DR controller) 2.
> > > > > Using CONFIG_HAS_FSL_MPH_USB (for socs having MPH controller)
> 3.
> > > > > Using CONFIG_HAS_FSL_XHCI_USB (for socs having XHCI controller)
> > > > >
> > > > > This is why I wanted a single macro (CONFIG_USB_DEVTREE_FIXUP)
> > > > > for invocation of fdt_fixup_dr_usb() from all platforms. One
> > > > > macro --> one feature
> > > >
> > > > That'd be fine, but you're adding ifdefs all around the place and
> > > > that is not fine. You can solve this without ifdefs too, for
> > > > example by having a __weak empty version of the function where
> applicable.
> > >
> > > Ok, so you're suggesting me to have multiple definitions of this
> > > function...the function Itself being  __weak...one for ehci and
> > > another for xhci. In this case, we'll be having problem with boards
> > > of an soc having both ehci and xhci controller...then how do we
> > > handle that situation?
> >
> > I only see one implementation of fdt_fixup_dr_usb(blob, bd); being
> > invoked throughout this patch. Where are these "multiple"
> implementations ?
> The only implementation right now was in drivers/usb/host/ehci-fsl.c which I
> moved to boards/freescale/common/usb.c This was done so as not to have
> another definition of this function in drivers/usb/host/xhci-fsl.c.
Hi Marek...a kind reminder for the above discussion...please let me know if you're
ok with the above patch or shall I resend the patch with #defines removed. Please suggest.



More information about the U-Boot mailing list