Re: [PATCH] include/asm-generic/io.h: add dummy fuctions to support 'COMPILE_TEST' in 'asm-generic'.

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



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




[Index of Archives]     [Linux Kernel]     [Kernel Newbies]     [x86 Platform Driver]     [Netdev]     [Linux Wireless]     [Netfilter]     [Bugtraq]     [Linux Filesystems]     [Yosemite Discussion]     [MIPS Linux]     [ARM Linux]     [Linux Security]     [Linux RAID]     [Samba]     [Device Mapper]

  Powered by Linux