MIPS: Remove "weak" from mips_cdmm_phys_base() declaration

Weak header file declarations are error-prone because they make every
definition weak, and the linker chooses one based on link order (see
10629d711e ("PCI: Remove __weak annotation from pcibios_get_phb_of_node
decl")).

mips_cdmm_phys_base() is defined only in arch/mips/mti-malta/malta-memory.c
so there's no problem with multiple definitions.  But it works better to
have a weak default implementation and allow a strong function to override
it.  Then we don't have to test whether a definition is present, and if
there are ever multiple strong definitions, we get a link error instead of
calling a random definition.

Add a weak mips_cdmm_phys_base() definition and remove the weak annotation
from the declaration in arch/mips/include/asm/cdmm.h.

Signed-off-by: Bjorn Helgaas <bhelgaas@google.com>
Reviewed-by: James Hogan <james.hogan@imgtec.com>
Cc: Andrew Bresticker <abrestic@chromium.org>
Cc: linux-mips@linux-mips.org
Cc: linux-kernel@vger.kernel.org
Patchwork: https://patchwork.linux-mips.org/patch/10688/
Signed-off-by: Ralf Baechle <ralf@linux-mips.org>
This commit is contained in:
Bjorn Helgaas 2015-07-12 18:11:54 -05:00 committed by Ralf Baechle
parent 770847bad0
commit e1d9749730
2 changed files with 15 additions and 3 deletions

View File

@ -53,7 +53,7 @@ struct mips_cdmm_driver {
* mips_cdmm_phys_base() - Choose a physical base address for CDMM region. * mips_cdmm_phys_base() - Choose a physical base address for CDMM region.
* *
* Picking a suitable physical address at which to map the CDMM region is * Picking a suitable physical address at which to map the CDMM region is
* platform specific, so this weak function can be defined by platform code to * platform specific, so this function can be defined by platform code to
* pick a suitable value if none is configured by the bootloader. * pick a suitable value if none is configured by the bootloader.
* *
* This address must be 32kB aligned, and the region occupies a maximum of 32kB * This address must be 32kB aligned, and the region occupies a maximum of 32kB
@ -61,7 +61,7 @@ struct mips_cdmm_driver {
* *
* Returns: Physical base address for CDMM region, or 0 on failure. * Returns: Physical base address for CDMM region, or 0 on failure.
*/ */
phys_addr_t __weak mips_cdmm_phys_base(void); phys_addr_t mips_cdmm_phys_base(void);
extern struct bus_type mips_cdmm_bustype; extern struct bus_type mips_cdmm_bustype;
void __iomem *mips_cdmm_early_probe(unsigned int dev_type); void __iomem *mips_cdmm_early_probe(unsigned int dev_type);

View File

@ -331,6 +331,18 @@ static phys_addr_t mips_cdmm_cur_base(void)
<< MIPS_CDMMBASE_ADDR_START; << MIPS_CDMMBASE_ADDR_START;
} }
/**
* mips_cdmm_phys_base() - Choose a physical base address for CDMM region.
*
* Picking a suitable physical address at which to map the CDMM region is
* platform specific, so this weak function can be overridden by platform
* code to pick a suitable value if none is configured by the bootloader.
*/
phys_addr_t __weak mips_cdmm_phys_base(void)
{
return 0;
}
/** /**
* mips_cdmm_setup() - Ensure the CDMM bus is initialised and usable. * mips_cdmm_setup() - Ensure the CDMM bus is initialised and usable.
* @bus: Pointer to bus information for current CPU. * @bus: Pointer to bus information for current CPU.
@ -368,7 +380,7 @@ static int mips_cdmm_setup(struct mips_cdmm_bus *bus)
if (!bus->phys) if (!bus->phys)
bus->phys = mips_cdmm_cur_base(); bus->phys = mips_cdmm_cur_base();
/* Otherwise, ask platform code for suggestions */ /* Otherwise, ask platform code for suggestions */
if (!bus->phys && mips_cdmm_phys_base) if (!bus->phys)
bus->phys = mips_cdmm_phys_base(); bus->phys = mips_cdmm_phys_base();
/* Otherwise, copy what other CPUs have done */ /* Otherwise, copy what other CPUs have done */
if (!bus->phys) if (!bus->phys)