[U-Boot] [PATCH v4 4/4]: arm: Define test_and_set_bit and test_and_clear bit for ARM

Justin Waters justin.waters at timesys.com
Fri Sep 4 23:27:59 CEST 2009


Simon,

I found a slight problem with this section of the patch:

On Mon, 2009-08-24 at 03:10 -0400, Simon Kagstrom wrote:
> diff --git a/include/asm-arm/bitops.h b/include/asm-arm/bitops.h
> index 854e225..3c7b00c 100644
> --- a/include/asm-arm/bitops.h
> +++ b/include/asm-arm/bitops.h
> @@ -17,6 +17,8 @@
>  
>  #ifdef __KERNEL__
>  
> +#include <asm/proc/system.h>
> +

It causes a compiler error on the arm926ejs platform:

  In file included from cpu.c:34:
  /home/justin/git/u-boot/include/asm/system.h: At top level:
  /home/justin/git/u-boot/include/asm/system.h:71: error: expected
identifier or '(' before 'asm'

I did some digging, and it looks like set_cr() is implemented by both
asm-arm/system.h and asm-arm/proc-armv/system.h.  One implements the
function as a macro, while the other uses a standard C function, hence
the weird error message.  The conflict occurs in cpu/arm926ejs/cpu.c.  

* cpu.c includes both common.h and asm/system.h
* common.h includes asm/bitops.h, which now includes asm/proc/system.h

There are a few other values that are defined in both files, although
they don't seem to cause any problems.

If I comment out one of the two implementations, the code compiles fine.
However, I'm not really sure what the correct fix would be.  I just
wanted to let you know.

-Justin Waters



More information about the U-Boot mailing list