On Fri, Jul 05, 2013 at 08:03:31AM +0800, Chen Gang F T wrote: > On 07/04/2013 05:25 PM, Arnd Bergmann wrote: > > On Thursday 04 July 2013, Chen Gang wrote: > > > >> > --------------------------patch begin---------------------------------- > >> > > >> > 'asm-generic' need provide necessary configuration checking, if can't > >> > pass checking, 'asm-generic' shouldn't implement it. > >> > > >> > For 'COMPILE_TEST', according to its help contents, 'asm-generic' need > >> > let it pass configuration checking, and provide related dummy contents > >> > for it. > >> > > >> > Part of 'COMPLE_TEST' help contents in "init/Kconfig": > >> > > >> > "...Despite they cannot be loaded there (or even when they load they cannot be used due to missing HW support)..." > >> > > >> > One sample for using 'COMPILE_TEST': > >> > > >> > 'PTP_1588_CLOCK_PCH' in drivers/ptp/Kconfig, which need depend on 'HAS_IOMEM'. > > Then please submit a patch that adds the 'depends on HAS_IOMEM' line there. > > That line was clearly left out by accident. > > > > Yes, I will send the related patch for it (I have sent one, but that > seems incorrect, I will send patch v2 for that, after this patch > finishes discussing). > > But excluding 'PTP_1588_CLOCK_PCH' own issue, it is as a sample for our > discussion (If "COMPILE_TEST=y", it should can be compiled under the > archs which no 'HAS_IOMEM'). > > > >> > Signed-off-by: Chen Gang <gang.chen@xxxxxxxxxxx> > >> > --- > >> > include/asm-generic/io.h | 22 ++++++++++++++++++---- > >> > 1 files changed, 18 insertions(+), 4 deletions(-) > >> > > >> > diff --git a/include/asm-generic/io.h b/include/asm-generic/io.h > >> > index d5afe96..301ce80 100644 > >> > --- a/include/asm-generic/io.h > >> > +++ b/include/asm-generic/io.h > >> > @@ -303,13 +303,18 @@ static inline void *phys_to_virt(unsigned long address) > >> > /* > >> > * Change "struct page" to physical address. > >> > * > >> > - * This implementation is for the no-MMU case only... if you have an MMU > >> > - * you'll need to provide your own definitions. > >> > + * This for the no-MMU, or no-IOMEM but still try to COMPILE_TEST cases. > >> > + * if you have an MMU and IOMEM, you'll need to provide your own definitions. > >> > */ > >> > -#ifndef CONFIG_MMU > >> > +#if !defined(CONFIG_MMU) || \ > >> > + (!defined(CONFIG_HAS_IOMEM) && defined(CONFIG_COMPILE_TEST)) > >> > static inline void __iomem *ioremap(phys_addr_t offset, unsigned long size) > >> > { > >> > +#if !defined(CONFIG_MMU) > >> > return (void __iomem*) (unsigned long)offset; > >> > +#else > >> > + return NULL; > >> > +#endif > >> > } > >> > > >> > #define __ioremap(offset, size, flags) ioremap(offset, size) > > This is wrong for multiple reasons, all of which have been discussed in > > this thread before. > > Hmm..., COMPILE_TEST has integrated into 3.11 (at least can be found in > next tree). > > When a module select "COMPILE_TEST=y" (e.g with allmodconfig), it has > right to compile under the architecture which no related HW support. That is not true at all, and is not what COMPILE_TEST means. > If it can not pass compiling, at least it is not the module's issue, > neither the architecture's issue. What? > We have to look for who has duty on it. At least now, it seems only > 'asm-generic' can be qualified to play this unlucky role. Huh? Look, asm-generic is not what you think it is it seems, nor is COMPILE_TEST, which has caused this whole mess of a thread. Please start over, learn what asm-generic is there for, and used for today. Same goes for COMPILE_TEST. I'm done with this thread, it's madness... greg k-h -- To unsubscribe from this list: send the line "unsubscribe linux-arch" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html