1. 04 Jan, 2019 1 commit
    • Antonio Nino Diaz's avatar
      Sanitise includes across codebase · 09d40e0e
      Antonio Nino Diaz authored
      Enforce full include path for includes. Deprecate old paths.
      
      The following folders inside include/lib have been left unchanged:
      
      - include/lib/cpus/${ARCH}
      - include/lib/el3_runtime/${ARCH}
      
      The reason for this change is that having a global namespace for
      includes isn't a good idea. It defeats one of the advantages of having
      folders and it introduces problems that are sometimes subtle (because
      you may not know the header you are actually including if there are two
      of them).
      
      For example, this patch had to be created because two headers were
      called the same way: e0ea0928 ("Fix gpio includes of mt8173 platform
      to avoid collision."). More recently, this patch has had similar
      problems: 46f9b2c3 ("drivers: add tzc380 support").
      
      This problem was introduced in commit 4ecca339
      
       ("Move include and
      source files to logical locations"). At that time, there weren't too
      many headers so it wasn't a real issue. However, time has shown that
      this creates problems.
      
      Platforms that want to preserve the way they include headers may add the
      removed paths to PLAT_INCLUDES, but this is discouraged.
      
      Change-Id: I39dc53ed98f9e297a5966e723d1936d6ccf2fc8f
      Signed-off-by: default avatarAntonio Nino Diaz <antonio.ninodiaz@arm.com>
      09d40e0e
  2. 04 Sep, 2018 1 commit
    • Bryan O'Donoghue's avatar
      imx: imx_io_mux: Define an IO-mux layer · 965bda4d
      Bryan O'Donoghue authored
      
      
      This patch defines:
      
      - The full range of IO-mux register offsets relative to the base address of
        the IO-mux block base address.
      
      - The bits for muxing the UART1 TX/RX lines.
      
      - The bits for muxing the UART6 TX/RX lines.
      
      - The pad control pad bits for the UART
      
      Two functions are provided to configure pad muxes:
      
      - void io_muxc_set_pad_alt_function(pad_mux_offset, alt_function)
        Takes a pad_mux_offset and sets the alt_function bit-mask supplied.
        This will have the effect of switching the pad into one of its defined
        peripheral functions. These peripheral function modes are defined in the
        NXP documentation and need to be referred to in order to correctly
        configure a new alternative-function.
      
      - void io_muxc_set_pad_features(pad_feature_offset, pad_features)
        Takes a pad_feature_offset and applies a pad_features bit-mask to the
        indicated pad.
        This function allows the setting of PAD drive-strength, pull-up values,
        hysteresis glitch filters and slew-rate settings.
      Signed-off-by: default avatarBryan O'Donoghue <bryan.odonoghue@linaro.org>
      965bda4d